@charset "UTF-8";.navigation-sidebar{position:fixed;top:0;left:0;width:420px;height:100vh;background:#fff;border-right:none;display:flex;flex-direction:column;overflow:hidden;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sidebar)}.navigation-sidebar.open{transform:translate(0)}.nav-header{padding:24px 20px;border-bottom:none;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-soft)}.nav-header h3{margin:0;font-size:1.25em;font-weight:600;letter-spacing:.3px}.nav-title{display:flex;flex-direction:column;gap:4px}.nav-title-row{display:inline-flex;align-items:center;gap:10px}.nav-logo{width:28px;height:28px;border-radius:var(--radius-sm);background:#fff3;padding:4px;flex:0 0 auto}.nav-subtitle{font-size:.85em;opacity:.85;letter-spacing:.3px}.nav-header-actions{display:flex;align-items:center;gap:12px;position:relative}.nav-more-wrap{position:relative}.nav-more-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;padding:0;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;justify-content:center}.nav-more-btn:hover{background:#ffffff40}.nav-more-btn svg{width:18px;height:18px}.nav-more-popover{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;padding:8px 0;background:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;box-shadow:0 2px 12px #00000014;z-index:100;animation:nav-more-pop-in .2s ease}.nav-more-row{display:flex;flex-direction:column;gap:4px;padding:6px 12px}.nav-more-row:not(:last-child){border-bottom:1px solid rgba(0,0,0,.05)}.nav-more-label{font-size:11px;font-weight:500;color:#0006;letter-spacing:.02em}.nav-more-options{display:flex;flex-wrap:wrap;gap:4px}.nav-more-opt{padding:4px 10px;font-size:12px;font-weight:500;color:#000000a6;background:transparent;border:none;border-radius:4px;cursor:pointer;outline:none;transition:background .12s ease,color .12s ease}.nav-more-opt:hover{background:#0000000d;color:var(--primary-color)}.nav-more-opt.is-active{background:#0ea5e91f;color:var(--primary-color)}.nav-more-opt:focus-visible{box-shadow:0 0 0 1px #0ea5e959}@keyframes nav-more-pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-lang-btn{background:#ffffff26;border:none;color:#fff;min-width:36px;height:36px;padding:0 8px;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;justify-content:center}.nav-lang-btn:hover{background:#ffffff40}.nav-theme-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;padding:0;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;justify-content:center}.nav-theme-btn:hover{background:#ffffff40;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.nav-theme-btn:active{transform:translateY(0)}.nav-font-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;padding:0;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;justify-content:center}.nav-font-btn:hover{background:#ffffff40;transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.nav-font-btn:active{transform:translateY(0)}.nav-theme-btn svg,.nav-font-btn svg{width:18px;height:18px}.nav-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:16px 0;background:var(--page-bg)}.nav-content::-webkit-scrollbar{width:8px}.nav-content::-webkit-scrollbar-track{background:transparent}.nav-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px;transition:background .2s}.nav-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.nav-section{margin-bottom:24px}.nav-section-title{padding:14px 20px;font-weight:700;font-size:.95em;color:var(--primary-color);background:linear-gradient(135deg,var(--primary-soft) 0%,var(--primary-soft-2) 100%);border-left:none;letter-spacing:.5px;text-transform:uppercase;margin:0 12px 12px;border-radius:8px;box-shadow:0 2px 4px rgba(var(--primary-rgb),.08)}.nav-level{margin:4px 0}.nav-level-header{padding:12px 20px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s ease;font-weight:600;color:#374151;font-size:.95em;margin:0 12px;border-radius:8px}.nav-level-header:hover{background:#f3f4f6;transform:translate(2px)}.nav-expand-icon{font-size:.75em;color:var(--primary-color);width:18px;display:inline-block;transition:transform .2s ease;font-weight:700}.nav-level-title{flex:1;font-size:.95em}.nav-units{padding-left:16px;border-left:2px solid #e5e7eb;margin-left:32px;margin-top:4px}.nav-unit{margin:2px 0}.nav-unit-header{padding:10px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all .2s ease;font-weight:500;color:#4b5563;font-size:.9em;border-radius:6px;margin:0 8px}.nav-unit-header:hover{background:#f9fafb;color:var(--primary-color)}.nav-unit-title{flex:1}.nav-modules{padding-left:16px;border-left:2px dashed #e5e7eb;margin-left:24px;margin-top:4px}.nav-module{padding:12px 16px 12px 44px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .2s ease;font-size:.9em;color:#6b7280;border-left:3px solid transparent;line-height:1.5;word-break:break-word;margin:2px 8px;border-radius:6px;position:relative;text-decoration:none}.nav-module:link,.nav-module:visited{color:inherit;text-decoration:none}.nav-module:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--primary-color);border-radius:0 2px 2px 0;transition:height .2s ease}@media (hover: hover){.nav-module:hover{background:var(--primary-soft);color:var(--primary-color);transform:translate(4px);box-shadow:0 2px 8px rgba(var(--primary-rgb),.1)}.nav-module:hover:before{height:60%}}.nav-module.selected{background:linear-gradient(135deg,var(--primary-soft-2) 0%,var(--primary-soft) 100%);color:var(--primary-color);font-weight:600;box-shadow:0 2px 12px rgba(var(--primary-rgb),.15);transform:translate(2px)}.nav-module.selected:before{height:80%;background:var(--primary-color)}.nav-module.selected .nav-item-count{color:var(--primary-color);font-weight:600;background:rgba(var(--primary-rgb),.1);padding:2px 8px;border-radius:4px}.nav-module-text{flex:1;padding-right:12px;word-break:break-word;line-height:1.5}.nav-item{padding:14px 20px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .2s ease;border-left:3px solid transparent;margin:4px 12px;border-radius:8px;position:relative;text-decoration:none}.nav-item:link,.nav-item:visited{color:inherit;text-decoration:none}.nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--primary-color);border-radius:0 2px 2px 0;transition:height .2s ease}@media (hover: hover){.nav-item:hover{background:var(--primary-soft);transform:translate(4px);box-shadow:0 2px 8px rgba(var(--primary-rgb),.1)}.nav-item:hover:before{height:60%}}.nav-item.selected{background:linear-gradient(135deg,var(--primary-soft-2) 0%,var(--primary-soft) 100%);font-weight:600;color:var(--primary-color);box-shadow:0 2px 12px rgba(var(--primary-rgb),.15);transform:translate(2px)}.nav-item.selected:before{height:80%;background:var(--primary-color)}.nav-item.selected .nav-item-count{color:var(--primary-color);font-weight:600;background:rgba(var(--primary-rgb),.1);padding:2px 8px;border-radius:4px}.nav-item-icon{font-size:1.3em;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.nav-item-text{flex:1;font-weight:500}.nav-item-count{font-size:.85em;color:#9ca3af;font-weight:500;transition:all .2s ease}:root[data-font-size=xs] .navigation-sidebar .nav-content{padding:10px 0}:root[data-font-size=xs] .navigation-sidebar .nav-section{margin-bottom:14px}:root[data-font-size=xs] .navigation-sidebar .nav-section-title{padding:10px 14px;margin:0 10px 8px}:root[data-font-size=xs] .navigation-sidebar .nav-level{margin:2px 0}:root[data-font-size=xs] .navigation-sidebar .nav-level-header{padding:8px 14px;margin:0 10px;gap:6px}:root[data-font-size=xs] .navigation-sidebar .nav-units{padding-left:12px;margin-left:24px;margin-top:2px}:root[data-font-size=xs] .navigation-sidebar .nav-unit{margin:1px 0}:root[data-font-size=xs] .navigation-sidebar .nav-unit-header{padding:6px 12px;margin:0 6px;gap:6px}:root[data-font-size=xs] .navigation-sidebar .nav-modules{padding-left:12px;margin-left:18px;margin-top:2px}:root[data-font-size=xs] .navigation-sidebar .nav-module{padding:8px 12px 8px 36px;margin:1px 6px}:root[data-font-size=xs] .navigation-sidebar .nav-item{padding:10px 14px;margin:2px 10px;gap:8px}:root[data-font-size=sm] .navigation-sidebar .nav-content{padding:10px 0}:root[data-font-size=sm] .navigation-sidebar .nav-section{margin-bottom:14px}:root[data-font-size=sm] .navigation-sidebar .nav-section-title{padding:10px 14px;margin:0 10px 8px}:root[data-font-size=sm] .navigation-sidebar .nav-level{margin:2px 0}:root[data-font-size=sm] .navigation-sidebar .nav-level-header{padding:8px 14px;margin:0 10px;gap:6px}:root[data-font-size=sm] .navigation-sidebar .nav-units{padding-left:12px;margin-left:26px;margin-top:2px}:root[data-font-size=sm] .navigation-sidebar .nav-unit{margin:1px 0}:root[data-font-size=sm] .navigation-sidebar .nav-unit-header{padding:6px 12px;margin:0 6px;gap:6px}:root[data-font-size=sm] .navigation-sidebar .nav-modules{padding-left:12px;margin-left:20px;margin-top:2px}:root[data-font-size=sm] .navigation-sidebar .nav-module{padding:8px 12px 8px 38px;margin:1px 6px}:root[data-font-size=sm] .navigation-sidebar .nav-item{padding:10px 14px;margin:2px 10px;gap:8px}:root[data-font-size=md] .navigation-sidebar .nav-content{padding:12px 0}:root[data-font-size=md] .navigation-sidebar .nav-section{margin-bottom:18px}:root[data-font-size=md] .navigation-sidebar .nav-section-title{padding:12px 16px;margin:0 10px 10px}:root[data-font-size=md] .navigation-sidebar .nav-level{margin:3px 0}:root[data-font-size=md] .navigation-sidebar .nav-level-header{padding:10px 16px;margin:0 10px;gap:8px}:root[data-font-size=md] .navigation-sidebar .nav-units{padding-left:14px;margin-left:28px;margin-top:3px}:root[data-font-size=md] .navigation-sidebar .nav-unit{margin:2px 0}:root[data-font-size=md] .navigation-sidebar .nav-unit-header{padding:8px 14px;margin:0 8px;gap:8px}:root[data-font-size=md] .navigation-sidebar .nav-modules{padding-left:14px;margin-left:24px;margin-top:3px}:root[data-font-size=md] .navigation-sidebar .nav-module{padding:10px 14px 10px 42px;margin:2px 8px}:root[data-font-size=md] .navigation-sidebar .nav-item{padding:12px 16px;margin:3px 10px;gap:10px}@media (max-width: 768px){.navigation-sidebar{width:85%;max-width:380px}.navigation-sidebar.open{box-shadow:4px 0 32px #0003}.nav-header{padding:20px 16px}.nav-header .nav-header-actions{gap:8px}.nav-header .nav-title h3{font-size:1.1em}.nav-header .nav-subtitle{font-size:.8em}.nav-header .nav-theme-btn,.nav-header .nav-font-btn,.nav-header .nav-more-btn{width:32px;height:32px}.nav-section-title{margin:0 8px 8px;padding:12px 16px}.nav-level-header,.nav-unit-header,.nav-module,.nav-item{margin-left:8px;margin-right:8px}}:root{--onboarding-bg: #fff;--onboarding-text: #333;--onboarding-shadow: 0 12px 40px rgba(0, 0, 0, .2);--onboarding-spotlight: rgba(255, 255, 255, .95);--onboarding-backdrop: rgba(0, 0, 0, .45)}.onboarding-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:var(--onboarding-backdrop);pointer-events:none}.onboarding-spotlight{position:fixed;z-index:10001;border-radius:16px;box-shadow:0 0 0 2px #ffffffe6,0 0 0 4px var(--primary-color),0 0 20px 2px rgba(var(--primary-rgb, 102, 126, 234),.25),0 0 0 9999px var(--onboarding-backdrop);pointer-events:none;animation:onboarding-pulse 2.5s ease-in-out infinite}@keyframes onboarding-pulse{0%,to{box-shadow:0 0 0 2px #ffffffe6,0 0 0 4px var(--primary-color),0 0 20px 2px rgba(var(--primary-rgb, 102, 126, 234),.25),0 0 0 9999px var(--onboarding-backdrop)}50%{box-shadow:0 0 0 2px #fffffff2,0 0 0 5px var(--primary-color),0 0 28px 4px rgba(var(--primary-rgb, 102, 126, 234),.35),0 0 0 9999px var(--onboarding-backdrop)}}.onboarding-tooltip{position:fixed;z-index:10002;background:var(--onboarding-bg);color:var(--onboarding-text);border-radius:var(--radius-md);box-shadow:var(--onboarding-shadow);padding:14px 16px;min-width:200px;max-width:280px;pointer-events:auto}.onboarding-arrow-wrap{line-height:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.06))}.onboarding-text{font-size:15px;line-height:1.45;margin-bottom:12px;white-space:normal}.onboarding-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.onboarding-skip{padding:6px 12px;font-size:13px;color:#666;background:transparent;border:none;border-radius:var(--radius-xs);cursor:pointer;transition:background .15s,color .15s}.onboarding-skip:hover{background:#0000000f;color:#333}.onboarding-next{padding:6px 14px;font-size:13px;font-weight:500;color:#fff;background:var(--primary-color);border:none;border-radius:var(--radius-xs);cursor:pointer;transition:background .15s,transform .1s}.onboarding-next:hover{filter:brightness(1.08)}.onboarding-next:active{transform:scale(.98)}:root{--primary-color: #667eea;--secondary-color: #764ba2;--primary-rgb: 102, 126, 234;--secondary-rgb: 118, 75, 162;--primary-soft: #f0f4ff;--primary-soft-2: #e6f0ff;--primary-tint: #f7f9ff;--page-bg: #fafbfc;--translation-bg: #faf5ff;--explain-bg: #fff9e6;--explain-border: #ffc107;--explain-divider: #ffe69c;--explain-title: #856404;--tip-color: #fd7e14;--tip-bg: #fff5eb;--logo-bg: #6c7bf0;--logo-ring: rgba(255, 255, 255, .2);--logo-ring-2: rgba(255, 255, 255, .12);--logo-petal: #f0f4ff;--logo-center: #764ba2;--radius-lg: 20px;--radius-md: 12px;--radius-sm: 10px;--radius-xs: 6px;--radius-xxs: 4px;--shadow-card: 0 20px 60px rgba(0, 0, 0, .3);--shadow-card-mobile: 0 12px 30px rgba(0, 0, 0, .16);--shadow-soft: 0 4px 12px rgba(0, 0, 0, .12);--shadow-hover: 0 6px 16px rgba(0, 0, 0, .2);--shadow-sidebar: 4px 0 24px rgba(0, 0, 0, .12);--font-scale: 1}:root[data-theme=sakura]{--primary-color: #f7a7c4;--secondary-color: #f08db2;--primary-rgb: 247, 167, 196;--secondary-rgb: 240, 141, 178;--primary-soft: #fff1f6;--primary-soft-2: #ffe6ee;--primary-tint: #fff6fa;--page-bg: #fff7fb;--translation-bg: #fff1f6;--explain-bg: #fff3f8;--explain-border: #f5a3be;--explain-divider: #f3c1d3;--explain-title: #c85a7d;--tip-color: #c24972;--tip-bg: #ffe3ee;--logo-bg: #f7a7c4;--logo-ring: rgba(255, 255, 255, .18);--logo-ring-2: rgba(255, 255, 255, .12);--logo-petal: #fff1f6;--logo-center: #f08db2}:root[data-font-size=sm]{--font-scale: .74}:root[data-font-size=xs]{--font-scale: .66}:root[data-font-size=md]{--font-scale: .82}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);min-height:100vh;color:#333;margin:0;padding:0;font-size:calc(16px * var(--font-scale))}button{-webkit-tap-highlight-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0;border:none;font:inherit;color:inherit;cursor:pointer}button:focus{outline:none}button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}#root{width:100%;min-height:100vh}.app-layout{position:relative;min-height:100vh;width:100%}.menu-toggle-btn{position:fixed;top:20px;left:20px;z-index:100;background:#fff;border:none;width:48px;height:48px;border-radius:12px;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--primary-color);transition:all .3s ease}.menu-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003;background:var(--primary-soft)}.menu-toggle-btn:active{transform:translateY(0)}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.main-content{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:80px 40px 40px;text-align:center;max-width:900px;margin:20px auto;min-height:calc(100vh - 40px)}.module-page--lock-x{touch-action:pan-y;overscroll-behavior-x:none}.group-info-header{margin-bottom:20px;padding:12px 16px;background:var(--primary-soft);border-radius:var(--radius-md);border-left:4px solid var(--primary-color);text-align:left}.group-info-header h2{font-size:.95em;color:var(--primary-color);margin-bottom:6px;font-weight:600;line-height:1.4;word-break:break-word}.group-description{color:#666;font-size:.85em;margin:4px 0;line-height:1.4}.container{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:800px;width:100%;padding:40px;text-align:center;margin:0 auto}header{margin-bottom:40px}header h1{font-size:2.5em;color:var(--primary-color);margin-bottom:10px;font-weight:700}.subtitle{color:#666;font-size:1.1em}.group-selector{margin-bottom:30px;padding:20px;background:var(--page-bg);border-radius:12px;text-align:left}.group-label{display:block;font-size:1em;color:#666;font-weight:500;margin-bottom:10px}.group-select{width:100%;padding:10px 15px;font-size:1em;border:2px solid #e9ecef;border-radius:8px;background:#fff;color:#333;cursor:pointer;transition:all .3s ease;font-weight:500;margin-bottom:10px}.group-select:hover{border-color:var(--primary-color);box-shadow:0 2px 8px rgba(var(--primary-rgb),.2)}.group-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.group-info{font-size:.9em;color:var(--primary-color);font-weight:500;padding:8px 12px;background:var(--primary-soft);border-radius:var(--radius-xs);border-left:3px solid var(--primary-color)}.sentence-display{margin:40px 0;min-height:200px;display:flex;flex-direction:column;justify-content:center;align-items:center;will-change:transform,opacity}.sentence-display--trigger{transform:translateY(0)}.sentence-display--next{animation:sentence-slide-next .26s cubic-bezier(.22,.61,.36,1)}.sentence-display--prev{animation:sentence-slide-prev .26s cubic-bezier(.22,.61,.36,1)}@keyframes sentence-slide-next{0%{transform:translateY(6px) scale(.995)}to{transform:translateY(0) scale(1)}}@keyframes sentence-slide-prev{0%{transform:translateY(-6px) scale(.995)}to{transform:translateY(0) scale(1)}}.sentence-text{font-size:2em;line-height:1.6;color:#333;padding:30px;background:#f8f9fa;border-radius:var(--radius-lg);margin-bottom:15px;min-height:120px;display:flex;align-items:center;justify-content:center;word-break:break-word;transition:all .3s ease;font-weight:600;width:100%}.sentence-text:hover{background:#e9ecef;transform:translateY(-2px)}.sentence-kana{font-size:1.4em;line-height:1.6;color:var(--primary-color);padding:20px;background:var(--primary-soft);border-radius:var(--radius-md);margin-bottom:15px;width:100%;display:flex;align-items:center;justify-content:center;word-break:break-word;font-weight:500}.sentence-translation{font-size:1.5em;line-height:1.6;color:var(--secondary-color);padding:20px;background:var(--translation-bg);border-radius:var(--radius-md);margin-bottom:15px;width:100%;display:flex;align-items:center;justify-content:center;word-break:break-word;font-weight:500}.sentence-explanation{font-size:1em;line-height:2;color:#555;padding:25px;background:var(--explain-bg);border-radius:var(--radius-md);margin-bottom:20px;width:100%;text-align:left;border-left:4px solid var(--explain-border)}.sentence-explanation .vocab{color:var(--primary-color);font-weight:600;background:var(--primary-soft);padding:2px 6px;border-radius:var(--radius-xxs)}.sentence-explanation .grammar{color:#d63384;font-weight:600;background:#fff0f7;padding:2px 6px;border-radius:var(--radius-xxs)}.sentence-explanation .usage{color:#198754;font-weight:600;background:#f0fff4;padding:2px 6px;border-radius:var(--radius-xxs)}.sentence-explanation .tip{color:var(--tip-color);font-weight:600;background:var(--tip-bg);padding:2px 6px;border-radius:var(--radius-xxs)}.sentence-explanation .section{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--explain-divider)}.sentence-explanation .section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.sentence-explanation .section-title{font-weight:700;color:var(--explain-title);margin-bottom:8px;font-size:1.05em}.sentence-info{font-size:1.2em;color:#666;font-weight:500;margin-top:10px}.controls{display:flex;gap:15px;justify-content:center;flex-wrap:wrap;margin:12px 0}.btn{padding:12px 30px;font-size:1.1em;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .3s ease;font-weight:500;background:#e9ecef;color:#333}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;padding:16px 40px;font-size:1.5em}.btn-primary:hover{opacity:.9}.audio-container{display:none}.speed-controls{display:flex;align-items:center;justify-content:center;gap:10px;margin:20px 0}.speed-label{font-size:1em;color:#666;font-weight:500}.speed-select{padding:8px 15px;font-size:1em;border:2px solid #e9ecef;border-radius:var(--radius-sm);background:#fff;color:#333;cursor:pointer;transition:all .3s ease;font-weight:500;min-width:120px}.speed-select:hover{border-color:var(--primary-color);box-shadow:0 2px 8px rgba(var(--primary-rgb),.2)}.speed-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.loop-controls{display:flex;align-items:center;justify-content:center;gap:10px;margin:20px 0}.loop-label{font-size:1em;color:#666;font-weight:500}.loop-select{padding:8px 15px;font-size:1em;border:2px solid #e9ecef;border-radius:var(--radius-sm);background:#fff;color:#333;cursor:pointer;transition:all .3s ease;font-weight:500;min-width:120px}.loop-select:hover{border-color:var(--primary-color);box-shadow:0 2px 8px rgba(var(--primary-rgb),.2)}.loop-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}footer{margin-top:40px;color:#999;font-size:.9em}.mobile-fixed-nav{display:none;align-items:center;justify-content:center}.mobile-fixed-nav-main{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:0;background:transparent;border-radius:0;box-shadow:none;border:none;-webkit-backdrop-filter:none;backdrop-filter:none}.mobile-fixed-nav-play{width:59px;height:59px;border:none;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;outline:none;background:linear-gradient(145deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;box-shadow:0 3px 12px rgba(var(--primary-rgb),.4),0 1px 3px #0000001f,inset 0 1px #ffffff40;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.mobile-fixed-nav-play:hover{box-shadow:0 4px 16px rgba(var(--primary-rgb),.45),0 2px 6px #0000001a,inset 0 1px #ffffff4d}.mobile-fixed-nav-play:active{transform:scale(.96)}.mobile-fixed-nav-play:disabled{opacity:.65;cursor:default}.mobile-fixed-nav-play .mobile-btn-icon{width:30px;height:30px}.mobile-fixed-nav-play .mobile-btn-icon svg{width:30px;height:30px}.mobile-fixed-nav-play .mobile-btn-icon--play{width:32px;height:32px}.mobile-fixed-nav-play .mobile-btn-icon--play svg{width:32px;height:32px}.mobile-fixed-nav-settings{width:40px;height:40px;border:none;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none;background:#0000000f;color:var(--primary-color);transition:background .2s ease,transform .2s ease}.mobile-fixed-nav-settings:hover{background:rgba(var(--primary-rgb),.15)}.mobile-fixed-nav-settings:active{transform:scale(.95)}.mobile-fixed-nav-settings svg{width:22px;height:22px}.mobile-fixed-nav-settings--corner{position:fixed;top:12px;right:12px;z-index:50}.mobile-settings-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:flex;align-items:flex-end;justify-content:center}.mobile-settings-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000040}.mobile-settings-panel{position:relative;width:min(92%,520px);margin:0 16px 20px;background:#fff;border-radius:var(--radius-md);box-shadow:0 12px 32px #00000029;padding:14px 14px 16px;border:1px solid rgba(var(--primary-rgb),.1)}.mobile-settings-panel:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:38px;height:4px;border-radius:999px;background:#00000014}.mobile-settings-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:#333;margin-bottom:8px;padding-top:6px}.mobile-settings-close{border:none;background:#0000000a;font-size:1em;color:#666;cursor:pointer;width:28px;height:28px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.mobile-settings-close:hover{background:#00000014}.vip-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:16px}.vip-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000059}.vip-modal-panel{position:relative;width:min(100%,320px);background:#fff;border-radius:var(--radius-md);box-shadow:0 12px 32px #0003;padding:20px 20px 16px}.vip-modal-label{margin:0 0 10px;font-weight:600;color:#333;font-size:.95em}.vip-modal-input{width:100%;padding:10px 12px;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius-sm);font-size:1em;margin-bottom:8px}.vip-modal-error{color:#c00;font-size:.85em;margin:-4px 0 8px}.vip-modal-submit{width:100%;margin-bottom:14px}.vip-modal-wechat-tip{margin:0;font-size:.88em;color:#666}.vip-modal-join{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;padding:0;font-size:inherit;-webkit-tap-highlight-color:transparent;outline:none;border-radius:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.vip-modal-join:hover{color:var(--secondary-color)}.vip-modal-join:active{background:none;color:var(--secondary-color)}.vip-modal-join:focus-visible{outline:1px dotted var(--primary-color);outline-offset:2px}.toast{position:fixed;left:50%;bottom:28%;transform:translate(-50%);z-index:100;padding:10px 20px;background:#000000bf;color:#fff;font-size:.95em;border-radius:8px;box-shadow:0 4px 12px #00000040;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.vip-modal-close{position:absolute;top:10px;right:10px;border:none;background:transparent;font-size:1.25em;color:#999;cursor:pointer;line-height:1;padding:4px}.vip-modal-close:hover{color:#333}.wechat-qr-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:91;display:flex;align-items:center;justify-content:center;padding:16px}.wechat-qr-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000059}.wechat-qr-panel{position:relative;width:min(100%,300px);background:#fff;border-radius:var(--radius-md);box-shadow:0 12px 32px #0003;padding:24px 20px 20px;text-align:center}.wechat-qr-title{margin:0 0 16px;font-weight:600;font-size:1.05em;color:#333}.wechat-qr-placeholder{width:200px;height:200px;margin:0 auto 16px;background:#e8e8e8;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.9em;color:#999}.wechat-qr-desc{margin:0;font-size:.9em;color:#666;line-height:1.45}.wechat-qr-close{position:absolute;top:10px;right:10px;border:none;background:transparent;font-size:1.25em;color:#999;cursor:pointer;line-height:1;padding:4px}.wechat-qr-close:hover{color:#333}.mobile-settings-item{background:var(--primary-soft);border-radius:var(--radius-md);padding:10px 12px 12px;margin-top:10px}.mobile-settings-item:first-of-type{border-top:none}.mobile-settings-label{color:var(--primary-color);font-weight:600;font-size:.85em}.mobile-settings-value{margin-top:2px;color:#555;font-weight:500;font-size:.95em}.mobile-settings-radio-group{margin-top:8px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.mobile-settings-radio{display:inline-flex;align-items:center;gap:8px;font-size:.9em;font-weight:600;color:#4b5563}.mobile-settings-radio input{width:12px;height:12px;accent-color:var(--primary-color)}.mobile-settings-item--swipe{background:rgba(var(--primary-rgb),.08)}.mobile-settings-slider-wrap{padding:0 7px;margin-top:8px}.mobile-settings-slider-wrap .mobile-settings-slider-ticks{margin-top:4px;padding:0}.mobile-settings-slider{width:100%;margin:0;accent-color:var(--primary-color);height:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;padding:0;display:block;height:16px}.mobile-settings-slider::-webkit-slider-runnable-track{height:3px;border-radius:999px;background:rgba(var(--primary-rgb),.35);margin:0}.mobile-settings-slider::-webkit-slider-thumb{width:14px;height:14px;margin-top:-6px;border-radius:50%;background:var(--primary-color);box-shadow:0 4px 10px rgba(var(--primary-rgb),.35);-webkit-appearance:none}.mobile-settings-slider::-moz-range-track{height:3px;border-radius:999px;background:rgba(var(--primary-rgb),.35);margin:0}.mobile-settings-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary-color);border:none;box-shadow:0 4px 10px rgba(var(--primary-rgb),.35)}.mobile-settings-slider-ticks{display:flex;justify-content:space-between;margin-top:4px;padding:0 2px;width:100%}.mobile-settings-tick{font-size:11px;color:#0000008c;flex-shrink:0}.mobile-btn-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.mobile-btn-icon svg{width:18px;height:18px;display:block}.mobile-btn-icon--play{width:22px;height:22px}.mobile-btn-icon--play svg{width:22px;height:22px}@media (max-width: 768px){.menu-toggle-btn{top:10px;left:10px;width:40px;height:40px}.main-content{margin:10px;padding:70px 20px 0;box-shadow:var(--shadow-card-mobile);min-height:auto}.container{padding:20px}header h1{font-size:2em}.group-selector{padding:15px}.group-info{font-size:.85em}.sentence-text{font-size:1.5em;padding:20px;min-height:100px}.sentence-kana{font-size:1.2em;padding:15px}.sentence-translation{font-size:1.3em;padding:15px}.sentence-explanation{font-size:.9em;padding:15px}.controls{flex-direction:column}.btn{width:100%}.module-page .subtitle,.module-page footer{display:none}.desktop-controls{display:none}.mobile-fixed-nav{display:flex;flex-direction:column;position:fixed;right:12px;left:auto;transform:none;bottom:auto;width:auto;padding:0;background:transparent;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;z-index:50;align-items:flex-end}.mobile-fixed-nav--left{align-items:flex-start}.mobile-fixed-nav--draggable{touch-action:none}.mobile-swipe-hint{position:fixed;left:50%;transform:translate(-50%);z-index:60;background:#000000b8;color:#fff;font-size:.85rem;padding:8px 12px;border-radius:999px;letter-spacing:.2px;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 4px 12px #0000002e}.mobile-swipe-hint--bottom{bottom:16px}.mobile-swipe-hint--top{top:16px}}
