:root {
    --turquoise: #08a7bc;
    --turquoise-dark: #07889a;
    --ink: #17191b;
    --graphite: #62676a;
    --paper: #f7f7f4;
    --sand: #ebe7df;
    --white: #fff;
    --border: rgba(23, 25, 27, .13);
    --shadow: 0 24px 65px rgba(27, 34, 36, .14);
    --radius: 4px;
    --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    color: var(--ink);
    background: var(--white);
    font-family: "DM Sans", sans-serif;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
.container { width: min(calc(100% - 48px), var(--container)); margin-inline: auto; }
.narrow { max-width: 900px; }
.section { padding: 120px 0; }
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.skip-link { position: fixed; top: -60px; left: 16px; z-index: 100; padding: 12px 18px; background: var(--ink); color: white; }
.skip-link:focus { top: 12px; }

.site-header {
    position: fixed;
    inset: 0 0 auto;
    z-index: 50;
    transition: color .3s ease, background .3s ease, box-shadow .3s ease;
}
.site-header.is-scrolled { background: rgba(255, 255, 255, .94); box-shadow: 0 8px 30px rgba(20, 25, 26, .08); backdrop-filter: blur(14px); }
.header-inner { min-height: 110px; display: flex; align-items: center; justify-content: space-between; gap: 30px; }
.brand { position: relative; width: 166px; height: 86px; flex: 0 0 auto; }
.brand-logo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: contain; transition: opacity .25s ease; }
.brand-logo-light { opacity: 0; }
.site-header--dark { color: white; }
.site-header--dark .brand-logo-dark { opacity: 0; }
.site-header--dark .brand-logo-light { opacity: 1; }
.site-header--dark.is-scrolled { color: var(--ink); }
.site-header--dark.is-scrolled .brand-logo-dark { opacity: 1; }
.site-header--dark.is-scrolled .brand-logo-light { opacity: 0; }
.site-nav { display: flex; align-items: center; gap: 31px; font-size: .91rem; font-weight: 600; }
.site-nav > a:not(.button) { position: relative; padding: 43px 0; }
.site-nav > a:not(.button)::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 35px;
    left: 0;
    height: 2px;
    background: var(--turquoise);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform .25s ease;
}
.site-nav > a:hover::after, .site-nav > a.is-active::after { transform: scaleX(1); transform-origin: left; }
.menu-toggle { display: none; background: none; border: 0; width: 42px; height: 42px; padding: 9px; }
.menu-toggle span:not(.sr-only) { display: block; width: 24px; height: 2px; margin: 5px 0; background: var(--ink); transition: .2s ease; }
.site-header--dark:not(.is-scrolled) .menu-toggle span:not(.sr-only) { background: white; }

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 27px;
    border: 1px solid var(--turquoise);
    border-radius: var(--radius);
    color: var(--white);
    background: var(--turquoise);
    font-weight: 700;
    cursor: pointer;
    transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.button:hover { transform: translateY(-2px); background: var(--turquoise-dark); box-shadow: 0 12px 25px rgba(8, 167, 188, .22); }
.button-small { min-height: 44px; padding-inline: 20px; }
.button-light { color: var(--ink); background: var(--white); border-color: var(--white); }
.button-light:hover { color: white; background: transparent; }
.text-link { display: inline-flex; align-items: center; gap: 12px; padding-bottom: 4px; border-bottom: 1px solid currentColor; font-weight: 700; }
.text-link span { color: var(--turquoise); transition: transform .2s ease; }
.text-link:hover span { transform: translateX(4px); }
.eyebrow { margin: 0 0 16px; color: var(--turquoise-dark); font-size: .76rem; font-weight: 800; letter-spacing: .19em; text-transform: uppercase; }
.section-index { margin: 0 0 42px; color: #929698; font-size: .7rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
h1, h2, h3 { margin-top: 0; font-family: "Manrope", sans-serif; line-height: 1.12; }
h1 { font-size: clamp(3rem, 6.2vw, 6rem); letter-spacing: -.055em; }
h2 { font-size: clamp(2.25rem, 4.2vw, 4rem); letter-spacing: -.045em; }
h3 { letter-spacing: -.025em; }

.hero { position: relative; min-height: 820px; overflow: hidden; background: var(--paper); }
.hero::after {
    content: "";
    position: absolute;
    top: -320px;
    right: -270px;
    width: 750px;
    height: 750px;
    border: 1px solid rgba(98, 103, 106, .2);
    border-radius: 50%;
}
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr .92fr; align-items: center; min-height: 820px; padding-top: 105px; }
.hero-content { padding: 68px 5vw 80px 0; }
.hero h1 { max-width: 700px; margin-bottom: 28px; }
.hero h1 em { color: var(--turquoise); font-family: Georgia, serif; font-weight: 400; }
.hero-copy { max-width: 580px; margin: 0 0 38px; color: var(--graphite); font-size: 1.13rem; }
.hero-actions { display: flex; align-items: center; gap: 30px; }
.hero-trust { display: flex; gap: 54px; margin-top: 68px; padding-top: 25px; border-top: 1px solid var(--border); }
.hero-trust div { display: grid; grid-template-columns: auto 100px; align-items: center; gap: 11px; }
.hero-trust strong { color: var(--turquoise-dark); font-family: "Manrope"; font-size: 1.6rem; }
.hero-trust span { color: var(--graphite); font-size: .75rem; line-height: 1.35; }
.hero-visual { position: relative; height: 620px; }
.hero-image {
    position: absolute;
    inset: 10px 0 0 40px;
    background:
        linear-gradient(160deg, rgba(255,255,255,.06), rgba(18,25,25,.14)),
        url("../img/showcase/inicio-hero.webp") center/cover;
    box-shadow: var(--shadow);
}
.hero-image::after { content: ""; position: absolute; inset: auto 0 0; height: 35%; background: linear-gradient(transparent, rgba(15,20,21,.28)); }
.material-card {
    position: absolute;
    left: -22px;
    bottom: 34px;
    z-index: 2;
    display: flex;
    align-items: center;
    gap: 13px;
    width: 222px;
    padding: 15px;
    background: white;
    box-shadow: 0 12px 40px rgba(20, 28, 29, .18);
}
.material-card strong, .material-card small { display: block; }
.material-card strong { font-size: .82rem; }
.material-card small { color: var(--graphite); font-size: .7rem; }
.material-swatch { width: 48px; height: 48px; background: repeating-linear-gradient(90deg, #b48c64 0 7px, #9b7451 7px 8px, #c59d74 8px 16px); }
.line-drawing { position: absolute; right: -60px; bottom: -56px; z-index: 3; width: 190px; }
.line-drawing path { fill: none; stroke: var(--turquoise); stroke-width: 1.4; }
.scroll-cue { position: absolute; bottom: 28px; left: 24px; z-index: 3; display: flex; align-items: center; gap: 14px; color: var(--graphite); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; transform: rotate(-90deg); transform-origin: left center; }
.scroll-cue i { display: block; width: 54px; height: 1px; background: var(--turquoise); }
.hero-texture { position: absolute; inset: 0 50% 0 0; opacity: .16; background-image: linear-gradient(90deg, transparent 97%, #d8d3ca 97%), linear-gradient(0deg, transparent 97%, #d8d3ca 97%); background-size: 38px 38px; mask-image: linear-gradient(90deg, black, transparent); }

.intro { background: white; }
.intro-grid { display: grid; grid-template-columns: .55fr 1.5fr .8fr; gap: 65px; align-items: start; }
.intro h2 { margin-bottom: 0; }
.intro h2 span { color: #8a8e90; }
.intro-copy { padding-top: 65px; }
.intro-copy p { margin: 0 0 28px; color: var(--graphite); font-size: 1.04rem; }

.services { background: var(--ink); color: white; }
.services .section-index { color: #717779; }
.section-heading { display: flex; align-items: flex-end; justify-content: space-between; gap: 50px; margin-bottom: 56px; }
.section-heading h2 { margin-bottom: 0; }
.section-heading > p { max-width: 430px; margin: 0; color: var(--graphite); }
.services .section-heading > p { color: #a7adaf; }
.services-carousel { position: relative; }
.carousel-controls { display: flex; justify-content: flex-end; gap: 12px; margin: -18px 0 22px; }
.carousel-button {
    display: grid;
    place-items: center;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(255,255,255,.22);
    border-radius: 50%;
    color: white;
    background: transparent;
    cursor: pointer;
    transition: border-color .2s ease, background .2s ease, color .2s ease, transform .2s ease, opacity .2s ease;
}
.carousel-button:hover:not(:disabled) { border-color: var(--turquoise); background: var(--turquoise); transform: translateY(-2px); }
.carousel-button:disabled { cursor: not-allowed; opacity: .35; }
.service-grid {
    --service-card-width: 25%;
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    border-top: 1px solid rgba(255,255,255,.13);
    border-left: 1px solid rgba(255,255,255,.13);
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}
.service-grid::-webkit-scrollbar { display: none; }
.service-grid:focus-visible { outline: 2px solid var(--turquoise); outline-offset: 8px; }
.service-card { position: relative; min-height: 410px; padding: 42px 31px 34px; border-right: 1px solid rgba(255,255,255,.13); border-bottom: 1px solid rgba(255,255,255,.13); transition: background .3s ease, transform .3s ease; }
.service-grid .service-card { flex: 0 0 var(--service-card-width); scroll-snap-align: start; }
.service-card:hover, .service-card-featured { background: var(--turquoise); transform: translateY(-7px); }
.service-number { position: absolute; top: 20px; right: 24px; color: #777c7e; font-size: .7rem; }
.service-card:hover .service-number, .service-card-featured .service-number { color: rgba(255,255,255,.65); }
.service-icon { width: 56px; height: 56px; margin: 35px 0 48px; }
.service-icon svg { fill: none; stroke: var(--turquoise); stroke-linecap: round; stroke-linejoin: round; stroke-width: 1.6; }
.service-card:hover svg, .service-card-featured svg { stroke: white; }
.service-card h3 { margin-bottom: 18px; font-size: 1.4rem; }
.service-card p { min-height: 93px; margin: 0 0 25px; color: #a9adaf; font-size: .9rem; }
.service-card:hover p, .service-card-featured p { color: rgba(255,255,255,.85); }
.service-card a { display: flex; justify-content: space-between; color: white; font-size: .78rem; font-weight: 700; }

.process { background: var(--sand); }
.process .container { display: grid; grid-template-columns: .9fr 1.1fr; gap: 120px; }
.process-intro > p:last-child { max-width: 480px; color: var(--graphite); }
.process-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid rgba(23,25,27,.25); }
.process-list li { display: grid; grid-template-columns: 65px 1fr; gap: 20px; padding: 37px 0; border-bottom: 1px solid rgba(23,25,27,.25); }
.process-list > li > span { color: var(--turquoise-dark); font-size: .72rem; font-weight: 800; }
.process-list h3 { margin-bottom: 9px; font-size: 1.35rem; }
.process-list p { margin: 0; color: var(--graphite); }

.projects { overflow: hidden; background: white; }
.project-grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: 32px; }
.project-card-large { grid-row: span 2; }
.project-image { height: 280px; overflow: hidden; background-color: #ddd; background-position: center; background-size: cover; transition: transform .45s ease, filter .45s ease; }
.project-card-large .project-image { height: 618px; }
.project-card:hover .project-image { transform: scale(.985); filter: saturate(1.1); }
.project-meta { display: flex; justify-content: space-between; align-items: center; padding: 18px 2px 0; }
.project-meta span { color: var(--turquoise-dark); font-size: .67rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.project-meta h3, .project-meta h2 { margin: 6px 0 0; font-size: 1.22rem; }
.project-meta i { display: grid; place-items: center; width: 40px; height: 40px; border: 1px solid var(--border); border-radius: 50%; color: var(--turquoise-dark); font-style: normal; }
.projects-archive { background: var(--paper); }
.project-toolbar { display: flex; align-items: flex-end; justify-content: space-between; gap: 45px; margin-bottom: 58px; }
.project-toolbar h2 { margin-bottom: 0; font-size: clamp(2.1rem, 3.5vw, 3.4rem); }
.project-filters { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 10px; }
.project-filter {
    min-height: 42px;
    padding: 0 18px;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--graphite);
    background: transparent;
    font-size: .78rem;
    font-weight: 700;
    cursor: pointer;
    transition: color .2s ease, border-color .2s ease, background .2s ease, transform .2s ease;
}
.project-filter:hover { color: var(--ink); border-color: var(--turquoise); transform: translateY(-1px); }
.project-filter.is-active { color: white; border-color: var(--turquoise); background: var(--turquoise); }
.project-grid-archive { align-items: start; }
.project-grid-archive .project-card { transition: opacity .25s ease, transform .25s ease; }
.project-grid-archive .project-card[hidden] { display: none; }
.project-empty { padding: 70px 25px; border: 1px solid var(--border); text-align: center; }
.project-empty h2 { margin-bottom: 10px; font-size: 1.8rem; }
.project-empty h3 { margin-bottom: 10px; font-size: 1.55rem; }
.project-empty p { margin: 0; color: var(--graphite); }
.project-empty-home { background: var(--paper); }
.project-pagination { display: flex; align-items: center; justify-content: center; gap: 12px; margin-top: 68px; }
.pagination-pages { display: flex; align-items: center; gap: 8px; }
.pagination-arrow,
.pagination-page {
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--ink);
    background: transparent;
    font-size: .8rem;
    font-weight: 700;
    cursor: pointer;
    transition: color .2s ease, border-color .2s ease, background .2s ease, transform .2s ease, opacity .2s ease;
}
.pagination-arrow:hover:not(:disabled),
.pagination-page:hover:not(.is-active) { border-color: var(--turquoise); transform: translateY(-2px); }
.pagination-page.is-active { color: white; border-color: var(--turquoise); background: var(--turquoise); }
.pagination-arrow:disabled { cursor: not-allowed; opacity: .3; }
.project-pagination[hidden] { display: none; }

.about-hero { padding: 200px 0 0; color: white; background: var(--ink); }
.about-hero-grid { display: grid; grid-template-columns: 1.35fr .65fr; align-items: end; gap: 90px; margin-bottom: 70px; }
.about-hero h1 { max-width: 970px; margin-bottom: 0; font-size: clamp(3.4rem, 6.3vw, 6.3rem); }
.about-hero-copy { padding-bottom: 10px; }
.about-hero-copy > p { margin: 0 0 32px; color: #aeb3b4; font-size: 1.08rem; }
.about-hero .text-link { color: white; }
.about-hero-image {
    height: min(59vw, 680px);
    min-height: 480px;
    background:
        linear-gradient(120deg, rgba(12,17,18,.08), rgba(12,17,18,.3)),
        url("../img/showcase/empresa-cabecera.webp") center 58%/cover;
}
.about-story { background: white; }
.about-story-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 115px; }
.about-story h2 { max-width: 570px; margin-bottom: 0; }
.about-story-copy { padding-top: 78px; }
.about-story-copy p { color: var(--graphite); }
.about-story-copy .about-lead { margin-top: 0; color: var(--ink); font-family: "Manrope", sans-serif; font-size: 1.35rem; font-weight: 600; line-height: 1.55; }
.about-numbers { padding: 0 0 120px; background: white; }
.about-numbers-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--border); border-left: 1px solid var(--border); }
.about-numbers-grid > div { min-height: 190px; padding: 32px; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.about-numbers strong { display: block; margin-bottom: 35px; color: var(--turquoise-dark); font-family: "Manrope", sans-serif; font-size: 2.7rem; line-height: 1; }
.about-numbers span { display: block; max-width: 150px; color: var(--graphite); font-size: .8rem; line-height: 1.45; }
.about-philosophy { background: var(--sand); }
.about-philosophy-grid { display: grid; grid-template-columns: 1.1fr .9fr; align-items: center; gap: 105px; }
.about-philosophy-images { position: relative; min-height: 680px; }
.about-image { position: absolute; background-position: center; background-size: cover; box-shadow: var(--shadow); }
.about-image-main { inset: 0 95px 75px 0; background-image: url("../img/showcase/empresa-filosofia.webp"); background-position: center 62%; }
.about-image-detail { right: 0; bottom: 0; width: 260px; height: 300px; border: 12px solid var(--sand); background-image: url("../img/showcase/empresa-detalle.webp"); background-position: center 68%; }
.about-philosophy-content > p:not(.eyebrow):not(.section-index) { color: var(--graphite); font-size: 1.04rem; }
.about-philosophy blockquote { margin: 42px 0; padding: 26px 0 26px 28px; border-left: 2px solid var(--turquoise); font-family: "Manrope", sans-serif; font-size: 1.3rem; font-weight: 600; line-height: 1.55; }
.about-values { color: white; background: var(--ink); }
.about-values-heading { display: flex; align-items: end; justify-content: space-between; gap: 60px; margin-bottom: 58px; }
.about-values-heading h2 { max-width: 650px; margin-bottom: 0; }
.about-values-heading > p { max-width: 380px; margin: 0; color: #aeb3b4; }
.about-values-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(255,255,255,.14); border-left: 1px solid rgba(255,255,255,.14); }
.about-values-grid article { min-height: 315px; padding: 32px 27px; border-right: 1px solid rgba(255,255,255,.14); border-bottom: 1px solid rgba(255,255,255,.14); transition: background .25s ease, transform .25s ease; }
.about-values-grid article:hover { background: var(--turquoise-dark); transform: translateY(-5px); }
.about-values-grid span { color: var(--turquoise); font-size: .68rem; font-weight: 800; }
.about-values-grid h3 { margin: 75px 0 18px; font-size: 1.35rem; }
.about-values-grid p { margin: 0; color: #aeb3b4; font-size: .88rem; }
.about-values-grid article:hover p { color: rgba(255,255,255,.82); }
.about-method { background: var(--paper); }
.about-method-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 115px; }
.about-method-grid > div > p:last-child { max-width: 430px; color: var(--graphite); }
.about-method-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid var(--border); }
.about-method-list li { display: grid; grid-template-columns: 60px 1fr; gap: 24px; padding: 30px 0; border-bottom: 1px solid var(--border); }
.about-method-list > li > span { color: var(--turquoise-dark); font-size: .7rem; font-weight: 800; }
.about-method-list h3 { margin-bottom: 8px; font-size: 1.25rem; }
.about-method-list p { margin: 0; color: var(--graphite); }
.about-work-preview { padding: 0; background: white; }
.about-work-grid { display: grid; grid-template-columns: 1.2fr .8fr; width: 100%; max-width: none; }
.about-work-image { min-height: 610px; background: url("../img/showcase/empresa-trabajos.webp") center/cover; }
.about-work-content { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: 80px max(40px, calc((100vw - var(--container)) / 2)); background: white; }
.about-work-content h2 { max-width: 570px; }
.about-work-content > p:not(.eyebrow) { max-width: 510px; margin-bottom: 32px; color: var(--graphite); }

.services-page-hero { padding: 210px 0 70px; color: white; background: var(--ink); }
.services-hero-grid { display: grid; grid-template-columns: 1.35fr .65fr; align-items: end; gap: 90px; }
.services-page-hero h1 { max-width: 950px; margin-bottom: 0; font-size: clamp(3.4rem, 6.5vw, 6.5rem); }
.services-hero-copy { padding-bottom: 12px; }
.services-hero-copy p { margin: 0 0 30px; color: #aeb3b4; font-size: 1.05rem; }
.service-jump-nav { display: grid; grid-template-columns: repeat(6, 1fr); margin-top: 85px; border-top: 1px solid rgba(255,255,255,.14); border-left: 1px solid rgba(255,255,255,.14); }
.service-jump-nav a { min-height: 105px; padding: 22px 18px; border-right: 1px solid rgba(255,255,255,.14); border-bottom: 1px solid rgba(255,255,255,.14); color: #c5c9ca; font-size: .78rem; font-weight: 700; transition: color .2s ease, background .2s ease; }
.service-jump-nav span { display: block; margin-bottom: 14px; color: var(--turquoise); font-size: .66rem; }
.service-jump-nav a:hover { color: white; background: var(--turquoise-dark); }
.services-detail-list { background: white; }
.service-detail { padding: 120px 0; scroll-margin-top: 90px; }
.service-detail:nth-child(even) { background: var(--paper); }
.service-detail-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 105px; }
.service-detail-reversed .service-detail-image { order: 2; }
.service-detail-image { position: relative; min-height: 620px; background-position: center; background-size: cover; box-shadow: var(--shadow); }
.service-detail-image::after { content: ""; position: absolute; inset: 0; background: linear-gradient(150deg, transparent 55%, rgba(10,15,16,.36)); }
.service-detail-image > span { position: absolute; right: 28px; bottom: 22px; z-index: 2; color: white; font-family: "Manrope", sans-serif; font-size: 3.5rem; font-weight: 700; }
.service-detail-parquet { background-image: url("../img/showcase/servicio-parquet.webp"); background-position: center 64%; }
.service-detail-vinyl { background-image: url("../img/showcase/servicio-vinilico.webp"); background-position: center 70%; }
.service-detail-slats { background-image: url("../img/showcase/servicio-palilleria.webp"); background-position: center; }
.service-detail-restoration { background-image: url("../img/showcase/servicio-restauracion.webp"); background-position: center 62%; }
.service-detail-stairs { background-image: url("../img/showcase/servicio-escaleras.webp"); background-position: center 42%; }
.service-detail-walls { background-image: url("../img/showcase/servicio-revestimientos.webp"); background-position: center; }
.service-detail-content h2 { margin-bottom: 16px; }
.service-detail-content h3 { max-width: 520px; margin-bottom: 28px; color: var(--turquoise-dark); font-size: 1.25rem; }
.service-detail-content > p { max-width: 610px; margin-bottom: 32px; color: var(--graphite); font-size: 1.04rem; }
.service-detail-content ul { margin: 0 0 42px; padding: 0; list-style: none; border-top: 1px solid var(--border); }
.service-detail-content li { position: relative; padding: 15px 0 15px 28px; border-bottom: 1px solid var(--border); font-size: .88rem; font-weight: 600; }
.service-detail-content li::before { content: "✓"; position: absolute; left: 2px; color: var(--turquoise-dark); }
.service-detail-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 28px; }
.service-advice { color: white; background: var(--ink); }
.service-advice-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 110px; }
.service-advice h2 { margin-bottom: 0; }
.advice-points { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid rgba(255,255,255,.15); border-left: 1px solid rgba(255,255,255,.15); }
.advice-points > div { min-height: 220px; padding: 27px; border-right: 1px solid rgba(255,255,255,.15); border-bottom: 1px solid rgba(255,255,255,.15); }
.advice-points span { color: var(--turquoise); font-size: .67rem; font-weight: 800; }
.advice-points h3 { margin: 35px 0 10px; font-size: 1.15rem; }
.advice-points p { margin: 0; color: #aeb3b4; font-size: .85rem; }

.project-detail { background: white; }
.project-detail-hero { padding: 145px 0 0; color: white; background: var(--ink); }
.breadcrumbs { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 60px; color: #878d8f; font-size: .75rem; }
.breadcrumbs a:hover { color: var(--turquoise); }
.breadcrumbs span[aria-current="page"] { color: white; }
.project-detail-heading { display: grid; grid-template-columns: 1.4fr .6fr; align-items: end; gap: 60px; margin-bottom: 58px; }
.project-detail-heading h1 { max-width: 900px; margin-bottom: 0; font-size: clamp(3.5rem, 7vw, 7.2rem); }
.project-detail-heading > p { margin: 0 0 12px; color: #aeb3b4; text-align: right; }
.project-cover {
    position: relative;
    display: block;
    width: 100%;
    height: min(68vw, 720px);
    min-height: 480px;
    padding: 0;
    border: 0;
    background-position: center;
    background-size: cover;
    cursor: zoom-in;
}
.project-cover::after { content: ""; position: absolute; inset: 50% 0 0; background: linear-gradient(transparent, rgba(10,15,16,.42)); }
.project-cover > span {
    position: absolute;
    right: 30px;
    bottom: 28px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 12px 17px;
    color: var(--ink);
    background: white;
    font-size: .78rem;
    font-weight: 700;
}
.project-cover i { color: var(--turquoise-dark); font-style: normal; }
.project-story { background: var(--paper); }
.project-story-grid { display: grid; grid-template-columns: .65fr 1.35fr; gap: 110px; align-items: start; }
.project-facts { position: sticky; top: 125px; }
.project-facts dl { margin: 0; border-top: 1px solid var(--border); }
.project-facts dl div { display: grid; grid-template-columns: 1fr 1.25fr; gap: 25px; padding: 18px 0; border-bottom: 1px solid var(--border); }
.project-facts dt { color: #888d8f; font-size: .74rem; font-weight: 700; text-transform: uppercase; }
.project-facts dd { margin: 0; font-size: .88rem; font-weight: 600; }
.project-narrative h2 { max-width: 780px; margin-bottom: 35px; }
.project-lead { max-width: 790px; margin: 0 0 55px; color: var(--graphite); font-size: 1.22rem; line-height: 1.85; }
.project-text-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; padding-top: 42px; border-top: 1px solid var(--border); }
.project-text-columns h3 { margin-bottom: 14px; font-size: 1.1rem; }
.project-text-columns p { margin: 0; color: var(--graphite); }
.share-project { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 55px; padding-top: 28px; border-top: 1px solid var(--border); }
.share-project > span { margin-right: 8px; font-size: .76rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.share-project a,
.share-project button {
    padding: 8px 13px;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--graphite);
    background: transparent;
    font-size: .72rem;
    font-weight: 700;
    cursor: pointer;
}
.share-project a:hover,
.share-project button:hover { color: white; border-color: var(--turquoise); background: var(--turquoise); }
.share-project small { flex-basis: 100%; min-height: 18px; color: var(--turquoise-dark); }
.project-gallery-section { background: white; }
.project-gallery-heading { display: flex; justify-content: space-between; align-items: end; gap: 40px; margin-bottom: 50px; }
.project-gallery-heading h2 { margin-bottom: 0; }
.project-gallery-heading > p { max-width: 330px; margin: 0; color: var(--graphite); }
.project-detail-gallery { display: grid; grid-template-columns: 1.35fr 1fr; grid-auto-rows: 300px; gap: 22px; }
.gallery-item {
    min-height: 300px;
    padding: 0;
    border: 0;
    background-position: center;
    background-size: cover;
    cursor: zoom-in;
    transition: filter .3s ease, transform .3s ease;
}
.gallery-item:hover { filter: brightness(.88); transform: scale(.992); }
.gallery-item-large { grid-row: span 2; min-height: 622px; }
.project-result { padding: 105px 0; color: white; background: var(--ink); text-align: center; }
.project-result-inner { max-width: 900px; }
.project-result blockquote { margin: 0 auto 30px; font-family: "Manrope", sans-serif; font-size: clamp(2.2rem, 4vw, 4rem); font-weight: 600; letter-spacing: -.045em; line-height: 1.2; }
.project-result-inner > p:last-child { max-width: 650px; margin: 0 auto; color: #aeb3b4; }
.project-detail-navigation { display: grid; grid-template-columns: 1fr 1fr; background: var(--paper); }
.project-detail-navigation a { display: flex; flex-direction: column; min-height: 170px; padding: 42px max(30px, calc((100vw - var(--container)) / 2)); border-right: 1px solid var(--border); }
.project-detail-navigation a:last-child { align-items: flex-end; text-align: right; border-right: 0; }
.project-detail-navigation span { margin-bottom: 12px; color: var(--turquoise-dark); font-size: .72rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.project-detail-navigation strong { max-width: 460px; font-family: "Manrope", sans-serif; font-size: clamp(1.15rem, 2vw, 1.65rem); }
.project-detail-navigation a:hover strong { color: var(--turquoise-dark); }
.gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: grid;
    grid-template-columns: 70px 1fr 70px;
    grid-template-rows: 1fr auto;
    align-items: center;
    padding: 70px 30px 25px;
    color: white;
    background: rgba(8, 11, 12, .96);
}
.gallery-lightbox[hidden] { display: none; }
.lightbox-image { width: 100%; height: 100%; max-height: calc(100vh - 120px); background-position: center; background-repeat: no-repeat; background-size: contain; }
.lightbox-close,
.lightbox-arrow { border: 1px solid rgba(255,255,255,.24); border-radius: 50%; color: white; background: transparent; cursor: pointer; }
.lightbox-close { position: absolute; top: 20px; right: 25px; width: 44px; height: 44px; font-size: 1.6rem; }
.lightbox-arrow { width: 48px; height: 48px; justify-self: center; }
.gallery-lightbox > p { grid-column: 1 / -1; margin: 12px 0 0; color: #aeb3b4; text-align: center; font-size: .78rem; }
body.lightbox-open { overflow: hidden; }
.preview-banner { position: sticky; top: 0; z-index: 80; display: flex; align-items: center; justify-content: center; gap: 18px; padding: 11px 24px; color: #4f410d; background: #f3d966; font-size: .78rem; }
.preview-banner strong { font-family: "Manrope", sans-serif; }
.preview-banner a { padding-bottom: 2px; border-bottom: 1px solid currentColor; font-weight: 700; }

.cta-section { position: relative; overflow: hidden; padding: 115px 0; color: white; background: var(--turquoise-dark); text-align: center; }
.cta-content { position: relative; z-index: 2; }
.cta-section .eyebrow { color: rgba(255,255,255,.7); }
.cta-section h2 { max-width: 850px; margin: 0 auto 22px; }
.cta-section p:not(.eyebrow) { max-width: 590px; margin: 0 auto 36px; color: rgba(255,255,255,.82); }
.cta-pattern { position: absolute; inset: -130px; opacity: .18; background: repeating-linear-gradient(45deg, transparent 0 24px, white 24px 25px); transform: rotate(-9deg); }

.site-footer { padding: 80px 0 105px; color: #b7bbbd; background: #111315; font-size: .86rem; }
.footer-grid { display: grid; grid-template-columns: 2fr repeat(3, 1fr); gap: 70px; padding-bottom: 65px; }
.footer-brand img { width: 230px; margin-bottom: 25px; }
.footer-brand p { max-width: 330px; }
.site-footer h2 { margin-bottom: 22px; color: white; font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; }
.site-footer a, .site-footer div > p { display: block; margin: 0 0 10px; }
.site-footer a:hover { color: var(--turquoise); }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 23px; border-top: 1px solid rgba(255,255,255,.1); color: #777d80; font-size: .73rem; }
.footer-bottom p { margin: 0; }
.footer-legal { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 18px; }
.footer-legal a { margin: 0; }
.whatsapp-float {
    position: fixed;
    right: 24px;
    bottom: 24px;
    z-index: 70;
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 60px;
    padding: 8px 18px 8px 9px;
    border-radius: 999px;
    color: white;
    background: #1f9d55;
    box-shadow: 0 12px 35px rgba(11, 58, 34, .28);
    transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}
.whatsapp-float:hover { color: white; background: #188447; transform: translateY(-3px); box-shadow: 0 16px 38px rgba(11, 58, 34, .34); }
.whatsapp-float-icon { display: grid; place-items: center; flex: 0 0 auto; width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.14); }
.whatsapp-float-icon svg { width: 28px; height: 28px; overflow: visible; }
.whatsapp-float-icon svg path:first-child { fill: none; stroke: currentColor; stroke-width: 1.8; }
.whatsapp-float-icon svg path:last-child { fill: currentColor; stroke: none; transform: scale(.72); transform-origin: center; }
.whatsapp-float-copy { display: grid; gap: 1px; line-height: 1.15; }
.whatsapp-float-copy small { color: rgba(255,255,255,.78); font-size: .62rem; }
.whatsapp-float-copy strong { font-size: .76rem; }

.page-hero { padding: 210px 0 110px; color: white; background: var(--ink); }
.page-hero h1 { max-width: 900px; font-size: clamp(3rem, 5.5vw, 5.5rem); }
.page-hero p:last-child { max-width: 680px; color: #b9bdbe; font-size: 1.1rem; }
.two-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; }
.two-columns p { margin-top: 0; color: var(--graphite); font-size: 1.05rem; }
.contact-section { background: var(--paper); }
.contact-grid { display: grid; grid-template-columns: .75fr 1.25fr; gap: 100px; }
.contact-grid > div > a { display: block; margin: 15px 0; color: var(--turquoise-dark); font-size: 1.25rem; font-weight: 700; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; padding: 40px; background: white; box-shadow: 0 20px 60px rgba(20,28,29,.08); }
.contact-form label { display: grid; gap: 8px; font-size: .78rem; font-weight: 700; }
.contact-form .contact-field-wide, .contact-form .checkbox, .contact-form .form-note, .contact-form .contact-alert { grid-column: 1 / -1; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid #d7dadb; border-radius: 2px; padding: 13px; outline: none; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--turquoise); box-shadow: 0 0 0 3px rgba(8,167,188,.1); }
.contact-form .checkbox { display: flex; grid-template-columns: auto 1fr; align-items: center; font-weight: 400; }
.contact-form .checkbox a { color: var(--turquoise-dark); font-weight: 700; text-decoration: underline; text-underline-offset: 2px; }
.checkbox input { width: auto; }
.contact-form .button { justify-self: start; }
.form-note { margin: 0; color: var(--graphite); font-size: .72rem; }
.contact-alert { margin: 0; padding: 14px 16px; border: 1px solid; font-size: .82rem; line-height: 1.5; }
.contact-alert ul { margin: 0; padding-left: 18px; }
.contact-alert-success { color: #126747; border-color: #a8d7c5; background: #eaf8f2; }
.contact-alert-error { color: #8a2929; border-color: #e2b5b5; background: #fff0f0; }
.contact-captcha { display: grid; grid-template-columns: 1fr 120px; align-items: end; gap: 16px; }
.contact-captcha p { margin: 0; color: var(--graphite); font-size: .76rem; font-weight: 400; }
.contact-honeypot { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.legal-hero { padding: 190px 0 95px; color: white; background: var(--ink); }
.legal-hero h1 { max-width: 900px; margin-bottom: 22px; font-size: clamp(3.2rem, 6vw, 6rem); }
.legal-hero p:last-child { max-width: 720px; color: #b9bdbe; font-size: 1.05rem; }
.legal-content { background: var(--paper); }
.legal-layout { display: grid; grid-template-columns: 230px minmax(0, 780px); justify-content: space-between; gap: 90px; }
.legal-layout > aside { position: sticky; top: 120px; align-self: start; display: grid; gap: 8px; padding-top: 6px; }
.legal-layout > aside strong { font-family: "Manrope", sans-serif; }
.legal-layout > aside a { margin-top: 12px; color: var(--turquoise-dark); font-size: .78rem; font-weight: 700; }
.legal-text { display: grid; gap: 54px; }
.legal-text section { padding-bottom: 52px; border-bottom: 1px solid var(--border); }
.legal-text section:last-child { padding-bottom: 0; border-bottom: 0; }
.legal-text h2 { margin-bottom: 22px; font-size: clamp(1.65rem, 2.6vw, 2.25rem); }
.legal-text p { color: var(--graphite); line-height: 1.75; }
.legal-text a { color: var(--turquoise-dark); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }
.legal-data { margin: 28px 0 0; border-top: 1px solid var(--border); }
.legal-data div { display: grid; grid-template-columns: 180px 1fr; gap: 24px; padding: 15px 0; border-bottom: 1px solid var(--border); }
.legal-data dt { color: var(--graphite); font-size: .72rem; font-weight: 800; text-transform: uppercase; }
.legal-data dd { margin: 0; }
.legal-table-wrap { overflow-x: auto; margin: 28px 0; }
.legal-table { width: 100%; min-width: 650px; border-collapse: collapse; background: white; font-size: .8rem; }
.legal-table th, .legal-table td { padding: 15px; border: 1px solid var(--border); text-align: left; vertical-align: top; }
.legal-table th { color: var(--graphite); background: #f8f9f8; font-size: .68rem; text-transform: uppercase; }
.legal-table code, .legal-text code { padding: 2px 5px; border-radius: 2px; background: #e9eceb; font-size: .82em; }
.error-hero { min-height: 720px; padding: 190px 0 105px; color: white; background: var(--ink); }
.error-layout { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 90px; }
.error-code { color: transparent; font-family: "Manrope", sans-serif; font-size: clamp(9rem, 20vw, 18rem); font-weight: 800; letter-spacing: -.1em; line-height: .8; -webkit-text-stroke: 1px rgba(255,255,255,.2); }
.error-content h1 { max-width: 720px; margin-bottom: 25px; font-size: clamp(3rem, 5vw, 5.4rem); }
.error-content > p:not(.eyebrow) { max-width: 600px; color: #b9bdbe; font-size: 1.05rem; line-height: 1.7; }
.error-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 28px; margin-top: 38px; }
.error-actions .text-link { color: white; }
.error-links { background: var(--paper); }
.error-link-grid { display: grid; grid-template-columns: repeat(3, 1fr); margin-top: 32px; border-top: 1px solid #d7dadb; border-left: 1px solid #d7dadb; }
.error-link-grid a { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 18px; min-height: 130px; padding: 28px; border-right: 1px solid #d7dadb; border-bottom: 1px solid #d7dadb; background: white; transition: color .2s ease, background .2s ease; }
.error-link-grid a:hover { color: white; background: var(--turquoise-dark); }
.error-link-grid span { color: var(--turquoise-dark); font-size: .68rem; font-weight: 800; }
.error-link-grid a:hover span { color: white; }
.error-link-grid strong { font-family: "Manrope", sans-serif; font-size: 1.15rem; }
.error-link-grid i { font-style: normal; }

[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
[data-reveal].is-visible { opacity: 1; transform: none; }

@media (max-width: 1020px) {
    .site-nav { gap: 18px; }
    .site-nav > a:not(.button) { font-size: .78rem; }
    .hero-grid { grid-template-columns: 1.08fr .92fr; }
    .hero-visual { height: 540px; }
    .hero-trust { gap: 24px; }
    .service-grid { --service-card-width: 50%; }
    .process .container { gap: 65px; }
}

@media (max-width: 820px) {
    .container { width: min(calc(100% - 36px), var(--container)); }
    .section { padding: 85px 0; }
    .header-inner { min-height: 88px; }
    .brand { width: 132px; height: 72px; }
    .menu-toggle { display: block; position: relative; z-index: 3; }
    .menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
    .menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
    .site-header--dark .menu-toggle[aria-expanded="true"] span:not(.sr-only) { background: var(--ink); }
    .site-nav {
        position: fixed;
        inset: 0;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        gap: 8px;
        padding: 100px 32px;
        background: white;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-10px);
        transition: .25s ease;
    }
    .site-header--dark .site-nav { color: var(--ink); }
    .site-nav.is-open { opacity: 1; visibility: visible; transform: none; }
    .site-nav > a:not(.button) { width: 100%; padding: 12px 0; font-family: "Manrope"; font-size: 1.5rem; }
    .site-nav > a:not(.button)::after { bottom: 8px; }
    .site-nav .button { margin-top: 20px; }
    .hero, .hero-grid { min-height: auto; }
    .hero-grid { grid-template-columns: 1fr; padding: 130px 0 75px; }
    .hero-content { padding: 25px 0 55px; }
    .hero-visual { height: 560px; }
    .hero-image { inset: 0 0 0 7%; }
    .scroll-cue { display: none; }
    .intro-grid { grid-template-columns: 1fr; gap: 20px; }
    .intro-grid .section-index { margin-bottom: 20px; }
    .intro-copy { padding-top: 10px; }
    .section-heading { align-items: flex-start; flex-direction: column; margin-bottom: 42px; }
    .carousel-controls { justify-content: flex-start; margin-top: -14px; }
    .project-toolbar { align-items: flex-start; flex-direction: column; }
    .project-filters { justify-content: flex-start; }
    .project-story-grid { grid-template-columns: 1fr; gap: 65px; }
    .services-hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .about-hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .about-story-grid, .about-philosophy-grid, .about-method-grid { grid-template-columns: 1fr; gap: 65px; }
    .about-story-copy { padding-top: 0; }
    .about-numbers-grid { grid-template-columns: 1fr 1fr; }
    .about-values-grid { grid-template-columns: 1fr 1fr; }
    .about-values-heading { align-items: flex-start; flex-direction: column; }
    .about-work-grid { grid-template-columns: 1fr; }
    .about-work-image { min-height: 500px; }
    .about-work-content { padding: 80px 36px; }
    .service-jump-nav { grid-template-columns: repeat(3, 1fr); }
    .service-detail-grid { grid-template-columns: 1fr; gap: 55px; }
    .service-detail-reversed .service-detail-image { order: 0; }
    .service-detail-image { min-height: 540px; }
    .service-advice-grid { grid-template-columns: 1fr; gap: 60px; }
    .project-facts { position: static; }
    .project-detail-heading { grid-template-columns: 1fr; gap: 25px; }
    .project-detail-heading > p { text-align: left; }
    .project-detail-gallery { grid-template-columns: 1fr; grid-auto-rows: 430px; }
    .gallery-item-large { grid-row: auto; min-height: 430px; }
    .process .container { grid-template-columns: 1fr; gap: 50px; }
    .project-grid { grid-template-columns: 1fr; }
    .project-card-large { grid-row: auto; }
    .project-card-large .project-image { height: 500px; }
    .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; gap: 45px; }
    .footer-brand { grid-column: 1 / -1; }
    .contact-grid, .two-columns { grid-template-columns: 1fr; gap: 50px; }
    .legal-layout { grid-template-columns: 1fr; gap: 50px; }
    .legal-layout > aside { position: static; }
    .error-hero { min-height: auto; padding: 165px 0 90px; }
    .error-layout { grid-template-columns: 1fr; gap: 45px; }
    .error-code { font-size: clamp(9rem, 35vw, 15rem); }
    .error-link-grid { grid-template-columns: 1fr; }
    .whatsapp-float { right: 18px; bottom: 18px; width: 58px; height: 58px; min-height: 58px; padding: 7px; }
    .whatsapp-float-icon { width: 44px; height: 44px; }
    .whatsapp-float-copy { display: none; }
}

@media (max-width: 540px) {
    h1 { font-size: 3.1rem; }
    h2 { font-size: 2.35rem; }
    .hero-grid { padding-top: 105px; }
    .hero-actions { align-items: flex-start; flex-direction: column; gap: 22px; }
    .hero-trust { margin-top: 48px; }
    .hero-trust div { grid-template-columns: 1fr; }
    .hero-visual { height: 430px; }
    .hero-image { left: 0; }
    .line-drawing { display: none; }
    .material-card { left: 14px; bottom: -20px; }
    .service-grid { --service-card-width: 100%; }
    .service-card { min-height: 350px; }
    .service-card p { min-height: auto; }
    .project-image, .project-card-large .project-image { height: 350px; }
    .project-detail-hero { padding-top: 120px; }
    .services-page-hero { padding: 150px 0 50px; }
    .about-hero { padding-top: 145px; }
    .about-hero-image { height: 460px; min-height: 0; }
    .about-numbers { padding-bottom: 80px; }
    .about-numbers-grid { grid-template-columns: 1fr; }
    .about-numbers-grid > div { min-height: 145px; }
    .about-numbers strong { margin-bottom: 24px; }
    .about-philosophy-images { min-height: 500px; }
    .about-image-main { right: 45px; bottom: 65px; }
    .about-image-detail { width: 190px; height: 220px; border-width: 8px; }
    .about-values-grid { grid-template-columns: 1fr; }
    .about-values-grid article { min-height: 260px; }
    .about-values-grid h3 { margin-top: 55px; }
    .about-work-image { min-height: 390px; }
    .about-work-content { padding: 70px 24px; }
    .service-jump-nav { grid-template-columns: 1fr 1fr; margin-top: 55px; }
    .service-detail { padding: 80px 0; }
    .service-detail-image { min-height: 420px; }
    .service-detail-actions { align-items: flex-start; flex-direction: column; }
    .advice-points { grid-template-columns: 1fr; }
    .breadcrumbs { margin-bottom: 40px; }
    .project-cover { height: 440px; min-height: 0; }
    .project-text-columns { grid-template-columns: 1fr; }
    .project-gallery-heading { align-items: flex-start; flex-direction: column; }
    .project-detail-gallery { grid-auto-rows: 330px; }
    .gallery-item, .gallery-item-large { min-height: 330px; }
    .project-detail-navigation { grid-template-columns: 1fr; }
    .project-detail-navigation a { min-height: 135px; padding: 32px 24px; border-right: 0; border-bottom: 1px solid var(--border); }
    .project-detail-navigation a:last-child { border-bottom: 0; }
    .gallery-lightbox { grid-template-columns: 48px 1fr 48px; padding-inline: 8px; }
    .lightbox-arrow { width: 40px; height: 40px; }
    .preview-banner { align-items: flex-start; flex-direction: column; gap: 3px; padding: 10px 18px; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .footer-brand { grid-column: 1 / -1; }
    .footer-bottom { flex-direction: column; gap: 8px; }
    .footer-legal { justify-content: flex-start; }
    .whatsapp-float { right: 16px; bottom: 16px; }
    .page-hero { padding: 150px 0 80px; }
    .legal-hero { padding: 145px 0 75px; }
    .legal-data div { grid-template-columns: 1fr; gap: 5px; }
    .contact-form { grid-template-columns: 1fr; padding: 25px 20px; }
    .contact-form label { grid-column: 1 / -1; }
    .contact-captcha { grid-template-columns: 1fr; }
    .error-hero { padding: 145px 0 80px; }
    .error-code { font-size: clamp(8rem, 45vw, 13rem); }
}

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