: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-top,.sidebar-left-cluster{display:contents}.sidebar .brand{display:grid;justify-items:start;gap:12px;width:100%;font-size:1.4rem;letter-spacing:.02em;font-family:Work Sans,system-ui,sans-serif}.sidebar .brand span{display:block;width:100%;line-height:1.15}.brand-logo{width:100%;max-width:96px;height:auto;object-fit:contain;border-radius:12px;padding:4px;background:#fff;box-shadow:0 6px 18px #0000002e}.sidebar nav{display:grid;gap:10px}.mobile-nav-toggle,.mobile-sidebar-controls,.mobile-icon-btn{display:none}.desktop-sidebar-action{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:56px;padding:10px 18px;text-align:center;font-size:1rem;font-weight:600}.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}.topbar-user-language{display:inline-flex;align-items:center;gap:18px}.topbar-user-name{font-size:1rem;font-weight:600;color:var(--muted)}.language-menu{position:relative}.language-icon-btn{width:38px;height:38px;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem}.language-menu-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:136px;display:grid;gap:4px;padding:8px;border-radius:14px;background:#fffdf8;border:1px solid #e7dcc6;box-shadow:0 18px 34px #2017091f;z-index:20}.language-option{width:100%;text-align:left;padding:10px 12px;border:0;border-radius:10px;background:transparent;color:var(--ink);font:inherit;cursor:pointer}.language-option:hover,.language-option.active{background:#f5ecdb}.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)}.mobile-cards{overflow-x:visible}.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:82vh;min-height:760px;border:0;border-radius:12px;background:#f5efe4;display:block}.pdf-frame-shell{width:100%;border-radius:12px;overflow:hidden;background:#fff;border:1px solid #efe6d7}.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:82vh;min-height:760px;border:none;border-radius:10px;background:#fff;display:block}.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}.message-layout{display:grid;grid-template-columns:1fr;gap:14px}.message-list{display:grid;gap:8px;align-content:start}.message-list-item{width:100%;text-align:left;display:block;padding:14px 16px;border-radius:14px;border:1px solid #efe6d7;background:#fff;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.message-list-item:hover{transform:translateY(-1px);box-shadow:0 10px 18px #20170914}.message-list-item.active{border-color:#1a786159;box-shadow:0 10px 18px #1a78611a;background:#fffaf2}.message-list-head{display:flex;justify-content:space-between;gap:12px;align-items:center;width:100%}.message-list-title{display:block;font-weight:700;color:var(--ink);min-width:0;font-size:1rem}.message-list-inline-group{font-size:.82rem;font-weight:600;color:var(--muted)}.message-list-date{display:block;flex-shrink:0;font-size:.9rem;color:var(--muted);white-space:nowrap;text-align:right}.message-list-meta{display:flex;gap:14px;flex-wrap:wrap;font-size:.92rem;color:var(--muted);padding-top:2px}.message-detail{display:grid;gap:18px;padding:24px;border-radius:20px;background:#fffdf8;border:1px solid #efe6d7;align-content:start}.message-detail-panel{margin-top:24px;padding-top:18px;border-top:1px solid #f1e8da}.message-detail-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}.message-detail-head h4{margin:0 0 10px;font-size:1.5rem}.message-detail-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.98rem}.message-body{padding:18px 20px;border-radius:16px;border:1px solid #efe6d7;background:#fff;color:#2c2417;line-height:1.7;white-space:pre-wrap;word-break:break-word}.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;grid-auto-rows:min-content;align-content:start}.sidebar{position:sticky;top:0;z-index:20;padding:18px 18px 16px;gap:14px}.sidebar-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-left-cluster{display:flex;align-items:center;gap:4px;min-width:0;flex:1 1 auto}.sidebar-left-cluster .brand{order:1}.sidebar-left-cluster .mobile-menu-btn{order:2}.mobile-nav-toggle{display:none}.mobile-sidebar-controls{display:flex;align-items:center;gap:14px;order:3;flex-shrink:0;margin-left:auto}.mobile-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border-radius:10px;font-size:1rem;line-height:1}.mobile-menu-btn{flex-shrink:0}.sidebar .brand{flex:0 1 auto;min-width:0}.sidebar nav{display:none;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;position:absolute;top:calc(100% + 8px);left:12px;right:12px;padding:10px;border-radius:14px;background:#0e2a24f5;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 34px #0000003d}.sidebar nav.nav-open{display:grid}.sidebar nav a{min-width:0;font-size:.95rem}.main{padding:20px}.topbar,.section-head{gap:12px;align-items:flex-start;flex-wrap:wrap}.logout,.desktop-sidebar-action{display:none}.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 minmax(0,1fr);justify-items:start;align-items:start}.course-row>:nth-child(1){grid-row:1 / span 3}.course-row>:nth-child(2),.course-row>:nth-child(3),.course-row>:nth-child(4){grid-column:2}.course-row>:nth-child(5){grid-column:1 / -1;width:100%}}@media (max-width: 720px){.main,.panel{padding:18px}.sidebar{padding:8px 12px;gap:10px;border-bottom:1px solid rgba(255,255,255,.12)}.sidebar .brand{justify-content:flex-start;gap:8px;font-size:.96rem;min-width:0}.sidebar-top{gap:8px}.form-grid,.users-create-grid{grid-template-columns:1fr}.content-frame,.content-media,.content-text{max-height:420px}.message-list-item,.message-detail{padding:16px}.message-list-head{flex-direction:column;align-items:flex-start;gap:6px}.message-list-item{min-height:84px}.message-detail-head{flex-direction:column;align-items:stretch}.message-detail-head .row-actions{width:100%}.message-list-title{font-size:.98rem}.message-body{padding:16px}.message-list-date{font-size:.82rem;text-align:left;white-space:normal;margin-top:2px}.table.mobile-cards{gap:12px}.mobile-cards .table-head{display:none}.mobile-cards .table-row{grid-template-columns:1fr;gap:10px;padding:14px;border-radius:16px}.mobile-cards .table-row>span{display:grid;gap:6px;min-width:0}.mobile-cards .table-row>span:before{content:attr(data-label);font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:.02em;text-transform:uppercase}.mobile-cards .table-row>span.row-actions:before{margin-bottom:2px}.mobile-cards .table-row>span:empty:after{content:"-";color:var(--muted)}.users-table .table-row,.courses-table .table-row{min-width:0}.users-table .table-row>span:first-child,.mobile-cards .table-row>span[data-label=Foto],.mobile-cards .table-row>span[data-label=QR]{justify-items:start}.group-actions-panel{gap:12px}.group-action-row{padding:12px;border-radius:12px;background:#fff;border:1px solid #efe6d7}.group-action-delete{background:transparent;border:0;padding:0}.course-row{grid-template-columns:1fr;gap:10px}.course-row>:nth-child(1){grid-row:auto}.course-row>:nth-child(2),.course-row>:nth-child(3),.course-row>:nth-child(4),.course-row>:nth-child(5){grid-column:auto}.course-thumb{width:100%;height:150px}.course-thumb-placeholder{font-size:.9rem}.modal{width:100%;max-height:100vh;border-radius:16px}.modal-backdrop{padding:12px}}@media (max-width: 560px){.sidebar{padding:8px 10px;gap:8px}.sidebar-left-cluster{gap:2px}.sidebar .brand{gap:10px}.sidebar .brand span{font-size:.88rem;line-height:1.1}.brand-logo{width:28px;height:28px;border-radius:10px}.mobile-icon-btn{width:30px;height:30px;border-radius:9px;font-size:.92rem}.sidebar nav{grid-template-columns:1fr;left:10px;right:10px}.sidebar nav a{padding:10px;border-radius:10px;font-size:.9rem}.nav-label{min-width:0}.topbar .title{font-size:1rem;line-height:1.1}.tag{padding:4px 9px;font-size:.82rem}.language-icon-btn{width:34px;height:34px;font-size:1rem}.main{padding:14px}.panel{padding:16px;border-radius:14px}.row-actions .btn-sm,.row-actions .file{width:100%;justify-content:center}.content-frame,.preview-pdf{height:88vh;min-height:1100px}.topbar{margin-bottom:14px;align-items:center}.topbar-user-language{gap:12px}.topbar-user-name{font-size:.9rem}.title{font-size:1rem}.section-head h2{font-size:1.05rem}.section-head h3{font-size:.98rem}}
