/* ===========================================================================
   Sundara Field - "Clay Room" design system
   Palette: primary #A8482B  secondary #7A4A35  accent #1F6F6B
            background #F7F1E6  foreground #2B221C
   ONE accent locked (deep teal) for every interactive moment.
   ONE radius scale: 16px cards, full-pill buttons.
   =========================================================================== */
:root{
  --primary:#A8482B;          /* rust-clay: headings + warmth */
  --primary-deep:#8F3A22;
  --secondary:#7A4A35;        /* warm umber-brown */
  --accent:#1F6F6B;           /* deep teal: ALL interactive */
  --accent-deep:#185754;
  --bg:#F7F1E6;               /* ecru paper */
  --bg-sink:#F1E8D8;          /* slightly deeper paper */
  --bg-card:#FFFDF8;          /* card surface */
  --fg:#2B221C;               /* foreground 13.9:1 on bg */
  --fg-soft:#5A4E43;          /* helper / muted, real contrast */
  --fg-faint:#6B5E51;         /* placeholder-strength, AA on bg */
  --line:#E2D4BE;            /* hairline on paper */
  --line-strong:#D2BFA2;
  --teal-tint:#E4EFEE;        /* teal wash */
  --rust-tint:#F4E2D8;        /* rust wash */
  --on-accent:#FFFFFF;        /* white on teal = 5.9:1 */

  --r-card:16px;
  --r-sm:10px;
  --r-pill:999px;

  --measure:66ch;             /* 65-68ch body measure cap */
  --shadow-sm:0 1px 2px rgba(74,46,30,.06), 0 2px 8px rgba(74,46,30,.05);
  --shadow:0 6px 18px rgba(74,46,30,.10), 0 2px 6px rgba(74,46,30,.06);
  --shadow-lg:0 18px 44px rgba(74,46,30,.16), 0 6px 16px rgba(74,46,30,.08);
  --ring:0 0 0 3px rgba(31,111,107,.42);

  --ff-display:"Varela Round", system-ui, sans-serif;
  --ff-body:"Krub", system-ui, sans-serif;
  --ff-mono:"Lekton", ui-monospace, monospace;

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

*,*::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(--ff-body);
  font-weight:400;
  color:var(--fg);
  background:var(--bg);
  line-height:1.7;
  font-size:clamp(16px,.5vw + 15px,17.5px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  background-image:
    radial-gradient(1100px 620px at 82% -8%, rgba(31,111,107,.07), transparent 60%),
    radial-gradient(900px 560px at 0% 0%, rgba(168,72,43,.07), transparent 58%);
  background-attachment:fixed;
}

h1,h2,h3,h4{ font-family:var(--ff-display); font-weight:400; color:var(--primary); line-height:1.16; letter-spacing:.1px; margin:0 0 .5em; }
h1{ font-size:clamp(2.1rem,5.2vw,3.5rem); }
h2{ font-size:clamp(1.7rem,3.4vw,2.5rem); }
h3{ font-size:clamp(1.2rem,1.8vw,1.45rem); }
p{ margin:0 0 1.1em; }
a{ color:var(--accent); text-decoration-color:rgba(31,111,107,.4); text-underline-offset:3px; transition:color .2s var(--ease); }
a:hover{ color:var(--accent-deep); }
strong{ font-weight:600; color:var(--fg); }
img{ max-width:100%; height:auto; display:block; }
.mono{ font-family:var(--ff-mono); }

/* focus: ONE accent ring everywhere */
:focus-visible{ outline:none; box-shadow:var(--ring); border-radius:6px; }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{ box-shadow:var(--ring); }

.skip-link{ position:fixed; left:14px; top:-60px; z-index:200; background:var(--accent); color:#fff; padding:.6rem 1rem; border-radius:var(--r-pill); transition:top .2s var(--ease); text-decoration:none; }
.skip-link:focus{ top:14px; color:#fff; }

.wrap{ width:min(100% - 2.4rem, var(--maxw)); margin-inline:auto; }
section{ position:relative; }

/* ---- buttons : full pill, teal interactive ---- */
.btn{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--ff-body); font-weight:600; font-size:1rem; line-height:1; padding:.85rem 1.5rem; border-radius:var(--r-pill); border:1.5px solid transparent; cursor:pointer; text-decoration:none; transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .2s var(--ease); position:relative; overflow:hidden; }
.btn-pill{ background:var(--accent); color:var(--on-accent); box-shadow:0 8px 20px rgba(31,111,107,.26); }
.btn-pill:hover{ background:var(--accent-deep); color:#fff; transform:translateY(-2px); box-shadow:0 12px 28px rgba(31,111,107,.32); }
.btn-ghost{ background:transparent; color:var(--accent); border-color:rgba(31,111,107,.4); }
.btn-ghost:hover{ background:var(--teal-tint); color:var(--accent-deep); border-color:var(--accent); transform:translateY(-2px); }
.btn svg{ flex:0 0 auto; }

.eyebrow{ display:inline-flex; align-items:center; gap:.55rem; font-family:var(--ff-mono); font-size:.74rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin:0 0 1rem; }
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--accent); border-radius:2px; }
[dir=rtl] .eyebrow{ letter-spacing:.04em; }

/* ===================== HEADER ===================== */
.site-head{ position:sticky; top:0; z-index:90; background:rgba(247,241,230,.82); backdrop-filter:saturate(140%) blur(12px); border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s, background .3s; }
.site-head.scrolled{ border-bottom-color:var(--line); box-shadow:0 6px 22px rgba(74,46,30,.07); }
.head-inner{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.brand{ display:inline-flex; align-items:center; gap:.6rem; text-decoration:none; color:var(--primary); font-family:var(--ff-display); font-size:1.18rem; }
.brand-mark{ display:grid; place-items:center; width:38px; height:38px; border-radius:12px; background:linear-gradient(140deg,var(--primary),var(--secondary)); color:#fff; box-shadow:inset 0 0 0 1px rgba(255,255,255,.16); }
.brand-name{ color:var(--primary); letter-spacing:.2px; }
.nav{ display:flex; align-items:center; gap:1.6rem; }
.nav a{ color:var(--fg); text-decoration:none; font-weight:500; font-size:.98rem; position:relative; padding:.3rem 0; }
.nav a:not(.btn)::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--accent); border-radius:2px; transition:width .25s var(--ease); }
.nav a:not(.btn):hover{ color:var(--accent); }
.nav a:not(.btn):hover::after, .nav a[aria-current=page]::after{ width:100%; }
.nav a[aria-current=page]{ color:var(--accent); }
.nav-cta{ padding:.62rem 1.15rem; font-size:.95rem; color:#fff; }
.nav-cta:hover{ color:#fff; }
.nav-toggle{ display:none; background:var(--bg-card); border:1px solid var(--line); border-radius:12px; padding:.4rem; color:var(--primary); cursor:pointer; }
.mobile-nav{ display:none; flex-direction:column; gap:.2rem; padding:1rem 1.2rem 1.4rem; background:var(--bg-card); border-bottom:1px solid var(--line); }
.mobile-nav a{ padding:.75rem .4rem; text-decoration:none; color:var(--fg); font-weight:500; border-radius:10px; }
.mobile-nav a:hover{ background:var(--teal-tint); color:var(--accent); }
.mobile-nav .btn{ margin-top:.5rem; justify-content:center; color:#fff; }

/* reading progress */
.reading-progress{ position:fixed; top:0; left:0; right:0; height:3px; z-index:120; background:transparent; }
.reading-progress span{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--primary),var(--accent)); box-shadow:0 0 10px rgba(31,111,107,.4); transition:width .08s linear; }

/* ===================== HERO ===================== */
.hero{ padding:clamp(3rem,7vw,5.5rem) 0 clamp(2.5rem,5vw,4rem); position:relative; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,4vw,3.4rem); align-items:center; }
.hero-copy{ max-width:38rem; }
.hero h1{ margin:.2rem 0 1rem; }
.hero h1 .clay{ color:var(--primary); }
.hero h1 .teal{ color:var(--accent); }
.hero-sub{ font-size:clamp(1.05rem,1.4vw,1.2rem); color:var(--fg-soft); max-width:34rem; margin-bottom:1.7rem; }
.hero-cta-row{ display:flex; flex-wrap:wrap; gap:.9rem; align-items:center; }
.hero-note{ margin:1.3rem 0 0; font-family:var(--ff-mono); font-size:.82rem; color:var(--fg-faint); display:flex; align-items:center; gap:.5rem; }
.hero-note .dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(31,111,107,.16); }

.hero-art{ position:relative; }
.hero-card{ position:relative; border-radius:calc(var(--r-card) + 8px); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line); background:var(--bg-card); transform-style:preserve-3d; }
.hero-card img{ width:100%; aspect-ratio:4/3.4; object-fit:cover; }
.hero-card .sheen{ position:absolute; inset:0; background:linear-gradient(115deg, transparent 30%, rgba(168,72,43,.16) 47%, rgba(31,111,107,.16) 53%, transparent 70%); transform:translateX(-30%); pointer-events:none; mix-blend-mode:screen; opacity:.0; }
.hero-float{ position:absolute; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); box-shadow:var(--shadow); padding:.85rem 1rem; display:flex; align-items:center; gap:.7rem; }
.hero-float .ic{ display:grid; place-items:center; width:40px; height:40px; border-radius:12px; background:var(--teal-tint); color:var(--accent); flex:0 0 auto; }
.hero-float .ic.rust{ background:var(--rust-tint); color:var(--primary); }
.hero-float strong{ display:block; font-family:var(--ff-display); color:var(--primary); font-size:1.05rem; line-height:1; }
.hero-float span{ font-size:.78rem; color:var(--fg-soft); }
.hero-float.f1{ left:-18px; bottom:34px; }
.hero-float.f2{ right:-14px; top:34px; }
[dir=rtl] .hero-float.f1{ left:auto; right:-18px; }
[dir=rtl] .hero-float.f2{ right:auto; left:-14px; }

/* ===================== TRUST STRIP ===================== */
.trust{ padding:1.4rem 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:linear-gradient(var(--bg-sink),var(--bg-sink)); }
.trust-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.trust-item{ text-align:center; padding:.4rem .6rem; }
.trust-item .v{ font-family:var(--ff-display); color:var(--primary); font-size:clamp(1.4rem,2.4vw,1.9rem); line-height:1; }
.trust-item .l{ font-size:.82rem; color:var(--fg-soft); margin-top:.35rem; }

/* ===================== SECTION SCAFFOLD ===================== */
.section{ padding:clamp(3.4rem,7vw,6rem) 0; }
.section-head{ max-width:42rem; margin-bottom:clamp(2rem,4vw,3rem); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head p{ color:var(--fg-soft); font-size:1.06rem; margin-bottom:0; }
.section-tint{ background:var(--bg-sink); }

/* pillars */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.tilt{ transform-style:preserve-3d; will-change:transform; }
.pillar-card{ position:relative; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.9rem 1.7rem; box-shadow:var(--shadow-sm); overflow:hidden; transition:box-shadow .3s var(--ease), border-color .3s var(--ease); height:100%; }
.pillar-card:hover{ box-shadow:var(--shadow); border-color:var(--line-strong); }
.pillar-card .sheen{ position:absolute; inset:0; background:linear-gradient(120deg, transparent 35%, rgba(168,72,43,.10) 48%, rgba(31,111,107,.12) 54%, transparent 68%); opacity:0; transform:translateX(-25%); transition:opacity .4s; pointer-events:none; }
.pillar-card:hover .sheen{ opacity:1; }
.pillar-card .ico{ display:grid; place-items:center; width:54px; height:54px; border-radius:14px; background:var(--rust-tint); color:var(--primary); margin-bottom:1.1rem; transform:translateZ(30px); }
.pillar-card .topic{ font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.pillar-card h3{ margin:.4rem 0 .55rem; }
.pillar-card p{ color:var(--fg-soft); margin:0; font-size:.98rem; }

/* approach / values */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.value{ display:flex; gap:1rem; align-items:flex-start; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.6rem; box-shadow:var(--shadow-sm); }
.value .ico{ display:grid; place-items:center; width:46px; height:46px; border-radius:12px; background:var(--teal-tint); color:var(--accent); flex:0 0 auto; }
.value h3{ margin:0 0 .35rem; font-size:1.15rem; }
.value p{ margin:0; color:var(--fg-soft); font-size:.96rem; }

/* reading / blogroll */
.reading-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem; }
.read-card{ position:relative; display:flex; flex-direction:column; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s var(--ease), box-shadow .3s var(--ease); text-decoration:none; color:inherit; }
.read-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.read-thumb{ position:relative; aspect-ratio:16/8.4; overflow:hidden; background:var(--bg-sink); }
.read-thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.read-card:hover .read-thumb img{ transform:scale(1.05); }
.read-thumb .badge{ position:absolute; top:.9rem; inset-inline-start:.9rem; background:rgba(247,241,230,.92); color:var(--accent); font-family:var(--ff-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; padding:.35rem .7rem; border-radius:var(--r-pill); backdrop-filter:blur(4px); }
.read-body{ padding:1.4rem 1.5rem 1.6rem; display:flex; flex-direction:column; flex:1; }
.read-meta{ font-family:var(--ff-mono); font-size:.76rem; color:var(--fg-faint); display:flex; gap:.8rem; margin-bottom:.6rem; }
.read-body h3{ font-size:1.28rem; margin:0 0 .5rem; color:var(--primary); }
.read-card[dir=rtl] .read-body h3{ font-family:var(--ff-body); font-weight:700; }
.read-excerpt{ color:var(--fg-soft); font-size:.96rem; margin:0 0 1.1rem; }
.read-more{ margin-top:auto; display:inline-flex; align-items:center; gap:.4rem; color:var(--accent); font-weight:600; font-size:.95rem; }
.read-card:hover .read-more svg{ transform:translateX(3px); }
[dir=rtl] .read-card:hover .read-more svg{ transform:translateX(-3px) scaleX(-1); }
.read-more svg{ transition:transform .25s var(--ease); }
[dir=rtl] .read-more svg{ transform:scaleX(-1); }

/* resources blogroll (dofollow) */
.resources{ display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; margin-top:1.4rem; }
.resource{ display:flex; align-items:center; gap:.9rem; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.1rem 1.3rem; text-decoration:none; color:inherit; box-shadow:var(--shadow-sm); transition:border-color .25s, transform .25s var(--ease); }
.resource:hover{ border-color:var(--accent); transform:translateY(-2px); }
.resource .ic{ display:grid; place-items:center; width:42px; height:42px; border-radius:11px; background:var(--teal-tint); color:var(--accent); flex:0 0 auto; }
.resource .rt{ font-weight:600; color:var(--fg); display:block; }
.resource .rh{ font-family:var(--ff-mono); font-size:.76rem; color:var(--accent); }

/* testimonials */
.tests{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.test{ position:relative; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.8rem 1.7rem; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.test .qm{ color:var(--rust-tint); position:absolute; top:1.1rem; inset-inline-end:1.2rem; }
.test .stars{ display:flex; gap:.15rem; color:var(--primary); margin-bottom:.9rem; }
.test blockquote{ margin:0 0 1.3rem; font-size:1.02rem; color:var(--fg); line-height:1.65; }
.test .who{ display:flex; align-items:center; gap:.8rem; margin-top:auto; }
.test .av{ display:grid; place-items:center; width:44px; height:44px; border-radius:50%; background:linear-gradient(140deg,var(--accent),var(--accent-deep)); color:#fff; font-family:var(--ff-display); font-size:.95rem; }
.test .nm{ font-weight:600; color:var(--fg); }
.test .rl{ font-size:.82rem; color:var(--fg-soft); }

/* CTA band */
.cta-band{ position:relative; overflow:hidden; border-radius:calc(var(--r-card) + 8px); padding:clamp(2.4rem,5vw,3.6rem); background:linear-gradient(135deg,var(--accent),var(--accent-deep)); color:#fff; box-shadow:var(--shadow-lg); }
.cta-band::after{ content:""; position:absolute; inset:0; background:radial-gradient(600px 300px at 90% -20%, rgba(255,255,255,.16), transparent 60%); pointer-events:none; }
.cta-band h2{ color:#fff; max-width:20ch; }
.cta-band p{ color:rgba(255,255,255,.9); max-width:48ch; }
.cta-band .btn-pill{ background:#fff; color:var(--accent-deep); box-shadow:0 10px 24px rgba(0,0,0,.18); }
.cta-band .btn-pill:hover{ background:#fff; color:var(--accent-deep); transform:translateY(-2px); }

/* ===================== ARTICLE ===================== */
.article-hero{ padding:clamp(2.4rem,5vw,3.6rem) 0 1.4rem; }
.crumbs{ font-family:var(--ff-mono); font-size:.8rem; color:var(--fg-faint); margin-bottom:1.1rem; }
.crumbs a{ color:var(--accent); text-decoration:none; }
.crumbs a:hover{ text-decoration:underline; }
.crumbs span{ margin:0 .45rem; color:var(--line-strong); }
.article-hero .topic-tag{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--ff-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); background:var(--teal-tint); padding:.4rem .9rem; border-radius:var(--r-pill); margin-bottom:1rem; }
.article-hero h1{ max-width:20ch; }
.article-rtl .article-hero h1{ font-family:var(--ff-body); font-weight:700; max-width:24ch; }
.article-meta{ display:flex; flex-wrap:wrap; gap:1.2rem; font-family:var(--ff-mono); font-size:.84rem; color:var(--fg-soft); margin-top:1rem; align-items:center; }
.article-meta .mi{ display:inline-flex; align-items:center; gap:.4rem; }
.article-feat{ margin:1.8rem 0 0; border-radius:var(--r-card); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); }
.article-feat img{ width:100%; max-height:440px; object-fit:cover; }

.article-layout{ display:grid; grid-template-columns:minmax(0,1fr) 260px; gap:clamp(2rem,4vw,3.4rem); align-items:start; padding:2.4rem 0 1rem; }
.article-rtl .article-layout{ grid-template-columns:260px minmax(0,1fr); }
.prose{ max-width:var(--measure); }
.prose > *{ }
.prose p, .prose li{ font-size:1.06rem; line-height:1.75; color:var(--fg); }
.prose h2{ font-size:clamp(1.5rem,2.4vw,1.9rem); margin:2.2rem 0 .8rem; }
.prose h3{ font-size:1.2rem; color:var(--secondary); margin:1.7rem 0 .6rem; }
.prose a{ color:var(--accent); font-weight:600; text-decoration:underline; text-decoration-color:rgba(31,111,107,.45); text-underline-offset:3px; }
.prose a:hover{ color:var(--accent-deep); text-decoration-color:var(--accent); }
.prose img{ border-radius:var(--r-card); margin:1.6rem 0; box-shadow:var(--shadow-sm); border:1px solid var(--line); width:100%; height:auto; }
.prose ul, .prose ol{ padding-inline-start:1.3rem; margin:0 0 1.2rem; }
.prose li{ margin-bottom:.5rem; }
.prose ul li::marker{ color:var(--accent); }
.prose ol li::marker{ color:var(--primary); font-family:var(--ff-mono); }
.prose strong{ color:var(--fg); }
.prose section{ margin:0; }
.prose section h2{ }
.article-rtl .prose{ max-width:var(--measure); }
.article-rtl .prose h2, .article-rtl .prose h3{ font-family:var(--ff-body); font-weight:700; color:var(--primary); }
.article-rtl .prose h3{ color:var(--secondary); }

/* sidebar */
.aside{ position:sticky; top:96px; display:flex; flex-direction:column; gap:1.2rem; }
.aside-card{ background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.4rem; box-shadow:var(--shadow-sm); }
.aside-card h4{ font-family:var(--ff-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin:0 0 .9rem; font-weight:700; }
.aside-card .src{ display:flex; align-items:center; gap:.7rem; text-decoration:none; color:var(--fg); padding:.55rem 0; border-bottom:1px solid var(--line); }
.aside-card .src:last-child{ border-bottom:none; }
.aside-card .src:hover{ color:var(--accent); }
.aside-card .src .ic{ display:grid; place-items:center; width:34px; height:34px; border-radius:9px; background:var(--teal-tint); color:var(--accent); flex:0 0 auto; }
.aside-card .src small{ display:block; font-family:var(--ff-mono); font-size:.72rem; color:var(--accent); }
.aside-cta{ background:linear-gradient(140deg,var(--rust-tint),var(--bg-card)); }
.aside-cta p{ font-size:.92rem; color:var(--fg-soft); margin:0 0 1rem; }
.aside-cta .btn{ width:100%; justify-content:center; color:#fff; }

.article-foot{ border-top:1px solid var(--line); margin-top:2rem; padding-top:2rem; }
.more-reading{ padding-bottom:1rem; }

/* ===================== ABOUT / SERVICES / CONTACT ===================== */
.page-hero{ padding:clamp(2.8rem,6vw,4.4rem) 0 clamp(1.4rem,3vw,2.4rem); }
.page-hero .lead{ font-size:clamp(1.08rem,1.5vw,1.25rem); color:var(--fg-soft); max-width:52ch; }
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,4vw,3.4rem); align-items:center; }
.split-img{ border-radius:var(--r-card); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); }
.split-img img{ width:100%; aspect-ratio:4/3.3; object-fit:cover; }
.prose-narrow{ max-width:var(--measure); }
.prose-narrow p{ color:var(--fg-soft); font-size:1.06rem; }

.team{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.member{ background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.7rem; box-shadow:var(--shadow-sm); text-align:center; }
.member .av{ display:grid; place-items:center; width:64px; height:64px; border-radius:18px; margin:0 auto 1rem; background:linear-gradient(140deg,var(--primary),var(--secondary)); color:#fff; }
.member h3{ margin:0 0 .2rem; font-size:1.2rem; }
.member .role{ font-family:var(--ff-mono); font-size:.78rem; color:var(--accent); letter-spacing:.06em; text-transform:uppercase; margin-bottom:.7rem; }
.member p{ color:var(--fg-soft); font-size:.94rem; margin:0; }

.svc-list{ display:grid; gap:1.4rem; }
.svc{ display:grid; grid-template-columns:64px 1fr; gap:1.4rem; background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.8rem; box-shadow:var(--shadow-sm); align-items:start; }
.svc .ico{ display:grid; place-items:center; width:64px; height:64px; border-radius:16px; background:var(--rust-tint); color:var(--primary); }
.svc .topic{ font-family:var(--ff-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.svc h3{ margin:.3rem 0 .5rem; }
.svc p{ color:var(--fg-soft); margin:0 0 1rem; }
.svc ul{ list-style:none; margin:0 0 1.1rem; padding:0; display:grid; gap:.5rem; }
.svc li{ display:flex; align-items:flex-start; gap:.6rem; color:var(--fg); font-size:.96rem; }
.svc li .ck{ color:var(--accent); flex:0 0 auto; margin-top:.05rem; }
.svc .link{ display:inline-flex; align-items:center; gap:.4rem; color:var(--accent); font-weight:600; text-decoration:none; }
.svc .link:hover svg{ transform:translateX(3px); }
.svc .link svg{ transition:transform .25s var(--ease); }

.faq-list{ display:grid; gap:.9rem; max-width:var(--measure); }
.faq{ background:var(--bg-card); border:1px solid var(--line); border-radius:var(--r-card); padding:1.3rem 1.5rem; box-shadow:var(--shadow-sm); }
.faq h3{ font-size:1.12rem; margin:0 0 .4rem; color:var(--primary); }
.faq p{ margin:0; color:var(--fg-soft); font-size:.98rem; }

/* ===================== CONTACT FORM ===================== */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,3rem); align-items:start; }
.contact-info .ci{ display:flex; gap:1rem; align-items:flex-start; padding:1.1rem 0; border-bottom:1px solid var(--line); }
.contact-info .ci:last-child{ border-bottom:none; }
.contact-info .ic{ display:grid; place-items:center; width:48px; height:48px; border-radius:13px; background:var(--teal-tint); color:var(--accent); flex:0 0 auto; }
.contact-info .ci h3{ margin:0 0 .2rem; font-size:1.05rem; color:var(--fg); font-family:var(--ff-body); font-weight:700; }
.contact-info .ci a{ color:var(--accent); text-decoration:none; font-weight:600; }
.contact-info .ci p{ margin:0; color:var(--fg-soft); font-size:.94rem; }

.form-card{ background:var(--bg-card); border:1px solid var(--line); border-radius:calc(var(--r-card) + 4px); padding:clamp(1.6rem,3vw,2.2rem); box-shadow:var(--shadow); }
.field{ margin-bottom:1.2rem; }
.field label{ display:block; font-weight:600; color:var(--fg); margin-bottom:.45rem; font-size:.95rem; }
.field .req{ color:var(--primary); }
.field input, .field textarea{ width:100%; font-family:var(--ff-body); font-size:1rem; color:var(--fg); background:var(--bg); border:1.5px solid var(--line-strong); border-radius:12px; padding:.85rem 1rem; transition:border-color .2s, box-shadow .2s; }
.field textarea{ min-height:128px; resize:vertical; line-height:1.6; }
.field input::placeholder, .field textarea::placeholder{ color:var(--fg-faint); }
.field input:focus, .field textarea:focus{ border-color:var(--accent); box-shadow:var(--ring); outline:none; }
.field input:user-invalid, .field textarea:user-invalid{ border-color:#B23A2E; }
.field .help{ font-size:.82rem; color:var(--fg-soft); margin-top:.4rem; }
.field .err{ display:none; font-size:.82rem; color:#9A2C22; margin-top:.4rem; }
.field input:user-invalid ~ .err, .field textarea:user-invalid ~ .err{ display:block; }
.form-card .btn{ width:100%; justify-content:center; font-size:1.05rem; padding:1rem; color:#fff; }
.form-ok{ display:none; align-items:center; gap:.7rem; background:var(--teal-tint); color:var(--accent-deep); border:1px solid rgba(31,111,107,.3); border-radius:12px; padding:1rem 1.2rem; margin-top:1rem; font-weight:600; }
.form-ok.show{ display:flex; }
.form-ok .ic{ display:grid; place-items:center; width:32px; height:32px; border-radius:50%; background:var(--accent); color:#fff; flex:0 0 auto; }

/* ===================== REVEAL ===================== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.stagger > *{ opacity:0; transform:translateY(20px); }
.stagger.in > *{ opacity:1; transform:none; transition:opacity .6s var(--ease), transform .6s var(--ease); }
.stagger.in > *:nth-child(2){ transition-delay:.08s; }
.stagger.in > *:nth-child(3){ transition-delay:.16s; }
.stagger.in > *:nth-child(4){ transition-delay:.24s; }

@media (prefers-reduced-motion:reduce){
  .reveal,.stagger>*{ opacity:1 !important; transform:none !important; transition:none !important; }
  .hero-card .sheen,.pillar-card .sheen{ display:none; }
  *{ scroll-behavior:auto !important; }
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:960px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-art{ order:-1; max-width:520px; margin-inline:auto; }
  .hero-float.f1,.hero-float.f2{ display:none; }
  .pillars,.values,.tests,.team,.reading-grid,.resources{ grid-template-columns:1fr 1fr; }
  .article-layout,.article-rtl .article-layout{ grid-template-columns:1fr; }
  .aside{ position:static; flex-direction:row; flex-wrap:wrap; }
  .aside-card{ flex:1 1 240px; }
  .split{ grid-template-columns:1fr; }
  .split-img{ order:-1; }
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .nav{ display:none; }
  .nav-toggle{ display:inline-grid; place-items:center; }
  .site-head.open .mobile-nav{ display:flex; }
  .trust-row{ grid-template-columns:1fr 1fr; gap:.6rem; }
  .pillars,.values,.tests,.team,.reading-grid,.resources,.svc-list{ grid-template-columns:1fr; }
  .svc{ grid-template-columns:1fr; }
  .svc .ico{ margin-bottom:.2rem; }
  .aside{ flex-direction:column; }
}
