/* ============================================================
   MECCHA CHAMELEON Companion — cozy camouflage landing
   ============================================================ */
:root{
  --cream:#F4F0E4;
  --cream-2:#EBE6D6;
  --paper:#FBFAF4;
  --ink:#1A2620;
  --ink-soft:#4A574E;
  --green:#1F6F54;
  --green-deep:#14543F;
  --green-dark:#0C2C21;
  --olive:#6B7B3A;
  --brown:#7A5230;
  --clay:#B9692F;
  --gold:#CBA23B;
  --sage:#A9C3A0;
  --line:rgba(26,38,32,.10);
  --shadow:0 24px 50px -18px rgba(12,44,33,.30);
  --r-lg:26px; --r-md:18px; --r-sm:12px;
  --maxw:1180px;
  --display:"Bricolage Grotesque",sans-serif;
  --body:"Hanken Grotesk",sans-serif;
  --mono:"Space Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:var(--body); font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--display); line-height:1.04; margin:0; letter-spacing:-.02em; font-weight:800}
a{color:inherit; text-decoration:none}
img{max-width:100%}
em{font-style:normal; color:var(--green); font-weight:700}

/* texture + atmosphere ------------------------------------- */
.grain{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='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.blobs{position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.blob{position:absolute; border-radius:46% 54% 60% 40%/50% 46% 54% 50%; filter:blur(8px); opacity:.18; animation:drift 22s ease-in-out infinite}
.blob.b1{width:340px;height:340px;background:var(--olive); top:-80px; left:-90px}
.blob.b2{width:260px;height:260px;background:var(--clay); top:30%; right:-90px; animation-delay:-6s}
.blob.b3{width:300px;height:300px;background:var(--green); bottom:8%; left:-100px; animation-delay:-12s}
.blob.b4{width:200px;height:200px;background:var(--gold); top:64%; right:18%; animation-delay:-3s; opacity:.12}
@keyframes drift{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(40px,-30px) rotate(20deg)}}

/* ============================ NAV ============================ */
.nav{position:sticky; top:0; z-index:100; display:flex; align-items:center; gap:24px;
  padding:14px clamp(16px,4vw,48px); transition:background .3s, box-shadow .3s, padding .3s}
.nav.scrolled{background:rgba(251,250,244,.82); backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--line); padding-top:10px; padding-bottom:10px}
.brand{display:flex; align-items:center; gap:10px; font-family:var(--display); font-weight:800}
.brand-icon{width:34px;height:34px;border-radius:9px; box-shadow:0 4px 10px rgba(12,44,33,.25)}
.brand-name{font-size:15px; letter-spacing:.02em}
.nav-links{margin-left:auto; display:flex; gap:26px; font-weight:600; font-size:15px}
.nav-links a{color:var(--ink-soft); position:relative; padding:4px 0}
.nav-links a::after{content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--green); transition:width .25s}
.nav-links a:hover{color:var(--ink)} .nav-links a:hover::after{width:100%}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:8px; font-family:var(--body); font-weight:700; font-size:15px;
  padding:11px 20px; border-radius:999px; background:var(--green); color:#fff; cursor:pointer; border:0;
  transition:transform .15s, box-shadow .25s, background .25s; box-shadow:0 8px 20px -8px rgba(31,111,84,.7)}
.btn:hover{transform:translateY(-2px); box-shadow:0 14px 26px -10px rgba(31,111,84,.8); background:var(--green-deep)}
.btn:active{transform:translateY(0)}
.btn-sm{padding:9px 16px; font-size:14px}
.btn-lg{padding:15px 28px; font-size:17px}
.btn-ghost{background:transparent; color:var(--ink); box-shadow:inset 0 0 0 2px var(--line)}
.btn-ghost:hover{background:rgba(26,38,32,.05); box-shadow:inset 0 0 0 2px var(--green); color:var(--ink)}
.btn-light{background:var(--cream); color:var(--green-dark)}
.btn-light:hover{background:#fff}
.btn-ghost-light{background:transparent; color:var(--cream); box-shadow:inset 0 0 0 2px rgba(244,240,228,.4)}
.btn-ghost-light:hover{background:rgba(244,240,228,.1); box-shadow:inset 0 0 0 2px var(--cream); color:#fff}

main{position:relative; z-index:1}
section{padding:clamp(64px,9vw,130px) clamp(16px,4vw,48px)}

/* ============================ HERO ============================ */
.hero{display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  max-width:var(--maxw); margin:0 auto; padding-top:clamp(30px,6vw,70px)}
.eyebrow{display:inline-block; font-weight:700; font-size:14px; color:var(--green-deep);
  background:rgba(31,111,84,.10); padding:7px 14px; border-radius:999px; margin:0 0 22px}
.hero h1{font-size:clamp(44px,7vw,86px); margin-bottom:20px}
.ink-stroke{position:relative; color:var(--clay)}
.ink-stroke::after{content:""; position:absolute; left:-4px; right:-4px; bottom:6px; height:.34em; z-index:-1;
  background:var(--gold); opacity:.5; border-radius:6px; transform:rotate(-1.5deg)}
.lede{font-size:clamp(17px,2vw,21px); color:var(--ink-soft); max-width:30em; margin:0 0 30px}
.cta-row{display:flex; gap:14px; flex-wrap:wrap; align-items:center}
.pills{display:flex; gap:10px; flex-wrap:wrap; margin-top:26px}
.pill{font-size:13px; font-weight:600; color:var(--ink-soft); padding:7px 13px; border-radius:999px; background:var(--paper); box-shadow:inset 0 0 0 1px var(--line)}

.hero-art{position:relative; display:flex; align-items:center; justify-content:center; min-height:440px}
.aura{position:absolute; width:min(420px,80%); aspect-ratio:1; border-radius:50%; filter:blur(6px);
  background:conic-gradient(var(--green),var(--olive),var(--gold),var(--clay),var(--sage),var(--green));
  opacity:.32; animation:spin 16s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-char{position:relative; width:min(420px,82%); filter:drop-shadow(0 30px 30px rgba(12,44,33,.25))}
.float{animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-16px) rotate(1.5deg)}}
.palette-strip{position:absolute; bottom:6%; left:50%; transform:translateX(-50%); display:flex; gap:9px}
.palette-strip i{width:15px;height:15px;border-radius:50%; animation:cyc 3s linear infinite}
.palette-strip i:nth-child(1){background:var(--green)} .palette-strip i:nth-child(2){background:var(--olive); animation-delay:-.4s}
.palette-strip i:nth-child(3){background:var(--brown); animation-delay:-.8s} .palette-strip i:nth-child(4){background:var(--sage); animation-delay:-1.2s}
.palette-strip i:nth-child(5){background:var(--gold); animation-delay:-1.6s} .palette-strip i:nth-child(6){background:var(--clay); animation-delay:-2s}
.palette-strip i:nth-child(7){background:var(--green-deep); animation-delay:-2.4s} .palette-strip i:nth-child(8){background:var(--olive); animation-delay:-2.8s}
@keyframes cyc{0%,100%{transform:scale(1); opacity:.65}50%{transform:scale(1.5); opacity:1}}
.readout{position:absolute; top:8%; right:-2%; display:flex; gap:11px; align-items:center; background:var(--paper);
  padding:12px 14px; border-radius:var(--r-md); box-shadow:var(--shadow); animation:bobcard 5s ease-in-out infinite}
@keyframes bobcard{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.readout .swatch{width:42px;height:42px;border-radius:10px; background:#3F6B52; box-shadow:inset 0 0 0 1px var(--line)}
.readout-vals{display:flex; flex-direction:column; line-height:1.35}
.readout-vals b{font-size:12px; color:var(--ink-soft)} .readout-vals code{font-family:var(--mono); font-size:12.5px; color:var(--green-deep)}

/* ============================ MARQUEE ============================ */
.marquee{background:var(--green-dark); color:var(--cream); overflow:hidden; padding:0; border-block:0}
.marquee{padding-block:0}
.marquee-track{display:flex; gap:26px; align-items:center; white-space:nowrap; padding:18px 0; width:max-content;
  animation:scroll 24s linear infinite; font-family:var(--display); font-weight:800; font-size:clamp(20px,3vw,34px); letter-spacing:.02em}
.marquee-track b{color:var(--gold)}
.marquee-track span{opacity:.92}
@keyframes scroll{to{transform:translateX(-33.33%)}}

/* ============================ FEATURES ============================ */
.sec-head{max-width:var(--maxw); margin:0 auto clamp(40px,6vw,70px); text-align:center}
.kicker{font-weight:700; color:var(--clay); text-transform:uppercase; letter-spacing:.12em; font-size:13px; margin:0 0 12px}
.sec-head h2{font-size:clamp(34px,5vw,58px)}
.sec-sub{color:var(--ink-soft); margin:14px auto 0; max-width:34em}
.features{max-width:var(--maxw); margin:0 auto; display:flex; flex-direction:column; gap:clamp(60px,9vw,120px)}
.feature{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(30px,5vw,70px); align-items:center}
.feature.reverse{grid-template-columns:1.1fr .9fr}
.feature.reverse .feature-media{order:2}
.feature-media{display:flex; justify-content:center}
.feat-no{font-family:var(--mono); color:var(--clay); font-size:14px; letter-spacing:.1em}
.feature-body h3{font-size:clamp(28px,3.6vw,42px); margin:8px 0 14px}
.feature-body p{color:var(--ink-soft); font-size:18px; max-width:32em}
.ticks{list-style:none; padding:0; margin:20px 0 0; display:flex; flex-direction:column; gap:10px}
.ticks li{position:relative; padding-left:30px; font-weight:500}
.ticks li::before{content:"✓"; position:absolute; left:0; top:-1px; width:20px;height:20px; display:grid; place-items:center;
  background:var(--green); color:#fff; border-radius:50%; font-size:12px; font-weight:800}
.region-chips,.chapter-row{display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; align-items:center}
.region-chips span{font-weight:600; font-size:14px; padding:8px 14px; border-radius:999px; background:var(--paper); box-shadow:inset 0 0 0 1px var(--line)}
.chapter-row img{width:46px;height:46px;border-radius:50%; box-shadow:0 6px 14px -6px rgba(12,44,33,.4)}
.chapter-row span{font-weight:600; font-size:14px; margin-right:8px}

/* device frame */
.device{position:relative; width:min(280px,72vw); border-radius:38px; padding:11px; background:#0C1A14;
  box-shadow:var(--shadow), inset 0 0 0 2px rgba(255,255,255,.06); transition:transform .4s}
.device img{display:block; width:100%; border-radius:28px}
.device::after{content:""; position:absolute; top:13px; left:50%; transform:translateX(-50%); width:42%; height:17px; background:#0C1A14; border-radius:0 0 13px 13px}
.tilt-l{transform:rotate(-3deg)} .tilt-r{transform:rotate(3deg)}
.feature:hover .device{transform:rotate(0) translateY(-6px)}

/* creative illustration frame (replaces phone screenshots) */
.art{position:relative; width:min(440px,84vw); transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.art::before{content:""; position:absolute; inset:-8% -10%; z-index:0; filter:blur(2px); opacity:.18;
  border-radius:46% 54% 58% 42%/52% 46% 54% 48%; background:var(--art-accent,var(--green));
  animation:morph 14s ease-in-out infinite}
.art::after{content:""; position:absolute; width:26px;height:26px; right:6%; top:-3%; border-radius:50% 50% 50% 0;
  background:var(--art-accent,var(--green)); opacity:.5; transform:rotate(12deg)}
.art img{position:relative; z-index:1; display:block; width:100%; border-radius:28px; background:var(--paper);
  border:7px solid var(--paper); box-shadow:var(--shadow)}
.art-green{--art-accent:var(--green)} .art-olive{--art-accent:var(--olive)}
.art-clay{--art-accent:var(--clay)} .art-gold{--art-accent:var(--gold)}
.feature:hover .art{transform:rotate(0) translateY(-8px)}
@keyframes morph{0%,100%{border-radius:46% 54% 58% 42%/52% 46% 54% 48%}50%{border-radius:58% 42% 45% 55%/45% 58% 42% 55%}}

/* ============================ SURFACES ============================ */
.surfaces{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.tier-grid{max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.tile{margin:0; background:var(--paper); border-radius:var(--r-md); overflow:hidden; box-shadow:0 10px 26px -16px rgba(12,44,33,.4); transition:transform .25s, box-shadow .25s}
.tile:hover{transform:translateY(-6px); box-shadow:0 22px 38px -18px rgba(12,44,33,.5)}
.tile img{display:block; width:100%; aspect-ratio:1; object-fit:cover}
.tile figcaption{padding:13px 14px 16px; display:flex; flex-direction:column; gap:8px; position:relative}
.tier{position:absolute; top:-22px; left:12px; width:34px;height:34px;border-radius:10px; display:grid; place-items:center;
  color:#fff; font-family:var(--display); font-weight:800; box-shadow:0 6px 12px -4px rgba(0,0,0,.4)}
.tier.s{background:#2E7D52} .tier.a{background:#6BA368} .tier.b{background:#CBA23B} .tier.c{background:#B9692F}
.tile b{font-size:15px; margin-top:6px}
.meter{display:flex; gap:4px}
.meter i{flex:1; height:6px; border-radius:3px; background:var(--cream-2); box-shadow:inset 0 0 0 1px var(--line)}
.tile.in .meter i.on{background:var(--green)}
.meter i{transition:background .4s}

/* ============================ HOW ============================ */
.how{max-width:var(--maxw); margin:0 auto}
.steps{list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:s}
.step{background:var(--paper); border-radius:var(--r-lg); padding:32px 28px; box-shadow:0 14px 30px -20px rgba(12,44,33,.45); position:relative; overflow:hidden}
.step::before{content:""; position:absolute; right:-30px; top:-30px; width:120px;height:120px; border-radius:50%; background:rgba(31,111,84,.07)}
.step-no{font-family:var(--display); font-weight:800; font-size:54px; color:var(--green); opacity:.25; display:block; line-height:1}
.step h4{font-size:22px; margin:6px 0 10px}
.step p{color:var(--ink-soft); margin:0; font-size:16px}

/* ============================ GET CTA ============================ */
.get{background:radial-gradient(120% 140% at 80% 0%, var(--green-deep), var(--green-dark)); color:var(--cream)}
.get-inner{max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:auto 1fr; gap:clamp(20px,5vw,60px); align-items:center}
.get-char{width:min(240px,40vw); filter:drop-shadow(0 24px 26px rgba(0,0,0,.4))}
.get-copy h2{font-size:clamp(34px,5vw,62px); color:#fff}
.get-copy p{color:rgba(244,240,228,.82); font-size:19px; max-width:34em; margin:16px 0 26px}
.soon{font-size:14px; color:rgba(244,240,228,.6); margin-top:18px!important}
.soon span{font-family:var(--mono)}

/* ============================ FOOTER ============================ */
.footer{background:var(--green-dark); color:var(--cream); padding:48px clamp(16px,4vw,48px); display:flex; flex-wrap:wrap; gap:24px; align-items:center; justify-content:space-between}
.foot-brand{display:flex; gap:14px; align-items:center}
.foot-brand img{width:46px;height:46px;border-radius:12px}
.foot-brand strong{display:block; font-family:var(--display)}
.foot-brand span{font-size:14px; color:rgba(244,240,228,.65)}
.foot-links{display:flex; gap:22px; font-weight:600; font-size:15px}
.foot-links a{color:rgba(244,240,228,.85)} .foot-links a:hover{color:#fff}
.foot-legal{width:100%; border-top:1px solid rgba(244,240,228,.14); padding-top:20px; margin:8px 0 0; font-size:13px; color:rgba(244,240,228,.55)}

/* ============================ REVEAL ANIM ============================ */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}
.hero .reveal{transition-delay:0s}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important; scroll-behavior:auto}
  .reveal{opacity:1; transform:none}
}

/* ============================ RESPONSIVE ============================ */
@media(max-width:900px){
  .hero{grid-template-columns:1fr; text-align:center; gap:24px}
  .hero-copy{order:1} .hero-art{order:2; min-height:380px}
  .lede{margin-inline:auto} .cta-row,.pills{justify-content:center}
  .feature,.feature.reverse{grid-template-columns:1fr; text-align:center}
  .feature.reverse .feature-media{order:0}
  .feature-body p,.lede{margin-inline:auto}
  .ticks{display:inline-flex; text-align:left}
  .region-chips,.chapter-row{justify-content:center}
  .tier-grid{grid-template-columns:repeat(2,1fr); gap:24px 16px}
  .steps{grid-template-columns:1fr}
  .get-inner{grid-template-columns:1fr; text-align:center} .get-char{margin:0 auto}
  .cta-row{justify-content:center}
  .nav-links{display:none}
}
@media(max-width:430px){
  body{font-size:16px}
  .tier-grid{grid-template-columns:1fr 1fr}
  .brand-name{display:none}
}
