:root{--indigo: #5b5fe0;--indigo-dark: #4a4ec9;--indigo-pale: #eef0fe;--bg: #f4f5fb;--card: #ffffff;--border: #e3e5f0;--text: #2f3240;--muted: #8a8da0;--danger: #d64545;--warn-bg: #fff7e6;--warn-border: #f0c36d;--cell-bg: #f6f7fb;--cell-out-bg: #f1f2f8;--radius: 14px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,Yu Gothic UI,sans-serif;font-size:15px;line-height:1.6}.app-header{background:var(--indigo);color:#fff;padding:14px 16px}.app-header-inner{max-width:1040px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px}.app-title{font-size:19px;font-weight:700}.header-user{display:flex;align-items:center;gap:10px;font-size:13px}.header-name{opacity:.95;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:40vw}.btn-ghost{background:#ffffff24;color:#fff;border:1px solid rgba(255,255,255,.55);border-radius:8px;padding:5px 12px;font-size:13px;cursor:pointer}.btn-ghost:hover{background:#ffffff3d}.container{max-width:1040px;margin:0 auto;padding:16px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:0 1px 2px #282c5a0a}.card.narrow{max-width:420px;width:100%}.center-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--bg)}.page-title{margin:0 0 6px;font-size:17px}.muted{color:var(--muted)}.small{font-size:12px}.error-text{color:var(--danger);font-size:14px}.dimmed{opacity:.55;pointer-events:none}.btn-primary{background:var(--indigo);color:#fff;border:1px solid var(--indigo);border-radius:9px;padding:9px 18px;font-size:14px;font-weight:600;cursor:pointer}.btn-primary:hover{background:var(--indigo-dark)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-primary.wide{width:100%;margin-top:6px}.btn-outline{background:#fff;color:var(--indigo);border:1.5px solid var(--indigo);border-radius:9px;padding:8px 14px;font-size:13.5px;font-weight:600;cursor:pointer}.btn-outline:hover{background:var(--indigo-pale)}.btn-outline:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:5px 12px;font-size:12.5px}.btn-icon{padding:8px 12px;line-height:1}input[type=email],input[type=password],input[type=time],input[type=month],input[type=search],input[type=number],select,textarea{border:1px solid var(--border);border-radius:9px;padding:8px 10px;font-size:14px;font-family:inherit;background:#fff;color:var(--text)}input:focus,select:focus,textarea:focus{outline:2px solid var(--indigo-pale);border-color:var(--indigo)}textarea{width:100%;resize:vertical}.login-title{margin:0;font-size:20px;color:var(--indigo)}.login-card .muted{margin-top:2px}.field-label{display:block;font-size:13px;font-weight:600;margin:14px 0 0}.field-label input{display:block;width:100%;margin-top:5px}.setup-steps{padding-left:20px}.setup-steps li{margin-bottom:6px}code{background:var(--cell-bg);border:1px solid var(--border);border-radius:5px;padding:1px 5px;font-size:.9em}.period-head{margin-top:14px}.period-label{font-weight:700;font-size:15.5px}.period-nav{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:12px 0 16px}.month-input{width:140px}.search-input{flex:1;min-width:180px;margin-left:auto}.search-results{border:1px solid var(--border);border-radius:10px;margin-bottom:14px;overflow:hidden}.search-result{display:flex;gap:10px;align-items:baseline;width:100%;text-align:left;background:#fff;border:none;border-bottom:1px solid var(--border);padding:9px 12px;font-size:13.5px;cursor:pointer}.search-result:last-child{border-bottom:none}.search-result:hover{background:var(--indigo-pale)}.search-results>.muted{padding:10px 12px}.result-date{font-weight:600;white-space:nowrap}.result-summary{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-head{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}.cal-head-cell{text-align:center;color:var(--muted);font-size:13px;font-weight:600}.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.cell{min-height:74px;border-radius:10px;background:var(--cell-bg);border:1.5px solid transparent;padding:7px 8px;font:inherit;font-size:13px;color:var(--text);text-align:left;display:flex;flex-direction:column;gap:4px;cursor:pointer;overflow:hidden}button.cell:hover{border-color:#c9ccef}.cell.selected{background:var(--indigo-pale);border-color:var(--indigo)}.cell.today .cell-date{color:var(--indigo)}.cell.out{background:var(--cell-out-bg);border:1.5px dashed #d8dbea;color:var(--muted);cursor:default}.cell-top{display:flex;justify-content:space-between;align-items:baseline;gap:4px}.cell-date{font-weight:700}.cell-dow{color:var(--muted);font-size:11.5px}.chips{display:flex;flex-wrap:wrap;gap:3px}.chip{font-size:10.5px;line-height:1;padding:3px 5px;border-radius:6px;white-space:nowrap}.chip-work{background:#e3e9ff;color:#3a4bbd}.chip-leave{background:#e0f4e8;color:#1f7a44}.chip-ot{background:#fdeede;color:#b25f12}.chip-abs{background:#fde5e5;color:#b03030}.chip-case{background:#e9e3ff;color:#5b3ec9}.chip-memo{background:#eceef5;color:#6b6f85}.day-editor{border:1px solid var(--border);border-radius:12px;padding:16px;margin-top:16px}.day-editor-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.day-editor-head h3{margin:0;font-size:15.5px}.editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}.field{display:flex;flex-direction:column;gap:6px}.field.span2{grid-column:1 / -1}.field-name{font-size:13px;font-weight:700}.check-label{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;cursor:pointer}.check-label input{width:17px;height:17px;accent-color:var(--indigo)}.time-row{display:flex;flex-wrap:wrap;align-items:end;gap:12px}.time-row label{display:flex;flex-direction:column;gap:4px;font-size:12.5px;font-weight:600}.hint{font-size:12px;color:var(--muted)}.hint.warn{color:#a96a00}.field-error{font-size:12.5px;color:var(--danger);font-weight:600}.net-display{font-size:13.5px}.net-display strong{color:var(--indigo);font-size:15px}.hm-select{display:inline-flex;align-items:center;gap:6px}.hm-select .unit,.case-row .unit{font-size:13px}.case-row{display:inline-flex;align-items:center;gap:6px}.case-row input{width:90px}.editor-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.select-hint{margin-top:16px;padding:18px;text-align:center;border:1px dashed var(--border);border-radius:12px;font-size:13.5px}.totals{display:flex;flex-wrap:wrap;gap:8px 22px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border);font-size:13.5px;font-weight:600}.totals strong{color:var(--indigo)}.warn-box{margin-top:14px;background:var(--warn-bg);border:1px solid var(--warn-border);border-radius:10px;padding:10px 14px;font-size:13.5px;font-weight:600;color:#8a5a00}.error-box{border:1px solid #f0c5c5;background:#fdf3f3;border-radius:10px;padding:14px;margin-bottom:14px}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);background:#33364a;color:#fff;font-size:13.5px;padding:10px 20px;border-radius:999px;box-shadow:0 4px 14px #14163240;z-index:50}@media(max-width:640px){body{font-size:14px}.app-header{padding:10px 12px}.app-title{font-size:15.5px;white-space:nowrap}.header-user{font-size:12px;gap:7px}.header-name{max-width:26vw}.btn-ghost{padding:4px 9px;font-size:12px;white-space:nowrap}.container{padding:10px}.card{padding:12px}.cal-head,.cal-grid{gap:3px}.cal-head-cell{font-size:11.5px}.cell{min-height:52px;padding:4px 3px;font-size:10px;border-radius:7px;border-width:1px;gap:2px}.cell-dow{display:none}.chip{font-size:8.5px;padding:2px 3px}.editor-grid{grid-template-columns:1fr;gap:14px}.month-input{width:125px}.search-input{min-width:100%;margin-left:0;order:9}.totals{gap:6px 16px;font-size:12.5px}}
