/* =========================================================================
   Meenu S & Associates — shared design system
   One source of truth for tokens, chrome (header/footer), and page primitives.
   ========================================================================= */

:root{
  --bg:#F3EEE4; --panel:#FBF8F1; --ink:#16140E; --ink-soft:#6B6352; --hair:#DCD3C2;
  --accent:#B4541F; --accent-ink:#fff;
  --c-roc:#927A2E; --c-sebi:#3E7E96; --c-fema:#4E8C5A; --c-llp:#8E5BA6;
  --maxw:1680px; --gut:clamp(22px,4.5vw,88px); --measure:62ch;
  --sans:"Switzer",system-ui,sans-serif; --serif:"Sentient",Georgia,serif; --display:"Zodiak",Georgia,serif;
  --ease:cubic-bezier(.22,.61,.36,1); --tnum:"tnum" 1,"lnum" 1;
}
html[data-theme="dark"]{
  --bg:#100F0C; --panel:#16140F; --ink:#ECE5D5; --ink-soft:#938B7C; --hair:#2A2722;
  --accent:#E0894A; --accent-ink:#15130D;
  --c-roc:#CDBF9E; --c-sebi:#7FAEC0; --c-fema:#8FBE9A; --c-llp:#C39BD3;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:400;line-height:1.5;
  letter-spacing:-.011em;-webkit-font-smoothing:antialiased;overflow-x:clip;
  transition:background .55s var(--ease),color .55s var(--ease)}
::selection{background:var(--accent);color:var(--accent-ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.num{font-feature-settings:var(--tnum)}

/* ---- type ---- */
h1,h2,h3{font-weight:500;letter-spacing:-.035em;line-height:1.02}
.eyebrow{font-size:.71rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;color:var(--accent);display:inline-block}
.lede{font-size:clamp(1.05rem,1.5vw,1.32rem);font-weight:300;color:var(--ink-soft);line-height:1.5;max-width:46ch}
.serif-i{font-family:var(--serif);font-style:italic}

/* ---- header ---- */
header{position:fixed;inset:0 0 auto 0;z-index:50;transition:background .4s var(--ease),border-color .4s}
header.scr{background:color-mix(in srgb,var(--bg) 84%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--hair)}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center}
.logotype{font-family:var(--display);font-weight:500;letter-spacing:-.005em;font-size:1.2rem;line-height:1}
.logotype .mk{font-style:italic;color:var(--accent)}
.navlinks{display:flex;gap:1.7rem;align-items:center}
.navlinks a{font-size:.85rem;color:var(--ink-soft);font-weight:450;position:relative;transition:color .3s}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--accent);transition:width .35s var(--ease)}
.navlinks a:hover,.navlinks a[aria-current="page"]{color:var(--ink)}
.navlinks a:hover::after,.navlinks a[aria-current="page"]::after{width:100%}
.nav-r{display:flex;align-items:center;gap:1.1rem}
.tg{width:34px;height:34px;border:1px solid var(--hair);border-radius:50%;background:none;color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:border-color .3s,transform .5s var(--ease)}
.tg:hover{border-color:var(--accent);transform:rotate(25deg)}.tg svg{width:15px;height:15px}
.cta{font-size:.82rem;font-weight:500;padding:.5rem 1.05rem;border:1px solid var(--ink);border-radius:40px;transition:background .3s,color .3s;white-space:nowrap}
.cta:hover{background:var(--ink);color:var(--bg)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:22px;height:1.5px;background:var(--ink);transition:.35s var(--ease)}
.mobpanel{position:fixed;inset:0;z-index:49;background:var(--bg);transform:translateY(-100%);transition:transform .5s var(--ease);
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;padding:var(--gut)}
.mobpanel.open{transform:translateY(0)}
.mobpanel a{font-size:1.9rem;font-weight:500;letter-spacing:-.03em;padding:.5rem 0;border-bottom:1px solid var(--hair);font-family:var(--display)}
.mobpanel a .mk{font-style:italic;color:var(--accent)}

/* ---- page header (inner pages) ---- */
.pagehead{padding-top:clamp(120px,15vh,180px);padding-bottom:clamp(2.4rem,5vw,4.2rem)}
.pagehead h1{font-size:clamp(2.4rem,5.2vw,4.6rem);margin:1rem 0 0;max-width:18ch}
.pagehead .lede{margin-top:1.6rem;max-width:52ch}
.pagehead.center{text-align:center}
.pagehead.center .lede{margin-inline:auto}

/* ---- sections ---- */
.section{padding-block:clamp(3rem,7vw,6.5rem)}
.section.tight{padding-block:clamp(2rem,4vw,3.5rem)}
.section + .section{border-top:1px solid var(--hair)}
.sec-head{max-width:60ch;margin-bottom:clamp(2rem,4vw,3.4rem)}
.sec-head h2{font-size:clamp(1.7rem,3vw,2.6rem);margin-top:.7rem}
.sec-head p{color:var(--ink-soft);font-weight:300;margin-top:1rem;font-size:1.05rem;max-width:52ch}

/* ---- grids & cards ---- */
.grid{display:grid;gap:clamp(1rem,2vw,1.6rem)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{border:1px solid var(--hair);border-radius:16px;padding:clamp(1.5rem,2.4vw,2.1rem);background:var(--panel);
  transition:border-color .35s var(--ease),transform .35s var(--ease)}
.card:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--hair));transform:translateY(-3px)}
.card .kicker{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600}
.card h3{font-size:1.22rem;margin:.85rem 0 .55rem;letter-spacing:-.02em}
.card p{color:var(--ink-soft);font-weight:300;font-size:.95rem;line-height:1.55}
.card ul{list-style:none;margin-top:.9rem;display:flex;flex-direction:column;gap:.4rem}
.card ul li{font-size:.85rem;color:var(--ink-soft);padding-left:1rem;position:relative}
.card ul li::before{content:"";position:absolute;left:0;top:.6em;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.7}

/* feature row (alternating) */
.feature{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,4vw,4rem);align-items:start;padding-block:clamp(2rem,4vw,3.2rem)}
.feature + .feature{border-top:1px solid var(--hair)}
.feature .f-no{font-family:var(--display);font-size:2.2rem;color:var(--accent);line-height:1}
.feature h3{font-size:clamp(1.4rem,2.4vw,2rem);margin:.4rem 0 0}
.feature p{color:var(--ink-soft);font-weight:300;margin-top:1rem;max-width:54ch}
.feature .f-list{list-style:none;margin-top:1.2rem;display:grid;gap:.55rem}
.feature .f-list li{font-size:.92rem;color:var(--ink-soft);padding-left:1.3rem;position:relative}
.feature .f-list li::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:1px;background:var(--accent)}

/* ---- prose (articles) ---- */
.prose{max-width:var(--measure);margin-inline:auto}
.prose p{margin-top:1.2rem;color:var(--ink);font-weight:300;font-size:1.08rem;line-height:1.7}
.prose h2{font-size:1.6rem;margin-top:2.6rem}
.prose h3{font-size:1.22rem;margin-top:1.9rem}
.prose ul,.prose ol{margin:1.1rem 0 0 1.1rem;color:var(--ink-soft);font-weight:300}
.prose li{margin-top:.5rem;line-height:1.6}
.prose blockquote{margin:1.8rem 0;padding-left:1.2rem;border-left:2px solid var(--accent);font-family:var(--serif);font-style:italic;color:var(--ink);font-size:1.15rem}
.prose strong{font-weight:500;color:var(--ink)}
.prose a{color:var(--accent);border-bottom:1px solid color-mix(in srgb,var(--accent) 45%,transparent)}

/* ---- article list (insights) ---- */
.artlist{display:flex;flex-direction:column;border-top:1px solid var(--hair)}
.artrow{display:grid;grid-template-columns:140px 1fr auto;gap:1.5rem;align-items:baseline;padding:1.6rem 0;border-bottom:1px solid var(--hair);transition:padding .35s var(--ease)}
.artrow:hover{padding-left:.6rem}
.artrow .date{font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em;text-transform:uppercase}
.artrow .t{font-size:1.2rem;font-weight:500;letter-spacing:-.02em}
.artrow .t span{display:block;font-weight:300;font-size:.92rem;color:var(--ink-soft);margin-top:.4rem;letter-spacing:0;max-width:60ch}
.artrow .go{color:var(--accent);font-size:1.1rem;transition:transform .3s var(--ease)}
.artrow:hover .go{transform:translateX(4px)}
.tag{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--ink-soft)}
.tag i{width:8px;height:8px;border-radius:50%}

/* ---- definition / contact ---- */
.deflist{display:grid;gap:1.4rem}
.deflist .row{display:grid;grid-template-columns:160px 1fr;gap:1.2rem;padding-bottom:1.2rem;border-bottom:1px solid var(--hair)}
.deflist .k{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);padding-top:.2rem}
.deflist .v{font-size:1.05rem;font-weight:300}
.deflist .v a{color:var(--accent);border-bottom:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}

/* ---- links / buttons ---- */
.link-arrow{font-size:.9rem;font-weight:500;color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:3px;display:inline-block;transition:gap .3s}
.btn{display:inline-block;font-size:.9rem;font-weight:500;padding:.7rem 1.4rem;border-radius:40px;border:1px solid var(--ink);transition:background .3s,color .3s}
.btn:hover{background:var(--ink);color:var(--bg)}
.btn.solid{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn.solid:hover{filter:brightness(1.06)}

/* ---- callout strip ---- */
.callout{border:1px solid var(--hair);border-radius:20px;background:var(--panel);padding:clamp(2rem,5vw,4rem);text-align:center}
.callout h2{font-size:clamp(1.7rem,3.4vw,2.8rem);max-width:20ch;margin:0 auto}
.callout p{color:var(--ink-soft);font-weight:300;margin:1.1rem auto 0;max-width:50ch}
.callout .actions{margin-top:2rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---- footer ---- */
.site-footer{border-top:1px solid var(--hair);padding-block:clamp(3rem,5vw,4.5rem) 2rem;margin-top:clamp(3rem,6vw,6rem);font-weight:300;letter-spacing:-.006em}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2rem;padding-bottom:2.6rem;border-bottom:1px solid var(--hair)}
.foot-brand p{color:var(--ink-soft);font-size:.86rem;font-weight:300;margin-top:.8rem}
.foot-nav{display:flex;flex-direction:column;gap:.6rem}
.foot-nav h4{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:.3rem}
.foot-nav a{font-size:.88rem;color:var(--ink-soft);font-weight:300;transition:color .3s}
.foot-nav a:hover{color:var(--accent)}
.disc-l{font-size:.72rem;color:var(--ink-soft);font-weight:200;line-height:1.7;margin-top:1.8rem}
.disc-l b{color:var(--ink);font-weight:500}
.fbot{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.4rem;font-size:.78rem;color:var(--ink-soft)}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---- responsive ---- */
@media(max-width:1000px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
}
@media(max-width:760px){
  .navlinks,.nav .cta{display:none}
  .burger{display:flex}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .feature{grid-template-columns:1fr;gap:1rem}
  .artrow{grid-template-columns:1fr;gap:.4rem}
  .artrow .go{display:none}
  .deflist .row{grid-template-columns:1fr;gap:.3rem}
  .foot-top{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
