:root{--space-1:4px;--space-2:8px;--space-3:16px;--space-4:24px;--space-5:32px;--space-6:48px;--space-7:64px;--radius:12px;--radius-sm:8px;--radius-xs:6px;--ease:cubic-bezier(.2, 0, 0, 1);--motion-fast:.12s;--motion-default:.16s;--motion-slow:.24s;--bg:#fdfcfb;--surface:#fff;--surface-sub:#fafafa;--border:#ececec;--border-subtle:#f2f2f2;--border-hover:#d0d0d0;--divider:#f2f2f2;--text:#1a1a1a;--text-sub:#555;--text-muted:#888;--text-dis:#aaa;--text-ter:var(--text-muted);--blue-bg:#e6f2fb;--blue:#5ba3d4;--green-bg:#e8f4ec;--green:#5ca873;--pink-bg:#fce8ee;--pink:#d47a94;--orange-bg:#fce8d9;--orange:#e8710a;--warning-bg:#fdf6d9;--warning:#c9a945;--yellow-bg:#fdf6d9;--yellow:#c9a945;--danger-bg:#fde4e4;--danger:#d44;--red-bg:#fde4e4;--red:#d44;--gray-bg:#f0f0f0;--gray:#888;--purple-bg:#f3e8fd;--purple:#7627bb;--font-brand:"Zen Kaku Gothic New", "Noto Sans JP", sans-serif;--font-ui:"Zen Kaku Gothic New", "Noto Sans JP", sans-serif;--font-content:"Noto Sans JP", sans-serif;--font-mono:"DM Mono", monospace;--font:var(--font-ui);--content-font:var(--font-content);--mono:var(--font-mono);--text-xs:12px;--text-sm:14px;--text-md:16px;--text-lg:20px;--text-xl:24px;--text-2xl:32px;--app-shell-max:1440px;--app-header-max:1440px;--app-content-max:1024px;--container-max:1440px;--container-pad:24px;--container-pad-mobile:16px;--grid-columns:12;--grid-gutter:24px;--z-header:20;--z-mobile-toolbar:50;--z-menu:130;--z-overlay:200;--z-dialog:210;--z-toast:300}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:var(--text-md);min-height:100dvh;line-height:1.5}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}img,svg{display:block}.app-header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;width:100%}.app-header-inner{align-items:center;gap:var(--space-2);width:100%;max-width:var(--app-header-max);padding:10px var(--container-pad);padding-top:calc(10px + env(safe-area-inset-top));min-height:calc(61px + env(safe-area-inset-top));grid-template-columns:40px minmax(0,1fr) 40px;margin:0 auto;display:grid}.header-brand{justify-content:center;align-items:center;min-width:0;display:flex}.app-header-title{font-family:var(--font-brand);color:var(--text);letter-spacing:0;text-align:center;font-size:28px;font-weight:700;line-height:1.2}.header-actions{justify-content:flex-end;align-items:center;display:flex;position:relative}.app-header-button{border-radius:var(--radius);width:40px;min-width:40px;min-height:40px;color:var(--text-muted);cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.app-header-button:hover{border-color:var(--border);background:var(--surface-sub);color:var(--text)}.app-header-button:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.app-header-button svg{stroke-width:2px;width:20px;height:20px}.app-header-logo{pointer-events:none;width:26px;height:26px;display:block}.app-logo{border-radius:var(--radius);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;width:40px;min-width:40px;min-height:40px;display:inline-flex}.dashboard-link,.dashboard-link:hover{color:inherit;background:0 0;border-color:#0000}.app-menu-wrap{position:relative}.app-menu{z-index:var(--z-menu);width:180px;padding:var(--space-1);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);display:none;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 20px #1a1a1a0f}.app-menu.open{display:block}.app-menu-item{width:100%;min-height:40px;color:var(--text-sub);font-family:var(--font-ui);font-size:var(--text-xs);text-align:left;cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;padding:9px 12px;font-weight:500;text-decoration:none;display:flex}.app-menu-item:hover{border-color:var(--border);background:var(--surface-sub);color:var(--text)}.app-menu-item:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.app-menu-item.danger{color:var(--danger)}.app-menu-item.danger:hover{border-color:var(--danger);background:var(--danger-bg)}@media (max-width:767px){.app-header-inner{padding-inline:var(--container-pad-mobile)}.app-header-title{font-size:24px}}.app-shell{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.app-main{min-height:0;padding:var(--space-4) var(--container-pad) calc(var(--space-5) + env(safe-area-inset-bottom));flex:1;overflow:auto}.app-container{width:100%;max-width:var(--app-content-max);margin:0 auto}@media (max-width:767px){.app-main{padding-inline:var(--container-pad-mobile)}}.page-title{font-family:var(--font);font-size:var(--text-xl);color:var(--text);letter-spacing:0;font-weight:700;line-height:1.2}.section-title{font-family:var(--font);font-size:var(--text-lg);color:var(--text);font-weight:600;line-height:1.3}.card-title{font-family:var(--font);font-size:var(--text-md);color:var(--text);font-weight:600;line-height:1.4}.meta-text{font-family:var(--mono);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.04em;font-weight:400}.mono-label{font-family:var(--mono);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.08em;font-weight:500}.btn{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);min-height:40px;color:var(--text-sub);font-family:var(--font-ui);font-size:var(--text-xs);letter-spacing:.03em;white-space:nowrap;cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);padding:9px 16px;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{border-color:var(--border-hover);background:var(--surface-sub);color:var(--text)}.btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.btn:active{transform:translateY(1px)}.btn:disabled,.btn[disabled]{opacity:.45;pointer-events:none}.btn svg{stroke-width:2px;flex-shrink:0;width:16px;height:16px}.btn-primary{background:var(--blue-bg);border-color:var(--blue);color:var(--blue)}.btn-primary:hover{background:var(--blue-bg);border-color:var(--blue);color:var(--blue);filter:brightness(.98)}.btn-secondary{background:var(--surface-sub);border-color:var(--border);color:var(--text-sub)}.btn-danger{background:var(--danger-bg);border-color:var(--danger-bg);color:var(--danger)}.btn-danger:hover{border-color:var(--danger);background:var(--danger-bg);color:var(--danger)}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--surface-sub);border-color:var(--border);color:var(--text)}.btn-sm{min-height:36px;padding:7px 12px;font-size:10px}.icon-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:40px;min-width:40px;min-height:40px;color:var(--text-muted);cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{border-color:var(--border-hover);background:var(--surface-sub);color:var(--text)}.icon-btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.icon-btn svg{stroke-width:2px;width:20px;height:20px}.btn.is-success-feedback,.icon-btn.is-success-feedback{border-color:var(--blue);background:var(--blue-bg);color:var(--blue)}.app-main .field,.app-shell~.dialog-overlay .field{gap:var(--space-1);flex-direction:column;display:flex}.app-main .field-label,.app-shell~.dialog-overlay .field-label{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.08em;display:block}.app-main .form-control,.app-main .input,.app-main .textarea,.app-shell~.dialog-overlay .form-control,.app-shell~.dialog-overlay .input,.app-shell~.dialog-overlay .textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);font-family:var(--font-content);font-size:var(--text-md);transition:border-color var(--motion-default) var(--ease), background var(--motion-default) var(--ease);outline:none;line-height:1.5}.app-main .form-control,.app-main .input,.app-shell~.dialog-overlay .form-control,.app-shell~.dialog-overlay .input{min-height:40px;padding:8px 12px}.app-main .textarea,.app-shell~.dialog-overlay .textarea{resize:vertical;min-height:160px;padding:10px 12px}.app-main .form-control:focus,.app-main .input:focus,.app-main .textarea:focus,.app-shell~.dialog-overlay .form-control:focus,.app-shell~.dialog-overlay .input:focus,.app-shell~.dialog-overlay .textarea:focus{border-color:var(--blue)}.app-main .form-control::placeholder,.app-main .input::placeholder,.app-main .textarea::placeholder,.app-shell~.dialog-overlay .form-control::placeholder,.app-shell~.dialog-overlay .input::placeholder,.app-shell~.dialog-overlay .textarea::placeholder{color:var(--text-dis)}.app-main .form-control:disabled,.app-main .input:disabled,.app-main .textarea:disabled,.app-shell~.dialog-overlay .form-control:disabled,.app-shell~.dialog-overlay .input:disabled,.app-shell~.dialog-overlay .textarea:disabled{color:var(--text-dis);background:var(--surface-sub);cursor:not-allowed}.app-main .field.has-error .form-control,.app-main .field.has-error .input,.app-main .field.has-error .textarea,.app-main .form-control.has-error,.app-main .input.has-error,.app-main .textarea.has-error,.app-shell~.dialog-overlay .field.has-error .form-control,.app-shell~.dialog-overlay .field.has-error .input,.app-shell~.dialog-overlay .field.has-error .textarea,.app-shell~.dialog-overlay .form-control.has-error,.app-shell~.dialog-overlay .input.has-error,.app-shell~.dialog-overlay .textarea.has-error{border-color:var(--danger)}.app-auth-shell{min-height:100dvh;padding:calc(var(--space-4) + env(safe-area-inset-top)) var(--space-3) calc(var(--space-4) + env(safe-area-inset-bottom));justify-content:center;align-items:center;display:flex}.app-auth-card{width:100%;max-width:380px;padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.app-auth-label,.app-auth-field-label{font-family:var(--font-ui);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.08em;display:block}.app-auth-label{margin-bottom:var(--space-1)}.app-auth-title{margin-bottom:var(--space-4);font-family:var(--font-brand);font-size:var(--text-xl);color:var(--text);font-weight:700;line-height:1.25}.app-auth-field-label{margin-bottom:var(--space-1)}.app-auth-password-field{margin-bottom:var(--space-3);position:relative}.app-auth-password-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;min-height:40px;color:var(--text);font-family:var(--font-ui);font-size:var(--text-md);transition:border-color var(--motion-default) var(--ease), background var(--motion-default) var(--ease);outline:none;padding:9px 60px 9px 12px}.app-auth-password-input:focus{border-color:var(--blue)}.app-auth-password-toggle{min-height:28px;padding:4px 10px;font-size:10px;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.app-auth-password-toggle:active{transform:translateY(calc(1px - 50%))}.app-auth-submit{width:100%}.app-auth-error{min-height:16px;margin-top:var(--space-2);color:var(--danger);font-family:var(--font-mono);font-size:11px;line-height:1.4}.app-input-group{margin-bottom:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-sub);transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease);padding:10px 14px}.app-input-group:focus-within{border-color:var(--blue)}.app-input-group.is-danger:focus-within,.app-input-group.deduction:focus-within{border-color:var(--pink)}.app-input-label{margin-bottom:var(--space-1);color:var(--text-muted);font-family:var(--font-ui);letter-spacing:.05em;font-size:10px;display:block}.app-input-row{align-items:center;gap:6px;display:flex}.app-input-row input,.app-input-row select,.app-input-row textarea{width:100%;min-width:0;color:var(--text);font-family:var(--font-mono);font-size:var(--text-md);background:0 0;border:0;outline:none}.app-input-row input[type=number]{-moz-appearance:textfield}.app-input-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.app-input-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.app-input-group.is-danger .app-input-row input,.app-input-group.deduction .app-input-row input{color:var(--pink)}.app-input-unit{color:var(--text-muted);font-family:var(--font-mono);font-size:var(--text-xs);white-space:nowrap;flex-shrink:0}.app-input-helper,.app-input-error{margin-top:var(--space-1);font-size:var(--text-xs);line-height:1.4}.app-input-helper{color:var(--text-muted)}.app-input-error{color:var(--danger)}.app-toolbar{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.app-save-toolbar{width:100%;max-width:var(--app-content-max);margin:0 auto var(--space-4);padding:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.app-save-status{min-width:76px;color:var(--text-muted);font-family:var(--font-mono);font-size:var(--text-xs);text-align:right;letter-spacing:0;font-weight:500}.app-save-status[data-status=saved],.app-save-status.is-saved{color:var(--green)}.app-save-status[data-status=failed],.app-save-status[data-status=error],.app-save-status.is-failed,.app-save-status.is-error{color:var(--danger)}.app-save-status[data-status=saving],.app-save-status[data-status=loading],.app-save-status.is-saving,.app-save-status.is-loading{color:var(--text-muted)}.app-tabs{gap:var(--space-2);-webkit-overflow-scrolling:touch;flex-direction:row;width:100%;padding-bottom:2px;display:flex;overflow-x:auto}.app-tab{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:max-content;min-height:40px;color:var(--text-muted);font-family:var(--font-ui);font-size:var(--text-xs);letter-spacing:.03em;white-space:nowrap;cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);flex:1;justify-content:center;align-items:center;padding:0 12px;font-weight:500;display:inline-flex}.app-tab:hover{border-color:var(--border-hover);color:var(--text-sub)}.app-tab:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.app-tab.is-active,.app-tab[aria-selected=true]{border-color:var(--blue);background:var(--blue-bg);color:var(--blue)}.app-row{align-items:center;gap:var(--space-2);width:100%;margin-bottom:var(--space-2);display:flex}.app-row-fields{display:contents}.app-row-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.app-row input[type=text],.app-row input[type=number]{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-sub);min-height:40px;color:var(--text);font-size:var(--text-md);transition:border-color var(--motion-fast) var(--ease);outline:none}.app-row input[type=text]{min-width:0;font-family:var(--font-content);flex:1;padding:8px 12px}.app-row input[type=number]{width:100px;font-family:var(--font-mono);text-align:right;-moz-appearance:textfield;flex-shrink:0;padding:8px 12px;font-weight:500}.app-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.app-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.app-row:focus-within input{border-color:var(--blue)}.app-row.is-danger:focus-within input,.app-row.deduction-row:focus-within input{border-color:var(--pink)}.app-row.is-danger input[type=number],.app-row.deduction-row input[type=number]{color:var(--pink)}.app-add-button{font-size:18px;line-height:1}.app-add-button:hover{border-color:var(--blue);color:var(--blue)}.app-add-button.is-danger:hover{border-color:var(--pink);color:var(--pink)}.app-delete-button{color:var(--text-dis);font-size:var(--text-sm)}.app-delete-button:hover{border-color:var(--danger);background:var(--danger-bg);color:var(--danger)}.app-summary{gap:var(--space-2);flex-direction:column;display:flex}.app-summary-row{justify-content:space-between;align-items:center;gap:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-sub);padding:12px 16px;display:flex}.app-summary-row.is-primary,.app-summary-row.blue{border-color:var(--blue);background:var(--blue-bg)}.app-summary-row.is-success,.app-summary-row.green{border-color:var(--green);background:var(--green-bg)}.app-summary-row.is-danger,.app-summary-row.red{border-color:var(--danger);background:var(--danger-bg)}.app-summary-label{color:var(--text-sub);font-size:var(--text-sm);font-weight:500}.app-summary-value{color:var(--text);font-family:var(--font-mono);font-size:var(--text-lg);text-align:right;font-weight:500}.app-summary-row.is-primary .app-summary-value,.app-summary-row.blue .app-summary-value{color:var(--blue);font-size:22px}.app-summary-row.is-success .app-summary-value,.app-summary-row.green .app-summary-value{color:var(--green);font-size:22px}.app-summary-row.is-danger .app-summary-value,.app-summary-row.red .app-summary-value{color:var(--danger)}.app-dialog-overlay{z-index:var(--z-overlay);padding:calc(1rem + env(safe-area-inset-top)) 1rem calc(1rem + env(safe-area-inset-bottom));background:#1a1a1a3d;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.app-dialog-overlay.open,.app-dialog-overlay.is-open{animation:dialog-overlay-in .4s var(--ease) both;display:flex}.app-dialog-overlay.open.is-closing,.app-dialog-overlay.is-open.is-closing{animation:dialog-overlay-out .4s var(--ease) both}.app-dialog-box,.app-dialog-panel,.app-confirm-modal{z-index:var(--z-dialog);width:100%;max-width:360px;padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);position:relative}.app-dialog-panel{max-width:min(720px,100vw - 32px);max-height:calc(88dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow-y:auto}.app-dialog-overlay.open .app-dialog-box,.app-dialog-overlay.open .app-dialog-panel,.app-dialog-overlay.open .app-confirm-modal,.app-dialog-overlay.is-open .app-dialog-box,.app-dialog-overlay.is-open .app-dialog-panel,.app-dialog-overlay.is-open .app-confirm-modal{animation:dialog-in .4s var(--ease) both}.app-dialog-overlay.open.is-closing .app-dialog-box,.app-dialog-overlay.open.is-closing .app-dialog-panel,.app-dialog-overlay.open.is-closing .app-confirm-modal,.app-dialog-overlay.is-open.is-closing .app-dialog-box,.app-dialog-overlay.is-open.is-closing .app-dialog-panel,.app-dialog-overlay.is-open.is-closing .app-confirm-modal{animation:dialog-out .4s var(--ease) both}.app-dialog-title{margin-bottom:var(--space-2);color:var(--text);font-size:var(--text-lg);padding-right:42px;font-weight:600;line-height:1.35}.app-dialog-actions{justify-content:flex-end;gap:var(--space-2);display:flex}.app-confirm-modal{max-width:360px;padding:26px var(--space-3) var(--space-4)}.app-confirm-modal .app-dialog-title,.app-confirm-title{font-size:var(--text-md);text-align:center;margin-bottom:0;padding-right:0;font-weight:700;line-height:1.4}.app-confirm-modal .app-dialog-actions,.app-confirm-actions{justify-content:center;margin-top:20px}.app-confirm-modal .btn{min-width:84px}.app-toast-wrap{top:calc(1rem + env(safe-area-inset-top));right:max(1rem, env(safe-area-inset-right));z-index:var(--z-toast);pointer-events:none;flex-direction:column;gap:.4rem;display:flex;position:fixed}.app-toast{align-items:center;gap:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);max-width:280px;color:var(--text-sub);font-family:var(--font-mono);font-size:var(--text-xs);opacity:0;pointer-events:auto;cursor:pointer;touch-action:manipulation;padding:10px 14px;display:flex;transform:translateY(-8px)scale(.985)}.app-toast.is-visible,.app-toast.show{animation:toast-in .32s var(--ease) forwards}.app-toast.is-closing,.app-toast.leaving{animation:toast-out .32s var(--ease) forwards;pointer-events:none}.app-toast-info,.app-toast.info{border-color:var(--blue);background:var(--blue-bg);color:var(--blue)}.app-toast-success,.app-toast.success{border-color:var(--green);background:var(--green-bg);color:var(--green)}.app-toast-warning,.app-toast.warning{border-color:var(--warning);background:var(--warning-bg);color:var(--warning)}.app-toast-error,.app-toast.error{border-color:var(--danger);background:var(--danger-bg);color:var(--danger)}@media (max-width:767px){.app-auth-card{padding:var(--space-3)}.app-auth-title{font-size:var(--text-lg)}.app-save-toolbar{align-items:center;gap:var(--space-2);flex-wrap:nowrap}.app-save-status{display:none}.app-tabs{margin-inline:-2px;padding-inline:2px}.app-dialog-panel{margin-top:calc(18px + env(safe-area-inset-top));max-height:calc(100dvh - 36px - env(safe-area-inset-top) - env(safe-area-inset-bottom));align-self:flex-start}.app-toast-wrap{top:calc(.75rem + env(safe-area-inset-top));right:var(--space-2);left:var(--space-2);align-items:flex-end}.app-toast{max-width:min(100%,360px)}}.app-main .toolbar,.app-main .app-toolbar{align-items:center;gap:var(--space-2);padding:.75rem var(--space-4);background:var(--surface);border-bottom:1px solid var(--divider);flex-shrink:0;display:flex}.app-main .toolbar-group,.app-main .toolbar-actions{align-items:center;gap:var(--space-2);min-width:0;display:flex}.app-main .toolbar-actions{justify-content:flex-end;margin-left:auto}.app-main .toolbar-status{color:var(--text-muted)}.app-main .form-tool-toolbar,.app-main .app-save-toolbar{width:100%;max-width:var(--app-content-max);margin:0 auto var(--space-4);padding:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.app-main .inline-status,.app-main .app-save-status{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:0;font-weight:500}@media (max-width:767px){.app-main .toolbar,.app-main .app-toolbar{padding:var(--space-2);min-height:50px}.app-main .toolbar-group,.app-main .toolbar-actions{gap:var(--space-2)}}.app-main .tabs,.app-main .app-tabs{gap:var(--space-2);-webkit-overflow-scrolling:touch;flex-direction:row;width:100%;padding-bottom:2px;display:flex;overflow-x:auto}.app-main .tab,.app-main .app-tab{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:max-content;min-height:40px;color:var(--text-muted);font-family:var(--font-ui);font-size:var(--text-xs);letter-spacing:.03em;white-space:nowrap;cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);flex:1;justify-content:center;align-items:center;padding:0 12px;font-weight:500;display:inline-flex}.app-main .tab:hover,.app-main .app-tab:hover{border-color:var(--border-hover);color:var(--text-sub)}.app-main .tab:focus-visible,.app-main .app-tab:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.app-main .tab.is-active,.app-main .tab[aria-selected=true],.app-main .app-tab.is-active,.app-main .app-tab[aria-selected=true]{border-color:var(--blue);background:var(--blue-bg);color:var(--blue)}.app-main .editable-row,.app-main .app-row{align-items:center;gap:var(--space-2);width:100%;margin-bottom:var(--space-2);display:flex}.app-main .editable-row-fields,.app-main .app-row-fields{display:contents}.app-main .editable-row-actions,.app-main .app-row-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.app-main .editable-row input[type=text],.app-main .editable-row input[type=number],.app-main .app-row input[type=text],.app-main .app-row input[type=number]{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-sub);min-height:40px;color:var(--text);font-size:var(--text-md);transition:border-color var(--motion-fast) var(--ease);outline:none}.app-main .editable-row input[type=text],.app-main .app-row input[type=text]{min-width:0;font-family:var(--font-content);flex:1;padding:8px 12px}.app-main .editable-row input[type=number],.app-main .app-row input[type=number]{width:100px;font-family:var(--font-mono);text-align:right;-moz-appearance:textfield;flex-shrink:0;padding:8px 12px;font-weight:500}.app-main .editable-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.app-main .editable-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.app-main .app-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.app-main .app-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.app-main .editable-row:focus-within input,.app-main .app-row:focus-within input{border-color:var(--blue)}.app-main .editable-row.is-danger:focus-within input,.app-main .editable-row.deduction-row:focus-within input,.app-main .app-row.is-danger:focus-within input,.app-main .app-row.deduction-row:focus-within input{border-color:var(--pink)}.app-main .editable-row.is-danger input[type=number],.app-main .editable-row.deduction-row input[type=number],.app-main .app-row.is-danger input[type=number],.app-main .app-row.deduction-row input[type=number]{color:var(--pink)}.split-view{grid-template-columns:repeat(var(--grid-columns), minmax(0, 1fr));width:100%;max-width:var(--app-shell-max);padding-inline:var(--container-pad);flex:1;gap:0;min-height:0;margin:0 auto;display:grid;overflow:hidden}.split-list-pane{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;grid-column:span 3;min-height:0;display:flex}.split-content-pane{background:var(--bg);flex-direction:column;grid-column:span 9;min-height:0;display:flex;overflow:hidden}.utility-sidebar{border-left:1px solid var(--border);background:var(--surface);flex-direction:column;grid-column:span 3;min-height:0;display:flex}.app-main .list{flex-direction:column;min-height:0;display:flex;overflow-y:auto}.app-main .list-item{width:100%;padding:12px var(--space-3);background:var(--surface);color:var(--text);text-align:left;cursor:pointer;transition:background var(--motion-default) var(--ease), color var(--motion-default) var(--ease);border:0;border-radius:0;display:block;position:relative}.app-main .list-item:after{content:"";left:var(--space-4);right:var(--space-4);background:var(--divider);pointer-events:none;height:1px;position:absolute;bottom:0}@media (hover:hover){.app-main .list-item:hover{background:var(--surface-sub)}}.app-main .list-item:focus-visible{outline:2px solid var(--blue);outline-offset:2px}.app-main .list-item.is-active,.app-main .list-item.is-selected{background:color-mix(in srgb, var(--blue-bg) 58%, var(--surface))}.app-main .list-item-title{font-family:var(--font-content);font-size:var(--text-md);color:var(--text);word-break:break-word;font-weight:500;line-height:1.3;display:block}.app-main .list-item-title.is-empty{color:var(--text-muted);font-weight:400}.app-main .list-item-description{font-family:var(--font-content);font-size:var(--text-sm);color:var(--text-muted);word-break:break-word;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;line-height:1.45;display:-webkit-box;overflow:hidden}.app-main .list-item-meta,.app-main .list-count-row{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted)}.app-main .list-item-meta{margin-top:4px;display:block}.app-main .list-item-actions{align-items:center;gap:var(--space-1);display:flex}.app-main .list-count-row{justify-content:space-between;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);display:flex}.app-main .chip,.app-main .filter-chip,.app-shell~.dialog-overlay .chip,.app-shell~.dialog-overlay .filter-chip{align-items:center;gap:var(--space-1);background:var(--gray-bg);min-height:28px;color:var(--text-sub);font-family:var(--font-ui);font-size:var(--text-xs);border:1px solid #0000;border-radius:999px;padding:4px 10px;line-height:1.2;display:inline-flex}.app-main .filter-chip,.app-shell~.dialog-overlay .filter-chip{cursor:pointer;transition:border-color var(--motion-fast) var(--ease), background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease)}.app-main .filter-chip:hover,.app-shell~.dialog-overlay .filter-chip:hover{border-color:var(--border-hover);background:var(--surface-sub);color:var(--text)}.app-main .filter-chip.is-active,.app-main .filter-chip.is-selected,.app-shell~.dialog-overlay .filter-chip.is-active,.app-shell~.dialog-overlay .filter-chip.is-selected{border-color:var(--blue);background:var(--blue-bg);color:var(--blue)}.app-main .empty-state{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4);color:var(--text-muted);text-align:center;flex-direction:column;flex:1;display:flex}.app-main .empty-state-icon{color:var(--text-muted);justify-content:center;align-items:center;display:flex}.app-main .empty-state-title{font-size:var(--text-lg);color:var(--text);font-weight:600}.app-main .empty-state-text{max-width:28rem;font-size:var(--text-sm);color:var(--text-muted)}.app-main .empty-state-compact{min-height:220px;padding:var(--space-4) var(--space-3)}.app-shell~.dialog-overlay{z-index:var(--z-overlay);padding:calc(1rem + env(safe-area-inset-top)) 1rem calc(1rem + env(safe-area-inset-bottom));background:#1a1a1a3d;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.app-shell~.dialog-overlay.open{animation:dialog-overlay-in .4s var(--ease) both;display:flex}.app-shell~.dialog-overlay.open .dialog-box,.app-shell~.dialog-overlay.open .dialog-panel{animation:dialog-in .4s var(--ease) both}.app-shell~.dialog-overlay.open.is-closing{animation:dialog-overlay-out .4s var(--ease) both}.app-shell~.dialog-overlay.open.is-closing .dialog-box,.app-shell~.dialog-overlay.open.is-closing .dialog-panel{animation:dialog-out .4s var(--ease) both}.app-shell~.dialog-overlay .dialog-box,.app-shell~.dialog-overlay .dialog-panel{z-index:var(--z-dialog);width:100%;max-width:360px;padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);position:relative}.app-shell~.dialog-overlay .dialog-panel{max-width:min(720px,100vw - 32px);max-height:calc(88dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow-y:auto}.app-shell~.dialog-overlay .dialog-close-btn{border-radius:999px;width:36px;min-width:36px;height:36px;min-height:36px;padding:0;position:absolute;top:10px;right:10px}.app-shell~.dialog-overlay .dialog-title{margin-bottom:var(--space-2);font-size:var(--text-lg);color:var(--text);padding-right:42px;font-weight:600;line-height:1.35}.app-shell~.dialog-overlay .dialog-desc{margin-bottom:var(--space-4);font-size:var(--text-sm);color:var(--text-sub)}.app-shell~.dialog-overlay .dialog-actions{justify-content:flex-end;gap:var(--space-2);display:flex}.app-shell~.dialog-overlay .confirm-modal,.app-shell~.dialog-overlay .confirm-dialog-box{max-width:360px;padding:26px var(--space-3) var(--space-4)}.app-shell~.dialog-overlay .confirm-modal .dialog-title,.app-shell~.dialog-overlay .confirm-dialog-box .dialog-title{font-size:var(--text-md);text-align:center;margin-bottom:0;padding-right:0;font-weight:700;line-height:1.4}.app-shell~.dialog-overlay .confirm-modal .dialog-actions,.app-shell~.dialog-overlay .confirm-dialog-box .dialog-actions{justify-content:center;margin-top:20px}.app-shell~.dialog-overlay .confirm-modal .btn,.app-shell~.dialog-overlay .confirm-dialog-box .btn{min-width:84px}.app-shell~.dialog-overlay .input-dialog{max-width:480px;max-height:min(88vh,680px);overflow-y:auto}@media (max-width:767px){.app-shell~.dialog-overlay .input-dialog{margin-top:calc(18px + env(safe-area-inset-top));max-height:calc(100dvh - 36px - env(safe-area-inset-top) - env(safe-area-inset-bottom));align-self:flex-start}}.app-shell~.toast-wrap{top:calc(1rem + env(safe-area-inset-top));right:max(1rem, env(safe-area-inset-right));z-index:var(--z-toast);pointer-events:none;flex-direction:column;gap:.4rem;display:flex;position:fixed}.app-shell~.toast-wrap .toast{align-items:center;gap:var(--space-2);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);max-width:280px;color:var(--text-sub);font-family:var(--font-mono);font-size:var(--text-xs);opacity:0;pointer-events:auto;cursor:pointer;touch-action:manipulation;padding:10px 14px;display:flex;transform:translateY(-8px)scale(.985)}.app-shell~.toast-wrap .toast.is-visible{animation:toast-in .32s var(--ease) forwards}.app-shell~.toast-wrap .toast.is-closing,.app-shell~.toast-wrap .toast.leaving{animation:toast-out .32s var(--ease) forwards;pointer-events:none}.app-shell~.toast-wrap .toast-info,.app-shell~.toast-wrap .toast.info{border-color:var(--blue);background:var(--blue-bg);color:var(--blue)}.app-shell~.toast-wrap .toast-success,.app-shell~.toast-wrap .toast.success{border-color:var(--green);background:var(--green-bg);color:var(--green)}.app-shell~.toast-wrap .toast-warning,.app-shell~.toast-wrap .toast.warning{border-color:var(--warning);background:var(--warning-bg);color:var(--warning)}.app-shell~.toast-wrap .toast-error,.app-shell~.toast-wrap .toast.error{border-color:var(--danger);background:var(--danger-bg);color:var(--danger)}.app-shell~.toast-wrap .toast-msg{flex:1}.app-shell~.toast-wrap .toast-close{color:inherit;font-size:var(--text-sm);opacity:.7;background:0 0;border:0;flex-shrink:0;padding:0 2px;line-height:1}.app-shell~.toast-wrap .toast-close:hover{opacity:1}@media (max-width:767px){.app-shell~.toast-wrap{top:calc(.75rem + env(safe-area-inset-top));right:var(--space-2);left:var(--space-2);align-items:flex-end}.app-shell~.toast-wrap .toast{max-width:min(100%,360px)}}.app-shell~.mobile-floating-toolbar{left:50%;bottom:calc(28px + env(safe-area-inset-bottom));z-index:var(--z-mobile-toolbar);border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 94%, transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:999px;align-items:center;gap:10px;width:min(92vw,560px);padding:8px 10px;display:none;position:fixed;transform:translate(-50%);box-shadow:0 10px 28px #1a1a1a1f}.app-shell~.mobile-floating-toolbar.visible,.app-shell~.mobile-floating-toolbar.is-visible{display:flex}.app-shell~.mobile-floating-toolbar .search-button{border-radius:999px;flex:auto;justify-content:flex-start;min-width:0;height:52px;min-height:52px;padding:10px 18px}.app-shell~.mobile-floating-toolbar .primary-action{gap:var(--space-2);min-width:132px;height:52px;min-height:52px;font-size:var(--text-sm);white-space:nowrap;border-radius:999px;flex:none;padding:0 18px;line-height:1.2}@media (max-width:1023px){.app-shell~.mobile-floating-toolbar{gap:var(--space-2);width:min(92vw - 40px,520px);min-height:56px;padding:6px 8px;bottom:56px}.app-shell~.mobile-floating-toolbar .search-button,.app-shell~.mobile-floating-toolbar .primary-action{height:44px;min-height:44px;padding:8px 14px}.app-shell~.mobile-floating-toolbar .primary-action{min-width:120px;padding-block:0}}@media (max-width:359px){.app-shell~.mobile-floating-toolbar{width:calc(100vw - 64px)}.app-shell~.mobile-floating-toolbar .primary-action{min-width:104px}}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-8px)scale(.985)}}@keyframes dialog-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes dialog-overlay-out{0%{opacity:1}to{opacity:0}}@keyframes dialog-in{0%{opacity:0;transform:translateY(8px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes dialog-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(8px)scale(.985)}}@media (max-width:1023px){.split-view{flex-direction:column;padding-inline:0;display:flex;overflow:visible}.split-list-pane{border-right:none;border-bottom:1px solid var(--border)}.split-content-pane{flex:1;min-height:0;overflow:auto}.utility-sidebar{border-left:none;border-top:1px solid var(--border)}}@media (prefers-reduced-motion:reduce){.app-shell~.toast-wrap .toast,.app-shell~.toast-wrap .toast.is-closing,.app-shell~.toast-wrap .toast.leaving,.app-shell~.dialog-overlay.open,.app-shell~.dialog-overlay.open .dialog-box,.app-shell~.dialog-overlay.open .dialog-panel,.app-shell~.dialog-overlay.open.is-closing,.app-shell~.dialog-overlay.open.is-closing .dialog-box,.app-shell~.dialog-overlay.open.is-closing .dialog-panel,.app-toast,.app-toast.is-closing,.app-toast.leaving,.app-dialog-overlay.open,.app-dialog-overlay.is-open,.app-dialog-overlay.open .app-dialog-box,.app-dialog-overlay.open .app-dialog-panel,.app-dialog-overlay.open .app-confirm-modal,.app-dialog-overlay.is-open .app-dialog-box,.app-dialog-overlay.is-open .app-dialog-panel,.app-dialog-overlay.is-open .app-confirm-modal,.app-dialog-overlay.open.is-closing,.app-dialog-overlay.is-open.is-closing,.app-dialog-overlay.open.is-closing .app-dialog-box,.app-dialog-overlay.open.is-closing .app-dialog-panel,.app-dialog-overlay.open.is-closing .app-confirm-modal,.app-dialog-overlay.is-open.is-closing .app-dialog-box,.app-dialog-overlay.is-open.is-closing .app-dialog-panel,.app-dialog-overlay.is-open.is-closing .app-confirm-modal{animation:none}.app-shell~.toast-wrap .toast,.app-toast{opacity:1;transform:none}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
.lv-page{gap:var(--space-4);display:grid}.lv-header-row,.lv-filter-grid,.lv-form-grid,.lv-detail-header{gap:var(--space-3);display:grid}.lv-header-row{grid-template-columns:minmax(0,1fr) auto;align-items:end}.lv-filter-grid{grid-template-columns:minmax(180px,1.4fr) minmax(140px,.8fr) minmax(140px,.8fr) auto;align-items:end}.lv-form-grid{grid-template-columns:minmax(0,1fr) minmax(220px,320px)}.lv-form-main,.lv-form-side,.lv-list,.lv-empty,.lv-login-note{gap:var(--space-3);display:grid}.lv-list{list-style:none}.lv-link-item{text-align:left;width:100%}.lv-link-line{gap:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.lv-domain,.lv-date{align-items:center;gap:var(--space-1);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);display:inline-flex}.lv-chip-row{gap:var(--space-2);flex-wrap:wrap;display:flex}.lv-chip{background:var(--surface-sub);border:1px solid var(--border);min-height:28px;color:var(--text-sub);font-size:var(--text-sm);border-radius:999px;align-items:center;padding:3px 9px;display:inline-flex}.lv-chip.is-blue{background:var(--blue-bg);color:var(--blue);border-color:#0000}.lv-chip.is-pink{background:var(--pink-bg);color:var(--pink);border-color:#0000}.lv-chip.is-green{background:var(--green-bg);color:var(--green);border-color:#0000}.lv-muted{color:var(--text-muted)}.lv-actions{gap:var(--space-2);flex-wrap:wrap;justify-content:flex-end;display:flex}.lv-checkbox-row{align-items:center;gap:var(--space-2);min-height:42px;display:flex}.lv-status{min-height:24px}.lv-danger-zone{border-top:1px solid var(--divider);padding-top:var(--space-3)}@media (max-width:767px){.lv-header-row,.lv-filter-grid,.lv-form-grid{grid-template-columns:1fr}.lv-actions{justify-content:stretch}.lv-actions .btn{flex:1}}
