/* 친정찬 출퇴근 — 직원 앱 (시니어 우선 UX: 본문 17px+, 버튼 22px+, 터치 56px+, 애니메이션 없음) */
:root{
  --ink:#1C2433; --ink-soft:#4A5468; --bg:#F4F5F7; --card:#FFFFFF;
  --green:#157A46; --green-soft:#E5F3EC; --navy:#1F4E8C; --navy-soft:#E8EFF8;
  --amber:#A3630A; --amber-soft:#FBF0DC; --red:#B3372A; --red-soft:#F9E9E6;
  --line:#DDE0E6; --muted:#6E7686; --radius:14px;
  --font:-apple-system,'Apple SD Gothic Neo','Malgun Gothic','Noto Sans KR',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
button:focus-visible,select:focus-visible,input:focus-visible{outline:3px solid var(--navy);outline-offset:2px}
.num{font-variant-numeric:tabular-nums}

#loginView,#appView{display:flex;justify-content:center;padding:14px 10px 40px}
.phone{width:100%;max-width:440px;background:var(--card);border:1.5px solid var(--line);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;min-height:92vh}
.phone-head{padding:20px 22px 14px;border-bottom:1.5px solid var(--line)}
.phone-head .store{font-weight:700;font-size:21px}
.phone-head .who{font-size:15.5px;color:var(--ink-soft);margin-top:3px}
.phone-body{flex:1;overflow-y:auto;padding:18px 16px 26px}
.tabbar{display:flex;border-top:1.5px solid var(--line);background:var(--card)}
.tabbar button{flex:1;padding:16px 0 18px;font-size:17px;font-weight:700;color:var(--muted);min-height:60px}
.tabbar button.on{color:var(--ink);box-shadow:inset 0 4px 0 var(--navy)}

.card{background:var(--card);border:1.5px solid var(--line);border-radius:var(--radius);padding:20px}
.eyebrow{font-size:14px;font-weight:700;color:var(--muted);margin-bottom:8px}

.status-card{text-align:center;padding:24px 18px}
.st-line{font-size:20px;font-weight:700;margin-bottom:4px}
.st-line.working{color:var(--green)}
.st-line.alert{color:var(--red)}
.st-sub{font-size:16px;color:var(--ink-soft)}
.time-rows{margin-top:18px;border-top:1.5px solid var(--line)}
.time-row{display:flex;justify-content:space-between;align-items:center;padding:15px 4px;border-bottom:1.5px solid var(--line);font-size:17px}
.time-row .t-lbl{color:var(--ink-soft);font-weight:600}
.time-row .t-val{font-weight:700;font-size:18px}
.time-row .t-note{display:block;font-size:14px;color:var(--muted);font-weight:500;text-align:right;margin-top:2px}

.big-btn{display:block;width:100%;margin-top:22px;padding:24px 0;border-radius:16px;background:var(--navy);color:#fff;font-size:24px;font-weight:700;letter-spacing:1px;min-height:76px}
.big-btn:active{background:#173D6E}
.big-btn:disabled{background:#C6CAD2;cursor:default}
.big-btn.green{background:var(--green)}
.big-btn.green:active{background:#0E5230}
.btn-hint{text-align:center;font-size:15px;color:var(--muted);margin-top:10px;line-height:1.6}

.result-box{margin-top:22px;border-radius:14px;padding:20px;font-size:17px;line-height:1.7;text-align:left}
.result-box.ok{background:var(--green-soft);color:#0E5230;border:1.5px solid #BBDCC9}
.result-box.wait{background:var(--amber-soft);color:#6E4507;border:1.5px solid #EBD3A8}
.result-box.early,.result-box.late{background:var(--red-soft);color:#7C271D;border:1.5px solid #ECC4BD}
.result-box.err{background:var(--red-soft);color:#7C271D;border:1.5px solid #ECC4BD}
.result-box .r-title{font-size:19px;font-weight:700;margin-bottom:8px;display:block}

.overlay{position:fixed;inset:0;background:rgba(20,26,38,.65);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.overlay.show{display:flex}
.ov-card{background:var(--card);border-radius:18px;padding:28px 24px;width:100%;max-width:360px;text-align:center}
.ov-card .ttl{font-weight:700;font-size:22px;margin-bottom:8px}
.ov-card .dsc{font-size:16.5px;color:var(--ink-soft);line-height:1.6}
.ov-card .act{margin-top:20px;width:100%;padding:18px 0;border-radius:13px;background:var(--navy);color:#fff;font-weight:700;font-size:19px;min-height:60px}
.ov-card .act.ghost{background:var(--card);color:var(--ink-soft);border:1.5px solid var(--line)}
#qrVideo{width:100%;max-width:280px;border-radius:14px;margin-top:16px;background:#000;aspect-ratio:1/1;object-fit:cover}

.list-row{display:flex;justify-content:space-between;align-items:center;padding:16px 4px;border-bottom:1.5px solid var(--line);gap:10px}
.list-row:last-child{border-bottom:none}
.list-row .d1{font-weight:700;font-size:17px}
.list-row .d1 .today-tag{font-size:13px;color:var(--navy);background:var(--navy-soft);border-radius:6px;padding:2px 8px;margin-left:6px;vertical-align:2px}
.list-row .d2{font-size:15px;color:var(--muted);margin-top:2px}
.list-row .tm{font-weight:700;font-size:16.5px;text-align:right}

.badge{display:inline-flex;align-items:center;gap:6px;font-size:14.5px;font-weight:700;padding:6px 14px;border-radius:99px;white-space:nowrap}
.badge.ok{background:var(--green-soft);color:var(--green)}
.badge.warn{background:var(--amber-soft);color:var(--amber)}
.badge.alert{background:var(--red-soft);color:var(--red)}

.req-form{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.req-form select,.req-form input{padding:17px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:17.5px;font-family:inherit;background:var(--card);color:var(--ink);width:100%}
.req-form .send{padding:18px 0;border-radius:13px;background:var(--navy);color:#fff;font-weight:700;font-size:19px;min-height:60px}
.req-form .send:disabled{background:#C6CAD2}
.in-lbl{font-size:15.5px;font-weight:700;color:var(--ink-soft);margin-bottom:-4px}
.login-msg{margin-top:14px;font-size:16px;color:var(--red);line-height:1.6;text-align:center}
.login-msg.good{color:var(--green)}

.week-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}
.wk-btn{padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;font-weight:700;min-height:48px;background:var(--card)}

/* 홈 화면 추가 안내 바 */
#installBar{position:fixed;left:10px;right:10px;bottom:12px;z-index:90;display:flex;gap:8px;
            background:var(--navy);border-radius:14px;padding:8px;box-shadow:0 6px 22px rgba(28,36,51,.35)}
#installBtn{flex:1;color:#fff;font-size:17px;font-weight:700;padding:14px 8px;min-height:56px;text-align:center;line-height:1.5}
#installClose{flex:0 0 48px;color:rgba(255,255,255,.75);font-size:18px;font-weight:700}
