/* =============================================================
   Nemomex — Calculator (app.php) styles
   Compact maritime spreadsheet
   ============================================================= */

.app-body{background:var(--bg);min-height:100vh;font-size:13px}

/* Voyage identity strip below navbar */
.voyage-strip{
  background:#fff;border-bottom:1px solid var(--line);
  padding:8px 22px;display:grid;
  grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end;
  max-width:100%;box-shadow:0 1px 0 var(--line-soft);
}
.voyage-strip label{display:flex;flex-direction:column;font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);font-weight:700}
.voyage-strip input{padding:6px 9px;border:1px solid var(--line);border-radius:4px;font-family:inherit;font-size:13px;background:#fbfcfe;margin-top:3px;transition:border-color .12s,background .12s}
.voyage-strip input:focus{outline:none;border-color:var(--navy);background:#fff}
.voy-actions{display:flex;gap:6px;flex-wrap:wrap}
.voyage-strip .btn{padding:7px 12px;font-size:12px}
.voyage-strip .btn-ghost{background:#f0f4f8;color:var(--ink-2);border:1px solid var(--line)}
.voyage-strip .btn-ghost:hover{background:#e6ecf2;color:var(--navy)}
@media(max-width:900px){.voyage-strip{grid-template-columns:1fr 1fr}.voy-actions{grid-column:1/-1}}
@media(max-width:600px){.voyage-strip{grid-template-columns:1fr}}

/* Remove spinner arrows on all number inputs in the app */
input[type=number].no-spin::-webkit-outer-spin-button,
input[type=number].no-spin::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
input[type=number]{ -moz-appearance:textfield; appearance:textfield; }

/* Main map + right col */
.layout{display:grid;grid-template-columns:1fr 300px;gap:0;min-height:420px}
.left-col{position:relative;background:#fff}
#map{width:100%;height:440px;background:#dbe7ee}

.controls-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-top:1px solid var(--line);background:#eef3f7;flex-wrap:wrap}
.canal-group{display:flex;gap:16px}
.chk{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px;color:var(--ink-2)}
.chk input{accent-color:var(--navy);width:14px;height:14px}
.controls-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.inline{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--ink-2)}
.inline input{width:66px;padding:5px 7px;border:1px solid var(--line);border-radius:3px;text-align:right;font-family:inherit;font-size:12px}
.unit{color:var(--muted);font-size:11px;font-weight:500}

/* Right summary / Fuel Estimation */
.right-col{background:linear-gradient(180deg,#0b3d5c 0%,#0a2e46 100%);color:#d5e4f0;padding:14px 16px;border-left:3px solid var(--brass)}
.right-col h3{margin:0 0 10px;font-size:12px;color:var(--brass);letter-spacing:1px;text-transform:uppercase;display:flex;align-items:center;gap:6px}
.right-col h3 i{color:var(--brass)}
.fuel-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;padding:8px;background:rgba(0,0,0,.15);border-radius:4px;margin-bottom:10px}
.fuel-inputs label{display:flex;flex-direction:column;font-size:10px;font-weight:600;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.5px}
.fuel-inputs input{padding:4px 6px;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.25);color:#fff;border-radius:3px;font-family:'JetBrains Mono',monospace;font-size:12px;text-align:right;margin-top:3px}
.fuel-inputs input:focus{outline:none;border-color:var(--brass)}
.fuel-inputs .unit{color:rgba(255,255,255,.5);margin-top:2px;font-size:9px}
.metric{display:flex;align-items:baseline;justify-content:space-between;padding:7px 0;border-bottom:1px dashed rgba(255,255,255,.1);font-size:12px}
.metric span{color:rgba(255,255,255,.7)}
.metric b{font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace}
.metric em{font-style:normal;color:var(--brass);font-size:10px;margin-left:3px}
.metric.hi b{color:var(--brass);font-size:16px}
.canals-tags{display:flex;flex-wrap:wrap;gap:5px;margin:10px 0 6px}
.canal-pill{background:var(--brass);color:#1c1200;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.5px}
.tips{margin-top:12px;font-size:11px;line-height:1.5;color:rgba(255,255,255,.55);padding:8px 10px;background:rgba(0,0,0,.15);border-radius:4px;border-left:2px solid var(--brass)}
.tips i{color:var(--brass);margin-right:4px}

/* Tables area */
.tables-wrap{background:#fff;border-top:1px solid var(--line);padding:0 0 20px}
.tabs{display:flex;align-items:center;gap:2px;padding:6px 8px 0;background:#eaf0f5;border-bottom:1px solid var(--line)}
.tab{background:#dae3ec;color:var(--ink-2);border:1px solid var(--line);border-bottom:none;padding:5px 14px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;border-radius:4px 4px 0 0}
.tab:hover{background:#e3ebf3}
.tab.active{background:#fff;color:var(--navy);border-bottom:2px solid #fff;margin-bottom:-1px;box-shadow:0 -2px 6px rgba(11,61,92,.06)}
.tabs-spacer{flex:1}
.tables-wrap .btn-ghost{background:#f0f4f8;color:var(--ink-2);border:1px solid var(--line)}
.tables-wrap .btn-ghost:hover{background:#e6ecf2}

.table-panel{display:none}
.table-panel.active{display:block}
.ports-table{width:100%;overflow-x:auto}
.pt-head,.pt-row,.pt-total{
  display:grid;
  /* Wider Distance / ECA / Port Charge */
  grid-template-columns:
    32px minmax(260px,2.2fr)
    120px 90px 55px 60px
    60px 60px 120px
    130px 130px 34px;
  align-items:center;
  min-width:1240px;
  font-size:12px;
}
.pt-head{background:var(--navy);color:#fff;font-weight:600;font-size:10.5px;letter-spacing:.5px;text-transform:uppercase}
.pt-head > div,.pt-row > div,.pt-total > div{padding:6px 8px;border-right:1px solid var(--line-soft);min-height:28px;display:flex;align-items:center}
.pt-head > div{border-right:1px solid rgba(255,255,255,.15);justify-content:flex-start}
.pt-head .c-dist,.pt-head .c-eca,.pt-head .c-wf,.pt-head .c-speed,.pt-head .c-sea,.pt-head .c-port-days,.pt-head .c-charge{justify-content:center}
.pt-row{border-bottom:1px solid var(--line-soft);background:#fff}
.pt-row:nth-child(even){background:#fbfcfe}
.pt-row:hover{background:#f2f7fb}

.cell-input{width:100%;border:none;background:transparent;padding:4px 6px;font-family:inherit;font-size:12px;text-align:right;outline:none;-moz-appearance:textfield;appearance:textfield}
.cell-input::-webkit-outer-spin-button,.cell-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.cell-input:focus{background:#fff8d0}
.pt-row .c-dist input,.pt-row .c-sea input,.pt-row .c-wf input,.pt-row .c-charge input{background:#fff9c8;border-radius:2px}
.pt-row .c-eca input{background:#ddf2df;border-radius:2px}
.pt-row .c-port-days input{background:#fff9c8;border-radius:2px}
.c-no{color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:11px}
.c-port{position:relative;padding:0 !important}
.port-picker{width:100%;height:100%;padding:4px 8px;border:none;outline:none;background:transparent;font-family:inherit;font-size:12px;color:var(--ink)}
.port-picker::placeholder{color:#98a5b5}
.port-picker:focus{background:#fff8d0}
.port-suggest{position:absolute;top:100%;left:0;z-index:900;min-width:340px;max-height:260px;overflow-y:auto;background:#fff;border:1px solid var(--line);border-radius:3px;box-shadow:0 6px 18px rgba(15,28,43,.15);display:none}
.port-suggest.open{display:block}
.suggest-item{padding:6px 10px;font-size:12px;border-bottom:1px solid var(--line-soft);cursor:pointer;display:flex;justify-content:space-between;gap:8px}
.suggest-item:hover,.suggest-item.hi{background:#f0f5f9}
.suggest-item small{color:var(--muted);font-size:11px}
.suggest-empty{padding:10px;color:var(--muted);font-size:11px;text-align:center}
.c-arr input,.c-dep input{width:100%;border:none;background:transparent;padding:4px 8px;font-family:inherit;font-size:12px;outline:none}
.c-arr input:focus,.c-dep input:focus{background:#fff8d0}
.c-act{justify-content:center !important}
.btn-del{background:transparent;border:none;color:var(--coral);cursor:pointer;padding:4px;border-radius:3px;font-size:13px}
.btn-del:hover{background:#ffe6e6}
.pt-total{background:#f6f9fc;border-top:2px solid var(--navy);font-weight:700;color:var(--navy);font-family:'JetBrains Mono',monospace}
.pt-total > div{padding:9px 8px}
.pt-total .c-port b{color:var(--ink);font-family:'Barlow',sans-serif}
.below-total-spacer{height:36px;background:transparent}   /* extra breathing space */

/* Modal */
.modal{position:fixed;inset:0;background:rgba(9,20,30,.55);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:2000;padding:20px}
.modal.open{display:flex}
.modal-card{background:#fff;border-radius:6px;width:100%;max-width:460px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35);border-top:4px solid var(--brass);animation:pop .18s ease-out}
.modal-card.lg{max-width:680px}
@keyframes pop{from{transform:translateY(20px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-card header{padding:12px 16px;border-bottom:1px solid var(--line);background:var(--navy);color:#fff;display:flex;justify-content:space-between;align-items:center}
.modal-card h3{margin:0;font-size:13px;letter-spacing:.5px}
.modal-card h3 i{color:var(--brass);margin-right:5px}
.modal-card .x{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer}
.modal-body{padding:16px;font-size:13px;line-height:1.5}
.modal-body label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.modal-body label input{width:100%;padding:9px 11px;border:1.5px solid var(--line);border-radius:5px;font-family:inherit;font-size:14px;margin-top:6px;font-weight:400;text-transform:none;letter-spacing:0}
.modal-body .hint{color:var(--muted);font-size:11px;margin:0 0 8px}
.modal-body textarea{width:100%;min-height:260px;font-family:'JetBrains Mono',monospace;font-size:12px;padding:10px;border:1px solid var(--line);border-radius:4px;resize:vertical;background:#fbfcfe;outline:none}
.modal-body textarea:focus{border-color:var(--navy);background:#fff}
.modal-card footer{padding:10px 16px;border-top:1px solid var(--line);background:#f5f7fa;display:flex;justify-content:flex-end;gap:8px}
.modal-card footer .btn-ghost{background:#e6ecf2;color:var(--ink-2);border:1px solid var(--line)}
.canal-item{padding:10px;border:1px solid var(--line);border-radius:4px;margin-bottom:8px;background:#f7fbff;font-size:12px}
.canal-item b{color:var(--navy)}
.canal-save{color:var(--cyan);font-weight:700;font-family:'JetBrains Mono',monospace}
.load-list{max-height:400px;overflow-y:auto}
.load-item{display:grid;grid-template-columns:1fr auto;padding:10px 12px;border-bottom:1px solid var(--line-soft);gap:12px;align-items:center;cursor:pointer}
.load-item:hover{background:#f0f5f9}
.load-item .li-main{color:var(--navy);font-weight:600}
.load-item .li-meta{font-size:11px;color:var(--muted);margin-top:2px}
.load-item .li-actions button{background:transparent;border:none;cursor:pointer;padding:4px 6px;color:var(--muted);font-size:14px}
.load-item .li-actions button:hover{color:var(--coral)}
.load-empty{padding:30px;text-align:center;color:var(--muted)}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:10px 18px;border-radius:4px;font-size:13px;box-shadow:0 8px 24px rgba(0,0,0,.35);opacity:0;transition:opacity .2s,transform .2s;z-index:3000;border-left:3px solid var(--brass);max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{border-left-color:var(--coral)}
.toast.success{border-left-color:var(--cyan)}
.port-marker{background:var(--brass);border:2px solid var(--navy);border-radius:50%;width:12px !important;height:12px !important;box-shadow:0 0 8px rgba(224,179,74,.6)}
.port-marker.start{background:var(--cyan)}
.port-marker.end{background:var(--coral)}

@media(max-width:1000px){.layout{grid-template-columns:1fr}.right-col{border-left:none;border-top:3px solid var(--brass)}#map{height:340px}}
@media(max-width:640px){#map{height:260px}.tab{padding:5px 10px;font-size:11px}}
