/* SHAVIM — shared design system (mirrors shavim-2026.html). Used by interior pages. */
:root{
  --sand:#F4F1E8; --clay:#E7E2D6; --sage:#6B7F6B; --sage-soft:#6b7f6b40;
  --terracotta:#C76E48; --soil:#2B2B2B;
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Inter',-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--sand);color:var(--soil);font-family:var(--sans);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:var(--soil);text-decoration:none}

.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.narrow{max-width:760px;margin:0 auto;padding:0 32px}
section{padding:120px 0}
.hair{height:1px;background:var(--sage-soft);border:0;width:100%}

h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.08;letter-spacing:.01em}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:1.7rem;font-weight:400}
.eyebrow{font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);font-weight:500}
.lead{font-size:1.15rem;max-width:620px}
.italic{font-family:var(--serif);font-style:italic;color:var(--sage)}

header{position:sticky;top:0;z-index:50;background:rgba(244,241,232,.86);backdrop-filter:blur(8px)}
nav{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;max-width:1240px;margin:0 auto}
.brand{display:flex;align-items:center;gap:13px}
.brand-mark{height:42px;width:auto;display:block}
.mark{font-family:var(--serif);font-size:1.5rem;letter-spacing:.42em;font-weight:400;padding-left:.42em}
.navlinks{display:flex;gap:30px;font-size:.82rem;letter-spacing:.04em}
.navlinks a{color:var(--soil);transition:color .2s}
.navlinks a:hover{color:var(--sage)}
.navbtn{border:1px solid var(--sage);color:var(--sage);padding:9px 20px;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}
.lang{display:inline-flex;gap:9px;font-size:.74rem;letter-spacing:.1em;margin-left:16px;align-items:center}
.lang a{color:#aaa498}
.lang a.on{color:var(--soil);font-weight:500}
.navtoggle{position:absolute;opacity:0;pointer-events:none}
.hamburger{display:none;cursor:pointer;font-size:1.5rem;line-height:1;color:var(--soil);user-select:none;padding:2px 6px}
@media(max-width:980px){
  nav{flex-wrap:wrap}
  .navlinks{display:none;order:4;flex-basis:100%;flex-direction:column;gap:0;margin-top:12px}
  .navtoggle:checked ~ .navlinks{display:flex}
  .navlinks a{padding:13px 2px;border-top:1px solid var(--sage-soft)}
  .hamburger{display:block;order:2;margin-left:auto}
  .navbtn{order:3;margin-left:14px}
}

.campus{background:var(--clay)}
.map-hint{font-size:.78rem;color:#8a8474;margin-top:18px;letter-spacing:.02em}

footer{background:var(--soil);color:#cfc9bb;padding:80px 0 48px}
footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
@media(max-width:760px){footer .wrap{grid-template-columns:1fr;gap:32px}}
footer .mark{color:#fff}
footer h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#8f897b;margin-bottom:16px;font-weight:500}
footer a{color:#cfc9bb;font-size:.9rem;display:block;margin-bottom:10px}
footer a:hover{color:#fff}
.foot-tag{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:#cfc9bb;margin-top:14px}
.foot-bottom{max-width:1240px;margin:48px auto 0;padding:24px 32px 0;border-top:1px solid #3d3d3d;font-size:.74rem;color:#8f897b;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

.btn{display:inline-block;background:var(--sage);color:var(--sand);padding:15px 34px;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin-top:36px}

.statement{font-family:var(--serif);font-weight:300;font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1.34;max-width:24ch}
.statement .italic{display:inline}
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:44px;margin-top:56px}
@media(max-width:860px){.cols3{grid-template-columns:1fr;gap:38px}}
.col .num{font-family:var(--serif);font-size:1rem;color:var(--terracotta);letter-spacing:.1em}
.col h3{font-size:1.45rem;margin:12px 0 10px}
.col p{font-size:.98rem;color:#5c5a52}
.lead-block{max-width:640px;margin-top:22px;font-size:1.12rem;color:#5c5a52}

.connect{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:52px}
@media(max-width:860px){.connect{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.connect{grid-template-columns:1fr}}
.node{border:1px solid var(--sage-soft);padding:22px 20px;background:rgba(244,241,232,.5)}
.node .k{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:6px}
.node p{font-size:.86rem;color:#5c5a52}

.legacy{display:grid;grid-template-columns:repeat(2,1fr);gap:0 56px;margin-top:48px}
@media(max-width:700px){.legacy{grid-template-columns:1fr}}
.legacy .li{padding:24px 0;border-bottom:1px solid var(--sage-soft);font-size:1.12rem;font-family:var(--serif);font-weight:400}
.legacy .li span{display:block;font-family:var(--sans);font-size:.92rem;color:#5c5a52;margin-top:6px}

.movement{background:var(--soil);color:var(--sand);text-align:center}
.movement .eyebrow{color:#9fae9f}
.movement .statement{margin:18px auto 0;color:var(--sand);max-width:22ch}
.movement p{max-width:50ch;margin:24px auto 0;color:#b9b3a4;font-size:1.05rem}

.sig-stamp{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--sage);text-align:center;letter-spacing:.01em}
.sig-line{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:30px}
.sig-line::before,.sig-line::after{content:'';height:1px;width:54px;background:var(--sage-soft)}

.brand-stack{display:flex;flex-direction:column;line-height:1}
.brand-stack .mark{padding-left:0}
.brand-stack .sub{font-family:var(--sans);font-size:.58rem;letter-spacing:.36em;text-transform:uppercase;color:var(--sage);margin-top:3px;padding-left:.2em}

.build{background:var(--soil);color:var(--sand)}
.build .eyebrow{color:#9fae9f}
.build h2,.build .statement{color:var(--sand)}
.build .lead-block{color:#b9b3a4}
.builders{display:flex;flex-wrap:wrap;gap:12px;margin-top:46px}
.builders .role{border:1px solid #4a4a4a;color:#e7e2d6;padding:13px 22px;font-family:var(--serif);font-size:1.05rem;transition:all .2s}
.builders .role:hover{border-color:var(--sage);background:rgba(107,127,107,.18)}
.btn-light{display:inline-block;background:var(--sand);color:var(--soil);padding:15px 34px;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin-top:36px}

/* ---------- interior-page additions ---------- */
.pagehead{background:var(--clay);padding:84px 0 78px}
.pagehead .lead-block{color:#5c5a52}
.backlink{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);display:inline-block;margin-bottom:24px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:52px}
@media(max-width:860px){.grid3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid3{grid-template-columns:1fr}}
.node .feeds{font-size:.82rem;color:var(--sage);margin-top:10px;display:block;font-weight:500;letter-spacing:.02em}
.future-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:46px 56px;margin-top:54px}
@media(max-width:760px){.future-grid{grid-template-column