/* ================= TOKENS ================= */
:root{
  --paper:#F8F5EF;
  --ink:#171511;
  --fg:#171511;
  --muted:#5D5A51;
  --faint:#8A8578;
  --ghost:rgba(23,21,17,.22);
  --line:rgba(23,21,17,.11);
  --line-strong:rgba(23,21,17,.22);
  --surface:#FFFEFB;
  --tint:#EDF1FE;
  --bgc:var(--paper);
  --blue:#2F6BFF;
  --blue-hover:#2459E8;
  --blue-down:#1E4CC9;
  --blue-deep:#1E4FD6;
  --blue-dim:rgba(47,107,255,.10);
  --display:'Space Grotesk',sans-serif;
  --body:'Inter',sans-serif;
  --serif:'Instrument Serif',Georgia,serif;
  --ease-out:cubic-bezier(.23,1,.32,1);
  --ease-in-out:cubic-bezier(.77,0,.175,1);
}
/* Dark ink band — same components, swapped tokens.
   Full-bleed: background runs edge-to-edge, content stays on the grid. */
.inkband{
  --bgc:#171511;
  --fg:#F2EFE8;
  --muted:#B5B0A4;
  --faint:#8E897C;
  --ghost:rgba(242,239,232,.25);
  --line:rgba(242,239,232,.13);
  --line-strong:rgba(242,239,232,.28);
  --surface:#211E19;
  --tint:#201E22;
  --blue-deep:#7DA2FF;
  background:var(--bgc);color:var(--fg);
  margin-inline:calc(50% - 50vw);
  padding-inline:calc(50vw - 50%);
}

/* ================= BASE ================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:76px}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--blue);color:#fff}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px}
em{font-family:var(--serif);font-style:italic;font-size:1.06em;letter-spacing:0}

.skip-link{
  position:absolute;left:16px;top:-48px;z-index:200;
  background:var(--blue);color:#fff;padding:10px 16px;border-radius:999px;
  font-size:14px;font-weight:500;transition:top 150ms var(--ease-out);
}
.skip-link:focus{top:16px}

/* ================= FRAME ================= */
.frame{max-width:1200px;margin:0 auto}
@media(min-width:900px){
  .frame{border-left:1px solid var(--line);border-right:1px solid var(--line)}
}
.pad{padding:0 20px}
@media(min-width:768px){.pad{padding:0 48px}}

section,.strip{border-top:1px solid var(--line)}
section{padding:88px 0}
@media(min-width:900px){section{padding:124px 0}}

.label{
  display:flex;align-items:center;gap:10px;
  font-family:var(--display);font-size:11.5px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--faint);
  margin-bottom:26px;
}
.label .dots{display:inline-flex;gap:5px;margin-right:2px}
.label .dots i{width:5.5px;height:10px;border-radius:1px;background:var(--blue);transform:skewX(-16deg)}
.label .dots i+i{background:none;border:1px solid var(--faint)}
.label .n{color:var(--ghost);margin-left:auto;letter-spacing:.08em}
h2{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.95rem,4vw,3rem);
  line-height:1.08;letter-spacing:-.03em;
  max-width:20ch;color:var(--fg);
}
.sub{color:var(--muted);font-size:16.5px;max-width:52ch;margin-top:16px}

/* ================= BUTTONS ================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--display);font-weight:500;font-size:15px;
  padding:13px 26px;border-radius:999px;
  min-height:48px;white-space:nowrap;
  transition:transform 160ms var(--ease-out),background-color 160ms ease,border-color 160ms ease,color 160ms ease;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:active{background:var(--blue-down)}
.btn-secondary{border:1px solid var(--line-strong);color:var(--fg)}
.btn .arr{transition:transform 200ms var(--ease-out)}
@media(hover:hover) and (pointer:fine){
  .btn-primary:hover{background:var(--blue-hover)}
  .btn-secondary:hover{border-color:var(--fg);background:var(--surface)}
  .inkband .btn-secondary:hover{background:rgba(242,239,232,.07)}
  .btn:hover .arr{transform:translateX(3px)}
}
.btn-sm{padding:9px 18px;min-height:38px;font-size:14px}

/* ================= HEADER ================= */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;height:64px;
  background:rgba(248,245,239,.82);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color 200ms ease;
}
.site-header.scrolled{border-bottom-color:var(--line)}
.header-in{
  max-width:1200px;margin:0 auto;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;
}
@media(min-width:768px){.header-in{padding:0 48px}}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.02em;color:var(--fg)}
.logo svg{width:19px;height:19px}
.main-nav{display:none;gap:30px}
.main-nav a{font-size:14px;color:var(--muted);transition:color 150ms ease}
.main-nav a.act{color:var(--ink)}
.header-cta{display:none}
/* base hamburger rule lives BEFORE the desktop media query so display:none wins ≥900px */
.menu-btn{width:44px;height:44px;display:grid;place-items:center;margin-right:-10px}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{
  content:"";display:block;width:20px;height:1.5px;background:var(--ink);
  position:relative;transition:transform 250ms var(--ease-out),background-color 150ms ease;
}
.menu-btn span::before{position:absolute;top:-6px}
.menu-btn span::after{position:absolute;top:6px}
body.menu-open .menu-btn span{background:transparent}
body.menu-open .menu-btn span::before{transform:translateY(6px) rotate(45deg)}
body.menu-open .menu-btn span::after{transform:translateY(-6px) rotate(-45deg)}
@media(min-width:900px){
  .main-nav{display:flex}
  .header-cta{display:inline-flex}
  .menu-btn{display:none}
}
@media(hover:hover) and (pointer:fine){
  .main-nav a:hover{color:var(--ink)}
}

.mobile-menu{
  position:fixed;inset:0;z-index:90;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;padding:0 24px;
  opacity:0;visibility:hidden;
  transition:opacity 220ms var(--ease-out),visibility 220ms;
}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
body.menu-open{overflow:hidden}
.mobile-menu a{
  font-family:var(--display);font-size:30px;font-weight:500;
  padding:16px 0;border-bottom:1px solid var(--line);color:var(--ink);
}
.mobile-menu .btn{margin-top:28px;border-bottom:0}

/* ================= HERO ================= */
.hero{border-top:0;padding:160px 0 88px}
@media(min-width:900px){
  .hero{padding:196px 0 112px}
  .hero-grid{display:grid;grid-template-columns:1fr 300px;gap:72px;align-items:end}
}
.hero h1{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2.9rem,8.4vw,5.9rem);
  line-height:1.02;letter-spacing:-.042em;
  max-width:11ch;
}
.hero h1 .dot{color:var(--blue)}
.hw{display:inline-block;overflow:hidden;vertical-align:bottom;padding-bottom:.12em;margin-bottom:-.12em}
.hw>span{display:inline-block}
.squig-wrap{position:relative;display:inline-block}
.squig{
  position:absolute;left:0;right:6%;bottom:-.06em;height:.14em;width:94%;
  overflow:visible;pointer-events:none;
}
.squig path{
  fill:none;stroke:var(--blue);stroke-width:7;stroke-linecap:round;
  vector-effect:non-scaling-stroke;
}
.hero-sub{
  color:var(--muted);font-size:clamp(16px,1.9vw,18px);line-height:1.65;
  max-width:54ch;margin-top:30px;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:36px}
.trust-line{
  display:flex;align-items:center;gap:12px;
  margin-top:52px;font-size:13px;color:var(--faint);
}
.trust-line::before{content:"";width:24px;height:1px;background:var(--line-strong);flex:none}

.hero-side{margin-top:56px}
@media(min-width:900px){.hero-side{margin-top:0}}
.heromark{width:110px;margin-bottom:36px}
.hero-meta div{
  border-top:1px solid var(--line);padding:11px 0 18px;
  font-family:var(--display);font-size:11px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--faint);
  line-height:1.7;
}
.hero-meta div strong{display:block;color:var(--muted);font-weight:500}

/* ================= STRIPS ================= */
.strip{padding:0}
.strip-in{display:grid;gap:20px;padding-top:36px;padding-bottom:36px}
@media(min-width:900px){
  .strip-in{grid-template-columns:240px 1fr;gap:48px;align-items:center;padding-top:44px;padding-bottom:44px}
}
.strip-label{font-size:13px;color:var(--faint);line-height:1.5;max-width:24ch}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;column-gap:40px;row-gap:18px}
.logo-row span{
  font-family:var(--display);font-weight:500;font-size:16px;letter-spacing:-.01em;
  color:var(--ink);opacity:.45;
}
@media(min-width:900px){.logo-row{column-gap:52px;justify-content:flex-end}.logo-row span{font-size:17px}}
/* tech marquee */
.marquee{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee-track{
  display:flex;align-items:center;gap:56px;width:max-content;
  animation:scrollX 26s linear infinite;
}
.marquee-track span{
  font-family:var(--display);font-weight:500;font-size:17px;letter-spacing:-.01em;
  color:var(--ink);opacity:.5;white-space:nowrap;
}
.marquee-track .sep{width:5px;height:5px;border-radius:50%;background:var(--blue);opacity:.6;flex:none}
@keyframes scrollX{to{transform:translateX(-50%)}}
@media(hover:hover) and (pointer:fine){.marquee:hover .marquee-track{animation-play-state:paused}}

/* ================= ABOUT ================= */
.statement{
  font-family:var(--display);font-weight:500;
  font-size:clamp(1.6rem,3.9vw,2.75rem);
  line-height:1.3;letter-spacing:-.022em;
  max-width:26ch;
}
.statement .w{color:var(--ghost);transition:color 450ms ease}
.statement .w.lit{color:var(--ink)}
.statement em{color:inherit}

/* ================= RULED GRIDS ================= */
.grid-ruled{
  display:grid;gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:18px;overflow:hidden;
  margin-top:56px;
}
.grid-ruled>*{background:var(--bgc)}

.stats{grid-template-columns:1fr 1fr}
@media(min-width:900px){.stats{grid-template-columns:repeat(4,1fr);margin-top:88px}}
.stat{padding:26px 22px 30px}
.stat-num{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2rem,3.4vw,2.8rem);letter-spacing:-.03em;
  color:var(--blue);line-height:1.1;
  font-variant-numeric:tabular-nums;
}
.stat-label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:10px;font-family:var(--display);font-weight:500}

/* services — each card opens with a living micro-diagram */
@media(min-width:760px){.cells{grid-template-columns:1fr 1fr}}
.cell{padding:28px 24px 36px}
@media(min-width:900px){.cell{padding:32px 30px 42px}}
.cell-viz{
  position:relative;background:rgba(23,21,17,.045);
  border-radius:14px;padding:20px 16px;margin-bottom:26px;
}
.cell-viz .viz{width:100%;max-width:230px;margin:0 auto;color:var(--ink)}
.cell-num{
  position:absolute;top:12px;left:14px;
  font-family:var(--display);font-size:12px;color:var(--ghost);letter-spacing:.1em;
}
.cell h3{font-family:var(--display);font-weight:500;font-size:20px;letter-spacing:-.015em;margin-bottom:10px}
.cell p{color:var(--muted);font-size:15px;max-width:40ch}
.vs{fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.vb{stroke:var(--blue)}
.ty{fill:currentColor;opacity:.25;animation:ty 1.5s ease-in-out infinite}
.ty:nth-of-type(2){animation-delay:.2s}
.ty:nth-of-type(3){animation-delay:.4s}
@keyframes ty{0%,60%,100%{opacity:.25}30%{opacity:1}}
.dashflow{stroke-dasharray:5 6;animation:dashmove 1.1s linear infinite}
@keyframes dashmove{to{stroke-dashoffset:-22}}
.knob{
  fill:var(--paper);stroke:currentColor;stroke-width:2.2;
  transform-box:fill-box;transform-origin:center;
  animation:knob ease-in-out infinite alternate;
}
.knob.vbk{stroke:var(--blue)}
@keyframes knob{to{transform:translateX(var(--kx))}}
.bl{animation:blfade 3.4s ease-in-out infinite}
.vbl{stroke:var(--blue)}
@keyframes blfade{0%,12%{opacity:0}30%,72%{opacity:1}88%,100%{opacity:0}}

/* ================= WORKFLOW BAND ================= */
.wfband{padding:72px 0}
@media(min-width:900px){.wfband{padding:96px 0}}
.wf-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-top:40px}
.wf-scroll::-webkit-scrollbar{display:none}
.wf{min-width:820px;width:100%;color:var(--ink)}
.wf .node{fill:var(--surface);stroke:var(--line-strong);stroke-width:1.5}
.wf text{font-family:var(--display);font-weight:500;font-size:17px;fill:var(--ink);letter-spacing:-.01em}
.wf .edge{fill:none;stroke:var(--line-strong);stroke-width:1.8}
.wf .fdot{fill:var(--blue)}
.wf .nicon{fill:none;stroke:var(--faint);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.wf-hint{display:block;font-size:12px;color:var(--faint);margin-top:14px;text-align:right}
@media(min-width:900px){.wf-hint{display:none}}

/* process — pipeline with a travelling dot */
.pipeline{position:relative;display:none;margin-top:56px;height:34px}
@media(min-width:900px){.pipeline{display:grid;grid-template-columns:repeat(4,1fr)}}
.pipeline::before{content:"";position:absolute;left:6px;right:6px;top:50%;height:1.5px;background:var(--line)}
.pnode{
  width:11px;height:11px;border-radius:50%;place-self:center;
  border:2px solid var(--faint);background:var(--paper);position:relative;z-index:1;
}
.pnode.on{border-color:var(--blue);background:var(--blue)}
.pdot{
  position:absolute;top:50%;left:0;width:8px;height:8px;
  margin:-4px 0 0 -4px;border-radius:50%;background:var(--blue);
  animation:flowX 7s linear infinite;
}
@keyframes flowX{0%{left:0;opacity:0}5%{opacity:1}95%{opacity:1}100%{left:100%;opacity:0}}
@media(min-width:900px){.process.tight{margin-top:14px}}
@media(min-width:900px){.process{grid-template-columns:repeat(4,1fr)}}
.step{padding:30px 26px 38px}
@media(min-width:900px){.step{padding:34px 30px 44px}}
.step-num{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2.4rem,4vw,3.2rem);letter-spacing:-.04em;
  color:var(--ghost);line-height:1;margin-bottom:40px;
  font-variant-numeric:tabular-nums;
}
.step:first-child .step-num{color:var(--blue)}
.step h3{font-family:var(--display);font-weight:500;font-size:18px;margin-bottom:8px}
.step p{color:var(--muted);font-size:14.5px;max-width:28ch}

/* ================= RESULTS ================= */
@media(min-width:900px){.results{grid-template-columns:repeat(3,1fr)}}
.result{padding:32px 28px;display:flex;flex-direction:column}
@media(min-width:900px){.result{padding:38px 32px}}
.result-tag{font-family:var(--display);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:26px}
.result-metric{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.6rem,2.4vw,2rem);line-height:1.15;letter-spacing:-.025em;
  color:var(--blue-deep);margin-bottom:14px;
  font-variant-numeric:tabular-nums;
}
.rbar{height:6px;background:var(--line);border-radius:99px;margin:4px 0 24px;overflow:hidden}
.rbar i{display:block;height:100%;width:var(--w,50%);background:var(--blue);border-radius:99px;transform-origin:left}
.result-story{color:var(--muted);font-size:14.5px;margin-bottom:30px}
.result-quote{
  margin-top:auto;padding-top:18px;border-top:1px solid var(--line);
  font-size:14px;color:var(--muted);
}
.result-quote footer{margin-top:8px;font-size:12.5px;color:var(--faint)}

/* ================= PRICING ================= */
@media(min-width:900px){.tiers{grid-template-columns:repeat(3,1fr)}}
.tier{padding:36px 30px 34px;display:flex;flex-direction:column;position:relative}
.tier.featured{background:var(--tint)}
.tier.featured::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue)}
.tier-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;min-height:26px}
.tier-name{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:500;font-size:17px}
.tier-name svg{width:17px;height:17px;color:var(--faint);flex:none}
.tier.featured .tier-name svg{color:var(--blue)}
.badge{
  font-family:var(--display);font-size:10.5px;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:var(--blue);
  padding:5px 11px;border-radius:999px;
}
.tier-price{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.8rem,2.4vw,2.2rem);letter-spacing:-.03em;line-height:1.1;
  font-variant-numeric:tabular-nums;
}
.tier-price small{font-size:13px;font-weight:400;color:var(--faint);font-family:var(--body);letter-spacing:0}
.tier-desc{color:var(--muted);font-size:14.5px;margin-top:14px;flex:1}
.tier-best{font-size:13px;color:var(--faint);margin-top:20px;padding-top:18px;border-top:1px solid var(--line)}
.tier-best em{font-size:1.12em}
.tier .btn{margin-top:30px;width:100%}

/* ================= FAQ ================= */
.faq-list{max-width:720px;margin-top:48px}
.faq-group{
  font-family:var(--display);font-size:11.5px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--faint);
  margin:44px 0 4px;
}
.faq-group:first-child{margin-top:0}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:first-of-type{border-top:1px solid var(--line)}
.faq-item summary{
  list-style:none;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:22px 2px;cursor:pointer;
  font-family:var(--display);font-weight:500;font-size:17px;letter-spacing:-.01em;
  color:var(--muted);
  transition:color 150ms ease;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item[open] summary{color:var(--ink)}
@media(hover:hover) and (pointer:fine){.faq-item summary:hover{color:var(--ink)}}
.faq-item summary::after{
  content:"";flex:none;width:11px;height:11px;
  background:
    linear-gradient(currentColor,currentColor) center/11px 1.5px no-repeat,
    linear-gradient(currentColor,currentColor) center/1.5px 11px no-repeat;
  transition:transform 200ms var(--ease-out);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows 250ms var(--ease-out)}
.faq-item[open] .faq-body{grid-template-rows:1fr}
.faq-body>div{min-height:0;overflow:hidden}
.faq-body p{color:var(--muted);font-size:15px;padding:0 2px 24px;max-width:58ch}

/* ================= CONTACT (ink band) ================= */
.inkband{border-top:0}
.contact-grid{grid-template-columns:1fr;border-radius:18px}
@media(min-width:900px){.contact-grid{grid-template-columns:1.15fr .85fr}}
.contact-form{padding:32px 28px 36px}
@media(min-width:900px){.contact-form{padding:40px 36px 44px}}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:7px;font-weight:500}
.field input,.field textarea{
  width:100%;background:var(--surface);border:1px solid var(--line);
  border-radius:6px;padding:12px 14px;color:var(--fg);
  font:inherit;font-size:16px;
  transition:border-color 150ms ease;
}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue)}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.form-note{font-size:12.5px;color:var(--faint);margin-top:14px}
.form-success{
  display:none;border-left:2px solid var(--blue);background:rgba(47,107,255,.14);
  padding:14px 16px;font-size:14.5px;margin-top:18px;border-radius:0 8px 8px 0;
}
.booking{background:var(--tint)!important;padding:32px 28px 36px;display:flex;flex-direction:column}
@media(min-width:900px){.booking{padding:40px 36px 44px}}
.booking h3{font-family:var(--display);font-weight:500;font-size:19px;margin-bottom:10px}
.booking p{color:var(--muted);font-size:14.5px;margin-bottom:26px;max-width:36ch}
.booking-meta{display:grid;grid-template-columns:repeat(3,auto);gap:20px;margin-bottom:30px;justify-content:start}
.booking-meta div{font-size:12px;color:var(--faint)}
.booking-meta strong{display:block;font-family:var(--display);font-size:14.5px;color:var(--fg);font-weight:500;margin-bottom:2px}

/* ================= FOOTER (ink band) ================= */
footer.site{padding:64px 0 36px;border-top:1px solid var(--line)}
.footer-grid{display:grid;gap:40px}
@media(min-width:760px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.footer-brand p{color:var(--faint);font-size:14px;margin-top:14px;max-width:28ch}
.footer-col h4{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.footer-col a{display:block;font-size:14px;color:var(--muted);padding:5px 0;transition:color 150ms ease}
@media(hover:hover) and (pointer:fine){.footer-col a:hover{color:var(--fg)}}
.footer-bottom{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;
  margin-top:52px;padding-top:24px;border-top:1px solid var(--line);
  font-size:12.5px;color:var(--faint);
}

/* ================= SUBPAGE COMPONENTS ================= */
.page-hero{padding:152px 0 56px}
@media(min-width:900px){.page-hero{padding:180px 0 72px}}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.2rem)}
.page-hero .hero-sub{margin-top:22px}

.svc{display:grid;gap:36px;padding:64px 0;border-top:1px solid var(--line)}
.svc:first-of-type{border-top:0}
@media(min-width:900px){
  .svc{grid-template-columns:1fr 1fr;gap:72px;align-items:center;padding:88px 0}
  .svc.flip>.svc-viz{order:2}
}
.svc h3{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,2.6vw,2rem);letter-spacing:-.02em;margin-bottom:14px}
.svc p{color:var(--muted);font-size:15.5px;max-width:50ch}
.svc .cell-viz{margin-bottom:0;padding:34px 24px}
.svc .cell-viz .viz{max-width:290px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.chips span{
  font-family:var(--display);font-weight:500;font-size:12.5px;
  padding:7px 14px;border:1px solid var(--line-strong);border-radius:999px;color:var(--muted);
}
.dl{margin-top:22px;list-style:none}
.dl li{display:flex;gap:10px;padding:6px 0;color:var(--muted);font-size:14.5px}
.dl li::before{content:"\2192";color:var(--blue);font-family:var(--display);flex:none}

.tabs{display:flex;flex-wrap:wrap;gap:8px;margin:36px 0 30px}
.tab{
  font-family:var(--display);font-weight:500;font-size:14px;
  padding:9px 18px;border:1px solid var(--line-strong);border-radius:999px;color:var(--muted);
  transition:transform 160ms var(--ease-out),background-color 160ms ease,color 160ms ease,border-color 160ms ease;
}
.tab:active{transform:scale(.97)}
.tab.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
@media(hover:hover) and (pointer:fine){.tab:not(.on):hover{border-color:var(--ink);color:var(--ink)}}
.tabpane{display:none}
.tabpane.on{display:block;animation:paneIn .35s var(--ease-out)}
@keyframes paneIn{from{opacity:0;transform:translateY(6px)}}
.tabpane .wf{min-width:700px}
.tabpane .sub{margin-top:10px}

.journey{position:relative;margin-top:56px;padding-left:36px}
@media(min-width:900px){.journey{padding-left:52px}}
.journey::before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:var(--line)}
.jfill{position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:var(--blue);transform:scaleY(0);transform-origin:top}
.jstage{position:relative;padding-bottom:56px}
.jstage:last-child{padding-bottom:8px}
.jdot{
  position:absolute;left:-36px;top:2px;width:18px;height:18px;border-radius:50%;
  border:2px solid var(--faint);background:var(--paper);
  transition:border-color 300ms ease,background-color 300ms ease;
}
@media(min-width:900px){.jdot{left:-52px}}
.jstage.on .jdot{border-color:var(--blue);background:var(--blue)}
.jweek{
  display:inline-block;font-family:var(--display);font-weight:500;font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--blue-deep);
  background:var(--blue-dim);padding:5px 12px;border-radius:999px;margin-bottom:14px;
}
.jstage h3{font-family:var(--display);font-weight:500;font-size:22px;letter-spacing:-.02em;margin-bottom:10px}
.jstage>p{color:var(--muted);font-size:15px;max-width:58ch}
.jcols{display:grid;gap:16px;margin-top:22px}
@media(min-width:760px){.jcols{grid-template-columns:1fr 1fr;max-width:760px}}
.jcol{background:rgba(23,21,17,.045);border-radius:12px;padding:18px 20px}
.jcol h4{font-family:var(--display);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.jcol ul{list-style:none}
.jcol li{display:flex;gap:9px;padding:4px 0;color:var(--muted);font-size:14px}
.jcol li::before{content:"\2192";color:var(--blue);font-family:var(--display);flex:none}

.calc{display:grid;gap:40px;margin-top:48px}
@media(min-width:900px){.calc{grid-template-columns:1.05fr .95fr;gap:72px;align-items:start}}
.crow{margin-bottom:30px}
.crow label{display:flex;justify-content:space-between;gap:16px;font-size:14.5px;color:var(--muted);margin-bottom:12px}
.crow output{font-family:var(--display);font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.crow input[type=range]{
  -webkit-appearance:none;appearance:none;
  width:100%;height:28px;background:transparent;cursor:pointer;
}
.crow input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:99px;background:var(--line-strong)}
.crow input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--blue);border:3px solid var(--paper);
  box-shadow:0 1px 4px rgba(23,21,17,.3);margin-top:-9px;
}
.crow input[type=range]::-moz-range-track{height:4px;border-radius:99px;background:var(--line-strong)}
.crow input[type=range]::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;border:3px solid var(--paper);
  background:var(--blue);box-shadow:0 1px 4px rgba(23,21,17,.3);
}
.couts{border:1px solid var(--line);border-radius:18px;background:var(--surface);padding:8px 28px 14px}
.cout{padding:20px 0;border-bottom:1px solid var(--line)}
.cout:last-of-type{border-bottom:0}
.cout b{
  display:block;font-family:var(--display);font-weight:600;
  font-size:clamp(1.7rem,2.6vw,2.3rem);letter-spacing:-.03em;color:var(--blue);
  font-variant-numeric:tabular-nums;line-height:1.15;
}
.cout span{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.cfoot{font-size:12.5px;color:var(--faint);margin-top:18px;max-width:46ch}

.cmp-wrap{overflow-x:auto;margin-top:56px;-webkit-overflow-scrolling:touch}
.cmp{width:100%;min-width:580px;border-collapse:collapse;font-size:14.5px}
.cmp th,.cmp td{padding:14px 12px;border-bottom:1px solid var(--line);text-align:left}
.cmp thead th{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.cmp tbody th{font-weight:500;color:var(--ink)}
.cmp td.c{text-align:center;font-family:var(--display)}
.cmp .yes{color:var(--blue);font-weight:600}
.cmp .no{color:var(--ghost)}
.cmp thead th.hl{color:var(--blue-deep)}

.ctaband{padding:88px 0}
.ctaband h2{max-width:14ch}
.ctaband .hero-ctas{margin-top:32px}

/* ================= CASE STUDIES / ABOUT / CHECKLIST ================= */
.pullquote{
  font-size:18px;line-height:1.6;border-left:3px solid var(--blue);
  padding:6px 0 6px 22px;color:var(--ink);max-width:58ch;margin-top:36px;
}
.pullquote footer{color:var(--faint);font-size:13px;margin-top:10px}
.study-stats{margin-top:44px}
.photo-slot{
  aspect-ratio:4/5;border:2px dashed var(--line-strong);border-radius:18px;
  display:grid;place-items:center;text-align:center;color:var(--faint);
  font-size:13px;background:var(--surface);padding:20px;
}
.principles .cell p{max-width:34ch}
.gate{counter-reset:gateitem;list-style:none;margin-top:36px;max-width:680px}
.gate li{
  counter-increment:gateitem;display:flex;gap:14px;align-items:baseline;
  padding:13px 2px;border-bottom:1px solid var(--line);
  color:var(--ink);font-size:15.5px;
}
.gate li::before{
  content:counter(gateitem,decimal-leading-zero);
  font-family:var(--display);font-size:12px;color:var(--blue-deep);flex:none;
}
.gate li.lock{filter:blur(5px);user-select:none;pointer-events:none}
@media(prefers-reduced-motion:reduce){.gate li.lock{filter:blur(5px)}}
.magnet-form{max-width:480px;margin-top:40px}
.magnet-form .btn{width:100%}

/* ================= MOTION ================= */
@media(prefers-reduced-motion:no-preference){
  .hw>span{transform:translateY(112%)}
  .hero-sub,.hero-ctas,.trust-line,.hero-side{opacity:0;transform:translateY(8px)}
  .reveal{opacity:0;transform:translateY(10px)}
  .gstag>*{opacity:0;transform:translateY(8px)}
  .squig path{stroke-dasharray:1;stroke-dashoffset:1}
  .rbar i{transform:scaleX(0)}
  html.no-motion .hw>span,
  html.no-motion .hero-sub,html.no-motion .hero-ctas,
  html.no-motion .trust-line,html.no-motion .hero-side,
  html.no-motion .reveal,html.no-motion .gstag>*{opacity:1;transform:none}
  html.no-motion .squig path{stroke-dashoffset:0}
  html.no-motion .rbar i{transform:none}
  html.no-motion .statement .w{color:var(--ink)}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .statement .w{color:var(--ink);transition:none}
  .faq-body{transition:none}
  .btn,.btn .arr,.menu-btn span,.menu-btn span::before,.menu-btn span::after{transition:none}
  .ty,.dashflow,.knob,.bl,.pdot,.marquee-track{animation:none!important}
  .ty{opacity:.6}
  .rbar i{transform:none}
  .tabpane.on{animation:none}
  .jdot{transition:none}
  .jfill{transform:scaleY(1)}
  .jstage .jdot{border-color:var(--blue)}
}

/* ================= ADMIN ================= */
.adm .cmp td,.adm .cmp th{vertical-align:top}
.adm-msg{max-width:38ch;white-space:pre-wrap}
.adm select{background:var(--surface);border:1px solid var(--line-strong);border-radius:8px;padding:6px 10px;color:var(--fg);font:inherit;font-size:13px;cursor:pointer}
.adm-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:32px;margin-bottom:8px}
.adm-stat{font-family:var(--display);font-size:13px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:7px 14px;white-space:nowrap}
.adm-stat b{color:var(--blue);font-weight:600}
.login-card{max-width:420px;border:1px solid var(--line);border-radius:18px;background:var(--surface);padding:34px 30px;margin-top:48px}

/* ================= WOW PACK ================= */
/* industry picker */
.indpick{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:22px}
.indpick-label{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-right:4px}
.ipill{
  font-family:var(--display);font-weight:500;font-size:13px;
  padding:7px 15px;border:1px solid var(--line-strong);border-radius:999px;color:var(--muted);
  transition:transform 160ms var(--ease-out),background-color 160ms ease,color 160ms ease,border-color 160ms ease;
}
.ipill:active{transform:scale(.97)}
.ipill.on{background:var(--blue);border-color:var(--blue);color:#fff}
@media(hover:hover) and (pointer:fine){.ipill:not(.on):hover{border-color:var(--ink);color:var(--ink)}}

/* workflow builder */
.bgrid{display:grid;gap:44px;margin-top:52px}
@media(min-width:900px){.bgrid{grid-template-columns:380px 1fr;gap:64px;align-items:start}}
.bgroup-label{font-family:var(--display);font-size:11.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
.bmax{letter-spacing:.06em;color:var(--ghost)}
.bchips{display:flex;flex-wrap:wrap;gap:8px}
.bchip{
  font-family:var(--display);font-weight:500;font-size:13.5px;
  padding:9px 16px;border:1px solid var(--line-strong);border-radius:999px;color:var(--muted);
  transition:transform 160ms var(--ease-out),background-color 160ms ease,color 160ms ease,border-color 160ms ease;
}
.bchip:active{transform:scale(.97)}
.bchip.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
#bActions .bchip.on{background:var(--blue);border-color:var(--blue);color:#fff}
@media(hover:hover) and (pointer:fine){.bchip:not(.on):hover{border-color:var(--ink);color:var(--ink)}}
#builderWF{margin-top:0;min-height:170px}
#builderWF .wf{min-width:680px}

/* chat agent */
.chat-fab{
  position:fixed;right:20px;bottom:20px;z-index:120;
  width:58px;height:58px;border-radius:50%;background:var(--blue);
  display:grid;place-items:center;cursor:pointer;border:0;
  box-shadow:0 6px 24px -6px rgba(23,21,17,.4);
  transition:transform 160ms var(--ease-out),background-color 160ms ease;
}
.chat-fab:active{transform:scale(.94)}
@media(hover:hover) and (pointer:fine){.chat-fab:hover{background:var(--blue-hover)}}
.chat-fab svg{width:24px;height:24px}
.chat-panel{
  position:fixed;right:20px;bottom:90px;z-index:120;
  width:min(380px,calc(100vw - 32px));max-height:min(560px,calc(100dvh - 120px));
  background:#171511;color:#F2EFE8;border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 18px 60px -12px rgba(23,21,17,.5);
  opacity:0;transform:translateY(12px);visibility:hidden;
  transition:opacity 220ms var(--ease-out),transform 220ms var(--ease-out),visibility 220ms;
}
.chat-panel.open{opacity:1;transform:none;visibility:visible}
@media(max-width:600px){.chat-panel{right:16px;left:16px;width:auto}}
.chat-head{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid rgba(242,239,232,.13)}
.chat-head svg{width:18px;height:18px;flex:none}
.chat-head b{font-family:var(--display);font-weight:500;font-size:15px}
.chat-head span{font-size:11px;color:#8E897C;display:block}
.chat-close{margin-left:auto;color:#8E897C;font-size:22px;line-height:1;padding:4px 8px;cursor:pointer}
.chat-log{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px}
.cmsg{max-width:85%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.55;white-space:pre-line}
.cmsg.bot{background:#211E19;border-bottom-left-radius:4px;align-self:flex-start}
.cmsg.me{background:var(--blue);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}
.cmsg a{color:#7DA2FF;text-decoration:underline}
.chat-quick{display:flex;flex-wrap:wrap;gap:6px;padding:0 18px 12px}
.chat-quick button{
  font-family:var(--display);font-size:12px;font-weight:500;color:#B5B0A4;
  border:1px solid rgba(242,239,232,.2);border-radius:999px;padding:6px 12px;cursor:pointer;
}
@media(hover:hover) and (pointer:fine){.chat-quick button:hover{color:#F2EFE8;border-color:rgba(242,239,232,.45)}}
.chat-in{display:flex;gap:8px;padding:12px;border-top:1px solid rgba(242,239,232,.13)}
.chat-in input{
  flex:1;background:#211E19;border:1px solid rgba(242,239,232,.15);border-radius:999px;
  padding:11px 16px;color:#F2EFE8;font:inherit;font-size:14px;
}
.chat-in input:focus{outline:none;border-color:var(--blue)}
.chat-in button{
  width:42px;height:42px;border-radius:50%;background:var(--blue);color:#fff;
  display:grid;place-items:center;flex:none;cursor:pointer;font-size:16px;
}
.chat-note{font-size:10.5px;color:#8E897C;text-align:center;padding:0 16px 10px}
.cmsg .tydots{display:inline-flex;gap:4px;padding:4px 2px}
.cmsg .tydots i{width:6px;height:6px;border-radius:50%;background:#8E897C;animation:ty 1.2s ease-in-out infinite}
.cmsg .tydots i:nth-child(2){animation-delay:.15s}
.cmsg .tydots i:nth-child(3){animation-delay:.3s}

/* command palette */
.palette{
  position:fixed;inset:0;z-index:130;display:none;
  background:rgba(23,21,17,.45);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  padding:12vh 16px 0;
}
.palette.open{display:block}
.palette-box{
  max-width:520px;margin:0 auto;background:var(--paper);border-radius:16px;overflow:hidden;
  box-shadow:0 24px 80px -16px rgba(23,21,17,.5);
}
.palette-box input{
  width:100%;border:0;border-bottom:1px solid var(--line);background:transparent;
  padding:18px 20px;font:inherit;font-size:16px;color:var(--ink);
}
.palette-box input:focus{outline:none}
.palette-list{max-height:320px;overflow-y:auto;padding:8px}
.pitem{
  display:flex;align-items:center;gap:12px;width:100%;text-align:left;
  padding:12px 14px;border-radius:10px;font-size:14.5px;color:var(--ink);cursor:pointer;
}
.pitem .pk{margin-left:auto;font-family:var(--display);font-size:11px;color:var(--faint);letter-spacing:.08em;text-transform:uppercase}
.pitem.sel,.pitem:hover{background:rgba(23,21,17,.06)}
.phint{font-family:var(--display);font-size:11px;color:var(--faint);letter-spacing:.1em;text-transform:uppercase}

/* slots + calc share */
.slots{
  display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;
  font-family:var(--display);font-size:12.5px;font-weight:500;color:var(--fg);
}
.slots::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--blue);animation:slotpulse 2.2s ease-in-out infinite}
@keyframes slotpulse{0%,100%{opacity:1}50%{opacity:.35}}
.share-est{margin-top:14px;width:100%}

@media(prefers-reduced-motion:reduce){
  .chat-panel,.chat-fab,.ipill,.bchip{transition:none}
  .slots::before{animation:none}
  .cmsg .tydots i{animation:none}
}

/* ================= AD LANDERS ================= */
.lp-head{position:fixed;inset:0 0 auto 0;z-index:100;height:60px;background:rgba(248,245,239,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.lp-head .header-in{height:60px}
.lp-hero{border-top:0;padding:120px 0 56px}
@media(min-width:900px){
  .lp-hero{padding:150px 0 72px}
  .lp-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:start}
}
.lp-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(2.1rem,6.4vw,3.6rem);line-height:1.05;letter-spacing:-.035em;max-width:15ch}
.lp-proof{display:flex;flex-wrap:wrap;gap:8px;margin-top:26px}
.lp-proof span{font-family:var(--display);font-weight:500;font-size:12.5px;color:var(--blue-deep);background:var(--blue-dim);border-radius:999px;padding:7px 14px}
.lform-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:28px 24px;margin-top:40px}
@media(min-width:900px){.lform-card{margin-top:0;position:sticky;top:84px}}
.lform-card h3{font-family:var(--display);font-weight:500;font-size:19px;margin-bottom:6px}
.lform-card>p{color:var(--muted);font-size:14px;margin-bottom:20px}
.lform-card .btn{width:100%}
.lp-alt{display:block;text-align:center;font-size:13.5px;color:var(--muted);margin-top:14px;text-decoration:underline;text-underline-offset:3px}
.lp-section{padding:64px 0}
@media(min-width:900px){.lp-section{padding:88px 0}}
.lp-foot{border-top:1px solid var(--line);padding:28px 0;font-size:12.5px;color:var(--faint)}
.lp-foot .pad{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.lcta-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:110;
  padding:10px 16px calc(10px + env(safe-area-inset-bottom));
  background:rgba(248,245,239,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
}
.lcta-bar .btn{width:100%}
@media(min-width:900px){.lcta-bar{display:none}}
body[data-lander]{padding-bottom:84px}
@media(min-width:900px){body[data-lander]{padding-bottom:0}}

/* ================= MOBILE POLISH PASS ================= */
/* swipeable diagrams + comparison table: fade edge signals "more this way" */
@media(max-width:899px){
  .wf-scroll{
    -webkit-mask-image:linear-gradient(90deg,#000 88%,transparent);
    mask-image:linear-gradient(90deg,#000 88%,transparent);
  }
  .cmp-wrap{
    -webkit-mask-image:linear-gradient(90deg,#000 90%,transparent);
    mask-image:linear-gradient(90deg,#000 90%,transparent);
  }
  .cmp tbody th,.cmp thead th:first-child{
    position:sticky;left:0;background:var(--bgc);z-index:1;
  }
}
@media(max-width:599px){
  /* rhythm: phones don't need desktop-scale breathing room */
  section{padding:68px 0}
  .hero{padding:124px 0 64px}
  .page-hero{padding:118px 0 48px}
  .lp-hero{padding:104px 0 48px}
  .wfband{padding:60px 0}
  /* full-width tap-first CTAs */
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%}
  /* hero side: smaller mark, tighter meta */
  .hero-side{margin-top:44px}
  .heromark{width:72px;margin-bottom:24px}
  /* stats cells tighter */
  .stat{padding:20px 16px 24px}
  /* tap targets */
  .ipill,.bchip,.tab{min-height:40px;padding-top:8px;padding-bottom:8px}
  .footer-col a{padding:8px 0}
  .main-nav a{padding:10px 0}
  /* booking meta wraps gracefully */
  .booking-meta{display:flex;flex-wrap:wrap;gap:14px 22px}
  /* pullquote tighter */
  .pullquote{font-size:16.5px;padding-left:18px}
  /* journey columns full-bleed of card */
  .jcols{grid-template-columns:1fr}
}
/* safe-area: floating chat + mobile menu on notched phones */
.chat-fab{bottom:calc(20px + env(safe-area-inset-bottom))}
.chat-panel{bottom:calc(90px + env(safe-area-inset-bottom))}
.mobile-menu{
  justify-content:flex-start;
  padding-top:96px;
  padding-bottom:calc(32px + env(safe-area-inset-bottom));
  overflow-y:auto;
}

/* ================= VERTICAL FLOWS (mobile) ================= */
/* grid children must be allowed to shrink — stops scrollable diagrams
   blowing the column (and the chip rows) past the viewport */
.bgrid>*,.lp-grid>*,.hero-grid>*,.calc>*,.svc>*,.contact-grid>*{min-width:0}
.wf-scroll.noswipe{
  overflow:visible;
  -webkit-mask-image:none;mask-image:none;
}
.wf.vert{min-width:0;width:100%;max-width:400px}
#builderWF .wf.vert{min-width:0}
@media(max-width:899px){
  .wf-hint.off{display:none}
}
