:root{
  --primary:#3949ab;
  --primary-dark:#283593;
  --primary-light:#e8eaf6;
  --sidebar:#283593;
  --sidebar-hover:rgba(255,255,255,.1);
  --sidebar-active:rgba(255,255,255,.16);
  --bg:#f0f4f8;
  --surface:#fff;
  --text:#1a2b42;
  --muted:#64748b;
  --border:#e2e8f0;
  --success:#10b981;
  --danger:#ef4444;
  --warn:#f59e0b;
  --radius:12px;
  --radius-lg:16px;
  --shadow:0 1px 3px rgba(15,45,107,.06),0 8px 24px rgba(15,45,107,.08);
  --shadow-sm:0 1px 2px rgba(15,45,107,.06);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"PingFang SC","Microsoft YaHei",sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}
.hidden{display:none!important}
a{color:var(--primary);text-decoration:none}

/* Login */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(145deg,#0d47a1 0%,#1976d2 42%,#e3f2fd 100%)}
.login-card{width:min(420px,94vw);background:var(--surface);border-radius:20px;padding:32px 28px;box-shadow:0 24px 64px rgba(13,71,161,.28)}
.login-logo{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#1565c0,#42a5f5);display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 8px 20px rgba(21,101,192,.35)}
.login-logo svg{width:30px;height:30px;stroke:#fff}
.logo{font-size:24px;font-weight:800;color:var(--primary-dark);letter-spacing:-.02em}
.login-sub{color:var(--muted);font-size:14px;margin:6px 0 22px}
.login-card input{width:100%;padding:13px 14px;border:1px solid var(--border);border-radius:10px;margin:6px 0;font-size:15px;transition:border-color .15s,box-shadow .15s}
.login-card input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(21,101,192,.15)}
.profile-qr-tip{margin:7px 2px 2px;text-align:center}

/* Buttons */
/* Shared base for all action button variants */
.btn-primary,
.btn-ghost,
.btn-ok,
.btn-bad,
.btn-outline,
.btn-warn{
  border:0;
  padding:10px 18px;
  border-radius:10px;
  font-weight:600;
  cursor:pointer;
  font-size:14px;
  line-height:1.2;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box;
  transition:background .15s,transform .1s,box-shadow .15s;
  text-decoration:none;
  white-space:nowrap;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(57,73,171,.22)}
.btn-primary:hover:not(:disabled){background:#303f9f}
.btn-primary:active:not(:disabled){transform:translateY(1px)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
button{font-family:inherit;cursor:pointer}
.btn-block{width:100%;padding:14px}
.btn-ghost{background:var(--primary-light);color:var(--primary);box-shadow:none}
.btn-ghost:hover{background:#d4e8fc}
.btn-ghost-light{background:rgba(255,255,255,.2);color:#fff;box-shadow:none}
.btn-ok{background:var(--success);color:#fff;box-shadow:0 2px 8px rgba(16,185,129,.3)}
.btn-ok:hover:not(:disabled){background:#059669}
.btn-bad{background:var(--danger);color:#fff;box-shadow:0 2px 8px rgba(239,68,68,.25)}
.btn-bad:hover:not(:disabled){background:#dc2626}
.btn-warn{background:var(--warn);color:#fff;box-shadow:none}
.btn-sm{padding:7px 12px;font-size:12px;border-radius:8px;min-height:32px}
.btn-outline{background:#fff;color:var(--primary);border:1px solid var(--primary)!important;box-shadow:none}
.btn-outline:hover{background:var(--primary-light)}

/* Mobile */
.mobile-app{max-width:480px;margin:0 auto;min-height:100vh;background:#eef2f7;padding-bottom:76px}
.m-header{background:linear-gradient(180deg,#283593 0%,#3949ab 100%);color:#fff;padding:18px 18px 52px;border-radius:0 0 24px 24px;position:relative;overflow:hidden}
.m-header::after{content:'';position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.08)}
.m-user{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.m-avatar{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.22);border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}
.m-user b{display:block;font-size:18px;font-weight:700}
.m-user span{font-size:12px;opacity:.92}
.m-clock{text-align:center;margin-top:14px;position:relative;z-index:1}
.m-time{font-size:44px;font-weight:200;letter-spacing:3px}
.m-date{font-size:13px;opacity:.92;margin-top:2px}
.m-main{padding:0 16px 16px;margin-top:-36px;position:relative;z-index:2}
.m-stats{background:var(--surface);border-radius:var(--radius-lg);padding:18px 14px;display:flex;gap:8px;margin-bottom:14px;box-shadow:var(--shadow)}
.m-stat{flex:1;text-align:center}
.m-stat b{display:block;font-size:24px;font-weight:700;color:var(--text)}
.m-stat b.ok{color:var(--success)}
.m-stat b.bad{color:var(--danger)}
.m-stat span{font-size:11px;color:var(--muted);margin-top:2px;display:block}
.m-region{flex:1.15;border-left:1px solid var(--border);padding-left:12px;font-size:12px;line-height:1.5}
.m-region .ok{color:var(--success);font-weight:600}
.m-card{background:var(--surface);border-radius:14px;padding:16px 16px 16px 20px;margin-bottom:10px;border:1px solid var(--border);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.m-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:#cbd5e1;border-radius:4px 0 0 4px}
.m-card.st-done::before{background:var(--success)}
.m-card.st-miss::before{background:var(--danger)}
.m-card.st-open::before{background:var(--primary)}
.m-card.st-wait::before{background:#94a3b8}
.m-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:8px}
.m-card-top span:first-child{font-weight:600;font-size:15px}
.m-tag{font-size:11px;padding:4px 12px;border-radius:999px;font-weight:600}
.m-tag.done{background:#d1fae5;color:#047857}
.m-tag.miss{background:#fee2e2;color:#b91c1c}
.m-tag.open{background:var(--primary-light);color:var(--primary)}
.m-tag.wait{background:#f1f5f9;color:#64748b}
.m-tabbar{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:var(--surface);display:flex;border-top:1px solid var(--border);padding:6px 0 calc(8px + env(safe-area-inset-bottom));z-index:50;box-shadow:0 -4px 20px rgba(15,45,107,.06)}
.m-tab{flex:1;text-align:center;padding:6px;border:0;background:transparent;color:var(--muted);font-size:11px;font-weight:600}
.m-tab.active{color:var(--primary)}
.m-tab svg{display:block;margin:0 auto 4px;width:22px;height:22px}

/* Panels & cards */
.card,.panel{background:var(--surface);border-radius:var(--radius-lg);margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.card{padding:18px}
.panel{overflow:hidden}
.panel-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff}
.panel-head h3{margin:0;font-size:15px;font-weight:700;color:var(--text)}
.panel-head .mini{margin:0}
.panel-body{padding:20px 24px 24px}
.card h3{margin:0 0 12px;font-size:16px;font-weight:700}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px 16px;margin-bottom:0}
.form-grid input,.form-grid select,.form-grid textarea{width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:#fff}
.form-grid input:focus,.form-grid select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(57,73,171,.12)}
.form-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}
.form-actions .btn-primary,.form-actions .btn-ok,.form-actions .btn-ghost,.form-actions .btn-outline,.form-actions .btn-bad{min-width:96px}
.panel-stack>.panel{margin-bottom:18px}
.panel-stack>.panel:last-child{margin-bottom:0}
.toolbar-row{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 18px}
.upload-field{margin:12px 0 4px}
.upload-field input[type=file]{display:block;width:100%;max-width:360px;padding:8px 0;font-size:13px}
.table td.table-actions{white-space:nowrap}
.table-actions{display:inline-flex;flex-wrap:wrap;gap:8px;align-items:center}
.card .form-actions,.card .form-grid{margin-left:0;margin-right:0}
.card>.mini:first-of-type{margin-top:0}
.card{padding:20px 24px}
.form-check{display:flex;align-items:center;gap:8px;margin:4px 0;font-size:14px;color:var(--text);cursor:pointer}
.form-check input{width:auto;margin:0}
.field-spaced{margin:18px 0 0}
.form-grid-labeled .field{margin:0}
.form-grid-labeled .field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500}
.form-grid-labeled .field input,.form-grid-labeled .field select{width:100%}
.field{margin:10px 0}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px}
.field input:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(21,101,192,.12)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.mini{font-size:12px;color:var(--muted);line-height:1.55}
.section-title{font-weight:700;font-size:16px;margin:0 0 12px;color:var(--text)}
.photo-preview{width:100%;max-width:100%;border-radius:12px;background:#e8eef5;display:block}
.capture-source{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;left:-9999px;top:auto}
.photo-empty{min-height:132px;border:1px dashed var(--border);border-radius:12px;background:#f8fafc;color:#64748b;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;padding:18px}
.photo-empty::before{content:'CAM';font-size:12px;letter-spacing:.08em;color:var(--primary);border:1px solid currentColor;border-radius:6px;padding:4px 8px}
.photo-empty b{font-size:15px;color:#334155}
.photo-empty span{font-size:12px;line-height:1.5}
.watermark{font-size:12px;color:#475569;line-height:1.65;background:#f8fafc;padding:12px;border-radius:10px;margin-top:10px;border:1px solid var(--border)}
.badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;background:var(--primary-light);color:var(--primary)}
.badge.pending{background:#fef3c7;color:#b45309}
.badge.approved,.badge.ok{background:#d1fae5;color:#047857}
.badge.rejected,.badge.bad{background:#fee2e2;color:#b91c1c}

/* Admin layout */
.admin-app{display:flex;min-height:100vh;width:100%;background:var(--bg)}
.admin-side{width:220px;min-width:220px;background:var(--sidebar);color:#fff;flex-shrink:0;display:flex;flex-direction:column;min-height:100vh}
.admin-brand{padding:18px 16px 14px;font-weight:700;font-size:16px;line-height:1.4;border-bottom:1px solid rgba(255,255,255,.1);letter-spacing:.02em}
.admin-menu{list-style:none;margin:0;padding:10px 8px;flex:1;overflow-y:auto;width:100%}
.admin-menu li{margin:2px 0;padding:0;display:block;width:100%}
.admin-menu-link{display:flex;align-items:center;gap:10px;width:100%;box-sizing:border-box;text-align:left;padding:11px 14px;border:0;border-radius:10px;background:transparent!important;color:rgba(255,255,255,.82)!important;font-size:14px;font-weight:500;line-height:1.35;cursor:pointer;transition:background .15s,color .15s}
.admin-menu-link svg{width:18px;height:18px;flex-shrink:0;opacity:.85}
.admin-menu-link:hover{background:var(--sidebar-hover)!important;color:#fff!important}
.admin-menu-link.active{background:rgba(255,255,255,.12)!important;color:#fff!important;box-shadow:inset 4px 0 0 #90caf9}
.admin-menu-link.active svg{opacity:1}
.admin-menu-group{margin:2px 0}
.admin-group-toggle.group-active{color:#fff!important}
.admin-menu-arrow{margin-left:auto;font-size:16px;line-height:1;transition:transform .18s ease}
.admin-menu-group.open .admin-menu-arrow{transform:rotate(180deg)}
.admin-submenu{display:none;list-style:none;margin:0;padding:2px 0 4px}
.admin-menu-group.open .admin-submenu{display:block}
.admin-submenu li{margin:1px 0}
.admin-submenu-link{padding:9px 12px 9px 42px;font-size:13px;border-radius:8px}
.admin-submenu-link svg{width:15px;height:15px}
.admin-submenu-link.active{background:#0869e8!important;box-shadow:none}
.admin-side-footer{padding:14px 12px 18px;border-top:1px solid rgba(255,255,255,.1);margin-top:auto}
.admin-logout-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px;border:1px solid rgba(255,255,255,.25);border-radius:10px;background:rgba(255,255,255,.08)!important;color:#fff!important;font-size:13px;font-weight:600;cursor:pointer}
.admin-logout-btn:hover{background:rgba(255,255,255,.14)!important}
.admin-body{flex:1;display:flex;flex-direction:column;min-width:0;min-height:100vh}
.admin-top{background:var(--surface);padding:16px 28px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
.admin-top h1{margin:0;font-size:20px;font-weight:700;color:var(--text)}
.admin-breadcrumb{margin:4px 0 0;font-size:12px;color:var(--muted)}
.admin-top-right{display:flex;align-items:center;gap:14px}
.admin-user-pill{font-size:13px;color:#475569;padding:6px 12px;background:#fff;border-radius:999px;border:1px solid var(--border);display:inline-flex;align-items:center;gap:8px}
.admin-user-dot{width:28px;height:28px;border-radius:50%;background:#e8eaf6;display:inline-block}
.btn-help{width:28px;height:28px;min-width:28px;min-height:28px;border-radius:50%;border:1px solid #fecaca;background:#fff!important;color:#ef4444!important;font-weight:700;font-size:15px;cursor:pointer;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;line-height:1;vertical-align:middle;flex-shrink:0;box-shadow:none!important}
.btn-admin-logout{padding:8px 16px;border:1px solid var(--border);border-radius:8px;background:#fff!important;color:#475569!important;font-size:13px;font-weight:600;cursor:pointer;box-shadow:none!important}
.btn-admin-logout:hover{background:#f8fafc!important}
.btn-active{background:var(--primary-light)!important;color:var(--primary)!important;border:1px solid var(--primary)!important}
.poly-hint{margin:0 0 12px;padding:10px 12px;background:#fff8e1;border:1px solid #ffe082;border-radius:8px;color:#795548}
.link-toggle{display:block;width:100%;text-align:left;margin-top:16px;padding:12px 16px;border:1px dashed var(--border);border-radius:10px;background:#f8fafc;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;box-shadow:none!important}
.link-toggle:hover{background:var(--primary-light)}
.link-toggle-open{background:var(--primary-light);border-color:var(--primary);border-style:solid}
.panel-head-left h3{margin:0}
.panel-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.filter-in-panel{margin:0 0 12px;border:0;box-shadow:none;padding:12px 0}
.stats-tip{font-size:12px;color:var(--muted);margin:0 0 12px;padding:8px 12px;background:#f8fafc;border-radius:8px}
.table-in-panel{border:0;box-shadow:none}
.table-stats th{font-size:11px;padding:10px 8px}
.table-stats td.status-cell{font-size:15px;padding:8px}
.tag{display:inline-block;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:500}
.tag-blue{background:#e3f2fd;color:#1565c0}
.tag-green{background:#e8f5e9;color:#2e7d32}
.tag-red{background:#fee2e2;color:#b91c1c}
.tag-amber{background:#fef3c7;color:#92400e}
.import-summary,.import-warning{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px;padding:12px 14px;border:1px solid #bfdbfe;border-radius:10px;background:#eff6ff;color:#1e3a5f}
.import-summary b,.import-warning b{font-size:13px}
.import-summary span,.import-warning span{font-size:12px;line-height:1.5}
.import-summary-ok{border-color:#bbf7d0;background:#f0fdf4;color:#166534}
.import-warning{border-color:#fde68a;background:#fffbeb;color:#854d0e}
.overtime-preview-table{margin-top:12px;max-height:480px;overflow:auto}
.overtime-preview-table select{min-width:180px;max-width:240px;padding:7px 9px;border:1px solid var(--border);border-radius:7px;background:#fff}
.rate-bar{display:inline-block;width:80px;height:8px;background:#e2e8f0;border-radius:4px;vertical-align:middle;margin-right:6px;overflow:hidden}
.rate-bar i{display:block;height:100%;background:#43a047;border-radius:4px}
.rate-text{font-size:12px;color:#43a047;font-weight:600}
.stat-grid-ref{grid-template-columns:repeat(6,1fr)}
@media(max-width:1200px){.stat-grid-ref{grid-template-columns:repeat(3,1fr)}}
.stat-ref .stat-icon{font-size:20px;width:40px;height:40px;border-radius:8px}
.stat-purple .stat-icon{background:#ede7f6;color:#5e35b1}
.stat-orange .stat-icon{background:#fff3e0;color:#ef6c00}
.stat-ref.stat-blue .stat-icon{background:#e3f2fd;color:#1565c0}
.todo-dot-warn{background:#f59e0b}
.todo-names{line-height:1.7}
.detail-block{margin-top:12px;padding-top:12px;border-top:1px dashed var(--border)}
.detail-actions{margin:16px 0 12px}
.record-row{padding:12px 0;border-bottom:1px solid var(--border)}
.record-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin:2px 0 12px}
.record-detail-head b{display:block;font-size:14px;color:var(--text);margin-bottom:3px}
.record-detail-counts{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.record-detail-counts span{display:inline-flex;align-items:center;height:28px;padding:0 10px;border-radius:999px;background:#eef6ff;color:var(--primary);font-size:12px;font-weight:700}
.record-detail-subhead{margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}
.live-photo-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.live-photo-card{display:grid;grid-template-rows:150px auto;width:100%;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;overflow:hidden;text-align:left;cursor:pointer;box-shadow:var(--shadow-sm);color:var(--text)}
.live-photo-card:hover{border-color:#93c5fd;box-shadow:0 8px 22px rgba(15,23,42,.12)}
.live-photo-img{display:block;background:#f1f5f9;overflow:hidden}
.live-photo-img img{width:100%;height:100%;object-fit:cover;display:block}
.live-photo-meta{display:flex;flex-direction:column;gap:3px;padding:9px 10px 10px;min-width:0}
.live-photo-meta b{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-photo-meta span{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-photo-meta .badge{align-self:flex-start;margin-top:3px;font-style:normal}
.record-list-compact{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#fff}
.record-compact-row{display:grid;grid-template-columns:54px minmax(0,1fr) auto;gap:10px;align-items:center;padding:9px 10px;border-bottom:1px solid var(--border)}
.record-compact-row:last-child{border-bottom:0}
.record-photo-mini{width:46px;height:46px;border:0;border-radius:7px;overflow:hidden;padding:0;background:#f1f5f9;cursor:pointer}
.record-photo-mini img{width:100%;height:100%;object-fit:cover;display:block}
.record-photo-empty{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:7px;background:#f8fafc;color:var(--muted);font-size:11px;border:1px dashed var(--border)}
.record-compact-main{min-width:0}
.record-compact-title{display:flex;align-items:center;gap:8px;min-width:0}
.record-compact-title b{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.record-compact-title span:last-child{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-region-pill{flex:1.2;text-align:right;padding:8px 12px;background:#ede7f6;border-radius:12px;font-size:11px;line-height:1.45;color:#5e35b1}
.m-region-pill span{font-weight:600}
.m-page-title{font-size:16px;font-weight:700;margin:4px 0 10px;color:var(--text)}
.m-date-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}
.m-date-pick{color:var(--primary);font-weight:600;font-size:14px}
.admin-main{flex:1;padding:22px 28px 28px;overflow:auto}

/* Dashboard stats */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:14px;margin-bottom:18px}
.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px 18px 16px;display:flex;align-items:flex-start;gap:14px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon svg{width:22px;height:22px}
.stat-card span{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}
.stat-card b{font-size:28px;font-weight:700;line-height:1.1}
.stat-blue .stat-icon{background:#e3f2fd;color:#1565c0}
.stat-blue b{color:#1565c0}
.stat-green .stat-icon{background:#d1fae5;color:#059669}
.stat-green b{color:#059669}
.stat-red .stat-icon{background:#fee2e2;color:#dc2626}
.stat-red b{color:#dc2626}
.stat-amber .stat-icon{background:#fef3c7;color:#d97706}
.stat-amber b{color:#d97706}
.stat-slate .stat-icon{background:#f1f5f9;color:#475569}
.stat-slate b{color:#334155}

.todo-list{margin:0;padding:0}
.todo-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f1f5f9}
.todo-item:last-child{border-bottom:0}
.todo-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);flex-shrink:0}
.task-center{display:flex;flex-direction:column;gap:16px}
.task-hero{display:grid;grid-template-columns:220px minmax(0,1fr);gap:16px;align-items:stretch}
.task-total-card{border:1px solid var(--border);border-radius:14px;padding:18px;background:#f8fafc;display:flex;flex-direction:column;justify-content:center;min-height:124px}
.task-total-card span,.task-card span,.task-label{font-size:12px;color:var(--muted);font-weight:600}
.task-total-card b{font-size:46px;line-height:1;color:#334155;margin:8px 0 6px}
.task-total-card em,.task-card em{font-style:normal;font-size:12px;color:var(--muted);line-height:1.35}
.task-total-card.is-hot{background:#fff7ed;border-color:#fed7aa}
.task-total-card.is-hot b{color:#ea580c}
.task-total-card.is-clear{background:#f0fdf4;border-color:#bbf7d0}
.task-total-card.is-clear b{color:#16a34a}
.task-warning-card{border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:16px;background:#f8fafc;min-height:124px}
.task-warning-card b{display:block;font-size:18px;color:var(--text);margin:5px 0 6px}
.task-warning-card p{margin:0;color:#475569;font-size:13px;line-height:1.6;max-width:720px}
.task-warning-danger{background:#fff7ed;border-color:#fed7aa}
.task-warning-warn{background:#fffbeb;border-color:#fde68a}
.task-warning-ok{background:#f0fdf4;border-color:#bbf7d0}
.task-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.task-card{border:1px solid var(--border);border-radius:14px;background:#fff;padding:15px;display:grid;gap:8px;min-height:142px;align-content:start}
.task-card b{font-size:30px;line-height:1;color:#334155}
.task-card .btn-sm{align-self:end;justify-self:start;margin-top:4px}
.task-card-danger.active{border-color:#fecaca;background:#fff7f7}
.task-card-danger.active b{color:#dc2626}
.task-card-warn.active{border-color:#fde68a;background:#fffbeb}
.task-card-warn.active b{color:#d97706}
.task-card-blue.active{border-color:#bfdbfe;background:#eff6ff}
.task-card-blue.active b{color:#2563eb}
.task-card-green.active{border-color:#bbf7d0;background:#f0fdf4}
.task-card-green.active b{color:#16a34a}
.missed-preview{border:1px solid var(--border);border-radius:14px;background:#f8fafc;padding:14px 16px}
.missed-preview-clear{display:flex;align-items:center;justify-content:space-between;gap:12px}
.missed-preview-clear span,.missed-preview-head span{display:block;font-size:12px;color:var(--muted);font-weight:600}
.missed-preview-clear b,.missed-preview-head b{font-size:15px;color:var(--text)}
.missed-preview-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.missed-tags{display:flex;flex-wrap:wrap;gap:8px}
.missed-tags span{display:inline-flex;align-items:center;max-width:260px;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid #e2e8f0;color:#334155;font-size:12px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.missed-tags .missed-more{background:#eef2ff;border-color:#c7d2fe;color:#3730a3;font-weight:700}
.task-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;border-top:1px solid var(--border);padding-top:14px}
@media(max-width:1100px){
  .task-hero{grid-template-columns:1fr}
  .task-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){
  .task-grid{grid-template-columns:1fr}
  .task-warning-card,.missed-preview-head,.missed-preview-clear{align-items:flex-start;flex-direction:column}
  .task-actions{justify-content:flex-start}
  .task-total-card b{font-size:38px}
  .record-detail-head{flex-direction:column}
  .record-detail-counts{justify-content:flex-start}
  .live-photo-wall{grid-template-columns:repeat(2,minmax(0,1fr))}
  .live-photo-card{grid-template-rows:128px auto}
  .record-compact-row{grid-template-columns:48px minmax(0,1fr);align-items:start}
  .record-compact-row .table-actions{grid-column:1/-1;justify-content:flex-start}
  .record-photo-mini,.record-photo-empty{width:42px;height:42px}
}
.dash-quick{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.quick-tile{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:14px;border:1px solid var(--border);border-radius:12px;background:#f8fafc;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}
.quick-tile:hover{border-color:var(--primary);background:var(--primary-light)}
button.quick-tile{font:inherit;width:100%;box-shadow:none}
.quick-tile b{font-size:14px;color:var(--text)}
.quick-tile span{font-size:11px;color:var(--muted)}

/* Tables & filters */
.table-wrap{overflow:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm)}
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left}
.table th{background:#f8fafc;font-weight:600;color:#475569;white-space:nowrap;font-size:12px;text-transform:none;letter-spacing:.01em}
.table tbody tr:hover td{background:#fafbfd}
.table tbody tr:last-child td{border-bottom:0}
.table td.status-cell{cursor:pointer;text-align:center;font-size:17px;min-width:48px;vertical-align:middle}
.table td.status-cell:hover{background:var(--primary-light)}
.table td.status-cell.status-waiting{color:var(--muted);font-size:12px;background:#f8fafc}
.table td.status-cell.status-waiting:hover{background:var(--primary-light)}
.table td.status-cell .status-time{display:block;font-size:10px;color:var(--muted);margin-top:3px}
.weekly-report-toolbar{display:flex;gap:10px;align-items:end;flex-wrap:wrap;margin-bottom:14px}
.weekly-report-toolbar .field{min-width:180px;margin:0}
.weekly-period-field select{min-width:260px}
.weekly-missed-filter input{min-width:160px}
.weekly-period-summary{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:-4px 0 14px;padding:10px 12px;background:#f8fafc;border:1px solid var(--border);border-radius:8px;color:var(--text)}
.weekly-period-summary span{color:var(--muted)}
.weekly-filter-note{padding:8px 10px;margin:0 0 10px;background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;color:#9a3412}
.weekly-report-table .table th{background:#4773c7;color:#fff}
.weekly-report-data td{text-align:center}
.weekly-report-data td:nth-child(2){text-align:left;font-weight:700}
.scope-switch{display:inline-flex;align-items:center;gap:2px;padding:3px;background:#edf3f8;border:1px solid var(--border);border-radius:7px}
.scope-switch button{min-width:74px;padding:7px 12px;border:0;border-radius:5px;background:transparent;color:var(--muted);font-weight:700;cursor:pointer}
.scope-switch button.active{background:#1f5683;color:#fff;box-shadow:0 1px 3px rgba(15,45,68,.18)}
.panel-actions .scope-switch{margin-right:8px}
.contractor-task-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.contractor-task-center .task-total-card b{color:#d64545}
@media(max-width:760px){
  .scope-switch{width:100%}
  .scope-switch button{flex:1}
  .panel-actions .scope-switch{margin:0 0 8px}
  .contractor-task-grid{grid-template-columns:1fr}
}
.manager-approval-table td{text-align:center}
.manager-approval-table td:first-child{text-align:left}
.manager-approval-table td:first-child .mini{display:block;margin-top:3px}
.ok-text{color:#059669}
.bad-text{color:#e11d48}
.table.dash-recent{font-size:13px}
.stats-help{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:14px}
.stats-help .mini{margin:4px 0}
.filter-bar{background:var(--surface);padding:16px 18px;border-radius:var(--radius-lg);margin-bottom:16px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.filter-bar label{font-size:12px;color:var(--muted);font-weight:500;display:flex;flex-direction:column;gap:5px}
.filter-bar input,.filter-bar select{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;min-width:140px}
.filter-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-left:auto;margin-top:14px;width:100%;justify-content:flex-end}
.filter-actions .btn-ghost,.filter-actions .btn-primary,.filter-actions .btn-ok,.filter-actions .btn-bad{min-width:96px}
.panel-actions .btn-ghost,.panel-actions .btn-primary,.panel-actions .btn-ok{min-width:96px}
.table-actions .btn-ghost,.table-actions .btn-primary,.table-actions .btn-bad{min-width:64px}
.filter-bar+.form-actions,.filter-bar+.stats-tip{margin-top:0}
.filter-in-panel.filter-bar{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}

/* Map & photos */
.mapbox{height:360px;border-radius:var(--radius);overflow:hidden;background:#dfe7f2;position:relative;margin:12px 0;border:1px solid var(--border)}
.map-canvas{position:absolute;inset:0;background:linear-gradient(45deg,#e7eef8 25%,#f8fbff 25%,#f8fbff 50%,#e7eef8 50%,#e7eef8 75%,#f8fbff 75%);background-size:36px 36px;cursor:crosshair}
.poly{position:absolute;inset:0;pointer-events:none}
.map-hint{font-size:12px;color:var(--muted);margin-top:6px}
.real-map-host{width:100%;height:560px;min-height:520px;border-radius:12px;border:1px solid var(--border);background:#e8eef5}
.map-badge{display:inline-block;padding:4px 10px;border-radius:8px;font-size:12px;background:var(--primary-light);color:var(--primary);margin-bottom:8px;font-weight:500}
.map-preview-canvas{width:100%;height:220px;border-radius:12px;background:#e8eef5;display:block;border:1px solid var(--border)}
.overview-toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:12px}
.overview-toolbar label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted)}
.overview-toolbar input,.overview-toolbar select{min-width:220px;padding:9px 11px;border:1px solid var(--border);border-radius:8px;background:#fff}
.overview-summary{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;padding:11px 13px;margin-bottom:12px;background:#f5f9fc;border:1px solid var(--border);border-radius:8px}
.overview-summary span{font-size:12px;color:var(--muted)}
.map-legend{display:flex;flex-wrap:wrap;gap:18px;margin-top:10px;font-size:12px;color:var(--muted)}
.map-legend span{display:inline-flex;align-items:center;gap:6px}
.map-legend i{width:18px;height:10px;border-radius:2px;display:inline-block}
.legend-active{background:rgba(0,184,115,.32);border:2px solid #00a86b}
.legend-other{background:rgba(100,116,139,.12);border:2px solid #94a3b8}
.legend-checkin-inside{background:#16a34a;border:2px solid #fff;box-shadow:0 0 0 1px #16a34a}
.legend-checkin-outside{background:#dc2626;border:2px solid #fff;box-shadow:0 0 0 1px #dc2626}
.legend-checkin-uncertain{background:#f59e0b;border:2px solid #fff;box-shadow:0 0 0 1px #f59e0b}
.legend-fence{background:rgba(6,182,212,.22);border:2px solid #22d3ee}
.region-map-label{background:rgba(255,255,255,.84);border:1px solid #64748b;color:#475569;border-radius:6px;padding:3px 7px;font-weight:500;box-shadow:none}
.region-map-label.active{border-color:#00a86b;color:#087f5b;font-weight:700;background:rgba(255,255,255,.96)}
.checkin-map-summary{display:flex;flex-wrap:wrap;gap:8px 18px;margin:-4px 0 12px;font-size:12px;color:var(--muted)}
.checkin-map-layout{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(300px,.7fr);gap:16px;align-items:start}
.checkin-map-canvas-wrap{min-width:0}
.checkin-map-list{max-height:560px;overflow:auto;border:1px solid var(--border);border-radius:12px;background:#f8fafc;padding:8px}
.checkin-map-item{width:100%;display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:10px;align-items:center;padding:11px 10px;border:1px solid transparent;border-radius:9px;background:transparent;text-align:left;cursor:pointer;color:var(--text)}
.checkin-map-item:hover{background:#fff;border-color:#dbe5ef}
.checkin-map-item.active{background:#eef6ff;border-color:#93c5fd;box-shadow:0 0 0 1px rgba(37,99,235,.08)}
.checkin-map-item:disabled{cursor:not-allowed;opacity:.68}
.checkin-map-number,.checkin-number-marker{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:#fff;font-size:12px;font-weight:800;border:2px solid #fff;box-shadow:0 2px 8px rgba(15,23,42,.35)}
.checkin-map-number.inside{background:#16a34a}
.checkin-map-number.outside{background:#dc2626}
.checkin-map-number.uncertain{background:#f59e0b}
.checkin-map-item-main{display:flex;min-width:0;flex-direction:column;gap:3px}
.checkin-map-item-main b{font-size:13px}
.checkin-map-item-main span{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.checkin-number-icon{background:transparent!important;border:0!important}
.checkin-map-popup{display:flex;flex-direction:column;gap:5px;min-width:220px;padding:4px 2px;color:#1e293b;font-size:12px;line-height:1.45}
.checkin-map-popup b{font-size:14px}
.checkin-map-popup span{display:block}
.assignment-groups{display:grid;gap:14px}
.assignment-group{border:1px solid var(--border);border-radius:8px;padding:14px;background:#fbfdff}
.assignment-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.assignment-head>div{display:flex;align-items:baseline;gap:10px}
.assignment-head span,.assignment-person-info span{font-size:12px;color:var(--muted)}
.assignment-list{display:grid;gap:8px;margin-top:12px}
.assignment-person{display:grid;grid-template-columns:minmax(220px,1fr) minmax(420px,1.8fr);align-items:center;gap:14px;padding:11px 12px;background:#fff;border:1px solid var(--border);border-radius:8px}
.assignment-person-info{display:flex;flex-direction:column;gap:4px}
.assignment-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.assignment-actions select{min-width:180px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fff}
.inline-check{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);white-space:nowrap}
.risk-text{color:var(--danger)!important;font-weight:600}
@media(max-width:700px){.real-map-host{height:440px;min-height:420px}}
@media(max-width:760px){
  .overview-toolbar>*{width:100%}
  .overview-toolbar input,.overview-toolbar select{width:100%;min-width:0}
  .assignment-person{grid-template-columns:1fr}
  .assignment-actions{justify-content:flex-start}
  .assignment-actions select{width:100%}
  .region-overview-card{padding:14px}
  .checkin-map-layout{grid-template-columns:1fr}
  .checkin-map-list{max-height:360px}
}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:12px;margin-top:12px}
.photo-thumb{background:var(--surface);border-radius:12px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.photo-thumb img{width:100%;height:124px;object-fit:cover;display:block;cursor:pointer}
.photo-thumb .cap{padding:8px 10px;font-size:11px;color:var(--muted);line-height:1.4}
.no-photo{padding:28px;text-align:center;color:#94a3b8;background:#f8fafc;border-radius:12px;border:1px dashed var(--border);font-size:13px}
.map-pin-center{position:absolute;width:12px;height:12px;background:var(--primary);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(21,101,192,.25)}
.map-circle{position:absolute;border:2px solid rgba(21,101,192,.6);background:rgba(21,101,192,.12);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none}
.progress{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;min-width:80px}
.progress i{display:block;height:100%;background:var(--success)}
.approval-card{padding:14px;border:1px solid var(--border);border-radius:12px;margin-bottom:10px;background:#fafbfd}
.empty-state{text-align:center;padding:32px 20px;color:var(--muted)}
.empty-state svg{width:48px;height:48px;opacity:.35;margin-bottom:10px}

/* Legacy aliases */
.dash-stats{display:contents}
.dash-stat{display:none}
.todo-card{display:contents}

@media(max-width:900px){
  .admin-app{flex-direction:column}
  .admin-side{width:100%;min-width:0;min-height:auto}
  .admin-menu{display:flex;flex-wrap:nowrap;overflow-x:auto;padding:8px;gap:4px;-webkit-overflow-scrolling:touch}
  .admin-menu li{flex:0 0 auto;width:auto}
  .admin-menu-link{white-space:nowrap;padding:10px 14px}
  .admin-side-footer{display:none}
  .admin-main{padding:16px}
  .filter-actions{margin-left:0;width:100%}
}

/* 2026 UI refresh: stable operational interface */
:root{
  --primary:#1f4e79;
  --primary-dark:#163c5d;
  --primary-light:#e8f1f8;
  --accent:#0f766e;
  --sidebar:#172033;
  --sidebar-hover:rgba(255,255,255,.08);
  --sidebar-active:rgba(255,255,255,.12);
  --bg:#eef3f7;
  --surface:#fff;
  --surface-soft:#f7fafc;
  --text:#172033;
  --muted:#68768a;
  --border:#dce5ee;
  --success:#0f9f6e;
  --danger:#d64545;
  --warn:#c47a18;
  --radius:8px;
  --radius-lg:8px;
  --shadow:0 10px 28px rgba(20,42,70,.08);
  --shadow-sm:0 1px 2px rgba(20,42,70,.06),0 8px 18px rgba(20,42,70,.05);
}

html{background:var(--bg)}
body{background:var(--bg);color:var(--text);font-size:14px;letter-spacing:0}
::selection{background:#cfe3f3;color:#0f2d44}
a:hover{text-decoration:underline}

.login-page{
  align-items:stretch;
  justify-content:flex-start;
  padding:0;
  background:
    linear-gradient(90deg,rgba(14,39,63,.86),rgba(14,39,63,.62)),
    linear-gradient(135deg,#204d74 0%,#4f8f9b 52%,#dfeff0 100%);
}
.login-page::before{
  content:'';
  flex:1;
  min-height:100vh;
  background:
    linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,0)),
    repeating-linear-gradient(90deg,rgba(255,255,255,.06) 0 1px,transparent 1px 48px);
}
.login-card{
  width:420px;
  max-width:100%;
  min-height:100vh;
  border-radius:0;
  padding:72px 40px 40px;
  box-shadow:-18px 0 48px rgba(9,24,38,.18);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.login-brand{display:flex;align-items:center;margin-bottom:24px}
.login-logo{flex:0 0 auto;border-radius:8px;background:#1f4e79;box-shadow:none;margin:0}
.logo{font-size:26px;color:var(--text);letter-spacing:0}
.login-sub{font-size:13px;color:#607086;margin:7px 0 28px}
.login-form{display:grid;gap:12px}
.login-field{
  min-height:50px;
  display:flex;
  align-items:center;
  gap:11px;
  padding:0 14px;
  border:1px solid #d8e2ec;
  border-radius:8px;
  background:#fbfdff;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.login-field:focus-within{border-color:#1f4e79;background:#fff;box-shadow:0 0 0 3px rgba(31,78,121,.12)}
.login-field svg{width:19px;height:19px;flex:0 0 auto;color:#77889a}
.login-card .login-field input{
  flex:1;
  width:auto;
  min-width:0;
  height:48px;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.login-card .login-field input:focus{border:0;box-shadow:none}
.login-submit{min-height:48px;margin-top:2px;font-size:15px}
.login-submit svg{width:18px;height:18px}
.login-security{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  margin-top:22px;
  color:#8190a0;
  font-size:12px;
}
.login-security svg{width:15px;height:15px;color:#0f766e}
.login-record{
  margin-top:12px;
  text-align:center;
  font-size:12px;
  line-height:1.5;
}
.login-record a{color:#8190a0;text-decoration:none}
.login-record a:hover{color:#1f4e79;text-decoration:underline}

.btn-primary,.btn-ghost,.btn-ok,.btn-bad,.btn-outline,.btn-warn{
  border-radius:8px;
  min-height:38px;
  gap:6px;
  box-shadow:none;
}
.btn-primary{background:#1f4e79}
.btn-primary:hover:not(:disabled){background:#163c5d}
.btn-ghost{background:#edf3f8;color:#1f4e79}
.btn-ghost:hover{background:#dfeaf3}
.btn-outline{border-color:#b7cbdd!important;color:#1f4e79}
.btn-ok{background:#0f766e}
.btn-bad{background:#c94040}
.btn-warn{background:#ba6b12}
.btn-sm{min-height:30px;padding:6px 10px}

.admin-app{background:#eef3f7}
.admin-side{
  width:232px;
  min-width:232px;
  background:#172033;
  box-shadow:4px 0 18px rgba(23,32,51,.12);
}
.admin-brand{
  min-height:64px;
  display:flex;
  align-items:center;
  padding:18px 18px;
  font-size:17px;
  letter-spacing:0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.admin-brand::before{
  content:'';
  width:28px;
  height:28px;
  margin-right:10px;
  border-radius:8px;
  background:linear-gradient(135deg,#69b7aa,#d7b46a);
  box-shadow:0 0 0 1px rgba(255,255,255,.16) inset;
}
.admin-menu{padding:12px 10px}
.admin-menu-link{
  min-height:42px;
  border-radius:8px;
  padding:10px 12px;
  color:rgba(255,255,255,.74)!important;
}
.admin-menu-link svg{width:17px;height:17px}
.admin-menu-link.active{
  background:#22304a!important;
  box-shadow:inset 3px 0 0 #69b7aa;
}
.admin-side-footer{padding:14px 10px 18px}
.admin-logout-btn{border-radius:8px;border-color:rgba(255,255,255,.18)}
.admin-body{background:#eef3f7}
.admin-top{
  min-height:64px;
  padding:14px 26px;
  box-shadow:none;
  position:sticky;
  top:0;
  z-index:20;
}
.admin-top h1{font-size:19px;letter-spacing:0}
.admin-breadcrumb{font-size:12px;color:#7b8797}
.admin-user-pill{border-radius:8px;background:#f7fafc;color:#39485b}
.admin-user-dot{
  width:24px;
  height:24px;
  background:linear-gradient(135deg,#1f4e79,#0f766e);
}
.btn-help,.btn-admin-logout{border-radius:8px}
.admin-main{padding:22px 26px 34px}

.panel,.card,.table-wrap,.filter-bar,.stat-card,.approval-card,.quick-tile,.m-card,.m-stats,.photo-thumb{
  border-radius:8px;
  box-shadow:var(--shadow-sm);
}
.panel,.card{border-color:#dbe5ee}
.panel-head{
  min-height:54px;
  padding:14px 18px;
  background:#fbfdff;
}
.panel-head h3{font-size:15px}
.panel-body,.card{padding:18px}
.card h3{font-size:15px}
.mini{color:#68768a}

.stat-grid{gap:12px}
.stat-card{
  padding:16px;
  align-items:center;
  background:linear-gradient(180deg,#fff,#fbfdff);
}
.stat-icon{
  width:40px;
  height:40px;
  border-radius:8px;
  font-size:17px;
}
.stat-card span{font-size:12px}
.stat-card b{font-size:26px}
.stat-purple .stat-icon{background:#eef2ff;color:#4453a3}
.stat-orange .stat-icon{background:#fff4e5;color:#ba6b12}
.stat-ref.stat-blue .stat-icon,.stat-blue .stat-icon{background:#e8f1f8;color:#1f4e79}
.stat-green .stat-icon{background:#e6f6f2;color:#0f766e}
.stat-red .stat-icon{background:#faeaea;color:#c94040}

.table-wrap{background:#fff;overflow:auto}
.table{font-size:13px}
.table th{
  position:sticky;
  top:0;
  z-index:1;
  background:#f3f7fb;
  color:#4d5d70;
  font-weight:700;
}
.table th,.table td{padding:11px 12px}
.table tbody tr:hover td{background:#f7fbff}
.table td.status-cell{min-width:52px}
.table-actions{gap:6px}

.filter-bar{
  padding:14px;
  gap:10px 12px;
  align-items:flex-end;
  background:#fbfdff;
}
.filter-bar label,.field label,.form-grid-labeled .field label{
  color:#536579;
  font-weight:650;
}
.filter-bar input,.filter-bar select,
.field input,.field select,.field textarea,
.form-grid input,.form-grid select,.form-grid textarea{
  border-radius:8px;
  border-color:#d8e2ec;
  background:#fff;
}
.filter-bar input:focus,.filter-bar select:focus,
.field input:focus,.field select:focus,.field textarea:focus,
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{
  border-color:#1f4e79;
  box-shadow:0 0 0 3px rgba(31,78,121,.12);
  outline:none;
}
.form-actions{border-top-color:#dce5ee}
.badge,.tag,.m-tag{border-radius:999px}

.mapbox,.real-map-host,.map-preview-canvas,.photo-preview,.photo-empty,.watermark{
  border-radius:8px;
}
.photo-empty{background:#f6f9fc}
.photo-empty::before{content:'PHOTO';border-radius:6px}
.photo-thumb img{height:132px}
.approval-card{background:#fbfdff}
.empty-state{background:#fbfdff;border:1px dashed #d7e1ec;border-radius:8px}

.photo-save-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(15,23,42,.72);
}
.photo-save-dialog{
  width:min(460px,100%);
  max-height:92vh;
  overflow:auto;
  padding:16px;
  border-radius:8px;
  background:#fff;
  box-shadow:0 20px 60px rgba(0,0,0,.28);
}
.photo-save-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:8px;
  font-size:17px;
}
.photo-save-head button{
  width:36px;
  height:36px;
  border:0;
  background:transparent;
  color:#536579;
  font-size:28px;
}
.photo-save-dialog p{margin:0 0 12px;color:#536579;line-height:1.6}
.photo-save-dialog img{display:block;width:100%;height:auto;border-radius:8px;background:#eef3f7}
.photo-save-actions{display:flex;gap:10px;margin-top:14px}
.photo-save-actions a,.photo-save-actions button{flex:1;text-align:center;text-decoration:none}
.live-camera-overlay{position:fixed;inset:0;z-index:10000;display:flex;flex-direction:column;background:#05080c;color:#fff}
.live-camera-head{height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#0b1118;font-size:17px}
.live-camera-head button{width:40px;height:40px;border:0;background:transparent;color:#fff;font-size:30px}
.live-camera-overlay video{width:100%;flex:1;min-height:0;object-fit:cover;background:#000}
.live-camera-actions{min-height:96px;display:grid;grid-template-columns:1fr 84px 1fr;gap:14px;align-items:center;padding:14px 18px calc(14px + env(safe-area-inset-bottom));background:#0b1118}
.live-camera-actions .btn-ghost{color:#fff;border-color:#52606d;background:#18222d}
.camera-shutter{width:68px;height:68px;margin:auto;border:6px solid #fff;border-radius:50%;background:#e8eef5;box-shadow:inset 0 0 0 4px #111827}

.mobile-app{
  max-width:480px;
  background:#edf3f7;
  box-shadow:0 0 0 1px rgba(20,42,70,.08);
}
.m-header{
  border-radius:0;
  padding:20px 18px 58px;
  background:linear-gradient(180deg,#1f4e79 0%,#2f6f8b 100%);
}
.m-header::after{
  right:-46px;
  top:-54px;
  width:168px;
  height:168px;
  background:rgba(255,255,255,.09);
}
.m-user{gap:12px}
.m-avatar{
  width:46px;
  height:46px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.36);
  background:rgba(255,255,255,.14);
}
.m-user b{font-size:18px}
.m-user span{font-size:12px}
.m-time{font-size:42px;letter-spacing:0;font-weight:300}
.m-date{font-size:13px}
.m-main{padding:0 14px 18px;margin-top:-34px}
.m-stats{
  padding:16px 12px;
  gap:8px;
  border:1px solid rgba(31,78,121,.08);
}
.m-stat b{font-size:25px}
.m-region-pill{
  border-radius:8px;
  background:#eef7f6;
  color:#0f766e;
}
.m-card{
  padding:15px 15px 15px 18px;
  border-color:#dce5ee;
}
.m-card::before{width:4px;border-radius:0}
.m-card-top span:first-child{font-size:16px}
.m-tabbar{
  border-top-color:#dce5ee;
  box-shadow:0 -8px 24px rgba(20,42,70,.08);
}
.m-tab{
  min-height:54px;
  color:#6b7788;
}
.m-tab.active{color:#1f4e79}
.m-tab svg{width:21px;height:21px}
.m-page-title{font-size:17px}

@media(max-width:900px){
  .login-page{
    display:flex;
    min-height:100dvh;
    padding:0;
    background:
      linear-gradient(180deg,rgba(239,247,250,.94) 0%,#f7fafc 42%,#fff 100%);
  }
  .login-page::before{
    display:block;
    position:absolute;
    inset:0 0 auto 0;
    min-height:250px;
    background:
      linear-gradient(135deg,rgba(31,78,121,.98),rgba(15,118,110,.84)),
      repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 1px,transparent 1px 48px);
    clip-path:polygon(0 0,100% 0,100% 63%,0 100%);
  }
  .login-card{
    position:relative;
    z-index:1;
    width:calc(100% - 32px);
    max-width:430px;
    min-height:0;
    margin:auto;
    padding:30px 24px 24px;
    border:1px solid rgba(255,255,255,.86);
    border-radius:8px;
    box-shadow:0 18px 48px rgba(22,60,93,.15);
    justify-content:flex-start;
  }
  .login-brand{margin-bottom:26px}
  .login-logo{
    width:54px;
    height:54px;
    background:linear-gradient(145deg,#1f4e79,#2c6f88);
  }
  .logo{font-size:27px;line-height:1.3}
  .login-sub{margin:8px 0 28px}
  .login-field{min-height:52px}
  .login-card .login-field input{height:50px;font-size:16px}
  .login-submit{min-height:50px}
  .admin-side{
    width:100%;
    min-width:0;
  }
  .admin-top{
    position:static;
    padding:12px 14px;
    align-items:flex-start;
    gap:10px;
  }
  .admin-top-right{gap:8px;flex-wrap:wrap;justify-content:flex-end}
  .admin-user-pill{max-width:180px}
  .admin-main{padding:14px}
  .admin-menu{background:#172033}
  .admin-menu-link.active{box-shadow:inset 0 -3px 0 #69b7aa}
  .admin-submenu-link{padding-left:30px}
  .panel-body,.card{padding:14px}
  .filter-bar{display:grid;grid-template-columns:1fr;align-items:stretch}
  .filter-bar input,.filter-bar select{width:100%;min-width:0}
  .filter-actions{justify-content:stretch}
  .filter-actions .btn-ghost,.filter-actions .btn-primary,.filter-actions .btn-ok,.filter-actions .btn-bad{flex:1}
  .stat-grid,.stat-grid-ref{grid-template-columns:repeat(2,minmax(0,1fr))}
  .table th,.table td{padding:10px 9px}
}

@media(max-width:420px){
  .login-page{align-items:stretch}
  .login-page::before{min-height:225px}
  .login-card{
    width:calc(100% - 32px);
    margin:calc(72px + env(safe-area-inset-top)) auto max(18px,env(safe-area-inset-bottom));
    padding:26px 20px 22px;
  }
  .login-brand{margin-bottom:24px}
  .login-logo{width:50px;height:50px}
  .login-logo svg{width:27px;height:27px}
  .logo{font-size:25px}
  .login-sub{font-size:12px;margin-bottom:24px}
  .m-main{padding-left:12px;padding-right:12px}
  .m-stats{display:grid;grid-template-columns:repeat(3,1fr)}
  .m-region-pill{grid-column:1 / -1;text-align:left}
  .m-time{font-size:38px}
  .stat-grid,.stat-grid-ref{grid-template-columns:1fr}
  .panel-head{align-items:flex-start;flex-direction:column}
}

.camera-fallback-overlay{position:fixed;inset:0;z-index:10020;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(4,15,25,.72)}
.camera-fallback-dialog{width:min(430px,100%);padding:22px;background:#fff;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.28)}
.camera-fallback-dialog h3{margin:0 0 12px;font-size:20px;color:#12283a}
.camera-fallback-dialog p{margin:8px 0;line-height:1.65;color:#425466}
.camera-fallback-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;flex-wrap:wrap}
@media(max-width:520px){.camera-fallback-actions{display:grid;grid-template-columns:1fr}.camera-fallback-actions button{width:100%}}
