:root{--brand: #00b4d8;--brand-dark: #0091b0;--brand-ink: #033a47;--brand-soft: #e2f6fb;--ink: #14171c;--ink-2: #22272f;--muted: #616a76;--faint: #97a0ab;--bg: #f5f6f8;--surface: #ffffff;--surface-2: #f1f3f6;--border: #e7e9ee;--border-strong: #d6dae1;--danger: #e5484d;--danger-dark: #cf3439;--success: #17a34a;--warn: #f59e0b;--radius: 14px;--radius-sm: 10px;--ring: 0 0 0 3px rgba(0, 180, 216, .28);--shadow: 0 1px 2px rgba(16, 24, 40, .04), 0 1px 3px rgba(16, 24, 40, .05);--shadow-md: 0 6px 20px rgba(16, 24, 40, .08);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--maxw: 720px}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{-webkit-text-size-adjust:100%}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--font);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3{margin:0 0 .4em;line-height:1.25;font-weight:700;letter-spacing:-.012em}h1{font-size:1.4rem}h2{font-size:1.08rem}p{margin:0 0 .75em}a{color:var(--brand-dark);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--maxw);margin:0 auto;padding:16px;padding-bottom:calc(28px + env(safe-area-inset-bottom))}.container-sm{max-width:460px;margin:0 auto;padding:16px;padding-bottom:calc(28px + env(safe-area-inset-bottom))}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card+.card{margin-top:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:46px;padding:0 18px;font-family:inherit;font-size:15px;font-weight:600;line-height:1;border:1px solid transparent;border-radius:var(--radius-sm);background:var(--brand);color:var(--brand-ink);cursor:pointer;text-decoration:none;transition:background .15s ease,border-color .15s ease,transform .05s ease,box-shadow .15s ease,filter .15s ease}.btn:hover{background:var(--brand-dark);text-decoration:none}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn:disabled{opacity:.5;cursor:default;transform:none}.btn-lg{min-height:54px;font-size:17px;border-radius:12px}.btn-sm{min-height:38px;font-size:14px;padding:0 14px;width:auto}.btn-inline{width:auto}.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--border-strong)}.btn-ghost:hover{background:var(--surface-2)}.btn-dark{background:var(--ink);color:#fff}.btn-dark:hover{background:var(--ink-2)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-dark)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(.96)}label.field{display:block;margin-bottom:14px}label.field>span{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}input,select,textarea{width:100%;min-height:46px;padding:11px 13px;font-family:inherit;font-size:16px;color:var(--ink);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);transition:border-color .15s ease,box-shadow .15s ease}input,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none}input::placeholder,textarea::placeholder{color:var(--faint)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring)}textarea{min-height:84px;resize:vertical;line-height:1.5}input[inputmode=numeric]{letter-spacing:1px;font-variant-numeric:tabular-nums}.muted{color:var(--muted)}.small{font-size:13px}.row{display:flex;gap:10px;align-items:center}.row-between{display:flex;gap:10px;align-items:center;justify-content:space-between}.stack{display:flex;flex-direction:column;gap:12px}.grid{display:grid;gap:12px}.spacer{flex:1}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:600;letter-spacing:.01em;white-space:nowrap}.badge-in{background:#e7f7ee;color:#10864a}.badge-out{background:#fdeaea;color:#c53437}.badge-late{background:#fef2d9;color:#b0761c}.badge-unassigned{background:var(--surface-2);color:var(--muted)}.notice{padding:11px 13px;border-radius:var(--radius-sm);font-size:14px;line-height:1.5;border:1px solid transparent}.notice-error{background:#fdeeee;color:#b42433;border-color:#f6d4d6}.notice-ok{background:#eaf7ef;color:#147a3d;border-color:#cdeede}.notice-info{background:var(--brand-soft);color:#0b6a80;border-color:#bce8f2}.appbar{display:flex;align-items:center;gap:6px;padding:11px 16px;padding-top:calc(11px + env(safe-area-inset-top));background:#ffffffd1;-webkit-backdrop-filter:saturate(1.6) blur(12px);backdrop-filter:saturate(1.6) blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.appbar nav a{color:var(--muted);font-weight:600;font-size:14px;padding:6px 10px;border-radius:8px}.appbar nav a:hover{color:var(--ink);background:var(--surface-2);text-decoration:none}.appbar nav a.active{color:var(--brand-dark);background:var(--brand-soft)}.brand{font-weight:700;font-size:15px;color:var(--ink);display:inline-flex;align-items:center;gap:8px;letter-spacing:-.01em}.brand:hover{text-decoration:none}.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px #00b4d829}.list{list-style:none;margin:0;padding:0}.list-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);text-decoration:none;color:inherit;transition:border-color .12s ease,box-shadow .12s ease}.list-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow);text-decoration:none}.list-item+.list-item{margin-top:8px}.thumb{width:46px;height:46px;border-radius:10px;object-fit:cover;background:var(--surface-2);flex:none;border:1px solid var(--border)}.thumb-ph{display:flex;align-items:center;justify-content:center;color:var(--faint);font-size:20px}.statbar{display:flex;padding:0;margin-bottom:14px}.statbar .stat{flex:1;text-align:center;padding:13px 8px}.statbar .stat+.stat{border-left:1px solid var(--border)}.statbar .n{display:block;font-size:21px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.statbar .l{display:block;font-size:12px;color:var(--muted);margin-top:1px}@media(min-width:640px){.grid-2{grid-template-columns:1fr 1fr}}@media print{.appbar,.no-print{display:none!important}html,body{background:#fff}}
