/* ═══ PAGE HERO (shared) ═══ */
.page-hero { padding:140px 0 80px; position:relative; overflow:hidden; color:#fff; }
.ph-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.ph-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(9,32,47,0.82) 0%,rgba(13,77,107,0.7) 50%,rgba(26,106,142,0.5) 100%); }
.ph-content { position:relative; z-index:2; max-width:760px; }
.ph-eyebrow { font-family:var(--mono); font-size:11px; letter-spacing:5px; text-transform:uppercase; color:rgba(255,255,255,0.7); margin-bottom:20px; display:block; }
.ph-title { font-family:var(--serif); font-size:clamp(36px,5vw,64px); font-weight:900; line-height:1.05; color:#fff; margin-bottom:20px; }
.ph-title em { font-style:italic; color:rgba(255,255,255,0.8); }
.ph-sub { font-size:18px; line-height:1.75; color:rgba(255,255,255,0.78); margin-bottom:36px; max-width:620px; }
.ph-stats { display:flex; align-items:center; gap:0; flex-wrap:wrap; margin-bottom:36px; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.15); border-radius:var(--r); padding:20px 28px; backdrop-filter:blur(8px); }
.ph-stat { text-align:center; flex:1; min-width:100px; }
.ph-stat-num { font-family:var(--serif); font-size:28px; font-weight:900; color:#fff; margin-bottom:4px; }
.ph-stat-label { font-size:11px; color:rgba(255,255,255,0.6); font-weight:600; letter-spacing:1px; }
.ph-stat-div { width:1px; height:40px; background:rgba(255,255,255,0.2); }
.ph-ctas { display:flex; gap:16px; flex-wrap:wrap; }
.owner-hero .ph-bg, .guest-hero .ph-bg, .marina-hero .ph-bg { background:linear-gradient(135deg,#09202f 0%,#0d4d6b 40%,#1a6a8e 70%,#2a8ab0 100%); }

/* Nav active state */
.nav-link.active { color:var(--ocean); font-weight:600; }

/* ═══ OWNERS PAGE ═══ */
.truth-section { padding:100px 0; background:var(--white); }
.truth-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.cost-breakdown { background:var(--salt); border:1px solid var(--bdr); border-radius:var(--r-lg); padding:32px; }
.cb-title { font-family:var(--mono); font-size:11px; letter-spacing:4px; text-transform:uppercase; color:var(--txt-lt); margin-bottom:20px; }
.cb-item { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid var(--mist); font-size:14px; color:var(--txt-mid); }
.cb-item:last-child { border-bottom:none; }
.cb-cost { font-family:var(--mono); font-weight:700; font-size:14px; }
.cb-cost.red { color:#dc3545; }
.cb-cost.green { color:var(--green); }
.cb-total { font-weight:700; color:var(--ink); font-size:15px; padding-top:14px; border-top:2px solid var(--bdr); }
.cb-divider { height:2px; background:linear-gradient(90deg,var(--ocean),var(--sky-lt)); margin:16px 0; border-radius:2px; }
.cb-earn { font-weight:600; }
.cb-net { font-weight:700; font-size:16px; color:var(--ink); }
.cb-note { font-size:11px; color:var(--txt-lt); font-style:italic; text-align:center; margin-top:8px; }

/* Calculator */
.calculator { padding:100px 0; background:var(--salt); }
.calc-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:48px; align-items:start; margin-top:24px; }
.calc-field { margin-bottom:28px; }
.calc-field label { display:block; font-size:13px; font-weight:700; color:var(--txt); margin-bottom:12px; letter-spacing:0.3px; }
.slider-wrap { display:flex; align-items:center; gap:16px; }
.slider { flex:1; -webkit-appearance:none; height:4px; border-radius:2px; background:linear-gradient(90deg,var(--ocean) 0%,var(--sky-lt) 100%); outline:none; }
.slider::-webkit-slider-thumb { -webkit-appearance:none; width:20px; height:20px; border-radius:50%; background:var(--ocean); cursor:pointer; box-shadow:0 2px 8px rgba(26,106,142,0.3); border:2px solid #fff; }
.slider-val { font-family:var(--mono); font-size:14px; color:var(--ocean); font-weight:700; white-space:nowrap; min-width:70px; text-align:right; }
.type-btns { display:flex; gap:8px; flex-wrap:wrap; }
.type-btn { padding:8px 16px; border-radius:50px; font-size:13px; font-weight:600; color:var(--txt-mid); border:1.5px solid var(--bdr); cursor:pointer; transition:all 0.2s; }
.type-btn.active, .type-btn:hover { background:var(--ocean); color:#fff; border-color:var(--ocean); }
.calc-result { position:sticky; top:90px; }
.cr-card { background:#fff; border:1px solid var(--bdr); border-radius:var(--r-lg); padding:32px; box-shadow:var(--sh-md); }
.cr-label { font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--txt-lt); margin-bottom:8px; }
.cr-monthly { font-family:var(--serif); font-size:52px; font-weight:900; color:var(--ocean); line-height:1; margin-bottom:20px; }
.cr-divider { height:1px; background:var(--mist); margin:20px 0; }
.cr-annual { font-family:var(--serif); font-size:36px; font-weight:900; color:var(--ink); margin-top:8px; }
.cr-breakdown { margin-top:20px; display:flex; flex-direction:column; gap:10px; }
.crb-item { display:flex; justify-content:space-between; font-size:13px; color:var(--txt-mid); padding:6px 0; border-bottom:1px solid var(--mist); }
.crb-item.green span { color:var(--green); font-weight:700; }

/* Owner steps */
.owner-hiw { padding:100px 0; background:var(--white); }
.owner-steps { display:flex; align-items:flex-start; gap:0; }
.os-step { flex:1; text-align:center; padding:0 20px; }
.os-num { font-family:var(--mono); font-size:11px; letter-spacing:3px; color:var(--txt-lt); margin-bottom:12px; }
.os-icon { font-size:40px; margin-bottom:16px; display:block; }
.os-step h3 { font-family:var(--serif); font-size:20px; font-weight:700; color:var(--ink); margin-bottom:10px; }
.os-step p { font-size:14px; line-height:1.8; color:var(--txt-mid); }
.os-time { display:inline-block; margin-top:12px; background:var(--mist); color:var(--ocean); font-size:11px; font-weight:700; padding:5px 12px; border-radius:50px; font-family:var(--mono); }
.os-conn { flex-shrink:0; width:40px; height:2px; background:linear-gradient(90deg,var(--ocean),var(--sky-lt)); margin:60px 0 0; }

/* Programs */
.programs { padding:100px 0; background:var(--mist); }
.prog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.prog-card { background:#fff; border:1px solid var(--bdr); border-radius:var(--r-lg); padding:36px 28px; position:relative; transition:all 0.3s; }
.prog-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); }
.prog-featured { border-color:var(--sky); box-shadow:var(--sh-md); }
.prog-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--ocean); color:#fff; font-size:11px; font-weight:700; padding:4px 16px; border-radius:50px; white-space:nowrap; }
.prog-icon { font-size:36px; margin-bottom:12px; display:block; }
.prog-name { font-family:var(--serif); font-size:22px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.prog-price { font-family:var(--mono); font-size:18px; color:var(--ocean); font-weight:700; margin-bottom:16px; }
.prog-price span { font-size:12px; color:var(--txt-lt); }
.prog-card p { font-size:14px; line-height:1.8; color:var(--txt-mid); margin-bottom:20px; }
.prog-list { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.prog-list li { font-size:13px; color:var(--txt-mid); }
.prog-btn { display:block; text-align:center; padding:12px 20px; border-radius:50px; font-size:14px; font-weight:700; color:var(--ocean); border:2px solid var(--ocean); transition:all 0.2s; }
.prog-btn:hover { background:var(--ocean); color:#fff; }
.prog-btn-primary { background:var(--ocean); color:#fff; }
.prog-btn-primary:hover { background:var(--deep); }

/* Maintenance Passport */
.passport { padding:100px 0; background:var(--white); }
.passport-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:80px; align-items:center; }
.mp-card { background:var(--ink); border-radius:var(--r-lg); padding:28px; color:#fff; box-shadow:var(--sh-xl); }
.mp-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; font-size:13px; font-weight:700; color:rgba(255,255,255,0.8); }
.mp-badge { background:#22c55e; color:#fff; font-size:10px; font-weight:700; padding:3px 10px; border-radius:50px; }
.mp-vessel { font-family:var(--serif); font-size:18px; color:#fff; margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid rgba(255,255,255,0.1); }
.mp-log { display:flex; flex-direction:column; gap:12px; margin-bottom:20px; }
.mp-entry { display:flex; align-items:flex-start; gap:12px; }
.mp-dot { width:10px; height:10px; border-radius:50%; background:#22c55e; flex-shrink:0; margin-top:4px; }
.upcoming-dot { background:var(--amber); }
.mp-entry-title { font-size:13px; font-weight:600; color:#fff; }
.mp-entry-date { font-size:11px; color:rgba(255,255,255,0.5); font-family:var(--mono); }
.mp-score { display:flex; align-items:center; gap:12px; font-size:12px; color:rgba(255,255,255,0.6); margin-top:16px; padding-top:16px; border-top:1px solid rgba(255,255,255,0.1); }
.mp-score-bar { flex:1; height:6px; background:rgba(255,255,255,0.15); border-radius:3px; overflow:hidden; }
.mp-score-fill { height:100%; width:0%; background:linear-gradient(90deg,#22c55e,#4ade80); border-radius:3px; transition:width 1.5s ease; }
.mp-pct { font-family:var(--mono); font-size:14px; color:#22c55e; font-weight:700; }
.passport-benefits { display:flex; flex-direction:column; gap:20px; margin-top:32px; }
.pb-item { display:flex; align-items:flex-start; gap:16px; }
.pb-icon { font-size:28px; flex-shrink:0; }
.pb-item strong { display:block; font-size:15px; color:var(--ink); margin-bottom:4px; }
.pb-item p { font-size:13px; color:var(--txt-mid); line-height:1.7; }

/* Owner testimonials */
.owner-testi { padding:80px 0; background:var(--salt); }

/* Form */
.list-form-section { padding:100px 0; background:var(--mist); }
.form-card { background:#fff; border:1px solid var(--bdr); border-radius:var(--r-xl); padding:48px; box-shadow:var(--sh-md); max-width:800px; margin:0 auto; }
.owner-form { display:flex; flex-direction:column; gap:20px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-field { display:flex; flex-direction:column; gap:6px; }
.form-field.full { grid-column:1/-1; }
.form-field label { font-size:13px; font-weight:700; color:var(--txt); }
.form-field input, .form-field select, .form-field textarea { padding:12px 16px; border:1.5px solid var(--bdr); border-radius:var(--r); font-size:14px; color:var(--txt); transition:border-color 0.2s; font-family:var(--sans); background:#fff; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color:var(--ocean); outline:none; box-shadow:0 0 0 3px rgba(26,106,142,0.1); }
.form-field textarea { resize:vertical; min-height:100px; }
.form-submit { align-self:flex-start; padding:16px 36px; font-size:16px; margin-top:8px; }
.form-note { font-size:12px; color:var(--txt-lt); }
.form-note a { color:var(--ocean); }

/* ═══ GUESTS PAGE ═══ */
.guest-hero { padding:120px 0 60px; }
.search-sticky { background:#fff; border-bottom:1px solid var(--bdr); padding:16px 0; position:sticky; top:68px; z-index:100; box-shadow:var(--sh-sm); }
.ss-inner { display:flex; align-items:center; gap:0; background:var(--salt); border:1.5px solid var(--bdr); border-radius:60px; padding:6px 6px 6px 0; }
.ss-field { flex:1; padding:8px 20px; display:flex; flex-direction:column; gap:2px; }
.ss-field label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--txt-lt); }
.ss-field input, .ss-field select { font-size:13px; color:var(--txt); width:100%; border:none; background:none; outline:none; padding:2px 0; }
.ss-sep { width:1px; height:32px; background:var(--bdr); flex-shrink:0; }
.ss-btn { background:var(--ocean); color:#fff; padding:12px 24px; border-radius:50px; font-size:14px; font-weight:700; cursor:pointer; transition:all 0.2s; flex-shrink:0; margin:0 0 0 6px; border:none; font-family:var(--sans); }
.ss-btn:hover { background:var(--deep); }
.filter-bar { padding:16px 0; background:#fff; border-bottom:1px solid var(--bdr); }
.fb-inner { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.fb-label { font-size:12px; font-weight:700; color:var(--txt-lt); white-space:nowrap; }
.fb-pills { display:flex; gap:8px; flex-wrap:wrap; flex:1; }
.fb-pill { padding:7px 16px; border-radius:50px; font-size:12px; font-weight:600; color:var(--txt-mid); border:1.5px solid var(--bdr); cursor:pointer; transition:all 0.2s; background:#fff; }
.fb-pill.active, .fb-pill:hover { background:var(--ocean); color:#fff; border-color:var(--ocean); }
.fb-sort { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--txt-mid); white-space:nowrap; }
.fb-sort select { font-size:12px; color:var(--ocean); font-weight:600; cursor:pointer; border:none; background:none; outline:none; font-family:var(--sans); }
.listings-section { padding:40px 0 80px; background:var(--salt); }
.listings-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; }
.lh-count { font-size:14px; color:var(--txt-mid); font-weight:600; }
.lh-view { display:flex; gap:4px; }
.view-btn { width:32px; height:32px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--txt-lt); cursor:pointer; transition:all 0.2s; border:1px solid var(--bdr); }
.view-btn.active { background:var(--ocean); color:#fff; border-color:var(--ocean); }
.listings-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.bc-img-sail2 { background:linear-gradient(135deg,#2a6eb0 0%,#4a9abe 40%,#7ec8e0 100%); }
.bc-img-power2 { background:linear-gradient(135deg,#1a3a50 0%,#2a6a8e 50%,#4a9ab8 100%); }
.bc-img-cat2 { background:linear-gradient(135deg,#0a3d5c 0%,#1a6a8e 40%,#2a9abe 80%,#5ab8d8 100%); }
.bc-work-badge { position:absolute; bottom:14px; right:14px; background:rgba(42,138,94,0.9); color:#fff; font-size:10px; font-weight:700; padding:4px 10px; border-radius:50px; backdrop-filter:blur(6px); }
.charter-badge { background:rgba(192,125,32,0.9) !important; color:#fff !important; }
.bc-stars { font-size:12px; color:var(--amber); margin-bottom:8px; }
.bc-stars span { color:var(--txt-lt); font-size:11px; }
.bc-desc { font-size:12px; line-height:1.7; color:var(--txt-mid); margin-bottom:12px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.split { font-size:11px; color:var(--green); font-weight:700; margin-top:2px; display:block; }
.boat-card.hidden { display:none; }

/* Voyage Log teaser */
.voyage-log-teaser { padding:100px 0; background:var(--white); }
.vlt-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.vl-card { background:var(--ink); border-radius:var(--r-lg); padding:28px; color:#fff; box-shadow:var(--sh-xl); }
.vlc-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; font-size:14px; font-weight:700; }
.vlc-badge { background:var(--ocean); color:#fff; font-size:10px; font-weight:700; padding:4px 12px; border-radius:50px; }
.vlc-map-stub { height:140px; background:linear-gradient(135deg,rgba(26,106,142,0.3),rgba(74,154,190,0.2)); border-radius:var(--r); margin-bottom:20px; display:flex; align-items:center; justify-content:center; font-size:40px; opacity:0.5; }
.vlc-map-stub::after { content:'🗺'; }
.vlc-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:16px; }
.vls { text-align:center; }
.vls-num { font-family:var(--serif); font-size:24px; font-weight:900; color:#fff; }
.vls-label { font-size:10px; color:rgba(255,255,255,0.5); margin-top:2px; }
.vlc-pins { display:flex; flex-wrap:wrap; gap:6px; }
.vp { background:rgba(255,255,255,0.1); color:rgba(255,255,255,0.7); font-size:11px; padding:4px 10px; border-radius:50px; }
.vp.active { background:var(--ocean); color:#fff; }

/* Booking modal */
.booking-modal { position:fixed; inset:0; z-index:2000; display:flex; align-items:center; justify-content:center; padding:24px; }
.booking-modal[hidden] { display:none; }
.bm-overlay { position:absolute; inset:0; background:rgba(9,32,47,0.7); backdrop-filter:blur(4px); }
.bm-card { position:relative; z-index:2; background:#fff; border-radius:var(--r-xl); padding:40px; max-width:520px; width:100%; box-shadow:var(--sh-xl); max-height:90vh; overflow-y:auto; }
.bm-close { position:absolute; top:16px; right:16px; width:32px; height:32px; border-radius:50%; background:var(--mist); color:var(--txt-mid); font-size:14px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all 0.2s; }
.bm-close:hover { background:var(--bdr); }
.bm-card h2 { font-family:var(--serif); font-size:26px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.bm-vessel { font-size:14px; color:var(--ocean); font-weight:600; margin-bottom:24px; }
.bm-form { display:flex; flex-direction:column; gap:16px; }
.bm-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bm-field { display:flex; flex-direction:column; gap:6px; }
.bm-field label { font-size:12px; font-weight:700; color:var(--txt); }
.bm-field input, .bm-field select { padding:10px 14px; border:1.5px solid var(--bdr); border-radius:var(--r); font-size:14px; color:var(--txt); outline:none; font-family:var(--sans); }
.bm-field input:focus, .bm-field select:focus { border-color:var(--ocean); }
.bm-price-line { display:flex; justify-content:space-between; padding:12px 0; border-top:1px solid var(--mist); font-size:14px; font-weight:700; color:var(--ink); }
.bm-submit { padding:16px; font-size:16px; }
.bm-note { font-size:11px; color:var(--txt-lt); text-align:center; }

/* ═══ MARINAS PAGE ═══ */
.marina-truth { padding:100px 0; background:var(--white); }
.marina-comparison { display:grid; grid-template-columns:1fr auto 1fr; gap:24px; align-items:start; }
.mc-col { background:var(--salt); border-radius:var(--r-lg); padding:24px; border:1px solid var(--bdr); }
.mc-head { font-family:var(--serif); font-size:18px; font-weight:700; color:var(--ink); margin-bottom:16px; padding-bottom:12px; border-bottom:2px solid var(--bdr); text-align:center; }
.mc-item { padding:10px 14px; border-radius:var(--r); margin-bottom:8px; font-size:13px; font-weight:600; }
.mc-item.bad { background:rgba(220,53,69,0.08); color:#dc3545; }
.mc-item.good { background:rgba(42,138,94,0.1); color:var(--green); }
.mc-arrow { display:flex; align-items:center; font-size:28px; color:var(--ocean); padding-top:60px; }
.marina-pulse { padding:100px 0; background:var(--salt); }
.pulse-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:60px; align-items:start; margin-top:24px; }
.mp-dashboard { background:var(--ink); border-radius:var(--r-lg); padding:28px; color:#fff; box-shadow:var(--sh-xl); }
.mpd-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.mpd-title { font-size:14px; font-weight:700; color:rgba(255,255,255,0.8); }
.mpd-live { display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px; color:#22c55e; letter-spacing:2px; }
.mpd-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:20px; }
.mpds { text-align:center; background:rgba(255,255,255,0.07); border-radius:var(--r); padding:16px 8px; }
.mpds-num { font-family:var(--serif); font-size:26px; font-weight:900; color:#fff; }
.mpds-label { font-size:10px; color:rgba(255,255,255,0.5); margin-top:4px; }
.mpd-chart { margin-bottom:20px; }
.mpdc-label { font-size:11px; color:rgba(255,255,255,0.5); margin-bottom:10px; letter-spacing:2px; text-transform:uppercase; }
.mpdc-bars { display:flex; align-items:flex-end; gap:6px; height:80px; }
.mpdc-bar-wrap { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; height:100%; justify-content:flex-end; }
.mpdc-bar { width:100%; background:rgba(26,106,142,0.6); border-radius:3px 3px 0 0; transition:height 1s ease; }
.mpdc-bar-peak { background:var(--ocean); }
.mpdc-bar-wrap span { font-size:9px; color:rgba(255,255,255,0.4); }
.mpd-slips { }
.mpd-slips-title { font-size:11px; color:rgba(255,255,255,0.5); margin-bottom:10px; letter-spacing:2px; text-transform:uppercase; }
.slip-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:6px; margin-bottom:10px; }
.slip-item { height:32px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; }
.slip-item.booked { background:rgba(26,106,142,0.5); color:rgba(255,255,255,0.8); }
.slip-item.avail { background:rgba(34,197,94,0.3); color:#4ade80; }
.slip-item.blocked { background:rgba(221,160,48,0.3); color:var(--amber); }
.slip-legend { display:flex; gap:12px; font-size:10px; color:rgba(255,255,255,0.4); }
.sl-dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:4px; }
.sl-booked { background:rgba(26,106,142,0.8); }
.sl-avail { background:#22c55e; }
.sl-blocked { background:var(--amber); }
.pulse-features { display:flex; flex-direction:column; gap:24px; }
.pf-item { display:flex; gap:16px; align-items:flex-start; padding:20px; background:#fff; border-radius:var(--r); border:1px solid var(--bdr); transition:all 0.3s; }
.pf-item:hover { box-shadow:var(--sh-sm); border-color:var(--sky-lt); }
.pf-icon { font-size:28px; flex-shrink:0; }
.pf-item h3 { font-size:16px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.pf-item p { font-size:13px; line-height:1.7; color:var(--txt-mid); }
.marina-calc { padding:100px 0; background:var(--white); }
.mcalc-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:48px; align-items:start; margin-top:24px; }
.marina-tiers { padding:100px 0; background:var(--mist); }
.tiers-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.tier-card { background:#fff; border:1px solid var(--bdr); border-radius:var(--r-lg); padding:36px 28px; position:relative; transition:all 0.3s; }
.tier-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); }
.tier-feat { border-color:var(--sky); box-shadow:var(--sh-md); }
.tier-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--ocean); color:#fff; font-size:11px; font-weight:700; padding:4px 16px; border-radius:50px; white-space:nowrap; }
.tier-name { font-family:var(--serif); font-size:22px; font-weight:700; color:var(--ink); margin-bottom:4px; }
.tier-slips { font-family:var(--mono); font-size:11px; color:var(--ocean); letter-spacing:2px; margin-bottom:16px; }
.tier-card p { font-size:14px; line-height:1.8; color:var(--txt-mid); margin-bottom:20px; }
.tier-list { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.tier-list li { font-size:13px; color:var(--txt-mid); }
.marina-testi { padding:80px 0; background:var(--white); }
.marina-form-section { padding:100px 0; background:var(--mist); }

/* ═══ RESPONSIVE ═══ */
@media (max-width:1024px) {
  .calc-grid, .mcalc-grid, .pulse-grid { grid-template-columns:1fr; }
  .calc-result, .mcalc-result { position:static; }
  .prog-grid, .tiers-grid { grid-template-columns:1fr 1fr; }
  .truth-grid, .passport-grid, .vlt-grid { grid-template-columns:1fr; gap:40px; }
  .marina-comparison { grid-template-columns:1fr; }
  .mc-arrow { display:none; }
}
@media (max-width:768px) {
  .page-hero { padding:110px 0 60px; }
  .ph-stats { flex-direction:column; gap:16px; }
  .ph-stat-div { width:100%; height:1px; }
  .owner-steps, .os-conn { flex-direction:column; }
  .os-conn { width:2px; height:24px; background:linear-gradient(180deg,var(--ocean),var(--sky-lt)); margin:0 0 0 0; align-self:center; }
  .prog-grid, .tiers-grid { grid-template-columns:1fr; }
  .form-row, .bm-row { grid-template-columns:1fr; }
  .listings-grid { grid-template-columns:1fr 1fr; }
  .vlc-stats { grid-template-columns:repeat(3,1fr); }
  .slip-grid { grid-template-columns:repeat(4,1fr); }
  .mpd-stats { grid-template-columns:repeat(3,1fr); }
  .ss-inner { flex-direction:column; border-radius:var(--r-lg); align-items:stretch; }
  .ss-sep { width:100%; height:1px; }
  .ss-btn { border-radius:var(--r); margin:8px; }
}
@media (max-width:480px) {
  .listings-grid { grid-template-columns:1fr; }
  .tribe-badges { grid-template-columns:1fr 1fr; }
}
