/* ============================================================
   Mission Construction — shared stylesheet (multi-page)
   Light theme = "Reality"  ·  Dark theme = "Blueprint"
   ============================================================ */

:root{
  --cream:#FAF7F2;
  --cream-2:#F2ECE3;
  --white:#FFFFFF;
  --ink:#1C1B19;
  --body:#56514A;
  --muted:#8A847A;
  --bronze:#9A7A4F;
  --bronze-deep:#80623D;
  --bronze-soft:#B0885A;
  --espresso:#241B13;
  --slate:#46545F;
  --line:#E8E1D5;
  --line-soft:#F0EAE0;
  --bar-bg:rgba(250,247,242,.9);   /* header / mobile-cta glass */
  --shadow:0 18px 50px -18px rgba(50,38,25,.22);
  --shadow-sm:0 8px 24px -12px rgba(50,38,25,.18);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--body);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .45s ease,color .45s ease}
h1,h2,h3,h4,.disp{font-family:'Space Grotesk',sans-serif;color:var(--ink);line-height:1.06;font-weight:600;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1340px;margin:0 auto;padding:0 clamp(26px,5vw,72px)}
.eyebrow{font-family:'Space Grotesk',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.74rem;color:var(--bronze)}

/* subtle blueprint grid helper (kept faint) */
.bp-grid{position:relative}
.bp-grid::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:34px 34px;-webkit-mask-image:radial-gradient(circle at 50% 40%,#000,transparent 72%);mask-image:radial-gradient(circle at 50% 40%,#000,transparent 72%);opacity:.55;pointer-events:none}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:.93rem;padding:.92rem 1.7rem;border-radius:10px;cursor:pointer;border:1.5px solid transparent;transition:transform .18s ease,background .22s ease,border-color .22s ease,color .22s ease;letter-spacing:.01em;will-change:transform}
.btn-bronze{background:var(--bronze);color:#fff;box-shadow:0 10px 24px -10px rgba(154,122,79,.7)}
.btn-bronze:hover{background:var(--bronze-deep)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:var(--white)}
.btn-white{background:#fff;color:var(--bronze-deep)}
.btn-white:hover{background:var(--ink);color:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}.reveal[data-d="2"]{transition-delay:.14s}.reveal[data-d="3"]{transition-delay:.21s}.reveal[data-d="4"]{transition-delay:.28s}

/* ===== LOADER ===== */
#loader{position:fixed;inset:0;z-index:200;background:var(--cream);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;transition:opacity .6s ease,visibility .6s}
#loader.done{opacity:0;visibility:hidden}
.load-art{width:180px;height:auto;overflow:visible}
#lLetters path,#lLetters polyline{stroke-dasharray:1;stroke-dashoffset:1}
.lM{animation:draw .55s .15s forwards ease}
.lC{animation:draw .55s .6s forwards ease}
#lLetters{animation:lfade .4s 1.2s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes lfade{to{opacity:0}}
#lCube polygon{opacity:0;transform-box:fill-box;transform-origin:center}
#lCube .top{animation:drop .5s 1.12s forwards cubic-bezier(.2,.8,.3,1)}
#lCube .left{animation:slideL .5s 1.3s forwards cubic-bezier(.2,.8,.3,1)}
#lCube .right{animation:slideR .5s 1.45s forwards cubic-bezier(.2,.8,.3,1)}
@keyframes drop{from{opacity:0;transform:translateY(-26px)}to{opacity:1;transform:none}}
@keyframes slideL{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:none}}
@keyframes slideR{from{opacity:0;transform:translateX(22px)}to{opacity:1;transform:none}}
.load-word{font-family:'Space Grotesk';font-weight:600;letter-spacing:.34em;font-size:.82rem;color:var(--ink);text-transform:uppercase;opacity:0;animation:fadeUp .5s 1.7s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:.85;transform:none}}

/* ===== HEADER ===== */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.3s ease}
header .bar{display:flex;align-items:center;justify-content:space-between;height:78px;transition:.3s}
header.scrolled{background:var(--bar-bg);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
header.scrolled .bar{height:64px}
.brand{display:flex;align-items:center;gap:.7rem;cursor:pointer}
.brand .mono{width:38px;height:38px;perspective:300px}
.brand .mono svg{width:100%;height:100%;transition:transform .8s cubic-bezier(.4,.2,.2,1)}
.brand.spin .mono svg{transform:rotateY(360deg)}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:'Space Grotesk';font-weight:700;font-size:1.02rem;color:var(--ink);letter-spacing:.02em}
.brand .wm span{font-family:'Space Grotesk';font-weight:500;font-size:.6rem;letter-spacing:.34em;color:var(--bronze);text-transform:uppercase;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a.lnk{font-weight:500;font-size:.93rem;color:var(--ink);position:relative}
.nav-links a.lnk::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--bronze);transition:.25s}
.nav-links a.lnk:hover::after,.nav-links a.lnk.active::after{width:100%}
.nav-links a.lnk.active{color:var(--bronze)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;z-index:70}
.menu-btn span{width:24px;height:2px;background:var(--ink);transition:.3s}
@media(max-width:980px){
  .brand .wm{display:none}
  .nav-links{position:fixed;inset:0 0 0 auto;width:80%;max-width:320px;background:var(--cream);flex-direction:column;justify-content:center;gap:1.8rem;transform:translateX(100%);transition:.35s ease;box-shadow:var(--shadow);padding:2rem}
  .nav-links.open{transform:none}
  .menu-btn{display:flex}
  .menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-btn.open span:nth-child(2){opacity:0}
  .menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ===== HERO ===== */
.hero{padding:148px 0 86px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-tag{display:inline-flex;align-items:center;gap:.6rem;background:var(--white);border:1px solid var(--line);border-radius:50px;padding:.45rem 1rem;font-size:.78rem;font-weight:500;color:var(--body);margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}
.hero-tag .dot{width:7px;height:7px;border-radius:50%;background:var(--bronze);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(154,122,79,.5)}70%{box-shadow:0 0 0 7px rgba(154,122,79,0)}}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:700;margin-bottom:1.3rem;letter-spacing:-.03em}
.hero h1 .accent{color:var(--bronze)}
.hero .sub{font-size:1.12rem;color:var(--body);max-width:47ch;margin-bottom:2.1rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:2.4rem}
.hero-mini{display:flex;gap:2rem;flex-wrap:wrap}
.hero-mini b{font-family:'Space Grotesk';font-size:1.35rem;color:var(--ink);font-weight:700;display:block;line-height:1}
.hero-mini span{font-size:.78rem;color:var(--muted)}
.hero-visual{position:relative}
.hero-photo{aspect-ratio:4/5;border-radius:20px;overflow:hidden;background:linear-gradient(160deg,#ECE3D6,#DfD3C2);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;position:relative}
.ph-label{display:flex;flex-direction:column;align-items:center;gap:.6rem;color:var(--bronze);opacity:.8;z-index:2;text-align:center;padding:1rem}
.ph-label svg{width:46px;height:46px;stroke:var(--bronze);stroke-width:1.3;fill:none}
.ph-label span{font-size:.74rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase}
.hero-photo .bp-house{position:absolute;inset:0;width:100%;height:100%;opacity:.5}
.bp-house path,.bp-house line,.bp-house polyline,.bp-house rect{stroke:#fff;stroke-width:1.4;fill:none;stroke-dasharray:1;stroke-dashoffset:1;pathLength:1}
.bp-house.draw path,.bp-house.draw line,.bp-house.draw polyline,.bp-house.draw rect{animation:draw 2.2s ease forwards}
.float-card{position:absolute;background:var(--white);border-radius:14px;box-shadow:var(--shadow);padding:.85rem 1.1rem;display:flex;align-items:center;gap:.75rem;z-index:3}
.float-card.fc1{bottom:22px;left:-24px;animation:floaty 5s ease-in-out infinite}
.float-card.fc2{top:24px;right:-18px;animation:floaty 6s ease-in-out infinite .6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.float-card .fci{width:38px;height:38px;border-radius:9px;background:var(--cream);display:flex;align-items:center;justify-content:center}
.float-card .fci svg{width:21px;height:21px;stroke:var(--bronze);stroke-width:1.9;fill:none}
.float-card b{font-family:'Space Grotesk';color:var(--ink);font-size:.92rem;display:block;line-height:1.1}
.float-card small{font-size:.7rem;color:var(--muted)}
.stars{color:var(--bronze);letter-spacing:2px;font-size:.85rem}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:46px}.hero{padding:128px 0 64px}.float-card.fc1{left:6px}.float-card.fc2{right:6px}}

/* ===== PAGE HERO (sub-pages) ===== */
.page-hero{padding:150px 0 56px;position:relative;overflow:hidden}
.page-hero .inner{position:relative;z-index:2;max-width:62ch}
.page-hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:700;letter-spacing:-.03em;margin:.7rem 0 1rem}
.page-hero p{font-size:1.1rem;color:var(--body);max-width:54ch}
.crumbs{font-family:'Space Grotesk';font-size:.78rem;font-weight:500;letter-spacing:.06em;color:var(--muted)}
.crumbs a:hover{color:var(--bronze)}

/* ===== SECTION ===== */
section.block{padding:84px 0}
section.block.tight{padding:60px 0}
.head{max-width:60ch}
.head.center{margin:0 auto;text-align:center}
.head .eyebrow{display:block;margin-bottom:1rem}
.head h2{font-size:clamp(2rem,4vw,3rem);font-weight:600;margin-bottom:1.05rem;letter-spacing:-.025em}
.head p{color:var(--body);font-size:1.05rem}

/* ===== SERVICES BENTO ===== */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:52px}
.cell{background:var(--white);border:1px solid var(--line-soft);border-radius:18px;padding:1.7rem;transition:.28s ease;position:relative;overflow:hidden}
.cell::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--bronze);transition:.3s}
.cell:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.cell:hover::before{width:100%}
.cell .ico{width:50px;height:50px;border-radius:12px;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:.28s}
.cell:hover .ico{background:var(--bronze)}
.cell .ico svg{width:25px;height:25px;stroke:var(--bronze);stroke-width:1.7;transition:.28s;fill:none}
.cell:hover .ico svg{stroke:#fff}
.cell h3{font-size:1.16rem;margin-bottom:.4rem;font-weight:600}
.cell p{font-size:.9rem;color:var(--body)}
.cell.feature{grid-column:span 2;grid-row:span 2;background:linear-gradient(160deg,var(--espresso),#3a2c1d);color:#fff;display:flex;flex-direction:column;justify-content:space-between}
.cell.feature::before{display:none}
.cell.feature .ico{background:rgba(255,255,255,.1)}
.cell.feature:hover .ico{background:var(--bronze)}
.cell.feature h3{color:#fff;font-size:1.9rem}
.cell.feature p{color:rgba(255,255,255,.8);font-size:.98rem;max-width:34ch}
.cell.feature .tagpill{display:inline-block;font-family:'Space Grotesk';font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--bronze-soft);border:1px solid rgba(176,136,90,.4);border-radius:50px;padding:.3rem .8rem;margin-bottom:1rem;width:fit-content}
@media(max-width:900px){.bento{grid-template-columns:repeat(2,1fr)}.cell.feature{grid-column:span 2;grid-row:span 1}}
@media(max-width:560px){.bento{grid-template-columns:1fr}.cell.feature{grid-column:span 1}}

/* ===== EXPLORE CARDS (home hub) ===== */
.explore{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:52px}
.xcard{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line-soft);background:linear-gradient(160deg,#ECE3D6,#DcCfBD);min-height:260px;display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;transition:.28s;color:var(--ink)}
.xcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.xcard .xbp{position:absolute;inset:0;opacity:.5}
.xcard .xbp svg{width:100%;height:100%}
.xcard .xbp .bl{fill:none;stroke:var(--bronze);stroke-width:1.1;opacity:.4}
.xcard h3{position:relative;z-index:2;font-size:1.3rem;margin-bottom:.2rem}
.xcard p{position:relative;z-index:2;font-size:.86rem;color:var(--body)}
.xcard .go{position:relative;z-index:2;margin-top:.7rem;font-family:'Space Grotesk';font-weight:600;font-size:.82rem;color:var(--bronze-deep);display:inline-flex;align-items:center;gap:.3rem}
.xcard.big{grid-column:span 2;min-height:300px}
@media(max-width:900px){.explore{grid-template-columns:repeat(2,1fr)}.xcard.big{grid-column:span 2}}
@media(max-width:560px){.explore{grid-template-columns:1fr}.xcard.big{grid-column:span 1}}

/* ===== PHOTO CAROUSEL (replaces text marquee) ===== */
.carousel{margin-top:50px;position:relative}
.carousel-frame{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/9;background:var(--cream-2)}
.cslide{position:absolute;inset:0;opacity:0;z-index:0;transform:scale(1.04);transition:opacity .8s ease,transform 1.2s ease;display:flex;align-items:flex-end;background:linear-gradient(160deg,#ECE3D6,#DcCfBD)}
.cslide.on{opacity:1;z-index:2;transform:scale(1)}
.cslide .cbp{position:absolute;inset:0;opacity:.45;display:flex;align-items:center;justify-content:center}
.cslide .cbp svg{width:60%;height:60%}
.cslide .cbp .bl{fill:none;stroke:var(--bronze);stroke-width:1.1;opacity:.5}
.cslide .cph{position:relative;z-index:2;width:100%;padding:1.6rem 1.8rem;background:linear-gradient(0deg,rgba(28,27,25,.6),transparent);color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap}
.cslide .cph .ttl{font-family:'Space Grotesk';font-weight:600;font-size:1.15rem}
.cslide .cph .meta{font-size:.82rem;opacity:.85}
.cslide .cph .pill{font-family:'Space Grotesk';font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);padding:.3rem .7rem;border-radius:50px}
.cslide .midlabel{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--bronze);opacity:.8}
.cslide .midlabel svg{width:40px;height:40px;stroke:var(--bronze);stroke-width:1.2;fill:none}
.cslide .midlabel span{font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.cnav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border-radius:50%;background:rgba(250,247,242,.92);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;box-shadow:var(--shadow-sm)}
.cnav:hover{background:var(--ink)}
.cnav:hover svg{stroke:#fff}
.cnav svg{width:20px;height:20px;stroke:var(--ink);stroke-width:2;fill:none}
.cnav.prev{left:16px}.cnav.next{right:16px}
.cdots{display:flex;gap:.55rem;justify-content:center;margin-top:1.4rem}
.cdots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--line);cursor:pointer;transition:.25s;padding:0}
.cdots button.on{background:var(--bronze);width:26px;border-radius:50px}
@media(max-width:560px){.cnav{width:38px;height:38px}.cslide .cph{padding:1.1rem 1.1rem}}

/* ===== BLUEPRINT BAND ===== */
.bp-band{background:var(--espresso);color:#fff;position:relative;overflow:hidden}
.bp-band::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:44px 44px}
.bp-inner{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;position:relative;z-index:2}
.bp-band .eyebrow{color:var(--bronze-soft)}
.bp-band h2{color:#fff;font-size:clamp(1.9rem,3.6vw,2.8rem);margin:.8rem 0 1.1rem}
.bp-band p{color:rgba(255,255,255,.78);font-size:1.05rem;max-width:46ch}
.bp-stage{aspect-ratio:5/4;border-radius:18px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.02);display:flex;align-items:center;justify-content:center;position:relative}
.bp-stage svg{width:84%;height:84%}
.bp-stage .bpline{stroke:var(--bronze-soft);stroke-width:1.6;fill:none;stroke-dasharray:1;stroke-dashoffset:1;pathLength:1}
.bp-stage .bpfill{fill:var(--bronze);opacity:0;transition:opacity 1s 1.8s ease}
.bp-stage.draw .bpline{animation:draw 2s ease forwards}
.bp-stage.draw .bpfill{opacity:.14}
@media(max-width:820px){.bp-inner{grid-template-columns:1fr;gap:36px}}

/* ===== BEFORE/AFTER ===== */
.ba-section{background:var(--cream-2)}
.ba{max-width:920px;margin:50px auto 0;position:relative;aspect-ratio:16/9;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);user-select:none;touch-action:pan-y}
.ba .pane{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk';font-size:1.2rem;color:#fff;letter-spacing:.1em}
.ba .after{background:linear-gradient(150deg,#5b6f5a,#41513f)}
.ba .before{background:linear-gradient(150deg,#6b6258,#4a433b);clip-path:inset(0 50% 0 0)}
.ba .tag{position:absolute;top:15px;padding:.3rem .85rem;border-radius:50px;font-family:'Space Grotesk';font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;background:rgba(0,0,0,.42);color:#fff}
.ba .tag.l{left:15px}.ba .tag.r{right:15px}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);cursor:ew-resize}
.ba .grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%;background:#fff;box-shadow:0 4px 14px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center}
.ba .grip svg{width:21px;height:21px;stroke:var(--bronze);stroke-width:2.2;fill:none}
.ba-hint{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1rem;font-style:italic}

/* ===== GALLERY (varied sizes) ===== */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:40px 0 30px}
.filter{font-family:'Space Grotesk';border:1px solid var(--line);background:var(--white);color:var(--body);padding:.52rem 1.25rem;border-radius:10px;font-size:.86rem;font-weight:500;cursor:pointer;transition:.2s}
.filter.active,.filter:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:15px}
.gtile{border-radius:15px;overflow:hidden;position:relative;cursor:pointer;background:linear-gradient(160deg,#ECE3D6,#DcCfBD);display:flex;align-items:center;justify-content:center;transition:.3s;border:1px solid var(--line-soft)}
.gtile.tall{grid-row:span 2}
.gtile.wide{grid-column:span 2}
.gtile.big{grid-column:span 2;grid-row:span 2}
.gtile:hover{transform:scale(.984)}
.gtile .gl{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--bronze);opacity:.72;text-align:center;padding:.6rem}
.gtile .gl svg{width:32px;height:32px;stroke:var(--bronze);stroke-width:1.3;fill:none}
.gtile .gl span{font-size:.64rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.gtile .cat{position:absolute;top:11px;left:11px;background:rgba(255,255,255,.85);backdrop-filter:blur(4px);padding:.24rem .65rem;border-radius:50px;font-family:'Space Grotesk';font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.gtile.hide{display:none}
@media(max-width:760px){.gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}.gtile.big{grid-column:span 2}.gtile.wide{grid-column:span 2}}

/* ===== PROCESS ===== */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:52px}
.step .n{font-family:'Space Grotesk';font-size:2rem;color:var(--bronze);font-weight:700;line-height:1;margin-bottom:.75rem;display:flex;align-items:center;gap:.7rem}
.step .n::after{content:"";flex:1;height:1px;background:var(--line)}
.step:last-child .n::after{display:none}
.step h3{font-size:1.14rem;margin-bottom:.35rem;font-weight:600}
.step p{font-size:.9rem;color:var(--body)}
@media(max-width:760px){.proc{grid-template-columns:1fr 1fr}}

/* ===== TEAM COLLAGE ===== */
.collage{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(150px,auto);gap:18px;margin-top:52px}
.mtile{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line-soft);background:linear-gradient(160deg,#ECE3D6,#DcCfBD);display:flex;flex-direction:column;justify-content:flex-end;padding:1.4rem;transition:.3s;min-height:150px}
.mtile:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.mtile .pbp{position:absolute;inset:0;opacity:.4}
.mtile .pbp svg{width:100%;height:100%}
.mtile .pbp .bl{fill:none;stroke:var(--bronze);stroke-width:1.1;opacity:.45}
.mtile .pic{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--bronze);opacity:.7}
.mtile .pic svg{width:46px;height:46px;stroke:var(--bronze);stroke-width:1.2;fill:none}
.mtile .pic span{font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.mtile .info{position:relative;z-index:2}
.mtile h3{font-size:1.16rem;margin-bottom:.15rem}
.mtile .role{font-family:'Space Grotesk';font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--bronze-deep)}
.mtile.lead{grid-column:span 2;grid-row:span 2;background:linear-gradient(160deg,var(--espresso),#3a2c1d);color:#fff;justify-content:space-between}
.mtile.lead .pic{position:relative;inset:auto;align-items:flex-start;color:var(--bronze-soft);opacity:.9;margin-bottom:auto}
.mtile.lead h3{color:#fff;font-size:1.7rem}
.mtile.lead .role{color:var(--bronze-soft)}
.mtile.lead p{position:relative;z-index:2;color:rgba(255,255,255,.8);font-size:.92rem;max-width:32ch;margin-top:.6rem}
.mtile.lead .pbp{opacity:.18}
.mtile.lead .pbp .bl{stroke:#fff;opacity:.5}
.mtile.tall{grid-row:span 2}
.mtile.open{background:repeating-linear-gradient(45deg,var(--cream-2),var(--cream-2) 12px,var(--cream) 12px,var(--cream) 24px);align-items:center;justify-content:center;text-align:center;border:1.5px dashed var(--line)}
.mtile.open .info{text-align:center}
.mtile.open .role{color:var(--muted)}
@media(max-width:900px){.collage{grid-template-columns:repeat(2,1fr)}.mtile.lead{grid-column:span 2}}
@media(max-width:560px){.collage{grid-template-columns:1fr}.mtile.lead{grid-column:span 1}}

/* ===== TESTIMONIALS ===== */
.tst-section{background:var(--cream-2)}
.tst{max-width:760px;margin:42px auto 0;position:relative;min-height:210px}
.quote{position:absolute;inset:0;opacity:0;transition:.6s ease;transform:translateY(14px);pointer-events:none;text-align:center}
.quote.on{opacity:1;transform:none;pointer-events:auto;position:relative}
.quote p{font-family:'Space Grotesk';font-size:clamp(1.25rem,2.5vw,1.7rem);font-weight:500;color:var(--ink);line-height:1.4;margin-bottom:1.5rem;letter-spacing:-.01em}
.quote .who{font-family:'Space Grotesk';font-weight:600;color:var(--ink)}
.quote .loc{color:var(--muted);font-size:.86rem}
.quote .stars{font-size:1.05rem;margin-bottom:1.3rem;display:block}
.dots{display:flex;gap:.55rem;justify-content:center;margin-top:1.8rem}
.dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--line);cursor:pointer;transition:.25s;padding:0}
.dots button.on{background:var(--bronze);width:26px;border-radius:50px}
.tst-note{text-align:center;color:var(--muted);font-size:.76rem;margin-top:1.5rem;font-style:italic}

/* ===== CTA band ===== */
.cta-band{background:var(--bronze);color:#fff;border-radius:22px;padding:3rem 2.8rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:32px 32px}
.cta-band>*{position:relative;z-index:2}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3vw,2.3rem)}
.cta-band p{color:rgba(255,255,255,.88);margin-top:.35rem}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px;align-items:start;margin-top:48px}
.ci{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.4rem}
.ci .cico{width:44px;height:44px;border-radius:11px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci .cico svg{width:20px;height:20px;stroke:var(--bronze);stroke-width:1.8;fill:none}
.ci small{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.12rem}
.ci b{font-family:'Space Grotesk';font-size:1.08rem;color:var(--ink);font-weight:600}
form{background:var(--white);border:1px solid var(--line-soft);border-radius:18px;padding:2.3rem;box-shadow:var(--shadow-sm)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem}
.field label{display:block;font-family:'Space Grotesk';font-size:.78rem;font-weight:600;color:var(--ink);margin-bottom:.38rem}
.field input,.field select,.field textarea{width:100%;padding:.78rem .9rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--cream);transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--bronze);background:var(--white);box-shadow:0 0 0 4px rgba(154,122,79,.1)}
.field textarea{resize:vertical;min-height:94px}
form .btn{width:100%;justify-content:center;margin-top:.3rem}
.fineprint{font-size:.75rem;color:var(--muted);text-align:center;margin-top:.85rem}
.formnote{font-size:.74rem;color:var(--muted);text-align:center;margin-top:.6rem;font-style:italic}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:34px}.frow{grid-template-columns:1fr}}

/* ===== FAQ ===== */
.faq{max-width:780px;margin:42px auto 0}
.qa{border-bottom:1px solid var(--line);padding:1.35rem 0}
.qa summary{font-family:'Space Grotesk';font-size:1.1rem;color:var(--ink);font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";font-family:'Space Grotesk';font-size:1.4rem;color:var(--bronze);transition:.25s;font-weight:500}
.qa[open] summary::after{transform:rotate(45deg)}
.qa p{margin-top:.8rem;color:var(--body);font-size:.95rem}

/* ===== FOOTER ===== */
footer{background:var(--espresso);color:rgba(255,255,255,.62);padding:66px 0 28px;font-size:.92rem;position:relative;overflow:hidden}
footer::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:42px 42px}
footer .wrap{position:relative;z-index:2}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2.4rem;border-bottom:1px solid rgba(255,255,255,.1)}
footer .flogo{height:38px;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.92}
.fbrand{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.fbrand .mono{width:38px;height:38px;display:block}
.fbrand .mono svg{width:100%;height:100%}
.fbrand .wm{display:flex;flex-direction:column;line-height:1}
.fbrand .wm b{font-family:'Space Grotesk';font-weight:700;font-size:1.02rem;color:#fff;letter-spacing:.02em}
.fbrand .wm span{font-family:'Space Grotesk';font-weight:500;font-size:.6rem;letter-spacing:.34em;color:var(--bronze-soft);text-transform:uppercase;margin-top:3px}
footer h4{font-family:'Space Grotesk';font-weight:600;color:#fff;font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}
footer a:hover{color:var(--bronze-soft)}
.flist{display:flex;flex-direction:column;gap:.55rem}
.foot-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-top:1.6rem;font-size:.8rem;color:rgba(255,255,255,.45)}
@media(max-width:760px){.foot-top{grid-template-columns:1fr 1fr;gap:2rem}}

/* ===== MOBILE CTA ===== */
.mobile-cta{position:fixed;bottom:0;left:0;right:0;z-index:55;display:none;gap:.7rem;padding:.7rem;background:var(--bar-bg);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.mobile-cta .btn{flex:1;justify-content:center;padding:.78rem}
@media(max-width:900px){.mobile-cta{display:flex}body{padding-bottom:70px}}

/* lightbox */
.lb{position:fixed;inset:0;background:rgba(20,15,10,.86);backdrop-filter:blur(6px);z-index:100;display:none;align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex}
.lb-inner{max-width:760px;width:100%;aspect-ratio:4/3;border-radius:16px;background:linear-gradient(160deg,#ECE3D6,#DcCfBD);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--bronze);gap:.8rem}
.lb-inner svg{width:52px;height:52px;stroke:var(--bronze);stroke-width:1.2;fill:none}
.lb-close{position:absolute;top:24px;right:30px;color:#fff;font-size:2rem;cursor:pointer;background:none;border:none}

/* scroll progress */
#prog{position:fixed;top:0;left:0;right:0;height:3px;z-index:65;pointer-events:none;background:transparent}
#progFill{height:100%;width:0;background:var(--bronze);transition:width .12s linear}

/* custom cursor */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:999;pointer-events:none;transform:translate(-50%,-50%);will-change:transform}
.cursor-dot{width:6px;height:6px;border-radius:50%;background:var(--bronze)}
.cursor-ring{width:30px;height:30px;border:1.5px solid var(--bronze);border-radius:8px;opacity:.55;transition:width .2s,height .2s,opacity .2s,border-radius .2s,background .2s}
.cursor-ring.hot{width:46px;height:46px;opacity:1;border-radius:13px;background:rgba(154,122,79,.08)}
body.cursor-on{cursor:none}
@media(pointer:coarse){.cursor-dot,.cursor-ring{display:none!important}}

/* blueprint toggle button */
.bp-toggle{display:inline-flex;align-items:center;gap:.5rem;font-family:'Space Grotesk';font-weight:600;font-size:.8rem;color:var(--ink);background:transparent;border:1px solid var(--line);border-radius:50px;padding:.45rem .9rem;cursor:pointer;transition:.2s}
.bp-toggle:hover{border-color:var(--bronze)}
.bp-toggle svg{width:15px;height:15px;stroke:var(--bronze);fill:none;stroke-width:1.8}

/* ============================================================
   BLUEPRINT MODE  (dark) — full coverage, no white leaks
   ============================================================ */
body.blueprint{
  --cream:#0c1a28;--cream-2:#0f2233;--white:#13293c;--ink:#e2f4ff;--body:#a6c9dd;--muted:#6f93ab;
  --bronze:#3cc3e9;--bronze-deep:#1f9fc4;--bronze-soft:#8ce2ff;--espresso:#081320;
  --line:rgba(120,200,240,.22);--line-soft:rgba(120,200,240,.12);
  --bar-bg:rgba(8,19,32,.85);
  --shadow:0 18px 50px -18px rgba(0,0,0,.6);--shadow-sm:0 8px 24px -12px rgba(0,0,0,.5);
}
/* faint global grid layer */
body.blueprint::after{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;background-image:linear-gradient(rgba(120,200,240,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(120,200,240,.04) 1px,transparent 1px);background-size:32px 32px}
/* Jackson-inspired plan layer */
#bpBg{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:0;transition:opacity .6s ease}
body.blueprint #bpBg{opacity:1}
#bpBg svg{width:100%;height:100%;display:block}
#bpBg .bl{fill:none;stroke:#8ce2ff;stroke-width:.9;opacity:.10}
#bpBg .bl.dash{stroke-dasharray:6 5;opacity:.075}
#bpBg .bl.thin{stroke-width:.6;opacity:.07}
#bpBg .bt{fill:#8ce2ff;opacity:.10;font-family:'Space Grotesk',sans-serif;font-size:12px;letter-spacing:.12em}
/* placeholder surfaces -> dark */
body.blueprint .hero-photo,body.blueprint .gtile,body.blueprint .lb-inner,
body.blueprint .xcard,body.blueprint .mtile,body.blueprint .carousel-frame,body.blueprint .cslide{background:linear-gradient(160deg,#11283b,#0a1726)!important}
body.blueprint .mtile.open{background:repeating-linear-gradient(45deg,#0f2233,#0f2233 12px,#0c1a28 12px,#0c1a28 24px)!important;border-color:var(--line)}
body.blueprint .mtile.lead,body.blueprint .cell.feature{background:linear-gradient(160deg,#0f2233,#16344e)!important}
body.blueprint .ba .after{background:linear-gradient(150deg,#16344a,#0f2536)}
body.blueprint .ba .before{background:linear-gradient(150deg,#1c3b52,#13293c)}
body.blueprint .strip,body.blueprint .bp-band,body.blueprint footer{background:#081320}
body.blueprint .cta-band{background:linear-gradient(120deg,#1f9fc4,#3cc3e9)}
body.blueprint .float-card{background:var(--white)}
body.blueprint .cnav{background:rgba(8,19,32,.9)}
body.blueprint .cnav svg{stroke:var(--ink)}
body.blueprint .cnav:hover{background:var(--bronze)}
body.blueprint .cnav:hover svg{stroke:#081320}
body.blueprint .btn-ghost:hover{background:rgba(120,200,240,.06)}

/* konami confetti + toast */
.confetti{position:fixed;top:0;z-index:998;pointer-events:none;width:13px;height:13px}

.egg-toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--cream);font-family:'Space Grotesk';font-weight:600;font-size:.9rem;padding:.8rem 1.4rem;border-radius:50px;z-index:999;opacity:0;transition:.3s;box-shadow:var(--shadow)}
.egg-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
  .reveal{opacity:1;transform:none}
  .cslide{transition:opacity .2s ease}
}

/* monoline M&C monogram theming */
.brand .mono{color:var(--bronze);display:inline-block}
.brand .mono svg{width:100%;height:100%;display:block}
.fbrand .mono{color:var(--bronze-soft);display:inline-block}
.fbrand .mono svg{width:100%;height:100%;display:block}
