/* HORTUS — Warm Magazine SaaS Platform (Aesop x Stripe) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;450;500;600;700&display=swap');

:root{
  --cream:#f6f4ea;
  --cream-2:#ecead9;
  --paper:#fbf9f0;
  --sand:#e0dcc6;
  --rule:#d4cfb7;
  --rule-2:rgba(45,55,38,.07);
  --ink:#1c2418;
  --ink-2:#3a4632;
  --ink-3:#5d6b54;
  --mute:#8a9080;
  --sage:#4a6a4a;
  --sage-d:#2f4830;
  --leaf:#7da064;
  --moss:#5b8246;
  --terra:#b4632d;
  --terra-d:#8c4519;
  --rose:#e4b8a8;
  --rose-d:#c98775;
  --amber:#d49538;
  --plum:#6e3a52;
  --sky:#5e8a98;
  --t:.4s cubic-bezier(.2,.7,.2,1);
  --t-fast:.18s ease;
  --shadow-1:0 2px 6px rgba(28,36,24,.05),0 1px 2px rgba(28,36,24,.04);
  --shadow-2:0 14px 38px -12px rgba(28,36,24,.18),0 4px 12px rgba(28,36,24,.06);
  --shadow-3:0 32px 70px -20px rgba(28,36,24,.30);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--cream);
  line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv01";
}
img{max-width:100%;display:block}
.skip-link{position:absolute;top:-40px;left:0;background:var(--ink);color:var(--cream);padding:10px 16px;border-radius:0 0 8px 0;z-index:9999;font-weight:600;font-size:.88rem}
.skip-link:focus{top:0;color:var(--leaf);outline:2px solid var(--leaf);outline-offset:2px}
*:focus-visible{outline:2px solid var(--sage);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}
a{color:inherit;text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--sage-d)}
h1,h2,h3,h4{font-family:'Fraunces','Georgia',serif;font-variation-settings:"opsz" 144;font-weight:500;color:var(--ink);margin:0 0 .5em;line-height:1.08;letter-spacing:-.018em}
h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:400}
h2{font-size:clamp(2rem,4vw,3.4rem);font-weight:400}
h3{font-size:1.5rem;font-weight:500}
h4{font-size:1.1rem;font-weight:600}
p{margin:0 0 1em;color:var(--ink-2)}
.serif{font-family:'Fraunces',serif}
.italic{font-style:italic;color:var(--sage)}
.mono{font-family:ui-monospace,'SF Mono',Consolas,monospace;font-size:.85em;letter-spacing:-.005em}

.container{max-width:1320px;margin:0 auto;padding:0 28px}
.container-narrow{max-width:920px;margin:0 auto;padding:0 28px}
@media (max-width:680px){.container,.container-narrow{padding:0 20px}}

/* ── ANNOUNCEMENT BAR (news strip) ───────────────────── */
.announce{background:var(--ink);color:var(--cream);padding:10px 28px;font-size:.82rem;display:flex;align-items:center;justify-content:center;gap:14px;text-align:center}
.announce strong{color:var(--rose)}
.announce a{color:var(--cream);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.announce a:hover{color:var(--rose)}
.announce svg{width:14px;height:14px;flex-shrink:0}
@media (max-width:680px){.announce{font-size:.72rem;padding:8px 16px}}

/* ── MEGA NAV ───────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,246,236,.92);backdrop-filter:blur(20px) saturate(170%);-webkit-backdrop-filter:blur(20px) saturate(170%);border-bottom:1px solid var(--rule)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:32px;padding:18px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:44px;height:44px;background:var(--ink);display:grid;place-items:center;color:var(--leaf);border-radius:14px;position:relative;overflow:hidden;padding:6px}
.brand-mark svg{width:100%;height:100%;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text .name{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:500}
.brand-text .tag{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:600;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:0}
.nav-links > li{position:relative;list-style:none}
.nav-links > li > a,.nav-links > li > button{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-size:.92rem;color:var(--ink-2);font-weight:500;cursor:pointer;background:none;border:0;font-family:inherit;transition:color var(--t-fast)}
.nav-links > li > a:hover,.nav-links > li > button:hover,.nav-links > li.has-menu:hover > button,.nav-links > li > a.active{color:var(--sage-d)}
.nav-links > li > a.active{font-weight:600}
.nav-links .chev{width:12px;height:12px;transition:transform var(--t-fast)}
.nav-links li.has-menu:hover .chev{transform:rotate(180deg)}

/* Mega panel */
.mega{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);background:var(--paper);border:1px solid var(--rule);border-radius:20px;padding:28px;min-width:680px;box-shadow:var(--shadow-3);opacity:0;visibility:hidden;transition:all var(--t);z-index:60}
.nav-links li.has-menu:hover .mega,.nav-links li.has-menu:focus-within .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.mega-feat{padding:22px;background:linear-gradient(135deg,var(--cream-2),var(--cream));border-radius:16px;border:1px solid var(--rule)}
.mega-feat .lbl{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;color:var(--terra);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.mega-feat .lbl svg{width:14px;height:14px}
.mega-feat h4{font-family:'Fraunces';font-size:1.25rem;margin-bottom:8px;font-weight:500;line-height:1.15}
.mega-feat h4 em{color:var(--sage);font-style:italic}
.mega-feat p{font-size:.85rem;margin-bottom:12px;color:var(--ink-2)}
.mega-feat .btn-link{font-size:.78rem;font-weight:600;color:var(--sage-d);border-bottom:1.5px solid var(--sage-d);padding-bottom:2px}
.mega-col h5{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;color:var(--mute);margin-bottom:14px}
.mega-link{display:flex;flex-direction:column;padding:8px 0;border-bottom:1px dashed var(--rule-2);transition:var(--t-fast)}
.mega-link:last-child{border-bottom:0}
.mega-link strong{font-size:.92rem;color:var(--ink);font-weight:600}
.mega-link span{font-size:.78rem;color:var(--mute);margin-top:1px}
.mega-link:hover{padding-left:6px;color:var(--sage-d)}
.mega-link:hover strong{color:var(--sage-d)}

.nav-cta{display:flex;align-items:center;gap:10px}
.lang{display:flex;font-size:.78rem;font-weight:600;color:var(--mute);padding:0 6px;gap:8px}
.lang a.active{color:var(--ink)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:99px;font-family:inherit;font-weight:600;font-size:.9rem;cursor:pointer;border:1.5px solid transparent;transition:all var(--t);white-space:nowrap}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--ink);color:var(--cream);box-shadow:0 4px 14px rgba(28,36,24,.18)}
.btn-primary:hover{background:var(--sage-d);transform:translateY(-1px);box-shadow:0 8px 22px rgba(47,72,48,.3)}
.btn-soft{background:var(--cream-2);color:var(--ink);border-color:var(--rule)}
.btn-soft:hover{background:var(--sand)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-link{padding:0;background:none;color:var(--sage-d);font-weight:600;display:inline-flex;align-items:center;gap:6px;border-bottom:1.5px solid var(--sage-d);padding-bottom:2px}
.btn-link:hover{gap:10px}
.btn-sm{padding:8px 16px;font-size:.82rem}
.menu-toggle{display:none;width:42px;height:42px;border-radius:50%;background:var(--cream-2);border:0;cursor:pointer;color:var(--ink);place-items:center}
@media (max-width:960px){
  .nav-links{display:none;position:absolute;top:100%;left:16px;right:16px;flex-direction:column;background:var(--paper);padding:12px;border-radius:18px;margin-top:8px;box-shadow:var(--shadow-3);align-items:stretch;gap:0}
  .nav-links.open{display:flex}
  .nav-links > li{width:100%}
  .nav-links > li > a,.nav-links > li > button{width:100%;padding:14px;border-bottom:1px solid var(--rule-2);justify-content:space-between}
  .mega{position:static;transform:none;min-width:0;width:100%;padding:14px;box-shadow:none;border:0;background:var(--cream-2);opacity:1;visibility:visible;display:none;border-radius:14px}
  .nav-links li.has-menu.open .mega{display:block}
  .mega-grid{grid-template-columns:1fr;gap:14px}
  .menu-toggle{display:grid}
}

/* ── HERO ─────────────────────────────────────────────── */
.hero{position:relative;padding:60px 0 100px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;position:relative}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 16px;background:var(--cream-2);border:1px solid var(--rule);border-radius:99px;font-size:.76rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--sage-d);margin-bottom:24px}
.eyebrow svg{width:14px;height:14px}
.eyebrow.terra{background:rgba(180,99,45,.10);border-color:rgba(180,99,45,.3);color:var(--terra-d)}
.hero h1{letter-spacing:-.025em;margin-bottom:20px}
.hero h1 em{font-style:italic;color:var(--sage);font-weight:400}
.hero h1 .swash{position:relative;display:inline-block}
.hero h1 .swash::after{content:"";position:absolute;left:0;right:0;bottom:8px;height:10px;background:var(--rose);z-index:-1;opacity:.5;border-radius:8px;transform:rotate(-1deg)}
.hero-lede{font-size:1.18rem;color:var(--ink-2);max-width:560px;margin:20px 0 36px;line-height:1.6}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;flex-wrap:wrap;gap:0;margin-top:56px;padding-top:32px;border-top:1px solid var(--rule)}
.hero-stat{padding:0 28px 0 0;border-right:1px dashed var(--rule);margin-right:28px}
.hero-stat:last-child{border:0;margin:0;padding-right:0}
.hero-stat strong{display:block;font-family:'Fraunces',serif;font-size:1.9rem;font-weight:500;color:var(--sage-d);line-height:1;margin-bottom:4px}
.hero-stat span{font-size:.82rem;color:var(--mute);font-weight:500}

/* hero visual collage */
.hero-visual{position:relative;aspect-ratio:1}
.hero-blob{position:absolute;inset:-30px;background:radial-gradient(circle at 30% 40%,rgba(228,184,168,.4),transparent 60%);filter:blur(40px)}
.hero-photo-main{position:absolute;inset:0;border-radius:48% 52% 50% 50% / 40% 50% 50% 60%;overflow:hidden;box-shadow:var(--shadow-3)}
.hero-photo-main img{width:100%;height:100%;object-fit:cover;animation:slowzoom 20s ease-in-out infinite alternate}
@keyframes slowzoom{from{transform:scale(1)}to{transform:scale(1.06)}}
.hero-card{position:absolute;background:var(--paper);border-radius:18px;box-shadow:var(--shadow-3);border:1px solid var(--rule);overflow:hidden;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-card-1{top:-20px;right:-20px;width:240px;padding:18px 20px;animation-delay:0s;z-index:3}
.hero-card-2{bottom:30px;left:-30px;width:220px;padding:16px;animation-delay:1.5s;z-index:3}
.hero-card .lbl{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:6px}
.hero-card .lbl svg{width:12px;height:12px;color:var(--terra)}
.hero-card .val{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:500;color:var(--ink);line-height:1}
.hero-card .val small{font-size:.85rem;color:var(--mute);font-weight:400;margin-left:2px;font-family:'Inter'}
.hero-card .desc{font-size:.78rem;color:var(--ink-2);margin-top:6px}
.hero-card .row{display:flex;justify-content:space-between;padding:4px 0;font-size:.78rem;color:var(--ink-2);border-bottom:1px dashed var(--rule-2)}
.hero-card .row:last-child{border:0}
.hero-card .row strong{font-family:'Fraunces';font-weight:500;color:var(--sage-d)}
@media (max-width:960px){.hero-card-1{position:relative;top:auto;right:auto;width:auto;margin:-20px 24px 0;z-index:5}.hero-card-2{display:none}}

/* ── TRUST STRIP ────────────────────────────────────── */
.trust-strip{background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:36px 0}
.trust-grid{display:grid;grid-template-columns:auto repeat(5,1fr);align-items:center;gap:40px}
@media (max-width:960px){.trust-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
.trust-label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--mute);font-family:'Inter'}
.trust-item{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:500;color:var(--ink-2);font-style:italic;text-align:center;opacity:.7;transition:var(--t-fast)}
.trust-item:hover{opacity:1;color:var(--sage-d)}

/* ── SECTIONS ───────────────────────────────────────── */
section.block{padding:100px 0;position:relative}
section.block-tight{padding:60px 0}
.section-head{margin-bottom:60px;max-width:780px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2 em{font-style:italic;color:var(--sage)}
.section-head h2 .swash{position:relative;display:inline-block}
.section-head h2 .swash::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:10px;background:var(--rose);opacity:.45;z-index:-1;border-radius:8px}
.section-head p{font-size:1.1rem;color:var(--ink-2)}

/* ── BENTO LAYOUT (mixed grid for index) ────────────── */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;grid-auto-rows:minmax(180px,auto)}
@media (max-width:960px){.bento{grid-template-columns:repeat(2,1fr)}}
.bento-cell{background:var(--paper);border:1px solid var(--rule);border-radius:24px;padding:28px;position:relative;overflow:hidden;transition:var(--t)}
.bento-cell:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--rule);background:var(--cream-2)}
.bento-cell .ic{width:42px;height:42px;border-radius:12px;background:var(--cream-2);color:var(--sage-d);display:grid;place-items:center;margin-bottom:14px}
.bento-cell .ic svg{width:18px;height:18px}
.bento-cell h4{font-size:1.2rem;margin-bottom:8px}
.bento-cell h4 em{font-style:italic;color:var(--sage)}
.bento-cell p{font-size:.92rem;margin:0;color:var(--ink-2)}
.bento-cell .lbl{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--mute);margin-bottom:8px}
.bento-cell.feature{grid-column:span 3;grid-row:span 2;background:var(--ink);color:var(--cream)}
.bento-cell.feature h4{color:var(--cream);font-size:1.8rem}
.bento-cell.feature p{color:rgba(251,246,236,.7)}
.bento-cell.feature .ic{background:rgba(251,246,236,.1);color:var(--leaf)}
.bento-cell.feature .demo{margin-top:24px;background:rgba(251,246,236,.05);border:1px solid rgba(251,246,236,.12);border-radius:14px;padding:18px;font-family:ui-monospace;font-size:.82rem;color:rgba(251,246,236,.85)}
.bento-cell.feature .demo-tag{color:var(--leaf);font-weight:600}
.bento-cell.span-2{grid-column:span 2}
.bento-cell.span-3{grid-column:span 3}
.bento-cell.span-4{grid-column:span 4}
.bento-cell.row-2{grid-row:span 2}
.bento-cell.terra{background:var(--terra);color:var(--cream);border-color:var(--terra-d)}
.bento-cell.terra h4,.bento-cell.terra p{color:var(--cream)}
.bento-cell.terra .ic{background:rgba(251,246,236,.15);color:var(--cream)}
.bento-cell.rose{background:var(--rose);border-color:var(--rose-d)}
.bento-cell.photo{padding:0;overflow:hidden}
.bento-cell.photo img{width:100%;height:100%;object-fit:cover;display:block}
.bento-cell .arrow{position:absolute;bottom:24px;right:24px;width:36px;height:36px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;transition:var(--t-fast)}
.bento-cell:hover .arrow{transform:translate(4px,-4px)}
.bento-cell .stat-big{font-family:'Fraunces';font-size:3.2rem;font-weight:500;color:var(--sage-d);line-height:1;margin-bottom:8px}
@media (max-width:960px){.bento-cell.span-2,.bento-cell.span-3,.bento-cell.span-4,.bento-cell.feature{grid-column:span 2}.bento-cell.row-2{grid-row:span 1}}

/* ── PRODUCTS — magazine row with mini gallery ───── */
.prod-section{padding:100px 0;background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:980px){.prod-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.prod-grid{grid-template-columns:1fr}}
.prod-card{background:var(--cream);border:1px solid var(--rule);border-radius:24px;overflow:hidden;transition:var(--t);display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-2)}
.prod-card-photo{aspect-ratio:5/4;background:var(--cream-2);overflow:hidden;position:relative}
.prod-card-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.prod-card:hover .prod-card-photo img{transform:scale(1.05)}
.prod-tag{position:absolute;top:14px;left:14px;padding:5px 12px;border-radius:99px;background:var(--paper);color:var(--sage-d);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;box-shadow:var(--shadow-1)}
.prod-tag.terra{background:var(--terra);color:var(--cream)}
.prod-tag.amber{background:var(--amber);color:var(--ink)}
.prod-card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.prod-card-body h3{font-size:1.4rem;margin-bottom:6px}
.prod-card-body h3 em{font-style:italic;color:var(--sage)}
.prod-card-body p{font-size:.88rem;margin-bottom:16px;color:var(--ink-2);flex:1}
.prod-price{display:flex;align-items:baseline;gap:8px;margin-bottom:18px;padding-top:14px;border-top:1px dashed var(--rule)}
.prod-price strong{font-family:'Fraunces';font-size:1.6rem;font-weight:600;color:var(--ink);line-height:1}
.prod-price .was{text-decoration:line-through;color:var(--mute);font-size:.85rem}
.prod-price small{color:var(--mute);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600}
.prod-card .btn{justify-content:center}

/* ── DOCS HUB ───────────────────────────────────────── */
.docs-section{padding:100px 0;background:var(--cream)}
.docs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
@media (max-width:880px){.docs-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.docs-grid{grid-template-columns:1fr}}
.docs-cell{padding:32px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--paper);transition:var(--t)}
.docs-cell:hover{background:var(--cream-2)}
.docs-cell .lbl{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--mute);font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:6px}
.docs-cell .lbl svg{width:12px;height:12px;color:var(--terra)}
.docs-cell h4{font-family:'Fraunces';font-size:1.3rem;font-weight:500;margin-bottom:8px;line-height:1.15}
.docs-cell p{font-size:.88rem;color:var(--ink-2);margin-bottom:14px}
.docs-cell .count{font-size:.78rem;color:var(--mute);font-weight:500;display:flex;align-items:center;gap:4px}
.docs-cell .count::before{content:"●";color:var(--leaf)}

/* ── TUTORIALS — video card grid ─────────────────── */
.tut-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.tut-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.tut-grid{grid-template-columns:1fr}}
.tut-card{background:var(--paper);border:1px solid var(--rule);border-radius:22px;overflow:hidden;transition:var(--t);display:flex;flex-direction:column}
.tut-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.tut-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#5a7f5e,#3d5f42);position:relative;overflow:hidden}
.tut-thumb img{width:100%;height:100%;object-fit:cover;opacity:.85}
.tut-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4))}
.tut-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;border-radius:50%;background:var(--cream);display:grid;place-items:center;box-shadow:0 8px 24px rgba(0,0,0,.3);transition:var(--t)}
.tut-card:hover .tut-play{transform:translate(-50%,-50%) scale(1.1)}
.tut-play::after{content:"";display:block;width:0;height:0;margin-left:4px;border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent var(--ink)}
.tut-duration{position:absolute;bottom:12px;right:12px;background:rgba(28,36,24,.85);color:var(--cream);font-family:ui-monospace;font-size:.7rem;padding:3px 8px;border-radius:6px;font-weight:600}
.tut-level{position:absolute;top:12px;left:12px;background:var(--cream);color:var(--sage-d);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:99px}
.tut-body{padding:22px;flex:1;display:flex;flex-direction:column}
.tut-meta{font-size:.7rem;color:var(--mute);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;display:flex;gap:12px}
.tut-body h4{font-family:'Fraunces';font-weight:500;font-size:1.15rem;margin-bottom:8px;line-height:1.2}
.tut-body p{font-size:.85rem;color:var(--ink-2);margin:0 0 14px;flex:1}
.tut-progress{height:4px;background:var(--cream-2);border-radius:99px;overflow:hidden;margin-bottom:8px}
.tut-progress > div{height:100%;background:var(--sage);transition:width .8s ease}
.tut-progress-label{font-size:.72rem;color:var(--mute)}

/* ── NEWS / BLOG / UPDATES ──────────────────────── */
.updates-section{padding:100px 0;background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.updates-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.updates-tabs{display:flex;border:1px solid var(--rule);border-radius:99px;padding:4px;background:var(--cream-2);gap:0}
.updates-tabs a{padding:9px 18px;border-radius:99px;font-size:.82rem;color:var(--ink-2);font-weight:600}
.updates-tabs a.active{background:var(--ink);color:var(--cream)}
.updates-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:24px}
@media (max-width:980px){.updates-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.updates-grid{grid-template-columns:1fr}}
.update-card{background:var(--cream);border:1px solid var(--rule);border-radius:22px;overflow:hidden;transition:var(--t)}
.update-card:hover{box-shadow:var(--shadow-2);transform:translateY(-3px)}
.update-card.featured{grid-row:span 2;display:flex;flex-direction:column}
.update-photo{aspect-ratio:5/3;overflow:hidden;background:var(--cream-2);position:relative}
.update-card.featured .update-photo{aspect-ratio:5/4}
.update-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.update-card:hover .update-photo img{transform:scale(1.05)}
.update-cat{position:absolute;top:14px;left:14px;background:var(--paper);color:var(--sage-d);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:5px 12px;border-radius:99px;box-shadow:var(--shadow-1)}
.update-cat.firmware{background:var(--terra);color:var(--cream)}
.update-cat.product{background:var(--amber);color:var(--ink)}
.update-body{padding:22px;flex:1;display:flex;flex-direction:column}
.update-card.featured .update-body{padding:32px}
.update-meta{font-size:.72rem;color:var(--mute);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px}
.update-body h4{font-family:'Fraunces';font-weight:500;font-size:1.2rem;margin-bottom:10px;line-height:1.15}
.update-card.featured .update-body h4{font-size:1.8rem}
.update-body p{font-size:.9rem;color:var(--ink-2);margin:0 0 14px;flex:1}

/* ── NEWSLETTER ─────────────────────────────────── */
.newsletter-block{padding:80px 60px;background:linear-gradient(135deg,var(--sage-d),var(--sage));color:var(--cream);border-radius:40px;position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.newsletter-block::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,var(--leaf),transparent 60%);filter:blur(50px);opacity:.4}
@media (max-width:880px){.newsletter-block{grid-template-columns:1fr;padding:60px 40px}}
.newsletter-block h2{color:var(--cream);font-size:clamp(2rem,3.5vw,3rem);margin-bottom:14px;position:relative}
.newsletter-block h2 em{color:var(--rose);font-style:italic}
.newsletter-block p{color:rgba(251,246,236,.85);margin:0;position:relative;font-size:1.05rem}
.newsletter-form{display:flex;gap:0;background:var(--cream);border-radius:99px;padding:6px;position:relative;box-shadow:0 12px 30px rgba(0,0,0,.2)}
.newsletter-form input{flex:1;padding:14px 22px;background:transparent;border:0;font-family:inherit;font-size:.95rem;color:var(--ink);min-width:0}
.newsletter-form input:focus{outline:none}
.newsletter-form button{padding:14px 24px;background:var(--ink);color:var(--cream);border:0;border-radius:99px;font-family:inherit;font-weight:600;font-size:.92rem;cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.newsletter-form button:hover{background:var(--sage-d)}
.newsletter-perks{margin-top:18px;display:flex;gap:18px;flex-wrap:wrap;position:relative}
.newsletter-perks span{font-size:.78rem;color:rgba(251,246,236,.7);display:inline-flex;align-items:center;gap:6px}
.newsletter-perks svg{width:13px;height:13px;color:var(--leaf)}

/* ── PRICING / SERVICE TIERS ────────────────────── */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.tiers{grid-template-columns:1fr}}
.tier{background:var(--paper);border:1px solid var(--rule);border-radius:28px;padding:36px 32px;position:relative;transition:var(--t)}
.tier:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.tier.featured{background:var(--ink);color:var(--cream);border-color:var(--ink);transform:scale(1.03)}
.tier.featured:hover{transform:scale(1.03) translateY(-4px)}
.tier .ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--terra);color:var(--cream);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;font-weight:700;padding:6px 16px;border-radius:99px;box-shadow:var(--shadow-1)}
.tier-name{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:700;margin-bottom:12px}
.tier.featured .tier-name{color:var(--leaf)}
.tier h3{font-family:'Fraunces';font-weight:500;margin-bottom:16px;color:var(--ink)}
.tier.featured h3{color:var(--cream)}
.tier .price{font-family:'Fraunces';font-size:3rem;font-weight:500;line-height:1;margin-bottom:8px;color:var(--sage-d)}
.tier.featured .price{color:var(--leaf)}
.tier .price small{font-size:.85rem;color:var(--mute);font-weight:400;font-family:'Inter'}
.tier.featured .price small{color:rgba(251,246,236,.6)}
.tier .desc{font-size:.92rem;margin-bottom:24px;color:var(--ink-2)}
.tier.featured .desc{color:rgba(251,246,236,.7)}
.tier ul{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px}
.tier li{display:flex;align-items:flex-start;gap:10px;font-size:.92rem;color:var(--ink-2)}
.tier.featured li{color:rgba(251,246,236,.85)}
.tier li svg{flex-shrink:0;margin-top:3px;color:var(--sage);width:16px;height:16px}
.tier.featured li svg{color:var(--leaf)}
.tier .btn{width:100%;justify-content:center}

/* ── APP TEASER ───────────────────────────────── */
.app-teaser{padding:100px 0;background:var(--paper);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.app-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
@media (max-width:880px){.app-grid{grid-template-columns:1fr;gap:40px}}
.phone-stack{position:relative;display:flex;justify-content:center;align-items:center}
.phone{width:280px;height:560px;background:linear-gradient(180deg,#2a3025,#1d231a);border-radius:48px;padding:8px;box-shadow:var(--shadow-3),inset 0 0 0 6px #3a4230;position:relative;overflow:hidden;animation:phoneFloat 6s ease-in-out infinite}
@keyframes phoneFloat{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-12px) rotate(0deg)}}
.phone::before{content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);width:100px;height:24px;background:#1a221d;border-radius:99px;z-index:2}
.phone-screen{width:100%;height:100%;background:var(--cream);border-radius:42px;padding:54px 16px 20px;display:flex;flex-direction:column;gap:8px}
.phone-status{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage-d);font-weight:700;padding:0 6px;display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.phone-status::before{content:"●";color:var(--sage)}
.phone-tile{padding:12px 14px;background:var(--paper);border:1px solid var(--rule);border-radius:14px;display:flex;justify-content:space-between;align-items:center}
.phone-tile .lbl{font-size:.58rem;color:var(--mute);letter-spacing:.08em;text-transform:uppercase;font-weight:700}
.phone-tile .desc{font-size:.7rem;color:var(--ink);font-weight:600;margin-top:2px}
.phone-tile .v{font-family:'Fraunces';font-weight:500;color:var(--sage-d);font-size:1rem}
.phone-chart{flex:1;background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:12px;display:flex;flex-direction:column}
.coming-tag{position:absolute;top:-16px;right:-30px;background:var(--terra);color:var(--cream);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:10px 18px;border-radius:99px;transform:rotate(8deg);box-shadow:var(--shadow-3);z-index:3}

/* ── VOICES / TESTIMONIALS ─────────────────────── */
.voices-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:880px){.voices-grid{grid-template-columns:1fr}}
.voice{padding:36px 32px;background:var(--paper);border:1px solid var(--rule);border-radius:24px;position:relative;transition:var(--t)}
.voice:hover{box-shadow:var(--shadow-2);transform:translateY(-3px)}
.voice .stars{color:var(--amber);letter-spacing:.15em;margin-bottom:16px}
.voice blockquote{margin:0 0 22px;font-family:'Fraunces';font-style:italic;font-weight:400;font-size:1.25rem;line-height:1.4;color:var(--ink)}
.voice-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px dashed var(--rule)}
.voice-init{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--leaf),var(--sage));color:var(--cream);font-family:'Fraunces';font-weight:500;display:grid;place-items:center;font-size:1rem}
.voice-author strong{display:block;font-weight:600;font-size:.95rem}
.voice-author span{font-size:.78rem;color:var(--mute)}

/* ── CTA BLOCK ─────────────────────────────────── */
.cta-block{padding:80px 60px;text-align:center;background:linear-gradient(135deg,var(--ink) 0%,#2c3826 100%);color:var(--cream);border-radius:48px;position:relative;overflow:hidden}
.cta-block::before{content:"";position:absolute;top:-50%;left:-30%;width:160%;height:120%;background:radial-gradient(ellipse,rgba(125,160,100,.18),transparent 60%)}
.cta-block h2{color:var(--cream);position:relative;margin-bottom:14px}
.cta-block h2 em{color:var(--rose)}
.cta-block p{color:rgba(251,246,236,.8);font-size:1.15rem;max-width:580px;margin:0 auto 32px;position:relative}
.cta-block .hero-cta{justify-content:center;position:relative}
.cta-block .btn-primary{background:var(--cream);color:var(--ink)}
.cta-block .btn-primary:hover{background:var(--rose);color:var(--ink)}
.cta-block .btn-ghost{border-color:var(--cream);color:var(--cream)}
.cta-block .btn-ghost:hover{background:var(--cream);color:var(--ink)}

/* ── FOOTER (multi-column with newsletter) ───── */
.site-footer{background:var(--ink);color:rgba(251,246,236,.7);padding:80px 0 32px;margin-top:60px}
.foot-top{display:grid;grid-template-columns:1.5fr 3fr;gap:48px;margin-bottom:60px;padding-bottom:48px;border-bottom:1px solid rgba(251,246,236,.15)}
@media (max-width:880px){.foot-top{grid-template-columns:1fr;gap:40px}}
.foot-brand p{margin:18px 0 0;max-width:280px;font-size:.92rem;color:rgba(251,246,236,.6)}
.site-footer .brand-text .name{color:var(--cream)}
.site-footer .brand-text .tag{color:var(--leaf)}
.foot-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
@media (max-width:780px){.foot-cols{grid-template-columns:1fr 1fr}}
.foot-cols h5{color:var(--cream);font-family:'Fraunces';font-size:1.05rem;font-weight:500;margin-bottom:18px}
.foot-cols a{display:block;padding:5px 0;font-size:.92rem;color:rgba(251,246,236,.6)}
.foot-cols a:hover{color:var(--cream)}
.foot-cols .new{display:inline-block;margin-left:6px;padding:2px 6px;background:var(--terra);color:var(--cream);font-size:.62rem;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;font-weight:600}
.foot-bottom{display:flex;justify-content:space-between;font-size:.82rem;color:rgba(251,246,236,.4)}
.foot-social{display:flex;gap:12px}
.foot-social a{width:38px;height:38px;border:1px solid rgba(251,246,236,.2);border-radius:50%;display:grid;place-items:center;padding:0;transition:var(--t-fast)}
.foot-social a:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.foot-social svg{width:16px;height:16px}

/* ── INSIDE PAGE STYLES ──────────────────────── */
.page-hero{padding:80px 0;text-align:center;border-bottom:1px solid var(--rule)}
.page-hero .eyebrow{margin-bottom:16px}
.page-hero h1{margin-bottom:14px}
.page-hero h1 em{color:var(--sage);font-style:italic}
.page-hero p{font-size:1.15rem;max-width:720px;margin:0 auto;color:var(--ink-2)}
.breadcrumb{display:inline-flex;gap:8px;font-size:.78rem;color:var(--mute);margin-bottom:18px;letter-spacing:.04em;align-items:center;font-weight:500}
.breadcrumb a:hover{color:var(--sage-d)}
.breadcrumb svg{width:10px;height:10px;color:var(--mute)}

/* ── DOCS PAGE LAYOUT ──────────────────────────── */
.docs-page{display:grid;grid-template-columns:260px 1fr;gap:48px;padding:48px 0;min-height:80vh}
@media (max-width:980px){.docs-page{grid-template-columns:1fr}}
.docs-sidebar{position:sticky;top:120px;align-self:start;padding:24px;background:var(--paper);border:1px solid var(--rule);border-radius:20px}
.docs-sidebar h5{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:700;margin:18px 0 10px}
.docs-sidebar h5:first-child{margin-top:0}
.docs-sidebar a{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:10px;font-size:.88rem;color:var(--ink-2);transition:var(--t-fast)}
.docs-sidebar a:hover{background:var(--cream-2);color:var(--ink)}
.docs-sidebar a.active{background:var(--sage-d);color:var(--cream)}
.docs-sidebar a .count{font-size:.7rem;color:var(--mute);font-weight:600}
.docs-sidebar a.active .count{color:rgba(251,246,236,.7)}
.docs-main h2{font-size:clamp(2rem,3.5vw,3rem);margin-bottom:14px}
.docs-search{position:relative;margin-bottom:28px}
.docs-search input{width:100%;padding:14px 22px 14px 50px;background:var(--paper);border:1px solid var(--rule);border-radius:99px;font-family:inherit;font-size:.95rem}
.docs-search svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--mute)}
.doc-article{padding:24px;background:var(--paper);border:1px solid var(--rule);border-radius:18px;margin-bottom:14px;transition:var(--t)}
.doc-article:hover{box-shadow:var(--shadow-1);border-color:var(--sage)}
.doc-article-meta{display:flex;gap:14px;font-size:.72rem;color:var(--mute);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.doc-article h3{font-family:'Fraunces';font-weight:500;font-size:1.25rem;margin-bottom:6px}
.doc-article p{font-size:.92rem;margin:0;color:var(--ink-2)}

/* ── FORMS ─────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--ink-2)}
.field input,.field select,.field textarea{padding:13px 16px;background:var(--paper);border:1px solid var(--rule);border-radius:14px;font-family:inherit;font-size:.95rem;color:var(--ink);transition:var(--t-fast)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 4px rgba(74,106,74,.10)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer}
.toggle input{display:none}
.toggle .track{width:42px;height:22px;background:var(--rule);border-radius:99px;position:relative;transition:var(--t)}
.toggle .track::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--cream);transition:var(--t);box-shadow:0 1px 2px rgba(0,0,0,.15)}
.toggle input:checked+.track{background:var(--sage)}
.toggle input:checked+.track::after{left:22px}

/* ── PANEL (dashboard) ────────────────────────── */
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;padding:24px 18px;background:var(--paper);border-right:1px solid var(--rule);display:flex;flex-direction:column;overflow-y:auto}
.sidebar .brand{padding:0 6px 22px;border-bottom:1px dashed var(--rule);margin-bottom:8px}
.side-nav{display:flex;flex-direction:column;gap:1px;flex:1;margin-top:10px}
.side-section{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--mute);padding:18px 14px 6px}
.side-nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;color:var(--ink-2);font-size:.92rem;font-weight:500;transition:var(--t-fast)}
.side-nav a svg{width:18px;height:18px}
.side-nav a:hover{background:var(--cream-2)}
.side-nav a.active{background:var(--ink);color:var(--cream)}
.side-nav a.active svg{color:var(--cream)}
.side-nav a .badge{margin-left:auto;font-size:.7rem;color:var(--mute);font-weight:700;padding:2px 8px;background:var(--cream-2);border-radius:99px}
.side-nav a.active .badge{background:rgba(251,246,236,.15);color:var(--cream)}
.side-foot{margin-top:auto;padding:16px;border-radius:18px;background:var(--cream-2);display:flex;align-items:center;gap:12px}
.side-foot .avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--leaf),var(--sage));color:var(--cream);display:grid;place-items:center;font-family:'Fraunces';font-weight:500}
.side-foot .name{font-weight:600;font-size:.92rem;line-height:1.1}
.side-foot .role{font-size:.72rem;color:var(--mute);margin-top:2px}
.main{padding:32px 40px 60px;min-width:0}
.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding-bottom:24px;margin-bottom:32px;border-bottom:1px solid var(--rule)}
.topbar h2{margin:0;font-size:2rem}
.topbar h2 em{font-style:italic;color:var(--sage)}
.topbar p.lede{margin:6px 0 0;font-size:.95rem;color:var(--ink-2)}
.topbar-actions{display:flex;align-items:center;gap:10px}
.icon-btn{width:42px;height:42px;border-radius:50%;background:var(--paper);border:1px solid var(--rule);display:grid;place-items:center;color:var(--ink-2);cursor:pointer;transition:var(--t-fast);position:relative}
.icon-btn:hover{border-color:var(--sage);color:var(--sage-d)}
.icon-btn svg{width:18px;height:18px}
.dot{position:absolute;top:7px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--terra);box-shadow:0 0 0 3px var(--paper)}
@media (max-width:880px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:-100%;width:80%;max-width:300px;transition:var(--t);z-index:60;box-shadow:var(--shadow-3)}.sidebar.open{left:0}.main{padding:20px}}

.kpis-soft{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px}
.kpi-pill{padding:22px;background:var(--paper);border:1px solid var(--rule);border-radius:22px;position:relative;overflow:hidden;transition:var(--t)}
.kpi-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow-1)}
.kpi-pill .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.kpi-pill .lbl{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--mute)}
.kpi-pill .ic{width:34px;height:34px;border-radius:50%;background:var(--cream-2);color:var(--sage-d);display:grid;place-items:center}
.kpi-pill .ic svg{width:16px;height:16px}
.kpi-pill.warn .ic{background:var(--rose);color:var(--terra-d)}
.kpi-pill.terra .ic{background:rgba(180,99,45,.15);color:var(--terra-d)}
.kpi-pill .v{font-family:'Fraunces';font-size:2.2rem;font-weight:500;color:var(--ink);line-height:1}
.kpi-pill .v small{font-size:.9rem;color:var(--mute);font-family:'Inter';font-weight:400;margin-left:3px}
.kpi-pill .delta{margin-top:6px;font-size:.78rem;color:var(--sage);font-weight:600}
.kpi-pill.warn .delta{color:var(--terra)}

.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:99px;background:var(--cream-2);color:var(--ink-2);font-size:.74rem;font-weight:600;border:1px solid var(--rule)}
.chip.ok{background:rgba(125,160,100,.15);color:var(--sage-d);border-color:rgba(125,160,100,.3)}
.chip.warn{background:rgba(212,149,56,.15);color:#8a6510;border-color:rgba(212,149,56,.3)}
.chip.bad{background:rgba(180,99,45,.15);color:var(--terra-d);border-color:rgba(180,99,45,.3)}
.chip.live::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.card{padding:28px;background:var(--paper);border:1px solid var(--rule);border-radius:22px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;padding-bottom:14px;border-bottom:1px dashed var(--rule)}
.card-head h3{margin:0;font-family:'Fraunces';font-size:1.3rem;font-weight:500}
.card-head h3 em{font-style:italic;color:var(--sage)}
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px}
@media (max-width:880px){.dash-grid{grid-template-columns:1fr}}

.dev-card{display:grid;grid-template-columns:160px 1fr;background:var(--paper);border:1px solid var(--rule);border-radius:22px;overflow:hidden;text-decoration:none;color:inherit;transition:var(--t)}
.dev-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
@media (max-width:680px){.dev-card{grid-template-columns:1fr}}
.dev-photo{background:var(--cream-2);overflow:hidden}
.dev-photo img{width:100%;height:100%;object-fit:cover;min-height:140px}
.dev-body{padding:22px}
.dev-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.dev-name{font-family:'Fraunces';font-size:1.2rem;font-weight:500;margin:0}
.dev-name em{font-style:italic;color:var(--sage)}
.dev-id{font-size:.72rem;letter-spacing:.05em;color:var(--mute);margin-top:4px;font-weight:600}
.dev-readings{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.dev-readings .r{padding:10px;background:var(--cream-2);border-radius:12px}
.dev-readings .lbl{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);font-weight:700;margin-bottom:2px}
.dev-readings .v{font-family:'Fraunces';font-size:1.15rem;font-weight:500}

.live-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.live-cell{padding:22px;background:var(--paper);border:1px solid var(--rule);border-radius:20px;position:relative}
.live-cell .lbl{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--mute);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.live-cell .lbl svg{width:14px;height:14px;color:var(--sage)}
.live-cell .v{font-family:'Fraunces';font-size:2.2rem;font-weight:500;line-height:1;color:var(--ink)}
.live-cell .u{font-size:.85rem;color:var(--mute);font-family:'Inter';font-weight:400;margin-left:3px}
.live-cell.warn{background:linear-gradient(135deg,var(--paper),rgba(212,149,56,.10))}
.live-cell.warn .v{color:var(--terra-d)}
.live-cell .mini-chart{height:24px;margin-top:10px;opacity:.55}
.live-cell .mini-chart path{stroke:var(--sage);stroke-width:1.5;fill:none}

.chart{height:280px;position:relative}
.chart svg{width:100%;height:100%}
.chart text{font-family:'Inter';font-size:.66rem;fill:var(--mute);font-weight:500}
.legend{display:flex;gap:20px;flex-wrap:wrap;margin-top:14px}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--ink-2);font-weight:500}
.legend span::before{content:"";width:14px;height:2px;background:var(--c,var(--sage))}

.tabs{display:flex;padding:4px;background:var(--cream-2);border-radius:99px;width:fit-content}
.tabs a{padding:7px 14px;border-radius:99px;font-size:.82rem;font-weight:600;color:var(--mute)}
.tabs a.active{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-1)}

.activity{display:flex;flex-direction:column;gap:0}
.activity-item{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px dashed var(--rule-2)}
.activity-item:last-child{border:0}
.activity-dot{width:34px;height:34px;border-radius:50%;background:var(--cream-2);color:var(--sage-d);display:grid;place-items:center;flex-shrink:0}
.activity-dot svg{width:14px;height:14px}
.activity-dot.warn{background:var(--rose);color:var(--terra-d)}
.activity-dot.bad{background:rgba(110,58,82,.15);color:var(--plum)}
.activity-body strong{display:block;font-family:'Fraunces';font-weight:500;font-size:1rem}
.activity-body .desc{font-size:.82rem;color:var(--mute);margin-top:2px}
.activity-time{font-size:.7rem;color:var(--mute);font-weight:700;letter-spacing:.05em;white-space:nowrap}

.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);padding:14px 12px;border-bottom:1px dashed var(--rule);font-weight:700}
.tbl td{padding:14px 12px;border-bottom:1px solid var(--rule-2);font-size:.92rem}
.tbl tr:last-child td{border:0}
.tbl tr:hover td{background:var(--cream-2)}

.notif{display:grid;grid-template-columns:auto 1fr auto;gap:14px;padding:18px 24px;background:var(--paper);border:1px solid var(--rule);border-radius:18px;margin-bottom:10px;align-items:flex-start;transition:var(--t)}
.notif.unread{border-left:4px solid var(--sage)}
.notif.unread.warn{border-left-color:var(--terra)}
.notif.unread.bad{border-left-color:var(--plum)}
.notif:hover{box-shadow:var(--shadow-2)}
.notif-icon{width:40px;height:40px;border-radius:50%;background:var(--cream-2);color:var(--sage-d);display:grid;place-items:center;flex-shrink:0}
.notif-icon.warn{background:var(--rose);color:var(--terra-d)}
.notif-icon.bad{background:rgba(110,58,82,.15);color:var(--plum)}
.notif-icon svg{width:18px;height:18px}
.notif-body strong{display:block;font-family:'Fraunces';font-weight:500;font-size:1.05rem}
.notif-body p{margin:4px 0 0;font-size:.88rem;color:var(--ink-2)}
.notif-time{font-size:.7rem;color:var(--mute);font-weight:700;white-space:nowrap}

.wizard-rail{display:flex;justify-content:space-between;background:var(--paper);border:1px solid var(--rule);border-radius:99px;padding:6px;margin-bottom:32px;gap:6px}
.wizard-step{flex:1;padding:14px 18px;border-radius:99px;display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--mute);font-weight:600}
.wizard-step.done{color:var(--ink)}
.wizard-step.active{background:var(--ink);color:var(--cream)}
.wizard-num{width:24px;height:24px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;font-weight:700;font-size:.78rem;color:var(--ink-2)}
.wizard-step.active .wizard-num{background:rgba(251,246,236,.2);color:var(--cream)}
.wizard-step.done .wizard-num{background:var(--leaf);color:var(--cream)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:780px){.grid-2,.grid-3{grid-template-columns:1fr}}
.flex{display:flex;align-items:center;gap:12px}
.spread{justify-content:space-between}
.text-mute{color:var(--mute)}
.text-dim{color:var(--ink-2)}
.text-ok{color:var(--sage-d)}
.text-warn{color:var(--terra)}
.mb-1{margin-bottom:10px}.mb-2{margin-bottom:20px}.mb-3{margin-bottom:36px}.mb-4{margin-bottom:60px}
.mt-1{margin-top:10px}.mt-2{margin-top:20px}.mt-3{margin-top:36px}.mt-4{margin-top:60px}

[data-reveal]{opacity:0;transform:translateY(20px);transition:1s cubic-bezier(.2,.7,.2,1)}
[data-reveal].visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}[data-reveal]{opacity:1;transform:none}}
