:root{--bg:#f6f8ff;--card:#ffffff;--text:#24304a;--muted:#7d88a5;--primary:#7c9cff;--primary2:#9ed8ff;--danger:#ff7c91;--success:#70d6a3;--warning:#ffd166;--line:#e8ecf8;--shadow:0 14px 40px rgba(52,70,120,.10);--radius:22px}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:radial-gradient(circle at top left,#eaf1ff,transparent 35%),linear-gradient(135deg,#f8fbff,#f6f1ff 55%,#f4fbff);min-height:100vh}a{color:#5d7df4;text-decoration:none}small,.muted{color:var(--muted)}hr{border:0;border-top:1px solid var(--line);margin:22px 0}.app-shell{display:flex;min-height:100vh}.sidebar{width:278px;background:rgba(255,255,255,.78);backdrop-filter:blur(18px);border-right:1px solid var(--line);padding:22px;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;gap:20px;z-index:20}.brand{display:flex;align-items:center;gap:12px;color:var(--text)}.brand.big{justify-content:center;margin-bottom:18px}.brand-mark{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--primary),var(--primary2));display:grid;place-items:center;color:white;font-weight:800;box-shadow:0 10px 25px rgba(124,156,255,.35)}.brand small{display:block;color:var(--muted);font-weight:500}.nav-menu{display:flex;flex-direction:column;gap:6px}.nav-menu a{padding:12px 14px;border-radius:15px;color:#52607d;font-weight:650}.nav-menu a:hover,.nav-menu a.active{background:#eef3ff;color:#4568e8}.nav-caption{font-size:12px;text-transform:uppercase;color:#9aa5bd;font-weight:800;margin:16px 10px 4px}.sidebar-footer{margin-top:auto;background:#f4f7ff;border:1px solid var(--line);padding:14px;border-radius:18px}.footer-links{display:flex;gap:12px;margin-top:8px}.main-content{flex:1;margin-left:278px;padding:28px;max-width:1600px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.topbar h1{margin:0;font-size:28px}.topbar p{margin:4px 0 0;color:var(--muted)}.hamburger{display:none;border:0;background:white;border-radius:14px;padding:11px 14px;box-shadow:var(--shadow)}.card,.auth-card,.student-card{background:rgba(255,255,255,.86);border:1px solid rgba(232,236,248,.9);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.auth-card{width:min(440px,92vw);margin:8vh auto}.install-card{margin-top:6vh}.public-page{padding:24px}.student-wrap{min-height:100vh;display:grid;place-items:center;padding:22px}.student-wrap.wide{display:block;max-width:980px;margin:auto}.student-card h2,.card h2{margin:0 0 10px}.grid{display:grid;gap:18px}.two-col{grid-template-columns:1fr 1fr}.detail-grid{grid-template-columns:1.6fr .8fr}.stats-grid{grid-template-columns:repeat(5,minmax(150px,1fr));margin-bottom:18px}.stats-grid.compact{grid-template-columns:repeat(6,minmax(120px,1fr))}.stat-card{background:rgba(255,255,255,.86);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow)}.stat-card span{font-size:26px}.stat-card small{display:block;margin-top:10px}.stat-card strong{font-size:32px;display:block;margin-top:2px}.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.card-head p{margin:0;color:var(--muted)}.align-start{align-items:start}.max-card{max-width:980px}.form-stack{display:grid;gap:14px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.span-2{grid-column:span 2}label{display:grid;gap:7px;font-weight:700;color:#39445e}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:15px;padding:13px 14px;background:#fbfcff;color:var(--text);font:inherit;outline:none}textarea{resize:vertical}input:focus,select:focus,textarea:focus{border-color:#9bb2ff;box-shadow:0 0 0 4px rgba(124,156,255,.15)}.btn{border:0;border-radius:15px;background:#eef3ff;color:#4866d8;padding:12px 16px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px}.btn:hover{filter:brightness(.98);transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#7c9cff,#8ed3ff);color:white}.btn-danger{background:#ffe8ec;color:#d34860}.btn-small{padding:8px 11px;border-radius:12px;font-size:12px}.full{width:100%}.actions,.actions-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.actions-right{justify-content:flex-end}.actions form{display:inline-flex}.alert{padding:14px 16px;border-radius:16px;margin:0 0 16px;border:1px solid var(--line);background:white}.alert-success{background:#ebfff4;color:#207b4d;border-color:#c9f4db}.alert-danger{background:#fff0f3;color:#b42b43;border-color:#ffd2da}.alert-warning{background:#fff9e8;color:#9a6b00;border-color:#ffedb8}.table-responsive{overflow:auto}table{width:100%;border-collapse:separate;border-spacing:0 8px}th{font-size:12px;color:#8791aa;text-transform:uppercase;text-align:left;padding:8px 12px}td{background:#fbfcff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:12px}td:first-child{border-left:1px solid var(--line);border-radius:14px 0 0 14px}td:last-child{border-right:1px solid var(--line);border-radius:0 14px 14px 0}.empty{text-align:center;color:var(--muted);padding:24px}.badge{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800}.badge-success{background:#e8fff3;color:#1c8b56}.badge-danger{background:#ffe9ee;color:#c83e56}.badge-warning{background:#fff6d9;color:#a66a00}.badge-soft{background:#eef3ff;color:#5368bd}.filter-bar{display:flex;gap:10px;margin:12px 0 18px}.filter-bar select{max-width:560px}.material-picker{background:#fbfcff;border:1px solid var(--line);border-radius:18px;padding:14px}.check-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:10px}.check-card{display:flex;grid-template-columns:auto 1fr;gap:10px;padding:12px;border:1px solid var(--line);background:white;border-radius:15px;font-weight:700}.check-card input{width:auto}.check-card small{display:block;font-weight:500}.qr-card{text-align:center}.qr-img{width:260px;max-width:100%;border-radius:20px;background:white;padding:10px;border:1px solid var(--line)}.quick-meta,.student-meta{display:flex;gap:10px;flex-wrap:wrap;margin:15px 0}.quick-meta span,.student-meta span{background:#f3f6ff;border:1px solid var(--line);padding:9px 12px;border-radius:999px}.flow-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.flow-line span{background:#f4f7ff;border:1px solid var(--line);padding:10px 12px;border-radius:999px;font-weight:700}.feedback-item,.mini-card,.material-card,.feedback-card{background:#fbfcff;border:1px solid var(--line);border-radius:18px;padding:14px;margin-bottom:12px}.feedback-item p,.mini-card p,.material-card p{margin:8px 0 0;color:#5f6c88}.material-list{display:grid;gap:12px}.material-card{display:flex;justify-content:space-between;align-items:center;gap:12px}.next-action{margin-top:22px}.text-content{background:#fbfcff;border:1px solid var(--line);border-radius:18px;padding:18px;margin:15px 0;line-height:1.7}.feedback-list{display:grid;gap:14px}.feedback-card header{display:flex;justify-content:space-between;gap:12px}.feedback-body{margin:10px 0}.progress{height:10px;background:#eef3ff;border-radius:999px;overflow:hidden;min-width:140px}.progress span{display:block;height:100%;background:linear-gradient(135deg,#7c9cff,#8ed3ff);border-radius:inherit}@media(max-width:1050px){.sidebar{transform:translateX(-105%);transition:.25s}.sidebar.open{transform:none}.main-content{margin-left:0}.hamburger{display:block}.two-col,.detail-grid{grid-template-columns:1fr}.stats-grid,.stats-grid.compact{grid-template-columns:repeat(2,1fr)}.topbar{align-items:flex-start}.topbar .btn-primary{display:none}}@media(max-width:720px){.main-content,.public-page{padding:16px}.card,.auth-card,.student-card{padding:18px;border-radius:18px}.form-grid{grid-template-columns:1fr}.span-2{grid-column:span 1}.check-grid{grid-template-columns:1fr}.stats-grid,.stats-grid.compact{grid-template-columns:1fr}.topbar h1{font-size:22px}.filter-bar{flex-direction:column}.actions-right{justify-content:stretch}.actions-right .btn{width:100%}.student-wrap{padding:12px}.material-card{align-items:flex-start;flex-direction:column}.material-card .btn{width:100%}td,th{white-space:nowrap}.flow-line b{display:none}.flow-line span{width:100%;text-align:center}}@media print{.sidebar,.topbar,.actions,.btn,.filter-bar{display:none!important}.main-content{margin:0;padding:0}.card{box-shadow:none;border:0}.app-shell{display:block}}
