:root {
    --gc-bg: #f4f7fb;
    --gc-surface: #ffffff;
    --gc-surface-soft: #f8fafc;
    --gc-text: #0f172a;
    --gc-muted: #64748b;
    --gc-primary: #2563eb;
    --gc-primary-strong: #1d4ed8;
    --gc-border: #e2e8f0;
    --gc-shadow-soft: 0 12px 30px rgba(15, 23, 42, 0.06);
    --gc-shadow-hover: 0 18px 40px rgba(15, 23, 42, 0.1);
    --gc-radius: 20px;
}

body {
    background:
        radial-gradient(1000px 360px at 95% -80px, rgba(37, 99, 235, 0.12), transparent 70%),
        linear-gradient(180deg, #f8fbff 0%, var(--gc-bg) 100%);
    color: var(--gc-text);
}

a {
    text-underline-offset: 3px;
}

.footer-link {
    color: #475569;
    text-decoration: none;
}

.footer-link:hover {
    color: var(--gc-primary-strong);
}

.gc-page {
    padding: 1.1rem 0 2.8rem;
}

.gc-home-slider-wrap {
    padding-top: 1rem;
}

.gc-home-slider {
    border-radius: calc(var(--gc-radius) + 4px);
    border: 1px solid var(--gc-border);
    background: #fff;
    box-shadow: var(--gc-shadow-soft);
    overflow: hidden;
}

.gc-home-slide {
    min-height: 430px;
    display: flex;
    align-items: center;
}

.gc-home-slide--mint {
    background: linear-gradient(135deg, #ecfeff 0%, #dbeafe 100%);
}

.gc-home-slide--sky {
    background: linear-gradient(135deg, #eff6ff 0%, #dcfce7 100%);
}

.gc-home-slide--amber {
    background: linear-gradient(135deg, #fff7ed 0%, #fef3c7 100%);
}

.gc-home-slide__content {
    color: var(--gc-text);
}

.gc-home-slide__badge {
    display: inline-flex;
    align-items: center;
    border: 1px solid #bfdbfe;
    border-radius: 999px;
    background: #ffffffcc;
    color: #1e3a8a;
    padding: 0.3rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 700;
}

.gc-home-slide h1,
.gc-home-slide h2 {
    margin: 0.8rem 0 0.55rem;
    color: #0f172a;
    font-size: clamp(1.35rem, 1.3vw + 1rem, 2.3rem);
    line-height: 1.38;
    font-weight: 800;
}

.gc-home-slide p {
    margin: 0;
    color: #334155;
    max-width: 64ch;
    line-height: 1.9;
}

.gc-home-slide__visual {
    border-radius: 24px;
    border: 1px solid #dbeafe;
    background: #ffffffea;
    box-shadow: 0 18px 34px rgba(37, 99, 235, 0.14);
    padding: 0.85rem;
    display: grid;
    place-items: center;
}

.gc-home-slide__visual svg {
    width: 100%;
    max-width: 340px;
    height: auto;
}

.gc-home-actions {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.gc-home-slider .carousel-indicators {
    margin-bottom: 0.7rem;
}

.gc-home-slider .carousel-indicators [data-bs-target] {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 0;
    background: #94a3b8;
}

.gc-home-slider .carousel-indicators .active {
    background: var(--gc-primary);
}

.gc-home-slider .carousel-control-prev,
.gc-home-slider .carousel-control-next {
    width: 48px;
    opacity: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gc-home-slider .carousel-control-prev i,
.gc-home-slider .carousel-control-next i {
    width: 2.15rem;
    height: 2.15rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 1.45rem;
    color: #1d4ed8;
    background-color: #ffffffd9;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.15);
}

.gc-page-hero {
    padding-top: 1rem;
}

.gc-page-hero__surface {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--gc-border);
    border-radius: calc(var(--gc-radius) + 2px);
    background: #fff;
    box-shadow: var(--gc-shadow-soft);
    padding: 1.15rem;
}

.gc-page-hero__surface::before {
    content: "";
    position: absolute;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    top: -170px;
    inset-inline-end: -120px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.15), transparent 70%);
    pointer-events: none;
}

.gc-page-hero__kicker {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #eff6ff;
    color: #1e3a8a;
    padding: 0.32rem 0.8rem;
    font-size: 0.8rem;
    font-weight: 700;
}

.gc-page-hero__title {
    position: relative;
    z-index: 1;
    margin: 0.75rem 0 0.45rem;
    font-size: clamp(1.3rem, 1.2vw + 1rem, 2rem);
    font-weight: 800;
    line-height: 1.45;
}

.gc-page-hero__desc {
    position: relative;
    z-index: 1;
    margin: 0;
    max-width: 72ch;
    color: #475569;
}

.gc-page-hero__actions {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-top: 0.95rem;
}

.gc-page-hero__stats {
    position: relative;
    z-index: 1;
    margin-top: 1rem;
    display: grid;
    gap: 0.55rem;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}

.gc-page-hero__stat {
    border: 1px solid #dbeafe;
    background: #f8fbff;
    border-radius: 14px;
    padding: 0.5rem 0.7rem;
    display: flex;
    flex-direction: column;
}

.gc-page-hero__stat-value {
    font-weight: 800;
    color: #0f172a;
}

.gc-page-hero__stat-label {
    font-size: 0.8rem;
    color: #64748b;
}

.gc-section-surface {
    background: var(--gc-surface);
    border: 1px solid var(--gc-border);
    border-radius: var(--gc-radius);
    box-shadow: var(--gc-shadow-soft);
    padding: 1rem;
}

.gc-section-head {
    margin-bottom: 1rem;
}

.gc-section-head__title {
    margin: 0;
    color: #0f172a;
    font-size: clamp(1.05rem, 0.45vw + 1rem, 1.3rem);
    font-weight: 800;
}

.gc-section-head__desc {
    margin: 0.32rem 0 0;
    color: var(--gc-muted);
    font-size: 0.89rem;
}

.gc-empty-state {
    border: 1px dashed var(--gc-border);
    background: var(--gc-surface-soft);
    border-radius: 16px;
    text-align: center;
    padding: 1.1rem;
}

.gc-empty-state__icon {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 50%;
    display: inline-grid;
    place-items: center;
    background: #dbeafe;
    color: #1d4ed8;
    font-weight: 800;
}

.gc-empty-state__title {
    margin: 0.6rem 0 0.22rem;
    font-size: 1rem;
    font-weight: 700;
}

.gc-empty-state__desc {
    margin: 0;
    color: var(--gc-muted);
    font-size: 0.88rem;
}

.gc-topbar {
    border-bottom: 1px solid var(--gc-border);
    background: #ffffff;
}

.gc-topbar__inner {
    min-height: 46px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.gc-topbar__links {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.gc-topbar__links a {
    color: #475569;
    text-decoration: none;
    font-size: 0.82rem;
}

.gc-topbar__links a:hover {
    color: var(--gc-primary-strong);
}

.gc-topbar__auth {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin-inline-start: auto;
}

.gc-btn-light {
    border-radius: 999px;
    border: 1px solid #bfdbfe;
    background: #eff6ff;
    color: #1e3a8a;
    padding-inline: 0.9rem;
}

.gc-btn-light:hover {
    background: #dbeafe;
    color: #1e3a8a;
}

.gc-btn-outline {
    border-radius: 999px;
    border: 1px solid var(--gc-border);
    background: #fff;
    color: #1e293b;
    padding-inline: 0.9rem;
}

.gc-btn-outline:hover {
    border-color: #cbd5e1;
    color: #0f172a;
}

.gc-navbar-wrap {
    position: sticky;
    top: 0;
    z-index: 1028;
    border-bottom: 1px solid var(--gc-border);
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
}

.gc-navbar {
    min-height: 68px;
}

.gc-navbar .navbar-toggler {
    color: #334155;
}

.gc-navbar .nav-link {
    color: #334155;
    font-weight: 700;
    border-radius: 999px;
    padding: 0.45rem 0.82rem;
}

.gc-navbar .nav-link:hover {
    color: var(--gc-primary-strong);
    background: #eff6ff;
}

.gc-navbar .nav-link.active {
    color: #1d4ed8;
    background: #dbeafe;
}

.gc-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
}

.gc-logo__mark {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 10px 22px rgba(37, 99, 235, 0.2);
}

.gc-logo__text {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
}

.gc-logo__title {
    color: #0f172a;
    font-size: 0.95rem;
    font-weight: 800;
}

.gc-logo__sub {
    color: #64748b;
    font-size: 0.72rem;
}

.gc-bottom-nav {
    position: fixed;
    inset-inline: 0;
    bottom: 0;
    z-index: 1035;
    background: #ffffffee;
    border-top: 1px solid var(--gc-border);
    box-shadow: 0 -8px 20px rgba(15, 23, 42, 0.08);
    backdrop-filter: blur(8px);
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.gc-bottom-nav__item {
    min-height: 58px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.1rem;
    color: #334155;
    text-decoration: none;
    font-weight: 700;
    font-size: 0.73rem;
}

.gc-bottom-nav__item i {
    font-size: 1.15rem;
    line-height: 1;
}

.gc-bottom-nav__item.is-active {
    background: #eff6ff;
    color: #1d4ed8;
}

.gc-card-grid {
    row-gap: 1rem;
}

.complex-card,
.mag-card,
.team-card {
    background: var(--gc-surface);
    border: 1px solid var(--gc-border);
    border-radius: 18px;
    box-shadow: var(--gc-shadow-soft);
    overflow: hidden;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.complex-card:hover,
.mag-card:hover,
.team-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--gc-shadow-hover);
}

.complex-card__media-wrap {
    position: relative;
}

.complex-card__media {
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #e2e8f0;
}

.complex-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.complex-card__placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #64748b;
    background: linear-gradient(180deg, #f8fafc, #e2e8f0);
}

.complex-card:hover .complex-card__media img {
    transform: scale(1.04);
}

.complex-card__badges {
    position: absolute;
    top: 0.65rem;
    inset-inline-start: 0.65rem;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    z-index: 2;
}

.chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.2rem;
    border-radius: 999px;
    padding: 0.2rem 0.55rem;
    font-size: 0.74rem;
    line-height: 1;
    border: 1px solid var(--gc-border);
    background: #fff;
    color: #334155;
    white-space: nowrap;
}

.chip--floating {
    border-color: #cbd5e1;
    background: #ffffffeb;
    font-weight: 700;
}

.chip--soft {
    border-color: #dbeafe;
    background: #f8fbff;
    color: #475569;
}

.chip--light {
    border-color: #e2e8f0;
    background: #f8fafc;
    color: #475569;
}

.chip--open {
    color: #166534;
    border-color: #bbf7d0;
    background: #f0fdf4;
}

.chip--closed {
    color: #9f1239;
    border-color: #fecdd3;
    background: #fff1f2;
}

.complex-card__body {
    padding: 0.95rem 1rem 1rem;
}

.complex-card__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-bottom: 0.55rem;
}

.complex-card__likes {
    margin-inline-start: auto;
    color: #dc2626;
}

.complex-card__likes .d-flex {
    align-items: center;
    gap: 0.15rem;
}

.complex-card__likes box-icon {
    cursor: pointer;
}

.complex-card__title-link {
    color: inherit;
}

.complex-card__title {
    margin: 0;
    color: #0f172a;
    font-size: 1.06rem;
    font-weight: 800;
    line-height: 1.5;
}

.complex-card__excerpt {
    margin: 0.42rem 0 0;
    color: #64748b;
    font-size: 0.86rem;
    line-height: 1.8;
}

.text-truncate-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mag-media-wrap {
    position: relative;
}

.mag-media {
    aspect-ratio: 16/9;
    overflow: hidden;
    background: #e2e8f0;
}

.mag-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.mag-media__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.08), rgba(15, 23, 42, 0.52));
}

.mag-media__placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    color: #64748b;
    background: linear-gradient(180deg, #f8fafc, #e2e8f0);
}

.mag-card:hover .mag-media img {
    transform: scale(1.04);
}

.mag-badge {
    position: absolute;
    top: 0.65rem;
    inset-inline-start: 0.65rem;
    z-index: 2;
    border-radius: 999px;
    background: #fef3c7;
    color: #92400e;
    padding: 0.25rem 0.55rem;
    font-size: 0.72rem;
    font-weight: 800;
}

.mag-content {
    padding: 0.85rem 0.95rem 1rem;
}

.mag-content__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.55rem;
    flex-wrap: wrap;
    margin-bottom: 0.5rem;
}

.mag-content__meta small {
    color: #64748b;
    font-size: 0.78rem;
}

.mag-title {
    margin: 0;
    font-size: 1.02rem;
    font-weight: 800;
    line-height: 1.52;
    color: #0f172a;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mag-kicker {
    color: #64748b;
    font-size: 0.8rem;
}

.mag-excerpt {
    margin: 0.42rem 0 0;
    color: #64748b;
    font-size: 0.86rem;
    line-height: 1.75;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mag-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.65rem;
}

.mag-read-more {
    margin-top: 0.72rem;
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: var(--gc-primary-strong);
    font-size: 0.86rem;
    font-weight: 700;
}

.mag-read-more:hover {
    color: #1e3a8a;
}

.mag-card--placeholder,
.team-card--light {
    background: #fff;
}

.gc-mag-featured {
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid var(--gc-border);
    box-shadow: var(--gc-shadow-soft);
}

.gc-mag-featured__slide {
    position: relative;
    min-height: 310px;
    display: block;
}

.gc-mag-featured__slide img {
    width: 100%;
    height: 310px;
    object-fit: cover;
}

.gc-mag-featured__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.08), rgba(15, 23, 42, 0.72));
}

.gc-mag-featured__content {
    position: absolute;
    inset-inline: 0;
    bottom: 0;
    z-index: 2;
    padding: 1rem;
    color: #f8fafc;
}

.gc-mag-featured__content h2 {
    margin: 0.6rem 0 0.32rem;
    font-size: clamp(1rem, 0.9vw + 0.9rem, 1.4rem);
    font-weight: 800;
    line-height: 1.45;
}

.gc-mag-featured__content p {
    margin: 0;
    font-size: 0.86rem;
    color: rgba(248, 250, 252, 0.92);
}

.gc-mag-featured .carousel-indicators {
    margin-bottom: 0.38rem;
}

.gc-mag-featured .carousel-indicators [data-bs-target] {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 0;
}

.team-card {
    text-align: center;
    padding: 0.95rem;
}

.gc-team-lead {
    height: 100%;
    border: 1px solid #bfdbfe;
    border-radius: 15px;
    background: linear-gradient(130deg, #eff6ff, #dbeafe);
    color: #1e3a8a;
    padding: 1rem;
    box-shadow: var(--gc-shadow-soft);
}

.gc-team-lead h3 {
    margin: 0 0 0.2rem;
    font-size: 1.08rem;
    font-weight: 800;
}

.gc-team-lead span {
    font-size: 0.83rem;
}

.gc-team-lead p {
    margin: 0.56rem 0 0;
    color: #334155;
    font-size: 0.86rem;
}

.team-avatar {
    margin-inline: auto;
    width: 88px;
    height: 88px;
    position: relative;
}

.team-avatar__ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: linear-gradient(140deg, #93c5fd, #3b82f6);
    opacity: 0.22;
}

.team-avatar__img {
    position: absolute;
    inset: 6px;
    border-radius: 50%;
    overflow: hidden;
    display: grid;
    place-items: center;
    background: #f1f5f9;
    color: #64748b;
}

.team-avatar__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.team-name {
    margin: 0.66rem 0 0.2rem;
    font-size: 1rem;
    font-weight: 800;
}

.team-role {
    color: #64748b;
    font-size: 0.83rem;
}

.social-btn {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid var(--gc-border);
    background: #fff;
    color: #334155;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.social-btn:hover {
    color: var(--gc-primary-strong);
    border-color: #bfdbfe;
}

.gc-contact-item {
    background: #fff;
    border: 1px solid var(--gc-border);
    border-radius: 14px;
    padding: 0.78rem 0.9rem;
}

.gc-contact-item__label {
    display: block;
    margin-bottom: 0.2rem;
    color: var(--gc-muted);
    font-size: 0.8rem;
}

.gc-contact-item__value {
    color: #0f172a;
    font-weight: 700;
    text-decoration: none;
}

.gc-article-hero {
    position: relative;
    overflow: hidden;
}

.gc-article-hero__shape {
    position: absolute;
    inset-inline: 0;
    top: 0;
    width: 100%;
    height: 130px;
    fill: rgba(37, 99, 235, 0.12);
    z-index: 0;
}

.gc-article-hero .row,
.gc-article-hero .d-flex {
    position: relative;
    z-index: 1;
}

.gc-related-link {
    height: 100%;
    border: 1px solid var(--gc-border);
    border-radius: 14px;
    background: #fff;
    padding: 0.85rem 0.9rem;
    box-shadow: var(--gc-shadow-soft);
    color: #0f172a;
}

.gc-related-link:hover {
    transform: translateY(-2px);
    box-shadow: var(--gc-shadow-hover);
}

.gc-related-link h3 {
    margin: 0 0 0.45rem;
    font-size: 1rem;
    line-height: 1.45;
    font-weight: 700;
}

.gc-related-link p {
    margin: 0;
    color: var(--gc-muted);
    font-size: 0.85rem;
}

.gc-mini-stat {
    border: 1px solid var(--gc-border);
    border-radius: 12px;
    background: #fff;
    padding: 0.55rem 0.65rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.gc-mini-stat span {
    color: var(--gc-muted);
    font-size: 0.8rem;
}

.gc-mini-stat strong {
    color: #0f172a;
    font-size: 0.86rem;
    font-weight: 800;
}

.gc-section-surface .accordion-item {
    border-color: var(--gc-border);
}

.gc-section-surface .accordion-button {
    font-weight: 700;
}

.gc-about-timeline {
    position: relative;
}

.gc-about-timeline__line {
    width: 100%;
    height: 74px;
    fill: none;
    stroke: rgba(37, 99, 235, 0.28);
    stroke-width: 3;
    margin-bottom: 0.35rem;
}

.gc-about-step {
    height: 100%;
    border: 1px solid var(--gc-border);
    border-radius: 14px;
    background: #fff;
    padding: 0.85rem;
}

.gc-about-step span {
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 50%;
    display: inline-grid;
    place-items: center;
    background: #dbeafe;
    color: #1d4ed8;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.gc-about-step h3 {
    margin: 0 0 0.35rem;
    font-size: 1rem;
    font-weight: 700;
}

.gc-about-step p {
    margin: 0;
    color: var(--gc-muted);
    font-size: 0.86rem;
}

.gc-home-grid .gc-about-tile {
    background: #fff;
    border: 1px solid var(--gc-border);
    border-radius: 14px;
    padding: 0.95rem;
    height: 100%;
}

.gc-home-grid h3 {
    margin: 0 0 0.4rem;
    font-size: 1rem;
    font-weight: 700;
}

.gc-home-grid p {
    margin: 0;
    color: var(--gc-muted);
    font-size: 0.88rem;
}

.gc-page--home {
    padding-top: 0.35rem;
}

.gc-home-vivid-stats {
    padding-top: 1rem;
}

.gc-vivid-card {
    position: relative;
    overflow: hidden;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.35);
    padding: 1rem;
    color: #fff;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.18);
    min-height: 176px;
}

.gc-vivid-card::after {
    content: "";
    position: absolute;
    width: 130px;
    height: 130px;
    border-radius: 50%;
    inset-inline-end: -45px;
    top: -38px;
    background: rgba(255, 255, 255, 0.17);
}

.gc-vivid-card--blue {
    background: linear-gradient(140deg, #2563eb 0%, #0891b2 100%);
}

.gc-vivid-card--teal {
    background: linear-gradient(140deg, #0d9488 0%, #22c55e 100%);
}

.gc-vivid-card--violet {
    background: linear-gradient(140deg, #7c3aed 0%, #ec4899 100%);
}

.gc-vivid-card--amber {
    background: linear-gradient(140deg, #d97706 0%, #ef4444 100%);
}

.gc-vivid-card__icon {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 12px;
    display: inline-grid;
    place-items: center;
    background: rgba(255, 255, 255, 0.22);
    font-size: 1.15rem;
}

.gc-vivid-card__label {
    display: block;
    margin-top: 0.7rem;
    font-size: 0.86rem;
    opacity: 0.95;
}

.gc-vivid-card__value {
    display: block;
    margin-top: 0.25rem;
    font-size: 1.7rem;
    font-weight: 900;
    letter-spacing: 0.02em;
}

.gc-vivid-card p {
    margin: 0.45rem 0 0;
    font-size: 0.84rem;
    line-height: 1.75;
    opacity: 0.95;
}

.gc-home-city-section {
    padding: 0.35rem 0 0.9rem;
}

.gc-home-city-shell {
    position: relative;
    overflow: hidden;
}

.gc-home-city-shell::before {
    content: "";
    position: absolute;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    inset-inline-start: -92px;
    top: -92px;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.16), transparent 72%);
    pointer-events: none;
}

.gc-home-city-search-card {
    position: relative;
    border: 1px solid #dbeafe;
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    box-shadow: var(--gc-shadow-soft);
    padding: 0.9rem;
}

.gc-home-city-side {
    height: 100%;
    border: 1px solid #bfdbfe;
    border-radius: 16px;
    background: linear-gradient(160deg, #eff6ff 0%, #dbeafe 100%);
    padding: 1rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0.8rem;
}

.gc-home-city-side h3 {
    margin: 0;
    font-size: 1rem;
    color: #0f172a;
    font-weight: 800;
}

.gc-home-city-side p {
    margin: 0;
    color: #334155;
    font-size: 0.87rem;
    line-height: 1.8;
}

.gc-city-search__label {
    display: block;
    margin-bottom: 0.55rem;
    color: #0f172a;
    font-size: 0.88rem;
    font-weight: 700;
}

.gc-city-search__input-wrap {
    position: relative;
}

.gc-city-search__icon {
    position: absolute;
    top: 50%;
    inset-inline-start: 0.78rem;
    transform: translateY(-50%);
    color: #64748b;
    font-size: 1.15rem;
    pointer-events: none;
}

.gc-city-search__input {
    border-radius: 12px;
    border-color: #cbd5e1;
    padding-inline-start: 2.45rem;
    min-height: 48px;
    font-size: 0.92rem;
}

.gc-city-search__input:focus {
    border-color: #60a5fa;
    box-shadow: 0 0 0 0.2rem rgba(59, 130, 246, 0.16);
}

.gc-city-search__results {
    margin-top: 0.55rem !important;
    border: 1px solid var(--gc-border);
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
}

.gc-city-search__option {
    width: 100%;
    border: 0;
    border-bottom: 1px solid #eef2f7;
    background: #fff;
    color: #0f172a;
    min-height: 42px;
    padding: 0.5rem 0.8rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 600;
    text-align: right;
}

.gc-city-search__results li:last-child .gc-city-search__option {
    border-bottom: 0;
}

.gc-city-search__option:hover {
    background: #eff6ff;
    color: #1d4ed8;
}

.gc-city-search__error {
    margin-top: 0.4rem;
    color: #dc2626;
    font-size: 0.8rem;
    display: inline-block;
}

.gc-city-search__empty {
    margin-top: 0.55rem;
    border: 1px dashed #cbd5e1;
    border-radius: 10px;
    padding: 0.55rem 0.7rem;
    color: #64748b;
    font-size: 0.82rem;
}

.gc-home-types-section {
    padding: 0.2rem 0 0.9rem;
}

.gc-home-types-shell {
    position: relative;
    overflow: hidden;
}

.gc-home-types-shell::after {
    content: "";
    position: absolute;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    inset-inline-end: -92px;
    bottom: -120px;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.14), transparent 72%);
    pointer-events: none;
}

.gc-home-types-swiper {
    position: relative;
    padding: 0.2rem 0 1.3rem;
}

.gc-home-types-swiper .swiper-slide {
    height: auto;
    padding: 0.2rem 0.08rem 0.55rem;
}

.gc-home-type-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 140px;
    border-radius: 16px;
    background: var(--gc-type-bg);
    color: #ffffff;
    padding: 0.9rem;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.24);
    transition: transform 0.22s ease, box-shadow 0.22s ease, filter 0.22s ease;
}

.gc-home-type-tile::before {
    content: "";
    position: absolute;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    inset-inline-end: -54px;
    top: -58px;
    background: rgba(255, 255, 255, 0.18);
}

.gc-home-type-tile:hover {
    transform: translateY(-4px);
    filter: brightness(1.05);
    box-shadow: 0 18px 36px rgba(15, 23, 42, 0.22);
}

.gc-home-type-tile__icon {
    width: 2.45rem;
    height: 2.45rem;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.2);
    display: inline-grid;
    place-items: center;
}

.gc-home-type-tile__icon box-icon {
    width: 1.45rem;
    height: 1.45rem;
}

.gc-home-type-tile__title {
    margin-top: 0.65rem;
    font-size: 0.98rem;
    font-weight: 800;
}

.gc-home-type-tile__meta {
    margin-top: auto;
    font-size: 0.8rem;
    opacity: 0.95;
}

.gc-home-types__pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: 0;
}

.gc-home-types__pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 4px !important;
    background: #94a3b8;
    opacity: 0.45;
}

.gc-home-types__pagination .swiper-pagination-bullet-active {
    opacity: 1;
    background: #1d4ed8;
}

.gc-home-process {
    position: relative;
    overflow: hidden;
}

.gc-home-process::before {
    content: "";
    position: absolute;
    inset-inline-end: -75px;
    top: -75px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.12), transparent 72%);
    pointer-events: none;
}

.gc-process-card {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    border: 1px solid var(--gc-border);
    padding: 0.95rem 0.95rem 0.9rem;
    min-height: 152px;
    box-shadow: var(--gc-shadow-soft);
}

.gc-process-card__index {
    width: 1.85rem;
    height: 1.85rem;
    border-radius: 999px;
    display: inline-grid;
    place-items: center;
    font-size: 0.84rem;
    font-weight: 800;
    margin-bottom: 0.45rem;
}

.gc-process-card h3 {
    margin: 0 0 0.3rem;
    font-size: 1rem;
    font-weight: 800;
    color: #0f172a;
}

.gc-process-card p {
    margin: 0;
    color: #475569;
    font-size: 0.86rem;
    line-height: 1.75;
}

.gc-process-card--blue {
    background: linear-gradient(180deg, #f8fbff, #eef6ff);
}

.gc-process-card--blue .gc-process-card__index {
    background: #dbeafe;
    color: #1d4ed8;
}

.gc-process-card--teal {
    background: linear-gradient(180deg, #f0fdfa, #e6fffa);
}

.gc-process-card--teal .gc-process-card__index {
    background: #ccfbf1;
    color: #0f766e;
}

.gc-process-card--violet {
    background: linear-gradient(180deg, #faf5ff, #f5efff);
}

.gc-process-card--violet .gc-process-card__index {
    background: #ede9fe;
    color: #6d28d9;
}

.gc-home-slider-section {
    padding: 0.2rem 0 0.9rem;
}

.gc-home-slider-shell {
    position: relative;
    border: 1px solid var(--gc-border);
    border-radius: 22px;
    background: #fff;
    box-shadow: var(--gc-shadow-soft);
    padding: 1rem;
}

.gc-home-slider-shell::before {
    content: "";
    position: absolute;
    inset-inline-start: 1rem;
    inset-inline-end: 1rem;
    top: 0.52rem;
    height: 4px;
    border-radius: 999px;
    pointer-events: none;
}

.gc-home-slider-section--complex .gc-home-slider-shell::before {
    background: linear-gradient(90deg, #2563eb, #06b6d4);
}

.gc-home-slider-section--magazine .gc-home-slider-shell::before {
    background: linear-gradient(90deg, #0d9488, #22c55e);
}

.gc-home-slider-section--team .gc-home-slider-shell::before {
    background: linear-gradient(90deg, #7c3aed, #ec4899);
}

.gc-home-swiper {
    position: relative;
    padding: 0.15rem 0 1.6rem;
}

.gc-home-swiper-controls {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.45rem;
    margin-bottom: 0.45rem;
    position: relative;
    z-index: 4;
}

.gc-home-swiper .swiper-slide {
    height: auto;
    padding: 0.2rem 0.08rem 0.75rem;
}

.gc-home-swiper .swiper-slide > * {
    height: 100%;
}

.gc-home-swiper__pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: 0;
}

.gc-home-swiper__pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 4px !important;
    background: #94a3b8;
    opacity: 0.45;
}

.gc-home-swiper__pagination .swiper-pagination-bullet-active {
    opacity: 1;
    background: var(--gc-primary);
}

.gc-home-swiper .gc-home-swiper__prev,
.gc-home-swiper .gc-home-swiper__next {
    position: relative !important;
    inset: auto !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    transform: none !important;
    width: 36px;
    height: 36px;
    margin: 0 !important;
    border-radius: 50%;
    background: #ffffff;
    border: 1px solid #dbeafe;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
    color: #1d4ed8;
}

.gc-home-swiper .gc-home-swiper__prev::after,
.gc-home-swiper .gc-home-swiper__next::after {
    font-size: 0.95rem;
    font-weight: 800;
}

.gc-home-swiper .gc-home-swiper__prev.swiper-button-disabled,
.gc-home-swiper .gc-home-swiper__next.swiper-button-disabled {
    opacity: 0.35;
}

.gc-home-quick {
    margin-top: 0.8rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.gc-home-quick .chip {
    border-color: #bfdbfe;
    background: #eff6ff;
    color: #1e3a8a;
}

.gc-filter-panel {
    position: sticky;
    top: 82px;
}

.gc-results-head {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    padding: 0.95rem 1rem;
    border: 1px solid var(--gc-border);
    background: #fff;
    box-shadow: var(--gc-shadow-soft);
    display: flex;
    align-items: center;
    gap: 0.8rem;
    flex-wrap: wrap;
}

.gc-results-head::before {
    content: "";
    position: absolute;
    inset-block: 0;
    inset-inline-start: 0;
    width: 5px;
    background: linear-gradient(180deg, #2563eb, #16a34a);
}

.gc-results-head__shape {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    fill: rgba(37, 99, 235, 0.08);
}

.gc-results-head__content {
    position: relative;
    z-index: 1;
    padding-inline-start: 0.35rem;
}

.gc-results-head h2 {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
    color: #0f172a;
}

.gc-results-head p {
    margin: 0;
    color: #475569;
    font-size: 0.87rem;
}

.gc-pagination-wrap {
    display: flex;
    justify-content: center;
}

.gc-pagination-nav {
    width: 100%;
    max-width: 640px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    border: 1px solid var(--gc-border);
    background: #ffffff;
    border-radius: 16px;
    padding: 0.55rem 0.7rem;
    box-shadow: var(--gc-shadow-soft);
}

.gc-pagination-meta {
    color: #64748b;
    font-size: 0.83rem;
    white-space: nowrap;
}

.gc-pagination-list.pagination {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin: 0;
}

.gc-pagination-list .page-item {
    margin: 0 !important;
}

.gc-pagination-list .page-link {
    min-width: 2.15rem;
    height: 2.15rem;
    border-radius: 11px !important;
    border: 1px solid #dbeafe;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.56rem;
    color: #334155;
    font-weight: 700;
    background: #ffffff;
    text-decoration: none;
    box-shadow: none;
    transition: all 0.2s ease;
}

.gc-pagination-list .page-link i {
    font-size: 1.12rem;
    line-height: 1;
    pointer-events: none;
}

.gc-pagination-list .page-link:hover {
    border-color: #93c5fd;
    color: #1d4ed8;
    background: #eff6ff;
}

.gc-pagination-list .page-item.active .page-link {
    color: #ffffff;
    border-color: transparent;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 8px 20px rgba(37, 99, 235, 0.28);
}

.gc-pagination-list .page-item.disabled .page-link {
    color: #94a3b8;
    background: #f8fafc;
    border-color: #e2e8f0;
    opacity: 1;
}

@media (max-width: 991.98px) {
    body {
        padding-bottom: 62px;
    }

    .gc-topbar__links a:last-child {
        display: none;
    }

    .gc-filter-panel {
        position: static;
    }

    .gc-home-slide {
        min-height: 470px;
    }

    .gc-home-swiper .gc-home-swiper__prev,
    .gc-home-swiper .gc-home-swiper__next {
        display: none !important;
    }

    .gc-pagination-nav {
        max-width: 100%;
    }

    .gc-pagination-meta {
        display: none;
    }
}

@media (max-width: 767.98px) {
    .gc-navbar .navbar-collapse {
        background: #fff;
        border: 1px solid var(--gc-border);
        border-radius: 14px;
        margin-top: 0.65rem;
        padding: 0.55rem;
    }

    .gc-home-slide__visual {
        max-width: 360px;
        margin: 0 auto;
    }

    .gc-home-city-side {
        min-height: auto;
    }

    .gc-pagination-nav {
        border-radius: 14px;
        padding: 0.42rem 0.5rem;
    }

    .gc-pagination-list {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .gc-pagination-list::-webkit-scrollbar {
        display: none;
    }
}

@media (max-width: 575.98px) {
    .gc-page {
        padding-top: 0.9rem;
    }

    .gc-topbar__inner {
        min-height: 42px;
    }

    .gc-topbar__links {
        gap: 0.55rem;
    }

    .gc-topbar__links a {
        font-size: 0.77rem;
    }

    .gc-page-hero__surface {
        padding: 1rem;
    }

    .gc-home-slide {
        min-height: 520px;
    }

    .gc-home-slide h1,
    .gc-home-slide h2 {
        font-size: clamp(1.2rem, 2.8vw + 0.95rem, 1.45rem);
    }

    .gc-home-actions {
        gap: 0.45rem;
    }

    .gc-vivid-card {
        min-height: 154px;
        padding: 0.85rem;
    }

    .gc-vivid-card__value {
        font-size: 1.45rem;
    }

    .gc-process-card {
        min-height: auto;
    }

    .gc-home-city-search-card,
    .gc-home-city-side {
        padding: 0.82rem;
    }

    .gc-city-search__input {
        min-height: 44px;
    }

    .gc-home-type-tile {
        min-height: 130px;
        padding: 0.82rem;
    }

    .gc-home-slider-shell {
        padding: 0.85rem;
    }

    .gc-home-slider-shell::before {
        inset-inline-start: 0.85rem;
        inset-inline-end: 0.85rem;
    }

    .gc-home-slider .carousel-control-prev,
    .gc-home-slider .carousel-control-next {
        width: 40px;
    }

    .gc-mag-featured__slide,
    .gc-mag-featured__slide img {
        min-height: 235px;
        height: 235px;
    }
}
