:root{font-family:Space Grotesk,Segoe UI,sans-serif;color:#132238;background:radial-gradient(circle at top left,rgba(240,196,25,.18),transparent 32%),radial-gradient(circle at top right,rgba(31,74,102,.16),transparent 30%),linear-gradient(180deg,#f6f8fb,#edf3f7);--ink: #132238;--navy: #17324d;--navy-2: #254a68;--paper: #ffffff;--line: #d8e2ec;--muted: #60758a;--success: #208154;--warning: #d3a016;--danger: #c44032;--orange: #cb6a12;--gray: #708090;--success-bg: #e7f4ee;--success-text: #155b3d;--warning-bg: #fff4cc;--warning-text: #6f4d06;--danger-bg: #fdebe8;--danger-text: #8f2d24;--orange-bg: #fff0df;--orange-text: #8a4308;--gray-bg: #edf2f6;--gray-text: #475569;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--text-xs: .75rem;--text-xs-line: 1rem;--text-sm: .875rem;--text-sm-line: 1.25rem;--text-base: 1rem;--text-base-line: 1.5rem;--text-lg: 1.125rem;--text-lg-line: 1.75rem;--text-xl: 1.375rem;--text-xl-line: 1.9rem;--text-2xl: 1.75rem;--text-2xl-line: 2.2rem;--shadow-card: 0 4px 16px rgba(17, 34, 52, .06);--shadow-overlay: 0 28px 70px rgba(15, 23, 42, .24)}*{box-sizing:border-box}body{margin:0;min-height:100vh}body,button,input,select,textarea{font:inherit}h1,h2,h3,h4,p{margin:0}h2{font-size:var(--text-2xl);line-height:var(--text-2xl-line)}h3{font-size:var(--text-xl);line-height:var(--text-xl-line)}button,.button-link{border:0;border-radius:14px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff;cursor:pointer;padding:11px 16px;text-decoration:none;text-align:center;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}button:hover,.button-link:hover{transform:translateY(-1px);box-shadow:var(--shadow-card)}button:disabled,.button-link:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.ghost-button{background:#eef3f7;color:var(--navy)}.button,.button-link{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.button--secondary,.button-link.button--secondary{background:#fff;color:var(--navy);border:1px solid var(--line)}.button--ghost,.button-link.button--ghost{background:transparent;color:var(--navy);border:1px solid rgba(16,42,67,.16)}.button--danger,.button-link.button--danger{background:var(--danger-bg);color:var(--danger-text);border:1px solid rgba(196,64,50,.28)}.button--sm,.button-link.button--sm{padding:8px 12px;border-radius:10px;font-size:var(--text-sm);line-height:var(--text-sm-line)}.btn-like{border:0;border-radius:10px;background:#1f2937;color:#e5e7eb;padding:9px 14px;cursor:pointer}.btn-like:hover{background:#111827;box-shadow:none;transform:none}input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:14px;background:#fff;color:inherit}textarea{resize:vertical}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.nav-link:focus-visible{outline:3px solid rgba(36,100,158,.25);outline-offset:2px}label,.eyebrow,.muted-text{color:var(--muted)}.eyebrow{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sandbox-banner{background:linear-gradient(90deg,#854d0e,#92400e,#854d0e);background-size:200% 100%;animation:banner-slide 4s linear infinite;color:#fef3c7;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:8px 16px;display:flex;align-items:center;justify-content:center;gap:var(--space-3);position:sticky;top:0;z-index:100}.sandbox-banner .dot{width:7px;height:7px;background:#fbbf24;border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite;flex-shrink:0}.sidebar{background:radial-gradient(circle at top,rgba(240,196,25,.22),transparent 25%),linear-gradient(180deg,#10243b,#17324d 60%,#1f4564);color:#fff;padding:28px 22px;display:grid;align-content:start;gap:var(--space-6)}.brand-block p{margin-top:8px;color:#d8e9f5}.sidebar nav{display:grid;gap:var(--space-3)}.nav-separator{height:1px;margin:4px 0;background:#ffffff2e}.sidebar-logout{margin-top:auto}.nav-link{color:#ebf3f8;text-decoration:none;display:flex;gap:var(--space-3);align-items:center;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a}.nav-link:hover{background:#ffffff14}.nav-link--active{background:#f0c41929;border-color:#f0c41980;color:#fff8d8}.nav-badge{margin-left:auto;border-radius:999px;padding:2px 7px;background:#f0c4192e;color:#fff8d8;font-size:10px;font-weight:700;text-transform:uppercase}.sidebar-user{margin-top:auto;display:grid;gap:var(--space-1);padding:var(--space-3);border:1px solid rgba(255,255,255,.14);border-radius:12px;background:#ffffff0f}.sidebar-user span{color:#d8e9f5;font-size:var(--text-sm);line-height:var(--text-sm-line);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tooltip-wrap{position:relative}.tooltip-bubble{position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:#10243b;color:#fff;padding:6px 9px;border-radius:10px;font-size:12px;white-space:nowrap;z-index:30}.content{padding:var(--space-7);display:grid;gap:var(--space-5)}.page-grid{display:grid;gap:var(--space-5)}.section-head{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.section-title-row{display:flex;align-items:center;gap:var(--space-3)}.section-head p{margin-top:6px;color:var(--muted)}.card{background:#fffffff0;border:1px solid var(--line);border-radius:22px;padding:var(--space-5);display:grid;gap:var(--space-3);box-shadow:var(--shadow-card)}.dashboard-kpis,.quick-action-grid,.placeholder-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.metric-card--link{color:inherit;text-decoration:none;transition:transform .15s ease,border-color .15s ease}.metric-card--link:hover{border-color:#20815447;transform:translateY(-1px)}.attention-list,.session-card-list,.session-groups{display:grid;gap:var(--space-3)}.attention-item,.session-card,.checklist-step{display:grid;gap:var(--space-2);color:inherit;text-align:left;text-decoration:none;border:1px solid var(--line);border-radius:12px;background:#fff;padding:var(--space-3)}.session-card{grid-template-columns:auto minmax(0,1fr);align-items:center;width:100%}.session-card:hover,.session-card--active{border-color:#20815459;background:var(--success-bg);box-shadow:none}.session-card--compact{grid-template-columns:auto minmax(0,1fr) auto}.session-card p,.attention-item span{color:var(--muted)}.session-status-banner{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--line);border-radius:12px;background:#fff}.live-dot{width:10px;height:10px;border-radius:999px;background:var(--success);box-shadow:0 0 0 6px #2081541f}.checklist-step{grid-template-columns:auto 1fr;align-items:center}.checklist-step--done{background:var(--success-bg);border-color:#20815433}.two-col{display:grid;grid-template-columns:1.15fr 1fr;gap:var(--space-5)}.tab-row,.chip-row,.inline-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.quickstart-card{background:radial-gradient(circle at top right,rgba(74,222,128,.12),transparent 24%),linear-gradient(180deg,#10243b,#17324d);color:#eef6fb;border-color:#60a5fa40}.quickstart-card .eyebrow{color:#93c5fd}.steps{display:grid;gap:var(--space-3)}.step{display:flex;gap:var(--space-3);align-items:flex-start}.step-num{background:#1e3a5fe6;color:#93c5fd;border-radius:999px;width:24px;height:24px;display:inline-grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0}.step-text{color:#d4e2ee;line-height:1.5;font-size:13px}.csv-strip{display:flex;gap:var(--space-3);flex-wrap:wrap}.csv-btn{display:inline-flex;align-items:center;gap:8px;border-radius:12px;padding:9px 14px;background:#10243b59;border:1px solid rgba(74,222,128,.45);color:#8af0b2}.csv-btn:hover{background:#14532de6}.csv-btn--muted{border-color:#93c5fd59;color:#c6def5}.csv-icon{font-size:15px}.demo-shell{min-height:100vh;background:#0f0f0f;color:#eee}.demo-main{max-width:960px;margin:0 auto;padding:28px 20px 48px}.demo-header{margin-bottom:24px}.demo-header h1{font-size:26px;font-weight:700;color:#4ade80;letter-spacing:-.5px}.demo-header p{color:#94a3b8;font-size:13px;margin-top:4px}.demo-card{background:#111827;border:1px solid #1f2937;border-radius:14px;padding:16px}.demo-drop{margin-bottom:8px;background:#111827;border-color:#4ade80}.demo-drop .drop-zone__title{color:#d1fae5}.demo-drop .drop-zone__hint{color:#94a3b8}.demo-msg{min-height:22px;font-size:13px;margin:6px 0 14px}.demo-msg--success{color:#4ade80}.demo-msg--error{color:#ef4444}.demo-msg--warning{color:#facc15}.demo-two-col{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.demo-feed-wrap{position:relative;width:100%}.demo-feed{width:100%;border-radius:14px;border:2px solid #333;display:block;aspect-ratio:4 / 3;object-fit:contain;background:#111}.demo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.demo-box{position:absolute;border:2px solid #f97316;outline:1px solid rgba(0,0,0,.2);outline-offset:-3px}.demo-box--known{border-color:#4ade80}.demo-box__label{position:absolute;left:-2px;top:-30px;background:#f97316;color:#fff;font-size:12px;font-weight:700;padding:5px 8px;border-radius:8px;white-space:nowrap}.demo-box--known .demo-box__label{background:#15803d}.demo-feed-placeholder{width:100%;aspect-ratio:4 / 3;border-radius:14px;border:2px solid #333;background:#111;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:#475569;font-size:13px}.demo-feed-emoji{font-size:32px}.demo-toolbar{display:flex;gap:var(--space-3);flex-wrap:wrap;margin-top:12px;align-items:center}.cam-state{font-size:12px;color:#93c5fd;align-self:center}.cam-state.off{color:#fca5a5}.people-list{display:grid;gap:6px}.person-row{display:flex;align-items:center;justify-content:space-between;background:#1a2e1a;border:1px solid #166534;border-radius:8px;padding:6px 10px}.person-name{font-size:13px;color:#d1fae5}.person-del{background:none;border:none;color:#ef4444;cursor:pointer;font-size:14px;padding:2px 4px;line-height:1}.person-del:hover{box-shadow:none;transform:none;color:#f87171}.empty-roster{color:#475569;font-size:13px;text-align:center;padding:20px 0}.drop-zone{border:2px dashed rgba(32,129,84,.45);border-radius:18px;padding:18px;display:grid;gap:6px;text-align:center;cursor:pointer;background:#2081540a;transition:border-color .15s ease,background .15s ease,transform .15s ease}.drop-zone:hover,.drop-zone--active{background:#2081541a;border-color:var(--success);transform:translateY(-1px)}.drop-zone input{display:none}.drop-zone__title{font-weight:700;color:var(--navy)}.drop-zone__hint{color:var(--muted);font-size:13px}.photo-naming-guide{display:grid;gap:var(--space-3);padding:14px;border-radius:16px;background:#f6fbf7;border:1px solid rgba(32,129,84,.14)}.photo-naming-guide h4{margin:0;color:var(--navy);font-size:.96rem}.photo-naming-guide p{margin:0;color:var(--muted);line-height:1.5}.naming-examples{display:grid;gap:8px}.naming-example{display:grid;grid-template-columns:auto 1fr;gap:var(--space-3);align-items:start;padding:10px 12px;border-radius:12px}.naming-example--good{background:#20815414}.naming-example--bad{background:#c4403214}.naming-icon{font-weight:700}.naming-example code{display:inline-block;margin-bottom:4px}.naming-example small{display:block;color:var(--muted)}.tab-button,.choice-chip{background:#edf2f7;color:var(--navy)}.tab-button--active,.choice-chip--active{background:linear-gradient(135deg,#d49d17,#f0c419);color:#132238}.thumb-grid,.person-grid,.camera-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.thumb,.person-photo{width:100%;height:128px;object-fit:cover;border-radius:16px;background:#ecf2f8}.placeholder{display:block}.person-card,.list-row{display:grid;gap:var(--space-3);align-items:center;border:1px solid var(--line);border-radius:18px;padding:12px;background:#fff}.list-board{display:grid;gap:var(--space-3)}.list-row{grid-template-columns:minmax(0,1.5fr) auto auto auto}.search-input{max-width:280px}.board-controls{display:grid;grid-template-columns:minmax(180px,280px) minmax(140px,180px);gap:var(--space-3);align-items:end}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line)}.data-table tbody tr:nth-child(2n){background:#edf3f773}.data-table tbody tr:hover{background:#2081540f}.data-table thead th{position:sticky;top:0;z-index:1;background:#fff}.table-cell--right{text-align:right!important}.table-sort-button{width:100%;justify-content:flex-start;padding:0;border-radius:0;background:transparent;color:inherit;box-shadow:none}.table-sort-button:hover{box-shadow:none;transform:none}.inline-form{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--line)}.badge{background:var(--gray-bg);color:var(--gray-text);border:1px solid rgba(112,128,144,.16);border-radius:999px;font-size:12px;font-weight:700;padding:5px 10px;width:fit-content}.badge--on_time,.badge.online{background:var(--success-bg);color:var(--success-text);border-color:#20815433}.badge--late{background:var(--warning-bg);color:var(--warning-text);border-color:#d3a0163d}.badge--left_early,.badge--late_left_early{background:var(--orange-bg);color:var(--orange-text);border-color:#cb6a123d}.badge--absent,.badge.offline{background:var(--danger-bg);color:var(--danger-text);border-color:#c440323d}.badge--excused,.badge--unknown{background:var(--gray-bg);color:var(--gray-text)}.stat-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:var(--space-3)}.stat-chip{border-radius:18px;padding:var(--space-4);color:var(--ink);border:1px solid var(--line);display:grid;gap:var(--space-1)}button.stat-chip{text-align:left}.stat-chip--active{outline:3px solid rgba(32,129,84,.22);outline-offset:2px}.stat-chip--green{background:var(--success-bg);border-color:#20815433}.stat-chip--yellow{background:var(--warning-bg);border-color:#d3a0163d}.stat-chip--orange{background:var(--orange-bg);border-color:#cb6a123d}.stat-chip--red{background:var(--danger-bg);border-color:#c440323d}.stat-chip--gray{background:var(--gray-bg);border-color:#70809029}.stat-chip--green .stat-chip-count{color:var(--success-text)}.stat-chip--yellow .stat-chip-count{color:var(--warning-text)}.stat-chip--orange .stat-chip-count{color:var(--orange-text)}.stat-chip--red .stat-chip-count{color:var(--danger-text)}.stat-chip--gray .stat-chip-count{color:var(--gray-text)}.stat-chip-count{font-size:28px;font-weight:700}.stat-chip-label{font-size:13px;letter-spacing:.03em}.stat-chip--alert{animation:pulse 1.4s ease-in-out infinite}.quality-meter{display:grid;gap:8px}.quality-meter-head{display:flex;justify-content:space-between;font-size:13px;color:var(--muted)}.quality-meter-track{height:10px;border-radius:999px;background:#ebf1f6;overflow:hidden}.quality-meter-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#d3a016,#1d7d54)}.empty-state{border:1px dashed var(--line);border-radius:16px;padding:20px;color:var(--muted);text-align:center}.empty-state--designed{display:grid;place-items:center;gap:var(--space-3)}.empty-state--designed h3{font-size:var(--text-lg);line-height:var(--text-lg-line)}.empty-state--designed p{margin-top:var(--space-1)}.empty-state__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:999px;background:var(--gray-bg);color:var(--navy)}.skeleton{border-radius:14px;background:linear-gradient(90deg,#eef3f7 25%,#f7fafc,#eef3f7 75%);background-size:200% 100%;animation:shimmer 1.4s infinite linear}.skeleton-input{height:44px}.skeleton-row{height:58px}.skeleton-panel{min-height:280px}.modal-backdrop,.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;padding:20px;z-index:50}.segmented-control{display:inline-flex;flex-wrap:wrap;gap:var(--space-1);padding:var(--space-1);border:1px solid var(--line);border-radius:14px;background:#eef4f8;width:fit-content}.segmented-control__tab{background:transparent;color:var(--navy);border-radius:10px;padding:var(--space-2) var(--space-3)}.segmented-control__tab--active{background:#fff;box-shadow:var(--shadow-card)}.breadcrumbs{display:flex;flex-wrap:wrap;gap:var(--space-2);color:var(--muted);font-size:var(--text-sm);line-height:var(--text-sm-line)}.breadcrumbs__item{display:inline-flex;gap:var(--space-2)}.breadcrumbs a{color:var(--navy);text-decoration:none}.drawer-backdrop{place-items:stretch end;overflow-y:auto}.modal-card,.drawer-card{background:#fff;border-radius:24px;width:min(520px,100%);padding:var(--space-5);display:grid;gap:var(--space-4);box-shadow:var(--shadow-overlay);min-height:0}.drawer-card{align-self:center;height:min(100%,calc(100vh - 32px));max-height:calc(100vh - 32px);max-width:460px;border-radius:24px 0 0 24px;grid-template-rows:auto minmax(0,1fr)}.modal-head{display:flex;justify-content:space-between;gap:var(--space-3);align-items:start}.modal-form,.drawer-form,.auth-form{display:grid;gap:var(--space-3)}.drawer-form{min-height:0;overflow-y:auto;padding-right:6px;scrollbar-gutter:stable}.drawer-form>button[type=submit]{position:sticky;bottom:0;box-shadow:var(--shadow-card)}.alert-list{margin:0;padding-left:18px;display:grid;gap:8px}.field-group{display:grid;gap:var(--space-2)}.field-group label{font-weight:700}.confirm-dialog{max-width:440px}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.toast-stack{position:fixed;right:var(--space-5);bottom:var(--space-5);z-index:120;display:grid;gap:var(--space-3);width:min(380px,calc(100vw - 40px))}.toast{position:relative;display:grid;gap:var(--space-1);padding:var(--space-3) 44px var(--space-3) var(--space-4);border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);box-shadow:var(--shadow-overlay)}.toast strong{font-size:var(--text-sm);line-height:var(--text-sm-line)}.toast span{color:var(--muted);font-size:var(--text-sm);line-height:var(--text-sm-line)}.toast--success{border-color:#2081543d;background:var(--success-bg)}.toast--error{border-color:#c440323d;background:var(--danger-bg)}.toast--info{background:var(--gray-bg)}.toast__close{position:absolute;right:var(--space-2);top:var(--space-2);width:32px;height:32px;padding:0;border-radius:999px;background:transparent;color:var(--muted)}.success-panel{display:grid;gap:var(--space-2);padding:var(--space-3);border:1px solid rgba(32,129,84,.24);border-radius:12px;background:var(--success-bg)}.success-panel code{display:block;padding:var(--space-2);border-radius:8px;background:#ffffffb8}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:28px}.auth-panel{width:min(1080px,100%);display:grid;grid-template-columns:1.1fr .9fr;gap:var(--space-6);align-items:stretch}.auth-copy{padding:32px;border-radius:28px;color:#fff;background:radial-gradient(circle at top right,rgba(240,196,25,.26),transparent 24%),linear-gradient(135deg,#11253c,#17324d 55%,#275273);display:grid;gap:14px}.auth-copy h1{font-size:clamp(32px,4vw,54px);line-height:.95}.auth-copy p:last-child{color:#d9e7f3}.auth-card{align-content:start}.auth-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.error{color:var(--danger)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes banner-slide{0%{background-position:0% 0}to{background-position:200% 0}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@media (max-width: 980px){.app-shell{grid-template-columns:1fr}.sidebar{gap:14px}.two-col,.demo-two-col,.auth-panel,.stat-strip{grid-template-columns:1fr}.list-row,.section-head,.row{grid-template-columns:1fr;display:grid}.tooltip-bubble{display:none}}.auth-card--enhanced{gap:var(--space-5)}.auth-tabs{background:#eef4f8;border-radius:18px;padding:6px}.auth-form--rich>div{display:grid;gap:8px}.auth-form--rich label{font-size:.92rem;font-weight:700;color:var(--ink)}.field-hint{margin:0;color:var(--muted);font-size:.88rem}.field-hint--error{color:var(--danger)}.auth-error{margin:0;padding:12px 14px;border-radius:14px;background:#c6282814;color:var(--danger);border:1px solid rgba(198,40,40,.18)}.password-field{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;padding-right:6px;border:1px solid rgba(16,42,67,.12);border-radius:16px;background:#fff}.password-field input{border:0;background:transparent}.password-field input:focus{box-shadow:none}.icon-button{border:0;background:transparent;color:var(--muted);display:inline-grid;place-items:center;width:36px;height:36px;border-radius:999px}.icon-button:hover{background:#102a4314}.password-strength{display:grid;grid-template-columns:1fr auto;gap:var(--space-3);align-items:center;color:var(--muted);font-size:.88rem}.password-strength__bar{--segments: 4;--width: calc((100% / var(--segments)) * var(--strength));height:8px;border-radius:999px;background:linear-gradient(90deg,var(--strength-color) var(--width),rgba(16,42,67,.08) var(--width))}.password-strength__bar--muted{--strength-color: #a0aec0}.password-strength__bar--danger{--strength-color: #d64545}.password-strength__bar--warning{--strength-color: #f0a202}.password-strength__bar--info{--strength-color: #2f7ed8}.password-strength__bar--success{--strength-color: #1f9d55}.dev-hint{justify-self:start;border:1px dashed rgba(255,255,255,.4);background:#ffffff14;color:#fff;border-radius:999px;padding:10px 14px}.spinner{animation:spin 1s linear infinite}.inline-actions{display:inline-flex;gap:var(--space-2);margin-left:0}.ghost-button{background:transparent;color:var(--ink);border:1px solid rgba(16,42,67,.16)}.badge.warning{background:#f0a20224;color:#8b5e00}.inaccessible-card{max-width:560px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 640px){.password-strength{grid-template-columns:1fr}.inline-actions{display:flex;margin:10px 0 0}}.success{color:var(--success)}.batch-list{display:grid;gap:var(--space-3)}.batch-row{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(180px,.7fr) auto;gap:var(--space-4);align-items:center;background:#fffffff5;border:1px solid var(--line);border-radius:8px;padding:14px;box-shadow:var(--shadow-card)}.batch-row h3{margin-top:4px}.batch-progress{display:grid;gap:7px}.progress-bar{position:relative;height:10px;overflow:hidden;border-radius:999px;background:#dce6ee}.progress-bar span{display:block;height:100%;background:var(--success)}.progress-bar i{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--navy)}.progress-bar--warn span{background:var(--warning)}.progress-bar--danger span{background:var(--danger)}.progress-bar--mini{width:120px;height:8px}.mini-progress{display:grid;gap:var(--space-1)}.status-pill{width:fit-content;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700;background:#e7eef5;color:var(--navy)}.status-pill--active{background:#2081541f;color:var(--success)}.status-pill--live{background:var(--success-bg);color:var(--success-text)}.status-pill--upcoming,.status-pill--not_started{background:var(--warning-bg);color:var(--warning-text)}.status-pill--ended,.status-pill--completed{background:#70809024;color:var(--gray)}.status-pill--review_pending{background:var(--danger-bg);color:var(--danger-text)}.gov-form label,.enroll-card label{display:grid;gap:7px}.gov-summary-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(4,minmax(0,1fr))}.metric-card{display:grid;gap:6px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:14px;box-shadow:var(--shadow-card)}.metric-card span,.metric-card small{color:var(--muted)}.metric-card strong{font-size:28px}.table-scroll,.heatmap-wrap{overflow-x:auto}.heatmap-grid{display:grid;gap:6px;min-width:680px;align-items:center}.heatmap-name{position:sticky;left:0;z-index:1;background:#fff;padding:var(--space-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.heatmap-name--head{z-index:2}.heatmap-cell{display:grid;place-items:center;min-height:32px;border-radius:8px;font-weight:700;background:#e9eff5;color:var(--gray)}.heatmap-cell--present{background:#20815429;color:var(--success)}.heatmap-cell--late{background:#d3a0162e;color:#8a6408}.heatmap-cell--excused{background:#254a6824;color:var(--navy-2)}.heatmap-cell--absent{background:#c440321f;color:var(--danger)}.heatmap-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);color:var(--muted);font-size:var(--text-sm)}.heatmap-legend span{display:inline-flex;align-items:center;gap:var(--space-1)}.heatmap-legend .heatmap-cell{width:24px;min-height:24px;font-style:normal}.heatmap-pct{padding:var(--space-1);border-radius:8px}.heatmap-pct--risk{background:var(--danger-bg);color:var(--danger-text);font-weight:700}.checkbox-row{display:flex!important;align-items:center;gap:var(--space-3)}.checkbox-row input{width:auto}.warning-panel{display:grid;gap:8px;padding:12px;border-radius:8px;border:1px solid rgba(211,160,22,.38);background:#d3a0161a}.photo-capture-panel{display:grid;gap:var(--space-3)}.camera-preview{display:grid;place-items:center;min-height:220px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#edf3f8}.live-feed-frame{position:relative;overflow:hidden;border-radius:12px;background:#edf3f8}.live-feed{display:block;width:100%;min-height:220px;aspect-ratio:16 / 10;object-fit:cover}.direction-line-preview{position:absolute;top:0;bottom:0;width:3px;background:var(--warning);box-shadow:0 0 0 2px #fff4cccc}.camera-preview video,.camera-preview img{width:100%;max-height:280px;object-fit:cover}.camera-video-hidden{display:none}.camera-empty{color:var(--muted);font-weight:700}.upload-button{width:fit-content;display:inline-flex!important;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--navy);cursor:pointer;font-weight:700}.upload-button input,.hidden-canvas{display:none}.receipt-card{max-width:520px}.receipt-photo{width:120px;height:120px;border-radius:8px;object-fit:cover}.attendance-review{display:grid;gap:16px;padding-bottom:82px}.review-header,.review-summary{display:flex;justify-content:space-between;gap:14px;align-items:center}.review-summary{justify-content:flex-start;flex-wrap:wrap;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff}.review-panels{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}.review-panel{display:grid;gap:var(--space-3);background:#fffffff0;border:1px solid var(--line);border-radius:8px;padding:14px;box-shadow:var(--shadow-card)}.trainee-list{display:grid;gap:var(--space-3)}.trainee-card{display:grid;grid-template-columns:56px minmax(0,1fr) auto;gap:var(--space-3);align-items:center;border:1px solid var(--line);border-radius:8px;padding:10px;background:#fff}.trainee-card--amber{border-color:#d3a01675;background:#d3a01612}.trainee-photo{width:56px;height:56px;border-radius:8px;object-fit:cover;background:#e7eef5}.trainee-photo--placeholder{display:grid;place-items:center;color:var(--navy);font-weight:700}.trainee-info{display:grid;gap:4px;min-width:0}.trainee-info span{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-row{display:flex;flex-wrap:wrap;gap:6px}.mini-badge{width:fit-content;border-radius:999px;padding:3px 7px;background:#e7eef5;color:var(--navy);font-size:11px;font-weight:700}.mini-badge--green{background:#20815424;color:var(--success)}.mini-badge--blue{background:#254a6824;color:var(--navy-2)}.mini-badge--amber{background:#d3a0162e;color:#8a6408}.review-submit-bar{position:fixed;left:300px;right:20px;bottom:18px;z-index:20;display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:#fffffff5;box-shadow:var(--shadow-card)}@media (max-width: 900px){.batch-row,.review-panels,.gov-summary-grid{grid-template-columns:1fr}.sidebar{padding:var(--space-4)}.sidebar nav{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.sidebar-user{margin-top:var(--space-3)}.content{padding:var(--space-4)}.review-header{align-items:flex-start;flex-direction:column}.review-submit-bar{left:12px;right:12px;bottom:12px}}@media (max-width: 520px){.board-controls,.dashboard-kpis,.quick-action-grid,.placeholder-grid,.session-card,.session-card--compact{grid-template-columns:1fr}.trainee-card{grid-template-columns:48px minmax(0,1fr)}.trainee-card>button,.trainee-card>.inline-actions{grid-column:1 / -1}}
