/* Cairn Practice — sonians.com
   Palette: Mint-Cream & Electric Charcoal
   primary #1C2B33  secondary #5C7A86  accent #2563EB  bg #EDF7F4  fg #13211F */

:root{
  --primary:#1C2B33;
  --secondary:#5C7A86;
  --accent:#2563EB;
  --accent-press:#1d4fd0;
  --bg:#EDF7F4;
  --fg:#13211F;

  --surface:#FBFEFD;
  --surface-2:#E3F1ED;
  --line:#D2E3DE;
  --line-strong:#BFD5CF;
  --muted:#46585A;

  --r:14px;            /* single locked corner radius */
  --r-sm:10px;
  --r-lg:16px;

  /* shadows tinted toward the mint bg, never pure black */
  --shadow-sm:0 1px 2px rgba(28,43,51,.05), 0 1px 1px rgba(92,122,134,.06);
  --shadow:0 18px 40px -24px rgba(28,43,51,.28), 0 6px 16px -12px rgba(92,122,134,.22);

  --maxw:1180px;
  --gutter:clamp(20px,5vw,56px);

  --font-display:"Funnel Display", system-ui, sans-serif;
  --font-body:"Fustat", system-ui, sans-serif;
  --font-mono:"Ubuntu Sans Mono", ui-monospace, monospace;

  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--fg);
  background:var(--bg);
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* layered, calm background wash */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(60% 50% at 82% -8%, rgba(92,122,134,.16), transparent 70%),
    radial-gradient(55% 45% at 8% 4%, rgba(37,99,235,.07), transparent 70%),
    linear-gradient(180deg, #EFF8F5 0%, var(--bg) 38%, #E7F3EF 100%);
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--primary);
  font-weight:700;
  line-height:1.06;
  letter-spacing:-0.02em;
  margin:0;
  text-wrap:balance;
}
h2{font-weight:600}
p{margin:0}
a{color:var(--accent); text-decoration:none}
img{max-width:100%; display:block}

.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,84px)}

.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--secondary);
  display:inline-flex; align-items:center; gap:.6em;
  margin:0 0 1.1rem;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--secondary); opacity:.7;
}

/* Headings clearly outrank body */
.h-display{font-size:clamp(2.6rem,6.2vw,4.6rem); line-height:1.02; letter-spacing:-0.035em}
.h1{font-size:clamp(2.1rem,4.4vw,3.3rem)}
.h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
.h3{font-size:clamp(1.2rem,1.8vw,1.45rem); letter-spacing:-0.01em}
.lead{font-size:clamp(1.08rem,1.5vw,1.28rem); color:var(--muted); line-height:1.6; max-width:62ch}
.measure{max-width:65ch}
.text-primary{color:var(--primary)}
.text-secondary{color:var(--secondary)}

/* ---- accent draw-in underline ---- */
.draw{
  position:relative;
  display:inline;
  background-image:linear-gradient(var(--accent),var(--accent));
  background-repeat:no-repeat;
  background-position:0 100%;
  background-size:0% 2px;
  padding-bottom:.06em;
  transition:background-size .5s var(--ease);
}
.is-revealed .draw, .draw.is-drawn{background-size:100% 2px}
a.link-draw{
  position:relative; color:var(--accent); font-weight:600;
  background-image:linear-gradient(var(--accent),var(--accent));
  background-repeat:no-repeat; background-position:0 100%;
  background-size:0% 1.5px; transition:background-size .35s var(--ease);
  padding-bottom:2px;
}
a.link-draw:hover, a.link-draw:focus-visible{background-size:100% 1.5px}

/* ---- buttons ---- */
.btn{
  --btnpad:.92em 1.5em;
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--font-body); font-weight:600;
  font-size:1rem; line-height:1;
  padding:var(--btnpad);
  border-radius:var(--r);
  border:1px solid transparent;
  cursor:pointer; text-decoration:none;
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
  will-change:transform;
}
.btn:focus-visible{outline:3px solid rgba(37,99,235,.45); outline-offset:2px}
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 10px 22px -10px rgba(37,99,235,.5) }
.btn-primary:hover{ background:var(--accent-press); transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(37,99,235,.55) }
.btn-ghost{ background:transparent; color:var(--primary); border-color:var(--line-strong) }
.btn-ghost:hover{ background:var(--surface); border-color:var(--secondary); transform:translateY(-2px) }
.btn-arrow svg{width:1.05em;height:1.05em}

/* ---- header / nav ---- */
.site-header{position:sticky; top:0; z-index:50; transition:background .3s var(--ease), box-shadow .3s var(--ease), border-color .3s}
.site-header.is-stuck{ background:rgba(237,247,244,.82); backdrop-filter:saturate(140%) blur(12px); border-bottom:1px solid var(--line); box-shadow:var(--shadow-sm) }
.nav{display:flex; align-items:center; justify-content:space-between; gap:1.5rem; height:74px}
.brand{display:inline-flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:700; font-size:1.18rem; color:var(--primary); letter-spacing:-0.02em}
.brand:hover{color:var(--primary)}
.brand-mark{width:30px;height:30px;flex:none}
.nav-links{display:flex; align-items:center; gap:2rem; list-style:none; margin:0; padding:0}
.nav-links a{
  font-size:.96rem; color:var(--primary); font-weight:500; position:relative;
  background-image:linear-gradient(var(--accent),var(--accent));
  background-repeat:no-repeat; background-position:0 100%; background-size:0% 1.5px;
  transition:background-size .35s var(--ease), color .2s; padding-bottom:3px;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{background-size:100% 1.5px}
.nav-links a[aria-current="page"]{color:var(--primary)}
.nav-cta{display:inline-flex; align-items:center; gap:1rem}
.nav-toggle{display:none; background:none; border:1px solid var(--line-strong); border-radius:var(--r-sm); width:44px;height:44px; cursor:pointer; align-items:center; justify-content:center}
.nav-toggle svg{width:22px;height:22px;stroke:var(--primary)}

@media (max-width:880px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:inline-flex}
  .nav.is-open .nav-links{
    display:flex; flex-direction:column; align-items:flex-start; gap:1.2rem;
    position:absolute; left:var(--gutter); right:var(--gutter); top:74px;
    background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
    padding:1.4rem 1.5rem; box-shadow:var(--shadow);
  }
}

/* ---- hero ---- */
.hero{min-height:100dvh; display:flex; align-items:center; position:relative; padding-block:clamp(40px,7vh,96px)}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; width:100%}
.hero-eyebrow{margin-bottom:1.4rem}
.hero h1{font-size:clamp(2.5rem,6vw,4.4rem); line-height:1.0; letter-spacing:-0.035em; margin-bottom:1.5rem; max-width:14ch}
.hero .lead{margin-bottom:2.2rem; max-width:46ch}
.hero-cta{display:flex; align-items:center; gap:1.25rem; flex-wrap:wrap}
.hero-note{font-size:.92rem; color:var(--secondary); margin-top:1.6rem; display:flex; align-items:center; gap:.55rem}
.hero-note svg{width:1.1em;height:1.1em;color:var(--accent)}
.hero-media{position:relative}
.hero-media .frame{
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--line); box-shadow:var(--shadow);
  aspect-ratio:4/3.4;
}
.hero-media .frame img{width:100%;height:100%;object-fit:cover}
.hero-media .frame::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, rgba(28,43,51,.18))}
.hero-badge{
  position:absolute; left:-18px; bottom:26px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:.9rem 1.1rem; box-shadow:var(--shadow); display:flex; gap:.8rem; align-items:center; max-width:230px;
}
.hero-badge .dot{width:38px;height:38px;border-radius:10px; background:linear-gradient(135deg,var(--accent),#5b87f5); display:grid; place-items:center; flex:none}
.hero-badge .dot svg{width:20px;height:20px;color:#fff}
.hero-badge b{font-family:var(--font-display); display:block; color:var(--primary); font-size:.98rem; line-height:1.1}
.hero-badge span{font-size:.82rem; color:var(--muted)}
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr; gap:2.5rem}
  .hero-media{order:-1; max-width:520px}
  .hero h1{max-width:18ch}
}

/* ---- stats strip ---- */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--r); background:var(--surface); overflow:hidden}
.stat{padding:1.7rem 1.6rem; border-left:1px solid var(--line)}
.stat:first-child{border-left:0}
.stat .v{font-family:var(--font-display); font-weight:700; color:var(--primary); font-size:clamp(1.5rem,2.4vw,2.1rem); line-height:1; letter-spacing:-0.02em}
.stat .l{font-size:.9rem; color:var(--muted); margin-top:.45rem}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)} .stat:nth-child(odd){border-left:0} .stat:nth-child(n+3){border-top:1px solid var(--line)}}

/* ---- generic section head ---- */
.sec-head{max-width:60ch}
.sec-head.center{margin-inline:auto; text-align:center}
.sec-head .lead{margin-top:1.1rem}
.sec-head.center .lead{margin-inline:auto}

/* ---- split feature ---- */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center}
.split.rev .split-media{order:2}
.split-media{border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); aspect-ratio:5/4}
.split-media img{width:100%;height:100%;object-fit:cover}
@media (max-width:820px){.split{grid-template-columns:1fr; gap:2.2rem} .split.rev .split-media{order:0}}

/* ---- bento services ---- */
.bento{display:grid; grid-template-columns:repeat(12,1fr); gap:18px}
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:clamp(1.4rem,2.4vw,2rem);
  transition:transform .3s var(--ease), border-color .3s, box-shadow .3s;
}
.card:hover{transform:translateY(-3px); border-color:var(--line-strong); box-shadow:var(--shadow)}
.card .ico{
  width:46px;height:46px;border-radius:12px; display:grid; place-items:center; margin-bottom:1.1rem;
  background:linear-gradient(135deg, rgba(37,99,235,.12), rgba(92,122,134,.12));
  border:1px solid var(--line);
}
.card .ico svg{width:24px;height:24px;color:var(--accent)}
.card h3{margin-bottom:.6rem}
.card p{color:var(--muted); font-size:.98rem}
.card .pts{list-style:none; margin:1.1rem 0 0; padding:0; display:grid; gap:.55rem}
.card .pts li{display:flex; gap:.6rem; align-items:flex-start; font-size:.94rem; color:var(--fg)}
.card .pts svg{width:1.05em;height:1.05em;color:var(--accent);flex:none;margin-top:.18em}
.card .more{margin-top:1.3rem; display:inline-flex; align-items:center; gap:.4em; font-weight:600; font-size:.95rem}
.span-7{grid-column:span 7}.span-5{grid-column:span 5}
.span-6{grid-column:span 6}.span-4{grid-column:span 4}.span-8{grid-column:span 8}
.span-12{grid-column:span 12}
@media (max-width:820px){.bento>*{grid-column:1/-1 !important}}

/* feature card big (bento hero cell) */
.card-feature{display:grid; grid-template-columns:1.1fr .9fr; gap:1.5rem; align-items:center; padding:0; overflow:hidden}
.card-feature .cf-body{padding:clamp(1.6rem,2.6vw,2.4rem)}
.card-feature .cf-media{align-self:stretch; min-height:240px; position:relative}
.card-feature .cf-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media (max-width:600px){.card-feature{grid-template-columns:1fr} .card-feature .cf-media{min-height:200px}}

/* ---- approach steps ---- */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line)}
.step{padding:2rem 1.8rem 2rem 0; border-top:0; position:relative}
.step + .step{border-left:1px solid var(--line); padding-left:1.8rem}
.step .n{font-family:var(--font-mono); color:var(--accent); font-size:.85rem; letter-spacing:.1em; font-weight:600}
.step h3{margin:.7rem 0 .55rem}
.step p{color:var(--muted); font-size:.96rem}
@media (max-width:760px){.steps{grid-template-columns:1fr} .step{padding:1.6rem 0; border-top:1px solid var(--line)} .step+.step{border-left:0;padding-left:0}}

/* ---- full-width quote ---- */
.quote-band{
  border-radius:var(--r-lg); padding:clamp(2.4rem,5vw,4.2rem);
  background:
    radial-gradient(70% 120% at 88% 0%, rgba(37,99,235,.16), transparent 60%),
    linear-gradient(135deg, var(--primary), #14202a);
  color:#EAF2F0; position:relative; overflow:hidden;
}
.quote-band .qmark{font-family:var(--font-display); font-size:6rem; line-height:.6; color:var(--accent); opacity:.55; height:.5em; display:block}
.quote-band blockquote{margin:0; font-family:var(--font-display); font-weight:600; font-size:clamp(1.5rem,3.2vw,2.4rem); line-height:1.22; letter-spacing:-0.02em; max-width:24ch; color:#fff}
.quote-band cite{display:block; margin-top:1.6rem; font-style:normal; color:#B9D2CC; font-size:.98rem}
.quote-band cite b{color:#fff; font-weight:600; font-family:var(--font-body)}

/* ---- testimonials ---- */
.tgrid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.tcard{background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.7rem 1.7rem 1.5rem; display:flex; flex-direction:column}
.tcard p{font-size:1.02rem; color:var(--fg); line-height:1.55}
.tcard .who{margin-top:auto; padding-top:1.3rem; display:flex; align-items:center; gap:.8rem}
.tcard .av{width:42px;height:42px;border-radius:50%; background:linear-gradient(135deg,var(--secondary),#7d9aa4); color:#fff; display:grid;place-items:center; font-family:var(--font-display); font-weight:700; font-size:.95rem; flex:none}
.tcard .who b{display:block; font-family:var(--font-display); color:var(--primary); font-size:.98rem}
.tcard .who span{font-size:.85rem; color:var(--muted)}
.stars{display:flex; gap:.15rem; margin-bottom:1rem; color:var(--accent)}
.stars svg{width:1em;height:1em}
@media (max-width:820px){.tgrid{grid-template-columns:1fr}}

/* ---- team ---- */
.team{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.member{background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.6rem}
.member .av{width:54px;height:54px;border-radius:14px; background:linear-gradient(135deg,var(--primary),var(--secondary)); color:#fff; display:grid;place-items:center; font-family:var(--font-display); font-weight:700; margin-bottom:1.1rem}
.member h3{font-size:1.1rem}
.member .role{font-family:var(--font-mono); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); margin:.3rem 0 .8rem}
.member p{color:var(--muted); font-size:.94rem}
@media (max-width:820px){.team{grid-template-columns:1fr}}

/* ---- resources / blogroll ---- */
.res-list{display:grid; gap:0; border-top:1px solid var(--line)}
.res-item{display:grid; grid-template-columns:auto 1fr auto; gap:1.4rem; align-items:center; padding:1.5rem 0; border-bottom:1px solid var(--line)}
.res-item .idx{font-family:var(--font-mono); color:var(--secondary); font-size:.85rem}
.res-item h3{font-size:1.2rem; margin-bottom:.35rem}
.res-item p{color:var(--muted); font-size:.95rem; max-width:62ch}
.res-item .meta{font-family:var(--font-mono); font-size:.78rem; color:var(--secondary); white-space:nowrap; letter-spacing:.06em}
.res-source{margin-top:.6rem; font-size:.85rem; color:var(--secondary)}
.res-source a{font-weight:600}
@media (max-width:680px){.res-item{grid-template-columns:1fr; gap:.4rem} .res-item .meta{order:-1}}

/* ---- CTA band ---- */
.cta-band{
  border:1px solid var(--line); border-radius:var(--r-lg);
  background:
    radial-gradient(60% 120% at 12% 0%, rgba(37,99,235,.1), transparent 60%),
    linear-gradient(180deg, var(--surface), var(--surface-2));
  padding:clamp(2.2rem,4.5vw,3.6rem); text-align:center;
}
.cta-band h2{margin-bottom:1rem}
.cta-band .lead{margin:0 auto 2rem}
.cta-band .row{display:flex; gap:1rem; justify-content:center; flex-wrap:wrap}

/* ---- footer ---- */
.site-footer{background:var(--primary); color:#C9DAD5; margin-top:clamp(60px,8vw,110px)}
.site-footer a{color:#C9DAD5}
.site-footer a:hover{color:#fff}
.foot-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.5rem; padding-block:clamp(48px,6vw,72px)}
.foot-brand .brand{color:#fff}
.foot-brand p{color:#9DB6B0; margin-top:1rem; max-width:34ch; font-size:.95rem}
.foot-col h4{color:#fff; font-family:var(--font-display); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:1rem; font-weight:600}
.foot-col ul{list-style:none; margin:0; padding:0; display:grid; gap:.7rem; font-size:.95rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); padding-block:1.5rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.86rem; color:#9DB6B0}
.foot-bottom .soc{display:flex; gap:1.2rem}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr; gap:2rem} .foot-brand{grid-column:1/-1}}

/* ---- page hero (inner) ---- */
.page-hero{padding-block:clamp(56px,8vw,104px) clamp(20px,3vw,32px)}
.page-hero .eyebrow{margin-bottom:1.1rem}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.6rem); letter-spacing:-0.03em; margin-bottom:1.2rem; max-width:16ch}
.page-hero .lead{max-width:60ch}

/* ---- breadcrumb ---- */
.crumb{font-family:var(--font-mono); font-size:.8rem; color:var(--secondary); letter-spacing:.05em; margin-bottom:1.4rem; display:flex; gap:.5rem; align-items:center}
.crumb a{color:var(--secondary)} .crumb a:hover{color:var(--accent)}

/* ---- forms ---- */
.form{display:grid; gap:1.3rem}
.field{display:grid; gap:.5rem}
.field label{font-weight:600; color:var(--primary); font-size:.95rem; font-family:var(--font-display)}
.field input,.field textarea{
  font-family:var(--font-body); font-size:1rem; color:var(--fg);
  background:var(--surface); border:1px solid var(--line-strong); border-radius:var(--r-sm);
  padding:.85rem 1rem; width:100%; transition:border-color .2s, box-shadow .2s;
}
.field textarea{min-height:140px; resize:vertical; line-height:1.55}
.field input:focus,.field textarea:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(37,99,235,.16)}
.field input::placeholder,.field textarea::placeholder{color:#90a4a2}
.form .btn{justify-content:center}
.form-note{font-size:.85rem; color:var(--muted)}
.form-ok{
  display:none; align-items:center; gap:.7rem;
  background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.25); color:var(--primary);
  border-radius:var(--r); padding:1rem 1.2rem; font-size:.97rem; margin-top:.4rem;
}
.form-ok.show{display:flex}
.form-ok svg{width:1.3em;height:1.3em;color:var(--accent);flex:none}

/* contact layout */
.contact-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,5vw,64px); align-items:start}
.contact-panel{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(1.6rem,3vw,2.4rem); box-shadow:var(--shadow-sm)}
.contact-info{display:grid; gap:1.4rem}
.info-row{display:flex; gap:1rem; align-items:flex-start}
.info-row .ico{width:42px;height:42px;border-radius:11px; background:var(--surface); border:1px solid var(--line); display:grid;place-items:center; flex:none}
.info-row .ico svg{width:20px;height:20px;color:var(--accent)}
.info-row b{font-family:var(--font-display); color:var(--primary); display:block; font-size:.98rem}
.info-row span,.info-row a{color:var(--muted); font-size:.95rem}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ---- article ---- */
.article-hero{padding-block:clamp(40px,6vw,72px) 0}
.article-head{max-width:760px}
.article-kicker{font-family:var(--font-mono); font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:1rem}
.article-head h1{font-size:clamp(2.1rem,4.6vw,3.3rem); letter-spacing:-0.03em; margin-bottom:1.2rem}
.article-meta{display:flex; gap:1.4rem; flex-wrap:wrap; font-family:var(--font-mono); font-size:.82rem; color:var(--secondary); letter-spacing:.04em; margin-top:1.3rem}
.article-figure{margin:clamp(2rem,4vw,3rem) 0 0; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); aspect-ratio:16/8}
.article-figure img{width:100%;height:100%;object-fit:cover}
.article-body{max-width:none; padding-block:clamp(36px,5vw,56px)}
.article-cols{display:grid; grid-template-columns:1fr minmax(0,68ch) 1fr; gap:0}
.prose{grid-column:2}
.prose>*{margin-bottom:1.15rem}
.prose p{color:var(--fg); line-height:1.72}
.prose h2{font-size:clamp(1.5rem,2.6vw,2rem); margin-top:2.6rem; margin-bottom:1rem; letter-spacing:-0.02em}
.prose h3{font-size:clamp(1.2rem,1.9vw,1.4rem); margin-top:1.9rem; margin-bottom:.7rem; color:var(--primary)}
.prose a{color:var(--accent); font-weight:600; background-image:linear-gradient(var(--accent),var(--accent)); background-repeat:no-repeat; background-position:0 100%; background-size:100% 1.5px; padding-bottom:1px}
.prose a:hover{background-size:0% 1.5px; transition:background-size .3s var(--ease)}
.prose ul{padding-left:1.2rem; display:grid; gap:.5rem}
.prose ul li{padding-left:.3rem}
.prose ul li::marker{color:var(--accent)}
.prose img{border-radius:var(--r); border:1px solid var(--line); margin-block:1.6rem; box-shadow:var(--shadow-sm)}
.prose strong{color:var(--primary)}
.prose section{margin-bottom:1.15rem}
.prose section h2{margin-top:2.2rem}
.prose [itemprop="mainEntity"]{border:1px solid var(--line); border-radius:var(--r); padding:1.1rem 1.3rem; background:var(--surface); margin-bottom:.9rem}
.prose [itemprop="mainEntity"] h3{margin-top:0}
.article-cta{margin-top:1rem}
@media (max-width:900px){.article-cols{grid-template-columns:1fr} .prose{grid-column:1}}

/* RTL article */
[dir="rtl"] .prose{text-align:right}
[dir="rtl"] .prose ul{padding-left:0; padding-right:1.2rem}
[dir="rtl"] .prose ul li{padding-left:0; padding-right:.3rem}
[dir="rtl"] .prose a{background-position:100% 100%}

/* related */
.related{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.rel-card{display:block; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.5rem; transition:transform .3s var(--ease), box-shadow .3s, border-color .3s}
.rel-card:hover{transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--line-strong)}
.rel-card .k{font-family:var(--font-mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--secondary)}
.rel-card h3{font-size:1.15rem; margin:.5rem 0; color:var(--primary)}
.rel-card p{color:var(--muted); font-size:.92rem}
@media (max-width:680px){.related{grid-template-columns:1fr}}

/* values list */
.vgrid{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.vitem{border:1px solid var(--line); border-radius:var(--r); padding:1.5rem; background:var(--surface)}
.vitem .n{font-family:var(--font-mono); font-size:.8rem; color:var(--accent)}
.vitem h3{font-size:1.15rem; margin:.5rem 0 .5rem}
.vitem p{color:var(--muted); font-size:.95rem}
@media (max-width:640px){.vgrid{grid-template-columns:1fr}}

/* faq */
.faq{display:grid; gap:0; border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line); padding:1.3rem 0}
.faq summary{cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:1rem; align-items:center; font-family:var(--font-display); font-weight:600; color:var(--primary); font-size:1.1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{width:24px;height:24px;flex:none; position:relative; transition:transform .3s var(--ease)}
.faq summary .pl::before,.faq summary .pl::after{content:""; position:absolute; background:var(--accent); border-radius:2px}
.faq summary .pl::before{top:50%; left:3px; right:3px; height:2px; transform:translateY(-50%)}
.faq summary .pl::after{left:50%; top:3px; bottom:3px; width:2px; transform:translateX(-50%); transition:opacity .3s}
.faq details[open] summary .pl::after{opacity:0}
.faq details[open] summary .pl{transform:rotate(180deg)}
.faq p{margin-top:.9rem; color:var(--muted); max-width:65ch}

/* scroll reveal base (JS adds .is-revealed) */
.reveal{opacity:0; transform:translateY(22px) skewY(1.2deg); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.is-revealed{opacity:1; transform:none}
.reveal-d1{transition-delay:.08s}
.reveal-d2{transition-delay:.16s}
.reveal-d3{transition-delay:.24s}

@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-d1,.reveal-d2,.reveal-d3{opacity:1 !important; transform:none !important; transition:none !important}
  .draw,.link-draw,.nav-links a{transition:none !important}
  .is-revealed .draw, .draw.is-drawn{background-size:100% 2px}
  *{animation:none !important}
  .btn:hover,.card:hover,.rel-card:hover{transform:none !important}
}

.skip-link{position:absolute; left:-999px; top:0; background:var(--accent); color:#fff; padding:.7rem 1.1rem; border-radius:0 0 var(--r-sm) 0; z-index:100}
.skip-link:focus{left:0}
