/* ============================================
   Shared additions: ribbon, footer, left-aligned section heads,
   yacht detail sections, route detail, about/contact
   ============================================ */

/* ---- Top ribbon (above navbar) ---- */
.kek-ribbon{background:#0F1B33;color:#fff;font-size:13px;}
.kek-ribbon-inner{max-width:1320px;margin:0 auto;padding:10px 64px;display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
.kek-ribbon .marquee{flex:1;display:flex;gap:24px;flex-wrap:wrap;align-items:center;color:rgba(255,255,255,0.85);}
.kek-ribbon .marquee span{display:inline-flex;gap:8px;align-items:center;}
.kek-ribbon .marquee svg{width:14px;height:14px;color:#C9A663;flex-shrink:0;}
.kek-ribbon .marquee .dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,0.3);display:inline-block;}
.kek-ribbon .links{display:flex;gap:18px;align-items:center;color:rgba(255,255,255,0.85);}
.kek-ribbon .links a{color:inherit;text-decoration:none;display:inline-flex;gap:6px;align-items:center;}
.kek-ribbon .links a:hover{color:#fff;}
.kek-ribbon .links svg{width:13px;height:13px;}
.kek-ribbon .lang{display:flex;gap:6px;}
.kek-ribbon .lang a{padding:2px 8px;border-radius:999px;font-size:12px;font-weight:600;color:rgba(255,255,255,0.6);}
.kek-ribbon .lang a.active{background:rgba(255,255,255,0.15);color:#fff;}
@media (max-width:900px){.kek-ribbon-inner{padding:10px 24px;font-size:12px;}.kek-ribbon .marquee{gap:14px;}}

/* ---- Footer ---- */
.kek-footer{background:#0B1428;color:rgba(255,255,255,0.7);padding:80px 0 24px;}
.kek-footer-inner{max-width:1320px;margin:0 auto;padding:0 64px;}
.kek-footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,0.1);}
.kek-footer-brand .logo{display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none;font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:700;margin-bottom:18px;}
.kek-footer-brand .logo img{height:36px;width:auto;}
.kek-footer-brand .logo em{font-style:italic;font-weight:400;opacity:0.8;}
.kek-footer-brand p{font-size:14px;line-height:1.6;margin:0 0 22px;max-width:36ch;}
.kek-footer-brand .socials{display:flex;gap:10px;}
.kek-footer-brand .socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,0.18);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.7);transition:all 0.18s;}
.kek-footer-brand .socials a:hover{background:#fff;color:#0F1B33;border-color:#fff;}
.kek-footer-brand .socials svg{width:16px;height:16px;}
.kek-footer-col h4{font-family:'Bricolage Grotesque',sans-serif;color:#fff;font-size:13px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;margin:0 0 16px;}
.kek-footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.kek-footer-col a{color:rgba(255,255,255,0.7);text-decoration:none;font-size:14px;transition:color 0.18s;}
.kek-footer-col a:hover{color:#fff;}
.kek-footer-contact .item{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;font-size:14px;line-height:1.5;}
.kek-footer-contact .item svg{width:16px;height:16px;color:#C9A663;flex-shrink:0;margin-top:3px;}
.kek-footer-contact .item strong{display:block;color:#fff;font-weight:600;}
.kek-footer-contact .item a{color:rgba(255,255,255,0.7);text-decoration:none;}
.kek-footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;padding-top:24px;font-size:12px;color:rgba(255,255,255,0.45);}
.kek-footer-bottom .legal{display:flex;gap:18px;flex-wrap:wrap;}
.kek-footer-bottom .legal a{color:rgba(255,255,255,0.55);text-decoration:none;}
.kek-footer-bottom .legal a:hover{color:#fff;}
.kek-footer-bottom .insurances{display:flex;gap:14px;align-items:center;color:rgba(255,255,255,0.55);}
.kek-footer-bottom .insurances .badge{padding:4px 10px;border:1px solid rgba(255,255,255,0.2);border-radius:999px;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;}
@media (max-width:1100px){.kek-footer-top{grid-template-columns:1fr 1fr 1fr;}}
@media (max-width:720px){.kek-footer-top{grid-template-columns:1fr 1fr;}.kek-footer-inner{padding:0 24px;}}

/* ---- Section heads aligned LEFT ---- */
.section-head-left{display:grid;grid-template-columns:1.05fr 2fr;gap:64px;margin-bottom:56px;align-items:end;}
.section-head-left .lhs .kicker{display:inline-block;font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:#C9A663;margin-bottom:16px;}
.section-head-left .lhs h2{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(40px,4.6vw,60px);font-weight:700;letter-spacing:-0.025em;line-height:1;margin:0;}
.section-head-left .lhs h2 .italic-accent{font-style:italic;font-weight:500;color:#4A6395;}
.section-head-left .rhs{font-size:17px;line-height:1.6;color:#3A3D4A;max-width:54ch;padding-bottom:6px;}
.section-head-left .rhs p{margin:0;}
@media (max-width:900px){.section-head-left{grid-template-columns:1fr;gap:18px;}}

/* ---- Yacht detail: virtual tour ---- */
.virtual-tour{background:#0F1B33;border-radius:24px;overflow:hidden;position:relative;aspect-ratio:16/8;color:#fff;}
.virtual-tour .vt-photo{position:absolute;inset:0;background:linear-gradient(140deg,#253D6F 0%,#0F1B33 60%,#1A2C54 100%);}
.virtual-tour .vt-photo::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 30% 40%,rgba(201,166,99,0.2),transparent 50%),radial-gradient(circle at 70% 60%,rgba(110,159,184,0.2),transparent 50%);}
.virtual-tour .vt-content{position:absolute;inset:0;padding:48px;display:flex;flex-direction:column;justify-content:space-between;}
.virtual-tour .vt-tag{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,0.12);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.2);padding:8px 14px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;align-self:flex-start;}
.virtual-tour .vt-tag svg{width:14px;height:14px;color:#C9A663;}
.virtual-tour .vt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:96px;height:96px;border-radius:50%;background:rgba(255,255,255,0.96);color:#0F1B33;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 16px 40px rgba(0,0,0,0.4);transition:transform 0.2s;}
.virtual-tour .vt-play:hover{transform:translate(-50%,-50%) scale(1.06);}
.virtual-tour .vt-play svg{width:32px;height:32px;margin-left:4px;}
.virtual-tour .vt-text h3{font-family:'Bricolage Grotesque',sans-serif;font-size:36px;font-weight:700;letter-spacing:-0.02em;margin:0 0 8px;color:#fff;}
.virtual-tour .vt-text p{font-size:15px;color:rgba(255,255,255,0.75);margin:0;max-width:50ch;}
.virtual-tour .vt-features{display:flex;gap:24px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,0.85);}
.virtual-tour .vt-features span{display:inline-flex;gap:6px;align-items:center;}
.virtual-tour .vt-features svg{width:16px;height:16px;color:#C9A663;}

/* ---- Weekly price calendar ---- */
.price-cal{background:#fff;border:1px solid #EFE9DC;border-radius:18px;overflow:hidden;}
.price-cal-head{background:#0F1B33;color:#fff;padding:18px 24px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:16px;font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;}
.price-cal-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:16px;padding:14px 24px;border-top:1px solid #F0EBDD;align-items:center;font-size:14px;}
.price-cal-row:nth-child(even){background:#FBF8EF;}
.price-cal-row .period{font-weight:600;color:#0F1B33;}
.price-cal-row .nights{color:#6B6E7B;font-size:13px;}
.price-cal-row .price{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;justify-self:end;display:flex;align-items:center;gap:10px;}
.price-cal-row .swatch{width:14px;height:14px;border-radius:4px;}
.price-cal-row.s-low .swatch{background:#86C97A;}
.price-cal-row.s-low{}
.price-cal-row.s-shoulder .swatch{background:#F2DC4F;}
.price-cal-row.s-mid .swatch{background:#F7B330;}
.price-cal-row.s-high .swatch{background:#EE862A;}
.price-cal-row.s-peak .swatch{background:#D2502A;}
.price-cal-legend{display:flex;flex-wrap:wrap;gap:18px;padding:18px 24px;border-top:1px solid #F0EBDD;background:#F6F1E6;font-size:12px;color:#6B6E7B;}
.price-cal-legend .item{display:inline-flex;gap:6px;align-items:center;}
.price-cal-legend .swatch{width:12px;height:12px;border-radius:3px;}

/* ---- Equipment categories (yacht detail) ---- */
.equip-categories{display:flex;flex-direction:column;gap:14px;}
.equip-cat{background:#fff;border:1px solid #EFE9DC;border-radius:14px;overflow:hidden;}
.equip-cat-head{display:flex;align-items:center;gap:14px;padding:18px 22px;cursor:pointer;background:#FBF8EF;list-style:none;}
.equip-cat-head::-webkit-details-marker{display:none;}
.equip-cat-head .cat-ic{width:40px;height:40px;border-radius:10px;background:#0F1B33;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.equip-cat-head .cat-ic svg{width:22px;height:22px;}
.equip-cat-head .cat-name{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;flex:1;}
.equip-cat-head .cat-count{font-size:13px;color:#6B6E7B;background:#fff;border:1px solid #EFE9DC;padding:4px 10px;border-radius:999px;}
.equip-cat-head .chev{margin-left:8px;transition:transform 0.25s;color:#6B6E7B;}
details[open] .equip-cat-head .chev{transform:rotate(180deg);}
.equip-cat-body{padding:8px 22px 22px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px 24px;}
.equip-cat-body .row{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:#3A3D4A;line-height:1.5;padding:6px 0;border-bottom:1px dashed #F0EBDD;}
.equip-cat-body .row:last-child{border:none;}
.equip-cat-body .row .name{font-weight:600;color:#0F1B33;}
.equip-cat-body .row .det{color:#6B6E7B;font-size:13px;display:block;margin-top:2px;font-style:italic;}
.equip-cat-body .row svg{width:16px;height:16px;color:#1F8A5B;flex-shrink:0;margin-top:3px;}
@media (max-width:720px){.equip-cat-body{grid-template-columns:1fr;}}

/* ---- FAQ list ---- */
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:880px;margin:0 auto;}
.faq-list details{background:#fff;border:1px solid #EFE9DC;border-radius:14px;padding:20px 24px;transition:box-shadow 0.18s;}
.faq-list details[open]{box-shadow:0 8px 24px -16px rgba(15,27,51,0.12);}
.faq-list summary{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:18px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px;align-items:center;color:#0F1B33;}
.faq-list summary::-webkit-details-marker{display:none;}
.faq-list summary::after{content:"+";font-size:28px;line-height:1;color:#C9A663;font-weight:300;flex-shrink:0;}
.faq-list details[open] summary::after{content:"–";}
.faq-list details p{margin:14px 0 0;color:#3A3D4A;line-height:1.65;font-size:15px;}
.faq-list details ul{margin:12px 0 0;padding-left:18px;color:#3A3D4A;}
.faq-list details li{font-size:14px;line-height:1.65;margin-bottom:4px;}

/* ---- Services: visual hero rows ---- */
.svc-hero-row{display:grid;grid-template-columns:1.05fr 1.4fr;gap:64px;align-items:center;margin-bottom:80px;}
.svc-hero-row.flip{grid-template-columns:1.4fr 1.05fr;}
.svc-hero-row.flip .lhs{order:2;}
.svc-hero-row .lhs .kicker{font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:#C9A663;display:block;margin-bottom:16px;}
.svc-hero-row .lhs h3{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(36px,4vw,52px);font-weight:700;letter-spacing:-0.02em;line-height:1;margin:0 0 20px;}
.svc-hero-row .lhs h3 .italic-accent{font-style:italic;font-weight:500;color:#4A6395;}
.svc-hero-row .lhs p{font-size:16px;line-height:1.6;color:#3A3D4A;margin:0 0 18px;}
.svc-vis{aspect-ratio:5/4;border-radius:24px;background:linear-gradient(140deg,#F6F1E6,#E0D6BC);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.svc-vis.dark{background:linear-gradient(140deg,#253D6F 0%,#0F1B33 100%);color:#fff;}
.svc-vis svg{width:55%;height:auto;color:#0F1B33;opacity:0.8;}
.svc-vis.dark svg{color:#C9A663;}
.svc-vis .stamps{position:absolute;left:24px;right:24px;bottom:24px;display:flex;gap:8px;flex-wrap:wrap;}
.svc-vis .stamps span{background:rgba(255,255,255,0.92);backdrop-filter:blur(6px);padding:8px 14px;border-radius:999px;font-size:12px;font-weight:600;color:#0F1B33;}
.svc-vis.dark .stamps span{background:rgba(255,255,255,0.12);color:#fff;border:1px solid rgba(255,255,255,0.2);}

/* ---- Extras list with icons (the table style from screenshot) ---- */
.extras-table{background:#fff;border:1px solid #EFE9DC;border-radius:18px;overflow:hidden;margin-bottom:32px;}
.extras-table-head{background:#0F1B33;color:#fff;padding:18px 24px;display:flex;align-items:center;gap:14px;}
.extras-table-head .ic{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;}
.extras-table-head .ic svg{width:20px;height:20px;color:#C9A663;}
.extras-table-head h4{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:700;margin:0;letter-spacing:-0.01em;}
.extras-row{display:grid;grid-template-columns:48px 1fr auto;gap:16px;padding:16px 24px;border-top:1px solid #F0EBDD;align-items:center;}
.extras-row:nth-child(even){background:#FBF8EF;}
.extras-row .ic{width:40px;height:40px;border-radius:10px;background:#F6F1E6;color:#253D6F;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.extras-row .ic svg{width:20px;height:20px;}
.extras-row .label .name{font-weight:600;color:#0F1B33;font-size:15px;display:block;}
.extras-row .label .det{font-size:13px;color:#6B6E7B;font-style:italic;}
.extras-row .label .req{display:inline-block;font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#D2502A;background:#FFF1E6;padding:2px 8px;border-radius:999px;margin-right:6px;}
.extras-row .label .opt{display:inline-block;font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#6B6E7B;background:#F0ECDF;padding:2px 8px;border-radius:999px;margin-right:6px;}
.extras-row .price{font-family:'Bricolage Grotesque',sans-serif;font-size:17px;font-weight:700;color:#0F1B33;text-align:right;white-space:nowrap;}
.extras-row .price small{font-size:12px;color:#6B6E7B;font-weight:500;display:block;}

.extras-table-sub{background:#F6F1E6;padding:10px 24px;font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#3A3D4A;border-top:1px solid #F0EBDD;display:flex;align-items:center;gap:10px;}
.extras-table-sub svg{width:16px;height:16px;color:#C9A663;}

/* ---- Legal links cluster ---- */
.legal-cluster{background:#F6F1E6;border-radius:18px;padding:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px;}
.legal-cluster a{background:#fff;border:1px solid #EFE9DC;border-radius:12px;padding:18px;display:flex;flex-direction:column;gap:6px;text-decoration:none;color:#0F1B33;transition:all 0.18s;}
.legal-cluster a:hover{transform:translateY(-2px);box-shadow:0 12px 24px -16px rgba(15,27,51,0.18);}
.legal-cluster .ic{width:32px;height:32px;color:#253D6F;margin-bottom:6px;}
.legal-cluster strong{font-family:'Bricolage Grotesque',sans-serif;font-size:15px;font-weight:700;}
.legal-cluster small{font-size:12px;color:#6B6E7B;}
@media (max-width:900px){.legal-cluster{grid-template-columns:repeat(2,1fr);}}

/* ---- Route detail page (single route) ---- */
.route-hero-page{position:relative;height:60vh;min-height:480px;color:#fff;overflow:hidden;}
.route-hero-page .bg{position:absolute;inset:0;background:linear-gradient(160deg,#4A6395 0%,#1A2C54 100%);}
.route-hero-page .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(15,27,51,0.7) 100%);}
.route-hero-page .content{position:relative;height:100%;max-width:1320px;margin:0 auto;padding:80px 64px;display:flex;flex-direction:column;justify-content:flex-end;}
.route-hero-page .crumbs{font-size:13px;color:rgba(255,255,255,0.7);margin-bottom:20px;}
.route-hero-page .crumbs a{color:rgba(255,255,255,0.7);text-decoration:none;}
.route-hero-page .crumbs a:hover{color:#fff;}
.route-hero-page h1{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(54px,7vw,96px);line-height:0.95;font-weight:700;letter-spacing:-0.025em;margin:0 0 18px;color:#fff;}
.route-hero-page h1 .italic-accent{font-style:italic;font-weight:500;color:rgba(255,255,255,0.65);}
.route-hero-page .rh-pills{display:flex;gap:10px;flex-wrap:wrap;}
.route-hero-page .rh-pills span{background:rgba(255,255,255,0.14);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.22);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;}

/* Route stats banner */
.route-stats{background:#0F1B33;color:#fff;}
.route-stats-inner{max-width:1320px;margin:0 auto;padding:32px 64px;display:grid;grid-template-columns:repeat(5,1fr);gap:32px;}
.route-stats .item{display:flex;flex-direction:column;gap:4px;}
.route-stats .item .lbl{font-size:11px;color:rgba(255,255,255,0.55);letter-spacing:0.1em;text-transform:uppercase;}
.route-stats .item strong{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:700;}
.route-stats .item span.note{font-size:12px;color:rgba(255,255,255,0.7);}

/* Route content layout */
.route-layout{display:grid;grid-template-columns:1fr 360px;gap:64px;padding:80px 0;}
@media (max-width:1100px){.route-layout{grid-template-columns:1fr;}}

/* Day-by-day timeline */
.itinerary-day{display:grid;grid-template-columns:120px 1fr;gap:32px;padding:32px 0;border-bottom:1px solid #EFE9DC;align-items:start;}
.itinerary-day:last-child{border:none;}
.itinerary-day .day-tag{position:sticky;top:24px;}
.itinerary-day .day-tag .num{font-family:'Bricolage Grotesque',sans-serif;font-size:48px;font-weight:700;color:#0F1B33;line-height:1;}
.itinerary-day .day-tag .lbl{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#C9A663;margin-top:4px;}
.itinerary-day h4{font-family:'Bricolage Grotesque',sans-serif;font-size:28px;font-weight:700;letter-spacing:-0.02em;margin:0 0 8px;}
.itinerary-day .route-line{font-size:14px;color:#6B6E7B;margin-bottom:14px;display:flex;gap:14px;flex-wrap:wrap;}
.itinerary-day .route-line span{display:inline-flex;gap:6px;align-items:center;}
.itinerary-day .route-line svg{width:14px;height:14px;color:#253D6F;}
.itinerary-day p{font-size:15px;line-height:1.65;color:#3A3D4A;margin:0 0 14px;}
.itinerary-day .highlights{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.itinerary-day .highlights span{background:#F6F1E6;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;color:#0F1B33;}
.itinerary-day .photo-strip{margin-top:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.itinerary-day .photo-strip .ph{aspect-ratio:4/3;border-radius:10px;background:linear-gradient(160deg,#BFD2DD,#6E8FA8);}
.itinerary-day .photo-strip .ph:nth-child(2){background:linear-gradient(160deg,#4A6395,#253D6F);}
.itinerary-day .photo-strip .ph:nth-child(3){background:linear-gradient(160deg,#C9A663,#8B7438);}

.route-aside{position:sticky;top:24px;align-self:start;display:flex;flex-direction:column;gap:18px;}
.route-aside .card{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:24px;}
.route-aside .card h4{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;margin:0 0 14px;}
.route-aside .card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:14px;color:#3A3D4A;}
.route-aside .card li{display:flex;justify-content:space-between;border-bottom:1px dashed #EFE9DC;padding-bottom:6px;}
.route-aside .card li:last-child{border:none;padding-bottom:0;}
.route-aside .btn{justify-content:center;}

/* Route map */
.route-map{background:#F6F1E6;border-radius:24px;padding:32px;margin-bottom:48px;}
.route-map svg{width:100%;height:auto;display:block;}

/* ---- About page ---- */
.about-hero{padding:120px 0 80px;background:#FBF8F2;}
.about-hero-inner{max-width:1320px;margin:0 auto;padding:0 64px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.about-hero .kicker{display:inline-block;font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:#C9A663;margin-bottom:18px;}
.about-hero h1{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(54px,6vw,84px);line-height:0.95;font-weight:700;letter-spacing:-0.025em;margin:0 0 22px;}
.about-hero h1 .italic-accent{font-style:italic;font-weight:500;color:#4A6395;}
.about-hero p{font-size:18px;line-height:1.6;color:#3A3D4A;margin:0;}
.about-hero .vis{aspect-ratio:4/5;border-radius:24px;background:linear-gradient(140deg,#4A6395 0%,#253D6F 60%,#0F1B33 100%);position:relative;overflow:hidden;}
.about-hero .vis .stamp{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,0.95);padding:14px 18px;border-radius:14px;font-size:14px;color:#0F1B33;}
.about-hero .vis .stamp strong{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:18px;}
@media (max-width:900px){.about-hero-inner{grid-template-columns:1fr;}}

.numbers-row{background:#0F1B33;color:#fff;}
.numbers-row-inner{max-width:1320px;margin:0 auto;padding:48px 64px;display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
.numbers-row .item{display:flex;flex-direction:column;gap:6px;}
.numbers-row strong{font-family:'Bricolage Grotesque',sans-serif;font-size:48px;font-weight:700;line-height:1;letter-spacing:-0.02em;}
.numbers-row strong span{font-size:24px;color:#C9A663;}
.numbers-row .lbl{font-size:13px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.1em;}

.team-row{display:grid;grid-template-columns:repeat(2,1fr);gap:48px;}
.team-card{background:#fff;border:1px solid #EFE9DC;border-radius:24px;overflow:hidden;}
.team-card .ph{aspect-ratio:4/3;background:linear-gradient(140deg,#BFD2DD,#4A6395);position:relative;}
.team-card.k2 .ph{background:linear-gradient(140deg,#6E9A9C,#3F6364);}
.team-card .body{padding:32px;}
.team-card .role{font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:#C9A663;margin-bottom:8px;}
.team-card h3{font-family:'Bricolage Grotesque',sans-serif;font-size:32px;font-weight:700;margin:0 0 6px;letter-spacing:-0.02em;}
.team-card .creds{font-size:13px;color:#6B6E7B;margin-bottom:16px;}
.team-card p{font-size:15px;line-height:1.65;color:#3A3D4A;margin:0 0 16px;}
.team-card .contact{display:flex;gap:18px;font-size:14px;color:#253D6F;flex-wrap:wrap;}
.team-card .contact a{color:#253D6F;text-decoration:none;display:inline-flex;gap:6px;align-items:center;}

.story-block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.story-block .vis{aspect-ratio:4/5;border-radius:24px;background:linear-gradient(160deg,#F6F1E6,#C9A663);position:sticky;top:24px;}
.story-block article p{font-size:17px;line-height:1.75;color:#3A3D4A;margin:0 0 20px;}
.story-block article p:first-child::first-letter{font-family:'Bricolage Grotesque',sans-serif;font-size:64px;float:left;line-height:0.9;margin:6px 12px 0 0;color:#0F1B33;font-weight:700;}
.story-block article h3{font-family:'Bricolage Grotesque',sans-serif;font-size:32px;font-weight:700;letter-spacing:-0.02em;margin:32px 0 12px;}
@media (max-width:900px){.story-block,.team-row{grid-template-columns:1fr;}}

/* Timeline */
.timeline{position:relative;padding-left:32px;}
.timeline::before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:#EFE9DC;}
.timeline .yr{position:relative;margin-bottom:32px;}
.timeline .yr::before{content:"";position:absolute;left:-32px;top:6px;width:14px;height:14px;border-radius:50%;background:#C9A663;border:3px solid #FBF8F2;}
.timeline .yr-num{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:700;color:#0F1B33;margin-bottom:4px;}
.timeline .yr p{font-size:15px;color:#3A3D4A;margin:0;line-height:1.6;}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.values-grid .item{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:32px;}
.values-grid .ic{width:48px;height:48px;border-radius:12px;background:#F6F1E6;color:#253D6F;display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.values-grid .ic svg{width:26px;height:26px;}
.values-grid h4{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:700;margin:0 0 8px;}
.values-grid p{font-size:14px;line-height:1.6;color:#3A3D4A;margin:0;}

/* ---- Contact page ---- */
.contact-hero{padding:96px 0 48px;background:#FBF8F2;}
.contact-hero-inner{max-width:1320px;margin:0 auto;padding:0 64px;text-align:center;max-width:760px;}
.contact-hero h1{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(48px,5.5vw,72px);line-height:1;font-weight:700;letter-spacing:-0.025em;margin:18px 0;}
.contact-hero h1 .italic-accent{font-style:italic;font-weight:500;color:#4A6395;}
.contact-hero p{font-size:17px;line-height:1.6;color:#3A3D4A;margin:0;}

.contact-channels{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.contact-channel{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:28px;text-decoration:none;color:#0F1B33;display:flex;flex-direction:column;gap:8px;transition:all 0.18s;}
.contact-channel:hover{transform:translateY(-3px);box-shadow:0 16px 32px -20px rgba(15,27,51,0.18);}
.contact-channel .ic{width:48px;height:48px;border-radius:14px;background:#F6F1E6;color:#253D6F;display:flex;align-items:center;justify-content:center;margin-bottom:8px;}
.contact-channel .ic svg{width:22px;height:22px;}
.contact-channel.wa .ic{background:#E7F8EA;color:#1F8A5B;}
.contact-channel.tel .ic{background:#FFF3DA;color:#A07C30;}
.contact-channel .label{font-size:12px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#6B6E7B;}
.contact-channel strong{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;}
.contact-channel small{font-size:13px;color:#6B6E7B;margin-top:auto;}
@media (max-width:900px){.contact-channels{grid-template-columns:repeat(2,1fr);}}

.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.contact-form{background:#fff;border:1px solid #EFE9DC;border-radius:24px;padding:40px;}
.contact-form h2{font-family:'Bricolage Grotesque',sans-serif;font-size:36px;font-weight:700;letter-spacing:-0.02em;margin:0 0 8px;}
.contact-form .sub{font-size:14px;color:#6B6E7B;margin-bottom:24px;}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.contact-form .field{display:flex;flex-direction:column;gap:6px;}
.contact-form label{font-size:12px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:#6B6E7B;}
.contact-form input,.contact-form select,.contact-form textarea{font-family:'Manrope',sans-serif;background:#FBF8F2;border:1px solid #EFE9DC;border-radius:10px;padding:12px 14px;font-size:15px;color:#0F1B33;}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:#253D6F;background:#fff;}
.contact-form textarea{min-height:120px;resize:vertical;}
.contact-form .full{grid-column:1/-1;}
.contact-form button{margin-top:8px;width:100%;justify-content:center;}

.contact-side{display:flex;flex-direction:column;gap:18px;}
.contact-side .card{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:28px;}
.contact-side .card h4{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;margin:0 0 14px;}
.contact-side .card .item{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:#3A3D4A;line-height:1.5;margin-bottom:14px;}
.contact-side .card svg{width:18px;height:18px;color:#C9A663;flex-shrink:0;margin-top:3px;}
.contact-side .card strong{display:block;color:#0F1B33;}
.contact-side .map{aspect-ratio:5/4;border-radius:18px;background:#EAEEF3;position:relative;overflow:hidden;border:1px solid #EFE9DC;}
.contact-side .map svg{width:100%;height:100%;}

/* Better boat type badges (replaces emoji) */
.badge-type-pretty{position:absolute;top:12px;right:12px;display:inline-flex;gap:6px;align-items:center;background:rgba(255,255,255,0.96);backdrop-filter:blur(10px);color:#0F1B33;font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:6px 12px 6px 8px;border-radius:999px;box-shadow:0 4px 12px rgba(15,27,51,0.12);}
.badge-type-pretty svg{width:16px;height:16px;color:#253D6F;}
.badge-type-pretty.cat svg{color:#C9A663;}


/* ============================================
   Additional styles for route detail / about / contact
   ============================================ */

/* ---- Route detail hero (full page) ---- */
.route-hero{position:relative;min-height:520px;color:#fff;overflow:hidden;padding:80px 0 100px;}
.route-hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,#4A6395 0%,#1A2C54 60%,#0F1B33 100%);}
.route-hero-bg::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 75% 25%,rgba(201,166,99,0.18),transparent 50%),radial-gradient(circle at 20% 80%,rgba(110,159,184,0.18),transparent 50%);}
.route-hero-inner{position:relative;max-width:1320px;margin:0 auto;padding:0 64px;}
.route-hero-inner .kicker{display:inline-block;font-size:13px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;margin-bottom:24px;}
.route-hero-inner h1{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(54px,7vw,96px);line-height:0.95;font-weight:700;letter-spacing:-0.025em;color:#fff;margin:0 0 24px;max-width:14ch;}
.route-hero-inner h1 .italic-accent{font-style:italic;font-weight:500;color:rgba(255,255,255,0.65);}
.route-hero-inner > p{font-size:18px;line-height:1.6;color:rgba(255,255,255,0.85);max-width:60ch;margin:0 0 40px;}
.route-hero-stats{display:flex;align-items:center;gap:32px;flex-wrap:wrap;}
.route-hero-stats .stat{display:flex;flex-direction:column;}
.route-hero-stats .stat strong{font-family:'Bricolage Grotesque',sans-serif;font-size:32px;font-weight:700;letter-spacing:-0.02em;line-height:1;}
.route-hero-stats .stat span{font-size:12px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.1em;margin-top:4px;}
.route-hero-stats .divider{width:1px;height:36px;background:rgba(255,255,255,0.2);}

/* ---- Route map + summary ---- */
.route-map-block{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;background:#fff;border:1px solid #EFE9DC;border-radius:24px;padding:32px;box-shadow:0 24px 60px -40px rgba(15,27,51,0.25);}
.route-map-block .map{background:#EAEEF3;border-radius:18px;overflow:hidden;}
.route-map-block .summary{display:flex;flex-direction:column;justify-content:center;}
.route-map-block .summary h3{font-family:'Bricolage Grotesque',sans-serif;font-size:36px;font-weight:700;letter-spacing:-0.02em;line-height:1.05;}
.route-summary-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.route-summary-list li{display:flex;gap:12px;font-size:15px;color:#3A3D4A;line-height:1.5;align-items:flex-start;}
.route-summary-list svg{width:20px;height:20px;color:#C9A663;flex-shrink:0;margin-top:2px;}
.route-summary-list strong{color:#0F1B33;}
@media (max-width:900px){.route-map-block{grid-template-columns:1fr;}}

/* ---- Route day-by-day timeline ---- */
.route-timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:24px;}
.route-timeline > li{display:grid;grid-template-columns:120px 1fr;gap:32px;align-items:start;}
.route-timeline .day-num{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;color:#0F1B33;background:#F6F1E6;border-radius:12px;padding:14px 18px;text-align:center;text-transform:uppercase;letter-spacing:0.08em;position:sticky;top:24px;}
.route-timeline .day-card{background:#fff;border:1px solid #EFE9DC;border-radius:20px;overflow:hidden;display:grid;grid-template-columns:1fr 1.4fr;}
.route-timeline .day-photo{position:relative;min-height:240px;}
.route-timeline .day-photo image-slot{position:absolute;inset:0;width:100%;height:100%;}
.route-timeline .day-body{padding:28px 32px;}
.route-timeline .day-body h3{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:700;letter-spacing:-0.02em;margin:0 0 6px;}
.route-timeline .day-body .route{font-size:13px;color:#6B6E7B;margin:0 0 14px;font-weight:500;}
.route-timeline .day-body p{font-size:15px;line-height:1.6;color:#3A3D4A;margin:0 0 14px;}
.route-timeline .day-body p:last-of-type{margin:0;}
.route-timeline .day-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}
.route-timeline .day-tags span{display:inline-flex;align-items:center;gap:6px;background:#FBF8EF;color:#0F1B33;font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px;border:1px solid #EFE9DC;}
.route-timeline .day-tags svg{width:14px;height:14px;color:#C9A663;}
@media (max-width:900px){.route-timeline > li{grid-template-columns:1fr;}.route-timeline .day-card{grid-template-columns:1fr;}.route-timeline .day-num{position:static;display:inline-block;}}

/* ---- Highlights grid (route page) ---- */
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.highlights-grid .hl{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:28px;}
.highlights-grid .ic{width:44px;height:44px;border-radius:12px;background:#F6F1E6;color:#253D6F;display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px;}
.highlights-grid .ic svg{width:22px;height:22px;}
.highlights-grid h4{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;margin:0 0 8px;letter-spacing:-0.01em;}
.highlights-grid p{font-size:14px;line-height:1.55;color:#3A3D4A;margin:0;}
@media (max-width:900px){.highlights-grid{grid-template-columns:1fr 1fr;}}

/* ---- Route yacht recommendations ---- */
.route-yacht-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.route-yacht-card{background:#fff;border:1px solid #EFE9DC;border-radius:18px;overflow:hidden;text-decoration:none;color:#0F1B33;display:block;transition:transform 0.18s,box-shadow 0.18s;}
.route-yacht-card:hover{transform:translateY(-3px);box-shadow:0 16px 32px -20px rgba(15,27,51,0.18);}
.route-yacht-card .photo{aspect-ratio:4/3;position:relative;}
.route-yacht-card .photo image-slot{position:absolute;inset:0;width:100%;height:100%;}
.route-yacht-card .body{padding:20px;display:flex;flex-direction:column;gap:4px;}
.route-yacht-card strong{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:700;}
.route-yacht-card .model{font-size:13px;color:#6B6E7B;}
.route-yacht-card .price{font-size:14px;font-weight:600;color:#0F1B33;margin-top:6px;}
@media (max-width:900px){.route-yacht-grid{grid-template-columns:1fr;}}

/* ---- Other routes grid ---- */
.route-other-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
.route-other-grid a{background:#fff;border:1px solid #EFE9DC;border-radius:14px;padding:20px;text-decoration:none;color:#0F1B33;display:flex;flex-direction:column;gap:6px;transition:all 0.18s;}
.route-other-grid a:hover{border-color:#C9A663;transform:translateY(-2px);}
.route-other-grid strong{font-family:'Bricolage Grotesque',sans-serif;font-size:16px;font-weight:700;letter-spacing:-0.01em;}
.route-other-grid span{font-size:12px;color:#6B6E7B;}
@media (max-width:1100px){.route-other-grid{grid-template-columns:repeat(2,1fr);}}

/* ============================================
   ABOUT page
   ============================================ */
.about-story{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:start;background:#fff;border:1px solid #EFE9DC;border-radius:24px;padding:40px;box-shadow:0 24px 60px -40px rgba(15,27,51,0.18);}
.about-story .story-photo{aspect-ratio:4/5;border-radius:18px;overflow:hidden;position:relative;}
.about-story .story-photo image-slot{position:absolute;inset:0;width:100%;height:100%;}
.about-story .story-body h2{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(36px,4vw,52px);font-weight:700;letter-spacing:-0.025em;line-height:1;}
.about-story .story-body p{font-size:16px;line-height:1.7;color:#3A3D4A;margin:0 0 16px;}
@media (max-width:900px){.about-story{grid-template-columns:1fr;}}

.about-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:24px;background:#0F1B33;color:#fff;padding:48px 40px;border-radius:24px;}
.about-stats .stat{display:flex;flex-direction:column;gap:6px;}
.about-stats .stat strong{font-family:'Bricolage Grotesque',sans-serif;font-size:44px;font-weight:700;letter-spacing:-0.025em;line-height:1;}
.about-stats .stat span{font-size:12px;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.08em;}
@media (max-width:900px){.about-stats{grid-template-columns:repeat(2,1fr);}}

.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.team-grid .member{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:28px;text-align:left;}
.team-grid .photo{width:120px;height:120px;border-radius:50%;overflow:hidden;position:relative;margin-bottom:18px;}
.team-grid .photo image-slot{position:absolute;inset:0;width:100%;height:100%;}
.team-grid h4{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:700;margin:0 0 4px;letter-spacing:-0.01em;}
.team-grid .role{font-size:12px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#C9A663;display:block;margin-bottom:12px;}
.team-grid p{font-size:14px;line-height:1.55;color:#3A3D4A;margin:0;}
@media (max-width:900px){.team-grid{grid-template-columns:1fr 1fr;}}

.maintenance-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.maintenance-timeline .m-item{background:#fff;border:1px solid #EFE9DC;border-radius:14px;padding:24px;border-left:3px solid #C9A663;}
.maintenance-timeline .month{display:inline-block;font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#C9A663;margin-bottom:10px;}
.maintenance-timeline strong{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;margin-bottom:6px;}
.maintenance-timeline p{font-size:14px;line-height:1.55;color:#3A3D4A;margin:0;}
@media (max-width:900px){.maintenance-timeline{grid-template-columns:1fr;}}

.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.cert-grid .cert{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:24px;display:flex;flex-direction:column;gap:8px;}
.cert-grid .ic{width:44px;height:44px;border-radius:12px;background:#F6F1E6;color:#253D6F;display:inline-flex;align-items:center;justify-content:center;margin-bottom:8px;}
.cert-grid .ic svg{width:24px;height:24px;}
.cert-grid h4{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;margin:0;}
.cert-grid p{font-size:14px;line-height:1.55;color:#3A3D4A;margin:0;}
@media (max-width:900px){.cert-grid{grid-template-columns:1fr;}}

/* ============================================
   CONTACT page
   ============================================ */
.contact-channels{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.contact-channels .channel{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:28px;text-decoration:none;color:#0F1B33;display:flex;flex-direction:column;gap:6px;transition:all 0.18s;align-items:flex-start;}
.contact-channels .channel:hover{transform:translateY(-3px);box-shadow:0 16px 32px -20px rgba(15,27,51,0.18);}
.contact-channels .ic{width:48px;height:48px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;margin-bottom:8px;}
.contact-channels .ic svg{width:22px;height:22px;}
.contact-channels strong{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;}
.contact-channels .num{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:600;color:#253D6F;}
.contact-channels .meta{font-size:13px;color:#6B6E7B;}
.contact-channels .reply{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#1F8A5B;margin-top:6px;}
@media (max-width:900px){.contact-channels{grid-template-columns:repeat(2,1fr);}}
@media (max-width:760px){
  .contact-channels{grid-template-columns:repeat(2,1fr) !important; gap: 12px !important;}
  .contact-channels .channel{padding: 18px 14px !important; min-width: 0 !important; gap: 4px !important;}
  .contact-channels .channel > *{min-width: 0 !important; max-width: 100% !important;}
  .contact-channels .ic{margin-bottom: 6px !important;}
  .contact-channels .ic svg{width: 32px !important; height: 32px !important;}
  .contact-channels strong{font-size: 16px !important;}
  .contact-channels .num{font-size: 14px !important; word-break: break-word; overflow-wrap: anywhere;}
  .contact-channels .meta{font-size: 11px !important; line-height: 1.35 !important;}
  .contact-channels .reply{font-size: 10px !important; margin-top: 4px !important;}
}

.contact-form-wrap{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;}
.form-side{background:#fff;border:1px solid #EFE9DC;border-radius:24px;padding:40px;}
.form-side h2{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(36px,4vw,52px);font-weight:700;letter-spacing:-0.025em;line-height:1;}
.form-side h2 .italic-accent{font-style:italic;font-weight:500;color:#4A6395;}
.contact-form{display:flex;flex-direction:column;gap:14px;}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.contact-form .row.checks{grid-template-columns:1fr;gap:8px;}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#6B6E7B;}
.contact-form .chk{flex-direction:row;align-items:center;gap:10px;text-transform:none;letter-spacing:0;font-size:14px;font-weight:500;color:#3A3D4A;}
.contact-form input,.contact-form select,.contact-form textarea{font-family:'Manrope',sans-serif;background:#FBF8F2;border:1px solid #EFE9DC;border-radius:10px;padding:12px 14px;font-size:15px;color:#0F1B33;font-weight:500;letter-spacing:0;text-transform:none;}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:#253D6F;background:#fff;}
.contact-form textarea{resize:vertical;}
.contact-form button{margin-top:8px;align-self:flex-start;}

.form-aside{display:flex;flex-direction:column;gap:18px;}
.aside-card{background:#FBF8EF;border:1px solid #EFE9DC;border-radius:18px;padding:24px;}
.aside-card.cta{background:#0F1B33;color:#fff;border-color:#0F1B33;}
.aside-card.cta h4{color:#fff;}
.aside-card.cta p{color:rgba(255,255,255,0.8);}
.aside-card h4{font-family:'Bricolage Grotesque',sans-serif;font-size:16px;font-weight:700;margin:0 0 12px;letter-spacing:0.04em;text-transform:uppercase;}
.aside-card ul,.aside-card ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:14px;}
.aside-card ul li{display:flex;justify-content:space-between;color:#3A3D4A;}
.aside-card ul li strong{color:#0F1B33;}
.aside-card ol{counter-reset:s;padding-left:0;}
.aside-card ol li{counter-increment:s;padding-left:28px;position:relative;color:#3A3D4A;line-height:1.5;}
.aside-card ol li::before{content:counter(s);position:absolute;left:0;top:0;width:20px;height:20px;border-radius:50%;background:#C9A663;color:#0F1B33;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.aside-card p{font-size:14px;line-height:1.55;margin:0 0 14px;}

.visit-block{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start;background:#fff;border:1px solid #EFE9DC;border-radius:24px;overflow:hidden;}
.visit-map{aspect-ratio:8/5;background:#EAEEF3;}
.visit-info{padding:40px;}
.visit-info h3{font-family:'Bricolage Grotesque',sans-serif;font-size:32px;font-weight:700;letter-spacing:-0.02em;margin:0 0 6px;}
.visit-row{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px dashed #EFE9DC;}
.visit-row:last-of-type{border:none;}
.visit-row svg{width:20px;height:20px;color:#C9A663;flex-shrink:0;margin-top:2px;}
.visit-row strong{display:block;font-family:'Bricolage Grotesque',sans-serif;font-size:14px;font-weight:700;color:#0F1B33;margin-bottom:2px;}
.visit-row span{font-size:13px;line-height:1.5;color:#6B6E7B;}
@media (max-width:900px){.visit-block{grid-template-columns:1fr;}}

.booking-steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(5,1fr);gap:18px;counter-reset:bs;}
.booking-steps li{background:#fff;border:1px solid #EFE9DC;border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:10px;}
.booking-steps .num{font-family:'Bricolage Grotesque',sans-serif;width:36px;height:36px;border-radius:50%;background:#0F1B33;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;}
.booking-steps strong{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;letter-spacing:-0.01em;display:block;margin-bottom:4px;}
.booking-steps p{font-size:13px;line-height:1.5;color:#6B6E7B;margin:0;}
@media (max-width:900px){.booking-steps{grid-template-columns:1fr 1fr;}}

/* btn outline light */
.btn-outline-light{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.4);padding:14px 24px;border-radius:999px;font-family:'Bricolage Grotesque',sans-serif;font-weight:600;font-size:15px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all 0.18s;}
.btn-outline-light:hover{background:rgba(255,255,255,0.1);border-color:#fff;}


/* ============================================
   v2 patches — single-line ribbon, colored trust, payment icons
   uniform page hero, breadcrumb under header, services arrow fix, etc.
   ============================================ */

/* Single-line ribbon (no wrap) */
.kek-ribbon{background:#0B1428;color:rgba(255,255,255,0.85);font-size:13px;border-bottom:1px solid rgba(255,255,255,0.06);}
.kek-ribbon-inner{max-width:1320px;margin:0 auto;padding:9px 64px;display:flex;align-items:center;gap:24px;flex-wrap:nowrap;overflow:hidden;}
.kek-ribbon .marquee{flex:1;display:flex;gap:18px;align-items:center;flex-wrap:nowrap;overflow:hidden;white-space:nowrap;}
.kek-ribbon .marquee span{display:inline-flex;gap:7px;align-items:center;flex-shrink:0;}
.kek-ribbon .marquee svg{width:13px;height:13px;color:#C9A663;flex-shrink:0;}
.kek-ribbon .marquee .dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,0.3);}
.kek-ribbon .links{display:flex;gap:14px;align-items:center;flex-shrink:0;}
.kek-ribbon .links a{color:rgba(255,255,255,0.85);text-decoration:none;display:inline-flex;gap:6px;align-items:center;}
.kek-ribbon .links svg{width:13px;height:13px;}
.kek-ribbon .lang{display:flex;gap:4px;}
.kek-ribbon .lang a{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;color:rgba(255,255,255,0.6);}
.kek-ribbon .lang a.active{background:rgba(255,255,255,0.15);color:#fff;}
@media (max-width:1100px){.kek-ribbon .marquee span:nth-child(n+5){display:none;}}
@media (max-width:780px){.kek-ribbon-inner{padding:9px 24px;font-size:12px;gap:14px;}.kek-ribbon .links a span,.kek-ribbon .marquee span:nth-child(n+3){display:none;}}

/* Footer trust badges: colored variants */
.foot-mini-trust{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.foot-mini-trust span{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;color:rgba(255,255,255,0.9);}
.foot-mini-trust svg{width:14px;height:14px;flex-shrink:0;}
.foot-mini-trust .trust-uniqa{color:#0066B3;background:#fff;border-color:#fff;}
.foot-mini-trust .trust-uniqa svg{color:#0066B3;}
.foot-mini-trust .trust-nausys{color:#1FAA5F;background:#E7F8EA;border-color:#1FAA5F;}
.foot-mini-trust .trust-google{color:#0F1B33;background:#fff;border-color:#fff;}
.foot-mini-trust .trust-google svg{width:16px;height:16px;}

/* Footer contact: icons stacked above text per item */
.foot-contact-col .contact-line{display:flex;flex-direction:column;gap:14px;margin-bottom:18px;}
.foot-contact-col .cl-item{display:flex;gap:10px;align-items:flex-start;color:rgba(255,255,255,0.78);font-size:14px;line-height:1.5;}
.foot-contact-col .cl-item svg{width:18px;height:18px;color:#C9A663;flex-shrink:0;margin-top:2px;}
.foot-contact-col .cl-item a{color:rgba(255,255,255,0.85);text-decoration:none;}

/* Payment icons row */
.foot-bottom .pay-icons{display:flex;gap:8px;align-items:center;}
.foot-bottom .pay-icons span{padding:0;border:none;background:transparent;height:24px;display:inline-flex;align-items:center;}
.foot-bottom .pay-icons svg{height:24px;width:auto;display:block;border-radius:4px;}

/* ---- Uniform page header (smaller font, consistent height) ---- */
.page-hero{min-height:380px;}
.page-hero-content{padding:60px 64px 80px;}
.page-hero-content h1{font-size:clamp(40px,5vw,68px);max-width:18ch;margin-bottom:20px;}
.page-hero-content p{font-size:17px;max-width:62ch;}
.page-hero-content .kicker{margin-bottom:18px;}

/* Breadcrumbs bar (under header) */
.breadcrumbs{background:#fff;border-bottom:1px solid #EFE9DC;padding:14px 0;}
.breadcrumbs .container{font-size:13px;color:#6B6E7B;}
.breadcrumbs a{color:#6B6E7B;text-decoration:none;}
.breadcrumbs a:hover{color:#0F1B33;}
.breadcrumbs .sep{margin:0 8px;color:#C9A663;}
.breadcrumbs .here{color:#0F1B33;font-weight:600;}

/* ---- Yacht standard equipment: bigger icons, no border/bg ---- */
.equip-cat-body .row{padding:10px 0;}
.equip-cat-body .row svg{width:22px;height:22px;color:#1F8A5B;}
/* Make whole equip lists feel less "box-y" — categories without separating borders */
.equip-cat{box-shadow:none;}
.equip-cat-head{background:transparent;}

/* ---- Services extras: bigger icons, OPTIONAL badge inline next to name (not above) ---- */
.extras-row{grid-template-columns:60px 1fr auto;gap:18px;padding:18px 24px;}
.extras-row .ic{width:52px;height:52px;background:transparent;color:#253D6F;border-radius:0;}
.extras-row .ic svg{width:30px;height:30px;}
.extras-row .label{display:flex;flex-direction:column;gap:4px;}
.extras-row .label .name-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.extras-row .label .name{font-size:16px;}
.extras-row .label .req,.extras-row .label .opt{margin:0;font-size:10px;padding:3px 8px;}
.extras-row .label .det{margin-top:2px;}

/* ---- Contact channel icons: keep colored backgrounds, larger size ---- */
.contact-channels .channel{padding:32px;}
.contact-channels .ic{width:56px;height:56px;border-radius:16px;margin-bottom:14px;}
.contact-channels .ic svg{width:26px;height:26px;}
.contact-channels strong{font-size:20px;margin-top:4px;}

/* ---- Booking steps: more visual, no icon backgrounds ---- */
.booking-steps{grid-template-columns:repeat(5,1fr);gap:0;background:#fff;border:1px solid #EFE9DC;border-radius:18px;overflow:hidden;}
.booking-steps li{background:#fff;border:none;border-right:1px solid #EFE9DC;border-radius:0;padding:32px 24px;position:relative;}
.booking-steps li:last-child{border-right:none;}
.booking-steps .num{background:transparent;color:#C9A663;width:auto;height:auto;font-size:64px;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;line-height:0.9;letter-spacing:-0.04em;}
.booking-steps strong{margin-top:8px;font-size:20px;}
.booking-steps p{font-size:14px;}
.booking-steps li::after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:16px;height:16px;background:#fff;border-top:1px solid #EFE9DC;border-right:1px solid #EFE9DC;transform:translateY(-50%) rotate(45deg);z-index:2;}
.booking-steps li:last-child::after{display:none;}
@media (max-width:900px){.booking-steps{grid-template-columns:1fr;}.booking-steps li{border-right:none;border-bottom:1px solid #EFE9DC;}.booking-steps li::after{display:none;}}

/* Visit block: nicer */
.visit-block{box-shadow:0 24px 60px -40px rgba(15,27,51,0.18);}
.visit-info .visit-row svg{color:#253D6F;}

/* ---- Routes detail page: page hero match ---- */
/* We'll use page-hero now on routes.html */


/* ============================================
   v3 — taller headers, left-aligned content,
   mobile menu, booking-steps redesign, mobile fixes
   ============================================ */

/* Ribbon: push content to left, full-bleed (no centered max-width) */
.kek-ribbon-inner{max-width:none;padding:11px 36px;gap:24px;}
.kek-ribbon .marquee{flex:0 1 auto;}
.kek-ribbon .links{margin-left:auto;}

/* Page hero — taller, content left-aligned */
.page-hero{min-height:520px;}
.page-hero-content{max-width:none;padding:80px 36px 100px;display:flex;flex-direction:column;justify-content:center;flex:1;}
.page-hero-content > *{max-width:1280px;width:100%;}
.page-hero-content h1{font-size:clamp(48px,5.6vw,84px);max-width:18ch;margin-bottom:22px;}
.page-hero-content p{font-size:18px;max-width:62ch;}

/* Page-hero header alignment matches body */
.page-hero .site-header .nav{padding:0 36px;}

/* Breadcrumbs container alignment (under header) */
.breadcrumbs .container{padding-inline:36px;}

/* ============== Mobile menu (drawer) ============== */
.mobile-drawer{position:fixed;inset:0;background:rgba(15,27,51,0.6);z-index:120;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;}
.mobile-drawer.open{opacity:1;visibility:visible;}
.mobile-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(380px,90vw);background:#0F1B33;color:#fff;padding:24px 28px;display:flex;flex-direction:column;gap:14px;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto;}
.mobile-drawer.open .mobile-drawer-panel{transform:translateX(0);}
.mobile-drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.mobile-drawer-head .brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;text-decoration:none;}
.mobile-drawer-head .brand img{height:32px;}
.mobile-drawer-head .brand em{font-style:italic;font-weight:400;opacity:0.85;}
.mobile-drawer-close{appearance:none;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.16);width:40px;height:40px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.mobile-drawer-nav{display:flex;flex-direction:column;gap:2px;margin-top:8px;}
.mobile-drawer-nav a{padding:14px 0;color:rgba(255,255,255,0.92);text-decoration:none;font-size:18px;font-weight:600;font-family:'Bricolage Grotesque',sans-serif;letter-spacing:-0.01em;border-bottom:1px solid rgba(255,255,255,0.08);display:flex;justify-content:space-between;align-items:center;}
.mobile-drawer-nav a svg{opacity:0.5;transition:opacity .2s,transform .2s;}
.mobile-drawer-nav a:hover{color:#fff;}
.mobile-drawer-nav a:hover svg{opacity:1;transform:translateX(4px);}
.mobile-drawer-cta{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:20px;}
.mobile-drawer-cta .btn{justify-content:center;height:52px;}
.mobile-drawer-cta .wa{display:flex;align-items:center;justify-content:center;gap:10px;background:#1FAA5F;color:#fff;height:52px;border-radius:999px;font-family:'Manrope',sans-serif;font-weight:700;font-size:15px;letter-spacing:0.02em;text-decoration:none;}
.mobile-drawer-meta{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.5;border-top:1px solid rgba(255,255,255,0.08);padding-top:16px;margin-top:8px;}
.mobile-drawer-meta a{color:rgba(255,255,255,0.85);text-decoration:none;display:block;margin-top:4px;}

/* hamburger always visible on mobile */
@media (max-width:900px){
  .site-header .hamburger{display:inline-flex !important;}
  .site-header .nav-links{display:none !important;}
  .nav-actions .btn-book{padding:0 16px;height:42px;font-size:12px;}
  .nav-actions .btn-book .arrow{display:none;}
  .nav-actions{gap:8px;}
}

/* ============== Booking steps — redesigned numbers ============== */
.booking-steps{grid-template-columns:repeat(5,1fr);gap:18px;background:transparent;border:none;border-radius:0;}
.booking-steps li{background:#fff;border:1px solid #EFE9DC;border-radius:18px;padding:28px 24px;display:flex;flex-direction:column;gap:12px;border-right:1px solid #EFE9DC;position:relative;overflow:hidden;}
.booking-steps li::after{display:none;}
.booking-steps .num-row{display:flex;align-items:center;gap:14px;}
.booking-steps .num{width:44px;height:44px;border-radius:50%;background:#0F1B33;color:#C9A663;display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700;line-height:1;letter-spacing:0;flex-shrink:0;}
.booking-steps .num-line{flex:1;height:1px;background:#EFE9DC;}
.booking-steps strong{margin-top:0;font-size:19px;}
.booking-steps p{font-size:13.5px;line-height:1.55;color:#6B6E7B;margin:0;}
@media (max-width:900px){.booking-steps{grid-template-columns:1fr;gap:12px;}.booking-steps li{border-right:1px solid #EFE9DC;}}

/* ============== Routes "Why this base" heading left ============== */
.why-pirovac-section .container > h2,
.why-pirovac-section .container > .kicker{text-align:left;}

/* ============== Mobile breakpoint cleanups ============== */
@media (max-width:900px){
  .page-hero-content{padding:48px 24px 64px;}
  .page-hero{min-height:380px;}
  .page-hero-content h1{font-size:clamp(36px,8vw,48px);max-width:none;}
  .page-hero-content p{font-size:15px;}
  .kek-ribbon-inner{padding:9px 18px;font-size:11px;gap:10px;}
  .kek-ribbon .links{gap:8px;}
  .kek-ribbon .links a span:not(.lang-text){display:none;}
  .site-header .nav{padding:0 18px !important;height:72px !important;}
  .brand-word{font-size:18px !important;}
  .brand img,.brand-mark{height:36px !important;}
  .container{padding-inline:18px;}
  .breadcrumbs .container{padding-inline:18px;}
  /* Sticky filter bar */
  .filter-bar{padding:12px 0;}
  .filter-inner{flex-wrap:nowrap;overflow-x:auto;gap:10px;padding-bottom:4px;}
  .filter-group{flex-shrink:0;}
  .filter-spacer,.filter-results,.filter-sort,.filter-reset{display:none;}
  /* Section padding */
  .section{padding:56px 0 !important;}
  /* Forms / hero CTAs */
  .hero-cta{flex-direction:column;align-items:flex-start;}
  .btn-on-image{height:52px;padding:0 22px;font-size:13px;}
  /* Footer */
  .kek-footer-inner,.foot-grid,.kek-footer-top{padding-inline:18px !important;}
  .foot-newsletter{grid-template-columns:1fr !important;gap:24px !important;}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:14px;}
  /* Yacht detail */
  .yacht-titlebar h1{font-size:36px !important;}
  .yacht-layout{padding:32px 0 !important;gap:32px !important;}
  .at-a-glance{grid-template-columns:repeat(2,1fr) !important;gap:20px !important;}
  .yacht-tabs{padding:0 18px;margin:0 -18px 24px;}
  .equip-grid{grid-template-columns:1fr 1fr !important;}
  .price-table th,.price-table td{padding:12px 14px;font-size:13px;}
  .skipper-card{grid-template-columns:1fr;gap:18px;padding:24px;}
  /* Yacht hero gallery */
  .yacht-hero{height:48vh;min-height:340px;}
  .yacht-hero-gallery{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;}
  .yacht-hero-gallery .yh-slot:nth-child(1){grid-row:1/2;grid-column:1/3;}
  .yacht-hero-gallery .yh-slot:nth-child(5){display:none;}
  /* Routes/services */
  .pricing-mental,.svc-hero-row,.routes-detail,.map-block,.about-stats,.team-grid,
  .why-home-grid,.cert-grid,.maintenance-timeline,.values-grid,
  .highlights-grid,.route-yacht-grid,.route-other-grid{grid-template-columns:1fr !important;gap:18px !important;}
  .extras-tabs{grid-template-columns:1fr 1fr;}
  .extras-grid{grid-template-columns:1fr !important;}
  .included-grid{grid-template-columns:1fr 1fr !important;padding:24px !important;}
  .map-block,.svc-hero-row{padding:24px !important;}
  .svc-hero-row.flip .lhs{order:0;}
  /* Contact */
  .contact-form-wrap,.visit-block,.about-story{grid-template-columns:1fr !important;}
  .form-side,.contact-form{padding:24px !important;}
  .contact-form .row{grid-template-columns:1fr !important;}
  /* Route detail */
  .route-stats-inner{grid-template-columns:1fr 1fr !important;padding:24px 18px !important;gap:18px !important;}
  .route-layout{padding:48px 0 !important;}
  .route-map-block{padding:18px !important;}
  /* Home hero */
  .header-utility{display:none !important;}
  .hero-frame{height:auto;min-height:560px;border-radius:0 0 24px 24px;}
  .hero-content{position:relative;padding:80px 24px 100px;}
  .hero-content-inner{margin:0;}
  .hero h1{font-size:clamp(40px,9vw,64px) !important;}
  .hero-stamp{display:none;}
  .search-card{grid-template-columns:1fr;border-radius:18px;padding:14px;}
  .search-card .field{border-right:none;border-bottom:1px solid #EFE9DC;padding:12px 0;}
  .search-card .field:last-of-type{border-bottom:none;}
  .search-card .btn-primary{width:100%;justify-content:center;height:52px;margin-top:8px;}
  .fleet-grid,.routes-grid,.steps,.offers-grid,.destinations,.blog-grid,.ig-grid,.why-grid,.reviews-grid,.team-row{grid-template-columns:1fr !important;gap:18px !important;}
  .ig-grid{grid-template-columns:1fr 1fr !important;}
  .blog-featured{grid-template-columns:1fr !important;}
  .blog-featured .body{padding:24px !important;}
  .section-head{grid-template-columns:1fr !important;gap:16px !important;margin-bottom:32px !important;}
  .section-head-left{grid-template-columns:1fr !important;gap:16px !important;}
  /* Booking steps */
  .booking-steps{grid-template-columns:1fr !important;}
  /* Trust ribbon: simpler */
  .trust-ribbon-visual .trust-ribbon-inner{grid-template-columns:1fr 1fr !important;gap:18px !important;}
  .trust-ribbon-visual .divider{display:none !important;}
}

@media (max-width:480px){
  .nav-actions .btn-book{display:none;}
  .booking-widget .field-row{grid-template-columns:1fr;}
  .yacht-hero-gallery{grid-template-columns:1fr;grid-template-rows:1fr;}
  .yacht-hero-gallery .yh-slot:nth-child(n+2){display:none;}
}

/* ============ Push search bar lower (closer to fleet) on home ============ */
.search-row{padding-top:64px;margin-top:84px;}

/* Hide breadcrumbs that appear ABOVE site-header (on yacht page) */
.breadcrumbs.before-hero{display:none;}

/* ============================================
   v4 — rounded headers, unified edges, taller,
   contact icons clean, illustrations
   ============================================ */

/* Round the page-hero like the homepage hero-frame */
.page-hero{
  border-radius: 0 0 28px 28px;
  overflow: hidden;
  margin: 0 18px;
  width: auto;
  min-height: 600px;
}
.page-hero .site-header .nav{padding: 0 28px;}
.page-hero-content{padding: 100px 36px 110px;}
.page-hero-content h1{font-size:clamp(56px,6.4vw,96px);}

/* Unified edge gaps across pages — match homepage container (36px / 18px on mobile) */
.kek-ribbon-inner{padding: 11px 28px;}
.breadcrumbs .container{padding-inline: 36px;}
.site-foot .container{padding-inline: 36px;}

/* Taller header on mobile too */
@media (max-width:900px){
  .page-hero{margin: 0 10px; border-radius: 0 0 22px 22px; min-height: 480px;}
  .page-hero-content{padding: 56px 22px 72px;}
  .kek-ribbon-inner{padding: 9px 18px;}
  .site-header .nav{padding: 0 18px !important; height: 80px !important;}
}

/* ===== Contact channels — icons bigger, no bg, no color overrides ===== */
.contact-channels .ic{
  background: transparent !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  margin-bottom: 16px !important;
  color: #0F1B33 !important;
}
.contact-channels .ic svg{width:44px !important; height:44px !important;}
.contact-channels .channel{padding: 32px;}

/* ===== Booking process cards — more visual ===== */
.booking-steps li{
  padding: 28px 22px 26px;
  position: relative;
}
.booking-steps li::before{
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 4px;
  background: linear-gradient(90deg, #C9A663, transparent);
  border-radius: 0 0 18px 18px;
}
.booking-steps .num-row{display:flex;align-items:center;gap:14px;margin-bottom:6px;}
.booking-steps .num-icon{
  width:48px;height:48px;border-radius:14px;background:#F6F1E6;
  color:#0F1B33;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.booking-steps .num-icon svg{width:24px;height:24px;}
.booking-steps .num{
  width:30px;height:30px;border-radius:50%;background:#0F1B33;color:#C9A663;
  display:flex;align-items:center;justify-content:center;
  font-family:'Bricolage Grotesque',sans-serif;font-size:14px;font-weight:700;
  margin-left:auto;
}

/* ===== About: stats in hero ===== */
.page-hero .about-stats-inline{
  display:grid;grid-template-columns:repeat(5,1fr);gap:36px;
  margin-top:48px;padding-top:36px;
  border-top:1px solid rgba(255,255,255,0.16);
  max-width: 1280px;
}
.page-hero .about-stats-inline .stat{display:flex;flex-direction:column;gap:6px;}
.page-hero .about-stats-inline strong{
  font-family:'Bricolage Grotesque',sans-serif;font-size:48px;font-weight:700;
  color:#fff;letter-spacing:-0.02em;line-height:1;
}
.page-hero .about-stats-inline span{
  font-family:'Manrope',sans-serif;font-size:11px;font-weight:600;
  color:rgba(255,255,255,0.65);letter-spacing:0.12em;text-transform:uppercase;
}
@media (max-width:900px){
  .page-hero .about-stats-inline{grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px;padding-top:24px;}
  .page-hero .about-stats-inline strong{font-size:32px;}
}

/* ===== Routes: left-align "Six routes" heading ===== */
.section-head.section-head-left,
.section-head.section-head-left h2,
.section-head.section-head-left .kicker,
.section-head.section-head-left p{text-align:left !important;}
.section-head.section-head-left{display:block;}

/* ===== Footer illustrations ===== */
.kek-foot-v2{position:relative;overflow:hidden;}
.kek-foot-v2::before{
  content:'';position:absolute;left:-80px;bottom:-60px;width:520px;height:380px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 520 380"><g fill="none" stroke="%23C9A663" stroke-width="1.4" opacity="0.12"><path d="M40 320 Q 100 280, 180 300 T 320 300 T 480 280"/><path d="M40 340 Q 120 305, 200 320 T 360 315 T 480 305"/><path d="M260 280 L 250 130 L 350 250 Z"/><path d="M260 280 L 270 160 L 200 250 Z"/><circle cx="420" cy="80" r="32"/><path d="M70 230 L 60 130 L 130 220 Z"/><path d="M70 230 L 78 150 L 35 215 Z"/><circle cx="100" cy="60" r="2"/><circle cx="180" cy="40" r="2"/><circle cx="280" cy="50" r="2"/><circle cx="370" cy="30" r="2"/><circle cx="460" cy="60" r="2"/></g></svg>');
  background-repeat: no-repeat; pointer-events: none;
}
.kek-foot-v2 .container{position:relative;z-index:1;}

/* Subtle compass illustration on page-hero — bottom right */
.page-hero::after{
  content:'';position:absolute;right:32px;bottom:24px;width:140px;height:140px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 140 140"><g fill="none" stroke="%23C9A663" stroke-width="1.2" opacity="0.32"><circle cx="70" cy="70" r="56"/><circle cx="70" cy="70" r="44"/><path d="M70 14 L70 126 M14 70 L126 70" /><path d="M70 30 L78 70 L70 110 L62 70 Z" fill="%23C9A663" opacity="0.5"/></g><text x="70" y="22" text-anchor="middle" fill="%23C9A663" opacity="0.5" font-family="serif" font-size="11">N</text></svg>');
  background-repeat:no-repeat;background-size:contain;pointer-events:none;
  z-index:1;
}
.page-hero-content{position:relative;z-index:2;}
@media (max-width:900px){.page-hero::after{display:none;}}

/* ============================================
   v6 — page-hero matches homepage container,
   edge-to-edge mobile w/ rounded bottoms,
   fleet-help + skipper-card mobile redesign
   ============================================ */

/* Page-hero wraps to homepage container width, with same gutter + radius */
.page-hero{
  margin: 0 auto !important;
  width: auto !important;
  padding: 0 var(--gutter, 32px);
  background: transparent;
  min-height: auto;
  border-radius: 0;
  overflow: visible;
}
.page-hero > .page-hero-bg,
.page-hero > .site-header,
.page-hero > .page-hero-content,
.page-hero > .about-stats-inline{position: relative;}
.page-hero{
  display: grid;
}
/* Inner frame technique: wrap the navy section so radii apply */
.page-hero{position: relative;}
.page-hero .page-hero-bg{
  border-radius: 0 0 36px 36px;
  inset: 0 var(--gutter, 32px);
  position: absolute;
}
/* Constrain everything to container width */
.page-hero .site-header > .nav,
.page-hero .page-hero-content{
  max-width: var(--container, 1560px);
  margin-inline: auto;
  width: 100%;
}
.page-hero .page-hero-content{padding: 100px 32px 110px;}
.page-hero::after{
  /* compass relocated to fit inside the rounded frame */
  right: calc(var(--gutter, 32px) + 24px);
}

/* Round the page-hero ENTIRELY by using a wrapper effect via overflow on inner */
.page-hero{
  overflow: visible;
}
/* Make the content area itself the rounded frame */
.page-hero{
  background: transparent;
}
.page-hero::before{
  content: '';
  position: absolute;
  inset: 0 var(--gutter, 32px);
  background: linear-gradient(160deg,#0F1B33 0%,#253D6F 50%,#1A2C54 100%);
  border-radius: 0 0 36px 36px;
  z-index: 0;
}
.page-hero > .page-hero-bg{display: none;}
.page-hero > .site-header,
.page-hero > .page-hero-content{position: relative; z-index: 2;}

/* Mobile: edge-to-edge with rounded bottom corners */
@media (max-width: 900px){
  .page-hero::before{inset: 0; border-radius: 0 0 22px 22px;}
  .page-hero::after{display: none;}
  .page-hero .page-hero-content{padding: 56px 22px 64px;}
  .page-hero .site-header > .nav{padding: 0 18px !important;}
}

/* ===== Fleet "Not sure which yacht" — clean stacked, no awkward wrap ===== */
.fleet-help{
  background:#F6F1E6;
  border-radius: 22px;
  padding: 56px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 48px;
}
.fleet-help .left{max-width: 32ch;}
.fleet-help h3{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size: clamp(28px, 3.4vw, 44px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 14px;
  color: #0F1B33;
}
.fleet-help p{font-size: 15px; line-height: 1.6; color:#3A3D4A; margin: 0; max-width: 38ch;}
.fleet-help .right{display: flex; flex-direction: column; gap: 12px; min-width: 220px;}

@media (max-width: 900px){
  .fleet-help{
    grid-template-columns: 1fr !important;
    padding: 32px 24px !important;
    gap: 24px !important;
  }
  .fleet-help .left{max-width: none;}
  .fleet-help h3{font-size: 30px; max-width: none;}
  .fleet-help p{max-width: none;}
  .fleet-help .right{min-width: 0; width: 100%;}
  .fleet-help .right .btn{justify-content: center; width: 100%;}
}

/* ===== Services skipper-card — same treatment ===== */
.skipper-card{
  background:#fff;
  border-radius: 22px;
  display: grid;
  align-items: center;
  gap: 48px;
}
.skipper-card > div:first-child{max-width: 56ch;}

@media (max-width: 900px){
  .skipper-card{
    grid-template-columns: 1fr !important;
    padding: 28px 22px !important;
    gap: 22px !important;
  }
  .skipper-card > div:first-child{max-width: none;}
  .skipper-card h3{font-size: 26px !important; line-height: 1.1;}
  .skipper-card p{font-size: 14px !important;}
  .skipper-card > div:last-child{width: 100%;}
  .skipper-card > div:last-child .btn{justify-content: center; width: 100%;}
}

/* Yacht page: stop cramping to screen edges (desktop + mobile) */
.yacht-titlebar .container,
.yacht-layout{padding-inline: 36px;}
.yacht-content,.yacht-aside{min-width:0;}

/* Route detail icons: bigger, no background */
.highlights-grid .item .ic,
.route-other-grid .item .ic,
.day-card .ic,
.route-yacht-grid .ic{
  background: transparent !important;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  color: #C9A663 !important;
  margin-bottom: 14px;
}
.highlights-grid .item .ic svg,
.route-other-grid .item .ic svg,
.day-card .ic svg,
.route-yacht-grid .ic svg{width: 40px !important; height: 40px !important;}

/* Why-pirovac items same treatment */
.why-pirovac .item .ic{
  background: transparent !important;
  color: #C9A663 !important;
}
.why-pirovac .item .ic svg{width: 44px !important; height: 44px !important;}

@media (max-width: 900px){
  /* Headers edge-to-edge on mobile WITH curved bottom corners */
  .page-hero{margin: 0 !important; border-radius: 0 0 32px 32px !important; overflow: hidden !important;}
  .hero-frame{border-radius: 0 0 32px 32px !important; margin: 0 !important;}
  .page-hero::before{inset: 0 !important; border-radius: 0 0 32px 32px !important;}
  .page-hero-content{padding: 48px 20px 60px !important;}
  .page-hero-content h1{font-size: clamp(34px, 8vw, 44px) !important; max-width: none !important;}
  .page-hero-content p{font-size: 14px !important;}

  /* Hamburger pushed flush right */
  .nav-actions{margin-left: auto !important;}
  .nav .hamburger{margin-left: 8px;}

  /* Buttons / CTAs left-aligned, full container width respected */
  .hero-cta{align-items: stretch !important; padding-left: 0;}
  .hero-cta .btn-on-image{align-self: flex-start; margin-left: 0;}
  .hero-watch{align-self: flex-start; margin-left: 0;}

  /* Yacht page padding on mobile */
  .yacht-titlebar .container,
  .yacht-layout{padding-inline: 18px !important;}
  .yacht-titlebar{padding: 24px 0 !important;}
  .yacht-content > *{max-width: 100%;}
  .yacht-content p, .yacht-content h2, .yacht-content h3{word-wrap: break-word;}

  /* Homepage check-in/checkout: shrink + tighten */
  .charter-essentials,
  .check-in-out,
  .yacht-essentials,
  [class*="essentials"]{padding: 22px !important;}
  .charter-essentials .item strong,
  .check-in-out strong,
  [class*="essentials"] strong{font-size: 22px !important;}
  .charter-essentials .item span,
  [class*="essentials"] span{font-size: 11px !important;}

  /* Set Sail / Reach us — stack, full width, no overflow */
  .set-sail,
  .ready-to-sail,
  .contact-cta,
  .reach-direct,
  [class*="set-sail"],
  [class*="reach"]{grid-template-columns: 1fr !important; padding: 28px 22px !important;}
  .set-sail > *, .reach-direct > *{min-width: 0 !important; max-width: 100% !important;}

  /* Final CTA (homepage Set Sail) — stack columns, contain channels */
  .final-cta{margin: 0 12px 60px !important;}
  .final-cta-inner{grid-template-columns: 1fr !important; padding: 44px 22px !important; gap: 36px !important;}
  .final-cta .left, .final-cta .right{min-width: 0 !important; max-width: 100% !important;}
  .final-cta .left h2{font-size: 34px !important; line-height: 1.08 !important; max-width: 100% !important; margin: 14px 0 16px !important;}
  .final-cta .sub{font-size: 15px !important; margin: 0 0 22px !important;}
  .final-cta .actions{flex-direction: column !important; align-items: stretch !important; gap: 10px !important;}
  .final-cta .actions .btn{width: 100% !important; justify-content: center !important;}
  .final-cta .channels{grid-template-columns: 1fr !important; gap: 10px !important;}
  .final-cta .help-channel{padding: 14px !important; gap: 12px !important; min-width: 0 !important;}
  .final-cta .help-channel > div{min-width: 0 !important; flex: 1 1 auto !important;}
  .final-cta .help-channel strong{font-size: 14px !important; word-break: break-all; overflow-wrap: anywhere;}
  .final-cta .help-channel .ic{width: 40px !important; height: 40px !important; flex: 0 0 40px !important;}
  .final-cta .help-channel .ic svg{width: 22px !important; height: 22px !important;}

  /* "Not sure which yacht" CTA card */
  .yacht-help,
  .not-sure,
  .fleet-help-cta,
  [class*="help-cta"],
  [class*="not-sure"]{grid-template-columns: 1fr !important; padding: 28px 22px !important; gap: 20px !important;}
  .yacht-help h2, .not-sure h2{font-size: 28px !important;}

  /* "Before you charter" — section padding + cards/row stack */
  .before-charter{padding: 64px 0 !important;}
  .before-charter .head{margin: 0 auto 32px !important;}
  .before-charter h2{font-size: 32px !important; line-height: 1.1 !important;}
  .before-charter .head p{font-size: 15px !important;}
  .bc-grid{grid-template-columns: 1fr !important; gap: 14px !important; margin-bottom: 24px !important;}
  .bc-card{padding: 22px !important;}
  .bc-card h3{font-size: 20px !important;}
  .bc-card p{font-size: 14px !important;}
  /* Check-in / out / deposit / support row → 2×2 grid, tighter */
  .bc-row{grid-template-columns: 1fr 1fr !important; gap: 18px 14px !important; padding: 22px !important; border-radius: 16px !important;}
  .bc-row .col{min-width: 0 !important;}
  .bc-row .lbl{font-size: 10px !important;}
  .bc-row strong{font-size: 18px !important; line-height: 1.15 !important;}
  .bc-row p{font-size: 12px !important; line-height: 1.4 !important;}

  /* Why this base — Pirovac vs cards */
  .why-pirovac{grid-template-columns: 1fr !important; gap: 14px !important;}
  .why-pirovac .item{padding: 22px !important;}
  .why-pirovac h4{font-size: 20px !important;}

  /* Services pricing / sample weeks */
  .pricing-mental,
  .sample-weeks,
  .price-cards,
  [class*="sample-week"],
  [class*="price-card"]{grid-template-columns: 1fr !important; gap: 16px !important; overflow: visible !important;}

  /* Footer: align all items to same left edge as the newsletter heading */
  .kek-foot-v2 .container{padding-inline: 22px !important;}
  .kek-foot-v2 .foot-grid{padding-inline: 0 !important;}
  .kek-foot-v2 .foot-brand,
  .kek-foot-v2 .foot-col,
  .kek-foot-v2 .foot-newsletter{padding-left: 0 !important; margin-left: 0 !important;}
  .kek-foot-v2 .foot-mini-trust{flex-wrap: wrap; gap: 8px;}
  .kek-foot-v2 .foot-mini-trust > span{font-size: 11px;}

  /* Section containers full-bleed friendly */
  .section .container{padding-inline: 18px;}
  .container{max-width: 100% !important;}

  /* Card grids that overflow */
  .booking-flow,
  .booking-process,
  [class*="booking-flow"]{grid-template-columns: 1fr !important; overflow: visible !important;}
  .booking-flow > *, .booking-process > *{width: 100% !important; min-width: 0 !important;}
}

/* Tiny wave divider above footer (on every page) */
.site-foot::before{
  content:'';display:block;height:48px;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 48" preserveAspectRatio="none"><path d="M0 24 Q 75 8 150 24 T 300 24 T 450 24 T 600 24 T 750 24 T 900 24 T 1050 24 T 1200 24" fill="none" stroke="%23C9A663" stroke-width="1.4" opacity="0.4"/><path d="M0 36 Q 75 20 150 36 T 300 36 T 450 36 T 600 36 T 750 36 T 900 36 T 1050 36 T 1200 36" fill="none" stroke="%23C9A663" stroke-width="1.2" opacity="0.25"/></svg>');
  background-size: 1200px 48px; background-repeat: repeat-x;
  width:100%;
}
