:root{--bg:#f2f6fb;--surface:#ffffff;--surface-alt:#edf5ff;--text:#132033;--muted:#63748a;--line:#d7e2ef;--primary:#3158d6;--primary-dark:#18284f;--accent:#b87938;--sky:#2563eb;--violet:#6f58d9;--rose:#d15c78;--danger:#e85d5d;--success:#15803d;--shadow:0 24px 60px rgba(13,26,45,0.1);--radius-lg:24px;--radius-md:18px;--radius-sm:12px;--sidebar-width:308px;--font-sans:"Avenir Next","Segoe UI","Helvetica Neue",Helvetica,sans-serif}*{box-sizing:border-box}html{font-family:var(--font-sans)}body{margin:0;background:radial-gradient(circle at top left,rgba(49,88,214,.14),transparent 22%),radial-gradient(circle at 85% 12%,rgba(111,88,217,.1),transparent 24%),radial-gradient(circle at 55% 100%,rgba(184,121,56,.12),transparent 30%),linear-gradient(180deg,#f8fbff 0,var(--bg) 100%);color:var(--text)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.page-shell{min-height:100vh}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:min(100%,980px);display:grid;grid-template-columns:1.1fr .9fr;grid-gap:24px;gap:24px;padding:24px;border-radius:28px;background:rgba(255,255,255,.88);border:1px solid rgba(215,226,239,.84);box-shadow:var(--shadow)}.auth-card__hero{padding:28px;border-radius:24px;background:radial-gradient(circle at top right,rgba(255,255,255,.16),transparent 28%),linear-gradient(135deg,#121b36,#203d8f 56%,#b87938);color:white}.auth-card__hero h1{margin:10px 0 12px;font-size:2.2rem}.auth-card__hero p{margin:0;color:rgba(255,255,255,.8);line-height:1.6}.auth-form{display:grid;grid-gap:18px;gap:18px;align-content:center;padding:18px 8px}.auth-field{display:grid;grid-gap:8px;gap:8px}.auth-field label{font-weight:600}.auth-field input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid var(--line);background:white}.auth-error{padding:12px 14px;border-radius:14px;background:rgba(232,93,93,.12);color:var(--danger)}.auth-submit{width:100%;justify-content:center}.auth-links{display:flex;justify-content:flex-end;gap:12px;font-size:.92rem}.auth-links a{color:var(--primary);font-weight:600}.auth-hint{color:var(--muted);font-size:.92rem;padding:0 8px 8px}.settings-stack{display:grid;grid-gap:16px;gap:16px}.settings-row{display:flex;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:rgba(49,88,214,.04)}.settings-hint,.settings-row span{color:var(--muted)}.settings-hint{font-size:.92rem;line-height:1.5}.settings-success{display:inline-flex;align-items:center;padding:10px 12px;border-radius:12px;background:rgba(21,128,61,.12);color:var(--success)}.settings-secret{display:grid;grid-gap:6px;gap:6px;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#f9fbfb}.settings-secret code{overflow-wrap:anywhere;padding:10px 12px;border-radius:12px;background:#eef3ff;color:var(--primary-dark)}.settings-methods{display:flex;gap:12px;flex-wrap:wrap}.settings-qr{display:grid;place-items:center;padding:18px;border-radius:18px;border:1px solid var(--line);background:#f7f9ff}.settings-qr img{width:min(240px,100%);height:auto;display:block}.audit-list{display:grid;grid-gap:12px;gap:12px}.audit-item{display:grid;grid-gap:10px;gap:10px;padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(49,88,214,.04),rgba(255,255,255,.92))}.audit-item--full{padding:18px 20px}.audit-item__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.audit-item__header span{color:var(--muted);white-space:nowrap}.audit-item__meta{display:flex;gap:10px;flex-wrap:wrap}.audit-item__meta span{padding:6px 10px;border-radius:999px;background:rgba(49,88,214,.08);color:var(--primary-dark);font-size:.9rem}.audit-empty{padding:18px;border-radius:18px;border:1px dashed var(--line);color:var(--muted);background:rgba(255,255,255,.7)}.live-indicator{display:flex;align-items:center;gap:10px;margin-bottom:12px;color:var(--muted);font-size:.92rem}.live-indicator__dot{width:10px;height:10px;border-radius:999px;background:#cbd5e1}.live-indicator__dot--connected{background:var(--success);box-shadow:0 0 0 6px rgba(21,128,61,.12)}.live-indicator__dot--connecting{background:var(--accent);box-shadow:0 0 0 6px rgba(245,158,11,.12)}.live-indicator__dot--offline{background:var(--danger);box-shadow:0 0 0 6px rgba(232,93,93,.12)}.message-list__side{display:grid;justify-items:end;grid-gap:8px;gap:8px}.message-list__date{color:var(--muted);font-size:.9rem}.preferences-grid{display:grid;grid-gap:14px;gap:14px}.preference-row{display:grid;grid-template-columns:minmax(0,1.3fr) 180px 160px;grid-gap:14px;gap:14px;align-items:center;padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:rgba(49,88,214,.04)}.preference-row p{margin:6px 0 0;color:var(--muted);font-size:.92rem}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:14px;background:#fff;border:1px solid var(--line)}.toggle-row input{width:18px;height:18px}.student-form{display:grid;grid-gap:18px;gap:18px}.student-form__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.dashboard-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;min-height:100vh;padding:22px 18px;border-right:1px solid rgba(215,226,239,.75);background:linear-gradient(180deg,rgba(15,23,42,.98),rgba(27,46,94,.94)),rgba(24,40,79,.94);color:white;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);overflow:hidden}.sidebar__brand{display:grid;grid-gap:14px;gap:14px;margin-bottom:22px;padding:18px;border-radius:24px;background:radial-gradient(circle at top right,rgba(191,132,66,.22),transparent 30%),linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 40px rgba(3,7,18,.26)}.sidebar__brand-mark{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,#3158d6,#b87938);color:white;box-shadow:0 16px 28px rgba(49,88,214,.24)}.sidebar__brand-mark svg{width:24px;height:24px}.sidebar__brand-copy{display:grid;grid-gap:6px;gap:6px}.sidebar__brand-copy strong{font-size:1.12rem;letter-spacing:-.02em}.sidebar__brand-copy span{color:rgba(255,255,255,.72);font-size:.9rem;line-height:1.55}.sidebar__status{display:inline-flex;align-items:center;gap:8px;width:max-content;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.92);font-size:.84rem;font-weight:600}.sidebar__status svg{width:16px;height:16px}.sidebar__nav{display:grid;grid-gap:10px;gap:10px}.sidebar__link{position:relative;display:grid;grid-template-columns:auto 1fr;grid-gap:12px;gap:12px;align-items:center;padding:13px 14px;border-radius:18px;color:rgba(255,255,255,.8);border:1px solid transparent;transition:transform .18s ease,background-color .18s ease,border-color .18s ease}.sidebar__link:hover{transform:translateX(4px);background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1)}.sidebar__link-icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#bfdbfe}.sidebar__link-icon svg{width:18px;height:18px}.sidebar__link-copy{display:grid;grid-gap:2px;gap:2px}.sidebar__link-copy strong{font-size:.95rem}.sidebar__link-copy span{color:rgba(255,255,255,.6);font-size:.78rem}.sidebar__link--active{background:radial-gradient(circle at top right,rgba(255,255,255,.22),transparent 35%),linear-gradient(135deg,#2542a8,#4a56c8 54%,#b87938);color:white;border-color:rgba(255,255,255,.15);box-shadow:0 18px 34px rgba(37,99,235,.2)}.sidebar__link--active .sidebar__link-icon{background:rgba(255,255,255,.18);color:white}.sidebar__link--active .sidebar__link-copy span{color:rgba(255,255,255,.82)}.main-panel{padding:24px 26px 32px}.topbar{position:relative;display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:24px;padding:26px 28px;border-radius:var(--radius-lg);background:radial-gradient(circle at 85% 15%,rgba(255,255,255,.2),transparent 18%),radial-gradient(circle at 25% 120%,rgba(191,132,66,.24),transparent 30%),linear-gradient(135deg,#111936,#274cb6 44%,#7c5a3b);color:white;box-shadow:var(--shadow);overflow:hidden}.topbar__title{display:grid;grid-gap:6px;gap:6px;max-width:760px}.topbar__eyebrow{color:rgba(255,255,255,.72);font-size:.88rem;text-transform:uppercase;letter-spacing:.08em}.topbar__summary{margin:0;color:rgba(255,255,255,.78);line-height:1.6;max-width:72ch}.topbar__actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end}.chip-button{border:0;border-radius:999px;padding:11px 15px;background:rgba(255,255,255,.14);color:white;font-weight:600;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.chip-button,.chip-button--with-badge{display:inline-flex;align-items:center;gap:8px}.chip-button__badge{min-width:22px;height:22px;padding:0 6px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(245,158,11,.9);color:#1f2937;font-size:.78rem;font-weight:700}.button-icon{width:16px;height:16px}.topbar__profile{display:inline-flex;align-items:center;gap:12px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.14);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.topbar__avatar{width:38px;height:38px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(255,255,255,.26),rgba(255,255,255,.06));color:white;font-weight:700}.topbar__profile-meta{display:grid;grid-gap:2px;gap:2px}.topbar__profile-meta span{color:rgba(255,255,255,.74);font-size:.82rem}.notification-menu{position:relative}.notification-panel{position:absolute;top:calc(100% + 12px);right:0;width:min(92vw,420px);padding:16px;border-radius:20px;background:rgba(255,255,255,.98);color:var(--text);border:1px solid var(--line);box-shadow:var(--shadow);z-index:20;display:grid;grid-gap:12px;gap:12px}.notification-panel__header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.notification-panel__header>div:first-child{display:grid;grid-gap:4px;gap:4px}.notification-panel__header span{color:var(--muted);font-size:.88rem}.notification-panel__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.modal-shell{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:24px}.modal-backdrop{position:absolute;inset:0;background:rgba(12,18,34,.56);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-card{position:relative;width:min(100%,760px);max-height:calc(100vh - 48px);overflow:auto;border-radius:28px;background:rgba(255,255,255,.98);border:1px solid rgba(215,226,239,.88);box-shadow:0 32px 72px rgba(15,23,42,.24)}.modal-card__header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:24px 24px 14px;border-bottom:1px solid rgba(215,226,239,.8)}.modal-card__header h2{margin:0;font-size:1.4rem}.modal-card__header p{margin:8px 0 0;color:var(--muted);line-height:1.6}.modal-card__close{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(49,88,214,.08);color:var(--primary-dark);flex-shrink:0}.modal-card__close svg{width:18px;height:18px}.modal-card__body{padding:20px 24px 24px}.task-composer{display:grid;grid-gap:22px;gap:22px}.task-composer__hero{display:flex;gap:16px;align-items:center;padding:20px 22px;border-radius:24px;background:radial-gradient(circle at top right,rgba(255,255,255,.16),transparent 20%),linear-gradient(135deg,#2b4fcc,#4b58cf 58%,#6f58d9);color:white}.task-composer__hero strong{display:block;font-size:1.8rem;margin-bottom:4px}.task-composer__hero p{margin:0;color:rgba(255,255,255,.82);font-size:1.05rem}.task-composer__hero-icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:rgba(255,255,255,.14);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}.task-composer__hero-icon svg{width:24px;height:24px}.task-date-picker{display:grid;grid-gap:16px;gap:16px;padding:22px;border-radius:24px;background:linear-gradient(180deg,rgba(255,248,232,.82),rgba(255,252,245,.94));border:1px solid rgba(233,179,86,.48)}.task-date-picker__header{display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap}.task-date-picker__header strong{display:block;font-size:1.2rem;color:#9a531d}.task-date-picker__header span{display:block;margin-top:6px;color:#b66a2d}.task-date-picker__nav{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.task-date-picker__range{min-width:180px;text-align:center;font-weight:700;color:#8d4f1e}.task-date-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:12px;gap:12px}.task-date-chip{border:1px solid rgba(233,179,86,.62);border-radius:20px;padding:16px 10px;background:rgba(255,255,255,.92);color:#944c1d;display:grid;grid-gap:6px;gap:6px;justify-items:center;min-height:96px}.task-date-chip span{font-weight:700;text-transform:capitalize}.task-date-chip strong{font-size:2rem;line-height:1}.task-date-chip--today{box-shadow:inset 0 0 0 1px rgba(49,88,214,.18)}.task-date-chip--active{background:linear-gradient(180deg,#d97800,#db8400);color:white;border-color:transparent;box-shadow:0 16px 28px rgba(217,120,0,.22)}.task-composer__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:18px;gap:18px}.task-composer__section{display:grid;grid-gap:16px;gap:16px;padding:18px;border-radius:22px;border:1px solid rgba(215,226,239,.82);background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,250,255,.94))}.task-composer__section-title{display:flex;align-items:center;gap:12px;color:#334155;font-size:1.05rem}.task-composer__section-icon{width:36px;height:36px;border-radius:14px;display:grid;place-items:center;color:white}.task-composer__section-icon svg{width:18px;height:18px}.task-composer__section-icon--lesson{background:linear-gradient(135deg,#94aef3,#7a91e8)}.task-composer__section-icon--task{background:linear-gradient(135deg,#d9cef9,#b9a7f5)}.task-composer__section-icon--time{background:linear-gradient(135deg,#b9f0d1,#90deb2)}.task-composer__footer{display:flex;justify-content:flex-end;gap:14px;align-items:center}.notification-panel__list{display:grid;grid-gap:10px;gap:10px;max-height:380px;overflow:auto}.notification-item{display:grid;grid-gap:10px;gap:10px;padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:white}.notification-item--unread{background:linear-gradient(180deg,rgba(239,243,255,.96),white);border-color:rgba(49,88,214,.18)}.notification-item__meta{display:grid;grid-gap:4px;gap:4px}.notification-item__meta span{color:var(--muted);font-size:.88rem}.notification-item__actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.content-grid{display:grid;grid-gap:20px;gap:20px}.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:16px;gap:16px}.dashboard-spotlight{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.8fr);grid-gap:18px;gap:18px}.dashboard-spotlight__hero{position:relative;padding:26px;border-radius:28px;overflow:hidden;background:radial-gradient(circle at top right,rgba(255,255,255,.25),transparent 18%),linear-gradient(135deg,rgba(24,40,79,.99),rgba(49,88,214,.96) 52%,rgba(184,121,56,.94));color:white;box-shadow:0 28px 50px rgba(24,40,79,.18)}.dashboard-spotlight__hero h2{margin:12px 0 10px;font-size:clamp(1.8rem,2vw,2.4rem);line-height:1.1;letter-spacing:-.03em}.dashboard-spotlight__hero p{margin:0;max-width:62ch;color:rgba(255,255,255,.82);line-height:1.7}.dashboard-spotlight__eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.16);font-size:.84rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.dashboard-spotlight__eyebrow svg{width:16px;height:16px}.dashboard-spotlight__metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:12px;gap:12px;margin-top:20px}.dashboard-spotlight__metric{display:grid;grid-gap:4px;gap:4px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.12)}.dashboard-spotlight__metric span{color:rgba(255,255,255,.72);font-size:.85rem}.dashboard-spotlight__metric strong{font-size:1.35rem;letter-spacing:-.02em}.dashboard-spotlight__aside{display:grid;grid-gap:16px;gap:16px}.spotlight-mini-card{display:grid;grid-gap:10px;gap:10px;padding:22px;border-radius:24px;background:rgba(255,255,255,.88);border:1px solid rgba(215,226,239,.7);box-shadow:var(--shadow)}.spotlight-mini-card--teal{background:radial-gradient(circle at top right,rgba(184,121,56,.16),transparent 30%),rgba(255,255,255,.92)}.spotlight-mini-card--violet{background:radial-gradient(circle at top right,rgba(124,58,237,.18),transparent 30%),rgba(255,255,255,.92)}.spotlight-mini-card__icon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#3158d6,#b87938);color:white}.spotlight-mini-card__icon svg{width:20px;height:20px}.spotlight-mini-card strong{font-size:1.05rem}.spotlight-mini-card span:last-child{color:var(--muted);line-height:1.6}.section-card,.stat-card{background:rgba(255,255,255,.86);border:1px solid rgba(215,226,223,.75);border-radius:var(--radius-md);box-shadow:var(--shadow)}.stat-card{position:relative;padding:18px;display:grid;grid-gap:10px;gap:10px;overflow:hidden}.stat-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,rgba(49,88,214,.96),rgba(111,88,217,.92),rgba(184,121,56,.92))}.stat-card__top{display:flex;justify-content:space-between;gap:12px;align-items:center}.stat-card__icon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;color:white;box-shadow:0 16px 28px rgba(37,99,235,.18)}.stat-card__icon svg{width:20px;height:20px}.stat-card__tag{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;background:rgba(49,88,214,.08);color:var(--primary-dark);font-size:.78rem;font-weight:700}.stat-card--teal .stat-card__icon{background:linear-gradient(135deg,#3158d6,#5d7af0)}.stat-card--amber .stat-card__icon{background:linear-gradient(135deg,#f59e0b,#f97316)}.stat-card--violet .stat-card__icon{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}.stat-card--rose .stat-card__icon{background:linear-gradient(135deg,#e11d48,#fb7185)}.stat-card--sky .stat-card__icon{background:linear-gradient(135deg,#2563eb,#38bdf8)}.stat-card__label{color:var(--muted);font-size:.92rem;font-weight:600}.stat-card__value{font-size:2rem;font-weight:700;letter-spacing:-.03em}.stat-card__meta{color:var(--primary);font-size:.9rem}.two-column{display:grid;grid-template-columns:1.45fr 1fr;grid-gap:20px;gap:20px}.section-card{position:relative;padding:22px;overflow:hidden}.section-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,rgba(37,99,235,.92),rgba(124,58,237,.92))}.section-card--amber:before{background:linear-gradient(90deg,rgba(245,158,11,.92),rgba(249,115,22,.92))}.section-card--rose:before{background:linear-gradient(90deg,rgba(225,29,72,.92),rgba(251,113,133,.92))}.section-card--sky:before{background:linear-gradient(90deg,rgba(37,99,235,.92),rgba(56,189,248,.92))}.section-card--teal:before{background:linear-gradient(90deg,rgba(49,88,214,.92),rgba(93,122,240,.92))}.section-card__header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:18px}.section-card__title-group{display:flex;align-items:center;gap:14px}.section-card__icon{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;color:white;background:linear-gradient(135deg,#3158d6,#b87938)}.section-card__icon svg{width:20px;height:20px}.section-card--amber .section-card__icon{background:linear-gradient(135deg,#f59e0b,#f97316)}.section-card--rose .section-card__icon{background:linear-gradient(135deg,#e11d48,#fb7185)}.section-card--sky .section-card__icon{background:linear-gradient(135deg,#2563eb,#38bdf8)}.section-card--teal .section-card__icon{background:linear-gradient(135deg,#3158d6,#5d7af0)}.section-card__title{font-size:1.08rem;font-weight:700;letter-spacing:-.02em}.section-card__subtitle{color:var(--muted);font-size:.9rem;margin-top:4px}.list{display:grid;grid-gap:12px;gap:12px}.list-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 16px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(247,250,255,.88));border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 10px 22px rgba(13,26,45,.04)}.list-item__meta{display:grid;grid-gap:4px;gap:4px}.list-item__meta span{color:var(--muted);font-size:.9rem}.list-item__aside{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.badge{padding:6px 10px;border-radius:999px;font-size:.84rem;font-weight:600}.badge--success{background:rgba(21,128,61,.12);color:var(--success)}.badge--warning{background:rgba(245,158,11,.16);color:#a16207}.badge--danger{background:rgba(232,93,93,.13);color:var(--danger)}.chart-placeholder{min-height:240px;border-radius:var(--radius-md);background:linear-gradient(180deg,rgba(49,88,214,.08),rgba(49,88,214,.01)),repeating-linear-gradient(90deg,rgba(49,88,214,.05) 0,rgba(49,88,214,.05) 1px,transparent 0,transparent 72px),repeating-linear-gradient(180deg,rgba(96,112,124,.08) 0,rgba(96,112,124,.08) 1px,transparent 0,transparent 48px);border:1px solid var(--line);position:relative;overflow:hidden}.chart-placeholder:after{content:"";position:absolute;inset:auto 0 24px 0;height:120px;background:linear-gradient(90deg,transparent,rgba(49,88,214,.16) 16%,rgba(49,88,214,.72) 48%,rgba(184,121,56,.62) 72%,transparent);-webkit-clip-path:polygon(0 80%,16% 62%,32% 72%,48% 36%,64% 46%,78% 20%,100% 6%,100% 100%,0 100%);clip-path:polygon(0 80%,16% 62%,32% 72%,48% 36%,64% 46%,78% 20%,100% 6%,100% 100%,0 100%)}.chart-card{display:grid;grid-gap:16px;gap:16px}.chart-card__header{display:flex;justify-content:flex-start}.chart-card__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(49,88,214,.08);color:var(--primary-dark);font-size:.84rem;font-weight:700}.chart-card__badge svg{width:16px;height:16px}.chart-card__badge--sky{background:rgba(37,99,235,.08);color:#1d4ed8}.chart-card__badge--amber{background:rgba(245,158,11,.12);color:#a16207}.trend-chart{width:100%;height:auto;border:1px solid var(--line);border-radius:var(--radius-md);background:linear-gradient(180deg,rgba(37,99,235,.06),rgba(255,255,255,.9)),white}.trend-chart__label{fill:var(--muted);font-size:12px}.trend-chart__value{fill:#1d4ed8;font-size:11px;font-weight:700}.chart-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));grid-gap:10px;gap:10px}.chart-pill{display:grid;grid-gap:4px;gap:4px;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.9)}.chart-pill strong{font-size:.95rem}.chart-pill span{color:var(--muted);font-size:.84rem}.breakdown-list{display:grid;grid-gap:14px;gap:14px}.breakdown-item{display:grid;grid-gap:8px;gap:8px}.breakdown-item__meta{display:flex;justify-content:space-between;gap:10px}.breakdown-item__meta span{color:var(--muted)}.breakdown-item__bar{height:12px;border-radius:999px;background:rgba(96,112,124,.12);overflow:hidden}.breakdown-item__fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--primary-dark),var(--primary))}.breakdown-item__fill--success{background:linear-gradient(90deg,#15803d,#22c55e)}.breakdown-item__fill--warning{background:linear-gradient(90deg,#f59e0b,#f97316)}.breakdown-item__fill--danger{background:linear-gradient(90deg,#e11d48,#fb7185)}.bar-chart{min-height:280px;display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));grid-gap:14px;gap:14px;align-items:flex-end}.bar-chart__item{display:grid;grid-gap:8px;gap:8px;justify-items:center}.bar-chart__value{font-weight:700;color:var(--primary-dark)}.bar-chart__track{width:100%;min-height:170px;border-radius:18px;padding:10px;display:flex;align-items:flex-end;justify-content:center;background:linear-gradient(180deg,rgba(49,88,214,.08),rgba(96,112,124,.04)),white;border:1px solid var(--line)}.bar-chart__fill{width:100%;border-radius:14px;min-height:14px}.bar-chart__fill--0{background:linear-gradient(180deg,#38bdf8,#2563eb)}.bar-chart__fill--1{background:linear-gradient(180deg,#a78bfa,#7c3aed)}.bar-chart__fill--2{background:linear-gradient(180deg,#c6955f,#8f5d30)}.bar-chart__fill--3{background:linear-gradient(180deg,#f59e0b,#f97316)}.bar-chart__label{font-weight:700}.bar-chart__meta{color:var(--muted);font-size:.8rem;text-align:center}.student-hero{display:grid;grid-template-columns:auto 1fr auto;grid-gap:20px;gap:20px;align-items:center}.avatar{width:84px;height:84px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:white;font-weight:700;font-size:1.5rem}.hero-meta{display:grid;grid-gap:6px;gap:6px}.hero-subline{color:var(--muted)}.hero-actions,.hero-subline{display:flex;gap:10px;flex-wrap:wrap}.primary-button,.secondary-button{border:0;border-radius:14px;padding:12px 16px;display:inline-flex;align-items:center;gap:8px}.primary-button{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:white}.secondary-button{background:rgba(49,88,214,.08);color:var(--primary-dark);box-shadow:inset 0 0 0 1px rgba(49,88,214,.08)}.danger-button{border:0;border-radius:14px;padding:12px 16px;background:rgba(232,93,93,.12);color:var(--danger)}.inline-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.inline-button{padding:8px 12px;border-radius:10px;font-size:.86rem}.inline-error{color:var(--danger);font-size:.82rem}.inline-editor{width:100%}.inline-editor summary{list-style:none;cursor:pointer}.inline-editor summary::-webkit-details-marker{display:none}.inline-editor__form{margin-top:10px;display:grid;grid-gap:10px;gap:10px;padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.86)}.inline-editor__form input,.inline-editor__form select,.inline-editor__form textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:white}.inline-grid{display:grid;grid-gap:10px;gap:10px}.inline-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-toolbar{justify-content:space-between;gap:12px;margin-bottom:14px}.filter-form,.filter-toolbar{display:flex;align-items:center;flex-wrap:wrap}.filter-form{gap:10px}.filter-form input,.filter-form select{min-width:180px;border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:white}.checkbox-field{display:flex;align-items:center;gap:10px;color:var(--muted)}.tabs{display:flex;gap:10px;flex-wrap:wrap}.tab{padding:10px 14px;border-radius:999px;background:white;border:1px solid var(--line);color:var(--muted)}.tab--active{background:var(--primary-dark);color:white;border-color:transparent}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:16px;gap:16px}.metric-card{padding:18px;border-radius:var(--radius-md);background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(232,243,241,.82));border:1px solid var(--line)}.metric-card strong{display:block;font-size:1.4rem;margin-top:10px}.split-grid{display:grid;grid-template-columns:1.2fr .8fr;grid-gap:20px;gap:20px}.progress-bar{height:10px;border-radius:999px;background:#dbe7e5;overflow:hidden}.progress-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#4fd1c5)}.planner-shell{display:grid;grid-gap:20px;gap:20px}.planner-panel{padding:28px;border-radius:28px;background:rgba(255,255,255,.9);border:1px solid rgba(215,226,223,.78);box-shadow:var(--shadow)}.planner-panel--hero{display:grid;grid-gap:20px;gap:20px}.planner-panel__heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.planner-heading{display:flex;gap:18px;align-items:flex-start}.planner-heading__bar{width:8px;min-height:56px;border-radius:999px;background:linear-gradient(180deg,#3158d6,#b87938)}.planner-heading h2{margin:0;font-size:clamp(1.9rem,3vw,2.6rem)}.planner-heading p{margin:10px 0 0;color:var(--muted);line-height:1.6;max-width:760px}.planner-pdf-button{border:1px solid rgba(239,68,68,.2);border-radius:18px;padding:14px 18px;background:rgba(255,248,248,.94);color:#dc2626;font-weight:700}.planner-toolbar-card{display:grid;grid-gap:16px;gap:16px;padding:20px;border-radius:22px;background:#fbfcfe;border:1px solid rgba(215,226,223,.9)}.planner-toolbar-card__row{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}.planner-toolbar-card__row--secondary{align-items:flex-start}.planner-nav{display:flex;gap:10px;flex-wrap:wrap}.planner-nav__button{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 18px;border-radius:16px;background:white;border:1px solid var(--line);color:#334155;font-weight:700;box-shadow:0 8px 20px rgba(15,23,42,.05)}.planner-nav__button--primary{background:linear-gradient(135deg,#274cb6,#4b57cc);color:white;border-color:transparent}.planner-nav__button--icon{width:52px;padding:0}.planner-toolbar-card__meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.planner-toolbar-card__meta strong{font-size:1.1rem;color:#24324a}.planner-bullet{width:11px;height:11px;border-radius:999px;background:#3b82f6;box-shadow:0 0 0 6px rgba(59,130,246,.12)}.planner-switch{display:inline-flex;align-items:center;gap:12px;position:relative;padding:12px 16px;border-radius:16px;background:white;border:1px solid var(--line);color:var(--muted);font-weight:600}.planner-switch input{position:absolute;inset:0;opacity:0}.planner-switch__track{width:52px;height:30px;border-radius:999px;background:#d1d5db;position:relative;transition:background .2s ease}.planner-switch__track:after{content:"";position:absolute;top:4px;left:4px;width:22px;height:22px;border-radius:999px;background:white;box-shadow:0 4px 12px rgba(15,23,42,.16);transition:transform .2s ease}.planner-switch input:checked+.planner-switch__track{background:linear-gradient(135deg,#2563eb,#4f46e5)}.planner-switch input:checked+.planner-switch__track:after{transform:translateX(22px)}.planner-actions{display:flex;gap:12px;flex-wrap:wrap}.planner-action{border:1px solid rgba(203,213,225,.9);border-radius:16px;padding:14px 20px;background:white;color:#334155;font-weight:700;box-shadow:0 8px 20px rgba(15,23,42,.05)}.planner-action--primary{background:linear-gradient(135deg,#2563eb,#4f46e5);color:white;border-color:transparent}.planner-action--success{background:linear-gradient(135deg,#3158d6,#5d7af0);color:white;border-color:transparent}.planner-action--active{box-shadow:0 12px 28px rgba(49,88,214,.22)}.planner-filters{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.planner-student-select{display:grid;grid-gap:8px;gap:8px;min-width:250px;color:var(--muted);font-weight:600}.planner-student-select select{border:1px solid var(--line);border-radius:14px;padding:12px 14px;background:white}.planner-banner{padding:12px 14px;border-radius:16px;background:rgba(49,88,214,.08);color:#274cb6;font-weight:600}.planner-inline-card{display:grid;grid-gap:14px;gap:14px;padding:18px;border-radius:20px;background:white;border:1px solid var(--line)}.planner-inline-card__header{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center;color:var(--muted)}.planner-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:16px;gap:16px}.planner-metric{padding:18px 20px;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(239,246,255,.82));border:1px solid rgba(215,226,223,.78);box-shadow:var(--shadow)}.planner-metric span{color:var(--muted);display:block;margin-bottom:8px}.planner-metric strong{font-size:1.5rem;color:#1e293b}.planner-week-grid{display:grid;grid-template-columns:repeat(7,minmax(160px,1fr));grid-gap:0;gap:0;border:1px solid rgba(215,226,223,.9);border-radius:24px;overflow:hidden;background:white}.planner-day{min-height:360px;border-right:1px solid rgba(215,226,223,.9);display:grid;grid-template-rows:auto 1fr;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(246,248,252,.92))}.planner-day:last-child{border-right:0}.planner-day--today{background:linear-gradient(180deg,rgba(239,246,255,.95),rgba(255,255,255,.9))}.planner-day--droppable{transition:background .18s ease,transform .18s ease}.planner-day__header{padding:18px 16px;display:flex;justify-content:space-between;gap:12px;align-items:center;border-bottom:1px solid rgba(215,226,223,.9);background:white}.planner-day__header strong{display:block;font-size:1.05rem;color:#334155}.planner-day__header span{color:var(--muted)}.planner-day__header--today{background:linear-gradient(135deg,#4f46e5,#3b82f6)}.planner-day__header--today span,.planner-day__header--today strong{color:white}.planner-day__add{width:38px;height:38px;border-radius:12px;border:1px solid rgba(203,213,225,.9);background:white;color:#334155;font-size:1.35rem;line-height:1}.planner-day__body{padding:16px;display:grid;grid-gap:12px;gap:12px;align-content:flex-start}.planner-empty{min-height:90px;display:grid;place-items:center;text-align:center;color:#94a3b8;border-radius:18px;border:1px dashed rgba(148,163,184,.35);background:rgba(248,250,252,.9)}.planner-task-card{display:grid;grid-gap:10px;gap:10px;padding:14px;border-radius:18px;border:1px solid rgba(215,226,223,.9);background:white;box-shadow:0 10px 26px rgba(15,61,63,.06)}.planner-task-card--draggable{cursor:-webkit-grab;cursor:grab}.planner-task-card__top{display:grid;grid-gap:8px;gap:8px}.planner-task-card__top strong{font-size:.98rem;color:#1e293b}.planner-task-card__meta,.planner-task-card__stats{display:flex;gap:8px;flex-wrap:wrap}.planner-task-card__meta span,.planner-task-card__stats span{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:rgba(241,245,249,.9);color:#475569;font-size:.82rem;font-weight:600}.planner-week-grid--hourly .planner-day__body{background:repeating-linear-gradient(180deg,transparent 0,transparent 46px,rgba(226,232,240,.7) 0,rgba(226,232,240,.7) 47px)}@media (max-width:1200px){.metric-grid,.planner-metrics,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-spotlight,.split-grid,.two-column{grid-template-columns:1fr}.planner-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:900px){.dashboard-shell{grid-template-columns:1fr}.sidebar{position:static;border-right:0;border-bottom:1px solid rgba(215,226,223,.7);min-height:0}.auth-card,.inline-grid--2,.student-form__grid,.student-hero{grid-template-columns:1fr}.filter-form,.filter-toolbar,.planner-panel__heading,.planner-toolbar-card__row,.topbar{flex-direction:column;align-items:stretch}.topbar__actions{justify-content:flex-start}.dashboard-spotlight__metrics,.planner-week-grid{grid-template-columns:1fr}.planner-day{min-height:0;border-right:0;border-bottom:1px solid rgba(215,226,223,.9)}.planner-day:last-child{border-bottom:0}}@media (max-width:640px){.main-panel,.metric-card,.section-card,.stat-card,.topbar{padding:16px}.metric-grid,.planner-metrics,.stats-grid{grid-template-columns:1fr}.sidebar{padding:14px}.sidebar__link{grid-template-columns:40px 1fr}.sidebar__link-copy span{display:none}.topbar__profile{width:100%;justify-content:flex-start}.dashboard-spotlight__hero,.planner-panel,.spotlight-mini-card{padding:18px}}