/* ===========================
   Elite Real Estate Media — Shared design tokens & primitives
   Used by Landing Page, Pricing, Portfolio, and future pages.
   =========================== */

:root{
  --gold: #C9A24E;
  --gold-soft: #B8923F;
  --gold-bright: #E0BC6A;
  --bg: #0A0A0A;
  --bg-2: #131313;
  --bg-3: #1A1A1A;
  --line: rgba(201,162,78,0.18);
  --line-soft: rgba(255,255,255,0.08);
  --fg: #F4F1EA;
  --fg-dim: #9A958B;
  --fg-mute: #5C584F;
}
html.light{
  --bg: #F6F2EA;
  --bg-2: #EFE9DD;
  --bg-3: #E4DCCB;
  --fg: #14110B;
  --fg-dim: #58524A;
  --fg-mute: #8A8579;
  --line: rgba(184,146,63,0.28);
  --line-soft: rgba(0,0,0,0.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--fg);font-family:'Archivo',sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* Type primitives */
.display{font-family:var(--display-font, 'Anton'),sans-serif;font-weight:var(--display-weight,400);font-style:var(--display-style,normal);letter-spacing:var(--display-tracking,-0.01em);line-height:var(--display-leading,0.92);text-transform:var(--display-case,uppercase)}
.narrow{font-family:'Archivo Narrow',sans-serif}
.mono{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.08em;text-transform:uppercase}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--gold)}
.index{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;color:var(--gold)}

/* Layout */
.container{max-width:1440px;margin:0 auto;padding:0 48px}
section{padding:140px 0;position:relative}
.section-head{display:grid;grid-template-columns:minmax(0, 1.4fr) minmax(0, 1fr);gap:80px;margin-bottom:80px;align-items:end}
.section-head .left{display:flex;flex-direction:column;gap:14px}
.section-head h2{font-size:clamp(48px,6vw,96px)}
.section-head h2 em{color:var(--gold);font-style:normal}
.section-head .right{max-width:480px;color:var(--fg-dim);font-size:15px;line-height:1.6;align-self:end}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;border-radius:0;font-weight:600;font-size:13px;letter-spacing:0.12em;text-transform:uppercase;transition:all .25s;cursor:pointer;border:1px solid transparent;font-family:'Archivo',sans-serif}
.btn-gold{position:relative;background:var(--gold);color:#0A0A0A;border-color:var(--gold);overflow:hidden;isolation:isolate}
.btn-gold::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.0) 30%, rgba(255,255,255,0.85) 50%, rgba(255,255,255,0.0) 70%, transparent 100%);transform:skewX(-18deg);transition:left .85s cubic-bezier(.2,.7,.2,1);z-index:-1;pointer-events:none}
.btn-gold::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 50%, var(--gold-soft) 100%);opacity:0;transition:opacity .3s;z-index:-2}
.btn-gold:hover{color:#0A0A0A;border-color:var(--gold-bright);box-shadow:0 8px 24px -8px rgba(201,162,78,0.55), 0 0 0 1px rgba(255,255,255,0.15) inset;transform:translateY(-1px)}
.btn-gold:hover::before{left:140%}
.btn-gold:hover::after{opacity:1}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.arrow{display:inline-block;transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:20px 0;backdrop-filter:blur(14px);background:color-mix(in oklab, var(--bg) 70%, transparent);border-bottom:1px solid var(--line-soft)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:40px;height:40px;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text .a{font-family:'Anton',sans-serif;font-size:18px;letter-spacing:0.04em;color:var(--fg)}
.brand-text .b{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.2em;color:var(--gold);margin-top:3px}
.nav-links{display:flex;gap:34px}
.nav-links a{font-size:13px;color:var(--fg-dim);transition:color .2s;font-weight:500}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-cta{display:flex;flex-direction:column;align-items:center;gap:10px}
.nav-util-row{display:flex;align-items:center;justify-content:center;gap:14px}
.nav-util{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-dim);transition:color .2s;white-space:nowrap;font-weight:500}
.nav-util:hover{color:var(--gold)}
.nav-util-sep{width:3px;height:3px;border-radius:50%;background:var(--fg-mute)}
.btn-nav{padding:0;background:var(--gold);border:1px solid var(--gold);display:inline-flex;align-items:center;gap:10px;font-family:'Archivo',sans-serif;cursor:pointer;color:#0A0A0A;position:relative;isolation:isolate;overflow:hidden;transition:transform .25s, box-shadow .25s, border-color .25s}
.btn-nav::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.0) 30%, rgba(255,255,255,0.85) 50%, rgba(255,255,255,0.0) 70%, transparent 100%);transform:skewX(-18deg);transition:left .85s cubic-bezier(.2,.7,.2,1);z-index:1;pointer-events:none}
.btn-nav::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 50%, var(--gold-soft) 100%);opacity:0;transition:opacity .3s;z-index:-1}
.btn-nav .nav-cta-l{position:relative;z-index:2;padding:11px 0 11px 22px;background:transparent;color:#0A0A0A;font-weight:600;font-size:11.5px;letter-spacing:0.16em;text-transform:uppercase;border:0}
.btn-nav .nav-cta-r{position:relative;z-index:2;padding:11px 22px 11px 0;background:transparent;color:#0A0A0A;border:0;display:inline-flex;align-items:center}
.btn-nav:hover{box-shadow:0 8px 24px -8px rgba(201,162,78,0.55), 0 0 0 1px rgba(255,255,255,0.15) inset;transform:translateY(-1px);border-color:var(--gold-bright)}
.btn-nav:hover::before{left:140%}
.btn-nav:hover::after{opacity:1}
.btn-nav:hover .arrow{transform:translateX(2px)}

/* FOOTER */
footer{background:var(--bg);padding:80px 0 32px;border-top:1px solid var(--line-soft)}
.ftop{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--line-soft)}
.ftop h4{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--gold);letter-spacing:0.15em;margin-bottom:18px}
.ftop ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.ftop a{font-size:14px;color:var(--fg-dim);transition:color .2s}
.ftop a:hover{color:var(--gold)}
.ftop p{color:var(--fg-dim);font-size:14px;line-height:1.6;max-width:340px;margin-top:14px}
.fbot{padding-top:24px;display:flex;justify-content:space-between;align-items:center;color:var(--fg-mute);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.12em;flex-wrap:wrap;gap:16px}
.fsocial{display:flex;gap:14px;align-items:center}
.fsocial a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--line-soft);border-radius:50%;color:var(--fg-dim);transition:all .25s}
.fsocial a:hover{color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}

/* Hide iOS Safari's native play-button overlay so paused videos stay clean */
video::-webkit-media-controls{display:none !important;-webkit-appearance:none}
video::-webkit-media-controls-start-playback-button{display:none !important;-webkit-appearance:none;opacity:0}
video::-webkit-media-controls-panel{display:none !important;-webkit-appearance:none}

/* MOBILE NAV (hamburger + slide-down panel) — hidden on desktop */
.nav-burger{display:none;background:transparent;border:0;width:40px;height:40px;cursor:pointer;padding:10px;flex-direction:column;justify-content:space-between;z-index:51}
.nav-burger span{display:block;width:20px;height:2px;background:var(--fg);transition:transform .25s ease, opacity .25s ease;border-radius:1px}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-panel{display:none;position:fixed;top:100px;left:0;right:0;background:color-mix(in oklab, var(--bg) 96%, transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--line-soft);padding:24px 24px 32px;flex-direction:column;gap:4px;z-index:49;max-height:calc(100vh - 100px);overflow-y:auto}
.nav-panel.open{display:flex}
.nav-panel a{font-family:'Anton',sans-serif;font-size:22px;letter-spacing:0.02em;color:var(--fg);padding:10px 0;text-transform:uppercase;line-height:1}
.nav-panel a:hover{color:var(--gold)}
.nav-panel a.np-util{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.14em;color:var(--fg-dim);padding:6px 0;text-transform:uppercase}
.nav-panel hr{border:0;border-top:1px solid var(--line-soft);margin:10px 0}
.nav-panel a.np-cta{background:var(--gold);color:#0A0A0A;padding:16px 24px;text-align:center;font-family:'Archivo',sans-serif;font-size:13px;letter-spacing:0.16em;text-transform:uppercase;font-weight:600;margin-top:12px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.nav-panel a.np-cta:hover{color:#0A0A0A}
@media (max-width: 1100px){
  .nav-burger{display:flex !important}
  .nav-inner .nav-links,.nav-inner .nav-cta{display:none !important}
}

/* REEL BAND — dark hero band promoting The Signature Reel */
.reel-band{background:#0A0A0A;color:#F4F1EA;padding:80px 0;position:relative;overflow:hidden}
.reel-band-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center;max-width:1440px;margin:0 auto;padding:0 48px}
.reel-band .eyebrow-tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);display:inline-block;padding:7px 14px;border:1px solid color-mix(in oklab, var(--gold) 40%, transparent);margin-bottom:28px}
.reel-band h2{font-family:'Anton',sans-serif;font-size:clamp(44px, 5vw, 80px);line-height:0.95;text-transform:uppercase;letter-spacing:-0.01em;margin-bottom:24px;color:#F4F1EA;font-weight:400}
.reel-band h2 em{color:var(--gold);font-style:normal}
.reel-band .sub{color:#9A958B;font-size:15px;line-height:1.65;max-width:580px;margin-bottom:36px}
.reel-band .chips{display:flex;gap:12px;flex-wrap:wrap}
.reel-band .chip{padding:14px 18px;border:1px solid color-mix(in oklab, var(--gold) 40%, transparent);min-width:96px}
.reel-band .chip-val{font-family:'Anton',sans-serif;font-size:26px;color:var(--gold);line-height:1}
.reel-band .chip-lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;color:var(--fg-dim);margin-top:6px;text-transform:uppercase}
.reel-band-cta{margin-top:32px;display:inline-flex}
.reel-band-phone{justify-self:end;display:block;width:280px;height:560px;background:#0A0A0A;border-radius:42px;padding:8px;box-shadow:0 30px 60px -10px rgba(0,0,0,0.7),0 0 0 2px rgba(255,255,255,0.06),inset 0 0 0 1px rgba(255,255,255,0.04);position:relative;text-decoration:none;color:inherit;transition:transform .35s ease}
.reel-band-phone:hover{transform:translateY(-4px) scale(1.015)}
.reel-band-phone::before{content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);width:96px;height:24px;background:#0A0A0A;border-radius:14px;z-index:3}
.reel-band-screen{position:relative;width:100%;height:100%;border-radius:34px;overflow:hidden;background:#1a1a1a}
.reel-band-screen video,.reel-band-screen img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.reel-band-screen::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.2) 0%, transparent 25%, transparent 70%, rgba(0,0,0,0.5) 100%);pointer-events:none}
.reel-band-meta{position:absolute;top:48px;left:18px;background:var(--gold);color:#0A0A0A;font-family:'JetBrains Mono',monospace;font-size:10px;padding:5px 10px;letter-spacing:0.18em;z-index:2;font-weight:700}
.reel-band-time{position:absolute;top:48px;right:18px;color:rgba(255,255,255,0.85);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.12em;z-index:2}
.reel-band-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:var(--gold);color:#0A0A0A;display:flex;align-items:center;justify-content:center;z-index:2;padding-left:4px;transition:transform .25s ease, background .25s ease}
.reel-band-phone:hover .reel-band-play{transform:translate(-50%,-50%) scale(1.08);background:var(--gold-bright)}
@media (max-width: 980px){
  .reel-band{padding:56px 0}
  .reel-band-inner{grid-template-columns:1fr;gap:40px;padding:0 24px}
  .reel-band-phone{justify-self:center;width:240px;height:480px}
  .reel-band .chip{min-width:80px;padding:12px 14px}
  .reel-band .chip-val{font-size:22px}
}
@media (max-width: 480px){
  .reel-band-phone{width:220px;height:440px}
  .reel-band h2{font-size:clamp(38px, 11vw, 56px)}
}

/* IMAGE SLOT */
image-slot{--placeholder-color:var(--fg-mute)}

/* PAGE HERO (used by Pricing / Portfolio) */
.page-hero{padding:200px 0 80px;background:var(--bg);border-bottom:1px solid var(--line-soft);position:relative}
.page-hero .container{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:80px;align-items:end}
.page-hero h1{font-size:clamp(64px,9vw,140px)}
.page-hero h1 em{color:var(--gold);font-style:normal}
.page-hero .sub{color:var(--fg-dim);font-size:16px;line-height:1.6;max-width:480px;align-self:end}

/* Responsive */
@media (max-width: 1100px){
  .container{padding-left:24px;padding-right:24px}
  .nav-links{display:none}
  .section-head,.page-hero .container{grid-template-columns:1fr;gap:32px}
  .ftop{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .ftop{grid-template-columns:1fr}
  .nav-cta{align-items:flex-end}
  .page-hero{padding-top:160px}
}
