/* ============================================================
   THEME ARCHITECTURE
   ============================================================ */
:root[data-theme="dark"]{
  --bg:#0b0b0b;
  --bg-2:#111114;
  --fg:#f5f3ee;
  --dim:#9e9c96;
  --faint:#5d5b56;
  --line:#f5f3ee;            /* heavy 2px brutalist borders */
  --line-soft:rgba(245,243,238,.16);
  --surface:#15151a;
  --invert-bg:#f5f3ee;       /* hover-inversion target */
  --invert-fg:#0b0b0b;
  --invert-dim:rgba(11,11,11,.62);
  --tang:#ff5a1f;
  --tang-d:#e6450d;
  --shadow:rgba(0,0,0,.6);
}
:root[data-theme="light"]{
  --bg:#f5f3ee;
  --bg-2:#ebe8e0;
  --fg:#0b0b0b;
  --dim:#5a5854;
  --faint:#9a9892;
  --line:#0b0b0b;
  --line-soft:rgba(11,11,11,.14);
  --surface:#ebe8e0;
  --invert-bg:#0b0b0b;
  --invert-fg:#f5f3ee;
  --invert-dim:rgba(245,243,238,.65);
  --tang:#ff5a1f;
  --tang-d:#e6450d;
  --shadow:rgba(11,11,11,.18);
}

/* ============================================================
   RESET + BASE
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;text-rendering:optimizeLegibility}
body{background:var(--bg);color:var(--fg);font-family:'Outfit',sans-serif;font-weight:300;font-size:17px;line-height:1.6;overflow-x:hidden;transition:background .3s ease,color .3s ease}
::selection{background:var(--tang);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
:focus-visible{outline:2px solid var(--tang);outline-offset:3px}

:root{
  --maxw:1280px;
  --pad:clamp(16px,4vw,52px);
  --ease:cubic-bezier(.16,1,.28,1);
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative}
.ab{font-family:'Archivo Black',sans-serif;font-weight:400}
.arch{font-family:'Archivo',sans-serif}
.tang{color:var(--tang)}

/* ============================================================
   TICKER (top strip — always inverted)
   ============================================================ */
.ticker{background:var(--tang);color:#fff;overflow:hidden;border-bottom:2px solid var(--line);white-space:nowrap;position:relative}
.ticker .track{display:inline-flex;animation:slide 32s linear infinite;will-change:transform}
.ticker .track span{font-family:'Archivo';font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:9px 22px;display:inline-flex;align-items:center;gap:22px}
.ticker .track span::after{content:"✦";color:rgba(255,255,255,.6);font-size:11px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================
   HEADER
   ============================================================ */
[data-site-header]{position:sticky;top:0;z-index:100;}
header{position:relative;z-index:1;background:var(--bg);border-bottom:2px solid var(--line);transition:background .3s ease,border-color .3s ease}
header .inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:flex;align-items:center;justify-content:space-between;height:72px;gap:12px}
.logo{display:flex;align-items:center;flex-shrink:0}
.logo img{height:24px}
:root[data-theme="light"] .logo img{filter:invert(1) hue-rotate(180deg);}

nav.main{display:flex;align-items:center;height:100%}
nav.main>a,nav.main>.drop>button,nav.main>button.cn{font-family:'Archivo';font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--fg);padding:0 14px;height:72px;display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease)}
nav.main>a:hover,nav.main>.drop>button:hover,nav.main>button.cn:hover{background:var(--invert-bg);color:var(--invert-fg)}

.drop{position:relative;height:72px;display:flex;align-items:center}
.drop>button .chev{transition:transform .3s var(--ease)}
.drop.open>button{background:var(--invert-bg);color:var(--invert-fg)}
.drop.open>button .chev{transform:rotate(180deg)}
.dropdown{position:absolute;top:72px;left:0;width:340px;background:var(--bg);color:var(--fg);border:2px solid var(--line);box-shadow:8px 8px 0 var(--line);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;z-index:120}
.drop.open .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown a{display:block;padding:16px 18px;border-bottom:2px solid var(--line);transition:background .2s var(--ease),color .2s var(--ease)}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{background:var(--tang);color:#fff}
.dropdown a .t{font-family:'Archivo';font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.02em;display:block}
.dropdown a .d{font-size:12.5px;color:var(--dim);margin-top:2px}
.dropdown a:hover .d{color:rgba(255,255,255,.85)}

.hr-cta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.book{font-family:'Archivo';font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase;background:var(--tang);color:#fff;padding:12px 20px;border:2px solid var(--line);transition:background .2s var(--ease)}
.book:hover{background:var(--invert-bg);color:var(--invert-fg)}

/* Theme toggle — brutalist square button */
.tog{width:44px;height:44px;border:2px solid var(--line);background:var(--bg);color:var(--fg);display:grid;place-items:center;transition:background .2s var(--ease),color .2s var(--ease);flex-shrink:0}
.tog:hover{background:var(--invert-bg);color:var(--invert-fg)}
.tog svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .35s var(--ease)}
.tog:hover svg{transform:rotate(20deg)}
:root[data-theme="dark"] .tog .sun{display:block}
:root[data-theme="dark"] .tog .moon{display:none}
:root[data-theme="light"] .tog .sun{display:none}
:root[data-theme="light"] .tog .moon{display:block}

.burger{display:none;width:44px;height:44px;border:2px solid var(--line);background:var(--bg);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;transition:background .2s var(--ease)}
.burger:hover{background:var(--invert-bg)}
.burger span{width:20px;height:2.5px;background:var(--fg);transition:background .2s ease}
.burger:hover span{background:var(--invert-fg)}

@media(max-width:980px){nav.main{display:none}.hr-cta .book{display:none}.burger{display:flex}}
@media(max-width:380px){.hr-cta{gap:6px}}

/* ============================================================
   SIDEBAR (mobile)
   ============================================================ */
.scrim{position:fixed;inset:0;z-index:300;background:rgba(11,11,11,.55);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.scrim.open{opacity:1;visibility:visible}
.sidebar{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);z-index:310;background:var(--bg);color:var(--fg);border-left:2px solid var(--line);transform:translateX(100%);transition:transform .45s var(--ease);display:flex;flex-direction:column;padding:22px var(--pad)}
.sidebar.open{transform:none}
.sidebar .sb-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.sidebar .x{width:44px;height:44px;border:2px solid var(--line);background:var(--bg);font-family:'Archivo';font-weight:800;font-size:15px;transition:background .2s var(--ease),color .2s var(--ease)}
.sidebar .x:hover{background:var(--invert-bg);color:var(--invert-fg)}
.sidebar nav{display:flex;flex-direction:column;border-top:2px solid var(--line);overflow-y:auto;flex:1}
.sidebar nav a{font-family:'Archivo Black';font-size:22px;text-transform:uppercase;padding:15px 0;border-bottom:2px solid var(--line);transition:padding-left .25s var(--ease),color .25s var(--ease)}
.sidebar nav a:hover{padding-left:12px;color:var(--tang)}
.sidebar .sb-cta{margin-top:18px;display:block;background:var(--tang);color:#fff;font-family:'Archivo';font-weight:800;font-size:14px;letter-spacing:.04em;text-transform:uppercase;text-align:center;padding:16px;border:2px solid var(--line);transition:background .2s var(--ease)}
.sidebar .sb-cta:hover{background:var(--invert-bg);color:var(--invert-fg)}
.sidebar .se{margin-top:18px;font-family:'Archivo';font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--dim);text-align:center}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:clamp(40px,7vw,90px) 0 0;border-bottom:2px solid var(--line)}
.hero .badge{display:inline-flex;align-items:center;gap:10px;border:2px solid var(--line);padding:7px 14px;font-family:'Archivo';font-weight:800;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:30px}
.hero .badge .dot{width:8px;height:8px;background:var(--tang);border-radius:50%;animation:bk 1.6s steps(1) infinite}
@keyframes bk{50%{opacity:.25}}
.hero h1{font-family:'Archivo Black';font-size:clamp(42px,11vw,150px);line-height:.88;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:0}
.hero h1 .out{-webkit-text-stroke:2px var(--fg);color:transparent;transition:color .4s var(--ease),-webkit-text-stroke-color .4s var(--ease)}
.hero h1:hover .out{color:var(--tang);-webkit-text-stroke-color:var(--tang)}
.hero .sub{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:end;border-top:2px solid var(--line);margin-top:clamp(30px,5vw,56px);padding-top:28px;padding-bottom:clamp(36px,6vw,64px)}
.hero .sub p{font-size:clamp(16px,1.9vw,21px);max-width:42ch;color:var(--fg)}
.hero .cta-row{display:flex;flex-direction:column}
.cbtn{font-family:'Archivo';font-weight:800;font-size:14px;letter-spacing:.03em;text-transform:uppercase;padding:18px 24px;border:2px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:18px;transition:background .25s var(--ease),color .25s var(--ease);cursor:pointer;width:100%;color:var(--fg);background:var(--bg);min-height:56px}
.cbtn .ar{transition:transform .3s var(--ease);font-size:18px}
.cbtn:hover .ar{transform:translateX(6px)}
.cbtn.primary{background:var(--tang);color:#fff;border-color:var(--line)}
.cbtn.primary:hover{background:var(--invert-bg);color:var(--invert-fg)}
.cbtn.ghost{border-top:none}
.cbtn.ghost:hover{background:var(--invert-bg);color:var(--invert-fg)}
@media(max-width:780px){.hero .sub{grid-template-columns:1fr;gap:24px;align-items:start}}

/* ============================================================
   MARQUEE STRIP (always tangerine)
   ============================================================ */
.mq{background:var(--tang);color:#fff;border-bottom:2px solid var(--line);overflow:hidden;white-space:nowrap}
.mq .track{display:inline-flex;animation:slide 26s linear infinite}
.mq .track span{font-family:'Archivo Black';font-size:clamp(20px,3vw,34px);text-transform:uppercase;padding:14px 28px;display:inline-flex;align-items:center;gap:28px;letter-spacing:-.01em}
.mq .track span::after{content:"●";font-size:11px;opacity:.6}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;padding:clamp(50px,7vw,96px) 0 clamp(34px,4vw,56px);border-bottom:2px solid var(--line)}
.shead .idx{font-family:'Archivo';font-weight:800;font-size:12.5px;letter-spacing:.1em;color:var(--dim)}
.shead h2{font-family:'Archivo Black';font-size:clamp(28px,5.5vw,68px);line-height:.9;text-transform:uppercase;letter-spacing:-.02em;margin-top:10px}
.shead p{font-size:15.5px;color:var(--dim);max-width:34ch;text-align:right}
@media(max-width:680px){.shead{flex-direction:column;align-items:flex-start;gap:14px}.shead p{text-align:left}}

/* ============================================================
   SALES LETTER
   ============================================================ */
.letter{border-bottom:2px solid var(--line)}
.letter .wrap{max-width:820px;padding-top:clamp(50px,7vw,96px);padding-bottom:clamp(50px,7vw,96px)}
.letter .idx{font-family:'Archivo';font-weight:800;font-size:12.5px;letter-spacing:.1em;color:var(--dim);margin-bottom:18px;display:block}
.letter h2{font-family:'Archivo Black';font-size:clamp(26px,5vw,60px);line-height:.94;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:30px}
.letter p{font-size:clamp(16px,1.9vw,18px);color:var(--fg);margin-bottom:18px;line-height:1.7}
.letter strong{font-weight:700;color:var(--fg)}
.letter .big{font-family:'Archivo Black';font-size:clamp(18px,2.6vw,28px);line-height:1.2;text-transform:uppercase;background:var(--tang);color:#fff;display:inline;padding:5px 8px;box-decoration-break:clone;-webkit-box-decoration-break:clone;margin:12px 0;letter-spacing:-.01em}
.letter .sign{font-family:'Archivo Black';text-transform:uppercase;font-size:14px;margin-top:30px;color:var(--dim);letter-spacing:.04em}

/* ============================================================
   AGENTS
   ============================================================ */
.agents{border-bottom:2px solid var(--line)}
.agrid{display:grid;grid-template-columns:repeat(3,1fr);background:var(--bg)}
.ac{border-right:2px solid var(--line);padding:36px 28px;transition:color .35s var(--ease);position:relative;overflow:hidden;color:var(--fg)}
.agrid .ac:last-child{border-right:none}
.ac::before{content:"";position:absolute;left:0;right:0;top:0;height:0;background:var(--tang);transition:height .4s var(--ease);z-index:0}
.ac:hover::before{height:100%}
.ac>*{position:relative;z-index:1}
.ac:hover{color:#fff}
.ac .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.ac .ic{width:52px;height:52px;border:2px solid var(--line);display:grid;place-items:center;transition:border-color .3s var(--ease),background .3s var(--ease)}
.ac:hover .ic{border-color:#fff}
.ac .ic svg{width:24px;height:24px;stroke:var(--fg);fill:none;stroke-width:2;transition:stroke .3s var(--ease)}
.ac:hover .ic svg{stroke:#fff}
.ac .tag{font-family:'Archivo';font-weight:800;font-size:10px;letter-spacing:.14em;border:2px solid var(--line);padding:5px 9px;transition:border-color .3s var(--ease)}
.ac:hover .tag{border-color:#fff}
.ac h3{font-family:'Archivo Black';font-size:21px;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:10px;line-height:1}
.ac>p{font-size:14.5px;color:var(--dim);margin-bottom:22px;min-height:66px;transition:color .3s var(--ease)}
.ac:hover>p{color:rgba(255,255,255,.92)}
.ac ul{list-style:none;border-top:2px solid var(--line);transition:border-color .3s var(--ease)}
.ac:hover ul{border-color:rgba(255,255,255,.45)}
.ac li{font-family:'Archivo';font-weight:600;font-size:13px;padding:11px 0;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:10px;transition:border-color .3s var(--ease)}
.ac:hover li{border-color:rgba(255,255,255,.22)}
.ac li:last-child{border-bottom:none}
.ac li::before{content:"→";color:var(--tang);font-weight:900;transition:color .3s var(--ease)}
.ac:hover li::before{color:#fff}
@media(max-width:880px){.agrid{grid-template-columns:1fr}.ac{border-right:none;border-bottom:2px solid var(--line)}.agrid .ac:last-child{border-bottom:none}.ac>p{min-height:0}}

/* ============================================================
   GUARANTEE (always inverted — hardcoded contrast block)
   ============================================================ */
.guar{border-bottom:2px solid var(--line);background:var(--invert-bg);color:var(--invert-fg)}
.guar .wrap{padding:clamp(46px,7vw,90px) var(--pad);text-align:center;max-width:920px}
.guar .seal{font-family:'Archivo';font-weight:800;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--tang);margin-bottom:18px}
.guar h2{font-family:'Archivo Black';font-size:clamp(24px,4.6vw,52px);line-height:.98;text-transform:uppercase;letter-spacing:-.02em;max-width:22ch;margin:0 auto}
.guar p{color:var(--invert-dim);max-width:54ch;margin:22px auto 0;font-size:16px;line-height:1.6}

/* ============================================================
   PROOF / CASE STUDIES
   ============================================================ */
.proof{border-bottom:2px solid var(--line)}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr)}
.pc{border-right:2px solid var(--line);padding:30px 24px;display:flex;flex-direction:column;min-height:280px;transition:background .3s var(--ease),color .3s var(--ease);color:var(--fg);background:var(--bg)}
.pgrid .pc:last-child{border-right:none}
.pc:hover{background:var(--invert-bg);color:var(--invert-fg)}
.pc .stars{color:var(--tang);font-size:14px;letter-spacing:2px;margin-bottom:16px}
.pc blockquote{font-family:'Archivo';font-weight:700;font-size:15.5px;line-height:1.4;min-height:118px}
.pc .who{margin-top:auto;padding-top:14px;border-top:2px solid currentColor}
.pc .who .nm{font-family:'Archivo Black';font-size:13.5px;text-transform:uppercase;letter-spacing:.01em}
.pc .who .meta{font-size:12px;color:var(--dim);margin-top:3px;transition:color .3s var(--ease)}
.pc:hover .who .meta{color:var(--invert-dim)}
@media(max-width:880px){.pgrid{grid-template-columns:1fr 1fr}.pgrid .pc:nth-child(2n){border-right:none}.pgrid .pc:nth-child(-n+2){border-bottom:2px solid var(--line)}}
@media(max-width:520px){.pgrid{grid-template-columns:1fr}.pc{border-right:none!important;border-bottom:2px solid var(--line)!important;min-height:0}.pgrid .pc:last-child{border-bottom:none!important}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{border-bottom:2px solid var(--line)}
.acc{border-top:2px solid var(--line)}
.qa{border-bottom:2px solid var(--line)}
.qa button{width:100%;text-align:left;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:'Archivo';font-weight:900;font-size:clamp(16px,2.4vw,25px);text-transform:uppercase;letter-spacing:-.01em;color:var(--fg);transition:padding-left .25s var(--ease),color .25s var(--ease);min-height:60px}
.qa button:hover{padding-left:12px;color:var(--tang)}
.qa .pm{font-family:'Archivo Black';font-size:26px;color:var(--tang);transition:transform .35s var(--ease);flex-shrink:0}
.qa.on .pm{transform:rotate(45deg)}
.qa .a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.qa .a p{font-size:15.5px;color:var(--dim);padding-bottom:24px;max-width:72ch;line-height:1.65}

/* ============================================================
   CTA (always tangerine)
   ============================================================ */
.cta{background:var(--tang);color:#fff;border-bottom:2px solid var(--line)}
.cta .wrap{padding:clamp(52px,8vw,110px) var(--pad)}
.cta .idx{font-family:'Archivo';font-weight:800;font-size:12.5px;letter-spacing:.1em;margin-bottom:22px;color:#fff;opacity:.9}
.cta h2{font-family:'Archivo Black';font-size:clamp(30px,7vw,92px);line-height:.9;text-transform:uppercase;letter-spacing:-.02em;max-width:14ch}
.cta .lede{font-size:clamp(15px,2vw,20px);max-width:46ch;margin:26px 0 0;color:rgba(255,255,255,.94);line-height:1.55}
.cta .deliver{display:flex;flex-wrap:wrap;gap:0;margin:34px 0;border:2px solid #fff}
.cta .deliver span{font-family:'Archivo';font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;padding:12px 16px;border-right:2px solid #fff;display:flex;align-items:center;gap:8px}
.cta .deliver span:last-child{border-right:none}
.cta .deliver span::before{content:"✓";font-weight:900}
.cta .big{font-family:'Archivo Black';font-size:clamp(15px,2vw,19px);text-transform:uppercase;background:#0b0b0b;color:#fff;padding:20px 32px;border:2px solid #0b0b0b;display:inline-flex;align-items:center;gap:14px;transition:background .25s var(--ease),color .25s var(--ease);min-height:60px}
.cta .big:hover{background:#fff;color:#0b0b0b}
.cta .big .ar{transition:transform .3s;font-size:18px}.cta .big:hover .ar{transform:translateX(6px)}
.cta .note{font-family:'Archivo';font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;margin-top:18px;opacity:.92}
@media(max-width:560px){.cta .deliver span{border-right:none;border-bottom:2px solid #fff;width:100%}.cta .deliver span:last-child{border-bottom:none}.cta .big{width:100%;justify-content:center}}

/* ============================================================
   FOOTER (always black — anchors the 70-20-10 palette)
   ============================================================ */
footer{background:#0b0b0b;color:#f5f3ee;border-top:2px solid var(--line)}
.fg{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr 1.1fr;gap:36px;padding:clamp(46px,6vw,72px) 0 44px}
.fb img{height:24px;margin-bottom:18px}  /* white logo on black — correct in both themes */
.fb p{color:rgba(245,243,238,.58);font-size:14px;max-width:30ch;line-height:1.55}
.socials{display:flex;gap:10px;margin-top:20px}
.socials a{width:42px;height:42px;border:2px solid rgba(245,243,238,.3);color:#f5f3ee;display:grid;place-items:center;transition:background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.socials a:hover{background:var(--tang);border-color:var(--tang);color:#fff}
.socials svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8}
.fcol h5{font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--tang);margin-bottom:18px}
.fcol a,.fcol button{display:block;color:rgba(245,243,238,.62);font-size:14px;padding:6px 0;transition:color .2s,padding .2s;text-align:left;font-family:inherit;width:100%}
.fcol a:hover,.fcol button:hover{color:#f5f3ee;padding-left:5px}
.fbot{border-top:2px solid rgba(245,243,238,.18);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:rgba(245,243,238,.5);font-family:'Archivo';font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.fbot a:hover{color:#f5f3ee}
@media(max-width:900px){.fg{grid-template-columns:1fr 1fr;gap:32px}.fb{grid-column:1/-1}}
@media(max-width:520px){.fg{grid-template-columns:1fr;gap:28px}}

/* ============================================================
   CONTACT MODAL
   ============================================================ */
.mscrim{position:fixed;inset:0;z-index:400;background:rgba(11,11,11,.6);opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;display:grid;place-items:center;padding:16px}
.mscrim.open{opacity:1;visibility:visible}
.modal{background:var(--bg);color:var(--fg);border:2px solid var(--line);box-shadow:12px 12px 0 var(--tang);width:min(520px,100%);transform:translateY(20px) scale(.98);transition:transform .4s var(--ease);max-height:92vh;overflow:auto}
.mscrim.open .modal{transform:none}
.modal .mhead{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:2px solid var(--line)}
.modal .mhead h3{font-family:'Archivo Black';font-size:20px;text-transform:uppercase}
.modal .mx{width:40px;height:40px;border:2px solid var(--line);background:var(--bg);font-family:'Archivo';font-weight:800;transition:background .2s,color .2s}
.modal .mx:hover{background:var(--tang);color:#fff;border-color:var(--tang)}
.modal .mbody{padding:24px}
.modal label{font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:7px;color:var(--dim)}
.modal .fld{margin-bottom:18px}
.modal input,.modal textarea{width:100%;border:2px solid var(--line);background:var(--bg);color:var(--fg);padding:13px 14px;font-family:'Outfit';font-size:15px;outline:none;transition:box-shadow .2s}
.modal input:focus,.modal textarea:focus{box-shadow:4px 4px 0 var(--tang)}
.modal textarea{resize:vertical;min-height:96px;font-family:'Outfit'}
.modal .submit{width:100%;font-family:'Archivo Black';text-transform:uppercase;font-size:15px;background:var(--tang);color:#fff;border:2px solid var(--line);padding:16px;cursor:pointer;transition:background .2s;min-height:54px}
.modal .submit:hover{background:var(--invert-bg);color:var(--invert-fg)}
.modal .mfoot{font-size:13px;color:var(--dim);margin-top:14px;text-align:center}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  .ticker .track,.mq .track{animation:none}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* small-screen safety: avoid the .out hover stroke flicker on touch */
@media(hover:none){
  .hero h1:hover .out{color:transparent;-webkit-text-stroke-color:var(--fg)}
  .ac:hover::before{height:0}
  .ac:hover{color:var(--fg)}
  .ac:hover .ic{border-color:var(--line)}
  .ac:hover .ic svg{stroke:var(--fg)}
  .ac:hover .tag{border-color:var(--line)}
  .ac:hover>p{color:var(--dim)}
  .ac:hover ul{border-color:var(--line)}
  .ac:hover li{border-color:var(--line-soft)}
  .ac:hover li::before{color:var(--tang)}
  .pc:hover{background:var(--bg);color:var(--fg)}
  .pc:hover .who .meta{color:var(--dim)}
}

/* ============================================================
   PARTNER MARQUEE (homepage — ambiguous, intrigue-driving)
   ============================================================ */
.partners{border-bottom:2px solid var(--line);background:var(--bg);overflow:hidden}
.partners .lab{font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);text-align:center;padding:26px 0 0}
.pmarq{overflow:hidden;white-space:nowrap;padding:22px 0 30px;position:relative}
.pmarq::before,.pmarq::after{content:"";position:absolute;top:0;bottom:0;width:90px;z-index:2;pointer-events:none}
.pmarq::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.pmarq::after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.pmarq .ptrack{display:inline-flex;align-items:center;animation:slide 46s linear infinite;will-change:transform}
.pmarq .ptrack span{font-family:'Archivo';font-weight:800;font-size:clamp(16px,2.1vw,24px);letter-spacing:-.01em;text-transform:uppercase;color:var(--fg);opacity:.4;padding:0 26px;display:inline-flex;align-items:center;gap:26px;transition:opacity .3s var(--ease),color .3s var(--ease);white-space:nowrap}
.pmarq .ptrack span::after{content:"/";color:var(--tang);opacity:.5;font-weight:900}
.pmarq .ptrack span:hover{opacity:1;color:var(--tang)}

/* ============================================================
   CONTENT PAGE SCAFFOLD (about / agents / case studies / legal / forms)
   ============================================================ */
.page-hero{border-bottom:2px solid var(--line);padding:clamp(48px,8vw,110px) 0 clamp(40px,6vw,72px)}
.page-hero .idx{font-family:'Archivo';font-weight:800;font-size:12.5px;letter-spacing:.1em;color:var(--dim);display:block;margin-bottom:18px}
.page-hero h1{font-family:'Archivo Black';font-size:clamp(38px,9vw,110px);line-height:.9;text-transform:uppercase;letter-spacing:-.02em}
.page-hero p{font-size:clamp(17px,2vw,22px);color:var(--dim);max-width:54ch;margin-top:26px}

.prose{border-bottom:2px solid var(--line)}
.prose .wrap{max-width:780px;padding-top:clamp(48px,7vw,90px);padding-bottom:clamp(48px,7vw,90px)}
.prose h2{font-family:'Archivo Black';font-size:clamp(24px,4vw,42px);text-transform:uppercase;letter-spacing:-.01em;margin:0 0 22px;line-height:1}
.prose h2:not(:first-child){margin-top:clamp(40px,5vw,64px)}
.prose h3{font-family:'Archivo';font-weight:900;font-size:clamp(17px,2.2vw,22px);text-transform:uppercase;letter-spacing:-.01em;margin:28px 0 10px}
.prose p{font-size:clamp(16px,1.9vw,18px);line-height:1.7;margin-bottom:18px;color:var(--fg)}
.prose ul{list-style:none;margin:0 0 20px}
.prose li{font-size:16px;line-height:1.6;padding:9px 0 9px 26px;position:relative;color:var(--fg)}
.prose li::before{content:"→";position:absolute;left:0;color:var(--tang);font-weight:900}
.prose strong{font-weight:700}
.prose a{color:var(--tang);text-decoration:underline;text-underline-offset:2px}
.prose .big{font-family:'Archivo Black';font-size:clamp(18px,2.6vw,28px);line-height:1.2;text-transform:uppercase;background:var(--tang);color:#fff;display:inline;padding:5px 8px;box-decoration-break:clone;-webkit-box-decoration-break:clone;letter-spacing:-.01em}
.prose .legal-meta{font-family:'Archivo';font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--dim);margin-bottom:30px}

/* mid-page tangerine CTA band (reusable) */
.midcta{background:var(--tang);color:#fff;border-bottom:2px solid var(--line)}
.midcta .wrap{padding:clamp(46px,7vw,90px) var(--pad);text-align:center}
.midcta h2{font-family:'Archivo Black';font-size:clamp(26px,5vw,56px);line-height:.94;text-transform:uppercase;letter-spacing:-.02em;max-width:20ch;margin:0 auto}
.midcta p{color:rgba(255,255,255,.94);max-width:48ch;margin:20px auto 0;font-size:clamp(15px,2vw,18px)}
.midcta .big{font-family:'Archivo Black';font-size:clamp(15px,2vw,19px);text-transform:uppercase;background:#0b0b0b;color:#fff;padding:20px 32px;border:2px solid #0b0b0b;display:inline-flex;align-items:center;gap:14px;transition:background .25s var(--ease),color .25s var(--ease);margin-top:30px;min-height:60px}
.midcta .big:hover{background:#fff;color:#0b0b0b}
.midcta .big .ar{transition:transform .3s}.midcta .big:hover .ar{transform:translateX(6px)}

/* agent detail blocks (meet-the-agents) */
.adetail{border-bottom:2px solid var(--line)}
.adetail .wrap{padding:clamp(50px,7vw,96px) var(--pad)}
.adetail .row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:start}
.adetail .idx{font-family:'Archivo';font-weight:800;font-size:12.5px;letter-spacing:.1em;color:var(--tang);display:block;margin-bottom:16px}
.adetail h2{font-family:'Archivo Black';font-size:clamp(32px,6vw,72px);line-height:.9;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:18px}
.adetail .tagline{font-size:clamp(17px,2.2vw,22px);color:var(--dim);margin-bottom:30px;max-width:30ch}
.adetail .cap-h{font-family:'Archivo';font-weight:800;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:14px}
.adetail .caps{list-style:none;border-top:2px solid var(--line);margin-bottom:8px}
.adetail .caps li{font-family:'Archivo';font-weight:600;font-size:14.5px;padding:13px 0;border-bottom:1px solid var(--line-soft);display:flex;gap:12px;align-items:flex-start}
.adetail .caps li::before{content:"→";color:var(--tang);font-weight:900;flex-shrink:0}
.adetail .out-h{font-family:'Archivo';font-weight:800;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin:30px 0 14px}
.adetail .out-acc{border-top:2px solid var(--line)}
.adetail .out-acc .qa button{font-family:'Archivo';font-weight:700;font-size:14.5px;text-transform:none;letter-spacing:0;padding:14px 0;min-height:0;gap:12px}
.adetail .out-acc .qa button .pm{font-size:20px}
.adetail .out-acc .qa .a p{font-size:14px;line-height:1.6;padding-bottom:16px;padding-left:0}
@media(max-width:820px){.adetail .row{grid-template-columns:1fr;gap:36px}}

/* lead-capture form (get-powered / support / careers) */
.leadform{border:2px solid var(--line);background:var(--surface);padding:clamp(24px,3vw,40px)}
.leadform .fld{margin-bottom:18px}
.leadform label{font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:7px;color:var(--dim)}
.leadform input,.leadform textarea,.leadform select{width:100%;border:2px solid var(--line);background:var(--bg);color:var(--fg);padding:13px 14px;font-family:'Outfit';font-size:15px;outline:none;transition:box-shadow .2s}
.leadform input:focus,.leadform textarea:focus,.leadform select:focus{box-shadow:4px 4px 0 var(--tang)}
.leadform textarea{resize:vertical;min-height:120px}
.leadform .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.leadform .submit{width:100%;font-family:'Archivo Black';text-transform:uppercase;font-size:15px;background:var(--tang);color:#fff;border:2px solid var(--line);padding:17px;cursor:pointer;transition:background .2s,color .2s;min-height:56px}
.leadform .submit:hover{background:var(--invert-bg);color:var(--invert-fg)}
.leadform .submit:disabled{opacity:.7;cursor:default}
.leadform .status{font-size:13.5px;color:var(--dim);margin-top:14px;text-align:center}
@media(max-width:560px){.leadform .two{grid-template-columns:1fr}}

/* quick-support cards */
.qcards{display:grid;grid-template-columns:1fr;gap:0;border-top:2px solid var(--line)}
.qcards .qc{border-bottom:2px solid var(--line);padding:22px 20px;transition:background .3s var(--ease),color .3s var(--ease)}
.qcards .qc:hover{background:var(--tang);color:#fff}
.qcards .qc h4{font-family:'Archivo';font-weight:900;font-size:14px;text-transform:uppercase;letter-spacing:.01em;margin-bottom:5px}
.qcards .qc p{font-size:13px;color:var(--dim);transition:color .3s}
.qcards .qc:hover p{color:rgba(255,255,255,.9)}

a.ac{text-decoration:none;cursor:pointer}
