/* ══════ ROOT & RESET ══════ */
:root{
    --bg:#070a10;
    --surface:#0d1526;
    --surface2:#182038;
    --primary:#6366f1;
    --gold:#facc15;
    --green:#34d399;
    --pink:#f472b6;
    --purple:#818cf8;
    --orange:#fb923c;
    --text:#f1f5f9;
    --muted:#64748b;
    --border:rgba(255,255,255,0.06);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden}

/* ══════ BG CANVAS ══════ */
#bgCanvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ══════ NAV ══════ */
#phet-stage {
    position: absolute; top: 0; left: 0;
    width: 1280px; height: 720px;
    background: var(--bg);
    display: flex; flex-direction: column;
    overflow: hidden; transform-origin: 0 0;
    box-shadow: 0 0 50px rgba(0, 0, 0, 0.4);
    touch-action: none;
}

.venn-nav{position:absolute;top:0;left:0;right:0;height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;background:rgba(7,10,16,0.93);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:200}
.nav-logo a{text-decoration:none;font-weight:800;font-size:1.15rem;color:var(--text);display:flex;align-items:center;gap:0.4rem}
.nav-logo em{color:var(--primary);font-style:normal}
.nav-center{font-size:0.82rem;color:var(--muted);letter-spacing:0.5px;font-weight:500}
.nav-back{display:flex;align-items:center;gap:0.4rem;padding:0.45rem 1.1rem;border-radius:50px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:0.82rem;text-decoration:none;transition:0.2s}
.nav-back:hover{border-color:var(--primary);color:var(--primary)}

/* ══════ APP SHELL ══════ */
.app-shell{position:absolute;top:58px;bottom:0;left:0;right:0;display:grid;grid-template-columns:520px 1fr;z-index:1;overflow:hidden}

/* ══════ STORY PANEL ══════ */
.story-panel{display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow:hidden}
.progress-bar-wrap{height:4px;background:var(--surface2);flex-shrink:0}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--green),var(--purple));width:0%;transition:width 0.5s ease;border-radius:0 4px 4px 0}
.story-content{flex:1;overflow-y:auto;padding:2.2rem 2.5rem 1rem;scroll-behavior:smooth}
.story-content::-webkit-scrollbar{width:4px}
.story-content::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:4px}

/* Step blocks */
.step-block{display:none;flex-direction:column;gap:1.2rem;animation:fadeUp 0.4s ease}
.step-block.active{display:flex}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

.step-kicker{display:inline-flex;align-items:center;gap:0.5rem;background:rgba(99,102,241,0.12);border:1px solid rgba(99,102,241,0.25);border-radius:50px;padding:0.28rem 1rem;font-size:0.74rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--primary);width:fit-content}
.step-block h2{font-size:1.65rem;font-weight:900;line-height:1.2;color:white}
.step-block h2 span{color:var(--gold)}
.step-block p{color:#94a3b8;line-height:1.82;font-size:0.97rem}
.step-block p strong{color:white;font-weight:700}

.hl{color:var(--gold);font-family:'JetBrains Mono';font-weight:700;background:rgba(250,204,21,0.08);padding:0.1em 0.3em;border-radius:4px}
.green{color:var(--green);font-weight:700}
.pink{color:var(--pink);font-weight:700}
.purple{color:var(--purple);font-weight:700}

/* Equation boxes */
.eq{background:var(--surface2);border:1px solid var(--border);border-radius:14px;padding:1.1rem 1.5rem;font-family:'JetBrains Mono',monospace;font-size:1.05rem;color:white;line-height:2}
.eq.center{text-align:center}
.eq.gold{border-color:rgba(250,204,21,0.4);background:rgba(250,204,21,0.06);color:var(--gold);text-align:center;font-size:1.3rem}
.eq.green-box{border-color:rgba(52,211,153,0.4);background:rgba(52,211,153,0.06);color:var(--green);text-align:center}
.eq.purple-box{border-color:rgba(129,140,248,0.4);background:rgba(129,140,248,0.07);color:var(--purple);text-align:center}
.eq.pink-box{border-color:rgba(244,114,182,0.4);background:rgba(244,114,182,0.06);color:var(--pink);text-align:center}
.eq small{display:block;font-family:'Outfit';font-size:0.74rem;color:var(--muted);margin-top:0.4rem;font-style:italic}

/* Color legend */
.color-legend{display:flex;flex-direction:column;gap:0.6rem}
.cl-item{display:flex;align-items:flex-start;gap:0.8rem;font-size:0.9rem;color:#94a3b8}
.cl-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:3px}

/* Hint block */
.hint{background:rgba(99,102,241,0.06);border:1px dashed rgba(99,102,241,0.3);border-radius:12px;padding:0.9rem 1.2rem;font-size:0.88rem;color:#818cf8;display:flex;gap:0.7rem;align-items:flex-start;line-height:1.7}
.hint i{margin-top:2px;flex-shrink:0}

/* Notation examples */
.notation-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.7rem}
.notebox{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:0.7rem 1rem;font-size:0.88rem}
.notebox span{display:block;font-family:'JetBrains Mono';font-size:1rem;font-weight:700;margin-bottom:0.2rem}

/* Footer */
.story-footer{display:flex;align-items:center;gap:1rem;padding:1.1rem 2.5rem 3.5rem;border-top:1px solid var(--border);flex-shrink:0}
.step-pips{display:flex;gap:6px;flex:1;justify-content:center}
.pip{width:7px;height:7px;border-radius:50%;background:var(--muted);cursor:pointer;transition:0.3s;border:none;padding:0}
.pip.active{background:var(--green);transform:scale(1.5)}
.pip:hover{background:var(--primary)}
.nav-btn{display:flex;align-items:center;gap:0.5rem;padding:0.65rem 1.4rem;border-radius:50px;font-family:'Outfit';font-weight:700;font-size:0.9rem;cursor:pointer;transition:0.2s;border:none}
.nav-btn.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}
.nav-btn.ghost:hover:not(:disabled){border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.05)}
.nav-btn.primary{background:var(--primary);color:white;box-shadow:0 0 18px rgba(99,102,241,0.4)}
.nav-btn.primary:hover{background:#4f46e5}
.nav-btn.gold-btn{background:var(--gold);color:#000}
.nav-btn:disabled{opacity:0.3;cursor:default}

/* ══════ VISUAL SHELL ══════ */
.visual-shell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.2rem;gap:1rem;background:var(--bg);overflow:hidden}
#mainCanvas{border-radius:18px;border:1px solid var(--border);background:var(--surface);max-width:100%;max-height:100%}
.canvas-caption{font-size:0.82rem;color:var(--muted);text-align:center;max-width:480px;line-height:1.6;min-height:2.5em;transition:opacity 0.3s}

/* Interactive row */
.interact-row{display:flex;align-items:center;gap:0.8rem;width:100%;max-width:460px}
.elem-input{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:0.6rem 1rem;color:var(--text);font-family:'JetBrains Mono';font-size:0.95rem;outline:none;transition:0.2s}
.elem-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,0.15)}
.add-btn{display:flex;align-items:center;gap:0.4rem;padding:0.6rem 1.2rem;background:var(--green);color:#000;border:none;border-radius:10px;font-weight:700;font-family:'Outfit';cursor:pointer;font-size:0.88rem;transition:0.2s}
.add-btn:hover{background:#22c55e}
.clear-btn{display:flex;align-items:center;gap:0.4rem;padding:0.6rem 1rem;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:10px;font-weight:600;font-family:'Outfit';cursor:pointer;font-size:0.88rem;transition:0.2s}
.clear-btn:hover{border-color:var(--pink);color:var(--pink)}

/* Chips */
.chip-row{display:flex;gap:0.7rem;flex-wrap:wrap;justify-content:center;max-width:500px}
.chip{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:0.5rem 1rem;font-size:0.82rem;display:flex;flex-direction:column;gap:0.2rem;align-items:center;min-width:90px}
.chip-label{color:var(--muted);font-size:0.72rem;text-transform:uppercase;letter-spacing:0.5px;font-weight:600}
.chip-val{font-family:'JetBrains Mono';font-size:0.95rem;font-weight:700;color:white;text-align:center}
.chip.green-chip{border-color:rgba(52,211,153,0.4);background:rgba(52,211,153,0.07)}
.chip.green-chip .chip-val{color:var(--green)}
.chip.purple-chip{border-color:rgba(129,140,248,0.4);background:rgba(129,140,248,0.07)}
.chip.purple-chip .chip-val{color:var(--purple)}
.chip.gold-chip{border-color:rgba(250,204,21,0.4);background:rgba(250,204,21,0.07)}
.chip.gold-chip .chip-val{color:var(--gold)}

/* ══════ FINALE OVERLAY ══════ */
.finale-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.88);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.6s;backdrop-filter:blur(12px)}
.finale-overlay.show{opacity:1;pointer-events:all}
.finale-card{position:relative;background:var(--surface);border:1px solid rgba(52,211,153,0.3);border-radius:28px;padding:3rem 3.5rem;text-align:center;max-width:520px;overflow:hidden;animation:popUp 0.6s cubic-bezier(0.34,1.56,0.64,1) both}
@keyframes popUp{from{transform:scale(0.7);opacity:0}to{transform:scale(1);opacity:1}}
.finale-rings{position:absolute;inset:0;pointer-events:none}
.ring{position:absolute;border-radius:50%;border:1px solid;top:50%;left:50%;transform:translate(-50%,-50%);animation:expand 3s ease-in-out infinite}
.ring1{width:220px;height:220px;border-color:rgba(52,211,153,0.15);animation-delay:0s}
.ring2{width:360px;height:360px;border-color:rgba(52,211,153,0.07);animation-delay:1s}
@keyframes expand{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:0.8}50%{transform:translate(-50%,-50%) scale(1.05);opacity:0.3}}
.finale-kicker{font-size:0.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:1.2rem;position:relative}
.finale-icons{font-size:3.5rem;font-weight:900;margin-bottom:1.2rem;position:relative;display:flex;align-items:center;justify-content:center;gap:0.5rem}
.finale-icons span:nth-child(1){color:var(--green)}
.finale-icons span:nth-child(2){color:var(--muted);font-size:2.5rem}
.finale-icons span:nth-child(3){color:var(--purple)}
.finale-facts{display:flex;flex-direction:column;gap:0.6rem;margin-bottom:2rem;position:relative;text-align:left}
.ff{display:flex;align-items:center;gap:0.7rem;font-size:0.9rem;color:#94a3b8}
.finale-btn{display:inline-flex;align-items:center;gap:0.6rem;padding:0.85rem 2.2rem;border-radius:50px;border:2px solid var(--green);background:transparent;color:var(--green);font-family:'Outfit';font-weight:700;font-size:1rem;cursor:pointer;transition:0.3s;position:relative}
.finale-btn:hover{background:var(--green);color:#000}
sup,sub{line-height:0}

/* Media Query to keep footer compact on mobile */
@media screen and (max-width: 899px) {
    .story-footer {
        padding: 1.1rem 2.5rem !important;
    }
}
