/* ============================================================
   Data Druid Tech Services — design system v3
   Light · Bricolage Grotesque + Inter + Martian Mono
   Navy #1a2f5e · ink greys · baby-pink #e8b4b8 (sparing)
   Capabilities = system-map (data bus) · one dark band
   ============================================================ */

:root{
  --paper:#f6f6f4; --surface:#fff; --surface2:#fbfbf9;
  --ink:#16161c; --ink2:#54545f; --ink3:#6e6e7a; --ink4:#b6b6bd;
  --navy:#1a2f5e; --navy2:#28457f; --navy-soft:#eef1f7;
  --pink:#e8b4b8; --pink-ink:#b06d78; --pink-soft:#fbeef0;
  --line:#e7e7e2; --line2:#d8d8d1;
  --bg:var(--surface); /* defensive alias — some templates referenced var(--bg) */
  --dot:#b6b6bd;       /* truly-decorative grey (was --ink3) */

  /* dark surfaces (dark band · footer · code · hero field) */
  --dark:#14141b; --dark-2:#0e0e14; --dark-head:#f2f2ec;
  --dark-ink:#cfcfc8; --dark-ink2:#a6a6ad; --dark-line:#25252f;

  /* spacing scale */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-6:1.5rem; --space-8:2rem; --space-12:3rem;

  --r:12px; --r-sm:8px; --r-pill:999px;
  --maxw:1180px; --gutter:clamp(1.25rem,4vw,2.5rem);
  --ease:cubic-bezier(.22,1,.36,1);
  --disp:"Bricolage Grotesque", system-ui, sans-serif;
  --body:"Inter", system-ui, -apple-system, sans-serif;
  --mono:"Martian Mono", ui-monospace, "SFMono-Regular", monospace;

  --sh-sm:0 1px 2px rgb(22 22 28/.04), 0 4px 14px rgb(22 22 28/.05);
  --sh-md:0 2px 6px rgb(22 22 28/.05), 0 16px 40px rgb(22 22 28/.07);
}
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{ margin:0; background:var(--paper); color:var(--ink2); font-family:var(--body);
  font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
::selection{ background:var(--navy); color:#fff; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
section{ position:relative; padding-block:clamp(3.5rem,8vw,7rem); }
.section-tight{ padding-block:clamp(2.5rem,5vw,4.5rem); }
.section-soft{ background:var(--surface); border-block:1px solid var(--line); }

/* ---------- type ---------- */
h1,h2,h3,h4{ font-family:var(--disp); color:var(--ink); font-weight:700; letter-spacing:-.03em; line-height:1.08; margin:0; text-wrap:balance; }
h1{ font-size:clamp(2.6rem,6.2vw,4.6rem); }
h2{ font-size:clamp(2rem,4.6vw,3.3rem); }
h3{ font-size:1.3rem; letter-spacing:-.02em; }
p{ margin:0 0 1rem; }
.lead{ font-size:clamp(1.05rem,.95rem+.6vw,1.3rem); color:var(--ink2); line-height:1.55; max-width:60ch; }
.muted{ color:var(--ink2); }
.dim{ color:var(--ink3); }
.tiny{ font-size:.8rem; }
em.it{ font-style:italic; color:var(--navy); }

/* monospace section marker (replaces pink-dash eyebrow; varies per section via content) */
.micro{ font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--pink-ink); display:inline-flex; align-items:center; gap:.5rem; }
.micro b{ color:var(--ink3); font-weight:500; }
.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-family:var(--body); font-weight:600; font-size:.95rem;
  min-height:2.75rem; padding:.8rem 1.4rem; border-radius:var(--r-sm); border:1px solid transparent; cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .2s, border-color .2s; }
.btn:hover{ transform:translateY(-2px); }

/* ---------- accessibility: visible keyboard focus everywhere ---------- */
:focus-visible{ outline:2px solid var(--navy); outline-offset:3px; border-radius:3px; }
a:focus-visible,.btn:focus-visible,button:focus-visible,summary:focus-visible{ outline:2px solid var(--navy); outline-offset:3px; }
.btn-primary{ background:var(--navy); color:#fff; box-shadow:0 6px 16px rgb(26 47 94/.18); }
.btn-primary:hover{ background:var(--navy2); box-shadow:0 12px 26px rgb(26 47 94/.26); }
.btn-pink{ background:var(--pink); color:#3a2a2c; }
.btn-pink:hover{ background:#e0a3a8; }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line2); }
.btn-ghost:hover{ border-color:var(--navy); background:var(--surface); }
.btn .ico{ transition:transform .25s var(--ease); }
.btn:hover .ico{ transform:translateX(3px); }

/* chips / badges */
.chip{ font-family:var(--mono); font-size:10.5px; letter-spacing:.03em; color:var(--ink2); border:1px solid var(--line2); border-radius:3px; padding:3px 7px; }
.badge{ font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; padding:4px 9px; border-radius:3px; color:var(--navy); background:var(--navy-soft); }
.badge.product{ color:var(--pink-ink); background:var(--pink-soft); }

.material-symbols-outlined{ font-variation-settings:'FILL' 0,'wght' 300,'GRAD' 0,'opsz' 24; line-height:1; vertical-align:middle; user-select:none; font-size:1.4rem; }
.msi-sm{ font-size:1.1rem; } .msi-lg{ font-size:1.7rem; }

/* ---------- nav ---------- */
.nav{ position:sticky; top:0; z-index:50; background:rgba(246,246,244,.82); backdrop-filter:saturate(160%) blur(12px); border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s; }
.nav.scrolled{ border-bottom-color:var(--line); box-shadow:var(--sh-sm); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:4.5rem; }
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand img{ height:26px; width:auto; }
.brand span{ font-family:var(--disp); font-weight:700; font-size:1.15rem; letter-spacing:-.02em; color:var(--ink); }
.nav-links{ display:flex; align-items:center; gap:1.8rem; }
.nav-links a.lnk{ font-family:var(--mono); font-size:12.5px; letter-spacing:.02em; color:var(--ink2); transition:color .2s; }
.nav-links a.lnk:hover, .nav-links a.lnk.active{ color:var(--navy); }
.nav-toggle{ display:none; background:none; border:0; color:var(--ink); cursor:pointer; padding:.4rem; }
@media (max-width:920px){
  .nav-links{ display:none; }
  .nav-toggle{ display:grid; place-items:center; }
  .nav-links.open{ display:flex; flex-direction:column; align-items:flex-start; gap:1.1rem; position:absolute; top:4.5rem; inset-inline:0; background:var(--paper); padding:1.4rem var(--gutter); border-bottom:1px solid var(--line); box-shadow:var(--sh-md); }
}

/* ---------- hero ---------- */
.hero{ padding-block:clamp(3rem,7vw,6rem) clamp(2.5rem,5vw,4rem); }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
@media (max-width:920px){ .hero-grid{ grid-template-columns:1fr; } }
.hero h1{ max-width:14ch; margin-block-start:1.2rem; }
.hero .lead{ margin-block-start:1.4rem; }
.hero-cta{ display:flex; gap:.8rem; margin-block-start:2rem; flex-wrap:wrap; }
.hero-bar{ display:flex; flex-wrap:wrap; gap:1.3rem; margin-block-start:2.5rem; padding-block-start:1.5rem; border-top:1px solid var(--line2); font-family:var(--mono); font-size:12px; color:var(--ink3); }
.hero-bar span{ display:inline-flex; align-items:center; gap:.4rem; }
.hero-bar b{ color:var(--navy); font-weight:500; }

/* hero terminal status */
.term{ background:var(--surface); border:1px solid var(--line2); border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-md); }
.term-bar{ display:flex; align-items:center; gap:.45rem; padding:.7rem 1rem; border-bottom:1px solid var(--line); background:var(--surface2); }
.term-bar .dot{ width:10px; height:10px; border-radius:50%; background:#dcdcd5; }
.term-bar .path{ margin-left:.5rem; font-family:var(--mono); font-size:11.5px; color:var(--ink3); }
.term-body{ padding:1.2rem 1.3rem; font-family:var(--mono); font-size:12.5px; line-height:1.95; color:var(--ink2); }
.term-body .pr{ color:var(--pink-ink); } .term-body .ok{ color:var(--navy); } .term-body .c{ color:var(--ink4); }
.cur{ display:inline-block; width:7px; height:14px; background:var(--navy); margin-left:3px; vertical-align:-2px; animation:blink 1.1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0; } }

/* ---------- compact centered page hero (inner pages) ---------- */
.phero{ position:relative; overflow:hidden; padding-block:clamp(3.5rem,7vw,5.5rem) clamp(1.75rem,3.5vw,3rem); text-align:center; }
.phero::before{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(46rem 18rem at 50% -18%, rgb(232 180 184/.20), transparent 64%); }
.phero::after{ content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:url("../img/contours.28e2c8a476f7.svg") center top / 150% no-repeat; opacity:.07;
  -webkit-mask-image:linear-gradient(#000, transparent 72%); mask-image:linear-gradient(#000, transparent 72%); }
.phero .inner{ position:relative; z-index:1; max-width:48rem; margin-inline:auto; }
.phero .micro{ justify-content:center; }
.phero h1{ font-size:clamp(2rem,4.4vw,3.1rem); margin:1rem auto .85rem; max-width:20ch; }
.phero .lead{ margin-inline:auto; }
.phero .meta{ display:inline-flex; gap:1.1rem; flex-wrap:wrap; justify-content:center; align-items:center; margin-top:1.6rem; font-family:var(--mono); font-size:11.5px; color:var(--ink3); }
.phero .meta span{ display:inline-flex; gap:.45rem; align-items:center; }
.phero .meta b{ color:var(--navy); font-weight:500; }
.phero .pulse{ width:7px; height:7px; border-radius:50%; background:#2e9e6b; box-shadow:0 0 0 0 rgb(46 158 107/.5); animation:pulse 2.2s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgb(46 158 107/.45); } 70%{ box-shadow:0 0 0 7px rgb(46 158 107/0); } 100%{ box-shadow:0 0 0 0 rgb(46 158 107/0); } }
.phero .filters{ display:flex; gap:.5rem; flex-wrap:wrap; justify-content:center; margin-top:1.5rem; position:relative; z-index:1; }

/* ---------- section head ---------- */
.shead{ margin-bottom:clamp(2rem,4vw,3rem); }
.shead h2{ margin-top:.9rem; }
.shead .lead{ margin-top:.9rem; }
.shead.row{ display:flex; justify-content:space-between; align-items:flex-end; gap:1rem; flex-wrap:wrap; }

/* ============ CAPABILITIES — SYSTEM MAP (data bus) ============ */
.map{ display:grid; grid-template-columns:240px 1fr; gap:0; }
@media (max-width:760px){ .map{ grid-template-columns:1fr; } }
.core{ position:sticky; top:5.5rem; align-self:start; border:1.5px solid var(--navy); border-radius:14px; padding:1.4rem; background:var(--surface); }
@media (max-width:760px){ .core{ position:static; margin-bottom:1.5rem; } }
.core .glyph{ width:42px; height:42px; border-radius:50%; border:2px solid var(--navy); display:grid; place-items:center; color:var(--navy); position:relative; }
.core .glyph::after{ content:""; position:absolute; right:-9px; width:8px; height:8px; border-radius:50%; background:var(--pink); }
.core h3{ font-size:1.3rem; margin-top:1rem; }
.core p{ font-size:.86rem; color:var(--ink2); margin-top:.4rem; }
.core .mono{ font-size:10px; color:var(--ink3); margin-top:.9rem; display:block; }
.bus{ position:relative; padding-left:2.2rem; }
.bus::before{ content:""; position:absolute; left:0; top:1.4rem; bottom:1.4rem; width:2px; background:linear-gradient(var(--navy),var(--pink)); opacity:.5; }
.node{ position:relative; display:grid; grid-template-columns:auto 1fr auto; gap:1rem; align-items:center; padding:1.05rem 1.1rem; border:1px solid var(--line2); border-radius:10px; background:var(--surface); margin-bottom:.7rem; transition:border-color .2s, transform .2s; }
.node::before{ content:""; position:absolute; left:-2.2rem; top:50%; width:2.2rem; height:2px; background:var(--line2); }
.node::after{ content:""; position:absolute; left:-.45rem; top:calc(50% - 5px); width:10px; height:10px; border-radius:50%; background:var(--surface); border:2px solid var(--navy); transition:border-color .2s; }
.node:hover{ border-color:var(--navy); transform:translateX(4px); }
.node.ai::after{ border-color:var(--pink-ink); }
.node .ic{ width:36px; height:36px; border-radius:8px; display:grid; place-items:center; color:var(--navy); background:var(--navy-soft); }
.node.ai .ic{ color:var(--pink-ink); background:var(--pink-soft); }
.node .nm{ font-family:var(--disp); font-weight:600; font-size:1.08rem; color:var(--ink); letter-spacing:-.01em; }
.node .vv{ font-family:var(--mono); font-size:11px; color:var(--ink3); margin-top:1px; }
.node .cd{ font-family:var(--mono); font-size:10.5px; color:var(--ink3); }
@media (max-width:520px){ .node{ grid-template-columns:auto 1fr; } .node .cd{ display:none; } }

/* ============ DARK BAND (how we build + code) ============ */
.dark{ background:var(--dark); color:var(--dark-ink); }
.dark .micro{ color:var(--pink); } .dark .micro b{ color:#6f6f7c; }
.dark h2{ color:var(--dark-head); } .dark h2 em.it{ color:var(--pink); }
.dark .lead{ color:var(--dark-ink2); }
.dgrid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
@media (max-width:880px){ .dgrid{ grid-template-columns:1fr; } }
.principles{ margin-top:1.8rem; display:grid; gap:.2rem; }
.principles div{ display:grid; grid-template-columns:auto 1fr; gap:.8rem; padding:.85rem 0; border-top:1px solid var(--dark-line); }
.principles .material-symbols-outlined{ color:var(--pink); font-size:20px; }
.principles b{ color:#eaeae4; font-weight:600; }
.principles span.t{ color:#9a9aa2; font-size:.92rem; display:block; margin-top:.15rem; }
.code{ background:var(--dark-2); border:1px solid #22222c; border-radius:10px; overflow:hidden; }
.code-bar{ display:flex; gap:.45rem; align-items:center; padding:.7rem 1rem; border-bottom:1px solid #1d1d26; }
.code-bar .d{ width:10px; height:10px; border-radius:50%; }
.code-bar .fn{ margin-left:.5rem; font-family:var(--mono); font-size:11px; color:#62626e; }
.code pre{ margin:0; padding:1.1rem 1.2rem; font-family:var(--mono); font-size:12px; line-height:1.85; color:#d6d6cf; overflow-x:auto; }
.c-cmt{ color:#6f6f7c; } .c-key{ color:#8cc4ff; } .c-str{ color:#b8e986; } .c-num{ color:#fcaf3e; } .c-fn{ color:#c9a0e9; } .c-pink{ color:var(--pink); }

/* ============ SECTORS BAND ============ */
.sectors{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
@media (max-width:820px){ .sectors{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .sectors{ grid-template-columns:1fr; } }
.sector{ border:1px solid var(--line2); border-radius:var(--r); padding:1.4rem; background:var(--surface); transition:border-color .2s, transform .2s; }
.sector:hover{ border-color:var(--navy); transform:translateY(-3px); }
.sector .material-symbols-outlined{ color:var(--navy); }
.sector h3{ font-size:1.15rem; margin-top:.9rem; }
.sector p{ font-size:.9rem; color:var(--ink2); margin-top:.4rem; }
.sector .n{ font-family:var(--mono); font-size:10.5px; color:var(--ink3); margin-top:.8rem; }

/* ============ WORK / PROJECT CARDS ============ */
.cards{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
@media (max-width:760px){ .cards{ grid-template-columns:1fr; } }
.pcard{ background:var(--surface); border:1px solid var(--line2); border-radius:var(--r); padding:1.7rem; display:flex; flex-direction:column; transition:border-color .2s, transform .2s; }
.pcard:hover{ border-color:var(--navy); transform:translateY(-3px); }
.pcard .top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1.1rem; }
.pcard .ic{ color:var(--navy); }
.pcard h3{ font-size:1.5rem; font-weight:600; }
.pcard .role{ font-family:var(--mono); font-size:11px; color:var(--ink3); margin-top:.2rem; }
.pcard .desc{ color:var(--ink2); font-size:.95rem; margin-top:.8rem; flex:1; }
.pcard .chips{ display:flex; gap:.4rem; flex-wrap:wrap; margin-top:1.1rem; }
.pcard .go{ display:inline-flex; align-items:center; gap:.4rem; margin-top:1.1rem; font-family:var(--mono); font-size:11px; color:var(--navy); }

/* ============ BLOG / list rows ============ */
.rows{ border-top:1px solid var(--line2); }
.row-item{ display:grid; grid-template-columns:8rem 1fr auto; gap:1.3rem; align-items:center; padding:1.5rem .4rem; border-bottom:1px solid var(--line); transition:background .2s, padding .2s; }
.row-item:hover{ background:var(--surface); padding-left:1rem; }
.row-item .date{ font-family:var(--mono); font-size:12px; color:var(--ink3); }
.row-item h3{ font-size:1.2rem; font-weight:600; }
.row-item .go{ color:var(--ink3); transition:transform .2s, color .2s; }
.row-item:hover .go{ color:var(--navy); transform:translateX(4px); }
@media (max-width:600px){ .row-item{ grid-template-columns:1fr; gap:.5rem; } }

/* ============ FAQ ============ */
.faq details{ border-top:1px solid var(--line2); }
.faq details:last-child{ border-bottom:1px solid var(--line2); }
.faq summary{ list-style:none; cursor:pointer; display:flex; gap:.9rem; align-items:flex-start; padding:1.3rem .3rem; font-family:var(--disp); font-weight:600; font-size:1.1rem; color:var(--ink); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .q{ font-family:var(--mono); font-size:.8rem; color:var(--pink-ink); padding-top:.2rem; }
.faq .ans{ padding:0 .3rem 1.4rem 2.4rem; color:var(--ink2); }

/* ============ CTA ============ */
.cta{ position:relative; overflow:hidden; text-align:center; padding:clamp(2.5rem,6vw,5rem); border-radius:var(--r); border:1px solid var(--line2);
  background:radial-gradient(40rem 22rem at 80% -40%, rgb(232 180 184/.22), transparent 60%), linear-gradient(180deg,var(--surface),var(--surface2)); box-shadow:var(--sh-sm); }
.cta h2{ max-width:18ch; margin-inline:auto; }

/* ============ forms ============ */
.field{ display:flex; flex-direction:column; gap:.45rem; margin-block-end:1.1rem; }
.field label{ font-size:.85rem; color:var(--ink); font-weight:600; }
.field input,.field select,.field textarea{ background:var(--surface); border:1px solid var(--line2); color:var(--ink); padding:.8rem .95rem; border-radius:var(--r-sm); font-family:var(--body); font-size:.98rem; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgb(26 47 94/.1); }
.alert{ padding:.9rem 1.15rem; border-radius:var(--r-sm); margin-block-end:1.1rem; font-size:.92rem; border:1px solid; }
.alert-success{ background:var(--navy-soft); border-color:#cdd8ec; color:var(--navy); }
.alert-error{ background:var(--pink-soft); border-color:#efcfd2; color:var(--pink-ink); }

/* ============ footer (dark, revamped) ============ */
.footer{ background:var(--dark); color:#a4a4ac; padding-block:clamp(3.5rem,7vw,6rem) 1.8rem; }
.footer-top{ display:grid; grid-template-columns:1.05fr 1.35fr; gap:clamp(2rem,5vw,4.5rem); padding-block-end:clamp(2rem,4vw,3rem); border-block-end:1px solid #26262f; }
@media (max-width:820px){ .footer-top{ grid-template-columns:1fr; } }
.footer-cta .micro{ color:var(--pink); }
.footer-cta h2{ color:#f4f4ee; font-size:clamp(1.7rem,3.4vw,2.6rem); max-width:15ch; margin:.9rem 0 1.6rem; }
.footer-nav{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem 1.25rem; }
@media (max-width:520px){ .footer-nav{ grid-template-columns:repeat(2,1fr); } }
.footer h5{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:#6c6c78; margin:0 0 1rem; }
.footer a.fl{ display:block; color:#cdcdc6; font-size:.93rem; margin-block-end:.65rem; transition:color .2s; min-width:0; overflow-wrap:anywhere; }
.footer a.fl:hover{ color:var(--pink); }
.footer .addr{ color:#86868f; font-size:.88rem; display:block; margin-block-start:.3rem; }
.socials{ display:flex; gap:.55rem; margin-block-start:1.2rem; }
.socials a{ width:2.4rem; height:2.4rem; display:grid; place-items:center; border-radius:var(--r-sm); border:1px solid #2c2c36; color:#9a9aa2; transition:all .25s var(--ease); }
.socials a:hover{ color:#14141b; background:var(--pink); border-color:var(--pink); transform:translateY(-2px); }
.footer-bottom{ margin-block-start:1.8rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-bottom .brand img{ height:22px; filter:brightness(0) invert(1); opacity:.92; }
.footer-bottom .brand span{ color:#e6e6e0; }
.footer-bottom .legal{ font-family:var(--mono); font-size:11px; color:#6c6c78; display:flex; gap:1.2rem; flex-wrap:wrap; }
.footer-bottom .legal a{ color:#9a9aa2; } .footer-bottom .legal a:hover{ color:var(--pink); }

/* ============ mobile safety — kill horizontal overflow from grid/flex text ============ */
.map,.dgrid,.cards,.sectors,.rows{ min-width:0; }
.node>span,.dgrid>div,.row-item>div,.pcard,.sector,.core,.term,.code{ min-width:0; }
.node .nm,.node .vv,.row-item h3,.pcard h3{ overflow-wrap:anywhere; }
.term-body,.code pre{ overflow-x:auto; max-width:100%; }
@media (max-width:560px){ .code pre{ font-size:10.5px; padding:.9rem 1rem; } .dgrid{ gap:1.5rem; } }
.principles>div{ min-width:0; } .principles .t{ overflow-wrap:anywhere; }
/* responsive 2-up split (used on What we build) */
.split2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3rem); align-items:start; }
@media (max-width:720px){ .split2{ grid-template-columns:1fr; } }

/* ============ sage ============ */
.sage-wrap{ position:fixed; inset-inline-end:1.4rem; inset-block-end:1.4rem; z-index:60; }
.sage-fab{ width:3.4rem; height:3.4rem; border-radius:14px; border:0; cursor:pointer; background:var(--navy); color:#fff; display:grid; place-items:center; box-shadow:0 10px 26px rgb(26 47 94/.3); transition:transform .3s var(--ease); }
.sage-fab:hover{ transform:translateY(-2px) scale(1.04); }
.sage-panel{ position:absolute; inset-inline-end:0; inset-block-end:4.4rem; width:min(23rem,86vw); background:var(--surface); border:1px solid var(--line2); border-radius:var(--r); box-shadow:var(--sh-md); display:none; flex-direction:column; overflow:hidden; }
.sage-panel.open{ display:flex; animation:pop .28s var(--ease); }
@keyframes pop{ from{ opacity:0; transform:translateY(10px); } }
.sage-head{ padding:1rem 1.1rem; border-bottom:1px solid var(--line); background:var(--surface2); }
.sage-head strong{ font-family:var(--disp); color:var(--ink); }
.sage-log{ padding:1.1rem; max-height:20rem; overflow-y:auto; display:flex; flex-direction:column; gap:.7rem; }
.sage-msg{ font-size:.9rem; padding:.65rem .85rem; border-radius:12px; max-width:88%; line-height:1.45; }
.sage-msg.user{ align-self:flex-end; background:var(--navy); color:#fff; }
.sage-msg.bot{ align-self:flex-start; background:var(--surface2); border:1px solid var(--line); color:var(--ink2); }
.sage-msg.bot strong{ color:var(--navy); }
.sage-suggest{ display:flex; flex-wrap:wrap; gap:.4rem; padding:0 1.1rem .9rem; }
.sage-suggest button{ font-family:var(--mono); font-size:11px; padding:.35rem .6rem; border-radius:var(--r-pill); background:var(--navy-soft); color:var(--navy); border:0; cursor:pointer; }
.sage-form{ display:flex; gap:.5rem; padding:.9rem; border-top:1px solid var(--line); }
.sage-form input{ flex:1; background:var(--surface2); border:1px solid var(--line2); color:var(--ink); padding:.6rem .85rem; border-radius:var(--r-sm); font-family:var(--body); }
.sage-form input:focus{ outline:none; border-color:var(--navy); }
.sage-form button{ background:var(--navy); border:0; color:#fff; width:2.75rem; min-height:2.75rem; border-radius:var(--r-sm); cursor:pointer; display:grid; place-items:center; }

/* ============ article ============ */
.article{ font-size:1.1rem; line-height:1.8; color:var(--ink2); max-width:44rem; }
.article p{ margin-bottom:1.4rem; }
.article h2,.article h3{ margin:2rem 0 .8rem; }

/* ============ reveal ============ */
.reveal{ opacity:0; transform:translateY(1.2rem); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.07s; } .reveal[data-delay="2"]{ transition-delay:.14s; } .reveal[data-delay="3"]{ transition-delay:.21s; }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; } .cur{ animation:none; }
  html{ scroll-behavior:auto; } .btn:hover,.pcard:hover,.sector:hover,.node:hover{ transform:none; }
}

/* WhatsApp click-to-chat (bottom-left, clear of the Sage FAB) */
.wa-fab{ position:fixed; inset-inline-start:1.4rem; inset-block-end:1.4rem; z-index:60;
  width:3.4rem; height:3.4rem; border-radius:14px; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 10px 26px rgb(37 211 102/.34);
  transition:transform .3s var(--ease); }
.wa-fab:hover{ transform:translateY(-2px) scale(1.04); color:#fff; }
@media (max-width:760px){ .wa-fab{ width:3rem; height:3rem; } }

/* ---------- trusted-by proof strip ---------- */
.trusted{ border-bottom:1px solid var(--line); background:var(--surface); }
.trusted-row{ display:flex; align-items:center; gap:clamp(1.2rem,4vw,3rem); flex-wrap:wrap; }
.trusted-row .micro{ white-space:nowrap; }
.trusted-logos{ display:flex; align-items:center; gap:clamp(1.8rem,4vw,3.4rem); flex-wrap:wrap; row-gap:1.1rem; }
.tlogo{ display:inline-flex; align-items:center; height:54px; }
.tlogo img{ height:54px; width:auto; max-width:180px; object-fit:contain; opacity:.95; transition:opacity .2s, transform .2s; }
.tlogo:hover img{ opacity:1; transform:translateY(-1px); }
.tword{ font-family:var(--disp); font-weight:600; font-size:1.1rem; color:var(--ink2); letter-spacing:-.01em; transition:color .2s; }
a.tlogo:hover .tword{ color:var(--navy); }
@media (max-width:560px){ .tlogo,.tlogo img{ height:44px; } }

/* ---------- project card client attribution ---------- */
.pcard .pclient{ display:inline-flex; align-items:center; gap:.3rem; margin-top:.4rem;
  font-family:var(--mono); font-size:11px; letter-spacing:.02em; color:var(--navy); }
.pcard .pclient .material-symbols-outlined{ font-size:1rem; color:var(--pink-ink); }

/* ---------- hero: full-bleed dark intelligence field ---------- */
.hero-dark{ position:relative; overflow:hidden; isolation:isolate;
  background:radial-gradient(130% 115% at 80% 0%, #20386a 0%, #16161f 52%, #0e0e15 100%);
  padding-block:clamp(4rem,9vw,7.5rem) clamp(3.5rem,7vw,6rem); }
.hero-dark::before{ content:""; position:absolute; inset:0; z-index:0;
  background:url("../img/contours.28e2c8a476f7.svg") center/120% no-repeat; opacity:.10; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg .hv-net{ position:absolute; inset:0; width:100%; height:100%; opacity:.72; }
.hero-bg-fade{ position:absolute; inset:0;
  background:linear-gradient(90deg, #0e0e15 4%, rgba(14,14,21,.78) 30%, rgba(14,14,21,.28) 62%, transparent 88%); }
.hero-copy{ position:relative; z-index:2; max-width:48rem; }
.hero-dark .micro{ color:var(--pink); }
.hero-dark .micro b{ color:#8b96b4; }
.hero-dark h1{ color:#fff; max-width:18ch; margin-block-start:1.2rem; }
.hero-dark .lead{ color:#bcc5db; margin-block-start:1.4rem; }
.hero-dark .hero-cta{ display:flex; gap:.8rem; margin-block-start:2.2rem; flex-wrap:wrap; }
.hero-dark .btn-primary{ background:#fff; color:var(--navy); box-shadow:0 8px 24px rgb(0 0 0/.28); }
.hero-dark .btn-primary:hover{ background:#eef1f7; }
.hero-dark .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.28); background:transparent; }
.hero-dark .btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.07); }
.hero-dark .hero-bar{ display:flex; flex-wrap:wrap; gap:1.4rem; margin-block-start:2.6rem; padding-block-start:1.6rem;
  border-top:1px solid rgba(255,255,255,.12); font-family:var(--mono); font-size:12px; color:#8b96b4; }
.hero-dark .hero-bar span{ display:inline-flex; align-items:center; gap:.4rem; }
.hero-dark .hero-bar b{ color:#fff; font-weight:500; }

/* constellation atoms */
.hv-links line{ stroke:#42568a; stroke-width:1; opacity:.5; }
.hv-nodes .n{ fill:#cdd7ee; }
.hv-nodes .n.p{ fill:var(--pink); }
.hv-nodes .halo{ fill:none; stroke:rgba(232,180,184,.5); stroke-width:1.2;
  animation:hvpulse 3.6s var(--ease) infinite; animation-delay:calc(var(--i,0) * .85s); }
@keyframes hvpulse{ 0%{ r:5; opacity:.65; } 70%{ r:22; opacity:0; } 100%{ r:22; opacity:0; } }
.hv-trace{ fill:#fff; filter:drop-shadow(0 0 6px rgba(255,255,255,.85)); }
.hv-glow{ position:absolute; top:-6%; right:2%; width:46%; height:70%; z-index:1;
  background:radial-gradient(circle, rgba(232,180,184,.20), transparent 60%); filter:blur(10px); }
.hv-cap{ position:absolute; right:1.4rem; bottom:1.2rem; z-index:2; font-family:var(--mono); font-size:11px;
  letter-spacing:.04em; color:#aeb9d6; display:inline-flex; align-items:center; gap:.45rem;
  background:rgba(16,16,24,.5); padding:.35rem .65rem; border-radius:6px; backdrop-filter:blur(4px); }
.hv-dot{ width:7px; height:7px; border-radius:50%; background:#7ee0a8; box-shadow:0 0 6px #7ee0a8;
  animation:hvblink 2s ease-in-out infinite; }
@keyframes hvblink{ 0%,100%{ opacity:1; } 50%{ opacity:.35; } }
@media (max-width:760px){
  .hero-bg-fade{ background:linear-gradient(180deg, rgba(14,14,21,.5) 0%, rgba(14,14,21,.82) 55%, #0e0e15 100%); }
  .hv-cap{ display:none; }
}
@media (prefers-reduced-motion: reduce){ .hv-nodes .halo,.hv-dot{ animation:none !important; } .hv-trace{ display:none; } }

/* ---------- impact metrics (count-up) ---------- */
.metrics{ display:grid; grid-template-columns:repeat(auto-fit,minmax(155px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.metric{ background:var(--surface); padding:1.7rem 1.5rem; }
.mval{ font-family:var(--disp); font-weight:700; font-size:clamp(2.1rem,4vw,3rem); color:var(--navy);
  line-height:1; letter-spacing:-.02em; font-variant-numeric:tabular-nums; }
.mpre,.msuf{ color:var(--pink-ink); }
.mlabel{ margin-top:.6rem; font-size:.95rem; color:var(--ink); font-weight:600; }
.mnote{ margin-top:.25rem; font-family:var(--mono); font-size:11px; letter-spacing:.02em; color:var(--ink3); }

/* ---------- sector filter chips (class-based active state) ---------- */
.chip.filter{ padding:.45rem .9rem; cursor:pointer; transition:background .2s, border-color .2s, color .2s; }
.chip.filter:hover{ border-color:var(--navy); color:var(--navy); }
.chip.filter.active{ background:var(--navy); color:#fff; border-color:var(--navy); }

/* ---------- engage reassurance ---------- */
.engage-assure{ display:flex; flex-direction:column; gap:.7rem; margin-top:1.8rem; }
.engage-assure div{ display:flex; align-items:center; gap:.6rem; font-size:.92rem; color:var(--ink2); }
.engage-assure .material-symbols-outlined{ color:var(--navy); }

/* ---------- framed cover images (consistent aspect) ---------- */
.case-cover,.article-cover{ width:100%; aspect-ratio:16/9; object-fit:cover;
  border-radius:var(--r); border:1px solid var(--line); }
.case-cover{ margin-top:2rem; }
.article-cover{ margin-top:1.5rem; }

/* ---------- Sage: full-width sheet on small screens ---------- */
@media (max-width:560px){
  .sage-wrap{ inset-inline:0; inset-block-end:0; }
  .sage-fab{ position:fixed; inset-inline-end:1.1rem; inset-block-end:1.1rem; }
  .sage-panel{ position:fixed; inset-inline:0; inset-block-end:0; width:100%;
    border-radius:14px 14px 0 0; max-height:82vh; }
  .sage-log{ max-height:52vh; }
}

/* ---------- why-we-exist mission statement ---------- */
.mission-statement{ font-family:var(--disp); font-weight:600; letter-spacing:-.02em;
  font-size:clamp(1.55rem,3.4vw,2.5rem); line-height:1.28; color:var(--ink); margin-top:1.2rem;
  text-wrap:balance; }

/* ============================================================
   CASE STUDY (work detail) — premium, data-company feel
   ============================================================ */
.case-hero{ position:relative; overflow:hidden; isolation:isolate;
  background:radial-gradient(120% 130% at 82% 0%, #20386a 0%, #16161f 54%, #0e0e15 100%);
  color:#cfd6e6; padding-block:clamp(2.5rem,6vw,4.5rem) clamp(2.5rem,5vw,4rem); }
.case-hero-fx{ position:absolute; inset:0; z-index:0;
  background:url("../img/contours.28e2c8a476f7.svg") center top / 150% no-repeat; opacity:.09; }
.case-back{ display:inline-flex; align-items:center; gap:.3rem; font-family:var(--mono);
  font-size:11px; text-transform:uppercase; letter-spacing:.07em; color:#aeb9d6; margin-bottom:1.6rem; }
.case-back:hover{ color:#fff; }
.case-eyebrow{ display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; margin-bottom:1rem; }
.case-client{ font-family:var(--mono); font-size:12px; color:var(--pink); }
.case-hero h1{ color:#fff; font-size:clamp(2.2rem,5vw,3.6rem); max-width:20ch; }
.case-lead{ color:#bcc5db; font-size:clamp(1.08rem,1.4vw,1.32rem); max-width:46rem; margin-top:1.1rem; line-height:1.5; }
.case-meta{ display:flex; flex-wrap:wrap; gap:2.2rem; margin-top:2rem; padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.12); }
.case-meta div{ font-size:.95rem; color:#fff; font-weight:600; }
.case-meta span{ display:block; font-family:var(--mono); font-size:10px; text-transform:uppercase;
  letter-spacing:.08em; color:#8b96b4; font-weight:400; margin-bottom:.35rem; }
.case-live{ display:inline-flex; align-items:center; gap:.4rem; color:#7ee0a8; }
.case-live .pulse{ width:7px; height:7px; border-radius:50%; background:#7ee0a8; box-shadow:0 0 6px #7ee0a8; }

.case-outcomes{ display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:1.8rem 1.6rem; }
.case-outcome{ border-top:2px solid var(--pink); padding-top:1rem; }
.case-outcome .v{ font-family:var(--disp); font-weight:700; font-size:clamp(1.5rem,2.7vw,2.1rem);
  color:var(--navy); line-height:1.08; letter-spacing:-.02em; text-wrap:balance; }
.case-outcome .l{ color:var(--ink2); margin-top:.5rem; font-size:.92rem; line-height:1.42; }

.case-story{ display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; margin-bottom:2.4rem; }
@media (max-width:760px){ .case-story{ grid-template-columns:1fr; gap:1.8rem; } }
.case-label{ display:inline-flex; align-items:center; gap:.4rem; font-family:var(--mono); font-size:11px;
  text-transform:uppercase; letter-spacing:.07em; color:var(--pink-ink); margin-bottom:.9rem; }
.case-label .material-symbols-outlined{ font-size:1rem; }
.case-block.accent .case-label{ color:var(--navy); }
.case-label.dim{ color:var(--ink3); }
.case-overview{ margin-top:.5rem; padding-top:2rem; border-top:1px solid var(--line); max-width:46rem; }
.case-chips-block{ margin-top:2.2rem; }

/* ---------- approach / niche (3-beat) ---------- */
.approach{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; margin-top:clamp(2rem,4vw,3rem); }
@media (max-width:820px){ .approach{ grid-template-columns:1fr; } }
.astep{ position:relative; border:1px solid var(--line2); border-radius:var(--r); padding:1.6rem 1.5rem;
  background:var(--surface); transition:border-color .2s, transform .2s; }
.astep:hover{ border-color:var(--navy); transform:translateY(-3px); }
.astep .anum{ position:absolute; top:1.3rem; right:1.4rem; font-family:var(--mono); font-size:11px; color:var(--ink4); }
.astep .ic{ display:grid; place-items:center; width:2.6rem; height:2.6rem; border-radius:10px;
  background:var(--navy-soft); color:var(--navy); margin-bottom:1rem; }
.astep:nth-child(3) .ic{ background:var(--pink-soft); color:var(--pink-ink); }
.astep h3{ font-size:1.15rem; margin-bottom:.5rem; }
.astep p{ color:var(--ink2); font-size:.95rem; margin:0; line-height:1.55; }

/* ---------- what-we-build: alive discipline grid ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:1.2rem; }
.svc-card{ position:relative; background:var(--surface); border:1px solid var(--line2); border-radius:var(--r);
  padding:1.7rem 1.6rem; overflow:hidden; transition:border-color .25s, transform .25s, box-shadow .25s; }
.svc-card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:linear-gradient(var(--navy), var(--pink)); transform:scaleY(0); transform-origin:top;
  transition:transform .4s var(--ease); }
.svc-card:hover{ border-color:var(--navy); transform:translateY(-4px); box-shadow:var(--sh-md); }
.svc-card:hover::before{ transform:scaleY(1); }
.svc-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1.1rem; }
.svc-ic{ width:48px; height:48px; border-radius:11px; display:grid; place-items:center;
  color:var(--navy); background:var(--navy-soft); transition:transform .25s var(--ease); }
.svc-card:hover .svc-ic{ transform:scale(1.06) rotate(-3deg); }
.svc-code{ font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--ink4); }
.svc-title{ font-size:1.3rem; letter-spacing:-.02em; }
.svc-highlight{ display:inline-block; font-family:var(--mono); font-size:10px; text-transform:uppercase;
  letter-spacing:.05em; color:var(--pink-ink); background:var(--pink-soft); padding:3px 8px; border-radius:3px; margin-top:.55rem; }
.svc-summary{ color:var(--navy); font-weight:500; margin:.7rem 0 0; }
.svc-desc{ color:var(--ink2); font-size:.95rem; margin:.6rem 0 0; line-height:1.55; }
.svc-caps{ display:flex; flex-direction:column; gap:.55rem; margin-top:1.2rem; padding-top:1.2rem; border-top:1px solid var(--line); }
.svc-cap{ display:flex; gap:.5rem; align-items:flex-start; font-size:.9rem; color:var(--ink2); }
.svc-cap .material-symbols-outlined{ color:var(--pink-ink); font-size:1rem; margin-top:1px; flex:none; }

/* ---------- case study diagram ---------- */
.case-diagram .case-label{ margin-bottom:.9rem; }
.case-diagram img{ width:100%; height:auto; border:1px solid var(--line2); border-radius:var(--r);
  background:var(--surface); box-shadow:var(--sh-sm); }

/* ---------- company: mission / vision / values / facts ---------- */
.mv-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
@media (max-width:760px){ .mv-grid{ grid-template-columns:1fr; } }
.mv-card{ border:1px solid var(--line2); border-radius:var(--r); padding:2rem 1.8rem; background:var(--surface); }
.mv-card.mission{ border-top:3px solid var(--navy); }
.mv-card.vision{ border-top:3px solid var(--pink); }
.mv-card.vision .case-label{ color:var(--navy); }
.mv-card p{ font-family:var(--disp); font-weight:500; font-size:clamp(1.2rem,2.1vw,1.55rem); line-height:1.35;
  color:var(--ink); letter-spacing:-.01em; margin:1rem 0 0; text-wrap:balance; }

.values-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.1rem; margin-top:clamp(1.5rem,3vw,2.2rem); }
.value-card{ border:1px solid var(--line); border-radius:var(--r); padding:1.5rem; background:var(--surface);
  transition:border-color .2s, transform .2s; }
.value-card:hover{ border-color:var(--navy); transform:translateY(-3px); }
.value-card h3{ font-size:1.1rem; margin-bottom:.55rem; }
.value-card h3::before{ content:""; display:inline-block; width:8px; height:8px; border-radius:50%;
  background:var(--pink); margin-right:.55rem; vertical-align:middle; }
.value-card p{ color:var(--ink2); font-size:.93rem; margin:0; line-height:1.55; }

.team-photo{ width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:var(--r-sm); border:1px solid var(--line); }

.facts{ display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.facts div{ background:var(--surface); padding:1.4rem 1.3rem; font-weight:600; color:var(--ink); font-size:.98rem; }
.facts span{ display:block; font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.08em;
  color:var(--ink3); font-weight:400; margin-bottom:.4rem; }

/* ============================================================
   INSIGHTS — editorial journal + article reading
   ============================================================ */
.post-feature{ display:grid; grid-template-columns:1.1fr .9fr; border:1px solid var(--line2);
  border-radius:var(--r); overflow:hidden; background:var(--surface); margin-bottom:1.4rem;
  transition:border-color .2s, box-shadow .2s; }
@media (max-width:760px){ .post-feature{ grid-template-columns:1fr; } }
.post-feature:hover{ border-color:var(--navy); box-shadow:var(--sh-md); }
.pf-img{ overflow:hidden; }
.pf-img img{ width:100%; height:100%; min-height:15rem; object-fit:cover; transition:transform .4s var(--ease); }
.post-feature:hover .pf-img img{ transform:scale(1.03); }
.pf-body{ padding:clamp(1.6rem,3vw,2.4rem); display:flex; flex-direction:column; }
.pf-body h2{ font-size:clamp(1.5rem,2.6vw,2.1rem); margin:.8rem 0 0; }
.post-meta{ display:flex; align-items:center; gap:.7rem; flex-wrap:wrap; }
.post-meta .mono{ font-size:11px; }
.post-excerpt{ color:var(--ink2); margin-top:.8rem; line-height:1.6; }
.post-by{ font-family:var(--mono); font-size:11.5px; color:var(--ink3); margin-top:1rem; }
.pf-body .go{ margin-top:auto; padding-top:1.2rem; }

.post-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.4rem; }
.post-card{ display:flex; flex-direction:column; border:1px solid var(--line2); border-radius:var(--r);
  overflow:hidden; background:var(--surface); transition:border-color .2s, transform .2s, box-shadow .2s; }
.post-card:hover{ border-color:var(--navy); transform:translateY(-4px); box-shadow:var(--sh-md); }
.pc-img{ overflow:hidden; aspect-ratio:16/9; }
.pc-img img{ width:100%; height:100%; object-fit:cover; transition:transform .35s var(--ease); }
.post-card:hover .pc-img img{ transform:scale(1.04); }
.pc-body{ padding:1.4rem 1.4rem 1.5rem; display:flex; flex-direction:column; flex:1; }
.pc-body h3{ font-size:1.2rem; margin:.7rem 0 0; }
.pc-body .post-excerpt{ font-size:.93rem; }
.pc-body .go{ margin-top:.9rem; }

.art-hero{ position:relative; padding-block:clamp(2rem,5vw,3.5rem) 0; }
.art-hero h1{ font-size:clamp(2rem,4.5vw,3.2rem); margin-top:.4rem; max-width:24ch; }
.art-byline{ display:flex; align-items:center; gap:.6rem; margin-top:1.3rem; font-size:.95rem; color:var(--ink2); }
.art-byline .dot{ color:var(--ink4); }
.art-avatar{ width:2rem; height:2rem; border-radius:50%; background:var(--navy); color:#fff; display:grid;
  place-items:center; font-family:var(--disp); font-weight:700; font-size:.9rem; text-transform:uppercase; }
.art-cover{ width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:var(--r); border:1px solid var(--line); margin-top:2rem; }
.art-body{ font-size:1.07rem; line-height:1.75; }
.art-foot{ display:flex; gap:.7rem; flex-wrap:wrap; margin-top:2.5rem; padding-top:1.8rem; border-top:1px solid var(--line); }
