:root{--bg:#f4f7ff;--surface:#fff;--surface2:#eef3ff;--surface3:#e2ebff;--border:#dde6ff;--border-bright:#b8ccff;--text:#1a2340;--text-muted:#5e6e9a;--text-dim:#9baed0;--blue:#1e56d0;--blue-mid:#2979ff;--blue-light:#40c4ff;--blue-grad:linear-gradient(135deg, #1565c0 0%, #2196f3 60%, #40c4ff 100%);--blue-glow:#1e56d02e;--blue-dim:#1e56d012;--green:#00a884;--green-dim:#00a8841a;--amber:#e07b00;--amber-dim:#e07b001a;--red:#dc2626;--red-dim:#dc262614;--purple:#7c3aed;--purple-dim:#7c3aed14;--sidebar-w:248px;--radius:14px;--radius-sm:9px;--shadow-sm:0 1px 4px #1e3ca012;--shadow:0 4px 20px #1e3ca01a;--shadow-lg:0 12px 48px #1e3ca024}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,ui-sans-serif,system-ui,sans-serif}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:100;height:100vh;box-shadow:var(--shadow-sm);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);padding:24px 20px 18px}.logo-img{object-fit:contain;width:auto;height:80px}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:14px 10px;display:flex;overflow-y:auto}.nav-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);padding:10px 10px 5px;font-size:.63rem;font-weight:700}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:9px 10px;font-size:.865rem;font-weight:500;transition:all .15s;display:flex}.nav-item svg{flex-shrink:0}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--blue-dim);color:var(--blue);border:1px solid #1e56d01f;font-weight:600}.sidebar-footer{border-top:1px solid var(--border);padding:14px 10px}.logout-btn{border-radius:var(--radius-sm);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:9px;padding:9px 10px;font-size:.865rem;font-weight:500;transition:all .15s;display:flex}.logout-btn:hover{background:var(--red-dim);color:var(--red)}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.topbar{border-bottom:1px solid var(--border);background:var(--surface);z-index:50;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;padding:16px 28px;display:flex;position:sticky;top:0}.topbar-title{letter-spacing:-.02em;font-size:1rem;font-weight:700}.topbar-sub{color:var(--text-muted);margin-top:1px;font-size:.75rem}.topbar-actions{align-items:center;gap:12px;display:flex}.live-badge{color:var(--green);background:var(--green-dim);border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.73rem;font-weight:600;display:flex}.live-dot{background:var(--green);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.page-body{flex:1;padding:24px 28px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:22px}.card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-title{color:var(--text);font-size:.875rem;font-weight:700}.card-hint{color:var(--text-muted);font-size:.73rem}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:14px;margin-bottom:20px;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;transition:box-shadow .2s,transform .2s}.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.kpi-card.accent{background:var(--blue-grad);border-color:#0000;box-shadow:0 6px 24px #1e56d040}.kpi-icon{border-radius:9px;justify-content:center;align-items:center;width:34px;height:34px;margin-bottom:12px;font-size:1rem;display:flex}.kpi-icon.blue{background:var(--blue-dim);color:var(--blue)}.kpi-icon.green{background:var(--green-dim);color:var(--green)}.kpi-icon.amber{background:var(--amber-dim);color:var(--amber)}.kpi-icon.red{background:var(--red-dim);color:var(--red)}.kpi-icon.purple{background:var(--purple-dim);color:var(--purple)}.kpi-icon.white{color:#fff;background:#ffffff38}.kpi-label{color:var(--text-muted);margin-bottom:5px;font-size:.73rem;font-weight:500}.kpi-card.accent .kpi-label{color:#fffc}.kpi-value{letter-spacing:-.03em;color:var(--text);font-size:1.9rem;font-weight:800;line-height:1}.kpi-card.accent .kpi-value{color:#fff}.kpi-change{margin-top:6px;font-size:.72rem;font-weight:500}.kpi-change.up{color:var(--green)}.kpi-change.down{color:var(--red)}.kpi-change-muted{color:var(--text-muted)}.grid-2{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:20px;display:grid}.mb-24{margin-bottom:20px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.845rem}thead th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface2);padding:9px 13px;font-size:.7rem;font-weight:600}tbody tr{cursor:pointer;transition:background .12s}tbody tr:hover{background:var(--surface2)}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text);padding:11px 13px}tbody tr:last-child td{border-bottom:none}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:3px 9px;font-size:.7rem;font-weight:600;display:inline-flex}.badge.blue{color:var(--blue);background:#1e56d01a}.badge.green{background:var(--green-dim);color:var(--green)}.badge.amber{background:var(--amber-dim);color:var(--amber)}.badge.red{background:var(--red-dim);color:var(--red)}.badge.purple{background:var(--purple-dim);color:var(--purple)}.badge.gray{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border)}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:7px;padding:9px 18px;font-size:.845rem;font-weight:600;transition:all .18s;display:inline-flex}.btn-primary{background:var(--blue-grad);color:#fff;box-shadow:0 4px 14px var(--blue-glow)}.btn-primary:hover{box-shadow:0 6px 20px var(--blue-glow);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface2);border-color:var(--border-bright)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid #dc26262e}.btn-danger:hover{background:#dc262626}.btn-full{justify-content:center;width:100%;padding:12px 18px}.spinner-white{border-top-color:#fff;width:16px;height:16px}.input{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;width:100%;padding:10px 13px;font-size:.875rem;transition:border-color .18s,box-shadow .18s}.input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}.input::placeholder{color:var(--text-dim)}.input-group{flex-direction:column;gap:5px;margin-bottom:14px;display:flex}.input-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.73rem;font-weight:700}textarea.input{resize:vertical;min-height:90px;font-family:inherit}.bar-chart{flex-direction:column;gap:10px;display:flex}.bar-row{align-items:center;gap:10px;display:flex}.bar-label{color:var(--text-muted);text-align:right;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:110px;font-size:.75rem;font-weight:500;overflow:hidden}.bar-track{background:var(--surface2);border:1px solid var(--border);border-radius:4px;flex:1;height:7px;overflow:hidden}.bar-fill{background:var(--blue-grad);border-radius:4px;height:100%;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.bar-fill.green{background:linear-gradient(90deg, #00896e, var(--green))}.bar-fill.amber{background:linear-gradient(90deg, #b86200, var(--amber))}.bar-fill.red{background:linear-gradient(90deg, #b91c1c, var(--red))}.bar-fill.purple{background:linear-gradient(90deg, #5b21b6, var(--purple))}.bar-value{color:var(--text);text-align:right;flex-shrink:0;width:38px;font-size:.75rem;font-weight:700}.donut-wrap{align-items:center;gap:22px;display:flex}.donut-legend{flex-direction:column;gap:8px;display:flex}.legend-item{align-items:center;gap:8px;font-size:.78rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.legend-name{color:var(--text-muted)}.legend-value{color:var(--text);margin-left:auto;padding-left:12px;font-weight:700}.login-page{background:linear-gradient(145deg,#ebf2ff 0%,#f4f8ff 40%,#e8f0ff 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-glow{pointer-events:none;background:radial-gradient(circle,#2196f31f,#0000 65%);width:700px;height:700px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#40c4ff26,#0000 65%);width:500px;height:500px;position:absolute;top:-200px;right:-200px}.login-card{background:var(--surface);border:1px solid var(--border);width:440px;box-shadow:var(--shadow-lg);z-index:1;border-radius:20px;padding:40px;animation:.4s cubic-bezier(.34,1.56,.64,1) slideUp;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.login-logo-wrap{justify-content:center;margin-bottom:24px;display:flex}.login-logo-img{width:auto;height:110px}.login-title{letter-spacing:-.03em;text-align:center;margin-bottom:4px;font-size:1.5rem;font-weight:800}.login-sub{color:var(--text-muted);text-align:center;margin-bottom:28px;font-size:.8rem}.login-form{flex-direction:column;gap:14px;display:flex}.error-banner{background:var(--red-dim);border-radius:var(--radius-sm);color:var(--red);border:1px solid #dc262633;padding:11px 13px;font-size:.845rem}.loading-wrap{color:var(--text-muted);justify-content:center;align-items:center;gap:10px;padding:48px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:.875rem}.search-bar{margin-bottom:18px;position:relative}.search-bar svg{color:var(--text-dim);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.search-bar .input{padding-left:36px}.avatar{background:var(--blue-grad);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.72rem;font-weight:700;display:flex}.user-cell{align-items:center;gap:9px;display:flex}.user-name{font-weight:500}.user-phone{color:var(--text-muted);font-size:.73rem}.spinner-sm{width:16px;height:16px}.td-muted{color:var(--text-muted)}.td-nowrap{white-space:nowrap}.td-bold{font-weight:600}.td-red{color:var(--red);text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.td-green{color:var(--green);text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.td-error-text{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.td-empty{text-align:center;color:var(--text-muted);padding:32px!important}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0a14328c;justify-content:center;align-items:center;padding:20px;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:20px;flex-direction:column;width:100%;max-width:520px;max-height:85vh;animation:.22s cubic-bezier(.34,1.56,.64,1) modalSlideUp;display:flex;overflow:hidden}.modal-wide{max-width:720px}@keyframes modalSlideUp{0%{opacity:0;transform:scale(.92)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:24px 24px 0;display:flex}.modal-title{letter-spacing:-.02em;font-size:1.05rem;font-weight:800}.modal-subtitle{color:var(--text-muted);margin-top:2px;font-size:.78rem}.modal-close{border:1px solid var(--border);background:var(--surface2);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--red-dim);color:var(--red);border-color:#dc262633}.modal-body{flex:1;padding:20px 24px 24px;overflow-y:auto}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.filter-bar .search-bar{flex:1;min-width:200px;margin-bottom:0}.select-filter{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235E6E9A' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:9px 32px 9px 12px;font-size:.845rem;font-weight:500;transition:border-color .18s,box-shadow .18s}.select-filter:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}.filter-bar-sm{margin-bottom:12px}.search-bar-inline{margin-bottom:0}.modal-kpi-row{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:20px;display:grid}.modal-kpi{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:14px}.modal-kpi-value{letter-spacing:-.03em;color:var(--text);font-size:1.6rem;font-weight:800}.modal-kpi-label{color:var(--text-muted);margin-top:3px;font-size:.72rem;font-weight:500}.page-header{margin-bottom:22px}.page-header-title{letter-spacing:-.03em;margin-bottom:3px;font-size:1.5rem;font-weight:800}.page-header-sub{color:var(--text-muted);font-size:.845rem}.tabs{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);gap:3px;width:fit-content;margin-bottom:20px;padding:3px;display:flex}.tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:6px 14px;font-size:.8rem;font-weight:600;transition:all .15s}.tab.active{background:var(--surface);color:var(--blue);box-shadow:var(--shadow-sm)}.notif-form{flex-direction:column;gap:14px;max-width:540px;display:flex}.progress-bar{background:var(--surface2);border:1px solid var(--border);border-radius:3px;height:6px;margin-top:5px;overflow:hidden}.progress-fill{background:var(--blue-grad);border-radius:3px;height:100%;transition:width .5s}.progress-fill-amber{background:linear-gradient(90deg, #d97706, var(--amber))}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-muted{color:var(--text-muted)}.user-header-card{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.avatar-xl{flex-shrink:0;width:64px;height:64px;font-size:1.4rem}.user-header-info{flex:1;min-width:0}.user-header-name{letter-spacing:-.02em;margin-bottom:8px;font-size:1.4rem;font-weight:800}.user-header-badges{flex-wrap:wrap;gap:8px;display:flex}.user-header-stats{flex-shrink:0;gap:16px;display:flex}.user-stat{text-align:center}.user-stat-value{letter-spacing:-.03em;font-size:1.8rem;font-weight:800}.user-stat-label{color:var(--text-muted);margin-top:2px;font-size:.75rem}.wallet-balance{color:var(--blue-light);font-size:1.8rem}.back-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;margin-bottom:18px;padding:0;font-size:.8rem;font-weight:500;transition:color .14s;display:inline-flex}.back-btn:hover{color:var(--blue)}.detail-item{border-bottom:1px solid var(--border);padding:12px 0}.detail-key{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:.72rem;font-weight:600}.detail-value{color:var(--text);font-size:.875rem;font-weight:600}.fade-in{animation:.25s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.topbar-left{align-items:center;gap:12px;display:flex}.hamburger-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:36px;height:36px;color:var(--text-muted);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:none}.hamburger-btn:hover{background:var(--surface2);color:var(--text)}.sidebar-overlay{z-index:99;background:#0a143273;animation:.2s fadeIn;display:none;position:fixed;inset:0}.mobile-sidebar{height:100vh;width:var(--sidebar-w);z-index:100;transition:transform .28s cubic-bezier(.4,0,.2,1);display:none;position:fixed;top:0;left:0;transform:translate(-100%)}.mobile-sidebar.open{transform:translate(0)}.avatar-sm{width:28px;height:28px;font-size:.7rem}.avatar-green{background:linear-gradient(135deg, var(--green), #059669)}.plan-dist-list{flex-direction:column;gap:16px;margin-top:8px;display:flex}.plan-dist-item{flex-direction:column;gap:4px;display:flex}.plan-dist-row{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.plan-dist-name{align-items:center;gap:8px;display:flex}.plan-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.plan-label-text{font-size:.875rem;font-weight:600}.plan-dist-meta{color:var(--text-muted);font-size:.875rem}.plan-bar{height:8px}.plan-dist-footer{color:var(--text-muted);justify-content:space-between;margin-top:2px;font-size:.72rem;display:flex}.transfer-credits{color:var(--amber);font-weight:700}.audio-player{align-items:center;min-width:180px;display:flex}.play-btn{background:var(--blue-grad);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:opacity .15s,transform .15s;display:flex}.play-btn:hover{opacity:.85;transform:scale(1.08)}.audio-track{background:var(--surface2);cursor:pointer;border:1px solid var(--border);border-radius:2px;flex:1;min-width:60px;height:4px;margin:0 8px;overflow:hidden}.audio-progress{background:var(--blue-grad);border-radius:2px;height:100%;transition:width .1s linear}.period-error{color:var(--red);font-size:.8rem}.period-kpi-grid{margin-bottom:16px}.error-badges{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.badge-error-grammar{color:#3b82f6;background:#3b82f61a}.badge-error-vocabulary{color:#8b5cf6;background:#8b5cf61a}.badge-error-pronunciation{color:#f59e0b;background:#f59e0b1a}.badge-error-fluency{color:#10b981;background:#10b9811a}.period-form{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:20px;padding:16px;display:flex}.period-form .input-group{min-width:150px;margin-bottom:0}.kpi-card-btn{text-align:left;cursor:pointer;width:100%;display:block}.kpi-card-btn:hover{transform:translateY(-2px)}.kpi-tap-hint{color:var(--text-dim);opacity:0;margin-top:6px;font-size:.7rem;transition:opacity .18s}.kpi-card-btn:hover .kpi-tap-hint{opacity:1}.modal-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:20px;margin-bottom:10px;font-size:.75rem;font-weight:700}.modal-section-title:first-child{margin-top:0}.modal-progress-item{margin-bottom:12px}.modal-progress-label{justify-content:space-between;align-items:center;margin-bottom:4px;font-size:.82rem;font-weight:500;display:flex}.modal-progress-pct{color:var(--text);font-weight:700}.modal-kpi-value-green{color:var(--green)}.modal-kpi-value-blue{color:var(--blue)}.modal-kpi-value-amber{color:var(--amber)}.modal-kpi-value-purple{color:var(--purple)}.modal-kpi-value-muted{color:var(--text-muted)}.svg-no-shrink{flex-shrink:0}.donut-arc{transition:stroke-dasharray .6s}.mt-8{margin-top:8px}.mt-20{margin-top:20px}@media (width<=1024px){.grid-3{grid-template-columns:1fr 1fr}}@media (width<=768px){.hamburger-btn{display:flex}.desktop-sidebar{display:none}.mobile-sidebar{flex-direction:column;display:flex}.sidebar-overlay{display:block}.main-content{margin-left:0}.grid-2,.grid-3{grid-template-columns:1fr}.page-body{padding:16px 14px}.topbar{padding:12px 16px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.kpi-value{font-size:1.5rem}.tabs{flex-wrap:wrap;width:100%}.login-card{width:calc(100vw - 32px);padding:28px 22px}.period-form{flex-direction:column;align-items:stretch}.donut-wrap{flex-direction:column}}
