*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',system-ui,sans-serif;background:#0a1628;overflow:hidden;height:100vh}
#map{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1}
.header{position:fixed;top:0;left:0;right:0;z-index:1000;height:50px;background:linear-gradient(135deg,rgba(10,61,98,.96),rgba(30,111,143,.96));color:#fff;display:flex;align-items:center;padding:0 16px;gap:12px;box-shadow:0 2px 12px rgba(0,0,0,.3)}
.header h1{font-size:.95rem;font-weight:600;white-space:nowrap}
.header-stats{display:flex;gap:14px;margin-left:auto;font-size:.78rem;opacity:.9}
.header-stats .stat{display:flex;align-items:center;gap:3px}
.header-stats .stat-val{font-weight:700;font-size:.9rem}
.boat-info{font-size:.7rem;opacity:.7;white-space:nowrap}
.panel{position:fixed;top:50px;right:0;bottom:0;width:390px;z-index:999;background:rgba(255,255,255,.98);box-shadow:-2px 0 16px rgba(0,0,0,.15);display:flex;flex-direction:column;transition:transform .3s;overflow:hidden}
.panel.collapsed{transform:translateX(350px)}
.panel-toggle{position:absolute;left:-36px;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.95);border:none;width:36px;height:60px;border-radius:8px 0 0 8px;cursor:pointer;font-size:1.1rem;box-shadow:-2px 0 8px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center}
.panel-section{padding:10px 14px;border-bottom:1px solid #e8ecf0}
.panel-section h3{font-size:.8rem;color:#0a3d62;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;user-select:none}
.collapse-arrow{font-size:.7rem;transition:transform .2s}
.panel-section-body{overflow:hidden;transition:max-height .25s ease}
.panel-section-body.collapsed{display:none}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 8px;font-size:.75rem}
.settings-grid label{color:#475569;font-weight:600;display:flex;align-items:center}
.settings-grid input,.settings-grid select{padding:4px 6px;border:1px solid #d1d5db;border-radius:5px;font-size:.75rem;background:#fff;color:#1a2a3a;width:100%}
.route-list{flex:1;overflow-y:auto;padding:6px;min-height:150px}
.route-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:4px;transition:all .2s;position:relative}
.route-item.fixed{background:#f8fafc;border-style:dashed}
.route-item:hover{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.route-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff;flex-shrink:0}
.route-num.marina{background:#e67e22}.route-num.anchor{background:#2ecc71}.route-num.city{background:#3498db}.route-num.party{background:#e91e63}
.route-info{flex:1;min-width:0}.route-info .name{font-size:.82rem;font-weight:600;color:#1a2a3a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-info .detail{font-size:.68rem;color:#64748b}
.route-dist{font-size:.7rem;color:#e67e22;font-weight:600;text-align:right;min-width:55px;line-height:1.2}.route-dist small{display:block;color:#94a3b8;font-weight:400;font-size:.65rem}
.route-remove{background:none;border:none;color:#cbd5e1;cursor:pointer;font-size:1rem;padding:2px}.route-remove:hover{color:#e74c3c}
.day-assign{font-size:.65rem;color:#0a3d62;background:#e8f4f8;padding:1px 5px;border-radius:4px;white-space:nowrap}
.filter-chips{display:flex;flex-wrap:wrap;gap:3px}.chip{padding:3px 8px;border-radius:12px;font-size:.68rem;font-weight:600;cursor:pointer;border:1.5px solid;transition:all .15s;user-select:none}.chip.active{color:#fff}
.filter-group{margin-bottom:5px}.filter-group-label{font-size:.6rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:2px}.filter-group.future .chip{opacity:.45;cursor:not-allowed}
.country-tab{display:inline-flex;align-items:center;gap:6px;background:#0a3d62;color:#fff;border:none;border-radius:6px 6px 0 0;padding:4px 12px;font-size:.72rem;font-weight:700;margin-bottom:0;cursor:pointer}.country-tab-inactive{display:inline-flex;align-items:center;gap:6px;background:#1e5f8a;color:#cce3f5;border:none;border-radius:6px 6px 0 0;padding:4px 12px;font-size:.72rem;font-weight:600;margin-bottom:0;cursor:pointer;opacity:.75}.country-tab-inactive:hover{opacity:1}.country-tab-future{opacity:.45;background:#94a3b8;cursor:not-allowed;border-radius:6px;padding:3px 9px;font-size:.7rem;font-weight:600;color:#fff;border:none}
.country-tabs{display:flex;gap:4px;margin-bottom:2px}.country-tabs-wrap{padding:6px 14px 0;border-bottom:2px solid #0a3d62}
.symbol-legend{display:flex;flex-wrap:wrap;gap:3px 8px;font-size:.62rem;color:#64748b;padding:5px 0;border-top:1px solid #e8ecf0;margin-top:4px}
.panel-actions{padding:8px 14px;border-top:1px solid #e8ecf0;display:flex;flex-direction:column;gap:5px}
.btn{padding:9px 14px;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}
.btn-primary{background:#0a3d62;color:#fff}.btn-primary:hover{background:#0c4b78}.btn-export{background:#2ecc71;color:#fff}.btn-clear{background:#fee2e2;color:#dc2626}.btn-row{display:flex;gap:5px}.btn-row .btn{flex:1}
.warning-bar{position:fixed;bottom:16px;left:50%;transform:translateX(calc(-50% - 195px));z-index:1001;background:#fff3e0;border:1px solid #ffb74d;border-radius:10px;padding:8px 16px;font-size:.78rem;color:#e65100;font-weight:500;display:none;box-shadow:0 2px 12px rgba(0,0,0,.15);max-width:620px;text-align:center}
.instruction{position:fixed;bottom:16px;left:50%;transform:translateX(calc(-50% - 195px));z-index:1001;background:rgba(10,61,98,.9);color:#fff;padding:8px 20px;border-radius:20px;font-size:.8rem;pointer-events:none}
.route-error{position:fixed;bottom:60px;left:50%;transform:translateX(calc(-50% - 195px));z-index:1002;background:#fee2e2;border:2px solid #ef4444;border-radius:10px;padding:10px 18px;font-size:.8rem;color:#991b1b;font-weight:500;display:none;box-shadow:0 4px 16px rgba(0,0,0,.2);max-width:620px;text-align:center}
.route-error .close-err{background:none;border:none;color:#991b1b;font-size:1.1rem;cursor:pointer;margin-left:8px;vertical-align:middle}
.debug-legend{position:fixed;bottom:60px;right:410px;z-index:1001;background:rgba(255,255,255,.95);border-radius:8px;padding:8px 12px;font-size:.7rem;box-shadow:0 2px 8px rgba(0,0,0,.15);display:none}
.zs-badge{background:#607d8b;color:#fff;font-size:.6rem;padding:1px 5px;border-radius:8px;font-weight:700;margin-left:4px;vertical-align:middle}
.route-item.zs{background:#f1f5f8;border-style:dotted;opacity:.9}
.route-num.waypoint{background:#455a64}
.custom-wp-popup{min-width:210px}.custom-wp-popup h3{color:#37474f;margin-bottom:4px;font-size:.9rem;font-weight:600}
.custom-wp-popup .coord{font-size:.7rem;color:#78909c;margin-bottom:10px}
.btn-wp{display:block;width:100%;padding:7px 10px;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:.78rem;margin-bottom:4px;text-align:left}
.btn-wp-main{background:#0a3d62;color:#fff}.btn-wp-zs{background:#607d8b;color:#fff}.btn-wp-cancel{background:#f0f4f8;color:#475569}
.debug-legend div{display:flex;align-items:center;gap:5px;margin:2px 0}.debug-legend .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.bay-popup{min-width:280px;max-width:380px}.bay-popup h3{color:#0a3d62;margin-bottom:4px;font-size:1rem}.bay-popup .tags{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:8px}.bay-popup .tag{display:inline-block;padding:1px 7px;border-radius:4px;font-size:.68rem;font-weight:600}.bay-popup .info-grid{display:grid;grid-template-columns:75px 1fr;gap:2px 8px;font-size:.82rem;margin-bottom:8px}.bay-popup .info-label{font-weight:600;color:#475569}.bay-popup .info-val{color:#334155}.bay-popup .desc{font-size:.84rem;color:#475569;line-height:1.55;margin-bottom:10px;border-top:1px solid #e8ecf0;padding-top:8px;white-space:pre-line}.bay-popup .add-btn{display:block;width:100%;padding:8px;border:none;border-radius:6px;background:#0a3d62;color:#fff;font-weight:600;cursor:pointer;font-size:.82rem}.bay-popup .add-btn.in-route{background:#e74c3c}
.party-badge{background:#e91e63;color:#fff;font-size:.6rem;padding:1px 5px;border-radius:8px;font-weight:700;margin-left:4px;vertical-align:middle}.top-star{color:#f39c12;margin-left:2px}
#jsErrorBox{display:none;position:fixed;top:56px;left:12px;right:400px;z-index:3000;background:#ffebee;color:#991b1b;border:1px solid #ef9a9a;border-radius:10px;padding:8px 12px;font:12px/1.35 system-ui;box-shadow:0 2px 10px rgba(0,0,0,.2)}
@media(max-width:820px){.panel{width:320px}.panel.collapsed{transform:translateX(280px)}.header h1{font-size:.82rem}.boat-info{display:none}.debug-legend{display:none!important}}

/* ── Auth Modal ─────────────────────────────────────────────────────────── */
.auth-modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(10,22,40,.85);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.auth-modal{background:#fff;border-radius:16px;padding:36px 32px 28px;width:100%;max-width:380px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.auth-logo{text-align:center;font-size:1.6rem;margin-bottom:8px;letter-spacing:.5px;color:#0a3d62;font-weight:700}
.auth-title{text-align:center;font-size:1.15rem;color:#1a2a3a;margin-bottom:20px;font-weight:600}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:.78rem;font-weight:600;color:#475569;margin-bottom:4px}
.auth-field input{width:100%;padding:9px 12px;border:1.5px solid #d1d5db;border-radius:8px;font-size:.9rem;background:#fafafa;color:#1a2a3a;outline:none;transition:border-color .2s}
.auth-field input:focus{border-color:#0a3d62;background:#fff}
.auth-error{background:#ffebee;color:#c62828;border-radius:6px;padding:8px 12px;font-size:.8rem;margin-bottom:10px}
.auth-btn{width:100%;padding:10px;background:#0a3d62;color:#fff;border:none;border-radius:8px;font-size:.92rem;font-weight:600;cursor:pointer;transition:background .2s;margin-top:4px}
.auth-btn:hover{background:#1565c0}
.auth-btn:disabled{background:#94a3b8;cursor:not-allowed}
.auth-link{color:#0a3d62;font-size:.8rem;text-decoration:none;opacity:.8}
.auth-link:hover{opacity:1;text-decoration:underline}
.auth-confirm{background:#e8f5e9;color:#2e7d32;border-radius:8px;padding:14px;font-size:.88rem;line-height:1.5;margin-top:12px;text-align:center}

/* ── User bar in header ──────────────────────────────────────────────────── */
.user-bar{display:flex;align-items:center;gap:10px;margin-left:8px;font-size:.75rem}
#userEmail{opacity:.8;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn-logout{padding:3px 10px;border-radius:5px;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;font-size:.72rem;cursor:pointer;white-space:nowrap}
.btn-logout:hover{background:rgba(255,255,255,.15)}

/* ── Cookie Banner ───────────────────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9998;background:rgba(15,23,42,.97);border-top:1px solid rgba(255,255,255,.1);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;backdrop-filter:blur(8px)}
.cookie-text{font-size:.82rem;color:#cbd5e1;line-height:1.5;flex:1}
.cookie-text a{color:#38bdf8}
.cookie-buttons{display:flex;gap:8px;flex-shrink:0}
.cookie-btn{padding:8px 16px;border:none;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer}
.cookie-accept{background:#0a3d62;color:#fff}
.cookie-accept:hover{background:#1565c0}
.cookie-essential{background:transparent;color:#94a3b8;border:1px solid #475569}
.cookie-essential:hover{background:rgba(255,255,255,.05)}

/* ── Legal Links (bottom-left) ───────────────────────────────────────────── */
.legal-links{position:fixed;bottom:8px;left:8px;z-index:998;display:flex;gap:12px}
.legal-links a{font-size:.68rem;color:rgba(255,255,255,.4);text-decoration:none;background:rgba(0,0,0,.3);padding:2px 8px;border-radius:4px}
.legal-links a:hover{color:rgba(255,255,255,.7)}

/* ── Privacy checkbox ────────────────────────────────────────────────────── */
.privacy-check{display:flex;align-items:flex-start;gap:8px;font-size:.78rem;color:#475569;cursor:pointer}
.privacy-check input{margin-top:2px}
.privacy-check a{color:#0a3d62}
