*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);background:var(--bg-canvas);color:var(--fg);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"cv11","ss01","ss03";letter-spacing:-.005em}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}a{color:inherit;text-decoration:none}input,textarea,select{font:inherit;color:inherit}ul,ol{list-style:none}svg{display:block}:root{--bg-canvas: #12141f;--bg-surface: #191c2a;--bg-raised: #1e2133;--bg-hover: #22263a;--bg-sunken: #0f1119;--stroke-1: rgba(255,255,255,.06);--stroke-2: rgba(255,255,255,.1);--stroke-3: rgba(255,255,255,.16);--stroke-focus: var(--accent);--fg-strong: #f4f4f8;--fg: #dcdce8;--fg-muted: #9898b2;--fg-faint: #717188;--accent: #4f8ef7;--accent-soft: rgba(79,142,247,.14);--accent-strong: #6ba3ff;--accent-fg: #141829;--success: #3ecf8e;--success-soft: rgba(62,207,142,.16);--warn: #f59e0b;--warn-soft: rgba(245,158,11,.16);--danger: #e54b4b;--danger-soft: rgba(229,75,75,.16);--r-xs: 6px;--r-sm: 8px;--r-md: 10px;--r-lg: 14px;--r-xl: 18px;--r-pill: 999px;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-7: 32px;--s-8: 40px;--s-9: 56px;--sidebar-w: 268px;--topbar-h: 56px;--content-max: 1180px;--font-sans: "Onest", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--shadow-sm: 0 1px 2px rgba(0,0,0,.18);--shadow-md: 0 8px 24px -8px rgba(0,0,0,.45);--shadow-lg: 0 24px 60px -20px rgba(0,0,0,.55);--bg-dark: var(--bg-canvas);--bg-card: var(--bg-surface);--bg-sidebar: var(--bg-sunken);--bg-active: var(--accent-soft);--accent-hover: var(--accent-strong);--accent-green: var(--success);--accent-orange: var(--warn);--text-primary: var(--fg-strong);--text-secondary: var(--fg-muted);--text-muted: var(--fg-faint);--border: var(--stroke-2);--border-accent: var(--accent-soft);--radius: var(--r-md);--radius-sm: var(--r-xs);--sidebar-width: var(--sidebar-w)}.theme-1{--accent: #4f8ef7;--accent-soft: rgba(79,142,247,.14);--accent-strong: #6ba3ff;--accent-fg: #141829}.theme-2{--accent: #3ecf8e;--accent-soft: rgba(62,207,142,.14);--accent-strong: #52e0a2;--accent-fg: #0f2b20}.theme-3{--accent: #f59e0b;--accent-soft: oklch(.78 .13 60 / .14);--accent-strong: #fbb03b;--accent-fg: #2b1f0a}.theme-4{--accent: #a855f7;--accent-soft: rgba(168,85,247,.14);--accent-strong: #ba74ff;--accent-fg: #1f1030}.theme-5{--accent: #e11d48;--accent-soft: oklch(.7 .16 15 / .14);--accent-strong: #f43363;--accent-fg: #2a0f15}.theme-6{--accent: #22d3ee;--accent-soft: rgba(34,211,238,.14);--accent-strong: #40e0f7;--accent-fg: #0a1f25}.theme-7{--accent: #22c55e;--accent-soft: rgba(34,197,94,.14);--accent-strong: #3dd974;--accent-fg: #0a1f12}.theme-8{--accent: #fbbf24;--accent-soft: oklch(.78 .13 75 / .14);--accent-strong: #fcd34d;--accent-fg: #2a1e08}.theme-9{--accent: #14b8a6;--accent-soft: rgba(20,184,166,.14);--accent-strong: #2dd4bf;--accent-fg: #081f1c}.theme-10{--accent: #6366f1;--accent-soft: rgba(99,102,241,.14);--accent-strong: #818cf8;--accent-fg: #0e1030}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--stroke-2);border-radius:10px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--stroke-3);background-clip:padding-box;border:2px solid transparent}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;background:var(--bg-canvas)}.main{display:grid;grid-template-rows:var(--topbar-h) 1fr;min-width:0;overflow:hidden}.main__scroll{overflow-y:auto;padding:var(--s-6) var(--s-7) var(--s-8)}.main__inner{max-width:var(--content-max);margin:0 auto}.sidebar{display:grid;grid-template-rows:auto auto 1fr auto;background:var(--bg-sunken);border-right:1px solid var(--stroke-1);min-height:0}.sidebar__brand{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-5) var(--s-4) var(--s-4)}.sidebar__logo{width:32px;height:32px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--accent),#9c3fe8);display:grid;place-items:center;font-weight:800;font-size:13px;color:var(--accent-fg);letter-spacing:0;box-shadow:inset 0 0 0 1px #ffffff1f;flex-shrink:0}.sidebar__brand-text{display:grid;line-height:1.2}.sidebar__brand-name{font-weight:700;font-size:15px;color:var(--fg-strong)}.sidebar__brand-sub{font-size:11px;color:var(--fg-muted);letter-spacing:.02em}.sidebar__search{margin:0 var(--s-3) var(--s-3);display:flex;align-items:center;gap:var(--s-2);padding:8px 10px;background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-sm);color:var(--fg-muted);font-size:13px;cursor:pointer;transition:border-color .15s,background .15s;text-align:left;width:calc(100% - var(--s-3) * 2);font:inherit}.sidebar__search:hover{border-color:var(--stroke-2);background:var(--bg-raised)}.sidebar__search svg{color:var(--fg-muted);flex-shrink:0}.sidebar__search-text{flex:1}.sidebar__search-kbd{font-family:var(--font-mono);font-size:10.5px;padding:2px 5px;border-radius:4px;background:var(--bg-canvas);border:1px solid var(--stroke-1);color:var(--fg-faint);line-height:1}.sidebar__nav{overflow-y:auto;padding:0 var(--s-2) var(--s-4);min-height:0;display:flex;flex-direction:column;gap:2px}.sidebar__group-label{display:flex;justify-content:space-between;align-items:center;padding:var(--s-3) var(--s-3) 6px;font-size:10.5px;font-weight:600;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.08em}.sidebar__group-toggle{width:16px;height:16px;display:grid;place-items:center;color:var(--fg-faint);border-radius:4px;transition:background .15s}.sidebar__group-toggle:hover{background:var(--bg-hover);color:var(--fg)}.sidebar__group-toggle svg{transition:transform .2s}.sidebar__group-toggle.collapsed svg{transform:rotate(-90deg)}.nav-item{display:flex;align-items:center;gap:var(--s-3);padding:8px 10px;border-radius:var(--r-sm);color:var(--fg-muted);font-size:13.5px;font-weight:500;cursor:pointer;transition:background .12s,color .12s;position:relative;-webkit-user-select:none;user-select:none;text-align:left;width:100%;text-decoration:none}.nav-item:hover{background:var(--bg-surface);color:var(--fg)}.nav-item.is-active{background:var(--bg-surface);color:var(--fg-strong)}.nav-item.is-active:before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:2px;border-radius:2px;background:var(--accent)}.nav-item__icon{width:18px;height:18px;color:var(--fg-faint);flex-shrink:0;display:flex;align-items:center;justify-content:center}.nav-item.is-active .nav-item__icon{color:var(--accent)}.nav-item__label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item__badge{font-size:10.5px;font-family:var(--font-mono);padding:1px 6px;border-radius:var(--r-pill);background:var(--bg-hover);color:var(--fg-muted);line-height:1.5}.nav-item__badge.is-accent{background:var(--accent-soft);color:var(--accent)}.sidebar__footer{border-top:1px solid var(--stroke-1);padding:var(--s-3);display:flex;align-items:center;gap:var(--s-3)}.sidebar__avatar{width:32px;height:32px;border-radius:var(--r-pill);background:linear-gradient(135deg,#b273c0,#c8635d);display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;flex-shrink:0}.sidebar__user-text{display:grid;line-height:1.25;min-width:0;flex:1}.sidebar__user-name{font-size:13px;color:var(--fg-strong);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__user-meta{font-size:11px;color:var(--fg-muted);overflow:hidden;text-overflow:ellipsis}.sidebar__user-action{width:28px;height:28px;border-radius:var(--r-xs);display:grid;place-items:center;color:var(--fg-muted);transition:background .15s,color .15s;flex-shrink:0}.sidebar__user-action:hover{background:var(--bg-hover);color:var(--fg)}.dir-tile{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-size:9px;font-weight:700;letter-spacing:.04em;color:#ffffffeb;text-transform:uppercase;flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff14;background:linear-gradient(135deg,var(--direction-icon-start, oklch(.55 .14 250)),var(--direction-icon-end, oklch(.42 .1 250)))}.dir-tile--lg{width:44px;height:44px;border-radius:var(--r-md);font-size:14px}.dir-tile--xl{width:64px;height:64px;border-radius:var(--r-lg);font-size:20px}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:var(--s-4);padding:0 var(--s-7);border-bottom:1px solid var(--stroke-1);background:var(--bg-canvas);flex-shrink:0}.crumbs{display:flex;align-items:center;gap:var(--s-2);font-size:13.5px;min-width:0}.crumb{color:var(--fg-muted);white-space:nowrap}.crumb.is-current{color:var(--fg-strong);font-weight:600}.crumb-sep{color:var(--fg-faint);display:flex;align-items:center}.topbar__spacer{flex:1}.topbar__search{display:flex;align-items:center;gap:var(--s-2);width:300px;max-width:100%;padding:7px 12px;border-radius:var(--r-sm);background:var(--bg-surface);border:1px solid var(--stroke-1);color:var(--fg-muted);font-size:13px;cursor:pointer;transition:border-color .15s;text-align:left;font:inherit}.topbar__search:hover{border-color:var(--stroke-2)}.topbar__search-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.topbar__actions{display:flex;align-items:center;gap:6px}.icon-btn{width:34px;height:34px;border-radius:var(--r-sm);display:grid;place-items:center;color:var(--fg-muted);transition:background .15s,color .15s;position:relative}.icon-btn:hover{background:var(--bg-surface);color:var(--fg-strong)}.icon-btn__dot{position:absolute;top:7px;right:7px;width:6px;height:6px;border-radius:var(--r-pill);background:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.btn--primary{background:var(--accent);color:var(--accent-fg)}.btn--primary:hover{background:var(--accent-strong)}.btn--secondary{background:var(--bg-surface);border-color:var(--stroke-1);color:var(--fg)}.btn--secondary:hover{background:var(--bg-raised);border-color:var(--stroke-2)}.btn--ghost{color:var(--fg-muted)}.btn--ghost:hover{background:var(--bg-surface);color:var(--fg)}.btn--sm{padding:5px 10px;font-size:12.5px;border-radius:var(--r-xs)}.btn--lg{padding:9px 18px;font-size:14px}.btn svg{width:16px;height:16px;flex-shrink:0}.btn--sm svg{width:14px;height:14px}.card{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);overflow:hidden}.card__head{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--stroke-1)}.card__title{display:flex;align-items:center;gap:var(--s-2);font-size:13.5px;font-weight:600;color:var(--fg-strong);white-space:nowrap}.card__head-spacer{flex:1}.card__body{padding:var(--s-5)}.card__body--flush{padding:0}.page-head{display:flex;align-items:flex-start;gap:var(--s-5);margin-bottom:var(--s-6)}.page-head__title{font-size:26px;font-weight:700;color:var(--fg-strong);letter-spacing:-.02em;line-height:1.15}.page-head__sub{color:var(--fg-muted);margin-top:4px;font-size:14px;max-width:720px}.page-head__spacer{flex:1}.page-head__actions{display:flex;gap:var(--s-2);align-items:center;flex-shrink:0}.stat{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-4) var(--s-5);display:grid;gap:4px;position:relative;overflow:hidden}.stat__label{font-size:12px;color:var(--fg-muted);font-weight:500;display:flex;align-items:center;gap:6px}.stat__value{font-size:28px;font-weight:700;color:var(--fg-strong);font-family:var(--font-mono);letter-spacing:-.03em}.stat__delta{font-size:11.5px;color:var(--success);display:flex;align-items:center;gap:3px}.stat__delta.is-down{color:var(--danger)}.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--s-3)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}@media (max-width: 900px){.grid-2,.grid-3{grid-template-columns:1fr}}.dir-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--s-3)}.dir-card{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-4);display:grid;gap:var(--s-3);cursor:pointer;transition:background .15s,border-color .15s;text-align:left;width:100%;color:inherit;font:inherit}.dir-card:hover{border-color:var(--stroke-2);background:var(--bg-raised)}.dir-card__head{display:flex;align-items:center;gap:var(--s-3)}.dir-card__name{font-size:15px;font-weight:600;color:var(--fg-strong);flex:1}.dir-card__count{font-family:var(--font-mono);font-size:11px;color:var(--fg-faint);padding:2px 7px;border-radius:var(--r-pill);background:var(--bg-canvas);border:1px solid var(--stroke-1)}.dir-card__desc{font-size:12.5px;color:var(--fg-muted);line-height:1.5;min-height:38px}.dir-card__foot{display:flex;align-items:center;gap:var(--s-2)}.dir-card__bar{flex:1;height:4px;border-radius:var(--r-pill);background:var(--bg-canvas);overflow:hidden}.dir-card__bar-fill{height:100%;background:var(--accent);border-radius:inherit}.dir-card__bar-fill.is-done{background:var(--success)}.dir-card__progress{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono)}.section{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);margin-bottom:var(--s-3);overflow:hidden}.section__head{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-5);background:var(--bg-raised);border-bottom:1px solid var(--stroke-1)}.section__title{font-size:13.5px;font-weight:600;color:var(--fg-strong);display:flex;align-items:center;gap:var(--s-2)}.section__count{font-size:11.5px;color:var(--fg-muted);font-family:var(--font-mono)}.entry{display:grid;grid-template-columns:auto 1fr auto;gap:var(--s-3);padding:var(--s-3) var(--s-5);border-bottom:1px solid var(--stroke-1);align-items:flex-start;text-align:left;width:100%;color:inherit}button.entry{font:inherit}.entry:last-child{border-bottom:none}.entry:hover{background:var(--bg-raised)}.tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:var(--r-pill);background:var(--bg-canvas);border:1px solid var(--stroke-1);color:var(--fg-muted);font-weight:500;line-height:1.5;font-family:var(--font-mono);letter-spacing:-.01em}.tag--accent{background:var(--accent-soft);color:var(--accent);border-color:#4f8ef752}.tag--success{background:var(--success-soft);color:var(--success)}.tag--warn{background:var(--warn-soft);color:var(--warn)}.tag--danger{background:var(--danger-soft);color:var(--danger)}.pill-bar{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.pill{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;font-size:12.5px;border-radius:var(--r-pill);color:var(--fg-muted);border:1px solid var(--stroke-1);background:var(--bg-surface);cursor:pointer;transition:all .15s;white-space:nowrap}.pill:hover{border-color:var(--stroke-2);color:var(--fg)}.pill.is-active{background:var(--accent-soft);border-color:#4f8ef766;color:var(--accent)}.tabs{display:flex;gap:2px;padding:3px;background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-sm);width:max-content}.tab{padding:6px 14px;font-size:13px;font-weight:500;border-radius:var(--r-xs);color:var(--fg-muted);cursor:pointer;transition:background .15s,color .15s}.tab:hover{color:var(--fg)}.tab.is-active{background:var(--bg-raised);color:var(--fg-strong);box-shadow:var(--shadow-sm)}.input,.textarea,.select{width:100%;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-sm);color:var(--fg);font-size:13.5px;outline:none;transition:border-color .15s,background .15s}.input:hover,.textarea:hover,.select:hover{border-color:var(--stroke-2)}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);background:var(--bg-canvas)}.textarea{resize:vertical;min-height:80px;line-height:1.55}.field{display:grid;gap:6px}.field__label{font-size:12px;color:var(--fg-muted);font-weight:500}.progress{height:6px;border-radius:var(--r-pill);background:var(--bg-canvas);overflow:hidden}.progress__fill{height:100%;background:var(--accent);border-radius:inherit;transition:width .3s}.progress__fill.is-success{background:var(--success)}.divider{height:1px;background:var(--stroke-1);margin:var(--s-3) 0}.divider--v{width:1px;height:16px;background:var(--stroke-1)}.empty{display:grid;place-items:center;gap:var(--s-3);padding:var(--s-7);color:var(--fg-muted);text-align:center}.empty__icon{width:40px;height:40px;border-radius:var(--r-md);display:grid;place-items:center;background:var(--bg-canvas);border:1px solid var(--stroke-1);color:var(--fg-faint)}.empty__title{font-size:14px;font-weight:600;color:var(--fg)}.empty__text{font-size:13px;max-width:320px}.spark{display:flex;align-items:flex-end;gap:3px;height:56px}.spark__bar{flex:1;background:var(--accent);border-radius:2px 2px 0 0;min-height:4px;opacity:.6}.spark__bar:last-child{opacity:1}.ai-hero{background:radial-gradient(circle at 100% 0%,rgba(79,142,247,.18),transparent 50%),radial-gradient(circle at 0% 100%,rgba(156,63,232,.16),transparent 50%),var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-6);display:grid;gap:var(--s-4)}.ai-hero__badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600;background:var(--accent-soft);color:var(--accent);border:1px solid rgba(79,142,247,.32);width:max-content}.ai-hero__title{font-size:22px;font-weight:700;color:var(--fg-strong);letter-spacing:-.02em}.ai-hero__sub{color:var(--fg-muted);max-width:640px}.ai-hero__prompts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--s-2)}.ai-prompt{display:grid;gap:2px;padding:var(--s-3) var(--s-4);background:var(--bg-canvas);border:1px solid var(--stroke-1);border-radius:var(--r-sm);text-align:left;cursor:pointer;transition:border-color .15s,background .15s;width:100%;color:inherit;font:inherit}.ai-prompt:hover{border-color:var(--stroke-2);background:var(--bg-raised)}.ai-prompt__label{font-size:13px;font-weight:600;color:var(--fg-strong)}.ai-prompt__q{font-size:12px;color:var(--fg-muted)}.dir-head{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-5);background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);margin-bottom:var(--s-5)}.dir-head__body{flex:1;min-width:0;display:grid;gap:6px}.dir-head__title-row{display:flex;align-items:center;gap:var(--s-3);flex-wrap:wrap}.dir-head__name{font-size:22px;font-weight:700;color:var(--fg-strong);letter-spacing:-.02em}.dir-head__desc{color:var(--fg-muted);font-size:13.5px}.dir-head__stats{display:flex;align-items:center;gap:var(--s-4);margin-top:4px;font-size:12px;color:var(--fg-muted);flex-wrap:wrap}.chat{display:grid;grid-template-rows:auto 1fr auto;height:calc(100vh - var(--topbar-h) - var(--s-6) - var(--s-8));min-height:500px}.chat__messages{overflow-y:auto;padding:var(--s-2);display:flex;flex-direction:column;gap:var(--s-4)}.chat__msg{display:grid;gap:var(--s-2);max-width:720px}.chat__msg--user{justify-self:end}.chat__msg--user .chat__bubble{background:var(--accent-soft);color:var(--fg-strong);border-color:#4f8ef74d}.chat__bubble{padding:var(--s-3) var(--s-4);border-radius:var(--r-md);background:var(--bg-surface);border:1px solid var(--stroke-1);font-size:14px;line-height:1.6}.chat__sources{display:flex;flex-wrap:wrap;gap:6px}.chat__src{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:var(--bg-canvas);border:1px solid var(--stroke-1);border-radius:var(--r-pill);font-size:11.5px;color:var(--fg-muted);font-family:var(--font-mono)}.chat__composer{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-md);padding:var(--s-3);display:grid;gap:var(--s-2)}.chat__composer:focus-within{border-color:var(--accent)}.chat__composer textarea{background:transparent;border:none;outline:none;resize:none;color:var(--fg);font-size:14px;line-height:1.55;min-height:32px;font-family:inherit;width:100%}.chat__composer-row{display:flex;align-items:center;gap:var(--s-2)}.chat__mode-bar{display:flex;gap:4px;flex-wrap:wrap;align-items:center;align-self:start}.quiz{max-width:640px;margin:0 auto;background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-6);display:grid;gap:var(--s-5)}.quiz__progress{display:flex;align-items:center;gap:var(--s-3)}.quiz__count{font-family:var(--font-mono);font-size:12px;color:var(--fg-muted)}.quiz__q{font-size:19px;font-weight:600;color:var(--fg-strong);line-height:1.4}.quiz__options{display:grid;gap:var(--s-2)}.quiz__opt{padding:var(--s-3) var(--s-4);background:var(--bg-canvas);border:1.5px solid var(--stroke-1);border-radius:var(--r-sm);text-align:left;font-size:14px;cursor:pointer;transition:border-color .15s,background .15s;display:flex;align-items:center;gap:var(--s-3);width:100%;color:inherit;font:inherit}.quiz__opt:hover{border-color:var(--stroke-3)}.quiz__opt.is-correct{border-color:var(--success);background:var(--success-soft)}.quiz__opt.is-wrong{border-color:var(--danger);background:var(--danger-soft)}.quiz__opt-letter{width:24px;height:24px;border-radius:var(--r-xs);background:var(--bg-surface);border:1px solid var(--stroke-1);display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:var(--fg-muted);flex-shrink:0}.quiz__rating{display:flex;gap:var(--s-2)}.quiz__rate{flex:1;padding:10px;border:1px solid var(--stroke-1);background:var(--bg-canvas);border-radius:var(--r-sm);text-align:center;cursor:pointer;transition:border-color .15s,background .15s;color:inherit;font:inherit}.quiz__rate:hover{background:var(--bg-raised);border-color:var(--stroke-2)}.quiz__rate-label{font-size:13px;font-weight:600;color:var(--fg-strong)}.quiz__rate-meta{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono);margin-top:2px}.toolbar{display:flex;align-items:center;gap:var(--s-3);flex-wrap:wrap;margin-bottom:var(--s-4)}.toolbar__spacer{flex:1}.palette__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:start center;padding-top:12vh;animation:paletteFade .15s ease-out}@keyframes paletteFade{0%{opacity:0}to{opacity:1}}.palette{width:min(640px,calc(100vw - 32px));background:var(--bg-surface);border:1px solid var(--stroke-2);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;display:grid;grid-template-rows:auto 1fr auto;max-height:70vh;animation:paletteSlide .18s ease-out}@keyframes paletteSlide{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}.palette__input-row{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-4) var(--s-5);border-bottom:1px solid var(--stroke-1);color:var(--fg-muted)}.palette__input{flex:1;background:transparent;border:none;outline:none;font-size:15px;color:var(--fg-strong)}.palette__esc,.palette__foot kbd{font-family:var(--font-mono);font-size:10.5px;padding:2px 6px;border-radius:4px;background:var(--bg-canvas);border:1px solid var(--stroke-1);color:var(--fg-faint)}.palette__body{overflow-y:auto;padding:var(--s-2);display:grid;gap:var(--s-2)}.palette__group{display:grid;gap:2px}.palette__group-label{padding:8px 12px 4px;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-faint)}.palette__item{display:flex;align-items:center;gap:var(--s-3);padding:8px 12px;border-radius:var(--r-sm);color:var(--fg);font-size:13.5px;cursor:pointer;text-align:left;width:100%;font:inherit;background:none;border:none}.palette__item:hover{background:var(--bg-raised)}.palette__item>span:nth-child(2){flex:1}.palette__item-meta{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono)}.palette__foot{display:flex;gap:var(--s-4);padding:var(--s-2) var(--s-5);border-top:1px solid var(--stroke-1);font-size:11.5px;color:var(--fg-faint)}.palette__foot kbd{color:var(--fg-muted);margin-right:4px}@media (max-width: 768px){:root{--sidebar-w: 0px}.app{grid-template-columns:1fr}.sidebar{display:none}.main__scroll{padding:var(--s-4)}.topbar{padding:0 var(--s-4)}}.app-layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;background:var(--bg-canvas)}.app-main{display:grid;grid-template-rows:var(--topbar-h) 1fr;min-width:0;overflow:hidden}.loading{display:grid;place-items:center;height:200px;color:var(--fg-muted);font-size:14px}.error-msg{background:var(--danger-soft);border:1px solid rgba(229,75,75,.3);color:var(--danger);border-radius:var(--r-sm);padding:var(--s-3) var(--s-4);font-size:13.5px;margin:var(--s-2) 0}.panel-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--r-xs);font-size:12.5px;font-weight:500;background:var(--bg-raised);border:1px solid var(--stroke-1);color:var(--fg-muted);cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.panel-btn:hover{background:var(--bg-hover);border-color:var(--stroke-2);color:var(--fg)}.panel-btn:disabled{opacity:.4;cursor:not-allowed}.panel-input{width:100%;padding:8px 12px;background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-sm);color:var(--fg);font-size:13.5px;outline:none;transition:border-color .15s;font:inherit}.panel-input:hover{border-color:var(--stroke-2)}.panel-input:focus{border-color:var(--accent);background:var(--bg-canvas)}.panel-list{list-style:none;padding:0;margin:0}.panel-empty{padding:var(--s-4) var(--s-5);color:var(--fg-faint);font-size:13px;text-align:center}.panel{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);overflow:hidden}.panel-header{padding:var(--s-3) var(--s-5);background:var(--bg-raised);border-bottom:1px solid var(--stroke-1);font-weight:600;font-size:13.5px;color:var(--fg-strong)}.panel-body{padding:var(--s-4) var(--s-5)}.panel-form{display:grid;gap:var(--s-2);margin-top:var(--s-3);padding-top:var(--s-3);border-top:1px solid var(--stroke-1)}.panels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--s-3);margin-top:var(--s-5)}.section-block{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);margin-bottom:var(--s-3);overflow:hidden}.section-header{padding:var(--s-3) var(--s-5);background:var(--bg-raised);border-bottom:1px solid var(--stroke-1);font-weight:600;font-size:13.5px;color:var(--fg-strong);display:flex;align-items:center;gap:var(--s-2)}.section-entries{list-style:none;padding:0;margin:0}.section-entry{padding:var(--s-3) var(--s-5);border-bottom:1px solid var(--stroke-1);font-size:13.5px;color:var(--fg);display:grid;grid-template-columns:auto 1fr;gap:var(--s-3);align-items:flex-start}.section-entry:last-child{border-bottom:none}.section-entry:hover{background:var(--bg-raised)}.section-entry-content{min-width:0}.entry-header{display:flex;align-items:flex-start;gap:var(--s-2)}.entry-content{font-size:13.5px;color:var(--fg);line-height:1.5;margin:0}.entry-details{margin-top:var(--s-2);padding:var(--s-3);background:var(--bg-canvas);border:1px solid var(--stroke-1);border-radius:var(--r-sm);font-size:12.5px;color:var(--fg-muted);line-height:1.55}.entry-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.entry-tag{display:inline-flex;align-items:center;font-size:11px;padding:2px 8px;border-radius:var(--r-pill);background:var(--bg-canvas);border:1px solid currentColor;font-weight:500;font-family:var(--font-mono)}.entry-actions{display:flex;gap:4px;align-items:center;margin-top:4px;flex-wrap:wrap}.entry-inline-btn{font-size:11.5px;padding:2px 8px;border-radius:var(--r-pill);background:var(--bg-canvas);border:1px solid var(--stroke-1);color:var(--fg-muted);cursor:pointer;transition:color .15s,border-color .15s}.entry-inline-btn:hover{color:var(--fg);border-color:var(--stroke-2)}.entry-inline-btn.active{background:var(--accent-soft);color:var(--accent);border-color:#4f8ef74d}.entry-details-toggle{font-size:12px;padding:3px 10px;border-radius:var(--r-pill);background:var(--bg-canvas);border:1px solid var(--stroke-1);color:var(--fg-muted);cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;flex-shrink:0}.entry-details-toggle:hover{color:var(--fg);border-color:var(--stroke-2)}.entry-learned-btn{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--stroke-3);display:grid;place-items:center;font-size:10px;color:var(--fg-faint);cursor:pointer;transition:all .15s;flex-shrink:0;margin-top:3px;background:transparent}.entry-learned-btn.learned{background:var(--success);border-color:var(--success);color:#fff}.entry-learned{opacity:.65}.entry-highlight{background:var(--accent-soft)!important}.entry-meta{display:flex;gap:var(--s-3);margin-top:var(--s-1);font-size:11.5px;color:var(--fg-muted);flex-wrap:wrap}.entry-image-wrap{margin-top:var(--s-2)}.entry-image{max-width:100%;border-radius:var(--r-sm);height:auto}.entry-audio-wrap{display:flex;align-items:center;gap:var(--s-3);margin-top:var(--s-2);flex-wrap:wrap}.entry-audio{height:32px}.entry-audio-link{font-size:12px;color:var(--accent)}.entry-audio-link:hover{text-decoration:underline}.entry-attachments{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--s-2)}.entry-attachment-link{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--fg-muted);padding:3px 8px;background:var(--bg-canvas);border:1px solid var(--stroke-1);border-radius:var(--r-sm)}.entry-attachment-link:hover{color:var(--accent)}.direction-progress{display:flex;align-items:center;gap:var(--s-2);margin-top:var(--s-2)}.direction-progress-bar{height:5px;border-radius:var(--r-pill);background:var(--bg-canvas);flex:1;overflow:hidden}.direction-progress-fill{height:100%;background:var(--accent);border-radius:inherit;transition:width .3s}.direction-progress-text{font-size:11px;color:var(--fg-muted);font-family:var(--font-mono);white-space:nowrap}.direction-subtitle{margin:var(--s-2) 0;font-size:15px;color:var(--accent);font-weight:600}.direction-symbol{display:inline-flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,var(--direction-icon-start, var(--bg-raised)),var(--direction-icon-end, var(--bg-surface)));color:var(--fg-strong);box-shadow:inset 0 0 0 1px #ffffff0f}.direction-symbol-token{position:relative;z-index:1;font-weight:800;letter-spacing:.04em;text-transform:uppercase;font-family:var(--font-sans);text-shadow:0 1px 0 rgba(0,0,0,.3)}.direction-header .direction-symbol,.direction-header .big-icon.direction-symbol{width:56px;height:56px;border-radius:var(--r-md);font-size:18px}.sidebar .direction-symbol{width:22px;height:22px;border-radius:6px;font-size:9px}.direction-card .direction-symbol{width:42px;height:42px;border-radius:var(--r-md);font-size:13px}.directions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--s-3)}.direction-card{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-4);text-decoration:none;color:var(--fg);transition:border-color .15s,background .15s;display:flex;flex-direction:column;gap:var(--s-2)}.direction-card:hover{border-color:var(--stroke-2);background:var(--bg-raised)}.direction-card .card-name{font-weight:600;font-size:14.5px;color:var(--fg-strong)}.direction-card .card-desc{font-size:12.5px;color:var(--fg-muted);line-height:1.45}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:var(--s-3);margin-bottom:var(--s-4)}.tile-grid-inner{padding:var(--s-3)}.tile-card{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-4);text-align:left;cursor:pointer;transition:border-color .15s,background .15s;color:var(--fg);display:grid;gap:var(--s-1);width:100%;font:inherit}.tile-card:hover{border-color:var(--stroke-2);background:var(--bg-raised)}.tile-card-title{font-size:14px;font-weight:600;color:var(--fg-strong)}.tile-card-desc{font-size:12.5px;color:var(--fg-muted);line-height:1.45}.tile-card-meta{font-size:11.5px;color:var(--fg-faint);font-family:var(--font-mono)}.tile-card-image{width:100%;border-radius:var(--r-sm)}.tile-card-image-wrap{display:flex;justify-content:center;padding:var(--s-2) 0}.dashboard-card{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-4) var(--s-5);display:grid;gap:4px}.tag-filter{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:var(--s-4)}.tag-filter-label{font-size:12px;color:var(--fg-muted);font-weight:500;white-space:nowrap}.tag-filter-btn{display:inline-flex;align-items:center;padding:5px 11px;font-size:12.5px;border-radius:var(--r-pill);color:var(--fg-muted);border:1px solid var(--stroke-1);background:var(--bg-surface);cursor:pointer;transition:all .15s;white-space:nowrap}.tag-filter-btn:hover{border-color:var(--stroke-2);color:var(--fg)}.tag-filter-btn.active{background:var(--accent-soft);border-color:#4f8ef766;color:var(--accent)}.notes-section{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-5);margin-top:var(--s-5)}.notes-label{font-weight:600;font-size:13.5px;color:var(--fg-strong);margin-bottom:var(--s-3)}.notes-controls{display:flex;gap:var(--s-2);margin-bottom:var(--s-2);flex-wrap:wrap}.notes-textarea{width:100%;padding:8px 12px;background:var(--bg-canvas);border:1px solid var(--stroke-1);border-radius:var(--r-sm);color:var(--fg);font-size:13.5px;outline:none;resize:vertical;min-height:72px;font:inherit;transition:border-color .15s;margin-bottom:var(--s-2)}.notes-textarea:focus{border-color:var(--accent)}.notes-save-btn{padding:7px 14px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;background:var(--accent);color:var(--accent-fg);cursor:pointer;transition:background .15s;border:none}.notes-save-btn:hover{background:var(--accent-strong)}.notes-list{list-style:none;padding:0;margin-top:var(--s-3);display:grid;gap:var(--s-2)}.note-item{background:var(--bg-raised);border:1px solid var(--stroke-1);border-radius:var(--r-sm);padding:var(--s-3) var(--s-4);display:grid;gap:6px}.note-item.checked{opacity:.65}.note-checkbox-wrap{display:flex;align-items:flex-start;gap:var(--s-2);font-size:13.5px;cursor:pointer}.note-meta{display:flex;align-items:center;gap:var(--s-2);font-size:11.5px;color:var(--fg-muted);flex-wrap:wrap}.note-tag{padding:1px 7px;border-radius:var(--r-pill);font-size:10.5px;font-weight:600}.note-tag.public{background:var(--accent-soft);color:var(--accent)}.note-tag.private{background:var(--bg-canvas);color:var(--fg-faint);border:1px solid var(--stroke-1)}.admin-view-switcher{display:flex;gap:2px;padding:3px;background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-sm);width:max-content;margin-bottom:var(--s-4)}.admin-view-switcher-active{background:var(--bg-raised)!important;color:var(--fg-strong)!important;box-shadow:var(--shadow-sm);border-radius:var(--r-xs)!important}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--bg-canvas)}.login-card{background:var(--bg-surface);border:1px solid var(--stroke-1);border-radius:var(--r-lg);padding:var(--s-7) var(--s-8);width:100%;max-width:400px;display:grid;gap:var(--s-5)}.direction-flag{width:28px;height:20px;border-radius:var(--r-xs);object-fit:cover}.theme-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--s-2)}.theme-choice{border-radius:var(--r-sm);height:36px;cursor:pointer;border:2px solid transparent;transition:border-color .15s}.theme-choice.active{border-color:var(--fg-strong)}.font-bigger{font-size:15.5px}.font-biggest{font-size:17.5px}.dir-head__progress-wrap{min-width:160px;width:180px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:var(--s-4);animation:fadeIn .15s ease}.modal-panel{background:var(--bg-surface);border:1px solid var(--stroke-2);border-radius:var(--r-lg);max-width:780px;width:100%;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .18s ease;box-shadow:0 24px 64px #00000080}.modal-head{display:flex;gap:var(--s-4);align-items:flex-start;padding:var(--s-5) var(--s-6);border-bottom:1px solid var(--stroke-1);flex-shrink:0}.modal-title{font-size:18px;font-weight:700;color:var(--fg-strong);line-height:1.4;letter-spacing:-.02em}.modal-meta{font-size:12px;color:var(--fg-muted);margin-top:5px}.modal-body{overflow-y:auto;padding:var(--s-5) var(--s-6);flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.entry-details{font-size:14px;line-height:1.72;color:var(--fg)}.entry-details p{margin-bottom:.6em}.entry-details--modal{font-size:15px;line-height:1.78}
