@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Sans+JP:wght@400;500;700&family=Outfit:wght@400;500;600;700&display=swap";:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-sidebar:#0f172a;--bg-card:#ffffffbf;--bg-hover:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-light:#fff;--primary:#ff5e83;--primary-hover:#e04468;--primary-glow:#ff5e8333;--secondary:#6366f1;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--border-color:#e2e8f0cc;--border-glass:#fff6;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-glass:0 8px 32px 0 #1f268712;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--font-sans:"Inter", sans-serif;--font-jp:"Noto Sans JP", sans-serif;--font-title:"Outfit", sans-serif;--sidebar-width:260px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}body.theme-dark{--bg-primary:#0b0f19;--bg-secondary:#131a26;--bg-sidebar:#070a10;--bg-card:#131a26b3;--bg-hover:#1e293b;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#64748b;--text-light:#fff;--primary:#ff7597;--primary-hover:#ff9fb6;--primary-glow:#ff759740;--secondary:#818cf8;--border-color:#1e293bcc;--border-glass:#ffffff0d;--shadow-glass:0 8px 32px 0 #0000004d}*{box-sizing:border-box;outline:none;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .3s,color .3s;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.app-container{width:100vw;height:100vh;display:flex;position:relative}.sidebar{width:var(--sidebar-width);background-color:var(--bg-sidebar);color:var(--text-light);z-index:100;transition:var(--transition);flex-direction:column;flex-shrink:0;padding:24px;display:flex}.logo-section{border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;margin-bottom:32px;padding-bottom:16px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;width:40px;height:40px;font-size:1.25rem;font-weight:700;font-family:var(--font-title);box-shadow:0 0 15px var(--primary-glow);border-radius:10px;justify-content:center;align-items:center;display:flex}.logo-text{font-family:var(--font-title);letter-spacing:.5px;background:linear-gradient(90deg,#fff,#cbd5e1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.25rem;font-weight:700}.nav-links{flex-direction:column;flex-grow:1;gap:8px;list-style:none;display:flex}.nav-item a{color:#94a3b8;border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;align-items:center;gap:16px;padding:12px 16px;font-weight:500;text-decoration:none;display:flex}.nav-item.active a,.nav-item a:hover{color:var(--text-light);background-color:#ffffff14}.nav-item.active a{background:linear-gradient(135deg, var(--primary), var(--secondary));box-shadow:0 4px 12px #ff5e834d}.sidebar-footer{border-top:1px solid #ffffff1a;margin-top:auto;padding-top:16px}.theme-toggle-btn{border-radius:var(--radius-sm);color:#cbd5e1;cursor:pointer;width:100%;transition:var(--transition);background:#ffffff0d;border:1px solid #ffffff1a;justify-content:center;align-items:center;gap:12px;padding:12px;font-weight:500;display:flex}.theme-toggle-btn:hover{color:#fff;background:#ffffff1a}.main-content{background-image:radial-gradient(circle at 10% 20%,#ff759708 0%,#6366f105 90%);flex-grow:1;height:100vh;padding:40px;position:relative;overflow-y:auto}.bg-circle{filter:blur(120px);z-index:0;pointer-events:none;border-radius:50%;position:absolute}.bg-circle-1{background:#ff75970f;width:400px;height:400px;top:-100px;right:-50px}.bg-circle-2{background:#6366f10a;width:500px;height:500px;bottom:-150px;left:20%}.main-content-inner{z-index:1;max-width:1200px;margin:0 auto;position:relative}.page-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.page-title{font-family:var(--font-title);letter-spacing:-.5px;background:linear-gradient(135deg, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:12px;font-size:2.25rem;font-weight:700;display:flex}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:1rem}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-glass);border-radius:var(--radius-lg);box-shadow:var(--shadow-glass);margin-bottom:32px;padding:32px}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--secondary));color:var(--text-light);box-shadow:0 4px 12px #ff5e8333}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ff5e8359}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-icon{cursor:pointer;background:var(--bg-hover);border:1px solid var(--border-color);width:40px;height:40px;color:var(--text-secondary);transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.btn-icon:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px;display:grid}.progress-widget{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-glass);border-radius:var(--radius-md);box-shadow:var(--shadow-glass);align-items:center;gap:20px;padding:24px;display:flex}.progress-circle-container{width:70px;height:70px;position:relative}.progress-circle-svg{width:70px;height:70px;transform:rotate(-90deg)}.progress-circle-bg{fill:none;stroke:var(--bg-hover);stroke-width:6px}.progress-circle-bar{fill:none;stroke:var(--primary);stroke-width:6px;stroke-linecap:round;stroke-dasharray:201;stroke-dashoffset:201px;transition:stroke-dashoffset .8s ease-in-out}.progress-circle-text{font-family:var(--font-title);color:var(--text-primary);font-size:.95rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.widget-info h3{font-size:1.1rem;font-family:var(--font-title);margin-bottom:4px}.widget-info p{color:var(--text-secondary);font-size:.85rem}.welcome-banner{background:linear-gradient(135deg,#ff5e8314,#6366f114);border:1px solid #ff5e8326;justify-content:space-between;align-items:center;gap:32px;display:flex}.welcome-text h2{font-family:var(--font-title);color:var(--primary);margin-bottom:12px;font-size:1.75rem}.welcome-text p{color:var(--text-secondary);font-size:1rem}.welcome-japanese{font-family:var(--font-jp);color:var(--text-primary);opacity:.85;white-space:nowrap;font-size:2rem;font-weight:500}.goals-container{grid-template-columns:2fr 1fr;gap:24px;display:grid}.last-studied-card{justify-content:space-between;align-items:center;display:flex}.last-studied-details{flex-direction:column;gap:4px;display:flex}.last-studied-title{font-family:var(--font-title);font-size:1.2rem;font-weight:600}.kana-controls{justify-content:center;gap:16px;margin-bottom:24px;display:flex}.kana-chart-grid{grid-template-columns:repeat(5,1fr);gap:12px;max-width:700px;margin:0 auto;display:grid}.kana-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;aspect-ratio:1;transition:var(--transition);flex-direction:column;justify-content:center;align-items:center;padding:16px;display:flex}.kana-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 8px 16px #ff5e831a}.kana-card.empty{opacity:.15;cursor:default;pointer-events:none;background:0 0;border-style:dashed}.kana-jp{font-family:var(--font-jp);color:var(--text-primary);font-size:2.2rem;font-weight:700}.kana-romaji{color:var(--text-muted);text-transform:uppercase;margin-top:4px;font-size:.9rem;font-weight:600}.vocab-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.search-bar-container{flex-grow:1;max-width:400px;position:relative}.search-input{border:1px solid var(--border-color);background-color:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:var(--radius-sm);transition:var(--transition);padding:12px 16px 12px 48px;font-size:.95rem}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search-icon-svg{color:var(--text-muted);pointer-events:none;width:20px;height:20px;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.filter-group{flex-wrap:wrap;gap:8px;display:flex}.filter-btn{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:500}.filter-btn.active,.filter-btn:hover{background-color:var(--primary);color:var(--text-light);border-color:var(--primary)}.vocab-mode-toggle{background-color:var(--bg-hover);border-radius:var(--radius-sm);border:1px solid var(--border-color);padding:4px;display:flex}.vocab-mode-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;padding:6px 16px;font-size:.9rem;font-weight:600}.vocab-mode-btn.active{background-color:var(--bg-secondary);color:var(--primary);box-shadow:var(--shadow-sm)}.vocab-list-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.vocab-list-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition);flex-direction:column;gap:12px;padding:20px;display:flex;position:relative}.vocab-list-item:hover{box-shadow:var(--shadow-md);border-color:var(--primary-glow);transform:translateY(-4px)}.vocab-list-top{justify-content:space-between;align-items:flex-start;display:flex}.vocab-japanese-wrapper{flex-direction:column;display:flex}.vocab-jp-text{font-family:var(--font-jp);font-size:1.6rem;font-weight:700}.vocab-romaji-text{color:var(--text-muted);font-size:.85rem}.vocab-badge{text-transform:capitalize;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600}.vocab-badge.body_physiology{color:#ec4899;background-color:#ec48991a}.vocab-badge.health_medical{color:var(--danger);background-color:#ef44441a}.vocab-badge.psychology_character{color:#8b5cf6;background-color:#8b5cf61a}.vocab-badge.food_culture{color:var(--warning);background-color:#f59e0b1a}.vocab-badge.fashion_beauty{color:#db2777;background-color:#db27771a}.vocab-badge.housing_space{color:#4f46e5;background-color:#4f46e51a}.vocab-badge.transport_mobility{color:#0ea5e9;background-color:#0ea5e91a}.vocab-badge.leisure_sports{color:var(--success);background-color:#10b9811a}.vocab-badge.astronomy_meteorology{color:#7c3aed;background-color:#7c3aed1a}.vocab-badge.geography_ecology{color:#65a30d;background-color:#65a30d1a}.vocab-badge.biological_world{color:#14b8a6;background-color:#14b8a61a}.vocab-badge.relations_human{color:#f97316;background-color:#f973161a}.vocab-badge.society_politics_law{color:#2563eb;background-color:#2563eb1a}.vocab-badge.economy_business{color:#ca8a04;background-color:#ca8a041a}.vocab-badge.culture_thought{color:#b91c1c;background-color:#b91c1c1a}.vocab-badge.math_quantity{color:#64748b;background-color:#64748b1a}.vocab-badge.properties_relations{color:#6b7280;background-color:#6b72801a}.vocab-meaning{color:var(--text-primary);font-size:1rem;font-weight:500}.vocab-example{background-color:var(--bg-primary);border-left:3px solid var(--primary);border-radius:6px;padding:10px;font-size:.85rem}.vocab-example-ja{font-family:var(--font-jp);margin-bottom:2px;font-weight:500}.vocab-example-en{color:var(--text-secondary)}.vocab-actions{justify-content:flex-end;gap:8px;display:flex}.flashcards-container{flex-direction:column;align-items:center;gap:24px;max-width:500px;margin:0 auto;padding:20px 0;display:flex}.flashcard-card-scene{aspect-ratio:1.22;perspective:1000px;width:100%}.flashcard-card{width:100%;height:100%;transform-style:preserve-3d;cursor:pointer;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.flashcard-card.flipped{transform:rotateY(180deg)}.card-face{backface-visibility:hidden;border-radius:var(--radius-lg);width:100%;height:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border-glass);flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex;position:absolute}.card-face.front{background:linear-gradient(135deg, var(--bg-secondary), var(--bg-hover));color:var(--text-primary)}.card-face.back{background:linear-gradient(135deg, var(--primary), var(--secondary));color:var(--text-light);transform:rotateY(180deg)}.flashcard-front-jp{font-family:var(--font-jp);text-align:center;font-size:2.8rem;font-weight:700}.flashcard-speak-btn{z-index:10;position:absolute;top:20px;right:20px}.flashcard-back-mean{text-align:center;margin-bottom:8px;font-size:1.8rem;font-weight:700}.flashcard-back-reading{opacity:.9;text-align:center;margin-bottom:24px;font-size:1.1rem}.flashcard-back-example{border-radius:var(--radius-sm);text-align:center;background:#ffffff26;max-width:90%;padding:12px;font-size:.9rem}.flashcard-indicator{color:var(--text-muted);letter-spacing:1px;font-size:.8rem;font-weight:600;position:absolute;bottom:20px}.card-face.back .flashcard-indicator{color:#ffffffb3}.flashcard-controls{align-items:center;gap:16px;width:100%;display:flex}.flashcard-btn-nav{flex-grow:1}.flashcard-progress-bar-bg{background-color:var(--border-color);border-radius:3px;width:100%;height:6px;overflow:hidden}.flashcard-progress-bar-fill{background-color:var(--primary);border-radius:3px;width:0%;height:100%;transition:width .3s}.flashcard-info-text{color:var(--text-secondary);font-size:.9rem;font-weight:600}.grammar-list-container{flex-direction:column;gap:20px;display:flex}.grammar-item-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition);overflow:hidden}.grammar-item-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:24px;display:flex}.grammar-item-header:hover{background-color:var(--bg-hover)}.grammar-header-left{align-items:center;gap:16px;display:flex}.grammar-index{background-color:var(--primary);color:var(--text-light);width:32px;height:32px;font-size:.9rem;font-weight:700;font-family:var(--font-title);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.grammar-title{font-family:var(--font-jp);font-size:1.25rem;font-weight:700}.grammar-collapse-icon{transition:var(--transition)}.grammar-item-card.expanded .grammar-collapse-icon{transform:rotate(180deg)}.grammar-item-body{border-top:1px solid var(--border-color);background-color:var(--bg-secondary);padding:24px;display:none}.grammar-item-card.expanded .grammar-item-body{display:block}.grammar-section-title{font-family:var(--font-title);color:var(--secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:1rem;font-weight:700}.grammar-structure-box{background-color:var(--bg-primary);border:1px dashed var(--primary);border-radius:var(--radius-sm);color:var(--primary);margin-bottom:20px;padding:14px 20px;font-size:1.1rem;font-weight:700}.grammar-explanation{color:var(--text-secondary);margin-bottom:24px;font-size:.95rem}.grammar-examples-list{flex-direction:column;gap:16px;display:flex}.grammar-example-item{background-color:var(--bg-primary);border-radius:var(--radius-sm);border-left:4px solid var(--secondary);justify-content:space-between;align-items:center;padding:16px;display:flex}.grammar-example-text-wrap{flex-direction:column;gap:4px;display:flex}.grammar-example-ja{font-family:var(--font-jp);font-size:1.2rem;font-weight:500}.grammar-example-en{color:var(--text-secondary);font-size:.9rem}.grammar-builder-container{border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);margin-top:24px;padding:20px}.grammar-builder-slots{border:1.5px dashed var(--text-muted);background:var(--bg-secondary);border-radius:6px;flex-wrap:wrap;align-items:center;gap:10px;min-height:50px;margin-bottom:16px;padding:10px;display:flex}.grammar-builder-tokens{flex-wrap:wrap;gap:8px;display:flex}.builder-token{background-color:var(--bg-secondary);border:1px solid var(--border-color);font-family:var(--font-jp);cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none;border-radius:6px;padding:6px 12px;font-size:1rem}.builder-token:hover{background-color:var(--primary);color:#fff;border-color:var(--primary)}.builder-token.selected{opacity:.4;pointer-events:none}.builder-feedback{margin-top:8px;font-size:.9rem;font-weight:600}.builder-feedback.success{color:var(--success)}.builder-feedback.error{color:var(--danger)}.quiz-welcome-box{text-align:center;max-width:600px;margin:0 auto;padding:40px 0}.quiz-welcome-icon{margin-bottom:16px;font-size:3.5rem}.quiz-selector-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:32px;margin-bottom:32px;display:grid}.quiz-selector-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition);padding:24px}.quiz-selector-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-6px)}.quiz-selector-card h4{font-family:var(--font-title);margin-bottom:8px;font-size:1.25rem}.quiz-selector-card p{color:var(--text-secondary);font-size:.85rem}.active-quiz-container{max-width:650px;margin:0 auto}.quiz-header-bar{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.quiz-progress-num{color:var(--text-secondary);font-size:.9rem;font-weight:700}.quiz-question-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;margin-bottom:24px;padding:32px}.quiz-question-hint{color:var(--text-muted);text-transform:uppercase;margin-bottom:12px;font-size:.85rem;font-weight:700}.quiz-question-title{font-family:var(--font-jp);margin-bottom:8px;font-size:2.2rem;font-weight:700}.quiz-question-sub{color:var(--text-secondary);font-size:1rem}.quiz-options-list{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.quiz-option-btn{border-radius:var(--radius-sm);background-color:var(--bg-secondary);border:1px solid var(--border-color);width:100%;color:var(--text-primary);text-align:left;cursor:pointer;transition:var(--transition);justify-content:space-between;align-items:center;padding:16px 24px;font-size:1.05rem;font-weight:500;display:flex}.quiz-option-btn:hover{background-color:var(--bg-hover);border-color:var(--text-muted)}.quiz-option-btn.selected{border-color:var(--primary);background-color:#ff5e830a}.quiz-option-btn.correct{border-color:var(--success);color:var(--success);background-color:#10b9810d;font-weight:600}.quiz-option-btn.wrong{border-color:var(--danger);color:var(--danger);background-color:#ef44440d}.option-letter{background-color:var(--bg-primary);border:1px solid var(--border-color);width:28px;height:28px;font-weight:700;font-family:var(--font-title);border-radius:50%;justify-content:center;align-items:center;margin-right:12px;font-size:.85rem;display:inline-flex}.quiz-option-btn.correct .option-letter{background-color:var(--success);color:#fff;border-color:var(--success)}.quiz-option-btn.wrong .option-letter{background-color:var(--danger);color:#fff;border-color:var(--danger)}.quiz-action-bar{justify-content:flex-end;display:flex}.quiz-results-box{text-align:center;padding:40px 20px}.results-score-circle{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:140px;height:140px;margin:0 auto 24px;display:flex;box-shadow:0 10px 25px #ff5e834d}.results-score-num{font-family:var(--font-title);font-size:2.8rem;font-weight:700;line-height:1}.results-score-label{text-transform:uppercase;letter-spacing:1px;opacity:.9;font-size:.8rem;font-weight:600}.results-title{font-family:var(--font-title);margin-bottom:12px;font-size:1.75rem;font-weight:700}.results-desc{color:var(--text-secondary);margin-bottom:32px;font-size:1rem}.hide{display:none!important}.ripple-effect{animation:.3s ease-out pulse}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}@media (width<=900px){.app-container{flex-direction:column}.sidebar{flex-direction:row;justify-content:space-between;align-items:center;width:100%;height:auto;padding:16px 20px;box-shadow:0 2px 10px #0000001a}.logo-section{border-bottom:none;margin-bottom:0;padding-bottom:0}.logo-text{font-size:1.1rem}.logo-icon{width:32px;height:32px;font-size:1rem}.nav-links{flex-direction:row;gap:4px;width:auto;margin:0}.nav-item a{gap:8px;padding:8px 12px;font-size:.85rem}.nav-item a span,.sidebar-footer{display:none}.main-content{height:calc(100vh - 72px);padding:24px 16px}.dashboard-grid,.goals-container{grid-template-columns:1fr}}@media (width<=600px){.sidebar{background-color:var(--bg-sidebar);justify-content:center;height:64px;padding:0;position:fixed;top:auto;bottom:0;left:0}.logo-section{display:none}.nav-links{justify-content:space-around;align-items:center;width:100%;height:100%}.nav-item{flex-grow:1;justify-content:center;height:100%;display:flex}.nav-item a{border-radius:0;flex-direction:column;justify-content:center;gap:4px;width:100%;height:100%;padding:0}.nav-item a svg{width:20px;height:20px}.nav-item a span{font-size:.65rem;display:block}.main-content{height:calc(100vh - 64px);padding:16px 12px 80px}.page-title{font-size:1.75rem}.glass-card{padding:20px}.kana-chart-grid{grid-template-columns:repeat(5,1fr);gap:6px}.kana-card{padding:8px}.kana-jp{font-size:1.5rem}.kana-romaji{margin-top:2px;font-size:.7rem}}.consolidation-table{border-collapse:collapse;background-color:var(--bg-secondary);border-radius:var(--radius-sm);width:100%;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);margin-top:8px;overflow:hidden}.consolidation-table th,.consolidation-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:14px 18px}.consolidation-table th{background-color:var(--bg-hover);color:var(--text-primary);font-family:var(--font-title);text-transform:uppercase;letter-spacing:.5px;font-size:.95rem;font-weight:700}.consolidation-table tbody tr{transition:var(--transition)}.consolidation-table tbody tr:hover{background-color:var(--bg-hover)}.consolidation-table td.clickable-jp{font-family:var(--font-jp);color:var(--primary);cursor:pointer;transition:var(--transition);font-weight:700}.consolidation-table td.clickable-jp:hover{color:var(--secondary);text-decoration:underline;transform:scale(1.02)}.font-sm{font-size:.85rem}.adjectives-split-container{grid-template-columns:1fr 1fr;gap:24px;display:grid}.adj-column{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:24px}.adj-header{font-family:var(--font-title);border-bottom:2px solid;margin-bottom:16px;padding-bottom:8px;font-size:1.15rem;font-weight:700}.adj-header.i-type{color:var(--primary);border-color:var(--primary)}.adj-header.na-type{color:var(--secondary);border-color:var(--secondary)}.counters-grid-container{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.counter-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:20px}.counter-header{font-family:var(--font-title);color:var(--primary);border-left:4px solid var(--primary);margin-bottom:16px;padding-left:8px;font-size:1.1rem;font-weight:700}.counter-cards-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.subtab-btn{font-size:.9rem;font-weight:600}@media (width<=900px){.adjectives-split-container{grid-template-columns:1fr}}.vocab-conjugations-grid{background-color:var(--bg-hover);border:1px dashed var(--border-color);border-radius:6px;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0;padding:10px;display:grid}.conj-item{justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.conj-label{color:var(--text-secondary);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:3px;padding:1px 5px;font-size:.72rem;font-weight:500}.conj-val{color:var(--primary);cursor:pointer;font-weight:600;transition:opacity .2s}.conj-val:hover{opacity:.8}.flashcard-back-conjugations{border-radius:var(--radius-sm);box-sizing:border-box;background:#ffffff26;grid-template-columns:1fr 1fr;gap:8px 16px;width:100%;margin-top:10px;margin-bottom:12px;padding:10px 12px;font-size:.8rem;display:grid}.fc-conj-item{justify-content:space-between;align-items:center;display:flex}.fc-conj-label{opacity:.85;font-size:.75rem;font-weight:500}.fc-conj-val{cursor:pointer;font-weight:700;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.fc-conj-val:hover{opacity:.8}.level-selector-section{margin-bottom:24px}.level-selector-section .section-label{text-transform:uppercase;letter-spacing:.05em;color:#fff6;margin-bottom:8px;font-size:.7rem;font-weight:600;display:block}.level-pills{background:#ffffff0f;border:1px solid #ffffff0d;border-radius:8px;grid-template-columns:repeat(5,1fr);gap:4px;padding:4px;display:grid}.level-pill{color:#ffffff80;cursor:pointer;font-size:.78rem;font-weight:700;font-family:var(--font-title);text-align:center;background:0 0;border:none;border-radius:6px;padding:6px 0;transition:all .2s}.level-pill:hover{color:#fff;background:#ffffff14}.level-pill.active{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 2px 8px #ff5e8359}.loading-overlay{-webkit-backdrop-filter:blur(8px);z-index:9999;background:#0f172ab3;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;transition:opacity .3s,visibility .3s;display:flex;position:fixed;top:0;left:0}.loading-overlay.hide{opacity:0;visibility:hidden;pointer-events:none}.spinner{border:5px solid #ffffff1a;border-top:5px solid var(--primary);width:50px;height:50px;box-shadow:0 0 15px var(--primary-glow);border-radius:50%;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:#fff;letter-spacing:.05em;font-size:1.1rem;font-weight:600;font-family:var(--font-title);text-shadow:0 2px 4px #0003;margin-top:16px}.category-filter-container{flex-direction:column;gap:16px;width:100%;display:flex}.category-group-tabs{border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:8px;padding-bottom:12px;display:flex}.category-subcats-panel{width:100%}.grouped-subcategories{background:var(--bg-hover);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-direction:column;gap:12px;padding:16px;display:flex}.grouped-row{border-bottom:1px dashed var(--border-color);align-items:flex-start;gap:16px;padding-bottom:12px;display:flex}.grouped-row:last-child{border-bottom:none;padding-bottom:0}.grouped-row .group-label{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);text-align:center;border-radius:6px;flex-shrink:0;min-width:120px;margin-top:2px;padding:4px 10px;font-size:.8rem;font-weight:700}.grouped-row .group-pills{flex-wrap:wrap;gap:6px;display:flex}.sub-pill{background-color:var(--bg-secondary)!important;border-radius:12px!important;padding:4px 12px!important;font-size:.75rem!important}.sub-pill.active{background-color:var(--primary)!important;color:var(--text-light)!important;border-color:var(--primary)!important}.nouns-grid-container,.pronouns-grid-container,.adverbs-grid-container{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-top:16px;display:grid}.noun-card,.pronoun-card,.adverb-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);padding:16px}.noun-word,.pronoun-word,.adverb-word{color:var(--text-primary);margin-bottom:8px;font-size:1.25rem;font-weight:700}.noun-kana,.pronoun-kana,.adverb-kana{color:var(--text-secondary);margin-bottom:4px;font-size:.85rem}.noun-meaning,.pronoun-meaning,.adverb-meaning{color:var(--text-primary);font-size:.95rem}
