  :root{
    --bunna-black:#1C1410;
    --highland-green:#27392F;
    --highland-green-light:#37503F;
    --golden-husk:#D9A441;
    --cherry-red:#A13D2C;
    --parchment:#EDE3D0;
    --cream:#FAF6EE;
    --ash:#8C8275;
    --light-roast:#C99A62;
    --medium-roast:#7A4B2E;
    --dark-roast:#2B1810;
    --max-w:1180px;
  }

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

  html{scroll-behavior:smooth;}
  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto;}
    *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
  }

  body{
    font-family:'Karla',sans-serif;
    color:var(--bunna-black);
    background:var(--cream);
    line-height:1.65;
    font-size:17px;
  }

  h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;letter-spacing:-0.01em;}
  a{color:inherit;text-decoration:none;}
  img,svg{display:block;max-width:100%;}
  button{font-family:inherit;cursor:pointer;border:none;background:none;}

  .wrap{max-width:var(--max-w);margin:0 auto;padding:0 28px;}
  .eyebrow{
    font-family:'Space Mono',monospace;
    font-size:0.72rem;
    letter-spacing:0.18em;
    text-transform:uppercase;
    color:var(--golden-husk);
  }

  /* focus visibility */
  a:focus-visible, button:focus-visible, input:focus-visible{
    outline:2px solid var(--cherry-red);
    outline-offset:3px;
  }

  /* ---------- NAV ---------- */
  header{
    position:sticky;top:0;z-index:50;
    background:rgba(250,246,238,0.92);
    backdrop-filter:blur(6px);
    border-bottom:1px solid rgba(28,20,16,0.08);
  }
  nav{
    display:flex;align-items:center;justify-content:space-between;
    max-width:var(--max-w);margin:0 auto;padding:16px 28px;
  }
  .logo{
    font-family:'Fraunces',serif;font-weight:700;font-size:1.15rem;
    letter-spacing:0.01em;
    display:flex;align-items:center;gap:8px;
  }
  .logo span{color:var(--cherry-red);}
  .nav-links{display:flex;gap:32px;font-size:0.92rem;font-weight:500;}
  .nav-links a{position:relative;padding:4px 0;}
  .nav-links a::after{
    content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
    background:var(--cherry-red);transition:width .25s ease;
  }
  .nav-links a:hover::after{width:100%;}
  .nav-cta{
    font-family:'Space Mono',monospace;font-size:0.78rem;
    padding:9px 18px;border:1px solid var(--bunna-black);
    border-radius:2px;transition:background .2s, color .2s;
  }
  .nav-cta:hover{background:var(--bunna-black);color:var(--cream);}
  @media (max-width:760px){
    .nav-links{display:none;}
  }

  /* ---------- HERO ---------- */
  .hero{
    background:radial-gradient(circle at 78% 20%, var(--highland-green-light), var(--highland-green) 60%, #1d2b23 100%);
    color:var(--cream);
    padding:88px 0 96px;
    position:relative;
    overflow:hidden;
  }
  .hero-grid{
    display:grid;grid-template-columns:1.15fr 0.85fr;gap:48px;align-items:center;
  }
  .hero h1{
    font-size:clamp(2.5rem,5.2vw,4.4rem);
    line-height:1.04;margin:18px 0 22px;color:var(--cream);
  }
  .hero h1 em{font-style:italic;color:var(--golden-husk);font-weight:500;}
  .hero p{
    font-size:1.08rem;max-width:480px;color:rgba(250,246,238,0.85);
  }
  .hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
  .btn{
    font-family:'Space Mono',monospace;font-size:0.82rem;letter-spacing:0.03em;
    padding:14px 26px;border-radius:2px;display:inline-block;
    transition:transform .2s ease, background .2s ease, color .2s ease;
  }
  .btn-primary{background:var(--golden-husk);color:var(--bunna-black);}
  .btn-primary:hover{transform:translateY(-2px);background:#e7b65a;}
  .btn-ghost{border:1px solid rgba(250,246,238,0.5);color:var(--cream);}
  .btn-ghost:hover{background:rgba(250,246,238,0.1);transform:translateY(-2px);}

  /* stamp badge */
  .stamp-wrap{display:flex;justify-content:center;}
  .stamp{width:min(520px,100%);height:auto;}
  .stamp text{font-family:'Space Mono',monospace;}
  .stamp .ring{fill:none;stroke:var(--golden-husk);}
  .stamp .ring-inner{stroke:rgba(217,164,65,0.45);}
  .stamp-icon{stroke:var(--golden-husk);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;}

  @media (max-width:880px){
    .hero-grid{grid-template-columns:1fr;}
    .stamp-wrap{order:-1;margin-bottom:8px;}
    .stamp{width:min(320px,80%);}
  }

  /* ---------- SECTION HEADERS ---------- */
  .section{padding:96px 0;}
  .section-head{max-width:640px;margin-bottom:56px;}
  .section-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin:10px 0 14px;}
  .section-head p{color:var(--ash);font-size:1.05rem;}
  .alt{background:var(--parchment);}

  /* ---------- SEVEN STEPS ---------- */
  .steps{position:relative;}
  .steps::before{
    content:"";position:absolute;left:27px;top:8px;bottom:8px;width:1px;
    background:linear-gradient(to bottom, var(--cherry-red), rgba(161,61,44,0.15));
  }
  .step{
    display:grid;grid-template-columns:56px 1fr;gap:26px;
    padding:22px 0;position:relative;
    opacity:0;transform:translateY(16px);
    transition:opacity .6s ease, transform .6s ease;
  }
  .step.in-view{opacity:1;transform:translateY(0);}
  .step-num{
    font-family:'Space Mono',monospace;font-size:0.95rem;color:var(--cherry-red);
    background:var(--cream);border:1px solid var(--cherry-red);
    width:56px;height:56px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    z-index:1;
  }
  .alt .step-num{background:var(--parchment);}
  .step-body h3{font-size:1.18rem;margin-bottom:6px;font-weight:600;}
  .step-body p{color:var(--ash);max-width:560px;font-size:0.98rem;}

  /* ---------- ROASTS ---------- */
  .spectrum{margin:0 auto 12px;max-width:640px;}
  .spectrum-bar{
    position:relative;height:10px;border-radius:6px;
    background:linear-gradient(to right, var(--light-roast), var(--medium-roast), var(--dark-roast));
    margin:54px 0 14px;
  }
  .marker{
    position:absolute;top:50%;transform:translate(-50%,-50%);
    width:26px;height:26px;border-radius:50%;
    background:var(--cream);border:3px solid var(--bunna-black);
    transition:transform .25s ease, border-color .25s ease;
  }
  .marker.active{transform:translate(-50%,-50%) scale(1.18);border-color:var(--cherry-red);}
  .marker:hover{border-color:var(--cherry-red);}
  .marker[data-roast="light"]{left:16.6%;}
  .marker[data-roast="medium"]{left:50%;}
  .marker[data-roast="dark"]{left:83.4%;}
  .spectrum-labels{
    display:flex;justify-content:space-between;
    font-family:'Space Mono',monospace;font-size:0.74rem;
    letter-spacing:0.1em;text-transform:uppercase;color:var(--ash);
  }
  .spectrum-labels button{color:inherit;transition:color .2s;}
  .spectrum-labels button.active{color:var(--cherry-red);font-weight:700;}

  .roast-panel{
    margin-top:56px;
    display:grid;grid-template-columns:0.9fr 1.1fr;gap:0;
    border:1px solid rgba(28,20,16,0.12);border-radius:6px;overflow:hidden;
    background:var(--cream);
  }
  .roast-swatch{
    padding:42px 34px;color:var(--cream);position:relative;
    display:flex;flex-direction:column;justify-content:space-between;
    min-height:340px;
    transition:background .35s ease;
  }
  .roast-swatch .rs-top .eyebrow{color:rgba(250,246,238,0.7);}
  .roast-swatch h3{font-size:1.9rem;color:var(--cream);margin:10px 0 4px;}
  .roast-swatch .tagline{font-style:italic;color:rgba(250,246,238,0.85);font-size:0.98rem;}
  .specs{font-family:'Space Mono',monospace;font-size:0.76rem;color:rgba(250,246,238,0.85);line-height:1.9;}
  .specs b{color:var(--cream);}

  .roast-detail{padding:42px 38px;display:flex;flex-direction:column;gap:18px;}
  .roast-detail h4{font-family:'Space Mono',monospace;font-size:0.74rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--ash);}
  .roast-detail p{font-size:1rem;}
  .tags{display:flex;flex-wrap:wrap;gap:8px;}
  .tag{
    font-family:'Space Mono',monospace;font-size:0.74rem;padding:6px 12px;
    border:1px solid rgba(28,20,16,0.18);border-radius:20px;color:var(--bunna-black);
  }
  .roast-cta{margin-top:auto;}

  .roast-card{display:none;}
  .roast-card.active{display:block;animation:fadein .4s ease;}
  @keyframes fadein{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

  @media (max-width:760px){
    .roast-panel{grid-template-columns:1fr;}
    .roast-swatch{min-height:auto;}
  }

  /* ---------- WHY ETHIOPIA ---------- */
  .why-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:64px;align-items:center;}
  .why-grid p{margin-bottom:16px;color:var(--bunna-black);}
  .why-grid .lede{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:500;color:var(--highland-green);margin-bottom:20px;}
  .fact-list{margin-top:28px;display:grid;gap:14px;}
  .fact{display:flex;gap:14px;align-items:flex-start;}
  .fact-mark{font-family:'Space Mono',monospace;color:var(--cherry-red);font-weight:700;flex:0 0 auto;}
  .why-art{display:flex;justify-content:center;}
  @media (max-width:880px){ .why-grid{grid-template-columns:1fr;} .why-art{order:-1;} }

  /* ---------- VISIT / ORDER ---------- */
  .visit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
  .visit-card{
    background:var(--cream);border:1px solid rgba(28,20,16,0.1);
    border-radius:6px;padding:30px;transition:border-color .2s, transform .2s;
  }
  .visit-card:hover{border-color:var(--cherry-red);transform:translateY(-3px);}
  .visit-card h3{font-size:1.15rem;margin:8px 0 8px;}
  .visit-card p{color:var(--ash);font-size:0.95rem;margin-bottom:14px;}
  .visit-card a{font-family:'Space Mono',monospace;font-size:0.78rem;color:var(--cherry-red);border-bottom:1px solid var(--cherry-red);}
  @media (max-width:880px){.visit-grid{grid-template-columns:1fr;}}

  .newsletter{
    margin-top:72px;padding:40px;background:var(--highland-green);color:var(--cream);
    border-radius:6px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;
  }
  .newsletter h3{color:var(--cream);font-size:1.3rem;max-width:340px;}
  .newsletter-form{display:flex;gap:0;flex:1;max-width:420px;min-width:260px;}
  .newsletter-form input{
    flex:1;padding:13px 16px;border:1px solid rgba(250,246,238,0.4);background:transparent;
    color:var(--cream);font-family:'Karla',sans-serif;border-radius:2px 0 0 2px;
  }
  .newsletter-form input::placeholder{color:rgba(250,246,238,0.6);}
  .newsletter-form button{
    background:var(--golden-husk);color:var(--bunna-black);padding:13px 20px;
    font-family:'Space Mono',monospace;font-size:0.8rem;border-radius:0 2px 2px 0;white-space:nowrap;
  }
  .newsletter-note{font-family:'Space Mono',monospace;font-size:0.78rem;margin-top:8px;color:var(--golden-husk);min-height:1em;}

  /* ---------- FOOTER ---------- */
  footer{background:var(--bunna-black);color:rgba(250,246,238,0.75);padding:56px 0 32px;}
  .footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
  footer .logo{color:var(--cream);}
  footer h4{font-family:'Space Mono',monospace;font-size:0.76rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--golden-husk);margin-bottom:14px;}
  footer ul{list-style:none;display:grid;gap:10px;font-size:0.92rem;}
  footer ul a:hover{color:var(--cream);}
  .footer-bottom{
    margin-top:48px;padding-top:24px;border-top:1px solid rgba(250,246,238,0.12);
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
    font-family:'Space Mono',monospace;font-size:0.74rem;color:rgba(250,246,238,0.45);
  }
  @media (max-width:760px){.footer-grid{grid-template-columns:1fr 1fr;}}
