/* 02-layout.css — App shell, header, toolbar, nav, grid, summary, responsive */
*{box-sizing:border-box}[hidden]{display:none!important}html{overflow-y:scroll;scrollbar-gutter:stable}body{margin:0;min-height:100vh;background:var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}button,input,select,textarea{font:inherit}.app{max-width:1240px;margin:0 auto;padding:24px}header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:22px}h1{margin:0;font-size:clamp(1.3rem,2.5vw,1.9rem);line-height:1.05;white-space:nowrap}.subtitle{margin:8px 0 0;color:var(--muted);max-width:760px;line-height:1.45}.toolbar{display:grid;gap:8px;justify-items:end;width:max-content;max-width:100%;margin-left:auto}.toolbar-actions,.toolbar-filter-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;align-items:flex-start;width:100%}.toolbar-filter-row{justify-content:flex-end;min-height:42px;width:100%;overflow:hidden}.toolbar-filter-row #filterBuilder{width:100%;max-width:none}button{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:8px;padding:10px 13px;cursor:pointer;min-height:42px}button.primary{background:var(--green);border-color:var(--green);color:white;font-weight:700}button.primary:hover{background:var(--green-dark)}button:hover{border-color:#b8ae9f}.grid{display:grid;grid-template-columns:minmax(330px,430px) 1fr;gap:18px;align-items:start}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.panel-inner{padding:18px}h2{margin:0 0 14px;font-size:1.05rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-section{border:0;border-top:1px solid var(--line);margin:16px 0 0;padding:16px 0 0}.form-section:first-of-type{border-top:0;margin-top:0;padding-top:0}.form-section legend{padding:0;margin:0 0 12px;color:var(--ink);font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.full{grid-column:1/-1}label{display:grid;gap:6px;color:var(--muted);font-size:.88rem;font-weight:650}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:10px 11px;background:var(--panel);color:var(--ink);min-height:42px}textarea{min-height:76px;resize:vertical}.form-actions{display:flex;gap:8px;align-items:center;margin-top:16px;flex-wrap:wrap}.summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.metric{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:14px;min-height:96px}.metric span{display:block;color:var(--muted);font-size:.84rem;margin-bottom:8px}.metric strong{display:block;font-size:clamp(1.15rem,2vw,1.55rem);line-height:1.1;overflow-wrap:anywhere}.metric.good strong{color:var(--green)}.metric.bad strong{color:var(--red)}.filter-builder{display:grid;gap:8px}.filter-row{display:grid;grid-template-columns:42px minmax(128px,var(--filter-key-width,160px)) minmax(150px,1fr) 42px;gap:8px;align-items:center;width:100%}.filter-row:has([data-remove-filter][disabled]){grid-template-columns:minmax(128px,var(--filter-key-width,160px)) minmax(150px,1fr) 42px}.filter-row select,.filter-row input{min-width:0;height:42px;min-height:42px}.filter-row .icon-btn{width:42px;height:42px;min-height:42px}.icon-btn{display:inline-grid;place-items:center;font-size:1.2rem;font-weight:800;padding:0}.icon-btn[disabled]{display:none}#tableWrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}th{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:var(--bg);vertical-align:middle}.specs-col{min-width:180px;width:20%}.nowrap{white-space:nowrap}tbody tr:hover{background:var(--bg)}.amount{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.money-line{display:inline-block;white-space:nowrap}.table-line{display:block;min-height:20px;line-height:20px}.table-line.primary{color:var(--ink);font-weight:750}.table-line.muted{color:var(--muted);font-size:.86rem}.table-line.vessel-line{font-size:.74rem;line-height:16px;min-height:16px}.table-line.clamp-2{display:-webkit-box;min-height:0;max-height:40px;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical;white-space:normal}.table-divider{display:block;border-top:1px solid var(--line);height:1px;margin:7px 0}.profit-positive{color:var(--green);font-weight:750}.profit-negative{color:var(--red);font-weight:750}.pill{display:inline-flex;border-radius:999px;padding:4px 9px;font-size:.76rem;font-weight:750;line-height:1.25;background:#e7f3ec;color:var(--green-dark);white-space:normal}.pill.finance{background:#fff3d8;color:var(--gold)}.pill.done{background:#e7f3ec;color:var(--green-dark)}.pill.warn{background:#f8e8e8;color:var(--red)}.row-actions{display:flex;justify-content:flex-end;gap:6px}.row-actions button{min-height:34px;padding:6px 9px;font-size:.82rem}.monthly{display:grid;gap:10px;margin-top:18px}.month-row{display:grid;grid-template-columns:120px 1fr 130px;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--line)}.bar{height:13px;background:#e4ded2;border-radius:999px;overflow:hidden}.bar>span{display:block;height:100%;width:0;background:var(--green);border-radius:inherit}.empty{padding:36px 18px;color:var(--muted);text-align:center}.hint{color:var(--muted);font-size:.86rem;line-height:1.4;margin-top:12px}.danger{color:var(--red)}@media(max-width:980px){.grid{grid-template-columns:1fr}.summary{grid-template-columns:repeat(2,1fr)}header{display:grid}.toolbar{justify-items:start;width:auto;margin-left:0}.toolbar-actions,.toolbar-filter-row{justify-content:flex-start}}@media(max-width:700px){.app{padding:16px}.form-grid,.summary{grid-template-columns:1fr}.filter-row,.filter-row:has([data-remove-filter][disabled]){grid-template-columns:1fr}.filter-row select,.filter-row input,.filter-row button{width:100%}.toolbar-filter-row{display:grid}.toggle-col{width:auto;min-width:0;text-align:left}table,thead,tbody,th,td,tr{display:block}thead{display:none}tr{border-bottom:1px solid var(--line);padding:10px 0}td{border:0;padding:5px 14px}td::before{content:attr(data-label);display:block;color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.specs-col{min-width:0;width:auto}.amount{text-align:left;white-space:normal}.row-actions{justify-content:flex-start}.month-row{grid-template-columns:1fr}}
