@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:"Inter Tight", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--font-display:"Space Grotesk", system-ui, sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.flex{display:flex}.grid{display:grid}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-sans);color:#0f172a;-webkit-font-smoothing:antialiased;background:#f8fafc;font-size:.875rem;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:0}ul,ol{list-style:none}.font-display{font-family:var(--font-display)}.app-root{background:#f8fafc;min-height:100vh;display:flex}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:264px;height:100vh;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid #e2e8f0;align-items:center;gap:12px;height:64px;padding:0 20px;display:flex}.sidebar-logo-icon{background:#4f46e5;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sidebar-logo-icon svg{color:#fff;width:20px;height:20px}.sidebar-logo-title{font-family:var(--font-display);letter-spacing:-.02em;color:#0f172a;font-size:17px;font-weight:700}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section-title{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;padding:12px 12px 6px;font-size:11px;font-weight:600}.nav-section-title:first-child{padding-top:4px}.nav-group{flex-direction:column;gap:2px;margin-bottom:8px;display:flex}.nav-link{color:#334155;border-radius:6px;align-items:center;gap:12px;padding:9px 12px;font-size:14px;font-weight:500;transition:background .12s;display:flex;position:relative}.nav-link:hover{background:#f8fafc}.nav-link.active{color:#4338ca;background:#eef2ff}.nav-link.active:before{content:"";background:#4f46e5;border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-12px}.nav-link svg{color:#94a3b8;flex-shrink:0;width:20px;height:20px}.nav-link.active svg{color:#4f46e5}.nav-link span{flex:1}.sidebar-user{border-top:1px solid #e2e8f0;flex-shrink:0;padding:12px}.sidebar-user-row{cursor:pointer;border-radius:6px;align-items:center;gap:12px;padding:8px;display:flex}.sidebar-user-row:hover{background:#f8fafc}.user-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.user-info{flex:1;min-width:0}.user-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.user-role{color:#64748b;font-size:12px}.user-logout{color:#94a3b8;flex-shrink:0;padding:4px}.user-logout:hover{color:#475569}.user-logout svg{width:16px;height:16px}.app-main{flex-direction:column;flex:1;min-width:0;display:flex}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:64px;padding:0 24px;display:flex}@media(min-width:1024px){.app-header{padding:0 40px}}.app-header-left{align-items:center;gap:16px;min-width:0;display:flex}.mobile-menu-btn{color:#475569;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:none}.mobile-menu-btn:hover{background:#f1f5f9}.mobile-menu-btn svg{width:20px;height:20px}.app-page-title{font-family:var(--font-display);letter-spacing:-.01em;color:#0f172a;font-size:20px;font-weight:600}.app-header-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.search-wrap{position:relative}.search-icon{color:#94a3b8;pointer-events:none;width:16px;height:16px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-input{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:280px;height:38px;padding:0 12px 0 40px;font-family:inherit;font-size:14px;transition:border-color .12s,background .12s}.search-input::placeholder{color:#94a3b8}.search-input:focus{background:#fff;border-color:#818cf8}.bell-btn{color:#475569;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:relative}.bell-btn:hover{background:#f1f5f9}.bell-btn svg{width:20px;height:20px}.bell-dot{background:#4f46e5;border-radius:50%;width:6px;height:6px;position:absolute;top:9px;right:9px}.app-content{flex:1;overflow-y:auto}@media(max-width:1023px){.sidebar{z-index:40;transition:transform .2s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-menu-btn{display:flex}.search-wrap{display:none}.mobile-overlay{z-index:30;background:#0f172a80;position:fixed;inset:0}}div.page-wrap{max-width:1536px;margin-left:auto;margin-right:auto;padding:28px 24px}@media(min-width:640px){div.page-wrap{padding:32px}}@media(min-width:1024px){div.page-wrap{padding:36px 40px}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px;display:flex}@media(min-width:1024px){.page-header{margin-bottom:32px}}.page-title{font-family:var(--font-display);letter-spacing:-.02em;color:#0f172a;font-size:28px;font-weight:600;line-height:1.2}@media(min-width:1024px){.page-title{font-size:32px}}.page-subtitle{color:#64748b;margin-top:6px;font-size:14px}.page-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.btn{cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.btn svg{width:16px;height:16px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#4f46e5}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-secondary{color:#334155;background:#fff;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.btn-ghost{color:#475569;background:0 0}.btn-ghost:hover:not(:disabled){background:#f1f5f9}.btn-danger{color:#be123c;background:#fff;border:1px solid #fecdd3}.btn-danger:hover:not(:disabled){background:#fff1f2}.btn-icon{color:#64748b;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .12s,color .12s;display:inline-flex}.btn-icon svg{width:16px;height:16px}.btn-icon:hover{color:#334155;background:#f1f5f9}.btn-icon.danger:hover{color:#be123c;background:#fef2f2}.form-field{margin-bottom:16px}.form-label{color:#334155;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input,.form-textarea,.form-select{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:14px;transition:border-color .12s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:#818cf8}.form-textarea{resize:vertical;min-height:80px}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8}.page-search{max-width:420px;margin-bottom:24px;position:relative}.page-search-icon{color:#94a3b8;pointer-events:none;width:18px;height:18px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.page-search-input{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;height:42px;padding:0 12px 0 42px;font-family:inherit;font-size:14px;transition:border-color .12s,box-shadow .12s}.page-search-input::placeholder{color:#94a3b8}.page-search-input:focus{border-color:#818cf8;box-shadow:0 0 0 3px #4f46e514}.empty-state{text-align:center;background:#fff;border:1px dashed #e2e8f0;border-radius:12px;padding:64px 24px}.empty-state-icon{color:#94a3b8;background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.empty-state-icon svg{width:28px;height:28px}.empty-state-title{font-family:var(--font-display);color:#0f172a;margin-bottom:6px;font-size:18px;font-weight:600}.empty-state-text{color:#64748b;max-width:400px;margin:0 auto 20px;font-size:14px}.loading-state{text-align:center;color:#94a3b8;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:64px 24px;font-size:14px}.modal-overlay{z-index:100;background:#0f172a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:24px 28px 0;display:flex}.modal-title{font-family:var(--font-display);color:#0f172a;font-size:20px;font-weight:600}.modal-close{color:#94a3b8;border-radius:6px;padding:4px}.modal-close:hover{color:#475569;background:#f1f5f9}.modal-close svg{width:20px;height:20px}.modal-body{padding:0 28px}.modal-foot{justify-content:flex-end;gap:10px;padding:24px 28px;display:flex}.cards-grid{grid-template-columns:1fr;gap:14px;display:grid}@media(min-width:640px){.cards-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media(min-width:1024px){.cards-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1440px){.cards-grid{grid-template-columns:repeat(4,1fr)}}.student-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:14px;padding:18px;transition:border-color .12s,box-shadow .12s;display:flex}.student-card:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #4f46e50d}.student-card-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:17px;font-weight:600;display:flex}.student-card-info{flex:1;min-width:0}.student-card-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.student-card-subject{color:#64748b;margin-top:2px;font-size:13px}.student-card-phone{color:#94a3b8;margin-top:2px;font-size:12px}.student-card-actions{flex-shrink:0;gap:4px;display:flex}div.stats-grid{grid-template-columns:1fr;gap:16px;margin-bottom:28px;display:grid}@media(min-width:640px){div.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){div.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:36px}}div.charts-grid{grid-template-columns:1fr;gap:16px;margin-bottom:28px;display:grid}@media(min-width:1024px){div.charts-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:36px}div.charts-grid>.chart-main{grid-column:span 2}}.greeting-row{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:28px;display:flex}@media(min-width:1024px){.greeting-row{margin-bottom:36px}}.greeting-title{font-family:var(--font-display);letter-spacing:-.02em;color:#0f172a;font-size:28px;font-weight:600;line-height:1.2}@media(min-width:1024px){.greeting-title{font-size:36px}}.greeting-title .accent{color:#4f46e5}.greeting-subtitle{color:#64748b;margin-top:8px;font-size:15px}.greeting-date{text-align:right;flex-direction:column;align-items:flex-end;display:none}@media(min-width:1024px){.greeting-date{display:flex}}.greeting-date-label{text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;font-size:11px;font-weight:500}.greeting-date-value{font-family:var(--font-display);color:#334155;margin-top:2px;font-size:18px;font-weight:600}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}@media(min-width:1024px){.stat-card{padding:24px}}.stat-card-head{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.stat-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-icon.indigo{color:#4f46e5;background:#eef2ff}.stat-icon.violet{color:#7c3aed;background:#f5f3ff}.stat-icon.amber{color:#d97706;background:#fffbeb}.stat-icon.emerald{color:#059669;background:#ecfdf5}.stat-icon svg{width:20px;height:20px}.stat-badge{color:#047857;background:#ecfdf5;border-radius:999px;align-items:center;gap:2px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.stat-badge.violet{color:#6d28d9;background:#f5f3ff}.stat-badge svg{width:12px;height:12px}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:500}.stat-value{font-family:var(--font-display);letter-spacing:-.02em;color:#0f172a;font-size:36px;font-weight:600;line-height:1.1}.stat-value .suffix{color:#94a3b8;font-size:20px;font-weight:500}.stat-foot{color:#64748b;margin-top:10px;font-size:12px}.section-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}@media(min-width:1024px){.section-card{padding:28px}}.section-head{margin-bottom:20px}.section-title{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;font-size:18px;font-weight:600}.section-sub{color:#64748b;margin-top:2px;font-size:12px}.lessons-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.lessons-head{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}@media(min-width:1024px){.lessons-head{padding:20px 28px}}.lessons-empty{text-align:center;color:#94a3b8;padding:56px 20px;font-size:14px}.lesson-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:16px;padding:16px 20px;transition:background .15s;display:flex;position:relative}.lesson-row:last-child{border-bottom:0}@media(min-width:1024px){.lesson-row{padding:16px 28px}}.lesson-row:hover{background:#f8fafc}.lesson-row.today{background:#eef2ff66}.lesson-row.today:hover{background:#eef2ffb3}.lesson-row.today:before{content:"";background:#6366f1;border-radius:0 2px 2px 0;width:4px;position:absolute;top:8px;bottom:8px;left:0}.lesson-date{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.lesson-row.today .lesson-date{background:#e0e7ff;border-color:#0000}.lesson-date-day{font-family:var(--font-display);color:#334155;font-size:18px;font-weight:600;line-height:1}.lesson-row.today .lesson-date-day{color:#3730a3}.lesson-date-mon{text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-top:4px;font-size:10px}.lesson-row.today .lesson-date-mon{color:#4f46e5}.lesson-body{flex:1;min-width:0}.lesson-title-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.lesson-student-name{color:#0f172a;font-weight:500}.lesson-row.today .lesson-student-name{font-weight:600}.lesson-time{color:#64748b;margin-top:2px;font-size:14px}.subject-chip{border-radius:4px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.subject-chip.sky{color:#0369a1;background:#e0f2fe}.subject-chip.violet{color:#6d28d9;background:#ede9fe}.subject-chip.amber{color:#b45309;background:#fef3c7}.subject-chip.indigo{color:#4338ca;background:#e0e7ff}.subject-chip.emerald{color:#047857;background:#d1fae5}.subject-chip.rose{color:#be123c;background:#ffe4e6}.subject-chip.fuchsia{color:#a21caf;background:#fae8ff}.subject-chip.slate{color:#475569;background:#f1f5f9}.status-badge{border-radius:6px;flex-shrink:0;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-badge.today{color:#fff;background:#4f46e5;font-weight:600}.status-badge.today .dot{background:#fff;border-radius:50%;width:6px;height:6px}.status-badge.tomorrow{color:#be123c;background:#ffe4e6}.status-badge.other{color:#334155;background:#f1f5f9}@media(max-width:639px){.status-badge.other{display:none}}.section-link{color:#4f46e5;font-size:14px;font-weight:500}.section-link:hover{color:#4338ca}.section-card.risk-card{flex-direction:column;display:flex}.risk-list{flex-direction:column;flex:1;gap:20px;display:flex}.risk-item-head{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;display:flex}.risk-label{color:#334155;align-items:center;gap:8px;display:flex}.risk-dot{border-radius:50%;width:8px;height:8px}.risk-dot.emerald{background:#10b981}.risk-dot.amber{background:#f59e0b}.risk-dot.rose{background:#f43f5e}.risk-count{font-family:var(--font-display);font-size:18px;font-weight:600}.risk-count.emerald{color:#059669}.risk-count.amber{color:#d97706}.risk-count.rose{color:#e11d48}.risk-bar-track{background:#f1f5f9;border-radius:999px;height:8px;overflow:hidden}.risk-bar-fill{border-radius:999px;height:100%;transition:width .5s}.risk-bar-fill.emerald{background:#10b981}.risk-bar-fill.amber{background:#f59e0b}.risk-bar-fill.rose{background:#f43f5e}.risk-footer-note{color:#94a3b8;padding-top:4px;font-size:12px}.risk-link-wrap{text-align:center;border-top:1px solid #f1f5f9;margin-top:20px;padding-top:16px}.risk-empty{color:#94a3b8;text-align:center;flex:1;justify-content:center;align-items:center;padding:0 16px;font-size:14px;display:flex}.chart-empty{color:#94a3b8;justify-content:center;align-items:center;height:260px;font-size:14px;display:flex}.hw-list{flex-direction:column;gap:12px;margin-bottom:32px;display:flex}.hw-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px 20px;transition:border-color .12s,box-shadow .12s}.hw-card:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #4f46e50d}.hw-card-top{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px;display:flex}.hw-info{flex:1;min-width:0}.hw-title{color:#0f172a;margin-bottom:6px;font-size:15px;font-weight:600}.hw-meta{color:#64748b;flex-wrap:wrap;align-items:center;gap:12px;font-size:13px;display:flex}.hw-meta-item{align-items:center;gap:4px;display:inline-flex}.hw-meta-item svg{color:#94a3b8;width:13px;height:13px}.hw-stats{flex-shrink:0;gap:18px;display:flex}.hw-stat{text-align:center;min-width:50px}.hw-stat-value{font-family:var(--font-display);color:#0f172a;font-size:18px;font-weight:600;line-height:1.1}.hw-stat-value.score-high{color:#059669}.hw-stat-value.score-mid{color:#d97706}.hw-stat-value.score-low{color:#e11d48}.hw-stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-top:3px;font-size:10px}.hw-card-bottom{color:#94a3b8;border-top:1px solid #f1f5f9;gap:16px;padding-top:12px;font-size:12px;display:flex}.hw-due{color:#d97706;font-weight:500}.accounts-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-top:32px;padding:24px}@media(min-width:1024px){.accounts-section{padding:28px}}.accounts-section .section-head{margin-bottom:18px}.accounts-list{flex-direction:column;gap:8px;display:flex}.account-row{border:1px solid #f1f5f9;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;transition:border-color .12s,background .12s;display:flex}.account-row:hover{background:#f8fafc;border-color:#e2e8f0}.account-info{align-items:center;gap:12px;min-width:0;display:flex}.account-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.account-name{color:#0f172a;font-size:14px;font-weight:500}.account-subject{color:#64748b;margin-top:1px;font-size:12px}.account-status{color:#059669;flex-shrink:0;align-items:center;gap:6px;font-size:13px;font-weight:500;display:inline-flex}.account-status svg{width:16px;height:16px}.form-error{color:#be123c;background:#fef2f2;border-radius:6px;margin-bottom:12px;padding:8px 12px;font-size:13px}.modal-desc{color:#64748b;margin-bottom:16px;font-size:13px}.status-pill{border-radius:999px;align-items:center;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.status-pill.status-new{color:#1d4ed8;background:#dbeafe}.status-pill.status-completed{color:#047857;background:#d1fae5}.status-pill.status-in_progress{color:#b45309;background:#fef3c7}.hw-score-value.score-high{color:#059669}.hw-score-value.score-mid{color:#d97706}.hw-score-value.score-low{color:#e11d48}.hw-not-started{color:#94a3b8;font-style:italic}.filter-row{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.filter-select{color:#0f172a;cursor:pointer;appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='2' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='m19.5 8.25-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E") right 10px center/16px no-repeat;border:1px solid #e2e8f0;border-radius:8px;outline:none;min-width:200px;height:38px;padding:0 36px 0 14px;font-family:inherit;font-size:14px;transition:border-color .12s}.filter-select:focus{border-color:#818cf8}.data-table{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.data-table-head{color:#64748b;text-transform:uppercase;letter-spacing:.06em;background:#f8fafc;border-bottom:1px solid #e2e8f0;grid-template-columns:2fr 2fr 1fr 2.5fr 1.2fr 100px;padding:14px 24px;font-size:11px;font-weight:600;display:grid}.data-table-row{border-top:1px solid #f1f5f9;grid-template-columns:2fr 2fr 1fr 2.5fr 1.2fr 100px;align-items:center;padding:14px 24px;font-size:14px;transition:background .15s;display:grid}.data-table-row:first-of-type{border-top:0}.data-table-row:hover{background:#f8fafc}.cell-student{color:#0f172a;align-items:center;gap:10px;min-width:0;font-weight:500;display:flex}.cell-student-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.cell-student-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cell-topic{color:#334155}.cell-comment{color:#64748b;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.cell-date{color:#64748b;font-size:13px}.cell-actions{justify-content:flex-end;gap:4px;display:flex}.grade-pill{min-width:40px;height:28px;font-family:var(--font-display);border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-size:14px;font-weight:700;display:inline-flex}.grade-pill.high{color:#047857;background:#d1fae5}.grade-pill.mid{color:#b45309;background:#fef3c7}.grade-pill.low{color:#be123c;background:#ffe4e6}.data-cards{flex-direction:column;gap:10px;display:flex}.data-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px}.data-card-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.data-card-student{align-items:center;gap:10px;min-width:0;display:flex}.data-card-topic{color:#334155;margin-bottom:6px;font-size:14px}.data-card-comment{color:#64748b;margin-bottom:8px;font-size:13px}.data-card-foot{color:#94a3b8;border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:8px;font-size:12px;display:flex}.data-card-actions{gap:4px;display:flex}.show-desktop{display:none}.show-mobile{display:block}@media(min-width:1024px){.show-desktop{display:block}.show-mobile{display:none}}.back-link{color:#64748b;align-items:center;gap:6px;margin-bottom:16px;font-size:14px;transition:color .12s;display:inline-flex}.back-link:hover{color:#4f46e5}.back-link svg{width:16px;height:16px}.section-header{justify-content:space-between;align-items:center;gap:16px;margin:32px 0 16px;display:flex}.section-header h2{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;align-items:center;gap:8px;font-size:18px;font-weight:600;display:flex}.section-header h2 svg{color:#64748b;width:18px;height:18px}.section-header-count{color:#94a3b8;font-size:14px;font-weight:400}.question-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:10px;padding:18px 20px}.q-head{align-items:center;gap:10px;margin-bottom:10px;display:flex}.q-num{color:#fff;background:#4f46e5;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:flex}.q-type-chip{border-radius:4px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.q-type-chip.test{color:#1d4ed8;background:#dbeafe}.q-type-chip.number{color:#047857;background:#d1fae5}.q-type-chip.text{color:#b45309;background:#fef3c7}.q-points{color:#64748b;margin-left:auto;font-size:13px;font-weight:500}.q-text{color:#0f172a;margin-bottom:10px;font-size:15px;line-height:1.5}.q-options{flex-direction:column;gap:6px;display:flex}.q-opt{color:#334155;background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:14px;display:flex}.q-opt.correct{color:#047857;background:#d1fae5;border-color:#a7f3d0;font-weight:500}.q-opt-mark{color:#fff;background:#10b981;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.q-opt-mark svg{width:12px;height:12px}.q-answer-block{color:#334155;background:#f0fdf4;border-left:3px solid #10b981;border-radius:6px;padding:10px 12px;font-size:14px}.q-answer-block strong{color:#047857;font-weight:600}.attempt-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:10px;padding:18px 20px}.attempt-head{border-bottom:1px solid #f1f5f9;align-items:center;gap:16px;margin-bottom:14px;padding-bottom:14px;display:flex}.attempt-score{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1}.attempt-score.sc-high{color:#059669}.attempt-score.sc-mid{color:#d97706}.attempt-score.sc-low{color:#e11d48}.attempt-info{color:#334155;font-size:13px}.attempt-info-points{font-weight:500}.attempt-info-date{color:#94a3b8;margin-top:2px;font-size:12px}.attempt-answers{flex-direction:column;gap:6px;display:flex}.att-answer{border-radius:6px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:8px 12px;font-size:13px;display:grid}.att-answer.correct{background:#f0fdf4}.att-answer.wrong{background:#fef2f2}.att-answer-label{color:#64748b}.att-answer-text{color:#0f172a;word-break:break-word}.att-answer-mark{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.att-answer-mark.ok{color:#fff;background:#10b981}.att-answer-mark.fail{color:#fff;background:#f43f5e}.att-answer-mark svg{width:14px;height:14px}.form-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:24px}@media(min-width:1024px){.form-card{padding:28px}}.form-row{grid-template-columns:1fr;gap:16px;display:grid}@media(min-width:768px){.form-row{grid-template-columns:1fr 1fr}}.add-question-row{flex-wrap:wrap;gap:8px;display:flex}.btn-add-question{color:#4338ca;cursor:pointer;background:#fff;border:1px dashed #c7d2fe;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.btn-add-question:hover{background:#eef2ff;border-color:#818cf8}.btn-add-question svg{width:14px;height:14px}.q-edit-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:20px}.q-edit-head{border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;display:flex}.q-edit-points{color:#64748b;align-items:center;gap:8px;margin-left:auto;font-size:13px;display:flex}.q-edit-points input{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;outline:none;width:60px;height:32px;padding:0 8px;font-family:inherit;font-size:13px}.q-edit-points input:focus{border-color:#818cf8}.options-block{margin-top:8px}.options-list{flex-direction:column;gap:8px;display:flex}.option-row{align-items:center;gap:10px;display:flex}.option-radio{cursor:pointer;flex-shrink:0;width:20px;height:20px;position:relative}.option-radio input{cursor:pointer;opacity:0;width:100%;height:100%;margin:0;position:absolute}.option-radio-circle{background:#fff;border:2px solid #cbd5e1;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;transition:border-color .12s,background .12s;display:flex}.option-radio input:checked+.option-radio-circle{border-color:#4f46e5}.option-radio input:checked+.option-radio-circle:after{content:"";background:#4f46e5;border-radius:50%;width:10px;height:10px}.option-input{background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;flex:1;height:38px;padding:0 12px;font-family:inherit;font-size:14px;transition:border-color .12s}.option-input:focus{border-color:#818cf8}.btn-add-option{color:#64748b;cursor:pointer;background:0 0;border:1px dashed #cbd5e1;border-radius:8px;align-items:center;gap:6px;margin-top:6px;padding:8px 12px;font-size:13px;transition:border-color .12s,color .12s;display:inline-flex}.btn-add-option:hover{color:#4f46e5;border-color:#818cf8}.btn-add-option svg{width:14px;height:14px}.empty-questions{text-align:center;color:#94a3b8;background:#fff;border:2px dashed #e2e8f0;border-radius:12px;margin-bottom:20px;padding:48px 20px;font-size:14px}.form-footer{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.calendar-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;overflow:hidden}@media(min-width:1024px){.calendar-card{padding:24px}}.fc .fc-toolbar.fc-header-toolbar{flex-wrap:wrap;gap:12px;margin-bottom:20px}.fc .fc-toolbar-title{color:#0f172a;letter-spacing:-.01em;text-transform:capitalize;font-family:var(--font-display)!important;font-size:22px!important;font-weight:600!important}.fc .fc-button{color:#334155!important;box-shadow:none!important;text-transform:capitalize!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;padding:7px 14px!important;font-size:13px!important;font-weight:500!important;transition:background .12s,border-color .12s!important}.fc .fc-button:hover{background:#f8fafc!important;border-color:#cbd5e1!important}.fc .fc-button-primary:not(:disabled).fc-button-active,.fc .fc-button-primary:not(:disabled):active{color:#fff!important;background:#4f46e5!important;border-color:#4f46e5!important}.fc .fc-button:focus{box-shadow:0 0 0 3px #4f46e526!important}.fc .fc-button-group{gap:4px}.fc .fc-button-group>.fc-button{border-radius:8px!important;margin-left:0!important}.fc .fc-today-button{text-transform:lowercase!important}.fc .fc-prev-button,.fc .fc-next-button{padding:7px 10px!important}.fc-theme-standard td,.fc-theme-standard th,.fc-theme-standard .fc-scrollgrid{border-color:#e2e8f0!important}.fc-theme-standard .fc-scrollgrid{border-radius:8px}.fc .fc-col-header-cell-cushion{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600;padding:10px 6px!important;text-decoration:none!important}.fc .fc-day-today{background:#eef2ff!important}.fc .fc-day-today .fc-col-header-cell-cushion{color:#4f46e5!important}.fc .fc-timegrid-slot{border-color:#f1f5f9!important;height:38px!important}.fc .fc-timegrid-slot-label{color:#94a3b8;font-size:12px;border-color:#e2e8f0!important}.fc .fc-timegrid-axis-cushion{padding:4px 8px!important}.fc-event{box-shadow:0 1px 2px #00000014;cursor:pointer!important;border:0!important;border-radius:6px!important;padding:2px 6px!important;font-family:inherit!important;font-size:12px!important}.fc-event:hover{opacity:.92}.fc-event-title{font-weight:500!important}.fc-event-time{opacity:.85;font-weight:400!important}.fc .fc-timegrid-now-indicator-line{border-width:2px!important;border-color:#ef4444!important}.fc .fc-timegrid-now-indicator-arrow{border-color:#ef4444!important}.repeat-toggle{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;display:grid}.repeat-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s;display:flex}.repeat-btn:hover{background:#f8fafc}.repeat-btn.active{color:#4338ca;background:#eef2ff;border-color:#818cf8}.repeat-btn svg{width:16px;height:16px}.repeat-hint{color:#64748b;background:#f8fafc;border-radius:6px;margin-bottom:16px;padding:8px 12px;font-size:12px}.checkbox-field{cursor:pointer;background:#f8fafc;border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:10px 12px;display:flex}.checkbox-field input{cursor:pointer;accent-color:#4f46e5;width:18px;height:18px;margin:0}.checkbox-field label{color:#334155;cursor:pointer;flex:1;font-size:14px}.delete-options{flex-direction:column;gap:8px;margin-bottom:4px;display:flex}.delete-option{cursor:pointer;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:10px;padding:12px 14px;transition:background .12s,border-color .12s;display:flex}.delete-option:hover{background:#f8fafc}.delete-option:has(input:checked){background:#eef2ff;border-color:#818cf8}.delete-option input[type=radio]{accent-color:#4f46e5;flex-shrink:0;width:18px;height:18px;margin:0}.delete-option span{color:#334155;font-size:14px}.modal-foot.with-danger{justify-content:space-between}.modal-foot.with-danger .left-actions,.modal-foot.with-danger .right-actions{gap:10px;display:flex}.student-hero{background:#fff;border:1px solid #e2e8f0;border-radius:16px;grid-template-columns:auto 1fr;align-items:start;gap:20px;margin-bottom:28px;padding:24px;display:grid}@media(min-width:1024px){.student-hero{grid-template-columns:auto 1fr auto;gap:28px;padding:28px}}.hero-avatar{color:#fff;width:80px;height:80px;font-family:var(--font-display);background:linear-gradient(135deg,#6366f1,#7c3aed);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:32px;font-weight:700;display:flex}.hero-info{min-width:0}.hero-name{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;margin-bottom:6px;font-size:22px;font-weight:600}@media(min-width:1024px){.hero-name{font-size:26px}}.hero-meta{flex-direction:column;gap:4px;margin-top:8px;display:flex}.hero-meta-row{color:#475569;align-items:center;gap:6px;font-size:14px;display:inline-flex}.hero-meta-row svg{color:#94a3b8;flex-shrink:0;width:14px;height:14px}.hero-notes{color:#475569;background:#f8fafc;border-left:3px solid #c7d2fe;border-radius:8px;margin-top:12px;padding:10px 14px;font-size:13px;line-height:1.5}.hero-stats{border-top:1px solid #f1f5f9;grid-column:1/-1;gap:24px;padding-top:20px;display:flex}@media(min-width:1024px){.hero-stats{border-top:0;border-left:1px solid #f1f5f9;flex-direction:column;grid-column:auto;justify-content:center;align-self:stretch;gap:14px;padding-top:0;padding-left:28px}}.hero-stat{text-align:center;min-width:70px}@media(min-width:1024px){.hero-stat{text-align:left;align-items:center;gap:16px;min-width:0;display:flex}}.hero-stat-value{font-family:var(--font-display);color:#0f172a;font-size:24px;font-weight:700;line-height:1}@media(min-width:1024px){.hero-stat-value{text-align:right;min-width:50px;font-size:26px}}.hero-stat-value.accent{color:#4f46e5}.hero-stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:11px;font-weight:500}@media(min-width:1024px){.hero-stat-label{text-transform:none;letter-spacing:0;color:#64748b;margin-top:0;font-size:13px}}.detail-section{margin-bottom:24px}.detail-section-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;display:flex}.detail-section-title{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;align-items:center;gap:8px;font-size:18px;font-weight:600;display:flex}.detail-section-title svg{color:#64748b;width:18px;height:18px}.detail-section-count{color:#94a3b8;font-size:14px;font-weight:400}.grade-list{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.grade-row{border-bottom:1px solid #f1f5f9;grid-template-columns:1fr auto auto;align-items:center;gap:14px;padding:14px 18px;transition:background .15s;display:grid}.grade-row:last-child{border-bottom:0}.grade-row:hover{background:#f8fafc}.grade-row-main{min-width:0}.grade-row-topic{color:#0f172a;margin-bottom:2px;font-size:14px;font-weight:500}.grade-row-comment{color:#64748b;text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.grade-row-date{color:#94a3b8;flex-shrink:0;font-size:12px}.detail-lesson-list{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.detail-lesson-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:14px;padding:14px 18px;transition:background .15s;display:flex}.detail-lesson-row:last-child{border-bottom:0}.detail-lesson-row:hover{background:#f8fafc}.detail-lesson-info{flex:1;min-width:0}.detail-lesson-topic{color:#0f172a;margin-bottom:2px;font-size:14px;font-weight:500}.detail-lesson-time{color:#64748b;font-size:13px}.lesson-badge{border-radius:6px;flex-shrink:0;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.lesson-badge.done{color:#047857;background:#d1fae5}.lesson-badge.done svg{width:12px;height:12px}.lesson-badge.pending{color:#b45309;background:#fef3c7}.detail-empty{text-align:center;color:#94a3b8;background:#fff;border:1px dashed #e2e8f0;border-radius:12px;padding:32px 20px;font-size:14px}.q-counter{color:#4338ca;background:#eef2ff;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.task-description{color:#475569;background:#f8fafc;border:1px solid #f1f5f9;border-left:3px solid #c7d2fe;border-radius:8px;margin-bottom:20px;padding:14px 18px;font-size:14px;line-height:1.5}.q-solve-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:20px 22px}.q-solve-text{color:#0f172a;margin:12px 0 14px;font-size:15px;line-height:1.5}.q-solve-options{flex-direction:column;gap:8px;display:flex}.q-solve-option{color:#334155;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:12px;padding:12px 14px;font-size:14px;transition:background .12s,border-color .12s;display:flex}.q-solve-option:hover{background:#fafbff;border-color:#c7d2fe}.q-solve-option.selected{color:#0f172a;background:#eef2ff;border-color:#818cf8;font-weight:500}.q-solve-option input{opacity:0;pointer-events:none;position:absolute}.q-solve-option-circle{background:#fff;border:2px solid #cbd5e1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:border-color .12s;display:flex}.q-solve-option.selected .q-solve-option-circle{border-color:#4f46e5}.q-solve-option.selected .q-solve-option-circle:after{content:"";background:#4f46e5;border-radius:50%;width:9px;height:9px}.q-solve-input{max-width:320px}.submit-row{justify-content:center;margin-top:24px;padding:24px 0;display:flex}.btn-submit-large{color:#fff;cursor:pointer;background:#4f46e5;border-radius:10px;align-items:center;gap:8px;padding:12px 32px;font-size:15px;font-weight:600;transition:background .12s;display:inline-flex}.btn-submit-large:hover:not(:disabled){background:#4338ca}.btn-submit-large:disabled{opacity:.6;cursor:not-allowed}.btn-submit-large svg{width:18px;height:18px}.result-card{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;max-width:620px;margin:0 auto;padding:40px 28px}.result-icon-large{border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 18px;display:flex}.result-icon-large svg{width:44px;height:44px}.result-icon-large.high{color:#10b981;background:#ecfdf5}.result-icon-large.mid{color:#f59e0b;background:#fffbeb}.result-icon-large.low{color:#f43f5e;background:#fef2f2}.result-title{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;margin-bottom:10px;font-size:24px;font-weight:600}.result-score-big{font-family:var(--font-display);margin-bottom:10px;font-size:56px;font-weight:700;line-height:1}.result-score-big.sc-high{color:#059669}.result-score-big.sc-mid{color:#d97706}.result-score-big.sc-low{color:#e11d48}.result-details{color:#64748b;margin-bottom:28px;font-size:14px}.result-details strong{color:#0f172a;font-weight:600}.result-answers{text-align:left;flex-direction:column;gap:6px;margin-bottom:24px;display:flex}.result-answer-row{border-radius:8px;grid-template-columns:28px 1fr auto auto;align-items:center;gap:10px;padding:10px 14px;font-size:14px;display:grid}.result-answer-row.ok{background:#f0fdf4}.result-answer-row.fail{background:#fef2f2}.result-answer-num{color:#475569;background:#fff;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:600;display:flex}.result-answer-text{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.result-answer-pts{color:#64748b;white-space:nowrap;font-size:12px}.result-answer-mark{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.result-answer-mark svg{width:14px;height:14px}.result-answer-mark.ok{color:#fff;background:#10b981}.result-answer-mark.fail{color:#fff;background:#f43f5e}.auth-page{background-color:#f8fafc;background-image:radial-gradient(circle at 0 0,#4f46e50f,#0000 40%),radial-gradient(circle at 100% 100%,#7c3aed0f,#0000 40%);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:440px;padding:40px;box-shadow:0 4px 24px #0f172a0a}@media(max-width:480px){.auth-card{padding:28px 24px}}.auth-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:6px;display:flex}.auth-logo-icon{background:#4f46e5;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.auth-logo-icon svg{color:#fff;width:24px;height:24px}.auth-logo-title{font-family:var(--font-display);letter-spacing:-.02em;color:#0f172a;font-size:22px;font-weight:700}.auth-subtitle{text-align:center;color:#64748b;margin-top:4px;margin-bottom:28px;font-size:14px}.auth-submit{color:#fff;cursor:pointer;background:#4f46e5;border-radius:10px;justify-content:center;align-items:center;width:100%;height:44px;margin-top:8px;font-size:15px;font-weight:600;transition:background .12s;display:flex}.auth-submit:hover:not(:disabled){background:#4338ca}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-link{text-align:center;color:#64748b;margin-top:24px;font-size:14px}.auth-link a{color:#4f46e5;font-weight:500}.auth-link a:hover{color:#4338ca}.auth-error{color:#be123c;background:#fef2f2;border:1px solid #fecdd3;border-radius:8px;margin-bottom:18px;padding:10px 14px;font-size:13px}.tabs-bar{background:#f1f5f9;border-radius:10px;align-items:center;gap:4px;padding:4px;display:inline-flex}.tab-btn{color:#64748b;cursor:pointer;background:0 0;border:0;border-radius:7px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:inline-flex}.tab-btn:hover{color:#334155}.tab-btn.active{color:#0f172a;background:#fff;box-shadow:0 1px 3px #00000014}.tab-btn svg{width:16px;height:16px}.an-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px;transition:border-color .12s,box-shadow .12s}.an-card:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #4f46e50d}.an-card.active{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.an-card-top{align-items:center;gap:12px;margin-bottom:14px;display:flex}.an-card-info{flex:1;min-width:0}.an-card-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.an-card-subject{color:#64748b;margin-top:1px;font-size:12px}.risk-badge{border-radius:999px;flex-shrink:0;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.risk-badge.low,.risk-badge.green{color:#047857;background:#d1fae5}.risk-badge.medium,.risk-badge.yellow{color:#b45309;background:#fef3c7}.risk-badge.high,.risk-badge.red{color:#be123c;background:#ffe4e6}.risk-badge.unknown,.risk-badge.gray{color:#64748b;background:#f1f5f9}.an-card-stats{border-top:1px solid #f1f5f9;grid-template-columns:repeat(4,1fr);gap:8px;padding-top:14px;display:grid}.an-card-stat{text-align:center}.an-card-stat-value{font-family:var(--font-display);color:#0f172a;font-size:16px;font-weight:600;line-height:1.1}.an-card-stat-value.grade-high{color:#059669}.an-card-stat-value.grade-mid{color:#d97706}.an-card-stat-value.grade-low{color:#e11d48}.an-card-stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-top:3px;font-size:10px}.trend-cell{justify-content:center;align-items:center;gap:4px;font-size:13px;font-weight:600;display:inline-flex}.trend-cell svg{width:14px;height:14px}.trend-cell.improving{color:#059669}.trend-cell.declining{color:#e11d48}.trend-cell.stable{color:#64748b}.select-hint{color:#4338ca;background:#eef2ff;border:1px dashed #c7d2fe;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-top:18px;padding:18px;font-size:14px;font-weight:500;display:flex}.select-hint svg{width:16px;height:16px}.an-detail{margin-top:32px}.an-detail-title{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;margin-bottom:18px;font-size:20px;font-weight:600}.an-grid{grid-template-columns:1fr;gap:16px;margin-bottom:20px;display:grid}@media(min-width:768px){.an-grid{grid-template-columns:1fr 1fr}}.an-detail-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px 22px}.an-detail-card-title{font-family:var(--font-display);color:#0f172a;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;font-size:15px;font-weight:600;display:flex}.an-detail-card-title svg{color:#64748b;width:18px;height:18px}.an-detail-card-title .title-left{align-items:center;gap:8px;display:flex}.prediction-value{font-family:var(--font-display);color:#4f46e5;margin-bottom:10px;font-size:48px;font-weight:700;line-height:1}.prediction-empty{color:#94a3b8;margin-bottom:10px;font-size:14px}.prediction-meta{color:#475569;flex-direction:column;gap:6px;font-size:13px;display:flex}.prediction-meta strong{color:#0f172a;font-weight:600}.risk-large{border-radius:999px;align-items:center;margin-bottom:14px;padding:8px 18px;font-size:15px;font-weight:600;display:inline-flex}.risk-large.low,.risk-large.green{color:#047857;background:#d1fae5}.risk-large.medium,.risk-large.yellow{color:#b45309;background:#fef3c7}.risk-large.high,.risk-large.red{color:#be123c;background:#ffe4e6}.risk-stats{color:#475569;flex-direction:column;gap:4px;margin-bottom:14px;font-size:13px;display:flex}.risk-stats strong{color:#0f172a;font-weight:600}.recommendation-box{color:#334155;background:#eef2ff;border-left:3px solid #4f46e5;border-radius:8px;align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;line-height:1.5;display:flex}.recommendation-box svg{color:#4f46e5;flex-shrink:0;width:16px;height:16px;margin-top:2px}.urgent-badge{color:#be123c;background:#fef2f2;border-radius:999px;align-items:center;padding:2px 10px;font-size:11px;font-weight:700;display:inline-flex}.review-description{color:#64748b;margin-bottom:16px;font-size:13px;line-height:1.5}.review-list{flex-direction:column;gap:10px;display:flex}.review-item{background:#f8fafc;border:1px solid #f1f5f9;border-radius:10px;padding:14px 16px}.review-item.urgent{background:#fff7ed;border-color:#fed7aa}.review-item-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.review-item-topic{color:#0f172a;font-size:14px;font-weight:600}.review-urgent-tag{color:#fff;background:#f97316;border-radius:999px;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.retention-bar-wrap{background:#e2e8f0;border-radius:999px;height:6px;margin-bottom:10px;overflow:hidden}.retention-bar{border-radius:999px;height:100%;transition:width .4s}.retention-bar.retention-good{background:#10b981}.retention-bar.retention-warning{background:#f59e0b}.retention-bar.retention-danger{background:#ef4444}.review-meta{color:#64748b;grid-template-columns:repeat(2,1fr);gap:4px 16px;margin-bottom:8px;font-size:12px;display:grid}@media(min-width:640px){.review-meta{grid-template-columns:repeat(4,1fr)}}.review-meta strong{color:#0f172a;font-weight:600}.review-next-date{color:#4f46e5;font-size:12px;font-weight:500}.topic-row{border-bottom:1px solid #f1f5f9;grid-template-columns:1fr 2fr auto auto;align-items:center;gap:12px;padding:10px 0;font-size:13px;display:grid}.topic-row:last-child{border-bottom:0}.topic-name{color:#0f172a;font-weight:500}.topic-bar-wrap{background:#f1f5f9;border-radius:999px;height:8px;overflow:hidden}.topic-bar{border-radius:999px;height:100%;transition:width .4s}.topic-bar.bar-high{background:#10b981}.topic-bar.bar-mid{background:#f59e0b}.topic-bar.bar-low{background:#ef4444}.topic-grade{font-family:var(--font-display);text-align:right;min-width:28px;font-size:14px;font-weight:600}.topic-grade.grade-high{color:#059669}.topic-grade.grade-mid{color:#d97706}.topic-grade.grade-low{color:#e11d48}.topic-count{color:#94a3b8;white-space:nowrap;font-size:12px}.topics-summary{border-radius:8px;align-items:flex-start;gap:8px;margin-top:12px;padding:10px 14px;font-size:13px;line-height:1.5;display:flex}.topics-summary svg{flex-shrink:0;width:16px;height:16px;margin-top:2px}.topics-summary.weak{color:#9a3412;background:#fff7ed;border-left:3px solid #f97316}.topics-summary.strong{color:#166534;background:#f0fdf4;border-left:3px solid #10b981}.clusters-grid{grid-template-columns:1fr;gap:14px;margin-bottom:24px;display:grid}@media(min-width:768px){.clusters-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1280px){.clusters-grid{grid-template-columns:repeat(3,1fr)}}.cluster-card{background:#fff;border:1px solid #e2e8f0;border-left:4px solid;border-radius:12px;padding:18px 20px}.cluster-head{align-items:center;gap:10px;margin-bottom:8px;display:flex}.cluster-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cluster-label{font-family:var(--font-display);color:#0f172a;flex:1;font-size:16px;font-weight:600}.cluster-count{color:#64748b;background:#f1f5f9;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:500}.cluster-description{color:#64748b;margin-bottom:14px;font-size:13px;line-height:1.5}.cluster-stats{border-top:1px solid #f1f5f9;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:14px;display:grid}.cluster-stat{text-align:center}.cluster-stat-value{font-family:var(--font-display);color:#0f172a;font-size:18px;font-weight:600;line-height:1;display:block}.cluster-stat-value.grade-high{color:#059669}.cluster-stat-value.grade-mid{color:#d97706}.cluster-stat-value.grade-low{color:#e11d48}.cluster-stat-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin-top:4px;font-size:10px;display:block}.cluster-table{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.cluster-table-head{color:#64748b;text-transform:uppercase;letter-spacing:.06em;background:#f8fafc;border-bottom:1px solid #e2e8f0;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr 1fr;padding:14px 20px;font-size:11px;font-weight:600;display:grid}.cluster-table-row{border-top:1px solid #f1f5f9;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr 1fr;align-items:center;padding:12px 20px;font-size:13px;transition:background .15s;display:grid}.cluster-table-row:first-of-type{border-top:0}.cluster-table-row:hover{background:#f8fafc}.cluster-table-name{color:#0f172a;font-weight:500}.cluster-mini-badge{border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.cluster-mini-badge .mini-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}@media(max-width:767px){.cluster-table{display:none}}div.auth-root{background:#f8fafc;grid-template-columns:1fr;min-height:100vh;display:grid}@media(min-width:1024px){div.auth-root{grid-template-columns:1fr 1fr}}.auth-hero{color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);flex-direction:column;justify-content:space-between;padding:64px 56px;display:none;position:relative;overflow:hidden}@media(min-width:1024px){.auth-hero{display:flex}}.auth-hero:before{content:"";background:#ffffff14;border-radius:50%;width:400px;height:400px;position:absolute;top:-120px;right:-120px}.auth-hero:after{content:"";background:#ffffff0d;border-radius:50%;width:300px;height:300px;position:absolute;bottom:-80px;left:-80px}.auth-hero-content{z-index:1;position:relative}.auth-hero-logo{align-items:center;gap:12px;display:flex}.auth-hero-logo-icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff2e;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.auth-hero-logo-icon svg{color:#fff;width:24px;height:24px}.auth-hero-logo-text{font-family:var(--font-display);letter-spacing:-.01em;font-size:20px;font-weight:700}.auth-hero-headline{z-index:1;max-width:480px;position:relative}.auth-hero-title{font-family:var(--font-display);letter-spacing:-.025em;margin-bottom:16px;font-size:40px;font-weight:700;line-height:1.15}.auth-hero-subtitle{opacity:.85;margin-bottom:32px;font-size:17px;line-height:1.5}.auth-hero-features{flex-direction:column;gap:14px;display:flex}.auth-hero-feature{align-items:center;gap:12px;font-size:15px;display:flex}.auth-hero-feature-icon{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.auth-hero-feature-icon svg{color:#fff;width:16px;height:16px}.auth-hero-footer{z-index:1;opacity:.7;font-size:13px;position:relative}.auth-form-wrap{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}@media(min-width:1024px){.auth-form-wrap{padding:48px}}.auth-form-card{width:100%;max-width:420px}.auth-mobile-logo{justify-content:center;align-items:center;gap:10px;margin-bottom:28px;display:flex}@media(min-width:1024px){.auth-mobile-logo{display:none}}.auth-mobile-logo-icon{background:#4f46e5;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.auth-mobile-logo-icon svg{color:#fff;width:20px;height:20px}.auth-mobile-logo-text{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;font-size:18px;font-weight:700}.auth-title{font-family:var(--font-display);color:#0f172a;letter-spacing:-.02em;margin-bottom:6px;font-size:28px;font-weight:600}.auth-subtitle{color:#64748b;margin-bottom:28px;font-size:14px}.auth-form .form-field{margin-bottom:18px}.auth-error{color:#be123c;background:#fef2f2;border:1px solid #fecdd3;border-radius:8px;align-items:center;gap:8px;margin-bottom:18px;padding:10px 14px;font-size:13px;display:flex}.auth-error svg{flex-shrink:0;width:16px;height:16px}.auth-submit-btn{color:#fff;cursor:pointer;background:#4f46e5;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:11px 18px;font-family:inherit;font-size:14px;font-weight:500;transition:background .12s;display:flex}.auth-submit-btn:hover:not(:disabled){background:#4338ca}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;color:#64748b;margin-top:24px;font-size:14px}.auth-footer a{color:#4f46e5;font-weight:500}.auth-footer a:hover{color:#4338ca}.model-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.model-card-head{border-bottom:1px solid #f1f5f9;align-items:center;gap:14px;margin-bottom:18px;padding-bottom:18px;display:flex}.model-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.model-card-icon.indigo{color:#4f46e5;background:#eef2ff}.model-card-icon.violet{color:#7c3aed;background:#f5f3ff}.model-card-icon svg{width:24px;height:24px}.model-card-name{font-family:var(--font-display);color:#0f172a;letter-spacing:-.01em;font-size:17px;font-weight:600}.model-card-purpose{color:#64748b;margin-top:2px;font-size:13px}.model-card-params{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.model-param{text-align:center;background:#f8fafc;border-radius:8px;padding:10px 14px}.model-param-label{text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin-bottom:4px;font-size:10px;font-weight:500;display:block}.model-param-value{font-family:var(--font-display);color:#0f172a;font-size:18px;font-weight:600;display:block}.model-section-title{color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;font-size:12px;font-weight:600}.model-importances{flex-direction:column;gap:8px;display:flex}.model-imp-row{grid-template-columns:130px 1fr 50px;align-items:center;gap:10px;font-size:13px;display:grid}.model-imp-name{color:#334155;white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.model-imp-bar-wrap{background:#f1f5f9;border-radius:999px;height:8px;overflow:hidden}.model-imp-bar{background:#818cf8;border-radius:999px;height:100%;transition:width .5s}.model-imp-bar.top{background:#4f46e5}.model-imp-bar.violet{background:#c4b5fd}.model-imp-bar.violet.top{background:#7c3aed}.model-imp-value{font-family:var(--font-display);color:#0f172a;text-align:right;font-size:13px;font-weight:600}.model-classes{color:#64748b;border-top:1px solid #f1f5f9;margin-top:18px;padding-top:18px;font-size:13px}.model-classes strong{color:#0f172a;font-weight:500}.feature-list{grid-template-columns:1fr;gap:8px;display:grid}@media(min-width:768px){.feature-list{grid-template-columns:1fr 1fr}}.feature-item{background:#f8fafc;border-radius:8px;align-items:baseline;gap:12px;padding:10px 14px;display:flex}.feature-name{color:#4f46e5;flex-shrink:0;width:50px;font-family:SF Mono,Consolas,monospace;font-size:13px;font-weight:700}.feature-desc{color:#475569;font-size:13px;line-height:1.4}.metrics-table{border:1px solid #f1f5f9;border-radius:8px;overflow:hidden}.metrics-row{border-top:1px solid #f1f5f9;grid-template-columns:1.2fr 1.8fr 1fr;align-items:center;padding:12px 16px;font-size:13px;display:grid}.metrics-row:first-child{border-top:0}.metrics-head{color:#64748b;text-transform:uppercase;letter-spacing:.06em;background:#f8fafc;font-size:11px;font-weight:600}.metrics-model{color:#0f172a;font-weight:600}.metrics-value{font-family:var(--font-display);color:#0f172a;text-align:right;font-weight:600}.metrics-value.good{color:#059669}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
