:root{color-scheme:light;--bg: #f7f8fb;--surface: #ffffff;--surface-2: #f2f4f8;--surface-3: #eceff4;--surface-sunken: #fafbfc;--border: #e5e8ef;--border-strong: #cfd5df;--text: #111827;--text-muted: #5f6b7a;--text-subtle: #64748b;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-active: #1e40af;--primary-soft: #eaf1ff;--primary-border: #d6e2ff;--accent-cyan: #22d3ee;--success: #15803d;--success-soft: #eaf8ef;--success-border: #c9ecd5;--danger: #dc2626;--danger-hover: #b91c1c;--danger-soft: #fff0f0;--danger-border: #ffd4d4;--warning: #b45309;--warning-soft: #fff7e6;--warning-border: #f7dfaa;--sidebar-bg: #0f172a;--sidebar-bg-2: #131d33;--sidebar-text: #94a3b8;--sidebar-text-hover: #e2e8f0;--sidebar-active-bg: rgba(255, 255, 255, .08);--sidebar-active-text: #ffffff;--sidebar-border: #1e293b;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius: 12px;--shadow-xs: 0 1px 2px rgba(17, 24, 39, .04);--shadow-sm: 0 1px 2px rgba(17, 24, 39, .05), 0 4px 12px rgba(17, 24, 39, .04);--shadow-md: 0 1px 2px rgba(17, 24, 39, .06), 0 12px 28px rgba(17, 24, 39, .08);--shadow-lg: 0 4px 10px rgba(17, 24, 39, .07), 0 24px 48px -12px rgba(17, 24, 39, .18);--shadow-focus: 0 0 0 4px rgba(29, 78, 216, .14);--font-sans: Inter, "Noto Sans JP", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", Meiryo, sans-serif;font-family:var(--font-sans)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,rgba(29,78,216,.05),transparent 420px),var(--bg);background-attachment:fixed;color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.6;letter-spacing:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"tnum" 1,"cv02" 1,"cv03" 1}.num,.amount,.time,.summary-value,.stat-value,.table td.num{font-variant-numeric:tabular-nums}.center{display:grid;place-items:center;min-height:100vh}.muted{color:var(--text-muted)}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--sidebar-bg);color:var(--sidebar-text);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;padding:18px 14px;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:10px;font-size:19px;font-weight:700;letter-spacing:-.01em;color:#fff;padding:4px 10px 22px}.sidebar-brand:before{content:"";width:24px;height:24px;border-radius:7px;background:linear-gradient(140deg,var(--primary),var(--accent-cyan));box-shadow:inset 0 1px #ffffff59,0 2px 10px #22d3ee4d;flex:none}.sidebar-nav{display:flex;flex-direction:column;gap:3px}.sidebar-link{position:relative;display:flex;align-items:center;height:38px;padding:0 12px;color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-md);font-size:13.5px;font-weight:500;transition:background-color .12s ease,color .12s ease}.sidebar-link:hover{background:#ffffff0d;color:var(--sidebar-text-hover)}.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:600}.sidebar-link.active:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:999px;background:var(--accent-cyan)}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}.header{height:60px;position:sticky;top:0;z-index:20;background:#ffffffd1;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px}.header-spacer{flex:1}.content{padding:32px;overflow:auto}.avatar-button{border:none;background:transparent;cursor:pointer;padding:0;border-radius:50%;transition:box-shadow .12s ease}.avatar-button:hover{box-shadow:0 0 0 3px var(--surface-2)}.avatar-button:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.avatar-img{width:36px;height:36px;border-radius:50%;object-fit:cover;display:block}.avatar-img.lg{width:64px;height:64px}.avatar-fallback{width:36px;height:36px;border-radius:50%;background:linear-gradient(140deg,var(--primary),#5b8dff);color:#fff;display:inline-grid;place-items:center;font-weight:600}.avatar-fallback.lg{width:64px;height:64px;font-size:24px}.avatar-preview-row{display:flex;align-items:center;gap:16px}.page{max-width:980px;margin:0 auto}.page-title{font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.28;margin:0 0 18px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}.page-head .page-title,.page-head .card-title{margin:0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px;margin-bottom:20px}.card-title{font-size:16px;font-weight:650;letter-spacing:-.01em;margin:0 0 16px}.mt{margin-top:16px}.clock-card{text-align:center;padding:36px 24px}.status-badge{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border-radius:999px;font-weight:600;font-size:13px;border:1px solid transparent;margin-bottom:18px}.status-badge:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.status-badge.on{background:var(--success-soft);color:var(--success);border-color:var(--success-border)}.status-badge.off{background:var(--surface-2);color:var(--text-muted);border-color:var(--border)}.clock-actions{margin:16px 0}.button.big{font-size:17px;height:54px;padding:0 44px;border-radius:var(--radius-lg)}.summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.summary-row>div{background:var(--surface-sunken);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px}.summary-value{font-size:28px;font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--text)}.summary-row>div .muted{font-size:12px;font-weight:500;margin-top:6px}.table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs);font-size:13px}.table th,.table td{text-align:left;padding:0 14px;border-bottom:1px solid var(--border)}.table th{height:40px;background:var(--surface-sunken);color:var(--text-subtle);font-weight:650;font-size:12px;white-space:nowrap}.table td{height:48px;color:var(--text);vertical-align:middle}.table tr:last-child td{border-bottom:0}.table tbody tr{transition:background-color .1s ease}.table tbody tr:hover td{background:#fafcff}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.card .table{box-shadow:none;border:0;border-top:1px solid var(--border);border-radius:0}.summary-row+.error-text{margin:14px 0 0}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent}.pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.pill.active{background:var(--success-soft);color:var(--success);border-color:var(--success-border)}.pill.disabled{background:var(--danger-soft);color:var(--danger-hover);border-color:var(--danger-border)}.link{color:var(--primary);text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field-label{font-size:13px;font-weight:500;color:var(--text-muted)}.field-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.input,.select{min-height:40px;border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:0 12px;font-size:14px;font-family:inherit;background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs);transition:border-color .12s ease,box-shadow .12s ease}.input::placeholder{color:var(--text-subtle)}.input:focus,.select:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-focus)}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;background:var(--primary);color:#fff;border:1px solid transparent;border-radius:var(--radius-md);padding:0 16px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:0 1px 1px #11182714;transition:background-color .14s ease,border-color .14s ease,box-shadow .14s ease}.button:hover{background:var(--primary-hover)}.button:active{background:var(--primary-active)}.button:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.button:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.button.full{width:100%}.button.ghost{background:var(--surface);color:var(--text);border-color:var(--border-strong);box-shadow:var(--shadow-xs)}.button.ghost:hover{background:var(--surface-2);border-color:var(--border-strong)}.button.danger{background:var(--danger)}.button.danger:hover{background:var(--danger-hover)}.icon-button{border:none;background:transparent;font-size:20px;cursor:pointer;color:var(--text-muted);line-height:1;width:32px;height:32px;border-radius:var(--radius-md);display:inline-grid;place-items:center;transition:background-color .12s ease,color .12s ease}.icon-button:hover{background:var(--surface-2);color:var(--text)}.error-text{color:var(--danger);font-size:13px}.month-picker{display:flex;align-items:center;gap:6px}.month-picker .button.ghost{width:40px;padding:0;font-size:16px}.spacer{flex:1}.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 50% 0%,rgba(29,78,216,.08),transparent 520px),var(--bg);padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:36px;width:min(400px,calc(100vw - 40px))}.login-brand{font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0 0 4px}.login-card .muted{margin:0 0 24px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182766;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:flex;overflow-y:auto;padding:24px;z-index:50}.modal{margin:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:min(460px,100%)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;font-size:17px;font-weight:650;letter-spacing:-.01em}.modal-body{padding:24px}.modal-footer{display:flex;align-items:center;gap:10px;padding:16px 24px;border-top:1px solid var(--border)}.user-menu{position:relative}.menu{position:absolute;top:calc(100% + 10px);right:0;width:248px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:6px;z-index:60;animation:menu-in .12s ease;transform-origin:top right}@keyframes menu-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-head{display:flex;align-items:center;gap:10px;padding:10px 10px 12px}.menu-avatar .avatar-img,.menu-avatar .avatar-fallback{width:40px;height:40px}.menu-id{min-width:0}.menu-name{font-weight:650;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-email{font-size:12.5px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-sep{height:1px;background:var(--border);margin:2px 0 4px}.menu-item{display:block;width:100%;text-align:left;border:none;background:transparent;color:var(--text);font-family:inherit;font-size:13.5px;font-weight:500;padding:10px;border-radius:var(--radius-md);cursor:pointer}.menu-item:hover{background:var(--surface-2)}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover{background:var(--danger-soft)}.settings-avatar{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px 0 20px;margin-bottom:16px;border-bottom:1px solid var(--border)}.avatar-img.xl,.avatar-fallback.xl{width:84px;height:84px}.avatar-fallback.xl{font-size:32px}.button.sm{height:32px;padding:0 14px;font-size:13px}.field-hint{font-size:12px;color:var(--text-subtle)}.icon-button:focus-visible,.sidebar-link:focus-visible,.link:focus-visible{outline:2px solid var(--primary);outline-offset:2px}input[type=file]{max-width:100%;font-size:13px;color:var(--text-muted)}input[type=file]::file-selector-button{margin-right:12px;height:34px;padding:0 14px;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-md);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:var(--shadow-xs);transition:background-color .12s ease,border-color .12s ease}input[type=file]::file-selector-button:hover{background:var(--surface-2)}.avatar-preview-row{flex-wrap:wrap}@media (max-width: 720px){.app-shell{flex-direction:column}.sidebar{width:100%;flex-direction:row;align-items:center;gap:8px;padding:10px 14px;border-right:0;border-bottom:1px solid var(--sidebar-border)}.sidebar-brand{padding:0 6px 0 4px;font-size:17px}.sidebar-nav{flex-direction:row;gap:4px;overflow-x:auto}.sidebar-link{height:34px;white-space:nowrap}.header{padding:0 16px}.content{padding:20px 16px}.page-head{flex-wrap:wrap}.card{padding:20px}}
