
:root{
  --primary:#475569;
  --secondary:#78716C;
  --accent:#BE185D;
  --bg:#FBF8F4;
  --fg:#1F2933;
  --paper:#FFFFFF;
  --line:#E7DFD4;
  --line-soft:#EFE9E0;
  --accent-ink:#9D1350;
  --shadow-sm:0 1px 2px rgba(31,41,51,.05),0 6px 16px -10px rgba(31,41,51,.18);
  --shadow-md:0 4px 10px -4px rgba(31,41,51,.10),0 24px 48px -28px rgba(31,41,51,.30);
  --r-sm:8px;
  --r:14px;
  --r-lg:22px;
  --measure:65ch;
  --display:"Zilla Slab",Georgia,serif;
  --body:"Nunito Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:"Fira Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--body);
  color:var(--fg);
  background:var(--bg);
  font-size:18px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1100px 720px at 86% -8%, rgba(190,24,93,.07), transparent 60%),
    radial-gradient(1000px 760px at -6% 8%, rgba(71,85,105,.10), transparent 58%),
    linear-gradient(180deg,#FBF8F4 0%,#F7F2EB 100%);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-ink);text-underline-offset:3px;text-decoration-thickness:1.5px}
a:hover{color:var(--accent)}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.12;color:var(--fg);letter-spacing:-.01em;margin:0}
p{margin:0 0 1.1em}
::selection{background:rgba(190,24,93,.18)}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px}

.wrap{width:min(1200px,92vw);margin-inline:auto}
.narrow{width:min(760px,92vw);margin-inline:auto}

/* ---------- Skip link ---------- */
.skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--r-sm) 0;z-index:200;font-weight:700}
.skip:focus{left:0}

/* ---------- Header ---------- */
.site-head{position:sticky;top:0;z-index:100;background:rgba(251,248,244,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.head-row{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.9rem 0}
.brand{display:inline-flex;align-items:center;gap:.62rem;font-family:var(--display);font-weight:700;font-size:1.42rem;letter-spacing:-.02em;color:var(--fg);text-decoration:none}
.brand:hover{color:var(--fg)}
.brand .mark{width:30px;height:30px;flex:none;border-radius:9px;background:linear-gradient(150deg,var(--primary),#34404f);position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.brand .mark::after{content:"";position:absolute;inset:0;display:block;background:radial-gradient(circle at 50% 38%, var(--accent) 0 28%, transparent 30%);opacity:.95}
.nav{display:flex;align-items:center;gap:.4rem}
.nav a{font-family:var(--body);font-weight:600;font-size:.96rem;color:var(--fg);text-decoration:none;padding:.5rem .8rem;border-radius:999px;transition:background .2s var(--ease),color .2s var(--ease)}
.nav a:hover{background:rgba(71,85,105,.10)}
.nav a[aria-current="page"]{color:var(--accent-ink);background:rgba(190,24,93,.10)}
.nav .cta{background:var(--accent);color:#fff;padding:.56rem 1.05rem}
.nav .cta:hover{background:var(--accent-ink);color:#fff}
.nav-toggle{display:none;border:1px solid var(--line);background:var(--paper);border-radius:10px;padding:.5rem .7rem;font:inherit;font-weight:700;cursor:pointer;color:var(--fg)}
@media(max-width:860px){
  .nav{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;gap:.2rem;background:var(--bg);border-bottom:1px solid var(--line);padding:.7rem 6vw 1.1rem;transform:translateY(-130%);transition:transform .38s var(--ease);box-shadow:var(--shadow-md)}
  .nav.open{transform:translateY(0)}
  .nav a{padding:.85rem .6rem;font-size:1.05rem}
  .nav .cta{text-align:center;margin-top:.4rem}
  .nav-toggle{display:inline-block}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--body);font-weight:700;font-size:1rem;border-radius:999px;padding:.85rem 1.5rem;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 26px -12px rgba(190,24,93,.7)}
.btn-primary:hover{background:var(--accent-ink);color:#fff;transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(190,24,93,.75)}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--primary);background:rgba(71,85,105,.06);color:var(--fg);transform:translateY(-2px)}
.btn .arr{transition:transform .25s var(--ease)}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- Kicker / eyebrow (used sparingly) ---------- */
.kicker{font-family:var(--mono);font-size:.74rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-ink);margin:0 0 1rem;display:inline-block}

/* ---------- Hero ---------- */
.hero{position:relative;padding:4.6rem 0 3.4rem}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{font-size:clamp(2.5rem,5.4vw,4rem);line-height:1.04;letter-spacing:-.025em;max-width:14ch}
.hero h1 em{font-style:italic;color:var(--accent-ink);font-weight:600}
.hero .sub{font-size:1.2rem;color:var(--fg);max-width:46ch;margin:1.4rem 0 2rem;line-height:1.6}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.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-md)}
.hero-media .frame img{width:100%;aspect-ratio:4/5;object-fit:cover}
.hero-media .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(200deg,rgba(71,85,105,.05),rgba(190,24,93,.12));mix-blend-mode:multiply}
.hero-chip{position:absolute;left:-18px;bottom:26px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:.85rem 1.05rem;box-shadow:var(--shadow-md);max-width:230px}
.hero-chip strong{font-family:var(--display);display:block;font-size:1.05rem}
.hero-chip span{font-size:.86rem;color:var(--secondary)}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:2.2rem}
  .hero{padding:3rem 0 2.4rem}
  .hero-chip{left:8px}
}

/* ---------- Section scaffolding ---------- */
section.band{padding:4.4rem 0;position:relative}
.sec-head{max-width:60ch;margin-bottom:2.6rem}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);letter-spacing:-.02em}
.sec-head p{color:var(--secondary);font-size:1.1rem;margin-top:.9rem;max-width:58ch}
.lead{font-size:1.18rem;line-height:1.7;max-width:var(--measure)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.stat{background:var(--paper);padding:1.7rem 1.4rem}
.stat .n{font-family:var(--display);font-weight:700;font-size:2.5rem;line-height:1;color:var(--primary);letter-spacing:-.02em}
.stat .l{margin-top:.55rem;color:var(--secondary);font-size:.95rem}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- Featured articles / blogroll ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.6rem}
.card{grid-column:span 4;display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#dcd2c4}
.card .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--line-soft)}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card:hover .thumb img{transform:scale(1.04)}
.card .body{padding:1.3rem 1.35rem 1.5rem;display:flex;flex-direction:column;flex:1}
.card .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;color:var(--primary);margin-bottom:.7rem}
.card h3{font-size:1.32rem;line-height:1.18;letter-spacing:-.01em}
.card h3 a{color:var(--fg);text-decoration:none}
.card:hover h3 a{color:var(--accent-ink)}
.card .label{color:var(--secondary);font-size:.96rem;margin-top:.6rem;line-height:1.5}
.card .more{margin-top:auto;padding-top:1.05rem;font-weight:700;font-size:.92rem;color:var(--accent-ink);display:inline-flex;gap:.4rem;align-items:center}
/* editorial asymmetry: first card spans wider */
.feat-grid .card.lead-card{grid-column:span 8;flex-direction:row}
.feat-grid .card.lead-card .thumb{aspect-ratio:auto;width:46%;flex:none}
.feat-grid .card.lead-card .body{justify-content:center}
.feat-grid .card.lead-card h3{font-size:1.7rem}
@media(max-width:980px){
  .card,.feat-grid .card.lead-card{grid-column:span 12}
  .feat-grid .card.lead-card{flex-direction:column}
  .feat-grid .card.lead-card .thumb{width:100%;aspect-ratio:16/9}
}

/* ---------- Blogroll (resources) ---------- */
.roll{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 2.4rem;border-top:1px solid var(--line);padding-top:1.8rem}
.roll li{list-style:none;padding:.2rem 0;border-bottom:1px solid var(--line-soft);padding-bottom:1rem}
.roll a{font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--fg);text-decoration:none}
.roll a:hover{color:var(--accent-ink)}
.roll .src{display:block;font-family:var(--mono);font-size:.74rem;color:var(--secondary);margin-top:.35rem;letter-spacing:.02em}
@media(max-width:680px){.roll{grid-template-columns:1fr}}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.9rem 1.7rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent))}
.svc .ico{width:46px;height:46px;border-radius:12px;background:rgba(71,85,105,.10);display:grid;place-items:center;margin-bottom:1.1rem;color:var(--primary)}
.svc h3{font-size:1.3rem;margin-bottom:.6rem}
.svc p{color:var(--secondary);font-size:1rem;margin:0}
@media(max-width:880px){.svc-grid{grid-template-columns:1fr}}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem 1.7rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.quote blockquote{margin:0;font-family:var(--display);font-size:1.18rem;line-height:1.45;font-weight:500;color:var(--fg)}
.quote .who{margin-top:1.3rem;display:flex;align-items:center;gap:.8rem}
.quote .av{width:42px;height:42px;border-radius:50%;flex:none;background:linear-gradient(150deg,var(--primary),var(--accent));color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700}
.quote .who b{display:block;font-size:.98rem}
.quote .who span{font-size:.84rem;color:var(--secondary)}
@media(max-width:880px){.quotes{grid-template-columns:1fr}}

/* ---------- Team ---------- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.member{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.7rem;box-shadow:var(--shadow-sm)}
.member .av{width:58px;height:58px;border-radius:16px;background:linear-gradient(150deg,var(--primary),#34404f);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.3rem;margin-bottom:1.1rem}
.member h3{font-size:1.22rem}
.member .role{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);margin:.35rem 0 .8rem}
.member p{color:var(--secondary);font-size:.97rem;margin:0}
@media(max-width:880px){.team{grid-template-columns:1fr}}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(140deg,var(--primary),#384351);color:#fff;border-radius:var(--r-lg);padding:clamp(2.4rem,5vw,3.6rem);position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
.cta-band::after{content:"";position:absolute;width:380px;height:380px;right:-90px;top:-120px;border-radius:50%;background:radial-gradient(circle,rgba(190,24,93,.55),transparent 65%)}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.6rem);max-width:18ch;position:relative}
.cta-band p{color:rgba(255,255,255,.86);max-width:48ch;margin:1rem 0 1.8rem;position:relative}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}

/* ---------- Forms ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-md)}
.field{margin-bottom:1.25rem}
.field label{display:block;font-weight:700;font-size:.95rem;margin-bottom:.5rem;color:var(--fg)}
.field input,.field textarea{width:100%;font:inherit;font-size:1rem;color:var(--fg);background:var(--bg);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.85rem 1rem;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.field textarea{min-height:148px;resize:vertical;line-height:1.6}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px rgba(190,24,93,.14)}
.form-note{font-size:.9rem;color:var(--secondary);margin-top:1rem}
.form-ok{display:none;margin-top:1.1rem;padding:.9rem 1.1rem;border-radius:var(--r-sm);background:rgba(71,85,105,.10);border:1px solid var(--line);color:var(--fg);font-weight:600}
.form-ok.show{display:block}

/* ---------- Contact layout ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.6rem;align-items:start}
.contact-aside .pill{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:.5rem .9rem;font-size:.9rem;color:var(--secondary);margin-bottom:1.4rem}
.contact-list{list-style:none;padding:0;margin:1.6rem 0 0}
.contact-list li{padding:1.1rem 0;border-top:1px solid var(--line-soft)}
.contact-list .k{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--primary)}
.contact-list .v{font-family:var(--display);font-size:1.25rem;font-weight:600;margin-top:.25rem}
.contact-list .v a{color:var(--fg);text-decoration:none}
.contact-list .v a:hover{color:var(--accent-ink)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:1.8rem}}

/* ---------- Article ---------- */
.article-hero{padding:3.2rem 0 1.4rem}
.crumbs{font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;color:var(--secondary);margin-bottom:1.3rem}
.crumbs a{color:var(--primary);text-decoration:none}
.crumbs a:hover{color:var(--accent-ink)}
.article-hero h1{font-size:clamp(2rem,4.4vw,3.1rem);line-height:1.08;letter-spacing:-.02em;max-width:20ch}
.article-meta{display:flex;flex-wrap:wrap;gap:.8rem 1.4rem;margin-top:1.3rem;color:var(--secondary);font-size:.95rem;align-items:center}
.article-meta .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);background:rgba(190,24,93,.10);padding:.3rem .7rem;border-radius:999px}
.article-cover{margin:2rem 0 .6rem;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md)}
.article-cover img{width:100%;aspect-ratio:16/8;object-fit:cover}
.prose{max-width:var(--measure);margin-inline:auto;font-size:1.12rem;line-height:1.75;color:var(--fg)}
.prose p{margin:0 0 1.25em}
.prose h2{font-size:1.85rem;margin:2.3rem 0 .9rem;letter-spacing:-.015em}
.prose h3{font-size:1.35rem;margin:1.9rem 0 .7rem;color:var(--primary)}
.prose a{color:var(--accent-ink);font-weight:600;text-decoration:underline;text-decoration-color:rgba(190,24,93,.4)}
.prose a:hover{text-decoration-color:var(--accent)}
.prose ul,.prose ol{margin:0 0 1.3em;padding-inline-start:1.3em}
.prose li{margin:.4em 0}
.prose img{border-radius:var(--r);margin:1.6rem auto;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.prose figure{margin:1.8rem 0}
.prose figure img{margin:0}
.prose em{font-style:italic}
.prose strong{font-weight:700}
.prose section{margin:0 0 1.25em}
.prose blockquote{border-inline-start:3px solid var(--accent);padding-inline-start:1.2rem;margin:1.5rem 0;font-family:var(--display);font-style:italic;color:var(--primary)}
.prose[dir="rtl"]{text-align:right}
.prose[dir="rtl"] .article-cover{direction:ltr}
.article-foot{max-width:var(--measure);margin:2.6rem auto 0;padding-top:1.8rem;border-top:1px solid var(--line)}
.source-box{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem 1.4rem;box-shadow:var(--shadow-sm)}
.source-box .k{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem}
.source-box a{font-weight:700;color:var(--accent-ink)}

/* ---------- Footer ---------- */
.site-foot{margin-top:4.4rem;background:#2A333E;color:#E6E2DB;padding:3.4rem 0 2rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
.foot-top .brand{color:#fff}
.foot-top .brand:hover{color:#fff}
.foot-blurb{color:#B9BEC6;max-width:34ch;margin-top:1rem;font-size:.98rem}
.foot-col h4{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#9AA1AB;margin:0 0 1rem}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col li{margin:.55rem 0}
.foot-col a{color:#E6E2DB;text-decoration:none;font-size:.98rem}
.foot-col a:hover{color:#fff;text-decoration:underline;text-decoration-color:var(--accent)}
.foot-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;margin-top:2.6rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12);color:#9AA1AB;font-size:.88rem}
@media(max-width:760px){.foot-top{grid-template-columns:1fr;gap:1.6rem}}

/* ---------- Reveal (default hidden, JS adds .in). threshold:0 driven. ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal="left"]{transform:translateX(-34px)}
[data-reveal="right"]{transform:translateX(34px)}
[data-reveal].in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .card:hover,.btn:hover{transform:none!important}
}
