body{background:#f1f5f9;margin:0;font-family:Arial,sans-serif}.dashboard-page{background:#f1f5f9;min-height:100vh}.dashboard-main{grid-template-columns:1fr 1fr 1fr;gap:24px;max-width:1400px;margin:auto;padding:20px;display:grid}.panel-space{flex-direction:column;gap:24px;display:flex}.dashboard-header{z-index:100;background:#fff;border-bottom:1px solid #ddd;position:sticky;top:0;box-shadow:0 1px 3px #00000014}.dashboard-header-inner{justify-content:space-between;align-items:center;max-width:1400px;height:70px;margin:auto;padding:0 20px;display:flex}.header-left{align-items:center;gap:15px;display:flex}.logo-circle{color:#fff;background:#1d4ed8;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-weight:700;display:flex}.app-title{color:#1e3a8a;margin:0;font-size:22px;font-weight:700}.app-subtitle{color:#64748b;margin:0;font-size:13px}.header-right{text-align:right}.header-date{color:#374151;margin:0;font-weight:600}.header-time{color:#2563eb;margin:0;font-weight:700}.dashboard-card{background:#fff;border-radius:24px;padding:24px;box-shadow:0 3px 10px #00000014}.card-title{margin-bottom:20px;font-size:22px;font-weight:700}.geo-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.geo-badge-success{color:#15803d;background:#dcfce7;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700}.geo-badge-error{color:#b91c1c;background:#fee2e2;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700}.info-box{border:1px solid #ddd;border-radius:18px;margin-bottom:15px;padding:16px}.info-label{color:#64748b;margin-bottom:5px;font-size:13px}.info-value{font-weight:700}.stats-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.stats-card{background:#e2e8f0;border-radius:18px;padding:16px}.stats-value{color:#2563eb;font-size:24px;font-weight:700}.camera-wrapper{background:#000;border-radius:18px;overflow:hidden}.camera-video{object-fit:cover;width:100%;height:320px}.attendance-center{text-align:center}.current-time{color:#2563eb;margin:10px 0;font-size:54px;font-weight:700}.attendance-status{color:#15803d;background:#dcfce7;border-radius:999px;padding:10px 18px;font-size:14px;font-weight:700;display:inline-block}.button-grid{grid-template-columns:1fr 1fr;gap:16px;margin-top:40px;display:grid}.btn{color:#fff;cursor:pointer;border:none;border-radius:18px;padding:18px;font-size:18px;font-weight:700;transition:all .3s}.btn-green{background:#16a34a}.btn-green:hover{background:#15803d}.btn-red{background:#dc2626}.btn-red:hover{background:#b91c1c}.btn-disabled{cursor:not-allowed;background:#9ca3af}.log-card{border:1px solid #ddd;border-radius:18px;margin-bottom:14px;padding:16px}.log-header{justify-content:space-between;align-items:center;display:flex}.success-badge{color:#15803d;background:#dcfce7;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700}.small-text{color:#64748b;font-size:12px}.team-card{border:1px solid #ddd;border-radius:18px;justify-content:space-between;align-items:center;margin-bottom:14px;padding:16px;display:flex}.team-left{align-items:center;gap:14px;display:flex}.team-avatar{color:#fff;background:#1d4ed8;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-weight:700;display:flex}.team-name{margin:0;font-weight:700}.team-role{color:#64748b;margin:0;font-size:13px}.status-present{color:#15803d;background:#dcfce7;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700}.status-absent{color:#b91c1c;background:#fee2e2;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700}.status-late{color:#b45309;background:#fef3c7;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700}@media (width<=1100px){.dashboard-main{grid-template-columns:1fr}}@media (width<=700px){.dashboard-header-inner{flex-direction:column;gap:10px;height:auto;padding:14px}.button-grid{grid-template-columns:1fr}.current-time{font-size:38px}}.attendance-filter-container{flex-wrap:wrap;align-items:center;gap:15px;margin-bottom:20px;display:flex}.attendance-select{background:#fff;border:1px solid #dcdcdc;border-radius:8px;outline:none;min-width:180px;padding:10px 14px;font-size:14px;transition:all .3s}.attendance-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.attendance-search-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:10px 20px;font-weight:600;transition:all .3s}.attendance-search-btn:hover{background:#1d4ed8}.attendance-search-btn:disabled{cursor:not-allowed;background:#94a3b8}.attendance-table-wrapper{width:100%;margin-top:20px;overflow-x:auto}.attendance-table{border-collapse:collapse;background:#fff;width:100%}.attendance-table thead{background:#f8fafc}.attendance-table th{text-align:left;color:#334155;border-bottom:1px solid #e2e8f0;padding:14px;font-size:14px;font-weight:600}.attendance-table td{color:#475569;border-bottom:1px solid #e2e8f0;padding:14px;font-size:14px}.attendance-table tbody tr:hover{background:#f8fafc}.attendance-table tbody tr:last-child td{border-bottom:none}.status-present{color:#166534;background:#dcfce7;border-radius:20px;padding:5px 10px;font-size:12px;font-weight:600;display:inline-block}.status-absent{color:#991b1b;background:#fee2e2;border-radius:20px;padding:5px 10px;font-size:12px;font-weight:600;display:inline-block}.status-late{color:#92400e;background:#fef3c7;border-radius:20px;padding:5px 10px;font-size:12px;font-weight:600;display:inline-block}@media (width<=768px){.attendance-filter-container{flex-direction:column;align-items:stretch}.attendance-select,.attendance-search-btn{width:100%}}.attendance-photo{object-fit:cover;cursor:pointer;border:2px solid #e2e8f0;border-radius:12px;width:70px;height:70px;transition:all .3s}.attendance-photo:hover{z-index:100;position:relative;transform:scale(1.8)}.attendance-no-photo{color:#64748b;text-align:center;background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;width:70px;height:70px;font-size:11px;display:flex}.no-data{text-align:center;color:#94a3b8;padding:30px;font-size:15px;font-weight:600}.header-user-section{align-items:center;gap:15px;display:flex}.logout-btn{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:10px;padding:10px 18px;font-weight:600;transition:all .3s}.logout-btn:hover{background:#b91c1c;transform:translateY(-1px)}.login-page{background:#f1f5f9;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:20px;width:100%;max-width:420px;padding:32px;box-shadow:0 10px 25px #0000001a}.login-title{text-align:center;color:#1e3a8a;margin-bottom:24px;font-size:28px;font-weight:700}.login-input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:10px;width:100%;margin-bottom:16px;padding:14px;font-size:14px}.login-input:focus{border-color:#2563eb;outline:none}.login-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;width:100%;padding:14px;font-size:16px;font-weight:600}.login-btn:hover{background:#1d4ed8}.attendance-dashboard{--navy:#08135f;--blue:#0865ed;--line:#dce5f3;--soft-blue:#f5f8fd;min-height:100vh;color:var(--navy);text-align:left;background:#fbfdff;padding:14px;font:600 12px/1.35 Inter,Segoe UI,Arial,sans-serif}.attendance-dashboard *{box-sizing:border-box}.attendance-dashboard button,.attendance-dashboard input,.attendance-dashboard textarea{font:inherit}.attendance-dashboard button{cursor:pointer;color:inherit}.attendance-header{align-items:flex-end;gap:28px;padding:2px 4px 12px;display:flex}.attendance-brand{align-items:center;gap:14px;min-width:430px;display:flex}.attendance-brand h1{color:var(--navy);letter-spacing:-.5px;margin:0;font-size:28px;font-weight:800;line-height:1.1}.attendance-brand p{margin-top:5px;font-size:13px}.brand-mark{width:52px;height:52px;color:var(--blue);font-size:48px;position:relative}.brand-check{color:#fff;background:var(--blue);border-radius:5px;width:24px;height:24px;padding:3px;position:absolute;top:15px;left:15px}.primary-filters{flex:1;grid-template-columns:170px minmax(280px,1fr) 190px minmax(270px,1fr);gap:16px;display:grid}.dashboard-field{min-width:160px;display:block}.dashboard-field>span,.message-panel label{margin:0 0 6px;font-size:11px;font-weight:700;display:block}.dashboard-field>div,.select-control{white-space:nowrap;background:#fff;border:1px solid #cfd9eb;border-radius:5px;justify-content:space-between;align-items:center;gap:10px;height:38px;padding:0 12px;display:flex;overflow:hidden;box-shadow:0 1px 2px #08135f08}.dashboard-field i{flex:none;font-size:16px;font-style:normal;display:flex}.select-field>div{padding:0;display:block;position:relative;overflow:visible}.select-field select{z-index:1;width:100%;min-width:0;height:100%;color:var(--navy);appearance:none;cursor:pointer;background:0 0;border:0;outline:0;padding:0 34px 0 12px;font-weight:700;display:block;position:relative}.select-field i{z-index:2;pointer-events:none;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.date-field>div{padding:0 8px}.date-field input{width:100%;height:100%;color:var(--navy);background:0 0;border:0;outline:0;padding:0 4px;font-weight:700}.multi-select-field,.multi-select-field details{position:relative}.multi-select-field summary{cursor:pointer;background:#fff;border:1px solid #cfd9eb;border-radius:5px;justify-content:space-between;align-items:center;gap:10px;height:38px;padding:0 12px;list-style:none;display:flex;overflow:hidden;box-shadow:0 1px 2px #08135f08}.multi-select-field summary::-webkit-details-marker{display:none}.multi-select-field summary>span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.multi-select-field details[open] summary{border-color:var(--blue);box-shadow:0 0 0 2px #0865ed1a}.multi-select-menu{z-index:30;background:#fff;border:1px solid #cfd9eb;border-radius:5px;max-height:260px;padding:7px;position:absolute;top:calc(100% + 5px);left:0;right:0;overflow-y:auto;box-shadow:0 10px 25px #08135f29}.multi-select-menu>label{cursor:pointer;border-radius:4px;align-items:center;gap:9px;padding:8px;display:flex}.multi-select-menu>label:hover{background:#f2f6fd}.multi-select-menu>label span{overflow-wrap:anywhere}.multi-select-menu button{width:100%;color:var(--blue);text-align:left;background:0 0;border:0;padding:7px 8px}.multi-select-menu p{color:#69739b;margin:0;padding:10px 8px}.multi-select-menu .multi-select-notice{color:#36558f;background:#eef4ff;border-radius:4px;margin-bottom:5px;font-size:10px;line-height:1.4}.filter-bar{border:1px solid var(--line);background:#fff;border-radius:7px;grid-template-columns:185px 185px 185px minmax(300px,1fr) auto;align-items:end;gap:28px;padding:12px 10px;display:grid}.filter-actions{justify-content:flex-end;gap:12px;display:flex}.button{white-space:nowrap;background:#fff;border:1px solid #0000;border-radius:5px;justify-content:center;align-items:center;gap:9px;height:38px;padding:0 18px;font-weight:700;display:inline-flex}.button svg{font-size:17px}.button-primary{background:var(--blue);color:#fff!important}.button-outline{background:#fff;border-color:#cfd9eb}.button-filter{border-color:var(--blue);min-width:150px;margin-top:17px;color:var(--blue)!important}.attendance-tabs{align-items:end;margin-top:10px;display:flex}.attendance-tabs button{border:1px solid var(--line);background:#f7f8fb;justify-content:center;align-items:center;gap:12px;min-width:195px;height:42px;font-weight:700;display:flex}.attendance-tabs button:hover{color:var(--blue);background:#f1f6ff}.attendance-tabs button:focus-visible{z-index:2;outline:2px solid var(--blue);outline-offset:-2px;position:relative}.attendance-tabs button:first-child{border-radius:6px 0 0}.attendance-tabs button:last-child{border-radius:0 6px 0 0}.attendance-tabs svg{font-size:19px}.attendance-tabs .active{color:var(--blue);background:#fff;border-bottom-color:#fff;position:relative}.attendance-tabs .active:before{content:"";background:var(--blue);border-radius:5px 5px 0 0;height:4px;position:absolute;inset:-1px -1px auto}.attendance-card{border:1px solid var(--line);background:#fff;border-radius:0 7px 7px;padding:15px 16px 0}.section-heading{justify-content:space-between;align-items:flex-start;gap:30px;display:flex}.section-heading h2{color:var(--navy);margin:0;font-size:17px;font-weight:800}.section-heading p{color:var(--blue);margin-top:5px;font-size:16px;font-weight:800}.inline-filters{grid-template-columns:210px 220px 150px;align-items:end;gap:28px;display:grid}.attendance-tab-empty{color:#69739b;text-align:center;place-content:center;justify-items:center;min-height:390px;padding:40px 20px;display:grid}.attendance-tab-empty-icon{width:64px;height:64px;color:var(--blue);background:#eaf2ff;border-radius:16px;place-items:center;margin-bottom:15px;font-size:30px;display:grid}.attendance-tab-empty h3{color:var(--navy);margin:0 0 7px;font-size:17px}.attendance-tab-empty p{max-width:420px;margin:0;font-size:12px}.dashboard-alert{color:#b4232c;background:#fff4f4;border:1px solid #f2b8bc;border-radius:6px;justify-content:space-between;align-items:center;gap:16px;margin-top:14px;padding:10px 14px;display:flex}.dashboard-alert button{color:inherit;background:#fff;border:1px solid;border-radius:4px;padding:5px 12px}.stats-grid{grid-template-columns:repeat(6,minmax(150px,1fr));gap:34px;margin-top:15px;display:grid}.stat-card{border:1px solid var(--line);background:linear-gradient(110deg,#fff,#f8fbff);border-radius:6px;align-items:center;gap:15px;min-height:78px;padding:12px;display:flex}.stat-card.green{background:linear-gradient(110deg,#fff,#f4fbf6);border-color:#d6eadc}.stat-card.red{background:linear-gradient(110deg,#fff,#fff7f7);border-color:#f2d9d9}.stat-card.orange{background:linear-gradient(110deg,#fff,#fffaf4);border-color:#f3e3cf}.stat-card.purple{background:linear-gradient(110deg,#fff,#faf7ff);border-color:#e5dbf4}.stat-icon{width:50px;height:50px;color:var(--blue);background:#e7f0ff;border-radius:10px;flex:none;place-items:center;font-size:32px;display:grid;box-shadow:inset 0 0 14px #0865ed1a}.stat-card.green .stat-icon{color:#079447;background:#e3f6e9}.stat-card.red .stat-icon{color:#f12632;background:#fee8e9}.stat-card.orange .stat-icon{color:#ee8508;background:#fff0dc}.stat-card.purple .stat-icon{color:#7d21e8;background:#f1e7ff}.stat-card span{margin-bottom:4px;font-size:11px;font-weight:800;display:block}.stat-card strong{color:var(--blue);font-size:22px;display:block}.stat-card.green strong{color:#079447}.stat-card.red strong{color:#ef2631}.stat-card.orange strong{color:#ee8508}.stat-card.purple strong{color:#7d21e8}.stat-card small{color:var(--navy);margin-left:7px;font-size:11px}.stats-grid.is-loading .stat-card{opacity:.7}.summary-actions{grid-template-columns:280px 265px 265px minmax(500px,1fr);align-items:center;gap:22px;margin-top:20px;display:grid}.zone-card{border:1px solid var(--line);background:#fff;border-radius:6px;min-height:52px;padding:9px 17px}.zone-card div{align-items:center;gap:10px;margin-bottom:4px;display:flex}.zone-card strong{padding-left:28px;font-size:12px}.zone-card.green{color:#098c44;border-color:#d4eadc}.zone-card.yellow{color:#ef8505;border-color:#f0dfc9}.zone-card.red{color:#e92f39;border-color:#f2d6d8}.zone-dot{background:currentColor;border-radius:50%;width:14px;height:14px;box-shadow:inset 0 2px 3px #ffffffb3}.communication-actions{grid-template-columns:repeat(4,1fr);gap:22px;display:grid}.action-button,.mini-action{white-space:nowrap;background:#fff;border:1px solid;border-radius:5px;justify-content:center;align-items:center;gap:9px;height:40px;display:flex}.action-button svg{font-size:18px}.excel,.whatsapp{color:#079447!important}.sms{color:#7a22df!important}.email{color:#f26522!important}.content-grid{grid-template-columns:minmax(0,1fr) 265px;gap:8px;margin-top:16px;display:grid}.table-panel,.message-panel{border:1px solid var(--line);background:#fff;border-radius:6px 6px 0 0;overflow:hidden}.bulk-bar{border-bottom:1px solid var(--line);align-items:center;gap:14px;min-height:43px;padding:7px 12px;display:flex}.selected-count{align-items:center;gap:10px;display:flex}.attendance-dashboard input[type=checkbox]{width:17px;height:17px;accent-color:var(--blue);margin:0}.link-button{background:0 0;border:0;margin-right:auto;font-size:10px;text-decoration:underline;color:var(--blue)!important}.bulk-label{font-size:11px;font-weight:800}.mini-action{height:30px;padding:0 13px;font-size:10px}.table-scroll{overflow-x:auto}.student-table{border-collapse:collapse;width:100%;min-width:1290px;color:var(--navy);font-size:10px}.student-table th{border-right:1px solid #e4ebf6;border-bottom:1px solid var(--line);white-space:nowrap;text-align:left;background:#f5f8fd;height:37px;padding:7px 10px;font-weight:800}.student-table td{white-space:nowrap;text-align:left;border-bottom:1px solid #e7edf6;border-right:1px solid #e7edf6;height:32px;padding:5px 10px}.student-table tbody tr:hover{background:#f9fbff}.table-state{color:#69739b;text-align:center;padding:35px;font-size:12px}.status-badge{text-align:center;border-radius:4px;min-width:69px;padding:4px 9px;font-weight:700;display:inline-block}.status-badge.green{color:#07863f;background:#e7f5ea}.status-badge.yellow{color:#e77800;background:#fff0dd}.status-badge.red{color:#ed2430;background:#fee8e9}.status-badge.purple{color:#7720d7;background:#f1e7fd}.row-actions{color:var(--blue);align-items:center;gap:10px;font-size:13px;display:flex}.row-actions svg:first-child{color:#079447}.row-actions svg:nth-child(3){color:#f26522}.table-footer{justify-content:space-between;align-items:center;min-height:48px;padding:7px 0;display:flex}.pagination{align-items:center;gap:7px;display:flex}.pagination button{border:1px solid var(--line);background:#fff;border-radius:4px;justify-content:center;align-items:center;min-width:29px;height:29px;display:flex}.pagination button.current{color:#fff;border-color:var(--blue);background:var(--blue)}.pagination button:disabled{cursor:not-allowed;opacity:.45}.pagination select{border:1px solid var(--line);height:29px;color:var(--navy);font:inherit;background:#fff;border-radius:4px;padding:0 22px 0 8px}.message-title{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;height:43px;padding:0 13px;display:flex}.message-title h3{margin:0;font-size:12px}.message-tabs{grid-template-columns:repeat(3,1fr);display:grid}.message-tabs button{border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#f7f9fd;height:38px;font-size:10px}.message-tabs .active{color:#07863f;background:#fff;border-top:2px solid #16a15a}.message-body{padding:18px 13px}.message-label{justify-content:space-between;align-items:start;display:flex}.message-label button{background:0 0;border:0;padding:0;font-size:9px;color:var(--blue)!important}.select-control{height:36px;margin-bottom:18px;font-size:10px}.textarea-wrap{position:relative}.textarea-wrap textarea{resize:none;width:100%;height:112px;color:var(--navy);border:1px solid #cfd9eb;border-radius:5px;outline:none;padding:10px;font-size:10px}.textarea-wrap span{color:#6c75a1;font-size:9px;position:absolute;bottom:8px;right:9px}.message-info{background:#f0f5ff;border-radius:5px;align-items:flex-start;gap:10px;margin-top:22px;padding:12px;font-size:10px;display:flex}.message-info>span{width:15px;height:15px;color:var(--blue);border:1px solid var(--blue);border-radius:50%;place-items:center;display:grid}.message-info p{margin:0}.message-footer{gap:12px;margin-top:12px;padding:12px 13px;display:flex}.send-button{background:#079447;flex:1;color:#fff!important}.send-button:disabled,.button:disabled{cursor:not-allowed;opacity:.55}@media (width<=1450px){.attendance-header{align-items:flex-start}.attendance-brand{min-width:340px}.primary-filters{grid-template-columns:repeat(2,minmax(200px,1fr))}.filter-bar{grid-template-columns:repeat(4,minmax(150px,1fr))}.filter-actions{grid-column:1/-1}.stats-grid{gap:14px}.summary-actions{grid-template-columns:repeat(3,1fr)}.communication-actions{grid-column:1/-1}}@media (width<=1050px){.attendance-header,.section-heading{flex-direction:column}.attendance-brand{min-width:0}.primary-filters,.inline-filters{width:100%}.stats-grid{grid-template-columns:repeat(3,1fr)}.content-grid{grid-template-columns:1fr}.message-panel{max-width:520px}}@media (width<=720px){.attendance-dashboard{padding:8px}.attendance-brand h1{font-size:22px}.primary-filters,.filter-bar,.inline-filters,.stats-grid,.summary-actions{grid-template-columns:1fr;gap:12px}.filter-actions,.communication-actions{grid-template-columns:1fr 1fr;display:grid}.attendance-tabs{overflow-x:auto}.attendance-tabs button{min-width:175px}.bulk-bar{flex-wrap:wrap}.link-button{margin-right:0}.table-footer{flex-direction:column;align-items:flex-start;gap:10px}.pagination{flex-wrap:wrap}}:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (width<=1024px){:root{font-size:16px}}#root{text-align:left;box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}
