:root{color-scheme:light;--bg: #f3f0e7;--bg-accent: #f8f5ef;--surface: #ffffff;--ink: #1b1b1b;--muted: #5f5f5f;--brand: #0f6b57;--brand-2: #f4b840;--danger: #b42318;--shadow: 0 16px 40px rgba(23, 23, 23, .12);--shadow-soft: 0 10px 24px rgba(23, 23, 23, .08);--radius: 16px;--field-height: 40px}*{box-sizing:border-box}body{margin:0;font-family:Work Sans,system-ui,sans-serif;background:radial-gradient(circle at top,#fbf8f2,#f4efe6 45%,#efe8da);color:var(--ink)}h1,h2,h3,.brand,.title{font-family:Space Grotesk,sans-serif;margin:0}a{text-decoration:none;color:inherit}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#0e2a24 0%,var(--brand) 60%,#109b7b 120%);color:#f8f5ef;padding:28px 22px;display:flex;flex-direction:column;gap:18px}.sidebar .brand{display:flex;align-items:center;gap:12px;font-size:1.4rem;letter-spacing:.02em;font-family:Work Sans,system-ui,sans-serif}.brand-logo{width:42px;height:42px;object-fit:contain;border-radius:12px;padding:4px;background:#fff;box-shadow:0 6px 18px #0000002e}.sidebar nav{display:grid;gap:10px}.sidebar nav a{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;background:#ffffff14;transition:transform .2s ease,background .2s ease}.sidebar nav a.active{background:#fff3;transform:translate(4px)}.table-row .btn-sm{margin-top:8px;padding:6px 10px;font-size:.8rem}.nav-label{flex:1}.nav-badge{min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#e74c3c;color:#fff;font-size:.75rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #e74c3c59}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.8rem;font-weight:600;background:#f6efe1;color:#3b2d12}.badge.success{background:#dff3ea;color:#0a5c3e}.badge.danger{background:#ffe8e6;color:#b42318}.chart-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:18px}.chart-card{background:#fff;border:1px solid #efe6d7;border-radius:16px;padding:16px;box-shadow:var(--shadow-soft);display:grid;gap:10px}.chart-title{font-weight:600;color:#3b2d12}.chart-value{font-size:1.6rem;font-weight:700}.bar-track{width:100%;height:10px;border-radius:999px;background:#f1e7d8;overflow:hidden;display:flex}.bar-fill{height:100%}.bar-fill.brand{background:var(--brand)}.bar-fill.success{background:#0a8f5b}.bar-fill.danger{background:#d6453d}.bar-legend{display:flex;gap:12px;font-size:.8rem;color:#5c4b2b}.legend.success:before,.legend.danger:before{content:"";width:10px;height:10px;border-radius:999px;display:inline-block;margin-right:6px}.legend.success:before{background:#0a8f5b}.legend.danger:before{background:#d6453d}.group-actions-panel{display:grid;gap:8px;width:100%;max-width:560px}.group-action-row{display:grid;grid-template-columns:92px minmax(180px,1fr) auto;align-items:center;gap:8px}.group-action-row label{font-size:.85rem;font-weight:600;color:#4d3d1f}.group-action-row select{width:100%}.group-action-delete{grid-template-columns:1fr}.group-action-delete button{justify-self:end}@media (max-width: 1200px){.group-action-row{grid-template-columns:80px minmax(160px,1fr) auto}}.logout{margin-top:auto}.main{padding:32px 40px 64px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}.title{font-size:1.3rem}.tag{background:var(--brand-2);color:#2f1b00;padding:6px 12px;border-radius:999px;font-weight:600}.content{display:grid;gap:24px}.section-head{display:flex;justify-content:space-between;align-items:center}.panel{background:var(--surface);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow);border:1px solid rgba(20,20,20,.04)}.inline-head{margin-bottom:14px}.form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:center}.form-grid>*{min-width:0}.users-create-grid{grid-template-columns:repeat(6,minmax(160px,1fr));align-items:end}.users-file-field{min-width:0}.users-file-field input[type=file]{width:100%;min-width:0}.users-submit-btn{width:100%}.users-filter-grid{margin-bottom:14px}.users-overview-head{margin-bottom:10px}.users-count{font-size:.9rem}.field{display:grid;gap:6px;font-size:.9rem;color:var(--muted)}input,select{padding:10px 12px;border-radius:12px;border:1px solid #e4dccd;font:inherit;background:#fff;width:100%;height:var(--field-height)}textarea{width:100%;min-height:120px;border-radius:12px;border:1px solid #e4dccd;padding:10px 12px;font:inherit;background:#fff;resize:vertical}.textarea{margin-top:12px}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:none;padding-right:12px}select::-ms-expand{display:none}input[type=number]{-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=file]{max-width:100%}button{border:none;cursor:pointer;padding:10px 16px;border-radius:999px;font-weight:600;white-space:nowrap;max-width:100%;height:var(--field-height)}button.primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-soft)}button.ghost{background:#f6efe1;color:#3b2d12}button.ghost.danger{color:var(--danger)}.notice{background:#f7f1e4;padding:10px 12px;border-radius:10px}.notice.error{background:#ffe8e6;color:var(--danger)}.notice.success{background:#e7f6f0;color:#0a5c3e}.table{display:grid;gap:10px;overflow-x:auto}.table-head,.table-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;align-items:center}.users-table .table-head,.users-table .table-row{min-width:1060px;grid-template-columns:64px minmax(190px,1.55fr) minmax(100px,.9fr) minmax(100px,.9fr) minmax(120px,.95fr) minmax(120px,1fr) minmax(140px,1.1fr) minmax(130px,1fr) 148px}.users-table .row-actions{justify-content:flex-start;gap:6px}.courses-table .table-head,.courses-table .table-row{min-width:720px;grid-template-columns:minmax(260px,1.8fr) minmax(180px,1fr) 180px}.courses-table .table-head{padding:0 10px}.courses-table .table-row{padding:10px 12px;min-height:64px}.courses-table .row-actions{justify-content:flex-start;gap:6px}.table-head{font-weight:600;color:var(--muted);font-size:.92rem}.table-row{padding:12px;border-radius:14px;background:var(--bg-accent);border:1px solid rgba(20,20,20,.04)}.users-table .table-head{padding:0 10px}.users-table .table-row{padding:10px 12px;min-height:74px}.users-table .table-row>span{line-height:1.3}.row-actions{display:flex;gap:8px;align-items:center;justify-content:flex-start;flex-wrap:wrap}.row-actions .btn-sm{height:32px;padding:6px 10px;font-size:.82rem}.row-actions .file{height:34px;padding:6px 12px;font-size:.85rem}.webcam-inline{display:grid;gap:8px;padding:10px;border-radius:12px;background:#fff;border:1px solid #efe6d7}.webcam-video{width:220px;max-width:100%;border-radius:10px;background:#000}.users-filter-grid input{max-width:560px}.brand-preview{margin-top:12px;display:flex;align-items:center;gap:12px}.brand-preview img{max-height:80px;max-width:240px;object-fit:contain;border-radius:14px;padding:6px;background:#fff;border:1px solid #efe6d7}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#120e0873;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000}.modal{background:#fff;border-radius:18px;width:min(92vw,900px);max-height:90vh;border:1px solid #efe6d7;box-shadow:0 18px 50px #17120a33;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid #f1e7d8}.modal-head h4{margin:0;font-size:18px}.modal-body{padding:16px 18px;overflow:auto}.preview-image{max-width:100%;max-height:70vh;border-radius:12px;border:1px solid #efe6d7;display:block;margin:0 auto}.preview-pdf{width:100%;height:70vh;border:0;border-radius:12px;background:#f5efe4}.option-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:center}.quiz-run{display:grid;gap:16px;margin-top:16px}.quiz-question{display:grid;gap:8px}.quiz-options{display:grid;gap:6px;text-align:left}.quiz-options .checkbox{display:grid;grid-template-columns:22px 1fr;align-items:center;gap:10px;justify-items:start}.quiz-options input[type=radio]{width:18px;height:18px}.quiz-builder{display:grid;gap:16px;margin-top:16px;margin-bottom:16px}.quiz-question-block{padding:14px;border-radius:14px;background:#fff;border:1px solid #efe6d7;display:grid;gap:12px}.content-stack{display:grid;gap:16px}.content-card{background:var(--bg-accent);padding:20px;border-radius:14px;display:grid;gap:10px}.content-title{font-weight:600}.content-image{max-width:100%;border-radius:10px}.content-frame{width:100%;height:560px;border:none;border-radius:10px;background:#fff}.content-media{width:100%;border-radius:10px;max-height:560px}.course-list{display:grid;gap:12px}.course-header{display:grid;grid-template-columns:88px minmax(160px,1.2fr) minmax(140px,1fr) 140px 120px;align-items:center;gap:12px;font-size:.85rem;color:#6b5a3a;padding:0 12px}.course-row{display:grid;grid-template-columns:88px minmax(160px,1.2fr) minmax(140px,1fr) 140px 120px;align-items:center;gap:12px;padding:12px;border-radius:12px;border:1px solid #efe6d7;background:#fffaf2}.course-thumb{width:80px;height:56px;border-radius:10px;overflow:hidden;background:#f1e7d8;border:1px solid #efe6d7;display:flex;align-items:center;justify-content:center;flex-shrink:0}.course-thumb-img{width:100%;height:100%;object-fit:cover}.course-thumb-frame{width:100%;height:100%;border:0}.course-thumb-placeholder{font-size:.75rem;color:#6b5a3a}.course-main{display:flex;align-items:center;gap:12px}.course-title{font-weight:600}.course-group{color:#6b5a3a;font-size:.95rem}.progress{position:relative;height:10px;background:#efe4cf;border-radius:999px;overflow:hidden;margin-bottom:12px}.progress-bar{height:100%;background:var(--brand);transition:width .3s ease}.progress-label{margin-top:8px;font-size:.9rem;color:var(--muted)}.content-text{white-space:pre-wrap;background:#fff;padding:12px;border-radius:10px;border:1px solid #e6dccb;max-height:560px;overflow:auto}.qr-video{width:100%;max-height:320px;border-radius:12px;background:#000;margin-top:12px}.avatar{width:36px;height:36px;border-radius:999px;object-fit:cover}.avatar.clickable{cursor:pointer;box-shadow:0 6px 14px #0000001f;transition:transform .2s ease}.avatar.clickable:hover{transform:scale(1.04)}.avatar.placeholder{background:#e6dccb}.avatar.qr{border-radius:8px;background:#fff;border:1px solid #efe6d7;padding:2px;cursor:pointer}.avatar-stack{display:flex;gap:8px;align-items:center}label.file input{display:none}.field{display:grid;gap:6px;font-size:.85rem;color:var(--muted)}.field input,.field select{font-size:1rem;color:var(--ink)}.hint{font-size:.8rem;color:var(--muted)}.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stat{background:var(--surface);border-radius:16px;padding:18px;box-shadow:var(--shadow)}.stat-label{color:var(--muted);font-size:.9rem}.stat-value{font-size:2rem;font-weight:700}.auth-shell{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top,#f8f5ef,#efe8da 60%,#f6f0e4)}.auth-card{background:var(--surface);border-radius:24px;padding:32px;width:min(420px,90vw);box-shadow:var(--shadow);display:grid;gap:18px}.auth-form,.bootstrap{display:grid;gap:12px}label{display:grid;gap:6px;font-size:.9rem}.divider{height:1px;background:#e5dbc6}.checkbox{display:flex;gap:8px;align-items:center}.checkbox.small input{width:16px;height:16px}.checkbox.small,.option-row .checkbox{font-size:.85rem;color:var(--muted);gap:6px}.option-row .checkbox input{width:14px;height:14px}@media (max-width: 720px){.option-row{grid-template-columns:1fr;align-items:stretch}}@media (max-width: 900px){.app-shell{grid-template-columns:1fr}.sidebar{flex-direction:row;align-items:center;gap:12px;overflow-x:auto}.sidebar nav{grid-auto-flow:column;grid-auto-columns:max-content;gap:8px}.sidebar nav a{font-size:.95rem}.main{padding:20px}.table-head,.table-row{grid-template-columns:repeat(2,1fr);gap:8px}.row-actions{width:100%}.group-actions-panel{max-width:100%}.group-action-row{grid-template-columns:1fr;justify-items:stretch}.group-action-delete button{justify-self:start}.users-create-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}button{width:auto}.course-header{display:none}.course-row{grid-template-columns:88px 1fr;justify-items:start}}@media (max-width: 720px){.main,.panel{padding:18px}.form-grid,.users-create-grid{grid-template-columns:1fr}.content-frame,.content-media,.content-text{max-height:420px}}@media (max-width: 560px){.sidebar{position:sticky;top:0;z-index:20;padding:14px 12px}.sidebar .brand span{display:none}.sidebar nav a{padding:8px 10px;border-radius:10px;font-size:.85rem}}
