@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&display=swap";@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css";:root{--color-primary: #007AFF;--color-primary-soft: #E5F1FF;--color-secondary: #00D1FF;--color-accent: #FF9500;--color-success: #34C759;--color-success-bg: #EAF9EE;--color-error: #FF3B30;--color-error-bg: #FFF1F0;--color-bg: #F2F4F6;--color-surface: #FFFFFF;--color-surface-dim: #F9FAFB;--color-text-primary: #191F28;--color-text-secondary: #4E5968;--color-text-dim: #8B95A1;--color-text-white: #FFFFFF;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .12);--glass-bg: rgba(255, 255, 255, .8);--glass-border: rgba(255, 255, 255, .2);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-full: 9999px;--safe-area-inset-bottom: env(safe-area-inset-bottom, 20px)}[data-theme=dark]{--color-primary: #0A84FF;--color-primary-soft: #1C1C1E;--color-secondary: #64D2FF;--color-accent: #FF9F0A;--color-success: #30D158;--color-success-bg: #1C2E20;--color-error: #FF453A;--color-error-bg: #2C1A1A;--color-bg: #000000;--color-surface: #1C1C1E;--color-surface-dim: #2C2C2E;--color-text-primary: #FFFFFF;--color-text-secondary: #A9ABB1;--color-text-dim: #8E8E93;--color-text-white: #FFFFFF;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 8px 24px rgba(0, 0, 0, .6);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .8);--glass-bg: rgba(28, 28, 30, .8);--glass-border: rgba(255, 255, 255, .1)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:Pretendard Variable,-apple-system,sans-serif;background-color:var(--color-bg);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}h1,h2,h3,h4{font-family:Outfit,sans-serif;font-weight:700}.app-root{display:flex;flex-direction:column;min-height:100vh}.app-header{position:sticky;top:0;z-index:1000;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:.75rem 1.25rem;border-bottom:1px solid rgba(0,0,0,.05)}.header-top{display:flex;justify-content:space-between;align-items:center;max-width:800px;margin:0 auto;width:100%}.brand-block{display:flex;flex-direction:column;text-decoration:none;color:inherit}.brand-pill{font-size:.625rem;font-weight:800;color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:-2px}.brand-block h1{font-size:1.125rem;font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.header-actions{display:flex;align-items:center;gap:.75rem}.header-progress{display:flex;align-items:center;gap:.5rem}.progress-bar.mini{width:60px;height:6px;background:#e5e8eb;border-radius:var(--radius-full);overflow:hidden}.progress-text{font-size:.75rem;font-weight:700;color:var(--color-primary);min-width:2.5ch}.user-group{display:flex;align-items:center;gap:.5rem}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;background:var(--color-surface);border-radius:var(--radius-full);box-shadow:var(--shadow-sm)}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.user-avatar-placeholder{width:24px;height:24px;border-radius:50%;background:var(--color-primary-soft);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.user-name{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout,.btn-login{padding:.4rem .8rem;border-radius:var(--radius-md);border:none;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-logout{background:transparent;color:var(--color-text-dim)}.btn-logout:hover{background:var(--color-bg);color:var(--color-error)}.btn-login{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #007aff33}.btn-login:hover{transform:translateY(-1px);filter:brightness(1.1)}.btn-admin-link{display:inline-flex;align-items:center;justify-content:center;padding:.38rem .7rem;border-radius:var(--radius-md);border:1px solid rgba(0,122,255,.22);background:var(--color-primary-soft);color:var(--color-primary);font-size:.75rem;font-weight:700;text-decoration:none;transition:all .2s}.btn-admin-link:hover{filter:brightness(.97);transform:translateY(-1px)}.page-wrap{flex:1;padding:1.5rem 1.25rem 6.5rem;max-width:800px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:grid;grid-template-columns:repeat(5,minmax(0,1fr));padding:.75rem .5rem calc(.5rem + var(--safe-area-inset-bottom));border-top:1px solid rgba(0,0,0,.05);z-index:1000}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:0;text-decoration:none;color:var(--color-text-dim);font-size:.6875rem;font-weight:600;white-space:nowrap;transition:all .2s cubic-bezier(.4,0,.2,1)}.bottom-nav a svg{transition:transform .2s}.bottom-nav a.active{color:var(--color-primary)}.bottom-nav a.active svg{transform:scale(1.1);stroke:var(--color-primary)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);margin-bottom:1.25rem;border:1px solid rgba(0,0,0,.02)}.card h2{font-size:1.25rem;margin-bottom:1.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.5rem;border-radius:var(--radius-md);font-weight:700;font-size:1rem;border:none;cursor:pointer;transition:all .2s;text-decoration:none}.icon-btn{background:transparent;border:none;color:var(--color-text-dim);display:flex;align-items:center;justify-content:center;padding:.5rem;cursor:pointer;border-radius:var(--radius-md);transition:all .2s}.icon-btn:hover{background:var(--color-bg);color:var(--color-primary)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 8px 16px #007aff33}.btn-primary:active{transform:scale(.98)}.question-meta{margin-bottom:1rem}.question-meta-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.question-meta-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.6rem}.question-meta-actions{display:inline-flex;align-items:center;gap:.45rem;flex-wrap:wrap;justify-content:flex-end}.question-chip{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:var(--radius-full);border:1px solid #E5E8EB;background:var(--color-surface-dim);font-size:.7rem;font-weight:700;color:var(--color-text-secondary)}.bookmark-toggle{display:inline-flex;align-items:center;gap:.35rem;border:1px solid #E5E8EB;background:var(--color-surface);color:var(--color-text-dim);border-radius:var(--radius-full);padding:.35rem .65rem;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.bookmark-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-soft)}.bookmark-toggle.active{color:#fff;border-color:var(--color-primary);background:var(--color-primary)}.question-edit-toggle{display:inline-flex;align-items:center;gap:.35rem;border:1px solid #E5E8EB;background:var(--color-surface-dim);color:var(--color-text-secondary);border-radius:var(--radius-full);padding:.35rem .65rem;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.question-edit-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-soft)}.question-copy-toggle{display:inline-flex;align-items:center;gap:.35rem;border:1px solid #E5E8EB;background:var(--color-surface);color:var(--color-text-secondary);border-radius:var(--radius-full);padding:.35rem .65rem;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}.question-copy-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-soft)}.question-edit-meta{margin-top:-.15rem;font-size:.72rem;color:var(--color-text-dim)}.question-stem{font-size:1.125rem;line-height:1.6;color:var(--color-text-primary);margin-bottom:2rem;font-weight:500}.question-stem p,.explanation-content p{margin:0 0 .8rem;word-break:keep-all;overflow-wrap:anywhere;line-break:strict}.question-stem p:last-child,.explanation-content p:last-child{margin-bottom:0}.question-stem table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.875rem;border-radius:var(--radius-md);overflow:hidden;border:1px solid #E5E8EB}.question-stem th{background:var(--color-surface-dim);color:var(--color-text-secondary);font-weight:700;text-align:left;padding:.75rem 1rem;border-bottom:2px solid #E5E8EB}.question-stem td{padding:.75rem 1rem;border-bottom:1px solid #F2F4F6;color:var(--color-text-primary)}.question-stem tr:last-child td{border-bottom:none}.question-stem tr:hover td{background:var(--color-surface-dim)}.question-stem img,.explanation-content img{max-width:100%;height:auto;border-radius:var(--radius-sm);cursor:zoom-in;transition:transform .15s ease,box-shadow .2s ease}.question-stem img:hover,.explanation-content img:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.question-stem .legacy-image-host,.explanation-content .legacy-image-host{margin-bottom:1rem}.question-stem .legacy-image-block,.explanation-content .legacy-image-block{display:grid;justify-content:center;gap:.7rem}.question-stem .legacy-image-grid,.explanation-content .legacy-image-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));max-width:min(100%,720px);margin-inline:auto}.question-stem .legacy-image-grid .legacy-inline-image,.explanation-content .legacy-image-grid .legacy-inline-image{display:block!important;width:100%!important;margin:0!important}.question-stem .legacy-image-grid .legacy-inline-image img,.explanation-content .legacy-image-grid .legacy-inline-image img{display:block;width:100%;max-height:260px;object-fit:contain;background:var(--color-surface-dim)}.question-stem .legacy-image-single .legacy-inline-image,.question-stem .legacy-mixed-paragraph .legacy-inline-image,.explanation-content .legacy-image-single .legacy-inline-image,.explanation-content .legacy-mixed-paragraph .legacy-inline-image{display:block!important;width:min(100%,max(260px,var(--legacy-source-width, 340px)))!important;max-width:480px;margin:.85rem auto 0!important}.question-stem .legacy-image-single .legacy-inline-image img,.question-stem .legacy-mixed-paragraph .legacy-inline-image img,.explanation-content .legacy-image-single .legacy-inline-image img,.explanation-content .legacy-mixed-paragraph .legacy-inline-image img{display:block;width:100%;height:auto!important;max-height:min(46vh,420px);object-fit:contain;background:var(--color-surface-dim)}.question-stem .legacy-inline-captions,.explanation-content .legacy-inline-captions{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.7rem;max-width:min(100%,720px);margin:-.2rem auto 1rem}.question-stem .legacy-inline-caption,.explanation-content .legacy-inline-caption{display:block;text-align:center;color:var(--color-text-secondary);font-weight:600;line-height:1.35;letter-spacing:.01em}.question-stem .legacy-standalone-caption,.explanation-content .legacy-standalone-caption{margin:-.1rem auto 1rem;text-align:center;color:var(--color-text-secondary);font-weight:600}.question-images{margin:1rem 0;display:flex;flex-wrap:wrap;gap:.75rem}.image-thumb-button{width:min(100%,360px);border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);background:transparent;padding:0;cursor:zoom-in;box-shadow:var(--shadow-sm);overflow:hidden}.image-thumb-button img{display:block;width:100%;height:auto}.options-list{display:grid;gap:.75rem}.option-btn{background:var(--color-surface-dim);border:1px solid #E5E8EB;color:var(--color-text-primary);padding:1rem 1.25rem;border-radius:var(--radius-md);display:flex;align-items:center;gap:1rem;text-align:left;cursor:pointer;transition:all .2s}.option-btn:hover{background:var(--color-surface);border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.option-text{word-break:keep-all;overflow-wrap:anywhere;line-break:strict}.option-number{width:28px;height:28px;background:#e5e8eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;color:var(--color-text-secondary);flex-shrink:0}.option-correct{border-color:var(--color-success);background:var(--color-success-bg)}.option-correct .option-number{background:var(--color-success);color:#fff}.option-incorrect{border-color:var(--color-error);background:var(--color-error-bg)}.option-incorrect .option-number{background:var(--color-error);color:#fff}.animate-fade-in{animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card:active{transform:scale(.99);transition:transform .1s}.study-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.study-progress{flex:1;display:flex;align-items:center;gap:.75rem;background:var(--color-surface);padding:.5rem 1rem;border-radius:var(--radius-full);box-shadow:var(--shadow-sm)}.progress-bar{flex:1;height:8px;background:#e5e8eb;border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));transition:width .3s ease}.study-checkpoint{display:grid;gap:1rem}.study-checkpoint-card{margin-bottom:0;padding:1.35rem}.study-checkpoint-title{margin:.65rem 0 .4rem;font-size:1.3rem}.study-checkpoint-subtitle{margin:0;color:var(--color-text-secondary);font-size:.86rem}.study-checkpoint-stats{margin-top:1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.study-checkpoint-stat{padding:.72rem .8rem;border-radius:var(--radius-md);border:1px solid rgba(0,0,0,.06);background:var(--color-surface-dim);display:flex;flex-direction:column;gap:.14rem}.study-checkpoint-stat span{font-size:.72rem;color:var(--color-text-dim);font-weight:700}.study-checkpoint-stat strong{font-family:Outfit,sans-serif;font-size:1.05rem;color:var(--color-text-primary)}.study-checkpoint-stat small{font-size:.7rem;color:var(--color-text-secondary)}.study-checkpoint-actions{margin-top:.95rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.study-checkpoint-actions .btn{width:100%;font-size:.83rem;padding:.68rem .75rem}.study-checkpoint-actions .btn:disabled{opacity:.55;cursor:not-allowed}.edit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2600;background:#080e188c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem}.edit-modal-panel{width:min(920px,100%);max-height:min(92vh,980px);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid rgba(0,0,0,.08);box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column}.edit-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid rgba(0,0,0,.08);background:var(--color-surface-dim)}.edit-modal-subtitle{margin:.45rem 0 0;font-size:.78rem;color:var(--color-text-dim)}.edit-modal-close{border:1px solid #E5E8EB;background:var(--color-surface);color:var(--color-text-secondary);border-radius:var(--radius-md);padding:.45rem .75rem;font-size:.8rem;font-weight:700;cursor:pointer}.edit-modal-close:hover{border-color:var(--color-primary);color:var(--color-primary)}.edit-modal-body{padding:1rem 1.25rem 1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.edit-modal-hint{margin:0;font-size:.78rem;color:var(--color-text-dim)}.edit-field{display:flex;flex-direction:column;gap:.5rem}.edit-field-head{display:flex;align-items:center;justify-content:space-between;gap:.65rem;flex-wrap:wrap}.edit-field-caption{font-size:.74rem;color:var(--color-text-dim);font-weight:600}.edit-field label{font-size:.82rem;font-weight:700;color:var(--color-text-secondary)}.edit-input,.edit-select,.edit-textarea{width:100%;border:1px solid #E5E8EB;border-radius:var(--radius-md);padding:.7rem .85rem;font-size:.9rem;color:var(--color-text-primary);background:var(--color-surface)}.edit-textarea{min-height:130px;resize:vertical;line-height:1.5}.edit-input:focus,.edit-select:focus,.edit-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #007aff26}.edit-select{cursor:pointer}.edit-select-compact{width:auto;min-width:100px}.rich-editor-shell{border:1px solid #E5E8EB;border-radius:var(--radius-md);background:var(--color-surface);overflow:hidden}.rich-editor-shell:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #007aff26}.rich-editor-toolbar{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;padding:.5rem .55rem;background:var(--color-surface-dim);border-bottom:1px solid rgba(0,0,0,.08)}.rich-editor-toolbar-group{display:inline-flex;gap:.32rem;align-items:center}.rich-editor-btn{border:1px solid rgba(15,23,42,.12);background:var(--color-surface);color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:.34rem .58rem;font-size:.74rem;font-weight:700;cursor:pointer;line-height:1.1}.rich-editor-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.rich-editor-surface{padding:.75rem .85rem;line-height:1.56;color:var(--color-text-primary);overflow:auto}.rich-editor-surface:focus{outline:none}.rich-editor-surface:empty:before{content:attr(data-placeholder);color:var(--color-text-dim);pointer-events:none}.rich-editor-surface p,.rich-editor-surface h3,.rich-editor-surface blockquote,.rich-editor-surface ul,.rich-editor-surface ol{margin:0 0 .75rem}.rich-editor-surface table{width:100%;border-collapse:collapse;margin:.85rem 0;font-size:.86rem;border:1px solid #E5E8EB;border-radius:var(--radius-sm);overflow:hidden}.rich-editor-surface th,.rich-editor-surface td{border:1px solid #E5E8EB;padding:.5rem .62rem;text-align:left}.rich-editor-surface th{background:var(--color-surface-dim);font-weight:700;color:var(--color-text-secondary)}.rich-editor-surface img{max-width:100%;height:auto;border-radius:var(--radius-sm);cursor:pointer}.rich-editor-surface img.rich-editor-image-selected{outline:2px solid var(--color-primary);outline-offset:2px}.rich-editor-image-tools{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;padding:.5rem .62rem;background:var(--color-surface-dim);border-top:1px solid rgba(0,0,0,.08)}.rich-editor-tools-label{font-size:.73rem;color:var(--color-text-dim);font-weight:700}.rich-editor-width-range{width:140px}.rich-editor-width-value{min-width:2.8rem;font-size:.74rem;font-weight:700;color:var(--color-text-secondary)}.edit-mini-btn{border:1px solid rgba(0,122,255,.24);background:#007aff14;color:var(--color-primary);border-radius:999px;padding:.32rem .7rem;font-size:.75rem;font-weight:700;cursor:pointer;white-space:nowrap}.edit-mini-btn:hover{background:#007aff24}.edit-mini-btn-strong{background:linear-gradient(135deg,#0a84ff29,#64d2ff29);border-color:#0a84ff59}.edit-options-head-actions{display:inline-flex;align-items:center;gap:.45rem}.edit-options-count{display:inline-flex;align-items:center;justify-content:center;min-width:44px;border-radius:var(--radius-full);padding:.26rem .55rem;font-size:.72rem;font-weight:700;color:var(--color-text-secondary);background:var(--color-surface-dim);border:1px solid rgba(0,0,0,.08)}.edit-option-list{display:grid;gap:.5rem}.edit-option-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.55rem;background:var(--color-surface-dim);border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-md);padding:.4rem .45rem .4rem .35rem}.edit-option-index{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--color-text-primary);background:var(--color-surface);border:1px solid rgba(0,0,0,.1)}.edit-option-row .edit-input{flex:1;border:none;background:transparent;padding:.55rem .6rem;box-shadow:none}.edit-option-row .edit-input:focus{border:none;box-shadow:none;background:#0a84ff12;border-radius:calc(var(--radius-md) - 4px)}.edit-option-textarea{width:100%;border:none;background:transparent;padding:.55rem .6rem;box-shadow:none;resize:vertical;min-height:44px;line-height:1.45;font-size:.9rem;color:var(--color-text-primary);font-family:inherit}.edit-option-textarea:focus{outline:none;background:#0a84ff12;border-radius:calc(var(--radius-md) - 4px)}.edit-option-remove{display:inline-flex;align-items:center;gap:.24rem;border:1px solid rgba(255,69,58,.25);background:#ff453a14;color:var(--color-error);border-radius:var(--radius-sm);padding:.4rem .5rem;font-size:.72rem;font-weight:700;cursor:pointer}.edit-option-remove:hover:not(:disabled){background:#ff453a24}.edit-option-remove:disabled{opacity:.45;cursor:not-allowed}.edit-options-footnote{margin:.1rem 0 0;font-size:.72rem;color:var(--color-text-dim)}.edit-icon-btn{border:1px solid rgba(15,23,42,.15);background:var(--color-surface-dim);color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:.36rem .62rem;font-size:.75rem;font-weight:700;cursor:pointer}.edit-icon-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.edit-icon-btn:disabled{opacity:.45;cursor:not-allowed}.edit-image-list{display:flex;flex-direction:column;gap:.55rem}.edit-image-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:.5rem;align-items:center}.edit-image-actions{display:flex;gap:.3rem}.edit-image-add-row{display:flex;align-items:center;gap:.5rem}.edit-image-add-row .edit-input{flex:1}.edit-modal-error{margin:0;font-size:.8rem;color:var(--color-error)}.edit-modal-footer{margin-top:.35rem;display:flex;gap:.75rem}.image-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#060c18d1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:1rem;display:flex;align-items:center;justify-content:center}.image-viewer-shell{width:min(1100px,100%);height:min(90vh,900px);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.2);overflow:hidden;display:flex;flex-direction:column}.image-viewer-toolbar{display:flex;align-items:center;gap:.5rem;padding:.65rem .75rem;border-bottom:1px solid rgba(0,0,0,.08);background:var(--color-surface-dim)}.image-viewer-btn{border:1px solid rgba(0,0,0,.12);background:var(--color-surface);color:var(--color-text-primary);border-radius:var(--radius-sm);min-width:44px;padding:.4rem .7rem;font-size:.82rem;font-weight:700;cursor:pointer}.image-viewer-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.image-viewer-close{margin-left:auto}.image-viewer-zoom{flex:1;min-width:180px;display:flex;align-items:center;gap:.55rem}.image-viewer-zoom input{flex:1}.image-viewer-zoom span{min-width:3.5rem;text-align:right;font-size:.75rem;font-weight:700;color:var(--color-text-secondary)}.image-viewer-canvas{flex:1;overflow:auto;padding:1rem;background:radial-gradient(circle at top,#E7F0FF 0%,var(--color-surface-dim) 42%,var(--color-bg) 100%)}[data-theme=dark] .image-viewer-canvas{background:radial-gradient(circle at top,rgba(10,132,255,.24) 0%,var(--color-surface-dim) 42%,var(--color-bg) 100%)}.image-viewer-stage{min-width:100%;min-height:100%;display:flex;align-items:flex-start;justify-content:center}.image-viewer-image{display:block;max-width:none;height:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);-webkit-user-select:none;user-select:none}@media(max-width:640px){.edit-modal-overlay{padding:.5rem}.edit-modal-panel{max-height:95vh}.edit-modal-header,.edit-modal-body{padding-left:.85rem;padding-right:.85rem}.edit-modal-footer{flex-direction:column}.edit-field-head{align-items:flex-start;flex-direction:column}.edit-options-head-actions{width:100%;justify-content:space-between}.edit-option-row{grid-template-columns:auto minmax(0,1fr);align-items:center}.edit-option-remove{grid-column:1 / -1;justify-self:end}.edit-image-row{grid-template-columns:minmax(0,1fr)}.edit-select-compact{width:100%}.edit-image-actions{justify-content:flex-start}.edit-image-add-row{flex-direction:column;align-items:stretch}}@media(max-width:600px){.page-wrap{padding-top:1rem}.card{padding:1.25rem;border-radius:var(--radius-md)}.brand-block h1{font-size:1rem}.question-meta-head{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;column-gap:.6rem}.question-meta-row{margin-bottom:0}.question-meta-actions{justify-self:end;align-self:start;margin-top:0}.study-checkpoint-stats,.study-checkpoint-actions{grid-template-columns:1fr}.image-viewer-shell{height:min(94vh,900px)}.image-viewer-toolbar{flex-wrap:wrap;row-gap:.55rem}.image-viewer-close{margin-left:0}.image-viewer-zoom{order:1;flex-basis:100%}}.plain-list{list-style:none}.plain-list li{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid #F2F4F6;font-size:.9375rem;color:var(--color-text-secondary)}.plain-list li span:last-child{font-weight:700;color:var(--color-text-primary)}.toggle-row{display:flex;gap:.5rem;margin-top:1rem;overflow-x:auto;padding-bottom:.5rem}.toggle-row button{padding:.5rem 1rem;border-radius:var(--radius-full);border:1px solid #E5E8EB;background:var(--color-surface);color:var(--color-text-primary);font-size:.8125rem;font-weight:600;white-space:nowrap;cursor:pointer;transition:all .2s}.toggle-row button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.review-page{display:flex;flex-direction:column}.review-header{margin-bottom:1rem}.review-tab-card{padding:.6rem!important;margin-bottom:.55rem}.review-toggle-row{display:flex;gap:.35rem}.review-action-wrap{margin-bottom:.75rem}.review-list{display:grid;gap:.55rem}.review-row-card{margin-bottom:0!important;padding:.9rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:.85rem}.review-row-main{flex:1;min-width:0}.review-row-title{font-weight:700;font-size:.9rem;margin-bottom:.2rem;color:var(--color-text-primary)}.review-row-preview{font-size:.78rem;color:var(--color-text-secondary);margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.review-row-meta{font-size:.74rem;color:var(--color-text-dim)}.review-open-btn{flex-shrink:0;padding:.46rem .95rem;font-size:.8rem;background:var(--color-primary-soft);color:var(--color-primary)}.skeleton{background:linear-gradient(90deg,#f2f4f6 25%,#e5e8eb,#f2f4f6 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.dashboard-main-card{padding:1.25rem!important;overflow:hidden}.dashboard-header-stats{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid rgba(0,0,0,.05)}.stat-circle{width:80px;height:80px;border-radius:50%;background:var(--color-primary-soft);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;box-shadow:inset 0 0 0 6px #fff}.stat-percent{font-size:1.25rem;font-weight:800;color:var(--color-primary);line-height:1}.stat-subtext{font-size:.625rem;font-weight:700;color:var(--color-text-dim);margin-top:2px}.progress-details{flex:1}.progress-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:.5rem}.progress-label{font-size:.8125rem;font-weight:700;color:var(--color-text-secondary)}.progress-value{font-family:Outfit,sans-serif;font-size:1rem;font-weight:800;color:var(--color-text-primary)}.dashboard-progress-bar{height:8px;background:#f2f4f6;border-radius:var(--radius-full);overflow:hidden}.dashboard-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);box-shadow:0 2px 8px #007aff4d;transition:width .8s cubic-bezier(.34,1.56,.64,1)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.dash-stat-compact{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:var(--color-surface-dim);border-radius:var(--radius-md);transition:all .2s}.dash-stat-compact:hover{background:#fff;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.stat-icon-wrap{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{display:flex;flex-direction:column}.stat-label{font-size:.6875rem;font-weight:600;color:var(--color-text-dim)}.stat-val{font-size:.9375rem;font-weight:800;color:var(--color-text-primary)}@media(max-width:600px){.dashboard-header-stats{flex-direction:column;gap:1rem;text-align:center;align-items:center}.progress-details{width:100%}.stat-circle{width:90px;height:90px}.review-row-card{align-items:flex-start;flex-direction:column}.review-open-btn{align-self:flex-end}}.analysis-page{display:grid;gap:1rem;padding-bottom:1rem}.analysis-hero-card{margin-bottom:0;position:relative;overflow:hidden;background:linear-gradient(145deg,var(--color-surface),var(--color-surface-dim))}.analysis-hero-card:after{content:"";position:absolute;right:-100px;top:-120px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle at center,#007aff2e,#007aff00);pointer-events:none}.analysis-header-row{display:flex;justify-content:space-between;gap:1rem;position:relative;z-index:1}.analysis-eyebrow{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.25rem}.analysis-title{font-size:1.65rem;line-height:1.2;margin-bottom:.4rem}.analysis-subtitle{color:var(--color-text-secondary);font-size:.875rem;max-width:520px}.analysis-kpi-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.75rem;position:relative;z-index:1}.analysis-kpi-card{background:#ffffffa6;border:1px solid rgba(0,0,0,.05);border-radius:var(--radius-md);padding:.85rem;display:flex;flex-direction:column;gap:.2rem;min-height:96px}[data-theme=dark] .analysis-kpi-card{background:#1c1c1ea6}.analysis-kpi-label{font-size:.72rem;font-weight:700;color:var(--color-text-dim)}.analysis-kpi-value{font-family:Outfit,sans-serif;font-size:1.28rem;font-weight:800;letter-spacing:-.01em;color:var(--color-text-primary)}.analysis-kpi-meta{font-size:.72rem;color:var(--color-text-secondary);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analysis-layout-grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:1rem}.analysis-stack{display:grid;gap:1rem}.analysis-card{margin-bottom:0;padding:1.25rem}.analysis-card-head{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem}.analysis-card-head h3{font-size:1rem;margin:0}.analysis-card-head span{font-size:.75rem;color:var(--color-text-dim);font-weight:600}.analysis-chart-wrap{width:100%;height:280px;margin-top:.75rem}.analysis-chart-wrap.small{height:190px}.analysis-confidence-body{margin-top:.75rem;display:flex;align-items:center;gap:1rem}.analysis-pie-wrap{width:130px;height:130px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.analysis-pie-empty{width:112px;height:112px;border-radius:50%;border:2px dashed rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--color-text-dim);font-weight:600}.analysis-forecast-empty{margin-top:.75rem;border-radius:var(--radius-md);border:1px dashed rgba(0,0,0,.14);background:linear-gradient(180deg,var(--color-surface-dim),rgba(0,0,0,.01));padding:.9rem}.analysis-forecast-empty-title{font-size:.82rem;font-weight:700;color:var(--color-text-primary);word-break:keep-all;line-break:strict}.analysis-forecast-empty-text{margin-top:.2rem;font-size:.74rem;color:var(--color-text-dim);word-break:keep-all;line-break:strict}.analysis-forecast-days{list-style:none;margin-top:.75rem;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.4rem}.analysis-forecast-days li{border-radius:10px;border:1px solid rgba(0,0,0,.07);background:var(--color-surface);padding:.45rem .25rem;display:grid;place-items:center;gap:.15rem}.analysis-forecast-days li span{font-size:.67rem;color:var(--color-text-dim);white-space:nowrap;word-break:keep-all;line-height:1.1}.analysis-forecast-days li strong{font-family:Outfit,sans-serif;font-size:.85rem;color:var(--color-text-secondary)}[data-theme=dark] .analysis-forecast-empty{border-color:#ffffff29;background:linear-gradient(180deg,var(--color-surface-dim),rgba(255,255,255,.01))}[data-theme=dark] .analysis-forecast-days li{border-color:#ffffff1f}.analysis-confidence-legend{list-style:none;width:100%;display:grid;gap:.5rem}.analysis-confidence-legend li{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:.5rem;font-size:.8rem;color:var(--color-text-secondary)}.analysis-confidence-legend li strong{color:var(--color-text-primary);font-family:Outfit,sans-serif;font-weight:700}.analysis-dot{width:10px;height:10px;border-radius:999px}.analysis-secondary-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.analysis-type-list{margin-top:.75rem;display:grid;gap:.7rem}.analysis-type-item{padding:.8rem;border-radius:var(--radius-md);background:var(--color-surface-dim);border:1px solid rgba(0,0,0,.04)}.analysis-type-row{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.analysis-type-name{font-size:.86rem;font-weight:700;color:var(--color-text-primary)}.analysis-type-meta{font-size:.72rem;color:var(--color-text-dim);margin-top:.2rem}.analysis-type-score{font-family:Outfit,sans-serif;font-size:1rem;color:var(--color-primary);line-height:1;margin-top:.15rem}.analysis-meter{height:8px;border-radius:var(--radius-full);background:#00000014;margin-top:.55rem;overflow:hidden}.analysis-meter-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));transition:width .35s ease}.analysis-weak-list{margin-top:.75rem;display:grid;gap:.65rem}.analysis-weak-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.8rem;border-radius:var(--radius-md);background:var(--color-surface-dim)}.analysis-weak-content{flex:1;min-width:0}.analysis-weak-title{font-size:.81rem;font-weight:600;color:var(--color-text-primary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.analysis-weak-meta{font-size:.72rem;color:var(--color-text-dim);margin-top:.35rem}.analysis-open-link{flex-shrink:0;text-decoration:none;font-size:.72rem;font-weight:700;color:var(--color-primary);background:var(--color-primary-soft);border-radius:var(--radius-full);padding:.45rem .72rem}.analysis-open-link:hover{filter:brightness(.98)}.analysis-weak-empty{text-align:center;padding:1.5rem .75rem;color:var(--color-text-dim);font-size:.82rem}.analysis-insight-list{list-style:none;margin-top:.75rem;display:grid;gap:.65rem}.analysis-insight-list li{display:flex;align-items:flex-start;gap:.7rem;padding:.7rem .85rem;border-radius:var(--radius-md);background:var(--color-surface-dim);color:var(--color-text-secondary);font-size:.82rem;line-height:1.45}.analysis-insight-index{width:22px;height:22px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;flex-shrink:0;margin-top:1px}.analysis-empty-card{margin-bottom:0;text-align:center;padding:2.5rem 1.2rem}.analysis-empty-title{font-size:1.1rem;font-weight:700}.analysis-empty-text{margin-top:.5rem;color:var(--color-text-dim);font-size:.85rem}.analysis-empty-actions{margin-top:1rem;display:inline-flex;gap:.6rem}@media(max-width:960px){.analysis-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.analysis-layout-grid,.analysis-secondary-grid{grid-template-columns:1fr}}@media(max-width:640px){.analysis-title{font-size:1.4rem}.analysis-header-row{flex-direction:column}.analysis-kpi-grid{grid-template-columns:1fr 1fr}.analysis-card{padding:1rem}.analysis-chart-wrap{height:230px}.analysis-confidence-body{flex-direction:column;align-items:stretch}.analysis-pie-wrap{width:100%}.analysis-forecast-days{grid-template-columns:repeat(4,minmax(0,1fr))}.analysis-empty-actions{display:grid;width:100%}}.admin-page{display:grid;gap:1rem;padding-bottom:1rem}.admin-access-card{margin-top:1rem;text-align:center;display:grid;gap:.75rem}.admin-help-text{font-size:.82rem;color:var(--color-text-dim)}.admin-error-card{border:1px solid rgba(255,59,48,.22);background:color-mix(in srgb,var(--color-error-bg) 70%,var(--color-surface) 30%);color:var(--color-error)}.admin-kpi-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;position:relative;z-index:1}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.admin-table-wrap{margin-top:.75rem;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.8rem}.admin-table th,.admin-table td{border-bottom:1px solid rgba(0,0,0,.08);text-align:left;padding:.55rem .5rem;vertical-align:middle}[data-theme=dark] .admin-table th,[data-theme=dark] .admin-table td{border-bottom-color:#ffffff1a}.admin-table th{font-weight:700;color:var(--color-text-secondary);font-size:.74rem}.admin-mono{font-family:JetBrains Mono,Fira Mono,SF Mono,monospace;font-size:.75rem}.admin-recent-list{margin-top:.75rem;display:grid;gap:.5rem;list-style:none}.admin-recent-list li{border-radius:var(--radius-md);background:var(--color-surface-dim);padding:.65rem .75rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem}.admin-recent-title{font-size:.8rem;font-weight:700;color:var(--color-text-primary)}.admin-recent-meta{margin-top:.2rem;font-size:.72rem;color:var(--color-text-dim)}.admin-recent-list li>span{font-size:.72rem;color:var(--color-text-dim);white-space:nowrap}.admin-empty-row{color:var(--color-text-dim);justify-content:center}.admin-trend-list{margin-top:.8rem;display:grid;gap:.5rem}.admin-trend-row{display:grid;grid-template-columns:56px minmax(0,1fr) 52px 130px;align-items:center;gap:.65rem}.admin-trend-label{font-size:.76rem;font-weight:700;color:var(--color-text-secondary)}.admin-trend-bar{height:8px;border-radius:var(--radius-full);background:#00000014;overflow:hidden}[data-theme=dark] .admin-trend-bar{background:#ffffff1f}.admin-trend-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--color-primary),var(--color-secondary))}.admin-trend-value{font-family:Outfit,sans-serif;font-size:.82rem;color:var(--color-text-primary);text-align:right}.admin-trend-detail{font-size:.72rem;color:var(--color-text-dim);white-space:nowrap}@media(max-width:960px){.admin-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-grid{grid-template-columns:1fr}.admin-trend-row{grid-template-columns:52px minmax(0,1fr) 44px}.admin-trend-detail{grid-column:2 / 4;margin-top:-.15rem}}
