:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg:#f6f8fb;--card:#fff;--muted:#6b7280;--accent:#023880ff;--content-max: 1440px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:#111827}.app-shell{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--card);box-shadow:0 1px 4px #0a6d330f;position:sticky;top:0;z-index:10}.brand{font-weight:700;display:flex;align-items:center;gap:.75rem}.app-title{font-size:1.5rem;font-weight:600}.right-side{display:flex;align-items:center;gap:1rem}.title-section{display:flex;align-items:center}.boat-name{font-size:2rem;font-weight:600;color:#0f4a9c;white-space:nowrap}.actions{display:flex;gap:.5rem;align-items:center}.add-btn,.hamburger{border:none;background:var(--accent);color:#fff;border-radius:.5rem;padding:.4rem .6rem;cursor:pointer}.hamburger{background:#111827}.menu{position:relative}.menu-dropdown{position:absolute;right:0;top:120%;background:var(--card);border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 30px #0000001f;min-width:220px}.menu-item{padding:.6rem .8rem;cursor:pointer}.menu-item:hover{background:#f3f4f6}.menu-item.selected{background:#e5f0ff}.menu-title{font-weight:600}.menu-sub{font-size:1rem;color:var(--muted)}.muted{color:var(--muted)}.content{width:min(var(--content-max),100% - 2rem);margin:1rem auto 2rem;display:grid;gap:1rem;align-items:start;grid-template-columns:1.15fr 1fr}@media(min-width:1600px){:root{--content-max: 1600px}.content{grid-template-columns:1.3fr 1fr;gap:1.25rem}}@media(max-width:1200px){.content{grid-template-columns:1fr 1fr}}@media(max-width:900px){.content{grid-template-columns:1fr}}.left,.right{min-width:0;display:grid;gap:1rem}.right{position:sticky;top:64px;height:fit-content}.card{background:var(--card);border-radius:2rem;padding:1rem;box-shadow:0 2px 16px #0000000f;border:1px solid #e5e7eb;overflow:visible}.chart-card{min-height:520px}.chart-wrap{width:100%;height:clamp(320px,42vh,560px)}.grid{display:grid;gap:1rem;grid-template-columns:repeat(2,minmax(0,1fr))}@media(max-width:640px){.grid{grid-template-columns:1fr}}label span{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.25rem}input,select{width:100%;padding:.55rem .6rem;border:1px solid #e5e7eb;border-radius:.5rem;background:#fff;font-size:14px;height:38px;outline:none}.row{margin-top:1rem;display:flex;gap:.7rem;flex-wrap:wrap}button{background:var(--accent);color:#fff;border:none;padding:.55rem .8rem;border-radius:.5rem;cursor:pointer;font-size:18px}button:disabled{opacity:.6;cursor:not-allowed}.table-wrap{max-height:420px;overflow:auto;border:1px solid #eef2f7;border-radius:.5rem}table{width:100%;border-collapse:collapse;table-layout:fixed}th,td{border-bottom:1px solid #e5e7eb;padding:.5rem .6rem;text-align:center;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}thead th{position:sticky;top:0;background:var(--card);z-index:1}.recharts-wrapper,.recharts-surface{overflow:visible}.result-box{margin-top:1.25rem;background:#f9fbfa;padding:1rem;border-radius:.75rem;border:1px solid #21884c}.result-row{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.result-row:last-child{margin-bottom:0}
