/* =============================================================================
   DAZTIFY  -  shared stylesheet
   The clean Daztify design system (formerly the Davonex template), extended
   with the components the agency pages need. Loaded by every page.
   Edit the tokens in :root to retheme the whole site.
   ============================================================================= */

:root{
  --bg:#FAFBFE;
  --bg-alt:#EFF4FD;
  --paper:#FFFFFF;
  --ink:#08152B;
  --ink-soft:#46597A;
  --blue:#136BEE;
  --blue-deep:#0C4497;
  --navy:#062757;
  --tint:#A9C9F8;
  --line:rgba(6,39,87,.12);
  --line-strong:rgba(6,39,87,.22);
  --bad:#C0362C;
  --good:#15803D;
  --shadow-sm:0 1px 2px rgba(8,21,43,.06), 0 6px 18px rgba(8,21,43,.05);
  --shadow-md:0 10px 30px rgba(12,68,151,.12), 0 2px 8px rgba(8,21,43,.06);
  --shadow-blue:0 18px 40px rgba(19,107,238,.28);
  --r-sm:10px; --r-md:16px; --r-lg:26px;
  --display:'Space Grotesk', sans-serif;
  --body:'Space Grotesk', sans-serif;
  --mono:'Space Grotesk', sans-serif;
  --maxw:1180px;
}

/* ============================ BASE ============================ */
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body); color:var(--ink); background:var(--bg);
  line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; position:relative;
}
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(900px 600px at 88% -8%, rgba(19,107,238,.14), transparent 60%),
    radial-gradient(700px 520px at -6% 12%, rgba(169,201,248,.20), transparent 55%),
    var(--bg);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.5;
  background-image:repeating-linear-gradient(-22deg, rgba(6,39,87,.035) 0 1px, transparent 1px 38px);
  mask-image:linear-gradient(180deg, rgba(0,0,0,.9), rgba(0,0,0,.15) 60%, transparent);
}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
section[id]{scroll-margin-top:96px}

.eyebrow{
  font-family:var(--mono); font-size:13.5px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--blue); font-weight:700; display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{content:""; width:26px; height:2px; background:var(--blue); display:inline-block}

h1,h2,h3{font-family:var(--display); font-weight:700; line-height:1.04; letter-spacing:-.02em; color:var(--navy)}
h1{font-size:clamp(2.4rem,6vw,4.6rem)}
h2{font-size:clamp(1.9rem,4.2vw,3.1rem)}
h3{font-size:1.16rem; letter-spacing:-.01em; line-height:1.15}
p{color:var(--ink-soft)}
.hl{position:relative; white-space:nowrap}
.hl::after{content:""; position:absolute; left:-2px; right:-2px; bottom:.05em; height:.28em; background:linear-gradient(90deg, rgba(19,107,238,.30), rgba(169,201,248,.55)); z-index:-1; border-radius:3px}

/* ============================ BUTTONS ============================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-family:var(--body); font-weight:700; font-size:1rem; line-height:1;
  padding:15px 26px; border-radius:999px; cursor:pointer; border:1.5px solid transparent;
  background:none; color:inherit; -webkit-appearance:none; appearance:none;
  transition:transform .22s cubic-bezier(.2,.8,.2,1), box-shadow .22s, background .22s, color .22s, border-color .22s;
  white-space:nowrap; min-height:48px;
}
.btn .arr{transition:transform .25s cubic-bezier(.2,.8,.2,1)}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--blue); color:#fff; box-shadow:var(--shadow-blue)}
.btn-primary:hover{transform:translateY(-2px); background:#0f5fdd; box-shadow:0 22px 46px rgba(19,107,238,.36)}
.btn-ghost{background:transparent; color:var(--navy); border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--navy); transform:translateY(-2px); background:rgba(6,39,87,.04)}
.btn:focus-visible{outline:3px solid rgba(19,107,238,.5); outline-offset:3px}

/* ============================ HEADER / NAV ============================ */
header.nav{position:sticky; top:0; z-index:50; transition:background .3s, box-shadow .3s, border-color .3s; border-bottom:1px solid transparent}
header.nav.scrolled{background:rgba(250,251,254,.82); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-color:var(--line); box-shadow:0 1px 0 rgba(8,21,43,.03)}
.nav-inner{display:flex; align-items:center; justify-content:space-between; height:78px; gap:14px}
.brand{display:flex; align-items:center; gap:12px}
.brand-icon{width:38px; height:38px; flex:none; display:block; filter:drop-shadow(0 4px 10px rgba(19,107,238,.25))}
.brand-icon svg{width:100%; height:100%; display:block}
.brand-name{font-family:var(--display); font-weight:700; font-size:1.34rem; letter-spacing:-.025em; color:var(--navy); line-height:1}
.nav-links{display:flex; align-items:center; gap:26px}
.nav-links a.link{font-weight:600; font-size:.95rem; color:var(--ink-soft); transition:color .2s}
.nav-links a.link:hover{color:var(--navy)}
.nav-links a.link[aria-current="page"]{color:var(--navy)}
.nav-toggle{display:none; background:none; border:0; padding:8px; cursor:pointer; color:var(--navy)}
.nav-toggle svg{width:28px; height:28px; display:block}

/* ============================ SECTIONS ============================ */
section{padding:72px 0}
.lede{max-width:640px; margin-top:18px; font-size:1.1rem}

/* ============================ HERO ============================ */
.hero{padding:70px 0 26px; position:relative}
.hero .streaks{position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none}
.hero .streaks span{position:absolute; height:2px; border-radius:2px; background:linear-gradient(90deg, transparent, rgba(19,107,238,.55), transparent); transform:rotate(-22deg); opacity:.5}
.hero-grid{position:relative; z-index:1; max-width:880px; margin-left:auto; margin-right:auto; text-align:center}
.hero h1{margin:20px 0 0}
.hero .lead{font-size:clamp(1.08rem,1.6vw,1.28rem); max-width:620px; margin:24px auto 0; color:var(--ink-soft)}
.hero .lead b{color:var(--navy); font-weight:700}
.cta-row{display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; justify-content:center}
.proofs{display:flex; flex-wrap:wrap; gap:12px 26px; margin-top:30px; align-items:center; justify-content:center}
.proof{display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:500; color:var(--ink-soft)}
.proof svg{width:15px; height:15px; flex:none; color:var(--blue)}

/* hero stat chips (right-side cards on home) */
.hero-stats{display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:34px}
.hero-stat{background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:14px 22px; box-shadow:var(--shadow-sm); text-align:center}
.hero-stat b{display:block; font-family:var(--display); font-size:1.5rem; color:var(--navy)}
.hero-stat span{font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); font-weight:600}

/* ============================ WHAT WE DO ============================ */
.wwd-points{display:flex; flex-wrap:wrap; gap:16px 30px; margin-top:30px; justify-content:center}
.wwd-point{display:inline-flex; align-items:center; gap:13px; font-weight:600; color:var(--navy); font-size:1.02rem}
.wwd-point .ic{width:40px; height:40px; border-radius:11px; background:linear-gradient(135deg, var(--blue), var(--blue-deep)); display:grid; place-items:center; flex:none; box-shadow:0 6px 16px rgba(19,107,238,.25)}

/* ============================ CENTERING HELPERS ============================ */
section h2{text-align:center; margin-left:auto; margin-right:auto}
.lead, .lede{text-align:center; margin-left:auto; margin-right:auto}
.eyebrow.center{display:flex; justify-content:center}

/* ============================ PROBLEM / PAIN ============================ */
.problem{background:linear-gradient(180deg, transparent, var(--bg-alt) 40%, var(--bg-alt) 100%); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.pain-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:44px}
.pain{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:26px 24px; box-shadow:var(--shadow-sm); transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s, border-color .28s}
.pain:hover{transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.pain .ic{width:46px; height:46px; border-radius:12px; background:rgba(192,54,44,.10); color:var(--bad); display:grid; place-items:center; margin-bottom:16px}
.pain h3{margin-bottom:8px}
.pain p{font-size:.96rem}

/* ============================ GENERIC CARDS ============================ */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px}
.card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:30px 26px 28px; box-shadow:var(--shadow-sm); transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s, border-color .28s; position:relative; overflow:hidden}
.card::before{content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--blue); transition:width .35s ease}
.card:hover{transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.card:hover::before{width:100%}
.card .ic{width:46px; height:46px; border-radius:12px; background:linear-gradient(135deg, var(--blue), var(--blue-deep)); display:grid; place-items:center; margin-bottom:20px; box-shadow:0 8px 20px rgba(19,107,238,.3)}
.card h3{color:var(--navy)}
.card p{margin-top:12px; font-size:.98rem}
.card .tag{display:inline-block; margin-top:14px; font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue)}

/* ============================ STEPS ============================ */
.steps{margin-top:44px; display:grid; gap:0; border-top:1px solid var(--line)}
.step{display:grid; grid-template-columns:96px 1fr; gap:24px; padding:28px 6px; border-bottom:1px solid var(--line); align-items:start; transition:background .25s}
.step:hover{background:rgba(19,107,238,.035)}
.step .num{font-family:var(--mono); font-weight:700; font-size:1.5rem; color:var(--blue)}
.step .st-body h3{margin-bottom:6px}
.step .st-body p{font-size:1rem; max-width:600px}

/* ============================ NAVY BAND (timeline / stats) ============================ */
.speed{background:var(--navy); color:#fff; border-radius:var(--r-lg); padding:clamp(34px,5vw,58px); position:relative; overflow:hidden; box-shadow:var(--shadow-md)}
.speed::before{content:""; position:absolute; inset:0; opacity:.5; background-image:repeating-linear-gradient(-22deg, rgba(255,255,255,.06) 0 1px, transparent 1px 40px); pointer-events:none}
.speed h2{color:#fff; position:relative}
.speed .eyebrow{color:var(--tint)} .speed .eyebrow::before{background:var(--tint)}
.timeline{position:relative; z-index:1; display:grid; grid-template-columns:repeat(5,1fr); gap:20px; margin-top:40px}
.tl{position:relative; padding-top:30px}
.tl::before{content:""; position:absolute; top:6px; left:0; width:100%; height:2px; background:linear-gradient(90deg, var(--blue), rgba(169,201,248,.5))}
.tl::after{content:""; position:absolute; top:0; left:0; width:14px; height:14px; border-radius:50%; background:#fff; box-shadow:0 0 0 4px rgba(19,107,238,.45)}
.tl .when{font-family:var(--mono); font-weight:700; font-size:13px; letter-spacing:.04em; color:var(--tint); text-transform:uppercase}
.tl .what{font-family:var(--body); font-weight:500; font-size:1rem; color:#fff; margin-top:8px; line-height:1.4}

/* stat grid inside navy band */
.stat-grid{position:relative; z-index:1; display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:40px}
.stat{text-align:center}
.stat .big{font-family:var(--display); font-weight:700; font-size:clamp(2rem,4vw,3rem); color:#fff; line-height:1}
.stat .lbl{font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--tint); margin-top:10px; font-weight:700}

/* ============================ PROJECT CARDS ============================ */
.proj-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:46px}
.proj-card{display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s, border-color .28s}
.proj-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.proj-thumb{aspect-ratio:16/10; overflow:hidden; background:var(--bg-alt); border-bottom:1px solid var(--line)}
.proj-thumb img{width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.proj-card:hover .proj-thumb img{transform:scale(1.05)}
.proj-body{padding:24px 24px 26px; display:flex; flex-direction:column; flex:1}
.proj-cat{align-self:flex-start; font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); background:rgba(19,107,238,.08); padding:5px 11px; border-radius:999px; margin-bottom:14px}
.proj-card h3{font-size:1.25rem; color:var(--navy)}
.proj-card .tagline{margin-top:10px; font-size:.97rem; color:var(--ink-soft)}
.proj-tags{display:flex; flex-wrap:wrap; gap:7px; margin-top:16px}
.proj-tags span{font-size:11px; font-weight:600; color:var(--ink-soft); background:var(--bg-alt); border:1px solid var(--line); border-radius:999px; padding:4px 10px}
.proj-card .read-link{margin-top:auto; padding-top:18px; font-weight:700; font-size:.92rem; color:var(--blue); display:inline-flex; align-items:center; gap:.45em}
.proj-card .read-link .arr{transition:transform .25s cubic-bezier(.2,.8,.2,1)}
.proj-card:hover .read-link .arr{transform:translateX(4px)}

/* ============================ CASE STUDIES (before / after) ============================ */
.case-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px}
.case-card{display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--shadow-sm); padding:30px 28px; transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s, border-color .28s}
.case-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.case-client{font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); font-weight:700; margin-bottom:8px}
.case-headline{font-family:var(--display); font-weight:700; font-size:1.28rem; line-height:1.18; letter-spacing:-.01em; color:var(--navy); margin-bottom:20px}
.case-label{font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; display:inline-block; padding:4px 10px; border-radius:6px; color:#fff}
.case-label.before{background:var(--bad)}
.case-label.after{background:var(--good)}
.case-list{list-style:none; display:grid; gap:9px; margin:12px 0 18px}
.case-list li{display:flex; gap:10px; align-items:flex-start; font-size:.95rem; color:var(--ink-soft); line-height:1.4}
.case-list .mk{flex:none; width:19px; height:19px; border-radius:50%; display:grid; place-items:center; font-size:11px; font-weight:700; margin-top:1px}
.case-before .mk{background:rgba(192,54,44,.12); color:var(--bad)}
.case-after .mk{background:rgba(22,163,74,.14); color:var(--good)}
.case-when{font-family:var(--mono); font-size:12px; color:var(--ink-soft); letter-spacing:.04em; margin-top:auto; padding-top:6px}

/* ============================ TESTIMONIALS ============================ */
.quote-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:46px}
.quote{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--shadow-sm); padding:28px 26px; display:flex; flex-direction:column; transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s, border-color .28s}
.quote:hover{transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.quote .stars{display:flex; gap:3px; color:var(--blue); margin-bottom:14px}
.quote .stars svg{width:18px; height:18px}
.quote p{color:var(--ink); font-size:1.02rem; line-height:1.55; font-weight:500}
.quote .who{margin-top:18px; padding-top:16px; border-top:1px solid var(--line)}
.quote .who b{color:var(--navy); font-weight:700; display:block}
.quote .who span{font-size:.86rem; color:var(--ink-soft)}

/* ============================ SKILL BARS (about) ============================ */
.skill-group{margin-top:30px}
.skill-group h3{margin-bottom:18px; color:var(--navy)}
.skill-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.skill{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:20px 22px; box-shadow:var(--shadow-sm)}
.skill .row{display:flex; align-items:center; justify-content:space-between; margin-bottom:12px}
.skill .row b{font-family:var(--display); font-weight:700; color:var(--navy); font-size:1.05rem}
.skill .dots{display:flex; gap:5px}
.skill .dots i{width:9px; height:9px; border-radius:50%; background:var(--line-strong)}
.skill .dots i.on{background:var(--blue)}
.skill .bar{height:7px; border-radius:999px; background:var(--bg-alt); overflow:hidden}
.skill .bar span{display:block; height:100%; border-radius:999px; background:linear-gradient(90deg, var(--blue), var(--blue-deep))}

/* chips (tools / tech pills) */
.chips{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}
.chip{font-size:.92rem; font-weight:600; color:var(--navy); background:var(--paper); border:1px solid var(--line); border-radius:999px; padding:9px 18px; box-shadow:var(--shadow-sm); transition:transform .2s, border-color .2s}
.chip:hover{transform:translateY(-2px); border-color:rgba(19,107,238,.35)}

/* ============================ FEATURE TIMELINE (about - what we've built) ============================ */
.vtimeline{position:relative; max-width:760px; margin:46px auto 0; padding-left:34px}
.vtimeline::before{content:""; position:absolute; left:7px; top:6px; bottom:6px; width:2px; background:var(--line-strong)}
.vt{position:relative; margin-bottom:26px}
.vt::before{content:""; position:absolute; left:-34px; top:6px; width:16px; height:16px; border-radius:50%; background:var(--blue); box-shadow:0 0 0 4px rgba(19,107,238,.18)}
.vt .vt-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:22px 24px; box-shadow:var(--shadow-sm); transition:transform .28s, box-shadow .28s, border-color .28s}
.vt .vt-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.vt .yr{font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue)}
.vt h3{margin:8px 0 6px; color:var(--navy)}
.vt p{font-size:.96rem}

/* ============================ FAQ ============================ */
.faq-list{margin-top:42px; display:grid; gap:14px; max-width:880px; margin-left:auto; margin-right:auto}
.faq-item{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--shadow-sm); overflow:hidden; transition:border-color .25s, box-shadow .25s}
.faq-item[open]{border-color:rgba(19,107,238,.32); box-shadow:var(--shadow-md)}
.faq-q{list-style:none; cursor:pointer; padding:22px 24px; display:flex; align-items:center; justify-content:space-between; gap:18px; font-family:var(--display); font-weight:700; font-size:1.05rem; color:var(--navy); letter-spacing:-.01em}
.faq-q::-webkit-details-marker{display:none}
.faq-ic{flex:none; width:28px; height:28px; border-radius:50%; background:rgba(19,107,238,.1); color:var(--blue); display:grid; place-items:center; font-weight:700; font-size:1.2rem; line-height:1; transition:transform .3s cubic-bezier(.2,.8,.2,1), background .25s, color .25s}
.faq-item[open] .faq-ic{transform:rotate(45deg); background:var(--blue); color:#fff}
.faq-a{padding:0 24px 22px}
.faq-a p{font-size:1rem; max-width:760px}

/* ============================ GUARANTEE / CALLOUT ============================ */
.guarantee{margin:26px auto 0; max-width:880px; display:flex; align-items:flex-start; gap:18px; padding:24px 26px; border-radius:var(--r-md); background:linear-gradient(120deg, rgba(19,107,238,.10), rgba(169,201,248,.22)); border:1px solid rgba(19,107,238,.25)}
.guarantee .g-ic{flex:none; width:46px; height:46px; border-radius:12px; background:linear-gradient(135deg, var(--blue), var(--blue-deep)); display:grid; place-items:center; box-shadow:0 8px 20px rgba(19,107,238,.3)}
.guarantee .g-tx .g-eyebrow{font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); font-weight:700}
.guarantee .g-tx p{color:var(--navy); font-size:1.08rem; font-weight:500; margin-top:6px}

/* ============================ FINAL CTA ============================ */
.final{position:relative; overflow:hidden; text-align:center; background:linear-gradient(135deg, var(--blue) 0%, var(--blue-deep) 60%, var(--navy) 100%); border-radius:var(--r-lg); padding:clamp(46px,7vw,84px) 28px; box-shadow:var(--shadow-blue)}
.final::before{content:""; position:absolute; inset:0; opacity:.45; background-image:repeating-linear-gradient(-22deg, rgba(255,255,255,.08) 0 1px, transparent 1px 44px)}
.final h2{color:#fff; font-size:clamp(2.1rem,4.6vw,3.4rem); position:relative}
.final p{color:rgba(255,255,255,.86); font-size:1.16rem; margin:18px auto 0; max-width:560px; position:relative}
.final .cta-row{position:relative; margin-top:34px}
.final .btn-primary{background:#fff; color:var(--navy); box-shadow:0 18px 40px rgba(0,0,0,.22)}
.final .btn-primary:hover{background:#fff; transform:translateY(-2px); box-shadow:0 24px 50px rgba(0,0,0,.3)}
.final .btn-ghost{color:#fff; border-color:rgba(255,255,255,.45)}
.final .btn-ghost:hover{border-color:#fff; background:rgba(255,255,255,.08)}

/* ============================ CALENDAR ============================ */
.cal-wrap{max-width:980px; margin:0 auto}
.cal-head{text-align:center; margin-bottom:34px}
.cal-head .eyebrow{justify-content:center}
.cal-head h2{margin-top:16px}
.cal-head p{max-width:520px; margin:14px auto 0; font-size:1.1rem}
.cal-ph{position:absolute; inset:0; display:grid; place-items:center; text-align:center; padding:40px}
.cal-ph .inner{max-width:440px}
.cal-ph h3{color:var(--navy); margin-bottom:10px}
.cal-ph p{color:var(--ink-soft); margin-bottom:22px}
.cal-box{position:relative; width:100%; min-height:640px; max-height:min(720px,85vh); overflow:auto; border-radius:26px; border:1px solid var(--line); background:#fff}

/* ============================ CONTACT PAGE ============================ */
.contact-hero{text-align:center; padding:70px 0 14px; position:relative}
.contact-hero .eyebrow{justify-content:center}
.contact-hero h1{margin-top:18px}
.contact-hero .lead{margin:22px auto 0; max-width:520px; font-size:clamp(1.08rem,1.6vw,1.28rem); color:var(--ink-soft)}
.contact-grid{display:grid; grid-template-columns:1.55fr 1fr; gap:26px; align-items:start; margin-top:8px}
.contact-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--shadow-sm); padding:30px 28px}
.contact-card h3{margin-bottom:18px; color:var(--navy)}
.c-row{display:flex; flex-direction:column; gap:4px; padding:14px 0; border-bottom:1px solid var(--line)}
.c-row:first-of-type{padding-top:0}
.c-row .c-label{font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue)}
.c-row .c-val{font-weight:600; color:var(--navy); font-size:1.05rem; word-break:break-word}
.contact-card .btn{margin-top:22px; width:100%}

/* generic page hero (about, projects, etc.) */
.page-hero{text-align:center; padding:70px 0 10px; position:relative}
.page-hero .eyebrow{justify-content:center}
.page-hero h1{margin-top:18px}
.page-hero .lead{margin:22px auto 0; max-width:600px; font-size:clamp(1.06rem,1.5vw,1.24rem)}

/* about hero with brand mark */
.about-hero{display:flex; align-items:center; gap:40px; max-width:980px; margin:0 auto; flex-wrap:wrap; justify-content:center; text-align:center}
.about-hero .mark{flex:none; width:150px; height:150px; border-radius:24px; background:linear-gradient(150deg,#0b2a64,#06183a 70%); display:grid; place-items:center; box-shadow:var(--shadow-md); padding:26px}
.about-hero .mark svg{width:100%; height:100%}
.about-hero .at-body{flex:1; min-width:280px; text-align:center}
.about-hero .at-body h1{margin:14px 0 0}
@media (min-width:760px){
  .about-hero{text-align:left; flex-wrap:nowrap}
  .about-hero .at-body{text-align:left}
  .about-hero .at-body .eyebrow{justify-content:flex-start}
}
.stat-chips{display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; justify-content:center}
@media (min-width:760px){ .stat-chips{justify-content:flex-start} }
.stat-chip{background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:12px 18px; box-shadow:var(--shadow-sm); font-weight:700; color:var(--navy)}

/* ============================ CASE STUDY DETAIL ============================ */
.cs-hero{padding:36px 0 8px}
.back-link{display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:.92rem; color:var(--ink-soft); transition:color .2s}
.back-link:hover{color:var(--navy)}
.cs-meta{display:flex; flex-wrap:wrap; gap:10px; margin:22px 0 18px}
.cs-meta span{font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:6px 12px; border-radius:999px; background:rgba(19,107,238,.08); color:var(--blue)}
.cs-hero h1{font-size:clamp(2.2rem,5vw,3.8rem)}
.cs-hero .tagline{font-size:clamp(1.1rem,1.7vw,1.4rem); color:var(--ink-soft); margin-top:18px; max-width:720px}
.cs-note{margin-top:14px; font-size:.88rem; font-style:italic; color:var(--ink-soft); max-width:560px}

.cs-shots{display:grid; grid-template-columns:2fr 1fr; gap:26px; align-items:start; margin-top:10px}
.cs-shot{border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-md); background:#fff}
.cs-shot.mobile{max-width:260px; margin:0 auto}
.cs-shot-label{text-align:center; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-top:10px; font-weight:700}

.cs-gallery{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:30px}
.cs-gallery a{display:block; border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .28s, box-shadow .28s, border-color .28s}
.cs-gallery a:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.cs-gallery .ph{aspect-ratio:16/10; overflow:hidden; background:var(--bg-alt)}
.cs-gallery img{width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .4s}
.cs-gallery a:hover img{transform:scale(1.05)}

.cs-body{display:grid; grid-template-columns:300px 1fr; gap:36px; align-items:start}
.cs-side{position:sticky; top:96px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:26px 24px; box-shadow:var(--shadow-sm)}
.cs-side h3{margin-bottom:18px; color:var(--navy)}
.cs-info{display:grid; gap:16px}
.cs-info .k{font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft)}
.cs-info .v{font-weight:600; color:var(--navy)}
.cs-info .v a{color:var(--blue)}
.cs-stack{margin-top:22px}
.cs-stack h4{font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:12px}
.cs-stack .chips{margin-top:0}
.cs-stack .chip{font-size:.82rem; padding:6px 13px}

.cs-lead{font-size:1.16rem; color:var(--navy); font-weight:500; line-height:1.55; margin-bottom:30px}
.cs-block{border:1px solid var(--line); border-radius:var(--r-md); padding:26px 28px; margin-bottom:22px; background:var(--paper); box-shadow:var(--shadow-sm)}
.cs-block.tint{background:linear-gradient(120deg, rgba(19,107,238,.06), rgba(169,201,248,.14))}
.cs-block h3{color:var(--navy); margin-bottom:12px}
.cs-block p{font-size:1.02rem; line-height:1.6}
.cs-outcomes{display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:8px}
.cs-outcome{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:22px 22px; box-shadow:var(--shadow-sm)}
.cs-outcome .m{font-family:var(--display); font-weight:700; font-size:1.5rem; color:var(--blue); line-height:1.1}
.cs-outcome .d{font-size:.94rem; margin-top:8px}

.cs-stack-full{margin-top:8px; display:grid; gap:16px}
.cs-stack-row{display:grid; grid-template-columns:160px 1fr; gap:16px; align-items:start; padding-bottom:14px; border-bottom:1px solid var(--line)}
.cs-stack-row .cat{font-family:var(--mono); font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--navy); padding-top:4px}

/* ============================ STARTER / BLOG ============================ */
.blog-intro{text-align:center; max-width:780px; margin:0 auto; padding-top:8px}
.blog-intro .eyebrow{justify-content:center}
.blog-intro h1{font-size:clamp(2.2rem,5vw,3.7rem); margin-top:18px}
.blog-intro .intro-line{font-size:1.15rem; margin:22px auto 0; max-width:620px; color:var(--ink-soft)}
.post-tag{display:inline-block; font-family:var(--mono); font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); background:rgba(19,107,238,.08); padding:5px 11px; border-radius:999px}
.post-meta{font-family:var(--mono); font-size:12px; color:var(--ink-soft); letter-spacing:.02em; display:flex; gap:9px; align-items:center; flex-wrap:wrap}
.post-meta .dot{width:3px; height:3px; border-radius:50%; background:var(--ink-soft); opacity:.5}
.post-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:42px}
.post-card{display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line); border-radius:var(--r-md); padding:26px 24px; box-shadow:var(--shadow-sm); transition:transform .28s cubic-bezier(.2,.8,.2,1), box-shadow .28s, border-color .28s}
.post-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(19,107,238,.3)}
.post-card h3{margin:15px 0 0; color:var(--navy)}
.post-card .excerpt{margin-top:10px; font-size:.96rem; color:var(--ink-soft)}
.post-card .post-meta{margin-top:auto; padding-top:18px}
.notice{max-width:760px; margin:38px auto 0; text-align:center; background:var(--paper); border:1px dashed var(--line-strong); border-radius:var(--r-md); padding:26px 28px; color:var(--ink-soft)}
.notice b{color:var(--navy)}

/* ============================ FOOTER ============================ */
footer{padding:54px 0 46px; border-top:1px solid var(--line); margin-top:80px}
.foot-inner{display:flex; align-items:flex-start; justify-content:space-between; gap:30px; flex-wrap:wrap}
.foot-brand{display:flex; align-items:center; gap:11px; margin-bottom:12px}
.foot-brand .brand-icon{width:30px; height:30px}
.foot-brand .brand-name{font-size:1.2rem}
.foot-tag{color:var(--ink-soft); font-size:.95rem; max-width:340px}
.foot-right{display:flex; flex-direction:column; gap:10px; text-align:right}
.foot-nav{display:flex; gap:22px; flex-wrap:wrap; justify-content:flex-end}
.foot-nav a{font-weight:600; font-size:.92rem; color:var(--ink-soft); transition:color .2s}
.foot-nav a:hover{color:var(--navy)}
.foot-parent{font-size:.9rem; color:var(--ink-soft)}
.foot-copy{font-family:var(--mono); font-size:12px; color:var(--ink-soft); letter-spacing:.04em; margin-left:12px}

/* ============================ MOTION ============================ */
.js .reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1)}
.js .reveal.in{opacity:1; transform:none}
.stg{opacity:0; transform:translateY(22px); animation:rise .8s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes rise{to{opacity:1; transform:none}}
.d1{animation-delay:.05s}.d2{animation-delay:.16s}.d3{animation-delay:.28s}.d4{animation-delay:.4s}.d5{animation-delay:.52s}

/* ============================ RESPONSIVE ============================ */
@media (max-width:980px){
  .cards, .proj-grid, .case-grid, .quote-grid, .pain-grid, .skill-grid, .post-grid{grid-template-columns:1fr 1fr}
  .cs-body{grid-template-columns:1fr}
  .cs-side{position:static}
  .stat-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .timeline{grid-template-columns:1fr 1fr}
  .step{grid-template-columns:64px 1fr; gap:16px}
  .contact-grid{grid-template-columns:1fr}
  .cs-shots{grid-template-columns:1fr}
  .cs-gallery{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .nav-links{position:fixed; inset:78px 0 auto 0; flex-direction:column; align-items:stretch; gap:0; background:rgba(250,251,254,.98); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--line); box-shadow:var(--shadow-md); padding:8px 22px 22px; transform:translateY(-12px); opacity:0; pointer-events:none; transition:opacity .25s, transform .25s}
  .nav-links.open{opacity:1; transform:none; pointer-events:auto}
  .nav-links a.link{padding:14px 2px; font-size:1.02rem; border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:14px; width:100%}
  .nav-toggle{display:inline-flex; align-items:center}
  .cards, .proj-grid, .case-grid, .quote-grid, .pain-grid, .skill-grid, .post-grid, .cs-outcomes, .cs-gallery{grid-template-columns:1fr}
  .timeline, .stat-grid{grid-template-columns:1fr 1fr}
  .cs-stack-row{grid-template-columns:1fr; gap:6px}
  .cs-stack-row .cat{padding-top:0}
}
@media (max-width:560px){
  .nav-inner{height:66px}
  .nav-links{inset-block-start:66px}
  .brand-name{font-size:1.12rem}
  .foot-inner{flex-direction:column}
  .foot-right{text-align:left; align-items:flex-start}
  .foot-nav{justify-content:flex-start}
  .foot-copy{margin-left:0}
}
@media (max-width:400px){
  .wrap{padding:0 16px}
  .brand-name{font-size:1rem}
  .brand-icon{width:32px; height:32px}
  .timeline, .stat-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important}
  .reveal, .js .reveal{opacity:1; transform:none}
  .stg{opacity:1; transform:none}
  html{scroll-behavior:auto}
}
