:root{--bg: #f4f6fb;--surface: #ffffff;--surface-soft: #fafbff;--ink: #1a1f2e;--ink-soft: #3a4258;--muted: #6b7388;--line: #e3e7f0;--line-soft: #eef1f7;--brand: #4f5dd1;--brand-soft: #eef0ff;--brand-ink: #ffffff;--accent: #f59f00;--ok: #1f8a4c;--ok-bg: #e7f5ec;--bad: #c0392b;--bad-bg: #fdecea;--warn: #b07a00;--warn-bg: #fff5d6;--radius: 14px;--radius-sm: 10px;--shadow-1: 0 1px 2px rgba(20, 25, 50, .04), 0 4px 16px rgba(20, 25, 50, .06);--shadow-2: 0 2px 6px rgba(20, 25, 50, .06), 0 10px 30px rgba(20, 25, 50, .08);--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5{line-height:1.2;margin:0 0 .5rem;font-weight:700;letter-spacing:-.01em}h1{font-size:1.8rem}h2{font-size:1.25rem}h3{font-size:1.05rem}h4{font-size:1rem}p{margin:.25rem 0}.muted{color:var(--muted);font-size:.9rem}.error{color:var(--bad);margin:.5rem 0}.eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;color:var(--muted);margin:0 0 .25rem;font-weight:600}.lead{color:var(--muted);margin:0 0 1.5rem}.full-center{min-height:100vh;display:grid;place-items:center;text-align:center;gap:1rem;padding:2rem}button,.primary-button{font:inherit;font-weight:600;border:0;padding:.7rem 1.2rem;border-radius:999px;background:var(--brand);color:var(--brand-ink);cursor:pointer;transition:opacity .15s ease,transform .05s ease,box-shadow .2s ease;display:inline-block;text-decoration:none;box-shadow:0 1px 2px #4f5dd133}button:hover,.primary-button:hover{opacity:.95;text-decoration:none;box-shadow:0 4px 14px #4f5dd140}button:active{transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}button.ghost{background:transparent;color:var(--ink);border:1px solid var(--line);box-shadow:none}button.ghost:hover{background:var(--line-soft)}.link-button{background:none;color:var(--brand);padding:.25rem 0;box-shadow:none;text-decoration:underline;font-weight:500}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:2rem;background:linear-gradient(135deg,var(--brand-soft),var(--bg))}.auth-card{background:var(--surface);padding:2.25rem;border-radius:var(--radius);box-shadow:var(--shadow-2);width:100%;max-width:400px}.auth-logo{display:block;max-height:64px;max-width:220px;margin:0 auto .75rem}.auth-card form{display:grid;gap:.35rem;margin-top:1rem}.auth-card label{font-size:.85rem;color:var(--muted);margin-top:.5rem;font-weight:500}.auth-card input{padding:.7rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:#fff}.auth-card input:focus{outline:2px solid var(--brand);outline-offset:1px}.auth-card button{margin-top:1.25rem;padding:.8rem;width:100%}.dashboard-layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.dashboard-sidebar{background:linear-gradient(180deg,#1a1f3a,#2a2f50);color:#fff;padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:1rem}.dashboard-sidebar .brand h1{font-size:1.05rem;margin:0;line-height:1.2}.dashboard-sidebar .brand p{font-size:.8rem;color:#ffffffa6;margin-top:.35rem}.dashboard-sidebar nav{display:flex;flex-direction:column;gap:.15rem;margin-top:1rem}.dashboard-sidebar nav a{color:#ffffffb3;padding:.55rem .8rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500}.dashboard-sidebar nav a:hover{background:#ffffff0f;color:#fff;text-decoration:none}.dashboard-sidebar nav a.active{background:#ffffff1a;color:#fff}.dashboard-sidebar .logout{margin-top:auto;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff}.dashboard-sidebar .logout:hover{background:#ffffff14}.dashboard-main{padding:2.5rem 3rem;overflow-y:auto;max-width:1500px;width:100%;margin:0 auto}.dash-header{margin-bottom:2rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2.5rem}.stat-card{background:var(--surface);padding:1.25rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-1);display:flex;flex-direction:column;gap:.35rem;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--brand)}.stat-card.steps:before{background:var(--accent)}.stat-card.badges:before{background:var(--ok)}.stat-card.streak:before{background:#ff6a35}.stat-sub{font-size:.72rem;color:var(--muted);margin-top:.15rem}.leaderboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.leaderboard-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.leaderboard-card h4{margin:0}.leaderboard-rank{font-size:.78rem;color:var(--brand);font-weight:700;background:var(--brand-soft);padding:.2rem .6rem;border-radius:999px}.leaderboard-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.leaderboard-list li{display:grid;grid-template-columns:36px 1fr auto;gap:.5rem;align-items:center;padding:.35rem .55rem;border-radius:6px;background:var(--surface-soft);font-size:.9rem}.leaderboard-list li.me{background:var(--brand-soft);color:var(--brand);font-weight:600}.leaderboard-list li.lb-gap{text-align:center;color:var(--muted);background:transparent;grid-template-columns:1fr}.lb-rank{font-weight:700;color:var(--muted)}.leaderboard-list li.me .lb-rank{color:var(--brand)}.lb-points{font-variant-numeric:tabular-nums}.stat-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-value{font-size:2.2rem;font-weight:700;color:var(--ink)}.content-band{margin-bottom:2.5rem}.section-heading{margin-bottom:1rem}.section-heading h3{margin-bottom:.15rem}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.course-card-rich{background:var(--surface);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-1);display:flex;flex-direction:column;gap:1rem;transition:transform .2s ease,box-shadow .2s ease}.course-card-rich:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.course-card-rich .lang-pill{display:inline-block;background:var(--brand-soft);color:var(--brand);padding:.15rem .55rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.08em}.course-card-rich h4{margin-top:.5rem;font-size:1.15rem}.course-action{font-weight:600;color:var(--brand);margin-top:auto}.meter{height:6px;background:var(--line);border-radius:999px;overflow:hidden;margin:.5rem 0}.meter span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),#6d7ce0);transition:width .4s ease}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.badge-card{background:var(--surface);padding:1.25rem 1rem;border-radius:var(--radius);box-shadow:var(--shadow-1);text-align:center;border:2px solid transparent;transition:transform .15s ease}.badge-card.earned{border-color:var(--accent)}.badge-card.earned .badge-icon{color:var(--accent)}.badge-card.locked{opacity:.5;filter:grayscale(.7)}.badge-icon{display:block;font-size:2rem;margin-bottom:.35rem;color:var(--muted)}.badge-card h5{margin:.25rem 0;font-size:.95rem}.badge-card p{font-size:.8rem;color:var(--muted);margin:0}.course-shell{max-width:880px;margin:0 auto;padding:2rem}.back-link{color:var(--muted);display:inline-block;margin-bottom:1rem;font-size:.9rem}.section-block{background:var(--surface);padding:1.5rem;margin-top:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-1)}.step-list{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}.step-list a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);background:var(--surface-soft);color:var(--ink)}.step-list a:hover{background:var(--brand-soft);text-decoration:none}.step-list .step-num{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--brand);color:#fff;font-size:.85rem;font-weight:600}.step-list li.done .step-num{background:var(--ok)}.step-list .step-badge{margin-left:auto;color:var(--ok);font-weight:700}.lesson-layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh;background:var(--bg)}.lesson-sidebar{background:var(--surface);border-right:1px solid var(--line);padding:1.5rem 1.25rem;overflow-y:auto;height:100vh;position:sticky;top:0}.lesson-sidebar .sidebar-brand{padding-bottom:1.25rem;border-bottom:1px solid var(--line);margin-bottom:1rem}.brand-back{font-size:.85rem;color:var(--muted);display:inline-block;margin-bottom:.75rem}.lesson-sidebar .sidebar-brand h2{font-size:1rem;margin-bottom:.75rem}.ring{position:relative;width:88px;height:88px;margin:.5rem auto}.ring svg{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--line);stroke-width:3}.ring-fg{fill:none;stroke:var(--brand);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .5s ease}.ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-weight:700;font-size:1.1rem;color:var(--ink)}.sidebar-points{text-align:center;color:var(--muted);font-size:.85rem;margin:0}.sidebar-nav{display:flex;flex-direction:column;gap:.75rem}.sidebar-section-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin:.25rem 0 .35rem;padding:0 .5rem}.sidebar-section ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.15rem}.sidebar-section li a{display:flex;align-items:center;gap:.6rem;padding:.45rem .55rem;border-radius:var(--radius-sm);color:var(--ink-soft);font-size:.88rem;font-weight:500}.sidebar-section li a:hover{background:var(--surface-soft);text-decoration:none}.sidebar-section li.current a{background:var(--brand-soft);color:var(--brand);font-weight:600}.sidebar-section li.done a{color:var(--muted)}.step-dot{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--line-soft);font-size:.75rem;font-weight:600;flex-shrink:0}.sidebar-section li.done .step-dot{background:var(--ok);color:#fff}.sidebar-section li.current .step-dot{background:var(--brand);color:#fff}.lesson-main{padding:2rem 2.5rem 3rem;max-width:1500px;width:100%}.lesson-content{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(380px,1fr);gap:1.5rem;align-items:start;margin-bottom:1.25rem}.lesson-content-left{display:flex;flex-direction:column;gap:1.25rem;min-width:0}.lesson-content-right{position:sticky;top:1rem;display:flex;flex-direction:column;gap:1rem}.lesson-content-right .card.practice{margin:0;max-height:calc(100vh - 2rem);overflow-y:auto}.lesson-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.lesson-header h1{font-size:1.8rem}.status-pill{padding:.35rem .85rem;border-radius:999px;font-size:.8rem;font-weight:600;background:var(--line-soft);color:var(--muted);flex-shrink:0}.status-pill.wait{background:var(--line-soft);color:var(--muted)}.status-pill.ok{background:var(--ok-bg);color:var(--ok)}.status-pill.bad{background:var(--bad-bg);color:var(--bad)}.lesson-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.step-media{display:flex;flex-direction:column;gap:.75rem;margin:0 0 1rem}.step-media-image{width:100%;max-width:100%;height:auto;border-radius:var(--radius-sm);background:var(--surface-soft)}.step-media-audio,.step-media-video{width:100%;border-radius:var(--radius-sm)}.card{background:var(--surface);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-1)}.card h2{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.75rem;font-weight:700}.card.example pre{background:#1a1f3a;color:#e6e8f0;padding:1rem;border-radius:var(--radius-sm);overflow-x:auto;font-family:var(--mono);font-size:.88rem;line-height:1.6;margin:0}.practice .prompt{font-size:1.05rem;color:var(--ink);margin:0 0 1rem}.choice-list{list-style:none;padding:0;margin:1rem 0;display:grid;gap:.5rem}.choice-list label{display:flex;gap:.75rem;align-items:center;padding:.85rem 1rem;background:var(--surface-soft);border:1.5px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.choice-list label:hover{border-color:var(--brand);background:var(--brand-soft)}.choice-list label.active{border-color:var(--brand);background:var(--brand-soft);box-shadow:0 0 0 3px #4f5dd126}.choice-list input[type=radio]{accent-color:var(--brand)}.choice-list code{font-family:var(--mono);font-size:.9rem}.code-editor{margin:1rem 0;border-radius:var(--radius-sm);overflow:hidden;box-shadow:0 1px 2px #0000001a}.code-editor .cm-editor{font-size:.95rem}.code-editor .cm-editor.cm-focused{outline:none}.pycode-step{display:flex;flex-direction:column;gap:.5rem}.pycode-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.pycode-output{background:#0e1525;color:#e6e8f0;padding:.85rem 1rem;border-radius:var(--radius-sm);font-family:var(--mono);font-size:.85rem;white-space:pre-wrap;word-break:break-word;margin:0;max-height:240px;overflow:auto;border-left:3px solid var(--ok)}.pycode-output.err{border-left-color:var(--bad)}.pycode-err{color:#ffb1a3;display:block}.sql-step{display:flex;flex-direction:column;gap:.5rem}.sql-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.sql-output{background:#0e1525;color:#e6e8f0;padding:.85rem 1rem;border-radius:var(--radius-sm);font-family:var(--mono);font-size:.85rem;white-space:pre-wrap;word-break:break-word;margin:0;max-height:200px;overflow:auto;border-left:3px solid var(--bad)}.sql-err{color:#ffb1a3;display:block}.sql-result{background:var(--surface-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.5rem;max-height:360px;overflow:auto}.sql-result-table{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:.85rem}.sql-result-table th,.sql-result-table td{text-align:left;padding:.35rem .65rem;border-bottom:1px solid var(--line);white-space:nowrap}.sql-result-table th{background:var(--brand-soft);color:var(--brand);font-weight:700;position:sticky;top:0}.sql-result-table tr:last-child td{border-bottom:0}.sql-rowcount{padding:.25rem .5rem 0}.fill-template{font-size:1.1rem;line-height:2;margin:1rem 0}.fill-input{display:inline-block;padding:.25rem .6rem;margin:0 .15rem;border:0;border-bottom:2px solid var(--brand);background:var(--brand-soft);font:inherit;font-family:var(--mono);font-size:.95rem;min-width:80px;border-radius:4px 4px 0 0}.fill-input:focus{outline:none;background:#fff}.reflection{margin:1rem 0}.reflection-area{width:100%;padding:1rem;border:1.5px solid var(--line);border-radius:var(--radius-sm);font:inherit;font-size:1rem;line-height:1.6;resize:vertical;background:#fff}.reflection-area:focus{outline:none;border-color:var(--brand)}.word-count{font-size:.8rem;color:var(--muted);text-align:right;margin-top:.25rem}.word-count.ok{color:var(--ok);font-weight:600}.feedback{margin:1rem 0 0;padding:1rem 1.1rem;border-radius:var(--radius-sm);border-left:4px solid}.feedback.ok{background:var(--ok-bg);border-color:var(--ok);color:var(--ok)}.feedback.bad{background:var(--bad-bg);border-color:var(--bad);color:var(--bad)}.feedback-message{font-weight:600;margin:0}.failed-checks{margin:.5rem 0 0;padding-left:1.5rem;font-size:.9rem}.failed-checks li{margin-bottom:.2rem}.hint-row{background:var(--warn-bg);color:var(--warn);padding:.5rem .75rem;border-radius:var(--radius-sm);margin-top:.5rem;font-size:.9rem}.common-mistakes{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.25rem}.common-mistakes li{background:#f59f0014;color:var(--ink);padding:.4rem .75rem;border-left:3px solid var(--accent);border-radius:var(--radius-sm);font-size:.9rem}.points-awarded{margin-top:.5rem;font-weight:700;color:var(--accent);font-size:1rem}.actions{display:flex;gap:.5rem;margin-top:1.5rem;justify-content:flex-end}.locale-toggle{display:flex;background:#ffffff14;border-radius:999px;padding:3px;margin-top:.5rem}.locale-toggle button{flex:1;background:transparent;color:#fff9;border:0;padding:.35rem .5rem;font-size:.75rem;font-weight:600;border-radius:999px;box-shadow:none}.locale-toggle button.active{background:#fff;color:var(--ink)}.locale-toggle button:hover{opacity:1}.image-step{display:flex;flex-direction:column;gap:.75rem;align-items:center}.image-wrap{position:relative;display:inline-block;border-radius:var(--radius-sm);overflow:hidden;max-width:100%}.image-wrap img{display:block;max-width:100%;height:auto;-webkit-user-select:none;user-select:none}.hotspot-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.hotspot{pointer-events:auto;cursor:pointer}.hotspot-dot{fill:#f59f0000;stroke:#fff0;stroke-width:.3;transition:all .2s ease}.hotspot-pulse{fill:#f59f0000;transition:all .2s ease}.hotspot:hover .hotspot-dot{fill:#f59f00e6}.hotspot:hover .hotspot-pulse{fill:#f59f0040}.hotspot.active .hotspot-dot{fill:#f59f00;stroke:#fff;stroke-width:.5}.hotspot.active .hotspot-pulse{fill:#f59f0059}.audio-step{display:flex;flex-direction:column;gap:1rem}.audio-player{width:100%}.transcript{background:var(--surface-soft);padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.9rem}.transcript summary{cursor:pointer;color:var(--brand);font-weight:500}.transcript p{margin-top:.35rem;color:var(--muted)}.order-list{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.5rem}.order-list li{display:flex;align-items:center;gap:.75rem;background:var(--surface-soft);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.65rem 1rem}.order-num{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;background:var(--brand);color:#fff;font-size:.85rem;font-weight:600;flex-shrink:0}.order-label{flex:1}.order-buttons{display:flex;gap:.25rem}.order-buttons button{padding:.35rem .65rem;font-size:.85rem}.match-step{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin:1rem 0}.match-col{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.match-card{display:block;width:100%;text-align:left;background:var(--surface-soft);border:2px solid var(--line);color:var(--ink);border-radius:var(--radius-sm);padding:.75rem 1rem;font-weight:500;box-shadow:none;cursor:pointer;transition:all .15s ease}.match-card:hover:not(:disabled){background:var(--brand-soft)}.match-card.pending{background:var(--brand-soft);border-color:var(--brand);box-shadow:0 0 0 3px #4f5dd126}.match-card.paired{background:#fff;opacity:.9}.match-card:disabled{opacity:.5;cursor:not-allowed}.drag-step{display:grid;grid-template-columns:220px 1fr;gap:1rem;margin:1rem 0}.drag-pool,.drag-bucket{background:var(--surface-soft);border:2px dashed var(--line);border-radius:var(--radius-sm);padding:.75rem;min-height:120px}.drag-pool ul,.drag-bucket ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.drag-buckets{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.drag-bucket h4{font-size:.9rem;margin:0 0 .5rem;color:var(--brand);text-align:center}.drag-item{background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:.45rem .75rem;cursor:grab;font-family:var(--mono);font-size:.9rem;-webkit-user-select:none;user-select:none}.drag-item:active{cursor:grabbing}.drag-item.placed{background:var(--brand-soft);border-color:var(--brand)}.drag-empty{color:var(--muted);font-size:.85rem;text-align:center;padding:.5rem}.result-shell{max-width:720px;margin:0 auto;padding:3rem 2rem;text-align:center}.certificate{background:linear-gradient(135deg,#fff,#fafbff);border:3px double var(--brand);border-radius:var(--radius);padding:3rem 2rem;box-shadow:var(--shadow-2);margin-bottom:2rem;position:relative}.certificate.passed{border-color:var(--accent)}.certificate.passed:before{content:"★";display:block;font-size:3rem;color:var(--accent);margin-bottom:.5rem}.cert-eyebrow{font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted);font-weight:600;margin:0}.cert-title{font-size:1.6rem;margin:.5rem 0;color:var(--ink)}.cert-line{color:var(--muted);font-style:italic}.cert-name{font-size:2.2rem;margin:1rem 0;color:var(--brand)}.cert-stats{display:flex;justify-content:center;gap:2.5rem;margin:1.5rem 0 .5rem}.cert-stats>div{display:flex;flex-direction:column}.cert-stats strong{font-size:1.5rem;color:var(--ink)}.cert-stats span{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.cert-foot{color:var(--muted);font-size:.85rem;margin-top:1rem}.result-band{margin-bottom:2rem;text-align:left}.result-band h3{text-align:center;margin-bottom:1rem}.result-actions{display:flex;gap:1rem;justify-content:center;align-items:center}.ghost-link{color:var(--muted);font-size:.9rem}.teacher-page{max-width:1080px;margin:0 auto;padding:2rem}.teacher-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.inline-form{display:flex;gap:.5rem;margin-bottom:1.5rem}.inline-form input{flex:1;padding:.7rem 1rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit}.inline-form input:focus{outline:2px solid var(--brand);outline-offset:1px}.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.class-card{background:var(--surface);padding:1.25rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-1);color:var(--ink);display:flex;flex-direction:column;gap:.25rem;transition:transform .15s ease}.class-card:hover{transform:translateY(-2px);text-decoration:none;box-shadow:var(--shadow-2)}.class-card h3{margin:0}.class-card .small{font-size:.8rem}.invite-card{margin-bottom:1rem}.invite-fresh{margin:.5rem 0;padding:.75rem 1rem;background:var(--brand-soft);border-radius:var(--radius-sm)}.invite-url{display:inline-block;font-family:var(--mono);font-size:.85rem;background:#fff;padding:.35rem .65rem;border-radius:6px;word-break:break-all;cursor:pointer;border:1px dashed var(--brand)}.invite-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.35rem}.invite-list li{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:.35rem 0}.invite-list code{font-family:var(--mono);font-size:.8rem;word-break:break-all}.roster{width:100%;border-collapse:collapse;margin-top:.5rem}.roster th,.roster td{text-align:left;padding:.75rem .5rem;border-bottom:1px solid var(--line);vertical-align:top}.roster th{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.roster td.num{font-variant-numeric:tabular-nums;font-weight:600}.roster .small{font-size:.8rem}.progress-cell{min-width:280px}.course-progress-row{display:grid;grid-template-columns:1fr 120px 50px;align-items:center;gap:.5rem;padding:.15rem 0}.meter.mini{height:4px;margin:0}.grading-stack{display:flex;flex-direction:column;gap:1rem}.grading-card header h3{margin:0}.reflection-quote{background:var(--surface-soft);border-left:3px solid var(--brand);padding:.75rem 1rem;margin:.75rem 0;font-style:italic;border-radius:6px;white-space:pre-wrap}.grade-comment{width:100%;padding:.75rem 1rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;resize:vertical}.role-pick{display:flex;background:var(--line-soft);border-radius:999px;padding:3px;margin:1rem 0 0}.role-pick button{flex:1;background:transparent;color:var(--muted);border:0;padding:.45rem .5rem;font-size:.85rem;font-weight:600;border-radius:999px;box-shadow:none}.role-pick button.active{background:#fff;color:var(--brand);box-shadow:0 1px 3px #00000014}.upload-drop{background:var(--surface);border:2px dashed var(--brand);border-radius:var(--radius);padding:2rem;text-align:center;margin-bottom:1.5rem}.upload-drop p{margin:0 0 .5rem;color:var(--muted)}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.asset-card{background:var(--surface);padding:.75rem;border-radius:var(--radius-sm);box-shadow:var(--shadow-1);display:flex;flex-direction:column;gap:.35rem}.asset-card img{width:100%;height:100px;object-fit:cover;border-radius:6px;background:var(--line-soft)}.asset-audio{font-size:2.5rem;text-align:center;padding:1rem 0;background:var(--surface-soft);border-radius:6px}.asset-name{font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0}.small-btn{padding:.35rem .75rem;font-size:.8rem}.branding-form{display:grid;gap:.75rem;max-width:480px;background:var(--surface);padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow-1)}.branding-form label{display:grid;gap:.25rem;font-size:.85rem;color:var(--muted)}.branding-form input{padding:.55rem .75rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit}.branding-form button{justify-self:start}.roster select{padding:.25rem .5rem;border:1px solid var(--line);border-radius:6px;font:inherit}.authoring-layout{display:grid;grid-template-columns:320px 1fr;min-height:100vh}.authoring-tree{background:var(--surface);border-right:1px solid var(--line);padding:1.25rem;overflow-y:auto;height:100vh;position:sticky;top:0}.authoring-tree header{margin:.5rem 0 1rem}.authoring-tree header h2{font-size:1.05rem;margin:0}.tree{display:flex;flex-direction:column;gap:1rem}.tree-section{background:var(--surface-soft);border-radius:var(--radius-sm);padding:.5rem .5rem .25rem}.tree-section-head{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem}.tree-section-head strong{font-size:.85rem}.tree-section ol{list-style:none;padding:0;margin:.25rem 0;display:flex;flex-direction:column;gap:.15rem}.tree-section li{display:flex;align-items:center;gap:.25rem;padding:.2rem .3rem;border-radius:6px}.tree-section li.active{background:var(--brand-soft)}.step-pick{background:transparent;border:0;padding:.3rem .4rem;display:flex;align-items:center;gap:.4rem;flex:1;text-align:left;color:var(--ink);box-shadow:none;font-size:.85rem;cursor:pointer}.step-pick:hover{background:#00000008}.kind-pill{font-family:var(--mono);font-size:.7rem;background:var(--line-soft);color:var(--muted);padding:.15rem .45rem;border-radius:999px;font-weight:600}.kind-pill.big{font-size:.85rem;padding:.25rem .65rem}.step-pick-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-controls{display:flex;gap:.15rem}.tree-controls button{padding:.15rem .4rem;font-size:.75rem}.add-bar{display:flex;gap:.25rem;padding:.25rem;margin-top:.25rem}.add-bar input,.add-bar select{flex:1;padding:.35rem .5rem;font:inherit;font-size:.85rem;border:1px solid var(--line);border-radius:6px}.authoring-main{padding:0}.authoring-split{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}.authoring-form{padding:1.5rem 2rem;overflow-y:auto;border-right:1px solid var(--line)}.authoring-preview{padding:1.5rem 2rem;overflow-y:auto;background:var(--bg);height:100vh}.step-editor-form fieldset{border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem 1.25rem;margin:0 0 1rem;display:flex;flex-direction:column;gap:.65rem}.step-editor-form legend{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:0 .5rem;font-weight:700}.step-editor-form label{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--muted)}.step-editor-form input,.step-editor-form textarea,.step-editor-form select{padding:.5rem .65rem;font:inherit;font-size:.9rem;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--ink)}.step-editor-form textarea.mono,.mono{font-family:var(--mono);font-size:.85rem}.step-editor-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.preview-frame{background:var(--surface);padding:1.25rem;border-radius:var(--radius);box-shadow:var(--shadow-1)}.preview-title{font-size:1.4rem;margin-bottom:1rem}.code-preview{background:#0e1525;color:#e6e8f0;padding:1rem;border-radius:var(--radius-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14193280;display:grid;place-items:center;z-index:100;padding:2rem}.modal-card{background:var(--surface);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow-2);max-width:720px;width:100%;max-height:85vh;display:flex;flex-direction:column}.modal-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.modal-card h2{margin:0}.modal-card textarea{width:100%;padding:1rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--mono);font-size:.85rem;resize:vertical}.authoring-actions{display:flex;gap:.35rem;margin-top:.5rem;flex-wrap:wrap}.authoring-actions button{font-size:.8rem;padding:.35rem .75rem}.dirty-banner{margin:.5rem 0 0;padding:.35rem .65rem;background:var(--warn-bg);color:var(--warn);border-radius:6px;font-size:.75rem;font-weight:600}.dirty-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);margin-left:.35rem;flex-shrink:0}.dirty-label{color:var(--accent);font-size:.8rem;font-weight:600}.section-title-btn{background:transparent;border:0;text-align:left;font:inherit;font-size:.85rem;font-weight:700;color:var(--ink);padding:.15rem .25rem;border-radius:4px;cursor:text;box-shadow:none;flex:1;overflow:hidden;text-overflow:ellipsis}.section-title-btn:hover{background:#0000000a}.inline-edit{font:inherit;font-size:.85rem;font-weight:700;padding:.15rem .35rem;border:1px solid var(--brand);border-radius:4px;flex:1;min-width:0}.empty-state{padding:4rem 2rem;text-align:center;max-width:480px;margin:0 auto}.empty-state h2{margin-bottom:.5rem}.kind-form{display:flex;flex-direction:column;gap:.85rem}.kind-form .field{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:var(--muted)}.field-with-button{display:flex;gap:.35rem}.field-with-button input{flex:1}.inner-fieldset{border:1px solid var(--line);border-radius:var(--radius-sm);padding:.75rem 1rem;margin:0;display:flex;flex-direction:column;gap:.5rem;background:var(--surface-soft)}.inner-fieldset legend{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:0 .35rem;font-weight:700}.row-pair{display:flex;gap:.35rem;align-items:center}.row-pair>input,.row-pair>select{flex:1;padding:.35rem .55rem;border:1px solid var(--line);border-radius:6px;font:inherit;font-size:.85rem}.row-pair>select{background:#fff}.row-pair-cols{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.row-num{width:22px;height:22px;display:inline-grid;place-items:center;background:var(--brand);color:#fff;border-radius:50%;font-size:.75rem;font-weight:600;flex-shrink:0}.row-label{font-size:.85rem;flex:1}.micro{font-size:.7rem;color:var(--muted);display:flex;gap:.25rem;align-items:center}.micro input{width:50px;padding:.2rem .35rem;border:1px solid var(--line);border-radius:4px;font:inherit;font-size:.75rem}.hotspot-id{font-family:var(--mono);font-size:.75rem;flex:0 0 90px}.hotspot-row{display:flex;gap:.35rem;align-items:center;padding:.25rem}.hotspot-row input[type=radio]{width:16px;height:16px}.choice-row{display:flex;gap:.35rem;align-items:center}.choice-row input[type=radio]{width:16px;height:16px;flex-shrink:0}.choice-row>input[type=text]{flex:1;padding:.35rem .55rem;border:1px solid var(--line);border-radius:6px;font:inherit;font-size:.85rem}.hotspot-preview{position:relative;border-radius:var(--radius-sm);overflow:hidden}.hotspot-preview img{width:100%;display:block}.hotspot-preview .hotspot-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.hotspot-correct{fill:var(--accent);stroke:#fff;stroke-width:.5}.hotspot-other{fill:#0000004d;stroke:#fff;stroke-width:.4}.audio-preview{width:100%}.asset-picker-modal{max-width:860px}.asset-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;margin-top:.75rem;overflow-y:auto;max-height:50vh}.asset-picker-card{background:var(--surface-soft);padding:.55rem;border-radius:var(--radius-sm);border:1.5px solid var(--line);cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:.25rem;box-shadow:none;color:var(--ink)}.asset-picker-card:hover{border-color:var(--brand)}.asset-picker-card img{width:100%;height:80px;object-fit:cover;border-radius:4px;background:var(--line-soft)}.cover-preview{max-width:100%;max-height:140px;border-radius:var(--radius-sm);align-self:flex-start}.branding-form textarea{padding:.55rem .75rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;resize:vertical}button.ghost.danger{color:var(--bad);border-color:var(--bad)}button.ghost.danger:hover{background:var(--bad-bg)}.toast-stack{position:fixed;bottom:1.5rem;right:1.5rem;z-index:200;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{background:var(--ink);color:#fff;padding:.65rem 1rem;border-radius:var(--radius-sm);box-shadow:0 8px 24px #00000040;font-size:.9rem;font-weight:500;min-width:200px;animation:toast-in .25s ease;pointer-events:auto;max-width:360px}.toast-ok{background:var(--ok)}.toast-bad{background:var(--bad)}.toast-info{background:var(--ink)}@keyframes toast-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.teacher-shell-main{max-width:1200px;width:100%}.dashboard-sidebar nav a,.dashboard-sidebar nav .active{display:block;text-decoration:none}.dash-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.crumb{font-size:.85rem;color:var(--muted);margin:0 0 .75rem}.crumb a{color:var(--muted)}.crumb a:hover{color:var(--brand)}.empty-card{background:var(--surface);border:1.5px dashed var(--line);border-radius:var(--radius);padding:2rem;text-align:center;margin:1.5rem 0}.empty-card.inset{margin:0;box-shadow:none}.empty-card h3{margin-bottom:.25rem}.empty-card p{color:var(--muted);max-width:480px;margin:.25rem auto}.game{--game-accent: var(--brand);background:linear-gradient(180deg,#1a1f3a,#2a2f50);color:#fff;border-radius:var(--radius);padding:1.5rem 1.75rem;margin:1rem 0;box-shadow:var(--shadow-2);position:relative;overflow:hidden}.game h2{color:#fff}.game .muted{color:#ffffffa6}.game .primary-button{background:var(--game-accent);color:#fff;box-shadow:0 4px 16px #4f5dd159}.game .ghost{color:#fff;border-color:#ffffff40;background:transparent}.game .ghost:hover{background:#ffffff14}.game .primary-button.big{padding:.9rem 1.5rem;font-size:1.1rem}.game .actions{justify-content:center;margin-top:1rem}.quiz-hud{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem;font-weight:600}.hud-lives{color:var(--bad);letter-spacing:.2em}.hud-progress{color:#fff9}.hud-score em{color:var(--accent);font-style:normal}.quiz-timer{height:6px;background:#ffffff14;border-radius:999px;overflow:hidden;margin-bottom:1rem}.quiz-timer span{display:block;height:100%;background:var(--game-accent);transition:width .1s linear,background-color .3s ease}.quiz-intro,.quiz-done{text-align:center;padding:2.5rem 2rem}.quiz-prompt{font-size:1.4rem;font-weight:700;margin:1rem 0;line-height:1.4}.quiz-choices{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}.quiz-choice{display:flex;gap:.75rem;align-items:center;width:100%;padding:.9rem 1rem;background:#ffffff0f;border:2px solid rgba(255,255,255,.1);color:#fff;border-radius:var(--radius-sm);text-align:left;font-size:1rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:none}.quiz-choice:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff40}.quiz-choice.picked{border-color:var(--game-accent);background:#4f5dd140}.quiz-choice.correct{background:#1f8a4c73;border-color:var(--ok);animation:pulse-ok .4s ease}.quiz-choice.wrong{background:#c0392b73;border-color:var(--bad);animation:pulse-bad .4s ease}.quiz-choice:disabled{cursor:default}.quiz-choice-letter{display:inline-grid;place-items:center;width:26px;height:26px;background:#ffffff1f;border-radius:6px;font-weight:700;font-size:.85rem;flex-shrink:0}.quiz-choice.correct .quiz-choice-letter{background:var(--ok)}.quiz-choice.wrong .quiz-choice-letter{background:var(--bad)}.quiz-feedback{margin-top:1rem;padding:1rem 1.2rem;border-radius:var(--radius-sm);display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.quiz-feedback.ok{background:#1f8a4c40;border-left:4px solid var(--ok)}.quiz-feedback.bad{background:#c0392b40;border-left:4px solid var(--bad)}.quiz-feedback p{margin:0;flex:1;min-width:200px}.quiz-stats{display:flex;justify-content:center;gap:2.5rem;margin:1.5rem 0;flex-wrap:wrap}.quiz-stats>div,.quiz-stats>span{display:flex;flex-direction:column;align-items:center;gap:.15rem}.quiz-stats strong{font-size:1.8rem;color:#fff}.quiz-stats span{font-size:.75rem;color:#ffffffa6;text-transform:uppercase;letter-spacing:.08em}@keyframes pulse-ok{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes pulse-bad{0%{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}to{transform:translate(0)}}.sort-intro,.sort-done{text-align:center;padding:2rem}.sort-pool{background:#ffffff0d;border:2px dashed rgba(255,255,255,.2);border-radius:var(--radius-sm);padding:1rem;margin:1rem 0;min-height:80px}.sort-pool ul{list-style:none;padding:0;margin:.5rem 0 0;display:flex;gap:.5rem;flex-wrap:wrap}.sort-buckets{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}.sort-bucket{background:#ffffff08;border:2px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);padding:.75rem;min-height:120px}.sort-bucket h4{margin:0 0 .5rem;font-size:.85rem;text-align:center;color:#fff}.sort-bucket ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.sort-card{background:#fff;color:var(--ink);padding:.5rem .75rem;border-radius:8px;cursor:grab;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem;-webkit-user-select:none;user-select:none}.sort-card:active{cursor:grabbing}.sort-card img{width:32px;height:32px;object-fit:cover;border-radius:4px}.sort-card.placed{background:#eef0ff}.sort-sequence{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.5rem}.sort-sequence li{display:flex;align-items:center;gap:.5rem;background:#ffffff0f;border-radius:var(--radius-sm);padding:.35rem}.sort-sequence .sort-card{flex:1}.sort-sequence .tree-controls button{color:#fff;border-color:#ffffff40;background:transparent}.sort-reveal{margin:1rem 0;text-align:left}.sort-reveal summary{cursor:pointer;color:#fffc;font-weight:600}.sort-reveal ul,.sort-reveal ol{padding-left:1.5rem;margin-top:.5rem}.sort-reveal li.ok{color:#b6f0ce}.sort-reveal li.bad{color:#ffd1cc}.game-dialogue{padding:0;background-color:#2a1f3a;background-size:cover;background-position:center;min-height:480px;display:flex;flex-direction:column;position:relative}.game-dialogue:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#1419324d,#141932d9);pointer-events:none}.dialogue-intro,.dialogue-done{display:grid;place-items:center;flex:1;padding:2rem;z-index:1}.dialogue-card-intro{background:#141932d9;padding:2rem;border-radius:var(--radius);text-align:center;max-width:480px;z-index:1}.dialogue-scoreboard{position:relative;z-index:2;align-self:flex-end;background:#ffffff26;padding:.35rem .85rem;border-radius:999px;margin:1rem 1rem 0;font-size:.85rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialogue-stage{position:relative;z-index:1;display:grid;grid-template-columns:120px 1fr;gap:1rem;align-items:end;padding:1.5rem;margin-top:auto}.dialogue-char{width:120px;height:120px;object-fit:cover;border-radius:50%;border:3px solid white;background:#ffffff1a}.dialogue-card{background:#fff;color:var(--ink);padding:1rem 1.25rem;border-radius:18px 18px 18px 4px;box-shadow:0 8px 24px #0000004d;min-height:80px}.dialogue-name{font-size:.8rem;color:var(--brand);font-weight:700;margin:0;text-transform:uppercase;letter-spacing:.08em}.dialogue-line{margin:.25rem 0 0;font-size:1.05rem;line-height:1.5;min-height:1.5em}.caret{color:var(--brand);margin-left:2px}.caret.blink{animation:blink 1s steps(2) infinite}.caret.gone{opacity:0}@keyframes blink{50%{opacity:0}}.dialogue-options{position:relative;z-index:1;padding:0 1.5rem 1.5rem;display:grid;gap:.5rem}.dialogue-option{display:flex;align-items:center;gap:.75rem;background:#fffffff2;color:var(--ink);border:2px solid rgba(255,255,255,.4);border-radius:var(--radius-sm);padding:.8rem 1rem;text-align:left;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:none}.dialogue-option:hover:not(:disabled){transform:translate(4px);border-color:var(--game-accent)}.dialogue-option:disabled{opacity:.5;cursor:not-allowed}.dialogue-opt-letter{display:inline-grid;place-items:center;width:26px;height:26px;background:var(--brand-soft);color:var(--brand);border-radius:6px;font-weight:700;font-size:.85rem;flex-shrink:0}.reveal-history{margin-top:1rem;text-align:left}.reveal-history summary{cursor:pointer;color:#fffc;font-weight:600}.reveal-history ol{padding-left:1.5rem;margin-top:.5rem;color:#ffffffd9}.reveal-history li{margin-bottom:.5rem}.reveal-history em{color:#c8d0ff}.reveal-history .my-line{padding-left:1rem;color:#fffffff2;font-style:italic}.quiz-q-card,.dialogue-node-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.quiz-q-head,.dialogue-node-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.dialogue-node-head select{padding:.25rem .5rem;border:1px solid var(--line);border-radius:6px;font:inherit;font-size:.8rem;margin-right:.35rem}.ai-modal{max-width:880px}.ai-stepper{display:flex;gap:.5rem;align-items:center;margin:.5rem 0 1rem;font-size:.85rem;color:var(--muted)}.ai-stepper button{background:transparent;color:var(--muted);border:1px solid var(--line);padding:.35rem .75rem;border-radius:999px;cursor:pointer;box-shadow:none;font-weight:500}.ai-stepper button.active{background:var(--brand-soft);color:var(--brand);border-color:var(--brand)}.ai-recipe{margin:.5rem 0 1rem;padding-left:1.5rem;color:var(--ink-soft);font-size:.9rem}.ai-recipe li{margin-bottom:.35rem}.ai-prompt-box{width:100%;padding:1rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-soft);font-family:var(--mono);font-size:.82rem;line-height:1.55;resize:vertical;white-space:pre-wrap;word-wrap:break-word}.ai-prompt-box.readonly{max-height:400px;overflow:auto;cursor:text}.ai-format-hint{background:var(--surface-soft);color:var(--muted);padding:.35rem .75rem;border-radius:6px;font-family:var(--mono);font-size:.8rem;margin:0 0 .5rem}.prompt-list{display:grid;gap:.75rem}.prompt-card{background:var(--surface);padding:1rem 1.25rem;border-radius:var(--radius);box-shadow:var(--shadow-1)}.prompt-card header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.35rem}.prompt-card header h4{margin:0}.prompt-card details{margin-top:.25rem}.prompt-card summary{cursor:pointer;color:var(--brand);font-size:.85rem}.prompt-card pre{margin-top:.5rem}.primary-button.copied{background:var(--ok)}.schema-list{display:grid;gap:.5rem}.schema-card{background:var(--surface);padding:.75rem 1rem;border-radius:var(--radius-sm);box-shadow:var(--shadow-1)}.schema-card summary{cursor:pointer;font-weight:600}.schema-card pre{margin-top:.5rem;padding:.75rem 1rem;background:var(--surface-soft);border-radius:6px;white-space:pre-wrap;font-size:.82rem;line-height:1.55}.tip-list{padding-left:1.5rem;margin:.5rem 0}.tip-list li{margin-bottom:.35rem;color:var(--ink-soft)}.sound-toggle{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.3rem .6rem;font-size:1rem;cursor:pointer;box-shadow:none}.sound-toggle:hover{background:#ffffff26}.sidebar-aside-row{display:flex;gap:.5rem;align-items:center;margin-top:auto}.sidebar-aside-row .ghost.logout{flex:1}.memory-intro,.memory-done{text-align:center;padding:2rem}.memory-grid{display:grid;gap:.5rem;margin:1rem auto;max-width:640px}.memory-card{aspect-ratio:3 / 4;perspective:800px;background:transparent;border:0;padding:0;cursor:pointer;box-shadow:none}.memory-card:disabled{cursor:default}.memory-card-inner{display:block;position:relative;width:100%;height:100%;transition:transform .35s cubic-bezier(.4,.1,.2,1);transform-style:preserve-3d}.memory-card.flipped .memory-card-inner{transform:rotateY(180deg)}.memory-back,.memory-front{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;border-radius:var(--radius-sm);font-weight:700;backface-visibility:hidden;padding:.5rem;text-align:center}.memory-back{background:linear-gradient(135deg,#2a2f50,#1a1f3a);color:#ffffff73;font-size:1.6rem;border:2px solid rgba(255,255,255,.1)}.memory-front{background:#fff;color:var(--ink);transform:rotateY(180deg);border:2px solid var(--brand-soft);font-size:.95rem;overflow:hidden}.memory-front img{max-width:100%;max-height:100%;object-fit:contain}.memory-text{font-size:.9rem}.memory-card.matched .memory-front{background:var(--ok-bg);border-color:var(--ok)}.words-intro,.words-done{text-align:center;padding:2rem}.word-answer-row{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;background:#ffffff14;border:2px dashed rgba(255,255,255,.2);border-radius:var(--radius-sm);padding:.85rem 1rem;min-height:56px;margin:1rem 0}.word-pool{display:flex;flex-wrap:wrap;gap:.4rem;padding:.25rem 0;min-height:48px}.word-token{background:#fff;color:var(--ink);border:1.5px solid var(--line);border-radius:8px;padding:.5rem .85rem;font-size:1rem;font-family:var(--mono);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;box-shadow:0 1px 2px #00000026}.word-token:hover:not(:disabled){transform:translateY(-1px)}.word-token:active:not(:disabled){transform:translateY(0)}.word-token:disabled{opacity:.55;cursor:not-allowed}.word-token.picked{background:var(--brand-soft);color:var(--brand);border-color:var(--brand)}.word-clear{padding:.4rem .65rem}.sort-card.selected,.drag-item.selected{outline:2px solid var(--accent);outline-offset:2px;box-shadow:0 0 0 4px #f59f0040}.sort-bucket.drop-target,.drag-bucket.drop-target{outline:2px dashed var(--accent);outline-offset:2px}.pair-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.65rem;display:flex;flex-direction:column;gap:.35rem}.pair-head{display:flex;justify-content:space-between;align-items:center}.pair-side{display:flex;gap:.35rem;align-items:center}.pair-side>input,.pair-side .field-with-button input{flex:1;padding:.35rem .55rem;border:1px solid var(--line);border-radius:6px;font:inherit;font-size:.85rem}.preview-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.preview-head h2{margin:0}@media (max-width: 1099px){.lesson-content{grid-template-columns:1fr}.lesson-content-right{position:static}.lesson-content-right .card.practice{max-height:none;overflow:visible}}@media (max-width: 960px){.dashboard-layout,.lesson-layout,.authoring-layout{grid-template-columns:1fr}.dashboard-sidebar,.lesson-sidebar,.authoring-tree{position:static;height:auto}.dashboard-main,.lesson-main,.authoring-main{padding:1.5rem}.stats-grid{grid-template-columns:1fr 1fr}.lesson-grid,.authoring-split{grid-template-columns:1fr}.game{padding:1rem}.quiz-prompt{font-size:1.15rem}.quiz-choice{padding:.75rem .85rem;font-size:.95rem}.quiz-stats{gap:1.25rem}.quiz-stats strong{font-size:1.4rem}.sort-buckets{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.row-pair-cols{grid-template-columns:1fr}.dialogue-stage{grid-template-columns:1fr;padding:1rem}.dialogue-char{width:88px;height:88px;margin:0 auto}.dialogue-options{padding:0 1rem 1rem}.memory-grid{gap:.35rem}.word-token{padding:.55rem .75rem;font-size:1.05rem}.preview-head{flex-direction:column;align-items:stretch}}@media (max-width: 540px){.stats-grid{grid-template-columns:1fr}.lesson-header{flex-direction:column}.quiz-stats{flex-direction:column;gap:.75rem}.quiz-hud{font-size:.82rem}.quiz-choice-letter{width:22px;height:22px;font-size:.8rem}.roster th,.roster td{padding:.5rem .25rem;font-size:.85rem}.progress-cell{min-width:0}.course-progress-row{grid-template-columns:1fr;gap:.15rem}}
