/* =========================================================
   Schumann Resonance Live v5 — ATLAS Observatory Dashboard
   World-class professional SR observatory with 40+ features.
   ========================================================= */
:root{
    --bg:#070a0e; --bg-1:#0b0f15; --bg-2:#0f141c; --panel:#0d1117; --panel-2:#11161f;
    --line:rgba(232,161,58,.12); --line-2:rgba(232,161,58,.24); --grid:rgba(232,161,58,.06);
    --amber:#e8a13a; --amber-b:#f5c460; --teal:#2bb6a3; --teal-b:#3fd9c2; --ember:#e0651f; --rose:#d24a6b; --green:#5ec98f;
    --cream:#f1e7d4; --text:#d9ceb8; --dim:#9a9079; --mute:#5f5747;
    --r:16px; --r-sm:10px; --maxw:1340px;
    --font:'Fraunces',Georgia,serif; --sans:'Space Grotesk',system-ui,sans-serif; --mono:'JetBrains Mono',ui-monospace,monospace;
    --ease:cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:-10%;z-index:-3;pointer-events:none;
    background:radial-gradient(55% 45% at 50% 0%,rgba(232,161,58,.10),transparent 70%),radial-gradient(45% 40% at 85% 25%,rgba(43,182,163,.07),transparent 70%),radial-gradient(60% 50% at 20% 80%,rgba(196,90,111,.05),transparent 70%);animation:bgd 40s ease-in-out infinite alternate}
@keyframes bgd{to{transform:translate(2%,1%) scale(1.03)}}
body::after{content:"";position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.035;mix-blend-mode:overlay;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='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
img,canvas,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--amber);color:#1a120a}
.skip-link{position:absolute;left:-9999px;top:0;z-index:999;background:var(--amber);color:#1a120a;padding:10px 16px}
.skip-link:focus{left:0}

/* CURSOR */
.cursor{position:fixed;top:0;left:0;z-index:300;pointer-events:none;mix-blend-mode:screen;opacity:0;transition:opacity .3s}
.cursor.on{opacity:1}
.cursor__dot{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--amber-b);box-shadow:0 0 12px var(--amber);transform:translate(-50%,-50%)}
.cursor__ring{position:absolute;width:36px;height:36px;border-radius:50%;border:1px solid rgba(245,196,96,.4);transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),border-color .25s}
.cursor.hot .cursor__ring{width:58px;height:58px;border-color:var(--amber-b)}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* SCENE */
.scene{position:fixed;inset:0;z-index:0;pointer-events:none}
#earthCanvas{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
.scene__fallback{position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,rgba(232,161,58,.18),rgba(43,182,163,.06) 40%,transparent 65%);opacity:0;transition:opacity 1s}
.scene.is-fallback .scene__fallback{opacity:1}
.scene.is-fallback #earthCanvas{display:none}

/* TOPBAR — PREMIUM */
.topbar{position:sticky;top:0;z-index:90;backdrop-filter:blur(20px) saturate(1.4);background:linear-gradient(180deg,rgba(7,10,14,.95),rgba(7,10,14,.6));border-bottom:1px solid var(--line-2);transition:transform .5s var(--ease),box-shadow .4s;box-shadow:0 1px 0 rgba(232,161,58,.08),0 8px 32px rgba(0,0,0,.4)}
.topbar.hide{transform:translateY(-100%)}
.topbar__inner{max-width:var(--maxw);margin:0 auto;padding:15px 32px;display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:13px;transition:transform .3s var(--ease)}
.brand:hover{transform:translateY(-1px)}
.brand__mark{width:38px;height:38px;filter:drop-shadow(0 0 12px rgba(232,161,58,.6));transition:filter .3s,transform .6s var(--ease)}
.brand:hover .brand__mark{transform:rotate(15deg) scale(1.05);filter:drop-shadow(0 0 18px rgba(245,196,96,.8))}
.brand__word{font-family:var(--font);font-weight:600;font-size:19px;letter-spacing:.22em;color:var(--cream);background:linear-gradient(120deg,var(--cream) 30%,var(--amber-b));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.topnav{display:flex;gap:2px;margin-left:auto}
.topnav a{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);padding:9px 14px;border-radius:999px;transition:.28s var(--ease);position:relative}
.topnav a:hover{color:var(--amber-b);background:rgba(232,161,58,.1);box-shadow:0 0 16px rgba(232,161,58,.15)}
.topnav a::after{content:"";position:absolute;bottom:4px;left:50%;width:0;height:1.5px;background:var(--amber-b);border-radius:1px;transform:translateX(-50%);transition:width .28s var(--ease);box-shadow:0 0 6px var(--amber-b)}
.topnav a:hover::after{width:40%}
.topbar__right{display:flex;align-items:center;gap:16px;margin-left:auto}
.topnav~.topbar__right{margin-left:0}

/* LANGUAGE SWITCHER — PREMIUM */
.lang-switch{position:relative}
.lang-switch__btn{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--dim);padding:7px 12px;border-radius:999px;border:1px solid var(--line-2);background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(232,161,58,.04));transition:.28s var(--ease);cursor:pointer}
.lang-switch__btn:hover{border-color:var(--amber-b);color:var(--cream);box-shadow:0 0 14px rgba(232,161,58,.18)}
.lang-switch__flag{font-size:13px}
.lang-switch__code{color:var(--amber-b);font-weight:700;letter-spacing:.08em}
.lang-switch__chev{font-size:8px;color:var(--mute);transition:transform .25s}
.lang-switch[open] .lang-switch__chev{transform:rotate(180deg)}
.lang-switch__drop{position:absolute;top:calc(100% + 10px);right:0;width:250px;max-height:0;overflow:hidden;background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:var(--r);box-shadow:0 24px 56px rgba(0,0,0,.6),0 0 0 1px rgba(232,161,58,.06);z-index:100;transition:max-height .35s var(--ease),opacity .3s;opacity:0;pointer-events:none}
.lang-switch[open] .lang-switch__drop{max-height:380px;overflow-y:auto;opacity:1;pointer-events:auto}
.lang-switch__drop::-webkit-scrollbar{width:5px}
.lang-switch__drop::-webkit-scrollbar-track{background:transparent}
.lang-switch__drop::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px}
.lang-opt{display:flex;align-items:center;gap:8px;padding:9px 16px;font-family:var(--mono);font-size:10.5px;color:var(--dim);transition:.18s;border-bottom:1px solid rgba(255,255,255,.03)}
.lang-opt:hover{background:rgba(232,161,58,.08);color:var(--cream);padding-left:20px}
.lang-opt.active{color:var(--amber-b);background:rgba(232,161,58,.1);font-weight:700}

/* LIVE COUNTER — PREMIUM */
.live-counter{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;color:var(--teal-b);letter-spacing:.08em;padding:6px 11px;border-radius:999px;border:1px solid rgba(43,182,163,.2);background:rgba(43,182,163,.05)}
.live-counter__icon{font-size:12px;filter:drop-shadow(0 0 4px rgba(63,217,194,.6))}
.live-counter__num{font-weight:700;font-variant-numeric:tabular-nums;min-width:20px;text-align:center;color:var(--teal-b);text-shadow:0 0 8px rgba(63,217,194,.4)}

/* STATUS — PREMIUM */
.status{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;color:var(--teal-b);padding:6px 12px;border-radius:999px;border:1px solid rgba(43,182,163,.18);background:linear-gradient(135deg,rgba(43,182,163,.06),rgba(7,10,14,.3))}
.status__pulse{width:8px;height:8px;border-radius:50%;background:var(--teal-b);box-shadow:0 0 12px var(--teal-b),0 0 4px var(--teal-b);animation:pulse 1.8s ease-in-out infinite}
.status__coord{color:var(--mute);margin-left:4px;letter-spacing:.1em}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}

/* TICKER */
.ticker{overflow:hidden;background:var(--bg-1);border-bottom:1px solid var(--line);padding:8px 0;mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.ticker__track{display:flex;width:max-content;animation:ticker 55s linear infinite;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--dim)}
.ticker:hover .ticker__track{animation-play-state:paused}
@keyframes ticker{to{transform:translateX(-50%)}}
.t-item{padding:0 6px;white-space:nowrap}.t-item b{color:var(--amber-b)}
.t-sep{color:var(--ember);opacity:.5;padding:0 2px}

/* SHARED */
main{position:relative;z-index:2}
.kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--teal);margin:0 0 12px}
.sec-head{display:flex;gap:24px;align-items:flex-start;margin-bottom:42px;border-bottom:1px solid var(--line);padding-bottom:26px}
.sec-no{font-family:var(--mono);font-size:12px;border:1px solid var(--line-2);width:46px;height:46px;display:grid;place-items:center;border-radius:50%;color:var(--amber-b);flex:none}
.sec-title{font-family:var(--font);font-weight:300;font-size:clamp(1.9rem,4vw,3rem);line-height:1.05;letter-spacing:-.018em;margin:0;color:var(--cream)}
.sec-title em{font-style:italic;font-weight:400;color:var(--amber-b)}
.sec-head__live{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--teal-b);display:flex;align-items:center;gap:7px}
.sec-head__live .dot{width:7px;height:7px;border-radius:50%;background:var(--teal-b);box-shadow:0 0 8px var(--teal-b);animation:pulse 1.8s infinite}
.section{max-width:var(--maxw);margin:0 auto;padding:84px 32px}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:110px 24px 70px;position:relative}
.hero__inner{position:relative;z-index:3;max-width:760px}
.hero__eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--amber);margin:0 0 28px;opacity:.9}
.hero__title{font-family:var(--font);font-weight:300;font-size:clamp(2.8rem,8vw,6.5rem);line-height:.98;letter-spacing:-.025em;margin:0 0 12px;color:var(--cream);text-shadow:0 0 50px rgba(7,10,14,.6)}
.hero__title em{font-style:italic;font-weight:400;background:linear-gradient(115deg,var(--amber),var(--ember),var(--amber-b));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__reading{font-family:var(--font);margin:8px 0 26px;display:flex;align-items:baseline;justify-content:center;gap:14px}
.reading__num{font-size:clamp(3.2rem,11vw,8rem);font-weight:300;line-height:1;color:var(--amber-b);font-variant-numeric:tabular-nums;text-shadow:0 0 60px rgba(232,161,58,.4);letter-spacing:-.04em}
.reading__unit{font-family:var(--mono);font-size:clamp(1rem,2.4vw,1.5rem);color:var(--dim);letter-spacing:.1em}
.hero__sub{font-size:clamp(1rem,1.4vw,1.12rem);color:var(--dim);max-width:520px;margin:0 auto 34px;line-height:1.7}
.hero__sub strong{color:var(--cream);font-weight:600}
.hero__cta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.hero__scope{width:min(620px,90vw);height:54px;margin:30px auto 0;opacity:.7}
.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:9px;z-index:3}
.hero__scroll span{font-family:var(--mono);font-size:9.5px;letter-spacing:.3em;color:var(--mute)}
.hero__scroll i{width:1px;height:42px;background:linear-gradient(var(--amber),transparent);animation:bl 2.2s ease-in-out infinite;transform-origin:top}
@keyframes bl{0%,100%{transform:scaleY(.5);opacity:.5}50%{transform:scaleY(1);opacity:1}}

/* HERO — FERDI MESSAGE */
.hero__message{max-width:680px;margin:0 auto 36px;padding:24px 28px;border-radius:var(--r);border:1px solid rgba(232,161,58,.15);background:linear-gradient(135deg,rgba(232,161,58,.04),rgba(43,182,163,.03));backdrop-filter:blur(8px);text-align:center;position:relative;overflow:hidden}
.hero__message::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--amber),transparent)}
.hero__message::after{content:"❝";position:absolute;top:8px;left:16px;font-family:var(--font);font-size:48px;color:rgba(232,161,58,.12);line-height:1}
.hero__message-text{font-family:var(--font);font-style:italic;font-size:clamp(.95rem,1.3vw,1.08rem);line-height:1.8;color:var(--text);margin:0 0 14px;font-weight:400}
.hero__message-text strong{color:var(--amber-b);font-weight:600;font-style:normal}
.hero__message-author{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-b);margin:0}
.hero__message-author b{color:var(--cream);font-weight:700}

/* PROMINENT TOMSK SPECTROGRAM (below hero) */
.spectro-hero{max-width:var(--maxw);margin:0 auto;padding:0 32px 40px;position:relative;z-index:3}
.spectro-hero__badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-b);padding:5px 12px;border-radius:999px;border:1px solid rgba(43,182,163,.25);background:rgba(43,182,163,.06);margin-bottom:14px}
.spectro-hero__badge .dot{width:6px;height:6px;border-radius:50%;background:var(--teal-b);box-shadow:0 0 8px var(--teal-b);animation:pulse 1.8s infinite}
.spectro-hero__title{font-family:var(--font);font-weight:300;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.1;letter-spacing:-.015em;color:var(--cream);margin:0 0 6px}
.spectro-hero__title em{font-style:italic;font-weight:400;color:var(--amber-b)}
.spectro-hero__sub{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--dim);margin:0 0 22px}
.spectro-main{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:var(--r);padding:20px;box-shadow:0 20px 56px rgba(0,0,0,.4);position:relative;overflow:hidden}
.spectro-main__screen{position:relative;background:#000;border-radius:var(--r-sm);width:100%;aspect-ratio:2.6/1;min-height:340px;overflow:hidden;border:1px solid var(--line)}
.spectro-main__screen img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.4s;filter:contrast(1.12) saturate(1.2)}
.spectro-main__screen img.loaded{opacity:1}
.spectro-main__loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;z-index:2}
.spectro-main__loader span{width:9px;height:9px;border-radius:50%;background:var(--amber);animation:ld 1.3s infinite}
.spectro-main__loader span:nth-child(2){animation-delay:.18s;background:var(--ember)}
.spectro-main__loader span:nth-child(3){animation-delay:.36s;background:var(--teal)}
.spectro-main__stamp{position:absolute;top:10px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--amber-b);background:rgba(0,0,0,.55);padding:4px 10px;border-radius:3px;z-index:3;opacity:.85;backdrop-filter:blur(4px)}
.spectro-main__info{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.spectro-main__info-text{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:.08em}
.spectro-main__info-text b{color:var(--amber-b)}
.spectro-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.spectro-mini{background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r-sm);padding:14px;transition:.3s var(--ease)}
.spectro-mini:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.3)}
.spectro-mini__title{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-b);margin:0 0 10px}
.spectro-mini__screen{position:relative;background:#000;border-radius:6px;width:100%;aspect-ratio:3/1;overflow:hidden;border:1px solid var(--line)}
.spectro-mini__screen img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s}
.spectro-mini__screen img.loaded{opacity:1}
.spectro-mini__loader{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-size:9px;color:var(--mute)}
@media (max-width:760px){
    .spectro-hero{padding:0 18px 30px}
    .spectro-main__screen{aspect-ratio:2/1;min-height:240px}
    .spectro-mini-grid{grid-template-columns:1fr}
}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 24px;border-radius:999px;font-family:var(--sans);font-weight:500;font-size:13.5px;transition:.3s var(--ease);border:1px solid transparent}
.btn--listen{background:linear-gradient(120deg,var(--amber),var(--ember));color:#1a120a;box-shadow:0 8px 26px rgba(232,161,58,.26)}
.btn--listen:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(232,161,58,.4)}
.btn--listen[aria-pressed="true"]{background:linear-gradient(120deg,var(--teal),var(--teal-b))}
.btn--ghost{border-color:var(--line-2);color:var(--cream);background:rgba(255,255,255,.02)}
.btn--ghost:hover{border-color:var(--amber-b);color:var(--amber-b);background:rgba(232,161,58,.08)}
.btn__icon{width:13px;height:13px;flex:none;position:relative}
.btn__icon::before{content:"";position:absolute;inset:0;border-style:solid;border-width:6.5px 0 6.5px 11px;border-color:transparent transparent transparent currentColor;transition:.25s}
.btn--listen[aria-pressed="true"] .btn__icon::before{border:0;background:currentColor;left:1px;right:1px;top:2px;bottom:2px;width:auto;height:auto;inset:auto}

/* PANEL — the workhorse container */
.panel{background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:22px;backdrop-filter:blur(10px);box-shadow:0 16px 40px rgba(0,0,0,.25)}
.panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}
.panel__head h3{font-family:var(--sans);font-weight:500;font-size:13px;letter-spacing:.04em;color:var(--cream);margin:0}
.panel__unit{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.panel__foot{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--mute);letter-spacing:.06em;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}

/* HARMONICS GRID */
.harm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.harm{background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:20px 18px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transition:.35s var(--ease)}
.harm:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 18px 40px rgba(0,0,0,.35)}
.harm[data-mode="SR1"]{box-shadow:0 0 0 1px rgba(232,161,58,.18),0 16px 40px rgba(0,0,0,.25)}
.harm[data-mode="SR1"]::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--amber),var(--ember))}
.harm__head{display:flex;align-items:baseline;justify-content:space-between}
.harm__name{font-family:var(--mono);font-weight:600;font-size:14px;color:var(--amber-b);letter-spacing:.08em}
.harm__freq{font-family:var(--mono);font-size:11px;color:var(--mute)}
.harm__spark{width:100%;height:34px}
.harm__stats{display:flex;flex-direction:column;gap:7px}
.harm__stat{display:flex;align-items:baseline;gap:5px;font-family:var(--mono)}
.harm__stat span{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);width:64px}
.harm__stat b{font-family:var(--font);font-weight:400;font-size:1.05rem;color:var(--cream);font-variant-numeric:tabular-nums}
.harm__stat i{font-style:normal;font-size:10px;color:var(--dim)}
.harm__bar{height:3px;background:rgba(255,255,255,.05);border-radius:999px;overflow:hidden}
.harm__bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--amber),var(--ember));border-radius:999px;transition:width .8s var(--ease)}

/* SIGNAL QUALITY + PHASE ANGLE */
.quality-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.quality-viz,.phase-viz{position:relative;display:flex;align-items:center;justify-content:center;min-height:180px}
.quality-readout,.phase-readout{position:absolute;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.quality-readout b,.phase-readout b{font-family:var(--font);font-weight:300;font-size:3.2rem;color:var(--amber-b);line-height:1;font-variant-numeric:tabular-nums}
.quality-readout span,.phase-readout span{font-family:var(--mono);font-size:14px;color:var(--dim)}
.quality-readout i,.phase-readout i{font-style:normal;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-b);margin-top:4px}
#qualityCanvas,#phaseCanvas{width:200px;height:200px}

/* CHART GRID */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chart-wrap{height:240px;position:relative}
.spec-wrap{height:280px;position:relative}
.tl-wrap{height:200px;position:relative}

/* TIMELINE READOUTS */
.tl-read{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;margin-top:14px}
.tl-read>div{padding:13px 16px;background:var(--panel);display:flex;flex-direction:column;gap:3px}
.tl-read span{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}
.tl-read b{font-family:var(--font);font-weight:400;font-size:1.3rem;color:var(--amber-b);font-variant-numeric:tabular-nums}
.legend-inline{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:9.5px;color:var(--mute);letter-spacing:.08em}
.legend-inline i{width:9px;height:9px;border-radius:2px;display:inline-block}
.lg-teal{background:var(--teal)}.lg-amber{background:var(--amber)}.lg-ember{background:var(--ember)}

/* 7-DAY HEATMAP */
.heatmap-wrap{height:200px;position:relative}
#heatmapCanvas{width:100%;height:100%}
.heatmap-axes{margin-top:8px}
.heatmap-axes__days{display:grid;grid-template-columns:repeat(7,1fr);gap:0;padding-left:38px;font-family:var(--mono);font-size:9px;color:var(--mute);text-align:center}
.heatmap-axes__hours{display:grid;grid-template-columns:repeat(8,1fr);gap:0;margin-top:4px;font-family:var(--mono);font-size:9px;color:var(--mute);text-align:center}
.heatmap-legend{display:flex;align-items:center;gap:14px;margin-top:14px;justify-content:flex-end}
.heatmap-legend__bar{width:200px;height:8px;border-radius:999px;background:linear-gradient(90deg,#0a0e14,#0d2818,#1a4a2e,#4a8a3a,#e8a13a,#e0651f,#d24a6b)}
.heatmap-legend__ends{display:flex;justify-content:space-between;width:200px;font-family:var(--mono);font-size:9px;color:var(--mute)}

/* SPACE WEATHER */
.space-grid{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:16px}
.kp-panel{display:flex;flex-direction:column}
.kp-gauge{position:relative;flex:1;display:grid;place-items:center;min-height:180px}
#kpGauge{width:200px;height:200px}
.kp-readout{position:absolute;text-align:center;display:flex;flex-direction:column;gap:2px}
.kp-readout b{font-family:var(--font);font-weight:300;font-size:3.2rem;color:var(--amber-b);line-height:1;font-variant-numeric:tabular-nums}
.kp-readout span{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-b)}
.kp-scale{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;padding:8px 4px 0}
.kp-tick{color:var(--mute);position:relative;padding-top:8px;text-align:center}
.kp-tick::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:2px;height:6px;background:var(--mute)}
.kp-tick.kp-4,.kp-tick.kp-5{color:var(--amber)}.kp-tick.kp-6,.kp-tick.kp-7{color:var(--ember)}
.kp-tick.kp-8,.kp-tick.kp-9{color:var(--rose)}
.kp-tick.kp-4::before,.kp-tick.kp-5::before{background:var(--amber)}
.kp-tick.kp-6::before,.kp-tick.kp-7::before{background:var(--ember)}
.kp-tick.kp-8::before,.kp-tick.kp-9::before{background:var(--rose)}

.solar-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.solar-stat{display:flex;flex-direction:column;gap:5px}
.solar-stat span{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.solar-stat b{font-family:var(--font);font-weight:400;font-size:1.4rem;color:var(--cream);font-variant-numeric:tabular-nums}
.solar-stat i{font-style:normal;font-family:var(--mono);font-size:10px;color:var(--dim)}
.solar-meter{display:block;height:3px;background:rgba(255,255,255,.05);border-radius:999px;overflow:hidden;margin-top:3px}
.solar-meter i{display:block;height:100%;width:40%;background:linear-gradient(90deg,var(--teal),var(--amber));border-radius:999px;transition:width .7s var(--ease)}

.xray{display:flex;flex-direction:column;gap:16px;padding:6px 0}
.xray-class{display:flex;flex-direction:column;gap:3px}
.xray-class b{font-family:var(--font);font-weight:300;font-size:2.6rem;color:var(--amber-b);line-height:1;font-variant-numeric:tabular-nums}
.xray-class span{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-b)}
.xray-ladder{display:flex;gap:4px}
.xr{flex:1;text-align:center;font-family:var(--mono);font-weight:600;font-size:13px;padding:8px 0;border-radius:6px;background:rgba(255,255,255,.04);color:var(--mute);border:1px solid var(--line)}
.xr-a{color:var(--green)}.xr-b{color:var(--teal-b)}.xr-c{color:var(--amber-b)}.xr-m{color:var(--ember)}.xr-x{color:var(--rose)}
.xr.active{background:rgba(232,161,58,.12);border-color:var(--line-2)}
.xray-note{font-size:12px;color:var(--dim);margin:0;line-height:1.6}

/* SPECTROGRAM */
.spectro{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:26px;backdrop-filter:blur(10px);box-shadow:0 16px 40px rgba(0,0,0,.25)}
.spectro__nav{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:18px}
.spectro__nav-btn{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--dim);padding:8px 16px;border:1px solid var(--line);border-radius:999px;transition:.25s;background:rgba(255,255,255,.02)}
.spectro__nav-btn:hover{color:var(--amber-b);border-color:var(--line-2);background:rgba(232,161,58,.06)}
.spectro__nav-btn:disabled{opacity:.3;cursor:default;pointer-events:none}
.spectro__date{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--amber-b);text-align:center;min-width:160px}
.spectro__panel{display:grid;grid-template-columns:auto 1fr;gap:12px}
.spectro__axis-y{display:flex;flex-direction:column-reverse;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--mute);padding:6px 0}
.spectro__screen{position:relative;background:#000;border-radius:var(--r-sm);aspect-ratio:4/1;min-height:280px;overflow:hidden;border:1px solid var(--line)}
#spectroFallback{position:absolute;inset:0;width:100%;height:100%}
.spectro__screen img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.4s;filter:contrast(1.1) saturate(1.15)}
.spectro__screen img.loaded{opacity:1}
.spectro__loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:9px;z-index:2}
.spectro__loader span{width:8px;height:8px;border-radius:50%;background:var(--amber);animation:ld 1.3s infinite}
.spectro__loader span:nth-child(2){animation-delay:.18s;background:var(--ember)}
.spectro__loader span:nth-child(3){animation-delay:.36s;background:var(--teal)}
@keyframes ld{0%,80%,100%{transform:scale(.4);opacity:.3}40%{transform:scale(1.1);opacity:1}}
.spectro__corners i{position:absolute;width:16px;height:16px;border:1.5px solid var(--amber);opacity:.6;z-index:3}
.spectro__corners i:nth-child(1){top:8px;left:8px;border-right:0;border-bottom:0}
.spectro__corners i:nth-child(2){top:8px;right:8px;border-left:0;border-bottom:0}
.spectro__corners i:nth-child(3){bottom:8px;left:8px;border-right:0;border-top:0}
.spectro__corners i:nth-child(4){bottom:8px;right:8px;border-left:0;border-top:0}
.spectro__stamp{position:absolute;top:8px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--amber-b);background:rgba(0,0,0,.5);padding:3px 8px;border-radius:3px;z-index:3;opacity:.8}
.spectro__axis-x{grid-column:2;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--mute);margin-top:8px}
.spectro__legend{display:flex;align-items:center;gap:14px;margin-top:18px;justify-content:flex-end}
.legend__k{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--mute)}
.legend__bar{width:200px;height:8px;border-radius:999px;background:linear-gradient(90deg,#050300,#3a1f08,#8a4a18,#e8a13a,#f5c460,#fff)}
.legend__ends{display:flex;justify-content:space-between;width:200px;font-family:var(--mono);font-size:9px;color:var(--mute)}

/* SPIRITUAL READING */
.spiritual-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:16px}
.spiritual-meter{position:relative;width:140px;height:140px;flex:none}
.spiritual-ring{position:absolute;inset:0;border-radius:50%;border:3px solid rgba(232,161,58,.12)}
#spiritualArc{position:absolute;inset:-3px;border-radius:50%;border:3px solid transparent;border-top-color:var(--amber);border-right-color:var(--teal-b);transform:rotate(-45deg)}
.spiritual-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:2px}
.spiritual-score{font-family:var(--font);font-weight:300;font-size:2.6rem;color:var(--amber-b);line-height:1}
.spiritual-pct{font-family:var(--mono);font-size:12px;color:var(--dim)}
.spiritual-body{display:flex;gap:24px;align-items:flex-start}
.spiritual-info{flex:1}
.spiritual-desc{font-size:.95rem;color:var(--dim);line-height:1.75;margin:0 0 16px}
.spiritual-tags{display:flex;flex-wrap:wrap;gap:8px}
.s-tag{font-family:var(--mono);font-size:10px;letter-spacing:.08em;padding:5px 12px;border-radius:999px;border:1px solid var(--line)}
.s-tag--calm{color:var(--teal-b);border-color:rgba(43,182,163,.3);background:rgba(43,182,163,.06)}
.s-tag--heal{color:var(--green);border-color:rgba(94,201,143,.3);background:rgba(94,201,143,.06)}
.s-tag--focus{color:var(--amber-b);border-color:rgba(232,161,58,.3);background:rgba(232,161,58,.06)}
.s-tag--dream{color:var(--rose);border-color:rgba(210,74,107,.3);background:rgba(210,74,107,.06)}

.guide-body{display:flex;flex-direction:column;gap:16px}
.guide-item{display:flex;gap:14px;align-items:flex-start}
.guide-item__icon{font-size:20px;flex:none;width:36px;height:36px;display:grid;place-items:center;background:rgba(232,161,58,.06);border:1px solid var(--line);border-radius:var(--r-sm)}
.guide-item b{display:block;font-family:var(--sans);font-size:13px;color:var(--cream);margin-bottom:4px}
.guide-item p{font-size:.88rem;color:var(--dim);line-height:1.6;margin:0}

/* PROSE */
.section--text .prose{max-width:760px;margin:0 auto;font-size:1.08rem;line-height:1.85;color:var(--dim)}
.prose .lede{font-family:var(--font);font-size:1.5rem;font-weight:300;line-height:1.42;color:var(--cream);font-style:italic;margin:0 0 32px}
.prose p{margin:0 0 22px}.prose strong{color:var(--cream);font-weight:600}
.prose h3{font-family:var(--font);font-weight:400;font-size:1.45rem;color:var(--amber-b);margin:40px 0 16px;font-style:italic}
.read-list{padding:0;list-style:none;display:grid;gap:12px}
.read-list li{display:flex;gap:14px;align-items:baseline;padding-bottom:12px;border-bottom:1px solid var(--line);color:var(--dim)}
.read-list li::before{content:"▸";color:var(--amber);font-family:var(--mono)}
.read-list b{color:var(--cream);font-weight:600}

/* FAQ */
.faq{max-width:760px;margin:0 auto;border-top:1px solid var(--line)}
.faq-i{border-bottom:1px solid var(--line)}
.faq-i summary{padding:24px 0;font-family:var(--font);font-weight:400;font-size:1.28rem;color:var(--cream);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:.25s}
.faq-i summary:hover{color:var(--amber-b)}
.faq-i summary::-webkit-details-marker{display:none}
.faq-i summary::after{content:"+";font-family:var(--mono);font-size:22px;color:var(--amber);transition:.3s;font-weight:300}
.faq-i[open] summary::after{transform:rotate(45deg)}
.faq-i p{margin:0 0 24px;color:var(--dim);font-size:1rem;max-width:640px}

/* =========================================================
   COMPREHENSIVE FOOTER
   ========================================================= */
.foot{margin-top:40px;border-top:1px solid var(--line);background:linear-gradient(180deg,var(--bg-1),var(--bg));position:relative;z-index:2}
.foot__inner{max-width:var(--maxw);margin:0 auto;padding:54px 32px}
.foot__top{background:var(--bg-1);border-bottom:1px solid var(--line)}
.foot__top .foot__inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:32px;align-items:start}
.foot__bottom{background:var(--bg)}
.foot__bottom-inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:28px 32px!important}
.foot__col--brand .brand__mark{width:32px;height:32px}
.foot__col--brand .brand__word{font-size:14px;letter-spacing:.18em}
.foot__desc{color:var(--dim);font-size:12.5px;margin:14px 0 18px;max-width:280px;line-height:1.7}
.foot__social{display:flex;gap:10px}
.social-icon{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--dim);transition:.25s}
.social-icon:hover{border-color:var(--amber-b);color:var(--amber-b);background:rgba(232,161,58,.06)}
.foot__heading{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);margin:0 0 18px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.foot__col nav{display:flex;flex-direction:column;gap:10px}
.foot__col nav a{font-size:12.5px;color:var(--dim);transition:.2s;padding:2px 0}
.foot__col nav a:hover{color:var(--amber-b);transform:translateX(3px)}
.foot__copyright{font-family:var(--mono);font-size:10.5px;color:var(--mute);letter-spacing:.04em}
.foot__legal{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px}
.foot__legal a{color:var(--dim);transition:.2s}
.foot__legal a:hover{color:var(--amber-b)}
.foot__legal span{color:var(--mute)}
.foot__tech{font-family:var(--mono);font-size:10px;color:var(--mute);display:flex;gap:8px;letter-spacing:.04em}
.foot__tech span{opacity:.6}

/* REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media (max-width:1200px){
    .foot__top .foot__inner{grid-template-columns:1fr 1fr 1fr;gap:28px}
    .foot__col--brand{grid-column:1/-1}
}
@media (max-width:1100px){
    .harm-grid{grid-template-columns:repeat(3,1fr)}
    .space-grid{grid-template-columns:1fr 1fr}
    .chart-grid{grid-template-columns:1fr}
    .spiritual-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
    .topnav{display:none}
    .topbar__inner{padding:12px 18px;gap:10px;flex-wrap:wrap}
    .brand__word{font-size:13px;letter-spacing:.12em}
    .topbar__right{flex-wrap:wrap;gap:10px}
    .hero{min-height:auto;padding:90px 18px 60px}
    .harm-grid{grid-template-columns:1fr 1fr}
    .space-grid{grid-template-columns:1fr}
    .quality-grid{grid-template-columns:1fr}
    .section{padding:60px 18px}
    .sec-head{flex-direction:column;gap:12px}
    .sec-head__live{margin-left:0}
    .spectro__panel{grid-template-columns:1fr}
    .spectro__axis-y{flex-direction:row;justify-content:space-between;padding:0 4px}
    .spectro__axis-x{grid-column:1}
    .spectro__screen{aspect-ratio:3/1}
    .spectro__nav{flex-wrap:wrap}
    .tl-read{grid-template-columns:1fr 1fr}
    .spiritual-body{flex-direction:column;align-items:center;text-align:center}
    .spiritual-tags{justify-content:center}
    .guide-item{flex-direction:column;align-items:center;text-align:center}
    .foot__top .foot__inner{grid-template-columns:1fr 1fr;gap:24px}
    .foot__bottom-inner{flex-direction:column;text-align:center;align-items:center;gap:12px}
    .legend__bar,.legend__ends,.heatmap-legend__bar,.heatmap-legend__ends{width:140px}
    .hero__cta .btn{flex:1;justify-content:center}
    .spectro__nav-btn{font-size:9px;padding:6px 12px}
    .lang-switch__drop{width:200px;right:auto;left:0}
}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}body::before{animation:none}}