:root{--bg:#FBF3E7;--paper:#FFFFFF;--surface:#FFFFFF;--surface-soft:#FCFAF6;--ink:#1B1235;--ink-soft:#5B5270;--ink-fixed:#1B1235;--pink:#E0227A;--pink-deep:#B5165E;--teal:#0FA68C;--gold:#F2A93B;--coral:#E8472A;--line:rgba(27,18,53,.13);--line-strong:rgba(27,18,53,.28);--shadow: 0 10px 30px rgba(27,18,53,.1)}:root[data-theme=dark]{--bg:#15101f;--paper:#211a30;--surface:#241c35;--surface-soft:#2a2138;--ink:#F3ECE0;--ink-soft:#B9AFC9;--ink-fixed:#1B1235;--pink:#F0388F;--pink-deep:#FF6FB0;--teal:#1BC7A8;--gold:#F5B94E;--coral:#FF6B52;--line:rgba(255,255,255,.13);--line-strong:rgba(255,255,255,.28);--shadow: 0 10px 30px rgba(0,0,0,.45)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:radial-gradient(circle at 8% 0%,rgba(224,34,122,.1),transparent 40%),radial-gradient(circle at 100% 10%,rgba(15,166,140,.1),transparent 45%),var(--bg);color:var(--ink);font-family:Public Sans,sans-serif;min-height:100vh;transition:background-color .2s ease,color .2s ease}h1,h2,h3,.display{font-family:Fraunces,serif}.mono{font-family:IBM Plex Mono,monospace}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}#app{max-width:960px;margin:0 auto;padding:18px 16px 110px;min-height:100vh}.brand{display:flex;align-items:center;gap:10px;margin-bottom:18px}.stamp-mark{width:38px;height:38px;border-radius:50%;border:2.5px solid var(--ink);position:relative;flex:none;display:flex;align-items:center;justify-content:center;transform:rotate(-8deg)}.stamp-mark:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1px solid var(--ink);border-radius:50%}.stamp-mark span{font-family:Fraunces,serif;font-weight:900;font-size:13px}.brand-name{font-family:Fraunces,serif;font-weight:700;font-size:20px;letter-spacing:.2px}.brand-sub{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:1.2px;margin-top:-2px}.card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:var(--shadow);margin-bottom:16px}.card h2{margin:0 0 4px;font-size:21px}.card .hint{color:var(--ink-soft);font-size:13.5px;margin:0 0 14px}.row{display:flex;gap:10px;flex-wrap:wrap}.col{flex:1;min-width:140px}label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin:10px 0 5px;text-transform:uppercase;letter-spacing:.4px}input[type=text],input[type=password],input[type=number],input[type=time],input[type=date],select,textarea{width:100%;padding:11px 12px;border-radius:10px;border:1.5px solid var(--line-strong);background:var(--surface);font-size:15px;color:var(--ink);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--pink)}textarea{min-height:120px;resize:vertical;line-height:1.5}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:12px;border:none;font-weight:700;font-size:15px;transition:transform .12s ease}.btn:active{transform:scale(.97)}.btn-primary{background:var(--pink);color:#fff}.btn-primary:hover{background:var(--pink-deep)}.btn-teal{background:var(--teal);color:#fff}.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong)}.btn-gold{background:var(--gold);color:#332100}.btn-block{width:100%}.btn[disabled]{opacity:.45;cursor:not-allowed}.btn-sm{padding:7px 12px;font-size:13px;border-radius:9px}.btn-danger{background:transparent;color:var(--coral);border:1.5px solid var(--coral)}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:700}.pill-ok{background:#0fa68c21;color:var(--teal)}.pill-pending{background:#f2a93b2e;color:#8a5c0c}.pill-warn{background:#e8472a21;color:var(--coral)}.pill-off{background:#1b123512;color:var(--ink-soft)}.pill-tag{background:#1b12350f;color:var(--ink-soft);font-weight:700}.login-wrap{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.login-card{max-width:380px;width:100%}.pin-input{font-family:IBM Plex Mono,monospace;font-size:22px;text-align:center;padding:14px}.pin-box-row{display:flex;gap:10px;justify-content:center;margin:6px 0}.pin-box{width:56px;height:64px;flex:none;font-family:IBM Plex Mono,monospace;font-size:26px;text-align:center;padding:0;border-radius:10px;border:1.5px solid var(--line-strong);background:var(--paper);color:var(--ink)}.pin-box:focus{border-color:var(--pink);outline:none}.switch-role{margin-top:14px;font-size:13.5px;color:var(--ink-soft)}.switch-role a{color:var(--pink-deep);font-weight:700;text-decoration:none;cursor:pointer}.tabbar{position:fixed;bottom:0;left:0;right:0;background:var(--paper);border-top:1px solid var(--line);display:flex;justify-content:center;z-index:40;box-shadow:0 -6px 20px #1b123512}.tabbar-inner{max-width:960px;width:100%;display:flex}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 2px 12px;background:none;border:none;color:var(--ink-soft);font-size:10.8px;font-weight:700}.tab-btn.active{color:var(--pink-deep)}.tab-btn .ic{font-size:18px}.mgr-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.mgr-tab{padding:9px 14px;border-radius:10px;border:1.5px solid var(--line-strong);background:var(--surface);font-weight:700;font-size:13.5px;color:var(--ink-soft)}.mgr-tab.active{background:var(--ink-fixed);color:#fff;border-color:var(--ink-fixed)}.punch-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.punch-card{border:1.5px dashed var(--line-strong);border-radius:14px;padding:14px;text-align:center}.punch-card.done{border-style:solid;border-color:var(--teal);background:#0fa68c0f}.punch-card.flagged{border-style:solid;border-color:var(--coral);background:#e8472a0d}.punch-card .lbl{font-size:12px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.4px}.punch-card .time{font-family:IBM Plex Mono,monospace;font-size:22px;font-weight:600;margin:6px 0}.punch-card .exp{font-size:11px;color:var(--ink-soft)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b12358c;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--paper);border-radius:20px;max-width:440px;width:100%;padding:26px;box-shadow:0 30px 60px #0000004d;max-height:86vh;overflow:auto}.stamp-anim{width:150px;height:150px;margin:6px auto 14px;border-radius:50%;border:6px solid var(--coral);display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--coral);transform:rotate(-10deg) scale(0);animation:stampdown .45s cubic-bezier(.2,1.4,.4,1) forwards;position:relative}.stamp-anim:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:2px solid var(--coral);border-radius:50%}.stamp-anim b{font-family:Fraunces,serif;font-size:14px;text-transform:uppercase;letter-spacing:1px;text-align:center;padding:0 10px}.stamp-anim .t{font-family:IBM Plex Mono,monospace;font-size:19px;margin-top:2px}@keyframes stampdown{0%{transform:rotate(-10deg) scale(2.4);opacity:0}60%{opacity:1}to{transform:rotate(-10deg) scale(1);opacity:1}}table{width:100%;border-collapse:collapse;font-size:13.5px}th,td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line);white-space:nowrap}th{color:var(--ink-soft);font-size:11.5px;text-transform:uppercase;letter-spacing:.4px}.table-wrap{overflow-x:auto}a.maplink{color:var(--pink-deep);font-weight:700;text-decoration:none}.doc-item{border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.doc-item .ttl{font-weight:700}.doc-text{white-space:pre-wrap;line-height:1.6;font-size:14.5px;border:1px solid var(--line);border-radius:12px;padding:14px;max-height:300px;overflow:auto;background:var(--surface-soft)}.banner{background:#e0227a14;border:1px solid rgba(224,34,122,.25);border-radius:12px;padding:10px 14px;font-size:13px;color:var(--pink-deep);margin-bottom:14px}.err{color:var(--coral);font-size:13px;font-weight:600;margin-top:6px}.toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}.muted{color:var(--ink-soft);font-size:13px}hr.div{border:none;border-top:1px solid var(--line);margin:16px 0}.kv{display:flex;justify-content:space-between;font-size:13.5px;padding:6px 0;border-bottom:1px dashed var(--line);gap:10px}.copy-pin{font-family:IBM Plex Mono,monospace;background:var(--ink-fixed);color:#fff;padding:3px 9px;border-radius:7px;font-size:13px;letter-spacing:2px}.tags-hint{font-size:12px;background:var(--surface-soft);border:1px dashed var(--line-strong);border-radius:10px;padding:10px 12px;color:var(--ink-soft);font-family:IBM Plex Mono,monospace;line-height:1.7}.recv-card{border:1.5px solid var(--line);border-radius:14px;padding:16px;margin-bottom:12px}.recv-card .ttl{font-weight:700;font-size:15.5px}.checkrow{display:flex;align-items:center;gap:8px;font-weight:500;text-transform:none;margin-top:14px}.checkrow input{width:auto}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:16px}.stat-tile{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:var(--shadow)}.stat-tile .num{font-family:IBM Plex Mono,monospace;font-size:28px;font-weight:600;line-height:1}.stat-tile .lbl{font-size:12px;color:var(--ink-soft);margin-top:6px;text-transform:uppercase;letter-spacing:.4px;font-weight:700}.stat-tile.good .num{color:var(--teal)}.stat-tile.warn .num{color:var(--coral)}
