:root{color:#222;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f5f5f5;font-family:Meiryo,メイリオ,sans-serif;font-size:15px}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;min-width:0}body{background:#f5f5f5;font-family:Meiryo,メイリオ,sans-serif;font-size:15px}.app{flex-direction:column;width:100%;min-height:100vh;display:flex}.app-header{color:#fff;background:#1a3a5c;flex-shrink:0;align-items:center;gap:24px;padding:10px 16px;display:flex}.app-header h1{white-space:nowrap;font-size:18px}.app-nav{gap:4px;display:flex}.app-nav button{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:3px;padding:7px 16px;font-size:15px}.app-nav button.active{color:#1a3a5c;background:#fff;font-weight:700}.app-nav button:hover:not(.active){background:#ffffff40}.app-main,.attendance-page{flex-direction:column;flex:1;display:flex;overflow:hidden}.toolbar{background:#fff;border-bottom:1px solid #ddd;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:10px 16px;display:flex}.toolbar label{margin-right:4px;font-size:15px;font-weight:700}.toolbar input[type=month],.toolbar select{border:1px solid #ccc;border-radius:3px;padding:6px 8px;font-size:15px}.toolbar-center{align-items:center;gap:8px;display:flex}.toolbar-right{align-items:center;gap:8px;margin-left:auto;display:flex}.year-month-label{color:#555;margin-left:8px;font-size:15px}.btn-save{color:#fff;cursor:pointer;background:#1a3a5c;border:none;border-radius:3px;padding:8px 24px;font-size:15px}.btn-save:disabled{opacity:.6}.save-msg{color:#2a8a2a;font-weight:700}.grid-wrapper{flex:1;width:100%;padding:8px;overflow:auto}.attendance-table{border-collapse:collapse;white-space:nowrap;background:#fff;font-size:14px}.attendance-table thead th{color:#fff;z-index:10;background:#1a3a5c;border:1px solid #2a4a6c;padding:7px 8px;font-size:13px;position:sticky;top:0}.attendance-table thead th.th-deduction{color:#fff;background:#8b2020}.attendance-table td{vertical-align:middle;border:1px solid #ddd;padding:3px 5px}.attendance-table tr:hover td{background:#f0f4ff}.office-header-row td{color:#1a3a5c;background:#d0d8e8;padding:4px 8px;font-weight:700}.total-row td{color:#1a5c1a;background:#e8f0e8;font-weight:700}.total-label{text-align:right;padding-right:8px}.name-cell{cursor:grab;min-width:120px}.drag-icon{color:#999;cursor:grab;margin-right:5px;font-size:13px}.data-row:hover .drag-icon{color:#555}td.deduction{background-color:#fff0f0}.total-row td.deduction{background-color:#ffe0e0}td.col-paid,td.col-paid input{color:#05c}td.col-work2,td.col-work2 input{color:#c00}.cell-num{text-align:right;border:1px solid #ccc;border-radius:2px;width:68px;padding:3px 5px;font-size:14px}.cell-time{text-align:center;border:1px solid #ccc;border-radius:2px;width:84px;padding:3px 5px;font-size:14px}.cell-notes{border:1px solid #ccc;border-radius:2px;width:180px;padding:3px 5px;font-size:14px}.calc{text-align:right;color:#555;background:#f8f8f8}.import-page,.admin-page{padding:20px;overflow:auto}.import-page h2,.admin-page h2{color:#1a3a5c;margin-bottom:16px}.import-form{background:#fff;border:1px solid #ddd;border-radius:4px;margin-bottom:16px;padding:16px}.form-row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.form-row label{align-items:center;gap:6px;display:flex}.file-label{color:#fff;cursor:pointer;background:#1a3a5c;border-radius:3px;padding:8px 20px;display:inline-block}.import-status{border-radius:3px;margin-top:8px;padding:8px 12px;font-weight:700}.import-status.success{color:#2a7a2a;background:#e8f5e8}.import-status.error{color:#c00;background:#fde8e8}.import-status.warn{color:#7a5a00;background:#fff8e0;border:1px solid #e6c800}.missing-offices{background:#fff8e0;border:2px solid #e6b800;border-radius:4px;margin-bottom:16px;padding:16px}.missing-offices h3{color:#7a4a00;margin-bottom:6px}.missing-offices p{color:#555;margin-bottom:10px;font-size:14px}.missing-table{border-collapse:collapse;width:100%;font-size:14px}.missing-table th{text-align:left;background:#f5e090;border:1px solid #d4c060;padding:6px 10px}.missing-table td{border:1px solid #e0d080;padding:5px 10px}.missing-row{background:#fffbe8}.missing-row:hover{background:#fff5c0}.preview{margin-top:16px}.preview h3{margin-bottom:8px}.preview-table-wrap{max-height:200px;overflow:auto}.preview table{border-collapse:collapse;font-size:11px}.preview th,.preview td{border:1px solid #ccc;padding:3px 6px}.preview th{background:#eee}.import-notes{background:#fff;border:1px solid #ddd;border-radius:4px;padding:16px}.import-notes h3{color:#1a3a5c;margin-bottom:8px}.import-notes ol{padding-left:20px;line-height:2}.admin-section{background:#fff;border:1px solid #ddd;border-radius:4px;margin-bottom:16px;padding:16px}.admin-section h3{color:#1a3a5c;margin-bottom:6px}.rate-active-row td{background:#e8f5e8;font-weight:700}.badge-active{color:#fff;background:#2a7a2a;border-radius:10px;padding:2px 8px;font-size:12px}.modal-note{color:#888;margin-bottom:4px;font-size:13px}.admin-note{color:#666;margin-bottom:10px;font-size:13px}.admin-table{border-collapse:collapse;width:100%;margin-bottom:10px}.admin-table th{text-align:left;background:#eee;border:1px solid #ccc;padding:6px 10px}.admin-table td{border:1px solid #ddd;padding:5px 10px}.admin-table tr:hover td{background:#f5f5f5}.admin-section>button{color:#fff;cursor:pointer;background:#1a3a5c;border:none;border-radius:3px;padding:6px 14px}.btn-delete{color:#fff;cursor:pointer;border:none;border-radius:2px;margin-left:4px;padding:3px 8px;background:#c00!important}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:6px;flex-direction:column;gap:10px;min-width:320px;padding:24px;display:flex}.modal h4{color:#1a3a5c;margin-bottom:4px}.modal label{align-items:center;gap:8px;display:flex}.modal input,.modal select{border:1px solid #ccc;border-radius:3px;flex:1;padding:5px 8px}.modal-actions{gap:8px;margin-top:8px;display:flex}.modal-actions button{color:#fff;background:#1a3a5c;border:none;border-radius:3px;flex:1;padding:8px}.modal-actions button:last-child{background:#888}.loading,.empty{text-align:center;color:#444;padding:40px;font-size:16px}.login-page{background:#f0f4f8;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-box{background:#fff;border-radius:8px;width:360px;padding:40px;box-shadow:0 2px 16px #0000001f}.login-box h1{color:#1a3a5c;text-align:center;margin-bottom:24px;font-size:18px}.login-field{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.login-field label{color:#333;font-size:14px;font-weight:700}.login-field input{border:1px solid #ccc;border-radius:4px;padding:10px 12px;font-size:15px}.login-field input:focus{border-color:#1a3a5c;outline:none}.login-error{color:#c00;background:#fde8e8;border-radius:4px;margin-bottom:12px;padding:8px 12px;font-size:14px}.login-btn{color:#fff;cursor:pointer;background:#1a3a5c;border:none;border-radius:4px;width:100%;margin-top:8px;padding:12px;font-size:16px}.login-btn:disabled{opacity:.6}.user-info{color:#ffffffd9;align-items:center;gap:12px;margin-left:auto;font-size:13px;display:flex}.btn-logout{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:3px;padding:5px 12px;font-size:13px}.btn-logout:hover{background:#ffffff59}.row-locked td{color:#aaa;background:#f8f8f8!important}.row-locked input{color:#aaa;cursor:not-allowed;background:#f0f0f0}.office-header-row.locked td{background:#c8d0c8}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
