/* ============================================================
   BDR Check-In — app.css
   ============================================================ */

:root {
  --sky:     #4F8EF7; --sky-2:    #2563EB;
  --mint:    #10B981; --mint-2:   #059669;
  --amber:   #F59E0B; --amber-2:  #D97706;
  --red:     #EF4444; --red-2:    #DC2626;
  --purple:  #8B5CF6;
  --bg:      #F0F4FA; --surface:  #FFFFFF;
  --border:  #E5E7EB; --border-2: #D1D5DB;
  --text-1:  #111827; --text-2: #374151; --text-3: #6B7280; --text-4: #9CA3AF;
  --radius:  14px; --radius-lg: 20px; --radius-xl: 28px;
  --nav-h:   60px; --tab-h: 68px;
  --safe-b:  env(safe-area-inset-bottom, 0px);
}

*, *::before, *::after {
  margin: 0; padding: 0; box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}
html { scroll-behavior: smooth; height: 100%; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--bg); color: var(--text-1);
  min-height: 100dvh; overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* BG orbs */
.orb { position:fixed; border-radius:50%; pointer-events:none; z-index:0; filter:blur(90px); }
.orb-1 { width:400px; height:400px; background:radial-gradient(circle,#BFDBFE,transparent 70%); top:-100px; right:-80px; opacity:.5; }
.orb-2 { width:350px; height:350px; background:radial-gradient(circle,#A7F3D0,transparent 70%); bottom:-80px; left:-60px; opacity:.4; }

/* Pages */
.page { display:none; min-height:100dvh; position:relative; z-index:1; }
.page.active { display:flex; flex-direction:column; }
[v-cloak] { display:none; }

/* Card */
.card {
  background: var(--surface); border:1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.03);
}

/* Loading */
.loading-screen {
  position:fixed; inset:0; background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  z-index:999; flex-direction:column; gap:12px;
}
.loader {
  width:36px; height:36px;
  border:3px solid #DBEAFE; border-top-color:#2563EB;
  border-radius:50%; animation:spin .7s linear infinite;
}

/* Topnav */
.topnav {
  height: var(--nav-h); padding:0 16px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(255,255,255,.92); border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  position:sticky; top:0; z-index:100; flex-shrink:0;
}
.topnav-brand { display:flex; align-items:center; gap:10px; }
.topnav-icon { width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:15px; color:#fff; flex-shrink:0; }
.topnav-name { font-family:'Inter',sans-serif; font-size:15px; font-weight:700; color:var(--text-1); white-space:nowrap; }

/* User menu */
.user-menu-wrap { position:relative; }
.user-menu-btn { display:flex; align-items:center; padding:4px; background:transparent; border:none; cursor:pointer; border-radius:99px; transition:background .15s; }
.user-menu-btn:hover { background:rgba(0,0,0,.05); }
.user-avatar { width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Inter',sans-serif; font-size:13px; font-weight:800; color:#fff; flex-shrink:0; cursor:pointer; }
.user-dropdown { position:absolute; top:calc(100% + 8px); right:0; min-width:210px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); box-shadow:0 8px 24px rgba(0,0,0,.12); overflow:hidden; z-index:200; animation:dropIn .15s ease; }
@keyframes dropIn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.dropdown-header { padding:14px 16px; background:#F9FAFB; border-bottom:1px solid var(--border); }
.dropdown-name { font-size:14px; font-weight:700; color:var(--text-1); }
.dropdown-email { font-size:12px; color:var(--text-3); margin-top:2px; }
.dropdown-role { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; padding:2px 8px; border-radius:99px; margin-top:5px; }
.dropdown-item { display:flex; align-items:center; gap:10px; padding:12px 16px; font-size:14px; color:var(--text-2); cursor:pointer; transition:background .12s; border:none; background:none; width:100%; text-align:left; }
.dropdown-item:hover { background:#F9FAFB; }
.dropdown-item i { width:16px; text-align:center; color:var(--text-3); }
.dropdown-item.danger { color:var(--red-2); }
.dropdown-item.danger i { color:var(--red-2); }
.dropdown-item.danger:hover { background:#FEF2F2; }
.dropdown-divider { height:1px; background:var(--border); }

/* Scroll content */
.scroll-content { flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:18px 16px calc(var(--tab-h) + var(--safe-b) + 8px); }

/* Forms */
.field { margin-bottom:14px; }
.field-label { display:block; font-size:11px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:7px; }
.field-input { width:100%; padding:12px 14px; background:var(--surface); border:1.5px solid var(--border-2); border-radius:12px; color:var(--text-1) !important; font-family:'DM Sans',sans-serif; font-size:15px; transition:border-color .2s,box-shadow .2s; outline:none; }
.field-input:focus { border-color:var(--sky-2); box-shadow:0 0 0 3px rgba(37,99,235,.1); }
.field-input::placeholder { color:var(--text-4); }
input, textarea { color:var(--text-1) !important; }
textarea.field-input { min-height:85px; resize:vertical; line-height:1.5; }
select.field-input { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; padding:12px 20px; border:none; border-radius:12px; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:500; cursor:pointer; transition:all .16s; }
.btn-block { width:100%; }
.btn-sm { padding:8px 14px; font-size:13px; border-radius:10px; }
.btn-primary { background:linear-gradient(135deg, var(--sky) 0%, var(--purple) 100%); color:#fff; box-shadow:0 4px 16px rgba(79,142,247,.35); }
.btn-primary:hover:not(:disabled) { transform:translateY(-1px); box-shadow:0 8px 24px rgba(79,142,247,.45); }
.btn-checkin { background:linear-gradient(135deg,#10B981 0%,#059669 100%); color:#fff; font-size:16px; font-weight:600; padding:16px; border-radius:14px; box-shadow:0 4px 20px rgba(16,185,129,.3); }
.btn-checkin:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 8px 28px rgba(16,185,129,.4); }
.btn-ghost { background:#F3F4F6; border:1px solid var(--border); color:var(--text-2); }
.btn-ghost:hover { background:#E5E7EB; }
.btn-gps { background:rgba(79,142,247,.08); border:1px solid rgba(79,142,247,.25); color:var(--sky-2); border-radius:12px; }
.btn-gps:hover { background:rgba(79,142,247,.14); }
.btn-export { background:rgba(245,158,11,.08); border:1px solid rgba(245,158,11,.3); color:#92400E; }
.btn-export:hover { background:rgba(245,158,11,.14); }
.btn-pdf { background:rgba(220,38,38,.08); border:1px solid rgba(220,38,38,.25); color:#991B1B; }
.btn-pdf:hover { background:rgba(220,38,38,.13); }
.btn:disabled { opacity:.4; cursor:not-allowed; transform:none !important; }

/* Alerts */
.alert { display:flex; align-items:flex-start; gap:9px; padding:11px 14px; border-radius:11px; font-size:13px; line-height:1.5; margin-bottom:14px; }
.alert i { margin-top:1px; flex-shrink:0; }
.alert-error   { background:#FEF2F2; border:1px solid #FECACA; color:#991B1B; }
.alert-success { background:#F0FDF4; border:1px solid #BBF7D0; color:#14532D; }
.alert-info    { background:#EFF6FF; border:1px solid #BFDBFE; color:#1E3A8A; }

/* Section title */
.section-title { font-family:'Inter',sans-serif; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--text-3); margin-bottom:16px; display:flex; align-items:center; gap:7px; }

/* Stat grid */
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:16px; }
.stat-card { padding:16px 14px; position:relative; overflow:hidden; }
.stat-label { font-size:10px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.1em; margin-bottom:8px; display:flex; align-items:center; gap:5px; }
.stat-value { font-family:'DM Mono',monospace; font-size:30px; font-weight:600; line-height:1; letter-spacing:-.5px; }
.stat-sub { font-size:11px; color:var(--text-4); margin-top:5px; }
.v-sky { color:var(--sky-2); } .v-mint { color:var(--mint-2); } .v-amber { color:var(--amber-2); } .v-red { color:var(--red-2); }

/* Progress */
.progress-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.progress-label { font-size:12px; font-weight:500; color:var(--text-3); }
.progress-count { font-family:'DM Mono',monospace; font-size:13px; font-weight:600; color:var(--sky-2); }
.progress-track { height:5px; background:#E5E7EB; border-radius:99px; overflow:hidden; }
.progress-fill  { height:100%; background:linear-gradient(90deg,var(--sky),var(--mint)); border-radius:99px; transition:width .6s cubic-bezier(.34,1.56,.64,1); }

/* Location box */
.loc-box { padding:12px 14px; margin-bottom:12px; background:rgba(79,142,247,.06); border:1px solid rgba(79,142,247,.2); border-radius:11px; }
.loc-header { display:flex; align-items:center; gap:6px; margin-bottom:4px; }
.loc-dot { width:6px; height:6px; background:#2563EB; border-radius:50%; animation:pulse 2s infinite; }
.loc-tag { font-size:10px; text-transform:uppercase; letter-spacing:.1em; color:#2563EB; font-weight:700; }
.loc-addr { font-size:12px; color:#1E3A5F; line-height:1.5; }
.loc-coords { font-family:'DM Mono',monospace; font-size:10px; color:var(--text-3); margin-top:3px; }

/* Next badge */
.next-badge { display:flex; align-items:center; gap:9px; padding:11px 14px; background:#FFFBEB; border:1px solid #FDE68A; border-radius:11px; margin-bottom:14px; font-size:13px; color:#92400E; }

/* History */
.hist-list { display:flex; flex-direction:column; gap:8px; }
.hist-item { display:grid; grid-template-columns:36px 1fr; gap:12px; align-items:start; padding:14px; background:#F9FAFB; border:1px solid var(--border); border-radius:13px; transition:border-color .15s; }
.hist-item:hover { border-color:var(--border-2); }
.hist-num { width:36px; height:36px; background:#EFF6FF; border:1px solid #BFDBFE; border-radius:9px; display:flex; align-items:center; justify-content:center; font-family:'DM Mono',monospace; font-size:12px; font-weight:600; color:#2563EB; }
.hist-time { font-family:'DM Mono',monospace; font-size:17px; font-weight:600; color:var(--mint-2); }
.hist-date { font-size:11px; color:var(--text-4); margin-left:8px; }
.hist-task { font-size:12px; color:var(--text-3); margin-top:4px; line-height:1.5; }
.hist-addr { font-size:11px; color:var(--text-4); margin-top:2px; }

/* Empty */
.empty { text-align:center; padding:36px 20px; }
.empty i { font-size:28px; color:var(--text-4); margin-bottom:10px; display:block; }
.empty-text { font-size:13px; color:var(--text-4); }

/* Bottom tabs */
.bottom-tabs, .admin-bottom-tabs {
  position:fixed; bottom:0; left:0; right:0; z-index:100;
  height:calc(var(--tab-h) + var(--safe-b));
  background:rgba(255,255,255,.95); border-top:1px solid var(--border);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  display:flex; padding-bottom:var(--safe-b);
}
.btab { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; border:none; background:none; cursor:pointer; color:var(--text-4); font-family:'Inter',sans-serif; font-size:10px; font-weight:600; transition:color .15s; padding:6px 0; }
.btab i { font-size:19px; transition:transform .15s; }
.btab.active { color:var(--sky-2); }
.btab.active i { transform:scale(1.1); }

/* Staff sub-views */
.sview { display:none; }
.sview.active { display:block; }

/* Admin tabs (top) */
.atabs { display:flex; gap:3px; background:#F3F4F6; border:1px solid var(--border); border-radius:13px; padding:4px; margin-bottom:16px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.atabs::-webkit-scrollbar { display:none; }
.atab { flex:0 0 auto; padding:9px 14px; border:none; border-radius:10px; background:none; color:var(--text-3); font-family:'Inter',sans-serif; font-size:12px; font-weight:600; cursor:pointer; transition:all .18s; display:flex; align-items:center; gap:5px; white-space:nowrap; }
.atab.active { background:var(--surface); color:var(--sky-2); box-shadow:0 1px 4px rgba(0,0,0,.1); }

/* Tables */
.tbl-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.tbl { width:100%; border-collapse:collapse; }
.tbl th { font-size:10px; text-transform:uppercase; letter-spacing:.1em; color:var(--text-4); font-weight:700; padding:8px 12px; text-align:left; border-bottom:1px solid var(--border); white-space:nowrap; }
.tbl td { padding:11px 12px; font-size:13px; border-bottom:1px solid var(--border); vertical-align:middle; color:var(--text-2); }
.tbl tr:last-child td { border-bottom:none; }
.tbl tr:hover td { background:#FAFAFA; }

/* Badges */
.badge { display:inline-flex; align-items:center; padding:2px 9px; border-radius:99px; font-size:11px; font-weight:600; white-space:nowrap; }
.badge-green  { background:#ECFDF5; color:#059669; border:1px solid #A7F3D0; }
.badge-red    { background:#FEF2F2; color:#DC2626; border:1px solid #FECACA; }
.badge-sky    { background:#EFF6FF; color:#2563EB; border:1px solid #BFDBFE; }
.badge-purple { background:#F5F3FF; color:#6D28D9; border:1px solid #DDD6FE; }
.badge-amber  { background:#FFFBEB; color:#92400E; border:1px solid #FDE68A; }

/* Compact activity */
.act-row { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:11px; transition:background .12s; }
.act-row:hover { background:#F9FAFB; }
.act-av { width:34px; height:34px; border-radius:9px; flex-shrink:0; background:#EFF6FF; border:1px solid #BFDBFE; display:flex; align-items:center; justify-content:center; font-family:'Inter',sans-serif; font-size:13px; font-weight:800; color:#2563EB; }
.act-name { font-size:13px; font-weight:600; color:var(--text-1); }
.act-task { font-size:11px; color:var(--text-4); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:160px; }
.act-time { font-family:'DM Mono',monospace; font-size:13px; font-weight:600; color:var(--mint-2); }

/* Grouped log */
.user-log-card { margin-bottom:10px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); background:var(--surface); box-shadow:0 1px 3px rgba(0,0,0,.04); }
.user-log-header { display:flex; align-items:center; gap:10px; padding:12px 14px; background:#F9FAFB; border-bottom:1px solid var(--border); cursor:pointer; user-select:none; }
.user-log-header:hover { background:#F3F4F6; }
.user-log-av { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-family:'Inter',sans-serif; font-size:13px; font-weight:800; color:#fff; flex-shrink:0; }
.user-log-name { font-size:13px; font-weight:700; color:var(--text-1); flex:1; }
.user-log-times { display:flex; flex-wrap:wrap; gap:4px; padding:10px 14px; }
.time-chip { display:inline-flex; align-items:center; gap:5px; padding:5px 10px; background:#F0FDF4; border:1px solid #BBF7D0; border-radius:99px; font-family:'DM Mono',monospace; font-size:12px; font-weight:600; color:#059669; cursor:pointer; transition:background .12s; }
.time-chip:hover { background:#DCFCE7; }
.time-chip-detail { font-size:11px; color:var(--text-4); padding:8px 14px 10px; border-top:1px solid var(--border); background:#FAFAFA; font-style:italic; line-height:1.5; }

/* Date & month filter */
.date-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.date-row label { font-size:12px; font-weight:600; color:var(--text-3); white-space:nowrap; }
.date-row input[type=date] { padding:8px 12px; border:1.5px solid var(--border-2); border-radius:10px; font-family:'DM Sans',sans-serif; font-size:13px; color:var(--text-1); background:var(--surface); outline:none; flex:1; min-width:130px; }
.date-row input[type=date]:focus { border-color:var(--sky-2); }
.month-row { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.month-row label { font-size:12px; font-weight:600; color:var(--text-3); white-space:nowrap; }
.month-row input[type=month] { padding:8px 12px; border:1.5px solid var(--border-2); border-radius:10px; font-family:'DM Sans',sans-serif; font-size:13px; color:var(--text-1); background:var(--surface); outline:none; }
.month-row input[type=month]:focus { border-color:var(--sky-2); }

/* Form grid */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* Profile */
.profile-card { display:flex; align-items:center; gap:14px; padding:16px; background:#F9FAFB; border-radius:14px; margin-bottom:20px; border:1px solid var(--border); }
.profile-av { width:50px; height:50px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-family:'Inter',sans-serif; font-size:22px; font-weight:800; color:#fff; flex-shrink:0; }
.profile-name { font-size:16px; font-weight:700; color:var(--text-1); }
.profile-email { font-size:13px; color:var(--text-3); margin-top:1px; }
.profile-un { font-size:11px; color:var(--text-4); margin-top:2px; }

/* Vue transitions */
.fade-enter-active, .fade-leave-active { transition:opacity .2s, transform .2s; }
.fade-enter-from { opacity:0; transform:translateY(6px); }
.fade-leave-to { opacity:0; transform:translateY(-4px); }

/* Login */
.login-page { min-height:100dvh; display:flex; align-items:center; justify-content:center; padding:20px; }
.login-card { width:100%; max-width:400px; background:var(--surface); border-radius:var(--radius-xl); padding:40px 32px; position:relative; overflow:hidden; box-shadow:0 4px 24px rgba(0,0,0,.08); border:1px solid var(--border); }
.login-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,rgba(37,99,235,.5),transparent); }
.login-brand { display:flex; align-items:center; gap:12px; margin-bottom:32px; }
.login-brand-icon { width:44px; height:44px; border-radius:12px; background:linear-gradient(135deg,var(--sky),var(--purple)); display:flex; align-items:center; justify-content:center; font-size:19px; color:#fff; box-shadow:0 6px 18px rgba(79,142,247,.3); }
.login-brand-name { font-family:'Inter',sans-serif; font-size:16px; font-weight:700; color:var(--text-1); }
.login-brand-sub { font-size:12px; color:var(--text-3); }
.login-heading { font-family:'Inter',sans-serif; font-size:28px; font-weight:800; letter-spacing:-.8px; line-height:1.15; color:var(--text-1); margin-bottom:6px; white-space:nowrap; }
.login-sub { font-size:14px; color:var(--text-3); margin-bottom:28px; }

/* PDF Modal */
.pdf-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:500; display:flex; align-items:center; justify-content:center; padding:16px; }
.pdf-modal { background:white; border-radius:16px; width:100%; max-width:700px; max-height:90vh; overflow-y:auto; box-shadow:0 20px 60px rgba(0,0,0,.2); }
.pdf-modal-header { display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--border); }
.pdf-modal-title { font-family:'Inter',sans-serif; font-size:16px; font-weight:700; color:var(--text-1); }
.pdf-close { width:30px; height:30px; display:flex; align-items:center; justify-content:center; border:none; background:#F3F4F6; border-radius:8px; cursor:pointer; font-size:14px; color:var(--text-3); }
.pdf-close:hover { background:#E5E7EB; }
.pdf-actions { display:flex; gap:8px; padding:14px 20px; border-top:1px solid var(--border); background:#F9FAFB; border-radius:0 0 16px 16px; }
.pdf-content { padding:24px 20px; }

/* PWA banner */
.pwa-banner { position:fixed; bottom:calc(var(--tab-h) + var(--safe-b) + 12px); left:12px; right:12px; background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:14px 16px; box-shadow:0 8px 24px rgba(0,0,0,.1); display:flex; align-items:center; gap:12px; z-index:150; animation:slideUp .3s ease; }
.pwa-banner.login-pos { bottom:16px; }
@keyframes slideUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.pwa-close { color:var(--text-4); cursor:pointer; padding:4px; font-size:14px; border:none; background:none; }

/* Spinner */
.spin { width:14px; height:14px; border:2px solid rgba(255,255,255,.3); border-top-color:currentColor; border-radius:50%; animation:spin .6s linear infinite; flex-shrink:0; }
.spin-dark { border-color:rgba(0,0,0,.1); border-top-color:var(--sky-2); }

/* Keyframes */
@keyframes spin  { to { transform:rotate(360deg); } }
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:.4; } }

/* Print (PDF) */
@media print {
  body * { visibility:hidden !important; }
  .pdf-print-area, .pdf-print-area * { visibility:visible !important; }
  .pdf-print-area { position:fixed; inset:0; background:white; z-index:9999; padding:20px; }
}

/* Responsive */
@media (min-width:640px) {
  .stat-grid { grid-template-columns:repeat(4,1fr); }
  .form-grid { grid-template-columns:1fr 1fr; }
  .scroll-content { padding-left:24px; padding-right:24px; }
  .topnav { padding:0 24px; }
}
@media (max-width:400px) {
  .login-heading { font-size:24px; }
}
