*,:before,:after{box-sizing:border-box}:root{--blue:#0ea5e9;--green:#16a34a;--amber:#d97706;--gray:#6b7280;--red:#dc2626;--bg:#f8fafc;--surface:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--sans:system-ui, "Segoe UI", Roboto, sans-serif}body{font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.5}#root{flex-direction:column;height:100svh;display:flex;overflow:hidden}.app-header{background:var(--blue);color:#fff;z-index:400;justify-content:space-between;align-items:center;height:52px;padding:0 16px;display:flex;position:sticky;top:0}.app-header h1{letter-spacing:-.3px;margin:0;font-size:20px;font-weight:700}.header-back{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:22px;line-height:1}.header-back:hover{background:#ffffff26}.search-screen{flex-direction:column;flex:1;align-items:center;padding:32px 16px 48px;display:flex;overflow-y:auto}.search-screen h2{margin:0 0 6px;font-size:26px;font-weight:700}.search-screen p{color:var(--muted);margin:0 0 32px}.search-form{flex-direction:column;gap:14px;width:100%;max-width:480px;display:flex}.field{text-align:left;flex-direction:column;gap:5px;display:flex}.field label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.field select,.field input[type=date]{border:1px solid var(--border);width:100%;font-size:15px;font-family:var(--sans);background:var(--surface);color:var(--text);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border-radius:8px;padding:10px 12px}.field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.field select:focus,.field input:focus{border-color:var(--blue);outline:none;box-shadow:0 0 0 3px #0ea5e926}.btn-primary{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:4px;padding:12px;font-size:16px;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:#0284c7}.btn-primary:disabled{opacity:.5;cursor:default}.itinerary-screen{-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.day-hero{color:#fff;background-position:50%;background-size:cover;padding:24px 20px 28px}.hero-sea{background:linear-gradient(#050f1eb3 0%,#0a284b99 100%),url(https://images.unsplash.com/photo-1755799868607-591e9a95e6b4?w=1200&q=80&auto=format&fit=crop) 50%/cover no-repeat}.hero-port{background:linear-gradient(#0a284ba6 0%,#0350828c 100%),url(https://images.unsplash.com/photo-1764608054270-9dfc5a47abe7?w=1200&q=80&auto=format&fit=crop) 50%/cover no-repeat}.hero-content{z-index:1;position:relative}.hero-meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:5px;display:flex}.hero-date{opacity:.85;font-size:13px}.hero-type-badge{text-transform:uppercase;letter-spacing:.6px;background:#ffffff38;border-radius:10px;padding:2px 9px;font-size:11px}.hero-port-name{text-shadow:0 1px 4px #0000004d;margin-bottom:14px;font-size:26px;font-weight:800;line-height:1.15}.hero-weather-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.hero-icon{font-size:48px;line-height:1}.hero-temp-block{align-items:baseline;display:flex}.hero-high{font-size:38px;font-weight:800}.hero-low{opacity:.65;font-size:22px}.hero-chips{flex-wrap:wrap;gap:6px;margin-top:2px;display:flex}.hero-chip{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:16px;padding:4px 10px;font-size:13px;font-weight:500}.hero-sea-content{margin-top:8px}.hero-sea-icon{font-size:48px}.hero-no-weather{opacity:.65;margin-top:10px;font-size:14px}.day-strip-wrap{background:var(--surface);border-bottom:1px solid var(--border)}.strip-row{border:none;border-bottom:1px solid var(--border);width:100%;font-family:var(--sans);color:var(--text);text-align:left;cursor:pointer;background:0 0;border-left:3px solid #0000;align-items:center;gap:12px;padding:12px 16px;transition:background .12s;display:flex}.strip-row:last-child{border-bottom:none}.strip-row.selected{border-left-color:var(--blue);background:#f0f9ff}.strip-row.prepost{background:#fafafa}.strip-row.prepost.selected{background:#f0f9ff}.strip-row:hover:not(.selected){background:#f8fafc}.strip-date-col{flex-direction:column;flex-shrink:0;align-items:center;width:46px;display:flex}.strip-dow{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:10px}.strip-date{font-size:14px;font-weight:700;line-height:1.2}.strip-info-col{flex:1;min-width:0}.strip-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;display:block;overflow:hidden}.strip-sub{color:var(--muted);margin-top:1px;font-size:11px;display:block}.strip-weather-col{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:1px;display:flex}.strip-icon-wrap{font-size:22px;line-height:1}.strip-temp{font-size:14px;font-weight:700}.strip-rain{color:var(--blue);font-size:11px}.prepost-controls{background:var(--surface);border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:48px;padding:10px 16px;display:flex}.prepost-ctrl{align-items:center;gap:8px;display:flex}.prepost-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:28px;height:28px;color:var(--text);border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:flex}.prepost-btn:hover:not(:disabled){border-color:var(--blue);color:var(--blue);background:#f0f9ff}.prepost-btn:disabled{opacity:.35;cursor:default}.prepost-label{color:var(--muted);text-align:center;min-width:88px;font-size:12px}.row-expanded{border-left:3px solid var(--blue);border-bottom:1px solid var(--border);background:var(--bg);padding-bottom:8px}.weather-grid{background:var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:1px;display:grid}.wg-cell{background:var(--surface);text-align:center;padding:12px}.wg-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;font-size:11px}.wg-val{font-size:15px;font-weight:600}.section-heading{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;padding:12px 16px 4px;font-size:11px;font-weight:700}.marine-grid{background:var(--border);border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:1px;display:grid}.mg-cell{text-align:center;background:#f0f9ff;padding:10px}.mg-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;font-size:11px}.mg-val{color:#0c4a6e;font-size:15px;font-weight:600}.sun-row{border-bottom:1px solid var(--border);justify-content:center;gap:32px;padding:10px 16px;font-size:13px;display:flex}.sun-item{align-items:center;gap:6px;display:flex}.sun-label{color:var(--muted)}.hourly-scroll-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.hourly-scroll{border-bottom:1px solid var(--border);gap:0;min-width:max-content;display:flex}.hour-col{border-right:1px solid var(--border);flex-direction:column;align-items:center;gap:3px;min-width:56px;padding:8px 10px;display:flex}.hour-col:last-child{border-right:none}.hour-time{color:var(--muted);font-size:11px}.hour-icon{font-size:18px}.hour-temp{font-size:13px;font-weight:600}.hour-rain{color:var(--blue);font-size:11px}.hour-wind{color:var(--muted);font-size:10px}.port-info{border-bottom:1px solid var(--border);padding:12px 16px}.port-times{gap:24px;margin-bottom:6px;font-size:13px;display:flex}.port-times span{color:var(--muted);margin-right:4px}.port-desc{color:var(--muted);font-size:13px}.transport-chips{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:6px;padding:10px 16px;display:flex}.transport-chip{background:#f1f5f9;border-radius:20px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;font-weight:500;display:flex}.nearby-section{padding:0 0 8px}.nearby-list{flex-direction:column;display:flex}.nearby-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 16px;display:flex}.nearby-curated{font-size:11px}.nearby-info{flex:1;min-width:0}.nearby-name{font-size:14px;font-weight:600}.nearby-desc{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.nearby-travel{flex-wrap:wrap;gap:6px;margin-top:5px;display:flex}.travel-chip{color:var(--muted);font-size:11px}.add-dest-btn{border:1px dashed var(--border);color:var(--blue);cursor:pointer;background:0 0;border-radius:8px;width:calc(100% - 32px);margin:10px 16px 4px;padding:8px 14px;font-size:13px;font-weight:500}.add-dest-btn:hover{border-color:var(--blue);background:#f0f9ff}.modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:16px 16px 0 0;width:100%;max-width:540px;max-height:90svh;padding:20px 16px 32px;overflow-y:auto}.modal h3{margin:0 0 16px;font-size:17px}.modal-form input,.modal-form textarea{border:1px solid var(--border);width:100%;font-size:14px;font-family:var(--sans);border-radius:8px;padding:9px 12px}.modal-form textarea{resize:vertical;min-height:60px}.modal-form input:focus,.modal-form textarea:focus{border-color:var(--blue);outline:none}.modal-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.modal-actions{gap:10px;margin-top:4px;display:flex}.btn-ghost{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:10px;font-size:14px}.btn-ghost:hover{background:#f8fafc}.modal-actions .btn-primary{flex:1;padding:10px;font-size:14px}.loading-state,.error-state{color:var(--muted);text-align:center;flex:1;justify-content:center;align-items:center;padding:48px 16px;font-size:15px;display:flex}.error-state{color:var(--red)}.spinner{border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;width:32px;height:32px;margin:0 auto 12px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.header-auth-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff2e;border:1px solid #ffffff59;border-radius:20px;padding:5px 12px;font-size:13px;font-weight:600}.header-auth-btn:hover{background:#ffffff47}.save-bar{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 16px;display:flex}.save-btn{border:1.5px solid var(--blue);color:var(--blue);cursor:pointer;background:0 0;border-radius:20px;padding:6px 16px;font-size:14px;font-weight:600;transition:background .15s,color .15s}.save-btn.saved{background:var(--blue);color:#fff}.save-btn:disabled{opacity:.5;cursor:default}.save-msg{color:var(--muted);font-size:13px}.modal-backdrop{z-index:200;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);border-radius:16px;width:100%;max-width:400px;padding:28px 24px;position:relative;box-shadow:0 20px 60px #0000004d}.modal-close{cursor:pointer;color:var(--muted);background:0 0;border:none;padding:4px;font-size:18px;line-height:1;position:absolute;top:14px;right:14px}.modal-title{margin:0 0 20px;font-size:22px;font-weight:700}.modal-form{flex-direction:column;gap:14px;display:flex}.modal-form label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;flex-direction:column;gap:5px;font-size:13px;font-weight:600;display:flex}.modal-form input{border:1.5px solid var(--border);font-size:15px;font-family:var(--sans);color:var(--text);background:var(--surface);border-radius:8px;outline:none;padding:10px 12px}.modal-form input:focus{border-color:var(--blue)}.modal-error{color:var(--red);margin:0;font-size:13px;font-weight:500}.modal-submit{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:4px;padding:11px;font-size:15px;font-weight:600}.modal-submit:disabled{opacity:.6;cursor:default}.modal-switch{text-align:center;color:var(--muted);margin:16px 0 0;font-size:14px}.modal-switch button{color:var(--blue);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;font-weight:600}.modal-sent{text-align:center;padding:8px 0}.modal-sent-icon{margin-bottom:12px;font-size:40px}.modal-sent h2{margin:0 0 8px}.modal-sent p{color:var(--muted);margin:0;font-size:14px}.header-left,.header-right{align-items:center;width:80px;display:flex}.header-right{justify-content:flex-end}.header-user-wrap{position:relative}.header-avatar-btn{cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.header-avatar{color:#fff;font-size:15px;font-weight:700;line-height:1}.header-dropdown{background:var(--surface);border:1px solid var(--border);z-index:300;border-radius:10px;min-width:140px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.header-dropdown button{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:11px 16px;font-size:14px;font-weight:500;display:block}.header-dropdown button:hover{background:var(--bg)}.dropdown-backdrop{z-index:300;position:fixed;inset:0}.home-screen{flex-direction:column;flex:1;display:flex;overflow-y:auto}.saved-section{border-bottom:1px solid var(--border);background:var(--surface);padding:20px 16px 0}.saved-heading{color:var(--text);margin:0 0 12px;font-size:16px;font-weight:700}.saved-empty{color:var(--muted);padding-bottom:16px;font-size:14px}.saved-list{flex-direction:column;gap:8px;padding-bottom:16px;display:flex}.saved-card{background:var(--bg);border:1px solid var(--border);text-align:left;cursor:pointer;border-radius:10px;align-items:center;gap:8px;width:100%;padding:12px 14px;transition:border-color .15s,box-shadow .15s;display:flex}.saved-card:hover{border-color:var(--blue);box-shadow:0 2px 8px #0ea5e91f}.saved-card-body{text-align:left;flex:1}.saved-card-line{color:var(--muted);margin-bottom:2px;font-size:12px}.saved-card-name{color:var(--text);margin-bottom:3px;font-size:15px;font-weight:600}.saved-card-dates{color:var(--muted);font-size:13px}.saved-card-remove{color:var(--muted);border-radius:50%;flex-shrink:0;padding:4px 6px;font-size:14px;line-height:1}.saved-card-remove:hover{color:#e53e3e;background:#e53e3e1a}.account-screen{flex:1;width:100%;max-width:480px;margin:0 auto;padding:24px 16px 48px;overflow-y:auto}.account-avatar-row{align-items:center;gap:14px;margin-bottom:16px;display:flex}.account-avatar{background:var(--blue);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:22px;font-weight:700;display:flex}.account-name{font-size:18px;font-weight:700}.account-email{color:var(--muted);font-size:13px}.account-tier-badge{background:var(--bg);border:1px solid var(--border);border-radius:20px;margin-bottom:8px;padding:4px 12px;font-size:13px;font-weight:600;display:inline-block}.account-upgrade-hint{color:var(--muted);margin:0 0 20px;font-size:13px}.account-section{border-top:1px solid var(--border);margin-top:24px;padding-top:20px}.account-section h3{text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin:0 0 14px;font-size:14px;font-weight:700}.account-form{flex-direction:column;gap:12px;display:flex}.account-form label{color:var(--muted);flex-direction:column;gap:5px;font-size:13px;font-weight:600;display:flex}.account-form input{border:1.5px solid var(--border);font-size:15px;font-family:var(--sans);border-radius:8px;outline:none;padding:10px 12px}.account-form input:focus{border-color:var(--blue)}.account-form-row{align-items:center;gap:10px;display:flex}.account-info-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:9px 0;font-size:14px;display:flex}.account-info-row span:first-child{color:var(--muted)}.account-info-row span:last-child{font-weight:500}.btn-signout{border:1.5px solid var(--red);color:var(--red);cursor:pointer;background:0 0;border-radius:8px;padding:9px 20px;font-size:14px;font-weight:600}.btn-signout:hover{background:#fef2f2}.print-header{display:none}.export-btns{gap:8px;display:flex}.export-btn{border:1.5px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:7px 13px;font-size:13px;font-weight:600;transition:border-color .15s,color .15s}.export-btn:hover{border-color:var(--blue);color:var(--blue)}.email-modal-backdrop{z-index:600;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.email-modal{background:#fff;border-radius:14px;width:100%;max-width:360px;padding:24px;box-shadow:0 8px 32px #0000002e}.email-modal-title{margin-bottom:16px;font-size:17px;font-weight:700}.email-form{gap:8px;display:flex}.email-input{border:1.5px solid var(--border);font-size:14px;font-family:var(--sans);border-radius:8px;outline:none;flex:1;padding:9px 12px}.email-input:focus{border-color:var(--blue)}.email-send-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:9px 16px;font-size:14px;font-weight:600}.email-send-btn:disabled{opacity:.6;cursor:default}.email-result{border-radius:7px;margin-top:10px;padding:8px 10px;font-size:13px}.email-result.ok{color:#166534;background:#f0fdf4}.email-result.err{color:#991b1b;background:#fef2f2}.email-cancel{width:100%;color:var(--muted);cursor:pointer;text-align:center;background:0 0;border:none;margin-top:12px;font-size:13px;display:block}@media (width>=640px){.weather-grid{grid-template-columns:repeat(4,1fr)}.modal-overlay{align-items:center;padding:16px}.modal{border-radius:16px;max-height:85svh}.hero-port-name{font-size:30px}.prepost-label{min-width:110px}}@media print{.app-header,.day-hero,.save-bar,.export-btns,.email-modal-backdrop,.prepost-controls,.row-expanded{display:none!important}body{background:#fff;font-family:sans-serif}.print-header{border-bottom:2px solid #0f3460;margin-bottom:20px;padding-bottom:12px;display:block!important}.print-title{color:#0f3460;margin-bottom:4px;font-size:22px;font-weight:700}.print-subtitle{color:#555;font-size:14px}.day-strip-wrap{display:block}.strip-row{text-align:left!important;box-shadow:none!important;cursor:default!important;background:0 0!important;border:none!important;border-bottom:1px solid #e0e0e0!important;grid-template-columns:80px 1fr 120px!important;padding:8px 4px!important;font-size:13px!important;display:grid!important}.strip-row.sea-day{background:#f5f9ff!important}.strip-date-col{font-weight:600}.strip-dow{color:#888;font-size:11px;display:block}.strip-date{font-size:13px;font-weight:600;display:block}.strip-info-col .strip-name{color:#1a1a2e;font-weight:600;display:block}.strip-info-col .strip-sub{color:#888;font-size:11px;display:block}.strip-weather-col{font-size:12px;display:block!important}@page{margin:.75in;size:letter portrait}}
