@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap";.app{flex-direction:column;min-height:100vh;display:flex}.app-main{flex-direction:column;flex:1;display:flex}.app-header{z-index:100;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-sm);background:#fffffff2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:12px 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;display:flex}.logo{align-items:center;gap:10px;text-decoration:none;display:flex}.logo:hover{text-decoration:none}.logo-badge{font-family:var(--font-sans);background:var(--primary);color:#fff;letter-spacing:.3px;border-radius:5px;padding:5px 9px;font-size:12px;font-weight:700}.logo-text{flex-direction:column;display:flex}.logo-title{font-family:var(--font-sans);color:var(--primary);letter-spacing:.3px;font-size:14px;font-weight:700}.logo-sub{font-family:var(--font-sans);color:var(--text-muted);letter-spacing:.5px;font-size:9px}.header-nav{gap:8px;display:flex}.nav-link{color:var(--text-secondary);border-radius:6px;padding:6px 12px;font-size:13px;transition:all .2s}.nav-link:hover{color:var(--primary);background:#2563ab0f;text-decoration:none}.header-right{align-items:center;gap:10px;display:flex}.user-menu{align-items:center;gap:12px;display:flex}.user-email{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.auth-buttons{align-items:center;gap:8px;display:flex}.btn-primary{cursor:pointer;font-family:var(--font-sans);letter-spacing:.4px;background:var(--primary);color:#fff;border:none;border-radius:7px;padding:10px 22px;font-size:12px;font-weight:700;transition:all .18s}.btn-primary:hover:not(:disabled){opacity:.88}.btn-primary:disabled{opacity:.3;cursor:not-allowed}.btn-primary.full-width{width:100%}.btn-primary-sm{cursor:pointer;background:var(--primary);color:#fff;border:none;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .18s}.btn-primary-sm:hover{opacity:.88}.btn-ghost{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;font-size:12px;transition:all .18s}.btn-ghost:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}.page-content{width:100%;max-width:880px;margin:0 auto;padding:24px 16px}.page-center{color:var(--text-muted);font-family:var(--font-sans);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:60px 20px;font-size:13px;display:flex}.loading-text{font-family:var(--font-sans);color:var(--text-muted);font-size:12px}.page-header{margin-bottom:28px}.page-title{color:var(--text-primary);margin-bottom:6px;font-size:28px;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:14px}.error-box{text-align:center;padding:40px 20px}.error-icon{margin-bottom:12px;font-size:32px}.error-msg{color:var(--danger);font-size:13px;font-family:var(--font-sans);word-break:break-all;max-width:500px;margin-bottom:18px;margin-left:auto;margin-right:auto}.error-help{color:var(--text-muted);margin-bottom:20px;font-size:13px}.error-actions{justify-content:center;gap:10px;display:flex}.exam-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.exam-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;text-align:left;width:100%;font-family:var(--font-sans);color:var(--text-primary);border-radius:12px;flex-direction:column;gap:12px;padding:24px;transition:all .2s;display:flex;position:relative;overflow:hidden}.exam-card:before{content:"";background:var(--primary);border-radius:12px 12px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.exam-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.exam-card-top{justify-content:space-between;align-items:center;display:flex}.cert-badge{font-family:var(--font-sans);letter-spacing:.3px;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:600}.exam-id{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.exam-name{color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.4}.exam-domains{flex-direction:column;gap:4px;display:flex}.exam-domain-item{color:var(--text-secondary);justify-content:space-between;padding:2px 0;font-size:12px;display:flex}.exam-domain-weight{font-family:var(--font-mono);color:var(--accent);font-size:11px}.exam-domain-count{font-family:var(--font-mono);color:var(--text-muted);margin-top:4px;font-size:11px}.domain-selector{flex-wrap:wrap;gap:7px;margin-bottom:16px;display:flex}.domain-chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:12px;font-family:var(--font-sans);background:0 0;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;transition:all .2s;display:flex}.domain-chip:hover{color:#bb8000;border-color:#e67e2261}.domain-chip.active{color:var(--accent);background:#e67e2217;border-color:#e67e226b}.domain-weight{font-family:var(--font-mono);opacity:.7;font-size:10px}.study-page{max-width:860px}.study-header{margin-bottom:16px}.study-title{color:var(--text-primary);margin-bottom:12px;font-size:22px;font-weight:700}.study-topbar{border:1px solid var(--border);font-family:var(--font-sans);background:#ffffff05;border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:14px;padding:8px 14px;font-size:12px;display:flex}.topbar-left{color:var(--text-muted)}.topbar-left strong{color:var(--accent)}.topbar-rate{color:var(--text-secondary)}.topbar-right{align-items:center;gap:9px;display:flex}.type-badge{font-family:var(--font-mono);letter-spacing:.3px;border-radius:4px;padding:3px 10px;font-size:10px}.type-badge.single{color:var(--primary);background:#2563ab12;border:1px solid #2563ab2e}.type-badge.multi{color:var(--accent);background:#e67e2212;border:1px solid #e67e222e}.btn-quit{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #dc262633;border-radius:5px;padding:4px 12px;font-size:11px;transition:all .15s}.btn-quit:hover{color:var(--danger);background:#dc26260f;border-color:#dc262680}.question-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:13px;margin-bottom:16px;padding:24px;position:relative;overflow:hidden}.question-card:before{content:"";background:var(--primary);border-radius:12px 12px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.question-meta{flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:12px;display:flex}.badge{font-family:var(--font-mono);letter-spacing:.3px;border-radius:4px;padding:2px 9px;font-size:10px}.badge-domain{color:var(--accent);background:#e67e2214;border:1px solid #e67e2229}.badge-hard{color:var(--danger);background:#dc262614;border:1px solid #dc262629}.badge-medium{color:#fa3;background:#e67e2214;border:1px solid #e67e2229}.badge-easy{color:var(--success);background:#16a34a14;border:1px solid #16a34a29}.question-num{font-family:var(--font-mono);color:var(--text-muted);margin-left:auto;font-size:11px}.multi-hint{font-family:var(--font-sans);color:var(--accent);background:#e67e220d;border:1px solid #e67e2224;border-radius:6px;margin-bottom:12px;padding:7px 12px;font-size:12px}.question-text{color:var(--text-primary);white-space:pre-wrap;font-size:14.5px;line-height:1.94}.options-list{flex-direction:column;gap:7px;margin-bottom:18px;display:flex}.option{border:1px solid var(--border);cursor:pointer;text-align:left;width:100%;font-family:var(--font-sans);color:var(--text-primary);background:#ffffff04;border-radius:8px;align-items:flex-start;gap:11px;padding:12px 14px;font-size:13.5px;transition:all .18s;display:flex}.option:hover:not(.answered){background:#2563ab0e;border-color:#2563ab5c}.option.selected{background:#2563ab13;border-color:#2563ab85}.option.answered{cursor:default}.option.correct{background:#16a34a11;border-color:#16a34a85}.option.wrong{background:#dc262611;border-color:#dc262685}.option.unselected-correct{background:#16a34a08;border-color:#16a34a4d}.option-circle{width:26px;height:26px;font-family:var(--font-sans);color:#2a4a68;border:2px solid #0096c847;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:all .18s;display:flex}.option.selected .option-circle{border-color:var(--primary);color:var(--primary);background:#2563ab24}.option.correct .option-circle{border-color:var(--success);color:var(--success);background:#16a34a24}.option.wrong .option-circle{border-color:var(--danger);color:var(--danger);background:#dc262624}.option.unselected-correct .option-circle{color:var(--success);border-color:#16a34a73}.option-text{flex:1;line-height:1.67}.option-tag{font-family:var(--font-mono);white-space:nowrap;flex-shrink:0;margin-left:auto;padding-left:10px;font-size:10px}.correct-tag{color:var(--success)}.wrong-tag{color:var(--danger)}.hint-tag{color:var(--success)}.study-actions{gap:10px;margin-bottom:16px;display:flex}.result-panel{border-radius:10px;margin-top:16px;padding:20px;animation:.3s fadeIn}.result-correct{border-left:3px solid var(--success);background:#16a34a08}.result-wrong{border-left:3px solid var(--danger);background:#dc262608}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.result-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.result-icon{font-size:20px;font-weight:700}.result-icon.correct{color:var(--success)}.result-icon.wrong{color:var(--danger)}.result-label{font-size:16px;font-weight:700}.result-section{margin-bottom:14px}.result-title{font-family:var(--font-sans);color:var(--primary);letter-spacing:.3px;margin-bottom:9px;font-size:10px}.result-text{color:var(--text-secondary);white-space:pre-wrap;font-size:13.5px;line-height:1.84}.result-docs{border-top:1px solid #2563ab1a;margin-top:14px;padding-top:13px}.result-docs-title{font-family:var(--font-sans);color:var(--text-muted);letter-spacing:.3px;margin-bottom:8px;font-size:10px}.doc-links{flex-direction:column;gap:5px;display:flex}.doc-link{color:#3a7090;border:1px solid var(--border);word-break:break-all;background:#0096c808;border-radius:5px;align-items:center;gap:8px;padding:5px 10px;font-size:12px;text-decoration:none;transition:all .18s;display:flex}.doc-link:hover{color:var(--primary);background:#2563ab0d;border-color:#2563ab47;text-decoration:none}.doc-icon{flex-shrink:0;font-size:11px}.feedback-panel{border:1px solid var(--border);background:#ffffff04;border-radius:8px;margin-top:16px;padding:16px}.feedback-label{font-family:var(--font-sans);color:var(--text-muted);letter-spacing:.3px;margin-bottom:10px;font-size:11px}.feedback-buttons{gap:8px;margin-bottom:10px;display:flex}.btn-feedback{border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:6px;padding:7px 18px;font-size:13px;transition:all .18s}.btn-feedback.good:hover,.btn-feedback.good.active{color:var(--success);background:#16a34a0f;border-color:#16a34a66}.btn-feedback.bad:hover,.btn-feedback.bad.active{color:var(--danger);background:#dc26260f;border-color:#dc262666}.feedback-comment{margin-top:8px}.feedback-textarea{border:1px solid var(--border);width:100%;min-height:60px;color:var(--text-primary);font-family:var(--font-sans);resize:vertical;background:#ffffff05;border-radius:6px;outline:none;padding:10px;font-size:13px}.feedback-textarea:focus{border-color:var(--border-hover)}.btn-send-feedback{color:var(--primary);cursor:pointer;background:#2563ab14;border:1px solid #2563ab42;border-radius:6px;margin-top:8px;padding:7px 18px;font-size:12px;transition:all .18s}.btn-send-feedback:hover{background:#2563ab26}.feedback-done{color:var(--success);background:#16a34a0d;border:1px solid #16a34a26;border-radius:6px;margin-top:16px;padding:10px 16px;font-size:13px}.feedback-error{color:var(--danger);margin-top:8px;font-size:12px}.stats-panel{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:13px;padding:24px}.stats-overview{flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:24px;display:flex}.stat-item{text-align:center;border:1px solid var(--border);background:#ffffff05;border-radius:8px;min-width:100px;padding:12px 24px}.stat-value{font-family:var(--font-mono);color:var(--text-primary);font-size:28px;font-weight:700;line-height:1}.stat-value.accent{color:var(--accent)}.stat-value.correct-color{color:var(--success)}.stat-label{font-family:var(--font-sans);color:var(--text-muted);letter-spacing:.3px;margin-top:6px;font-size:10px}.stats-domains{margin-top:16px}.stats-section-title{font-family:var(--font-sans);color:var(--text-muted);letter-spacing:.3px;margin-bottom:14px;font-size:11px}.domain-stat{margin-bottom:14px}.domain-stat-header{justify-content:space-between;margin-bottom:6px;display:flex}.domain-stat-label{color:var(--text-secondary);font-size:13px}.domain-stat-nums{font-family:var(--font-mono);color:var(--accent);font-size:12px}.progress-bar{background:#ffffff0a;border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:var(--primary);border-radius:2px;height:100%;transition:width .5s}.exam-tabs{background:#ffffff05;border-radius:9px;gap:4px;margin-bottom:20px;padding:3px;display:flex}.exam-tab{color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);letter-spacing:.4px;background:0 0;border:none;border-radius:7px;flex:1;padding:9px;font-size:11px;transition:all .2s}.exam-tab:hover{color:#5a90b8}.exam-tab.active{color:var(--primary);background:#2563ab17;border:1px solid #2563ab33}.empty-state{text-align:center;padding:60px 20px}.empty-icon{margin-bottom:16px;font-size:48px}.empty-state h2{color:var(--text-primary);margin-bottom:8px;font-size:20px}.empty-state p{color:var(--text-secondary);margin-bottom:24px}.auth-page{flex:1;justify-content:center;align-items:center;padding:24px 16px;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow-sm);border-radius:13px;padding:36px 32px}.auth-title{color:var(--text-primary);margin-bottom:6px;font-size:24px;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:13px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-error{color:var(--danger);background:#dc26260f;border:1px solid #dc262633;border-radius:6px;padding:10px 14px;font-size:13px}.auth-info{color:#16a34a;background:#22c55e0f;border:1px solid #22c55e33;border-radius:6px;padding:10px 14px;font-size:13px}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text-secondary);font-size:12px;font-weight:500}.form-input{border:1px solid var(--border);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);background:#ffffff05;border-radius:7px;outline:none;padding:10px 14px;transition:border-color .2s}.form-input:focus{border-color:var(--border-hover)}.form-input::placeholder{color:var(--text-muted)}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:20px;font-size:13px}.auth-link{color:var(--primary);margin-left:4px}.admin-content{width:100%;max-width:1100px;margin:0 auto;padding:24px 16px}.admin-tabs{background:#ffffff05;border-radius:9px;gap:4px;margin-bottom:24px;padding:3px;display:flex}.admin-tab{color:var(--text-muted);font-family:var(--font-sans);letter-spacing:.4px;white-space:nowrap;background:0 0;border-radius:7px;padding:9px 16px;font-size:11px;text-decoration:none;transition:all .2s}.admin-tab:hover{color:#5a90b8;text-decoration:none}.admin-tab.active{color:var(--accent);background:#e67e2217;border:1px solid #e67e224d}.admin-card{background:var(--bg-card);border:1px solid var(--border);border-radius:13px;margin-bottom:20px;padding:24px}.admin-section-title{font-family:var(--font-sans);color:var(--accent);letter-spacing:.3px;margin-bottom:16px;font-size:11px}.admin-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:8px 12px;font-size:10px}.admin-table td{color:var(--text-secondary);border-bottom:1px solid #0096c80f;padding:10px 12px;font-size:12px}.admin-table tr:hover td{background:#ffffff04}.admin-table-link{color:var(--primary);cursor:pointer;text-decoration:none}.admin-table-link:hover{text-decoration:underline}.admin-badge{font-family:var(--font-mono);letter-spacing:.3px;border-radius:4px;padding:2px 9px;font-size:10px;display:inline-block}.admin-badge-active{color:var(--success);background:#16a34a14;border:1px solid #16a34a29}.admin-badge-retired{color:var(--danger);background:#dc262614;border:1px solid #dc262629}.admin-badge-draft{color:var(--text-muted);background:#96969614;border:1px solid #96969633}.admin-badge-paused{color:var(--accent);background:#e67e2214;border:1px solid #e67e2229}.admin-exam-actions{flex-wrap:wrap;gap:6px;display:flex}.admin-quality-panel{padding:1rem .5rem}.admin-quality-loading{align-items:center;gap:8px;padding:1rem 0;display:flex}.admin-quality-fields{flex-wrap:wrap;gap:1.5rem;margin-bottom:1rem;display:flex}.admin-quality-field{flex-direction:column;gap:4px;min-width:180px;display:flex}.admin-quality-field input{max-width:160px}.admin-quality-hint{color:var(--text-secondary);font-size:.75rem}.admin-quality-actions{align-items:center;gap:8px;display:flex}.admin-quality-preview{background:var(--bg-secondary);border-radius:6px;margin-top:.75rem;padding:.75rem}.admin-quality-preview-ids{max-height:200px;margin-top:.25rem;padding-left:1rem;overflow-y:auto}.btn-ghost-sm{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:5px;padding:4px 10px;font-size:11px;transition:all .18s}.btn-ghost-sm:hover{border-color:var(--border-hover);color:var(--text-primary)}.btn-ghost-sm:disabled,.btn-primary-sm:disabled{opacity:.5;cursor:not-allowed}.admin-mono{font-family:var(--font-mono);letter-spacing:.5px}.admin-badge-running{color:var(--primary);background:#2563ab14;border:1px solid #2563ab2e}.admin-badge-succeeded{color:var(--success);background:#16a34a14;border:1px solid #16a34a29}.admin-badge-failed{color:var(--danger);background:#dc262614;border:1px solid #dc262629}.admin-badge-aborted{color:var(--text-muted);border:1px solid var(--border);background:#ffffff0a}.admin-filters{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;display:flex}.admin-filter-group{flex-direction:column;gap:4px;display:flex}.admin-filter-label{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.admin-select{border:1px solid var(--border);color:var(--text-primary);font-size:12px;font-family:var(--font-sans);background:#ffffff05;border-radius:6px;outline:none;padding:7px 12px;transition:border-color .2s}.admin-select:focus{border-color:var(--border-hover)}.admin-pagination{justify-content:center;gap:8px;margin-top:20px;display:flex}.admin-detail-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:20px;display:grid}.admin-detail-label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;margin-bottom:4px;font-size:10px}.admin-detail-value{color:var(--text-primary);word-break:break-all;font-size:13px}.admin-back-link{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:16px;font-size:12px;text-decoration:none;display:inline-flex}.admin-back-link:hover{color:var(--primary);text-decoration:none}.nav-link-admin{color:var(--accent)!important}.nav-link-admin:hover{background:#e67e220f!important}.admin-info{color:var(--primary);background:#2563ab0d;border:1px solid #2563ab26;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:12px}.admin-success{color:var(--success);background:#16a34a0d;border:1px solid #16a34a26;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:13px}.admin-success a{color:var(--success)}.btn-danger{color:var(--danger);cursor:pointer;background:#dc262614;border:1px solid #dc26264d;border-radius:6px;padding:7px 16px;font-size:12px;transition:all .18s}.btn-danger:hover{background:#dc262626;border-color:#dc262680}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.admin-question-text{color:var(--text-primary);margin-bottom:16px;font-size:14px;line-height:1.7}.admin-option{border:1px solid var(--border);color:var(--text-secondary);border-radius:6px;margin-bottom:6px;padding:8px 12px;font-size:13px}.admin-option-correct{color:var(--success);background:#16a34a0d;border-color:#16a34a4d}.admin-explanation{border:1px solid var(--border);color:var(--text-secondary);background:#ffffff05;border-radius:8px;margin-bottom:16px;padding:16px;font-size:13px;line-height:1.7}.admin-number-input{border:1px solid var(--border);color:var(--text-primary);background:#ffffff05;border-radius:6px;outline:none;width:80px;padding:7px 12px;font-size:14px;transition:border-color .2s}.admin-number-input:focus{border-color:var(--border-hover)}.admin-mono-sm{font-family:var(--font-mono);font-size:11px}.admin-empty{color:var(--text-muted);text-align:center;padding:20px;font-size:13px}.admin-rating-good{color:var(--success)}.admin-rating-bad{color:var(--danger)}.admin-color-cyan{color:var(--primary)}.admin-rating{font-size:11px}.admin-comment-cell{max-width:400px;font-size:12px}.admin-comment-cell-sm{max-width:300px;color:var(--text-muted);font-size:11px}.admin-correct-tag{margin-left:8px;font-size:11px}.admin-detail-label-mt{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;margin-top:16px;margin-bottom:4px;font-size:10px}.admin-refs{margin-bottom:8px;font-size:12px}.admin-refs a{color:var(--primary)}.admin-exam-group{margin-bottom:16px}.admin-exam-group-title{color:var(--text-primary);margin-bottom:8px;font-size:13px}.admin-stat-large{font-size:20px;font-weight:700}.admin-mt-16{margin-top:16px}.admin-mb-16{margin-bottom:16px}.app-footer{border-top:1px solid var(--border);text-align:center;color:var(--text-muted);padding:20px 24px;font-size:12px}.footer-links{justify-content:center;gap:8px;margin-bottom:8px;display:flex}.footer-link{color:var(--text-muted);text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--primary);text-decoration:none}.footer-sep{color:var(--border)}.footer-copy{font-family:var(--font-sans);letter-spacing:1px;font-size:10px}.footer-delete-account{opacity:.35;color:var(--text-muted,#888);cursor:pointer;background:0 0;border:none;margin-top:12px;padding:0;font-size:10px;text-decoration:none;transition:opacity .2s}.footer-delete-account:hover{opacity:.7;text-decoration:underline}.legal-page{max-width:720px;line-height:1.8}.legal-updated{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);margin-bottom:32px}.legal-section{margin-bottom:28px}.legal-section h2{color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:6px;font-size:16px;font-weight:700}.legal-section h3{color:var(--text-secondary);margin-top:14px;margin-bottom:6px;font-size:14px;font-weight:600}.legal-section p{color:var(--text-secondary);margin-bottom:8px;font-size:13.5px}.legal-section ul{margin-bottom:8px;padding-left:20px}.legal-section li{color:var(--text-secondary);margin-bottom:4px;font-size:13.5px}.legal-contact{font-family:var(--font-mono);color:var(--primary)}.legal-nav{border-top:1px solid var(--border);gap:10px;margin-top:40px;padding-top:20px;display:flex}.modal-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card,.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:13px;width:100%;max-width:440px;padding:28px}.modal-title{color:var(--text-primary);margin-bottom:12px;font-size:18px;font-weight:700}.modal-text,.modal-message{color:var(--text-secondary);margin-bottom:20px;font-size:13px;line-height:1.7}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.btn-ghost-danger{color:var(--danger)!important;border-color:#dc262633!important}.btn-ghost-danger:hover{color:var(--danger)!important;background:#dc26260f!important;border-color:#dc262680!important}.contact-page{justify-content:center;padding-top:40px;display:flex}.contact-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:540px;box-shadow:var(--shadow-sm);border-radius:13px;padding:36px 32px}.contact-textarea{resize:vertical;min-height:120px;line-height:1.7}.contact-char-count{font-family:var(--font-mono);color:var(--text-muted);text-align:right;margin-top:4px;font-size:10px;display:block}.contact-done{text-align:center;padding:20px 0}.contact-done h2{color:var(--success);margin-bottom:12px;font-size:20px}.contact-done p{color:var(--text-secondary);margin-bottom:24px;font-size:13px}.terms-check{align-items:flex-start;gap:8px;display:flex}.terms-check input[type=checkbox]{accent-color:var(--accent);cursor:pointer;margin-top:3px}.terms-check-label{color:var(--text-secondary);font-size:12px;line-height:1.6}.terms-check-label a{color:var(--primary)}.skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff12 50%,#ffffff08 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite skeletonPulse}@keyframes skeletonPulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{pointer-events:none}.skeleton-mt-8{margin-top:8px}.goal-selector{gap:3px;display:flex}.goal-chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);background:0 0;border-radius:4px;padding:2px 8px;font-size:10px;transition:all .18s}.goal-chip:hover{color:var(--accent);border-color:#e67e2261}.goal-chip.active{color:var(--accent);background:#e67e2217;border-color:#e67e226b}.session-progress-bar{background:#ffffff0a;border-radius:2px;flex:1;min-width:60px;height:3px;overflow:hidden}.session-progress-fill{background:var(--primary);border-radius:2px;height:100%;transition:width .4s}.topbar-center{flex:1;padding:0 12px}.topbar-progress-text{white-space:nowrap}.session-summary{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:13px;padding:32px 24px;animation:.3s fadeIn}.session-summary-header{text-align:center;margin-bottom:24px}.session-summary-title{color:var(--text-primary);margin-bottom:6px;font-size:22px;font-weight:700}.session-summary-sub{color:var(--text-secondary);font-size:13px}.session-domains{margin-top:20px}.session-summary-actions{justify-content:center;gap:10px;margin-top:28px;display:flex}.result-animate{animation:.35s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.result-animate-correct .result-panel{animation:.5s correctPulse}@keyframes correctPulse{0%{box-shadow:0 0 #16a34a33}50%{box-shadow:0 0 0 6px #16a34a00}to{box-shadow:0 0 #16a34a00}}.result-animate-wrong .result-panel{animation:.4s wrongShake}@keyframes wrongShake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.option:active:not(.answered){transform:scale(.98)}.btn-primary:active:not(:disabled){transform:scale(.96)}.smart-mode-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);white-space:nowrap;background:0 0;border-radius:4px;padding:3px 10px;font-size:10px;transition:all .18s}.smart-mode-btn:hover{color:var(--primary);border-color:#2563ab61}.smart-mode-btn.active{color:var(--primary);background:#2563ab17;border-color:#2563ab6b}.btn-theme-toggle{border:1px solid var(--border);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:all .18s;display:flex}.btn-theme-toggle:hover{border-color:var(--border-hover);color:var(--accent);background:#e67e220f}.weak-domain-panel{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:13px;margin-top:20px;padding:20px}.weak-domain-title{font-family:var(--font-sans);color:var(--accent);letter-spacing:.3px;margin-bottom:6px;font-size:11px}.weak-domain-desc{color:var(--text-secondary);margin-bottom:16px;font-size:12px}.weak-domain-list{flex-direction:column;gap:10px;display:flex}.weak-domain-card{border:1px solid var(--border);background:#ffffff04;border-radius:8px;align-items:center;gap:12px;padding:12px 14px;display:flex}.weak-domain-info{flex:1}.weak-domain-label{color:var(--text-primary);font-size:13px;font-weight:500}.weak-domain-meta{font-family:var(--font-sans);align-items:center;gap:8px;margin-top:4px;font-size:11px;display:flex}.weak-domain-rate{color:var(--accent);font-weight:700}.weak-domain-stats{color:var(--text-muted)}.weak-domain-weight{color:var(--text-secondary)}.weak-domain-btn{white-space:nowrap}.btn-bookmark{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:6px;margin-left:auto;padding:4px 10px;font-size:18px;line-height:1;transition:all .18s}.btn-bookmark:hover{border-color:var(--accent);color:var(--accent)}.btn-bookmark.active{color:var(--accent);background:#e67e2214;border-color:#e67e226b}.history-tabs{background:#ffffff05;border-radius:9px;gap:4px;margin-bottom:20px;padding:3px;display:flex}.history-tab{color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);letter-spacing:.4px;background:0 0;border:none;border-radius:7px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px;font-size:11px;transition:all .2s;display:flex}.history-tab:hover{color:#5a90b8}.history-tab.active{color:var(--primary);background:#2563ab17;border:1px solid #2563ab33}.bookmark-count{color:var(--accent);background:#e67e221f;border-radius:8px;padding:1px 6px;font-size:10px}.bookmark-list{flex-direction:column;gap:6px;display:flex}.bookmark-item{border:1px solid var(--border);background:#ffffff04;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.bookmark-item-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.bookmark-item-text{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.bookmark-item-date{font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0;font-size:10px}.records-section{flex-direction:column;gap:12px;display:flex}.records-filter{background:#ffffff05;border-radius:7px;gap:4px;padding:3px;display:flex}.records-filter-btn{color:var(--text-muted);cursor:pointer;font-family:var(--font-sans);background:0 0;border:none;border-radius:5px;flex:1;padding:7px;font-size:11px;transition:all .2s}.records-filter-btn:hover{color:#5a90b8}.records-filter-btn.active{color:var(--primary);background:#2563ab17;border:1px solid #2563ab33}.records-list{flex-direction:column;gap:6px;display:flex}.record-item{border:1px solid var(--border);background:#ffffff04;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.record-item-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.record-result{text-align:center;flex-shrink:0;width:24px;font-size:16px;font-weight:700}.record-result.correct{color:var(--success)}.record-result.incorrect{color:var(--danger)}.record-item-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.record-item-text{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.record-item-meta{align-items:center;gap:8px;display:flex}.record-item-date{font-family:var(--font-mono);color:var(--text-muted);font-size:10px}.btn-retry{color:var(--primary);font-family:var(--font-sans);cursor:pointer;background:#2563ab0f;border:1px solid #2563ab40;border-radius:6px;flex-shrink:0;padding:5px 12px;font-size:11px;transition:all .2s}.btn-retry:hover{background:#2563ab24;border-color:#2563ab66}@media (width<=640px){.app-header{padding:10px 14px}.header-nav{order:3;justify-content:center;width:100%}.exam-grid{grid-template-columns:1fr}.page-title{font-size:22px}.auth-card{padding:28px 20px}.stats-overview{gap:10px}.stat-item{min-width:80px;padding:10px 16px}.stat-value{font-size:22px}.admin-tabs{flex-wrap:wrap}.admin-filters{flex-direction:column}.admin-detail-grid{grid-template-columns:1fr}.domain-selector{-webkit-overflow-scrolling:touch;scrollbar-width:thin;flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.domain-chip{flex-shrink:0}.option{min-height:44px;padding:14px}.study-actions{flex-direction:column}.study-actions .btn-primary{width:100%}.session-summary-actions{flex-direction:column}.session-summary-actions .btn-primary,.session-summary-actions .btn-ghost{width:100%}.study-topbar{flex-direction:column;gap:6px}.topbar-right{justify-content:space-between;width:100%}.topbar-center{width:100%;padding:0}.feedback-panel{padding:12px}}.maintenance-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:40px 20px;display:flex}.maintenance-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:480px;padding:48px 36px}.maintenance-icon{opacity:.8;margin-bottom:16px;font-size:48px}.maintenance-title{color:var(--text-primary);margin:0 0 12px;font-size:24px;font-weight:700}.maintenance-message{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.7}.maintenance-badge{color:var(--danger);background:#dc26261f;border:1px solid #dc262640;border-radius:10px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.maintenance-toggle-card.maintenance-active{background:#dc262608;border-color:#dc26264d}.maintenance-status-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.dot-green{background:var(--success)}.dot-red{background:var(--danger)}.maintenance-status-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;display:flex}.maintenance-status-label{color:var(--text-primary);font-size:14px;font-weight:500}.maintenance-updated{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.maintenance-message-input{margin-bottom:16px}.maintenance-message-input .admin-input{width:100%;margin-top:4px}.maintenance-actions{gap:10px;display:flex}.modal-body{color:var(--text-secondary);margin-bottom:20px;font-size:13px;line-height:1.7}.landing-page{width:100%}.hero-section{text-align:center;max-width:880px;margin:0 auto;padding:56px 16px 48px}.hero-content{max-width:640px;margin:0 auto}.hero-eyecatch{font-family:var(--font-sans);letter-spacing:.3px;color:var(--accent);margin-bottom:16px;font-size:12px;font-weight:600}.hero-title{color:var(--text-primary);margin-bottom:20px;font-size:36px;font-weight:700;line-height:1.4}.hero-highlight{color:var(--primary)}.hero-description{color:var(--text-secondary);margin-bottom:28px;font-size:15px;line-height:1.8}.hero-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:14px;display:flex}.hero-cta{padding:12px 32px;font-size:14px;display:inline-block}.hero-cta-sub{padding:12px 24px;font-size:13px}.hero-note{color:var(--text-muted);font-size:12px}.features-section{max-width:880px;margin:0 auto;padding:40px 16px 48px}.section-heading{text-align:center;color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.section-sub{text-align:center;color:var(--text-secondary);margin-bottom:28px;font-size:14px}.features-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-sm);text-align:center;border-radius:12px;padding:24px 20px;transition:border-color .2s}.feature-card:hover{border-color:var(--border-hover)}.feature-icon{margin-bottom:12px;font-size:32px}.feature-title{color:var(--text-primary);margin-bottom:8px;font-size:15px;font-weight:600}.feature-desc{color:var(--text-secondary);font-size:13px;line-height:1.6}.exams-section{max-width:880px;margin:0 auto;padding:40px 16px 48px}.cta-section{text-align:center;max-width:600px;margin:0 auto;padding:48px 16px 64px}.cta-title{color:var(--text-primary);margin-bottom:12px;font-size:22px;font-weight:700}.cta-desc{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.7}@media (width<=600px){.hero-title{font-size:26px}.features-grid{grid-template-columns:1fr}}.ad-container{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;width:100%;max-width:728px;margin:24px auto;padding:8px 0 4px;overflow:hidden}.ad-label{color:var(--text-muted);letter-spacing:.5px;text-align:center;margin-bottom:4px;font-size:10px;display:block}.ad-container--horizontal{min-height:100px}.ad-container--rectangle{min-height:250px}.ad-placeholder{min-height:90px;color:var(--text-muted);border:1px dashed var(--border);border-radius:4px;justify-content:center;align-items:center;margin:0 8px 8px;font-size:12px;display:flex}.ad-study-result{margin-top:16px}.ad-session-summary,.ad-history{margin:20px 0}.ad-landing{max-width:880px}@media (width<=320px){.ad-container{display:none}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563ab;--primary-dark:#1e4f8c;--primary-light:#3b82c4;--accent:#e67e22;--accent-dark:#cf6d14;--success:#16a34a;--danger:#dc2626;--text-primary:#1f2937;--text-secondary:#4b5563;--text-muted:#9ca3af;--bg-primary:#f8fafc;--bg-card:#fff;--bg-card-hover:#f1f5f9;--border:#e2e8f0;--border-hover:#cbd5e1;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--font-sans:"Noto Sans JP", system-ui, -apple-system, sans-serif;--font-mono:"Consolas", "Monaco", monospace}[data-theme=dark]{--primary:#60a5fa;--primary-dark:#3b82f6;--primary-light:#93c5fd;--accent:#f59e0b;--accent-dark:#d97706;--success:#4ade80;--danger:#f87171;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--bg-primary:#0f172a;--bg-card:#1e293b;--bg-card-hover:#334155;--border:#334155;--border-hover:#475569;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0006}[data-theme=dark] body{-webkit-font-smoothing:antialiased}[data-theme=dark] .app-header{background:#0f172af2}[data-theme=dark] .logo-badge{background:var(--primary);color:#fff}[data-theme=dark] .exam-card:before,[data-theme=dark] .question-card:before{background:var(--primary)}[data-theme=dark] .option-circle{color:#94a3b8;border-color:#6496c840}[data-theme=dark] .question-text{color:#e2e8f0}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite skeletonPulse}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:auto;min-height:100vh;line-height:1.6}#root{text-align:left;border:none;flex-direction:column;max-width:100%;min-height:100vh;margin:0;display:flex}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}
