/* ============================================================
   Vellamore Studio — editorial wellbeing masthead
   Dusty Teal & Clay. Warm-cream light mode locked.
   ONE accent (clay-rose #C57B5E). ONE radius. ONE theme.
   ============================================================ */

:root{
  --primary:#3E6B66;      /* dusty teal — structural voice */
  --primary-deep:#2C504C; /* darker teal for text-on-cream contrast */
  --secondary:#7FA39C;    /* soft teal */
  --accent:#C57B5E;       /* clay-rose — the ONLY non-neutral CTA/link/active */
  --accent-deep:#A65E42;  /* clay for AA text-on-cream where needed */
  --bg:#F4EFE6;           /* warm cream */
  --bg-tint:#EFE7D9;      /* slightly deeper cream tint */
  --bg-teal:#E7EDEA;      /* cream-teal family tint (never off-palette) */
  --fg:#1E2A28;           /* near-black teal-green */
  --muted:#56635D;        /* muted teal-grey, AA on cream */
  --line:#DCD3C3;         /* hairline on cream */
  --line-soft:#E4DCCD;
  --card:#FBF8F1;         /* raised card surface, still cream family */
  --shadow:0 1px 2px rgba(30,42,40,.04), 0 12px 40px -18px rgba(30,42,40,.22);
  --shadow-lift:0 2px 6px rgba(30,42,40,.06), 0 30px 60px -24px rgba(30,42,40,.30);
  --radius:14px;          /* the ONE radius */
  --maxw:1160px;
  --ch:65ch;              /* editorial reading measure */
  --ease:cubic-bezier(.22,.61,.36,1);
  --font-display:"Forum", Georgia, "Times New Roman", serif;
  --font-body:"Reddit Sans", system-ui, -apple-system, Segoe UI, sans-serif;
  --font-mono:"Xanh Mono", ui-monospace, "Courier New", monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@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:17px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* layered warm background wash, stays in cream/teal family */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(1100px 620px at 82% -8%, rgba(127,163,156,.20), transparent 60%),
    radial-gradient(900px 560px at -6% 12%, rgba(197,123,94,.10), transparent 55%),
    radial-gradient(1200px 800px at 50% 118%, rgba(62,107,102,.10), transparent 60%),
    var(--bg);
}

img{ max-width:100%; height:auto; display:block; }
a{ color:var(--accent-deep); text-decoration:none; }
a:hover{ color:var(--accent); }

/* ---------- typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:400; color:var(--fg); line-height:1.06; letter-spacing:.004em; }
h1{ font-size:clamp(2.7rem,6vw,4.6rem); }
h2{ font-size:clamp(2rem,3.6vw,3rem); }
h3{ font-size:clamp(1.4rem,2.2vw,1.85rem); line-height:1.15; }
p{ margin:0 0 1.1em; }
strong{ font-weight:600; color:var(--fg); }
em{ font-style:italic; }
.text-primary{ color:var(--primary-deep); }
.text-accent{ color:var(--accent-deep); }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px; }
.section{ padding:clamp(64px,9vw,118px) 0; position:relative; }
.section--tint{ background:linear-gradient(180deg, var(--bg-teal), transparent 78%); }
.section--cream{ background:linear-gradient(180deg, var(--bg-tint), transparent 80%); }

.eyebrow{
  font-family:var(--font-mono);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.7rem;
  color:var(--accent-deep);
  display:inline-flex; align-items:center; gap:.7em;
  margin:0 0 1.2rem;
}
.eyebrow::before{ content:""; width:30px; height:1px; background:var(--accent); display:inline-block; opacity:.8; }

.lede{ font-size:clamp(1.12rem,1.5vw,1.32rem); color:var(--muted); max-width:60ch; line-height:1.62; }

/* ---------- buttons ---------- */
.btn{
  --bw:1px;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--font-body); font-weight:600; font-size:.97rem;
  padding:.92em 1.7em; border-radius:var(--radius);
  cursor:pointer; border:var(--bw) solid transparent;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .25s, color .25s;
  letter-spacing:.01em; line-height:1; text-align:center;
}
.btn:focus-visible{ outline:3px solid var(--accent-deep); outline-offset:3px; }
.btn-primary{ background:var(--accent); color:#fff; box-shadow:0 10px 26px -12px rgba(197,123,94,.75); }
.btn-primary:hover{ background:var(--accent-deep); color:#fff; transform:translateY(-2px); box-shadow:0 18px 36px -14px rgba(166,94,66,.8); }
.btn-ghost{ background:transparent; color:var(--primary-deep); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--primary); color:var(--primary-deep); transform:translateY(-2px); background:rgba(255,255,255,.5); }
.btn-lg{ padding:1.05em 2em; font-size:1.02rem; }

/* ---------- header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(140%) blur(12px);
  background:rgba(244,239,230,.78);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background .3s, box-shadow .3s;
}
.site-header.scrolled{ border-bottom-color:var(--line); box-shadow:0 8px 30px -22px rgba(30,42,40,.4); }
.nav{ display:flex; align-items:center; justify-content:space-between; height:74px; gap:24px; }
.brand{ display:inline-flex; align-items:baseline; gap:.55rem; font-family:var(--font-display); font-size:1.5rem; color:var(--fg); letter-spacing:.02em; }
.brand:hover{ color:var(--fg); }
.brand .mark{ color:var(--accent-deep); font-size:1.05em; line-height:0; }
.brand small{ font-family:var(--font-mono); font-size:.52rem; letter-spacing:.34em; text-transform:uppercase; color:var(--muted); align-self:center; }
.nav-links{ display:flex; align-items:center; gap:30px; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-size:.93rem; color:var(--fg); font-weight:500; letter-spacing:.01em;
  position:relative; padding:.35em 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--accent);
  transition:width .32s var(--ease);
}
.nav-links a:hover{ color:var(--accent-deep); }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ width:100%; }
.nav-links a[aria-current="page"]{ color:var(--accent-deep); }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-toggle{ display:none; background:none; border:1px solid var(--line); border-radius:10px; width:44px; height:42px; cursor:pointer; align-items:center; justify-content:center; }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; display:block; width:19px; height:2px; background:var(--fg); border-radius:2px; position:relative; transition:.3s;
}
.nav-toggle span::before{ position:absolute; top:-6px; } .nav-toggle span::after{ position:absolute; top:6px; }

@media (max-width:880px){
  .nav-toggle{ display:inline-flex; }
  .nav-links{
    position:absolute; top:74px; left:0; right:0;
    flex-direction:column; align-items:flex-start; gap:4px;
    background:var(--bg); border-bottom:1px solid var(--line);
    padding:14px 26px 22px; box-shadow:var(--shadow);
    transform:translateY(-12px); opacity:0; pointer-events:none; transition:.28s var(--ease);
  }
  .nav-links.open{ transform:none; opacity:1; pointer-events:auto; }
  .nav-links a{ width:100%; padding:.7em 0; border-bottom:1px solid var(--line-soft); }
  .nav .btn-ghost{ display:none; }
}

/* ---------- hero ---------- */
.hero{ position:relative; padding-top:clamp(56px,9vw,96px); padding-bottom:clamp(56px,8vw,92px); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.06fr .94fr; gap:clamp(34px,5vw,72px); align-items:center; }
.hero h1{ margin:0 0 1.1rem; }
.hero .lede{ margin-bottom:2rem; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero-note{ font-size:.84rem; color:var(--muted); margin-top:1.4rem; font-family:var(--font-mono); letter-spacing:.02em; }
.hero-figure{ position:relative; }
.hero-figure .frame{
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lift);
  position:relative; aspect-ratio:4/4.3; border:1px solid var(--line-soft);
}
.hero-figure .frame img{ width:100%; height:100%; object-fit:cover; transform:scale(1.04); }
.hero-figure .frame::after{ content:""; position:absolute; inset:0; background:linear-gradient(200deg, transparent 55%, rgba(44,80,76,.22)); }
.hero-badge{
  position:absolute; left:-22px; bottom:34px;
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:16px 20px; box-shadow:var(--shadow); max-width:230px;
}
.hero-badge .k{ font-family:var(--font-display); font-size:1.9rem; color:var(--primary-deep); line-height:1; }
.hero-badge .v{ font-size:.78rem; color:var(--muted); margin-top:.3rem; }
.hero-marquee{ margin-top:clamp(40px,5vw,64px); border-top:1px solid var(--line); padding-top:26px; display:flex; flex-wrap:wrap; gap:14px 30px; align-items:center; }
.hero-marquee span{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.hero-marquee .dot{ width:5px; height:5px; border-radius:50%; background:var(--secondary); }
@media (max-width:840px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-figure{ order:-1; }
  .hero-figure .frame{ aspect-ratio:16/11; }
  .hero-badge{ left:auto; right:16px; }
}

/* ---------- stats ---------- */
.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.stat{ background:var(--card); padding:30px 26px; }
.stat .k{ font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.5rem); color:var(--primary-deep); line-height:1; }
.stat .v{ font-size:.86rem; color:var(--muted); margin-top:.5rem; max-width:22ch; }
@media (max-width:720px){ .stat-row{ grid-template-columns:repeat(2,1fr); } }

/* ---------- section head ---------- */
.sec-head{ max-width:62ch; margin-bottom:clamp(34px,4vw,56px); }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head.center .eyebrow{ justify-content:center; }
.sec-head h2{ margin:0 0 .8rem; }

/* ---------- service / feature cards ---------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
@media (max-width:920px){ .grid-3{ grid-template-columns:1fr; } .grid-2{ grid-template-columns:1fr; } }

.tilt{ perspective:1100px; }
.card{
  position:relative; background:var(--card); border:1px solid var(--line-soft);
  border-radius:var(--radius); padding:30px; box-shadow:var(--shadow);
  transition:box-shadow .4s var(--ease), border-color .4s, transform .1s;
  transform-style:preserve-3d; overflow:hidden; height:100%;
}
.card:hover{ box-shadow:var(--shadow-lift); border-color:var(--line); }
/* clay-into-teal gradient sheen sweep */
.card .sheen{
  content:""; position:absolute; inset:-40% -10%; pointer-events:none; opacity:0;
  background:linear-gradient(115deg, transparent 38%, rgba(197,123,94,.16) 48%, rgba(127,163,156,.18) 56%, transparent 66%);
  transform:translateX(-30%); transition:opacity .4s ease;
}
.card:hover .sheen{ opacity:1; animation:sheenSweep 1.1s var(--ease); }
@keyframes sheenSweep{ from{ transform:translateX(-40%);} to{ transform:translateX(40%);} }
.card .ic{
  width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(150deg, rgba(62,107,102,.14), rgba(197,123,94,.16)); color:var(--primary-deep);
  margin-bottom:18px; border:1px solid var(--line-soft);
}
.card .ic svg{ width:22px; height:22px; }
.card h3{ margin:0 0 .55rem; }
.card .num{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.2em; color:var(--accent-deep); text-transform:uppercase; }
.card p{ color:var(--muted); margin:.5rem 0 1.1rem; font-size:.98rem; }
.card ul{ list-style:none; margin:0 0 1.2rem; padding:0; }
.card ul li{ font-size:.92rem; color:var(--fg); padding-left:1.5em; position:relative; margin-bottom:.5em; }
.card ul li::before{ content:""; position:absolute; left:0; top:.62em; width:8px; height:8px; border-radius:50%; border:2px solid var(--accent); }
.card .more{ font-weight:600; font-size:.93rem; color:var(--accent-deep); display:inline-flex; align-items:center; gap:.4em; }
.card .more svg{ width:15px; transition:transform .3s var(--ease); }
.card:hover .more svg{ transform:translateX(4px); }

/* feature/editorial split */
.split{ display:grid; grid-template-columns:1.04fr .96fr; gap:clamp(34px,5vw,68px); align-items:center; }
.split.reverse .split-media{ order:2; }
@media (max-width:900px){ .split{ grid-template-columns:1fr; } .split.reverse .split-media{ order:0; } }
.split-media{ position:relative; }
.split-media img{ border-radius:var(--radius); box-shadow:var(--shadow-lift); border:1px solid var(--line-soft); width:100%; object-fit:cover; aspect-ratio:5/4; }
.split-media .tag{
  position:absolute; bottom:18px; left:18px; background:var(--card); border:1px solid var(--line);
  border-radius:10px; padding:9px 14px; font-family:var(--font-mono); font-size:.7rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--primary-deep);
}
.approach-list{ list-style:none; margin:1.4rem 0 0; padding:0; }
.approach-list li{ display:flex; gap:16px; padding:18px 0; border-top:1px solid var(--line-soft); }
.approach-list li:first-child{ border-top:0; }
.approach-list .n{ font-family:var(--font-mono); font-size:.78rem; color:var(--accent-deep); padding-top:.3rem; min-width:30px; }
.approach-list h3{ font-size:1.2rem; margin:0 0 .25rem; }
.approach-list p{ margin:0; color:var(--muted); font-size:.96rem; }

/* ---------- insights / blogroll ---------- */
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:960px){ .post-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px){ .post-grid{ grid-template-columns:1fr; } }
.post-card{
  display:flex; flex-direction:column; background:var(--card); border:1px solid var(--line-soft);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s; height:100%;
}
.post-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lift); border-color:var(--line); }
.post-card .thumb{ aspect-ratio:16/10; overflow:hidden; background:var(--bg-teal); position:relative; }
.post-card .thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.post-card:hover .thumb img{ transform:scale(1.05); }
.post-card .thumb.noimg{ display:grid; place-items:center; }
.post-card .thumb.noimg .glyph{ font-family:var(--font-display); font-size:3rem; color:var(--secondary); }
.post-card .body{ padding:22px 24px 26px; display:flex; flex-direction:column; flex:1; }
.post-card .meta{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:.7rem; }
.post-card h3{ font-size:1.3rem; line-height:1.16; margin:0 0 .6rem; }
.post-card h3 a{ color:var(--fg); }
.post-card h3 a:hover{ color:var(--accent-deep); }
.post-card p{ color:var(--muted); font-size:.94rem; margin:0 0 1.2rem; flex:1; }
.post-card .more{ font-weight:600; font-size:.9rem; color:var(--accent-deep); display:inline-flex; gap:.4em; align-items:center; }
.post-card .more svg{ width:15px; transition:transform .3s var(--ease); }
.post-card:hover .more svg{ transform:translateX(4px); }

/* resources blogroll */
.blogroll{ border:1px solid var(--line); border-radius:var(--radius); background:var(--card); overflow:hidden; }
.blogroll li{ list-style:none; }
.blogroll a.roll{
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:20px 26px; border-top:1px solid var(--line-soft); transition:background .25s;
}
.blogroll li:first-child a.roll{ border-top:0; }
.blogroll a.roll:hover{ background:var(--bg-tint); }
.blogroll .rl-main{ display:flex; flex-direction:column; gap:.2rem; }
.blogroll .rl-anchor{ font-weight:600; color:var(--accent-deep); font-size:1.02rem; }
.blogroll .rl-ctx{ font-size:.85rem; color:var(--muted); }
.blogroll .rl-host{ font-family:var(--font-mono); font-size:.74rem; color:var(--primary-deep); letter-spacing:.04em; white-space:nowrap; }

/* ---------- testimonials ---------- */
.quote-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:920px){ .quote-grid{ grid-template-columns:1fr; } }
.quote{
  background:var(--card); border:1px solid var(--line-soft); border-radius:var(--radius);
  padding:30px 28px; box-shadow:var(--shadow); display:flex; flex-direction:column; height:100%;
}
.quote .mk{ font-family:var(--font-display); font-size:3rem; color:var(--accent); line-height:.4; height:.5em; }
.quote blockquote{ margin:0 0 1.4rem; font-size:1.06rem; line-height:1.6; color:var(--fg); flex:1; }
.quote .by{ display:flex; align-items:center; gap:12px; border-top:1px solid var(--line-soft); padding-top:16px; }
.quote .av{ width:42px; height:42px; border-radius:50%; display:grid; place-items:center; font-family:var(--font-mono); font-size:.8rem; color:#fff; background:var(--primary); }
.quote .nm{ font-weight:600; font-size:.95rem; } .quote .ro{ font-size:.8rem; color:var(--muted); }

/* ---------- team ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:920px){ .team-grid{ grid-template-columns:1fr; } }
.member{ text-align:left; background:var(--card); border:1px solid var(--line-soft); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow); }
.member .av{ width:58px; height:58px; border-radius:14px; display:grid; place-items:center; font-family:var(--font-display); font-size:1.3rem; color:#fff; background:linear-gradient(150deg,var(--primary),var(--accent)); margin-bottom:16px; }
.member h3{ font-size:1.25rem; margin:0 0 .15rem; }
.member .role{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-deep); margin-bottom:.8rem; }
.member p{ color:var(--muted); font-size:.93rem; margin:0; }

/* ---------- values / chips ---------- */
.values-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:860px){ .values-grid{ grid-template-columns:repeat(2,1fr); } }
.value{ padding:24px; border:1px solid var(--line-soft); border-radius:var(--radius); background:var(--card); }
.value h3{ font-size:1.15rem; margin:0 0 .4rem; }
.value p{ color:var(--muted); font-size:.9rem; margin:0; }

/* ---------- faq ---------- */
.faq{ max-width:780px; margin:0 auto; }
.faq details{ border:1px solid var(--line-soft); border-radius:var(--radius); background:var(--card); margin-bottom:14px; overflow:hidden; }
.faq summary{ cursor:pointer; padding:22px 26px; font-family:var(--font-display); font-size:1.22rem; list-style:none; display:flex; justify-content:space-between; gap:18px; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ width:22px; height:22px; flex:0 0 auto; position:relative; }
.faq summary .pm::before,.faq summary .pm::after{ content:""; position:absolute; background:var(--accent); border-radius:2px; transition:transform .3s var(--ease); }
.faq summary .pm::before{ top:10px; left:2px; width:18px; height:2px; }
.faq summary .pm::after{ top:2px; left:10px; width:2px; height:18px; }
.faq details[open] summary .pm::after{ transform:rotate(90deg); opacity:0; }
.faq .ans{ padding:0 26px 22px; color:var(--muted); }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; border-radius:calc(var(--radius) + 6px); overflow:hidden; padding:clamp(44px,6vw,72px); border:1px solid var(--line); background:linear-gradient(135deg, var(--primary-deep), var(--primary) 70%); color:#fff; box-shadow:var(--shadow-lift); }
.cta-band::after{ content:""; position:absolute; inset:0; background:radial-gradient(700px 360px at 88% 18%, rgba(197,123,94,.4), transparent 60%); pointer-events:none; }
.cta-band h2{ color:#fff; max-width:18ch; }
.cta-band p{ color:rgba(255,255,255,.85); max-width:52ch; }
.cta-band .btn-primary{ background:var(--accent); }
.cta-band .btn-primary:hover{ background:#fff; color:var(--accent-deep); }
.cta-band .ghost-light{ background:transparent; border:1px solid rgba(255,255,255,.45); color:#fff; }
.cta-band .ghost-light:hover{ background:rgba(255,255,255,.12); color:#fff; border-color:#fff; transform:translateY(-2px); }
.cta-inner{ position:relative; z-index:1; display:flex; flex-wrap:wrap; gap:28px; align-items:flex-end; justify-content:space-between; }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); margin-top:30px; background:linear-gradient(180deg, transparent, var(--bg-tint)); }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:40px; padding:64px 0 40px; }
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; } }
@media (max-width:520px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-grid h4{ font-family:var(--font-mono); font-weight:400; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 1.1rem; }
.footer-grid ul{ list-style:none; margin:0; padding:0; }
.footer-grid li{ margin-bottom:.6rem; }
.footer-grid a{ color:var(--fg); font-size:.94rem; }
.footer-grid a:hover{ color:var(--accent-deep); }
.footer-brand .brand{ margin-bottom:1rem; }
.footer-brand p{ color:var(--muted); font-size:.92rem; max-width:34ch; }
.footer-bottom{ border-top:1px solid var(--line-soft); padding:22px 0; display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center; }
.footer-bottom p{ margin:0; font-size:.82rem; color:var(--muted); }
.footer-bottom .fb-links{ display:flex; gap:18px; }
.footer-bottom .fb-links a{ font-size:.82rem; color:var(--muted); }

/* ---------- contact form ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(34px,5vw,64px); align-items:start; }
@media (max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-info .row{ display:flex; gap:14px; padding:18px 0; border-top:1px solid var(--line-soft); }
.contact-info .row:first-of-type{ border-top:0; }
.contact-info .ic{ width:40px; height:40px; border-radius:11px; background:var(--bg-teal); display:grid; place-items:center; color:var(--primary-deep); flex:0 0 auto; border:1px solid var(--line-soft); }
.contact-info .ic svg{ width:19px; }
.contact-info .lbl{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.contact-info .val{ font-size:1.02rem; color:var(--fg); }
.contact-info .val a{ color:var(--accent-deep); }
.form-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,4vw,40px); box-shadow:var(--shadow-lift); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:.84rem; font-weight:600; margin-bottom:.5rem; color:var(--fg); }
.field label .req{ color:var(--accent-deep); }
.field input,.field textarea{
  width:100%; font-family:var(--font-body); font-size:1rem; color:var(--fg);
  background:var(--bg); border:1px solid var(--line); border-radius:12px;
  padding:.85em 1em; transition:border-color .25s, box-shadow .25s; resize:vertical;
}
.field input::placeholder,.field textarea::placeholder{ color:#8C938D; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(197,123,94,.22); }
.field input:user-invalid,.field textarea:user-invalid{ border-color:#B14A3C; }
.form-card .btn-primary{ width:100%; }
.form-note{ font-size:.8rem; color:var(--muted); margin-top:14px; text-align:center; }
.form-thanks{
  display:none; margin-top:20px; padding:18px 20px; border-radius:12px;
  background:var(--bg-teal); border:1px solid var(--secondary); color:var(--primary-deep); font-size:.95rem;
}
.form-thanks.show{ display:block; animation:fadeUp .5s var(--ease); }

/* ---------- article ---------- */
.article-hero{ padding-top:clamp(40px,6vw,72px); padding-bottom:28px; }
.crumbs{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:1.6rem; }
.crumbs a{ color:var(--muted); } .crumbs a:hover{ color:var(--accent-deep); }
.article-hero h1{ max-width:18ch; margin:0 0 1.1rem; }
.article-meta{ display:flex; flex-wrap:wrap; gap:10px 22px; align-items:center; font-size:.88rem; color:var(--muted); font-family:var(--font-mono); letter-spacing:.04em; }
.article-cover{ margin:clamp(26px,4vw,44px) 0; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lift); border:1px solid var(--line-soft); }
.article-cover img{ width:100%; aspect-ratio:16/8; object-fit:cover; }
.article-layout{ display:grid; grid-template-columns:minmax(0,1fr) 280px; gap:clamp(32px,5vw,60px); align-items:start; }
@media (max-width:980px){ .article-layout{ grid-template-columns:1fr; } .article-aside{ order:2; } }

.prose{ max-width:var(--ch); font-size:1.075rem; line-height:1.78; color:#2A3633; }
.prose > *{ margin-left:0; }
.prose p{ margin:0 0 1.3em; }
.prose h2{ font-size:clamp(1.6rem,2.6vw,2.1rem); margin:2.2em 0 .7em; line-height:1.12; }
.prose h3{ font-size:clamp(1.25rem,2vw,1.5rem); margin:1.8em 0 .55em; }
.prose a{ color:var(--accent-deep); text-decoration:underline; text-decoration-color:rgba(197,123,94,.4); text-underline-offset:3px; font-weight:600; }
.prose a:hover{ color:var(--accent); text-decoration-color:var(--accent); }
.prose strong{ color:var(--fg); }
.prose ul,.prose ol{ margin:0 0 1.4em; padding-left:1.3em; }
.prose li{ margin-bottom:.55em; }
.prose ul li::marker{ color:var(--accent); }
.prose ol li::marker{ color:var(--accent-deep); font-family:var(--font-mono); }
.prose img{ border-radius:var(--radius); margin:1.8em 0; box-shadow:var(--shadow); border:1px solid var(--line-soft); width:100%; }
.prose table{ width:100%; border-collapse:collapse; margin:1.6em 0; font-size:.95rem; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.prose th{ background:var(--bg-teal); text-align:left; font-family:var(--font-body); font-weight:600; }
.prose th,.prose td{ padding:12px 16px; border-bottom:1px solid var(--line-soft); border-right:1px solid var(--line-soft); }
.prose tr:last-child td{ border-bottom:0; }
.prose th:last-child,.prose td:last-child{ border-right:0; }
.prose section{ margin-top:2.4em; }
.prose blockquote{ margin:1.6em 0; padding:.2em 0 .2em 1.3em; border-left:3px solid var(--accent); color:var(--muted); font-style:italic; }
.prose[dir="rtl"]{ text-align:right; }
.prose[dir="rtl"] ul,.prose[dir="rtl"] ol{ padding-left:0; padding-right:1.3em; }
.prose[dir="rtl"] blockquote{ border-left:0; border-right:3px solid var(--accent); padding:.2em 1.3em .2em 0; }

.article-aside{ position:sticky; top:96px; }
.aside-card{ background:var(--card); border:1px solid var(--line-soft); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow); margin-bottom:20px; }
.aside-card h4{ font-family:var(--font-mono); font-weight:400; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin:0 0 1rem; }
.aside-card .src{ display:block; font-weight:600; color:var(--accent-deep); margin-bottom:.3rem; }
.aside-card .src-host{ font-family:var(--font-mono); font-size:.76rem; color:var(--primary-deep); }
.aside-list{ list-style:none; margin:0; padding:0; }
.aside-list li{ margin-bottom:.85rem; padding-bottom:.85rem; border-bottom:1px solid var(--line-soft); }
.aside-list li:last-child{ margin-bottom:0; padding-bottom:0; border-bottom:0; }
.aside-list a{ color:var(--fg); font-size:.92rem; font-weight:500; }
.aside-list a:hover{ color:var(--accent-deep); }
.aside-list .d{ font-family:var(--font-mono); font-size:.7rem; color:var(--muted); display:block; margin-top:.2rem; }

.article-foot{ margin-top:clamp(40px,6vw,72px); border-top:1px solid var(--line); padding-top:36px; }

/* ---------- page hero (interior pages) ---------- */
.page-hero{ padding-top:clamp(54px,8vw,90px); padding-bottom:clamp(34px,4vw,52px); }
.page-hero h1{ max-width:16ch; margin:0 0 1rem; }
.page-hero .lede{ max-width:58ch; }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; }
.reveal-d1{ transition-delay:.07s; } .reveal-d2{ transition-delay:.14s; } .reveal-d3{ transition-delay:.21s; } .reveal-d4{ transition-delay:.28s; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(10px);} to{ opacity:1; transform:none; } }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  .card .sheen{ display:none; }
  .card:hover .sheen{ animation:none; }
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

.skip-link{ position:absolute; left:-999px; top:0; background:var(--accent-deep); color:#fff; padding:10px 16px; border-radius:0 0 10px 0; z-index:100; }
.skip-link:focus{ left:0; color:#fff; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
