:root{
  --paper:#f3efe5; --paper-2:#ece5d6; --card:#faf7f0;
  --ink:#1b2b26; --ink-2:#3c4a44; --ink-soft:#69756e;
  --spruce:#1f5b4c; --spruce-d:#163f34; --brass:#a9803f; --brass-l:#c19a5a;
  --line:#d8d0bf; --line-2:#c8bfa9;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',-apple-system,Segoe UI,sans-serif;
  --wrap:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
/* faint paper grain */
body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E")}
.wrap{width:min(var(--wrap),90%);margin-inline:auto}
a{color:var(--spruce);text-decoration:none}
em{font-style:italic}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;color:var(--ink);line-height:1.08;margin:0}
.kicker{font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--brass)}
/* ---- masthead ---- */
.mast{position:sticky;top:0;z-index:60;background:rgba(243,239,229,.86);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.mast-in{display:flex;align-items:center;gap:2rem;padding:.9rem 0}
.logo{display:flex;align-items:center;gap:.85rem;color:var(--ink)}
.logo-mono{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:.04em;color:var(--spruce);line-height:1}
.logo-mono span{color:var(--brass)}
.logo-mono.big{font-size:2.4rem}
.logo-name{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;line-height:1.4;color:var(--ink-2);border-left:1px solid var(--line-2);padding-left:.85rem}
.logo-name em{font-style:normal;color:var(--ink-soft)}
.nav{margin-left:auto;display:flex;gap:1.8rem}
.nav a{font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);position:relative;padding:.2rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--brass);transition:width .3s}
.nav a:hover{color:var(--ink)}.nav a:hover::after{width:100%}
.mast-tel{font-family:var(--serif);font-size:1rem;color:var(--ink);padding-left:1.8rem;border-left:1px solid var(--line)}
.mast-tel:hover{color:var(--spruce)}
.burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;margin-left:auto}
.burger span{width:26px;height:1.5px;background:var(--ink)}
/* ---- hero ---- */
.hero{border-bottom:1px solid var(--line);overflow:hidden}
.hero-in{padding:clamp(3.5rem,9vw,7rem) 0 clamp(2.5rem,5vw,4rem)}
.hero-h{font-size:clamp(2.7rem,8.5vw,6.4rem);font-weight:400;letter-spacing:-.02em;margin:1.4rem 0 0;font-optical-sizing:auto}
.hero-h em{color:var(--spruce)}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-top:clamp(2rem,5vw,3.5rem)}
.hero-foot p{max-width:42ch;font-size:1.18rem;color:var(--ink-2);margin:0}
.link-cta{font-family:var(--sans);font-weight:600;letter-spacing:.04em;color:var(--ink);border-bottom:1px solid var(--brass);padding-bottom:.25rem;white-space:nowrap}
.link-cta span{display:inline-block;transition:transform .3s;color:var(--brass)}
.link-cta:hover span{transform:translateY(3px)}
.link-cta.big{font-size:1.15rem}.link-cta.big:hover span{transform:translateX(5px)}
.ticker{border-top:1px solid var(--line);background:var(--paper-2)}
.ticker-in{display:flex;gap:1.4rem;align-items:center;padding:.85rem 0;font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);flex-wrap:wrap}
.ticker .dot{color:var(--brass)}
/* ---- lede / two-col ---- */
.two-col{display:grid;grid-template-columns:200px 1fr;gap:3rem;padding:clamp(3rem,7vw,6rem) 0}
.col-label{position:sticky;top:120px;align-self:start}
.prose{max-width:68ch;font-size:1.12rem;color:var(--ink-2)}
.prose p{margin:0 0 1.3em}
.prose h2{font-size:1.9rem;margin:1.8em 0 .5em;color:var(--ink);font-weight:500}
.prose h3{font-size:1.35rem;margin:1.5em 0 .4em}
.prose ul,.prose ol{padding-left:1.2em;margin:0 0 1.3em}.prose li{margin:.45em 0}
.prose a{color:var(--spruce);border-bottom:1px solid var(--line-2)}.prose a:hover{border-color:var(--spruce)}
.prose strong{color:var(--ink)}
.prose blockquote{margin:1.6em 0;padding-left:1.4rem;border-left:2px solid var(--brass);font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink)}
.lede>p:first-of-type{font-size:1.4rem;line-height:1.55;color:var(--ink);font-family:var(--serif);font-weight:400}
.lede>p:first-of-type::first-letter{float:left;font-family:var(--serif);font-weight:500;font-size:4.6rem;line-height:.78;padding:.35rem .6rem 0 0;color:var(--spruce)}
/* ---- section rule ---- */
.sec-rule{display:flex;align-items:center;gap:1.5rem;padding-bottom:2.5rem}
.sec-line{flex:1;height:1px;background:var(--line)}
.principles{padding:clamp(2.5rem,5vw,4rem) 0;border-top:1px solid var(--line)}
.prin-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.prin-list li{display:flex;gap:1.1rem;align-items:flex-start}
.roman{font-family:var(--serif);font-size:1.5rem;color:var(--brass);line-height:1;padding-top:.1rem;min-width:1.6rem}
.prin-list h3{font-size:1.3rem;margin:0 0 .5rem;font-weight:500}
.prin-list p{margin:0;color:var(--ink-soft);font-size:1rem}
/* ---- contents index ---- */
.contents{padding:clamp(3rem,6vw,5rem) 0;border-top:1px solid var(--line);background:var(--paper-2)}
.entries{border-top:1px solid var(--line-2)}
.entry{display:flex;align-items:center;gap:2rem;padding:1.7rem .5rem;border-bottom:1px solid var(--line-2);transition:padding .35s,background .35s}
.entry:hover{padding-left:1.4rem;background:rgba(31,91,76,.05)}
.num{font-family:var(--serif);font-size:1.15rem;color:var(--brass);min-width:2.4rem}
.entry-main{display:flex;flex-direction:column;gap:.25rem;flex:1}
.cat{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.etitle{font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,1.85rem);font-weight:400;color:var(--ink);line-height:1.15}
.entry:hover .etitle{color:var(--spruce)}
.arrow{font-size:1.4rem;color:var(--brass);opacity:0;transform:translateX(-8px);transition:.35s}
.entry:hover .arrow{opacity:1;transform:translateX(0)}
/* ---- invite ---- */
.invite{background:var(--spruce-d);color:var(--paper);padding:clamp(3.5rem,8vw,6rem) 0}
.invite .kicker{color:var(--brass-l)}
.invite-in h2{color:#fff;font-size:clamp(1.9rem,4.5vw,3rem);font-weight:400;margin:1.2rem 0 1.8rem;line-height:1.12}
.invite .link-cta{color:#fff;border-color:var(--brass-l)}.invite .link-cta span{color:var(--brass-l)}
/* ---- journal head (inner pages) ---- */
.jhead{border-bottom:1px solid var(--line);padding:clamp(3rem,7vw,5.5rem) 0 clamp(2rem,4vw,3rem)}
.jhead h1{font-size:clamp(2.2rem,6vw,4.2rem);font-weight:400;letter-spacing:-.015em;margin:1rem 0 0;max-width:18ch}
.jhead-sub{font-family:var(--sans);color:var(--ink-soft);margin:1.2rem 0 0;font-size:1.05rem}
.article{padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(3rem,7vw,5rem);max-width:760px}
.article .prose{max-width:none}
.lede-p{font-family:var(--serif);font-size:1.4rem;line-height:1.5;color:var(--ink)}
.back{display:inline-block;margin-top:3rem;font-family:var(--sans);font-weight:600;color:var(--ink);border-bottom:1px solid var(--brass);padding-bottom:.2rem}
.back:hover{color:var(--spruce)}
/* ---- definition list (contact) ---- */
.dlist{margin:2.5rem 0 0;border-top:1px solid var(--line-2)}
.drow{display:grid;grid-template-columns:200px 1fr;gap:1.5rem;padding:1.4rem .3rem;border-bottom:1px solid var(--line-2)}
.drow dt{font-family:var(--sans);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;color:var(--ink-soft);margin:0;padding-top:.3rem}
.drow dd{margin:0;font-family:var(--serif);font-size:1.45rem;color:var(--ink)}
.drow dd a{color:var(--spruce)}
/* ---- sitemap ---- */
.smap{display:flex;flex-direction:column;border-top:1px solid var(--line-2)}
.smap a{font-family:var(--serif);font-size:1.5rem;color:var(--ink);padding:1.1rem .3rem;border-bottom:1px solid var(--line-2);transition:padding .3s,color .3s}
.smap a:hover{padding-left:1rem;color:var(--spruce)}
/* ---- footer ---- */
.foot{background:var(--ink);color:#c3ccc7;padding:clamp(3rem,6vw,5rem) 0 2rem;margin-top:0}
.foot-top{display:grid;grid-template-columns:1.3fr 2fr;gap:3rem}
.foot-brand .logo-mono{color:var(--paper)}.foot-brand .logo-mono span{color:var(--brass-l)}
.foot-brand p{max-width:36ch;margin:1.3rem 0 0;color:#93a09a;font-size:.98rem}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.foot-cols h4{font-family:var(--sans);font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brass-l);margin:0 0 1.1rem}
.foot-cols a,.foot-contact span{display:block;color:#b3beb8;padding:.3rem 0;font-size:.98rem}
.foot-cols a:hover{color:#fff}
.foot-contact span{color:#93a09a}
.foot-rule{height:1px;background:rgba(255,255,255,.12);margin:3rem 0 1.5rem}
.foot-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;font-size:.85rem;color:#7d8a84;font-family:var(--sans)}
/* ---- load animation ---- */
@media(prefers-reduced-motion:no-preference){
  .hero-in>*,.two-col>*{animation:rise .9s cubic-bezier(.2,.7,.2,1) both}
  .hero-in>*:nth-child(2){animation-delay:.08s}.hero-in>*:nth-child(3){animation-delay:.16s}
  @keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
}
/* ---- responsive ---- */
@media(max-width:860px){
  .nav,.mast-tel{display:none}.burger{display:flex}
  body.nav-open .nav{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:.5rem 5%}
  body.nav-open .nav a{padding:.9rem 0;border-bottom:1px solid var(--line)}
  .two-col{grid-template-columns:1fr;gap:1.5rem}.col-label{position:static}
  .prin-list{grid-template-columns:1fr;gap:1.6rem}
  .foot-top{grid-template-columns:1fr;gap:2rem}.foot-cols{grid-template-columns:1fr 1fr}
  .drow{grid-template-columns:1fr;gap:.3rem}.drow dd{font-size:1.25rem}
}
@media(max-width:520px){.foot-cols{grid-template-columns:1fr}.entry{gap:1rem}.num{min-width:1.8rem}}
