:root{--brand-50: #ecf3ff;--brand-500: #465fff;--brand-600: #3641f5;--brand-700: #2a31d8;--gray-25: #fcfcfd;--gray-50: #f9fafb;--gray-100: #f2f4f7;--gray-200: #e4e7ec;--gray-300: #d0d5dd;--gray-400: #98a2b3;--gray-500: #667085;--gray-600: #475467;--gray-700: #344054;--gray-800: #1d2939;--gray-900: #101828;--success-500: #12b76a;--danger-500: #f04438;--warning-500: #f79009;--info-500: #0ba5ec;--white: #ffffff;--font-family-base: "Outfit", "Pretendard", "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.75rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-xs: 0 1px 2px rgba(16, 24, 40, .05);--shadow-sm: 0 1px 3px rgba(16, 24, 40, .1), 0 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0 4px 8px -2px rgba(16, 24, 40, .1), 0 2px 4px -2px rgba(16, 24, 40, .06);--shadow-lg: 0 12px 16px -4px rgba(16, 24, 40, .08), 0 4px 6px -2px rgba(16, 24, 40, .03);--header-height: 74px;--sidebar-width: 300px;--sidebar-collapsed-width: 86px}*{box-sizing:border-box}html,body,#root{margin:0;width:100%;min-height:100%}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:1.55;color:var(--gray-800);background:linear-gradient(180deg,#f8faff 0%,#f3f6fc 100%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,h6,p{margin:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.header-v2{position:fixed;top:0;left:0;right:0;height:var(--header-height);z-index:1000;border-bottom:1px solid #e4e7ec;background:rgba(255,255,255,.96);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-v2__container{height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 20px;gap:16px}.header-v2__left{display:flex;align-items:center;gap:14px;min-width:0}.header-v2__menu-toggle{width:38px;height:38px;border-radius:10px;border:1px solid #d0d5dd;background:#fff;color:#344054;display:inline-flex;align-items:center;justify-content:center}.header-v2__toggle-icon{font-size:16px;line-height:1}.header-v2__hamburger{width:16px;display:inline-flex;flex-direction:column;gap:3px}.header-v2__hamburger span{height:2px;background:#344054;border-radius:2px}.header-v2__hamburger--open span:nth-child(2){opacity:.5}.header-v2__title-wrap{min-width:0}.header-v2__eyebrow{display:block;font-size:10px;letter-spacing:.08em;color:#667085;font-weight:700}.header-v2__title{margin:0;font-size:20px;line-height:1.2;color:#101828;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-v2__right{display:flex;align-items:center;gap:12px}.header-v2__search input{width:220px;height:38px;border:1px solid #d0d5dd;border-radius:10px;padding:0 12px;background:#f9fafb;color:#667085}.header-v2__user-chip{position:relative;display:flex;align-items:center;gap:10px;border:1px solid #e4e7ec;border-radius:999px;padding:5px 8px 5px 5px;background:#fff}.header-v2__avatar{width:30px;height:30px;border-radius:999px;object-fit:cover}.header-v2__user-trigger{border:0;background:transparent;display:flex;align-items:center;gap:8px;padding:0}.header-v2__user-info{display:flex;flex-direction:column;text-align:left}.header-v2__user-name{font-size:12px;font-weight:700;line-height:1.2;color:#101828}.header-v2__user-role{font-size:10px;line-height:1.2;color:#667085}.header-v2__caret{font-size:10px;color:#667085}.header-v2__user-menu{position:absolute;right:0;top:calc(100% + 8px);width:180px;border:1px solid #e4e7ec;border-radius:12px;background:#fff;box-shadow:var(--shadow-md);padding:6px;display:grid;gap:4px;z-index:20}.header-v2__user-menu button{border:0;background:transparent;border-radius:8px;padding:8px 10px;text-align:left;font-size:13px;color:#344054}.header-v2__user-menu button:hover{background:#f2f4f7}.header-v2__user-menu button.danger{color:#b42318}.header-v2__user-menu button.danger:hover{background:#fef2f2}@media (max-width: 900px){.header-v2__search{display:none}}@media (max-width: 640px){.header-v2__container{padding:0 12px}.header-v2__title{font-size:17px}.header-v2__user-info{display:none}.header-v2__user-menu{right:-4px}}.sidebar-v2{position:fixed;top:var(--header-height);left:0;width:var(--sidebar-width);height:calc(100vh - var(--header-height));transform:translate(-100%);transition:transform .25s ease;z-index:999;overflow-y:auto;border-right:1px solid #e4e7ec;background:linear-gradient(180deg,#0f172a 0%,#111827 100%)}.sidebar-v2--open{transform:translate(0)}.sidebar-v2--collapsed{width:var(--sidebar-collapsed-width)}.sidebar-v2__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.45);z-index:998}.sidebar-v2__content{min-height:100%;display:flex;flex-direction:column;padding:14px 0}.sidebar-v2__nav{flex:1;display:grid;gap:14px}.sidebar-v2__section{padding:0 10px}.sidebar-v2__section-title{margin:0 0 8px;padding:0 8px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8}.sidebar-v2__section-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;border:0;border-radius:10px;background:#1f2937;color:#e5e7eb;padding:8px 10px;font-size:12px;margin-bottom:8px}.sidebar-v2__menu{list-style:none;margin:0;padding:0;display:grid;gap:4px}.sidebar-v2__link{width:100%;border:0;border-radius:10px;background:transparent;display:flex;align-items:center;gap:10px;color:#cbd5e1;padding:10px;text-align:left}.sidebar-v2--collapsed .sidebar-v2__link{justify-content:center;padding:10px 8px}.sidebar-v2__link:hover{background:rgba(148,163,184,.16)}.sidebar-v2__link--active{background:linear-gradient(90deg,rgba(70,95,255,.35),rgba(6,182,212,.2));color:#fff;box-shadow:inset 0 0 0 1px #93c5fd59}.sidebar-v2__icon{width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.1);display:inline-flex;align-items:center;justify-content:center;font-size:15px;line-height:1}.sidebar-v2__text-wrap{display:grid;min-width:0}.sidebar-v2__label{font-size:13px;font-weight:700;line-height:1.2}.sidebar-v2__desc{font-size:11px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-v2__footer{padding:10px;border-top:1px solid rgba(148,163,184,.2)}.sidebar-v2__user-card{display:flex;gap:10px;align-items:center;background:rgba(255,255,255,.06);border-radius:12px;padding:10px}.sidebar-v2__user-avatar{width:32px;height:32px;border-radius:999px;object-fit:cover}.sidebar-v2__user-info{min-width:0;display:grid}.sidebar-v2__user-name{font-size:12px;color:#f8fafc;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-v2__user-email{font-size:11px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (min-width: 769px){.sidebar-v2__overlay{display:none}}@media (max-width: 768px){.sidebar-v2{width:min(320px,92vw)}}.footer{background:#2c3e50;color:#fff;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;padding:40px 20px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px}.footer-section h3{color:#f90;margin-bottom:15px;font-size:24px}.footer-section h4{color:#ecf0f1;margin-bottom:15px;font-size:18px}.footer-section p{color:#bdc3c7;line-height:1.6;margin-bottom:10px}.footer-section ul{list-style:none;padding:0}.footer-section ul li{margin-bottom:8px}.footer-section ul li a{color:#bdc3c7;text-decoration:none;transition:color .3s}.footer-section ul li a:hover{color:#f90}.footer-bottom{border-top:1px solid #34495e;padding:20px;text-align:center;background:#1a252f}.footer-bottom p{margin:5px 0;color:#95a5a6;font-size:14px}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:30px;padding:30px 20px}.footer-section{text-align:center}}.layout{min-height:100vh}.layout__main{margin-top:var(--header-height);transition:margin-left .25s ease}.layout__main--sidebar-open{margin-left:var(--sidebar-width)}.layout__main--sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.layout__content{min-height:calc(100vh - var(--header-height) - 80px);padding:22px;background:radial-gradient(circle at 100% 0%,rgba(70,95,255,.08),transparent 40%),linear-gradient(180deg,#f8faff 0%,#f3f6fc 100%)}.layout__content>*{animation:layoutFadeIn .28s ease}@keyframes layoutFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.layout__main--sidebar-open,.layout__main--sidebar-collapsed{margin-left:0}.layout__content{padding:14px}}.signup-modal{background:white;border-radius:12px;padding:30px;max-width:400px;width:90%;box-shadow:0 10px 30px #0000004d}.signup-modal h2{margin:0 0 15px;color:#333;text-align:center}.signup-modal p{color:#666;text-align:center;margin-bottom:25px;line-height:1.5}.user-info-preview{background:#f8f9fa;border-radius:8px;padding:20px;margin-bottom:25px;display:flex;align-items:center;gap:15px}.profile-preview{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid #e9ecef}.info-details{flex:1}.info-item{margin-bottom:8px;color:#333}.info-item strong{color:#495057;margin-right:8px}.modal-buttons{display:flex;gap:12px;justify-content:flex-end}.cancel-button,.confirm-button{padding:10px 20px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.cancel-button{background:#6c757d;color:#fff}.confirm-button{background:#667eea;color:#fff}.confirm-button:hover{background:#5a67d8}.login-v2-page{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background-image:linear-gradient(rgba(7,12,24,.65),rgba(7,12,24,.55)),url(/login_back.png);background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden}.login-v2-background{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.login-v2-orb{position:absolute;filter:blur(40px);opacity:.35}.login-v2-orb-left{width:380px;height:380px;border-radius:999px;background:#465fff;top:-110px;left:-80px}.login-v2-orb-right{width:330px;height:330px;border-radius:999px;background:#10b981;right:-80px;bottom:-100px}.login-v2-shell{position:relative;z-index:1;width:100%;max-width:1160px;min-height:640px;display:grid;grid-template-columns:1.2fr .8fr;border:1px solid rgba(255,255,255,.14);border-radius:24px;background:rgba(15,23,42,.68);box-shadow:0 18px 42px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.login-v2-brand{padding:56px;display:flex;flex-direction:column;gap:20px;color:#f8fafc}.login-v2-badge{width:fit-content;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 14px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#cbd5e1}.login-v2-brand h1{margin:0;font-size:clamp(34px,4.1vw,56px);line-height:1.1;color:#fff}.login-v2-subtitle{margin:0;color:#cbd5e1;font-size:17px;line-height:1.6;max-width:560px}.login-v2-feature-list{margin-top:auto;display:grid;gap:14px}.login-v2-feature{display:flex;gap:14px;align-items:flex-start;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(15,23,42,.55);padding:14px 16px}.login-v2-feature-dot{min-width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:#93c5fd;font-size:12px;font-weight:700}.login-v2-feature h3{margin:0 0 4px;color:#f8fafc;font-size:16px}.login-v2-feature p{margin:0;color:#cbd5e1;font-size:14px;line-height:1.5}.login-v2-card-wrapper{padding:36px;display:flex;align-items:center;justify-content:center}.login-v2-card{width:100%;max-width:420px;background:#ffffff;border-radius:18px;border:1px solid #e5e7eb;box-shadow:0 18px 40px #0f172a33;padding:30px}.login-v2-card h2{margin:0 0 8px;color:#101828;font-size:30px;line-height:1.2}.login-v2-card>p{margin:0 0 24px;color:#475467;font-size:15px;line-height:1.6}.login-v2-error{margin-bottom:16px;border:1px solid #fecaca;background:#fef2f2;color:#b42318;border-radius:10px;padding:10px 12px;font-size:14px}.login-v2-google-area{display:flex;flex-direction:column;align-items:center;gap:10px;min-height:52px}.login-v2-google-button{width:100%;display:flex;justify-content:center}.login-v2-loading{color:#475467;font-size:13px}@media (max-width: 1024px){.login-v2-shell{grid-template-columns:1fr;max-width:680px}.login-v2-brand{padding:36px 30px 20px}.login-v2-feature-list{margin-top:8px}.login-v2-card-wrapper{padding:20px 24px 30px}}@media (max-width: 640px){.login-v2-page{padding:14px}.login-v2-shell{border-radius:18px}.login-v2-brand{padding:28px 20px 12px;gap:14px}.login-v2-card-wrapper{padding:10px 16px 20px}.login-v2-card{padding:22px 18px}.login-v2-card h2{font-size:26px}.login-v2-feature{padding:12px}}.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease}.card--shadow-none{box-shadow:none}.card--shadow-sm{box-shadow:var(--shadow-sm)}.card--shadow-md{box-shadow:var(--shadow-md)}.card--shadow-lg{box-shadow:var(--shadow-lg)}.card--hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#d6ddff}.card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 18px 0}.card__title{color:var(--gray-900);font-size:16px;font-weight:700;line-height:1.3}.card__subtitle{margin-top:4px;color:var(--gray-600);font-size:13px}.card--padding-none .card__body{padding:0}.card--padding-sm .card__body{padding:12px}.card--padding-md .card__body{padding:16px}.card--padding-lg .card__body{padding:20px}@media (max-width: 640px){.card--padding-lg .card__body{padding:14px}}.btn{border:1px solid transparent;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;cursor:pointer;transition:all .18s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--sm{padding:8px 12px;font-size:13px}.btn--md{padding:10px 14px;font-size:14px}.btn--lg{padding:12px 18px;font-size:15px}.btn--primary{color:#fff;background:linear-gradient(90deg,var(--brand-600),var(--brand-500));border-color:var(--brand-600);box-shadow:0 4px 12px #465fff40}.btn--primary:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.03)}.btn--secondary{color:var(--gray-800);background:#eef2ff;border-color:#dbe4ff}.btn--secondary:hover:not(:disabled){background:#e1e8ff}.btn--success{color:#fff;background:#16a34a;border-color:#16a34a}.btn--danger{color:#fff;background:#dc2626;border-color:#dc2626}.btn--warning{color:#fff;background:#d97706;border-color:#d97706}.btn--info{color:#fff;background:#0284c7;border-color:#0284c7}.btn--light{color:var(--gray-800);background:#fff;border-color:var(--gray-300)}.btn--dark{color:#fff;background:var(--gray-900);border-color:var(--gray-900)}.btn--outline-primary{color:var(--brand-600);background:#fff;border-color:#c7d2fe}.btn--outline-primary:hover:not(:disabled){background:#eef2ff}.btn--outline-secondary{color:var(--gray-700);background:#fff;border-color:var(--gray-300)}.btn--outline-secondary:hover:not(:disabled){background:var(--gray-50)}.btn--full-width{width:100%}.btn--loading{color:transparent;position:relative}.btn__spinner{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}.btn__spinner-icon{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;display:block;animation:btn-spin .7s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn__text,.btn__icon{display:inline-flex;align-items:center}.exam-status-card{background:white;border-radius:12px;padding:24px;margin-bottom:30px;box-shadow:0 4px 12px #0000001a;border-left:4px solid #ddd}.exam-status-card.active{border-left-color:#667eea;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.exam-status-card.paused{border-left-color:#ffc107;background:linear-gradient(135deg,#ffc107 0%,#ff8f00 100%);color:#fff}.exam-status-card.ready{border-left-color:#28a745}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.status-header h3{margin:0;font-size:20px;font-weight:600}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.active,.status-badge.paused{background:rgba(255,255,255,.2);color:#fff}.status-badge.ready,.status-badge.passed{background:#e8f5e8;color:#2e7d32}.status-badge.failed{background:#ffebee;color:#c62828}.exam-title{font-size:16px;font-weight:600;margin-bottom:12px;margin-left:16px}.exam-info>span{margin-left:16px;font-size:16px;color:#666;display:block;margin-top:0;margin-bottom:12px}.exam-details{display:flex;flex-direction:column;gap:4px;font-size:14px;color:#666;margin-bottom:12px;margin-left:16px}.exam-details span:not(:last-child):after{content:"";display:block;width:100%;height:1px;background:#eee;margin:4px 0}.exam-status-card.active .exam-details,.exam-status-card.active .progress-stats{color:#ffffffe6}.progress-info{margin-bottom:20px}.progress-stats{display:flex;justify-content:space-between;font-size:14px;margin-bottom:12px;flex-wrap:wrap;gap:8px;color:#fff}.progress-bar{background:rgba(255,255,255,.2);border-radius:10px;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill{background:white;height:100%;border-radius:10px;transition:width .3s ease}.progress-text{text-align:center;font-size:12px;opacity:.9}.last-attempt{font-size:14px;color:#666;padding:8px 0;border-top:1px solid #eee;display:flex;flex-direction:column;gap:4px}.action-button{width:100%;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.action-button.continue{background:white;color:#667eea}.action-button.continue:hover{background:#f8f9ff;transform:translateY(-1px)}.action-button.start{background:#28a745;color:#fff}.action-button.start:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.action-button:disabled{background:#ccc;cursor:not-allowed;transform:none}@media (max-width: 768px){.exam-status-card{margin:0 -10px 20px}.progress-stats{flex-direction:column;gap:4px}.status-header{flex-direction:column;align-items:stretch;gap:10px}.status-header h3{text-align:center;font-size:18px}.status-badge{align-self:center}}@media (max-width: 480px){.exam-status-card{padding:20px 15px;margin:0 -5px 15px}.exam-title{font-size:16px}.exam-details{font-size:13px}.action-button{padding:10px 20px;font-size:14px}}.ad-banner{margin:20px 0;text-align:center;border:1px solid #e0e0e0;border-radius:8px;padding:10px;background-color:#fafafa;overflow:hidden}.ad-label{font-size:12px;color:#666;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.adsbygoogle{background:transparent;overflow:hidden}.ad-banner.mobile{margin:15px 5px;padding:8px;border-radius:6px;max-width:calc(100vw - 20px)}.ad-banner.mobile .ad-label{font-size:11px;margin-bottom:6px}.ad-banner.mobile .adsbygoogle{min-height:250px!important;max-width:100%}.ad-banner.desktop{margin:20px auto;max-width:728px}.ad-banner.desktop .adsbygoogle{min-height:90px}@media (max-width: 768px){.ad-banner{margin:15px 5px;padding:8px;max-width:calc(100vw - 20px)}.ad-label{font-size:11px}.adsbygoogle{min-height:250px!important;min-width:300px!important}}@media (max-width: 480px){.ad-banner{margin:10px 5px;padding:6px}.ad-banner .adsbygoogle{min-height:200px!important;min-width:280px!important}}.dashboard-v2{display:grid;gap:18px}.dashboard-v2--loading{min-height:280px;display:grid;place-items:center;text-align:center;color:var(--gray-600)}.dashboard-v2__spinner{width:36px;height:36px;border:3px solid #dbe4ff;border-top-color:var(--brand-600);border-radius:999px;animation:dashboardSpin .8s linear infinite;margin:0 auto 10px}@keyframes dashboardSpin{to{transform:rotate(360deg)}}.dashboard-v2__error{padding:10px 12px;border:1px solid #fecaca;border-radius:var(--radius-md);background:#fef2f2;color:#b42318;font-size:14px}.dashboard-v2__hero{border:1px solid #d6ddff;border-radius:var(--radius-xl);background:radial-gradient(circle at 0% 0%,rgba(70,95,255,.18),transparent 42%),linear-gradient(135deg,#ffffff 0%,#f6f8ff 100%);padding:22px;display:grid;grid-template-columns:1fr 220px;gap:18px}.dashboard-v2__hero-eyebrow{display:inline-block;font-size:11px;letter-spacing:.08em;color:var(--brand-600);font-weight:700;margin-bottom:8px}.dashboard-v2__hero h1{font-size:clamp(24px,2.5vw,32px);line-height:1.2;color:var(--gray-900);margin-bottom:10px}.dashboard-v2__hero p{color:var(--gray-600);max-width:760px}.dashboard-v2__hero-actions{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.dashboard-v2__hero-meta{border:1px solid #d6ddff;border-radius:var(--radius-lg);background:#fff;padding:14px;display:grid;align-content:center;gap:6px}.dashboard-v2__meta-title{font-size:12px;color:var(--gray-500)}.dashboard-v2__hero-meta strong{font-size:34px;color:var(--brand-600);line-height:1}.dashboard-v2__hero-meta p{font-size:13px;color:var(--gray-600)}.dashboard-v2__metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dashboard-v2__metric{border-width:1px}.dashboard-v2__metric-label{display:block;color:var(--gray-600);font-size:13px;margin-bottom:8px}.dashboard-v2__metric-value{font-size:28px;line-height:1.1;color:var(--gray-900)}.dashboard-v2__metric--blue{border-color:#d6ddff}.dashboard-v2__metric--green{border-color:#d1f3e1}.dashboard-v2__metric--violet{border-color:#e8dfff}.dashboard-v2__metric--amber{border-color:#fbe7c2}.dashboard-v2__main-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:12px}.dashboard-v2__section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dashboard-v2__section-head h3{font-size:16px;color:var(--gray-900)}.dashboard-v2__section-head span{font-size:12px;color:var(--gray-500)}.dashboard-v2__empty{border:1px dashed var(--gray-300);border-radius:var(--radius-md);padding:16px;color:var(--gray-500);font-size:14px}.dashboard-v2__notice-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.dashboard-v2__notice-btn{width:100%;border:1px solid var(--gray-200);border-radius:10px;background:#fff;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left}.dashboard-v2__notice-btn:hover{border-color:#cdd7ff;background:#f8faff}.dashboard-v2__notice-title{min-width:0;color:var(--gray-800);font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-v2__notice-title em{font-style:normal;font-size:10px;background:#dbe4ff;color:var(--brand-700);border-radius:999px;padding:2px 6px;margin-right:6px}.dashboard-v2__notice-date{color:var(--gray-500);font-size:12px;flex-shrink:0}.dashboard-v2__quick-actions{display:grid;gap:8px}.dashboard-v2__status-wrap{border-radius:var(--radius-lg)}.dashboard-v2__ad{margin-top:6px}.dashboard-v2__modal{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.55);display:grid;place-items:center;padding:14px;z-index:1100}.dashboard-v2__modal-card{width:min(760px,100%);max-height:min(80vh,760px);overflow:auto;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--gray-200);box-shadow:var(--shadow-lg)}.dashboard-v2__modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--gray-200)}.dashboard-v2__modal-head h3{font-size:18px;color:var(--gray-900)}.dashboard-v2__modal-head button{border:0;background:#f2f4f7;color:var(--gray-700);width:30px;height:30px;border-radius:8px;font-size:18px;line-height:1}.dashboard-v2__modal-meta{padding:10px 16px;border-bottom:1px solid var(--gray-200);color:var(--gray-500);font-size:12px;display:flex;gap:14px}.dashboard-v2__modal-body{padding:16px;color:var(--gray-700);line-height:1.7}.dashboard-v2__modal-body p+p{margin-top:10px}@media (max-width: 1200px){.dashboard-v2__metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 980px){.dashboard-v2__hero,.dashboard-v2__main-grid{grid-template-columns:1fr}}@media (max-width: 640px){.dashboard-v2__hero{padding:16px}.dashboard-v2__hero-actions{display:grid;grid-template-columns:1fr}.dashboard-v2__metrics-grid{grid-template-columns:1fr}.dashboard-v2__notice-btn{flex-direction:column;align-items:flex-start}}.access-denied{text-align:center;padding:60px 20px;background:white;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.access-denied h2{margin:0 0 12px;color:#ef4444;font-size:24px;font-weight:600}.access-denied p{margin:0;color:#6b7280;font-size:16px}.loading{text-align:center;padding:40px 20px;color:#6b7280;font-size:14px}.admin-page{max-width:1200px;margin:0 auto;padding:24px;min-height:100vh;background:#f9fafb}.admin-page h1{margin:0 0 32px;color:#111827;font-size:28px;font-weight:700;text-align:center}.admin-btn{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:11px;transition:all .2s ease;text-align:center;box-shadow:0 1px 3px #0000001a;min-width:70px;height:28px;display:inline-flex;align-items:center;justify-content:center;gap:4px}.admin-btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.admin-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.admin-btn.primary{background:#4f46e5;color:#fff}.admin-btn.primary:hover{background:#4338ca}.admin-btn.success{background:#10b981;color:#fff}.admin-btn.success:hover{background:#059669}.admin-btn.danger{background:#ef4444;color:#fff}.admin-btn.danger:hover{background:#dc2626}.admin-btn.secondary{background:#6b7280;color:#fff}.admin-btn.secondary:hover{background:#4b5563}.admin-btn.outline{background:white;color:#4f46e5;border:1px solid #4f46e5}.admin-btn.outline:hover{background:#4f46e5;color:#fff}.admin-btn.large{padding:8px 16px;font-size:12px;height:32px;min-width:80px}.admin-btn.small{padding:4px 8px;font-size:10px;height:24px;min-width:50px}.admin-btn:before{margin-right:2px}.admin-btn.success:before{content:"✓"}.admin-btn.danger:before{content:"✕"}.admin-btn.warning:before{content:"✎"}.admin-btn.primary:before{content:"🔍"}.admin-btn.secondary:before{content:"↻"}.admin-form-control{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:11px;font-weight:400;background:white;color:#374151;transition:all .2s ease;height:26px;min-width:80px;box-shadow:0 1px 2px #0000000d}.admin-form-control:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51a}.admin-form-control:hover{border-color:#9ca3af}.admin-form-control:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}.admin-form-control.textarea{height:auto;min-height:60px;resize:vertical;line-height:1.4}.admin-form-control.select{cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 4px center;background-repeat:no-repeat;background-size:12px;padding-right:24px}.admin-form-control.sm{padding:2px 6px;font-size:10px;height:22px}.admin-form-control.sm.textarea{min-height:50px;max-height:120px;line-height:1.3}.admin-form-control.lg{padding:6px 12px;font-size:12px;height:32px}.admin-checkbox,.admin-radio{width:14px;height:14px;margin:0 4px 0 0;cursor:pointer;accent-color:#4f46e5}.admin-section{background:white;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;margin-bottom:24px}.admin-section h2{margin:0 0 24px;color:#111827;font-size:1.5rem;font-weight:600;display:flex;align-items:center;gap:8px}.admin-page--embedded{max-width:none;margin:0;padding:0;min-height:auto;background:transparent}.admin-management-tabs{display:inline-flex;align-items:center;gap:8px;margin-bottom:20px;padding:4px;background:#f3f4f6;border-radius:10px}.admin-management-tab{border:0;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:600;color:#4b5563;background:transparent;cursor:pointer;transition:all .15s ease}.admin-management-tab:hover{color:#111827;background:#e5e7eb}.admin-management-tab.active{background:#ffffff;color:#1f2937;box-shadow:0 1px 2px #0f172a1f}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.admin-header h2{margin:0}.admin-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.admin-controls .admin-form-control{margin-right:8px}.admin-table{width:100%;border-collapse:collapse;margin-top:16px}.admin-table th,.admin-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #e5e7eb;font-size:11px}.admin-table th{background:#f9fafb;font-weight:600;color:#374151}.admin-table tr:hover{background:#f9fafb}.admin-card{background:white;border:1px solid #e5e7eb;border-radius:6px;padding:16px;margin-bottom:12px;transition:all .2s ease}.admin-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.admin-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.admin-modal-content{background:white;border-radius:8px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.admin-modal-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#111827}.admin-modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:#6b7280;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.admin-modal-close:hover{background:#e5e7eb;color:#374151}.admin-modal-body{padding:20px}.admin-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid #e5e7eb;background:#f9fafb}.admin-form-group{margin-bottom:16px}.admin-form-group label{display:block;font-size:11px;font-weight:600;margin-bottom:4px;color:#374151}.admin-form-group .admin-form-control{width:100%}.admin-form-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.admin-form-inline .admin-form-control{margin-bottom:0}.admin-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding:16px;background:#f9fafb;border-radius:6px}.admin-pagination .admin-btn{background:white;color:#4f46e5;border:1px solid #4f46e5}.admin-pagination .admin-btn:hover:not(:disabled){background:#4f46e5;color:#fff}.admin-pagination .admin-btn:disabled{background:#f3f4f6;color:#9ca3af;border-color:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.admin-pagination span{font-size:11px;color:#6b7280;font-weight:500}.admin-badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.admin-badge.success{background:rgba(16,185,129,.1);color:#059669}.admin-badge.danger{background:rgba(239,68,68,.1);color:#dc2626}.admin-badge.warning{background:rgba(245,158,11,.1);color:#d97706}.admin-badge.info{background:rgba(79,70,229,.1);color:#4338ca}.admin-badge.secondary{background:rgba(107,114,128,.1);color:#4b5563}@media (max-width: 768px){.admin-management-tabs{display:flex;width:100%}.admin-management-tab{flex:1;text-align:center}.admin-btn{font-size:10px;padding:4px 8px;height:24px;min-width:50px}.admin-form-control{font-size:10px;padding:3px 6px;height:24px;min-width:60px}.admin-form-control.textarea{min-height:50px}.admin-form-control.select{padding-right:20px;background-size:10px}.admin-section{padding:16px;margin-bottom:16px}.admin-controls{flex-direction:column;align-items:stretch}.admin-modal-content{margin:10px;max-width:none}.admin-table{font-size:10px}.admin-table th,.admin-table td{padding:6px 8px}}.admin-text-xs{font-size:10px}.admin-text-sm{font-size:11px}.admin-text-base{font-size:12px}.admin-text-lg{font-size:14px}.admin-font-normal{font-weight:400}.admin-font-medium{font-weight:500}.admin-font-semibold{font-weight:600}.admin-font-bold{font-weight:700}.admin-text-gray-700{color:#374151}.admin-text-gray-900{color:#111827}.admin-mb-2{margin-bottom:8px}.admin-mb-4{margin-bottom:16px}.admin-mb-6{margin-bottom:24px}.admin-mt-2{margin-top:8px}.admin-mt-4{margin-top:16px}.admin-mt-6{margin-top:24px}.admin-flex{display:flex}.admin-flex-col{flex-direction:column}.admin-items-center{align-items:center}.admin-justify-between{justify-content:space-between}.admin-gap-2{gap:8px}.admin-gap-4{gap:16px}.admin-w-full{width:100%}.admin-h-full{height:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.user-modal{background:white;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background:#f9fafb;border-radius:0 0 12px 12px}.user-info{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:16px;background:#f9fafb;border-radius:8px}.user-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.user-avatar.large{width:60px;height:60px}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:600;color:#6b7280;font-size:14px}.user-avatar.large .avatar-placeholder{font-size:20px}.user-details h4{margin:0 0 4px;font-size:16px;font-weight:600;color:#111827}.user-details p{margin:0 0 8px;color:#6b7280;font-size:14px}.user-stats{display:flex;gap:12px;font-size:12px;color:#6b7280}.user-stats span{background:white;padding:4px 8px;border-radius:4px;border:1px solid #e5e7eb}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:14px}.form-group label input[type=checkbox]{margin-right:8px}.users-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;background:#f9fafb;border-radius:8px;font-size:14px;color:#6b7280}.users-stats span{font-weight:500}.user-admin-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.user-admin-table{min-width:980px;table-layout:fixed}.user-admin-table .col-user{width:210px}.user-admin-table .col-email{width:230px}.user-admin-table .col-role,.user-admin-table .col-plan{width:90px}.user-admin-table .col-exams,.user-admin-table .col-score{width:90px;text-align:center}.user-admin-table .col-login{width:180px}.user-admin-table .col-action{width:90px;text-align:center}.user-cell{display:flex;align-items:center;gap:10px}.user-cell__meta{display:flex;flex-direction:column;min-width:0}.user-cell__meta strong{font-size:12px;color:#111827;line-height:1.2}.user-email-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 1024px){.user-admin-table{min-width:760px}.user-admin-table .col-login,.user-admin-table .col-email{display:none}}@media (max-width: 768px){.user-admin-table{min-width:620px}.user-admin-table .col-score{display:none}}@media (max-width: 560px){.user-admin-table{min-width:520px}.user-admin-table .col-plan{display:none}}.exam-type-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.exam-type-table{min-width:980px;table-layout:fixed}.exam-type-table .col-exam-name{width:320px}.exam-type-table .col-exam-id{width:170px}.exam-type-table .col-total-questions,.exam-type-table .col-exam-time,.exam-type-table .col-pass-score{width:90px;text-align:center}.exam-type-table .col-access-scope{width:130px}.exam-type-table .col-status,.exam-type-table .col-action{width:90px;text-align:center}.exam-type-cell{display:flex;align-items:center;gap:10px}.examtype-icon{width:32px;height:32px;border-radius:8px;border:1px solid #e2e8f0;background:#f8fafc;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.examtype-icon img{width:100%;height:100%;border-radius:7px;object-fit:contain}.examtype-icon span{font-size:18px}.exam-type-cell__meta{min-width:0;display:flex;flex-direction:column}.exam-type-cell__meta strong{color:#111827;font-size:12px;line-height:1.2}.exam-type-cell__meta span{margin-top:3px;color:#6b7280;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.exam-type-table code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:2px 6px;color:#334155;font-size:11px}.exam-type-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.58);display:grid;place-items:center;z-index:1200;padding:16px}.exam-type-modal{width:min(920px,100%);max-height:calc(100vh - 32px);overflow:hidden;border-radius:14px;border:1px solid #dbe3ef;background:#ffffff;box-shadow:0 30px 60px #0f172a38;display:flex;flex-direction:column}.exam-type-modal__header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:16px 18px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.exam-type-modal__header h3{margin:0;color:#0f172a;font-size:18px}.exam-type-modal__close{border:none;background:transparent;color:#64748b;width:32px;height:32px;border-radius:8px;font-size:22px;line-height:1;cursor:pointer}.exam-type-modal__close:hover{background:#e2e8f0;color:#334155}.exam-type-modal__body{padding:16px 18px;overflow-y:auto}.exam-type-modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid #e5e7eb;background:#f8fafc}.exam-type-modal__error{margin:12px 0 0;padding:8px 10px;border:1px solid #fecaca;border-radius:8px;background:#fff1f2;color:#b91c1c;font-size:12px;font-weight:600}.exam-type-editor-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.exam-type-editor-grid>.admin-form-group{min-width:0}.exam-type-editor-grid>.admin-form-group:nth-child(1),.exam-type-editor-grid>.admin-form-group:nth-child(2),.exam-type-editor-grid>.admin-form-group:nth-child(3),.exam-type-editor-grid>.admin-form-group:nth-child(4),.exam-type-editor-grid>.admin-form-group:nth-child(6),.exam-type-editor-grid>.admin-form-group:nth-child(7){grid-column:1 / -1}.exam-type-editor-grid__metrics{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.exam-type-editor-grid__metrics .admin-form-group{margin-bottom:0}@media (max-width: 1024px){.exam-type-table{min-width:760px}.exam-type-table .col-exam-id,.exam-type-table .col-access-scope{display:none}}@media (max-width: 768px){.exam-type-table{min-width:620px}.exam-type-table .col-total-questions{display:none}.exam-type-editor-grid,.exam-type-editor-grid__metrics{grid-template-columns:1fr}.exam-type-modal__footer{flex-direction:column-reverse}.exam-type-modal__footer .admin-btn{width:100%}}@media (max-width: 560px){.exam-type-table{min-width:520px}.exam-type-table .col-exam-time{display:none}}.user-edit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.55);display:grid;place-items:center;z-index:1200;padding:16px}.user-edit-modal{width:min(640px,100%);border-radius:14px;border:1px solid #e2e8f0;background:#ffffff;box-shadow:0 28px 60px #0f172a33;overflow:hidden}.user-edit-modal__header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid #e5e7eb;background:#f8fafc}.user-edit-modal__header h3{margin:0;font-size:18px;color:#0f172a}.user-edit-modal__close{border:none;background:transparent;width:32px;height:32px;border-radius:8px;color:#64748b;font-size:22px;line-height:1;cursor:pointer}.user-edit-modal__close:hover{background:#e2e8f0;color:#334155}.user-edit-modal__body{padding:18px}.user-edit-profile{display:flex;align-items:center;gap:14px;padding:12px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc}.user-edit-profile__meta{min-width:0}.user-edit-profile__meta h4{margin:0;color:#0f172a;font-size:16px}.user-edit-profile__meta p{margin:4px 0 0;color:#475569;font-size:13px}.user-edit-profile__stats{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}.user-edit-profile__stats span{padding:4px 8px;border:1px solid #dbe1ea;border-radius:999px;background:#ffffff;color:#475569;font-size:12px}.user-edit-form{margin-top:14px;display:grid;gap:10px}.user-edit-form__row{display:grid;grid-template-columns:110px 1fr;gap:12px;align-items:center;padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px}.user-edit-form__label{margin:0;color:#475569;font-size:13px;font-weight:600}.user-edit-form__checkbox{margin:0;display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#1f2937}.user-edit-form__checkbox input[type=checkbox]{margin:0}.user-edit-modal__footer{padding:14px 18px;border-top:1px solid #e5e7eb;background:#f8fafc;display:flex;justify-content:flex-end;gap:8px}@media (max-width: 640px){.user-edit-modal{width:100%}.user-edit-profile{align-items:flex-start}.user-edit-form__row{grid-template-columns:1fr;gap:8px}.user-edit-modal__footer{flex-direction:column-reverse}.user-edit-modal__footer .admin-btn{width:100%}}.question-admin-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.question-admin-table{min-width:980px;table-layout:fixed}.question-admin-table .col-question-id{width:120px}.question-admin-table .col-question-text{width:360px}.question-admin-table .col-option-count{width:90px;text-align:center}.question-admin-table .col-correct-answer{width:120px}.question-admin-table .col-question-meta{width:110px;text-align:center}.question-admin-table .col-validated{width:90px;text-align:center}.question-admin-table .col-question-action{width:170px;text-align:center}.question-text-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.question-edit-modal-overlay,.question-ai-modal-overlay,.question-action-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.58);display:grid;place-items:center;z-index:1200;padding:16px}.question-edit-modal{width:min(920px,100%);max-height:calc(100vh - 32px);overflow:hidden;border-radius:14px;border:1px solid #dbe3ef;background:#ffffff;box-shadow:0 30px 60px #0f172a38;display:flex;flex-direction:column}.question-edit-modal__header,.question-ai-modal__header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:16px 18px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.question-edit-modal__header h3,.question-ai-modal__header h3{margin:0;color:#0f172a;font-size:18px}.question-edit-modal__close,.question-ai-modal__close{border:none;background:transparent;color:#64748b;width:32px;height:32px;border-radius:8px;font-size:22px;line-height:1;cursor:pointer}.question-edit-modal__close:hover,.question-ai-modal__close:hover{background:#e2e8f0;color:#334155}.question-edit-modal__body,.question-ai-modal__body{padding:16px 18px;overflow-y:auto}.question-edit-modal__footer,.question-ai-modal__footer{background:#f8fafc;padding:14px 18px;border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end}.question-edit-modal__error{margin:12px 0 0;padding:8px 10px;border:1px solid #fecaca;border-radius:8px;background:#fff1f2;color:#b91c1c;font-size:12px;font-weight:600}.question-ai-modal{width:min(640px,100%);max-height:calc(100vh - 32px);overflow:hidden;border-radius:14px;border:1px solid #dbe3ef;background:#ffffff;box-shadow:0 30px 60px #0f172a38;display:flex;flex-direction:column}.question-action-modal{width:min(420px,100%);border-radius:12px;border:1px solid #e2e8f0;background:#ffffff;box-shadow:0 24px 50px #0f172a33;padding:18px}.question-action-modal h3{margin:0 0 8px;color:#0f172a;font-size:18px}.question-action-modal p{margin:0;color:#475569;font-size:14px;line-height:1.5}.question-action-modal__footer{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}.question-modal{background:white;border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.ai-analysis-modal{background:white;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.question-editor{padding:0}.question-preview{max-width:300px;word-wrap:break-word;line-height:1.4}.correct-answers{display:flex;gap:4px;flex-wrap:wrap}.correct-answers .admin-badge{font-size:10px;padding:2px 6px;border-radius:3px;font-weight:600}.options-editor{display:flex;flex-direction:column;gap:12px}.option-item{border:1px solid #e5e7eb;border-radius:8px;padding:12px;background:#f9fafb}.option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.option-header label{display:flex;align-items:center;gap:8px;font-weight:500;color:#374151;margin-bottom:0}.option-header input[type=checkbox]{margin:0}.bulk-actions{display:flex;gap:12px;margin-bottom:16px;padding:12px 16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.questions-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;background:#f9fafb;border-radius:8px;font-size:14px;color:#6b7280}.questions-stats span{font-weight:500}@media (max-width: 1024px){.question-admin-table{min-width:760px}.question-admin-table .col-question-meta{display:none}}@media (max-width: 768px){.question-admin-table{min-width:620px}.question-admin-table .col-option-count{display:none}.question-edit-modal__footer,.question-ai-modal__footer,.question-action-modal__footer{flex-direction:column-reverse}.question-edit-modal__footer .admin-btn,.question-ai-modal__footer .admin-btn,.question-action-modal__footer .admin-btn{width:100%}}@media (max-width: 560px){.question-admin-table{min-width:520px}.question-admin-table .col-correct-answer{display:none}}.analysis-section{margin-bottom:20px}.analysis-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#111827}.analysis-content{display:flex;flex-direction:column;gap:12px}.analysis-item{padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.analysis-item strong{display:block;margin-bottom:6px;color:#374151;font-weight:600}.analysis-item p{margin:0;color:#6b7280;line-height:1.5}.recommended-answers{display:flex;gap:6px;margin-top:6px}.admin-btn.info{background:#3b82f6;color:#fff}.admin-btn.info:hover{background:#2563eb}.admin-btn.warning{background:#f59e0b;color:#fff}.admin-btn.warning:hover{background:#d97706}.admin-btn.small{padding:4px 8px;font-size:10px;min-width:50px;height:24px}.admin-btn.outline{background:transparent;border:1px solid #d1d5db;color:#374151}.admin-btn.outline:hover{background:#f9fafb;border-color:#9ca3af;color:#111827}.page-info{padding:8px 16px;background:#f3f4f6;border-radius:6px;font-size:12px;color:#6b7280;font-weight:500}.keywords-input{border:1px solid #d1d5db;border-radius:6px;padding:8px;background:white;min-height:40px}.keywords-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.keyword-tag{display:inline-flex;align-items:center;gap:4px;background:#e5e7eb;color:#374151;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.keyword-tag button{background:none;border:none;color:#6b7280;cursor:pointer;font-size:14px;line-height:1;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:2px;transition:all .2s ease}.keyword-tag button:hover{background:#d1d5db;color:#374151}.keywords-input input{border:none;outline:none;background:transparent;font-size:14px;color:#374151;width:100%;min-width:120px}.keywords-input input::placeholder{color:#9ca3af}.report-admin-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.report-admin-table{min-width:1080px;table-layout:fixed}.report-admin-table .col-report-id{width:90px}.report-admin-table .col-report-type,.report-admin-table .col-report-author{width:120px}.report-admin-table .col-report-question{width:140px}.report-admin-table .col-report-content{width:320px}.report-admin-table .col-report-status{width:90px;text-align:center}.report-admin-table .col-report-date{width:110px}.report-admin-table .col-report-action{width:190px;text-align:center}.report-question-cell{font-size:11px;color:#475569;line-height:1.35}.report-content-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-type-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;border:1px solid #dbe1ea;background:#f8fafc;color:#334155;font-size:11px;font-weight:600}.report-type-chip__icon{display:inline-flex;align-items:center;justify-content:center;font-size:13px}.report-detail-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.58);display:grid;place-items:center;z-index:1200;padding:16px}.report-detail-modal{width:min(760px,100%);max-height:calc(100vh - 72px);overflow:hidden;border-radius:14px;border:1px solid #dbe3ef;background:#ffffff;box-shadow:0 30px 60px #0f172a38;display:flex;flex-direction:column}.report-detail-modal__header{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.report-detail-modal__header h3{margin:0;color:#0f172a;font-size:18px}.report-detail-modal__close{border:none;background:transparent;color:#64748b;width:32px;height:32px;border-radius:8px;font-size:22px;line-height:1;cursor:pointer}.report-detail-modal__close:hover{background:#e2e8f0;color:#334155}.report-detail-modal__body{padding:12px 14px;overflow-y:auto}.report-detail-content{padding:0}.report-detail-table{width:100%;border-collapse:collapse;table-layout:fixed}.report-detail-table th,.report-detail-table td{border:1px solid #e5e7eb;padding:10px 12px;vertical-align:top;font-size:13px}.report-detail-table th{width:140px;background:#f8fafc;color:#475569;font-weight:700;text-align:left}.report-detail-table td{color:#0f172a}.report-detail-modal__footer{background:#f8fafc;padding:10px 14px;border-top:1px solid #e5e7eb;display:flex;gap:8px;justify-content:flex-end}.report-action-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.58);display:grid;place-items:center;z-index:1210;padding:16px}.report-action-modal{width:min(420px,100%);border-radius:12px;border:1px solid #e2e8f0;background:#ffffff;box-shadow:0 24px 50px #0f172a33;padding:18px}.report-action-modal h3{margin:0 0 8px;color:#0f172a;font-size:18px}.report-action-modal p{margin:0;color:#475569;font-size:14px;line-height:1.5}.report-action-modal__footer{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}.report-modal{background:white;border-radius:12px;width:90%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.report-info{padding:0}.info-section{margin-bottom:24px}.info-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#111827;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.info-item{display:flex;flex-direction:column;gap:4px}.info-item.full-width{grid-column:1 / -1}.info-item label{font-weight:500;color:#6b7280;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.info-item span{color:#111827;font-size:14px}.question-content{background:#f9fafb;padding:12px;border-radius:6px;border:1px solid #e5e7eb;font-size:14px;line-height:1.5;color:#374151}.options-list{background:#f9fafb;padding:12px;border-radius:6px;border:1px solid #e5e7eb}.option-item{display:flex;gap:8px;margin-bottom:8px;font-size:14px}.option-item:last-child{margin-bottom:0}.option-number{font-weight:600;color:#6b7280;min-width:20px}.option-text{color:#374151;line-height:1.4}.report-description{background:#f9fafb;padding:16px;border-radius:8px;border:1px solid #e5e7eb;font-size:14px;line-height:1.6;color:#374151;white-space:pre-wrap}.admin-response{background:#fef3c7;padding:16px;border-radius:8px;border:1px solid #fbbf24;font-size:14px;line-height:1.6;color:#92400e;white-space:pre-wrap}.reports-stats{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;background:#f9fafb;border-radius:8px;font-size:14px;color:#6b7280}.reports-stats span{font-weight:500}@media (max-width: 768px){.report-admin-table{min-width:780px}.report-admin-table .col-report-question,.report-admin-table .col-report-date{display:none}.report-detail-modal__footer{flex-direction:column-reverse}.report-detail-modal__footer .admin-btn{width:100%}.report-action-modal__footer{flex-direction:column-reverse}.report-action-modal__footer .admin-btn{width:100%}.report-detail-table th,.report-detail-table td{font-size:12px;padding:8px 10px}.report-detail-table th{width:108px}.info-grid{grid-template-columns:1fr}.report-modal{width:95%;max-height:95vh}}@media (max-width: 560px){.report-admin-table{min-width:640px}.report-admin-table .col-report-type{display:none}}.coupon-admin-tabs{display:inline-flex;align-items:center;gap:8px;margin-bottom:20px;padding:4px;background:#f3f4f6;border-radius:10px}.coupon-admin-tab{border:0;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:600;color:#4b5563;background:transparent;cursor:pointer;transition:all .15s ease}.coupon-admin-tab:hover{color:#111827;background:#e5e7eb}.coupon-admin-tab.active{background:#ffffff;color:#1f2937;box-shadow:0 1px 2px #0f172a1f}.coupon-modal{background:white;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.coupon-editor{padding:0}.coupon-editor-table{width:100%;border-collapse:collapse;table-layout:fixed}.coupon-editor-table th,.coupon-editor-table td{border:1px solid #e5e7eb;padding:10px 12px;vertical-align:top}.coupon-editor-table th{width:130px;background:#f8fafc;color:#475569;font-size:12px;font-weight:700;text-align:left}.coupon-editor-table td{background:#ffffff}.coupon-editor-checkbox{display:inline-flex;align-items:center;gap:8px;color:#1f2937;font-size:14px}.coupon-editor-checkbox input[type=checkbox]{margin:0}.form-text{font-size:12px;color:#6b7280;margin-top:4px;display:block}.admin-text-gray-500{color:#6b7280}.usage-logs-section{margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.usage-logs-section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#111827}.usage-search{display:flex;gap:12px;margin-bottom:16px;align-items:center}.usage-search input{flex:1;max-width:200px}.admin-badge.success{background:#10b981;color:#fff}.admin-badge.secondary{background:#6b7280;color:#fff}.admin-badge.info{background:#3b82f6;color:#fff}.admin-badge.warning{background:#f59e0b;color:#fff}.admin-badge.danger{background:#ef4444;color:#fff}@media (max-width: 768px){.coupon-admin-tabs{display:flex;width:100%}.coupon-admin-tab{flex:1;text-align:center}.coupon-editor-table th,.coupon-editor-table td{padding:8px 10px;font-size:12px}.coupon-editor-table th{width:104px}}.admin-layout{display:flex;min-height:100vh;background:#f9fafb}.admin-sidebar{width:250px;background:white;border-right:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.admin-sidebar-header{padding:20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.admin-sidebar-header h3{margin:0;font-size:16px;font-weight:600;color:#111827}.admin-sidebar-nav{padding:16px 0}.admin-sidebar-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 20px;border:none;background:none;text-align:left;cursor:pointer;transition:all .2s ease;color:#6b7280;font-size:14px;font-weight:500}.admin-sidebar-item:hover{background:#f3f4f6;color:#374151}.admin-sidebar-item.active{background:#e0e7ff;color:#4338ca;border-right:3px solid #4338ca}.admin-sidebar-icon{font-size:16px;width:20px;text-align:center}.admin-sidebar-label{flex:1}.admin-content{flex:1;padding:24px;overflow-y:auto}@media (max-width: 768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;order:2}.admin-content{order:1;padding:16px}.admin-sidebar-nav{display:flex;overflow-x:auto;padding:8px}.admin-sidebar-item{flex-shrink:0;padding:8px 16px;border-radius:6px;margin-right:8px;border-right:none}.admin-sidebar-item.active{border-right:none;border-radius:6px}}.post-editor-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.post-editor{background:white;border-radius:12px;width:100%;max-width:1200px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #eee;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:12px 12px 0 0}.editor-header h3{margin:0;font-size:20px}.close-button{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close-button:hover{background:rgba(255,255,255,.2)}.editor-form{padding:30px}.form-row{display:flex;gap:20px;align-items:end;margin-bottom:20px}.form-group{margin-bottom:20px;flex:1}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;margin-bottom:0!important}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid #e9ecef;border-radius:8px;font-size:14px;transition:border-color .3s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:300px;line-height:1.6}.form-group input[type=checkbox]{width:auto;margin:0}.editor-actions{display:flex;gap:15px;justify-content:flex-end;padding-top:20px;border-top:1px solid #eee}.save-button{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:600;cursor:pointer;transition:transform .2s}.save-button:hover{transform:translateY(-1px)}.cancel-button{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:600;cursor:pointer;transition:background .2s}@media (max-width: 768px){.post-editor-modal{padding:10px}.post-editor{max-height:95vh}.editor-header{padding:15px 20px}.editor-form{padding:20px}.form-row{flex-direction:column;gap:0}.editor-actions{flex-direction:column}.save-button,.cancel-button{width:100%}}.analytics-v2{max-width:1420px}.analytics-v2__header{align-items:flex-start;gap:16px}.analytics-v2__subtitle{margin:8px 0 0;color:#64748b;font-size:13px}.analytics-v2__subtitle span{color:#0f172a;font-weight:600;margin-left:8px}.analytics-v2__tabs{display:inline-flex;background:#eef2ff;border-radius:10px;padding:4px;margin-bottom:20px;border:1px solid #dbe4ff}.analytics-v2__tab{border:0;background:transparent;color:#475569;font-size:12px;font-weight:600;border-radius:8px;padding:8px 14px;cursor:pointer;transition:all .15s ease}.analytics-v2__tab:hover{background:#dbe4ff;color:#1e293b}.analytics-v2__tab.active{background:#ffffff;color:#334155;box-shadow:0 1px 2px #0f172a1a}.analytics-v2__kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.analytics-v2__kpi-card{background:#ffffff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 12px 22px #0f172a0d;padding:14px;display:flex;gap:12px;align-items:center}.analytics-v2__kpi-icon{width:40px;height:40px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;color:#fff}.analytics-v2__kpi-icon.blue{background:linear-gradient(135deg,#465fff,#6172f3)}.analytics-v2__kpi-icon.green{background:linear-gradient(135deg,#10b981,#34d399)}.analytics-v2__kpi-icon.amber{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.analytics-v2__kpi-icon.violet{background:linear-gradient(135deg,#8b5cf6,#a78bfa)}.analytics-v2__kpi-card p{margin:0;font-size:12px;color:#64748b;font-weight:600}.analytics-v2__kpi-card h3{margin:2px 0 0;font-size:24px;color:#0f172a;line-height:1.1}.analytics-v2__kpi-card small{display:block;margin-top:2px;color:#475569;font-size:11px}.analytics-v2__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.analytics-v2__grid--overview{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr)}.analytics-v2__panel{background:#ffffff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 12px 22px #0f172a0d;padding:14px;min-height:300px}.analytics-v2__panel--full{grid-column:1 / -1;min-height:auto}.analytics-v2__panel header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:10px}.analytics-v2__panel header h3{margin:0;color:#0f172a;font-size:15px;font-weight:700}.analytics-v2__panel header span{color:#64748b;font-size:11px;font-weight:600}.analytics-v2__chart-wrap{min-height:290px}.analytics-v2__empty{min-height:280px;display:grid;place-items:center;color:#64748b;font-size:13px;border:1px dashed #cbd5e1;border-radius:10px}.analytics-v2__system-list{display:grid;gap:10px;margin-top:6px}.analytics-v2__system-list div{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:10px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:10px;padding:12px}.analytics-v2__system-list svg{color:#465fff;font-size:16px}.analytics-v2__system-list span{font-size:12px;font-weight:600;color:#475569}.analytics-v2__system-list strong{font-size:13px;color:#0f172a}.analytics-v2__table-wrap{overflow-x:auto}.analytics-v2__table-wrap .admin-table{margin-top:0}.analytics-v2__legend-metrics{display:flex;justify-content:center;gap:14px;margin-top:-2px;font-size:12px;color:#475569;font-weight:600}.analytics-v2__panel--gauge{display:flex;flex-direction:column}.analytics-v2__gauge{min-height:250px}.analytics-v2__bullet-stats{margin:0;padding-left:16px;display:grid;gap:6px;color:#475569;font-size:12px}@media (max-width: 1200px){.analytics-v2__kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-v2__grid,.analytics-v2__grid--overview{grid-template-columns:1fr}}@media (max-width: 768px){.analytics-v2__tabs{display:flex;width:100%}.analytics-v2__tab{flex:1;text-align:center}.analytics-v2__kpi-grid{grid-template-columns:1fr}.analytics-v2__header{flex-direction:column}.analytics-v2__chart-wrap{min-height:240px}}.board-page{max-width:1200px;margin:0 auto;padding:24px;min-height:100vh;color:#1f2937}.board-header{text-align:left;margin-bottom:18px}.board-header h1{color:#111827;margin-bottom:6px;font-size:28px;font-weight:700}.board-header p{color:#64748b;font-size:14px}.back-button{background:none;border:none;color:#667eea;font-size:16px;cursor:pointer;margin-bottom:20px;padding:8px 0}.back-button:hover{text-decoration:underline}.board-categories{display:flex;gap:10px;margin-bottom:14px;justify-content:flex-start;flex-wrap:wrap;padding:8px;border:1px solid #e5e7eb;border-radius:12px;background:#ffffff}.category-button{padding:8px 14px;border:1px solid transparent;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:500;color:#64748b;font-size:14px}.category-button:hover{border-color:#e2e8f0;background:#f8fafc;color:#334155}.category-button.active{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.loading{text-align:center;padding:40px;font-size:16px;color:#666}.board-table-wrap{border:1px solid #e5e7eb;border-radius:12px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;background:#fff;box-shadow:0 1px 2px #0f172a0d}.board-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:700px}.board-table thead th{background:#f9fafb;color:#64748b;font-size:12px;font-weight:700;letter-spacing:.03em;padding:12px 10px;border-bottom:1px solid #e5e7eb}.board-table tbody td{padding:12px 10px;border-bottom:1px solid #f1f5f9;color:#344054;font-size:14px;text-align:center}.board-row{cursor:pointer}.board-row:hover{background:#f8fafc}.board-row.pinned{background:#fffef3}.col-no{width:72px}.col-category{width:110px}.col-author{width:140px}.col-date{width:110px}.col-views{width:80px}.board-title-cell{text-align:left!important}.board-title-text{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;vertical-align:middle}.pin-icon{font-size:16px;margin-right:6px}.post-category{background:#eef2ff;color:#334155;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.board-row.pinned .post-category{background:#fef3c7;color:#92400e}.board-pagination{margin-top:14px;display:flex;justify-content:center;gap:6px}.page-btn{min-width:36px;height:36px;padding:0 10px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;color:#344054;cursor:pointer;font-size:14px}.page-btn:hover:not(:disabled){background:#f5f8ff;border-color:#c7d2fe}.page-btn.active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}.page-btn:disabled{opacity:.5;cursor:not-allowed}.post-detail{background:white;border-radius:12px;padding:30px;box-shadow:0 1px 2px #0f172a0f;border:1px solid #e5e7eb}.post-detail .post-header{border-bottom:2px solid #f1f3f4;padding-bottom:20px;margin-bottom:30px}.post-detail .post-header h2{margin:15px 0;color:#333;font-size:24px;line-height:1.4}.post-detail .post-category{display:inline-block;margin-bottom:10px}.pinned-badge{display:inline-block;background:#ffc107;color:#333;padding:4px 8px;border-radius:8px;font-size:12px;font-weight:700;margin-left:10px}.post-content{line-height:1.8;color:#333;font-size:16px}.post-content p{margin-bottom:15px}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state p{font-size:18px;margin:0}@media (max-width: 768px){.board-page{padding:16px}.board-categories{gap:8px}.category-button{padding:8px 16px;font-size:14px}.board-table{table-layout:auto;min-width:560px}.col-author,.col-views{display:none}.board-table th:nth-child(4),.board-table th:nth-child(6),.board-table td:nth-child(4),.board-table td:nth-child(6){display:none}.post-detail{padding:20px}.post-detail .post-header h2{font-size:20px}}@media (max-width: 560px){.col-no,.col-date{display:none}.board-table th:nth-child(1),.board-table th:nth-child(5),.board-table td:nth-child(1),.board-table td:nth-child(5){display:none}.board-table tbody td{padding:10px 8px;font-size:13px}}.report-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.report-modal{background:white;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.report-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.report-modal-header h3{margin:0;color:#333}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#666}.report-form{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:4px;font-weight:500;color:#333}.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.form-actions button{padding:8px 16px;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px}.form-actions button[type=submit]{background:#dc3545;color:#fff;border-color:#dc3545}.form-actions button[type=submit]:hover:not(:disabled){background:#c82333}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.exam-page{min-height:100vh;background-color:#f8f9fa;display:flex;flex-direction:column}.exam-header{background:white;padding:20px 40px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.exam-body{flex:1;display:flex;flex-direction:column}.exam-info{display:flex;font-weight:500;align-items:center}.exam-info span{color:#333}.time-info{display:flex;flex-direction:column;gap:5px;min-width:150px}.time-progress-bar{width:100%;height:4px;background:#e9ecef;border-radius:2px;overflow:hidden}.time-progress-fill{height:100%;background:linear-gradient(90deg,#28a745 0%,#ffc107 50%,#dc3545 100%);border-radius:2px;transition:width 1s ease}.header-buttons{display:flex;gap:10px;flex-shrink:0}.navigation-button{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;position:relative;transition:all .2s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.navigation-button:hover{background:#5a6fd8}.navigation-button.active{background:#4285f4;box-shadow:0 2px 8px #4285f44d}.navigation-button.active:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid white}.complete-button{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.complete-button:hover{background:#218838}.abandon-button{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.abandon-button:hover{background:#c82333}.report-button{background:#fd7e14;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.report-button:hover{background:#e8650e}.pause-button{background:#ffc107;color:#212529;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.pause-button:hover{background:#e0a800}.resume-button{background:#17a2b8;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500}.resume-button:hover{background:#138496}.pause-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;justify-content:center;align-items:center;z-index:1000}.pause-content{background:white;padding:40px;border-radius:12px;text-align:center;max-width:400px}.pause-content h2{margin:0 0 15px;color:#333}.pause-content p{margin:0 0 25px;color:#666;line-height:1.5}.resume-large-button{background:#17a2b8;color:#fff;border:none;padding:15px 30px;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer}.resume-large-button:hover{background:#138496}.option.disabled{opacity:.6;cursor:not-allowed}.exam-content{flex:1;padding:40px;max-width:1000px;margin:0 auto;width:100%;transition:margin-top .3s ease}.exam-content.with-navigation{margin-top:240px}.question-section{background:white;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.question-header{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f8f9fa;display:flex;justify-content:space-between;align-items:center}.question-header h2{margin:0;color:#667eea;font-size:20px;font-weight:600}.report-button-inline{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s;white-space:nowrap}.report-button-inline:hover{background:#c82333}.question-text{font-size:18px;line-height:1.6;color:#333;margin-bottom:20px;white-space:pre-wrap}.answer-instruction{font-size:14px;color:#666;margin-bottom:20px;font-weight:500}.options{display:flex;flex-direction:column;gap:12px}.option{display:flex;align-items:flex-start;gap:15px;padding:15px;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .2s;background:white}.option:hover{border-color:#667eea;background:#f8f9ff}.option.selected{border-color:#667eea;background:#e8f0fe}.option-number{background:#667eea;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.option.selected .option-number{background:#4285f4}.option-text{flex:1;line-height:1.5;color:#333}.exam-controls{background:white;border-radius:12px;padding:20px 30px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center}.selected-info{color:#666;font-size:14px}.submit-button{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.submit-button:hover:not(:disabled){background:#218838}.submit-button:disabled{background:#ccc;cursor:not-allowed}.question-navigation{position:fixed;top:120px;left:280px;right:0;background:white;border-bottom:1px solid #e9ecef;padding:20px 40px;box-shadow:0 2px 8px #0000001a;z-index:90;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.navigation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.navigation-header h3{margin:0;color:#333;font-size:18px}.close-navigation{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-navigation:hover{background:#f8f9fa;color:#333}.navigation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:8px;margin-bottom:20px;max-height:300px;overflow-y:auto}.navigation-item{width:50px;height:50px;border:2px solid #e9ecef;background:white;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.navigation-item:hover{border-color:#667eea;background:#f8f9ff}.navigation-item.current{border-color:#667eea;background:#667eea;color:#fff}.navigation-item.answered{border-color:#28a745;background:#d4edda;color:#155724}.navigation-item.current.answered{border-color:#667eea;background:#667eea;color:#fff}.navigation-legend{display:flex;gap:20px;justify-content:center;align-items:center}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.legend-color{width:16px;height:16px;border-radius:4px;border:2px solid}.legend-color.current{background:#667eea;border-color:#667eea}.legend-color.answered{background:#d4edda;border-color:#28a745}.legend-color.unanswered{background:white;border-color:#e9ecef}.legend-color.flagged{background:#fff3cd;border-color:#ffc107}.flag-button{background:#6c757d;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:16px;transition:all .2s ease;white-space:nowrap}.flag-button:hover{background:#5a6268}.flag-button.flagged{background:#ffc107;color:#212529}.flag-button.flagged:hover{background:#e0a800}.navigation-filters{display:flex;align-items:center;gap:15px}.filter-button{background:#6c757d;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.filter-button:hover{background:#5a6268}.filter-button.active{background:#ffc107;color:#212529}.flagged-count{font-size:12px;color:#666;font-weight:500}.navigation-item.flagged{border-color:#ffc107;background:#fff3cd;color:#856404;position:relative}.navigation-item.flagged.current{border-color:#667eea;background:#667eea;color:#fff}.navigation-item.flagged.answered{border-color:#28a745;background:#d4edda;color:#155724}.navigation-item.review-mode.answered{background:#d4edda;border-color:#28a745;color:#155724;position:relative}.navigation-item.review-mode.answered:after{content:"✓";position:absolute;top:2px;right:2px;font-size:10px;color:#28a745;font-weight:700}.flag-indicator{position:absolute;top:-2px;right:-2px;font-size:10px;background:#ffc107;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.exam-header{padding:15px 20px;flex-direction:column;gap:15px}.question-navigation{top:160px;left:0}.exam-content.with-navigation{margin-top:260px}.header-buttons{width:100%;justify-content:center;flex-wrap:wrap}.exam-info{font-size:14px;justify-content:center}.navigation-button,.complete-button,.abandon-button,.pause-button,.flag-button{max-width:none}.flag-button{padding:6px 10px;font-size:14px}.navigation-filters{flex-direction:column;gap:8px;align-items:flex-start}.filter-button{font-size:11px;padding:4px 8px}.flagged-count{font-size:11px}.time-info{min-width:auto}.exam-content,.question-section{padding:20px}.question-text{font-size:16px}.question-header h2{font-size:18px}.exam-controls{padding:15px 20px;flex-direction:column;gap:15px;align-items:stretch}.submit-button{width:100%}.question-navigation{padding:15px 20px}.navigation-grid{grid-template-columns:repeat(auto-fill,minmax(45px,1fr));gap:6px}.navigation-item{width:45px;height:45px;font-size:14px}.navigation-legend{flex-direction:column;gap:10px;align-items:flex-start}}@media (max-width: 480px){.exam-header{padding:10px 15px}.question-navigation{top:180px;left:0}.exam-content.with-navigation{margin-top:280px}.exam-content,.question-section{padding:15px}.option{padding:12px}.option-text{font-size:14px}.question-navigation{padding:10px 15px}.navigation-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:4px}.navigation-item{width:40px;height:40px;font-size:12px}.navigation-header h3{font-size:16px}.legend-item{font-size:12px}.legend-color{width:14px;height:14px}}.practice-result{background:white;border-radius:var(--border-radius);padding:var(--spacing-lg);border:2px solid var(--gray-300)}.result-indicator{font-size:var(--font-size-lg);font-weight:600;padding:var(--spacing-md);border-radius:var(--border-radius);text-align:center;margin-bottom:var(--spacing-md)}.result-indicator.correct{background:rgba(40,167,69,.1);color:var(--success-color);border:2px solid var(--success-color)}.result-indicator.incorrect{background:rgba(220,53,69,.1);color:var(--danger-color);border:2px solid var(--danger-color)}.correct-answers{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--border-radius);font-size:var(--font-size-base)}.explanation,.reasoning{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--info-color);background:rgba(23,162,184,.1);border-radius:var(--border-radius);border-left:4px solid var(--info-color)}.explanation strong,.reasoning strong{color:var(--info-color);display:block;margin-bottom:var(--spacing-xs)}.explanation p,.reasoning p{margin:0;line-height:1.6;color:var(--gray-700)}.review-controls{display:flex;flex-direction:column;gap:15px;align-items:center;width:100%}.navigation-buttons{display:flex;gap:15px}.prev-button,.next-button{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.prev-button:hover,.next-button:hover{background:#5a6268}.finish-review-button{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.finish-review-button:hover{background:#218838}.navigation-header .finish-review-button{background:#dc3545;padding:8px 16px;font-size:14px}.navigation-header .finish-review-button:hover{background:#c82333}.exam-navigation-controls{display:flex;flex-direction:column;gap:15px;align-items:center;width:100%}.action-buttons{display:flex;gap:15px;align-items:center}.submit-answer-button{background:#17a2b8;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.submit-answer-button:hover{background:#138496}.review-button{background:#ffc107;color:#212529;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.review-button:hover{background:#e0a800}.exam-controls-layout{display:flex;flex-direction:column;gap:15px;align-items:center;width:100%}.main-navigation{display:flex;align-items:center;gap:20px;justify-content:center}.submit-answer-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.submit-answer-button:disabled:hover{background:#ccc}.submit-answer-button.auto-saved{background:#28a745;position:relative}.exam-shell-header{position:sticky;top:0;z-index:80;display:grid;grid-template-columns:180px 1fr auto;gap:16px;align-items:center;background:#ffffff;border-bottom:1px solid #e5e7eb;padding:12px 20px}.exam-shell-header__left{display:flex;flex-direction:column;gap:2px}.exam-shell-header__label{font-size:11px;letter-spacing:.08em;color:#64748b;font-weight:700}.exam-shell-header__left strong{font-size:18px;color:#0f172a}.exam-shell-header__center{display:flex;flex-direction:column;gap:6px;color:#334155;font-size:14px}.exam-shell-header__right{display:flex;gap:8px;align-items:center}.exam-main{width:min(920px,calc(100% - 32px));margin:16px auto 100px}.question-navigation-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.45);z-index:90}.question-navigation-drawer{position:fixed;top:0;right:-360px;width:340px;height:100vh;background:#ffffff;border-left:1px solid #e5e7eb;z-index:95;transition:right .22s ease;padding:16px;overflow-y:auto}.question-navigation-drawer.open{right:0}.exam-footer-actions{position:fixed;left:0;right:0;bottom:0;z-index:85;background:#ffffff;border-top:1px solid #e5e7eb;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px}.exam-footer-actions__left{display:flex;align-items:center;gap:8px;color:#64748b;font-size:13px}.exam-footer-actions__right{display:flex;gap:8px;align-items:center}.autosaved-chip{background:#dcfce7;color:#166534;font-size:12px;font-weight:700;padding:2px 8px;border-radius:999px}@media (max-width: 960px){.exam-shell-header{grid-template-columns:1fr;gap:10px}.exam-shell-header__right{flex-wrap:wrap}.exam-main{width:calc(100% - 20px);margin:10px auto 120px}.question-navigation-drawer{width:min(360px,100vw)}.exam-footer-actions{flex-direction:column;align-items:stretch}.exam-footer-actions__right{justify-content:flex-end;flex-wrap:wrap}}.exam-page{background:radial-gradient(circle at 12% 0%,rgba(59,130,246,.12),transparent 40%),radial-gradient(circle at 88% 10%,rgba(14,165,233,.12),transparent 35%),#f8fafc}.exam-shell-header{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:rgba(255,255,255,.9)}.exam-shell-header__right .navigation-button,.exam-shell-header__right .flag-button,.exam-shell-header__right .abandon-button{border-radius:10px;font-size:13px;padding:9px 12px;font-weight:700}.question-section{border:1px solid #dbe4ff;box-shadow:0 10px 30px #0f172a12;border-radius:16px;background:#ffffff}.question-header{border-bottom:1px solid #e5e7eb}.question-header h2{color:#1d4ed8;font-size:22px}.question-text{font-size:20px;color:#0f172a;font-weight:600;line-height:1.55}.answer-instruction{color:#475569;font-size:13px;margin-bottom:14px}.options{gap:10px}.option{border:1px solid #dbe4ff;border-radius:12px;background:#f8fbff;padding:16px}.option:hover{border-color:#93c5fd;background:#eff6ff;transform:translateY(-1px)}.option.selected{border-color:#2563eb;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(14,165,233,.08));box-shadow:inset 0 0 0 1px #60a5fa}.option.locked{cursor:not-allowed;opacity:.72}.option.locked:hover{transform:none}.option-number{width:28px;height:28px;background:#1d4ed8;border-radius:9px;font-size:13px}.option.selected .option-number{background:#0ea5e9}.option-text{color:#0f172a;font-size:15px}.exam-footer-actions{box-shadow:0 -8px 22px #0f172a14}.exam-footer-actions__right .prev-button,.exam-footer-actions__right .next-button,.exam-footer-actions__right .submit-answer-button,.exam-footer-actions__right .review-button,.exam-footer-actions__right .complete-button{border-radius:10px;padding:10px 14px;font-weight:700}.exam-action-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.62);display:grid;place-items:center;z-index:1200;padding:16px}.exam-action-modal{width:min(480px,100%);background:#ffffff;border:1px solid #dbe4ff;border-radius:14px;padding:20px;box-shadow:0 24px 50px #0f172a33}.exam-action-modal h3{margin:0 0 8px;color:#0f172a;font-size:21px}.exam-action-modal p{margin:0;color:#475569;line-height:1.55;white-space:pre-line}.exam-action-modal-buttons{margin-top:18px;display:flex;justify-content:flex-end;gap:8px}.exam-action-modal-buttons.single{justify-content:center}.modal-btn{border:none;border-radius:10px;padding:9px 14px;font-weight:700;cursor:pointer}.modal-btn.primary{background:#2563eb;color:#fff}.modal-btn.secondary{background:#e2e8f0;color:#334155}.modal-btn.danger{background:#dc2626;color:#fff}.submit-answer-button.auto-saved:hover{background:#218838}.submit-answer-button.auto-saved:before{content:"✓ ";margin-right:5px}@media (max-width: 640px){.exam-shell-header__right{width:100%}.exam-shell-header__right .navigation-button,.exam-shell-header__right .flag-button,.exam-shell-header__right .abandon-button{flex:1 1 auto}.question-navigation-drawer{width:100vw;right:-100vw}.exam-main{margin-bottom:170px}.exam-footer-actions{padding:10px 12px calc(10px + env(safe-area-inset-bottom))}.exam-footer-actions__right{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.exam-footer-actions__right .prev-button,.exam-footer-actions__right .next-button,.exam-footer-actions__right .submit-answer-button,.exam-footer-actions__right .review-button,.exam-footer-actions__right .complete-button{width:100%}}@media (max-width: 420px){.exam-main{margin-bottom:220px}.exam-footer-actions__right{grid-template-columns:1fr}}.exam-result-analysis{background:var(--white);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:var(--box-shadow-lg);border:1px solid var(--gray-200);margin-bottom:var(--spacing-xl)}.exam-result-analysis h3{margin:0 0 var(--spacing-lg) 0;color:var(--gray-900);font-size:1.5rem;font-weight:600}.performance-summary{margin-bottom:var(--spacing-xl)}.performance-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);border:2px solid;position:relative;overflow:hidden}.performance-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;opacity:.05;background:currentColor}.performance-card.excellent{border-color:#28a745;color:#28a745;background:rgba(40,167,69,.05)}.performance-card.good{border-color:#17a2b8;color:#17a2b8;background:rgba(23,162,184,.05)}.performance-card.average{border-color:#ffc107;color:#856404;background:rgba(255,193,7,.05)}.performance-card.poor{border-color:#dc3545;color:#dc3545;background:rgba(220,53,69,.05)}.performance-icon{font-size:3rem;flex-shrink:0;position:relative;z-index:1}.performance-text{flex:1;position:relative;z-index:1}.performance-text h4{margin:0 0 var(--spacing-sm) 0;font-size:1.25rem;font-weight:600}.performance-text p{margin:0;font-size:var(--font-size-base);opacity:.8;line-height:1.5}.detailed-stats{margin-bottom:var(--spacing-xl)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-md)}.stat-item{text-align:center;padding:var(--spacing-lg);border-radius:var(--border-radius);border:2px solid;background:var(--white)}.stat-item.correct{border-color:#28a745;color:#28a745}.stat-item.incorrect{border-color:#dc3545;color:#dc3545}.stat-item.unanswered{border-color:#6c757d;color:#6c757d}.stat-item.answered{border-color:#17a2b8;color:#17a2b8}.stat-number{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--font-size-sm);font-weight:500;opacity:.8}.type-analysis{margin-bottom:var(--spacing-xl)}.type-analysis h4{margin:0 0 var(--spacing-lg) 0;color:var(--gray-900);font-size:1.25rem;font-weight:600}.type-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.type-item{padding:var(--spacing-lg);background:var(--gray-100);border-radius:var(--border-radius);border:1px solid var(--gray-200)}.type-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.type-name{font-weight:600;color:var(--gray-900);font-size:var(--font-size-base)}.type-score{font-weight:500;color:var(--gray-600);font-size:var(--font-size-sm)}.type-progress{height:8px;background:var(--gray-300);border-radius:4px;overflow:hidden}.type-progress-bar{height:100%;border-radius:4px;transition:width .3s ease}.keyword-analysis{margin-bottom:var(--spacing-xl)}.keyword-analysis h4{margin:0 0 var(--spacing-lg) 0;color:var(--gray-900);font-size:1.25rem;font-weight:600}.keyword-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.keyword-item{padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--border-radius);border:1px solid var(--gray-200);border-left:4px solid #dc3545}.keyword-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.keyword-name{font-weight:600;color:var(--gray-900);font-size:var(--font-size-base)}.keyword-count{font-weight:500;color:#dc3545;font-size:var(--font-size-sm)}.keyword-progress{height:6px;background:var(--gray-300);border-radius:3px;overflow:hidden}.keyword-progress-bar{height:100%;border-radius:3px;transition:width .3s ease}.keyword-summary{padding:var(--spacing-md);background:rgba(220,53,69,.1);border-radius:var(--border-radius);border-left:4px solid #dc3545}.keyword-summary p{margin:0;color:var(--gray-700);font-size:var(--font-size-sm);line-height:1.5}.study-recommendations h4{margin:0 0 var(--spacing-lg) 0;color:var(--gray-900);font-size:1.25rem;font-weight:600}.recommendations-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.recommendation-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--gray-100);border-radius:var(--border-radius);border-left:4px solid var(--primary-color)}.recommendation-icon{font-size:1.25rem;flex-shrink:0;margin-top:2px}.recommendation-item span:last-child{flex:1;line-height:1.5;color:var(--gray-700);font-size:var(--font-size-base)}@media (max-width: 768px){.performance-card{flex-direction:column;text-align:center;gap:var(--spacing-md)}.performance-icon{font-size:2.5rem}.stat-grid{grid-template-columns:repeat(2,1fr)}.type-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}@media (max-width: 480px){.exam-result-analysis{padding:var(--spacing-lg)}.stat-grid{grid-template-columns:1fr}.stat-number{font-size:1.5rem}.recommendation-item{padding:var(--spacing-md)}}.results-v3{display:grid;gap:18px}.results-v3--loading{min-height:280px;display:grid;place-items:center;text-align:center;color:var(--gray-600)}.results-v3__spinner{width:38px;height:38px;border:3px solid #dbe4ff;border-top-color:var(--brand-600);border-radius:999px;animation:resultsV3Spin .8s linear infinite;margin:0 auto 12px}@keyframes resultsV3Spin{to{transform:rotate(360deg)}}.results-v3__error-box{text-align:center;display:grid;gap:8px}.results-v3__hero{border-radius:18px;padding:24px;border:1px solid #cdd8ff;background:radial-gradient(circle at 85% 10%,rgba(54,87,255,.22),transparent 36%),radial-gradient(circle at 0% 100%,rgba(56,189,248,.15),transparent 42%),linear-gradient(120deg,#ffffff 0%,#f3f7ff 100%);box-shadow:0 16px 32px #0f172a14}.results-v3__hero-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.results-v3__status{font-size:12px;font-weight:800;letter-spacing:.08em;border-radius:999px;padding:7px 12px}.results-v3__status.passed{color:#166534;background:#dcfce7}.results-v3__status.failed{color:#991b1b;background:#fee2e2}.results-v3__hero h1{font-size:clamp(24px,3vw,34px);line-height:1.16;color:#0f172a;margin-bottom:8px}.results-v3__hero p{color:#475467;max-width:740px}.results-v3__layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:14px;align-items:start}.results-v3__sidebar{display:grid;gap:12px}.results-v3__score-card{border-color:#cfd8ff;background:linear-gradient(160deg,rgba(255,255,255,1) 0%,rgba(243,247,255,1) 100%)}.results-v3__score-label{color:#475467;font-size:13px;font-weight:700;margin-bottom:10px}.results-v3__gauge-wrap{margin-bottom:10px}.results-v3__gauge-chart{width:220px;margin:0 auto;position:relative}.results-v3__gauge-chart .apexcharts-canvas{margin:0 auto}.results-v3__pass-line{display:flex;justify-content:center;margin-top:6px}.results-v3__pass-line span{border:1px solid #cfd8ff;background:#eef2ff;color:#3730a3;border-radius:999px;font-size:12px;font-weight:700;padding:4px 10px}.results-v3__score-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.results-v3__score-meta span{border:1px solid #dbe4ff;background:#fff;color:#334155;font-size:12px;border-radius:999px;padding:4px 10px}.results-v3__mini-grid .card__body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.results-v3__mini-item{border:1px solid #eaecf0;border-radius:10px;padding:10px;background:#f8fafc}.results-v3__mini-item span{font-size:12px;color:#667085}.results-v3__mini-item strong{display:block;margin-top:6px;color:#0f172a;font-size:16px;line-height:1.2}.results-v3__summary p{color:#344054;line-height:1.6;white-space:pre-wrap}.results-v3__questions-wrap{border-color:#d0d8ff}.results-v3__questions-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.results-v3__questions-head h2{color:#0f172a;font-size:20px}.results-v3__head-actions{display:flex;align-items:center;gap:6px}.results-v3__head-actions button{border:1px solid #d0d5dd;background:#fff;color:#344054;font-size:12px;font-weight:600;border-radius:9px;padding:7px 10px}.results-v3__head-actions button:hover{background:#f8fafc}.results-v3__filters{display:inline-flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.results-v3__filters button{border:1px solid #d0d5dd;background:#fff;color:#475467;border-radius:999px;font-size:13px;font-weight:700;padding:8px 14px}.results-v3__filters button.active{border-color:#4f46e5;color:#3730a3;background:#eef2ff;box-shadow:0 6px 14px #4f46e526}.results-v3__question-list{display:grid;gap:10px}.results-v3__quick-table-wrap{margin-bottom:14px;border:1px solid #e4e7ec;border-radius:10px;overflow:auto;max-height:320px}.results-v3__quick-table{width:100%;min-width:620px;border-collapse:separate;border-spacing:0}.results-v3__quick-table thead th{text-align:left;font-size:12px;font-weight:700;color:#667085;background:#f8fafc;padding:10px 12px;border-bottom:1px solid #eaecf0}.results-v3__quick-table tbody td{padding:10px 12px;border-bottom:1px solid #eaecf0;font-size:13px;color:#334155}.results-v3__quick-table tbody tr:last-child td{border-bottom:none}.results-v3__quick-table tbody tr:hover td{background:#f8fafc}.results-v3__quick-action{text-align:right}.results-v3__quick-action button{border:1px solid #d0d5dd;background:#fff;color:#344054;border-radius:8px;font-size:12px;font-weight:700;padding:5px 8px}.results-v3__quick-action button:hover{background:#eef2ff;border-color:#c7d2fe}.results-v3__question-item{border:1px solid #e4e7ec;border-radius:12px;overflow:hidden;background:#fff}.results-v3__question-header{width:100%;border:0;background:#f8fafc;padding:14px;display:flex;justify-content:space-between;align-items:center;gap:8px}.results-v3__question-header:hover{background:#f1f5f9}.results-v3__question-head-left{display:flex;align-items:center;gap:8px}.results-v3__q-number{font-size:14px;font-weight:800;color:#0f172a}.results-v3__badge{font-size:11px;font-weight:800;border-radius:999px;padding:4px 9px}.results-v3__badge.correct{background:#dcfce7;color:#15803d}.results-v3__badge.incorrect{background:#fee2e2;color:#b42318}.results-v3__expand{color:#475467;font-size:12px;font-weight:700}.results-v3__question-body{border-top:1px solid #eaecf0;padding:14px;background:#fff}.results-v3__question-text{color:#101828;line-height:1.65;margin-bottom:12px;white-space:pre-wrap}.results-v3__options{display:grid;gap:8px;margin-bottom:12px}.results-v3__option{border:1px solid #d0d5dd;border-radius:10px;padding:10px;display:flex;align-items:flex-start;gap:10px;background:#fff}.results-v3__option.correct-answer{border-color:#22c55e;background:#f0fdf4}.results-v3__option.wrong-answer{border-color:#ef4444;background:#fef2f2}.results-v3__option.correct-user-answer{box-shadow:inset 0 0 0 1px #22c55e59}.results-v3__option-no{width:24px;height:24px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#334155;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.results-v3__option.correct-answer .results-v3__option-no,.results-v3__option.correct-user-answer .results-v3__option-no{background:#16a34a}.results-v3__option.wrong-answer .results-v3__option-no{background:#dc2626}.results-v3__option-text{color:#0f172a;line-height:1.5}.results-v3__explain{background:#f8fafc;border:1px solid #eaecf0;border-radius:10px;padding:12px}.results-v3__explain h4{font-size:14px;color:#0f172a;margin-bottom:6px}.results-v3__explain p{color:#334155;line-height:1.6;white-space:pre-wrap}.results-v3__explain p+h4{margin-top:10px}@media (max-width: 1180px){.results-v3__layout{grid-template-columns:1fr}}@media (max-width: 768px){.results-v3__hero{padding:16px}.results-v3__gauge-chart{width:196px}.results-v3__questions-head{flex-direction:column;align-items:flex-start}}.exam-history-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.exam-history-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-xl);color:var(--gray-600);font-size:var(--font-size-lg);min-height:300px}.exam-history-page__error{margin-bottom:var(--spacing-lg)}.error-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);text-align:center}.error-icon{font-size:3rem}.error-content h3{color:var(--danger-color);margin:0}.error-content p{color:var(--gray-600);margin:0}.exam-history-page__header{text-align:center;margin-bottom:var(--spacing-lg)}.exam-history-page__header h1{font-size:2rem;font-weight:700;color:var(--gray-900);margin-bottom:var(--spacing-md);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.exam-history-page__header p{color:var(--gray-600);font-size:var(--font-size-lg);margin:0}.exam-history-page__empty{margin-bottom:var(--spacing-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);text-align:center;padding:var(--spacing-xl)}.empty-icon{font-size:4rem;opacity:.5}.empty-state h3{font-size:var(--font-size-xl);font-weight:600;color:var(--gray-700);margin:0}.exam-history-page__content{display:flex;flex-direction:column;gap:var(--spacing-xl)}.exam-history-page__stats{margin-bottom:var(--spacing-lg)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.stat-card{display:flex;align-items:center;gap:var(--spacing-lg)}.stat-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:50%;flex-shrink:0}.stat-content{flex:1}.stat-number{font-size:1.75rem;font-weight:700;color:var(--gray-900);line-height:1.2;margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.exam-history-page__list{margin-bottom:var(--spacing-lg)}.history-table{width:100%;border-collapse:separate;border-spacing:0;min-width:860px}.history-table thead th{text-align:left;font-size:12px;font-weight:700;letter-spacing:.03em;color:var(--gray-600);background:#f8fafc;padding:12px 14px;border-bottom:1px solid var(--gray-200)}.history-table tbody td{font-size:14px;color:var(--gray-800);padding:12px 14px;border-bottom:1px solid var(--gray-200);vertical-align:middle}.history-table__icon{width:18px;height:18px;border-radius:999px;object-fit:cover}.history-table__code{display:inline-block;padding:3px 7px;border-radius:8px;border:1px solid var(--gray-300);background:#f8fafc;color:var(--gray-700);font-size:12px}.status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-badge.passed{background:rgba(40,167,69,.1);color:var(--success-color)}.status-badge.failed{background:rgba(220,53,69,.1);color:var(--danger-color)}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width: 768px){.exam-history-page__header h1{font-size:1.75rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-card{gap:var(--spacing-md)}.stat-icon{font-size:1.5rem;width:40px;height:40px}.stat-number{font-size:1.5rem}.history-table{min-width:560px}.history-table .col-code,.history-table .col-date,.history-table .col-correct{display:none}}@media (max-width: 480px){.exam-history-page__header h1{font-size:1.5rem}.exam-history-page__header p{font-size:var(--font-size-base)}.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center;gap:var(--spacing-sm)}.history-table{min-width:460px}.history-table .col-time{display:none}.history-table thead th,.history-table tbody td{padding:10px 8px;font-size:12px}}.exam-select-v2{display:grid;gap:16px}.exam-select-v2--loading{min-height:260px;display:grid;place-items:center;text-align:center;color:var(--gray-600)}.exam-select-v2__spinner{width:36px;height:36px;border:3px solid #dbe4ff;border-top-color:var(--brand-600);border-radius:999px;animation:examSelectSpin .8s linear infinite;margin:0 auto 10px}@keyframes examSelectSpin{to{transform:rotate(360deg)}}.exam-select-v2__error{border:1px solid #fecaca;border-radius:var(--radius-md);background:#fef2f2;color:#b42318;padding:12px 14px;font-size:14px}.exam-select-v2__hero{border:1px solid #d6ddff;border-radius:var(--radius-xl);background:radial-gradient(circle at 0% 0%,rgba(70,95,255,.18),transparent 44%),linear-gradient(135deg,#fff 0%,#f7f9ff 100%);padding:20px;display:grid;grid-template-columns:1fr 260px;gap:14px}.exam-select-v2__eyebrow{display:inline-block;font-size:11px;font-weight:700;color:var(--brand-600);letter-spacing:.08em;margin-bottom:8px}.exam-select-v2__hero-main h1{font-size:clamp(22px,2.3vw,30px);color:var(--gray-900);line-height:1.2;margin-bottom:8px}.exam-select-v2__hero-main p{color:var(--gray-600)}.exam-select-v2__mode-wrap{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.exam-select-v2__mode-btn{border:1px solid var(--gray-300);border-radius:12px;background:#fff;padding:12px;display:flex;align-items:center;gap:10px;text-align:left}.exam-select-v2__mode-btn:hover{border-color:#cdd7ff;background:#f8faff}.exam-select-v2__mode-btn.is-active{border-color:#c7d2fe;background:#eef2ff;box-shadow:inset 0 0 0 1px #c7d2fe}.mode-icon{width:34px;height:34px;border-radius:10px;background:#f2f4f7;display:inline-flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.mode-text{display:grid;gap:2px}.mode-text strong{color:var(--gray-900);font-size:14px}.mode-text small{color:var(--gray-600);font-size:12px}.exam-select-v2__hero-side{border:1px solid #d6ddff;border-radius:var(--radius-lg);background:#fff;padding:14px;display:grid;gap:8px;align-content:start}.hero-side-title{font-size:12px;color:var(--gray-500)}.exam-select-v2__hero-side strong{font-size:22px;color:var(--brand-600);line-height:1.2}.exam-select-v2__hero-side p{color:var(--gray-600);font-size:13px;line-height:1.45}.exam-select-v2__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.exam-select-v2__exam-card{border-color:#dde3ef}.exam-select-v2__exam-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}.exam-select-v2__exam-title-wrap{display:flex;align-items:flex-start;gap:10px}.exam-select-v2__exam-icon-wrap{position:relative;width:38px;height:38px;border-radius:10px;background:#eef2ff;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;outline:none}.exam-select-v2__exam-icon-wrap:hover:after,.exam-select-v2__exam-icon-wrap:focus-visible:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%);min-width:220px;max-width:280px;padding:10px 12px;border-radius:10px;background:#101828;color:#f8fafc;font-size:12px;line-height:1.4;z-index:20;text-align:left;box-shadow:0 10px 20px #10182840}.exam-select-v2__exam-icon-wrap:hover:before,.exam-select-v2__exam-icon-wrap:focus-visible:before{content:"";position:absolute;left:50%;bottom:calc(100% + 5px);transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:#101828;z-index:19}.exam-select-v2__exam-icon-wrap--placeholder{background:#f1f5f9}.exam-select-v2__exam-icon{width:36px;height:36px;border-radius:9px;object-fit:contain;display:inline-flex;align-items:center;justify-content:center}.exam-select-v2__exam-icon--placeholder{font-size:18px;color:#344054}.exam-select-v2__exam-icon-svg{width:20px;height:20px}.exam-select-v2__exam-title-wrap h3{font-size:17px;line-height:1.2;color:var(--gray-900);margin-bottom:0}.exam-select-v2__status{font-size:12px;font-weight:700;border-radius:999px;padding:5px 10px;flex-shrink:0}.exam-select-v2__status.active{background:#dcfce7;color:#15803d}.exam-select-v2__status.inactive{background:#f3f4f6;color:#6b7280}.exam-select-v2__meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.exam-select-v2__meta-item{border:1px solid var(--gray-200);border-radius:10px;padding:9px 10px;background:#f9fafb;display:grid;grid-template-columns:20px 1fr;gap:8px;align-items:center}.exam-select-v2__meta-icon{color:#344054;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.exam-select-v2__meta-icon-svg{width:18px;height:18px}.exam-select-v2__meta-item strong{font-size:13px;color:var(--gray-900);line-height:1}.exam-select-v2__guide h4{color:var(--gray-900);font-size:16px;margin-bottom:8px}.exam-select-v2__guide ul{margin:0;padding-left:18px;color:var(--gray-700)}.exam-select-v2__guide li+li{margin-top:4px}.exam-select-v2__ad{margin-top:4px}.exam-select-v2__confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,23,42,.55);display:grid;place-items:center;padding:16px;z-index:1000}.exam-select-v2__confirm-modal{width:min(480px,100%);border-radius:14px;background:#ffffff;border:1px solid #dbe2ef;box-shadow:0 24px 64px #0f172a33;padding:20px}.exam-select-v2__confirm-modal h3{margin:0 0 10px;font-size:20px;color:var(--gray-900)}.exam-select-v2__confirm-modal ul{margin:0;padding-left:18px;color:var(--gray-700);line-height:1.5}.exam-select-v2__confirm-modal li+li{margin-top:4px}.exam-select-v2__confirm-actions{margin-top:16px;display:flex;justify-content:flex-end;gap:10px}.exam-select-v2__empty{text-align:center;padding:18px}.exam-select-v2__empty h3{color:var(--gray-900);margin-bottom:6px}.exam-select-v2__empty p{color:var(--gray-600)}@media (max-width: 980px){.exam-select-v2__hero{grid-template-columns:1fr}.exam-select-v2__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.exam-select-v2__hero{padding:14px}.exam-select-v2__mode-wrap,.exam-select-v2__grid,.exam-select-v2__meta-grid{grid-template-columns:1fr}}.exam-history-list{width:100%}.exam-history-empty{padding:var(--spacing-xl);text-align:center}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);color:var(--gray-600)}.empty-icon{font-size:3rem;opacity:.5}.empty-state h4{font-size:var(--font-size-lg);font-weight:600;color:var(--gray-700);margin:0}.empty-state p{font-size:var(--font-size-base);color:var(--gray-600);margin:0}.history-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.history-table{width:100%;border-collapse:separate;border-spacing:0;min-width:680px}.history-table.compact{min-width:700px}.history-table thead th{text-align:left;font-size:12px;font-weight:700;letter-spacing:.03em;color:var(--gray-600);background:#f8fafc;padding:10px 12px;border-bottom:1px solid var(--gray-200)}.history-table tbody td{font-size:13px;color:var(--gray-800);padding:10px 12px;border-bottom:1px solid var(--gray-200);vertical-align:middle}.history-table tbody tr:last-child td{border-bottom:none}.history-table tbody tr:hover td{background:#f8fafc}.history-table__exam{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--gray-900)}.history-table__icon{width:16px;height:16px;border-radius:999px;object-fit:cover}.history-table__code{display:inline-block;padding:2px 6px;border-radius:7px;border:1px solid var(--gray-300);background:#f8fafc;color:var(--gray-700);font-size:11px}.history-table__score{font-weight:700}.history-table__score.passed{color:#15803d}.history-table__score.failed{color:#b42318}.status-badge{padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700}.status-badge.passed{background:rgba(22,163,74,.12);color:#15803d}.status-badge.failed{background:rgba(220,38,38,.12);color:#b42318}.history-table__action{text-align:right}@media (max-width: 768px){.history-table{min-width:520px}.history-table .col-code,.history-table .col-date{display:none}}@media (max-width: 480px){.history-table{min-width:420px}.history-table .col-time{display:none}.history-table thead th,.history-table tbody td{padding:8px;font-size:12px}}.paid-plan-selector{margin:20px 0}.paid-plan-selector h3{margin-bottom:15px;color:#333}.current-plan{border:2px solid #007bff;border-radius:8px;padding:15px;background-color:#f0f8ff}.plan-badge{font-weight:700;color:#007bff;font-size:16px;margin-bottom:5px}.plan-description{color:#666;font-size:14px}.achievement-section{margin-bottom:2rem}.achievement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.achievement-header h3{margin:0;color:var(--text-primary)}.achievement-stats{font-size:1.1rem;font-weight:600}.completed-count{color:var(--success-color)}.total-count{color:var(--text-secondary)}.achievement-group{margin-bottom:1.5rem}.group-title{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary);font-weight:600}.achievement-list{display:flex;flex-direction:column;gap:.5rem}.achievement-item{background:white;border-radius:8px;padding:.75rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 1px 3px #0000001a;transition:transform .2s ease}.achievement-item:hover{transform:translateY(-1px)}.achievement-item.completed{border-left:3px solid var(--success-color);background:#f8fff8}.achievement-item.not-started{border-left:3px solid var(--gray-300);opacity:.8}.achievement-icon{font-size:1.5rem;flex-shrink:0}.achievement-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.achievement-title{font-weight:600;color:var(--text-primary);font-size:.9rem}.achievement-desc{color:var(--text-secondary);font-size:.8rem;line-height:1.3}.progress-info{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.progress-text{font-size:.75rem;color:var(--text-secondary);min-width:3rem}.progress-bar{flex:1;height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden}.progress-fill{height:0%;background:#28a745;transition:width .3s ease}.achievement-reward{background:#28a745;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;flex-shrink:0}.loading,.error{text-align:center;padding:2rem;color:var(--text-secondary)}.error{color:var(--error-color)}@media (max-width: 768px){.achievement-item{padding:.5rem}.achievement-icon{font-size:1.25rem}.progress-info{flex-direction:column;align-items:flex-start;gap:.25rem}.progress-text{min-width:auto}}.profile-page{min-height:100vh;background-color:#f8f9fa;padding:20px}.profile-header{display:flex;align-items:center;gap:20px;margin-bottom:30px}.back-button{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500}.back-button:hover{background:#5a6268}.profile-header h1{margin:0;color:#333;font-size:28px}.save-message{background:#d4edda;color:#155724;padding:12px 20px;border-radius:6px;margin-bottom:20px;border:1px solid #c3e6cb}.profile-content{max-width:800px;margin:0 auto}.profile-card{background:white;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a;display:flex;gap:30px;align-items:flex-start}.profile-avatar{flex-shrink:0}.profile-avatar img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #e9ecef}.avatar-placeholder{width:120px;height:120px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;pointer-events:none}.profile-info{flex:1}.view-mode h2{margin:0 0 10px;color:#333;font-size:24px}.email{color:#666;font-size:16px;margin-bottom:20px}.edit-button{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.edit-button:hover{background:#5a67d8}.edit-form{width:100%}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;color:#333;font-weight:500}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.form-actions{display:flex;gap:10px}.save-button{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500}.save-button:hover{background:#218838}.cancel-button{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500}.cancel-button:hover{background:#5a6268}.stats-section{background:white;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.stats-section h3{margin:0 0 20px;color:#333;font-size:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-item{text-align:center;padding:20px;background:#f8f9fa;border-radius:8px}.stat-number{font-size:36px;font-weight:700;color:#667eea;margin-bottom:5px}.stat-label{color:#666;font-size:14px}.recent-exams-section{background:white;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.recent-exams-section h3{margin:0 0 20px;color:#333;font-size:20px}.account-info{background:white;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a}.account-info h3{margin:0 0 20px;color:#333;font-size:20px}.info-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e9ecef}.info-item:last-child{border-bottom:none}.info-label{color:#666;font-weight:500}.info-value{color:#333}.loading,.error{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:18px;color:#666}.error{color:#dc3545;flex-direction:column;gap:20px}@media (max-width: 768px){.profile-page{padding:15px}.profile-header{flex-direction:column;align-items:stretch;gap:15px}.profile-header h1{font-size:24px;text-align:center}.profile-card{flex-direction:column;align-items:center;text-align:center;gap:20px}.stats-grid{grid-template-columns:1fr}.info-item{flex-direction:column;gap:5px}}@media (max-width: 480px){.profile-card,.stats-section,.recent-exams-section,.account-info{padding:20px 15px}.profile-avatar img,.avatar-placeholder{width:80px;height:80px}.avatar-placeholder{font-size:32px}.stat-number{font-size:28px}}.coupon-section{background:white;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.coupon-section h3{margin:0 0 20px;color:#333;font-size:20px}.coupon-form{display:flex;gap:10px;align-items:center}.coupon-form input{flex:1;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:border-color .3s ease}.coupon-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.coupon-form button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.coupon-form button:hover{transform:translateY(-1px);box-shadow:0 3px 6px #0000001f;background:linear-gradient(135deg,#5a67d8,#6b46c1)}@media (max-width: 480px){.coupon-form{flex-direction:column;align-items:stretch}.coupon-form button{margin-top:10px}}.ranking-page{max-width:1200px;margin:0 auto;padding:24px;min-height:100vh}.ranking-header{margin-bottom:20px}.ranking-header h1{margin:0 0 6px;font-size:30px;font-weight:700;color:#111827}.ranking-header p{margin:0;color:#64748b;font-size:14px}.ranking-controls{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:14px;align-items:end;border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:14px}.control-group{display:flex;flex-direction:column;gap:6px}.control-group label{font-size:12px;font-weight:700;color:#475467}.control-group select{min-width:180px;padding:10px 12px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;color:#111827}.control-group select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd4d}.view-mode-toggle{display:flex;border:1px solid #d0d5dd;border-radius:8px;overflow:hidden}.view-mode-toggle button{padding:10px 14px;border:none;background:#fff;color:#475467;cursor:pointer;font-weight:600}.view-mode-toggle button+button{border-left:1px solid #e5e7eb}.view-mode-toggle button.active{background:#eff6ff;color:#1d4ed8}.export-btn{padding:10px 14px;border:1px solid #16a34a;border-radius:8px;background:#16a34a;color:#fff;font-weight:600;cursor:pointer}.export-btn:hover{background:#15803d;border-color:#15803d}.loading-spinner{display:grid;place-items:center;gap:10px;padding:56px 0}.spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:999px;animation:ranking-spin .8s linear infinite}@keyframes ranking-spin{to{transform:rotate(360deg)}}.ranking-table-wrap{border:1px solid #e5e7eb;border-radius:12px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;background:#fff}.podium-wrap{border:1px solid #e5e7eb;border-radius:12px;background:#fff;margin-bottom:12px;padding:14px}.podium-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;align-items:end}.podium-card{border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc;padding:12px;text-align:center}.podium-card-empty{visibility:hidden}.podium-card.rank-1{background:linear-gradient(180deg,#fff7ed 0%,#ffedd5 100%);border-color:#fdba74;min-height:155px}.podium-card.rank-2{background:linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%);border-color:#cbd5e1;min-height:140px}.podium-card.rank-3{background:linear-gradient(180deg,#fef3c7 0%,#fde68a 100%);border-color:#f59e0b;min-height:130px}.podium-card.is-current-user{box-shadow:inset 0 0 0 2px #93c5fd}.podium-rank{font-size:24px;margin-bottom:8px}.podium-user{font-size:14px;font-weight:700;color:#111827;display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}.podium-score{margin-top:8px;font-size:20px;font-weight:800;color:#0f172a}.ranking-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:560px}.ranking-table th{background:#f8fafc;color:#64748b;font-size:12px;font-weight:700;padding:12px 10px;border-bottom:1px solid #e5e7eb;letter-spacing:.03em}.ranking-table td{border-bottom:1px solid #f1f5f9;padding:12px 10px;font-size:14px;color:#334155;text-align:center}.ranking-table tr:last-child td{border-bottom:none}.ranking-table tbody tr:hover{background:#f8fafc}.ranking-table tr.is-current-user{background:#eff6ff}.ranking-table tr.rank-top-1 .rank-cell{color:#b45309}.ranking-table tr.rank-top-2 .rank-cell{color:#475467}.ranking-table tr.rank-top-3 .rank-cell{color:#92400e}.col-rank{width:96px}.col-score{width:120px}.rank-cell{font-weight:700}.user-cell{text-align:left!important}.user-name{display:inline-block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;color:#111827}.you-badge{margin-left:8px;background:#1d4ed8;color:#fff;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}.score-cell{font-weight:700;color:#111827}.no-rankings{text-align:center;padding:56px 0;color:#64748b}.load-more{display:flex;justify-content:center;margin-top:14px}.load-more-btn{padding:10px 16px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;color:#344054;font-weight:600;cursor:pointer}.load-more-btn:hover{background:#f8fafc}.my-rank-section{margin-top:18px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:14px}.my-rank-section h3{margin:0 0 10px;font-size:18px;color:#111827}.my-rank-card{display:flex;align-items:center;gap:10px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;padding:10px 12px}.my-rank-label{color:#1e3a8a;font-size:13px;font-weight:600}.my-rank-card strong{font-size:18px;color:#1d4ed8}.my-rank-score{margin-left:auto;color:#1e3a8a;font-weight:700}.rank-summary{margin:10px 0 0;color:#64748b;font-size:13px}.table-empty{color:#64748b;text-align:center}@media (max-width: 768px){.ranking-page{padding:14px}.ranking-controls{gap:10px}.podium-grid{grid-template-columns:1fr}.podium-card.rank-1,.podium-card.rank-2,.podium-card.rank-3{min-height:auto}.control-group{width:100%}.control-group select{min-width:100%}.ranking-table{min-width:500px}}@media (max-width: 480px){.ranking-table{min-width:420px}.ranking-table th,.ranking-table td{padding:10px 8px;font-size:12px}.col-rank{width:72px}.col-score{width:88px}.you-badge{margin-left:4px;padding:2px 6px}}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 20%,rgba(70,95,255,.22),transparent 42%),radial-gradient(circle at 80% 0%,rgba(11,165,236,.2),transparent 38%),#0f172a}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:14px;color:#f8fafc;font-size:15px;font-weight:600}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.2);border-top:4px solid #ffffff;border-radius:999px;animation:spin .85s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
