*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,sans-serif;background:#1a1a2e;color:#eaeaea;user-select:none;-webkit-user-select:none;overflow:hidden}button{font-family:inherit;border:none;cursor:pointer}.clock-screen{height:100%;display:flex;flex-direction:column;padding:16px 24px}.clock-header{display:flex;align-items:baseline;justify-content:space-between}.clock-date{font-size:26px;color:#9aa}.clock-time{font-size:64px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:2px}.clock-time .sec{font-size:36px;color:#9aa}.alert-banner{background:#7a2c2c;color:#ffdada;border-radius:10px;padding:10px 16px;margin:8px 0;font-size:20px;font-weight:600}.staff-grid{flex:1;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:12px;align-content:start}.staff-btn{min-height:110px;border-radius:16px;font-size:30px;font-weight:700;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;transition:transform .1s}.staff-btn:active{transform:scale(.96)}.staff-btn .status{font-size:16px;font-weight:500;opacity:.85}.staff-btn.off{background:#4a4a5e}.staff-btn.working{background:#2e7d4f}.staff-btn.done{background:#2a5d9c}.staff-btn.locked{background:#333;color:#777}.gear-btn{position:fixed;right:14px;bottom:14px;width:52px;height:52px;border-radius:50%;background:#33334a;color:#99a;font-size:24px}.mode-badge{position:fixed;left:14px;bottom:14px;font-size:13px;color:#777}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#26263c;border-radius:20px;padding:28px 32px;min-width:420px;max-width:92vw;max-height:90vh;overflow-y:auto;text-align:center}.modal h2{font-size:28px;margin-bottom:16px}.pin-dots{display:flex;justify-content:center;gap:16px;margin:18px 0}.pin-dot{width:20px;height:20px;border-radius:50%;border:2px solid #888}.pin-dot.filled{background:#4fc3f7;border-color:#4fc3f7}.pin-error{color:#ff8a8a;font-size:18px;min-height:24px;margin-bottom:8px}.keypad{display:grid;grid-template-columns:repeat(3,90px);gap:12px;justify-content:center}.keypad button{height:74px;border-radius:14px;background:#3a3a54;color:#fff;font-size:30px;font-weight:600}.keypad button:active{background:#50506e}.keypad .fn{background:#2d2d42;font-size:20px;color:#aab}.cancel-link{margin-top:18px;background:none;color:#89a;font-size:18px;text-decoration:underline}.action-name{font-size:34px;font-weight:700;margin-bottom:8px}.office-toggle{display:flex;gap:10px;justify-content:center;margin:16px 0}.office-toggle button{padding:14px 34px;border-radius:12px;font-size:24px;font-weight:700;background:#3a3a54;color:#99a}.office-toggle button.selected{background:#b8860b;color:#fff}.punch-action-btn{width:100%;padding:26px;border-radius:16px;font-size:38px;font-weight:800;color:#fff;margin-top:8px}.punch-action-btn.in{background:#2e7d4f}.punch-action-btn.out{background:#2a5d9c}.done-screen{font-size:34px;font-weight:700;line-height:1.6;padding:30px 10px}.done-screen .big{font-size:46px;color:#7fe0a7}.admin-screen{height:100%;display:flex;flex-direction:column;background:#f4f4f8;color:#222;overflow:hidden}.admin-header{display:flex;align-items:center;gap:16px;padding:14px 20px;background:#26263c;color:#fff}.admin-header h1{font-size:22px;flex:1}.admin-tabs{display:flex;gap:4px}.admin-tabs button{padding:10px 20px;font-size:17px;border-radius:10px 10px 0 0;background:#3a3a54;color:#bbc}.admin-tabs button.active{background:#f4f4f8;color:#222;font-weight:700}.admin-body{flex:1;overflow-y:auto;padding:20px}.admin-body h3{margin:18px 0 10px}.admin-table{width:100%;border-collapse:collapse;background:#fff;font-size:15px}.admin-table th,.admin-table td{border:1px solid #ccc;padding:8px 10px;text-align:center}.admin-table th{background:#e8e8f0}.admin-table .warn{background:#ffe5e5}.admin-table .corrected{color:#b8860b;font-weight:700}.btn{padding:10px 18px;border-radius:8px;font-size:16px;background:#26263c;color:#fff}.btn.secondary{background:#667}.btn.danger{background:#a33}.btn.small{padding:5px 12px;font-size:14px}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.toolbar select,.toolbar input,.form-row input,.form-row select{padding:9px 12px;font-size:16px;border:1px solid #bbb;border-radius:8px;background:#fff;color:#222}.form-row{display:flex;gap:10px;align-items:center;margin:8px 0;flex-wrap:wrap}.form-row label{min-width:130px;font-weight:600;text-align:left}.modal.light{background:#fff;color:#222;text-align:left}.modal.light h2{font-size:22px}.history-list{font-size:13px;color:#666;text-align:left;margin-top:10px;max-height:160px;overflow-y:auto;border-top:1px solid #ddd;padding-top:8px}.summary-pre{background:#fff;border:1px solid #ccc;border-radius:8px;padding:14px;font-family:monospace;font-size:14px;white-space:pre-wrap;text-align:left}.print-area{display:none}@media print{body{background:#fff;overflow:visible}.admin-screen,.clock-screen,.overlay{display:none!important}.print-area{display:block;color:#000;font-size:12px}.print-sheet{page-break-after:always;padding:10mm}.print-sheet h2{font-size:16px;margin-bottom:4px}.print-sheet table{width:100%;border-collapse:collapse}.print-sheet th,.print-sheet td{border:1px solid #000;padding:3px 6px;text-align:center;font-size:11px}.print-footer{margin-top:8px;display:flex;justify-content:space-between}.print-stamp{border:1px solid #000;width:60px;height:60px;display:inline-block}}
