@import"https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800&display=swap";:root{font-family:Cairo,system-ui,sans-serif;color:#27263a;background:#f6f6fb;font-synthesis:none;--primary:#6d5dfc;--primary2:#8578ff;--text:#27263a;--muted:#7b7a8f;--line:#e8e7f0;--card:#fff;--success:#24a673;--warning:#e69a22;--danger:#dd5261;--shadow:0 12px 35px rgba(44,39,86,.08)}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#f6f6fb}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:#fff;border-left:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:20}.brand{display:flex;align-items:center;gap:12px;padding:0 5px 22px}.brand.centered{justify-content:center;flex-direction:column;text-align:center}.brand-mark{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,var(--primary),#9a8fff);display:grid;place-items:center;color:#fff;box-shadow:0 10px 25px #6d5dfc4d}.brand-mark.big{width:68px;height:68px;border-radius:22px}.brand strong{display:block;font-size:21px}.brand span{display:block;font-size:11px;color:var(--muted)}nav{display:flex;flex-direction:column;gap:7px}nav button{display:flex;align-items:center;gap:11px;border:0;background:transparent;padding:12px 14px;border-radius:12px;color:#626176;text-align:right}nav button:hover,nav button.active{background:#f0eeff;color:var(--primary);font-weight:700}.side-user{margin-top:auto;border-top:1px solid var(--line);padding-top:16px;display:grid;grid-template-columns:40px 1fr auto;gap:9px;align-items:center}.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--primary);color:#fff;font-weight:800}.avatar.soft{background:#eeecff;color:var(--primary)}.side-user strong,.side-user span{display:block;font-size:12px}.side-user span{color:var(--muted);font-size:10px}.side-user button,.mobile-menu{border:0;background:transparent;color:var(--muted)}main{min-width:0}.topbar{height:88px;background:#fff;border-bottom:1px solid var(--line);padding:0 28px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:10}.topbar h1{margin:0;font-size:22px}.topbar p{margin:3px 0 0;color:var(--muted);font-size:12px}.mode-badge{margin-right:auto;padding:7px 11px;border-radius:999px;font-size:11px;font-weight:700}.mode-badge.demo{background:#fff3dc;color:#a66a00}.mode-badge.supabase{background:#e5f8ef;color:#147a54}.mobile-menu{display:none}.content{padding:25px;max-width:1450px;margin:auto}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}.stats-grid.three{grid-template-columns:repeat(3,1fr)}.stat-card,.card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.stat-card{padding:18px;display:flex;align-items:center;gap:14px}.stat-icon{width:46px;height:46px;border-radius:14px;background:#eeecff;color:var(--primary);display:grid;place-items:center}.stat-card.warn .stat-icon{background:#fff2da;color:var(--warning)}.stat-card.danger .stat-icon{background:#ffe8eb;color:var(--danger)}.stat-card span,.stat-card small,.list-item span,.handover-row span{display:block;color:var(--muted);font-size:11px}.stat-card strong{display:block;font-size:23px;margin:3px 0}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}.card{padding:20px}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.card-head h3{margin:0;font-size:16px}.card-head p{margin:4px 0 0;color:var(--muted);font-size:11px}.list{display:flex;flex-direction:column}.list-item,.handover-row{display:flex;align-items:center;gap:11px;padding:12px 0;border-bottom:1px solid #f0eff5}.list-item:last-child,.handover-row:last-child{border-bottom:0}.list-item>div:nth-child(2){flex:1}.list-item b,.handover-row b{font-size:13px}.list-item em{margin-right:auto;font-style:normal;font-weight:700;font-size:12px}.circle-icon{width:36px;height:36px;border-radius:11px;background:#f1efff;color:var(--primary);display:grid;place-items:center}.circle-icon.money{background:#e7f8f0;color:var(--success)}.pill{display:inline-flex;padding:4px 9px;border-radius:999px;font-size:10px;font-style:normal;font-weight:700;white-space:nowrap}.pill.success{background:#e6f8f0;color:#16805a}.pill.warning{background:#fff2d8;color:#a86a00}.pill.danger{background:#ffe6e9;color:#bd3242}.pill.info{background:#e9efff;color:#4868b8}.toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px}.search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:0 12px;min-width:300px}.search input{border:0;outline:0;background:transparent;padding:11px;width:100%}.primary,.success-btn,.danger-btn,.settings-banner button{border:0;border-radius:11px;padding:10px 15px;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:700}.primary{background:var(--primary);color:#fff}.primary:hover{background:#5c4be9}.primary.wide{width:100%}.success-btn{background:#e5f8ef;color:#147a54}.danger-btn{background:#ffe7ea;color:#b83242}.table-card{padding:0;overflow:hidden}.table-wrap{overflow:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{text-align:right;padding:14px 17px;border-bottom:1px solid #efeff4;font-size:12px}th{background:#fafafe;color:var(--muted);font-weight:700}tbody tr:hover{background:#fbfaff}.filters{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:16px;align-items:end;margin-bottom:17px}.filter-summary{height:67px;border-radius:13px;background:#f4f2ff;color:var(--primary);display:flex;align-items:center;gap:10px;padding:12px}.filter-summary b,.filter-summary span{display:block}.filter-summary span{font-size:10px;color:var(--muted)}label{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:700;color:#57566a}input,select,textarea{width:100%;border:1px solid #dedde8;border-radius:10px;padding:10px 11px;background:#fff;color:var(--text);outline:0}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #efedff}textarea{min-height:78px;resize:vertical}.attendance-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.attendance-card{background:#fff;border:1px solid var(--line);border-radius:17px;padding:16px}.person{display:flex;align-items:center;gap:10px;margin-bottom:14px}.person>div:nth-child(2){flex:1}.person b,.person span{display:block}.person span{font-size:10px;color:var(--muted)}.attendance-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}.attendance-actions button{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 4px;font-size:10px;display:flex;flex-direction:column;align-items:center;gap:4px;color:#67657a}.attendance-actions button svg{width:17px}.attendance-actions button.selected{border-color:var(--primary);background:#f0eeff;color:var(--primary);font-weight:700}.attendance-actions button.selected.present{border-color:var(--success);background:#e9f8f1;color:var(--success)}.attendance-actions button.selected.absent{border-color:var(--danger);background:#ffecef;color:var(--danger)}.check-list{max-height:420px;overflow:auto}.check-list label{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid #f0eff5}.check-list input{width:18px;height:18px}.check-list b,.check-list span{display:block}.check-list span{font-size:10px;color:var(--muted)}.check-list em{font-style:normal;font-weight:800}.handover-total{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;margin-top:15px;padding-top:15px;border-top:1px solid var(--line)}.handover-total button{grid-column:1/-1}.handover-row>div{flex:1}.handover-row strong{font-size:12px}.confirm-box p{padding:12px;background:#f7f6fb;border-radius:11px}.bars{display:flex;flex-direction:column;gap:15px}.bars>div{display:grid;grid-template-columns:100px 1fr 25px;align-items:center;gap:8px;font-size:11px}.bars>div>div{height:9px;background:#eeedf4;border-radius:99px;overflow:hidden}.bars i{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#a99fff);border-radius:99px}.export-box{text-align:center;padding:20px;color:var(--muted)}.export-box p{font-size:12px}.settings-banner{background:linear-gradient(135deg,#5f4ff0,#8d81ff);color:#fff;border-radius:18px;padding:18px 20px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;gap:15px}.settings-banner b,.settings-banner span{display:block}.settings-banner span{font-size:11px;opacity:.85}.settings-banner button{background:#ffffff2e;color:#fff}.settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:17px}.stack-form{display:flex;flex-direction:column;gap:11px}.muted{color:var(--muted);font-size:12px}.empty{text-align:center;color:#aaa8b8;padding:32px}.empty p{margin:8px 0;font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#14122a7a;z-index:50;display:grid;place-items:center;padding:18px}.modal{background:#fff;border-radius:20px;padding:20px;width:min(620px,100%);max-height:90vh;overflow:auto;box-shadow:0 25px 70px #00000040}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-head h3{margin:0}.modal-head button{border:0;background:#f2f1f7;width:34px;height:34px;border-radius:10px;font-size:23px;color:#666}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}.form-grid .full{grid-column:1/-1}.login-page,.splash{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at 80% 10%,#e9e5ff 0,transparent 34%),radial-gradient(circle at 10% 90%,#e5f8f0 0,transparent 30%),#f7f7fb}.login-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px;box-shadow:0 25px 80px #3730741f}.login-card h2{margin:5px 0;text-align:center}.login-card>p{text-align:center;color:var(--muted);font-size:12px;margin-bottom:20px}.login-card form{display:flex;flex-direction:column;gap:13px}.demo-box{margin-top:18px;background:#fff6e4;border:1px dashed #e8bf6f;border-radius:13px;padding:13px;color:#7f5a13}.demo-box b,.demo-box span,.demo-box small{display:block}.demo-box span,.demo-box small{font-size:10px}.demo-box div{display:flex;gap:7px;margin:8px 0}.demo-box button{border:0;background:#fff;border-radius:8px;padding:7px 10px;color:#7f5a13}.splash{align-content:center;text-align:center}.splash h2{margin:14px}.spinner{width:32px;height:32px;border:3px solid #dedafc;border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:auto}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:25px;left:50%;transform:translate(-50%);background:#29273a;color:#fff;padding:11px 18px;border-radius:12px;z-index:100;font-size:12px;box-shadow:0 12px 35px #0003}.bottom-nav{display:none}@media(max-width:1050px){.stats-grid,.settings-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:820px){.app-shell{display:block}.sidebar{position:fixed;right:-280px;top:0;width:260px;transition:.25s;box-shadow:-15px 0 45px #00000026}.sidebar.open{right:0}.mobile-menu{display:block}.topbar{padding:0 15px;height:75px}.topbar h1{font-size:18px}.content{padding:15px 14px 90px}.two-col,.attendance-grid{grid-template-columns:1fr}.filters{grid-template-columns:1fr 1fr}.filter-summary{grid-column:1/-1}.bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;bottom:0;right:0;left:0;background:#fff;border-top:1px solid var(--line);z-index:30;padding:6px 4px calc(6px + env(safe-area-inset-bottom))}.bottom-nav button{border:0;background:transparent;color:#77758c;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:9px}.bottom-nav button.active{color:var(--primary);font-weight:800}.mode-badge{font-size:9px;padding:5px 8px}.settings-grid{grid-template-columns:1fr}.handover-layout{display:block}.handover-layout>.card{margin-bottom:15px}}@media(max-width:560px){.stats-grid,.stats-grid.three{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:13px;gap:9px}.stat-icon{width:38px;height:38px}.stat-card strong{font-size:17px}.stat-card span,.stat-card small{font-size:9px}.toolbar{align-items:stretch}.search{min-width:0;flex:1}.toolbar .primary{font-size:11px;padding:9px}.filters{grid-template-columns:1fr}.filter-summary{grid-column:auto}.attendance-actions{grid-template-columns:repeat(4,1fr)}.form-grid{grid-template-columns:1fr}.form-grid .full{grid-column:auto}.settings-banner{align-items:flex-start;flex-direction:column}.topbar p{display:none}.bars>div{grid-template-columns:70px 1fr 20px}.card{padding:15px}}
