  :root{
    --paper:        #f3ede2;
    --paper-deep:   #ebe2d2;
    --ink:          #1a1d22;
    --ink-soft:     #3a3f47;
    --ink-faint:    #6e6a60;
    --river:        #1f3a52;
    --river-deep:   #14283a;
    --copper:       #a8552b;
    --copper-soft:  #c97a4d;
    --rule:         #cdc2ac;
    --rule-soft:    #ddd3bd;
  }

  *{box-sizing:border-box;margin:0;padding:0}

  html{scroll-behavior:smooth}

  body{
    font-family:'IBM Plex Sans', system-ui, sans-serif;
    font-weight:400;
    color:var(--ink);
    background:var(--paper);
    background-image:
      radial-gradient(at 8% 12%, rgba(31,58,82,0.05) 0px, transparent 50%),
      radial-gradient(at 92% 88%, rgba(168,85,43,0.04) 0px, transparent 45%);
    background-attachment:fixed;
    line-height:1.55;
    font-size:16px;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }

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

  .wrap{
    position:relative;
    z-index:2;
    max-width:1240px;
    margin:0 auto;
    padding:0 clamp(20px, 5vw, 64px);
  }

  /* ───── Top bar ───── */
  header.top{
    padding:28px 0 0;
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:24px;
    flex-wrap:wrap;
  }
  .brand{
    display:flex;
    align-items:center;
    gap:14px;
    font-family:'Fraunces', serif;
    font-weight:500;
    font-size:18px;
    letter-spacing:.01em;
  }
  .brand-mark{
    width:38px;height:38px;
    flex:0 0 38px;
  }
  .brand-text{line-height:1.1}
  .brand-text small{
    display:block;
    font-family:'IBM Plex Mono', monospace;
    font-size:10.5px;
    font-weight:400;
    color:var(--ink-faint);
    letter-spacing:.12em;
    text-transform:uppercase;
    margin-top:4px;
  }
  .top-meta{
    font-family:'IBM Plex Mono', monospace;
    font-size:11px;
    letter-spacing:.1em;
    text-transform:uppercase;
    color:var(--ink-faint);
    text-align:right;
    line-height:1.8;
  }
  .top-meta a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
  .top-meta a:hover{border-bottom-color:var(--copper)}

  /* ───── Hero ───── */
  .hero{
    padding:clamp(80px, 14vw, 160px) 0 clamp(60px, 10vw, 120px);
    position:relative;
  }
  .hero-eyebrow{
    font-family:'IBM Plex Mono', monospace;
    font-size:11.5px;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--copper);
    margin-bottom:32px;
    display:flex;
    align-items:center;
    gap:14px;
    opacity:0;
    animation:rise .9s .2s cubic-bezier(.2,.6,.2,1) forwards;
  }
  .hero-eyebrow::before{
    content:"";
    width:36px;height:1px;
    background:var(--copper);
  }

  h1.hero-title{
    font-family:'Fraunces', serif;
    font-weight:300;
    font-size:clamp(44px, 7vw, 92px);
    line-height:1.02;
    letter-spacing:-.02em;
    color:var(--ink);
    max-width:14ch;
    opacity:0;
    animation:rise 1s .35s cubic-bezier(.2,.6,.2,1) forwards;
  }
  h1.hero-title em{
    font-style:italic;
    font-weight:300;
    color:var(--river);
  }

  .hero-sub{
    margin-top:36px;
    max-width:54ch;
    font-size:18px;
    line-height:1.55;
    color:var(--ink-soft);
    opacity:0;
    animation:rise 1s .55s cubic-bezier(.2,.6,.2,1) forwards;
  }

  .hero-stamps{
    margin-top:56px;
    display:flex;
    gap:48px;
    flex-wrap:wrap;
    font-family:'IBM Plex Mono', monospace;
    font-size:11px;
    letter-spacing:.15em;
    text-transform:uppercase;
    color:var(--ink-faint);
    opacity:0;
    animation:rise 1s .75s cubic-bezier(.2,.6,.2,1) forwards;
  }
  .hero-stamps strong{
    display:block;
    color:var(--ink);
    font-weight:500;
    font-size:13px;
    letter-spacing:.08em;
    margin-top:6px;
    font-family:'Fraunces', serif;
    text-transform:none;
  }

  /* River line motif */
  .river-line{
    position:absolute;
    right:-20px;
    top:50%;
    width:280px;
    height:auto;
    transform:translateY(-30%);
    opacity:.42;
    display:none;
    pointer-events:none;
  }
  @media (min-width: 1100px){
    .river-line{display:block}
  }
  .river-line path{
    stroke:var(--river);
    stroke-width:1.2;
    fill:none;
    stroke-dasharray:1200;
    stroke-dashoffset:1200;
    animation:flow 3.2s 1.1s cubic-bezier(.2,.6,.2,1) forwards;
  }
  @keyframes flow{to{stroke-dashoffset:0}}

  /* ───── Section scaffolding ───── */
  section{padding:clamp(60px, 9vw, 110px) 0;position:relative}
  section + section{border-top:1px solid var(--rule)}

  .section-label{
    font-family:'IBM Plex Mono', monospace;
    font-size:11px;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--copper);
    margin-bottom:28px;
    display:flex;
    align-items:center;
    gap:14px;
  }
  .section-label::before{
    content:"";
    width:8px;height:8px;
    background:var(--copper);
    border-radius:50%;
    display:inline-block;
  }
  .section-label .num{
    color:var(--ink-faint);
    margin-left:auto;
    font-size:10.5px;
    letter-spacing:.12em;
  }

  h2.section-title{
    font-family:'Fraunces', serif;
    font-weight:300;
    font-size:clamp(30px, 4.2vw, 48px);
    line-height:1.1;
    letter-spacing:-.015em;
    margin-bottom:48px;
    max-width:22ch;
  }
  h2.section-title em{font-style:italic;color:var(--river)}

  /* ───── Who We Are ───── */
  .who-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr;
    gap:clamp(40px, 6vw, 96px);
    align-items:start;
  }
  @media (max-width:820px){.who-grid{grid-template-columns:1fr}}

  .who-text p{
    font-size:18px;
    line-height:1.65;
    color:var(--ink-soft);
    margin-bottom:20px;
    max-width:62ch;
  }
  .who-text p.lead{
    font-family:'Fraunces', serif;
    font-weight:400;
    font-size:clamp(22px, 2.3vw, 26px);
    line-height:1.4;
    color:var(--ink);
    margin-bottom:32px;
  }
  .who-text p.lead em{font-style:italic;color:var(--river)}

  .facts{
    border-top:1px solid var(--rule);
    border-bottom:1px solid var(--rule);
    padding:24px 0;
  }
  .fact{
    display:grid;
    grid-template-columns:1fr 1.4fr;
    gap:20px;
    padding:12px 0;
    border-bottom:1px solid var(--rule-soft);
    align-items:baseline;
  }
  .fact:last-child{border-bottom:none}
  .fact dt{
    font-family:'IBM Plex Mono', monospace;
    font-size:10.5px;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--ink-faint);
    line-height:1.5;
  }
  .fact dd{
    font-family:'Fraunces', serif;
    font-size:15px;
    color:var(--ink);
    line-height:1.4;
  }
  .fact dd .mono{
    font-family:'IBM Plex Mono', monospace;
    font-size:13px;
    letter-spacing:.04em;
    color:var(--river);
  }

  /* ───── What We Supply ───── */
  .supply-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:0;
    border-top:1px solid var(--rule);
    border-bottom:1px solid var(--rule);
  }
  @media (max-width:860px){.supply-grid{grid-template-columns:1fr}}

  .supply{
    padding:40px 32px;
    border-right:1px solid var(--rule);
    position:relative;
    transition:background .35s ease;
  }
  .supply:last-child{border-right:none}
  @media (max-width:860px){
    .supply{border-right:none;border-bottom:1px solid var(--rule)}
    .supply:last-child{border-bottom:none}
  }
  .supply:hover{background:rgba(31,58,82,0.025)}

  .supply-num{
    font-family:'IBM Plex Mono', monospace;
    font-size:11px;
    letter-spacing:.14em;
    color:var(--copper);
    margin-bottom:24px;
    display:block;
  }
  .supply h3{
    font-family:'Fraunces', serif;
    font-weight:400;
    font-size:24px;
    line-height:1.2;
    margin-bottom:16px;
    color:var(--ink);
  }
  .supply p{
    font-size:15px;
    line-height:1.6;
    color:var(--ink-soft);
  }
  .supply ul{
    list-style:none;
    margin-top:16px;
  }
  .supply ul li{
    font-family:'IBM Plex Mono', monospace;
    font-size:11.5px;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:var(--ink-faint);
    padding:6px 0;
    border-top:1px dotted var(--rule);
  }
  .supply ul li:last-child{border-bottom:1px dotted var(--rule)}

  /* ───── Why ───── */
  .why-grid{
    display:grid;
    grid-template-columns:1fr 1.1fr;
    gap:clamp(40px, 7vw, 100px);
    align-items:start;
  }
  @media (max-width:860px){.why-grid{grid-template-columns:1fr}}

  .stat-block{
    background:var(--river);
    color:var(--paper);
    padding:48px 44px;
    position:relative;
    overflow:hidden;
  }
  .stat-block::before{
    content:"";
    position:absolute;
    top:0;left:0;right:0;
    height:1px;
    background:linear-gradient(90deg, transparent, var(--copper-soft), transparent);
  }
  .stat-num{
    font-family:'Fraunces', serif;
    font-weight:300;
    font-size:clamp(72px, 9vw, 120px);
    line-height:1;
    letter-spacing:-.03em;
    color:var(--paper);
    margin-bottom:16px;
  }
  .stat-num span{color:var(--copper-soft);font-style:italic}
  .stat-label{
    font-family:'IBM Plex Mono', monospace;
    font-size:11px;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(243,237,226,0.65);
    margin-bottom:24px;
  }
  .stat-block p{
    font-size:15px;
    line-height:1.6;
    color:rgba(243,237,226,0.88);
  }
  .stat-block p + p{margin-top:14px}

  .why-text p{
    font-size:17px;
    line-height:1.65;
    color:var(--ink-soft);
    margin-bottom:18px;
  }
  .why-text p:first-child{
    font-family:'Fraunces', serif;
    font-size:22px;
    line-height:1.45;
    color:var(--ink);
    margin-bottom:24px;
  }

  /* ───── Leadership ───── */
  .leader-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:clamp(40px, 6vw, 80px);
  }
  @media (max-width:760px){.leader-grid{grid-template-columns:1fr}}

  .leader{
    border-top:1px solid var(--ink);
    padding-top:24px;
  }
  .leader-role{
    font-family:'IBM Plex Mono', monospace;
    font-size:10.5px;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--copper);
    margin-bottom:14px;
  }
  .leader h3{
    font-family:'Fraunces', serif;
    font-weight:400;
    font-size:30px;
    line-height:1.15;
    margin-bottom:18px;
    color:var(--ink);
  }
  .leader p{
    font-size:15.5px;
    line-height:1.65;
    color:var(--ink-soft);
  }
  .leader p + p{margin-top:12px}

  /* ───── Contact / Footer ───── */
  .contact{
    padding:clamp(80px, 11vw, 130px) 0;
    border-top:1px solid var(--rule);
  }
  .contact-grid{
    display:grid;
    grid-template-columns:1.3fr 1fr;
    gap:clamp(40px, 6vw, 100px);
    align-items:end;
  }
  @media (max-width:780px){.contact-grid{grid-template-columns:1fr}}

  .contact h2{
    font-family:'Fraunces', serif;
    font-weight:300;
    font-size:clamp(34px, 5vw, 60px);
    line-height:1.05;
    letter-spacing:-.015em;
    color:var(--ink);
    max-width:14ch;
  }
  .contact h2 em{font-style:italic;color:var(--river)}

  .contact-info{
    font-size:15px;
    line-height:1.8;
    color:var(--ink-soft);
  }
  .contact-info strong{
    display:block;
    font-family:'IBM Plex Mono', monospace;
    font-size:10.5px;
    letter-spacing:.16em;
    text-transform:uppercase;
    color:var(--ink-faint);
    font-weight:400;
    margin-top:18px;
    margin-bottom:4px;
  }
  .contact-info strong:first-child{margin-top:0}
  .contact-info a{
    color:var(--river);
    text-decoration:none;
    border-bottom:1px solid var(--rule);
    transition:border-color .2s, color .2s;
  }
  .contact-info a:hover{
    color:var(--copper);
    border-bottom-color:var(--copper);
  }

  footer{
    padding:36px 0 48px;
    border-top:1px solid var(--rule);
  }
  .footer-grid{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:24px;
    flex-wrap:wrap;
    font-family:'IBM Plex Mono', monospace;
    font-size:10.5px;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--ink-faint);
    line-height:1.8;
  }
  .footer-grid .pending{
    color:var(--copper);
  }
  .footer-grid .pending::before{
    content:"●";
    margin-right:6px;
    font-size:8px;
    vertical-align:1px;
  }
  .land-ack{
    margin-top:32px;
    padding-top:24px;
    border-top:1px dotted var(--rule);
    font-family:'Fraunces', serif;
    font-style:italic;
    font-size:14px;
    color:var(--ink-faint);
    max-width:62ch;
    line-height:1.6;
  }

  /* ───── Animations ───── */
  @keyframes rise{
    from{opacity:0;transform:translateY(18px)}
    to{opacity:1;transform:translateY(0)}
  }
  .reveal{
    opacity:0;
    transform:translateY(24px);
    transition:opacity .9s cubic-bezier(.2,.6,.2,1), transform .9s cubic-bezier(.2,.6,.2,1);
  }
  .reveal.in{opacity:1;transform:translateY(0)}

  /* ───── Accessibility / selection ───── */
  ::selection{background:var(--river);color:var(--paper)}

  /* Print */
  @media print{
    body::before{display:none}
    .river-line{display:none}
    section + section{break-inside:avoid}
  }
