:root{--color-primary: #2563EB;--color-primary-dark: #1D4ED8;--color-primary-light: #DBEAFE;--color-surface: #FFFFFF;--color-bg: #F8FAFC;--color-sidebar: #1E293B;--color-sidebar-text: #E2E8F0;--color-sidebar-hover: #334155;--color-sidebar-active: #2563EB;--color-text: #1E293B;--color-text-secondary: #64748B;--color-text-muted: #94A3B8;--color-border: #E2E8F0;--color-success: #16A34A;--color-warning: #D97706;--color-danger: #DC2626;--sidebar-width: 240px;--topbar-height: 56px;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;font-size:16px}.app-layout{display:flex;min-height:100vh}.app-main-area{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width);min-height:100vh}.main-content{flex:1;max-width:1100px;margin:0 auto;padding:2rem;width:100%}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--color-sidebar);color:var(--color-sidebar-text);display:flex;flex-direction:column;z-index:100;overflow-y:auto}.sidebar-brand{padding:1.25rem 1.25rem 1rem}.sidebar-brand a{font-size:1.375rem;font-weight:700;color:#fff;text-decoration:none;letter-spacing:.02em}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.125rem;padding:.5rem .75rem}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:var(--radius-md);color:var(--color-sidebar-text);text-decoration:none;font-size:.9375rem;font-weight:500;transition:background .15s,color .15s}.sidebar-nav-item:hover{background:var(--color-sidebar-hover);color:#fff}.sidebar-nav-item.active{background:var(--color-sidebar-active);color:#fff}.sidebar-nav-item svg{flex-shrink:0;opacity:.8}.sidebar-nav-item.active svg,.sidebar-nav-item:hover svg{opacity:1}.topbar{position:sticky;top:0;height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;z-index:50}.topbar-left{display:flex;align-items:center}.topbar-right{display:flex;align-items:center;gap:.75rem}.topbar-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8125rem;cursor:pointer;border:none;padding:0;transition:box-shadow .15s}.topbar-avatar:hover{box-shadow:0 0 0 2px var(--color-primary-light)}.topbar-profile{position:relative}.topbar-profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000026;z-index:200;padding:.5rem 0}.topbar-profile-info{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem}.topbar-profile-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.topbar-profile-name{font-weight:600;font-size:.875rem}.topbar-profile-roles{font-size:.75rem;color:var(--color-text-muted)}.topbar-profile-divider{height:1px;background:var(--color-border);margin:.25rem 0}.topbar-profile-logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem 1rem;background:transparent;border:none;color:var(--color-text);cursor:pointer;font-size:.875rem;text-align:left}.topbar-profile-logout:hover{background:var(--color-bg)}.sidebar-mobile-toggle{display:none;position:fixed;top:.75rem;left:.75rem;z-index:200;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.5rem;cursor:pointer;box-shadow:var(--shadow-md);color:var(--color-text)}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .25s ease}.sidebar--open{transform:translate(0)}.app-main-area{margin-left:0}.sidebar-mobile-toggle{display:flex}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:99}.main-content{padding:3.5rem 1rem 2rem}}.notification-bell{position:relative;padding:.25rem .5rem}.notification-bell>button{background:transparent;border:none;color:var(--color-text);cursor:pointer;font-size:1.25rem;padding:.375rem .5rem;border-radius:var(--radius-sm);position:relative;transition:background .15s;display:flex;align-items:center}.notification-bell>button:hover{background:var(--color-bg)}.notification-badge{position:absolute;top:0;right:0;min-width:18px;height:18px;background:var(--color-danger);color:#fff;border-radius:9999px;font-size:.6875rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;overflow-y:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000026;z-index:200;color:var(--color-text)}.notification-dropdown-header{padding:.75rem 1rem;font-weight:600;font-size:.875rem;border-bottom:1px solid var(--color-border)}.notification-empty{padding:2rem 1.5rem;text-align:center;color:var(--color-text-secondary);font-size:.875rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.notification-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .1s}.notification-item-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.notification-item-icon--success{background:#dcfce7;color:#16a34a}.notification-item-icon--error{background:#fee2e2;color:#dc2626}.notification-item-icon--info{background:var(--color-primary-light);color:var(--color-primary)}.notification-item-content{flex:1;min-width:0}.notification-item:hover{background:var(--color-bg)}.notification-item:last-child{border-bottom:none}.notification-item--unread{background:var(--color-primary-light)}.notification-item--unread:hover{background:#c7d9f7}.notification-item-title{font-size:.875rem;font-weight:600;margin-bottom:.125rem}.notification-item-message{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.4}.notification-item-time{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.notification-mark-all{display:block;width:100%;text-align:center;padding:.625rem;background:var(--color-bg);border:none;border-top:1px solid var(--color-border);color:var(--color-primary);font-size:.8125rem;font-weight:600;cursor:pointer;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.notification-mark-all:hover{background:var(--color-primary-light)}button{padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .15s;font-family:inherit}button:hover{background:var(--color-bg)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn-danger{color:var(--color-danger);border-color:var(--color-danger)}.btn-danger:hover{background:#fef2f2}.btn-with-icon{display:inline-flex;align-items:center;gap:.375rem;text-decoration:none}.btn-icon{padding:.25rem .5rem;font-size:1.25rem;line-height:1;border:none;background:transparent}.btn-export{background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-primary)}.btn-export:hover{background:var(--color-primary-light)}.btn-export:disabled{opacity:.5;cursor:not-allowed}.btn-approve{padding:.25rem .75rem;font-size:.8125rem;background:#dcfce7;color:#166534;border:1px solid #bbf7d0;border-radius:var(--radius-sm);cursor:pointer;font-weight:500}.btn-approve:hover{background:#bbf7d0}.btn-reject{padding:.25rem .75rem;font-size:.8125rem;background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:var(--radius-sm);cursor:pointer;font-weight:500}.btn-reject:hover{background:#fecaca}.page h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.subtitle{color:var(--color-text-secondary);font-size:1.125rem;margin-bottom:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header .btn-primary{text-decoration:none;display:inline-flex;align-items:center}.home-hero{text-align:center;padding:3rem 1rem 2.5rem;max-width:640px;margin:0 auto}.home-hero-title{font-size:3rem;font-weight:800;color:var(--color-primary);margin-bottom:.5rem;letter-spacing:.02em}.home-hero-tagline{font-size:1.25rem;font-weight:600;color:var(--color-text);margin-bottom:.75rem}.home-hero-subtitle{font-size:1rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:1.5rem}.btn-lg{padding:.75rem 2rem;font-size:1rem}.home-features{max-width:960px;margin:0 auto 2.5rem;padding:0 1rem}.home-features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.home-feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:box-shadow .15s}.home-feature-card:hover{box-shadow:0 2px 8px #00000014}.home-feature-card svg{margin-bottom:.75rem}.home-feature-card h3{font-size:1rem;font-weight:600;margin-bottom:.5rem}.home-feature-card p{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.5}.home-recent{max-width:960px;margin:0 auto 2rem;padding:0 1rem}.home-recent h2{font-size:1.25rem;font-weight:600;margin-bottom:1rem}.home-recent-link{display:inline-block;margin-top:1rem;font-size:.875rem;color:var(--color-primary);font-weight:600;text-decoration:none}.home-recent-link:hover{text-decoration:underline}.loading,.not-authenticated,.forbidden{text-align:center;padding:3rem;color:var(--color-text-secondary)}.not-authenticated h2,.forbidden h2{margin-bottom:.5rem}.not-authenticated p,.forbidden p{color:var(--color-text-secondary);margin-bottom:1rem}.error{padding:2rem;text-align:center;color:var(--color-danger)}.empty-state{padding:3rem;text-align:center;color:var(--color-text-secondary);background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg)}.error-banner{padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;color:var(--color-danger);border-radius:var(--radius-sm);font-size:.875rem;margin-bottom:1rem}.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.deck-card{display:block;padding:1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s;box-shadow:var(--shadow-sm)}.deck-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #2563eb1a}.deck-card h3{margin-bottom:.25rem;font-weight:600}.deck-description{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:.5rem}.deck-meta{display:flex;gap:.75rem;font-size:.8rem;color:var(--color-text-secondary);margin-top:.5rem;align-items:center}.deck-study-link{margin-left:auto;color:var(--color-primary);font-weight:600;cursor:pointer}.deck-study-link:hover{text-decoration:underline}.deck-visibility{padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600}.visibility-public{background:#dcfce7;color:#166534}.visibility-listed{background:var(--color-primary-light);color:var(--color-primary-dark)}.visibility-restricted{background:#fef9c3;color:#854d0e}.deck-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.tag{padding:.125rem .5rem;background:var(--color-primary-light);color:var(--color-primary);border-radius:.25rem;font-size:.75rem;font-weight:500}.back-link{display:inline-block;color:var(--color-text-secondary);text-decoration:none;margin-bottom:1rem;font-size:.875rem}.back-link:hover{color:var(--color-primary)}.deck-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.deck-actions{display:flex;gap:.5rem;flex-wrap:wrap}.deck-settings-section{padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.5rem}.visibility-selector{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.visibility-selector>label{font-size:.875rem;font-weight:600;color:var(--color-text)}.visibility-buttons{display:flex;gap:.375rem}.visibility-btn{padding:.375rem .75rem;border-radius:9999px;font-size:.8125rem;font-weight:500;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.visibility-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.visibility-btn.active{font-weight:600}.visibility-btn.active.visibility-public{background:#dcfce7;color:#166534;border-color:#bbf7d0}.visibility-btn.active.visibility-listed{background:var(--color-primary-light);color:var(--color-primary-dark);border-color:var(--color-primary)}.visibility-btn.active.visibility-restricted{background:#fef9c3;color:#854d0e;border-color:#fde68a}.sharing-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.btn-share-toggle{font-size:.8125rem;padding:.375rem .75rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn-share-toggle:hover{color:var(--color-primary);border-color:var(--color-primary)}.sharing-panel{margin-top:.75rem}.share-input-row{display:flex;gap:.5rem}.share-input-row input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit}.share-input-row input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb26}.shares-list{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.share-item{display:flex;align-items:center;justify-content:space-between;padding:.375rem .5rem;background:var(--color-bg);border-radius:var(--radius-sm);font-size:.875rem}.shares-empty{font-size:.8125rem;color:var(--color-text-muted);margin-top:.5rem}.visibility-options{display:flex;flex-direction:column;gap:.5rem}.visibility-option{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s,background .15s}.visibility-option:hover{border-color:var(--color-primary)}.visibility-option.selected{border-color:var(--color-primary);background:var(--color-primary-light)}.visibility-option input[type=radio]{margin-top:.125rem;accent-color:var(--color-primary)}.visibility-option-label{font-weight:600;font-size:.875rem;display:block}.visibility-option-desc{font-size:.8125rem;color:var(--color-text-secondary);display:block}.generation-progress-banner{padding:1rem 1.25rem;background:var(--color-primary-light);border:1px solid #93c5fd;border-radius:var(--radius-lg);margin-bottom:1.5rem}.generation-progress-banner.error{background:#fef2f2;border-color:#fecaca}.generation-progress-banner.success{background:#f0fdf4;border-color:#bbf7d0}.generation-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.generation-progress-label{font-size:.875rem;font-weight:600;color:var(--color-text)}.btn-cancel-sm{padding:.25rem .625rem;font-size:.75rem;color:var(--color-danger);border-color:var(--color-danger);background:#fff}.btn-cancel-sm:hover{background:#fef2f2}.generation-progress-bar{height:8px;background:#2563eb26;border-radius:4px;overflow:hidden;margin-bottom:.375rem}.generation-progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .5s ease}.generation-progress-detail{font-size:.8125rem;color:var(--color-text-secondary)}.generation-complete,.generation-failed,.generation-cancelled{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.875rem;font-weight:500}.generation-complete{color:#166534}.generation-failed{color:#991b1b}.generation-cancelled{color:#854d0e}.btn-dismiss{padding:.25rem .625rem;font-size:.75rem;background:transparent;border:1px solid currentColor;border-radius:var(--radius-sm);color:inherit;cursor:pointer}.btn-dismiss:hover{opacity:.8}.cards-section{margin-top:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{font-size:1.25rem;font-weight:600}.card-list{display:flex;flex-direction:column;gap:.75rem}.flashcard-item{padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}.flashcard-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.flashcard-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.card-type-badge{padding:.125rem .5rem;background:var(--color-primary-light);color:var(--color-primary);border-radius:.25rem;font-size:.75rem;font-weight:600}.card-difficulty{font-size:.75rem;color:var(--color-text-muted);margin-left:auto}.flashcard-content{font-size:.9375rem}.flashcard-front{margin-bottom:.5rem}.flashcard-back{padding-top:.5rem;border-top:1px dashed var(--color-border);color:var(--color-text-secondary)}.flashcard-hint{font-size:.8rem;color:var(--color-text-muted);font-style:italic}.card-warnings{margin-top:.5rem;display:flex;gap:.375rem}.warning-badge{padding:.125rem .5rem;background:#fef9c3;color:#854d0e;border-radius:.25rem;font-size:.75rem}.card-status-badge{padding:.125rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.status-draft{background:#fef9c3;color:#854d0e}.status-review{background:#ffedd5;color:#9a3412}.status-approved{background:#dcfce7;color:#166534}.status-rejected{background:#fee2e2;color:#991b1b}.status-archived{background:#f1f5f9;color:#475569}.card-action-buttons{display:flex;gap:.375rem;margin-top:.5rem}.form,.card-form{max-width:600px;display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.form-group input,.form-group textarea,.form-group select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb26}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.generate-form{max-width:100%;padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.generate-form textarea{width:100%;min-height:150px;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:.875rem;resize:vertical;transition:border-color .15s,box-shadow .15s}.generate-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb26}.generate-options{display:flex;gap:1rem;margin-top:.75rem;align-items:flex-end}.generate-options .form-group{flex:1}.generating-spinner{text-align:center;padding:2rem;color:var(--color-text-secondary)}.study-page{max-width:700px;margin:0 auto}.study-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.study-progress-info{font-size:.875rem;color:var(--color-text-secondary);font-weight:500}.study-progress-bar{height:6px;background:var(--color-border);border-radius:3px;margin-bottom:2rem;overflow:hidden}.study-progress-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.study-flashcard{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2rem;min-height:200px;cursor:pointer;transition:border-color .15s;box-shadow:var(--shadow-md)}.study-flashcard:hover{border-color:var(--color-primary)}.study-flashcard.flipped{cursor:default}.flashcard-face{margin-bottom:1rem}.flashcard-face:last-child{margin-bottom:0}.flashcard-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:.5rem}.flashcard-text{font-size:1.125rem;line-height:1.6}.flashcard-back-face{padding-top:1rem;border-top:1px dashed var(--color-border)}.study-actions{margin-top:1.5rem;text-align:center}.btn-show-answer{padding:.75rem 2rem;font-size:1rem}.quality-prompt{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.75rem}.quality-buttons{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.quality-btn{display:flex;flex-direction:column;align-items:center;padding:.5rem .75rem;min-width:60px;border-radius:var(--radius-md);border:2px solid;font-weight:500;transition:transform .1s,box-shadow .1s}.quality-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.quality-value{font-size:1.125rem;font-weight:700}.quality-label{font-size:.6875rem}.quality-0{border-color:#dc2626;color:#dc2626;background:#fef2f2}.quality-1{border-color:#ea580c;color:#ea580c;background:#fff7ed}.quality-2{border-color:#d97706;color:#d97706;background:#fffbeb}.quality-3{border-color:#65a30d;color:#65a30d;background:#f7fee7}.quality-4{border-color:#16a34a;color:#16a34a;background:#f0fdf4}.quality-5{border-color:#059669;color:#059669;background:#ecfdf5}.quality-0:hover:not(:disabled){background:#fee2e2}.quality-1:hover:not(:disabled){background:#ffedd5}.quality-2:hover:not(:disabled){background:#fef3c7}.quality-3:hover:not(:disabled){background:#ecfccb}.quality-4:hover:not(:disabled){background:#dcfce7}.quality-5:hover:not(:disabled){background:#d1fae5}.study-summary{text-align:center;padding:3rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.study-summary h1{margin-bottom:2rem}.summary-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:2rem}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary)}.stat-label{font-size:.875rem;color:var(--color-text-secondary);margin-top:.25rem}.summary-actions{margin-top:1.5rem}.anki-page{max-width:800px}.anki-hero{text-align:center;margin-bottom:2rem}.anki-hero h1{margin-bottom:.5rem}.anki-hero .subtitle{color:var(--color-text-secondary);max-width:600px;margin:0 auto;font-size:1.0625rem}.anki-download-section{padding:2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.anki-download-section h2{font-size:1.25rem;margin-bottom:.75rem}.anki-download-section p{color:var(--color-text-secondary);margin-bottom:1.25rem;font-size:.9375rem;line-height:1.6}.btn-download{background:var(--color-primary);color:#fff;border:none;padding:.75rem 2rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-download:hover{background:var(--color-primary-dark)}.btn-download:disabled{opacity:.5;cursor:not-allowed}.anki-instructions,.anki-how-it-works{padding:1.5rem 2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.anki-instructions h2,.anki-how-it-works h2{font-size:1.25rem;margin-bottom:1rem}.anki-instructions ol{padding-left:1.5rem}.anki-instructions li{margin-bottom:.75rem;line-height:1.6}.anki-instructions code{padding:.125rem .375rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:.25rem;font-size:.8125rem}.anki-how-it-works p{color:var(--color-text-secondary);margin-bottom:.75rem;line-height:1.6}.anki-cta{text-align:center;padding:1.5rem;background:var(--color-primary-light);border-radius:var(--radius-lg)}.anki-cta a{color:var(--color-primary);font-weight:600}.feedback-trigger{background:none;border:none;color:var(--color-text-muted);font-size:.8rem;cursor:pointer;margin-top:1rem;text-decoration:underline;padding:0}.feedback-trigger:hover{color:var(--color-text)}.feedback-submitted{margin-top:1rem;font-size:.85rem;color:var(--color-success);font-weight:500}.feedback-form{margin-top:1rem;padding:1rem;background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.feedback-prompt{font-size:.85rem;font-weight:600;margin:0 0 .5rem;color:var(--color-text)}.feedback-type-buttons{display:flex;flex-wrap:wrap;gap:.375rem}.feedback-type-btn{padding:.35rem .65rem;border-radius:1rem;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.75rem;cursor:pointer;transition:all .15s ease}.feedback-type-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.feedback-type-btn.selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.feedback-textarea{width:100%;margin-top:.5rem;padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.8rem;font-family:inherit;resize:vertical;box-sizing:border-box}.feedback-actions{display:flex;gap:.5rem;margin-top:.5rem}.feedback-actions .btn-cancel{background:none;border:1px solid var(--color-border);padding:.35rem .75rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;color:var(--color-text-muted)}.feedback-actions .btn-primary{font-size:.8rem;padding:.35rem .75rem}.card-feedback-section{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.feedback-badge{background:#fef2f2;color:var(--color-danger);border:1px solid #fecaca;padding:.2rem .6rem;border-radius:1rem;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .15s ease}.feedback-badge:hover{background:#fee2e2;border-color:#fca5a5}.feedback-detail-list{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.feedback-detail-item{padding:.5rem .75rem;background:#fefce8;border:1px solid #fef08a;border-radius:var(--radius-sm);font-size:.8rem}.feedback-detail-type{font-weight:600;color:#92400e}.feedback-detail-comment{margin:.25rem 0 0;color:var(--color-text)}.feedback-detail-span{margin:.25rem 0 0;color:var(--color-danger);font-style:italic;font-size:.75rem}.feedback-detail-date{display:block;margin-top:.25rem;font-size:.7rem;color:var(--color-text-muted)}.prompt-agent-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.prompt-agent-tab{padding:.5rem 1.25rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;font-weight:500;font-size:.875rem;transition:all .15s}.prompt-agent-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.prompt-agent-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.prompt-active-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.prompt-active-section h2{font-size:1rem;font-weight:600;margin-bottom:.75rem}.prompt-active-meta{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.75rem}.prompt-no-active{color:var(--color-text-secondary);font-size:.875rem;font-style:italic}.prompt-text-display{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:1rem;font-family:monospace;font-size:.8125rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:400px;overflow-y:auto;margin:0}.prompt-create-section{margin-bottom:1.5rem}.prompt-create-section h2{font-size:1rem;font-weight:600;margin-bottom:.75rem}.prompt-textarea{width:100%;min-height:200px;font-family:monospace;font-size:.8125rem;line-height:1.5;padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);resize:vertical;margin-bottom:.75rem;transition:border-color .15s}.prompt-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.prompt-history-section h2{font-size:1rem;font-weight:600;margin-bottom:.75rem}.prompt-history-list{display:flex;flex-direction:column;gap:.75rem}.prompt-history-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem}.prompt-history-item--active{border-color:var(--color-primary);background:var(--color-primary-light)}.prompt-history-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.prompt-history-version{font-weight:700;font-size:.875rem}.prompt-history-badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;background:var(--color-primary);color:#fff;font-size:.6875rem;font-weight:600}.prompt-history-date{color:var(--color-text-secondary);font-size:.8125rem;margin-left:auto}.prompt-history-preview{background:var(--color-bg);border-radius:var(--radius-sm);padding:.5rem .75rem;font-family:monospace;font-size:.75rem;line-height:1.4;white-space:pre-wrap;word-break:break-word;color:var(--color-text-secondary);margin:0 0 .5rem;max-height:80px;overflow:hidden}.prompt-history-activate{font-size:.8125rem;padding:.375rem .75rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;flex-direction:column;align-items:center;padding:1.25rem 1rem;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.stat-card-value{font-size:2rem;font-weight:700;color:var(--color-primary);line-height:1}.stat-card-label{font-size:.875rem;color:var(--color-text-secondary);margin-top:.25rem}.stat-card-sub{font-size:.75rem;color:var(--color-text-muted);margin-top:.125rem}.admin-section{margin-bottom:2rem}.admin-section h2{margin-bottom:.75rem;font-weight:600}.status-breakdown{display:flex;flex-wrap:wrap;gap:.5rem}.status-breakdown-item{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.875rem}.status-breakdown-count{font-weight:700}.status-breakdown-label{font-weight:500}.feedback-breakdown{display:flex;flex-direction:column;gap:.375rem;max-width:400px}.feedback-breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem .75rem;background:var(--color-bg);border-radius:.25rem;font-size:.875rem}.feedback-breakdown-count{font-weight:700;color:var(--color-primary)}.review-queue-empty{text-align:center;padding:2rem;color:var(--color-text-secondary);background:var(--color-bg);border-radius:var(--radius-md)}.review-queue-list{display:flex;flex-direction:column;gap:.75rem}.review-queue-item{padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.review-queue-item-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.review-score{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-bg);padding:.125rem .5rem;border-radius:.25rem}.review-queue-date{font-size:.75rem;color:var(--color-text-muted);margin-left:auto}.review-queue-item-content{margin-bottom:.5rem;font-size:.9rem;line-height:1.5}.review-queue-front,.review-queue-back{margin-bottom:.25rem}.review-queue-justification{font-size:.8rem;color:var(--color-text-secondary);font-style:italic;padding:.375rem .75rem;background:#fffbeb;border-left:3px solid var(--color-warning);border-radius:.25rem;margin-bottom:.5rem}.review-queue-warnings{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem}.review-queue-actions{display:flex;gap:.5rem;justify-content:flex-end}
