/* Oliv — sections: nav, hero, showcase, pricing, footer */
/* ---------- nav ---------- */
nav{
  position:sticky;top:0;z-index:60;
  background:rgba(243,238,223,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-in{display:flex;align-items:center;gap:2rem;height:68px}
.logo{font-family:'Fraunces',serif;font-size:1.55rem;font-weight:600;text-decoration:none;display:flex;align-items:baseline;letter-spacing:-.01em}
.logo .dot{width:.5em;height:.5em;border-radius:50%;background:var(--leaf);display:inline-block;margin-left:.13em;position:relative;top:-.04em}
.nav-links{display:flex;gap:1.6rem;margin-left:auto;font-size:.92rem;font-weight:500}
.nav-links a{text-decoration:none;color:var(--ink-soft)}
.nav-links a:hover{color:var(--leaf)}
.nav-dl{display:flex;gap:.55rem;margin-left:1.4rem}
.nav-dl .btn{padding:.5rem 1rem;font-size:.85rem}
@media(max-width:880px){.nav-links{display:none}.nav-dl{margin-left:auto}}
@media(max-width:480px){.nav-dl .btn span.lbl{display:none}.nav-dl .btn{padding:.55rem .8rem}}

/* ---------- hero ---------- */
.hero{padding:5.5rem 0 0;position:relative;overflow:hidden}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);max-width:14ch}
.hero h1 em{font-style:italic;color:var(--leaf)}
.hero p.lead{font-size:1.18rem;color:var(--ink-soft);max-width:54ch;margin:1.4rem 0 2.1rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-note{margin-top:.9rem;font-size:.83rem;color:var(--ink-soft)}
.hero-note a{color:var(--leaf)}
.branch{position:absolute;right:-60px;top:30px;width:340px;opacity:.5;pointer-events:none}
@media(max-width:760px){.branch{display:none}}

/* ---------- dashboard mock frame ---------- */
.shot{
  background:var(--pit);border-radius:var(--radius);
  border:1px solid rgba(38,41,29,.2);
  box-shadow:0 30px 80px rgba(38,41,29,.25);
  overflow:hidden;
}
.shot-bar{display:flex;gap:6px;padding:12px 14px;border-bottom:1px solid rgba(243,238,223,.07)}
.shot-bar i{width:10px;height:10px;border-radius:50%;background:rgba(243,238,223,.16)}
.shot-bar i:first-child{background:var(--pimento)}
.shot-body{padding:clamp(14px,3vw,28px);color:#E9E6D8;font-size:.8rem}
.hero .shot{margin:3.6rem auto 0;max-width:980px;transform:translateY(34px)}
.panel{background:var(--pit-2);border:1px solid rgba(243,238,223,.06);border-radius:12px;padding:16px}
.panel h4{font-family:'IBM Plex Mono',monospace;font-weight:500;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#9b9f86;margin-bottom:8px}
.big-num{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:500;color:#F0EDDD}
.delta{color:var(--young);font-size:.78rem}
.grid-2{display:grid;grid-template-columns:1.7fr 1fr;gap:16px}
@media(max-width:700px){.grid-2{grid-template-columns:1fr}}
.legend{display:flex;gap:14px;font-size:.7rem;color:#9b9f86;margin-top:6px}
.legend i{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px}
.cap-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid rgba(243,238,223,.06);font-size:.76rem}
.cap-row:last-child{border:none}
.cap-row .nm{display:flex;align-items:center;gap:8px;color:#cfcdb8}
.cap-row .nm i{width:8px;height:8px;border-radius:50%}
.cap-row .pct{color:#9b9f86;font-family:'IBM Plex Mono',monospace;font-size:.7rem}

/* ---------- marquee strip ---------- */
.strip{background:var(--pit);color:var(--brine);padding:5.5rem 0 1.1rem;overflow:hidden}
.strip-inner{display:flex;gap:3rem;white-space:nowrap;font-family:'IBM Plex Mono',monospace;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;opacity:.75;animation:slide 30s linear infinite;width:max-content;padding-bottom:1.1rem}
.strip-inner span::after{content:"●";color:var(--young);margin-left:3rem;font-size:.6rem;vertical-align:middle}
@keyframes slide{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .strip-inner{animation:none}
  .reveal{opacity:1 !important;transform:none !important}
  .btn{transition:none}
}

/* ---------- sections ---------- */
section{padding:6rem 0}
.sec-head{max-width:60ch;margin-bottom:3.2rem}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.9rem)}
.sec-head p{color:var(--ink-soft);margin-top:.9rem;font-size:1.05rem}

/* features */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media(max-width:880px){.feat-grid{grid-template-columns:1fr}}
.feat{
  background:#fff;background:rgba(255,255,255,.55);
  border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;
}
.feat .pip{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;background:var(--leaf)}
.feat:nth-child(2) .pip{background:var(--oil)}
.feat:nth-child(3) .pip{background:var(--pimento)}
.feat .pip svg{width:20px;height:20px;stroke:var(--brine)}
.feat h3{font-size:1.25rem;margin-bottom:.55rem}
.feat p{color:var(--ink-soft);font-size:.95rem}

/* showcase */
.show-row{display:grid;grid-template-columns:1fr 1.15fr;gap:3.4rem;align-items:center;margin-bottom:5.5rem}
.show-row:last-child{margin-bottom:0}
.show-row.flip .show-txt{order:2}
@media(max-width:880px){.show-row,.show-row.flip{grid-template-columns:1fr;gap:1.8rem}.show-row.flip .show-txt{order:0}}
.show-txt h3{font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:.8rem}
.show-txt p{color:var(--ink-soft)}
.show-txt ul{list-style:none;margin-top:1.1rem}
.show-txt li{padding-left:1.4rem;position:relative;margin-bottom:.45rem;color:var(--ink-soft);font-size:.95rem}
.show-txt li::before{content:"";position:absolute;left:0;top:.52em;width:8px;height:8px;border-radius:50%;background:var(--young)}

/* dark privacy band */
.dark{background:var(--pit);color:var(--brine)}
.dark .sec-head p{color:#b9bca6}
.priv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
@media(max-width:760px){.priv-grid{grid-template-columns:1fr}}
.priv{border:1px solid rgba(243,238,223,.12);border-radius:var(--radius);padding:1.7rem;background:var(--pit-2)}
.priv h3{font-size:1.15rem;margin-bottom:.5rem;color:var(--young-2)}
.priv p{color:#b9bca6;font-size:.94rem}
.priv .mono-tag{font-family:'IBM Plex Mono',monospace;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--oil);display:block;margin-bottom:.7rem}

/* pricing */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;max-width:880px;margin:0 auto}
@media(max-width:760px){.price-grid{grid-template-columns:1fr}}
.price{
  border-radius:var(--radius);padding:2.2rem;border:1px solid var(--line);
  background:rgba(255,255,255,.55);display:flex;flex-direction:column;
}
.price.hero-card{background:var(--leaf);color:var(--brine);border:none;position:relative;overflow:hidden}
.price.hero-card::after{
  content:"";position:absolute;right:-70px;top:-70px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, var(--young) 0 38%, var(--leaf-deep) 39% 100%);
  opacity:.5;
}
.price h3{font-size:1.3rem}
.price .amount{font-family:'Fraunces',serif;font-size:3rem;margin:.9rem 0 .2rem}
.price .amount small{font-size:1rem;font-family:'Hanken Grotesk',sans-serif;font-weight:500}
.price p.sub{font-size:.92rem;opacity:.85;margin-bottom:1.3rem}
.price ul{list-style:none;margin-bottom:1.8rem;flex:1;position:relative;z-index:1}
.price li{padding-left:1.4rem;position:relative;margin-bottom:.5rem;font-size:.94rem}
.price li::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border-radius:50%;background:var(--oil)}
.price.hero-card li::before{background:var(--young-2)}
.price .btn{justify-content:center;position:relative;z-index:1}
.badge{position:absolute;top:1.3rem;right:1.3rem;font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;background:var(--pit);color:var(--young);padding:.32rem .7rem;border-radius:999px;z-index:1}

/* faq */
.faq{max-width:760px;margin:0 auto}
details{border-bottom:1px solid var(--line);padding:1.1rem 0}
summary{cursor:pointer;font-weight:600;font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-family:'Fraunces',serif;font-size:1.4rem;color:var(--leaf);flex:none;transition:transform .2s}
details[open] summary::after{transform:rotate(45deg)}
details p{margin-top:.7rem;color:var(--ink-soft);font-size:.95rem}

/* footer */
footer{background:var(--pit);color:var(--brine);padding:6rem 0 3rem}
.foot-cta{text-align:center;margin-bottom:4.5rem}
.foot-cta h2{font-size:clamp(2rem,5vw,3.4rem);max-width:20ch;margin:0 auto 1rem}
.foot-cta h2 em{font-style:italic;color:var(--young)}
.foot-cta p{color:#b9bca6;margin-bottom:2.1rem}
.foot-cta .hero-cta{justify-content:center}
.foot-base{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(243,238,223,.12);padding-top:2rem;gap:1.5rem;flex-wrap:wrap;font-size:.85rem;color:#9b9f86}
.foot-base a{text-decoration:none}
.foot-base a:hover{color:var(--young)}
.foot-links{display:flex;gap:1.6rem}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
