/* ==========================================================================
   NoPlastiq — Design tokens
   ========================================================================== */
:root{
  --paper:      #FAFAF8;
  --paper-dim:  #F1EEE6;
  --ink:        #14140F;
  --ink-soft:   #4A4A42;
  --line:       #DEDACE;

  --cane:       #C68A3D;   /* amber sugarcane */
  --cane-dark:  #9A6A28;
  --pine:       #23422F;   /* deep reed green  */
  --pine-soft:  #E7EEE7;

  --matsch:     #A6472B;   /* soggy-cardboard rust, used sparingly */
  --matsch-soft:#F3E3DC;

  --display: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;
  --body:    "Inter", "Helvetica Neue", Arial, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;
  --hand:    "Caveat", "Segoe Script", cursive;

  --radius: 2px;
  --max: 1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0 0 .5em;
}
h1{font-size:clamp(2.6rem,6vw,5rem); line-height:1.02; letter-spacing:-0.02em;}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem); line-height:1.08;}
h3{font-size:1.3rem;}
p{margin:0 0 1em; color:var(--ink-soft);}
.eyebrow{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--cane-dark);
  margin-bottom:1em;
  display:inline-block;
}

.wrap{max-width:var(--max); margin:0 auto; padding:0 32px;}
section{padding:120px 0;}
@media (max-width:720px){
  section{padding:72px 0;}
  .wrap{padding:0 22px;}
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5em;
  font-family:var(--display);
  font-weight:600;
  font-size:.98rem;
  padding:14px 28px;
  border-radius:var(--radius);
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--paper);
  text-decoration:none;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, color .18s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn.ghost{background:transparent; color:var(--ink); border-color:var(--ink);}
.btn.on-dark{border-color:var(--paper); background:var(--paper); color:var(--pine);}
.btn.on-dark.ghost{background:transparent; color:var(--paper); border-color:rgba(250,250,248,.5);}
.btn.cane{background:var(--cane); border-color:var(--cane); color:var(--ink);}

/* Header */
header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(250,250,248,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:var(--max); margin:0 auto; padding:18px 32px;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{
  font-family:var(--display); font-weight:700; font-size:1.15rem;
  text-decoration:none; color:var(--ink);
  display:flex; align-items:center; gap:8px;
}
.brand .leaf{color:var(--pine);}
.brand-logo{height:28px; width:auto; display:block;}
footer.site .brand-logo{height:26px;}
.footer-logo{filter:brightness(0) invert(1); opacity:.96;}
.nav-links{display:flex; gap:34px; list-style:none; margin:0; padding:0; align-items:center;}
.nav-links a{text-decoration:none; font-size:.95rem; font-weight:500; color:var(--ink-soft);}
.nav-links a.active, .nav-links a:hover{color:var(--ink);}
.nav-links a.nav-cta{color:var(--paper);}
.nav-links a.nav-cta:hover{color:var(--paper);}
.nav-cta{font-size:.9rem; padding:10px 20px;}
.burger{display:none; background:none; border:0; cursor:pointer;}
@media (max-width:760px){
  .nav-links{
    position:fixed; inset:64px 0 auto 0; background:var(--paper);
    flex-direction:column; align-items:flex-start; gap:0;
    border-bottom:1px solid var(--line);
    transform:translateY(-110%); transition:transform .25s ease;
  }
  .nav-links.open{transform:translateY(0);}
  .nav-links li{width:100%;}
  .nav-links a{display:block; padding:18px 22px; width:100%; border-bottom:1px solid var(--line);}
  .burger{display:block;}
}

/* Footer */
footer.site{
  background:var(--ink); color:var(--paper); padding:64px 0 32px;
}
footer.site a{text-decoration:none; opacity:.8;}
footer.site a:hover{opacity:1;}
.foot-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
}
.foot-grid h4{color:var(--paper); font-size:.85rem; letter-spacing:.06em; text-transform:uppercase; opacity:.6; margin-bottom:14px;}
.foot-grid ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; font-size:.95rem;}
.foot-bottom{
  max-width:var(--max); margin:56px auto 0; padding:22px 32px 0 32px;
  border-top:1px solid rgba(250,250,248,.14);
  display:flex; justify-content:space-between; font-size:.82rem; opacity:.55;
  flex-wrap:wrap; gap:10px;
}
@media (max-width:720px){.foot-grid{grid-template-columns:1fr 1fr;}}

/* Utility */
.center{text-align:center;}
.dark-section{background:var(--ink); color:var(--paper);}
.dark-section p{color:#C9C7BC;}
.dark-section .eyebrow{color:var(--cane);}
.pine-section{background:var(--pine); color:var(--paper);}
.pine-section p{color:#CFDCD2;}
.pine-section .eyebrow{color:#B7D6C0;}

/* Scroll reveal */
[data-reveal]{
  opacity:0; transform:translateY(28px);
  transition:opacity .8s cubic-bezier(.16,.8,.24,1), transform .8s cubic-bezier(.16,.8,.24,1);
  transition-delay:var(--reveal-delay, 0s);
}
[data-reveal].is-visible{opacity:1; transform:none;}
.cases .case[data-reveal]:nth-child(2){--reveal-delay:.1s;}
.cases .case[data-reveal]:nth-child(3){--reveal-delay:.2s;}
.plans .plan[data-reveal]:nth-child(2){--reveal-delay:.1s;}
.plans .plan[data-reveal]:nth-child(3){--reveal-delay:.2s;}
.values .value[data-reveal]:nth-child(2){--reveal-delay:.1s;}
.values .value[data-reveal]:nth-child(3){--reveal-delay:.2s;}
.cups .cup-card[data-reveal]:nth-child(2){--reveal-delay:.12s;}
@media (prefers-reduced-motion: reduce){
  [data-reveal]{opacity:1; transform:none; transition:none;}
}

/* Accessibility */
a:focus-visible, button:focus-visible, .btn:focus-visible{
  outline:2px solid var(--cane); outline-offset:3px;
}
.skip-link{
  position:absolute; left:12px; top:-48px;
  background:var(--ink); color:var(--paper); text-decoration:none;
  padding:12px 18px; border-radius:4px; font-size:.9rem; font-weight:600;
  z-index:200; transition:top .2s ease;
}
.skip-link:focus{top:12px;}

/* Floating CTA */
.float-cta{
  position:fixed; right:24px; bottom:24px; z-index:60;
  opacity:0; transform:translateY(16px) scale(.96); pointer-events:none;
  transition:opacity .3s ease, transform .3s ease;
  box-shadow:0 14px 30px -10px rgba(20,20,15,.4);
}
.float-cta.visible{opacity:1; transform:none; pointer-events:auto;}
@media (max-width:600px){
  .float-cta{left:16px; right:16px; bottom:16px; justify-content:center;}
}
@media (prefers-reduced-motion: reduce){
  .float-cta{transition:opacity .15s ease;}
}

/* Checkout success animation */
.success-check{width:64px; height:64px; margin:0 auto 18px;}
.success-check svg{width:100%; height:100%;}
.check-circle{
  stroke:var(--pine); stroke-width:2; fill:none;
  stroke-dasharray:152; stroke-dashoffset:152;
  animation:draw-circle .5s ease forwards;
}
.check-mark{
  stroke:var(--pine); stroke-width:3; fill:none;
  stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:36; stroke-dashoffset:36;
  animation:draw-check .3s .45s ease forwards;
}
@keyframes draw-circle{to{stroke-dashoffset:0;}}
@keyframes draw-check{to{stroke-dashoffset:0;}}
@media (prefers-reduced-motion: reduce){
  .check-circle, .check-mark{animation:none; stroke-dashoffset:0;}
}
