/* daysback — brand-matched, editorial execution.
   Vignelli, Discipline: one self-imposed scale. No ad-hoc spacing or type values
   past :root. Norman, Feedback: one motion timing for every interactive state. */
:root{
  /* colour */
  /* daysback brand-true: values taken from the real tailwind.config.ts / globals.css */
  --ink:#1b2d4c; --ink-2:#16233b;          /* real dark-navy (+ functional deeper shade for the footer seam) */
  --blue:#2560e8; --blue-deep:#1e4fc4;     /* real deep-blue for primary actions (+ darker press shade) */
  --indigo:#7a87f6;                        /* real brand-purple — the daysback signature accent */
  --amber:#ff934f; --amber-deep:#f2792f;   /* matches the real accent hsl(24 100% 65%) */
  --paper:#ffffff; --slate-50:#f1f5f9; --slate-100:#eaf0f8; /* real light-gray + faint divider tint */
  --border:#e3e8f0; --muted:#6b7689;       /* functional neutrals (no brand token exists for these) */

  /* frame */
  --maxw:1180px;
  --gutter:clamp(20px,5vw,64px);
  --r:14px;

  /* spacing scale — the only spacing values allowed */
  --s-0:.25rem; --s-1:.5rem; --s-2:.75rem; --s-3:1rem;
  --s-4:1.5rem; --s-5:2.5rem; --s-6:4rem; --s-7:6rem;

  /* responsive rhythm — section + grid cadence */
  --section-y:clamp(4rem,9vw,7rem);
  --section-y-tight:clamp(2.4rem,5vw,3.4rem);
  --block-gap:clamp(2rem,4vw,3rem);
  --flow:clamp(1.4rem,3vw,2.2rem);
  --flow-lg:clamp(2rem,5vw,4.5rem);

  /* type scale */
  --fs-xs:.8rem; --fs-overline:.86rem; --fs-sm:.92rem;
  --fs-body:1rem; --fs-md:1.1rem;
  --fs-lead:clamp(1.1rem,1.8vw,1.4rem);
  --fs-h3:clamp(1.18rem,1.5vw,1.35rem);
  --fs-h2:clamp(1.9rem,4vw,3rem);
  --fs-h1:clamp(2.4rem,6vw,4.6rem);
  --fs-num:clamp(2rem,5vw,3rem);
  --lh-tight:1.15; --lh-body:1.6;

  --motion:.18s ease;
  font-synthesis:none;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:Inter,system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:var(--lh-body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:var(--lh-tight);letter-spacing:-.03em;font-weight:800}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}

.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:var(--s-2) var(--s-3);z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:4px}

/* screen-reader only utility */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}

/* Norman — Affordance/Signifier: an in-text link must look like a link, not just a colour */
main p a,.work-note a,.handover-lede a,.statement-body a{
  text-decoration:underline;text-underline-offset:3px;
  text-decoration-thickness:1px;text-decoration-color:var(--border);
  transition:color var(--motion),text-decoration-color var(--motion);
}
main p a:hover,.work-note a:hover,.handover-lede a:hover,.statement-body a:hover{
  color:var(--blue);text-decoration-color:currentColor;
}
/* Norman — Feedback: links and nav acknowledge the press, not just the hover */
main p a:active,.work-note a:active,.text-link:active,.nav a:active,.site-footer a:active{opacity:.65}

/* active nav state */
.nav a[aria-current="page"]{color:var(--ink)}
.nav a[aria-current="page"]::after{width:100%}
.mobile-nav a[aria-current="page"]{color:var(--ink)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:var(--fs-sm);letter-spacing:-.01em;
  padding:var(--s-2) var(--s-4);border-radius:999px;cursor:pointer;
  transition:transform var(--motion),box-shadow var(--motion),background var(--motion);
  border:1.5px solid transparent;
}
.btn-lg{padding:var(--s-3) var(--s-5);font-size:var(--fs-body)}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--blue);transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(43,93,227,.7)}
.btn-ghost{border-color:var(--border);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
/* Norman — Feedback: every press gets a felt, immediate response */
.btn:active{transform:translateY(0);box-shadow:none;transition-duration:.05s}
.btn:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:999px}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease, background .25s ease;
}
.site-header.scrolled{border-color:var(--border);background:rgba(255,255,255,.92)}
.header-inner{display:flex;align-items:center;gap:var(--s-5);height:74px}
.wordmark{display:flex;align-items:center;gap:var(--s-1);font-weight:900;font-size:1.22rem;letter-spacing:-.04em}
.site-logo{height:26px;width:auto;display:block}
.site-logo--footer{height:30px}
.nav{display:flex;gap:var(--s-5);margin-left:auto;font-weight:600;font-size:var(--fs-sm)}
.nav a{color:var(--muted);position:relative;padding:var(--s-0) 0;transition:color var(--motion)}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--amber);transition:width .22s ease}
.nav a:hover{color:var(--ink)}
.nav a:hover::after{width:100%}
.nav-cta{margin-left:0}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;margin-left:auto;cursor:pointer}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:flex;flex-direction:column;gap:var(--s-1);padding:var(--s-3) var(--gutter) var(--s-4);border-bottom:1px solid var(--border);background:#fff}
.mobile-nav[hidden]{display:none}
.mobile-nav a{padding:var(--s-2) 0;font-weight:600;font-size:var(--fs-md);border-bottom:1px solid var(--slate-100)}
.mobile-nav .btn{margin-top:var(--s-2);border-bottom:0}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease;transition-delay:calc(var(--d,0)*90ms)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- hero (legacy) ---------- */
.hero{padding:var(--section-y) 0;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:var(--flow-lg);align-items:center}
.kicker{display:flex;align-items:center;gap:var(--s-2);font-size:var(--fs-overline);font-weight:600;letter-spacing:0;text-transform:none;color:var(--muted);margin-bottom:var(--s-3)}
.kicker::before{content:"";width:26px;height:1px;background:var(--border);display:inline-block;flex:none}
.kicker--accent{color:var(--amber-deep)}
h1{font-size:var(--fs-h1);font-weight:900;letter-spacing:-.045em}
h1 .ink{position:relative;white-space:nowrap}
h1 .ink::after{content:"";position:absolute;left:-.04em;right:-.04em;bottom:.08em;height:.16em;background:var(--amber);opacity:.55;z-index:-1;border-radius:2px}
.hero-sub{font-size:var(--fs-lead);color:var(--muted);max-width:34ch;margin:var(--s-5) 0;line-height:1.55}
.hero-sub strong{color:var(--ink);font-weight:700}
.hero-actions{display:flex;gap:var(--s-3);flex-wrap:wrap}
.hero-foot{margin-top:var(--s-4);font-size:var(--fs-sm);color:var(--muted)}

/* ledger device */
.ledger{
  background:var(--ink);color:#fff;border-radius:var(--r);
  padding:var(--s-5);box-shadow:0 30px 60px -28px rgba(20,34,61,.55);
  position:relative;overflow:hidden;
}
.ledger::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(43,93,227,.28),transparent 55%);pointer-events:none}
.ledger-head{display:flex;align-items:center;gap:var(--s-1);font-size:var(--fs-xs);font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#aab6cf}
.ledger-dot{width:9px;height:9px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(255,147,79,.22)}
.ledger-figure{display:flex;flex-direction:column;margin:var(--s-4) 0}
.ledger-num{font-size:var(--fs-num);font-weight:900;letter-spacing:-.04em;font-variant-numeric:tabular-nums;line-height:1}
.ledger-unit{font-size:var(--fs-sm);color:#aab6cf;margin-top:var(--s-1);font-weight:500}
.ledger-rows{list-style:none;border-top:1px solid rgba(255,255,255,.13)}
.ledger-rows li{display:flex;justify-content:space-between;padding:var(--s-2) 0;border-bottom:1px solid rgba(255,255,255,.09);font-size:var(--fs-sm)}
.ledger-rows li span:first-child{color:#dde3ef}
.ledger-rows li span:last-child{color:var(--amber);font-weight:600}

/* pending tags */
[data-pending]{
  color:var(--amber-deep);background:rgba(255,147,79,.12);
  border:1px dashed rgba(242,121,47,.5);border-radius:6px;
  padding:.05em .45em;font-style:normal;font-weight:600;
}
.ledger [data-pending]{color:var(--amber);background:rgba(255,147,79,.14);border-color:rgba(255,147,79,.4)}
.pending-note{margin-top:var(--s-3);font-size:var(--fs-xs);color:var(--muted);font-style:italic}
.pending-note.center{text-align:center}

/* ---------- proof ---------- */
.proof{background:var(--ink);color:#fff;padding:var(--section-y-tight) 0}
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--flow)}
.proof-item{display:flex;flex-direction:column;gap:var(--s-1)}
.proof-num{font-size:var(--fs-num);font-weight:900;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.proof-num[data-pending]{align-self:flex-start}
.proof-label{font-size:var(--fs-sm);color:#aab6cf;line-height:1.4}
.proof-label em{font-style:normal;color:#7f8da8}

/* ---------- section heads ---------- */
section{padding:var(--section-y) 0}
.section-head{max-width:60ch;margin-bottom:var(--block-gap)}
.section-head h2{font-size:var(--fs-h2)}
.section-head--dark h2,.section-head--dark{color:#fff}
.manifesto-lead{color:#c2cbdd;font-size:var(--fs-md);margin-top:var(--s-3);max-width:50ch}

/* ---------- principles ---------- */
.believe{background:var(--slate-50)}
.principles{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--flow)}
.principle{position:relative}
.principle h3{font-size:var(--fs-h3);margin-bottom:var(--s-2)}
.principle p{color:var(--muted);font-size:var(--fs-body)}

/* ---------- manifesto ---------- */
.manifesto{background:var(--ink);position:relative;overflow:hidden}
.manifesto .wrap{position:relative}
.manifesto h2{font-size:var(--fs-h2)}
.manifesto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--flow)}
.m-card{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:var(--s-5);color:#fff}
.m-card h3{font-size:var(--fs-h3);margin-bottom:var(--s-1)}
.m-card p{color:#aab6cf;font-size:var(--fs-sm)}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--flow)}
.svc{border:1px solid var(--border);border-radius:var(--r);padding:var(--s-5);background:#fff;transition:transform var(--motion),box-shadow var(--motion),border-color var(--motion)}
.svc:hover{transform:translateY(-4px);box-shadow:0 22px 44px -26px rgba(20,34,61,.4);border-color:var(--indigo)}
.svc h3{font-size:var(--fs-h3);margin-bottom:var(--s-2)}
.svc p{font-size:var(--fs-body);color:var(--ink);margin-bottom:var(--s-2)}
.svc-pain{color:var(--muted)!important;font-style:italic}
.svc-gain{font-weight:700;color:var(--blue)!important;margin-bottom:0!important}
.svc-anchor{margin-top:var(--s-5);font-size:var(--fs-body);color:var(--muted);max-width:62ch}
.svc-anchor strong{color:var(--ink)}

/* ---------- work / case ---------- */
.case{border:1px solid var(--border);border-left:5px solid var(--amber);border-radius:var(--r);padding:var(--s-6);background:var(--slate-50)}
.case-meta{display:flex;gap:var(--s-2);flex-wrap:wrap;margin-bottom:var(--s-3);font-size:var(--fs-xs);font-weight:600}
.case-title{font-size:var(--fs-h2);line-height:var(--lh-tight);max-width:24ch}
.case-body{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--flow);margin-top:var(--s-5)}
.case-body h4{font-size:var(--fs-xs);letter-spacing:.13em;text-transform:uppercase;color:var(--blue);margin-bottom:var(--s-1)}
.case-body p{font-size:var(--fs-sm);color:var(--ink)}

/* ---------- quote ---------- */
.quote-sec{background:var(--slate-50)}
.quote{max-width:42ch;margin:0 auto;text-align:center}
.quote>p{font-size:var(--fs-h2);font-weight:700;letter-spacing:-.03em;line-height:1.25}
.quote footer{margin-top:var(--s-4);display:flex;flex-direction:column;gap:var(--s-0)}
.quote-name{font-weight:700}
.quote-role{color:var(--muted);font-size:var(--fs-sm)}

/* ---------- how ---------- */
.steps{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--flow);counter-reset:s}
.step{position:relative;padding-top:var(--s-3)}
.step-no{font-size:var(--fs-sm);font-weight:800;color:var(--amber-deep);letter-spacing:.1em}
.step h3{font-size:var(--fs-h3);margin:var(--s-1) 0 var(--s-2)}
.step p{color:var(--muted)}
.step::before{content:"";position:absolute;top:1.55rem;left:2.6rem;right:-1.2rem;height:1.5px;background:repeating-linear-gradient(90deg,var(--border) 0 6px,transparent 6px 12px)}
.step:last-child::before{display:none}

/* ---------- cta ---------- */
.cta{background:var(--ink);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-inner{position:relative;max-width:46ch;margin-inline:auto}
.cta h2{font-size:var(--fs-h2)}
.cta p{color:#c2cbdd;margin:var(--s-4) 0 var(--s-5);font-size:var(--fs-md)}
.cta .btn-primary{background:var(--amber);color:var(--ink)}
.cta .btn-primary:hover{background:#fff;box-shadow:0 14px 30px -12px rgba(255,147,79,.6)}
.cta-foot{color:#8b97b0!important;font-size:var(--fs-sm)!important;margin:var(--s-4) 0 0!important}

/* ---------- footer ---------- */
.site-footer{background:var(--ink-2);color:#cdd5e4;padding:var(--section-y-tight) 0 var(--s-5)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:var(--s-5);padding-bottom:var(--s-5);border-bottom:1px solid rgba(255,255,255,.1)}
.wordmark--footer{color:#fff;font-size:var(--fs-md)}
.footer-tag{color:#8b97b0;margin-top:var(--s-1);font-size:var(--fs-sm)}
.site-footer h4{font-size:var(--fs-xs);letter-spacing:.14em;text-transform:uppercase;color:#8b97b0;margin-bottom:var(--s-3);font-weight:700}
.site-footer nav{display:flex;flex-direction:column;gap:var(--s-1)}
.site-footer a:hover{color:#fff}
.footer-base{display:flex;justify-content:space-between;gap:var(--s-3);flex-wrap:wrap;padding-top:var(--s-4);font-size:var(--fs-sm);color:#7f8da8}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .nav,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:var(--s-6)}
  .hero-sub{max-width:48ch}
  .proof-grid,.principles,.manifesto-grid,.svc-grid,.case-body,.steps,.footer-grid{grid-template-columns:1fr}
  .step::before{display:none}
  .footer-grid{gap:var(--s-5)}
}
@media (min-width:921px){.mobile-nav{display:none!important}}
@media (max-width:560px){
  .header-inner{height:64px}
}

/* ===== de-slopped home: editorial, ruled, asymmetric ===== */
.eyebrow{display:flex;align-items:center;gap:var(--s-2);font-size:var(--fs-overline);font-weight:600;color:var(--muted);margin-bottom:var(--s-3)}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--border);flex:none}
.eyebrow--warn{color:var(--amber-deep)}
.eyebrow--warn::before{background:var(--amber)}
.eyebrow--onDark{color:#9fb0cc}
.eyebrow--onDark::before{background:rgba(255,255,255,.3)}

.hero2{padding:var(--section-y) 0;border-bottom:1px solid var(--border)}
.hero2 h1{font-size:var(--fs-h1);font-weight:900;letter-spacing:-.045em;max-width:20ch;line-height:1.04}
.lede{font-size:var(--fs-lead);color:var(--muted);max-width:52ch;margin:var(--s-5) 0;line-height:1.55}
.hero2 .hero-actions{display:flex;align-items:center;gap:var(--s-4);flex-wrap:wrap}
.text-link{font-weight:600;color:var(--ink);border-bottom:1.5px solid var(--amber);padding-bottom:1px}
.text-link:hover{color:var(--blue)}
.hero-note{margin-top:var(--s-4);font-size:var(--fs-sm);color:var(--muted);max-width:48ch}

.statement{padding:var(--section-y) 0}
.statement-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:var(--flow-lg);align-items:start}
.statement-grid h2{font-size:var(--fs-h2);letter-spacing:-.035em;max-width:14ch}
.statement-body p{color:var(--muted);font-size:var(--fs-md);line-height:var(--lh-body);max-width:48ch}
.statement-body p+p{margin-top:var(--s-3)}

.ruled{padding:var(--section-y) 0;border-top:1px solid var(--border)}
.ruled--tint{background:var(--slate-50)}
.block-head{margin-bottom:var(--block-gap);max-width:52ch}
.block-head h2{font-size:var(--fs-h2);letter-spacing:-.03em}

.rows{list-style:none}
.row{display:grid;grid-template-columns:minmax(0,15rem) 1fr;gap:var(--flow);padding:var(--s-5) 0;border-top:1px solid var(--border)}
.row:last-child{border-bottom:1px solid var(--border)}
.row-label{font-size:var(--fs-h3);font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.row-body{color:var(--muted);font-size:var(--fs-body);line-height:var(--lh-body);max-width:58ch}
.row-body p+p{margin-top:var(--s-3)}
.row-body strong{color:var(--ink)}

.against{padding:var(--section-y) 0;border-top:1px solid var(--border)}
.against-lede{font-size:var(--fs-md);color:var(--ink);max-width:56ch;margin-bottom:var(--s-5);line-height:1.55}
.against-list{list-style:none;display:grid;gap:var(--s-4);max-width:64ch}
.against-list li{padding-left:var(--s-4);border-left:2px solid var(--amber);color:var(--muted);line-height:var(--lh-body)}
.against-list strong{display:block;color:var(--ink);font-weight:800;margin-bottom:var(--s-0)}

.handover{background:var(--ink);color:#fff;padding:var(--section-y) 0}
.handover .block-head h2{color:#fff}
.handover-lede{color:#aab6cf;font-size:var(--fs-md);margin-bottom:var(--s-5)}
.handover-list{list-style:none;display:grid;gap:var(--s-3);max-width:62ch}
.handover-list li{position:relative;padding-left:var(--s-5);color:#dde3ef;font-size:var(--fs-md);line-height:1.5}
.handover-list li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--amber);font-weight:800}

.work-note{font-size:var(--fs-md);color:var(--muted);max-width:62ch;line-height:1.65}

.cta2{background:var(--ink);color:#fff;padding:var(--section-y) 0}
.cta2 h2{font-size:var(--fs-h2);letter-spacing:-.035em;max-width:20ch}
.cta2 p{color:#c2cbdd;font-size:var(--fs-md);margin:var(--s-4) 0 var(--s-5);max-width:52ch}
.btn-cta{background:var(--amber);color:var(--ink)}
.btn-cta:hover{background:#fff;transform:translateY(-2px)}
.cta2 .cta-foot{color:#8b97b0;font-size:var(--fs-sm);margin-top:var(--s-4)}
.cta2 .hero-actions{align-items:center}
.cta2 .text-link{color:#fff;border-bottom-color:var(--amber)}
.cta2 .text-link:hover{color:var(--amber)}

@media (max-width:820px){
  .statement-grid{grid-template-columns:1fr;gap:var(--s-4)}
  .statement-grid h2{max-width:none}
  .row{grid-template-columns:1fr;gap:var(--s-1);padding:var(--s-4) 0}
}

/* ---------- blog ---------- */
.post{padding:var(--section-y) 0}
.post-wrap{max-width:46rem}
.post-back{display:inline-block;font-weight:600;color:var(--muted);margin-bottom:var(--s-5);transition:color var(--motion)}
.post-back:hover{color:var(--ink)}
.post-title{font-size:var(--fs-h1);letter-spacing:-.045em;line-height:1.05;margin-top:var(--s-2)}
.post-sub{font-size:var(--fs-lead);color:var(--muted);margin-top:var(--s-3)}
.post-meta{font-size:var(--fs-sm);color:var(--muted);margin-top:var(--s-3)}
.post-banner{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r);margin:var(--s-5) 0 var(--s-6);background:var(--slate-50)}
.post-body p{font-size:var(--fs-md);line-height:1.7;color:var(--ink);margin-bottom:var(--s-4);max-width:42rem}
.post-body h2{font-size:var(--fs-h2);letter-spacing:-.03em;margin:var(--s-6) 0 var(--s-3)}
.post-body strong{font-weight:700}
.ios{background:var(--ink);color:#fff;border-radius:var(--r);padding:var(--s-5);margin:0 0 var(--s-6)}
.ios-label{font-size:var(--fs-xs);font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--amber);margin-bottom:var(--s-2)}
.ios p:last-child{font-size:var(--fs-md);line-height:1.6;color:#dde3ef}
.post-cta{margin-top:var(--s-7);padding-top:var(--s-5);border-top:1px solid var(--border)}
.post-cta p{font-size:var(--fs-md);color:var(--ink);margin-bottom:var(--s-3)}
.blog-list{padding:var(--section-y) 0}
.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--flow)}
.post-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;background:#fff;transition:transform var(--motion),box-shadow var(--motion),border-color var(--motion)}
.post-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px -26px rgba(20,34,61,.4);border-color:var(--indigo)}
.post-card-img{display:block;aspect-ratio:16/9;background:var(--slate-50);overflow:hidden}
.post-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.post-card-body{display:flex;flex-direction:column;gap:var(--s-2);padding:var(--s-4) var(--s-4) var(--s-5)}
.post-card-meta{font-size:var(--fs-xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--blue)}
.post-card-title{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1.2}
.post-card-excerpt{font-size:var(--fs-sm);color:var(--muted);line-height:1.55}
@media (max-width:820px){.post-grid{grid-template-columns:1fr}}
