:root {
    --gc-ink: #151d17;
    --gc-olive: #29372b;
    --gc-cream: #f2eddf;
    --gc-sand: #d7c59c;
    --gc-yellow: #efd82c;
    --gc-terracotta: #a4573d;
    --gc-white: #fffdf8;
    --gc-border: rgba(21, 29, 23, .14);
    --gc-radius: 24px;
    --gc-shadow: 0 22px 80px rgba(13, 24, 17, .10);
    --gc-container: 1280px;
    --gc-serif: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;
    --gc-nav-font: Baskerville, "Baskerville Old Face", "Hoefler Text", "Palatino Linotype", Georgia, serif;
    --gc-sans: "Avenir Next", Avenir, "Segoe UI", Helvetica, Arial, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--gc-white);
    color: var(--gc-ink);
    font-family: var(--gc-sans);
    font-size: 16px;
    line-height: 1.65;
    text-rendering: optimizeLegibility;
}
body.gc-menu-open { overflow: hidden; }
img { max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
.screen-reader-text {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.gc-container { width: min(calc(100% - 48px), var(--gc-container)); margin-inline: auto; }
.gc-kicker {
    margin: 0 0 18px; font-size: .76rem; font-weight: 700;
    letter-spacing: .16em; text-transform: uppercase;
}

.gc-header {
    position: fixed; inset: 0 0 auto; z-index: 40; color: var(--gc-white);
    transition: background .35s ease, color .35s ease, box-shadow .35s ease;
}
.gc-header.is-scrolled {
    background: linear-gradient(90deg, rgba(248,244,235,.78), rgba(244,240,231,.68));
    color: var(--gc-ink);
    -webkit-backdrop-filter: blur(16px) saturate(118%);
    backdrop-filter: blur(16px) saturate(118%);
    border-bottom: 1px solid rgba(21,29,23,.09);
    box-shadow: 0 12px 36px rgba(19,31,21,.07);
}
.gc-header__inner {
    display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
    min-height: 84px; gap: 28px;
}
.gc-brand { display: inline-flex; align-items: center; gap: 12px; width: max-content; }
.gc-brand__logo, .gc-brand .custom-logo {
    width: 48px; height: 48px; object-fit: contain;
}
.gc-brand__name {
    white-space: nowrap;
    font-family: var(--gc-nav-font);
    font-size: 1.12rem;
    font-weight: 600;
    letter-spacing: .012em;
}
.gc-nav__list, .gc-footer__menu, .gc-language-switcher {
    display: flex; gap: 26px; align-items: center; padding: 0; margin: 0; list-style: none;
}
.gc-nav__list a {
    position: relative;
    font-family: var(--gc-nav-font);
    font-size: 1.08rem;
    font-weight: 500;
    letter-spacing: .015em;
}
.gc-nav__list a::after {
    content: ""; position: absolute; left: 0; right: 100%; bottom: -7px;
    height: 1px; background: currentColor; transition: right .25s ease;
}
.gc-nav__list a:hover::after { right: 0; }
.gc-header__tools { justify-self: end; display: flex; align-items: center; gap: 16px; }
.gc-language-switcher {
    gap: 8px;
    font-family: var(--gc-nav-font);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .045em;
    text-transform: uppercase;
}
.gc-language-switcher a { opacity: .58; }
.gc-language-switcher .current-lang a { opacity: 1; font-weight: 700; }
.gc-header__cta {
    padding: 11px 19px;
    border: 1px solid currentColor;
    border-radius: 999px;
    font-family: var(--gc-nav-font);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: .01em;
}
.gc-menu-toggle { display: none; }

.gc-hero {
    --gc-hero-image: none;
    position: relative; min-height: 100svh; display: grid; align-items: end; overflow: hidden;
    color: var(--gc-white);
    background-image:
        linear-gradient(120deg, rgba(15,29,19,.98), rgba(39,55,43,.88)),
        var(--gc-hero-image);
    background-size: cover; background-position: center;
}
.gc-hero::before {
    content: ""; position: absolute; inset: 0;
    background:
        radial-gradient(circle at 82% 28%, rgba(239,216,44,.17), transparent 18%),
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size: auto, 12vw 100%;
}
.gc-hero__brandmark {
    position: absolute; right: clamp(-120px, -4vw, -30px); top: 50%;
    width: min(46vw, 700px); transform: translateY(-48%);
    opacity: .09; filter: grayscale(1); pointer-events: none;
}
.gc-hero__brandmark img { width: 100%; }
.gc-hero__content { position: relative; z-index: 2; padding-top: 160px; padding-bottom: 105px; }
.gc-hero h1, .gc-section h2, .gc-story h2, .gc-territory h2,
.gc-trust h2, .gc-footer h2, .gc-page-hero h1, .gc-article h1 {
    margin: 0; font-family: var(--gc-serif); font-weight: 400;
    line-height: .98; letter-spacing: -.045em;
}
.gc-hero h1 { max-width: 980px; font-size: clamp(4rem, 8.4vw, 8.6rem); }
.gc-hero__lead { max-width: 650px; margin: 30px 0 0; font-size: clamp(1rem, 1.7vw, 1.25rem); color: rgba(255,255,255,.8); }
.gc-hero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 36px; }
.gc-button {
    display: inline-flex; align-items: center; justify-content: center; min-height: 52px;
    padding: 0 22px; border-radius: 999px; border: 1px solid transparent;
    font-size: .92rem; font-weight: 650; transition: transform .25s ease, background .25s ease, color .25s ease;
}
.gc-button:hover { transform: translateY(-2px); }
.gc-button--light { background: var(--gc-white); color: var(--gc-ink); }
.gc-button--ghost-light { border-color: rgba(255,255,255,.55); color: var(--gc-white); }
.gc-button--dark { background: var(--gc-ink); color: var(--gc-white); }
.gc-scroll-cue {
    position: absolute; z-index: 2; right: 34px; bottom: 30px; width: 38px; height: 64px;
    border: 1px solid rgba(255,255,255,.5); border-radius: 999px;
}
.gc-scroll-cue span {
    position: absolute; left: 50%; top: 14px; width: 4px; height: 4px; border-radius: 50%;
    background: var(--gc-white); transform: translateX(-50%); animation: gc-scroll 1.8s ease-in-out infinite;
}
@keyframes gc-scroll {
    0%,100% { transform: translate(-50%,0); opacity:.35; }
    45% { opacity:1; }
    70% { transform: translate(-50%,24px); opacity:0; }
}


.gc-story { position: relative; min-height: 280vh; overflow: visible; background: var(--gc-ink); color: var(--gc-white); }
.gc-story__sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 1;
    height: 100vh;
    height: 100svh;
    display: grid;
    place-items: center;
    pointer-events: none;
}
.gc-story__frame {
    width: min(72vw,1040px); height: min(62vh,700px); border-radius: var(--gc-radius);
    overflow: hidden; box-shadow: var(--gc-shadow); transform: scale(.84);
    transition: transform .6s cubic-bezier(.2,.7,.2,1);
}
.gc-story.is-active .gc-story__frame { transform: scale(1); }
.gc-story__landscape {
    width: 100%; height: 100%;
    background:
        radial-gradient(circle at 68% 26%, rgba(255,255,255,.36), transparent 14%),
        linear-gradient(152deg, #8d845b 0 22%, #c29b6d 22% 44%, #587574 44% 68%, #243a30 68%);
    transition: filter .6s ease, transform 1s ease;
}
.gc-story[data-step="2"] .gc-story__landscape { filter: hue-rotate(-16deg) saturate(.85); transform: scale(1.08); }
.gc-story[data-step="3"] .gc-story__landscape { filter: hue-rotate(22deg) saturate(1.05); transform: scale(1.14); }
.gc-story__copy {
    position: relative; z-index: 3; width: min(78vw, 1180px); margin: -100svh auto 0;
    padding-bottom: 30vh;
}
.gc-story__chapter {
    min-height: 92vh; display: flex; flex-direction: column; justify-content: center;
    width: min(34vw, 560px); max-width: none; margin-left: 3%; padding: 34px 36px;
    background: linear-gradient(180deg, rgba(15,23,18,.1), rgba(15,23,18,.24));
    border: 1px solid rgba(255,255,255,.12); border-radius: 28px;
    backdrop-filter: blur(8px); opacity: .22;
    transition: opacity .45s ease, transform .45s ease; transform: translateY(28px);
}
.gc-story__chapter:nth-child(even) { margin-left: auto; margin-right: 3%; }
.gc-story__chapter.is-current { opacity: 1; transform: translateY(0); }
.gc-story h2 { font-size: clamp(3.2rem,5vw,5.4rem); }
.gc-story__chapter p:last-child { max-width: 480px; color: rgba(255,255,255,.8); font-size: 1.12rem; }


.gc-section { padding: 126px 0; }
.gc-section--cream { background: var(--gc-cream); }
.gc-section__head {
    display: grid; grid-template-columns: minmax(0,1.4fr) minmax(260px,.6fr);
    align-items: end; gap: 40px; margin-bottom: 64px;
}
.gc-section__head h2, .gc-territory h2, .gc-trust h2, .gc-footer h2 { font-size: clamp(3.1rem,6vw,6rem); }
.gc-section__head > p, .gc-section__head > div > p { margin: 0 0 12px; color: rgba(21,29,23,.66); }
.gc-text-link { display: inline-block; margin-top: 14px; padding-bottom: 4px; border-bottom: 1px solid currentColor; }

.gc-service-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.gc-service-card {
    min-height: 360px; display: flex; flex-direction: column; padding: 26px;
    background: rgba(255,255,255,.66); border: 1px solid rgba(21,29,23,.08);
    border-radius: var(--gc-radius); transition: transform .35s ease, background .35s ease;
}
.gc-service-card:hover { transform: translateY(-8px); background: var(--gc-white); }
.gc-service-card > span { color: rgba(21,29,23,.45); font-size: .78rem; }
.gc-service-card h3 {
    margin: auto 0 16px; font-family: var(--gc-serif); font-size: 2rem;
    font-weight: 400; line-height: 1.05;
}
.gc-service-card p { margin: 0; color: rgba(21,29,23,.66); }

.gc-section__head--single {
    display: block;
    margin-bottom: 42px;
}

.gc-service-card__media {
    margin: 18px 0 20px;
    overflow: hidden;
    border-radius: 24px;
    aspect-ratio: 1.15 / 1;
    background: rgba(21,29,23,.06);
    border: 1px solid rgba(21,29,23,.06);
}
.gc-service-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.gc-service-card {
    min-height: 430px;
}

.gc-service-hero__copy {
    max-width: 820px;
}
.gc-service-hero__visual {
    align-self: center;
    justify-self: end;
    width: min(100%, 470px);
    border-radius: var(--gc-radius);
    overflow: hidden;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: var(--gc-shadow);
}
.gc-service-hero__visual img {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 5;
    min-height: 0;
    object-fit: cover;
    display: block;
}
.gc-service-hero__caption {
    display: grid;
    gap: 8px;
    padding: 22px 24px 26px;
    background: rgba(15,23,18,.62);
}
.gc-service-hero__caption strong {
    font-size: 1.24rem;
    font-weight: 600;
}
.gc-service-hero__caption span {
    color: rgba(255,255,255,.78);
    line-height: 1.55;
}

.gc-service-process {
    background: linear-gradient(180deg, rgba(246,242,232,.66), #fff 30%);
    border-top: 1px solid var(--gc-border);
}
.gc-process-card__media {
    margin: -28px -28px 22px;
    overflow: hidden;
    border-radius: 24px 24px 0 0;
    aspect-ratio: 1.45 / 1;
    border-bottom: 1px solid var(--gc-border);
    background: var(--gc-cream);
}
.gc-process-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.gc-process-card {
    min-height: 0;
    overflow: hidden;
}
.gc-process-card h3 {
    margin-top: 0;
}


.gc-post-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.gc-post-card {
    overflow: hidden; border: 1px solid var(--gc-border); border-radius: var(--gc-radius); background: var(--gc-white);
}
.gc-post-card__media { display: block; aspect-ratio: 3/2; overflow: hidden; background: var(--gc-cream); }
.gc-post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.gc-post-card:hover .gc-post-card__media img { transform: scale(1.035); }
.gc-post-card__placeholder {
    display: block; width: 100%; height: 100%;
    background:
        radial-gradient(circle at 76% 24%, rgba(239,216,44,.36), transparent 18%),
        linear-gradient(145deg, var(--gc-olive), #7f7454);
}
.gc-post-card__body { padding: 24px; }
.gc-post-card__meta { margin: 0 0 13px; color: var(--gc-terracotta); font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; }
.gc-post-card h2, .gc-post-card h3 {
    margin: 0 0 12px; font-family: var(--gc-serif); font-size: 2rem; font-weight: 400; line-height: 1.08;
}
.gc-post-card__body > p:last-child { margin: 0; color: rgba(21,29,23,.62); }
.gc-post-card--empty { grid-column: 1 / -1; min-height: 260px; display: flex; align-items: end; background: var(--gc-cream); }

.gc-territory { padding: 140px 0; background: var(--gc-olive); color: var(--gc-white); }
.gc-territory__grid, .gc-trust__grid, .gc-footer__grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.gc-territory__copy > p:last-of-type { max-width: 600px; color: rgba(255,255,255,.72); font-size: 1.08rem; }
.gc-territory__copy .gc-button { margin-top: 24px; background: var(--gc-white); color: var(--gc-ink); }
.gc-territory__map {
    position: relative; min-height: 560px; border: 1px solid rgba(255,255,255,.16);
    border-radius: 50% 42% 48% 44%;
    background: radial-gradient(circle at 60% 40%, rgba(239,216,44,.1), transparent 22%),
                linear-gradient(145deg, rgba(255,255,255,.04), transparent);
}
.gc-territory__map::before, .gc-territory__map::after {
    content: ""; position: absolute; inset: 15%; border: 1px dashed rgba(255,255,255,.16);
    border-radius: 50%; transform: rotate(-12deg);
}
.gc-territory__map::after { inset: 30%; transform: rotate(18deg); }
.gc-territory__map:not(.gc-territory__map--interactive) span {
    position: absolute; padding: 7px 10px; border-radius: 999px;
    background: rgba(255,255,255,.08); font-size: .78rem;
}
.gc-territory__map:not(.gc-territory__map--interactive) span:nth-child(1){left:42%;top:42%}
.gc-territory__map:not(.gc-territory__map--interactive) span:nth-child(2){right:10%;top:38%}
.gc-territory__map:not(.gc-territory__map--interactive) span:nth-child(3){right:22%;top:17%}
.gc-territory__map:not(.gc-territory__map--interactive) span:nth-child(4){right:2%;top:7%}
.gc-territory__map:not(.gc-territory__map--interactive) span:nth-child(5){left:18%;top:48%}
.gc-territory__map:not(.gc-territory__map--interactive) span:nth-child(6){right:4%;bottom:22%}

.gc-trust { padding: 120px 0; background: var(--gc-sand); }
.gc-trust__items { border-top: 1px solid rgba(21,29,23,.22); }
.gc-trust__items p { margin: 0; padding: 18px 0; border-bottom: 1px solid rgba(21,29,23,.22); font-size: 1.2rem; }

.gc-page-hero {
    padding: 190px 0 92px; background: var(--gc-olive); color: var(--gc-white);
}
.gc-page-hero--compact { padding-bottom: 78px; }
.gc-page-hero h1 { font-size: clamp(4rem,9vw,8rem); }
.gc-page-hero > .gc-container > p:last-child,
.gc-page-hero__description { max-width: 720px; color: rgba(255,255,255,.72); font-size: 1.12rem; }

.gc-article__narrow { max-width: 830px; }
.gc-article__header { padding: 190px 0 80px; background: var(--gc-cream); }
.gc-article h1 { font-size: clamp(3.7rem,8vw,7rem); }
.gc-article__lead { font-size: 1.2rem; color: rgba(21,29,23,.65); }
.gc-article__image {
    width: min(calc(100% - 40px), 980px);
    max-width: 980px;
    margin: 56px auto 0;
    padding-inline: 0;
}
.gc-article__image img {
    display: block;
    width: 100%;
    height: auto;
    max-height: none;
    object-fit: contain;
    border-radius: var(--gc-radius);
}

@media (max-width: 760px) {
    .gc-article__image {
        width: calc(100% - 28px);
        margin-top: 34px;
    }
}
.gc-article__content { padding-top: 72px; padding-bottom: 120px; font-size: 1.08rem; }
.gc-article__content h2, .gc-article__content h3 { font-family: var(--gc-serif); font-weight: 400; line-height: 1.1; }
.gc-article__content h2 { margin-top: 2.2em; font-size: 2.5rem; }
.gc-article__content a { text-decoration: underline; text-underline-offset: 3px; }
.gc-article__content blockquote {
    margin: 2.5em 0; padding: 1.5em 0 1.5em 1.5em; border-left: 3px solid var(--gc-yellow);
    font-family: var(--gc-serif); font-size: 1.5rem; line-height: 1.3;
}
.gc-pagination { margin-top: 54px; }
.gc-pagination .nav-links { display: flex; gap: 10px; flex-wrap: wrap; }
.gc-pagination .page-numbers { padding: 10px 14px; border: 1px solid var(--gc-border); border-radius: 999px; }
.gc-pagination .current { background: var(--gc-ink); color: var(--gc-white); }

.gc-footer {
    padding: 110px 0 28px;
    background: linear-gradient(135deg, #24372d 0%, #304536 58%, #54654a 100%);
    color: var(--gc-white);
    border-top: 1px solid rgba(255,255,255,.08);
}
.gc-footer__actions { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 12px; }
.gc-footer__bottom {
    display: flex; justify-content: space-between; align-items: center; gap: 20px;
    padding-top: 80px; color: rgba(255,255,255,.5); font-size: .82rem;
}
.gc-footer__menu { gap: 18px; }

.gc-reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.gc-reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1080px) {
    .gc-header__inner { grid-template-columns: 1fr auto auto; }
    .gc-nav {
        position: fixed; inset: 84px 18px auto; padding: 24px; border-radius: 20px;
        background: rgba(255,253,248,.98); color: var(--gc-ink); box-shadow: var(--gc-shadow);
        opacity: 0; visibility: hidden; transform: translateY(-12px); transition: .25s ease;
    }
    .gc-menu-open .gc-nav { opacity: 1; visibility: visible; transform: translateY(0); }
    .gc-nav__list { align-items: flex-start; flex-direction: column; }
    .gc-menu-toggle {
        display: grid; gap: 7px; width: 44px; height: 44px; place-content: center;
        background: transparent; border: 1px solid currentColor; border-radius: 50%; color: inherit;
    }
    .gc-menu-toggle span:not(.screen-reader-text) { display: block; width: 18px; height: 1px; background: currentColor; }
    .gc-header__cta { display: none; }
    .gc-service-grid { grid-template-columns: repeat(2,1fr); }
    .gc-post-grid { grid-template-columns: 1fr 1fr; }
    .gc-post-card:last-child:nth-child(odd) { grid-column: 1 / -1; }
}

@media (max-width: 760px) {
    .gc-container { width: min(calc(100% - 28px), var(--gc-container)); }
    .gc-header__inner { min-height: 72px; gap: 12px; }
    .gc-nav { inset: 72px 14px auto; }
    .gc-brand__logo, .gc-brand .custom-logo { width: 42px; height: 42px; }
    .gc-brand__name { display: none; }
    .gc-header__tools { gap: 8px; }
    .gc-hero__content { padding-top: 130px; padding-bottom: 82px; }
    .gc-hero h1 { font-size: clamp(3.45rem,15vw,5.6rem); }
    .gc-hero__brandmark { width: 82vw; right: -28vw; top: 35%; }
    .gc-scroll-cue { display: none; }
    .gc-story { min-height: 250vh; }
    .gc-story__frame { width: calc(100vw - 28px); height: 58vh; }
    .gc-story__copy { width: calc(100vw - 28px); padding-bottom: 18vh; }
    .gc-story__chapter, .gc-story__chapter:nth-child(even) {
        max-width: 100%; margin-left: 0; margin-right: 0; justify-content: flex-end; padding: 24px 22px; padding-bottom: 16vh;
        text-shadow: 0 3px 18px rgba(0,0,0,.45);
    }
    .gc-story h2 { font-size: clamp(3.1rem,14vw,5rem); }
    .gc-section, .gc-territory, .gc-trust { padding: 88px 0; }
    .gc-section__head, .gc-territory__grid, .gc-trust__grid, .gc-footer__grid {
        grid-template-columns: 1fr; gap: 34px;
    }
    .gc-section__head { margin-bottom: 42px; }
    .gc-section__head h2, .gc-territory h2, .gc-trust h2, .gc-footer h2 { font-size: clamp(3rem,14vw,5rem); }
    .gc-service-grid, .gc-post-grid { grid-template-columns: 1fr; }
    .gc-post-card:last-child:nth-child(odd) { grid-column: auto; }
    .gc-service-card { min-height: 0; }
    .gc-service-card__media { aspect-ratio: 1.38 / 1; }
    .gc-service-hero__visual img { aspect-ratio: 4 / 5; }
    .gc-territory__map { min-height: 430px; }
    .gc-page-hero, .gc-article__header { padding-top: 145px; }
    .gc-page-hero h1, .gc-article h1 { font-size: clamp(3.4rem,14vw,5.6rem); }
    .gc-footer { padding-top: 80px; }
    .gc-footer__actions { justify-content: flex-start; }
    .gc-footer__bottom { flex-direction: column; align-items: flex-start; padding-top: 58px; }
    .gc-footer__menu { flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    *, *::before, *::after {
        animation-duration: .01ms !important; animation-iteration-count: 1 !important;
        transition-duration: .01ms !important; scroll-behavior: auto !important;
    }
    .gc-reveal { opacity: 1; transform: none; }
}


.gc-service-hero {
    padding: 190px 0 110px;
    background:
        radial-gradient(circle at 82% 24%, rgba(239,216,44,.16), transparent 18%),
        linear-gradient(120deg, #152219, #304130);
    color: var(--gc-white);
}
.gc-service-hero__grid {
    display: grid;
    grid-template-columns: minmax(0,1.15fr) minmax(330px,.85fr);
    gap: 72px;
    align-items: center;
}
.gc-service-hero h1,
.gc-service-benefits h2,
.gc-service-cta h2 {
    margin: 0;
    font-family: var(--gc-serif);
    font-weight: 400;
    line-height: .98;
    letter-spacing: -.045em;
}
.gc-service-hero h1 {
    max-width: 9ch;
    font-size: clamp(4.4rem,7.2vw,7.6rem);
}
.gc-service-hero__intro {
    max-width: 640px;
    margin: 18px 0 0;
    color: rgba(255,255,255,.82);
    font-size: clamp(1.15rem,1.6vw,1.34rem);
    line-height: 1.62;
}
.gc-service-benefits {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
}
.gc-service-benefits h2,
.gc-service-cta h2 {
    font-size: clamp(3rem,5.2vw,5.3rem);
}
.gc-service-benefits ul {
    padding: 0;
    margin: 0;
    list-style: none;
    border-top: 1px solid rgba(21,29,23,.22);
}
.gc-service-benefits li {
    padding: 19px 0;
    border-bottom: 1px solid rgba(21,29,23,.22);
    font-size: 1.1rem;
}
.gc-process-grid {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 16px;
}
.gc-process-card {
    min-height: 330px;
    display: flex;
    flex-direction: column;
    padding: 28px;
    border: 1px solid var(--gc-border);
    border-radius: var(--gc-radius);
    background: var(--gc-white);
}
.gc-process-card > span {
    color: rgba(21,29,23,.42);
    font-size: .78rem;
}
.gc-process-card h3 {
    margin: auto 0 14px;
    font-family: var(--gc-serif);
    font-size: 2.25rem;
    font-weight: 400;
    line-height: 1.05;
}
.gc-process-card p {
    margin: 0;
    color: rgba(21,29,23,.65);
}
.gc-service-note {
    max-width: 900px;
    margin: 36px 0 0;
    padding: 20px 22px;
    border-left: 3px solid var(--gc-yellow);
    background: var(--gc-cream);
    color: rgba(21,29,23,.72);
}
.gc-service-editorial {
    border-top: 1px solid var(--gc-border);
}
.gc-service-cta {
    padding: 110px 0;
    background: linear-gradient(135deg, #ede4d3 0%, #f4eee2 100%);
    color: var(--gc-ink);
    border-top: 1px solid var(--gc-border);
    border-bottom: 1px solid var(--gc-border);
}
.gc-service-cta .gc-kicker { color: rgba(21,29,23,.68); }
.gc-service-cta h2 { max-width: 12ch; }
.gc-service-cta .gc-button--light { background: var(--gc-ink); color: var(--gc-white); }
.gc-service-cta .gc-button--light:hover { background: #24372d; }
.gc-service-cta__grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 60px;
    align-items: end;
}

@media (max-width: 900px) {
    .gc-service-hero__visual { width: min(100%, 560px); justify-self: start; }
    .gc-service-hero__grid,
    .gc-service-benefits {
        grid-template-columns: 1fr;
        gap: 34px;
    }
    .gc-process-grid {
        grid-template-columns: 1fr;
    }
    .gc-process-card {
        min-height: 0;
    }
    .gc-service-cta__grid {
        grid-template-columns: 1fr;
        align-items: start;
    }
}

@media (max-width: 760px) {
    .gc-service-hero {
        padding: 145px 0 82px;
    }
    .gc-service-hero h1 {
        max-width: none;
        font-size: clamp(3.4rem,13vw,5.4rem);
    }
    .gc-service-benefits h2,
    .gc-service-cta h2 {
        font-size: clamp(3rem,13vw,5rem);
    }
}


.gc-footer__address {
    display: inline-flex;
    flex-direction: column;
    gap: 5px;
    max-width: 560px;
    margin-top: 30px;
    color: rgba(255,255,255,.78);
    transition: color .25s ease, transform .25s ease;
}
.gc-footer__address:hover {
    color: var(--gc-white);
    transform: translateY(-2px);
}
.gc-footer__address span {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.48);
}
.gc-footer__address strong {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.5;
}
.gc-footer__actions {
    align-content: center;
}
.gc-footer .gc-button--light { background: var(--gc-white); color: var(--gc-ink); }
.gc-footer .gc-button--ghost-light { border-color: rgba(255,255,255,.72); color: var(--gc-white); }

@media (max-width: 760px) {
    .gc-footer__address {
        margin-top: 22px;
    }
}

.gc-service-hero .gc-kicker { font-size: .88rem; margin-bottom: 26px; letter-spacing: .18em; }


.gc-footer__contact {
    display: grid;
    gap: 28px;
    align-self: stretch;
}
.gc-footer__map {
    position: relative;
    min-height: 270px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.22);
    border-radius: var(--gc-radius);
    background: rgba(255,255,255,.08);
    box-shadow: 0 24px 70px rgba(14,28,20,.18);
}
.gc-footer__map iframe {
    display: block;
    width: 100%;
    min-height: 270px;
    height: 100%;
    border: 0;
    filter: saturate(.68) sepia(.08) contrast(.95);
    transition: filter .35s ease, transform .45s ease;
}
.gc-footer__map:hover iframe {
    filter: saturate(.9) contrast(1);
    transform: scale(1.012);
}
.gc-footer__map-link {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    padding: 18px;
}
.gc-footer__map-link span {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid rgba(255,255,255,.38);
    border-radius: 999px;
    background: rgba(36,55,45,.9);
    color: var(--gc-white);
    font-family: var(--gc-serif);
    font-size: .92rem;
    box-shadow: 0 10px 30px rgba(13,24,17,.18);
}

@media (pointer: fine) and (hover: hover) {
    body,
    a,
    button,
    [role="button"],
    input[type="submit"],
    input[type="button"],
    .gc-service-card,
    .gc-post-card {
        cursor: none;
    }

    input:not([type="submit"]):not([type="button"]),
    textarea,
    select,
    [contenteditable="true"] {
        cursor: text;
    }

    .gc-cursor {
        position: fixed;
        left: -80px;
        top: -80px;
        /* Keep the custom cursor above consent dialogs and their backdrop. */
        z-index: 100100;
        width: 30px;
        height: 30px;
        border: 1.5px solid var(--gc-yellow);
        border-radius: 50%;
        pointer-events: none;
        opacity: 0;
        transform: translate(-50%, -50%);
        transition:
            width .2s ease,
            height .2s ease,
            opacity .18s ease,
            border-color .2s ease,
            background .2s ease;
        box-shadow: 0 0 0 1px rgba(21,29,23,.12);
    }
    .gc-cursor.is-visible { opacity: 1; }
    .gc-cursor.is-hidden { opacity: 0; }
    .gc-cursor.is-hovering {
        width: 44px;
        height: 44px;
        background: rgba(239,216,44,.12);
    }
    .gc-cursor.is-pressed {
        width: 24px;
        height: 24px;
    }
    .gc-cursor__dot {
        position: absolute;
        left: 50%;
        top: 50%;
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: var(--gc-yellow);
        transform: translate(-50%, -50%);
        box-shadow: 0 0 0 1px rgba(21,29,23,.08);
    }
}

@media (max-width: 760px) {
    .gc-footer__contact { gap: 22px; }
    .gc-footer__map,
    .gc-footer__map iframe { min-height: 230px; }
}

@media (prefers-reduced-motion: reduce) {
    .gc-cursor { display: none !important; }
}


.gc-header.is-scrolled .gc-nav__list a,
.gc-header.is-scrolled .gc-brand__name,
.gc-header.is-scrolled .gc-language-switcher,
.gc-header.is-scrolled .gc-header__cta {
    text-shadow: 0 1px 0 rgba(255,255,255,.36);
}


/* v0.4.7 — corrección de desplazamiento horizontal en móvil */
html,
body {
    width: 100%;
    max-width: 100%;
}

main,
.gc-header,
.gc-hero,
.gc-story,
.gc-section,
.gc-territory,
.gc-trust,
.gc-footer {
    max-width: 100%;
}

.gc-header__inner,
.gc-header__tools,
.gc-language-switcher,
.gc-hero__content,
.gc-hero__actions {
    min-width: 0;
}

.gc-language-switcher {
    white-space: nowrap;
    flex-shrink: 0;
}

.gc-hero h1,
.gc-hero__lead {
    overflow-wrap: break-word;
    word-break: normal;
}

.gc-hero__actions .gc-button {
    max-width: 100%;
    white-space: normal;
    text-align: center;
}

@media (max-width: 760px) {
    html,
    body {
        overflow-x: clip;
    }

    .gc-header__inner {
        display: flex;
        width: 100%;
        max-width: 100%;
        align-items: center;
        justify-content: flex-start;
        gap: 10px;
    }

    .gc-brand {
        flex: 0 0 auto;
        min-width: 42px;
        max-width: 42px;
        overflow: hidden;
    }

    .gc-menu-toggle {
        flex: 0 0 44px;
        margin-left: auto;
    }

    .gc-header__tools {
        flex: 0 0 auto;
        max-width: calc(100vw - 124px);
        overflow: hidden;
    }

    .gc-language-switcher {
        gap: 6px;
        font-size: .78rem;
    }

    .gc-language-switcher li,
    .gc-language-switcher a {
        display: inline-flex;
        flex: 0 0 auto;
    }

    .gc-hero__content {
        width: min(calc(100% - 28px), var(--gc-container));
        max-width: calc(100% - 28px);
    }

    .gc-hero__actions {
        width: 100%;
    }

    .gc-hero__actions .gc-button {
        width: fit-content;
        max-width: 100%;
        padding-inline: 20px;
    }

    .gc-story__frame,
    .gc-story__copy {
        max-width: calc(100% - 28px);
    }

    iframe,
    .gc-footer__map,
    .gc-footer__contact {
        max-width: 100%;
    }
}


/* v0.4.8 — composición móvil de territorio y servicios */
@media (max-width: 760px) {
    /* Cabecera compacta sin recortes */
    .gc-header__inner {
        width: min(calc(100% - 24px), var(--gc-container));
        margin-inline: auto;
        gap: 9px;
    }

    .gc-brand {
        flex: 0 0 48px;
        min-width: 48px;
        max-width: 48px;
        overflow: visible;
    }

    .gc-brand__logo,
    .gc-brand .custom-logo {
        width: 46px;
        height: 46px;
    }

    .gc-header__tools {
        max-width: none;
        overflow: visible;
    }

    .gc-language-switcher {
        gap: 5px;
        font-size: .74rem;
    }

    /* En móvil, la narración del territorio se convierte en tres tarjetas completas. */
    .gc-story {
        min-height: auto;
        padding: 22px 0 76px;
        overflow: hidden;
    }

    .gc-story__sticky {
        display: none;
    }

    .gc-story__copy {
        width: min(calc(100% - 28px), var(--gc-container));
        max-width: calc(100% - 28px);
        margin: 0 auto;
        padding: 0;
        display: grid;
        gap: 18px;
    }

    .gc-story__chapter,
    .gc-story__chapter:nth-child(even) {
        position: relative;
        isolation: isolate;
        width: 100%;
        max-width: 100%;
        min-height: min(74svh, 680px);
        margin: 0;
        padding: 30px 26px;
        justify-content: flex-end;
        overflow: hidden;
        border-radius: 28px;
        opacity: 1;
        transform: none;
        text-shadow: 0 2px 18px rgba(0,0,0,.22);
        box-shadow: 0 22px 54px rgba(7,18,12,.18);
        backdrop-filter: none;
    }

    .gc-story__chapter::before {
        content: "";
        position: absolute;
        inset: 0;
        z-index: -1;
        background:
            linear-gradient(180deg, rgba(10,24,16,.08), rgba(10,24,16,.62)),
            radial-gradient(circle at 72% 22%, rgba(255,255,255,.28), transparent 17%);
    }

    .gc-story__chapter:nth-child(1) {
        background: linear-gradient(145deg, #8f895f 0 23%, #c6a06f 23% 49%, #718b89 49% 73%, #294236 73%);
    }

    .gc-story__chapter:nth-child(2) {
        background: linear-gradient(145deg, #756f52 0 24%, #b98c73 24% 48%, #6f8985 48% 72%, #233b31 72%);
    }

    .gc-story__chapter:nth-child(3) {
        background: linear-gradient(145deg, #8f8754 0 22%, #c5ad68 22% 47%, #67838b 47% 71%, #1f4039 71%);
    }

    .gc-story__chapter .gc-kicker {
        margin-bottom: 18px;
        font-size: .78rem;
    }

    .gc-story h2 {
        max-width: 8ch;
        font-size: clamp(3.15rem, 13vw, 4.7rem);
        line-height: .94;
        overflow-wrap: normal;
        word-break: normal;
    }

    .gc-story__chapter p:last-child {
        max-width: 29ch;
        margin: 22px 0 0;
        font-size: 1.08rem;
        line-height: 1.55;
        color: rgba(255,255,255,.88);
    }

    /* Evita que “Cuatro caminos…” o su versión catalana se corte. */
    .gc-section__head {
        min-width: 0;
        overflow: hidden;
    }

    .gc-section__head > div,
    .gc-section__head > p,
    .gc-section__head > div > p {
        min-width: 0;
        max-width: 100%;
    }

    .gc-section__head h2 {
        max-width: 100%;
        font-size: clamp(2.35rem, 10.8vw, 4rem);
        line-height: .98;
        letter-spacing: -.035em;
        overflow-wrap: break-word;
        word-break: normal;
        hyphens: auto;
    }

    .gc-section__head > p,
    .gc-section__head > div > p {
        font-size: 1rem;
        line-height: 1.6;
        overflow-wrap: break-word;
    }

    .gc-service-grid {
        width: 100%;
        min-width: 0;
    }

    .gc-service-card {
        width: 100%;
        min-width: 0;
    }
}

/* v0.5.0 — enlaces legales permanentes y bilingües en el pie */
.gc-footer__bottom {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 18px 28px;
}

.gc-footer__copyright {
    margin: 0;
    white-space: nowrap;
}

.gc-footer__legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 8px 20px;
    min-width: 0;
}

.gc-footer__legal a {
    color: rgba(255,255,255,.68);
    text-decoration: underline;
    text-decoration-color: rgba(255,255,255,.26);
    text-underline-offset: 4px;
    transition: color .2s ease, text-decoration-color .2s ease;
}

.gc-footer__legal a:hover,
.gc-footer__legal a:focus-visible {
    color: var(--gc-white);
    text-decoration-color: currentColor;
}

@media (max-width: 760px) {
    .gc-footer__bottom {
        grid-template-columns: 1fr;
        justify-items: start;
        align-items: start;
        gap: 18px;
        padding-top: 52px;
    }

    .gc-footer__legal {
        justify-content: flex-start;
        gap: 10px 18px;
    }
}

/* v0.5.1 — consentimiento de cookies y bloqueo previo de Google Maps */
.gc-footer__cookie-settings {
    appearance: none;
    padding: 0;
    border: 0;
    background: transparent;
    color: rgba(255,255,255,.68);
    font: inherit;
    text-decoration: underline;
    text-decoration-color: rgba(255,255,255,.26);
    text-underline-offset: 4px;
    transition: color .2s ease, text-decoration-color .2s ease;
}

.gc-footer__cookie-settings:hover,
.gc-footer__cookie-settings:focus-visible {
    color: var(--gc-white);
    text-decoration-color: currentColor;
}

.gc-footer__map [hidden],
.gc-cookie-banner[hidden],
.gc-cookie-modal[hidden] {
    display: none !important;
}

.gc-footer__map-placeholder {
    min-height: 270px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: clamp(24px, 4vw, 40px);
    background:
        radial-gradient(circle at 84% 16%, rgba(239,216,44,.16), transparent 25%),
        linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.035));
}

.gc-footer__map-kicker {
    margin: 0 0 12px;
    color: rgba(255,255,255,.58);
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.gc-footer__map-placeholder h3 {
    max-width: 17ch;
    margin: 0;
    font-family: var(--gc-serif);
    font-size: clamp(1.8rem, 3vw, 2.65rem);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -.025em;
}

.gc-footer__map-placeholder > p:not(.gc-footer__map-kicker) {
    max-width: 620px;
    margin: 15px 0 0;
    color: rgba(255,255,255,.72);
    font-size: .94rem;
    line-height: 1.55;
}

.gc-footer__map-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.gc-footer__map.is-loaded .gc-footer__map-link {
    pointer-events: auto;
}

.gc-cookie-banner {
    position: fixed;
    z-index: 99990;
    left: 18px;
    right: 18px;
    bottom: 18px;
    color: var(--gc-ink);
}

.gc-cookie-banner__inner {
    width: min(100%, 1180px);
    margin-inline: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 24px;
    border: 1px solid rgba(21,29,23,.16);
    border-radius: 22px;
    background: rgba(255,253,248,.97);
    box-shadow: 0 28px 90px rgba(13,24,17,.24);
    -webkit-backdrop-filter: blur(18px) saturate(120%);
    backdrop-filter: blur(18px) saturate(120%);
}

.gc-cookie-banner__copy {
    min-width: 0;
}

.gc-cookie-banner__kicker {
    margin: 0 0 7px;
    color: rgba(21,29,23,.58);
    font-size: .68rem;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.gc-cookie-banner h2,
.gc-cookie-modal h2 {
    margin: 0;
    font-family: var(--gc-serif);
    font-weight: 400;
    line-height: 1.08;
    letter-spacing: -.028em;
}

.gc-cookie-banner h2 {
    font-size: clamp(1.55rem, 2.5vw, 2.2rem);
}

.gc-cookie-banner__copy > p:not(.gc-cookie-banner__kicker) {
    max-width: 760px;
    margin: 8px 0 0;
    color: rgba(21,29,23,.72);
    font-size: .94rem;
    line-height: 1.5;
}

.gc-cookie-banner__copy > a,
.gc-cookie-modal__policy {
    display: inline-block;
    margin-top: 9px;
    font-size: .86rem;
    font-weight: 650;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.gc-cookie-banner__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(116px, 1fr));
    gap: 9px;
    min-width: 286px;
}

.gc-cookie-choice,
.gc-cookie-configure {
    min-height: 46px;
    border-radius: 999px;
    font-size: .9rem;
    font-weight: 700;
    transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}

.gc-cookie-choice {
    border: 1px solid var(--gc-ink);
    background: var(--gc-ink);
    color: var(--gc-white);
}

.gc-cookie-choice:hover,
.gc-cookie-choice:focus-visible,
.gc-cookie-configure:hover,
.gc-cookie-configure:focus-visible {
    transform: translateY(-1px);
}

.gc-cookie-configure {
    grid-column: 1 / -1;
    border: 1px solid rgba(21,29,23,.22);
    background: transparent;
    color: var(--gc-ink);
}

.gc-cookie-choice:focus-visible,
.gc-cookie-configure:focus-visible,
.gc-cookie-modal__close:focus-visible,
.gc-cookie-switch input:focus-visible + .gc-cookie-switch__track {
    outline: 3px solid rgba(164,87,61,.35);
    outline-offset: 3px;
}

html.gc-cookie-modal-open,
html.gc-cookie-modal-open body {
    overflow: hidden;
}

.gc-cookie-modal {
    position: fixed;
    z-index: 100000;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 20px;
}

.gc-cookie-modal__backdrop {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    background: rgba(9,17,12,.68);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.gc-cookie-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 680px);
    max-height: min(90vh, 760px);
    overflow: auto;
    padding: clamp(26px, 5vw, 44px);
    border: 1px solid rgba(21,29,23,.16);
    border-radius: 26px;
    background: var(--gc-white);
    box-shadow: 0 30px 100px rgba(0,0,0,.32);
}

.gc-cookie-modal__dialog:focus {
    outline: none;
}

.gc-cookie-modal h2 {
    padding-right: 48px;
    font-size: clamp(2rem, 5vw, 3.25rem);
}

.gc-cookie-modal__intro {
    margin: 12px 0 28px;
    color: rgba(21,29,23,.68);
}

.gc-cookie-modal__close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(21,29,23,.18);
    border-radius: 50%;
    background: transparent;
    color: var(--gc-ink);
    font-size: 1.7rem;
    line-height: 1;
}

.gc-cookie-option {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 22px;
    align-items: center;
    padding: 22px 0;
    border-top: 1px solid var(--gc-border);
}

.gc-cookie-option:last-of-type {
    border-bottom: 1px solid var(--gc-border);
}

.gc-cookie-option h3 {
    margin: 0;
    font-family: var(--gc-serif);
    font-size: 1.35rem;
    font-weight: 400;
}

.gc-cookie-option p {
    margin: 5px 0 0;
    color: rgba(21,29,23,.65);
    font-size: .9rem;
    line-height: 1.5;
}

.gc-cookie-option__status {
    white-space: nowrap;
    color: #49614d;
    font-size: .77rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.gc-cookie-switch {
    position: relative;
    display: inline-flex;
}

.gc-cookie-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.gc-cookie-switch__track {
    position: relative;
    display: block;
    width: 54px;
    height: 30px;
    border: 1px solid rgba(21,29,23,.22);
    border-radius: 999px;
    background: #dedfd9;
    transition: background .2s ease, border-color .2s ease;
}

.gc-cookie-switch__track::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--gc-white);
    box-shadow: 0 3px 10px rgba(13,24,17,.22);
    transition: transform .2s ease;
}

.gc-cookie-switch input:checked + .gc-cookie-switch__track {
    border-color: var(--gc-ink);
    background: var(--gc-ink);
}

.gc-cookie-switch input:checked + .gc-cookie-switch__track::after {
    transform: translateX(24px);
}

.gc-cookie-modal__policy {
    margin-top: 20px;
}

.gc-cookie-modal__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 26px;
}

.gc-cookie-modal__actions .gc-cookie-choice {
    min-width: 210px;
    padding-inline: 24px;
}

@media (max-width: 760px) {
    .gc-footer__map-placeholder {
        min-height: 320px;
        padding: 26px 22px;
    }

    .gc-footer__map-placeholder h3 {
        font-size: clamp(1.75rem, 8.5vw, 2.4rem);
    }

    .gc-footer__map-actions {
        width: 100%;
        flex-direction: column;
    }

    .gc-footer__map-actions .gc-button {
        width: 100%;
        justify-content: center;
    }

    .gc-cookie-banner {
        left: 10px;
        right: 10px;
        bottom: 10px;
    }

    .gc-cookie-banner__inner {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 20px;
        border-radius: 19px;
    }

    .gc-cookie-banner__copy > p:not(.gc-cookie-banner__kicker) {
        font-size: .9rem;
    }

    .gc-cookie-banner__actions {
        min-width: 0;
        width: 100%;
    }

    .gc-cookie-modal {
        align-items: end;
        padding: 10px;
    }

    .gc-cookie-modal__dialog {
        width: 100%;
        max-height: 92vh;
        padding: 28px 20px 22px;
        border-radius: 22px;
    }

    .gc-cookie-modal__close {
        top: 14px;
        right: 14px;
    }

    .gc-cookie-option {
        gap: 14px;
    }

    .gc-cookie-option__status {
        white-space: normal;
        text-align: right;
        font-size: .68rem;
    }

    .gc-cookie-modal__actions .gc-cookie-choice {
        width: 100%;
        min-width: 0;
    }
}


/* v0.5.3 — Ajustes del hero patrimonial y horario del pie */
.gc-footer__hours {
    display: flex;
    flex-direction: column;
    gap: 5px;
    max-width: 560px;
    margin-top: 22px;
    color: rgba(255,255,255,.78);
}
.gc-footer__hours > span {
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.48);
}
.gc-footer__hours > strong {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.45;
    color: rgba(255,255,255,.92);
}
.gc-footer__hours p {
    margin: 0;
    font-size: .96rem;
    line-height: 1.65;
    color: rgba(255,255,255,.74);
}
.gc-footer__hours b {
    font-weight: 600;
    color: rgba(255,255,255,.9);
}

@media (max-width: 760px) {
    .gc-service-page--inheritance .gc-service-hero h1 {
        font-size: clamp(2.85rem, 10.5vw, 4.15rem);
        line-height: 1.01;
        letter-spacing: -.04em;
        overflow-wrap: normal;
        word-break: normal;
        hyphens: none;
    }

    .gc-service-page--inheritance .gc-service-hero__copy {
        min-width: 0;
    }

    .gc-footer__hours {
        margin-top: 18px;
    }
}


/* v0.5.4 — Botón flotante de WhatsApp */
.gc-whatsapp-float {
    position: fixed;
    right: max(20px, env(safe-area-inset-right));
    bottom: max(20px, calc(env(safe-area-inset-bottom) + 20px));
    z-index: 99985;
    width: 64px;
    height: 64px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(255,255,255,.58);
    border-radius: 50%;
    background: #25d366;
    color: #fff;
    box-shadow: 0 14px 34px rgba(12,52,31,.3);
    transition: transform .2s ease, box-shadow .2s ease, bottom .28s ease, opacity .2s ease;
    isolation: isolate;
}

.gc-whatsapp-float:hover,
.gc-whatsapp-float:focus-visible {
    transform: translateY(-3px) scale(1.025);
    box-shadow: 0 18px 44px rgba(12,52,31,.38);
}

.gc-whatsapp-float:focus-visible {
    outline: 3px solid rgba(255,255,255,.92);
    outline-offset: 4px;
}

.gc-whatsapp-float__icon {
    width: 35px;
    height: 35px;
    display: grid;
    place-items: center;
}

.gc-whatsapp-float__icon svg {
    width: 100%;
    height: 100%;
    display: block;
    fill: currentColor;
}

.gc-whatsapp-float__label {
    position: absolute;
    right: calc(100% + 12px);
    top: 50%;
    width: max-content;
    max-width: min(240px, calc(100vw - 120px));
    padding: 10px 13px;
    border-radius: 999px;
    background: rgba(18,38,27,.96);
    color: #fff;
    font-size: .82rem;
    font-weight: 700;
    line-height: 1.15;
    white-space: nowrap;
    opacity: 0;
    transform: translate(8px, -50%);
    pointer-events: none;
    box-shadow: 0 10px 26px rgba(8,20,12,.2);
    transition: opacity .2s ease, transform .2s ease;
}

.gc-whatsapp-float:hover .gc-whatsapp-float__label,
.gc-whatsapp-float:focus-visible .gc-whatsapp-float__label {
    opacity: 1;
    transform: translate(0, -50%);
}

body.gc-cookie-banner-visible .gc-whatsapp-float {
    bottom: calc(var(--gc-cookie-banner-offset, 220px) + env(safe-area-inset-bottom));
}

html.gc-cookie-modal-open .gc-whatsapp-float {
    opacity: 0;
    pointer-events: none;
}

@media (max-width: 760px) {
    .gc-whatsapp-float {
        right: max(14px, env(safe-area-inset-right));
        bottom: max(16px, calc(env(safe-area-inset-bottom) + 16px));
        width: 58px;
        height: 58px;
    }

    .gc-whatsapp-float__icon {
        width: 32px;
        height: 32px;
    }

    .gc-whatsapp-float__label {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .gc-whatsapp-float,
    .gc-whatsapp-float__label {
        transition: none;
    }
}


/* v0.5.5 — tarjetas de servicios claramente identificables como enlaces */
.gc-service-card {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    border-color: rgba(21,29,23,.14);
    box-shadow: 0 8px 28px rgba(21,29,23,.045);
    transition: transform .35s ease, background .35s ease, border-color .35s ease, box-shadow .35s ease;
}

.gc-service-card:hover {
    border-color: rgba(21,29,23,.25);
    box-shadow: 0 22px 48px rgba(21,29,23,.12);
}

.gc-service-card:focus-visible {
    outline: 3px solid var(--gc-yellow);
    outline-offset: 5px;
}

.gc-service-card__index {
    color: rgba(21,29,23,.48);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .08em;
}

.gc-service-card__media img {
    transition: transform .45s ease;
}

.gc-service-card:hover .gc-service-card__media img,
.gc-service-card:focus-visible .gc-service-card__media img {
    transform: scale(1.035);
}

.gc-service-card__cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 22px;
    padding: 12px 14px 12px 17px;
    border-radius: 999px;
    background: rgba(41,55,43,.09);
    color: var(--gc-ink);
    font-size: .88rem;
    font-weight: 700;
    letter-spacing: .015em;
    transition: background .3s ease, color .3s ease, transform .3s ease;
}

.gc-service-card__arrow {
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: var(--gc-ink);
    color: var(--gc-white);
    font-size: 1.05rem;
    line-height: 1;
    transition: transform .3s ease, background .3s ease;
}

.gc-service-card:hover .gc-service-card__cta,
.gc-service-card:focus-visible .gc-service-card__cta {
    background: var(--gc-ink);
    color: var(--gc-white);
}

.gc-service-card:hover .gc-service-card__arrow,
.gc-service-card:focus-visible .gc-service-card__arrow {
    background: var(--gc-yellow);
    color: var(--gc-ink);
    transform: translateX(4px);
}

@media (max-width: 760px) {
    .gc-service-card {
        background: rgba(255,255,255,.84);
        border-color: rgba(21,29,23,.17);
        box-shadow: 0 12px 30px rgba(21,29,23,.07);
    }

    .gc-service-card__cta {
        width: 100%;
        margin-top: 20px;
        background: var(--gc-ink);
        color: var(--gc-white);
    }

    .gc-service-card__arrow {
        background: var(--gc-yellow);
        color: var(--gc-ink);
    }
}

@media (prefers-reduced-motion: reduce) {
    .gc-service-card,
    .gc-service-card__media img,
    .gc-service-card__cta,
    .gc-service-card__arrow {
        transition: none;
    }
}


/* v0.5.6 — nuevas ilustraciones editoriales para las tarjetas de servicios */
.gc-service-card__media {
    aspect-ratio: 4 / 3;
    background: #f7f3e9;
}

.gc-service-card__media img {
    object-fit: cover;
    object-position: center;
}

@media (max-width: 760px) {
    .gc-service-card__media {
        aspect-ratio: 4 / 3;
    }
}


/* v0.5.7 — imágenes seleccionadas para Gestión integral del alquiler */
.gc-service-page--rentals .gc-service-hero__visual {
    width: min(100%, 620px);
}

.gc-service-page--rentals .gc-service-hero__visual img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
}

.gc-service-page--rentals .gc-process-card__media {
    aspect-ratio: 2.3 / 1;
    background: #f7f3e9;
}

.gc-service-page--rentals .gc-process-card__media img {
    object-fit: cover;
    object-position: center;
}

@media (max-width: 760px) {
    .gc-service-page--rentals .gc-service-hero__visual img {
        aspect-ratio: 4 / 3;
    }

    .gc-service-page--rentals .gc-process-card__media {
        aspect-ratio: 2.3 / 1;
    }
}


/* v0.5.8 — imágenes seleccionadas para Administración de comunidades */
.gc-service-page--communities .gc-service-hero__visual {
    width: min(100%, 620px);
}

.gc-service-page--communities .gc-service-hero__visual img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
}

.gc-service-page--communities .gc-process-card__media {
    aspect-ratio: 3 / 2;
    background: #f7f3e9;
}

.gc-service-page--communities .gc-process-card__media img {
    object-fit: cover;
    object-position: center;
}

@media (max-width: 760px) {
    .gc-service-page--communities .gc-service-hero__visual img {
        aspect-ratio: 4 / 3;
    }

    .gc-service-page--communities .gc-process-card__media {
        aspect-ratio: 3 / 2;
    }
}

/* v0.5.9 — imágenes seleccionadas para Asesoramiento inmobiliario */
.gc-service-page--advisory .gc-service-hero__visual {
    width: min(100%, 620px);
}

.gc-service-page--advisory .gc-service-hero__visual img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
}

.gc-service-page--advisory .gc-process-card__media {
    aspect-ratio: 3 / 2;
    background: #f7f3e9;
}

.gc-service-page--advisory .gc-process-card__media img {
    object-fit: cover;
    object-position: center;
}

@media (max-width: 760px) {
    .gc-service-page--advisory .gc-service-hero__visual img {
        aspect-ratio: 4 / 3;
    }

    .gc-service-page--advisory .gc-process-card__media {
        aspect-ratio: 3 / 2;
    }
}



/* v0.5.11 — imágenes de Herencias con mayor altura en el proceso y separación segura del titular */
.gc-service-page--inheritance .gc-service-hero__grid {
    grid-template-columns: minmax(0, 1fr) minmax(420px, .9fr);
    gap: clamp(72px, 7vw, 118px);
}

.gc-service-page--inheritance .gc-service-hero__copy {
    min-width: 0;
    max-width: 720px;
}

.gc-service-page--inheritance .gc-service-hero h1 {
    max-width: 8.2ch;
    font-size: clamp(4rem, 6.15vw, 6.55rem);
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
}

.gc-service-page--inheritance .gc-service-hero__visual {
    width: min(100%, 620px);
}

.gc-service-page--inheritance .gc-service-hero__visual img {
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center;
}

.gc-service-page--inheritance .gc-process-card__media {
    aspect-ratio: 3 / 2;
    background: #fff;
}

.gc-service-page--inheritance .gc-process-card__media img {
    object-fit: cover;
    object-position: center;
}

@media (max-width: 1100px) {
    .gc-service-page--inheritance .gc-service-hero__grid {
        grid-template-columns: minmax(0, 1fr) minmax(360px, .86fr);
        gap: 56px;
    }

    .gc-service-page--inheritance .gc-service-hero h1 {
        font-size: clamp(3.75rem, 6.4vw, 5.5rem);
    }
}

@media (max-width: 900px) {
    .gc-service-page--inheritance .gc-service-hero__grid {
        grid-template-columns: 1fr;
        gap: 42px;
    }

    .gc-service-page--inheritance .gc-service-hero__copy {
        max-width: 760px;
    }

    .gc-service-page--inheritance .gc-service-hero h1 {
        max-width: 10ch;
    }
}

@media (max-width: 760px) {
    .gc-service-page--inheritance .gc-service-hero h1 {
        max-width: none;
        font-size: clamp(2.75rem, 10.2vw, 4.05rem);
        line-height: 1.01;
    }

    .gc-service-page--inheritance .gc-service-hero__visual img {
        aspect-ratio: 4 / 3;
    }

    .gc-service-page--inheritance .gc-process-card__media {
        aspect-ratio: 3 / 2;
    }
}


/* v0.5.13 — proporción e integración visual unificadas para las 12 imágenes de proceso */
.gc-service-page .gc-process-card__media {
    aspect-ratio: 3 / 2;
    background: #f8f4eb;
}

.gc-service-page .gc-process-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

@media (max-width: 760px) {
    .gc-service-page .gc-process-card__media {
        aspect-ratio: 3 / 2;
    }
}

/* v0.5.15 — rediseño editorial de la sección Història con elementos móviles */
.gc-story__frame {
    background:
        radial-gradient(circle at 12% 16%, rgba(255,255,255,.08), transparent 18%),
        linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}

.gc-story__scene {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(8,18,14,.12), rgba(8,18,14,.18)),
        linear-gradient(130deg, #11251d 0%, #1d352d 55%, #203229 100%);
    --gc-story-pointer-x: 0px;
    --gc-story-pointer-y: 0px;
}

.gc-story__halo,
.gc-story__sun,
.gc-story__cloud,
.gc-story__band,
.gc-story__ground,
.gc-story__legend,
.gc-story__path,
.gc-story__visual-card {
    position: absolute;
}

.gc-story__halo {
    border-radius: 50%;
    filter: blur(36px);
    opacity: .68;
    animation: gc-story-float 11s ease-in-out infinite;
}

.gc-story__halo--a {
    width: 240px;
    height: 240px;
    left: 5%;
    top: 12%;
    background: rgba(215, 199, 114, .22);
}

.gc-story__halo--b {
    width: 280px;
    height: 280px;
    right: 8%;
    bottom: 8%;
    background: rgba(122, 154, 172, .18);
    animation-duration: 13s;
    animation-delay: -4s;
}

.gc-story__sun {
    width: 132px;
    height: 132px;
    right: 8%;
    top: 10%;
    border-radius: 50%;
    background: radial-gradient(circle at 32% 32%, rgba(255,255,255,.36), rgba(255,255,255,0) 40%), #d7c36e;
    box-shadow: 0 0 60px rgba(215,195,110,.18);
    animation: gc-story-drift 12s ease-in-out infinite;
    transform: translate(calc(var(--gc-story-pointer-x) * .18), calc(var(--gc-story-pointer-y) * .18));
}

.gc-story__cloud {
    background: rgba(255,255,255,.16);
    border-radius: 999px;
    filter: blur(.2px);
    opacity: .8;
    animation: gc-story-cloud 18s linear infinite;
}

.gc-story__cloud::before,
.gc-story__cloud::after {
    content: "";
    position: absolute;
    background: inherit;
    border-radius: inherit;
}

.gc-story__cloud--1 {
    width: 140px;
    height: 38px;
    top: 16%;
    left: 58%;
}

.gc-story__cloud--1::before {
    width: 54px;
    height: 54px;
    left: 14px;
    top: -24px;
}

.gc-story__cloud--1::after {
    width: 70px;
    height: 70px;
    right: 18px;
    top: -32px;
}

.gc-story__cloud--2 {
    width: 120px;
    height: 34px;
    top: 24%;
    right: 18%;
    animation-duration: 22s;
    animation-delay: -7s;
}

.gc-story__cloud--2::before {
    width: 48px;
    height: 48px;
    left: 20px;
    top: -19px;
}

.gc-story__cloud--2::after {
    width: 58px;
    height: 58px;
    right: 12px;
    top: -25px;
}

.gc-story__band {
    inset: auto auto 0 0;
    width: 124%;
    border-radius: 42px;
    transform-origin: center;
}

.gc-story__band--gold {
    height: 46%;
    top: -2%;
    left: -8%;
    background: linear-gradient(135deg, rgba(198,180,101,.9), rgba(183,168,94,.9));
    clip-path: polygon(0 0, 88% 0, 54% 100%, 0 100%);
    opacity: .9;
}

.gc-story__band--sea {
    height: 56%;
    top: 24%;
    left: 18%;
    background: linear-gradient(135deg, rgba(126,149,165,.92), rgba(101,128,146,.92));
    clip-path: polygon(14% 0, 100% 0, 100% 56%, 0 100%, 0 30%);
}

.gc-story__band--deep {
    height: 30%;
    bottom: -8%;
    left: 46%;
    background: linear-gradient(135deg, rgba(34,61,53,.96), rgba(26,48,42,.96));
    clip-path: polygon(30% 0, 100% 0, 100% 100%, 0 100%);
    opacity: .84;
}

.gc-story__ground {
    left: 6%;
    right: 6%;
    bottom: 5%;
    height: 12px;
    border-radius: 999px;
    background: rgba(247,243,233,.24);
    box-shadow: 0 -1px 0 rgba(255,255,255,.16) inset;
}

.gc-story__path {
    inset: 0;
    opacity: .84;
}

.gc-story__path-segment {
    position: absolute;
    border-top: 3px dashed rgba(247,243,233,.44);
    transform-origin: left center;
}

.gc-story__path-segment--1 {
    left: 28%;
    top: 56%;
    width: 18%;
    transform: rotate(-17deg);
}

.gc-story__path-segment--2 {
    left: 46%;
    top: 46%;
    width: 18%;
    transform: rotate(16deg);
}

.gc-story__path-segment--3 {
    left: 62%;
    top: 57%;
    width: 16%;
    transform: rotate(22deg);
}

.gc-story__path-dot {
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: rgba(247,243,233,.5);
    box-shadow: 0 0 0 8px rgba(255,255,255,.04);
    transition: transform .45s ease, background .45s ease, box-shadow .45s ease;
}

.gc-story__path-dot--1 { left: 26%; top: 54%; }
.gc-story__path-dot--2 { left: 46%; top: 45%; }
.gc-story__path-dot--3 { left: 66%; top: 57%; }

.gc-story__visual-card {
    width: clamp(220px, 28vw, 310px);
    padding: 18px 18px 16px;
    border-radius: 28px;
    background: rgba(247,243,233,.92);
    border: 1px solid rgba(17,37,29,.08);
    box-shadow: 0 22px 50px rgba(7,18,12,.18);
    color: var(--gc-ink);
    transition: transform .75s cubic-bezier(.2,.7,.2,1), opacity .75s ease, filter .75s ease, box-shadow .75s ease;
    will-change: transform, opacity;
}

.gc-story__visual-card--city {
    left: 6%;
    top: 20%;
    transform: translate3d(calc(var(--gc-story-pointer-x) * -.08), calc(var(--gc-story-pointer-y) * -.08), 0) rotate(-4deg) scale(.92);
}

.gc-story__visual-card--interior {
    left: 35%;
    top: 10%;
    transform: translate3d(calc(var(--gc-story-pointer-x) * .06), calc(var(--gc-story-pointer-y) * -.10), 0) rotate(1.5deg) scale(.9);
}

.gc-story__visual-card--coast {
    right: 6%;
    bottom: 10%;
    transform: translate3d(calc(var(--gc-story-pointer-x) * .1), calc(var(--gc-story-pointer-y) * .06), 0) rotate(3deg) scale(.91);
}

.gc-story__visual-kicker {
    margin: 0 0 12px;
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(21,29,23,.58);
}

.gc-story__visual-caption {
    margin: 12px 0 0;
    font-size: .92rem;
    font-weight: 700;
    color: rgba(21,29,23,.76);
}

.gc-story__visual-illustration {
    position: relative;
    height: 210px;
    overflow: hidden;
    border-radius: 22px;
    background: #f5f0e5;
    border: 1px solid rgba(21,29,23,.08);
}

.gc-story__visual-illustration--city::before,
.gc-story__visual-illustration--interior::before,
.gc-story__visual-illustration--coast::before {
    content: "";
    position: absolute;
    inset: auto 10% 12px;
    height: 8px;
    border-radius: 999px;
    background: rgba(17,37,29,.08);
}

.gc-story__building,
.gc-story__mini-card,
.gc-story__mini-people,
.gc-story__house,
.gc-story__hill,
.gc-story__tree,
.gc-story__mini-sheet,
.gc-story__wave,
.gc-story__pin,
.gc-story__pier,
.gc-story__coast-card {
    position: absolute;
}

.gc-story__building {
    bottom: 28px;
    width: 48px;
    border-radius: 8px 8px 0 0;
    background: #1e4338;
}

.gc-story__building--city-a { left: 38%; height: 110px; }
.gc-story__building--city-b { left: 52%; height: 142px; background: #95abb4; }
.gc-story__building--city-c { left: 69%; height: 98px; background: #c0b08b; }

.gc-story__building::before {
    content: "";
    position: absolute;
    inset: 14px 10px auto;
    height: 56px;
    background:
        linear-gradient(#f7f3e9 0 0) 0 0/12px 12px,
        linear-gradient(#f7f3e9 0 0) 100% 0/12px 12px,
        linear-gradient(#f7f3e9 0 0) 0 50%/12px 12px,
        linear-gradient(#f7f3e9 0 0) 100% 50%/12px 12px;
    background-repeat: no-repeat;
}

.gc-story__mini-card--left {
    left: 8%;
    bottom: 44px;
    width: 92px;
    height: 112px;
    border-radius: 18px;
    background: rgba(255,255,255,.82);
    box-shadow: 12px 16px 26px rgba(17,37,29,.08);
}

.gc-story__mini-card--left::before,
.gc-story__mini-card--left::after,
.gc-story__mini-card--right::before,
.gc-story__mini-card--right::after,
.gc-story__mini-sheet::before,
.gc-story__mini-sheet::after,
.gc-story__coast-card::before,
.gc-story__coast-card::after {
    content: "";
    position: absolute;
    left: 16px;
    right: 16px;
    height: 6px;
    border-radius: 999px;
    background: rgba(17,37,29,.12);
}

.gc-story__mini-card--left::before { top: 28px; }
.gc-story__mini-card--left::after { top: 50px; }

.gc-story__mini-card--right {
    left: 18%;
    bottom: 66px;
    width: 72px;
    height: 54px;
    border-radius: 16px;
    background: rgba(215,195,110,.92);
}

.gc-story__mini-card--right::before { top: 18px; }
.gc-story__mini-card--right::after { top: 30px; opacity: .7; }

.gc-story__mini-people {
    right: 10%;
    bottom: 30px;
    width: 102px;
    height: 54px;
    background:
        radial-gradient(circle at 14px 14px, #213d33 0 13px, transparent 14px),
        radial-gradient(circle at 52px 14px, #d4c25f 0 13px, transparent 14px),
        radial-gradient(circle at 90px 14px, #213d33 0 13px, transparent 14px),
        radial-gradient(ellipse at 14px 46px, #d9cfbe 0 28px, transparent 29px),
        radial-gradient(ellipse at 52px 46px, #d9cfbe 0 28px, transparent 29px),
        radial-gradient(ellipse at 90px 46px, #d9cfbe 0 28px, transparent 29px);
}

.gc-story__house {
    left: 50%;
    bottom: 34px;
    width: 112px;
    height: 92px;
    transform: translateX(-50%);
    background: #f0ebdf;
    border-radius: 10px 10px 6px 6px;
    box-shadow: 0 0 0 1px rgba(17,37,29,.06) inset;
}

.gc-story__house::before {
    content: "";
    position: absolute;
    left: 50%;
    top: -34px;
    transform: translateX(-50%);
    width: 130px;
    height: 54px;
    background: #214136;
    clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.gc-story__house::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 24px;
    height: 38px;
    border-radius: 12px 12px 0 0;
    background: #214136;
}

.gc-story__hill {
    bottom: 18px;
    border-radius: 999px 999px 0 0;
    background: #b7be95;
}
.gc-story__hill--1 { left: 12%; width: 120px; height: 54px; }
.gc-story__hill--2 { right: 12%; width: 92px; height: 42px; background: #93a7a0; }

.gc-story__tree {
    bottom: 34px;
    width: 22px;
    height: 78px;
    border-radius: 16px 16px 0 0;
    background: #95abb4;
}

.gc-story__tree::after {
    content: "";
    position: absolute;
    left: 9px;
    bottom: -14px;
    width: 4px;
    height: 30px;
    background: #214136;
    border-radius: 999px;
}

.gc-story__tree--1 { left: 14%; }
.gc-story__tree--2 { right: 16%; height: 68px; background: #b8b28d; }

.gc-story__mini-sheet {
    left: 16%;
    top: 24px;
    width: 74px;
    height: 100px;
    border-radius: 18px;
    background: rgba(255,255,255,.78);
    transform: rotate(-8deg);
}

.gc-story__mini-sheet::before { top: 26px; }
.gc-story__mini-sheet::after { top: 48px; }

.gc-story__wave {
    left: 12%;
    right: 12%;
    height: 74px;
    border: 4px solid rgba(149,171,180,.9);
    border-color: rgba(149,171,180,.9) transparent transparent transparent;
    border-radius: 50% 50% 0 0;
}

.gc-story__wave--1 { bottom: 66px; }
.gc-story__wave--2 { bottom: 30px; left: 20%; right: 20%; opacity: .64; }

.gc-story__pin {
    left: 26%;
    bottom: 80px;
    width: 52px;
    height: 52px;
    background: #204135;
    border-radius: 50% 50% 50% 0;
    transform: rotate(-45deg);
}

.gc-story__pin::after {
    content: "";
    position: absolute;
    inset: 14px;
    border-radius: 50%;
    background: #f7f3e9;
}

.gc-story__pier {
    right: 16%;
    bottom: 28px;
    width: 14px;
    height: 112px;
    border-radius: 999px;
    background: #214136;
    box-shadow: 22px 0 0 #214136, 44px 0 0 #214136;
}

.gc-story__coast-card {
    right: 11%;
    top: 24px;
    width: 86px;
    height: 60px;
    border-radius: 18px;
    background: rgba(255,255,255,.78);
}

.gc-story__coast-card::before { top: 18px; }
.gc-story__coast-card::after { top: 34px; }

.gc-story__legend {
    left: 50%;
    bottom: 8%;
    display: flex;
    gap: 9px;
    transform: translateX(-50%);
}

.gc-story__legend span {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: rgba(247,243,233,.26);
    transition: background .35s ease, transform .35s ease;
}

.gc-story[data-step="1"] .gc-story__visual-card--city,
.gc-story[data-step="2"] .gc-story__visual-card--interior,
.gc-story[data-step="3"] .gc-story__visual-card--coast {
    opacity: 1;
    filter: none;
    box-shadow: 0 28px 56px rgba(7,18,12,.24);
}

.gc-story[data-step="1"] .gc-story__visual-card--city {
    transform: translate3d(calc(var(--gc-story-pointer-x) * -.12), calc(var(--gc-story-pointer-y) * -.12 - 10px), 0) rotate(-3deg) scale(1.02);
}
.gc-story[data-step="1"] .gc-story__visual-card--interior {
    opacity: .48;
    filter: saturate(.84) blur(.2px);
    transform: translate3d(calc(var(--gc-story-pointer-x) * .04), calc(var(--gc-story-pointer-y) * -.05 + 18px), 0) rotate(2deg) scale(.9);
}
.gc-story[data-step="1"] .gc-story__visual-card--coast {
    opacity: .32;
    filter: saturate(.7);
    transform: translate3d(calc(var(--gc-story-pointer-x) * .08 - 18px), calc(var(--gc-story-pointer-y) * .04 + 28px), 0) rotate(4deg) scale(.88);
}

.gc-story[data-step="2"] .gc-story__visual-card--city {
    opacity: .42;
    filter: saturate(.82);
    transform: translate3d(calc(var(--gc-story-pointer-x) * -.06 - 16px), calc(var(--gc-story-pointer-y) * -.05 + 16px), 0) rotate(-5deg) scale(.9);
}
.gc-story[data-step="2"] .gc-story__visual-card--interior {
    transform: translate3d(calc(var(--gc-story-pointer-x) * .08), calc(var(--gc-story-pointer-y) * -.10 - 6px), 0) rotate(0deg) scale(1.03);
}
.gc-story[data-step="2"] .gc-story__visual-card--coast {
    opacity: .45;
    filter: saturate(.82);
    transform: translate3d(calc(var(--gc-story-pointer-x) * .08 + 14px), calc(var(--gc-story-pointer-y) * .06 + 20px), 0) rotate(5deg) scale(.9);
}

.gc-story[data-step="3"] .gc-story__visual-card--city {
    opacity: .34;
    filter: saturate(.7);
    transform: translate3d(calc(var(--gc-story-pointer-x) * -.05 - 20px), calc(var(--gc-story-pointer-y) * -.04 + 24px), 0) rotate(-6deg) scale(.87);
}
.gc-story[data-step="3"] .gc-story__visual-card--interior {
    opacity: .5;
    filter: saturate(.84);
    transform: translate3d(calc(var(--gc-story-pointer-x) * .05 + 6px), calc(var(--gc-story-pointer-y) * -.08 + 16px), 0) rotate(2deg) scale(.92);
}
.gc-story[data-step="3"] .gc-story__visual-card--coast {
    transform: translate3d(calc(var(--gc-story-pointer-x) * .12), calc(var(--gc-story-pointer-y) * .08 - 10px), 0) rotate(2deg) scale(1.03);
}

.gc-story[data-step="1"] .gc-story__path-dot--1,
.gc-story[data-step="2"] .gc-story__path-dot--2,
.gc-story[data-step="3"] .gc-story__path-dot--3,
.gc-story[data-step="1"] .gc-story__legend span:nth-child(1),
.gc-story[data-step="2"] .gc-story__legend span:nth-child(2),
.gc-story[data-step="3"] .gc-story__legend span:nth-child(3) {
    background: var(--gc-yellow);
    transform: scale(1.2);
    box-shadow: 0 0 0 10px rgba(212,193,87,.12);
}

.gc-story[data-step="1"] .gc-story__band--gold { transform: translateY(-2%) scale(1.02); }
.gc-story[data-step="2"] .gc-story__band--sea { transform: translateY(-2%) scale(1.03); }
.gc-story[data-step="3"] .gc-story__band--deep { transform: translateY(-1%) scale(1.03); }

.gc-story[data-step="2"] .gc-story__scene { background: linear-gradient(180deg, rgba(10,20,17,.14), rgba(10,20,17,.18)), linear-gradient(130deg, #172820 0%, #20382f 50%, #23392f 100%); }
.gc-story[data-step="3"] .gc-story__scene { background: linear-gradient(180deg, rgba(8,20,20,.14), rgba(8,20,20,.18)), linear-gradient(130deg, #10231e 0%, #18322c 50%, #1d332d 100%); }

@keyframes gc-story-float {
    0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
    50% { transform: translate3d(12px, -16px, 0) scale(1.04); }
}

@keyframes gc-story-drift {
    0%, 100% { transform: translate(0, 0); }
    50% { transform: translate(-10px, 12px); }
}

@keyframes gc-story-cloud {
    0% { transform: translateX(0); }
    50% { transform: translateX(18px); }
    100% { transform: translateX(0); }
}

@media (prefers-reduced-motion: reduce) {
    .gc-story__halo,
    .gc-story__sun,
    .gc-story__cloud,
    .gc-story__visual-card,
    .gc-story__path-dot,
    .gc-story__legend span {
        animation: none !important;
        transition: none !important;
    }
}

/* v0.5.17 — mapa territorial interactivo con órbitas */
.gc-territory__map--interactive::before,
.gc-territory__map--interactive::after {
    content: none;
}


.gc-territory__map--interactive {
    position: relative;
    min-height: 640px;
    overflow: hidden;
    border-radius: 42px;
    border: 1px solid rgba(255,255,255,.14);
    background:
        radial-gradient(circle at 56% 40%, rgba(211,194,92,.12), transparent 18%),
        linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
    backdrop-filter: blur(4px);
}

.gc-territory__map-shell,
.gc-territory__nodes {
    position: absolute;
    inset: 0;
}

.gc-territory__orbit,
.gc-territory__center-ring,
.gc-territory__glow,
.gc-territory__dynamic-connector {
    position: absolute;
    pointer-events: none;
}

.gc-territory__orbit {
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 50%;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: border-color .3s ease, box-shadow .3s ease, transform .5s ease;
}

.gc-territory__orbit--outer { width: min(78%, 520px); aspect-ratio: 1; animation: gc-orbit-ring 28s linear infinite; }
.gc-territory__orbit--mid { width: min(58%, 390px); aspect-ratio: 1; border-style: dashed; animation: gc-orbit-ring-reverse 24s linear infinite; }
.gc-territory__orbit--inner { width: min(34%, 220px); aspect-ratio: 1; border-style: dashed; opacity: .92; animation: gc-orbit-ring 18s linear infinite; }

.gc-territory__center-ring {
    left: 50%;
    top: 50%;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    background: rgba(255,255,255,.05);
    box-shadow: 0 0 0 12px rgba(255,255,255,.02);
}

.gc-territory__glow {
    left: 50%;
    top: 50%;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(194,178,72,.16), transparent 65%);
    filter: blur(16px);
    animation: gc-territory-breathe 8s ease-in-out infinite;
}

.gc-territory__dynamic-connector {
    left: 0;
    top: 0;
    height: 2px;
    width: 0;
    transform-origin: left center;
    background: linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.08) 55%, rgba(214,196,90,.72));
    opacity: 0;
    transition: opacity .25s ease, filter .25s ease;
}

.gc-territory__dynamic-connector::after {
    content: "";
    position: absolute;
    right: -1px;
    top: 50%;
    width: 12px;
    height: 12px;
    transform: translateY(-50%);
    border-radius: 50%;
    background: var(--gc-yellow);
    box-shadow: 0 0 0 8px rgba(212,193,87,.12);
}

.gc-territory__dynamic-connector.is-active {
    opacity: 1;
    filter: drop-shadow(0 0 8px rgba(212,193,87,.24));
}

.gc-territory__orbiter {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 0;
    height: 0;
    transform: rotate(var(--angle));
    animation: gc-orbit-node var(--duration) linear infinite;
    animation-delay: var(--delay);
    z-index: 3;
}

.gc-territory__orbiter-counter {
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(var(--radius)) rotate(calc(var(--angle) * -1));
    animation: gc-orbit-counter var(--duration) linear infinite;
    animation-delay: var(--delay);
}

.gc-territory__orbiter--outer { z-index: 2; }
.gc-territory__orbiter--mid { z-index: 3; }

.gc-territory__node {
    position: relative;
    padding: 10px 14px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,.09);
    color: var(--gc-white);
    font: inherit;
    font-size: .9rem;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
    transition: transform .25s ease, background .25s ease, box-shadow .25s ease, opacity .25s ease;
    opacity: .82;
}

.gc-territory__node--core {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 4;
}

.gc-territory__node span { display: block; white-space: nowrap; }
.gc-territory__node:hover,
.gc-territory__node:focus-visible,
.gc-territory__node.is-active {
    background: rgba(255,255,255,.15);
    opacity: 1;
    box-shadow: 0 10px 26px rgba(0,0,0,.16), inset 0 0 0 1px rgba(255,255,255,.14);
}

.gc-territory__node:hover,
.gc-territory__node:focus-visible { transform: scale(1.04); }
.gc-territory__node--core:hover,
.gc-territory__node--core:focus-visible,
.gc-territory__node--core.is-active { transform: translate(-50%, -50%) scale(1.04); }

.gc-territory__node.is-active {
    background: rgba(212,193,87,.16);
    box-shadow: 0 12px 28px rgba(0,0,0,.22), inset 0 0 0 1px rgba(212,193,87,.34);
}

.gc-territory__node.is-active::before,
.gc-territory__node--core::before {
    content: "";
    position: absolute;
    inset: -7px;
    border-radius: inherit;
    border: 1px solid rgba(255,255,255,.12);
}

.gc-territory__panel {
    position: absolute;
    left: 22px;
    right: 22px;
    bottom: 22px;
    max-width: 380px;
    padding: 20px 22px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(18,34,28,.88), rgba(17,30,25,.94));
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 24px 50px rgba(0,0,0,.22);
    z-index: 5;
}

.gc-territory__panel.is-empty {
    background: linear-gradient(180deg, rgba(18,34,28,.72), rgba(17,30,25,.82));
}

.gc-territory__panel-kicker {
    margin: 0 0 8px;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.56);
}

.gc-territory__panel h3 {
    margin: 0;
    font-family: var(--gc-serif);
    font-size: clamp(2.1rem, 3vw, 2.9rem);
    line-height: .96;
}

.gc-territory__panel-title {
    margin: 10px 0 0;
    font-weight: 700;
    color: rgba(255,255,255,.92);
}

.gc-territory__panel-text {
    margin: 10px 0 0;
    color: rgba(255,255,255,.72);
    font-size: .98rem;
    line-height: 1.55;
}

.gc-territory__panel-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}

.gc-territory__panel-tags:empty { display: none; }

.gc-territory__panel-tags span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.92);
    font-size: .78rem;
    font-weight: 700;
}

.gc-territory__panel-tags span::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--gc-yellow);
}

.gc-territory__map[data-active-orbit="core"] .gc-territory__orbit--inner,
.gc-territory__map[data-active-orbit="mid"] .gc-territory__orbit--mid,
.gc-territory__map[data-active-orbit="outer"] .gc-territory__orbit--outer {
    border-color: rgba(212,193,87,.48);
    box-shadow: 0 0 0 1px rgba(212,193,87,.08), 0 0 36px rgba(212,193,87,.08);
}

.gc-territory__map[data-active-orbit="core"] .gc-territory__orbit--inner { transform: translate(-50%, -50%) scale(1.03); }
.gc-territory__map[data-active-orbit="mid"] .gc-territory__orbit--mid { transform: translate(-50%, -50%) scale(1.03); }
.gc-territory__map[data-active-orbit="outer"] .gc-territory__orbit--outer { transform: translate(-50%, -50%) scale(1.03); }

.gc-territory__map[data-active-key="figueres"] .gc-territory__glow { transform: translate(-50%, -50%) scale(.86); }
.gc-territory__map[data-active-key="roses"] .gc-territory__glow { transform: translate(-18%, -8%) scale(1.02); }
.gc-territory__map[data-active-key="llanca"] .gc-territory__glow { transform: translate(8%, -38%) scale(.98); }
.gc-territory__map[data-active-key="cadaques"] .gc-territory__glow { transform: translate(26%, -44%) scale(1.08); }
.gc-territory__map[data-active-key="vilafant"] .gc-territory__glow { transform: translate(-84%, -4%) scale(.96); }
.gc-territory__map[data-active-key="castello"] .gc-territory__glow { transform: translate(8%, 28%) scale(1.06); }

@keyframes gc-territory-breathe {
    0%, 100% { opacity: .7; }
    50% { opacity: 1; }
}

@keyframes gc-orbit-ring {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes gc-orbit-ring-reverse {
    from { transform: translate(-50%, -50%) rotate(360deg); }
    to { transform: translate(-50%, -50%) rotate(0deg); }
}

@keyframes gc-orbit-node {
    from { transform: rotate(var(--angle)); }
    to { transform: rotate(calc(var(--angle) + 1turn)); }
}

@keyframes gc-orbit-counter {
    from { transform: translateX(var(--radius)) rotate(calc(var(--angle) * -1)); }
    to { transform: translateX(var(--radius)) rotate(calc((var(--angle) + 1turn) * -1)); }
}

@media (max-width: 1080px) {
    .gc-territory__map--interactive { min-height: 580px; }
    .gc-territory__panel { max-width: 340px; }
}

@media (max-width: 720px) {
    .gc-territory__map--interactive {
        min-height: auto;
        padding: 24px 18px 18px;
        border-radius: 28px;
    }

    .gc-territory__map-shell {
        position: relative;
        height: 360px;
        margin-bottom: 16px;
    }

    .gc-territory__nodes {
        position: absolute;
        inset: 0 0 auto;
        height: 360px;
    }

    .gc-territory__orbit--outer { width: min(92%, 340px); }
    .gc-territory__orbit--mid { width: min(68%, 250px); }
    .gc-territory__orbit--inner { width: min(40%, 150px); }

    .gc-territory__orbiter { --radius: 110px !important; }
    .gc-territory__orbiter--outer { --radius: 148px !important; }

    .gc-territory__node { padding: 9px 12px; font-size: .82rem; }

    .gc-territory__panel {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        max-width: none;
        margin-top: 14px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .gc-territory__orbit,
    .gc-territory__glow,
    .gc-territory__orbiter,
    .gc-territory__orbiter-counter {
        animation: none !important;
    }
}


/* v0.5.18 — órbitas visibles, panel con cierre y nodos dentro del marco */
.gc-territory__map.gc-territory__map--interactive .gc-territory__map-shell,
.gc-territory__map.gc-territory__map--interactive .gc-territory__nodes {
    position: absolute;
    inset: 0;
}

.gc-territory__map.gc-territory__map--interactive .gc-territory__orbit,
.gc-territory__map.gc-territory__map--interactive .gc-territory__center-ring,
.gc-territory__map.gc-territory__map--interactive .gc-territory__glow,
.gc-territory__map.gc-territory__map--interactive .gc-territory__dynamic-connector {
    position: absolute;
}

.gc-territory__map.gc-territory__map--interactive .gc-territory__orbit {
    left: 50%;
    top: 50%;
    border-color: rgba(255,255,255,.22);
}

.gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--outer {
    width: 410px;
    max-width: calc(100% - 150px);
}

.gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--mid {
    width: 290px;
    max-width: calc(100% - 250px);
}

.gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--inner {
    width: 180px;
    max-width: calc(100% - 340px);
}

.gc-territory__node {
    max-width: 150px;
    white-space: normal;
    text-align: center;
}

.gc-territory__node > span {
    display: block;
    white-space: normal;
    line-height: 1.08;
}

.gc-territory__node[data-key="castello"] {
    max-width: 132px;
    font-size: .8rem;
}

.gc-territory__panel[hidden] {
    display: none !important;
}

.gc-territory__panel {
    padding: 24px 54px 22px 24px;
}

.gc-territory__panel-close {
    position: absolute;
    right: 16px;
    top: 16px;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    padding: 0;
    border: 1px solid rgba(255,255,255,.16);
    border-radius: 50%;
    background: rgba(255,255,255,.08);
    color: var(--gc-white);
    font: inherit;
    font-size: 1.45rem;
    line-height: 1;
    cursor: pointer;
    transition: background .2s ease, transform .2s ease, border-color .2s ease;
}

.gc-territory__panel-close:hover,
.gc-territory__panel-close:focus-visible {
    background: rgba(212,193,87,.18);
    border-color: rgba(212,193,87,.42);
    transform: rotate(5deg) scale(1.04);
}

@media (max-width: 1080px) {
    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--outer {
        width: 360px;
        max-width: calc(100% - 140px);
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--mid {
        width: 260px;
        max-width: calc(100% - 230px);
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--inner {
        width: 160px;
        max-width: calc(100% - 320px);
    }
}

@media (max-width: 720px) {
    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--outer {
        width: 220px;
        max-width: none;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--mid {
        width: 150px;
        max-width: none;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--inner {
        width: 92px;
        max-width: none;
    }

    .gc-territory__orbiter--mid {
        --radius: 72px !important;
    }

    .gc-territory__orbiter--outer {
        --radius: 104px !important;
    }

    .gc-territory__node {
        max-width: 108px;
        padding: 8px 10px;
        font-size: .76rem;
    }

    .gc-territory__node[data-key="castello"] {
        max-width: 108px;
        font-size: .7rem;
    }

    .gc-territory__panel {
        padding: 22px 50px 20px 20px;
    }
}

/* v0.5.19 — corrección completa del mapa orbital en móvil */
@media (max-width: 720px) {
    .gc-territory__map.gc-territory__map--interactive {
        min-height: 0;
        height: auto;
        padding: 18px;
        overflow: hidden;
        border-radius: 28px;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__map-shell {
        position: relative;
        inset: auto;
        width: 100%;
        height: clamp(330px, 92vw, 380px);
        margin: 0;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__nodes {
        position: absolute;
        top: 18px;
        right: 18px;
        bottom: auto;
        left: 18px;
        height: clamp(330px, 92vw, 380px);
        pointer-events: none;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__node,
    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbiter,
    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbiter-counter {
        pointer-events: auto;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--outer {
        width: 220px;
        max-width: none;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--mid {
        width: 150px;
        max-width: none;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--inner {
        width: 90px;
        max-width: none;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbiter--mid {
        --radius: 66px !important;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbiter--outer {
        --radius: 98px !important;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__node {
        max-width: 92px;
        padding: 7px 9px;
        font-size: .72rem;
        line-height: 1.05;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__node[data-key="castello"] {
        max-width: 92px;
        padding-inline: 8px;
        font-size: .64rem;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__panel {
        position: relative;
        inset: auto;
        width: 100%;
        max-width: none;
        margin: 14px 0 0;
        padding: 22px 48px 20px 20px;
        z-index: 6;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__panel h3 {
        padding-right: 4px;
        font-size: clamp(2rem, 10vw, 2.7rem);
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__panel-title,
    .gc-territory__map.gc-territory__map--interactive .gc-territory__panel-text {
        font-size: .95rem;
    }
}

@media (max-width: 380px) {
    .gc-territory__map.gc-territory__map--interactive .gc-territory__map-shell,
    .gc-territory__map.gc-territory__map--interactive .gc-territory__nodes {
        height: 330px;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--outer {
        width: 204px;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbit--mid {
        width: 140px;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbiter--mid {
        --radius: 62px !important;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__orbiter--outer {
        --radius: 90px !important;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__node {
        max-width: 84px;
        font-size: .68rem;
    }

    .gc-territory__map.gc-territory__map--interactive .gc-territory__node[data-key="castello"] {
        max-width: 84px;
        font-size: .6rem;
    }
}

/* v0.5.22 — jerarquía del título y separación de la imagen en artículos */
.gc-article__header {
    position: relative;
    z-index: 2;
    padding-bottom: 104px;
    overflow: visible;
}

.gc-article__header .gc-article__narrow {
    position: relative;
    z-index: 2;
}

.gc-article h1 {
    max-width: 12ch;
    margin: 0;
    font-size: clamp(3.45rem, 6.6vw, 6.25rem);
    line-height: .96;
    letter-spacing: -.035em;
    overflow-wrap: normal;
    word-break: normal;
}

.gc-article__lead {
    max-width: 680px;
    margin-top: 28px;
}

.gc-article__image {
    position: relative;
    z-index: 1;
    width: min(calc(100% - 40px), 820px);
    max-width: 820px;
    margin-top: 48px;
}

@media (max-width: 760px) {
    .gc-article__header {
        padding-top: 138px;
        padding-bottom: 64px;
    }

    .gc-article h1 {
        max-width: none;
        font-size: clamp(2.85rem, 12vw, 4.45rem);
        line-height: .98;
    }

    .gc-article__lead {
        margin-top: 22px;
    }

    .gc-article__image {
        width: calc(100% - 36px);
        margin-top: 30px;
    }
}
