/* ═══════════════════════════════════════════════════════════
   TSIPA VILLAS v3 — PERIGON SCROLL + GAUDÍ BACKGROUNDS
   Dark Navy · Aged Bronze
   ═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&family=Jost:wght@200;300;400;500&display=swap');

:root {
  --ink:         #060c14;
  --navy:        #0b1422;
  --navy-2:      #0f1c30;
  --navy-3:      #14243e;
  --bronze:      #7a5f38;
  --bronze-lt:   #b89458;
  --bronze-pale: #d4b07a;
  --cream:       #ede8e0;
  --cream-dim:   rgba(237,232,224,0.62);
  --cream-mute:  rgba(237,232,224,0.35);
  --line:        rgba(122,95,56,0.2);
  --line-lt:     rgba(122,95,56,0.1);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', sans-serif;
  --nav-h:    72px;
  --nav-sm:   50px;
  --ease:     cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --ease-bio: cubic-bezier(0.34,1.56,0.64,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
body{background:var(--navy);color:var(--cream);font-family:var(--sans);font-weight:300;font-size:16px;line-height:1.7;overflow-x:hidden;cursor:none}
a{text-decoration:none;color:inherit}
img{display:block;width:100%;height:100%;object-fit:cover}

/* Gesamtkunstwerk */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--bronze)}
::selection{background:rgba(184,148,88,0.22);color:var(--cream)}

/* ── SCROLL PROGRESS ─────────────────────────────────── */
#sp{position:fixed;top:0;left:0;height:2px;z-index:1000;background:linear-gradient(90deg,var(--bronze),var(--bronze-pale));width:0%;pointer-events:none;transition:width .1s linear}

/* ── CURSOR ──────────────────────────────────────────── */
#cd{width:5px;height:5px;background:var(--bronze-pale);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
#cr{width:30px;height:30px;border-radius:50%;border:1px solid rgba(184,148,88,0.4);position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),border-color .3s}

/* ── NAV ─────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 56px;z-index:900;transition:height .5s var(--ease),background .5s var(--ease),padding .5s var(--ease),border-color .5s;border-bottom:1px solid transparent}
#nav.solid{height:var(--nav-sm);background:rgba(6,12,20,.97);backdrop-filter:blur(24px);border-bottom-color:var(--line);padding:0 40px}
.nav-logo{font-family:var(--serif);font-size:20px;font-weight:300;letter-spacing:7px;text-transform:uppercase;color:var(--cream);display:flex;align-items:baseline;transition:font-size .5s var(--ease)}
#nav.solid .nav-logo{font-size:16px}
.nav-logo-sub{font-family:var(--sans);font-size:9px;font-weight:400;letter-spacing:4px;text-transform:uppercase;color:var(--bronze-lt);margin-left:8px}
.nav-menu{display:flex;gap:0;list-style:none}
.nav-item{position:relative}
.nav-link{display:block;padding:0 20px;height:var(--nav-h);line-height:var(--nav-h);font-size:10px;font-weight:400;letter-spacing:3px;text-transform:uppercase;color:var(--cream-dim);cursor:none;position:relative;transition:color .3s,height .5s var(--ease),line-height .5s var(--ease)}
#nav.solid .nav-link{height:var(--nav-sm);line-height:var(--nav-sm)}
/* Catenary arch underline */
.nav-link::after{content:'';position:absolute;bottom:0;left:20px;right:20px;height:2px;background:var(--bronze-lt);clip-path:polygon(0% 100%,10% 40%,30% 10%,50% 0%,70% 10%,90% 40%,100% 100%);transform:scaleX(0);transform-origin:center;transition:transform .4s var(--ease-bio)}
.nav-item:hover .nav-link,.nav-link.active{color:var(--cream)}
.nav-item:hover .nav-link::after,.nav-link.active::after{transform:scaleX(1)}
.nav-link.active{color:var(--bronze-pale)}
.nav-dd{position:absolute;top:100%;left:0;min-width:210px;background:rgba(6,12,20,.98);border:1px solid var(--line);border-top:2px solid var(--bronze);padding:8px 0;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(6px);transition:opacity .25s,transform .3s var(--ease-out),visibility .25s}
.nav-item:hover .nav-dd{opacity:1;visibility:visible;pointer-events:auto;transform:none}
.nav-dd a{display:block;padding:11px 22px;font-size:10px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:var(--cream-mute);transition:color .2s,padding-left .25s var(--ease);border-bottom:1px solid var(--line-lt)}
.nav-dd a:last-child{border-bottom:none}
.nav-dd a:hover{color:var(--bronze-pale);padding-left:32px}
.nav-cta{font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--ink);background:var(--bronze-lt);padding:10px 24px;cursor:none;clip-path:polygon(0 0,100% 0,100% 70%,88% 100%,0 100%);transition:background .3s,clip-path .35s var(--ease),padding .5s}
#nav.solid .nav-cta{padding:8px 20px}
.nav-cta:hover{background:var(--bronze-pale);clip-path:polygon(0 0,100% 0,100% 100%,12% 100%,0 70%)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:none;padding:4px}
.nav-burger span{display:block;width:24px;height:1px;background:var(--cream-dim);transition:all .3s}
#mob-nav{display:none;position:fixed;inset:0;top:var(--nav-h);background:rgba(6,12,20,.99);z-index:850;padding:40px 32px;overflow-y:auto}
#mob-nav.open{display:block}
.mob-sec{margin-bottom:36px}
.mob-sec-title{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--bronze);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.mob-sec a{display:block;padding:10px 0;font-size:14px;font-weight:300;color:var(--cream-dim);border-bottom:1px solid var(--line-lt);transition:color .2s}
.mob-sec a:hover{color:var(--cream)}

/* ═══════════════════════════════════════════════════════
   PERIGON SCROLL SCENE SYSTEM
   ═══════════════════════════════════════════════════════ */

/* The scroll-scene is N×100vh tall.
   Inside is a sticky container that pins at top:0.
   As user scrolls through the tall wrapper, JS detects
   progress and crossfades image layers + text panels.   */
.scroll-scene{position:relative}
.ss-sticky{position:sticky;top:0;width:100%;height:100vh;overflow:hidden}

/* Image layers — stack absolutely, crossfade via opacity */
.ss-layer{position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease)}
.ss-layer.active{opacity:1}

/* Scale-breathe: active layer zooms 1.06→1.0 */
.ss-bg{position:absolute;inset:-6%;transform:scale(1.06);transition:transform 1.5s var(--ease);will-change:transform}
.ss-layer.active .ss-bg{transform:scale(1.0)}

/* Gradient overlay for text legibility */
.ss-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,12,20,.88) 0%,rgba(6,12,20,.28) 50%,rgba(6,12,20,.08) 100%)}

/* Text panel per layer — slides up and fades in with layer */
.ss-text{position:absolute;inset:0;z-index:10;display:flex;flex-direction:column;justify-content:flex-end;padding:0 80px 96px;opacity:0;transform:translateY(16px);transition:opacity .65s var(--ease),transform .7s var(--ease);pointer-events:none}
.ss-layer.active .ss-text{opacity:1;transform:none;pointer-events:auto}

/* Counter — top right "01 / 04" */
.ss-counter{position:absolute;top:36px;right:60px;z-index:20;font-family:var(--sans);font-size:10px;font-weight:400;letter-spacing:4px;color:var(--cream-mute);display:flex;align-items:center;gap:10px}
.ss-cur{color:var(--bronze-pale)}
.ss-sep{width:22px;height:1px;background:var(--line)}

/* Scroll hint — animated descending line */
.ss-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:20;opacity:1;transition:opacity .5s}
.ss-hint.gone{opacity:0;pointer-events:none}
.ss-hint-line{width:1px;height:52px;background:linear-gradient(to bottom,var(--bronze-lt),transparent);animation:scrollDrop 2s ease-in-out infinite}
.ss-hint-label{font-size:8px;letter-spacing:5px;text-transform:uppercase;color:var(--cream-mute)}
@keyframes scrollDrop{0%{transform:scaleY(0);transform-origin:top;opacity:1}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom;opacity:0}}

/* ── PARALLAX SECTIONS ───────────────────────────────── */
.par-wrap{position:relative;overflow:hidden}
.par-bg{position:absolute;inset:-20% 0;will-change:transform}

/* ── WORD REVEAL ─────────────────────────────────────── */
.wr .wr-w{display:inline-block;opacity:0;transform:translateY(72%);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.wr.revealed .wr-w{opacity:1;transform:none}

/* ── STANDARD FADE REVEAL ────────────────────────────── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.on{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ═══════════════════════════════════════════════════════
   GAUDÍ SVG BACKGROUND SYSTEM
   Seven distinct architectural motifs — one per section.
   Pure SVG geometry, no images.
   ═══════════════════════════════════════════════════════ */
.g-bg{position:relative;overflow:hidden}
.g-layer{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.g-layer svg{position:absolute;inset:0;width:100%;height:100%}
.g-bg>*:not(.g-layer){position:relative;z-index:1}

/* Trencadís texture — on every section */
.g-trc::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background-image:linear-gradient(62deg,rgba(122,95,56,.028) 1px,transparent 1px),linear-gradient(118deg,rgba(122,95,56,.022) 1px,transparent 1px),linear-gradient(175deg,rgba(122,95,56,.016) 1px,transparent 1px);background-size:48px 48px,48px 48px,48px 48px}
.g-trc>*:not(.g-layer){position:relative;z-index:1}

/* ── SECTIONS ────────────────────────────────────────── */
.sec{padding:120px 80px}
.sec-sm{padding:80px 80px}
.sec-dark{background:var(--ink)}
.sec-navy{background:var(--navy)}
.sec-2{background:var(--navy-2)}
.sec-3{background:var(--navy-3)}

/* Trencadís divider — replaces flat hr */
.td-rule{width:100%;height:3px;background:linear-gradient(90deg,transparent,var(--bronze),var(--bronze-pale),var(--bronze),transparent);clip-path:polygon(0 0,2% 100%,5% 0,8% 100%,11% 0,14% 100%,17% 0,20% 100%,23% 0,26% 100%,29% 0,32% 100%,35% 0,38% 100%,41% 0,44% 100%,47% 0,50% 100%,53% 0,56% 100%,59% 0,62% 100%,65% 0,68% 100%,71% 0,74% 100%,77% 0,80% 100%,83% 0,86% 100%,89% 0,92% 100%,95% 0,98% 100%,100% 0,100% 100%,0 100%)}

/* ── TYPOGRAPHY ──────────────────────────────────────── */
.eyebrow{font-size:9px;font-weight:400;letter-spacing:5px;text-transform:uppercase;color:var(--bronze-lt);display:flex;align-items:center;gap:16px;margin-bottom:16px}
.eyebrow::before{content:'';flex-shrink:0;display:block;width:32px;height:10px;border-bottom:1px solid var(--bronze-lt);border-radius:0 0 50% 50%/0 0 10px 10px}
.display{font-family:var(--serif);font-size:clamp(42px,6vw,88px);font-weight:300;line-height:1.0;letter-spacing:-.5px}
.display em{font-style:italic;color:var(--bronze-pale)}
.title{font-family:var(--serif);font-size:clamp(28px,3.5vw,52px);font-weight:300;line-height:1.1}
.title em{font-style:italic;color:var(--bronze-lt)}
.body-copy{font-size:14px;font-weight:300;line-height:1.95;color:var(--cream-dim);max-width:640px}
.lbl{font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:var(--bronze)}

/* ── BUTTONS ─────────────────────────────────────────── */
.btn-p{display:inline-block;font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;padding:15px 34px;cursor:none;color:var(--ink);background:var(--bronze-lt);clip-path:polygon(0 0,100% 0,100% 72%,92% 100%,8% 100%,0 72%);transition:background .3s,transform .3s var(--ease)}
.btn-p:hover{background:var(--bronze-pale);transform:translateY(-2px)}
.btn-o{display:inline-block;font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;padding:15px 34px;cursor:none;color:var(--cream-dim);border:1px solid var(--line);clip-path:polygon(0 0,100% 0,100% 78%,94% 100%,6% 100%,0 78%);transition:border-color .3s,color .3s}
.btn-o:hover{border-color:var(--bronze-lt);color:var(--cream)}
.btn-t{font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:var(--bronze-pale);text-decoration:none;position:relative;padding-bottom:4px}
.btn-t::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:rgba(212,176,122,.35);clip-path:polygon(0 100%,15% 20%,50% 70%,85% 20%,100% 100%);transition:clip-path .4s var(--ease),background .3s}
.btn-t:hover{color:var(--cream)}
.btn-t:hover::after{background:rgba(237,232,224,.5);clip-path:polygon(0 100%,0 0,50% 45%,100% 0,100% 100%)}

/* ── GRID ────────────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.two-col-w{grid-template-columns:3fr 2fr}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-lt)}
.gc{padding:52px 44px;background:var(--navy-2);transition:background .4s;position:relative;overflow:hidden}
.gc::before{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--bronze),var(--bronze-pale),transparent);transition:width .6s var(--ease-out)}
.gc::after{content:'';position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 18px 18px 0;border-color:transparent rgba(122,95,56,.16) transparent transparent;transition:border-width .3s}
.gc:hover{background:var(--navy-3)}
.gc:hover::before{width:100%}
.gc:hover::after{border-width:0 26px 26px 0;border-color:transparent rgba(184,148,88,.28) transparent transparent}
.gc-num{font-family:var(--serif);font-size:64px;font-weight:300;color:rgba(122,95,56,.13);line-height:1;margin-bottom:20px}
.stat-g{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.stat-c{padding:44px 36px;text-align:center;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .3s;position:relative;overflow:hidden}
.stat-c::before{content:'';position:absolute;top:0;left:15%;right:15%;height:2px;background:var(--bronze-lt);clip-path:polygon(0% 100%,50% 0%,100% 100%);transform:scaleX(0);transition:transform .4s var(--ease-bio)}
.stat-c:hover{background:rgba(122,95,56,.04)}
.stat-c:hover::before{transform:scaleX(1)}
.stat-n{font-family:var(--serif);font-size:52px;font-weight:300;color:var(--bronze-pale);line-height:1;margin-bottom:8px}
.stat-l{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--cream-mute)}
.spec-t{width:100%;border-collapse:collapse}
.spec-t th{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--bronze-lt);font-weight:400;padding:14px 20px;border-bottom:1px solid var(--line);text-align:left}
.spec-t td{padding:18px 20px;border-bottom:1px solid var(--line-lt);font-size:14px;color:var(--cream-dim);vertical-align:top;line-height:1.6}
.spec-t tr:hover td{background:rgba(122,95,56,.03)}
.spec-t td.val{font-family:var(--serif);font-size:20px;color:var(--cream)}
.tl{position:relative;padding-left:40px}
.tl::before{content:'';position:absolute;left:0;top:8px;bottom:0;width:1px;background:linear-gradient(to bottom,var(--bronze),rgba(122,95,56,.2))}
.tl-i{position:relative;padding-bottom:48px}
.tl-i::before{content:'';position:absolute;left:-44px;top:8px;width:9px;height:9px;background:var(--bronze);border:2px solid var(--navy);clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%)}
.tl-yr{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--bronze-lt);margin-bottom:8px}
.tl-ti{font-family:var(--serif);font-size:22px;font-weight:300;margin-bottom:10px;line-height:1.2}
.tl-ti em{font-style:italic;color:var(--bronze-lt)}
.tl-bo{font-size:13px;line-height:1.9;color:var(--cream-mute);max-width:560px}
.bar-i{margin-bottom:18px}
.bar-h{display:flex;justify-content:space-between;margin-bottom:7px}
.bar-yr{font-size:12px;color:var(--cream-dim)}
.bar-v{font-family:var(--serif);font-size:16px;color:var(--bronze-pale)}
.bar-t{height:3px;background:rgba(122,95,56,.1)}
.bar-f{height:100%;background:linear-gradient(90deg,var(--bronze),var(--bronze-pale));transition:width 1.4s var(--ease-out)}

/* ── IMAGE PLACEHOLDERS ──────────────────────────────── */
.iph-b{position:relative;width:100%;min-height:460px;background:var(--navy-2);border:1px dashed rgba(122,95,56,.28);overflow:hidden}
.iph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border:1px dashed rgba(122,95,56,.35);background:repeating-linear-gradient(60deg,rgba(122,95,56,.025) 0,rgba(122,95,56,.025) 1px,transparent 1px,transparent 22px),repeating-linear-gradient(-60deg,rgba(122,95,56,.02) 0,rgba(122,95,56,.02) 1px,transparent 1px,transparent 22px);pointer-events:none}
.iph::before,.iph::after{content:'';position:absolute;background:rgba(122,95,56,.1)}
.iph::before{width:1px;height:70%;left:50%;top:15%}
.iph::after{height:1px;width:70%;top:50%;left:15%}
.iph-box{background:rgba(6,12,20,.85);border:1px solid var(--line);padding:10px 18px;text-align:center;position:relative;z-index:1;max-width:80%;clip-path:polygon(0 0,100% 0,100% 82%,96% 100%,0 100%)}
.iph-box .lbl{margin-bottom:5px}
.iph-box p{font-size:11px;color:var(--cream-mute);line-height:1.5;margin-bottom:4px}
.iph-box .sz{font-size:10px;color:rgba(122,95,56,.6);letter-spacing:1px}

/* ── FORMS ───────────────────────────────────────────── */
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.f-g{margin-bottom:22px}
.f-g label{display:block;font-size:9px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--bronze-lt);margin-bottom:8px}
.f-g input,.f-g select,.f-g textarea{width:100%;background:rgba(237,232,224,.04);border:1px solid rgba(122,95,56,.22);border-bottom-color:rgba(122,95,56,.55);color:var(--cream);font-family:var(--sans);font-size:14px;font-weight:300;padding:13px 16px;outline:none;appearance:none;transition:border-color .3s,box-shadow .3s}
.f-g input::placeholder,.f-g textarea::placeholder{color:var(--cream-mute)}
.f-g input:focus,.f-g select:focus,.f-g textarea:focus{border-color:rgba(122,95,56,.6);box-shadow:0 0 0 1px rgba(184,148,88,.1)}
.f-g select{cursor:none;color:var(--cream-dim)}
.f-g select option{background:var(--navy-2)}
.f-g textarea{resize:none;height:110px}
.f-ck{display:flex;gap:12px;align-items:flex-start;margin-bottom:28px}
.f-ck input[type=checkbox]{width:15px;height:15px;margin-top:3px;flex-shrink:0;accent-color:var(--bronze-lt);cursor:none}
.f-ck label{font-size:12px;color:var(--cream-mute);line-height:1.7}
.f-ck label a{color:var(--bronze-pale)}
.f-sub{width:100%;padding:16px;background:var(--bronze-lt);color:var(--ink);border:none;font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;clip-path:polygon(0 0,100% 0,100% 72%,96% 100%,4% 100%,0 72%);transition:background .3s,clip-path .35s;cursor:none}
.f-sub:hover{background:var(--bronze-pale);clip-path:polygon(2% 0,98% 0,100% 28%,100% 100%,0 100%,0 28%)}
.f-ok{display:none;text-align:center;padding:72px 20px}
.f-ok h3{font-family:var(--serif);font-size:34px;font-weight:300;margin-bottom:14px}
.f-ok h3 em{font-style:italic;color:var(--bronze-lt)}
.f-ok p{font-size:14px;color:var(--cream-mute);line-height:1.9}
.ok-ico{width:60px;height:60px;border:1px solid rgba(184,148,88,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 26px}
.ok-ico svg{width:22px;height:22px;stroke:var(--bronze-lt);stroke-width:1.5;fill:none}
.bk-note{background:rgba(122,95,56,.06);border:1px solid var(--line);border-left:2px solid var(--bronze);padding:14px 18px;margin-bottom:20px;font-size:12px;color:var(--cream-mute);line-height:1.7}
.inf-box{background:rgba(122,95,56,.07);border:1px solid var(--line);padding:22px 26px;margin-top:20px}
.inf-box .lbl{margin-bottom:6px}
.inf-box p{font-size:13px;color:var(--cream-mute);line-height:1.8}
.inf-box a{color:var(--bronze-pale)}
.ben-l{list-style:none}
.ben-l li{display:flex;align-items:flex-start;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-lt);font-size:13px;color:var(--cream-mute);line-height:1.6}
.ben-l li:last-child{border-bottom:none}
.ben-l li::before{content:"";display:inline-block;width:18px;height:1px;background:var(--bronze);flex-shrink:0;margin-top:10px}
.con-d{margin-bottom:24px}
.con-d .lbl{margin-bottom:5px}
.con-d p{font-size:14px;color:var(--cream-dim);line-height:1.7}
.con-d a{color:var(--bronze-pale)}

/* Contact tabs */
.c-tabs{display:flex;border-bottom:1px solid var(--line);margin-top:44px}
.c-tab{background:none;border:none;border-bottom:2px solid transparent;padding:0 36px;height:52px;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--cream-mute);cursor:none;transition:color .25s,border-color .25s;position:relative;bottom:-1px}
.c-tab:hover{color:var(--cream-dim)}
.c-tab.active{color:var(--bronze-pale);border-bottom-color:var(--bronze)}
.c-panel{display:none}
.c-panel.active{display:block}
.c-lay{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}

/* ── FOOTER ──────────────────────────────────────────── */
#footer{background:var(--ink);border-top:1px solid var(--line);padding:72px 80px 48px;position:relative}
#footer::before{content:'';position:absolute;top:-1px;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,var(--bronze-lt),transparent);clip-path:polygon(5% 100%,50% 0%,95% 100%)}
.ft-g{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px;padding-bottom:56px;border-bottom:1px solid var(--line-lt)}
.ft-logo{font-family:var(--serif);font-size:22px;font-weight:300;letter-spacing:6px;text-transform:uppercase;margin-bottom:14px}
.ft-logo span{color:var(--bronze-lt);font-size:10px;letter-spacing:4px;vertical-align:super}
.ft-tag{font-size:12px;color:var(--cream-mute);line-height:1.9;max-width:240px}
.ft-addr{font-size:12px;color:var(--cream-mute);line-height:1.9;margin-top:18px;font-style:normal}
.ft-ct{font-size:9px;font-weight:500;letter-spacing:4px;text-transform:uppercase;color:var(--bronze);margin-bottom:18px;padding-bottom:8px;border-bottom:1px solid var(--line-lt)}
.ft-col ul{list-style:none}
.ft-col ul li{margin-bottom:10px}
.ft-col ul li a{font-size:12px;color:var(--cream-mute);display:inline-block;transition:color .25s,padding-left .25s var(--ease)}
.ft-col ul li a:hover{color:var(--bronze-pale);padding-left:6px}
.ft-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.ft-cp{font-size:11px;color:rgba(237,232,224,.18)}
.ft-leg{display:flex;gap:24px}
.ft-leg a{font-size:10px;color:rgba(237,232,224,.18);transition:color .25s}
.ft-leg a:hover{color:var(--cream-mute)}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes bronzePulse{0%,100%{opacity:.06}50%{opacity:.12}}

@media(max-width:1100px){
  #nav{padding:0 28px}#nav.solid{padding:0 24px}
  .sec,.sec-sm{padding-left:32px;padding-right:32px}
  .two-col,.two-col-w{grid-template-columns:1fr;gap:48px}
  .stat-g{grid-template-columns:1fr 1fr}
  .three-col{grid-template-columns:1fr}
  .ft-g{grid-template-columns:1fr 1fr;gap:32px}
  #footer{padding:56px 32px 40px}
  .ss-text{padding:0 32px 72px}
  .c-lay{grid-template-columns:1fr;gap:48px}
}
@media(max-width:768px){
  .nav-menu,.nav-cta{display:none}
  .nav-burger{display:flex}
  .ft-g{grid-template-columns:1fr}
  .f-row{grid-template-columns:1fr}
  .sec{padding:64px 24px}.sec-sm{padding:48px 24px}
  #footer{padding:48px 24px 32px}
  .c-tab{padding:0 14px;font-size:9px}
}
