/* =========================================================
   BRANDCORE — page components. Extends site.css (uses its
   :root tokens). Covers multi-page chrome + new layouts.
   ========================================================= */

/* ---------- mobile nav ---------- */
.nav-toggle{display:none;align-items:center;justify-content:center;gap:5px;flex-direction:column;width:46px;height:40px;border:1px solid var(--line-2);border-radius:2px;background:transparent;cursor:pointer}
.nav-toggle span{display:block;width:18px;height:1.5px;background:var(--ink);transition:transform .35s var(--ease),opacity .25s}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-nav{position:fixed;inset:0;z-index:115;background:rgba(6,5,7,.98);backdrop-filter:blur(16px);display:flex;flex-direction:column;justify-content:center;gap:8px;padding:88px var(--pad) 44px;overflow-y:auto;transform:translateY(-102%);transition:transform .55s var(--ease);visibility:hidden}
@media (max-height:600px){.mobile-nav{justify-content:flex-start}}
body.menu-open .mobile-nav{transform:none;visibility:visible}
.mobile-nav a{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(2rem,9vw,3.4rem);line-height:1.04;letter-spacing:-.01em;color:var(--ink-dim);transition:color .3s,transform .3s var(--ease);display:flex;align-items:baseline;gap:14px}
.mobile-nav a:hover,.mobile-nav a:focus{color:var(--gold)}
.mobile-nav a .mn{font-family:var(--mono);font-size:.7rem;color:var(--ash);font-weight:500}
.mobile-nav .mn-foot{margin-top:36px;font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--ash);text-transform:uppercase;display:flex;flex-direction:column;gap:8px}
.mobile-nav .mn-foot a{font-family:var(--mono);font-size:.8rem;color:var(--gold-hot)}
@media (max-width:900px){.nav-toggle{display:flex}}
@media (min-width:901px){.mobile-nav{display:none}}

/* ---------- breadcrumbs ---------- */
.crumbs{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ash)}
.crumbs a{color:var(--ink-dim);transition:color .3s}
.crumbs a:hover{color:var(--gold-hot)}
.crumbs .sep{opacity:.5}

/* ---------- interior page header ---------- */
.page-head{position:relative;padding-top:clamp(116px,15vw,188px);padding-bottom:clamp(46px,6vw,84px);overflow:hidden;border-bottom:1px solid var(--line-2)}
.page-head::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(120% 110% at 82% -10%,rgba(201,162,48,.10),transparent 56%)}
.ph-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(26px,4vw,64px);align-items:end}
.page-head h1{font-family:var(--display);font-weight:800;text-transform:uppercase;line-height:.88;letter-spacing:-.02em;font-size:clamp(2.7rem,7.4vw,6.4rem);margin:24px 0 0}
.page-head h1 .gold{color:var(--gold)}
.ph-sub{color:var(--ink-dim);font-size:clamp(1.02rem,1.35vw,1.22rem);max-width:50ch;margin-top:20px}
.ph-aside{display:flex;flex-direction:column;gap:14px}
.ph-spec{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase}
.ph-spec .k{color:var(--ash)}
.ph-spec .v{color:var(--gold-hot)}
@media (max-width:860px){.ph-grid{grid-template-columns:1fr}.ph-aside{margin-top:6px}}

/* ---------- generic text ---------- */
.lead{color:var(--ink);font-size:clamp(1.1rem,1.5vw,1.4rem);max-width:62ch;line-height:1.5}
.prose{color:var(--ink-dim);max-width:70ch}
.prose>*+*{margin-top:1.1em}
.prose h2{font-family:var(--display);font-weight:800;text-transform:uppercase;color:var(--ink);font-size:clamp(1.7rem,3vw,2.6rem);line-height:.95;letter-spacing:-.01em;margin-top:1.7em}
.prose h3{font-family:var(--display);font-weight:700;text-transform:uppercase;color:var(--ink);font-size:clamp(1.3rem,2vw,1.7rem);margin-top:1.5em}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--gold-hot);border-bottom:1px solid var(--line-2);transition:border-color .3s}
.prose a:hover{border-color:var(--gold-hot)}
.prose ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.prose ul li{padding-left:24px;position:relative;color:var(--ink-dim)}
.prose ul li::before{content:"→";position:absolute;left:0;color:var(--gold)}

/* ---------- portfolio ---------- */
.pf-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(40px,5vw,70px)}
.pf-head p{max-width:42ch;color:var(--ink-dim)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.pf-card{background:var(--void);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background .4s}
.pf-card:hover{background:var(--void-2)}
.pf-thumb{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--panel);border-bottom:1px solid var(--line-2)}
.pf-thumb img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(.35) contrast(1.03) brightness(.92);transition:transform 1s var(--ease),filter .6s}
.pf-card:hover .pf-thumb img{transform:scale(1.06);filter:none}
.pf-thumb .idx{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;color:var(--gold-hot);background:rgba(6,5,7,.6);backdrop-filter:blur(6px);padding:5px 9px;border:1px solid var(--line-2);border-radius:2px}
.pf-thumb .live{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.56rem;letter-spacing:.14em;color:var(--ink);background:rgba(6,5,7,.6);backdrop-filter:blur(6px);padding:5px 9px;border:1px solid var(--line-2);border-radius:2px}
.pf-thumb .live i{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 7px var(--gold);animation:blink 1.6s steps(1) infinite}
.pf-body{padding:clamp(20px,2.1vw,30px);display:flex;flex-direction:column;gap:13px;flex:1}
.pf-sector{font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-hot)}
.pf-name{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.4rem,2vw,1.95rem);line-height:.95;letter-spacing:-.01em}
.pf-blurb{color:var(--ink-dim);font-size:.92rem;line-height:1.55;flex:1}
.pf-tags{display:flex;flex-wrap:wrap;gap:7px}
.pf-tags span{font-family:var(--mono);font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ash);border:1px solid var(--line-2);padding:5px 9px;border-radius:2px}
.pf-link{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);margin-top:4px;transition:color .3s}
.pf-link .arr{transition:transform .4s var(--ease)}
.pf-card:hover .pf-link{color:var(--gold-hot)}
.pf-card:hover .pf-link .arr{transform:translate(4px,-4px)}
@media (max-width:1000px){.pf-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.pf-grid{grid-template-columns:1fr}}

/* ---------- services grid (hub) ---------- */
.svc-cat{display:flex;align-items:center;gap:18px;margin:clamp(46px,6vw,80px) 0 26px}
.svc-cat:first-of-type{margin-top:0}
.svc-cat h2{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.4rem);line-height:1;white-space:nowrap;letter-spacing:-.01em}
.svc-cat .ln{flex:1;height:1px;background:var(--line-2)}
.svc-cat .ct{font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;color:var(--ash)}
.svc-grid{display:flex;flex-wrap:wrap;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.svc-grid>*{flex:1 1 31%;min-width:0}        /* grow to fill the last row — no blank columns */
.svc-grid.cols4>*{flex-basis:22%}            /* related: 4-up */
.svc-card{background:var(--void);padding:clamp(26px,2.8vw,40px);position:relative;display:flex;flex-direction:column;gap:13px;min-height:218px;overflow:hidden;transition:background .4s}
.svc-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:0 50%;transition:transform .5s var(--ease)}
.svc-card:hover::before{transform:none}
.svc-card:hover{background:var(--void-2)}
.svc-num{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;color:var(--ash)}
.svc-card h3{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.35rem,1.9vw,1.75rem);line-height:.98;letter-spacing:-.01em}
.svc-card p{color:var(--ink-dim);font-size:.88rem;line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.svc-card .go{display:inline-flex;align-items:center;gap:9px;margin-top:auto;font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-hot)}
.svc-card .go .arr{transition:transform .4s var(--ease)}
.svc-card:hover .go .arr{transform:translateX(5px)}
@media (max-width:1080px){.svc-grid.cols4>*{flex-basis:31%}}
@media (max-width:900px){.svc-grid>*,.svc-grid.cols4>*{flex-basis:46%}}
@media (max-width:560px){.svc-grid>*,.svc-grid.cols4>*{flex-basis:100%}}

/* ---------- feature grid (service "what's included") ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.feature{background:var(--void);padding:clamp(24px,2.6vw,38px);position:relative}
.feature .fi{font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;color:var(--gold);margin-bottom:18px}
.feature h4{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.2rem,1.7vw,1.5rem);line-height:1;margin-bottom:12px;letter-spacing:-.01em}
.feature p{color:var(--ink-dim);font-size:.92rem;line-height:1.55}
@media (max-width:680px){.feature-grid{grid-template-columns:1fr}}

/* ---------- process steps ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.step{background:var(--void-2);padding:clamp(24px,2.6vw,36px);position:relative}
.step .sn{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;color:var(--gold);margin-bottom:22px}
.step h4{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.2rem,1.7vw,1.55rem);line-height:.98;margin-bottom:12px;letter-spacing:-.01em}
.step p{color:var(--ink-dim);font-size:.9rem;line-height:1.55}
@media (max-width:760px){.process{grid-template-columns:1fr 1fr}}
@media (max-width:430px){.process{grid-template-columns:1fr}}

/* ---------- split: body + aside spec card ---------- */
.split{display:grid;grid-template-columns:1.5fr .85fr;gap:clamp(30px,4.5vw,70px);align-items:start}
.aside-card{border:1px solid var(--line-2);background:var(--void-2);padding:clamp(24px,2.6vw,34px);position:relative}
.aside-card::before{content:"";position:absolute;left:0;top:0;width:2px;height:100%;background:linear-gradient(var(--gold),transparent)}
.aside-card h4{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;color:var(--gold-hot);text-transform:uppercase;margin-bottom:18px}
.aside-card ul{list-style:none}
.aside-card li{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--line);color:var(--ink-dim);font-size:.92rem}
.aside-card li:last-child{border-bottom:0}
.aside-card li::before{content:"→";color:var(--gold);flex:none}
@media (max-width:860px){.split{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line-2)}
.faq details{border-bottom:1px solid var(--line-2)}
.faq summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:clamp(20px,2.4vw,30px) 0;font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.1rem,1.7vw,1.5rem);line-height:1.05;letter-spacing:-.01em;transition:color .3s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--gold-hot)}
.faq summary .pm{font-family:var(--mono);color:var(--gold);font-size:1.3rem;flex:none;transition:transform .35s var(--ease)}
.faq details[open] summary .pm{transform:rotate(45deg)}
.faq .a{color:var(--ink-dim);max-width:74ch;padding-bottom:clamp(20px,2.4vw,28px);font-size:.97rem;line-height:1.6}

/* ---------- reusable CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border:1px solid var(--line-2);background:var(--void-2);padding:clamp(44px,6vw,86px) clamp(24px,4vw,60px);text-align:center}
.cta-band .glow{position:absolute;left:50%;top:50%;width:min(80vw,760px);height:min(80vw,760px);transform:translate(-50%,-50%);pointer-events:none;background:radial-gradient(circle,rgba(201,162,48,.14),transparent 60%);filter:blur(8px)}
.cta-band h2{font-family:var(--display);font-weight:800;text-transform:uppercase;line-height:.9;letter-spacing:-.02em;font-size:clamp(2.4rem,6vw,5rem);position:relative}
.cta-band p{color:var(--ink-dim);max-width:48ch;margin:22px auto 0;position:relative;font-size:clamp(1rem,1.3vw,1.16rem)}
.cta-band .ctas{display:flex;gap:15px;justify-content:center;flex-wrap:wrap;margin-top:38px;position:relative}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2)}
.contact-pane{background:var(--void);padding:clamp(30px,3.4vw,56px)}
.contact-pane.alt{background:var(--void-2)}
.contact-pane h3{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.5rem,2.4vw,2.1rem);line-height:.98;margin-bottom:20px;letter-spacing:-.01em}
.form{display:flex;flex-direction:column;gap:17px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ash)}
.field input,.field textarea,.field select{width:100%;background:var(--void);border:1px solid var(--line-2);color:var(--ink);padding:13px 15px;font-family:var(--body);font-size:.95rem;border-radius:2px;transition:border-color .3s,background .3s}
.contact-pane.alt .field input,.contact-pane.alt .field textarea,.contact-pane.alt .field select{background:var(--void)}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold)}
.field input::placeholder,.field textarea::placeholder{color:var(--ash)}
.form .btn{align-self:flex-start;margin-top:6px;border:none;cursor:pointer}
.form-note{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;color:var(--ash);text-transform:uppercase}
/* honeypot — pulled far off-screen, hidden from people + assistive tech */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}
.cf-turnstile{margin:2px 0 2px}
.form-status{display:none;font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;line-height:1.55;padding:13px 15px;border:1px solid var(--line-2);border-radius:2px}
.form-status.show{display:block}
.form-status.ok{border-color:rgba(201,162,48,.5);color:var(--gold-hot);background:rgba(201,162,48,.07)}
.form-status.err{border-color:rgba(214,90,72,.55);color:#e9a08f;background:rgba(214,90,72,.08)}
.form .btn[disabled]{opacity:.55;pointer-events:none}
.info-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:17px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:0}
.info-row .k{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;color:var(--ash);text-transform:uppercase}
.info-row .v{font-family:var(--display);font-weight:700;font-size:clamp(1.05rem,1.6vw,1.4rem);transition:color .3s}
.info-row a.v:hover{color:var(--gold-hot)}
@media (max-width:780px){.contact-grid{grid-template-columns:1fr}}

/* ---------- footer legal links ---------- */
.foot-legal{display:flex;gap:16px;flex-wrap:wrap}
.foot-legal a{color:var(--ink-dim);transition:color .3s}
.foot-legal a:hover{color:var(--gold-hot)}

/* ---------- small helpers ---------- */
.center{text-align:center}
.band{border-block:1px solid var(--line-2);background:var(--void-2)}
.kicker{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;color:var(--ash);text-transform:uppercase}
.svc-mini{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.svc-mini a{font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);border:1px solid var(--line-2);padding:7px 12px;border-radius:2px;transition:border-color .3s,color .3s}
.svc-mini a:hover{border-color:var(--gold);color:var(--gold-hot)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,60px)}
@media (max-width:820px){.two-col{grid-template-columns:1fr}}
