*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--surface: #ffffff;--primary: #2563eb;--primary-hover: #1d4ed8;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--error: #ef4444;--success: #22c55e;--warning: #f59e0b;--radius: 12px;--shadow: 0 2px 16px rgba(0,0,0,.08);--accent: #4f46e5;--accent-hover: #4338ca;--accent-muted: #818cf8;--accent-subtle: #c7d2fe;--card: var(--surface);--card-text: var(--text);--card-text-muted: var(--text-muted);--card-accent: var(--accent);--lp-bg: #f7f4ef;--lp-surface: #ffffff;--lp-text: #1a2744;--lp-text-muted: #4a5568;--lp-text-subtle: #64748b;--lp-accent: #c8922a;--lp-border: rgba(26, 39, 68, .1);--lp-border-subtle: rgba(26, 39, 68, .08);--lp-nav-bg: rgba(247, 244, 239, .92);--lp-nav-hover: rgba(26, 39, 68, .07);--lp-btn-bg: #1a2744;--lp-btn-bg-hover: #243460;--lp-btn-shadow: rgba(26, 39, 68, .28);--lp-btn-shadow-hover: rgba(26, 39, 68, .35);--lp-banner-bg: #1a2744;--lp-banner-text-muted: rgba(255, 255, 255, .65);--lp-img-bg: #1a2744;--lp-img-shadow: rgba(26, 39, 68, .22)}[data-palette=forest]{--accent: #10b981;--accent-hover: #059669;--accent-muted: #6ee7b7;--accent-subtle: #d1fae5}[data-palette=sunset]{--accent: #f59e0b;--accent-hover: #d97706;--accent-muted: #fbbf24;--accent-subtle: #fef3c7}[data-palette=ocean]{--accent: #06b6d4;--accent-hover: #0891b2;--accent-muted: #67e8f9;--accent-subtle: #cffafe}[data-palette=rose]{--accent: #f43f5e;--accent-hover: #e11d48;--accent-muted: #fda4af;--accent-subtle: #ffe4e6}[data-theme=dark][data-palette=midnight],[data-theme=dark]:not([data-palette]){--bg: hsl(230, 60%, 12%);--surface: hsl(230, 60%, 20%);--border: hsl(230, 60%, 28%);--text: hsl(0, 0%, 93%);--text-muted: hsl(0, 0%, 74%);--accent: hsl(15, 85%, 60%);--accent-hover: hsl(15, 85%, 50%);--card: hsl(230, 60%, 88%);--card-text: hsl(0, 0%, 7%);--card-text-muted: hsl(0, 0%, 26%);--card-accent: hsl(15, 80%, 35%)}[data-theme=light][data-palette=midnight],[data-theme=light]:not([data-palette]){--bg: hsl(230, 60%, 88%);--surface: hsl(230, 60%, 80%);--border: hsl(230, 60%, 72%);--text: hsl(0, 0%, 7%);--text-muted: hsl(0, 0%, 26%);--accent: hsl(15, 85%, 40%);--accent-hover: hsl(15, 85%, 30%);--card: hsl(230, 60%, 12%);--card-text: hsl(0, 0%, 93%);--card-text-muted: hsl(0, 0%, 74%);--card-accent: hsl(15, 85%, 60%)}[data-theme=dark][data-palette=forest]{--bg: hsl(145, 62%, 9%);--surface: hsl(145, 62%, 17%);--border: hsl(145, 62%, 25%);--text: hsl(0, 0%, 93%);--text-muted: hsl(0, 0%, 74%);--accent: hsl(38, 90%, 55%);--accent-hover: hsl(38, 90%, 45%);--card: hsl(145, 62%, 91%);--card-text: hsl(0, 0%, 7%);--card-text-muted: hsl(0, 0%, 26%);--card-accent: hsl(38, 85%, 30%)}[data-theme=light][data-palette=forest]{--bg: hsl(145, 62%, 91%);--surface: hsl(145, 62%, 83%);--border: hsl(145, 62%, 75%);--text: hsl(0, 0%, 7%);--text-muted: hsl(0, 0%, 26%);--accent: hsl(38, 90%, 38%);--accent-hover: hsl(38, 90%, 28%);--card: hsl(145, 62%, 9%);--card-text: hsl(0, 0%, 93%);--card-text-muted: hsl(0, 0%, 74%);--card-accent: hsl(38, 90%, 55%)}[data-theme=dark][data-palette=sunset]{--bg: hsl(28, 58%, 11%);--surface: hsl(28, 58%, 19%);--border: hsl(28, 58%, 27%);--text: hsl(0, 0%, 93%);--text-muted: hsl(0, 0%, 74%);--accent: hsl(350, 80%, 58%);--accent-hover: hsl(350, 80%, 48%);--card: hsl(28, 58%, 89%);--card-text: hsl(0, 0%, 7%);--card-text-muted: hsl(0, 0%, 26%);--card-accent: hsl(350, 75%, 32%)}[data-theme=light][data-palette=sunset]{--bg: hsl(28, 58%, 89%);--surface: hsl(28, 58%, 81%);--border: hsl(28, 58%, 73%);--text: hsl(0, 0%, 7%);--text-muted: hsl(0, 0%, 26%);--accent: hsl(350, 80%, 40%);--accent-hover: hsl(350, 80%, 30%);--card: hsl(28, 58%, 11%);--card-text: hsl(0, 0%, 93%);--card-text-muted: hsl(0, 0%, 74%);--card-accent: hsl(350, 80%, 58%)}[data-theme=dark][data-palette=ocean]{--bg: hsl(200, 70%, 11%);--surface: hsl(200, 70%, 19%);--border: hsl(200, 70%, 27%);--text: hsl(0, 0%, 93%);--text-muted: hsl(0, 0%, 74%);--accent: hsl(42, 90%, 52%);--accent-hover: hsl(42, 90%, 42%);--card: hsl(200, 70%, 89%);--card-text: hsl(0, 0%, 7%);--card-text-muted: hsl(0, 0%, 26%);--card-accent: hsl(42, 85%, 30%)}[data-theme=light][data-palette=ocean]{--bg: hsl(200, 70%, 89%);--surface: hsl(200, 70%, 81%);--border: hsl(200, 70%, 73%);--text: hsl(0, 0%, 7%);--text-muted: hsl(0, 0%, 26%);--accent: hsl(42, 90%, 36%);--accent-hover: hsl(42, 90%, 26%);--card: hsl(200, 70%, 11%);--card-text: hsl(0, 0%, 93%);--card-text-muted: hsl(0, 0%, 74%);--card-accent: hsl(42, 90%, 52%)}[data-theme=dark][data-palette=rose]{--bg: hsl(345, 58%, 11%);--surface: hsl(345, 58%, 19%);--border: hsl(345, 58%, 27%);--text: hsl(0, 0%, 93%);--text-muted: hsl(0, 0%, 74%);--accent: hsl(168, 68%, 48%);--accent-hover: hsl(168, 68%, 38%);--card: hsl(345, 58%, 89%);--card-text: hsl(0, 0%, 7%);--card-text-muted: hsl(0, 0%, 26%);--card-accent: hsl(168, 65%, 28%)}[data-theme=light][data-palette=rose]{--bg: hsl(345, 58%, 89%);--surface: hsl(345, 58%, 81%);--border: hsl(345, 58%, 73%);--text: hsl(0, 0%, 7%);--text-muted: hsl(0, 0%, 26%);--accent: hsl(168, 68%, 32%);--accent-hover: hsl(168, 68%, 22%);--card: hsl(345, 58%, 11%);--card-text: hsl(0, 0%, 93%);--card-text-muted: hsl(0, 0%, 74%);--card-accent: hsl(168, 68%, 48%)}[data-theme=dark]{--bg: hsl(230, 60%, 12%);--surface: hsl(230, 55%, 20%);--text: hsl(0, 0%, 92%);--text-muted: hsl(0, 0%, 78%);--border: hsl(230, 48%, 28%);--shadow: 0 2px 16px rgba(0,0,0,.3);--lp-bg: #0d1526;--lp-surface: #152238;--lp-text: #e8e4dc;--lp-text-muted: #8095b5;--lp-text-subtle: #6a82a0;--lp-accent: #d4a443;--lp-border: rgba(255, 255, 255, .08);--lp-border-subtle: rgba(255, 255, 255, .06);--lp-nav-bg: rgba(13, 21, 38, .92);--lp-nav-hover: rgba(255, 255, 255, .07);--lp-btn-bg: #c8922a;--lp-btn-bg-hover: #b07c22;--lp-btn-shadow: rgba(200, 146, 42, .35);--lp-btn-shadow-hover: rgba(200, 146, 42, .45);--lp-banner-bg: #06101f;--lp-banner-text-muted: rgba(255, 255, 255, .55);--lp-img-bg: #0a1422;--lp-img-shadow: rgba(0, 0, 0, .5)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:18px;background:var(--bg);color:var(--text);min-height:100vh}.auth-page{position:relative;display:flex;align-items:center;justify-content:center;height:100vh;overflow:hidden;padding:1rem}.auth-card{position:relative;z-index:2;background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.6);border-radius:var(--radius);box-shadow:0 8px 32px #00000038;padding:2.5rem 2rem;width:100%;max-width:400px}[data-theme=dark] .auth-card{background:#0f172ae0;border-color:#ffffff14}.auth-card h1{font-size:1.8rem;margin-bottom:.25rem}.subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem}.field input{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;outline:none;transition:border-color .15s}.field input:focus{border-color:var(--primary)}button{width:100%;padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .15s;margin-top:.5rem;font-family:inherit}button:hover:not(:disabled){background:var(--primary-hover)}button:disabled{opacity:.6;cursor:not-allowed}.error{color:var(--error);font-size:.875rem;margin:.5rem 0}.switch-link{text-align:center;margin-top:1.25rem;font-size:.875rem;color:var(--text-muted)}.switch-link a{color:var(--primary);text-decoration:none}.home-page{display:flex;flex-direction:row;align-items:stretch;min-height:100vh}.home-hero{position:sticky;top:0;flex:1;height:100vh;overflow:hidden;background:#0d0d0d;display:flex;align-items:stretch}.home-bg-image{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center center;z-index:0}.home-bg-overlay{position:absolute;inset:0;background:linear-gradient(to right,#0000000d,#00000073);z-index:1}.hero-text{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;align-self:stretch;padding:3rem;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.6)}.banner-title{font-size:3.75rem;font-weight:800;margin:0;letter-spacing:-1.5px;line-height:1.1}.banner-subtitle{font-size:1.2rem;margin:.875rem 0 0;opacity:.85;font-weight:300;letter-spacing:.01em}.home-panel{width:400px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;padding:2rem 1.75rem;box-shadow:-4px 0 24px #0000001f}.user-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.user-bar-left{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.user-email{font-weight:600;font-size:.95rem;color:var(--text)}.role-badge{display:inline-block;padding:.2rem .65rem;border-radius:99px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border:1px solid transparent}.role-badge[data-role=teacher]{background:#dbeafe;color:#1e40af;border-color:#bfdbfe}.role-badge[data-role=admin]{background:#fce7f3;color:#9d174d;border-color:#fbcfe8}.role-badge[data-role=student]{background:#dcfce7;color:#166534;border-color:#bbf7d0}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);width:auto;padding:.5rem 1rem;font-size:.875rem;margin-top:0;border-radius:8px;transition:background .15s,color .15s}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.welcome-section{margin-bottom:1.75rem}.welcome-heading{font-size:1.6rem;font-weight:700;margin:0 0 .5rem;letter-spacing:-.5px;color:var(--text)}.welcome-text{color:var(--text-muted);font-size:.95rem;line-height:1.6;margin:0}.action-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 4px #0000000f;padding:1.5rem;margin-bottom:1.25rem}.action-card-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.action-card-icon-wrap{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.action-card-icon-wrap.teacher{background:linear-gradient(135deg,#2563eb,#7c3aed)}.action-card-icon-wrap.student{background:linear-gradient(135deg,#059669,#0d9488)}.action-card-title{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.action-card-subtitle{font-size:.875rem;color:var(--text-muted);line-height:1.5}.btn-action{width:100%;padding:.8rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;margin-top:0;font-family:inherit;letter-spacing:.01em}.btn-action:hover:not(:disabled){background:var(--primary-hover)}.btn-action:active:not(:disabled){transform:translateY(1px)}.btn-action:disabled{opacity:.6;cursor:not-allowed}.session-url-box{margin-top:1.25rem;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1rem 1.125rem}.session-url-label{font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:.625rem;text-transform:uppercase;letter-spacing:.04em}.session-url-row{display:flex;align-items:center;gap:.625rem;margin-bottom:.875rem}.session-url{flex:1;font-size:.8rem;color:var(--text);word-break:break-all;background:none;line-height:1.5}.copy-btn{width:auto;padding:.4rem .875rem;font-size:.8rem;margin-top:0;background:var(--primary);border-radius:6px;white-space:nowrap;font-weight:600}.join-link{display:inline-block;color:var(--primary);font-size:.875rem;text-decoration:none;font-weight:600}.join-link:hover{text-decoration:underline}.hint{color:var(--text-muted);font-size:.9rem;margin-bottom:.5rem}.hint.small{font-size:.8rem}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.1rem;color:var(--text-muted)}.session-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.status-banner{background:#fef3c7;border-bottom:1px solid #fde68a;color:#92400e;padding:.75rem 1.5rem;text-align:center;font-size:.95rem;font-weight:500}.session-layout{display:grid;grid-template-columns:280px 1fr 280px;grid-template-rows:1fr;flex:1;min-height:0;overflow:hidden}.video-panel{background:var(--surface);display:flex;flex-direction:column;padding:1rem;gap:.75rem;overflow-y:auto}.video-remote-wrap{position:relative;background:var(--surface);border-radius:8px;overflow:hidden;aspect-ratio:4/3}.video-remote{width:100%;height:100%;object-fit:cover}.video-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:.85rem;text-align:center;padding:1rem}.video-local-wrap{border-radius:8px;overflow:hidden;aspect-ratio:4/3;background:var(--surface)}.video-local{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.teacher-controls{padding:.5rem 0}.teacher-controls .hint{color:var(--text-muted);font-size:.8rem;margin-bottom:.5rem}.control-row{display:flex;gap:.5rem;margin-bottom:.5rem}.activity-btn{flex:1;padding:.5rem;font-size:.8rem;background:var(--surface);margin-top:0;border-radius:6px}.activity-btn:hover{background:#475569}.test-btn{background:#7c3aed;font-size:.8rem;padding:.5rem;margin-top:0;border-radius:6px}.test-btn:hover{background:#6d28d9}.ack-indicator{margin-top:.5rem;padding:.375rem .75rem;border-radius:6px;font-size:.78rem;text-align:center}.ack-ok{background:#14532d;color:#86efac}.ack-waiting{background:#78350f;color:#fcd34d}.media-controls{display:flex;gap:.5rem;padding:.75rem .5rem .25rem;justify-content:center}.ctrl-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;border:none;background:var(--surface);color:var(--text);font-size:1.1rem;cursor:pointer;transition:background .15s;margin-top:0;padding:0}.ctrl-btn:hover{background:#475569}.ctrl-btn.ctrl-muted{background:var(--error)}.ctrl-btn.ctrl-muted:hover{background:#dc2626}.ctrl-btn.ctrl-end,.ctrl-btn.ctrl-leave{font-size:.75rem;border-radius:12px;width:auto;padding:0 .75rem}.ctrl-btn.ctrl-end{background:var(--error)}.ctrl-btn.ctrl-end:hover{background:#dc2626}.ctrl-btn.ctrl-leave{background:#475569}.ctrl-btn.ctrl-leave:hover{background:#64748b}.mute-overlay{position:absolute;bottom:.5rem;left:.5rem;display:flex;gap:.25rem;font-size:1rem;pointer-events:none}.activity-panel{overflow:hidden;display:flex;flex-direction:column;align-items:stretch;min-height:0}.activity-screen{flex:1;display:flex;align-items:center;justify-content:center;transition:background-color .4s ease}.activity-content{text-align:center;padding:3rem 2rem;background:#ffffff26;border-radius:var(--radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:480px}.activity-icon{font-size:4rem;margin-bottom:1rem}.activity-title{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.75rem;text-shadow:0 1px 4px rgba(0,0,0,.2)}.activity-description{color:#ffffffd9;font-size:1rem;line-height:1.6;margin-bottom:1rem}.activity-id-badge{display:inline-block;background:#fff3;color:#fff;padding:.25rem .75rem;border-radius:99px;font-size:.75rem;font-family:monospace}.activity-loading{display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.chat-panel{background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-message{display:flex;flex-direction:column;gap:.125rem}.chat-system{text-align:center;font-size:.75rem;font-style:italic;color:var(--text-muted);opacity:.7;padding:.1rem 0}.chat-sender{font-size:.75rem;font-weight:600;color:var(--text-muted)}.chat-content{background:var(--bg);padding:.5rem .75rem;border-radius:8px;font-size:.9rem;line-height:1.4;word-break:break-word}.chat-time{font-size:.7rem;color:var(--text-muted)}.chat-form{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border)}.chat-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;outline:none;font-family:inherit}.chat-input:focus{border-color:var(--primary)}.chat-send{width:auto;padding:.5rem 1rem;font-size:.9rem;margin-top:0;border-radius:8px}.theme-toggle{position:fixed;top:1rem;right:1rem;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s;z-index:1000;box-shadow:var(--shadow)}.theme-toggle:hover{background:var(--bg)}.home-footer{padding:1.5rem 0 0;text-align:center;color:var(--text-muted);font-size:.8rem;margin-top:auto;border-top:1px solid var(--border)}.home-footer p{margin:0}.lp-page{display:flex;flex-direction:column;min-height:100vh;background:var(--lp-bg);color:var(--lp-text);font-family:Nunito,system-ui,sans-serif;transition:background .2s,color .2s}.lp-nav{position:sticky;top:0;z-index:100;background:var(--lp-nav-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--lp-border);transition:background .2s,border-color .2s}.lp-nav-inner{max-width:1100px;margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}.lp-brand{display:flex;align-items:baseline;gap:.35rem}.lp-logo-jp{font-family:Cormorant Garamond,Georgia,serif;font-size:.85rem;font-style:italic;color:var(--lp-accent);letter-spacing:.04em}.lp-logo-en{font-family:Cormorant Garamond,Georgia,serif;font-size:1.3rem;font-weight:600;color:var(--lp-text);letter-spacing:-.3px}.lp-nav-links{display:flex;align-items:center;gap:.75rem}.lp-nav-ghost{color:var(--lp-text-muted);text-decoration:none;font-size:.88rem;font-weight:500;padding:.45rem .875rem;border-radius:8px;transition:background .15s,color .15s}.lp-nav-ghost:hover{background:var(--lp-nav-hover);color:var(--lp-text)}.lp-nav-btn{background:var(--lp-btn-bg);color:#fff;text-decoration:none;font-size:.88rem;font-weight:700;padding:.5rem 1.125rem;border-radius:8px;transition:background .15s,box-shadow .15s;box-shadow:0 2px 8px var(--lp-btn-shadow)}.lp-nav-btn:hover{background:var(--lp-btn-bg-hover);box-shadow:0 4px 12px var(--lp-btn-shadow-hover)}.lp-btn-primary{display:inline-flex;align-items:center;justify-content:center;background:var(--lp-btn-bg);color:#fff;text-decoration:none;font-family:Nunito,system-ui,sans-serif;font-size:.95rem;font-weight:700;padding:.8rem 1.75rem;border-radius:10px;box-shadow:0 4px 16px var(--lp-btn-shadow);transition:background .15s,box-shadow .15s,transform .1s;letter-spacing:.01em}.lp-btn-primary:hover{background:var(--lp-btn-bg-hover);box-shadow:0 6px 20px var(--lp-btn-shadow-hover);transform:translateY(-1px)}.lp-btn-primary.large{padding:1rem 2.25rem;font-size:1.05rem}.lp-btn-secondary{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--lp-text);text-decoration:none;font-family:Nunito,system-ui,sans-serif;font-size:.95rem;font-weight:600;padding:.8rem 1.75rem;border-radius:10px;border:1.5px solid var(--lp-border);transition:background .15s,border-color .15s,transform .1s}.lp-btn-secondary:hover{background:var(--lp-nav-hover);border-color:var(--lp-text-muted);transform:translateY(-1px)}.lp-hero{position:relative;background:var(--lp-bg);padding:5rem 2rem 0;overflow:hidden}.lp-hero:before{content:"";position:absolute;top:-80px;right:-80px;width:480px;height:480px;background:radial-gradient(circle,rgba(200,146,42,.12) 0%,transparent 68%);pointer-events:none}.lp-hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 400px;gap:4rem;align-items:center;padding-bottom:4rem}.lp-hero-text{display:flex;flex-direction:column;gap:.9rem}.lp-eyebrow-jp{font-family:Cormorant Garamond,Georgia,serif;font-size:1.1rem;font-style:italic;color:var(--lp-accent);letter-spacing:.03em;margin:0;animation:lp-fade-up .6s ease both}.lp-eyebrow-en{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--lp-text-muted);margin:0;animation:lp-fade-up .6s ease .06s both}.lp-headline{font-family:Cormorant Garamond,Georgia,serif;font-size:3.8rem;font-weight:600;line-height:1.1;color:var(--lp-text);margin:.25rem 0;animation:lp-fade-up .7s ease .12s both}.lp-headline em{font-style:italic;color:var(--lp-accent)}.lp-subline-jp{font-family:Cormorant Garamond,Georgia,serif;font-size:1rem;font-style:italic;color:var(--lp-text-muted);line-height:1.6;margin:0;animation:lp-fade-up .7s ease .17s both}.lp-subline-en{font-size:1rem;color:var(--lp-text-muted);line-height:1.7;margin:0;max-width:48ch;animation:lp-fade-up .7s ease .22s both}.lp-hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem;animation:lp-fade-up .7s ease .3s both}.lp-hero-photo-wrap{position:relative;animation:lp-fade-up .9s ease .18s both}.lp-hero-photo-deco{position:absolute;inset:-12px -12px 12px 12px;background:var(--lp-accent);opacity:.1;border-radius:20px}.lp-hero-photo{position:relative;width:100%;border-radius:16px;display:block;box-shadow:0 24px 60px var(--lp-img-shadow);object-fit:cover;aspect-ratio:4/5}.lp-hero-badge{position:absolute;bottom:-16px;left:-20px;background:var(--lp-surface);border:1px solid var(--lp-border);border-radius:12px;padding:.7rem 1rem;display:flex;align-items:center;gap:.6rem;box-shadow:0 8px 24px #1a27441f}.lp-badge-icon{font-size:1.4rem;line-height:1}.lp-hero-badge strong{display:block;font-size:.8rem;font-weight:700;color:var(--lp-text);line-height:1.2}.lp-hero-badge span{display:block;font-size:.72rem;color:var(--lp-text-muted)}.lp-hero-wave{line-height:0;margin-top:-1px}.lp-hero-wave svg{width:100%;height:70px}.lp-section-inner{max-width:1100px;margin:0 auto;padding:0 2rem}.lp-section-header{text-align:center;margin-bottom:3.5rem}.lp-section-eyebrow{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--lp-accent);margin-bottom:.5rem}.lp-section-title{font-family:Cormorant Garamond,Georgia,serif;font-size:2.4rem;font-weight:600;color:var(--lp-text);line-height:1.15;margin-bottom:.75rem}.lp-section-sub{font-size:.98rem;color:var(--lp-text-muted);max-width:540px;margin:0 auto;line-height:1.65}.lp-animate{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.lp-visible{opacity:1;transform:none}.lp-paths{background:var(--lp-surface);padding:5rem 2rem}.lp-paths-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.lp-path-card{border-radius:20px;padding:2.25rem 2rem;display:flex;flex-direction:column;gap:1.1rem;border:1px solid var(--lp-border);transition:transform .22s,box-shadow .22s}.lp-path-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px #1a27441a}.lp-path-solo{background:#fef9f0}[data-theme=dark] .lp-path-solo{background:#c8922a0f}.lp-path-live{background:#f0f4fc}[data-theme=dark] .lp-path-live{background:#1a274a66}.lp-path-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--lp-surface);border:1px solid var(--lp-border);color:var(--lp-text)}.lp-path-jp{font-family:Cormorant Garamond,Georgia,serif;font-size:.88rem;font-style:italic;color:var(--lp-accent);letter-spacing:.04em}.lp-path-title{font-family:Cormorant Garamond,Georgia,serif;font-size:1.65rem;font-weight:600;color:var(--lp-text);line-height:1.2}.lp-path-desc{font-size:.9rem;color:var(--lp-text-muted);line-height:1.65}.lp-path-features{list-style:none;display:flex;flex-direction:column;gap:.55rem;flex:1}.lp-path-features li{font-size:.875rem;color:var(--lp-text-muted);display:flex;align-items:center;gap:.5rem}.lp-check{font-size:.8rem;color:var(--lp-accent);flex-shrink:0;font-weight:700}.lp-check.lp-soon{opacity:.45}.lp-coming-soon{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--lp-accent);background:#c8922a1f;border-radius:4px;padding:1px 6px;margin-left:4px;white-space:nowrap}.lp-path-btn{display:inline-flex;align-items:center;text-decoration:none;font-family:Nunito,system-ui,sans-serif;font-size:.875rem;font-weight:700;padding:.7rem 1.4rem;border-radius:10px;transition:background .15s,box-shadow .15s;align-self:flex-start;letter-spacing:.01em}.lp-path-btn-solo{background:var(--lp-accent);color:#fff;box-shadow:0 4px 14px #c8922a47}.lp-path-btn-solo:hover{background:#b07820;box-shadow:0 6px 18px #c8922a61}.lp-path-btn-live{background:var(--lp-btn-bg);color:#fff;box-shadow:0 4px 14px var(--lp-btn-shadow)}.lp-path-btn-live:hover{background:var(--lp-btn-bg-hover);box-shadow:0 6px 18px var(--lp-btn-shadow-hover)}.lp-journey{background:var(--lp-bg);padding:5rem 2rem}.lp-journey-steps{display:flex;align-items:flex-start;overflow-x:auto;padding-bottom:.5rem;gap:0}.lp-journey-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;min-width:160px;flex:1;padding:0 .5rem}.lp-journey-dot{width:16px;height:16px;border-radius:50%;border:2.5px solid var(--lp-border);background:var(--lp-surface);flex-shrink:0;transition:background .2s,border-color .2s}.lp-journey-active .lp-journey-dot{background:var(--lp-accent);border-color:var(--lp-accent);box-shadow:0 0 0 4px #c8922a2e}.lp-journey-connector{width:48px;height:2px;background:var(--lp-border);flex-shrink:0;margin-top:7px}.lp-journey-content h4{font-family:Cormorant Garamond,Georgia,serif;font-size:1.1rem;font-weight:600;color:var(--lp-text);margin-bottom:.3rem}.lp-journey-content p{font-size:.8rem;color:var(--lp-text-muted);line-height:1.5;margin-bottom:.4rem}.lp-journey-status{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:2px 8px;border-radius:4px}.lp-journey-status.available{background:#16a34a1f;color:#16a34a}.lp-journey-status.coming{background:#c8922a1f;color:var(--lp-accent)}.lp-how{background:var(--lp-surface);padding:5rem 2rem}.lp-how-steps{display:flex;align-items:flex-start;gap:1rem;justify-content:center;flex-wrap:wrap}.lp-how-step{flex:1;min-width:180px;max-width:280px;display:flex;flex-direction:column;gap:.5rem}.lp-how-num{font-family:Cormorant Garamond,Georgia,serif;font-size:2.75rem;font-weight:300;color:var(--lp-accent);line-height:1;opacity:.5}.lp-how-step h4{font-family:Cormorant Garamond,Georgia,serif;font-size:1.2rem;font-weight:600;color:var(--lp-text)}.lp-how-step p{font-size:.875rem;color:var(--lp-text-muted);line-height:1.6}.lp-how-arrow{font-size:1.4rem;color:var(--lp-border);flex-shrink:0;margin-top:1rem}.lp-cta-banner{background:var(--lp-banner-bg);padding:5rem 2rem;position:relative;overflow:hidden}.lp-cta-banner:before{content:"";position:absolute;top:-40%;right:-5%;width:420px;height:420px;background:radial-gradient(circle,rgba(200,146,42,.14) 0%,transparent 65%);pointer-events:none}.lp-cta-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:2.5rem;flex-wrap:wrap}.lp-cta-jp{font-family:Cormorant Garamond,Georgia,serif;font-style:italic;font-size:.95rem;color:var(--lp-accent);margin-bottom:.25rem}.lp-cta-title{font-family:Cormorant Garamond,Georgia,serif;font-size:2.2rem;font-weight:600;color:#fff;margin-bottom:.5rem;line-height:1.15}.lp-cta-sub{font-size:.92rem;color:var(--lp-banner-text-muted)}.lp-cta-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;flex-shrink:0}.lp-cta-signin{font-size:.83rem;color:var(--lp-banner-text-muted);text-decoration:none;transition:color .15s}.lp-cta-signin:hover{color:#fff}.lp-footer{background:var(--lp-bg);border-top:1px solid var(--lp-border);padding:2.5rem 2rem}.lp-footer-inner{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}.lp-footer-tagline{font-family:Cormorant Garamond,Georgia,serif;font-style:italic;font-size:.83rem;color:var(--lp-text-subtle);margin-top:.2rem}.lp-footer-links{display:flex;gap:1.5rem}.lp-footer-links a{font-size:.83rem;color:var(--lp-text-subtle);text-decoration:none;transition:color .15s}.lp-footer-links a:hover{color:var(--lp-text);text-decoration:underline}.lp-footer-copy{font-size:.78rem;color:var(--lp-text-subtle);width:100%;text-align:center;padding-top:1.25rem;border-top:1px solid var(--lp-border-subtle);margin-top:.5rem}@keyframes lp-fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}.admin-page{min-height:100vh;background:var(--bg);color:var(--text)}.admin-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1.5rem 2rem}.admin-back-link{color:var(--primary);text-decoration:none;font-size:.875rem;font-weight:500;display:inline-block;margin-bottom:.75rem}.admin-back-link:hover{text-decoration:underline}.admin-title{font-size:1.75rem;font-weight:800;margin:0 0 .25rem;letter-spacing:-.5px}.admin-subtitle{color:var(--text-muted);font-size:.95rem;margin:0}.admin-content{padding:2rem;max-width:1100px;margin:0 auto}.admin-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{text-align:left;padding:.875rem 1rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg)}.admin-table td{padding:.875rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg)}.admin-td-email{font-weight:500}.admin-td-date{color:var(--text-muted);font-size:.85rem}.admin-role-select{padding:.3rem .6rem;border:1px solid var(--border);border-radius:6px;font-size:.85rem;background:var(--bg);color:var(--text);cursor:pointer;font-family:inherit}.admin-flag{display:inline-block;padding:.2rem .6rem;border-radius:99px;font-size:.75rem;font-weight:700}.admin-flag-yes{background:#fef3c7;color:#92400e}.admin-flag-no{background:#dcfce7;color:#166534}.admin-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.admin-reset-btn{width:auto;padding:.35rem .875rem;font-size:.8rem;margin-top:0;background:var(--error, #dc2626);color:#fff;border:none;border-radius:6px;cursor:pointer;font-family:inherit;font-weight:600}.admin-reset-btn:hover{filter:brightness(.9)}.admin-delete-btn{width:auto;padding:.35rem .875rem;font-size:.8rem;margin-top:0;background:#7f1d1d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-family:inherit;font-weight:600}.admin-delete-btn:hover{background:#991b1b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-card{background:var(--surface);border-radius:var(--radius);box-shadow:0 16px 48px #0000004d;padding:2rem;width:100%;max-width:420px}.modal-title{font-size:1.4rem;font-weight:700;margin:0 0 .5rem}.modal-subtitle{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin:0 0 1.5rem}.modal-actions{display:flex;gap:.75rem;margin-top:1rem}.modal-actions .btn-ghost,.modal-actions button[type=submit]{flex:1;margin-top:0}@media(max-width:1024px){.home-panel{width:360px}.session-layout{grid-template-columns:240px 1fr 240px}.lp-hero-inner{grid-template-columns:1fr;gap:2.5rem}.lp-hero-photo-wrap{max-width:380px;margin:0 auto}.lp-headline{font-size:2.8rem}.lp-paths-grid{grid-template-columns:1fr}}.chat-toggle-btn,.chat-panel-header,.hamburger-btn,.mobile-menu-drawer{display:none}@media(max-width:640px){.auth-page{height:100dvh;align-items:flex-start;padding-top:2.5rem;overflow-y:auto}.auth-card{padding:2rem 1.25rem}.home-page{flex-direction:column}.home-hero{position:relative;height:220px;flex:none}.hero-text{padding:1.5rem}.banner-title{font-size:2.25rem}.banner-subtitle{font-size:1rem;margin-top:.5rem}.home-panel{width:100%;flex:1;border-left:none;border-top:1px solid var(--border);box-shadow:none;padding:1.5rem 1rem}.theme-toggle{width:36px;height:36px;font-size:1rem}body.session-active .theme-toggle{display:none}.session-page{height:100dvh;overflow:hidden;position:relative}.session-layout{display:flex;flex-direction:column;width:100%;height:100dvh;overflow:hidden}.video-panel{flex-shrink:0;flex-direction:row;align-items:center;height:64px;padding:0 .75rem;gap:.5rem;overflow:visible}.video-remote-wrap{flex-shrink:0;width:56px;aspect-ratio:4/3;border-radius:6px;box-shadow:none}.video-placeholder,.video-local-wrap,.teacher-controls,.media-controls{display:none}.chat-toggle-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:52px;height:44px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1.25rem;gap:.1rem;cursor:pointer}.chat-toggle-btn span{font-size:.6rem;color:var(--text-muted);letter-spacing:.02em}.hamburger-btn{display:flex;align-items:center;justify-content:center;margin-left:auto;width:44px;height:44px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1.4rem;cursor:pointer}.activity-panel{flex:1;min-height:0;overflow:hidden;min-height:unset}.chat-panel{position:fixed;bottom:0;left:0;right:0;height:65dvh;z-index:20;border-left:none;border-top:none;border-radius:16px 16px 0 0;box-shadow:0 -4px 24px #00000059;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.chat-panel.chat-open{transform:translateY(0)}.chat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem .5rem;border-bottom:1px solid var(--border);flex-shrink:0;font-weight:600;font-size:.95rem}.chat-close-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:var(--bg);border:1px solid var(--border);font-size:.9rem;cursor:pointer;color:var(--text-muted)}.mobile-menu-drawer{display:block;position:fixed;top:64px;left:0;right:0;z-index:30;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 4px 20px #0003;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease}.mobile-menu-drawer.menu-open{opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-menu-content{padding:.5rem 0}.mobile-menu-item{display:flex;align-items:center;width:100%;gap:.75rem;padding:.85rem 1.25rem;background:transparent;border:none;color:var(--text);font-size:1rem;cursor:pointer;text-align:left}.mobile-menu-item:active{background:var(--border)}.mobile-menu-item.mobile-menu-danger{color:var(--error)}.menu-item-icon{font-size:1.25rem;width:1.75rem;text-align:center;flex-shrink:0}.mobile-menu-divider{height:1px;background:var(--border);margin:.25rem 0}.mobile-menu-label{padding:.35rem 1.25rem .15rem;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.mobile-backdrop{position:fixed;inset:0;z-index:25;background:#0000004d}.lp-nav-inner{padding:0 1rem}.lp-nav-ghost{display:none}.lp-hero{padding:3rem 1rem 0}.lp-hero-inner{grid-template-columns:1fr;gap:2rem;padding-bottom:2rem}.lp-headline{font-size:2.4rem}.lp-hero-photo-wrap{max-width:320px;margin:0 auto}.lp-hero-badge{left:-8px}.lp-paths{padding:3rem 1rem}.lp-paths-grid{grid-template-columns:1fr}.lp-journey{padding:3rem 1rem}.lp-journey-step{min-width:130px}.lp-how{padding:3rem 1rem}.lp-how-steps{flex-direction:column;align-items:flex-start}.lp-how-arrow{transform:rotate(90deg)}.lp-cta-banner{padding:3rem 1rem}.lp-cta-banner-inner{flex-direction:column;align-items:flex-start;gap:1.5rem}.lp-cta-title{font-size:1.8rem}.lp-cta-actions{align-items:flex-start}.lp-footer-inner{flex-direction:column;align-items:flex-start;gap:1rem}.admin-header{padding:1.25rem 1rem}.admin-content{padding:1rem}.admin-title{font-size:1.4rem}}.spelling-drill{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg);color:#fff;padding:1rem;box-sizing:border-box;position:relative;overflow:hidden}.drill-waiting{flex:1;display:flex;align-items:center;justify-content:center}.drill-waiting-text{font-size:1.1rem;opacity:.5;font-style:italic}.drill-setup{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;text-align:center}.drill-setup-title{font-size:2rem;font-weight:800;margin:0}.drill-setup-sub{font-size:1.1rem;opacity:.7;margin:0}.drill-setup-presets{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.drill-preset-btn{width:72px;height:72px;border-radius:12px;border:2px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;font-size:1.5rem;font-weight:800;cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit}.drill-preset-btn:hover{background:#ffffff2e;border-color:#ffffff80}.drill-preset-btn-disabled{opacity:.3;cursor:not-allowed}.drill-setup-custom{display:flex;align-items:center;gap:.75rem;font-size:.9rem;opacity:.8}.drill-setup-custom input{width:64px;padding:.4rem .5rem;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:#ffffff14;color:#fff;font-family:inherit;font-size:1rem;text-align:center}.drill-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem;opacity:.8}.drill-round{font-weight:700;font-size:1rem}.drill-play-area{display:flex;flex:1;gap:.75rem;align-items:center;justify-content:center;min-height:0}.drill-pile{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:110px;flex-shrink:0}.pile-stacks-wrap{position:relative;width:90px;height:140px;flex-shrink:0}.pile-layer{position:absolute;left:0;right:0;bottom:calc((var(--total-layers, 1) - 1 - var(--layer-idx, 0)) * 14px);z-index:calc(var(--layer-idx, 0) + 1)}.pile-top-card{width:90px;height:64px;background:#fff;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;box-shadow:2px 3px #ffffff8c,4px 6px #ffffff59,0 8px 20px #0006}.drill-pile-incorrect .pile-top-card{border-top:3px solid #ef4444}.drill-pile-correct .pile-top-card{border-top:3px solid #22c55e}.pile-word{font-size:.85rem;font-weight:800;color:#1e1b4b;text-align:center;padding:0 4px;word-break:break-all;line-height:1.1}.pile-n{font-size:.65rem;color:#6b7280;font-weight:600}.pile-empty{color:#ffffff40;font-size:1.5rem;text-align:center;line-height:64px}.pile-label{font-size:.75rem;font-weight:600;opacity:.6}.drill-deck-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-width:0}.drill-card-flier{position:relative;width:200px;height:140px;border-radius:12px;transition:transform .4s ease,opacity .4s ease}.drill-card-flier.fly-right{transform:translate(240px) rotate(12deg);opacity:0}.drill-card-flier.fly-left{transform:translate(-240px) rotate(-12deg);opacity:0}.card-front{width:100%;height:100%;border-radius:12px;background:#fff;color:#1e1b4b;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #0006;transition:background .2s,border .2s}.card-front.verdict-correct{background:#dcfce7;border:3px solid #16a34a;box-shadow:0 0 0 4px #16a34a40,0 8px 32px #0006}.card-front.verdict-incorrect{background:#fee2e2;border:3px solid #dc2626;box-shadow:0 0 0 4px #dc262640,0 8px 32px #0006}.card-back-overlay{position:absolute;inset:0;border-radius:12px;background:linear-gradient(135deg,#4338ca,#7c3aed);display:flex;align-items:center;justify-content:center;transition:opacity .35s ease;box-shadow:0 8px 32px #0006}.card-back-overlay.card-back-hidden{opacity:0;pointer-events:none}.card-word{font-size:2rem;font-weight:800;letter-spacing:.05em}.card-back-symbol{font-size:3rem;font-weight:900;color:#ffffff59}.deck-empty{font-size:1.2rem;opacity:.5}.drill-key-hint{font-size:.75rem;opacity:.6;text-align:center}.drill-key-hint-dim{opacity:.25}.drill-key-hint kbd{background:#ffffff26;border-radius:4px;padding:.1rem .4rem;font-family:inherit}.drill-student-hint{font-size:.85rem;opacity:.65;text-align:center;font-style:italic;min-height:1.3em}.drill-btn-row{display:flex;gap:1rem;justify-content:center;padding:.75rem 0 0}.drill-btn{padding:.6rem 1.5rem;border:none;border-radius:8px;font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;transition:filter .15s}.drill-btn:hover{filter:brightness(1.1)}.drill-btn-correct{background:#16a34a;color:#fff}.drill-btn-incorrect{background:#dc2626;color:#fff}.drill-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10}.drill-overlay-card{background:var(--bg);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:2rem;max-width:420px;width:90%;text-align:center;display:flex;flex-direction:column;gap:1rem}.drill-overlay-card h2{font-size:1.5rem;margin:0}.drill-history{display:flex;flex-direction:column;gap:.4rem;text-align:left;font-size:.85rem;opacity:.8}.drill-history-row{display:flex;justify-content:space-between;gap:1rem;padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.08)}.practice-page{display:flex;flex-direction:column;height:100dvh;overflow:hidden;background:var(--bg)}.practice-header{display:flex;align-items:center;height:64px;padding:0 1.5rem;gap:1rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.practice-back-btn{background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.5rem 1rem;font-size:1rem;cursor:pointer;transition:background .15s}.practice-back-btn:hover{background:var(--border)}.practice-title{color:var(--text);font-weight:700;font-size:1.2rem}.practice-picker{display:flex;flex-direction:column;gap:1rem;padding:2rem 1.5rem;max-width:420px;margin:0 auto;width:100%}.practice-pick-btn{display:flex;flex-direction:column;gap:.25rem;padding:1.2rem 1.4rem;background:var(--card);border:1px solid var(--border);border-radius:14px;cursor:pointer;text-align:left;color:var(--card-text);transition:background .15s,border-color .15s}.practice-pick-btn:hover{border-color:var(--accent)}.practice-pick-icon{font-size:2rem;margin-bottom:.4rem}.practice-pick-name{font-size:1.25rem;font-weight:700;color:var(--card-accent)}.practice-pick-sub{font-size:1rem;color:var(--card-text-muted)}.solo-spell{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg);color:#fff;padding:1.5rem 1rem;box-sizing:border-box}.solo-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.solo-setup{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2rem;max-width:480px;margin:0 auto;width:100%;overflow-y:auto;padding-top:2rem;padding-bottom:2rem}.solo-setup-title{font-size:1.75rem;font-weight:700;color:var(--text);text-align:center}.solo-setup-section{width:100%;display:flex;flex-direction:column;gap:.75rem}.solo-setup-label{font-size:.85rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);text-align:center}.solo-setup-row{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}.solo-preset-btn{width:auto;min-width:56px;padding:.55rem 1rem;border-radius:10px;border:2px solid rgba(255,255,255,.1);background:#00000040;color:#475569;font-size:1.05rem;font-weight:700;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.solo-preset-btn:hover{border-color:#ffffff40;background:#ffffff0f;color:var(--text-muted)}.solo-preset-btn.solo-selected{background:var(--accent);border-color:var(--accent);color:#fff}.solo-preset-btn.solo-disabled{opacity:.3;cursor:not-allowed}.solo-diff-btn{width:auto;flex:1;display:flex;flex-direction:column;align-items:center;padding:.7rem .6rem;border-radius:10px;border:2px solid rgba(255,255,255,.1);background:#00000040;color:#475569;cursor:pointer;transition:border-color .15s,background .15s,color .15s;gap:.15rem}.solo-diff-btn:hover{border-color:#ffffff40;background:#ffffff0f;color:var(--text-muted)}.solo-diff-btn.solo-selected{background:var(--accent);border-color:var(--accent);color:#fff}.solo-diff-name{font-size:.9rem;font-weight:700}.solo-diff-sub{font-size:.68rem;color:var(--text-muted)}.solo-diff-btn.solo-selected .solo-diff-sub{color:#ffffffa6}.solo-start-btn{padding:.8rem 2.5rem;border-radius:12px;border:none;background:var(--accent);color:#fff;font-size:1.1rem;font-weight:700;cursor:pointer;transition:background .15s}.solo-start-btn:hover{background:var(--accent-hover)}.solo-start-btn.solo-disabled{background:#374151;color:#6b7280;cursor:not-allowed}.solo-play-area{flex:1;display:flex;flex-direction:column;gap:1rem;min-height:0}.solo-word-display{display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap;padding:.5rem 0}.solo-lb{min-width:2.8rem;height:3.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:2.8rem;font-weight:800;letter-spacing:.02em;transition:background .2s;border:2px solid transparent;background:transparent}.solo-lb-pending,.solo-lb-current{background:transparent;border-color:transparent}.solo-lb-correct{background:#16a34a4d;border-color:#16a34a;color:#86efac}.solo-lb-wrong{background:#dc26264d;border-color:#dc2626;color:#fca5a5}@keyframes solo-pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.solo-lb-pop{animation:solo-pop .3s cubic-bezier(.34,1.56,.64,1)}.solo-game-row{flex:1;display:flex;min-height:0;gap:.5rem}.solo-side-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:transparent;border:none;border-radius:16px;cursor:pointer;padding:.5rem .25rem;gap:.35rem;transition:background .15s;min-height:0}.solo-side-btn:active{background:transparent}.solo-tap-correct{background:#16a34a40!important;border-color:#16a34a!important}.solo-tap-wrong{background:#dc262640!important;border-color:#dc2626!important}.solo-letter-chip{width:3.5rem;height:3.5rem;border-radius:10px;background:transparent;border:none;display:flex;align-items:center;justify-content:center;font-size:2.8rem;font-weight:800;color:var(--text);pointer-events:none}.solo-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;width:72px;flex-shrink:0}.solo-speaker-btn{width:52px;height:52px;border-radius:50%;background:#ffffff14;border:1.5px solid rgba(255,255,255,.2);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:2}.solo-speaker-btn:hover{background:#ffffff26}.solo-progress{font-size:.75rem;color:#64748b;font-weight:600;text-align:center}.solo-complete{flex:1;display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem 0;overflow-y:auto}.solo-complete-title{font-size:2rem;font-weight:800}.solo-complete-stats{display:flex;gap:2rem}.solo-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.solo-stat-num{font-size:2.5rem;font-weight:800;color:var(--accent-muted)}.solo-stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.solo-word-list{width:100%;max-width:320px;display:flex;flex-direction:column;gap:.4rem}.solo-word-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#ffffff0d;border-radius:8px;border-left:3px solid #dc2626}.solo-word-row.solo-word-perfect{border-left-color:#16a34a}.solo-word-name{font-weight:600;font-size:1rem}.solo-word-score{font-size:.85rem;color:var(--text-muted)}.st-wrap{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg);color:#fff;padding:1.5rem 1rem;box-sizing:border-box}.st-setup{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:480px;margin:0 auto;width:100%}.st-setup-title{font-size:1.6rem;font-weight:700;color:var(--text)}.st-setup-desc{font-size:.9rem;color:var(--text-muted);text-align:center;margin-top:-.75rem}.st-setup-section{width:100%;display:flex;flex-direction:column;gap:.6rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1rem}.st-setup-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#64748b}.st-setup-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:stretch}.st-tag-btn{width:auto;padding:.45rem 1.1rem;border-radius:9999px;border:2px solid rgba(255,255,255,.1);background:#00000040;color:#475569;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.st-tag-btn:hover{border-color:#ffffff40;background:#ffffff0f;color:var(--text-muted)}.st-tag-btn.st-selected{background:var(--accent);border-color:var(--accent);color:#fff}.st-play{display:flex;flex-direction:column;align-items:center;gap:1rem;flex:1}.st-play-header{display:flex;justify-content:space-between;width:100%;max-width:460px;font-size:.82rem;color:var(--text-muted)}.st-progress{font-weight:700;color:var(--accent-subtle)}.st-stroke-counter{color:#a5b4fc}.st-debug-btn{padding:.2rem .6rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:background .15s,color .15s}.st-debug-btn:hover{background:#ffffff12}.st-debug-btn.st-debug-on{background:#facc1526;border-color:#facc15;color:#facc15}.st-canvas-wrap{position:relative;width:min(100%,440px);aspect-ratio:1;border-radius:18px;overflow:hidden;background:#13113a;box-shadow:0 8px 40px #00000073;touch-action:none}.st-canvas{display:block;width:100%;height:100%;cursor:crosshair;transition:box-shadow .2s}.st-canvas.st-canvas-correct{box-shadow:inset 0 0 0 4px #22c55eb3}.st-canvas.st-canvas-wrong{box-shadow:inset 0 0 0 4px #ef4444b3}.st-feedback-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:900;pointer-events:none;animation:st-flash .45s ease forwards}.st-feedback-overlay.correct{color:#22c55ed9}.st-feedback-overlay.wrong{color:#ef4444bf}@keyframes st-flash{0%{opacity:0;transform:scale(.6)}30%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1.3)}}.st-teacher-gate{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#13113ad1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.st-teacher-gate p{font-size:1rem;color:var(--accent-subtle)}.st-teacher-next-btn{padding:.6rem 1.6rem;background:var(--accent);color:#fff;border:none;border-radius:9999px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .15s}.st-teacher-next-btn:hover{background:var(--accent-hover)}.st-solo-celebrate{position:absolute;bottom:1.2rem;left:50%;transform:translate(-50%);background:#4f46e5e6;color:#fff;padding:.5rem 1.4rem;border-radius:9999px;font-size:1rem;font-weight:700;pointer-events:none;animation:st-pop .3s ease}@keyframes st-pop{0%{opacity:0;transform:translate(-50%) scale(.8)}to{opacity:1;transform:translate(-50%) scale(1)}}.st-stroke-dots{display:flex;gap:.5rem;justify-content:center}.st-dot{width:10px;height:10px;border-radius:50%;transition:background .2s,transform .2s}.st-dot-pending{background:#ffffff26}.st-dot-active{background:#c8922a;transform:scale(1.35)}.st-dot-pass{background:#22c55e}.st-dot-fail{background:#ef4444}.dict-page{display:flex;flex-direction:column;height:100dvh;overflow:hidden;background:var(--bg);color:var(--text)}.dict-header{display:flex;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.dict-title{font-size:1.25rem;font-weight:700;margin:0}.dict-panels{display:flex;flex:1;min-height:0;gap:0}.dict-panel{display:flex;flex-direction:column;flex:1;min-width:0;border-right:1px solid var(--border);overflow:hidden}.dict-panel:last-child{border-right:none}.dict-panel-head{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:.4rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0;min-height:38px}.dict-editing-label{font-size:.85rem;font-weight:600;color:var(--text-muted);margin-right:auto}.dict-panel-title{font-weight:600;font-size:.9rem;color:var(--text)}.dict-count{font-size:.75rem;color:var(--text-muted);background:var(--bg);padding:.1rem .5rem;border-radius:99px;border:1px solid var(--border)}.dict-search{margin:.5rem;padding:.4rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;flex-shrink:0}.dict-list{flex:1;overflow-y:auto;padding:.25rem 0}.dict-list-item{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;padding:.45rem 1rem;background:transparent;border:none;color:var(--text);font-size:.9rem;cursor:pointer;transition:background .1s}.dict-list-item:hover{background:var(--bg-card)}.dict-list-item.dict-selected{background:#6366f126;color:var(--accent-muted);font-weight:600}.dict-def-item{padding:.5rem .75rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.dict-def-item:hover{background:var(--bg-card)}.dict-def-item.dict-selected{background:#6366f11a}.dict-ex-item{padding:.5rem .75rem;border-bottom:1px solid var(--border)}.dict-def-view{display:flex;flex-direction:column;gap:.2rem;position:relative}.dict-pos-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-muted);background:#6366f11a;border-radius:4px;padding:.1rem .4rem;align-self:flex-start}.dict-def-text,.dict-ex-text{font-size:.9rem;color:var(--text)}.dict-japanese{font-size:.8rem;color:var(--text-muted)}.dict-row-actions{display:flex;gap:.25rem;margin-top:.25rem}.dict-icon-btn{background:none;border:none;cursor:pointer;font-size:.85rem;opacity:.6;padding:.1rem .25rem;border-radius:4px;transition:opacity .15s,background .15s}.dict-icon-btn:hover{opacity:1;background:var(--bg-card)}.dict-def-edit{display:flex;flex-direction:column;gap:.4rem;padding:.25rem 0}.dict-edit-actions{display:flex;gap:.4rem}.dict-save-btn{padding:.3rem .75rem;border-radius:6px;border:none;background:var(--accent);color:#fff;font-size:.8rem;cursor:pointer}.dict-cancel-btn{padding:.3rem .75rem;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.8rem;cursor:pointer}.dict-add-form{display:flex;flex-direction:row;gap:.4rem;padding:.75rem;border-top:1px solid var(--border);flex-shrink:0}.dict-def-form{gap:.4rem}.dict-input{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem}.dict-textarea{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;resize:vertical;font-family:inherit}.dict-select{padding:.4rem .6rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem}.dict-add-btn{padding:.4rem .75rem;border-radius:6px;border:none;background:var(--accent);color:#fff;font-size:.85rem;cursor:pointer;font-weight:600;transition:background .15s}.dict-add-btn:hover{background:var(--accent-hover)}.dict-empty{color:var(--text-muted);font-size:.85rem;text-align:center;padding:2rem 1rem}.dict-panel-narrow{flex:0 0 220px}.dict-panel-wide{flex:1}.dict-panel-actions{display:flex;align-items:center;gap:.5rem}.dict-def-badge{font-size:.7rem;color:var(--accent-muted);background:#6366f11f;border-radius:99px;padding:.1rem .4rem;font-weight:600;flex-shrink:0}.dict-def-editor{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.dict-def-block{border-left:3px solid rgba(99,102,241,.35);border-radius:0 6px 6px 0;padding:.65rem .85rem;display:flex;flex-direction:column;gap:.6rem;background:transparent}.dict-def-block-head{display:flex;align-items:center;justify-content:space-between}.dict-def-index{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.dict-def-row{display:flex;gap:.5rem;align-items:flex-start}.dict-def-input{flex:1}.dict-examples{display:flex;flex-direction:column;gap:.35rem}.dict-example-row{display:flex;gap:.35rem;align-items:center}.dict-ex-input{flex:1}.dict-add-ex-btn{background:none;border:1px dashed var(--border);color:var(--text-muted);font-size:.78rem;padding:.3rem .6rem;border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s;align-self:flex-start}.dict-add-ex-btn:hover{border-color:var(--accent-muted);color:var(--accent-muted)}.dict-add-def-btn{align-self:flex-start;background:none;border:1px dashed var(--border);color:var(--text-muted);font-size:.85rem;padding:.4rem .8rem;border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s}.dict-add-def-btn:hover{border-color:var(--accent-muted);color:var(--accent-muted)}.dict-delete-btn{padding:.3rem .75rem;border-radius:6px;border:1px solid rgba(239,68,68,.4);background:transparent;color:#f87171;font-size:.8rem;cursor:pointer;transition:background .15s}.dict-delete-btn:hover{background:#ef44441a}.dict-play-btn{background:none;border:none;cursor:pointer;font-size:inherit;color:#a78bfa;padding:0;line-height:1;transition:color .15s,transform .1s;flex-shrink:0}.dict-play-btn:hover{color:#fff;transform:scale(1.15)}.dict-refresh-wrap{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.dict-refresh-audio-btn{background:none;border:1px solid rgba(148,163,184,.3);border-radius:4px;cursor:pointer;font-size:1rem;color:var(--text-muted);padding:.1rem .35rem;line-height:1;transition:color .15s,border-color .15s;flex-shrink:0}.dict-refresh-audio-btn:hover{color:#fff;border-color:#94a3b899}.dict-refresh-audio-btn:disabled{opacity:.5;cursor:default}.dict-refresh-warning{font-size:.75rem;color:#f87171;font-weight:600;white-space:nowrap}.dict-refresh-ok-btn{background:#f87171;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;color:#fff;padding:.15rem .5rem;transition:background .15s}.dict-refresh-ok-btn:hover{background:#ef4444}.dict-refresh-countdown{font-size:.75rem;color:var(--text-muted);min-width:1.5rem}.dict-edit-btn{padding:.25rem .65rem;border-radius:5px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.78rem;cursor:pointer;transition:border-color .15s,color .15s}.dict-edit-btn:hover{border-color:var(--accent-muted);color:var(--accent-muted)}.dict-view{flex:1;overflow-y:auto;padding:2rem 2.5rem;display:flex;flex-direction:column}.dict-view-word{display:flex;align-items:center;align-self:flex-start;gap:.4rem;margin-bottom:1.75rem}.dict-view-heading{font-size:2.5rem;font-weight:800;letter-spacing:-.03em;color:var(--text);margin:0;line-height:1;flex:none}.dict-view-word .dict-play-btn{font-size:2.5rem}.dict-view-entry{padding:1.5rem 0}.dict-view-entry+.dict-view-entry{border-top:1px solid var(--border)}.dict-view-pos{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-muted);margin-bottom:.6rem}.dict-view-definition{font-size:1.05rem;color:var(--text);line-height:1.7;margin:0 0 1rem}.dict-view-examples{display:flex;flex-direction:column;gap:.5rem;padding-left:1.1rem;border-left:2px solid var(--border)}.dict-view-example{font-size:.88rem;font-style:italic;color:var(--text-muted);line-height:1.6;margin:0}.admin-dict-link{display:inline-block;margin-top:.5rem;font-size:.9rem;color:var(--accent-muted);text-decoration:none;font-weight:600}.admin-dict-link:hover{text-decoration:underline}.tsw-wrap{position:fixed;bottom:1.25rem;right:1.25rem;z-index:9999}.tsw-toggle{width:auto;width:2.6rem;height:2.6rem;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0006;transition:transform .15s}.tsw-toggle:hover{transform:scale(1.1)}.tsw-panel{position:absolute;bottom:3.2rem;right:0;width:240px;background:#1a1a2e;border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 8px 32px #00000080;overflow:hidden}.tsw-header{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem .5rem;border-bottom:1px solid rgba(255,255,255,.08)}.tsw-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#64748b}.tsw-close{width:auto;background:none;border:none;color:#64748b;font-size:1.1rem;cursor:pointer;padding:0 .2rem;line-height:1}.tsw-close:hover{color:var(--text)}.tsw-families{padding:.5rem .75rem .75rem;display:flex;flex-direction:column;gap:.4rem}.tsw-row{display:flex;align-items:center;gap:.5rem}.tsw-label{font-size:.78rem;font-weight:600;color:var(--text-muted);width:60px;flex-shrink:0}.tsw-swatches{display:flex;gap:.35rem;flex:1}.tsw-swatch{width:auto;flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.4rem .3rem;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .1s}.tsw-swatch:hover{transform:scale(1.04)}.tsw-swatch.tsw-active{border-color:#fff;box-shadow:0 0 0 1px #ffffff4d}.tsw-dot{width:14px;height:14px;border-radius:50%;display:block;box-shadow:0 1px 3px #0000004d}.tsw-mode-label{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff9}.sp-page{min-height:100vh;background:var(--bg);color:var(--text);padding-bottom:3rem}.sp-header{display:flex;align-items:center;gap:1.25rem;padding:1rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.sp-back{color:var(--text-muted);text-decoration:none;font-size:.9rem;white-space:nowrap}.sp-back:hover{color:var(--text)}.sp-title{font-size:1.2rem;font-weight:700;margin:0}.sp-tabs{display:flex;gap:.5rem;margin-left:auto}.sp-tab{width:auto;padding:.4rem 1rem;margin-top:0;font-size:.9rem;font-weight:600;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.sp-tab:hover{color:var(--text);border-color:var(--text-muted)}.sp-tab-active{background:var(--accent);color:#fff;border-color:var(--accent)}.sp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.75rem;padding:1.5rem}.sp-cell{display:flex;flex-direction:column;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}.sp-cell:hover{border-color:var(--accent)}.sp-svg{display:block;width:100%;aspect-ratio:1;color:var(--text)}.sp-char-label{font-size:.8rem;font-weight:600;color:var(--text-muted);padding:.3rem .5rem;border-top:1px solid var(--border);width:100%;text-align:center}.sp-section{margin-bottom:2rem}.sp-section-title{font-size:1rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:.5rem 1.5rem;margin:0}.sp-hint{font-size:.85rem;color:var(--text-muted);margin-left:auto}.sp-cell{cursor:pointer}.se-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.se-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:min(92vw,860px);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;position:relative}.se-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.se-big-char{font-size:2.2rem;font-family:Georgia,serif;font-weight:700;line-height:1;color:var(--accent);min-width:2.5rem;text-align:center}.se-header-title{font-size:1.1rem;font-weight:700;color:var(--text)}.se-close{margin-left:auto;width:auto;padding:.25rem .75rem;margin-top:0;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:8px;font-size:1.2rem;cursor:pointer}.se-close:hover{color:var(--text)}.se-test-btn{margin-left:auto;padding:.3rem 1rem;background:var(--accent);color:#0d0d0d;border:none;border-radius:7px;font-size:1rem;font-weight:700;cursor:pointer}.se-test-btn:hover{background:var(--accent-hover)}.se-test-overlay{position:absolute;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:16px}.se-test-modal{background:var(--bg);border-radius:14px;width:min(90%,500px);max-height:90%;overflow:hidden;display:flex;flex-direction:column}.se-test-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:1rem;font-weight:600}.se-body{display:flex;gap:0;flex:1;min-height:0;overflow:hidden}.se-canvas{flex-shrink:0;width:min(60%,500px);aspect-ratio:1;background:var(--bg);color:var(--text);border-right:1px solid var(--border);touch-action:none;-webkit-user-select:none;user-select:none}.se-anchor{cursor:grab}.se-anchor:active{cursor:grabbing}.se-handle{cursor:crosshair}.se-guide-line{stroke:currentColor;stroke-width:.5;opacity:.15}.se-guide-baseline{stroke-width:.8;opacity:.28}.se-guide-label{font-size:4.5px;fill:currentColor;opacity:.3;font-family:ui-monospace,monospace}.se-guide-label-base{opacity:.45}.se-panel{flex:1;display:flex;flex-direction:column;padding:1.25rem;overflow-y:auto;gap:1rem;min-width:0}.se-paths{display:flex;flex-direction:column;gap:.75rem}.se-path-row{display:flex;flex-direction:column;gap:.35rem}.se-stroke-label{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.se-path-code{font-size:.82rem;font-family:monospace;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;color:var(--text);word-break:break-all;line-height:1.6}.se-hint{font-size:1rem;color:var(--text-muted);line-height:1.6}.se-stroke-list{display:flex;flex-direction:column;gap:.4rem}.se-stroke-row{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;border-radius:8px;border:1px solid transparent}.se-stroke-row-active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.se-stroke-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.se-stroke-num{font-size:1.1rem;flex:1}.se-stroke-btns{display:flex;gap:.3rem}.se-icon-btn{background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:1.1rem;padding:.3rem .7rem;cursor:pointer;line-height:1.4;min-width:2.2rem;text-align:center}.se-icon-btn:hover{color:var(--text);border-color:var(--text-muted)}.se-icon-btn-del:hover{color:#e63946;border-color:#e63946}.se-add-stroke-btn{font-size:1.1rem;background:none;border:1px dashed var(--border);border-radius:8px;color:var(--text-muted);padding:.6rem .85rem;cursor:pointer;text-align:left}.se-add-stroke-btn:hover{color:var(--accent);border-color:var(--accent)}.se-seg-controls{display:flex;flex-direction:column;gap:.5rem;padding:.85rem;background:color-mix(in srgb,var(--accent) 6%,transparent);border:1px solid var(--border);border-radius:8px}.se-seg-label{font-size:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.se-seg-btn{font-size:1.05rem;background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:.6rem 1rem;cursor:pointer;text-align:left}.se-seg-btn:hover{border-color:var(--accent);color:var(--accent)}.se-seg-btn-del:hover{border-color:#e63946;color:#e63946}.se-seg-btn-active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.se-save-btn{width:100%;padding:1rem;background:var(--accent);color:#0d0d0d;border:2px solid color-mix(in srgb,var(--accent) 60%,#000);border-radius:9px;font-size:1.15rem;font-weight:800;cursor:pointer;letter-spacing:.04em;box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 50%,transparent);margin-top:auto}.se-save-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 6px 20px color-mix(in srgb,var(--accent) 65%,transparent)}.se-save-btn:disabled{opacity:.5;cursor:default;box-shadow:none}.se-save-msg{font-size:.95rem;color:var(--accent);text-align:center;margin-top:.3rem}.se-save-msg-err{color:#e63946}.sp-loading{color:var(--text-muted);font-size:.9rem;padding:1rem 0}
