:root{--green-50:#f3f9ea;--green-100:#e4f1cf;--green-200:#cae8a4;--green-300:#a9d86e;--green-400:#84c648;--green-500:#5cb83a;--green-600:#4a9c2e;--green-700:#3c7d26;--green-800:#2f6120;--green-900:#244a1a;--leaf-vein:#cbe793;--sun:#f4c95d;--bark:#8a6d4b;--color-bg:#f7faf6;--color-surface:#fff;--color-surface-alt:var(--green-50);--color-border:var(--green-200);--diagram-bg:#f1f8f3;--color-primary:var(--green-500);--color-primary-dark:var(--green-700);--color-accent:var(--sun);--color-text:var(--green-900);--color-text-muted:#5b6f63;--color-text-invert:#fff;--color-highlight:var(--green-400);--color-selected:var(--green-600);--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--radius-sm:8px;--radius-md:14px;--radius-lg:22px;--radius-pill:999px;--shadow-sm:0 1px 2px #163b2b0f;--shadow-md:0 6px 18px #163b2b14;--shadow-lg:0 16px 40px #163b2b1f;--ring:0 0 0 3px #5cb83a47}[data-theme=dark]{--color-bg:#0e1712;--color-surface:#15211a;--color-surface-alt:#1a2820;--color-border:#2a3a30;--color-primary:#6cc242;--color-primary-dark:#9ad86a;--color-text:#e9f1eb;--color-text-muted:#9cb0a3;--color-text-invert:#0e1712;--color-highlight:var(--green-400);--color-selected:var(--green-300);--shadow-sm:0 1px 2px #00000059;--shadow-md:0 6px 18px #0006;--shadow-lg:0 16px 40px #00000080;--ring:0 0 0 3px #6cc24266}*{box-sizing:border-box}html,body{margin:0;padding:0}html{background:var(--color-bg)}body{min-height:100vh;font-family:var(--font-sans);color:var(--color-text);background:radial-gradient(1200px 600px at 80% -10%, var(--green-100), transparent 60%), radial-gradient(900px 500px at -10% 10%, var(--green-50), transparent 55%), var(--color-bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background-attachment:fixed}h1,h2,h3,p{margin:0}button{cursor:pointer;font-family:inherit}:focus-visible{box-shadow:var(--ring);border-radius:var(--radius-sm);outline:none}.app{max-width:1100px;padding:var(--space-6) var(--space-5) var(--space-8);margin:0 auto;position:relative}.theme-toggle{top:var(--space-5);right:var(--space-5);border:1px solid var(--color-border);background:var(--color-surface);width:44px;height:44px;color:var(--color-text);box-shadow:var(--shadow-sm);border-radius:50%;place-items:center;transition:transform .2s,box-shadow .2s,border-color .2s;display:grid;position:absolute}.theme-toggle:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 8px 18px #5cb83a47}.theme-toggle svg{width:20px;height:20px}.app__header{text-align:center;margin-bottom:var(--space-6)}.brand{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);cursor:pointer;font:inherit;color:inherit;background:0 0;border:none;margin:0;transition:transform .18s;display:inline-flex}.brand:hover{transform:translateY(-1px)}.brand:active{transform:translateY(0)}.brand__mark{width:38px;height:38px}.brand__name{letter-spacing:-.02em;font-size:2rem;font-weight:700}.brand__spark{isolation:isolate;color:var(--green-500);text-shadow:0 0 3px #84c64880,0 0 7px #84c6484d;position:relative}.brand__spark:before{content:"";z-index:-1;filter:blur(9px);pointer-events:none;background:radial-gradient(#84c6484d,#84c64800 72%);position:absolute;inset:-.45em -.6em}.brand__mark{filter:drop-shadow(0 2px 5px #5cb83a59);transition:transform .3s}.brand:hover .brand__mark{transform:rotate(-8deg)scale(1.08)}.app__tagline{margin-top:var(--space-2);color:var(--color-text-muted);font-size:1rem}.search{max-width:560px;margin:0 auto var(--space-4);position:relative}.search__input{width:100%;padding:var(--space-4) var(--space-5);border:1.5px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm);padding-left:52px;font-size:1.05rem;transition:border-color .15s,box-shadow .15s}.search__input::placeholder{color:#9bae9f}.search__input:focus{border-color:var(--color-primary);box-shadow:var(--ring)}.search__icon{color:var(--color-primary);pointer-events:none;position:absolute;top:50%;left:20px;transform:translateY(-50%)}.suggestions{gap:var(--space-2);margin-bottom:var(--space-5);flex-wrap:wrap;justify-content:center;display:flex}.chip{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm);font-size:.9rem;font-weight:500;transition:transform .12s,border-color .12s,background .12s;display:inline-flex}.chip:hover{border-color:var(--color-primary);background:var(--color-surface-alt);transform:translateY(-2px);box-shadow:0 6px 16px #5cb83a38}.chip__dot{background:var(--color-primary);border-radius:50%;width:8px;height:8px}.chip__dot--organelle{background:var(--sun)}.workspace{gap:var(--space-5);grid-template-columns:1fr 320px;align-items:start;display:grid}.workspace--compare{grid-template-columns:1fr}@media (width<=860px){.workspace{grid-template-columns:1fr}}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.diagram{padding:var(--space-5)}.diagram__head{justify-content:space-between;align-items:baseline;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.diagram__title{font-size:1.4rem;font-weight:700}.diagram__type{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary-dark);background:var(--green-100);border-radius:var(--radius-pill);padding:2px 10px;font-size:.78rem;font-weight:600}.diagram__svg{border-radius:var(--radius-md);background:var(--diagram-bg);width:100%;height:auto;display:block}.diagram__hint{margin-top:var(--space-3);color:var(--color-text-muted);text-align:center;font-size:.85rem}.part{cursor:pointer;transition:filter .2s,opacity .2s}.part:hover{filter:drop-shadow(0 0 5px #5cb83a8c)}.part:focus{outline:none}.part:focus-visible{filter:drop-shadow(0 0 6px var(--color-primary));outline:none}.part--selected,.part--selected:hover{filter:drop-shadow(0 0 5px var(--sun)) drop-shadow(0 0 11px #f4c95d99)}.part__label{fill:var(--green-900);pointer-events:none;stroke:#fff;stroke-width:3.5px;paint-order:stroke fill;stroke-linejoin:round;font-size:13px;font-weight:700;transition:fill .15s}.cell-label{cursor:pointer}.part__label--clickable{pointer-events:auto}.cell-label:hover .part__label,.cell-label--active .part__label{fill:var(--green-700)}.cell-label:hover line,.cell-label--active line{stroke:var(--green-600)}.info{padding:var(--space-5);top:var(--space-4);position:sticky}.info__empty{color:var(--color-text-muted);font-size:.95rem;line-height:1.5}.info__name{margin-bottom:var(--space-2);font-size:1.2rem;font-weight:700}.info__desc{color:var(--color-text-muted);font-size:.95rem;line-height:1.6}.info__link{margin-top:var(--space-4);align-items:center;gap:var(--space-1);color:var(--color-primary-dark);background:0 0;border:none;padding:0;font-size:.9rem;font-weight:600;transition:color .15s;display:inline-flex}.info__link-arrow{transition:transform .2s}.info__link:hover{color:var(--color-primary)}.info__link:hover .info__link-arrow{transform:translate(5px)}.switcher{gap:var(--space-1);width:fit-content;padding:var(--space-1);margin:0 auto var(--space-4);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);display:flex}.switch-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-pill);color:var(--color-text-muted);background:0 0;border:none;font-size:.95rem;font-weight:600;transition:transform .18s,box-shadow .18s,background .18s,color .18s}.switch-btn:hover{color:var(--color-text);transform:translateY(-2px)}.switch-btn--active{background:linear-gradient(135deg, var(--green-400), var(--green-600));color:var(--color-text-invert);box-shadow:0 6px 16px #5cb83a73}.switch-btn--active:hover{color:var(--color-text-invert);transform:translateY(-2px);box-shadow:0 10px 22px #5cb83a8c}.toolbar{justify-content:center;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);display:flex}.btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm);font-size:.9rem;font-weight:600;transition:transform .18s,box-shadow .18s,background .18s,border-color .18s;display:inline-flex}.btn:hover{border-color:var(--color-primary);background:var(--color-surface-alt);transform:translateY(-2px);box-shadow:0 8px 20px #5cb83a47}.btn--active{background:linear-gradient(135deg, var(--green-400), var(--green-600));border-color:var(--color-primary);color:var(--color-text-invert)}.btn--active:hover{background:linear-gradient(135deg, var(--green-500), var(--green-700));box-shadow:0 10px 22px #5cb83a80}.compare{gap:var(--space-5);grid-template-columns:1fr 1fr;display:grid}@media (width<=860px){.compare{grid-template-columns:1fr}}.compare__slot{min-height:200px}.compare__picker{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-6);text-align:center;color:var(--color-text-muted);border:2px dashed var(--color-border);border-radius:var(--radius-lg);flex-direction:column;min-height:260px;display:flex}.legend{margin-top:var(--space-5);padding:var(--space-4) var(--space-5);background:var(--color-surface-alt);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.9rem;line-height:1.6}.legend b{color:var(--color-text)}.notfound{text-align:center;padding:var(--space-7) var(--space-5);color:var(--color-text-muted)}.notfound__title{color:var(--color-text);margin-bottom:var(--space-2);font-size:1.15rem;font-weight:700}.home{margin-top:var(--space-6);justify-content:center;display:flex}.home__cards{gap:var(--space-5);grid-template-columns:repeat(auto-fit,minmax(230px,1fr));width:100%;max-width:900px;display:grid}@media (width<=560px){.home__cards{grid-template-columns:1fr}}.home-card{text-align:center;align-items:center;gap:var(--space-3);padding:var(--space-7) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);cursor:pointer;font:inherit;color:var(--color-text);flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.home-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 16px 34px #5cb83a38}.home-card__icon{background:var(--color-surface-alt);filter:drop-shadow(0 3px 6px #5cb83a2e);border-radius:50%;place-items:center;width:76px;height:76px;display:grid}.home-card__title{font-size:1.4rem;font-weight:700}.home-card__desc{color:var(--color-text-muted);font-size:.95rem;line-height:1.55}.home-card__cta{margin-top:var(--space-2);color:var(--color-primary-dark);font-weight:600}.study{max-width:560px;margin:0 auto}.deck-picker,.study-modes{gap:var(--space-1);width:fit-content;padding:var(--space-1);margin:0 auto var(--space-5);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);display:flex}.deck-picker{margin-bottom:var(--space-5)}.flashcard{perspective:1400px;cursor:pointer;outline:none}.flashcard__inner{width:100%;min-height:300px;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.4,.1,.2,1);position:relative}.flashcard__inner.is-flipped{transform:rotateY(180deg)}.flashcard:focus-visible .flashcard__inner{box-shadow:var(--ring);border-radius:var(--radius-lg)}.flashcard__face{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-6);text-align:center;border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);backface-visibility:hidden;flex-direction:column;display:flex;position:absolute;inset:0}.flashcard__face--front{background:var(--color-surface)}.flashcard__face--back{background:linear-gradient(160deg, var(--green-50), var(--green-100));transform:rotateY(180deg)}.flashcard__type{text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary-dark);background:var(--green-100);border-radius:var(--radius-pill);padding:3px 12px;font-size:.72rem;font-weight:700}.flashcard__term{letter-spacing:-.01em;font-size:1.9rem;font-weight:700}.flashcard__def{color:var(--color-text);font-size:1.1rem;line-height:1.6}.flashcard__hint{color:var(--color-text-muted);font-size:.82rem}.flashcard-nav{justify-content:center;align-items:center;gap:var(--space-3);margin-top:var(--space-5);display:flex}.flashcard-nav__count{font-variant-numeric:tabular-nums;color:var(--color-text-muted);text-align:center;min-width:56px;font-weight:600}.flashcard-nav__shuffle{margin-left:var(--space-3)}@media (prefers-reduced-motion:reduce){.flashcard__inner{transition:none}}.quiz-timer-row{margin-bottom:var(--space-4);justify-content:center;display:flex}.quiz-timer-toggle{font-size:.85rem}.quiz__progress{color:var(--color-text-muted);margin-bottom:var(--space-3);justify-content:space-between;font-size:.85rem;font-weight:600;display:flex}.quiz-timer{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.quiz-timer__track{background:var(--green-100);border-radius:var(--radius-pill);flex:1;height:8px;overflow:hidden}.quiz-timer__fill{border-radius:var(--radius-pill);background:linear-gradient(90deg, var(--green-400), var(--green-600));height:100%;transition:width 1s linear,background .3s}.quiz-timer__fill[data-low=true]{background:linear-gradient(90deg,#e8896f,#d9534f)}.quiz-timer__num{font-variant-numeric:tabular-nums;text-align:right;min-width:36px;color:var(--color-text-muted);font-weight:700}.quiz-timer__num[data-low=true]{color:#d9534f}.quiz__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-6) var(--space-5);text-align:center;margin-bottom:var(--space-4)}.quiz__ask{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary-dark);margin-bottom:var(--space-3);font-size:.82rem;font-weight:700}.quiz__prompt{color:var(--color-text);font-size:1.15rem;line-height:1.55}.quiz__options{gap:var(--space-3);display:grid}.quiz-option{text-align:left;width:100%;padding:var(--space-4) var(--space-5);color:var(--color-text);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);font-size:1rem;font-weight:600;transition:transform .15s,box-shadow .15s,border-color .15s,background .15s}.quiz-option:not(:disabled):hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 8px 18px #5cb83a38}.quiz-option:disabled{cursor:default}.quiz-option--correct{border-color:var(--green-500);background:var(--green-50);color:var(--green-800)}.quiz-option--wrong{color:#9a3a3a;background:#fbeeee;border-color:#d98a8a}.quiz-option--dim{opacity:.55}.quiz__feedback{justify-content:space-between;align-items:center;gap:var(--space-4);margin-top:var(--space-5);flex-wrap:wrap;display:flex}.quiz__verdict{font-weight:700}.quiz__verdict--ok{color:var(--green-600)}.quiz__verdict--no{color:#b5483f}.quiz-result{text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-8) var(--space-6)}.quiz-result__title{font-size:1.5rem;font-weight:700}.quiz-result__score{color:var(--color-primary);margin:var(--space-4) 0 var(--space-2);font-size:3.4rem;font-weight:700}.quiz-result__score span{color:var(--color-text-muted);font-size:1.6rem}.quiz-result__msg{color:var(--color-text-muted);margin-bottom:var(--space-5)}[data-theme=dark] body{background:radial-gradient(1200px 600px at 80% -10%, #6cc24224, transparent 60%), radial-gradient(900px 500px at -10% 10%, #6cc24217, transparent 55%), var(--color-bg)}[data-theme=dark] .diagram__type,[data-theme=dark] .flashcard__type{color:var(--green-300);background:#6cc2422e}[data-theme=dark] .flashcard__face--back{background:linear-gradient(160deg,#1d2e24,#16241c)}[data-theme=dark] .quiz-option--correct{border-color:var(--green-500);color:var(--green-200);background:#6cc24229}[data-theme=dark] .quiz-option--wrong{color:#efb0ab;background:#d9534f29;border-color:#b5605a}[data-theme=dark] .quiz-timer__track{background:#ffffff14}.label-quiz__prompt{text-align:center;margin-bottom:var(--space-4);color:var(--color-text);font-size:1.2rem}.label-quiz__prompt strong{color:var(--color-primary-dark)}.label-quiz__cell{color:var(--color-text-muted);font-size:.95rem}.label-quiz__stage{padding:var(--space-3)}.label-quiz__stage .diagram__svg{border-radius:var(--radius-md)}.label-quiz__stage.is-revealed .part{transition:opacity .25s}.label-quiz__stage.is-revealed .part:not(.part--selected){opacity:.28}.label-quiz__stage.is-revealed .part--selected,.label-quiz__stage.is-revealed .part--selected:hover{filter:drop-shadow(0 0 6px var(--sun)) drop-shadow(0 0 16px #f4c95dd9)}.process,.processes{max-width:640px;margin:0 auto}.process__stage{padding:var(--space-5)}.ps-grana,.ps-calvin,.ps-mol{transition:opacity .35s,filter .35s}.ps-region{fill:#4f7a3a;font-size:13px;font-weight:700;transition:fill .3s}.ps-region.is-active{fill:#b07d12}.process__step{text-align:center;margin-top:var(--space-4);min-height:92px}.process__step-title{color:var(--color-primary-dark);margin-bottom:var(--space-2);font-size:1.2rem;font-weight:700}.process__step-text{color:var(--color-text);font-size:1rem;line-height:1.6}.process__equation{margin-top:var(--space-3);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-primary-dark);font-weight:600;display:inline-block}.process__nav{justify-content:center;align-items:center;gap:var(--space-3);margin-top:var(--space-5);display:flex}.process__count{font-variant-numeric:tabular-nums;color:var(--color-text-muted);text-align:center;min-width:84px;font-weight:600}@media (width<=540px){.app{padding:var(--space-5) var(--space-3) var(--space-7)}.brand__name{font-size:1.7rem}.brand__mark{width:32px;height:32px}.theme-toggle{top:var(--space-3);right:var(--space-3);width:40px;height:40px}.search__input{padding-left:46px;font-size:1rem}.switcher,.deck-picker,.study-modes{scrollbar-width:none;justify-content:flex-start;max-width:100%;overflow-x:auto}.switcher::-webkit-scrollbar{display:none}.deck-picker::-webkit-scrollbar{display:none}.study-modes::-webkit-scrollbar{display:none}.switch-btn{padding:var(--space-2) var(--space-4);white-space:nowrap;flex-shrink:0;font-size:.88rem}.process__nav,.quiz__feedback,.flashcard-nav,.toolbar{flex-wrap:wrap}.home-card{padding:var(--space-6) var(--space-4)}.diagram,.process__stage{padding:var(--space-4)}}.mastery{max-width:560px;margin:0 auto var(--space-4)}.mastery__track{border-radius:var(--radius-pill);background:var(--color-border);height:10px;display:flex;overflow:hidden}.mastery__seg{height:100%;transition:width .35s}.mastery__seg--known{background:var(--green-500)}.mastery__seg--learning{background:var(--sun)}.mastery__legend{gap:var(--space-3);margin-top:var(--space-2);color:var(--color-text-muted);flex-wrap:wrap;justify-content:center;align-items:center;font-size:.82rem;display:flex}.mastery__dot{border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.mastery__dot--known{background:var(--green-500)}.mastery__dot--learning{background:var(--sun)}.mastery__dot--new{background:var(--color-border)}.mastery__reset{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.8rem;text-decoration:underline}.mastery__reset:hover{color:var(--color-text)}.flashcard__rate{gap:var(--space-3);margin-top:var(--space-5);display:flex}.rate-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-pill);border:1.5px solid var(--color-border);font-size:.92rem;font-weight:600;transition:transform .15s,box-shadow .15s}.rate-btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.rate-btn--learning{background:var(--color-surface);border-color:var(--sun);color:var(--color-text)}.rate-btn--known{background:var(--green-500);border-color:var(--green-500);color:#fff}.flashcard-empty{text-align:center;padding:var(--space-8) var(--space-5)}.flashcard-empty__title{margin-bottom:var(--space-2);font-size:1.2rem;font-weight:700}.flashcard-empty__hint{color:var(--color-text-muted);line-height:1.6}
