/* ============================================================
   BREANN RENAE, WEBSITE DESIGN
   Bold editorial studio system: thick outlines, hard shadows,
   moody warm base, electric eclectic pops.
   Shared across index / project / contact.
   ============================================================ */

:root{
  /* moody warm base */
  --ink:#16110E;
  --ink-2:#241811;
  --espresso:#2E1D12;
  --oxblood:#6E1622;
  --paper:#F3E9D8;
  --paper-2:#EADCC4;
  --paper-3:#E1CFB2;

  /* eclectic pops */
  --gold:#E7A522;
  --clay:#CD5A31;
  --cobalt:#2E3BE0;
  --lime:#C8E24A;
  --pink:#EE6A9B;
  --mauve:#B27C8D;
  --teal:#10897B;

  --line:2.5px;
  --line-c:var(--ink);
  --shadow:7px 7px 0 var(--ink);
  --shadow-sm:4px 4px 0 var(--ink);
  --shadow-lg:12px 12px 0 var(--ink);

  --sans:'Space Grotesk',system-ui,sans-serif;
  --serif:'Fraunces',Georgia,serif;
  --hand:'Caveat',cursive;

  --wrap:1240px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--lime);color:var(--ink);}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 26px;}
.section{padding:78px 0;position:relative;}
.section--tint{background:var(--paper-2);border-top:var(--line) solid var(--ink);border-bottom:var(--line) solid var(--ink);}
.section--ink{background:var(--ink);color:var(--paper);border-top:var(--line) solid var(--ink);border-bottom:var(--line) solid var(--ink);}

/* ---- reusable type ---- */
.eyebrow{
  font-family:var(--sans);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--clay);display:inline-block;}
.eyebrow--on-ink::before{background:var(--gold);}
.serif{font-family:var(--serif);}
.hand{font-family:var(--hand);}

h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.02;letter-spacing:-.01em;}
.display{font-weight:600;font-size:clamp(2.6rem,7vw,6.4rem);line-height:.98;}
.section-head{max-width:760px;margin-bottom:44px;}
.section-head h2{font-size:clamp(2rem,4.4vw,3.5rem);margin:18px 0 16px;}
.section-head p{font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--ink-2);max-width:620px;}
.section--ink .section-head p{color:var(--paper-2);}
.center{text-align:center;margin-left:auto;margin-right:auto;}
.center .eyebrow{justify-content:center;}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:700;font-size:.94rem;
  padding:15px 26px;
  border:var(--line) solid var(--line-c);
  background:var(--gold);color:var(--ink);
  box-shadow:var(--shadow-sm);
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, background .2s ease;
  letter-spacing:.01em;
}
.btn:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink);}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}
.btn--ink{background:var(--ink);color:var(--paper);}
.btn--cobalt{background:var(--cobalt);color:#fff;}
.btn--outline{background:transparent;}
.btn--lime{background:var(--lime);}
.btn--pink{background:var(--pink);color:var(--ink);}
.btn--lg{padding:18px 34px;font-size:1.02rem;}
.btn--block{width:100%;justify-content:center;}
.btn .arw{transition:transform .15s ease;}
.btn:hover .arw{transform:translateX(4px);}

/* =============== NAV =============== */
.nav{position:sticky;top:0;z-index:100;background:var(--paper);border-bottom:var(--line) solid var(--ink);}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:15px 26px;max-width:var(--wrap);margin:0 auto;}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.02em;}
.brand .mark{
  width:42px;height:42px;border:var(--line) solid var(--ink);
  background:var(--oxblood);color:var(--paper);
  display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1rem;letter-spacing:.01em;
  box-shadow:var(--shadow-sm);transform:rotate(-4deg);
}
.brand .bt{font-size:.82rem;line-height:1.05;text-transform:uppercase;letter-spacing:.12em;}
.brand .bt b{display:block;font-size:.95rem;letter-spacing:.04em;}
.brand .bt span{font-size:.64rem;letter-spacing:.18em;color:var(--clay);}
.brand-logo{height:52px;width:auto;display:block;}
.brand-tag{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:700;line-height:1.1;border-left:2.5px solid var(--ink);padding-left:12px;}
.nav-links{display:flex;align-items:center;gap:18px;}
.nav-links a{font-size:.88rem;font-weight:500;position:relative;}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;height:2.5px;width:0;background:var(--clay);transition:width .2s ease;}
.nav-links a:not(.btn):hover::after{width:100%;}
.nav-links a.is-current::after{width:100%;}
.nav-cta{padding:10px 18px;font-size:.85rem;}

/* ---- dropdown menus ---- */
.nav-item{position:relative;display:flex;align-items:center;}
.nav-top{display:inline-flex;align-items:center;gap:5px;cursor:pointer;}
.caret{font-size:.6rem;position:relative;top:1px;transition:transform .15s ease;}
.has-drop:hover .caret,.has-drop:focus-within .caret{transform:rotate(180deg);}
.dropdown{position:absolute;top:100%;left:-10px;min-width:250px;background:var(--paper);border:var(--line) solid var(--ink);box-shadow:var(--shadow);padding:8px;display:flex;flex-direction:column;gap:1px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .15s ease,transform .15s ease;z-index:130;}
.has-drop:hover .dropdown,.has-drop:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.has-drop::after{content:"";position:absolute;top:100%;left:0;right:0;height:16px;}
.dropdown a{font-size:.86rem;font-weight:500;padding:9px 12px;white-space:nowrap;}
.dropdown a:hover{background:var(--paper-2);}
.dropdown a::after{content:none!important;}
.dropdown a.drop-flag{margin-top:6px;border:2.5px solid var(--cobalt);color:var(--cobalt);font-weight:700;border-radius:2px;text-align:center;letter-spacing:.02em;}
.dropdown a.drop-flag:hover{background:var(--cobalt);color:#fff;}

.menu-btn{display:none;border:var(--line) solid var(--ink);background:var(--lime);padding:9px 12px;box-shadow:var(--shadow-sm);cursor:pointer;font-weight:700;font-family:var(--sans);}

/* =============== marquee ticker =============== */
.ticker{background:var(--ink);color:var(--paper);border-bottom:var(--line) solid var(--ink);overflow:hidden;}
.ticker-track{display:flex;gap:0;white-space:nowrap;animation:scroll 34s linear infinite;}
.ticker-track span{padding:11px 0;font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;display:inline-flex;align-items:center;}
.ticker-track span::after{content:"✦";color:var(--gold);margin:0 26px;}
@keyframes scroll{to{transform:translateX(-50%);}}

/* =============== HERO =============== */
.hero{position:relative;padding:60px 0 20px;overflow:hidden;
  background-image:
    linear-gradient(rgba(22,17,14,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(22,17,14,.05) 1px,transparent 1px);
  background-size:34px 34px;
}
.hero-grid{display:grid;grid-template-columns:1fr 1.06fr;gap:46px;align-items:center;position:relative;z-index:2;}
.hero-copy .eyebrow{margin-bottom:22px;}
.hero h1{font-size:clamp(2.6rem,5.6vw,5.1rem);margin-bottom:24px;}
.hero h1 .u{background:linear-gradient(transparent 60%,var(--lime) 60%);padding:0 .04em;}
.hero h1 .ital{font-style:italic;color:var(--oxblood);}
.hero-lede{font-size:clamp(1.05rem,1.5vw,1.22rem);max-width:530px;color:var(--ink-2);margin-bottom:14px;font-weight:400;}
.hero-lede b{font-weight:700;background:var(--paper-3);padding:1px 5px;border:2px solid var(--ink);box-decoration-break:clone;-webkit-box-decoration-break:clone;}
.hero-note{font-family:var(--hand);font-size:1.5rem;color:var(--clay);transform:rotate(-3deg);display:inline-block;margin:6px 0 28px;}
.hero-note::before{content:"↳";font-family:var(--sans);margin-right:6px;color:var(--ink);}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px;align-items:center;}
.chip{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border:2px solid var(--ink);background:var(--paper);}
.hero-trust .chip{font-weight:700;font-size:.74rem;padding:8px 14px;border-width:2.5px;}
.chip--pink{background:var(--pink);color:var(--ink);}
.chip--cobalt{background:var(--cobalt);color:#fff;}
.chip--gold{background:var(--gold);color:var(--ink);}
.chip--lime{background:var(--lime);color:var(--ink);}

/* hero portrait */
.hero-figure{position:relative;justify-self:end;align-self:start;margin-top:18px;width:100%;max-width:560px;}
.hero-collage{width:100%;height:auto;display:block;overflow:visible;}
.hero-collage .float{animation:heroBob 4.6s ease-in-out infinite;will-change:transform;}
.hero-collage .f-b{animation-duration:5.3s;animation-delay:-1.3s;}
.hero-collage .f-c{animation-duration:4.2s;animation-delay:-2.1s;}
.hero-collage .f-d{animation-duration:5s;animation-delay:-.7s;}
.hero-collage .f-e{animation-duration:4.8s;animation-delay:-1.7s;}
@keyframes heroBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.hero-photo{
  border:var(--line) solid var(--ink);
  box-shadow:var(--shadow-lg);
  background:var(--paper-3);
  position:relative;z-index:2;
}
.hero-photo img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center top;}
.hero-figure .blob{position:absolute;inset:0;background:var(--gold);border:var(--line) solid var(--ink);transform:rotate(-4deg);z-index:1;top:18px;left:-18px;}
.hero-badge{
  position:absolute;z-index:3;bottom:-22px;right:-16px;
  background:var(--cobalt);color:#fff;border:var(--line) solid var(--ink);
  box-shadow:var(--shadow-sm);padding:12px 16px;transform:rotate(4deg);
  font-family:var(--sans);font-weight:700;font-size:.82rem;text-align:center;line-height:1.15;
}
.hero-badge b{font-family:var(--serif);font-size:1.5rem;display:block;}
.hero-tag{
  position:absolute;z-index:3;top:-18px;left:-14px;
  background:var(--lime);border:var(--line) solid var(--ink);box-shadow:var(--shadow-sm);
  padding:7px 13px;font-weight:700;font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;transform:rotate(-5deg);
}

/* =============== WHO THIS IS FOR =============== */
.audience-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:var(--line) solid var(--ink);box-shadow:var(--shadow);background:var(--paper);}
.aud{padding:24px 22px;border-right:var(--line) solid var(--ink);border-bottom:var(--line) solid var(--ink);display:flex;align-items:flex-start;gap:12px;font-weight:600;font-size:.98rem;}
.aud .dot{flex:0 0 auto;width:14px;height:14px;border:2px solid var(--ink);margin-top:4px;}
.aud:nth-child(4n){border-right:none;}
.aud:nth-child(1) .dot{background:var(--clay);}
.aud:nth-child(2) .dot{background:var(--cobalt);}
.aud:nth-child(3) .dot{background:var(--gold);}
.aud:nth-child(4) .dot{background:var(--teal);}
.aud:nth-child(5) .dot{background:var(--pink);}
.aud:nth-child(6) .dot{background:var(--lime);}
.aud:nth-child(7) .dot{background:var(--oxblood);}
.aud:nth-child(8) .dot{background:var(--mauve);}

/* =============== WHAT I BUILD =============== */
.build-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.build-card{border:var(--line) solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);padding:20px;transition:transform .12s ease,box-shadow .12s ease;}
.build-card:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow);}
.build-card .n{font-family:var(--serif);font-weight:700;font-size:1.1rem;color:var(--clay);}
.build-card h3{font-size:1.12rem;margin:8px 0 0;}

/* =============== PRICING =============== */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.tier{
  border:var(--line) solid var(--ink);background:var(--paper);
  box-shadow:var(--shadow-sm);padding:26px 24px;display:flex;flex-direction:column;
  position:relative;transition:transform .12s ease,box-shadow .12s ease;
}
.tier:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow);}
.tier--feature{background:var(--ink);color:var(--paper);box-shadow:var(--shadow);}
.tier--feature .tier-price{color:var(--gold);}
.tier--feature .tier-list li::before{color:var(--gold);}
.tier--feature .tier-best{color:var(--paper-2);border-color:var(--paper-2);}
.tier-flag{
  position:absolute;top:-16px;right:18px;background:var(--pink);color:var(--ink);
  border:var(--line) solid var(--ink);box-shadow:var(--shadow-sm);
  padding:5px 12px;font-weight:700;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;transform:rotate(3deg);
}
.tier-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);}
.tier--feature .tier-eyebrow{color:var(--gold);}
.tier h3{font-size:1.5rem;margin:8px 0 4px;}
.tier-price{font-family:var(--serif);font-weight:700;font-size:2.3rem;line-height:1;margin:8px 0 2px;}
.tier-price small{font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--ink-2);display:block;margin-top:6px;letter-spacing:.02em;}
.tier--feature .tier-price small{color:var(--paper-2);}
.tier-eta{font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--ink-2);margin:2px 0 0;display:inline-flex;align-items:center;gap:7px;}
.tier-eta::before{content:"";width:9px;height:9px;background:var(--clay);border:1.5px solid var(--ink);flex:0 0 auto;}
.tier-eta b{color:var(--clay);font-weight:700;}
.tier--feature .tier-eta{color:var(--paper-2);}
.tier--feature .tier-eta::before{background:var(--gold);}
.tier--feature .tier-eta b{color:var(--gold);}
.tier-list{list-style:none;margin:16px 0 22px;display:flex;flex-direction:column;gap:9px;}
.tier-list li{padding-left:26px;position:relative;font-size:.95rem;}
.tier-list li::before{content:"✦";position:absolute;left:0;color:var(--clay);font-size:.9rem;}
.tier-best{margin-top:auto;font-size:.85rem;border-top:2px solid var(--ink);padding-top:14px;color:var(--ink-2);}
.tier-best b{display:block;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;margin-bottom:4px;}
.tier .btn{margin-top:18px;}
.pricing-note{margin-top:26px;font-size:.95rem;text-align:center;color:var(--ink-2);}
.pricing-note b{background:var(--lime);padding:2px 6px;border:2px solid var(--ink);}
.pn-btn{display:inline-block;background:var(--lime);color:var(--ink);font-weight:700;padding:4px 12px;border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink);transition:transform .1s ease,box-shadow .1s ease;}
.pn-btn:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink);}
.pn-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink);}

/* =============== ADD-ONS =============== */
.addon-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.addon-block{border:var(--line) solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);padding:24px;}
.section--ink .addon-block{background:var(--ink-2);color:var(--paper);}
.addon-block h3{font-size:1.25rem;margin-bottom:14px;}
.addon-list{list-style:none;display:flex;flex-direction:column;}
.addon-list li{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1.5px dashed rgba(243,233,216,.25);font-size:.94rem;}
.section:not(.section--ink) .addon-list li{border-bottom-color:rgba(22,17,14,.2);}
.addon-list li:last-child{border-bottom:none;}
.addon-list .price{font-weight:700;white-space:nowrap;color:var(--gold);}
.section:not(.section--ink) .addon-list .price{color:var(--clay);}

/* =============== HOSTING / CARE =============== */
.care-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px;}
.care{border:var(--line) solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);padding:24px;display:flex;flex-direction:column;}
.care--mid{background:var(--gold);}
.care h3{font-size:1.35rem;}
.care .care-price{font-family:var(--serif);font-weight:700;font-size:1.9rem;margin:6px 0 14px;}
.care ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:.93rem;}
.care li{padding-left:22px;position:relative;}
.care li::before{content:"→";position:absolute;left:0;font-weight:700;}
.care-fine{border:var(--line) solid var(--ink);background:var(--paper-2);padding:18px 22px;font-size:.9rem;}
.care-fine b{background:var(--pink);padding:1px 6px;border:2px solid var(--ink);}

/* ---- manage-it-yourself panel ---- */
.selfmanage{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;margin-top:24px;
  border:var(--line) solid var(--ink);box-shadow:var(--shadow);background:var(--paper);padding:30px;}
.sm-copy h3{font-size:clamp(1.35rem,2.2vw,1.7rem);margin:8px 0 12px;}
.sm-copy p{font-size:.98rem;color:var(--ink-2);margin-bottom:10px;}
.sm-copy p b{color:var(--ink);}
.sm-copy .hl{background:var(--lime);padding:1px 6px;border:2px solid var(--ink);color:var(--ink);}
.sm-note{font-family:var(--hand);font-size:1.35rem;color:var(--clay);transform:rotate(-1deg);margin-top:6px;}
.sm-pick{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--gold);border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink);padding:2px 8px;margin-right:6px;transform:rotate(-1deg);}
/* dashboard mock */
.dash-mock{border:var(--line) solid var(--ink);box-shadow:var(--shadow-sm);background:#fff;overflow:hidden;transform:rotate(1deg);}
.dash-bar{display:flex;align-items:center;gap:10px;background:var(--ink);color:var(--paper);padding:10px 13px;}
.dash-dots{display:flex;gap:5px;}
.dash-dots i{width:9px;height:9px;border-radius:50%;background:var(--paper-3);display:block;}
.dash-title{font-size:.8rem;font-weight:600;letter-spacing:.02em;}
.dash-saved{margin-left:auto;font-size:.72rem;font-weight:700;color:var(--lime);}
.dash-body{padding:16px 16px 18px;background:#F4F5F7;}
.dash-label{display:block;font-size:.64rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#6b7280;margin:12px 0 5px;}
.dash-label:first-child{margin-top:0;}
.dash-field{background:#fff;border:1.5px solid #d7dbe0;border-radius:5px;padding:10px 12px;font-size:.9rem;color:var(--ink);}
.dash-area{min-height:46px;}
.dash-actions{display:flex;align-items:center;gap:10px;margin-top:16px;}
.dash-upload{font-size:.76rem;color:#6b7280;border:1.5px dashed #b6bcc4;border-radius:5px;padding:8px 11px;}
.dash-publish{margin-left:auto;background:var(--ink);color:var(--paper);font-weight:700;font-size:.82rem;padding:9px 18px;border-radius:5px;}

/* =============== PROCESS =============== */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:var(--line) solid var(--ink);box-shadow:var(--shadow);}
.step{padding:26px 22px;border-right:var(--line) solid var(--ink);border-bottom:var(--line) solid var(--ink);background:var(--paper);}
.step:nth-child(3n){border-right:none;}
.step:nth-child(n+4){border-bottom:none;}
.step .num{width:44px;height:44px;border:var(--line) solid var(--ink);display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:1.3rem;box-shadow:var(--shadow-sm);margin-bottom:14px;}
.step:nth-child(1) .num{background:var(--clay);color:#fff;}
.step:nth-child(2) .num{background:var(--cobalt);color:#fff;}
.step:nth-child(3) .num{background:var(--gold);}
.step:nth-child(4) .num{background:var(--lime);}
.step:nth-child(5) .num{background:var(--pink);}
.step:nth-child(6) .num{background:var(--teal);color:#fff;}
.step h3{font-size:1.15rem;margin-bottom:8px;}
.step p{font-size:.92rem;color:var(--ink-2);}

/* =============== FAQ =============== */
.faq{max-width:820px;margin:0 auto;border:var(--line) solid var(--ink);box-shadow:var(--shadow);background:var(--paper);}
.faq-item{border-bottom:var(--line) solid var(--ink);}
.faq-item:last-child{border-bottom:none;}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--serif);font-weight:600;font-size:1.15rem;color:var(--ink);
  padding:20px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq-q .ic{flex:0 0 auto;width:30px;height:30px;border:2.5px solid var(--ink);display:grid;place-items:center;font-family:var(--sans);font-weight:700;font-size:1.2rem;background:var(--gold);transition:transform .2s ease,background .2s ease;}
.faq-item.is-open .faq-q .ic{transform:rotate(45deg);background:var(--clay);color:#fff;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s ease;}
.faq-a-in{padding:0 22px 20px;font-size:.98rem;color:var(--ink-2);}

/* =============== CTA BANNER =============== */
.cta-band{border:var(--line) solid var(--ink);box-shadow:var(--shadow-lg);background:var(--oxblood);color:var(--paper);
  padding:54px 44px;text-align:center;position:relative;overflow:hidden;}
.cta-band h2{font-size:clamp(2rem,4.4vw,3.6rem);margin-bottom:16px;color:var(--paper);}
.cta-band p{font-size:1.1rem;max-width:560px;margin:0 auto 26px;color:var(--paper-2);}
.cta-band .hero-cta{justify-content:center;}
.cta-band .btn--outline{color:var(--paper);border-color:var(--paper);}

/* =============== FORMS =============== */
.form-shell{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border:var(--line) solid var(--ink);box-shadow:var(--shadow-lg);background:var(--paper);}
.form-aside{background:var(--ink);color:var(--paper);padding:38px 32px;}
.form-aside .eyebrow{margin-bottom:18px;}
.form-aside h1{font-size:clamp(1.9rem,3.4vw,2.8rem);color:var(--paper);margin-bottom:16px;}
.form-aside p{color:var(--paper-2);margin-bottom:22px;font-size:1.02rem;}
.form-aside ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.form-aside li{padding-left:26px;position:relative;font-size:.96rem;}
.form-aside li::before{content:"✦";position:absolute;left:0;color:var(--gold);}
.form-aside .aside-note{margin-top:26px;font-family:var(--hand);font-size:1.4rem;color:var(--lime);transform:rotate(-2deg);}
.form-body{padding:38px 34px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:20px;}
.field label{display:block;font-weight:700;font-size:.86rem;letter-spacing:.04em;margin-bottom:8px;}
.field label .req{color:var(--clay);}
.field .hint{font-weight:400;color:var(--ink-2);font-size:.8rem;letter-spacing:0;}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--ink);
  padding:13px 15px;border:var(--line) solid var(--ink);background:var(--paper);
  box-shadow:var(--shadow-sm);transition:transform .1s ease,box-shadow .1s ease;
}
.field textarea{min-height:130px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--gold);
}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"],.field select[aria-invalid="true"]{box-shadow:4px 4px 0 var(--oxblood);}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.check{display:flex;align-items:center;gap:10px;border:2px solid var(--ink);padding:10px 12px;background:var(--paper);font-size:.9rem;cursor:pointer;}
.check input{width:auto;box-shadow:none;padding:0;transform:none;accent-color:var(--clay);}
.check:hover{background:var(--paper-2);}
.form-msg{margin-top:6px;font-weight:600;padding:12px 16px;border:var(--line) solid var(--ink);display:none;}
.form-msg.is-visible{display:block;}
.form-msg.is-success{background:var(--lime);}
.form-msg.is-error{background:var(--pink);}
.form-legend{font-size:.78rem;color:var(--ink-2);margin-bottom:20px;}

/* =============== CONTACT =============== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start;}
.contact-cards{display:flex;flex-direction:column;gap:18px;}
.contact-card{border:var(--line) solid var(--ink);box-shadow:var(--shadow-sm);background:var(--paper);padding:24px;}
.contact-card h3{font-size:1.25rem;margin-bottom:8px;}
.contact-card a{color:var(--clay);font-weight:700;border-bottom:2px solid var(--gold);}
.social-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px;}
.social-row a{border:2px solid var(--ink);padding:9px 16px;font-weight:700;font-size:.86rem;box-shadow:var(--shadow-sm);background:var(--paper);transition:transform .1s ease,box-shadow .1s ease;}
.social-row a:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink);background:var(--gold);}

/* =============== FOOTER =============== */
.footer{background:var(--ink);color:var(--paper);border-top:var(--line) solid var(--ink);padding:48px 0 34px;}
.footer-in{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;}
.footer h4{font-family:var(--sans);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.footer-brand .serif{font-size:1.7rem;color:var(--paper);}
.footer-logo{width:190px;max-width:70%;height:auto;display:block;margin-bottom:4px;}
.footer-brand p{color:var(--paper-2);margin-top:10px;max-width:320px;font-size:.95rem;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px;}
.footer-links a{color:var(--paper-2);font-size:.95rem;}
.footer-links a:hover{color:var(--gold);}
.footer-bottom{border-top:2px solid rgba(243,233,216,.2);margin-top:34px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:var(--paper-2);}
.footer-studio{margin-top:16px;text-align:center;}
.footer-studio p{font-size:.82rem;color:var(--paper-2);max-width:660px;margin:0 auto;line-height:1.5;}
.footer-studio b{color:var(--gold);font-weight:600;}
.foot-legal{color:var(--paper);border-bottom:1px solid rgba(243,233,216,.45);}
.foot-legal:hover{color:var(--gold);border-bottom-color:var(--gold);}

/* =============== legal / prose page =============== */
.legal{max-width:820px;margin:0 auto;}
.legal .updated{font-size:.85rem;color:var(--ink-2);margin-bottom:26px;}
.legal h2{font-size:clamp(1.5rem,2.6vw,2rem);margin:36px 0 14px;}
.legal h3{font-family:var(--sans);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin:24px 0 8px;color:var(--ink);}
.legal p{font-size:1rem;color:var(--ink-2);margin-bottom:12px;line-height:1.65;}
.legal ul{padding-left:22px;margin:0 0 12px;}
.legal li{font-size:1rem;color:var(--ink-2);margin-bottom:7px;line-height:1.6;}
.legal a{color:var(--clay);font-weight:600;border-bottom:2px solid var(--gold);}
.legal strong{color:var(--ink);}
.legal .divider{height:2.5px;background:var(--ink);margin:44px 0;box-shadow:var(--shadow-sm);}

/* =============== honeypot (anti-spam; hidden from humans) =============== */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;}

/* =============== form consent line =============== */
.form-consent{font-size:.8rem;color:var(--ink-2);margin-top:14px;line-height:1.5;}
.form-consent a{color:var(--clay);font-weight:600;border-bottom:2px solid var(--gold);}

/* =============== services / offers =============== */
.jump-nav{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;}
.jump-nav a.chip{cursor:pointer;transition:background .15s ease,transform .1s ease;}
.jump-nav a.chip:hover{background:var(--gold);transform:translateY(-2px);}
.offer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.offer{border:var(--line) solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);padding:22px 24px;display:flex;flex-direction:column;transition:transform .12s ease,box-shadow .12s ease;}
.offer:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow);}
.offer h3{font-size:1.2rem;margin-bottom:6px;}
.offer p{font-size:.92rem;color:var(--ink-2);margin-bottom:16px;flex:1;}
.offer-price{font-family:var(--serif);font-weight:700;font-size:1.15rem;color:var(--clay);border-top:2px solid var(--ink);padding-top:12px;}
.offer-price small{font-family:var(--sans);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);display:block;margin-bottom:3px;}
.svc-note{margin-top:18px;font-size:.9rem;color:var(--ink-2);}
.svc-note b{background:var(--lime);padding:1px 6px;border:2px solid var(--ink);color:var(--ink);}

/* =============== about page =============== */
.about-role{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);margin-bottom:12px;}
.about-lede{font-family:var(--serif);font-weight:600;font-size:clamp(1.2rem,2vw,1.55rem);line-height:1.25;margin:4px 0 16px;}
.about-lede .u{background:linear-gradient(transparent 60%,var(--lime) 60%);padding:0 .05em;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.svc-grid .build-card p{font-size:.9rem;color:var(--ink-2);margin-top:6px;}
.cred-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px;}
.cred{border:var(--line) solid var(--ink);background:var(--paper);box-shadow:var(--shadow-sm);padding:24px;}
.cred .deg{font-family:var(--serif);font-weight:700;font-size:1.5rem;line-height:1;}
.cred .sch{margin-top:8px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--clay);font-weight:700;}
.chip-cloud{display:flex;flex-wrap:wrap;gap:10px;}
.chip-cloud .chip{font-size:.84rem;padding:8px 14px;background:var(--paper);}
.edge{border:var(--line) solid var(--ink);box-shadow:var(--shadow);background:var(--paper);padding:28px 30px;display:flex;gap:20px;align-items:flex-start;}
.edge .qm{font-family:var(--hand);font-size:2.6rem;color:var(--clay);line-height:.8;flex:0 0 auto;}
.edge p{font-size:1.05rem;color:var(--ink-2);}
.edge p b{color:var(--ink);}
.edge .fine{display:block;margin-top:8px;font-size:.85rem;color:var(--ink-2);font-style:italic;}

/* =============== the digital machine (scroll story) =============== */
.machine{background:var(--ink);color:var(--paper);}
.machine-track{position:relative;height:150vh;}
.machine-sticky{position:sticky;top:0;height:100vh;overflow:hidden;background-color:var(--ink);
  background-image:linear-gradient(rgba(243,233,216,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(243,233,216,.06) 1px,transparent 1px);
  background-size:42px 42px;}
.machine-stage{position:relative;max-width:1180px;height:100%;margin:0 auto;padding:0 26px;}
/* left copy (resolves in) */
.machine-copy{position:absolute;left:26px;top:50%;transform:translateY(-50%);width:min(46%,520px);z-index:8;color:var(--paper);}
.machine-copy .eyebrow{margin-bottom:16px;}
.machine-copy h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.7rem,3.2vw,3rem);line-height:1.03;color:var(--paper);margin-bottom:20px;}
.machine-copy h2 em{font-style:italic;color:var(--gold);}
.mc-body{color:var(--paper-2);font-size:clamp(.95rem,1.1vw,1.05rem);line-height:1.55;margin-bottom:14px;}
.mc-body b{color:var(--paper);}
.mc-btn{display:inline-flex;align-items:center;gap:10px;margin-top:26px;background:var(--lime);color:var(--ink);font-family:var(--sans);font-weight:700;font-size:1rem;padding:14px 26px;border:2.5px solid var(--ink);box-shadow:6px 6px 0 var(--clay);transition:transform .16s ease,box-shadow .16s ease;}
.mc-btn:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--clay);}
.mc-btn .arw{transition:transform .16s ease;}
.mc-btn:hover .arw{transform:translateX(5px);}
/* scattered cards */
.mcard{position:absolute;z-index:4;will-change:transform,opacity;}
.mcard-inner{display:inline-flex;align-items:center;gap:11px;padding:14px 24px;border:3px solid #000;box-shadow:6px 6px 0 #000;font-family:var(--sans);font-weight:700;font-size:clamp(1rem,1.5vw,1.3rem);white-space:nowrap;animation:mbob 4s ease-in-out infinite;}
.mcard-inner .mc-ic{width:16px;height:16px;border:2.5px solid #000;flex:0 0 auto;}
.mc-lime{background:var(--lime);color:var(--ink);}
.mc-pink{background:var(--pink);color:var(--ink);}
.mc-gold{background:var(--gold);color:var(--ink);}
.mc-cream{background:var(--paper);color:var(--ink);}
.mc-cobalt{background:var(--cobalt);color:#fff;}
.mc-clay{background:var(--clay);color:#fff;}
@keyframes mbob{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
/* flying cards: fixed layer that carries the cards from the hero collage into the machine */
.mfly{position:fixed;inset:0;z-index:60;pointer-events:none;overflow:hidden;}
.mflycard{position:absolute;top:0;left:0;will-change:transform,opacity;}
/* the machine console */
.machine-box{position:absolute;left:70%;top:40%;transform:translate(-50%,-50%);z-index:3;width:min(380px,42%);}
.machine-slot{height:16px;width:64%;margin:0 auto;background:#000;border:3px solid #000;border-bottom:none;border-radius:7px 7px 0 0;}
.machine-body{border:var(--line) solid #000;background:var(--oxblood);box-shadow:9px 9px 0 #000;padding:24px 26px;text-align:center;}
.machine-label{font-family:var(--serif);color:var(--paper);font-size:1rem;line-height:1.05;letter-spacing:.02em;}
.machine-label b{font-size:1.7rem;display:block;font-weight:700;margin-top:3px;}
.machine-lights{display:flex;gap:9px;justify-content:center;margin-top:14px;}
.machine-lights i{width:13px;height:13px;border:2px solid #000;background:var(--gold);}
.machine-tray{height:12px;width:74%;margin:0 auto;background:#000;border:3px solid #000;border-top:none;border-radius:0 0 7px 7px;}
/* organized output grid */
.machine-grid{position:absolute;left:70%;top:73%;transform:translate(-50%,-50%);z-index:2;
  display:grid;grid-template-columns:repeat(3,1fr);width:min(370px,40%);border:var(--line) solid #000;box-shadow:9px 9px 0 #000;opacity:0;}
.mg{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px 8px;font-family:var(--sans);font-weight:700;font-size:1rem;border:2px solid #000;white-space:nowrap;}
.mg .mgi{width:13px;height:13px;border:2px solid #000;flex:0 0 auto;}
.m-hint{position:absolute;bottom:5%;left:0;right:0;text-align:center;font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);opacity:.75;z-index:7;}

/* =============== SERVICES / what the studio builds =============== */
.svc-head{display:grid;grid-template-columns:1.6fr 1fr;gap:44px;align-items:end;margin:18px 0 48px;}
.svc-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.02;}
.svc-head h2 em{font-style:italic;color:var(--clay);}
.svc-note{color:var(--ink-2);font-size:clamp(1rem,1.2vw,1.12rem);line-height:1.5;max-width:360px;}
.svc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:26px;}
.svc-card{grid-column:span 2;display:flex;flex-direction:column;background:var(--paper);border:var(--line) solid var(--ink);
  box-shadow:8px 8px 0 var(--ink);padding:26px 26px 24px;transition:transform .18s ease,box-shadow .18s ease,opacity .5s ease;}
.svc-card--wide{grid-column:span 3;}
.svc-card:hover{transform:translate(-6px,-6px);box-shadow:18px 18px 0 var(--ink);}
.svc-cardtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;}
.svc-num{font-family:var(--sans);font-weight:700;font-size:1.05rem;letter-spacing:.05em;}
.svc-tag{border:2.5px solid var(--ink);padding:5px 11px;font-family:var(--sans);font-weight:700;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;box-shadow:2px 2px 0 var(--ink);}
.svc-card h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.35rem,1.9vw,1.7rem);line-height:1.08;margin-bottom:14px;}
.svc-card p{color:var(--ink-2);font-size:1rem;line-height:1.5;margin-bottom:22px;}
/* mini graphics */
.viz{margin-top:auto;height:92px;border:2.5px solid var(--ink);display:flex;align-items:center;padding:12px 14px;gap:12px;overflow:hidden;}
.viz--site{background:#fff;justify-content:space-between;}
.vs-left{display:flex;flex-direction:column;gap:7px;flex:1;}
.vs-bar{height:10px;width:72%;background:var(--oxblood);}
.vs-ln{height:6px;width:92%;background:var(--paper-3);}
.vs-ln--sh{width:58%;}
.vs-blk{width:70px;align-self:stretch;background:var(--gold);border:2.5px solid var(--ink);}
.viz--flow{background:var(--ink);justify-content:center;gap:34px;}
.vf-arw{color:var(--lime);font-size:1.7rem;font-weight:700;line-height:1;}
.viz--swatch{padding:0;gap:0;}
.viz--swatch span{flex:1;align-self:stretch;border-right:2.5px solid var(--ink);}
.viz--swatch span:last-child{border-right:none;}
.viz--road{background:var(--paper-3);justify-content:center;}
.vr-line{position:relative;display:flex;align-items:center;justify-content:space-between;width:78%;}
.vr-line::before{content:"";position:absolute;left:8px;right:8px;top:50%;transform:translateY(-50%);height:2.5px;background:var(--ink);}
.vr-dot{width:17px;height:17px;border-radius:50%;border:2.5px solid var(--ink);position:relative;z-index:1;}
.viz--feed{background:#fff;gap:10px;}
.viz--feed span{flex:1;align-self:center;height:58%;border:2.5px solid var(--ink);}
@media (max-width:920px){
  .svc-head{grid-template-columns:1fr;gap:18px;align-items:start;margin-bottom:36px;}
  .svc-grid{grid-template-columns:1fr;gap:22px;}
  .svc-card,.svc-card--wide{grid-column:auto;}
}

/* =============== STUDIO CTA (above footer) =============== */
.studio-cta{background:var(--gold);color:var(--ink);text-align:center;padding:78px 0 84px;
  background-image:linear-gradient(rgba(22,17,14,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(22,17,14,.055) 1px,transparent 1px);
  background-size:42px 42px;}
.studio-cta .eyebrow{justify-content:center;color:var(--ink);margin-bottom:20px;}
.studio-cta .eyebrow::before{background:var(--oxblood);}
.sc-h{font-family:var(--serif);font-weight:600;font-size:clamp(2.3rem,5.6vw,4.3rem);line-height:1.02;color:var(--ink);max-width:16ch;margin:0 auto 22px;}
.sc-h em{font-style:italic;color:var(--oxblood);}
.sc-body{font-size:clamp(1rem,1.4vw,1.2rem);line-height:1.5;color:var(--ink);max-width:620px;margin:0 auto;}
.sc-actions{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin:34px 0 24px;}
.sc-btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-weight:700;font-size:1.02rem;padding:16px 30px;border:2.5px solid var(--ink);box-shadow:6px 6px 0 var(--ink);transition:transform .16s ease,box-shadow .16s ease;}
.sc-btn--ink{background:var(--ink);color:var(--paper);}
.sc-btn--out{background:transparent;color:var(--ink);}
.sc-btn:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ink);}
.sc-btn .arw{transition:transform .16s ease;}
.sc-btn:hover .arw{transform:translateX(5px);}
.sc-note{font-family:var(--hand);font-size:1.4rem;color:var(--oxblood);margin-top:4px;}
@media (max-width:600px){
  .studio-cta{padding:56px 0 60px;}
  .sc-actions{flex-direction:column;align-items:center;}
  .sc-btn{width:100%;max-width:340px;justify-content:center;}
}

/* =============== FLAGSHIP OFFER =============== */
.flagship{position:relative;overflow:hidden;background:var(--oxblood);color:var(--paper);padding:70px 0 76px;}
.flag-watermark{position:absolute;top:-.28em;right:2%;font-family:var(--serif);font-weight:600;font-size:min(20vw,15rem);line-height:1;color:#fff;opacity:.05;letter-spacing:.02em;pointer-events:none;user-select:none;}
.flag-in{position:relative;z-index:1;}
.flag-tags{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px;}
.flag-tag{font-family:var(--sans);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 14px;border:2.5px solid var(--gold);}
.flag-tag--gold{background:var(--gold);color:var(--ink);transform:rotate(-1.5deg);}
.flag-tag--out{color:var(--paper);border-color:var(--paper);}
.flag-h{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,5vw,3.8rem);line-height:1.02;color:var(--paper);margin-bottom:16px;}
.flag-sub{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2vw,1.6rem);line-height:1.28;color:var(--paper);max-width:760px;margin-bottom:34px;}
.flag-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:start;margin-bottom:34px;}
.flag-body{color:var(--paper-2);font-size:clamp(1rem,1.2vw,1.1rem);line-height:1.55;max-width:520px;}
.flag-body b{color:var(--paper);}
.flag-chips{display:flex;flex-wrap:wrap;gap:10px;align-content:flex-start;}
.flag-chips span{border:2px solid rgba(243,233,216,.5);color:var(--paper);font-family:var(--sans);font-weight:600;font-size:.82rem;padding:8px 13px;white-space:nowrap;}
.flag-actions{display:flex;align-items:center;gap:24px;flex-wrap:wrap;}
.flag-btn{display:inline-flex;align-items:center;gap:12px;background:var(--ink);color:var(--paper);font-family:var(--sans);font-weight:700;font-size:1.02rem;padding:16px 30px;border:2.5px solid var(--ink);box-shadow:7px 7px 0 rgba(0,0,0,.45);transition:transform .16s ease,box-shadow .16s ease;}
.flag-btn:hover{transform:translate(-3px,-3px);box-shadow:12px 12px 0 rgba(0,0,0,.45);}
.flag-btn .arw{transition:transform .16s ease;}
.flag-btn:hover .arw{transform:translateX(5px);}
.flag-note{font-family:var(--hand);font-size:1.3rem;color:var(--gold);transform:rotate(-2deg);}
@media (max-width:820px){
  .flag-grid{grid-template-columns:1fr;gap:22px;}
}
@media (max-width:600px){
  .flagship{padding:52px 0 56px;}
  .flag-watermark{font-size:34vw;}
}

@media (max-width:760px){
  /* mobile machine: same beat as desktop -- cards fall from the collage into a
     stacked console, grid produced below, copy underneath. JS drives the fall. */
  .machine-track{height:auto;}
  .machine-sticky{position:static;height:auto;padding:56px 0 64px;background-color:var(--ink);}
  .machine-stage{height:auto;display:flex;flex-direction:column;gap:26px;align-items:center;}
  .machine-copy{position:static;transform:none;opacity:1;width:100%;max-width:520px;order:3;}
  .machine-box{position:static;transform:none;order:1;width:min(300px,84vw);}
  .machine-grid{position:static;transform:none;order:2;opacity:0;width:min(300px,84vw);will-change:transform,opacity;}
  .mcard,.m-hint{display:none;}
  .mfly{display:block;}
}

/* =============== reveal =============== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .5s ease,transform .5s ease;}
.reveal.is-in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .ticker-track{animation:none;}
  .hero-collage .float{animation:none;}
}

/* =============== RESPONSIVE =============== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-figure{justify-self:start;max-width:400px;margin-top:8px;}
  .audience-grid,.build-grid{grid-template-columns:repeat(2,1fr);}
  .aud:nth-child(4n){border-right:var(--line) solid var(--ink);}
  .aud:nth-child(2n){border-right:none;}
  .pricing-grid{grid-template-columns:1fr 1fr;}
  .care-grid{grid-template-columns:1fr;}
  .selfmanage{grid-template-columns:1fr;gap:24px;}
  .svc-grid{grid-template-columns:1fr 1fr;}
  .process-grid{grid-template-columns:1fr 1fr;}
  .step{border-right:none;border-bottom:var(--line) solid var(--ink);}
  .step:nth-child(odd){border-right:var(--line) solid var(--ink);}
  .step:nth-child(n+5){border-bottom:none;}
  .addon-cols{grid-template-columns:1fr;}
  .form-shell{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-in{grid-template-columns:1fr 1fr;}
}
@media (max-width:680px){
  .section{padding:56px 0;}
  .brand-logo{height:40px;}
  .brand-tag{font-size:.58rem;letter-spacing:.12em;padding-left:9px;}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:var(--paper);
    border-left:var(--line) solid var(--ink);flex-direction:column;align-items:flex-start;
    padding:80px 28px;gap:22px;transform:translateX(100%);transition:transform .25s ease;box-shadow:var(--shadow-lg);}
  .machine-track{height:auto;}
  .mcard-inner{font-size:.82rem;padding:9px 13px;gap:8px;}
  .mcard-inner .mc-ic{width:12px;height:12px;}
  .machine-box{width:84vw;}
  .machine-body{padding:18px;}
  .machine-label b{font-size:1.3rem;}
  .machine-output{width:88vw;}
  .mh{font-size:clamp(1.4rem,7vw,2rem);}
  .nav-links.is-open{transform:none;overflow-y:auto;gap:16px;}
  .nav-links a{font-size:1.05rem;}
  /* dropdowns expand inline on mobile */
  .nav-item{flex-direction:column;align-items:flex-start;width:100%;}
  .nav-top{font-size:1.05rem;}
  .caret{display:none;}
  .has-drop::after{display:none;}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;border:none;box-shadow:none;
    background:transparent;padding:6px 0 4px 16px;margin:4px 0 0;min-width:0;gap:0;}
  .dropdown a{padding:7px 0;font-size:.98rem;white-space:normal;}
  .menu-btn{display:block;z-index:120;}
  .pricing-grid{grid-template-columns:1fr;}
  .audience-grid,.build-grid,.process-grid{grid-template-columns:1fr;}
  .aud,.step{border-right:none !important;}
  .svc-grid,.cred-grid,.offer-grid{grid-template-columns:1fr;}
  .edge{flex-direction:column;gap:6px;}
  .step:nth-child(n+5){border-bottom:var(--line) solid var(--ink);}
  .step:last-child{border-bottom:none;}
  .form-row,.checks{grid-template-columns:1fr;}
  .footer-in{grid-template-columns:1fr;}
  .cta-band{padding:40px 24px;}
  .hero-badge{right:8px;}
}
