:root{--teal: #0f766e;--teal-d: #0b5a54;--line: #d8dee4;--bg: #f6f8f9;--warn: #fff7ed;--warn-line: #fdba74}*{box-sizing:border-box}html,body{margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Hiragino Kaku Gothic ProN,Noto Sans JP,Meiryo,sans-serif;background:var(--bg);color:#1f2933;-webkit-text-size-adjust:100%}.app{max-width:1100px;margin:0 auto;padding:16px}header h1{font-size:20px;margin:0 0 4px;display:flex;align-items:center;gap:8px}.badge{font-size:11px;font-weight:700;color:#fff;background:var(--teal);padding:2px 8px;border-radius:999px}.sub{margin:0 0 12px;color:#647280;font-size:13px}.account-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin:0 0 12px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 12px}.account-bar .acct{font-size:12px;color:#647280;font-weight:600}.account-bar-btns{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.feedback-btn{background:var(--teal);color:#fff;text-decoration:none;padding:6px 12px;border-radius:8px;font-weight:600;font-size:13px}.feedback-btn:hover{background:var(--teal-d)}.signout-btn{background:#fff;color:#647280;border:1px solid var(--line);padding:6px 12px;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer}.signout-btn:hover{background:#f0f2f4}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:8px 16px;flex-wrap:wrap;margin:0 0 12px}.topbar-left{min-width:0}.topbar-left .sub{margin:2px 0 0}.topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;margin-left:auto}.topbar-right .acct{font-size:12px;color:#647280;font-weight:600}.toolbar button:disabled{opacity:.5;cursor:not-allowed;background:#f4f6f7;border-color:var(--line);color:#aab4bd}.boot{min-height:60vh;display:flex;align-items:center;justify-content:center}.boot-spinner{width:36px;height:36px;border-radius:50%;border:4px solid #d8e3e1;border-top-color:var(--teal);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:380px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 22px;box-shadow:0 6px 24px #0000000f}.login-card h1{font-size:20px;margin:0 0 8px;display:flex;align-items:center;gap:8px}.login-lead{color:#647280;font-size:13px;margin:0 0 16px;line-height:1.6}.login-agree{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:#4a5763;margin:0 0 16px;line-height:1.5}.login-agree input{width:auto;min-width:0;margin-top:2px}.login-agree a{color:var(--teal-d)}.login-google{width:100%;background:#fff;color:#3c4043;border:1px solid #dadce0;padding:11px 14px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer}.login-google:hover:not(:disabled){background:#f7f8f8}.login-google:disabled{opacity:.5;cursor:not-allowed}.login-or{text-align:center;color:#9aa6b1;font-size:12px;margin:18px 0 14px}.login-field{display:flex;flex-direction:column;gap:6px;margin:0 0 14px}.login-field label{font-size:13px;font-weight:700;color:#4a5763}.login-field input{font-size:16px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:inherit}.login-field input:focus{outline:2px solid var(--teal);outline-offset:0;border-color:var(--teal)}.login-pw-wrap{position:relative;display:flex}.login-pw-wrap input{flex:1 1 auto;padding-right:64px}.login-pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:#eef2f4;color:var(--teal-d);border:none;border-radius:6px;padding:6px 10px;font-size:13px;font-weight:600;cursor:pointer}.login-pw-toggle:hover{background:#e1e8eb}.login-code-input{text-align:center;letter-spacing:.5em;font-size:24px!important;font-weight:700;font-variant-numeric:tabular-nums}.login-primary{width:100%;background:var(--teal);color:#fff;border:none;padding:14px;border-radius:8px;font-weight:700;font-size:16px;cursor:pointer}.login-primary:hover:not(:disabled){background:var(--teal-d)}.login-primary:disabled{background:#cbd2d8;cursor:not-allowed}.login-links{display:flex;flex-direction:column;gap:10px;margin:16px 0 0}.login-link{background:none;border:none;color:var(--teal-d);font-size:14px;font-weight:600;cursor:pointer;padding:4px 0;text-align:left}.login-link:hover{text-decoration:underline}.login-link:disabled{color:#9aa6b1;cursor:not-allowed;text-decoration:none}.login-notice{background:#ecf6f4;border:1px solid var(--teal);border-radius:8px;padding:12px;font-size:13px;color:var(--teal-d);line-height:1.6;margin:14px 0 0}.login-error{background:#fdecec;border:1px solid #f0b4b4;border-radius:8px;padding:12px;color:#c0392b;font-size:13px;line-height:1.6;margin:14px 0 0}.meta{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:0 0 12px}.field{display:flex;flex-direction:column;gap:4px;flex:1 1 280px}.field span{font-size:12px;color:#647280;font-weight:600}.field input{font-size:14px}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toolbar button{background:#fff;color:var(--teal-d);border:1px solid var(--teal);padding:8px 14px;border-radius:8px;font-weight:600;cursor:pointer;font-size:13px}.toolbar button:hover{background:#eaf5f3}.toolbar button.ghost{color:#647280;border-color:var(--line)}.toolbar button.ghost:hover{background:#f0f2f4}.saved{color:#8a97a3;font-size:12px;min-width:92px}.saved.dirty{color:#c0392b;font-weight:700}.open-panel{border:1px solid var(--line);border-radius:10px;background:#fff;padding:10px 12px;margin:0 0 12px}.open-head{font-size:12px;font-weight:700;color:var(--teal-d);margin-bottom:6px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.open-backup{border:1px solid var(--teal);background:#fff;color:var(--teal-d);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer}.open-backup:hover{background:#eaf5f3}.open-empty{font-size:13px;color:#647280}.open-list{list-style:none;margin:0;padding:0}.open-list li{display:flex;align-items:center;gap:10px;padding:7px 4px;border-top:1px solid #eef1f3}.open-list li.cur{background:#f0f8f6}.open-name{flex:1 1 auto;text-align:left;border:none;background:transparent;color:var(--teal-d);font-weight:600;font-size:14px;cursor:pointer;padding:4px 6px;border-radius:6px}.open-name:hover{background:#eaf5f3;text-decoration:underline}.open-date{color:#8a97a3;font-size:12px;white-space:nowrap}.open-del{border:1px solid var(--line);background:#fff;color:#c0392b;border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer}.open-del:hover{background:#fdecec}.drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f766e1a;display:flex;align-items:center;justify-content:center;pointer-events:none}.drop-box{background:#fff;border:2px dashed var(--teal);color:var(--teal-d);padding:20px 28px;border-radius:12px;font-weight:700;font-size:16px;box-shadow:0 8px 30px #00000026}.print-head{display:none}.table-wrap{overflow:auto;max-height:calc(100vh - 260px);border:1px solid var(--line);border-radius:10px;background:#fff}table{border-collapse:collapse;width:100%;min-width:820px;font-size:13px}th,td{border-bottom:1px solid var(--line);padding:6px 8px;text-align:left}thead th{background:var(--teal);color:#fff;font-weight:600;font-size:12px;line-height:1.2;position:sticky;top:0;z-index:2;white-space:nowrap}thead th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}.col-no{width:28px;text-align:center;color:#8a97a3}.col-grip{width:24px;text-align:center;padding-left:4px;padding-right:0}.grip-btn{border:none;background:transparent;color:#9aa6b1;cursor:grab;padding:3px;border-radius:4px;line-height:0;touch-action:none}.grip-btn:hover{color:var(--teal);background:#eef5f3}.grip-btn:focus-visible{outline:2px solid var(--teal);outline-offset:1px}.grip-btn:active{cursor:grabbing}tbody tr.dragging{opacity:.45}tbody tr.drag-over td{box-shadow:inset 0 2px 0 0 var(--teal)}tbody tr:nth-child(2n){background:#fafbfc}tbody tr.warn{background:var(--warn)}td.strong{font-weight:700}td.num{white-space:nowrap}input,select{width:100%;min-width:60px;padding:5px 6px;border:1px solid var(--line);border-radius:6px;font-size:13px;background:#fff;color:inherit}input:disabled,select:disabled{background:#eef1f3;color:#aab4bd}select{min-width:96px}input[type=number]{min-width:70px;text-align:right}.del{border:none;background:#fdecec;color:#c0392b;border-radius:6px;width:26px;height:26px;cursor:pointer;font-size:15px;line-height:1}.del:hover{background:#f8d4d4}tfoot td{background:#ecf6f4;font-weight:700;border-top:2px solid var(--teal)}.total-label{text-align:right;color:var(--teal-d)}td.total{color:var(--teal-d);font-size:14px}.actions{margin-top:12px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.add{background:var(--teal);color:#fff;border:none;padding:9px 16px;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px}.add:hover{background:var(--teal-d)}.add:disabled{background:#cbd2d8;cursor:not-allowed}.hint{color:#8a97a3;font-size:12px}.actions .hint{flex-basis:100%}.grand-total{margin-left:auto;font-weight:600;color:var(--teal-d);font-size:14px;white-space:nowrap}.grand-total strong{font-size:17px}.cards{display:flex;flex-direction:column;gap:10px}.card{border:1px solid var(--line);border-radius:10px;background:#fff;padding:10px 12px}.card.warn{background:var(--warn);border-color:var(--warn-line)}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.card-no{font-weight:700;color:#647280;font-size:13px}.card-head-btns{display:flex;gap:6px}.card-head-btns .mv{border:1px solid var(--line);background:#fff;color:var(--teal-d);border-radius:6px;width:34px;height:34px;font-size:12px;cursor:pointer}.card-head-btns .mv:disabled{color:#cbd2d8}.card-head-btns .del{width:34px;height:34px;font-size:18px}.card-row{display:flex;align-items:center;gap:10px;padding:5px 0}.card-row>span{width:80px;flex:none;font-size:13px;color:#647280}.card-row select,.card-row input{flex:1 1 auto;font-size:16px;padding:9px 8px}.card-weight{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px dashed var(--line)}.card-weight span{color:#647280;font-size:13px}.card-weight strong{color:var(--teal-d);font-size:18px}.m-total{position:sticky;bottom:0;margin-top:12px;display:flex;align-items:center;justify-content:space-between;background:#ecf6f4;border:1px solid var(--teal);border-radius:10px;padding:12px 14px}.m-total span{font-weight:700;color:var(--teal-d)}.m-total strong{color:var(--teal-d);font-size:20px}@media (max-width: 640px){.app{padding:10px}table{font-size:12px}.hint{font-size:11px}.meta{gap:8px}.toolbar button{padding:8px 12px}}@media print{.toolbar,.actions,.col-actions,.badge,.sub,.meta .field{display:none!important}.app{max-width:none;padding:0}.print-head{display:block;margin:0 0 8px}.ph-title{font-size:16px;font-weight:700}.ph-sub{font-size:12px;color:#000;margin-top:2px}.table-wrap{border:none;overflow:visible;border-radius:0}table{min-width:0;width:100%;font-size:11px}th,td{border:1px solid #999!important}thead th{background:#e8efee!important;color:#000!important;position:static;-webkit-print-color-adjust:exact;print-color-adjust:exact}tbody tr:nth-child(2n),tbody tr.warn{background:#fff!important}tfoot td{background:#eef5f3!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}input,select{border:none!important;background:transparent!important;color:#000!important;padding:1px!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0}tr{break-inside:avoid}}
