/* =========================================================
   Harrigan Creative — shared styles
   ========================================================= */
:root{
  --white:#ffffff;
  --canvas:#fcf8eb;            /* warmer, slightly more yellow */
  --paper:#f4ecd6;             /* deeper warm cream */
  --hairline:#ebe3c8;
  --hairline-strong:#d8caa0;
  --ink:#0a1228;
  --navy:#0a1f3d;
  --navy-mid:#142a4e;
  --navy-soft:#23416b;
  --gray-900:#171a22;
  --gray-700:#3a4050;
  --gray-500:#6c7280;
  --gray-400:#9aa0ab;
  --gray-300:#c8ccd3;
  --accent:#3a5d8c;
  --accent-soft:#dde6f2;
  --good:#15803d;
  --good-soft:#dcfce7;
  --bad:#9aa0ab;
  --max:1240px;
  --gutter:clamp(20px,4vw,40px);
  --radius-sm:6px;
  --radius:10px;
  --radius-lg:18px;
  --shadow-sm:0 1px 2px rgba(10,18,40,.04), 0 1px 1px rgba(10,18,40,.03);
  --shadow:0 18px 40px -22px rgba(10,18,40,.18), 0 4px 12px -6px rgba(10,18,40,.06);
  --shadow-lg:0 36px 80px -32px rgba(10,18,40,.28), 0 10px 24px -12px rgba(10,18,40,.10);
  --easing:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  font-size:16px;line-height:1.55;
  color:var(--gray-700);background:var(--white);
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}
h1,h2,h3,h4{color:var(--ink);font-weight:500;letter-spacing:-0.02em;line-height:1.08;margin:0}
h2{font-size:clamp(28px,4.4vw,48px)}
h3{font-size:clamp(20px,2.4vw,26px);letter-spacing:-0.015em}
h4{font-size:18px;font-weight:500;letter-spacing:-0.012em}
p{margin:0}
.serif{font-family:"Instrument Serif",Georgia,serif;font-weight:400;letter-spacing:-0.005em;font-style:italic}
.acc-italic{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-500);font-weight:500}
.eyebrow::before{content:"—  ";color:var(--gray-400)}
.shell{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
section{position:relative}
.section-pad{padding:clamp(72px,10vw,140px) 0}
.section-pad-sm{padding:clamp(56px,7vw,96px) 0}
::selection{background:var(--ink);color:var(--white)}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.78);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid transparent;transition:border-color .3s var(--easing), background-color .3s var(--easing)}
.nav.scrolled{border-bottom-color:var(--hairline);background:rgba(255,255,255,.92)}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand-mark{width:36px;height:36px;display:block}
.brand-name{font-size:15px;letter-spacing:.02em;font-weight:600;color:var(--ink);display:flex;flex-direction:column;line-height:1;gap:3px}
.brand-name small{font-size:9.5px;letter-spacing:.22em;font-weight:500;color:var(--gray-500);text-transform:uppercase}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{font-size:14px;color:var(--gray-700);font-weight:450;position:relative;transition:color .2s var(--easing)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--easing)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{font-size:13.5px;color:var(--gray-700);font-weight:500;display:none}
@media(min-width:900px){.nav-phone{display:inline-flex;align-items:center;gap:6px}}
.nav-phone::before{content:"";width:6px;height:6px;border-radius:99px;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.18)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:99px;font-size:14px;font-weight:500;letter-spacing:.005em;transition:all .25s var(--easing);white-space:nowrap;border:1px solid transparent;line-height:1}
.btn-primary{background:var(--ink);color:var(--white)}
.btn-primary:hover{background:var(--navy);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-ghost{border-color:var(--hairline-strong);color:var(--ink);background:var(--white)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--white)}
.btn .arrow{transition:transform .25s var(--easing)}
.btn:hover .arrow{transform:translateX(3px)}
@media(max-width:880px){.nav-links{display:none}}

/* HERO */
.hero{position:relative;overflow:hidden;padding:clamp(80px,12vw,160px) 0 clamp(60px,8vw,110px);background:radial-gradient(1200px 600px at 80% -10%, rgba(58,93,140,.06), transparent 60%),radial-gradient(900px 500px at -10% 30%, rgba(20,42,78,.05), transparent 55%),var(--white)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(to right, rgba(10,18,40,.035) 1px, transparent 1px),linear-gradient(to bottom, rgba(10,18,40,.035) 1px, transparent 1px);background-size:64px 64px;mask-image:linear-gradient(to bottom, black 30%, transparent 100%);-webkit-mask-image:linear-gradient(to bottom, black 30%, transparent 100%);pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:80px;align-items:center}
.hero-inner.single{grid-template-columns:1fr;max-width:840px;margin:0 auto;text-align:center;align-items:start}
.hero-inner.single .hero-ctas{justify-content:center}
.hero-inner.single .hero-sub{margin-left:auto;margin-right:auto}
@media(max-width:980px){.hero-inner{grid-template-columns:1fr;gap:48px}}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:6px 14px 6px 8px;border:1px solid var(--hairline-strong);border-radius:99px;font-size:12px;color:var(--gray-700);background:var(--white);margin-bottom:28px}
.hero-eyebrow .dot{width:18px;height:18px;border-radius:99px;background:var(--ink);display:inline-flex;align-items:center;justify-content:center;color:var(--white);font-size:10px}
.hero h1{font-size:clamp(40px,6.4vw,80px);font-weight:500;letter-spacing:-0.035em;line-height:.98;color:var(--ink);margin-bottom:28px}
.hero h1 .line2{display:block}
.hero h1 .accent{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;letter-spacing:-0.01em;color:var(--navy)}
.hero-sub{font-size:clamp(16px,1.55vw,18.5px);color:var(--gray-700);max-width:540px;margin-bottom:36px;line-height:1.55}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-meta{display:flex;gap:24px;margin-top:42px;padding-top:24px;border-top:1px solid var(--hairline);max-width:540px;flex-wrap:wrap}
.hero-meta.center{margin-left:auto;margin-right:auto;justify-content:center;border-top:1px solid var(--hairline)}
.hero-meta .meta{display:flex;flex-direction:column;gap:2px}
.hero-meta .num{font-size:24px;color:var(--ink);font-weight:500;letter-spacing:-0.02em;line-height:1}
.hero-meta .lbl{font-size:12px;color:var(--gray-500);letter-spacing:.04em}
.hero-visual{position:relative;aspect-ratio:1/1.05;border-radius:var(--radius-lg);background:linear-gradient(180deg, #ffffff 0%, #f6f4ec 100%);border:1px solid var(--hairline);box-shadow:var(--shadow-lg);overflow:hidden}
.hv-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--hairline);background:var(--white)}
.hv-pill{font-size:11.5px;color:var(--gray-500);letter-spacing:.06em;display:flex;align-items:center;gap:8px}
.hv-pill::before{content:"";width:8px;height:8px;border-radius:99px;background:#ef4444;box-shadow:0 0 0 4px rgba(239,68,68,.15);animation:livePulse 2.2s ease-in-out infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 4px rgba(239,68,68,.15)}50%{box-shadow:0 0 0 6px rgba(239,68,68,.05)}}
.hv-keyword{font-size:13px;color:var(--ink);font-weight:500}
.hv-keyword .kw{display:inline-block;color:var(--ink);padding:0 4px;background:linear-gradient(180deg, transparent 60%, rgba(58,93,140,.18) 60%)}
.hv-map{position:relative;height:calc(100% - 65px);padding:24px}
.hv-map svg{width:100%;height:100%;display:block}
.hv-stat{position:absolute;background:var(--white);border:1px solid var(--hairline);box-shadow:var(--shadow);border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:2px;min-width:140px}
.hv-stat .lbl{font-size:10.5px;letter-spacing:.08em;color:var(--gray-500);text-transform:uppercase}
.hv-stat .val{font-size:22px;color:var(--ink);font-weight:500;letter-spacing:-0.02em;line-height:1}
.hv-stat .delta{font-size:11.5px;color:var(--good);font-weight:500;display:inline-flex;align-items:center;gap:4px;margin-top:2px}
.hv-stat .delta::before{content:"▲";font-size:8px}
.hv-stat-1{top:30%;left:24px}
.hv-stat-2{bottom:24px;right:24px}

/* PROOF */
.proof{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);background:var(--canvas);padding:28px 0}
.proof-row{display:flex;align-items:center;gap:42px;flex-wrap:wrap;justify-content:space-between}
.proof-label{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-500);font-weight:500;flex-shrink:0}
.proof-items{display:flex;gap:36px;flex-wrap:wrap;align-items:center}
.proof-item{font-size:13.5px;color:var(--gray-700);font-weight:500;letter-spacing:.01em;display:flex;align-items:center;gap:8px}
.proof-item svg{flex-shrink:0;color:var(--accent)}

/* DIFFERENT (comparison) */
.diff{background:var(--white)}
.diff-head{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:end;margin-bottom:56px}
@media(max-width:880px){.diff-head{grid-template-columns:1fr;gap:20px}}
.diff-head h2{max-width:520px}
.diff-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.diff-head p{color:var(--gray-700);max-width:480px;font-size:16px;line-height:1.6}
.diff-table{border:1px solid var(--hairline);border-radius:var(--radius-lg);overflow:hidden;background:var(--canvas)}
.diff-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--hairline);transition:background .25s var(--easing)}
.diff-row:last-child{border-bottom:0}
.diff-row.head{background:var(--ink);color:var(--white)}
.diff-row.head .cell{color:var(--white)}
.diff-row.head .cell-bad{color:rgba(255,255,255,.55)}
.cell{padding:22px 28px;font-size:15px;line-height:1.45;display:flex;gap:14px;align-items:flex-start;color:var(--ink)}
.cell-bad{color:var(--gray-500);background:rgba(0,0,0,.015)}
.cell .ix{flex-shrink:0;margin-top:2px;width:16px;height:16px;border-radius:99px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}
.cell-bad .ix{background:rgba(154,160,171,.18);color:var(--gray-500)}
.cell-good .ix{background:var(--good-soft);color:var(--good)}
.cell-good{font-weight:500;color:var(--ink)}
.cell-good .ix svg{width:9px;height:9px}
.diff-row:hover{background:var(--white)}
.diff-row.head:hover{background:var(--ink)}
@media(max-width:680px){
  .diff-row{grid-template-columns:1fr}
  .diff-row.head .cell:first-child{padding-bottom:6px}
  .diff-row.head .cell:last-child{padding-top:6px}
}

/* GEO */
.geo{background:var(--ink);color:#dde2ec;position:relative;overflow:hidden}
.geo::before{content:"";position:absolute;inset:0;background:radial-gradient(1000px 500px at 80% 0%, rgba(58,93,140,.18), transparent 60%),radial-gradient(800px 400px at 0% 100%, rgba(58,93,140,.10), transparent 50%);pointer-events:none}
.geo .eyebrow{color:rgba(221,226,236,.6)}
.geo .eyebrow::before{color:rgba(221,226,236,.4)}
.geo h2{color:var(--white)}
.geo-head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:64px;position:relative}
@media(max-width:880px){.geo-head{grid-template-columns:1fr;gap:24px}}
.geo-head h2{max-width:560px}
.geo-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:#9fb6d4}
.geo-head p{color:rgba(221,226,236,.72);max-width:440px;font-size:15.5px}
.geo-board{display:grid;grid-template-columns:1.45fr .9fr;gap:32px;position:relative}
@media(max-width:980px){.geo-board{grid-template-columns:1fr}}
.geo-map-wrap{position:relative;background:#091a35;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1.45/1}
.geo-map-wrap svg{width:100%;height:100%;display:block}
.geo-controls{position:absolute;top:18px;left:18px;display:flex;gap:6px;background:rgba(9,26,53,.6);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:99px;padding:4px}
.geo-controls button{font-size:11.5px;color:rgba(221,226,236,.7);padding:7px 13px;border-radius:99px;letter-spacing:.02em;transition:all .25s var(--easing)}
.geo-controls button.active{background:rgba(255,255,255,.10);color:var(--white)}
.geo-controls button:hover{color:var(--white)}
.geo-legend{position:absolute;bottom:18px;right:18px;background:rgba(9,26,53,.7);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:14px;font-size:11px;color:rgba(221,226,236,.7)}
.geo-legend .swatch{display:flex;gap:3px;align-items:center}
.geo-legend .swatch span{width:14px;height:6px;border-radius:2px}
.s1{background:#7a8aa3}.s2{background:#5b89c9}.s3{background:#3a82e6}.s4{background:#2dd4a4}
.geo-side{display:flex;flex-direction:column;gap:14px}
.geo-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:22px 22px 20px}
.geo-card .lbl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(221,226,236,.55);margin-bottom:10px}
.geo-card .big{font-family:"Inter";font-size:38px;color:var(--white);font-weight:500;letter-spacing:-0.025em;line-height:1}
.geo-card .big .from{color:rgba(221,226,236,.45);font-weight:400;font-size:20px;margin-right:6px}
.geo-card .arr{display:inline-block;color:#9fb6d4;margin:0 8px;font-weight:300}
.geo-card .delta{font-size:13px;color:#2dd4a4;margin-top:8px;display:flex;align-items:center;gap:6px}
.geo-card .delta::before{content:"▲";font-size:9px}
.geo-card .meta{font-size:13px;color:rgba(221,226,236,.6);margin-top:12px;line-height:1.5}

/* SYSTEM */
.system{background:var(--ink);color:#dde2ec;position:relative;overflow:hidden;border-top:1px solid rgba(255,255,255,.04)}
.system::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 110% 0%, rgba(58,93,140,.18), transparent 60%),radial-gradient(700px 400px at -10% 100%, rgba(58,93,140,.12), transparent 55%);pointer-events:none}
.system .eyebrow{color:rgba(221,226,236,.55)}
.system .eyebrow::before{color:rgba(221,226,236,.35)}
.system h2{color:var(--white)}
.system-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:64px;position:relative}
@media(max-width:880px){.system-head{grid-template-columns:1fr;gap:24px}}
.system-head h2{max-width:560px}
.system-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:#9fb6d4}
.system-head p{color:rgba(221,226,236,.72);max-width:460px;font-size:15.5px;line-height:1.6}
.layers{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;position:relative}
.layer{display:grid;grid-template-columns:80px 1fr 280px;gap:36px;align-items:center;padding:36px 0;border-top:1px solid rgba(255,255,255,.07);position:relative}
.layer:last-child{border-bottom:1px solid rgba(255,255,255,.07)}
@media(max-width:980px){.layer{grid-template-columns:60px 1fr;gap:20px}.layer-vis{grid-column:1 / -1;max-width:420px;margin-top:8px}}
.layer-num{font-family:"Inter";font-size:14px;color:rgba(221,226,236,.5);font-variant-numeric:tabular-nums;letter-spacing:.06em;align-self:flex-start;padding-top:6px}
.layer-body h3{font-size:clamp(22px,2.4vw,28px);color:var(--white);font-weight:500;letter-spacing:-0.02em;line-height:1.15;margin-bottom:14px}
.layer-body h3 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:#9fb6d4}
.layer-body p{color:rgba(221,226,236,.78);font-size:15.5px;line-height:1.6;max-width:580px;margin-bottom:14px}
.layer-body p em.serif{font-family:"Instrument Serif",serif;font-style:italic;color:#fff}
.layer-tag{font-size:11.5px;letter-spacing:.06em;color:rgba(159,182,212,.7);padding:4px 0 4px 12px;border-left:2px solid rgba(159,182,212,.3);display:inline-block;font-family:"Inter"}
.layer-vis{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:14px;aspect-ratio:1.4/1;display:flex;align-items:center;justify-content:center}
.layer-vis svg{width:100%;height:100%;display:block}
.system-foot{margin-top:48px;padding-top:32px;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.system-foot p{color:rgba(221,226,236,.72);max-width:620px;font-size:15px;line-height:1.6}
.system .btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.18)}
.system .btn-ghost:hover{background:var(--white);color:var(--ink);border-color:var(--white)}

/* SERVICES */
.services{background:var(--white)}
.services-head{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:end;margin-bottom:56px}
@media(max-width:880px){.services-head{grid-template-columns:1fr;gap:20px}}
.services-head h2{max-width:520px}
.services-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.services-head p{color:var(--gray-700);max-width:460px;font-size:16px}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--radius-lg);overflow:hidden}
@media(max-width:780px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--white);padding:40px 36px;display:flex;flex-direction:column;gap:18px;position:relative;transition:background .35s var(--easing);min-height:340px}
.svc:hover{background:var(--canvas)}
.svc-num{font-size:11px;letter-spacing:.18em;color:var(--gray-400);font-variant-numeric:tabular-nums}
.svc h3{font-size:24px;color:var(--ink);font-weight:500;letter-spacing:-0.018em;line-height:1.1}
.svc h3 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.svc-desc{font-size:15px;color:var(--gray-700);line-height:1.55;max-width:420px}
.svc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.svc-list li{font-size:13.5px;color:var(--gray-700);display:flex;gap:10px;align-items:flex-start;line-height:1.45}
.svc-list li::before{content:"";width:14px;height:1px;background:var(--gray-400);flex-shrink:0;margin-top:9px;transition:width .3s var(--easing), background .3s var(--easing)}
.svc:hover .svc-list li::before{background:var(--ink);width:20px}
.svc-foot{margin-top:auto;padding-top:18px;border-top:1px solid var(--hairline);display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--gray-700)}
.svc-foot .lk{display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-weight:500;transition:gap .25s var(--easing)}
.svc:hover .svc-foot .lk{gap:10px}

/* SERVICE DETAIL (services.html) */
.svc-detail{padding:clamp(56px,8vw,100px) 0;border-bottom:1px solid var(--hairline)}
.svc-detail:last-child{border-bottom:0}
.svc-detail.dark{background:var(--ink);color:#dde2ec;border-bottom-color:rgba(255,255,255,.06)}
.svc-detail.dark .eyebrow{color:rgba(221,226,236,.55)}
.svc-detail.dark .eyebrow::before{color:rgba(221,226,236,.35)}
.svc-detail.dark h2,.svc-detail.dark h3,.svc-detail.dark h4{color:var(--white)}
.svc-detail.dark p,.svc-detail.dark li{color:rgba(221,226,236,.78)}
.svc-detail.dark .svc-d-list li::before{background:rgba(255,255,255,.4)}
.svc-d-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
@media(max-width:980px){.svc-d-inner{grid-template-columns:1fr;gap:40px}}
.svc-d-head h2{font-size:clamp(32px,4.2vw,46px);letter-spacing:-0.025em;line-height:1.04;margin-top:16px;margin-bottom:18px}
.svc-d-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.svc-detail.dark .svc-d-head h2 .acc{color:#9fb6d4}
.svc-d-head p{font-size:16.5px;line-height:1.6;max-width:520px;margin-bottom:24px}
.svc-d-pricing{display:flex;gap:24px;padding:18px 22px;border:1px solid var(--hairline);border-radius:12px;background:var(--canvas);max-width:480px;align-items:center;flex-wrap:wrap}
.svc-detail.dark .svc-d-pricing{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
.svc-d-pricing .lbl{font-size:11px;letter-spacing:.12em;color:var(--gray-500);text-transform:uppercase}
.svc-detail.dark .svc-d-pricing .lbl{color:rgba(221,226,236,.55)}
.svc-d-pricing .val{font-size:18px;color:var(--ink);font-weight:500;letter-spacing:-0.01em}
.svc-detail.dark .svc-d-pricing .val{color:var(--white)}
.svc-d-body h4{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-500);margin-bottom:14px;font-weight:500}
.svc-detail.dark .svc-d-body h4{color:rgba(221,226,236,.55)}
.svc-d-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px}
.svc-d-list li{font-size:14.5px;line-height:1.5;color:var(--gray-700);display:flex;gap:12px;align-items:flex-start;padding-left:0}
.svc-d-list li::before{content:"";width:16px;height:1px;background:var(--gray-400);flex-shrink:0;margin-top:10px}
.svc-d-list li strong{color:var(--ink);font-weight:500}
.svc-detail.dark .svc-d-list li strong{color:var(--white)}

/* RESULTS */
.results{background:var(--canvas);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:880px){.results-grid{grid-template-columns:repeat(2,1fr)}}
.stat{display:flex;flex-direction:column;gap:6px;padding:12px 0}
.stat .num{font-size:clamp(40px,5vw,60px);color:var(--ink);font-weight:500;letter-spacing:-0.04em;line-height:1;font-variant-numeric:tabular-nums}
.stat .num .small{font-size:.55em;color:var(--gray-500);font-weight:400;letter-spacing:0;margin-left:4px}
.stat .lbl{font-size:13.5px;color:var(--gray-700);max-width:240px;line-height:1.45}
.stat .lbl strong{color:var(--ink);font-weight:500}
.results-foot{margin-top:48px;padding-top:32px;border-top:1px solid var(--hairline);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.results-foot p{color:var(--gray-700);font-size:14.5px;max-width:540px}

/* PROCESS */
.process{background:var(--white)}
.process-head{margin-bottom:56px;max-width:680px}
.process-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--hairline)}
@media(max-width:880px){.process-grid{grid-template-columns:1fr}}
.step{padding:36px 28px 36px 0;border-right:1px solid var(--hairline);position:relative}
.step:last-child{border-right:0}
@media(max-width:880px){.step{border-right:0;border-bottom:1px solid var(--hairline);padding:28px 0}.step:last-child{border-bottom:0}}
.step-num{font-size:13px;color:var(--gray-400);font-variant-numeric:tabular-nums;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.step-num::after{content:"";flex:1;height:1px;background:var(--hairline)}
.step h3{font-size:18px;color:var(--ink);font-weight:500;letter-spacing:-0.012em;margin-bottom:10px}
.step p{font-size:14px;color:var(--gray-700);line-height:1.55}

/* WHY */
.why{background:var(--canvas);border-top:1px solid var(--hairline)}
.why-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}
@media(max-width:880px){.why-grid{grid-template-columns:1fr;gap:36px}}
.why-grid h2{max-width:420px}
.why-grid h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.why-list{display:flex;flex-direction:column;gap:0}
.why-item{padding:28px 0;border-top:1px solid var(--hairline);display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start}
.why-item:last-child{border-bottom:1px solid var(--hairline)}
.why-num{font-size:13px;color:var(--gray-400);font-variant-numeric:tabular-nums;letter-spacing:.06em}
.why-item h4{font-size:18px;color:var(--ink);font-weight:500;letter-spacing:-0.012em;margin-bottom:8px}
.why-item p{font-size:14.5px;color:var(--gray-700);line-height:1.55;max-width:560px}
.why-item p em.serif{font-family:"Instrument Serif",serif;font-style:italic;color:var(--ink)}

/* REVIEWS */
.reviews{background:var(--white)}
.reviews-head{display:flex;justify-content:space-between;align-items:end;gap:40px;margin-bottom:48px;flex-wrap:wrap}
.reviews-head h2{max-width:480px}
.reviews-head h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.rating-card{display:flex;align-items:center;gap:18px;padding:18px 24px;border:1px solid var(--hairline);border-radius:14px;background:var(--canvas)}
.rating-card .stars{display:flex;gap:2px;color:#f5b400}
.rating-card .num{font-size:28px;color:var(--ink);font-weight:500;letter-spacing:-0.02em;line-height:1}
.rating-card .meta{font-size:12px;color:var(--gray-500);letter-spacing:.02em}
.rating-card .meta strong{color:var(--ink);font-weight:500}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:980px){.review-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.review-grid{grid-template-columns:1fr}}
.review{background:var(--white);border:1px solid var(--hairline);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:18px;transition:transform .35s var(--easing), box-shadow .35s var(--easing)}
.review:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.review .stars{color:#f5b400;display:flex;gap:1px;font-size:14px}
.review .quote{font-size:15.5px;color:var(--ink);line-height:1.55;font-weight:400}
.review .quote em{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--navy)}
.review .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.review .who-avatar{width:40px;height:40px;border-radius:99px;background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;letter-spacing:.02em}
.review .who-name{font-size:14px;color:var(--ink);font-weight:500;line-height:1.2}
.review .who-meta{font-size:12.5px;color:var(--gray-500);margin-top:2px}
.review .badge{font-size:10.5px;letter-spacing:.06em;color:var(--gray-500);display:flex;align-items:center;gap:6px;margin-top:2px}
.review .badge svg{flex-shrink:0}

/* CASE STUDIES (work.html) */
.cases{background:var(--white)}
.case{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center;padding:64px 0;border-top:1px solid var(--hairline)}
.case:last-child{border-bottom:1px solid var(--hairline)}
.case.flip{grid-template-columns:1.1fr 1fr}
.case.flip .case-visual{order:-1}
@media(max-width:880px){.case,.case.flip{grid-template-columns:1fr;gap:32px}.case.flip .case-visual{order:0}}
.case-tag{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gray-500);font-weight:500;margin-bottom:14px}
.case h3{font-size:clamp(24px,3vw,32px);letter-spacing:-0.02em;line-height:1.1;color:var(--ink);font-weight:500;margin-bottom:18px}
.case h3 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.case-desc{color:var(--gray-700);font-size:15.5px;line-height:1.6;margin-bottom:24px;max-width:540px}
.case-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:20px 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);margin-bottom:24px}
@media(max-width:600px){.case-metrics{grid-template-columns:repeat(2,1fr)}}
.case-metric .mnum{font-size:28px;color:var(--ink);font-weight:500;letter-spacing:-0.025em;line-height:1;font-variant-numeric:tabular-nums}
.case-metric .mnum .small{font-size:.55em;color:var(--gray-500);margin-left:2px}
.case-metric .mlbl{font-size:12px;color:var(--gray-500);margin-top:6px;line-height:1.3}
.case-tools{font-size:12.5px;color:var(--gray-500);letter-spacing:.04em}
.case-tools strong{color:var(--ink);font-weight:500}
.case-visual{background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:36px;aspect-ratio:1.2/1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.case-visual.dark{background:var(--ink);border-color:rgba(255,255,255,.06)}
.case-visual svg{width:100%;height:100%;display:block}

/* INDUSTRIES grid (work) */
.industries{background:var(--canvas);border-top:1px solid var(--hairline)}
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--radius-lg);overflow:hidden;margin-top:48px}
@media(max-width:880px){.ind-grid{grid-template-columns:repeat(2,1fr)}}
.ind{background:var(--white);padding:32px 28px;display:flex;flex-direction:column;gap:8px;transition:background .25s var(--easing)}
.ind:hover{background:var(--canvas)}
.ind .ind-num{font-size:11px;letter-spacing:.18em;color:var(--gray-400);font-variant-numeric:tabular-nums;margin-bottom:6px}
.ind h4{font-size:17px;color:var(--ink);font-weight:500;letter-spacing:-0.012em;line-height:1.2}
.ind p{font-size:13px;color:var(--gray-500);line-height:1.5;margin-top:4px}

/* ABOUT */
.about-story{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
@media(max-width:980px){.about-grid{grid-template-columns:1fr;gap:40px}}
.about-side h2{font-size:clamp(28px,3.6vw,40px);max-width:380px;letter-spacing:-0.025em}
.about-side h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.about-body{display:flex;flex-direction:column;gap:22px}
.about-body p{font-size:16.5px;line-height:1.65;color:var(--gray-700)}
.about-body p strong{color:var(--ink);font-weight:500}
.about-body p em.serif{font-family:"Instrument Serif",serif;font-style:italic;color:var(--ink)}

/* PRINCIPLES (about) */
.principles{background:var(--canvas);border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline)}
.prin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--radius-lg);overflow:hidden;margin-top:48px}
@media(max-width:880px){.prin-grid{grid-template-columns:1fr}}
.prin{background:var(--white);padding:36px 32px;display:flex;flex-direction:column;gap:14px}
.prin-num{font-size:11px;letter-spacing:.18em;color:var(--gray-400);font-variant-numeric:tabular-nums}
.prin h4{font-size:18px;color:var(--ink);font-weight:500;letter-spacing:-0.012em;line-height:1.2}
.prin p{font-size:14px;color:var(--gray-700);line-height:1.55}

/* CONTACT */
.contact-form{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-side h2{font-size:clamp(28px,3.6vw,40px);letter-spacing:-0.025em;margin-bottom:18px}
.contact-side h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:var(--accent)}
.contact-side p{font-size:15.5px;color:var(--gray-700);line-height:1.6;margin-bottom:18px;max-width:380px}
.contact-info{margin-top:24px;padding-top:24px;border-top:1px solid var(--hairline);display:flex;flex-direction:column;gap:14px}
.contact-info-row{display:flex;align-items:center;gap:14px;color:var(--gray-700);font-size:14px}
.contact-info-row svg{color:var(--accent);flex-shrink:0}
.contact-info-row a:hover{color:var(--ink)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:36px;background:var(--canvas);border:1px solid var(--hairline);border-radius:var(--radius-lg)}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1 / -1}
.field label{font-size:12px;letter-spacing:.06em;color:var(--gray-500);text-transform:uppercase;font-weight:500}
.field input,.field textarea,.field select{
  font:inherit;font-size:14.5px;color:var(--ink);
  background:var(--white);border:1px solid var(--hairline-strong);border-radius:8px;
  padding:11px 14px;line-height:1.4;
  transition:border-color .2s var(--easing), box-shadow .2s var(--easing);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--ink);box-shadow:0 0 0 4px rgba(10,18,40,.08)}
.field textarea{min-height:120px;resize:vertical;font-family:inherit}
.form-submit{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:6px}
.form-submit small{font-size:12px;color:var(--gray-500)}

/* CTA */
.cta{background:var(--ink);color:var(--white);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 460px at 85% -20%, rgba(58,93,140,.22), transparent 60%),radial-gradient(700px 360px at -10% 110%, rgba(58,93,140,.16), transparent 60%);pointer-events:none}
.cta-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:end}
@media(max-width:880px){.cta-inner{grid-template-columns:1fr;gap:32px}}
.cta h2{color:var(--white);font-size:clamp(34px,5.4vw,64px);font-weight:500;letter-spacing:-0.035em;line-height:1.02}
.cta h2 .acc{font-family:"Instrument Serif",serif;font-style:italic;font-weight:400;color:#9fb6d4}
.cta-side{display:flex;flex-direction:column;gap:20px;align-items:flex-start}
.cta-side p{color:rgba(221,226,236,.72);font-size:16px;max-width:380px}
.cta .btn-primary{background:var(--white);color:var(--ink)}
.cta .btn-primary:hover{background:#9fb6d4;color:var(--ink);transform:translateY(-1px)}
.cta .btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.18)}
.cta .btn-ghost:hover{background:var(--white);color:var(--ink);border-color:var(--white)}

/* FOOTER */
footer{background:var(--ink);color:rgba(221,226,236,.6);border-top:1px solid rgba(255,255,255,.06);padding:36px 0}
.foot-row{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;font-size:13px}
.foot-row a:hover{color:var(--white)}
.foot-links{display:flex;gap:24px;flex-wrap:wrap}

/* REVEAL */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s var(--easing), transform .8s var(--easing)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}

/* =========================================================
   ICON SYSTEM (v2)
   ========================================================= */
.ico{
  width:44px;height:44px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--canvas);border:1px solid var(--hairline);
  color:var(--ink);flex-shrink:0;
  transition:background .25s var(--easing), border-color .25s var(--easing), transform .25s var(--easing);
}
.ico svg{width:22px;height:22px;stroke-width:1.6;display:block}
.svc:hover .ico, .prin:hover .ico{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.svc:h