@import"https://fonts.googleapis.com/css2?family=Noto+Serif+KR:wght@400;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #111827;--color-bg-card: #1e2536;--color-bg-elevated: #283044;--color-bg-hover: #334155;--color-bg-input: #1a2233;--color-primary: #60a5fa;--color-primary-hover: #93c5fd;--color-primary-light: rgba(96, 165, 250, .15);--color-accent: #f59e0b;--color-accent-hover: #fbbf24;--color-accent-light: rgba(245, 158, 11, .15);--color-success: #34d399;--color-success-light: rgba(52, 211, 153, .15);--color-warning: #fbbf24;--color-warning-light: rgba(251, 191, 36, .15);--color-danger: #f87171;--color-danger-light: rgba(248, 113, 113, .15);--color-info: #67e8f9;--color-info-light: rgba(103, 232, 249, .15);--color-text: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-text-inverse: #0f172a;--color-border: #334155;--color-border-light: #475569;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--font-family: "Pretendard", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-serif: "Noto Serif KR", "Georgia", serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .02em;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25), 0 1px 2px rgba(0, 0, 0, .15);--shadow-md: 0 4px 8px rgba(0, 0, 0, .2), 0 2px 4px rgba(0, 0, 0, .1);--shadow-lg: 0 12px 24px rgba(0, 0, 0, .2), 0 4px 8px rgba(0, 0, 0, .1);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .25);--shadow-glow: 0 0 20px rgba(96, 165, 250, .15);--shadow-accent-glow: 0 0 20px rgba(245, 158, 11, .1);--sidebar-width: 272px;--sidebar-collapsed-width: 72px;--header-height: 60px;--bottom-nav-height: 68px;--content-max-width: 1200px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-toast: 600;--color-text-primary: var(--color-text);--color-bg-primary: var(--color-bg-card);--color-bg-secondary: var(--color-bg-elevated);--color-bg-tertiary: var(--color-bg-hover);--bg-primary: var(--color-bg-card);--color-primary-bg: var(--color-primary-light);--color-primary-rgb: 96, 165, 250}[data-theme=light]{--color-bg: #faf8f5;--color-bg-card: #ffffff;--color-bg-elevated: #f5f1eb;--color-bg-hover: #ede8e0;--color-bg-input: #f8f5f0;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: rgba(37, 99, 235, .08);--color-accent: #d97706;--color-accent-hover: #b45309;--color-accent-light: rgba(217, 119, 6, .08);--color-success: #059669;--color-success-light: rgba(5, 150, 105, .08);--color-warning: #d97706;--color-warning-light: rgba(217, 119, 6, .08);--color-danger: #dc2626;--color-danger-light: rgba(220, 38, 38, .08);--color-info: #0891b2;--color-info-light: rgba(8, 145, 178, .08);--color-text: #1e293b;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-inverse: #f8fafc;--color-border: #e2ddd5;--color-border-light: #ede8e0;--shadow-sm: 0 1px 3px rgba(120, 100, 70, .06), 0 1px 2px rgba(120, 100, 70, .04);--shadow-md: 0 4px 8px rgba(120, 100, 70, .06), 0 2px 4px rgba(120, 100, 70, .04);--shadow-lg: 0 12px 24px rgba(120, 100, 70, .08), 0 4px 8px rgba(120, 100, 70, .04);--shadow-xl: 0 24px 48px rgba(120, 100, 70, .1);--shadow-glow: 0 0 20px rgba(37, 99, 235, .08);--shadow-accent-glow: 0 0 20px rgba(217, 119, 6, .06);--color-text-primary: var(--color-text);--color-bg-primary: var(--color-bg-card);--color-bg-secondary: var(--color-bg-elevated);--color-bg-tertiary: var(--color-bg-hover);--bg-primary: var(--color-bg-card);--color-primary-bg: var(--color-primary-light);--color-primary-rgb: 37, 99, 235}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:var(--line-height-normal);letter-spacing:var(--letter-spacing-normal);color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition-normal),color var(--transition-normal)}h1,h2,h3,h4,h5,h6{letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background-color:var(--color-primary-light);color:var(--color-text)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-center{text-align:center}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}:focus-visible{outline:2.5px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(prefers-contrast:high){:root{--color-border: #94a3b8;--color-border-light: #cbd5e1;--color-text-muted: #94a3b8}[data-theme=light]{--color-border: #475569;--color-border-light: #64748b;--color-text-muted: #475569}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulseGlow{0%,to{box-shadow:var(--shadow-sm)}50%{box-shadow:var(--shadow-glow)}}.page-container{animation:fadeInUp .4s cubic-bezier(.4,0,.2,1)}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:box-shadow var(--transition-normal),border-color var(--transition-normal),transform var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.page-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text)}.page-header-description{color:var(--color-text-secondary);font-size:var(--font-size-md);margin-top:var(--spacing-xs)}.skip-nav{position:absolute;top:-100%;left:var(--spacing-md);z-index:9999;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-weight:var(--font-weight-medium);text-decoration:none;transition:top var(--transition-fast)}.skip-nav:focus{top:var(--spacing-md)}.card.study-field-card{transition:all var(--transition-fast);border:1px solid var(--color-border);background-color:transparent!important}.card.study-field-card:hover{border-color:var(--color-primary);background-color:transparent!important;box-shadow:0 2px 8px #0000001a}.card.study-field-expanded{border-color:var(--color-primary);background-color:transparent!important}.card.study-field-expanded:hover{background-color:transparent!important}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:var(--font-family);font-weight:var(--font-weight-medium);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:var(--font-size-sm)}.btn-md{padding:10px 20px;font-size:var(--font-size-md)}.btn-lg{padding:14px 28px;font-size:var(--font-size-lg)}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-bg-elevated);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-bg-hover)}.btn-outline{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary-light)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-bg-hover);color:var(--color-text)}.btn-block{width:100%}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.input-field{width:100%;padding:10px 14px;font-family:var(--font-family);font-size:var(--font-size-md);color:var(--color-text);background-color:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input-field::placeholder{color:var(--color-text-muted)}.input-field--error{border-color:var(--color-danger)}.input-field--error:focus{box-shadow:0 0 0 3px var(--color-danger-light)}.input-error-text{font-size:var(--font-size-xs);color:var(--color-danger)}.select-field{width:100%;padding:10px 36px 10px 14px;font-family:var(--font-family);font-size:var(--font-size-md);color:var(--color-text);background-color:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.select-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.card:hover{border-color:var(--color-border-light)}.card-clickable{cursor:pointer}.card-clickable:hover{box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;padding:2px 10px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);line-height:1.5}.badge-sm{padding:1px 6px;font-size:10px}.badge-default{background-color:var(--color-bg-elevated);color:var(--color-text-secondary)}.badge-primary{background-color:var(--color-primary-light);color:var(--color-primary)}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger)}.badge-info{background-color:var(--color-info-light);color:var(--color-info)}.spinner{display:inline-block;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.spinner-sm{width:16px;height:16px}.spinner-md{width:24px;height:24px}.spinner-lg{width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);animation:fadeIn .15s ease}.modal-content{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);max-height:90vh;overflow-y:auto;z-index:var(--z-modal);animation:slideUp .2s ease}.modal-sm{width:min(400px,90vw)}.modal-md{width:min(560px,90vw)}.modal-lg{width:min(800px,90vw)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:20px;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.modal-close:hover{color:var(--color-text);background-color:var(--color-bg-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--color-text-muted)}.empty-state-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.empty-state-description{font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg);max-width:360px}.error-message{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-danger-light);color:var(--color-danger);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.error-message-text{flex:1}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.page-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.page-header-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.page-container{max-width:1200px}.topic-card{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.topic-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.topic-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.topic-card-delete{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);font-size:var(--font-size-sm);line-height:1;transition:color var(--transition-fast),background-color var(--transition-fast)}.topic-card-delete:hover{color:var(--color-danger);background-color:var(--color-danger-light)}.topic-card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);line-height:1.4}.topic-card-category{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.topic-card-sub{color:var(--color-text-secondary)}.topic-card-progress{margin-top:var(--spacing-sm)}.topic-card-progress-bar{height:4px;background-color:var(--color-bg-tertiary);border-radius:2px;overflow:hidden;margin-bottom:var(--spacing-xs)}.topic-card-progress-fill{height:100%;background-color:var(--color-primary);border-radius:2px;transition:width var(--transition-normal)}.topic-card-progress-text{font-size:var(--font-size-xs);color:var(--color-text-muted)}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.topic-filters{margin-bottom:var(--spacing-lg)}.topic-filters-row{display:flex;gap:var(--spacing-sm);align-items:flex-end}.topic-filters-row>*{flex:1;min-width:0}.topic-filters-row>*:first-child{flex:2}.topic-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.topic-form-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);background-color:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--radius-md);line-height:1.6}.topic-form-success{text-align:center;padding:var(--spacing-xl)}.topic-form-success p{font-size:var(--font-size-md);color:var(--color-success);margin-bottom:var(--spacing-md)}.topic-board-filters{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-wrap:wrap}.topic-board-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text);font-size:var(--font-size-sm);min-width:120px}.topic-board-search{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text);font-size:var(--font-size-sm);flex:1;min-width:200px}.topic-board-search::placeholder{color:var(--color-text-muted)}.topic-board-count{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.topic-board-empty{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-muted);font-size:var(--font-size-md)}.topic-board-table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-md)}.topic-board-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm);table-layout:fixed}.topic-board-table thead{background:var(--color-bg-elevated);position:sticky;top:0;z-index:1}.topic-board-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:600;color:var(--color-text);border-bottom:2px solid var(--color-border);white-space:nowrap}.topic-board-table td{padding:var(--spacing-xs) var(--spacing-md);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:top;line-height:1.5}.topic-board-table tbody tr:hover{background:var(--color-bg-hover)}.col-no{width:50px;text-align:center}.col-category{width:80px}.col-title{width:180px}.col-definition{width:auto}.col-keywords{width:200px}.col-memo{width:180px}.col-no{text-align:center}.topic-board-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-primary-light);color:var(--color-primary);font-size:var(--font-size-xs);font-weight:500;white-space:nowrap}.topic-board-keyword{display:inline-block;padding:1px 6px;margin:1px 2px;border-radius:var(--radius-sm);background:var(--color-bg-elevated);border:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap}.col-definition,.col-memo{font-size:var(--font-size-xs);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis}.topic-board-row-clickable{cursor:pointer}.topic-board-row-clickable .col-title{color:var(--color-primary)}@media(max-width:768px){.topic-board-table{min-width:900px}}.study-category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.study-category-card{cursor:pointer;text-align:center;padding:var(--spacing-lg);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.study-category-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.study-category-icon{font-size:36px;margin-bottom:var(--spacing-sm)}.study-category-name{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.study-category-stats{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.study-category-empty{font-style:italic}.study-category-progress{height:4px;background-color:var(--color-bg-tertiary);border-radius:2px;overflow:hidden}.study-category-progress-fill{height:100%;background-color:var(--color-primary);border-radius:2px;transition:width var(--transition-normal)}.next-topic-card{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);background-color:var(--color-bg-secondary);border:1px solid var(--color-primary);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.next-topic-label{font-size:var(--font-size-xs);color:var(--color-primary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.next-topic-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:var(--spacing-xs) 0}.next-topic-status{font-size:var(--font-size-sm);color:var(--color-text-muted)}.recommend-action-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.recommend-count{font-size:var(--font-size-sm);color:var(--color-text-muted)}.recommend-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.recommend-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast)}.recommend-item:hover{border-color:var(--color-primary)}.recommend-item-selected{border-color:var(--color-primary);background-color:var(--color-primary-light)}.recommend-item-existing{opacity:.6;cursor:default}.recommend-item-existing:hover{border-color:var(--color-border)}.recommend-checkbox{padding-top:2px;flex-shrink:0}.recommend-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.recommend-existing-mark{color:var(--color-success);font-weight:700;font-size:var(--font-size-md)}.recommend-info{flex:1;min-width:0}.recommend-title-row{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.recommend-title{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.recommend-sub{font-size:var(--font-size-xs);color:var(--color-text-muted);display:block;margin-top:2px}.recommend-reason{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs);line-height:1.5}.stage-progress{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) 0;overflow-x:auto;margin-bottom:var(--spacing-md)}.stage-progress-step{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:60px;flex:1}.stage-progress-step .step-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);border:2px solid var(--color-border);color:var(--color-text-muted);background-color:var(--color-bg-secondary);transition:all var(--transition-fast)}.stage-step-completed .step-circle{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.stage-step-current .step-circle{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.stage-progress-step .step-label{font-size:10px;color:var(--color-text-muted);text-align:center;white-space:nowrap}.stage-step-completed .step-label,.stage-step-current .step-label{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.stage-nav{display:flex;gap:var(--spacing-xs);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-lg);overflow-x:auto}.stage-nav-tab{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast)}.stage-nav-tab:hover:not(:disabled){color:var(--color-text-primary)}.stage-nav-active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-medium)}.stage-nav-completed{color:var(--color-success)}.stage-nav-disabled{opacity:.4;cursor:not-allowed}.study-meta-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.study-meta-left,.study-meta-right{display:flex;align-items:center;gap:var(--spacing-sm)}.study-meta-item{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-xs)}.study-fields{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.study-field-card{cursor:pointer}.study-field-header{display:flex;align-items:center;gap:var(--spacing-sm)}.study-field-icon{font-size:var(--font-size-lg)}.study-field-label{flex:1;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.study-field-toggle{color:var(--color-text-muted);font-size:var(--font-size-sm)}.study-field-content{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.study-field-text{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:1.8;white-space:pre-wrap}.field-memo-section{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed var(--color-border)}.field-memo-input{width:100%;min-height:80px;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-input);color:var(--color-text);font-family:inherit;font-size:var(--font-size-sm);line-height:1.5;resize:vertical;box-sizing:border-box;transition:border-color .2s ease,background-color .2s ease}.field-memo-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-bg-card)}.field-memo-input::placeholder{color:var(--color-text-muted);opacity:.6}.study-keywords{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.study-keyword-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.study-sources-card{margin-bottom:var(--spacing-lg)}.study-sources-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.study-sources-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.source-link{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.source-link a{color:var(--color-primary);text-decoration:none}.source-link a:hover{text-decoration:underline}.study-actions{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.study-actions-completed{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);color:var(--color-success);font-weight:var(--font-weight-medium)}.ai-generation-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);z-index:var(--z-modal)}.ai-generation-content{text-align:center;padding:var(--spacing-2xl)}.ai-generation-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.ai-generation-message{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.ai-generation-time{font-size:var(--font-size-sm);color:var(--color-text-muted)}.ai-generation-pulse{width:8px;height:8px;background-color:var(--color-primary);border-radius:50%;margin:var(--spacing-md) auto 0;animation:ai-pulse 1.5s ease-in-out infinite}@keyframes ai-pulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(2);opacity:1}}.divider{display:flex;align-items:center;gap:var(--spacing-md);color:var(--color-text-muted);font-size:var(--font-size-sm)}.divider:before,.divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.insight-editor{display:flex;flex-direction:column;gap:var(--spacing-md)}.insight-toggle-bar{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-xs)}.insight-fields{display:flex;flex-direction:column;gap:var(--spacing-sm)}.insight-cases-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.insight-case-item{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-primary);border-left:3px solid var(--color-primary)}.comparison-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.comparison-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.comparison-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.comparison-table th,.comparison-table td{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);text-align:left;line-height:1.5}.comparison-table th{background:var(--color-bg-secondary);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap}.comparison-table td{color:var(--color-text-secondary)}.comparison-table tr:nth-child(2n) td{background:var(--color-bg-secondary)}.comparison-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;margin-top:var(--spacing-sm)}.memo-editor{display:flex;flex-direction:column}.memo-textarea{width:100%;min-height:160px;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);line-height:1.8;resize:vertical;transition:border-color var(--transition-fast)}.memo-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb, 99, 102, 241),.15)}.memo-textarea::placeholder{color:var(--color-text-muted)}.memo-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-xs);padding:0 var(--spacing-xs)}.memo-char-count,.memo-auto-save{font-size:var(--font-size-xs);color:var(--color-text-muted)}.memo-guide-card{background:var(--color-bg-secondary);border-left:3px solid var(--color-primary)}.memo-guide-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.memo-saving-indicator,.memo-saved-indicator{font-size:var(--font-size-xs);color:var(--color-text-muted);display:block;margin-top:var(--spacing-xs)}.memo-section-card{margin-bottom:var(--spacing-md)}.memo-section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.memo-actions-row{display:flex;gap:var(--spacing-md);justify-content:center}.memo-actions-row .btn{flex:1;max-width:250px}.image-uploader{display:flex;flex-direction:column;gap:var(--spacing-md)}.image-type-selector{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.image-type-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.image-type-tags{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.image-type-tag{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.image-type-tag:hover{border-color:var(--color-primary);color:var(--color-primary)}.image-type-tag-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.image-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-md);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.image-drop-zone:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 99, 102, 241),.05)}.image-drop-zone-active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 99, 102, 241),.1)}.image-drop-icon{font-size:2rem}.image-drop-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.image-drop-hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.image-drop-uploading{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-primary);font-size:var(--font-size-sm)}.image-limit-warning{font-size:var(--font-size-sm);color:var(--color-warning);text-align:center;padding:var(--spacing-sm)}.image-error{font-size:var(--font-size-sm);color:var(--color-danger);padding:var(--spacing-xs) var(--spacing-sm)}.image-gallery{display:flex;flex-direction:column;gap:var(--spacing-md)}.image-group-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-sm)}.image-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:1px solid var(--color-border)}.image-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-fast)}.image-thumb:hover .image-thumb-img{transform:scale(1.05)}.image-thumb-delete{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;opacity:0;transition:opacity var(--transition-fast)}.image-thumb:hover .image-thumb-delete{opacity:1}.image-lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-xl)}.image-lightbox-content{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.image-lightbox-img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-md)}.image-lightbox-info{display:flex;align-items:center;gap:var(--spacing-md);color:#fff;font-size:var(--font-size-sm)}.dashboard-greeting{margin-bottom:var(--spacing-xl);animation:fadeInUp .4s cubic-bezier(.4,0,.2,1)}.dashboard-greeting h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);color:var(--color-text);margin-bottom:var(--spacing-xs)}.dashboard-greeting-sub{font-size:var(--font-size-md);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.dashboard-greeting-accent{color:var(--color-accent);font-weight:var(--font-weight-semibold)}.dashboard-action-bar{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);animation:fadeInUp .4s .05s cubic-bezier(.4,0,.2,1) both}.dashboard-action-bar .btn-primary{position:relative;overflow:hidden}.dashboard-action-bar .btn-primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.1) 50%,transparent 60%);transform:translate(-100%);transition:transform .6s ease}.dashboard-action-bar .btn-primary:hover:after{transform:translate(100%)}.dashboard-summary{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.dashboard-mid-row{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.dashboard-card{min-height:0;position:relative;overflow:hidden}.dashboard-card:nth-child(1){animation:fadeInUp .4s .08s cubic-bezier(.4,0,.2,1) both}.dashboard-card:nth-child(2){animation:fadeInUp .4s .14s cubic-bezier(.4,0,.2,1) both}.dashboard-card:nth-child(3){animation:fadeInUp .4s .2s cubic-bezier(.4,0,.2,1) both}.dashboard-card:nth-child(4){animation:fadeInUp .4s .26s cubic-bezier(.4,0,.2,1) both}.dashboard-card-wide{min-width:0}.dashboard-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.dashboard-card-title-icon{font-size:var(--font-size-lg)}.dashboard-empty-text{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;padding:var(--spacing-xl) 0;line-height:var(--line-height-relaxed)}.dashboard-action-card{cursor:pointer;margin-bottom:var(--spacing-md);border-left:3px solid transparent;transition:all var(--transition-normal)}.dashboard-action-card:hover{border-left-color:var(--color-primary);transform:translate(2px)}.dashboard-action-card.has-items{border-left-color:var(--color-accent)}.dashboard-action-card.has-items:hover{border-left-color:var(--color-accent-hover);box-shadow:var(--shadow-accent-glow)}.dashboard-action-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.dashboard-action-info{flex:1;min-width:0}.dashboard-action-info h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-xs)}.dashboard-action-info p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.dashboard-action-badge{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);flex-shrink:0;transition:transform var(--transition-spring)}.dashboard-action-card:hover .dashboard-action-badge{transform:scale(1.08)}.dashboard-action-badge.warning{background:var(--color-warning-light);color:var(--color-warning)}.dashboard-action-badge.danger{background:var(--color-danger-light);color:var(--color-danger)}.dashboard-action-badge.success{background:var(--color-success-light);color:var(--color-success)}.donut-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.donut-chart{width:148px;height:148px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.donut-hole{width:104px;height:104px;border-radius:50%;background:var(--color-bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center}.donut-percentage{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1;font-variant-numeric:tabular-nums}.donut-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:4px;letter-spacing:var(--letter-spacing-wide)}.donut-legend{text-align:center}.donut-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.streak-widget{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) 0}.streak-main{display:flex;align-items:baseline;gap:var(--spacing-xs)}.streak-fire{font-size:1.75rem;line-height:1}.streak-number{font-size:var(--font-size-3xl, 2.5rem);font-weight:var(--font-weight-bold);color:var(--color-accent);line-height:1;font-variant-numeric:tabular-nums}.streak-unit{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.streak-today-done{font-size:var(--font-size-sm);color:var(--color-success);font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:var(--spacing-xs)}.streak-today-pending{font-size:var(--font-size-sm);color:var(--color-text-muted)}.dashboard-quick-stats{display:flex;justify-content:center;gap:var(--spacing-xl);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.dashboard-stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.dashboard-stat-number{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1}.dashboard-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);letter-spacing:var(--letter-spacing-wide)}.category-chart{display:flex;flex-direction:column;gap:var(--spacing-sm)}.category-chart-row{cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.category-chart-row:hover{background:var(--color-bg-hover)}.category-chart-label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:6px}.category-chart-icon{font-size:var(--font-size-sm);width:20px;text-align:center}.category-chart-name{font-size:var(--font-size-sm);color:var(--color-text-primary);flex:1;font-weight:var(--font-weight-medium)}.category-chart-count{font-size:var(--font-size-xs);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.category-chart-bar{height:6px;background:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden}.category-chart-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full);transition:width .6s cubic-bezier(.4,0,.2,1);min-width:2px}.stage-overview{display:flex;flex-direction:column;gap:var(--spacing-md)}.stage-stack-bar{display:flex;height:16px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-bg-secondary)}.stage-stack-segment{height:100%;transition:width .6s cubic-bezier(.4,0,.2,1);min-width:2px}.stage-legend{display:flex;flex-wrap:wrap;gap:var(--spacing-sm) var(--spacing-lg)}.stage-legend-item{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs)}.stage-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stage-legend-label{color:var(--color-text-secondary)}.stage-legend-count{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.recent-activity{display:flex;flex-direction:column}.recent-activity-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-sm);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.recent-activity-item:hover{background:var(--color-bg-secondary)}.recent-activity-item+.recent-activity-item{border-top:1px solid var(--color-border)}.recent-activity-icon{font-size:var(--font-size-lg);flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-elevated);border-radius:var(--radius-md)}.recent-activity-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.recent-activity-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-activity-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}.dashboard-today-progress{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:linear-gradient(135deg,var(--color-primary-light),var(--color-accent-light));border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border);animation:fadeInUp .4s .1s cubic-bezier(.4,0,.2,1) both}.dashboard-today-progress-info{flex:1}.dashboard-today-progress-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin-bottom:var(--spacing-xs)}.dashboard-today-progress-bar{height:8px;background:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden}.dashboard-today-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full);transition:width .8s cubic-bezier(.4,0,.2,1)}.dashboard-today-progress-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.dashboard-today-progress-number{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);font-variant-numeric:tabular-nums;line-height:1;flex-shrink:0}.quiz-start-card,.practice-start-card,.quiz-session{margin-top:var(--spacing-lg)}.quiz-progress-bar{height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-xs)}.quiz-progress-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s ease}.quiz-progress-text{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.quiz-question-card{padding:var(--spacing-lg)}.quiz-q{display:flex;flex-direction:column;gap:var(--spacing-md)}.quiz-type-badge{display:inline-block;padding:2px 10px;background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);width:fit-content}.quiz-q-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.5}.quiz-ox-options{display:flex;gap:var(--spacing-md)}.quiz-ox-btn{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);font-size:var(--font-size-lg);cursor:pointer;transition:all .2s ease}.quiz-ox-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-bg)}.quiz-ox-selected{border-color:var(--color-primary);background:var(--color-primary-bg)}.quiz-ox-correct{border-color:var(--color-success)!important;background:#22c55e1a!important}.quiz-ox-wrong{border-color:var(--color-danger)!important;background:#ef44441a!important}.quiz-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quiz-context{font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic;padding:var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.quiz-text-input{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:var(--font-size-md);transition:border-color .2s ease}.quiz-text-input:focus{outline:none;border-color:var(--color-primary)}.quiz-text-input:disabled{opacity:.7}.quiz-matching{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quiz-matching-row{display:flex;align-items:center;gap:var(--spacing-md)}.quiz-matching-term{flex:1;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.quiz-matching-select,.quiz-ordering-select{flex:1;padding:var(--spacing-xs) var(--spacing-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-size:var(--font-size-sm)}.quiz-ordering{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quiz-ordering-hint{font-size:var(--font-size-sm);color:var(--color-text-muted)}.quiz-ordering-row{display:flex;align-items:center;gap:var(--spacing-sm)}.quiz-ordering-num{font-weight:var(--font-weight-bold);color:var(--color-primary);min-width:24px}.quiz-feedback{padding:var(--spacing-md);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.quiz-feedback-correct{background:#22c55e1a;border:1px solid var(--color-success)}.quiz-feedback-wrong{background:#ef44441a;border:1px solid var(--color-danger)}.quiz-correct-answer{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.quiz-explanation{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.quiz-nav{display:flex;justify-content:space-between;margin-top:var(--spacing-lg);gap:var(--spacing-md)}.quiz-result{margin-top:var(--spacing-lg)}.quiz-result-summary{text-align:center;padding:var(--spacing-xl)}.quiz-result-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-md)}.quiz-result-score{display:flex;align-items:baseline;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.quiz-result-number{font-size:3rem;font-weight:var(--font-weight-bold);color:var(--color-primary)}.quiz-result-divider{font-size:1.5rem;color:var(--color-text-muted)}.quiz-result-total{font-size:1.5rem;color:var(--color-text-secondary)}.quiz-result-rate{font-size:var(--font-size-lg);color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.quiz-result-actions{display:flex;justify-content:center;gap:var(--spacing-md)}.quiz-review-card{margin-top:var(--spacing-sm);padding:var(--spacing-md)}.quiz-review-correct{border-left:3px solid var(--color-success)}.quiz-review-wrong{border-left:3px solid var(--color-danger)}.quiz-review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-semibold)}.practice-mode-select{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.practice-mode-card{transition:all .2s ease}.practice-mode-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.practice-mode-content{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md)}.practice-mode-icon{font-size:2rem;flex-shrink:0}.practice-mode-info{flex:1}.practice-mode-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:4px}.practice-mode-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.practice-mode-arrow{font-size:var(--font-size-xl);color:var(--color-text-muted);flex-shrink:0}.practice-field-select{margin-top:var(--spacing-lg)}.practice-section-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.practice-section-header h3{font-size:var(--font-size-md);color:var(--color-text-primary)}.practice-group-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin:var(--spacing-lg) 0 var(--spacing-sm)}.practice-field-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sm)}.practice-field-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);transition:all .2s ease}.practice-field-item:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a;border-color:var(--color-primary)}.practice-field-icon{font-size:1.2rem}.practice-field-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.practice-question-guide{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.practice-original-card{padding:var(--spacing-md) var(--spacing-lg);border-left:3px solid var(--color-warning)}.practice-original-card h4{margin-bottom:var(--spacing-sm)}.practice-original-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.7;white-space:pre-wrap}.practice-session{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.practice-question-card{padding:var(--spacing-lg)}.practice-question-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.practice-question-type{display:inline-block;padding:2px 10px;background:var(--color-primary-bg);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.practice-difficulty{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.practice-difficulty-easy{background:#22c55e1a;color:var(--color-success)}.practice-difficulty-medium{background:#eab3081a;color:var(--color-warning)}.practice-difficulty-hard{background:#ef44441a;color:var(--color-danger)}.practice-question-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.6}.practice-hints{margin-top:var(--spacing-md)}.practice-hints-toggle{background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);transition:all .2s ease}.practice-hints-toggle:hover{background:var(--color-bg-tertiary)}.practice-hints-list{margin-top:var(--spacing-sm);padding-left:var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6}.practice-keywords{margin-top:var(--spacing-md);display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm)}.practice-keywords-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.practice-keywords-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.practice-keyword-tag{display:inline-block;padding:2px 8px;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:var(--font-size-xs)}.practice-keyword-missing{background:#ef44441a;color:var(--color-danger)}.practice-answer-card{padding:var(--spacing-lg)}.practice-answer-title{margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.practice-textarea{width:100%;min-height:160px;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-family:inherit;font-size:var(--font-size-md);line-height:1.7;resize:vertical;transition:border-color .2s ease;box-sizing:border-box}.practice-textarea:focus{outline:none;border-color:var(--color-primary)}.practice-textarea::placeholder{color:var(--color-text-muted);opacity:.6}.practice-answer-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-md)}.practice-char-count{font-size:var(--font-size-sm);color:var(--color-text-muted)}.practice-min-warning{font-size:var(--font-size-xs);color:var(--color-warning);margin-top:var(--spacing-xs)}.practice-evaluating-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);z-index:100;color:#fff;font-size:var(--font-size-lg)}.practice-result{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.practice-score-card{text-align:center;padding:var(--spacing-xl)}.practice-result-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-md)}.practice-score-main{display:flex;align-items:baseline;justify-content:center;gap:var(--spacing-xs)}.practice-score-number{font-size:3.5rem;font-weight:var(--font-weight-bold)}.practice-score-max{font-size:1.5rem;color:var(--color-text-muted)}.practice-score-label{display:block;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-lg)}.practice-score-breakdown{text-align:left;max-width:400px;margin:0 auto var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.practice-score-item{display:flex;flex-direction:column;gap:4px}.practice-score-item-header{display:flex;justify-content:space-between;align-items:center}.practice-score-item-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.practice-score-item-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.practice-score-bar{height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.practice-score-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease}.practice-score-item-comment{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.4}.practice-result-actions{display:flex;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-md)}.practice-feedback-card{padding:var(--spacing-md) var(--spacing-lg)}.practice-feedback-card h4{margin-bottom:var(--spacing-sm);font-size:var(--font-size-md)}.practice-feedback-card ul{padding-left:var(--spacing-lg);margin:0}.practice-feedback-card li{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.practice-feedback-good{border-left:3px solid var(--color-success)}.practice-feedback-weak{border-left:3px solid var(--color-danger)}.practice-feedback-improve{border-left:3px solid var(--color-info)}.practice-missing-keywords{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.practice-model-card{padding:var(--spacing-md) var(--spacing-lg);border-left:3px solid var(--color-primary)}.practice-model-card h4{margin-bottom:var(--spacing-sm)}.practice-model-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.7;white-space:pre-wrap}.practice-my-answer-card{padding:var(--spacing-md) var(--spacing-lg);opacity:.8}.practice-my-answer-card h4{margin-bottom:var(--spacing-sm)}.practice-my-answer-text{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.7;white-space:pre-wrap}.analytics-two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.analytics-calendar{overflow-x:auto;padding:var(--spacing-sm) 0}.analytics-calendar-cell:hover{opacity:.8}.analytics-accuracy-row{padding:var(--spacing-xs) 0}.analytics-accuracy-label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.analytics-accuracy-name{flex:1;color:var(--color-text)}.analytics-accuracy-value{font-size:var(--font-size-xs);color:var(--color-text-muted)}.analytics-accuracy-bar{height:8px;background:var(--color-bg-elevated);border-radius:var(--radius-full);overflow:hidden}.analytics-accuracy-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease;min-width:2px}.analytics-mastery-stack{display:flex;height:24px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-bg-elevated);margin-bottom:var(--spacing-md)}.analytics-mastery-segment{height:100%;transition:width .5s ease;min-width:2px}.analytics-mastery-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.analytics-mastery-item{display:flex;align-items:center;gap:var(--spacing-sm)}.analytics-mastery-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.analytics-mastery-info{flex:1;display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-sm)}.analytics-stage-row{padding:var(--spacing-xs) 0}.analytics-stage-label{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.analytics-stage-name{flex:1;color:var(--color-text)}.analytics-stage-count{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted)}.analytics-stage-bar{display:flex;height:16px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-bg-elevated)}.analytics-stage-segment{height:100%;transition:width .5s ease;min-width:2px}.fc-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.fc-stat-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);background:var(--bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.fc-stat-value{font-size:1.75rem;font-weight:700;color:var(--color-text-primary)}.fc-stat-due .fc-stat-value{color:var(--color-warning)}.fc-stat-mastered .fc-stat-value{color:var(--color-success)}.fc-stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px}.fc-review-cta{margin-bottom:var(--spacing-lg);border-left:4px solid var(--color-primary)}.fc-review-cta-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.fc-review-cta-left{display:flex;align-items:center;gap:var(--spacing-md)}.fc-review-cta-icon{font-size:1.5rem}.fc-review-cta-title{margin:0;font-size:var(--font-size-md);font-weight:600}.fc-review-cta-desc{margin:2px 0 0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.fc-section{margin-bottom:var(--spacing-xl)}.fc-section-title{font-size:var(--font-size-lg);margin:0 0 var(--spacing-md)}.fc-section-desc{color:var(--color-text-muted);font-size:var(--font-size-sm);margin:0 0 var(--spacing-md)}.fc-deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-md)}.fc-deck-card{position:relative;display:flex;flex-direction:column;gap:var(--spacing-xs)}.fc-deck-card-new{border-style:dashed}.fc-deck-delete{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.1rem;padding:2px 6px;border-radius:var(--radius-sm);line-height:1}.fc-deck-delete:hover{color:var(--color-danger);background:var(--color-bg-hover)}.fc-deck-title{font-size:var(--font-size-md);font-weight:600;margin:0;padding-right:var(--spacing-lg);line-height:1.4}.fc-deck-meta{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-muted)}.fc-deck-due-badge{display:inline-block;padding:1px 8px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-warning) 15%,transparent);color:var(--color-warning);font-size:var(--font-size-xs);font-weight:500}.fc-deck-done-badge{display:inline-block;padding:1px 8px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success);font-size:var(--font-size-xs);font-weight:500}.fc-deck-progress{height:4px;border-radius:var(--radius-full);background:var(--color-bg-hover);overflow:hidden;margin:var(--spacing-xs) 0}.fc-deck-progress-fill{height:100%;background:var(--color-success);border-radius:var(--radius-full);transition:width .3s ease}.fc-deck-status{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--spacing-sm)}.fc-deck-actions{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.fc-empty-state{text-align:center;padding:var(--spacing-2xl)}.fc-empty-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.fc-empty-title{margin:0 0 var(--spacing-sm)}.fc-empty-desc{color:var(--color-text-muted);margin:0 0 var(--spacing-lg)}.fcs-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.fcs-counter{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500}.fcs-progress{height:6px;border-radius:var(--radius-full);background:var(--color-bg-hover);margin-bottom:var(--spacing-lg);overflow:hidden}.fcs-progress-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width .3s ease}.fcs-topic-label{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);margin:0 0 var(--spacing-sm)}.fcs-card-container{perspective:1000px;width:100%;max-width:560px;margin:0 auto;min-height:280px;cursor:pointer}.fcs-card-inner{position:relative;width:100%;min-height:280px;transition:transform .5s ease;transform-style:preserve-3d}.fcs-card-flipped{transform:rotateY(180deg)}.fcs-card-face{position:absolute;top:0;left:0;width:100%;min-height:280px;backface-visibility:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-xl) var(--spacing-lg);border-radius:var(--radius-lg);border:2px solid var(--color-border);background:var(--bg-primary);box-sizing:border-box}.fcs-card-front{background:linear-gradient(145deg,var(--bg-primary),var(--color-bg-hover))}.fcs-card-back{transform:rotateY(180deg);background:linear-gradient(145deg,var(--color-bg-hover),var(--bg-primary));border-color:var(--color-primary)}.fcs-card-type{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.fcs-card-question{text-align:center;line-height:1.6;font-size:1.15rem;margin:0;font-weight:600}.fcs-card-hint{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-lg);opacity:.7}.fcs-card-answer{text-align:center;line-height:1.8;font-size:var(--font-size-md);white-space:pre-wrap;max-height:200px;overflow-y:auto;width:100%;padding:0 var(--spacing-sm)}.fcs-rating-buttons{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-xl)}.fcs-rate-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--bg-primary);cursor:pointer;transition:all .2s ease;min-width:100px}.fcs-rate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.fcs-rate-btn:disabled{opacity:.5;cursor:not-allowed}.fcs-rate-emoji{font-size:1.5rem}.fcs-rate-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.fcs-rate-fail{border-color:color-mix(in srgb,var(--color-danger) 40%,transparent)}.fcs-rate-fail:hover:not(:disabled){border-color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 8%,transparent)}.fcs-rate-hard{border-color:color-mix(in srgb,var(--color-warning) 40%,transparent)}.fcs-rate-hard:hover:not(:disabled){border-color:var(--color-warning);background:color-mix(in srgb,var(--color-warning) 8%,transparent)}.fcs-rate-easy{border-color:color-mix(in srgb,var(--color-success) 40%,transparent)}.fcs-rate-easy:hover:not(:disabled){border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 8%,transparent)}.fcs-result{text-align:center;max-width:420px;margin:0 auto;padding:var(--spacing-xl) 0}.fcs-result-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.fcs-result-title{margin:0 0 var(--spacing-xs)}.fcs-result-subtitle{color:var(--color-text-muted);margin:0 0 var(--spacing-lg)}.fcs-result-ring{position:relative;width:120px;height:120px;margin:0 auto var(--spacing-lg)}.fcs-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.fcs-ring-bg{fill:none;stroke:var(--color-bg-hover);stroke-width:8}.fcs-ring-fill{fill:none;stroke:var(--color-success);stroke-width:8;stroke-linecap:round;transition:stroke-dasharray .6s ease}.fcs-ring-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.fcs-result-stats{display:flex;justify-content:center;gap:var(--spacing-2xl);margin-bottom:var(--spacing-lg)}.fcs-result-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.fcs-result-stat-value{font-size:1.5rem;font-weight:700}.fcs-stat-correct .fcs-result-stat-value{color:var(--color-success)}.fcs-stat-incorrect .fcs-result-stat-value{color:var(--color-danger)}.fcs-result-stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.fcs-result-actions{display:flex;gap:var(--spacing-sm);justify-content:center}.app-layout{display:flex;min-height:100vh}.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0}.main-content{flex:1;padding:var(--spacing-lg);max-width:var(--content-max-width);width:100%;margin:0 auto}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;top:0;left:0;z-index:var(--z-fixed);background-color:var(--color-bg-card);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:transform var(--transition-normal);overflow-y:auto}.has-sidebar .main-wrapper{margin-left:var(--sidebar-width)}.header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);background-color:var(--color-bg-card);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:var(--z-sticky);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background-color:var(--color-bg-card);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-around;z-index:var(--z-fixed);padding-bottom:env(safe-area-inset-bottom,0);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs);color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-md);transition:color var(--transition-fast);min-width:44px;min-height:44px;justify-content:center}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-icon{font-size:22px}.bottom-nav{display:none}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.has-sidebar .main-wrapper{margin-left:0}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:calc(var(--z-fixed) - 1);opacity:0;pointer-events:none;transition:opacity var(--transition-normal)}.sidebar-overlay.visible{opacity:1;pointer-events:auto}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.has-sidebar .main-wrapper{margin-left:0}.bottom-nav{display:flex}.main-content{padding:var(--spacing-md);padding-bottom:calc(var(--bottom-nav-height) + var(--spacing-md))}.page-title{font-size:var(--font-size-lg)}.card{padding:var(--spacing-md)}.header-menu-btn{display:flex}.topic-filters-row{flex-direction:column}.topic-filters-row>*:first-child{flex:1}.topic-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.study-category-grid{grid-template-columns:repeat(2,1fr)}.next-topic-card{flex-direction:column;gap:var(--spacing-md);text-align:center}.recommend-action-bar{flex-direction:column;gap:var(--spacing-sm);text-align:center}.study-meta-bar{flex-direction:column;align-items:flex-start}.study-actions-completed{flex-direction:column;text-align:center}}@media(min-width:1025px){.header-menu-btn{display:none}}.sidebar-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);letter-spacing:var(--letter-spacing-tight)}.sidebar-logo-icon{font-size:26px}.sidebar-nav{flex:1;padding:var(--spacing-md)}.sidebar-nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-md);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:2px;min-height:44px}.sidebar-nav-item:hover{background-color:var(--color-bg-hover);color:var(--color-text)}.sidebar-nav-item.active{background-color:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-medium);border-left:3px solid var(--color-primary)}.sidebar-nav-icon{font-size:20px;width:24px;text-align:center}.sidebar-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border)}.sidebar-profile{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.sidebar-user-email{font-size:var(--font-size-xs);color:var(--color-text-muted)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.header-menu-btn{background:none;border:none;color:var(--color-text);font-size:22px;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-md);align-items:center;justify-content:center;min-width:44px;min-height:44px;display:flex}.header-menu-btn:hover{background-color:var(--color-bg-hover)}.header-theme-btn{background:none;border:none;color:var(--color-text-secondary);font-size:20px;cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.header-theme-btn:hover{background-color:var(--color-bg-hover);color:var(--color-text)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background-color:var(--color-bg)}.login-card{width:min(440px,100%);padding:var(--spacing-xl)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm);letter-spacing:var(--letter-spacing-tight)}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-google-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:14px;font-size:var(--font-size-md);font-weight:var(--font-weight-medium);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);min-height:48px}.login-google-btn:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.login-google-btn:active{transform:translateY(0)}.login-toggle{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.login-toggle-link{color:var(--color-primary);cursor:pointer;font-weight:var(--font-weight-medium)}.login-toggle-link:hover{text-decoration:underline}@media(max-width:768px){.comparison-table{font-size:var(--font-size-xs)}.comparison-table th,.comparison-table td{padding:var(--spacing-xs) var(--spacing-sm)}.memo-textarea{min-height:120px;font-size:var(--font-size-sm)}.memo-actions-row{flex-direction:column;align-items:stretch}.memo-actions-row .btn{max-width:none}.image-type-selector{flex-direction:column;align-items:flex-start}.image-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.image-drop-zone{padding:var(--spacing-lg) var(--spacing-sm)}.image-lightbox{padding:var(--spacing-sm)}.image-lightbox-img{max-height:70vh}.dashboard-summary,.dashboard-mid-row{grid-template-columns:1fr}.dashboard-quick-stats{gap:var(--spacing-md)}.donut-chart{width:120px;height:120px}.donut-hole{width:84px;height:84px}.stage-legend{gap:var(--spacing-xs) var(--spacing-sm)}.dashboard-greeting h1{font-size:var(--font-size-xl)}.quiz-ox-options{flex-direction:column}.quiz-matching-row{flex-direction:column;align-items:stretch}.quiz-nav{flex-direction:column}.quiz-result-actions{flex-direction:column;align-items:center}.practice-textarea{min-height:200px}.practice-answer-footer{flex-direction:column;gap:var(--spacing-sm);align-items:stretch}.practice-score-breakdown{max-width:100%}.practice-result-actions{flex-direction:column;align-items:center}.practice-keywords{flex-direction:column;align-items:flex-start}.practice-field-grid{grid-template-columns:repeat(2,1fr)}.practice-mode-content{flex-direction:column;text-align:center}.practice-mode-arrow{display:none}.analytics-two-col{grid-template-columns:1fr}}.sidebar-nav-item:focus-visible,.bottom-nav-item:focus-visible,.header-menu-btn:focus-visible,.header-theme-btn:focus-visible,.login-google-btn:focus-visible{outline:2.5px solid var(--color-primary);outline-offset:2px}@media(pointer:coarse){.btn,.sidebar-nav-item,.bottom-nav-item,.header-menu-btn,.header-theme-btn{min-height:48px;min-width:48px}.dashboard-action-card:active{transform:scale(.98)}.category-chart-row:active{background:var(--color-bg-hover)}}@media(prefers-contrast:high){.card{border-width:2px}.sidebar-nav-item.active{border-left-width:4px;font-weight:var(--font-weight-bold)}.bottom-nav-item.active{font-weight:var(--font-weight-bold);text-decoration:underline}.dashboard-action-card.has-items{border-left-width:4px}.stage-stack-bar{border:1px solid var(--color-border)}.donut-chart{border:2px solid var(--color-border)}}@media print{.sidebar,.header,.bottom-nav,.dashboard-action-bar,.skip-nav{display:none!important}.has-sidebar .main-wrapper{margin-left:0!important}.main-content{padding:0!important;max-width:none!important}.card{border:1px solid #ccc;box-shadow:none!important;break-inside:avoid}body{background:#fff!important;color:#000!important}}.api-usage-loading{display:flex;justify-content:center;padding:var(--spacing-lg)}.api-usage-card{display:flex;flex-direction:column;gap:var(--spacing-md)}.api-usage-month-nav{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.api-usage-nav-btn{background:var(--color-bg-elevated);border:1px solid var(--color-border);color:var(--color-text-secondary);width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);transition:all .15s ease}.api-usage-nav-btn:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text)}.api-usage-nav-btn:disabled{opacity:.3;cursor:not-allowed}.api-usage-month-label{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);min-width:120px;text-align:center}.api-usage-empty{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-lg) 0}.api-usage-summary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-sm)}.api-usage-stat{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-bg-elevated);border-radius:var(--radius-md)}.api-usage-stat-value{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.api-usage-cost .api-usage-stat-value{color:var(--color-accent)}.api-usage-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.api-usage-breakdown{margin-top:var(--spacing-xs)}.api-usage-breakdown-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.api-usage-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.api-usage-table th{text-align:left;color:var(--color-text-muted);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--color-border)}.api-usage-table th:not(:first-child){text-align:right}.api-usage-table td{padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-text);border-bottom:1px solid var(--color-border)}.api-usage-table td:not(:first-child){text-align:right;color:var(--color-text-secondary)}.api-usage-cost-detail{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--color-bg-elevated);border-radius:var(--radius-md)}.api-usage-cost-row{display:flex;justify-content:space-between;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.api-usage-projections{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--color-text-muted);padding-top:var(--spacing-xs);border-top:1px solid var(--color-border)}@media(max-width:480px){.api-usage-summary{grid-template-columns:1fr}.api-usage-stat{flex-direction:row;justify-content:space-between}}
