:root{
  --paper:#F6F0E4;
  --paper-2:#FCF8EF;
  --ink:#16241F;
  --ink-soft:#3b4d46;
  --forest:#1F3A33;
  --terra:#CD5E33;
  --terra-deep:#A8431E;
  --gold:#BD9B5C;
  --line:rgba(22,36,31,.14);
  --maxw:1200px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:18px;
  line-height:1.6;
  overflow-x:hidden;
  position:relative;
}

/* grain overlay */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;z-index:9999;
  opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection{background:var(--terra);color:var(--paper-2)}

a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* ---------- progress + nav ---------- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--terra);z-index:1000;transition:width .1s linear}

header{
  position:fixed;top:0;left:0;right:0;z-index:900;
  backdrop-filter:blur(8px);
  background:rgba(246,240,228,.78);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
header.scrolled{border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--serif);font-weight:600;font-size:1.25rem;letter-spacing:-.01em;display:flex;align-items:center;gap:.55rem}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--terra);display:inline-block}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500;color:var(--ink-soft);position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--terra);transition:width .3s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.menu-btn{display:none;background:none;border:none;font-family:var(--sans);font-size:.85rem;cursor:pointer;color:var(--ink)}

/* ---------- hero ---------- */
.hero{padding:170px 0 90px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:end}
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--terra-deep);margin-bottom:1.8rem}
.eyebrow::before{content:"";width:34px;height:1.5px;background:var(--terra)}
h1.hero-title{
  font-family:var(--serif);
  font-weight:430;
  font-size:clamp(2.6rem,5.6vw,4.6rem);
  line-height:1.04;
  letter-spacing:-.022em;
  margin-bottom:0;
}
h1.hero-title em{font-style:italic;color:var(--terra);font-weight:430}
.hero-side{padding-bottom:.6rem}
.hero-side p{font-size:1.06rem;color:var(--ink-soft);max-width:38ch}
.lead{
  font-family:var(--serif);
  font-size:1.32rem;line-height:1.55;font-weight:340;
  color:var(--forest);
  max-width:46ch;margin:2.4rem 0 0;
}
.bio{margin-top:2.3rem;max-width:62ch;color:var(--ink-soft);font-size:1.02rem}
.bio + .bio{margin-top:1.2rem}

.cta-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.8rem}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.92rem 1.7rem;border-radius:50px;
  font-size:.92rem;font-weight:600;letter-spacing:.01em;
  cursor:pointer;transition:transform .25s,background .25s,color .25s,box-shadow .25s;
  border:1.5px solid var(--ink);
}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper-2);box-shadow:0 8px 22px -12px rgba(22,36,31,.7)}
.btn-primary:hover{background:var(--forest);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper-2);transform:translateY(-2px)}

/* ---------- section framing ---------- */
section.block{padding:92px 0;position:relative}
.sec-head{display:flex;align-items:baseline;gap:1rem;margin-bottom:3rem}
.sec-num{font-family:var(--serif);font-size:1rem;color:var(--terra);font-weight:600;letter-spacing:.05em}
.sec-label{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--ink-soft)}
h2{font-family:var(--serif);font-weight:440;font-size:clamp(2rem,4vw,3rem);line-height:1.08;letter-spacing:-.02em;max-width:18ch}
h2 em{font-style:italic;color:var(--terra)}

.divider{height:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}
.divider-glyph{text-align:center;color:var(--gold);font-size:1.2rem;letter-spacing:1rem;padding:6px 0}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}
.about-body p{color:var(--ink-soft);margin-bottom:1.3rem}
.about-body p strong{color:var(--ink);font-weight:600}
.role-card{
  background:var(--paper-2);border:1px solid var(--line);border-radius:18px;
  padding:30px 32px;margin-top:14px;
}
.role-card h4{font-family:var(--serif);font-weight:600;font-size:1.05rem;margin-bottom:1.1rem;color:var(--forest)}
.tick-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.tick-list li{position:relative;padding-left:1.7rem;font-size:.98rem;color:var(--ink-soft)}
.tick-list li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:8px;height:8px;border-radius:2px;background:var(--terra);transform:rotate(45deg);
}
.journey{margin-top:30px}
.journey h4{font-family:var(--serif);font-weight:600;font-size:1.05rem;margin-bottom:1rem;color:var(--forest)}
.journey ol{list-style:none;counter-reset:j}
.journey li{counter-increment:j;position:relative;padding:.7rem 0 .7rem 3rem;border-bottom:1px dashed var(--line);color:var(--ink-soft);font-size:.98rem}
.journey li:last-child{border-bottom:none}
.journey li::before{
  content:"0" counter(j);position:absolute;left:0;top:.7rem;
  font-family:var(--serif);font-weight:600;color:var(--gold);font-size:.95rem;
}

/* ---------- focus / expertise ---------- */
.focus{background:var(--forest);color:var(--paper);border-radius:0;position:relative;overflow:hidden}
.focus .sec-label,.focus .about-body p{color:rgba(246,240,228,.72)}
.focus h2{color:var(--paper)}
.focus .sec-num{color:var(--gold)}
.focus-intro{max-width:54ch;color:rgba(246,240,228,.8);font-size:1.1rem;margin-bottom:3.4rem}
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(246,240,228,.16);border:1px solid rgba(246,240,228,.16)}
.fcard{
  background:var(--forest);padding:40px 38px;transition:background .3s;position:relative;
}
.fcard:hover{background:#244038}
.fcard .ix{font-family:var(--serif);font-size:.95rem;color:var(--gold);letter-spacing:.08em}
.fcard h3{font-family:var(--serif);font-weight:500;font-size:1.55rem;letter-spacing:-.01em;margin:.5rem 0 1.5rem;line-height:1.15}
.fcard ul{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.fcard li{position:relative;padding-left:1.4rem;color:rgba(246,240,228,.82);font-size:.97rem}
.fcard li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:50%;background:var(--terra)}
.focus-quote{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:rgba(246,240,228,.7);margin-top:2.6rem;max-width:60ch}

/* ---------- philosophy ---------- */
.phil{position:relative}
.phil .big{
  font-family:var(--serif);font-weight:380;font-size:clamp(1.8rem,3.6vw,2.7rem);
  line-height:1.18;letter-spacing:-.018em;max-width:20ch;margin-bottom:3rem;color:var(--ink);
}
.phil .big em{font-style:italic;color:var(--terra)}
.beliefs{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.belief{background:var(--paper-2);padding:28px 30px;display:flex;gap:1.1rem;align-items:flex-start;transition:background .25s}
.belief:hover{background:#fff}
.belief .b-ix{font-family:var(--serif);font-weight:600;color:var(--terra);font-size:1.1rem;line-height:1.2;flex-shrink:0}
.belief p{font-size:1.02rem;color:var(--ink);line-height:1.45}
.phil-close{margin-top:3rem;max-width:60ch;color:var(--ink-soft);font-size:1.08rem}
.phil-close em{font-family:var(--serif);font-style:italic;color:var(--forest)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--paper);padding:80px 0 46px}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.foot-name{font-family:var(--serif);font-size:clamp(2rem,5vw,3.4rem);font-weight:430;letter-spacing:-.02em;line-height:1.05}
.foot-name em{font-style:italic;color:var(--terra)}
.foot-tag{color:rgba(246,240,228,.7);max-width:34ch;margin-top:1rem}
.foot-cta{display:flex;flex-direction:column;gap:.9rem}
.foot-cta a{font-size:.95rem;color:var(--paper);border:1.5px solid rgba(246,240,228,.3);padding:.8rem 1.5rem;border-radius:50px;text-align:center;transition:background .25s,color .25s}
.foot-cta a:hover{background:var(--terra);border-color:var(--terra)}
.foot-bottom{margin-top:54px;padding-top:24px;border-top:1px solid rgba(246,240,228,.15);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(246,240,228,.55)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- conferences ---------- */
.conf-entry{display:grid;grid-template-columns:220px 1fr;gap:48px;align-items:start}
.conf-meta{padding-top:.3rem}
.conf-name{display:block;font-family:var(--serif);font-weight:600;font-size:1.05rem;color:var(--forest);margin-top:.4rem}
.conf-body h2{max-width:100%}
.conf-desc{color:var(--ink-soft);font-size:1.02rem;margin:1.4rem 0 2rem;max-width:100%;line-height:1.65}
.conf-btn{display:inline-flex}

@media(max-width:900px){
  .conf-entry{grid-template-columns:1fr;gap:16px}
}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .nav-links{display:none}
  .menu-btn{display:block}
  .hero-grid,.about-grid{grid-template-columns:1fr;gap:36px}
  .hero-side{padding-bottom:0}
  .card-grid,.beliefs{grid-template-columns:1fr}
  .hero{padding:140px 0 60px}
  section.block{padding:64px 0}
}
@media(max-width:560px){
  body{font-size:17px}
  .wrap{padding:0 22px}
  .cta-row{flex-direction:column;align-items:stretch}
  .btn{justify-content:center}
}
