*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Cairo,system-ui,sans-serif;background:#f1f5f9;color:#0f172a}a{color:inherit;text-decoration:none}table{border-collapse:collapse;width:100%}.admin-layout{display:flex;flex-direction:row;align-items:stretch;min-height:100%;min-height:100dvh}.admin-sidebar{flex-shrink:0;width:260px;background:#0f172a;color:#fff;padding:24px 16px;display:flex;flex-direction:column}.admin-main{flex:1;min-width:0;padding:clamp(12px,3vw,28px);overflow-x:hidden;overflow-y:auto;background:#f1f5f9}.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#0f172a;color:#fff;flex-shrink:0}.admin-topbar-title{font-weight:800;font-size:clamp(15px,4vw,17px)}.admin-menu-btn{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:10px;background:#ffffff1a;color:#fff;cursor:pointer;font-family:inherit}.admin-menu-btn:hover{background:#ffffff29}.admin-menu-icon{font-size:22px;line-height:1}.admin-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;border:none;padding:0;margin:0;background:#0f172a73;cursor:pointer;-webkit-tap-highlight-color:transparent}@media (max-width: 900px){.admin-layout{flex-direction:column}.admin-topbar{position:relative;z-index:210}.admin-backdrop{z-index:200}.admin-sidebar--drawer{position:fixed;top:0;bottom:0;right:0;width:min(300px,88vw);z-index:220;transform:translate(100%);transition:transform .2s ease;overflow-y:auto;box-shadow:-8px 0 32px #00000040}.admin-sidebar--drawer.admin-sidebar--open{transform:translate(0)}}.page-shell{max-width:100%}.page-title{margin:0 0 8px;font-size:clamp(1.25rem,4vw,1.65rem);font-weight:800;line-height:1.2}.page-header-row{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-header-row>div:first-child{min-width:min(100%,240px);flex:1 1 200px}.page-header-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}@media (max-width: 640px){.page-header-actions{width:100%}.page-header-actions>button{width:100%;justify-content:center}}.stat-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,148px),1fr));gap:14px;margin-bottom:24px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;overscroll-behavior-x:contain}.table-scroll table{min-width:0}.table-scroll--employees table{min-width:720px}.table-scroll--attendance table{min-width:640px}.table-scroll--devices table{min-width:520px}.modal-dialog-surface{width:100%;max-width:min(420px,100vw - 32px);max-height:min(90dvh,900px);overflow-y:auto;-webkit-overflow-scrolling:touch}.login-page{padding:clamp(12px,4vw,24px)}.login-card{width:100%;max-width:min(420px,100vw - 24px)}.overview-hero{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.overview-hero h1{margin:0 0 8px;font-size:clamp(1.35rem,4.5vw,1.75rem);font-weight:800}.responsive-grid-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:20px;margin-bottom:20px}.responsive-grid-bottom{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:20px}.chart-area{width:100%;height:min(300px,52vh);min-height:220px}.chart-card{padding:clamp(14px,3vw,20px)}@media (max-width: 480px){.chart-area{min-height:200px;height:min(280px,48vh)}}.attendance-filters{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:20px}@media (max-width: 480px){.attendance-filters input[type=date]{width:100%;max-width:100%;min-width:0}.attendance-filters button{width:100%}}
