/* ============================================
   근태킹 - 모바일 앱 스타일
   ============================================ */
:root {
  --primary: #2563eb;
  --primary-dark: #1d4ed8;
  --primary-light: #dbeafe;
  --accent: #f97316;
  --success: #16a34a;
  --success-light: #dcfce7;
  --warning: #d97706;
  --warning-light: #fef3c7;
  --danger: #dc2626;
  --danger-light: #fee2e2;
  --bg: #fff;
  --bg2: #f8fafc;
  --bg3: #f1f5f9;
  --border: #e5e7eb;
  --border-light: #f3f4f6;
  --t1: #111827;
  --t2: #6b7280;
  --t3: #9ca3af;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,.10),0 2px 6px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 40px rgba(0,0,0,.14);
  --r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:9999px;
  --font:'Apple SD Gothic Neo',-apple-system,BlinkMacSystemFont,'Noto Sans KR',system-ui,sans-serif;
  --tab-h:64px;--bar-h:56px;
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;-webkit-text-size-adjust:100%}
body{font-family:var(--font);font-size:15px;line-height:1.5;color:var(--t1);
  background:var(--bg2);height:100%;overflow:hidden;display:flex;
  justify-content:center;align-items:stretch}

#app,.login-screen{
  width:100%;max-width:500px;margin:0 auto;height:100dvh;height:100vh;
  background:var(--bg);display:flex;flex-direction:column;overflow:hidden;
  box-shadow:var(--shadow-lg);position:relative;
}
@media(min-width:520px){
  body::before{content:'';position:fixed;inset:0;
    background:linear-gradient(135deg,#e0e7ff 0%,#dbeafe 50%,#e0f2fe 100%);z-index:-1}
}

.hidden{display:none!important}

/* ---- Appbar ---- */
.app-bar{
  height:calc(var(--bar-h) + var(--safe-t));padding-top:var(--safe-t);
  background:var(--bg);border-bottom:1px solid var(--border-light);
  flex-shrink:0;z-index:10;
}
.app-bar-content{display:flex;align-items:center;justify-content:space-between;
  height:var(--bar-h);padding:0 20px}
.app-bar-title{font-size:18px;font-weight:700;letter-spacing:-.3px}

/* ---- Screen ---- */
.screen-container{flex:1;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:8px}
.screen-panel{padding:16px;min-height:100%}

/* ---- Tab bar ---- */
.tab-bar{
  height:calc(var(--tab-h) + var(--safe-b));padding-bottom:var(--safe-b);
  background:var(--bg);border-top:1px solid var(--border);
  display:flex;align-items:stretch;flex-shrink:0;z-index:10;
}
.tab-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:3px;cursor:pointer;border:none;
  background:transparent;padding:8px 2px;transition:all .15s;position:relative;
  user-select:none;
}
.tab-item:active{transform:scale(.92)}
.tab-icon{font-size:22px;transition:transform .15s;line-height:1}
.tab-label{font-size:10px;font-weight:500;color:var(--t3);transition:color .15s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.tab-item.active .tab-label{color:var(--primary);font-weight:700}
.tab-item.active .tab-icon{transform:translateY(-2px)}
.tab-item::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:0;height:2px;background:var(--primary);
  border-radius:0 0 var(--r-sm) var(--r-sm);transition:width .2s}
.tab-item.active::after{width:28px}

/* ---- Login ---- */
.login-screen{
  background:linear-gradient(160deg,#eff6ff 0%,#fff 60%);
  justify-content:center;align-items:center;
}
.login-container{display:flex;flex-direction:column;align-items:center;
  justify-content:center;height:100%;padding:40px 32px;gap:32px}
.login-logo{text-align:center}
.login-logo-icon{font-size:72px;line-height:1;margin-bottom:16px;
  filter:drop-shadow(0 4px 12px rgba(37,99,235,.3))}
.login-title{font-size:36px;font-weight:800;color:var(--primary);
  letter-spacing:-1px;margin-bottom:8px}
.login-subtitle{font-size:14px;color:var(--t2)}
.login-card{width:100%;background:var(--bg);border-radius:var(--r-xl);
  padding:28px 24px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:16px}
.login-hint{font-size:12px;color:var(--t3);text-align:center}

/* ---- Inputs ---- */
.input-label{display:block;font-size:13px;font-weight:600;color:var(--t2);margin-bottom:8px}
.input-field{
  width:100%;height:52px;padding:0 16px;font-family:var(--font);font-size:15px;
  color:var(--t1);background:var(--bg2);border:1.5px solid var(--border);
  border-radius:var(--r-md);outline:none;transition:border-color .15s,box-shadow .15s;
  -webkit-appearance:none;appearance:none;
}
.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.12);background:var(--bg)}
.input-field::placeholder{color:var(--t3)}
.date-field{cursor:pointer}
.select-wrapper{position:relative}
.select-field{padding-right:40px;cursor:pointer}
.select-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--t2);pointer-events:none;font-size:14px}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:52px;padding:0 24px;font-family:var(--font);font-size:15px;font-weight:700;
  border:none;border-radius:var(--r-md);cursor:pointer;transition:all .15s;
  letter-spacing:-.2px;white-space:nowrap;user-select:none;-webkit-appearance:none;
}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}
.btn-full{width:100%}
.btn-sm{height:40px;font-size:14px;padding:0 16px}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 12px rgba(37,99,235,.3)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:var(--bg2);color:var(--t1);border:1.5px solid var(--border)}
.btn-secondary:hover{background:var(--bg3)}
.btn-ghost{background:transparent;color:var(--t2)}
.btn-ghost:hover{background:var(--bg2)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#b91c1c}
.btn-checkin{width:100%;height:68px;font-size:18px;border-radius:var(--r-lg);
  letter-spacing:-.3px;box-shadow:var(--shadow-md)}
.btn-check-in{background:var(--primary);color:#fff;box-shadow:0 4px 20px rgba(37,99,235,.35)}
.btn-check-out{background:var(--accent);color:#fff;box-shadow:0 4px 20px rgba(249,115,22,.35)}
.btn-complete{background:var(--bg3);color:var(--t3);box-shadow:none;cursor:not-allowed}
.btn-icon-only{
  width:40px;height:40px;border-radius:var(--r-full);border:1.5px solid var(--border);
  background:var(--bg);display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .15s;font-size:18px;color:var(--t2);
}
.btn-icon-only:active{transform:scale(.88)}

/* ---- Cards ---- */
.section-card{background:var(--bg);border-radius:var(--r-lg);padding:16px;
  margin-bottom:12px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}
.section-title{font-size:15px;font-weight:700;color:var(--t1)}

/* ---- Checkin ---- */
.checkin-header{margin-bottom:16px;padding:4px 4px 8px}
.checkin-date{font-size:13px;color:var(--t2);margin-bottom:4px}
.checkin-greeting{font-size:20px;font-weight:700;letter-spacing:-.4px}
.map-container{background:var(--bg3);border-radius:var(--r-lg);overflow:hidden;
  margin-bottom:12px;position:relative;box-shadow:var(--shadow-sm);
  border:1px solid var(--border-light)}
#map{width:100%;height:240px;background:#e5e7eb}
.map-overlay{
  position:absolute;bottom:12px;left:12px;right:12px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-radius:var(--r-md);padding:10px 14px;display:flex;align-items:center;gap:8px;
  font-size:14px;font-weight:600;box-shadow:var(--shadow-sm);border:1px solid rgba(255,255,255,.8);
}
.checkin-action{padding:4px 0 8px}
.checkin-status-text{text-align:center;font-size:13px;color:var(--t2);margin-top:10px}

/* ---- Records ---- */
.records-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.records-list{display:flex;flex-direction:column;gap:10px}
.record-card{background:var(--bg);border-radius:var(--r-lg);padding:16px;
  box-shadow:var(--shadow-sm);border:1px solid var(--border-light);animation:fadeIn .2s}
.record-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.record-date{font-size:14px;font-weight:700}
.record-hospital{font-size:12px;color:var(--primary);font-weight:600;
  background:var(--primary-light);padding:3px 10px;border-radius:var(--r-full)}
.record-times{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.record-time-item{text-align:center}
.record-time-label{font-size:11px;color:var(--t3);font-weight:500;margin-bottom:3px}
.record-time-value{font-size:14px;font-weight:700}
.c-success{color:var(--success)}.c-accent{color:var(--accent)}.c-muted{color:var(--t3)}

/* ---- Hospitals ---- */
.hospitals-map-container{position:relative;border-radius:var(--r-lg);overflow:hidden;
  margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}
#hospitals-map{width:100%;height:280px}
.map-hint-overlay{position:absolute;top:12px;left:50%;transform:translateX(-50%);
  background:rgba(37,99,235,.9);color:#fff;font-size:12px;font-weight:600;
  padding:6px 14px;border-radius:var(--r-full);white-space:nowrap;pointer-events:none}
.hospitals-list-container{background:var(--bg);border-radius:var(--r-lg);
  border:1px solid var(--border-light);overflow:hidden;box-shadow:var(--shadow-sm)}
.hospitals-list-header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 16px 12px;border-bottom:1px solid var(--border-light)}
.badge{background:var(--primary-light);color:var(--primary);font-size:12px;
  font-weight:700;padding:3px 10px;border-radius:var(--r-full)}
.hospitals-list{max-height:240px;overflow-y:auto}
.hospital-item{display:flex;align-items:center;padding:14px 16px;
  border-bottom:1px solid var(--border-light);gap:12px;animation:fadeIn .2s}
.hospital-item:last-child{border-bottom:none}
.hospital-item-icon{width:40px;height:40px;border-radius:var(--r-md);
  background:var(--primary-light);display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0}
.hospital-item-info{flex:1;min-width:0}
.hospital-item-name{font-size:14px;font-weight:700;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.hospital-item-coords{font-size:11px;color:var(--t3);margin-top:2px}
.hospital-item-actions{display:flex;gap:6px}
.btn-action{height:34px;padding:0 12px;font-size:12px;font-weight:600;
  border-radius:var(--r-sm);border:1.5px solid var(--border);
  background:var(--bg2);color:var(--t2);cursor:pointer;transition:all .15s}
.btn-action.danger{border-color:var(--danger);color:var(--danger)}
.btn-action.danger:hover{background:var(--danger-light)}

/* ---- Dashboard ---- */
.dashboard-controls{display:flex;gap:10px;align-items:flex-end;margin-bottom:16px}
.date-picker-wrapper{flex:1}
.dashboard-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.summary-card{background:var(--bg);border-radius:var(--r-md);padding:12px 8px;
  text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}
.summary-card.success{background:var(--success-light);border-color:#bbf7d0}
.summary-card.warning{background:var(--warning-light);border-color:#fde68a}
.summary-card.danger{background:var(--danger-light);border-color:#fecaca}
.summary-num{display:block;font-size:22px;font-weight:800;letter-spacing:-.5px;line-height:1.2}
.summary-card.success .summary-num{color:var(--success)}
.summary-card.warning .summary-num{color:var(--warning)}
.summary-card.danger .summary-num{color:var(--danger)}
.summary-label{font-size:10px;font-weight:600;color:var(--t2);margin-top:3px;display:block}
.table-container{background:var(--bg);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{background:var(--bg2);padding:10px 12px;text-align:left;
  font-size:11px;font-weight:700;color:var(--t2);
  border-bottom:1px solid var(--border);white-space:nowrap}
.data-table td{padding:12px 12px;border-bottom:1px solid var(--border-light);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg2)}
.status-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;
  font-weight:700;padding:3px 8px;border-radius:var(--r-full);white-space:nowrap}
.status-badge.normal{background:var(--success-light);color:var(--success)}
.status-badge.ongoing{background:var(--warning-light);color:var(--warning)}
.status-badge.absent{background:var(--danger-light);color:var(--danger)}

/* ---- Settings ---- */
#screen-settings{display:flex;flex-direction:column;gap:16px;padding-bottom:32px}
.settings-profile{display:flex;flex-direction:column;align-items:center;
  padding:32px 16px 24px;gap:10px}
.profile-avatar{width:72px;height:72px;border-radius:50%;background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;font-size:36px;
  box-shadow:0 0 0 4px #fff,0 0 0 6px var(--primary-light)}
.profile-name{font-size:20px;font-weight:800;letter-spacing:-.4px}
.profile-badge{font-size:12px;font-weight:600;background:var(--primary);color:#fff;
  padding:3px 12px;border-radius:var(--r-full)}
.settings-group{background:var(--bg);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}
.settings-group-title{font-size:12px;font-weight:700;color:var(--t3);
  padding:14px 16px 8px;letter-spacing:.5px;text-transform:uppercase}
.settings-item{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid var(--border-light)}
.settings-item:last-child{border-bottom:none}
.settings-item-label{font-size:14px;color:var(--t1);font-weight:500}
.settings-item-value{font-size:14px;color:var(--t2)}
.settings-group .btn-full{margin:16px}
.settings-group .btn-danger.btn-full{width:calc(100% - 32px)}

/* ---- Modal ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);
  display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s}
.modal-card{width:100%;max-width:500px;background:var(--bg);
  border-radius:var(--r-xl) var(--r-xl) 0 0;padding:24px 24px 32px;
  display:flex;flex-direction:column;gap:12px;
  animation:slideUp .25s cubic-bezier(.4,0,.2,1)}
.modal-title{font-size:18px;font-weight:800;letter-spacing:-.3px}
.modal-subtitle{font-size:13px;color:var(--t2);margin-top:-4px}
.modal-actions{display:flex;gap:10px;margin-top:4px}
.modal-actions .btn{flex:1}

/* ---- Toast ---- */
.toast-container{position:fixed;top:calc(var(--bar-h) + var(--safe-t) + 12px);
  left:50%;transform:translateX(-50%);z-index:2000;
  display:flex;flex-direction:column;gap:8px;pointer-events:none;
  width:calc(100% - 32px);max-width:468px}
.toast{padding:13px 16px;border-radius:var(--r-lg);font-size:14px;font-weight:600;
  display:flex;align-items:center;gap:9px;box-shadow:var(--shadow-md);
  animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);pointer-events:all;
  border:1.5px solid transparent}
.toast.success{background:var(--success-light);color:var(--success);border-color:#bbf7d0}
.toast.error{background:var(--danger-light);color:var(--danger);border-color:#fecaca}
.toast.info{background:var(--primary-light);color:var(--primary);border-color:#bfdbfe}
.toast.warning{background:var(--warning-light);color:var(--warning);border-color:#fde68a}
.toast-out{animation:toastOut .25s ease forwards}

/* ---- Loading ---- */
.loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.85);
  backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;
  z-index:3000;animation:fadeIn .15s}
.loading-card{display:flex;flex-direction:column;align-items:center;gap:16px;
  background:#fff;padding:32px 40px;border-radius:var(--r-xl);box-shadow:var(--shadow-lg)}
.loading-card p{font-size:14px;font-weight:600;color:var(--t2)}
.spinner{width:28px;height:28px;border:3px solid var(--border);
  border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}
.spinner-lg{width:44px;height:44px;border-width:4px}

/* ---- Empty/Loading state ---- */
.empty-state,.loading-state{display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:48px 24px;gap:10px;text-align:center}
.empty-icon{font-size:48px;opacity:.45}
.empty-state p,.loading-state p{font-size:14px;color:var(--t2);font-weight:600}
.empty-hint{color:var(--t3)!important;font-weight:400!important;font-size:12px!important}

/* ---- Leaflet custom ---- */
.leaflet-control-attribution{font-size:9px!important}
.cur-loc-dot{width:14px;height:14px;border-radius:50%;background:#3b82f6;
  border:3px solid #fff;box-shadow:0 0 0 4px rgba(59,130,246,.3);
  animation:pulse 2s ease-in-out infinite}

/* ---- Animations ---- */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes toastIn{from{opacity:0;transform:translateY(-12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;transform:scale(.94)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(59,130,246,.3)}50%{box-shadow:0 0 0 10px rgba(59,130,246,0)}}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
html, body {
  height: auto;
  min-height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

body {
  position: static;
}

.app,
.screen-container,
.screen-panel {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
