/* ===================================================================================
* Theme Name: Yacty Child
* Template: yacty
* Description: Golden Shipyard child — minimal overrides; theme look reverted to yacty default.
====================================================================================== */

/* ─── Top announcement bar (above the header) ─── */
.gsy-topbar {
    position: absolute;          /* overlay the hero/banner like the template's .header__top — no dark band */
    top: 0;
    left: 0;
    right: 0;
    z-index: 1003;
    background: transparent;
    color: rgba(255, 255, 255, 0.9);
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-size: 13.5px;
    line-height: 1.4;
}
.gsy-topbar__inner {
    max-width: 1630px;
    margin: 0 auto;
    padding: 9px 30px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}
.gsy-topbar__msg { margin: 0; }
.gsy-topbar__cta {
    color: #fff;
    font-weight: 600;
    margin-left: 10px;
    white-space: nowrap;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    padding-bottom: 1px;
    transition: color .2s, border-color .2s;
}
.gsy-topbar__cta:hover { color: #C9A24B; border-color: #C9A24B; }
.gsy-topbar__meta { display: flex; align-items: center; gap: 10px; white-space: nowrap; }
.gsy-topbar__meta a { color: rgba(255, 255, 255, 0.9); }
.gsy-topbar__meta a:hover { color: #fff; }
.gsy-topbar__sep { opacity: .5; }
@media (max-width: 991px) {
    .gsy-topbar__inner { padding: 8px 18px; }
    .gsy-topbar__msg { font-size: 12.5px; }
    .gsy-topbar__meta { display: none; }
}
@media (max-width: 767px) {
    .gsy-topbar { display: none; }
}
/* Built-in top bar (.header__top): hide the (empty) countdown widget — we only use the text line. */
.header-style .header__top .countdown { display: none !important; }
/* Keep the top bar on a single line (left text | right text) — the theme's ul_li_between wraps.
   Match the template's top bar: text line sits ~11px down, no thick bottom padding. */
.header-style .header__top { flex-wrap: nowrap !important; padding-top: 11px !important; padding-bottom: 0 !important; }
.header-style .header__top .xb-left-content,
.header-style .header__top .xb-right-content { flex-wrap: nowrap !important; white-space: nowrap !important; }
/* The full line is long; on narrower desktops drop the secondary email/hours so the main line
   still fits on ONE line (it shows again on wide screens). Below 992px the whole bar is hidden. */
@media (max-width: 1400px) {
    .header-style .header__top .xb-right-content { display: none !important; }
}
/* Hide the top bar on narrow screens for a clean mobile header (logo + hamburger only). */
@media (max-width: 991px) { .header-style .header__top { display: none !important; } }

/* The top bar (in normal flow) already pushes the page down, so the transparent header only needs
   its small original inset gap below the bar — keep it tight, not a big empty band. */
.header-style.header-transparent { top: 0 !important; }
@media (max-width: 767px) {
    .header-style.header-transparent { top: 11px !important; } /* top bar hidden on phones */
}
/* Logged-in only: the top bar + header now stack correctly with the admin bar present (the
   header's containing block follows the admin bar's html offset), so the old -26px pull is no
   longer needed and was tucking the nav UP under the top bar. Keep the admin view identical to
   the visitor view. */
body.admin-bar .header-style.header-transparent { top: 0 !important; }

/* ─── Header layout — match the template. The parent theme's .header__wrap rounded floating card
       (background #1a416c, border-radius 20px, 1px border, inset via .container.mxw-1630) is kept
       as-is. We only set the inner arrangement: logo at the left, menu grouped right after it with
       a clear gap (so the logo and first menu item don't overlap), and the actions (search box +
       menu toggle) pushed to the far right. ─── */
@media (min-width: 992px) {
    #xb-header-area .header__wrap {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;   /* logo · menu · actions — space-between centers the menu */
        flex-wrap: nowrap !important;
    }
    #xb-header-area .header__wrap .xb-header-logo { flex: 0 0 auto !important; margin: 0 !important; }
    /* the menu sits in the middle, centered between the logo and the right zone, at any width */
    #xb-header-area .header__wrap .main-menu__wrap { flex: 0 1 auto !important; margin: 0 !important; }
    #xb-header-area .header__wrap .header-right {
        flex: 0 0 auto !important;
        display: flex !important;
        align-items: center !important;
        gap: 14px !important;
    }
}
/* On narrow screens the rounded floating card (inset + top gap) reads as "not flush to the top".
   Make the mobile header a full-width flat bar pinned to the very top instead. Desktop keeps the
   rounded floating card. */
@media (max-width: 991px) {
    #xb-header-area.header-style.header-transparent { top: 0 !important; }
    #xb-header-area .container.mxw-1630 {
        max-width: 100% !important;
        padding-left: 14px !important;
        padding-right: 14px !important;
    }
    #xb-header-area .header__wrap {
        border-radius: 0 !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
    /* Solid navy across the whole header area (static + sticky) so no transparent seam can show the
       page content behind the bar on narrow screens. */
    #xb-header-area .xb-header,
    #xb-header-area .xb-header-area-sticky,
    #xb-header-area .xb-header-area-sticky .header__wrap { background: #1a416c !important; }
}

/* The top bar (in flow) + the transparent header section's own ~52px height left a white band
   between the bar and the page content on EVERY page. Pull the page content (the .elementor block
   right after the header template #1210) up so it sits under the top bar and the transparent
   header overlays it — removing the white gap site-wide. */
.yacty-main-wrap > .elementor-1210 + .elementor { margin-top: -52px; }

/* ─── Premium inner-page banner ───────────────────────────────────────────────
   Only inner pages carry the theme's .breadcrumb section (the front page does not),
   so this upgrades every page EXCEPT the home page. A darkened navy-duotone vessel-
   at-sea photo with a left-weighted navy gradient keeps the title/breadcrumb crisp
   while the ship reads softly on the right — a more high-end look than flat navy. */
.breadcrumb.bg_img {
    --gsy-banner: url(/wp-content/uploads/2026/06/gsy-banner-bg.jpg); /* default / fallback image */
    min-height: 660px !important;   /* large hero banner (trimmed slightly from the reference) */
    display: flex !important;
    align-items: center !important;
    padding-top: 70px !important;
    padding-bottom: 50px !important;
    background-image:
        linear-gradient(90deg, rgba(7,32,59,.85) 0%, rgba(7,32,59,.58) 40%, rgba(7,32,59,.24) 72%, rgba(7,32,59,.08) 100%),
        var(--gsy-banner) !important;
    background-size: cover, cover !important;
    background-position: center center, center center !important;
    background-repeat: no-repeat, no-repeat !important;
    background-color: #07203b !important;
}
.breadcrumb.bg_img > .container { width: 100% !important; }
/* Banner shows only the page name — hide the breadcrumb trail (Golden Shipyard > …). */
.breadcrumb .yacty_breadcrumb { display: none !important; }

/* Search results page: identical banner treatment to the other inner pages —
   strong left navy gradient over the default seascape, top-aligned, smaller
   uppercase title; the query + match count render as the tagline (hero JS). */
body.search .breadcrumb.search-banner.bg_img {
    position: relative;
    overflow: hidden;
    align-items: flex-start !important;
    padding-top: 185px !important;
    padding-bottom: 54px !important;
    min-height: 660px !important;
    background:
        linear-gradient(95deg, #06203b 0%, #06203b 22%, rgba(7,32,59,.82) 34%, rgba(7,32,59,.42) 48%, rgba(7,32,59,.12) 63%, rgba(7,32,59,0) 80%) center/cover no-repeat,
        linear-gradient(to top, rgba(6,32,59,.85) 0%, rgba(7,32,59,0) 10%) center/cover no-repeat,
        var(--gsy-banner) center right / cover no-repeat !important;
    background-color: #06203b !important;
}
body.search .breadcrumb__title {
    font-size: clamp(32px, 4vw, 52px) !important;
    line-height: 1.05 !important;
    text-transform: uppercase !important;
    max-width: 24ch !important;
}
body.search .breadcrumb__text { max-width: 40ch !important; }

/* Single-vessel banner (.yacht-banner) was pinned to a short ~280px by an older rule below, so it
   looked much smaller than the page banners. Force the same full height/padding as the rest. */
section.breadcrumb.yacht-banner.bg_img {
    min-height: 660px !important;
    align-items: flex-start !important;     /* top-align so padding clears the floating header */
    padding-top: 185px !important;          /* push content well below the floating nav so the breadcrumb clears it */
    padding-bottom: 54px !important;
}

/* ─── Vessels for Sale hero banner — rich style (ref mockup): a vessel-at-sea photo with a
       left-weighted navy gradient, big gold-accented title, feature row, gold CTA, ship's-wheel
       watermark. The feature row + CTA + divider are injected by JS (see functions.php). ─── */
body.page-id-1541 .breadcrumb.bg_img {
    --gsy-banner: url(/wp-content/uploads/2026/06/gsy-sea-hero.jpg);   /* used by the narrow @media block */
    position: relative;
    overflow: hidden;
    min-height: 700px !important;
    align-items: flex-start !important;          /* top-align so the tall content clears the header */
    padding-top: 185px !important;               /* below the floating header card, with breathing room */
    padding-bottom: 54px !important;
    /* VFS hero: a bright ship-at-sea photograph on the right that feathers smoothly into the navy on
       the left (a wide, gentle transition — not a hard photo edge) so the vessel sits in a real
       seascape while the title stays legible over the navy. */
    background:
        linear-gradient(95deg, #06203b 0%, #06203b 22%, rgba(7,32,59,.82) 34%, rgba(7,32,59,.42) 48%, rgba(7,32,59,.12) 63%, rgba(7,32,59,0) 80%) center/cover no-repeat,
        linear-gradient(to top, rgba(6,32,59,.85) 0%, rgba(7,32,59,0) 10%) center/cover no-repeat,
        url(/wp-content/uploads/2026/06/gsy-sea-hero.jpg) center right / cover no-repeat !important;
    background-color: #06203b !important;
}
/* faint ship's-wheel watermark (the Golden Shipyard mark), large, centre-right */
body.page-id-1541 .breadcrumb.bg_img::after {
    content: "";
    position: absolute;
    top: 50%; right: 9%;
    transform: translateY(-54%);
    width: 430px; height: 430px;
    background: url(/wp-content/uploads/2026/05/golden-shipyard-logo-transparent.png) no-repeat center / contain;
    filter: brightness(0) invert(1);
    opacity: .06;
    pointer-events: none;
}
body.page-id-1541 .breadcrumb__content { position: relative; z-index: 2; }
body.page-id-1541 .breadcrumb__title {
    font-size: clamp(34px, 4.2vw, 56px) !important;
    line-height: 1.02 !important;
    max-width: 16ch !important;
    text-transform: uppercase !important;
}
body.page-id-1541 .breadcrumb__text { max-width: 32ch !important; font-size: 17px !important; }

/* When the viewport gets narrow, give the banner the PHOTO's own 4:3 proportions so the WHOLE vessel
   is always visible and the banner is exactly the size of the image (no crop). Only the title is kept
   in the banner (over a navy scrim so it stays legible); the tagline, features and the in-banner CTA
   are hidden because they can't fit without overlapping the title. The CTA is moved to a strip JUST
   BELOW the banner (.gsy-cta-below, inserted by the hero JS) so it's never clipped or overlapping. */
/* Narrow: the SAME treatment as the VFS hero, applied to every main inner page (each via its own
   --gsy-banner 4:3 photo). The banner becomes the size of the photo so the whole ship always shows;
   a navy scrim across the top holds the title + gold divider + the gold CTA (button INSIDE the
   banner); the button is pinned to the lower-centre over the sea so it never covers the vessel.
   Tagline + features are hidden to keep it tidy (the tagline still shows just below the banner). */
@media (max-width: 1000px) {
    body.page-id-1541 .breadcrumb.bg_img,
    body.page-id-939  .breadcrumb.bg_img,
    body.page-id-919  .breadcrumb.bg_img,
    body.page-id-1549 .breadcrumb.bg_img,
    body.page-id-1078 .breadcrumb.bg_img,
    body.blog         .breadcrumb.bg_img {
        min-height: 0 !important;
        aspect-ratio: 2400 / 1800;
        padding-top: 84px !important;
        padding-bottom: 24px !important;
        background:
            linear-gradient(to bottom, #06203b 0%, #06203b 33%, rgba(7,32,59,.7) 48%, rgba(7,32,59,.25) 62%, rgba(7,32,59,0) 78%) center / cover no-repeat,
            var(--gsy-banner) center / cover no-repeat,
            #06203b !important;
    }
    body.page-id-1541 .breadcrumb.bg_img .gsy-hero-features, body.page-id-1541 .breadcrumb.bg_img .breadcrumb__text,
    body.page-id-939  .breadcrumb.bg_img .gsy-hero-features, body.page-id-939  .breadcrumb.bg_img .breadcrumb__text,
    body.page-id-919  .breadcrumb.bg_img .gsy-hero-features, body.page-id-919  .breadcrumb.bg_img .breadcrumb__text,
    body.page-id-1549 .breadcrumb.bg_img .gsy-hero-features, body.page-id-1549 .breadcrumb.bg_img .breadcrumb__text,
    body.page-id-1078 .breadcrumb.bg_img .gsy-hero-features, body.page-id-1078 .breadcrumb.bg_img .breadcrumb__text,
    body.blog         .breadcrumb.bg_img .gsy-hero-features, body.blog         .breadcrumb.bg_img .breadcrumb__text {
        display: none !important;
    }
    body.page-id-1541 .breadcrumb.bg_img .breadcrumb__content,
    body.page-id-939  .breadcrumb.bg_img .breadcrumb__content,
    body.page-id-919  .breadcrumb.bg_img .breadcrumb__content,
    body.page-id-1549 .breadcrumb.bg_img .breadcrumb__content,
    body.page-id-1078 .breadcrumb.bg_img .breadcrumb__content,
    body.blog         .breadcrumb.bg_img .breadcrumb__content { position: static !important; }
    body.page-id-1541 .breadcrumb.bg_img .gsy-hero-btn,
    body.page-id-939  .breadcrumb.bg_img .gsy-hero-btn,
    body.page-id-919  .breadcrumb.bg_img .gsy-hero-btn,
    body.page-id-1549 .breadcrumb.bg_img .gsy-hero-btn,
    body.page-id-1078 .breadcrumb.bg_img .gsy-hero-btn,
    body.blog         .breadcrumb.bg_img .gsy-hero-btn {
        display: inline-flex !important;
        position: absolute !important;
        left: 50% !important;
        bottom: 30px !important;
        transform: translateX(-50%) !important;
        margin: 0 !important;
        white-space: nowrap !important;
    }
    body.page-id-1541 .breadcrumb__title, body.page-id-939 .breadcrumb__title, body.page-id-919 .breadcrumb__title,
    body.page-id-1549 .breadcrumb__title, body.page-id-1078 .breadcrumb__title, body.blog .breadcrumb__title {
        font-size: clamp(38px, 8.4vw, 60px) !important;   /* a touch smaller so the title clears the ship */
    }
    body.page-id-1541 .gsy-hero-divider, body.page-id-939 .gsy-hero-divider, body.page-id-919 .gsy-hero-divider,
    body.page-id-1549 .gsy-hero-divider, body.page-id-1078 .gsy-hero-divider, body.blog .gsy-hero-divider {
        margin: 12px 0 0 !important;
    }
}

/* The CTA now lives inside the banner at all sizes, so the below-banner copy stays hidden. */
.gsy-cta-below { display: none !important; }

/* ─── Same hero text treatment on the other inner pages (Services / About / Case Studies /
       Contact / News list / category archives). Top-aligned so the taller content clears the
       floating header; big uppercase title; gold divider + features + CTA come from the JS
       injection above. Single posts are intentionally excluded (long article headlines). ─── */
/* Wide-only: the tall hero layout. On narrow screens the @media(max-width:1000) block below takes
   over (4:3 compact), so this must NOT apply there or it would force a 700px box and crop the photo. */
@media (min-width: 1001px) {
    body.page-id-939  .breadcrumb.bg_img,
    body.page-id-919  .breadcrumb.bg_img,
    body.page-id-1549 .breadcrumb.bg_img,
    body.page-id-1078 .breadcrumb.bg_img,
    body.blog         .breadcrumb.bg_img,
    body[class*="term-"] .breadcrumb.bg_img {
        align-items: flex-start !important;
        min-height: 700px !important;
        padding-top: 150px !important;
        padding-bottom: 54px !important;
    }
}
body.page-id-939  .breadcrumb__title,
body.page-id-919  .breadcrumb__title,
body.page-id-1549 .breadcrumb__title,
body.page-id-1078 .breadcrumb__title,
body.blog         .breadcrumb__title,
body.single-post  .breadcrumb__title,
body[class*="term-"] .breadcrumb__title {
    font-size: clamp(32px, 4vw, 52px) !important;
    line-height: 1.02 !important;
    text-transform: uppercase !important;
    max-width: 18ch !important;
}
body.page-id-939  .breadcrumb__text,
body.page-id-919  .breadcrumb__text,
body.page-id-1549 .breadcrumb__text,
body.page-id-1078 .breadcrumb__text,
body.blog         .breadcrumb__text,
body[class*="term-"] .breadcrumb__text {
    max-width: 34ch !important;
    font-size: 17px !important;
}

/* gold divider with anchor, between the title and the tagline */
.gsy-hero-divider { display: flex; align-items: center; gap: 14px; width: 320px; max-width: 80%; margin: 18px 0 14px; }
.gsy-hero-divider::before, .gsy-hero-divider::after { content: ""; flex: 1; height: 1px; background: linear-gradient(90deg, rgba(201,162,75,0), #c9a24b, rgba(201,162,75,0)); }
.gsy-hero-divider svg { width: 20px; height: 20px; color: #c9a24b; flex: 0 0 auto; }

/* feature row */
.gsy-hero-features { list-style: none; display: flex; gap: 30px; flex-wrap: wrap; margin: 26px 0 0; padding: 0; }
.gsy-hero-features li { display: flex; align-items: center; gap: 12px; }
.gsy-hero-features .gsy-hero-ic {
    flex: 0 0 46px; width: 46px; height: 46px; border-radius: 50%;
    border: 1px solid rgba(201,162,75,.55);
    display: flex; align-items: center; justify-content: center; color: #c9a24b;
}
.gsy-hero-features .gsy-hero-ic svg { width: 20px; height: 20px; }
.gsy-hero-features strong { display: block; color: #fff; font-family: 'Jost', sans-serif; font-size: 15px; font-weight: 600; line-height: 1.2; }
.gsy-hero-features span { display: block; color: rgba(255,255,255,.62); font-family: 'Jost', sans-serif; font-size: 12.5px; }

/* gold CTA */
.gsy-hero-btn {
    display: inline-flex; align-items: center; gap: 10px; margin-top: 30px;
    padding: 14px 32px; border-radius: 7px;
    background: linear-gradient(180deg, #e4c47d 0%, #c9a24b 100%);
    color: #07203b !important; font-family: 'Jost', sans-serif; font-weight: 700;
    font-size: 14px; letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
    box-shadow: 0 10px 24px rgba(201,162,75,.28);
    transition: transform .2s, box-shadow .2s, filter .2s;
}
.gsy-hero-btn:hover { transform: translateY(-2px); filter: brightness(1.05); color: #07203b !important; box-shadow: 0 14px 30px rgba(201,162,75,.4); }
@media (max-width: 991px) { .gsy-hero-features { gap: 18px; } .gsy-hero-features li:nth-child(n+2) { display: none; } }

/* ─── Inner-page banners — a real ship-at-sea PHOTO with the same navy gradient as the VFS hero, so
       every inner page matches: big title + tagline + feature row + gold CTA over a photographic
       seascape. Each page/term swaps the photo via --gsy-banner. The front page has no .breadcrumb;
       the VFS page (1541) keeps its own hero block above; the search page hides its banner. ─── */
body.page-id-939  .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-hero-services.jpg); }  /* Services — full-ship 4:3, VFS treatment */
body.page-id-919  .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-hero-about.jpg); }     /* About Us */
body.page-id-1549 .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-hero-case.jpg); }      /* Case Studies */
body.page-id-1078 .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-hero-contact.jpg); }   /* Contact */
body.blog .breadcrumb.bg_img,
body.single-post .breadcrumb.bg_img  { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-hero-news.jpg); }      /* News list + posts */
body.term-bulk-carriers  .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-bulk.jpg); }
body.term-container-ships .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-container.jpg); }
body.term-deck-barges    .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-barge.jpg); }
body.term-tankers        .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-tanker.jpg); }
body.term-dredgers       .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-dredger.jpg); }
body.term-tugs-workboats .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-tug.jpg); }
body.term-multi-purpose  .breadcrumb.bg_img { --gsy-banner: url(/wp-content/uploads/2026/06/gsy-bn-cat-mpp.jpg); }

/* Shared ship-at-sea photo + navy gradient background for all the inner pages above — same treatment
   as the VFS hero (lighter navy on the left for the title, photo opening up on the right). */
body.page-id-939  .breadcrumb.bg_img,
body.page-id-919  .breadcrumb.bg_img,
body.page-id-1549 .breadcrumb.bg_img,
body.page-id-1078 .breadcrumb.bg_img,
body.blog         .breadcrumb.bg_img,
body.single-post  .breadcrumb.bg_img,
body[class*="term-"] .breadcrumb.bg_img {
    position: relative;
    overflow: hidden;
    align-items: flex-start !important;     /* top-align like the VFS hero (was centred → breadcrumb sat too high) */
    padding-top: 185px !important;          /* clear the floating nav with breathing room */
    background:
        linear-gradient(95deg, #06203b 0%, #06203b 22%, rgba(7,32,59,.82) 34%, rgba(7,32,59,.42) 48%, rgba(7,32,59,.12) 63%, rgba(7,32,59,0) 80%) center/cover no-repeat,
        linear-gradient(to top, rgba(6,32,59,.85) 0%, rgba(7,32,59,0) 10%) center/cover no-repeat,
        var(--gsy-banner) center right / cover no-repeat !important;
    background-color: #06203b !important;
}

/* ─── The ship cut-out as a tilted ::before element (so it reads as a vessel under way rather
       than a flat broadside). Sized by WIDTH so the whole ship always shows and scales down with
       the screen; bottom-masked so the hull melts into the navy. Covers every banner page incl.
       the VFS hero. ─────────────────────────────────────────────────────────────────────────── */
/* The inner pages now use real ship-at-sea photos (not the cut-out), so the cut-out ::before is
   disabled for all of them. */
body.page-id-1541 .breadcrumb.bg_img::before,
body.page-id-939  .breadcrumb.bg_img::before,
body.page-id-919  .breadcrumb.bg_img::before,
body.page-id-1549 .breadcrumb.bg_img::before,
body.page-id-1078 .breadcrumb.bg_img::before,
body.blog         .breadcrumb.bg_img::before,
body.single-post  .breadcrumb.bg_img::before,
body[class*="term-"] .breadcrumb.bg_img::before {
    content: none !important;
}

/* faint ship's-wheel watermark behind the cut-out, like the VFS hero */
body.page-id-939  .breadcrumb.bg_img::after,
body.page-id-919  .breadcrumb.bg_img::after,
body.page-id-1549 .breadcrumb.bg_img::after,
body.page-id-1078 .breadcrumb.bg_img::after,
body.blog         .breadcrumb.bg_img::after,
body.single-post  .breadcrumb.bg_img::after,
body[class*="term-"] .breadcrumb.bg_img::after {
    content: "";
    position: absolute; top: 50%; right: 9%;
    transform: translateY(-54%);
    width: 380px; height: 380px;
    background: url(/wp-content/uploads/2026/05/golden-shipyard-logo-transparent.png) no-repeat center / contain;
    filter: brightness(0) invert(1);
    opacity: .05;
    pointer-events: none;
}
body.page-id-939  .breadcrumb__content,
body.page-id-919  .breadcrumb__content,
body.page-id-1549 .breadcrumb__content,
body.page-id-1078 .breadcrumb__content,
body.blog         .breadcrumb__content,
body.single-post  .breadcrumb__content,
body[class*="term-"] .breadcrumb__content { position: relative; z-index: 2; }

/* ─── Header search box (replaces the old Rent Now button) — KEEP per user request ─── */
.gsy-header-search {
    display: inline-flex !important;
    align-items: center !important;
    background: #fff !important;
    border: 1px solid #e6eaf0 !important;
    border-radius: 999px !important;
    padding: 4px 5px 4px 18px !important;
    height: 44px !important;
    margin-right: 12px !important;
    box-shadow: 0 2px 8px rgba(10,43,80,.10) !important;
    transition: box-shadow .2s, border-color .2s !important;
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
}
.gsy-header-search:focus-within {
    border-color: #c98a3b !important;
    box-shadow: 0 4px 14px rgba(10,43,80,.16), 0 0 0 3px rgba(201,138,59,.18) !important;
}
.gsy-header-search:hover { box-shadow: 0 4px 14px rgba(10,43,80,.14) !important; }
.gsy-header-search input[type="search"] {
    background: transparent !important;
    border: 0 !important;
    outline: none !important;
    color: #0A2B50 !important;
    font-family: inherit !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    width: 124px !important;
    padding: 0 10px 0 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    line-height: 1 !important;
}
.gsy-header-search input[type="search"]::placeholder { color: #7a8696 !important; font-weight: 400 !important; }
.gsy-header-search input[type="search"]::-webkit-search-cancel-button { display: none; }
.gsy-header-search button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    height: 34px !important;
    background: #0A2B50 !important;
    color: #fff !important;
    border: 0 !important;
    border-radius: 999px !important;
    padding: 0 !important;
    cursor: pointer !important;
    transition: background .2s !important;
    flex: 0 0 34px !important;
}
.gsy-header-search button:hover { background: #c98a3b !important; }
@media (max-width: 991px) { .gsy-header-search { display: none !important; } }

/* ─── Header offcanvas (sidebar) toggle: was a faint empty circle. Make the injected 5-dot icon
       white and the circle a touch more visible, matching the reference template. ─── */
.offcanvas-sidebar-btn {
    color: #fff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
    transition: background .2s, border-color .2s !important;
}
.offcanvas-sidebar-btn svg { width: 18px !important; height: 18px !important; }
.offcanvas-sidebar-btn svg path { fill: currentColor !important; }
.offcanvas-sidebar-btn:hover {
    background: rgba(255, 255, 255, 0.12) !important;
    border-color: #fff !important;
}
/* On narrow screens the template hides the 5-dot offcanvas button and shows only the hamburger
   (which opens the mobile menu). Our !important display rules above re-showed it, giving two
   menu buttons — hide it again under 992px so only the hamburger remains, matching the template. */
@media (max-width: 991px) {
    .header-area .header-right .header-menu,
    .offcanvas-sidebar-btn { display: none !important; }
}

/* ─── Header "Rent Now" CTA pill (links to /contact/, same function as the template). White pill
       + navy arrow-circle, matching the reference header button; inverts on hover. ─── */
.header-area .header-right .header-menu {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
}
.header-area .header-right {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: nowrap !important;
}
.gsy-header-cta {
    display: inline-flex !important;
    align-items: center !important;
    gap: 9px !important;
    height: 44px !important;
    padding: 4px 18px 4px 5px !important;
    background: #fff !important;
    color: #0A2B50 !important;
    border-radius: 999px !important;
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    box-shadow: 0 2px 8px rgba(10, 43, 80, .12) !important;
    transition: background .2s, color .2s, box-shadow .2s !important;
}
.gsy-header-cta__arrow {
    width: 34px !important;
    height: 34px !important;
    flex: 0 0 34px !important;
    border-radius: 50% !important;
    background: #0A2B50 !important;
    color: #fff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .2s, color .2s !important;
}
.gsy-header-cta:hover {
    background: #0A2B50 !important;
    color: #fff !important;
    box-shadow: 0 6px 16px rgba(10, 43, 80, .22) !important;
}
.gsy-header-cta:hover .gsy-header-cta__arrow {
    background: #fff !important;
    color: #0A2B50 !important;
}
@media (max-width: 991px) {
    .gsy-header-cta { display: none !important; }
}

/* ─── Vessels for Sale: full-width alternating type blocks. One side = a floating transparent
       ship (bow flipped toward the list); other side = that type's products as rows with a small
       thumbnail. The left filter sidebar is hidden so the blocks get the full width. ─── */
.page-id-1541 .elementor-element-284367c { display: none !important; }                 /* hide filter sidebar */
.page-id-1541 .elementor-element-af29dd0 { width: 100% !important; max-width: 100% !important; flex: 1 1 100% !important; }
/* ─── Vessels-for-Sale card grid + filters (replaces the old .gsy-vfs rows) ───────────────────── */
.gsy-vessels { padding: 4px 0 120px; }

/* header + filter toolbar (title left, filters right, shared baseline) */
.gsy-vessels__bar {
    position: relative;
    display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap;
    gap: 26px 44px; margin: 0 0 48px; padding: 0 0 32px;
    border-bottom: 1px solid #e1e7f0;
}
.gsy-vessels__bar::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 72px; height: 3px; background: #c9a24b; border-radius: 2px; }
.gsy-vessels__head { margin: 0; }
.gsy-vessels__eyebrow { display: inline-block; font: 700 12px/1 'Jost', sans-serif; letter-spacing: .22em; text-transform: uppercase; color: #c9a24b; margin: 0 0 13px; }
.gsy-vessels__heading { font-family: 'Roboto Slab', serif; font-weight: 600; font-size: clamp(28px, 3.1vw, 38px); line-height: 1.05; letter-spacing: -.01em; color: #0a2b50; margin: 0; }
.gsy-vessels__sub { margin: 13px 0 0; font: 500 15px/1 'Jost', sans-serif; color: #7d8da3; }

/* filters */
.gsy-vessels__filters { display: flex; gap: 18px; flex-wrap: wrap; align-items: flex-end; margin: 0; padding: 0; border: 0; }
.gsy-vsl-field { display: flex; flex-direction: column; gap: 9px; }
.gsy-vsl-field label { font: 700 11px/1 'Jost', sans-serif; letter-spacing: .17em; text-transform: uppercase; color: #9aa8bd; }
.gsy-vsl-filter {
    -webkit-appearance: none; appearance: none;
    background: #fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230a2b50' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 16px center;
    border: 1px solid #d6deea; border-radius: 9px;
    padding: 14px 44px 14px 18px; min-width: 230px;
    font: 500 15px/1 'Jost', sans-serif; color: #0a2b50; cursor: pointer;
    box-shadow: 0 4px 14px rgba(10,43,80,.05);
    transition: border-color .2s, box-shadow .2s;
}
.gsy-vsl-filter:hover { border-color: #b9c6d8; }
.gsy-vsl-filter:focus { outline: none; border-color: #0a2b50; box-shadow: 0 0 0 3px rgba(10,43,80,.10); }
/* the theme prettifies <select> into a jQuery Nice Select div — restyle it into a refined control
   with a rotating chevron and a soft rounded dropdown panel. */
.nice-select.gsy-vsl-filter { position: relative; display: flex; align-items: center; height: 54px; padding: 0 46px 0 18px; line-height: 1.25; background-image: none; border-color: #d6deea; transition: border-color .2s, box-shadow .2s; }
.nice-select.gsy-vsl-filter:hover { border-color: #b9c6d8; }
.nice-select.gsy-vsl-filter.open { border-color: #0a2b50; box-shadow: 0 0 0 3px rgba(10,43,80,.10); }
.nice-select.gsy-vsl-filter .current { display: block; font-weight: 500; color: #0a2b50; }
/* chevron — rotates when the list is open */
.nice-select.gsy-vsl-filter::after { display: block; content: ""; position: absolute; right: 18px; top: 50%; width: 8px; height: 8px; margin-top: -6px; border: 0; border-right: 2px solid #0a2b50; border-bottom: 2px solid #0a2b50; transform: rotate(45deg); transition: transform .25s; pointer-events: none; }
.nice-select.gsy-vsl-filter.open::after { transform: rotate(-135deg); margin-top: -2px; }
/* dropdown panel */
.nice-select.gsy-vsl-filter .list { width: 100%; margin-top: 10px; padding: 7px; border: 1px solid #e6edf5; border-radius: 12px; box-shadow: 0 22px 46px -16px rgba(10,43,80,.32); background: #fff; max-height: 340px; overflow-y: auto; }
.nice-select.gsy-vsl-filter .option { position: relative; min-height: 0; line-height: 1.3; padding: 11px 14px; margin: 1px 0; border-radius: 8px; font: 500 14.5px/1.3 'Jost', sans-serif; color: #44566c; transition: background-color .15s, color .15s; }
.nice-select.gsy-vsl-filter .option:hover, .nice-select.gsy-vsl-filter .option.focus { background-color: #eef3f9; color: #0a2b50; }
.nice-select.gsy-vsl-filter .option.selected { color: #0a2b50; font-weight: 600; background-color: #f3f7fc; }
.nice-select.gsy-vsl-filter .option.selected::after { content: "\2713"; position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: #c9a24b; font-weight: 700; }
.nice-select.gsy-vsl-filter .list::-webkit-scrollbar { width: 9px; }
.nice-select.gsy-vsl-filter .list::-webkit-scrollbar-thumb { background: #d6deea; border-radius: 9px; border: 2px solid #fff; }

/* category group + heading */
.gsy-vessels__group { margin: 0 0 64px; }
.gsy-vessels__group:last-of-type { margin-bottom: 0; }
.gsy-vessels__group-head {
    position: relative;
    display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
    margin: 0 0 28px; padding-bottom: 15px;
    border-bottom: 1px solid #e1e7f0;
}
.gsy-vessels__group-head::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 62px; height: 3px; background: #c9a24b; border-radius: 2px; }
.gsy-vessels__group-title { font-family: 'Roboto Slab', serif; font-weight: 600; font-size: clamp(22px, 2.4vw, 28px); line-height: 1.1; letter-spacing: -.01em; color: #0a2b50; margin: 0; }
.gsy-vessels__group-count { font: 700 12px/1 'Jost', sans-serif; letter-spacing: .14em; text-transform: uppercase; color: #c9a24b; white-space: nowrap; }

/* card grid */
/* The vessels section is trapped inside Elementor's ~1120px content column, leaving big side gaps and
   cramped cards. Break it out to (near) full width and re-centre a wider inner container. */
.gsy-vessels { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.gsy-vessels > .container { width: 94vw !important; max-width: 1760px !important; }

/* align-items:start — each card ends just below its own Available row instead of
   stretching to the tallest card in the row (images keep their natural heights). */
.gsy-vessels__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; align-items: start; }
/* Vessel cards reuse the theme's NATIVE yacht-card markup (.xb-yacht-item …) so they look exactly
   like the template; we only fit them into our category grid and size the inline maritime spec icons. */
.gsy-vessels__grid .xb-yacht-item { margin: 0; width: 100%; height: auto !important; }
/* The theme's meta layout (2-column grid + flex spans that shrink to min-content) collapses with our
   longer vessel values, so label and value overlap. Re-lay it out explicitly: one spec per full-width
   row, icon+label on the left, value on the right, nothing allowed to shrink/wrap. */
#gsy-vessels .xb-item--meta { display: block !important; margin-top: 20px; }
#gsy-vessels .xb-item--meta li { display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 12px !important; padding: 17px 0 !important; }
#gsy-vessels .xb-item--meta li > span { width: auto !important; flex: 0 0 auto !important; white-space: nowrap !important; }
#gsy-vessels .xb-item--meta li > span:first-child { display: inline-flex !important; align-items: center; gap: 13px; font-weight: 500; color: rgba(10,43,80,.72); }
/* no decorative corner shape on the vessel cards */
#gsy-vessels .xb-item--icon_shape { display: none !important; }
#gsy-vessels .xb-item--meta li > span:last-child { font-weight: 500; color: #0a2b50; }
#gsy-vessels .xb-item--meta li > span:first-child > span { width: 18px !important; flex: 0 0 18px !important; display: inline-flex !important; }
#gsy-vessels .xb-item--meta li > span:first-child > span svg { width: 18px; height: 18px; display: block; }
/* card typography + proportions to match the template */
#gsy-vessels .xb-item--title, #gsy-vessels .xb-item--title a { font-family: 'Laginchy', var(--font-heading), Georgia, serif !important; font-weight: 400 !important; font-size: 23px !important; line-height: 1.2 !important; }
#gsy-vessels .xb-item--content { font-size: 17px !important; color: rgba(10,43,80,.7) !important; }
/* uniform image frame: every card gets the same 3:2 box and the photo FILLS it
   (object-fit: cover crops the overflow — same treatment as the admin tool) */
#gsy-vessels .xb-item--img { aspect-ratio: 3 / 2 !important; height: auto !important; }
#gsy-vessels .xb-item--img .img--1 { display: none !important; }                                  /* hide the duplicate hover-swap layer */
#gsy-vessels .xb-item--img .img--2 { position: absolute !important; inset: 0 !important; height: 100% !important; opacity: 1 !important; transform: none !important; filter: none !important; }
#gsy-vessels .xb-item--img img { width: 100% !important; height: 100% !important; max-height: none !important; object-fit: cover !important; }
#gsy-vessels .hover-effect-img:hover .xb-item--img img { transform: none !important; }            /* no zoom-crop on hover */
/* spec icons in the template's orange; value text in the lighter navy */
#gsy-vessels .xb-item--meta li > span:first-child > span { color: #ef5a38; }
#gsy-vessels .xb-item--meta li > span:last-child { color: rgba(10,43,80,.7); }
/* airier top padding above the title, like the template */
#gsy-vessels .xb-item--holder { padding: 26px 24px 22px; }
.gsy-vessels__empty { grid-column: 1 / -1; text-align: center; color: #5d738c; font: 500 17px 'Jost', sans-serif; padding: 40px 0; }
@media (max-width: 991px) {
    .gsy-vessels__grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
    /* Stack the toolbar so the title sits on top and the two filters form a tidy full-width row
       beneath it — instead of the dropdowns staggering on the right when the bar wraps. */
    .gsy-vessels__bar { flex-direction: column; align-items: stretch; gap: 28px; }
    .gsy-vessels__filters { width: 100%; gap: 16px; align-items: stretch; }
    .gsy-vsl-field { flex: 1 1 0; min-width: 0; }
    .gsy-vsl-filter, .nice-select.gsy-vsl-filter { width: 100%; min-width: 0; }
}
@media (max-width: 600px) {
    .gsy-vessels__grid { grid-template-columns: 1fr; }
}
/* Keep the two filters side-by-side down to small phones; only stack on very narrow screens. */
@media (max-width: 400px) {
    .gsy-vessels__filters { flex-direction: column; }
    .gsy-vsl-field { flex: 0 0 auto; width: 100%; }
}

.gsy-vfs { overflow: visible; }
.gsy-vfs__row {
    display: flex;
    align-items: center;
    gap: 44px;
    margin-bottom: 88px;
    scroll-margin-top: 120px;
}
.gsy-vfs__row:last-child { margin-bottom: 0; }
.gsy-vfs__row:nth-child(even) { flex-direction: row-reverse; }

/* ── big floating cut-out ship ── */
.gsy-vfs__ship { flex: 0 0 48%; min-width: 0; }
.gsy-vfs__row:nth-child(odd)  .gsy-vfs__ship { margin-left: -5%; }
.gsy-vfs__row:nth-child(even) .gsy-vfs__ship { margin-right: -5%; }
.gsy-vfs__ship > a { display: block; }
.gsy-vfs__ship img {
    width: 100%; height: auto; display: block;
    filter: drop-shadow(0 24px 32px rgba(10,43,80,.28));
    transition: transform .45s ease;
}
/* Native cut-out bow faces left → flip odd rows (ship on the left) so the bow points inward
   (toward the list on the right); even rows (ship on the right) keep the native bow. */
.gsy-vfs__row:nth-child(odd) .gsy-vfs__ship img { transform: scaleX(-1); }
.gsy-vfs__row:nth-child(odd)  .gsy-vfs__ship:hover img { transform: scaleX(-1) translateY(-7px); }
.gsy-vfs__row:nth-child(even) .gsy-vfs__ship:hover img { transform: translateY(-7px); }

/* ── framed photo-card variant (used where no clean cut-out exists, e.g. Tugs) ── */
.gsy-vfs__ship--photo img {
    border-radius: 18px;
    filter: none;
    box-shadow: 0 24px 40px rgba(10,43,80,.22);
    object-fit: cover;
}
.gsy-vfs__row .gsy-vfs__ship--photo img,
.gsy-vfs__row:nth-child(odd) .gsy-vfs__ship--photo img { transform: none; }
.gsy-vfs__ship--photo:hover img { transform: translateY(-7px) !important; }

/* ── text panel ── */
.gsy-vfs__panel { flex: 1 1 52%; min-width: 0; }
.gsy-vfs__type {
    display: inline-block;
    font-size: 12px; letter-spacing: .16em; text-transform: uppercase;
    font-weight: 700; color: #c98a3b; margin: 0 0 6px;
}
.gsy-vfs__title {
    font-family: 'Cormorant Garamond','Playfair Display',Georgia,serif;
    font-size: clamp(26px, 2.6vw, 36px); font-weight: 700; line-height: 1.05;
    color: #0A2B50; margin: 0 0 20px;
}
.gsy-vfs__title a { color: inherit; text-decoration: none; }
.gsy-vfs__title a:hover { color: #c98a3b; }

/* ── product pill list (max 3) ── */
.gsy-vfs__list { list-style: none; margin: 0 0 22px; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.gsy-vfs__item a {
    display: flex; align-items: center; gap: 16px;
    padding: 10px 14px 10px 12px;
    background: #d7e4f1; border-radius: 14px;
    text-decoration: none;
    transition: background .22s, transform .22s, box-shadow .22s;
}
.gsy-vfs__item a:hover {
    background: #0A2B50; transform: translateY(-2px);
    box-shadow: 0 12px 22px rgba(10,43,80,.18);
}
.gsy-vfs__thumb {
    flex: 0 0 70px; width: 70px; height: 52px;
    object-fit: cover; border-radius: 9px; display: block;
}
.gsy-vfs__item-name {
    flex: 1 1 auto; min-width: 0;
    font-family: 'Cormorant Garamond','Playfair Display',Georgia,serif;
    font-size: 18px; font-weight: 700; line-height: 1.2; color: #0A2B50;
}
.gsy-vfs__learn {
    flex: 0 0 auto; display: inline-flex; align-items: center; gap: 6px;
    font-family: 'Jost', system-ui, -apple-system, sans-serif;
    font-size: 13px; font-weight: 600; letter-spacing: .02em; color: #1a4a7a;
    white-space: nowrap;
}
.gsy-vfs__item a:hover .gsy-vfs__item-name,
.gsy-vfs__item a:hover .gsy-vfs__learn { color: #fff; }
.gsy-vfs__learn .gsy-vfs__arrow { transition: transform .22s; }
.gsy-vfs__item a:hover .gsy-vfs__learn .gsy-vfs__arrow { transform: translateX(3px); }

/* ── More button → category page ── */
.gsy-vfs__btn {
    display: inline-flex; align-items: center; gap: 9px;
    padding: 12px 26px; border-radius: 50px;
    background: #0A2B50; color: #fff;
    font-family: 'Jost', system-ui, -apple-system, sans-serif;
    font-size: 14px; font-weight: 600; letter-spacing: .02em;
    text-decoration: none;
    transition: background .25s, box-shadow .25s, transform .25s;
}
.gsy-vfs__btn:hover {
    background: #c98a3b; color: #fff;
    box-shadow: 0 14px 26px rgba(201,138,59,.35);
    transform: translateY(-2px);
}
.gsy-vfs__btn .gsy-vfs__arrow { transition: transform .25s; }
.gsy-vfs__btn:hover .gsy-vfs__arrow { transform: translateX(4px); }

@media (max-width: 991px) {
    .gsy-vfs__row,
    .gsy-vfs__row:nth-child(even) { flex-direction: column; gap: 24px; margin-bottom: 56px; }
    .gsy-vfs__ship,
    .gsy-vfs__panel { flex-basis: auto; width: 100%; margin: 0 !important; }
    .gsy-vfs__ship img { transform: none !important; }
    .gsy-vfs__row:nth-child(odd) .gsy-vfs__ship:hover img,
    .gsy-vfs__row:nth-child(even) .gsy-vfs__ship:hover img { transform: translateY(-7px) !important; }
}

/* Vessel grid cards: hide the empty decorative icon overlay (no icon set in theme options) */
.xb-yacht-item .xb-item--icon_shape,
.xb-yacht-item img[alt="icon"][src=""] { display: none; }

/* ─── Cap header / footer logo size (Golden Shipyard medal is near-square) ─── */
.xb-header-logo img, .xb-logo-mobile img, .sidebar-logo img {
    max-height: 56px !important; width: auto !important; height: auto !important; object-fit: contain;
}
.sidebar-logo img { max-height: 80px !important; }
.xb-logo-mobile img { max-height: 48px !important; }
.xb-footer .xb-logo img, footer .xb-logo img, .footer-area .xb-logo img {
    max-height: 90px !important; width: auto !important; height: auto !important; object-fit: contain;
}

/* (Logo backdrop reverted — the header logo uses its original plain styling: the medal at its
   capped size with no circular frame/ring.) */

/* ─── Smooth anchor scroll offset (general site-wide) ─── */
[id^="cat-"] { scroll-margin-top: 100px; }


/* ─── xb_destination: constrain map width + force pin visibility (wow.js can stay at opacity 0) ─── */
.elementor-widget-xb_destination .xb-destination-img {
    max-width: 1140px !important;
    margin: 0 auto !important;
}
.elementor-widget-xb_destination .xb-destination-img > img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}
/* Override wow.js initial opacity:0 so pins are visible even if animation hasn't run */
.elementor-widget-xb_destination .xb-destination-img .loc-img.wow {
    visibility: visible !important;
    opacity: 1 !important;
    animation-name: none !important;
}
.elementor-widget-xb_destination .xb-destination-img .loc-img img {
    max-width: 48px !important;
    height: auto !important;
}

/* ─── xb_funfact: show images on ALL 4 cards (yacty default hides them) + equalize heights + clean hover ─── */
.elementor-widget-xb_funfact .xb-funfact-item .xb-item--img {
    opacity: 1 !important;
    transform: scale(1) !important;
    flex: 1 1 auto !important;
    margin: 24px 0 !important;
    min-height: 160px !important;
}
.elementor-widget-xb_funfact .xb-funfact-item {
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    min-height: 380px !important;
    background: #fff !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
}
.elementor-widget-xb_funfact .xb-funfact-item .xb-item--img img {
    width: 100% !important;
    height: 160px !important;
    object-fit: cover !important;
}

/* Cancel the yacty default orange "active" state — keep card white, just enlarge + add shadow */
.elementor-widget-xb_funfact .xb-funfact-item:hover,
.elementor-widget-xb_funfact .xb-funfact-item.active {
    background: #fff !important;
    transform: scale(1.06) !important;
    box-shadow: 0 18px 40px rgba(10,43,80,.14) !important;
    z-index: 2;
    position: relative;
}
.elementor-widget-xb_funfact .xb-funfact-item:hover .xb-item--sub-title,
.elementor-widget-xb_funfact .xb-funfact-item.active .xb-item--sub-title { color: #0A2B50 !important; }
.elementor-widget-xb_funfact .xb-funfact-item:hover .xb-item--number,
.elementor-widget-xb_funfact .xb-funfact-item.active .xb-item--number { color: #0A2B50 !important; }
.elementor-widget-xb_funfact .xb-funfact-item:hover .xbo,
.elementor-widget-xb_funfact .xb-funfact-item.active .xbo,
.elementor-widget-xb_funfact .xb-funfact-item:hover .suffix,
.elementor-widget-xb_funfact .xb-funfact-item.active .suffix { color: #0A2B50 !important; }

.elementor-widget-xb_funfact .row > [class*="col-"] { display: flex; }
.elementor-widget-xb_funfact .col-lg-3.col-md-6.mt-30 > .xb-funfact-item { width: 100%; }

/* ─── xb_service_2 boat image: transparent PNG, mirrored to face right toward the text boxes ─── */
.elementor-widget-xb_service_2 .xb-service-boat,
.elementor-widget-xb_service_2 .boart-image { background: transparent !important; }
.elementor-widget-xb_service_2 .boart-image img {
    border-radius: 0 !important;
    box-shadow: none !important;
    mix-blend-mode: normal !important;
    filter: none !important;
    transform: scaleX(-1) !important;
}

/* ─── xb_service: equalize all 4 tab heights regardless of label length ─── */
.elementor-widget-xb_service .xb-ser-item .xb-holder {
    min-height: 130px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px 24px !important;
}
.elementor-widget-xb_service .xb-ser-item .xb-holder .title {
    margin: 0 !important;
    text-align: center !important;
    line-height: 1.25 !important;
}
@media (max-width: 991px) {
    .elementor-widget-xb_service .xb-ser-item .xb-holder { min-height: 90px !important; }
}

/* ===================================================================
 * /vessels-for-sale/  (page 1541) — match tt.goldenshipyard.com layout
 * =================================================================== */

/* Sidebar (22% column #284367c) sticks while right side scrolls */
.elementor-element-284367c {
    position: sticky !important;
    top: 100px !important;
    align-self: flex-start !important;
    max-height: calc(100vh - 120px) !important;
    overflow-y: auto !important;
}
.elementor-element-284367c::-webkit-scrollbar { width: 0 !important; display: none !important; }
.elementor-element-284367c { scrollbar-width: none !important; }
@media (max-width: 991px) {
    .elementor-element-284367c { position: static !important; max-height: none !important; overflow: visible !important; }
}

/* Each vessel-category container: single blue panel.
   The container is e-con-boxed which gives .e-con-inner a max-width — that creates
   a visible narrower "inner box". Solution: paint bg on the OUTER .e-con and force
   .e-con-inner to stretch full width with no own bg/padding, so they visually collapse. */
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) {
    background: #c9d6e4 !important;
    border-radius: 10px !important;
    padding: 16px 22px 28px !important;
    margin-bottom: 30px !important;
}
/* Defensively kill any background/border-radius on every nested wrapper, so
   only the outer .e-con shows blue. */
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) > .e-con-inner,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .elementor-widget-xb_yacht,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .elementor-widget-container,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) section.yacht,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) section.xb__yacht,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .yacht.xb__yacht > .container,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .yacht.xb__yacht .row,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .yacht.xb__yacht .col-lg-8,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .sec-title,
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) .sec-title--two {
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) > .e-con-inner {
    padding: 0 !important;
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
}
@media (max-width: 767px) {
    .elementor-element-af29dd0 > .e-con:has(.elementor-widget-xb_yacht) {
        padding: 40px 18px 50px !important;
    }
}

/* xb_yacht: remove yacty's big vertical padding inside the new blue panel */
.elementor-element-af29dd0 .elementor-widget-xb_yacht .xb__yacht.yacht {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
.elementor-element-af29dd0 .elementor-widget-xb_yacht .xb__yacht .container { padding: 0 !important; max-width: 100% !important; }

/* Section header: hide empty h2.title, restyle .sub-title as the big white centered heading */
.elementor-element-af29dd0 .elementor-widget-xb_yacht .sec-title--two .title { display: none !important; }
.elementor-element-af29dd0 .elementor-widget-xb_yacht .sec-title--two { margin-bottom: 20px !important; }
.elementor-element-af29dd0 .elementor-widget-xb_yacht .sec-title--two .sub-title {
    color: #0A2B50 !important;
    background: transparent !important;
    font-family: 'Cormorant Garamond', 'Playfair Display', Georgia, serif !important;
    font-size: 24px !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    padding: 0 !important;
    display: inline-block !important;
    line-height: 1.25 !important;
}
.elementor-element-af29dd0 .elementor-widget-xb_yacht .sec-title--two .sub-title::before,
.elementor-element-af29dd0 .elementor-widget-xb_yacht .sec-title--two .sub-title::after { display: none !important; }

/* 2 cards per row (was 3) */
.elementor-element-af29dd0 .elementor-widget-xb_yacht .row.mt-none-30 > .col-lg-4 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
}
@media (max-width: 767px) {
    .elementor-element-af29dd0 .elementor-widget-xb_yacht .row.mt-none-30 > .col-lg-4 {
        flex: 0 0 100% !important; max-width: 100% !important;
    }
}

/* Card shell — match production exactly */
.elementor-element-af29dd0 .xb-yacht-item {
    background: #fff !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    box-shadow: 0 1px 2px rgba(10,43,80,.04), 0 8px 20px rgba(10,43,80,.06) !important;
}
.elementor-element-af29dd0 .xb-item--inner { padding: 0 !important; }
.elementor-element-af29dd0 .xb-item--img { border-radius: 0 !important; }
.elementor-element-af29dd0 .xb-item--img img { width: 100% !important; height: 240px !important; max-height: 240px !important; object-fit: cover !important; display: block !important; }

/* Hover state: darken image, reveal arrow-circle + "Enquire" pill (match production) */
.elementor-element-af29dd0 .xb-item--img { position: relative !important; overflow: hidden !important; }
.elementor-element-af29dd0 .xb-item--img > a:first-child { display: block !important; position: relative !important; }
.elementor-element-af29dd0 .xb-item--img > a:first-child::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: rgba(10, 43, 80, 0.55) !important;
    opacity: 0 !important;
    transition: opacity .25s ease !important;
    pointer-events: none !important;
}
.elementor-element-af29dd0 .xb-yacht-item:hover .xb-item--img > a:first-child::after { opacity: 1 !important; }

.elementor-element-af29dd0 .xb-item--btn {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
    opacity: 0 !important;
    transition: opacity .25s ease !important;
    pointer-events: none !important;
    z-index: 3 !important;
}
.elementor-element-af29dd0 .xb-yacht-item:hover .xb-item--btn { opacity: 1 !important; pointer-events: auto !important; }

/* The whole <a class="thm-btn marine-btn"> becomes a row containing arrow-circle + label pill */
.elementor-element-af29dd0 .xb-item--btn > a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    color: #0A2B50 !important;
    box-shadow: none !important;
    text-decoration: none !important;
}
/* Arrow circle (first .arrow span) */
.elementor-element-af29dd0 .xb-item--btn > a > .arrow:first-child {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 56px !important;
    height: 56px !important;
    background: #fff !important;
    border-radius: 999px !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.18) !important;
}
.elementor-element-af29dd0 .xb-item--btn > a > .arrow:first-child svg { width: 18px !important; height: 16px !important; }
/* Hide the duplicate trailing arrow */
.elementor-element-af29dd0 .xb-item--btn > a > .arrow:last-child { display: none !important; }
/* The "Enquire" text pill */
.elementor-element-af29dd0 .xb-item--btn > a > span:not(.arrow) {
    display: inline-flex !important;
    align-items: center !important;
    background: #fff !important;
    color: #0A2B50 !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    padding: 16px 28px !important;
    border-radius: 999px !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.18) !important;
    line-height: 1 !important;
}

/* Dual badge stack top-right: split .b-cond (orange) + .b-stat (white) onto two lines */
.elementor-element-af29dd0 .xb-item--dollar {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    background: transparent !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 8px !important;
    box-shadow: none !important;
}
.elementor-element-af29dd0 .xb-item--dollar .b-cond,
.elementor-element-af29dd0 .xb-item--dollar .b-stat {
    display: inline-block !important;
    padding: 5px 12px !important;
    border-radius: 999px !important;
    font-size: 11.5px !important;
    font-weight: 600 !important;
    letter-spacing: .02em !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
}
.elementor-element-af29dd0 .xb-item--dollar .b-cond {
    background: #e75c2f !important;
    color: #fff !important;
}
.elementor-element-af29dd0 .xb-item--dollar .b-stat {
    background: #fff !important;
    color: #0A2B50 !important;
    border: 1px solid #e6eaf0 !important;
}

/* Card body — match production exactly */
.elementor-element-af29dd0 .xb-item--holder { padding: 18px 22px 20px !important; gap: 8px !important; }
.elementor-element-af29dd0 .xb-item--category {
    color: #e75c2f !important;
    font-size: 11.5px !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: .12em !important;
    margin-bottom: 2px !important;
    display: inline-block !important;
}
.elementor-element-af29dd0 .xb-item--title {
    font-family: 'Cormorant Garamond', 'Playfair Display', Georgia, serif !important;
    font-size: 18px !important;
    line-height: 1.3 !important;
    font-weight: 600 !important;
    margin: 0 0 4px !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
}
.elementor-element-af29dd0 .xb-item--title a { color: #0A2B50 !important; }
.elementor-element-af29dd0 .xb-item--content {
    color: #6a7a8c !important;
    font-size: 13px !important;
    line-height: 1.55 !important;
    margin: 0 0 6px !important;
}

/* Specs list: 2-column grid with bullet dots — match production exactly */
.elementor-element-af29dd0 .xb-item--meta {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 6px 18px !important;
    margin: 4px 0 0 0 !important;
    padding: 12px 0 0 0 !important;
    border-top: 1px solid #eef1f5 !important;
    list-style: none !important;
}
.elementor-element-af29dd0 .xb-item--meta li {
    font-size: 12.5px !important;
    color: #4a5a72 !important;
    line-height: 1.4 !important;
    padding: 2px 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: left !important;
    gap: 7px !important;
    border: 0 !important;
    background: transparent !important;
    float: none !important;
    width: auto !important;
}
.elementor-element-af29dd0 .xb-item--meta li > span,
.elementor-element-af29dd0 .xb-item--meta li img {
    width: 13px !important;
    height: 13px !important;
    flex: 0 0 13px !important;
    opacity: .65 !important;
}
/* (removed) obsolete leftover that drew a navy dot background on every spec span in the old grid */

/* Anchor offset (already site-wide via [id^="cat-"], but reinforce inside the panel) */
.elementor-element-af29dd0 [id^="cat-"] { scroll-margin-top: 100px !important; }

/* ─── Breadcrumb hero (page banner for /vessels-for-sale/, /services/, etc.):
       compress yacty's huge decorative title down to a normal h1 size, match production ─── */
.breadcrumb,
section.breadcrumb,
section.breadcrumb.yacht-banner {
    min-height: 280px !important;
    padding: 110px 0 50px !important;
}
.breadcrumb__title {
    font-family: 'Laginchy', var(--font-heading), 'Cormorant Garamond', Georgia, serif !important; /* match home hero / theme heading font */
    font-size: clamp(30px, 3.8vw, 54px) !important;   /* sized so most vessel names fit one line; the longest may wrap */
    font-weight: 700 !important;
    letter-spacing: -.005em !important;
    text-transform: none !important;
    line-height: 1.1 !important;
    padding-top: 18px !important;
    color: #fff !important;
}
.breadcrumb .breadcrumb__text { font-size: 17px !important; line-height: 1.6 !important; }
@media (max-width: 991px) {
    .breadcrumb,
    section.breadcrumb,
    section.breadcrumb.yacht-banner {
        min-height: 240px !important;
        padding: 100px 0 40px !important;
    }
}
@media (max-width: 767px) {
    .breadcrumb,
    section.breadcrumb,
    section.breadcrumb.yacht-banner {
        min-height: 200px !important;
        padding: 90px 0 30px !important;
    }
    .breadcrumb__title { font-size: 28px !important; }
}

/* Note: the news-detail (single post) banner intentionally uses the SAME compact inner-page
   banner as Services/Vessels (the .breadcrumb / .breadcrumb__title rules above). No special
   single-post banner overrides here — the title text is set to "News Details" in functions.php. */

/* ─── Home testimonials: make the photo fill the card's left column like the reference site
       (tall, cover-cropped) instead of a small landscape thumbnail, and size the quote mark. ─── */
.xb__testimonial .xb-testimonial-item .xb-item--img {
    width: 410px !important;
    height: 430px !important;
    flex: 0 0 410px !important;
}
.xb__testimonial .xb-testimonial-item .xb-item--img > img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}
.xb__testimonial .xb-testimonial-item .xb-item--quote img {
    width: 74px !important;
    height: auto !important;
}
@media (max-width: 991px) {
    .xb__testimonial .xb-testimonial-item .xb-item--img {
        width: 100% !important;
        flex-basis: 100% !important;
        height: 320px !important;
    }
}

/* ─── News detail body typography: the theme only loads Jost in upright weights (no italic
       face), so any <em>/<i> in an article falls back to an ugly serif italic. Force emphasized
       text in the article body to stay in the clean body font, and give the lead/intro paragraph
       a tidy, slightly larger treatment like the reference site. Content is untouched. ─── */
body.single-post .entry-content em,
body.single-post .entry-content i,
body.single-post .entry-content blockquote {
    font-family: var(--font-body), 'Jost', sans-serif !important;
}
/* Lead paragraph (the article's italic intro): clean, readable, a touch larger — matches the
   reference's intro. Kept subtly distinct from body via color/size, not a serif italic. */
body.single-post .entry-content > p:first-of-type {
    font-size: 19px !important;
    line-height: 1.7 !important;
    color: #3f5168 !important;
}
body.single-post .entry-content > p:first-of-type em,
body.single-post .entry-content > p:first-of-type i {
    font-style: normal !important;
}

/* ─── Vessel detail: status chip "Available" — use navy not orange ─── */
.gsy-vd .gsy-vd__chip--accent {
    background: #0A2B50 !important;
    border-color: #0A2B50 !important;
    color: #fff !important;
}

/* ─── Vessel detail page: 2-column layout, enquire card sticky on the right.
       (.gsy-vd is the single HTML widget container; children currently flow
       single column. We turn it into a grid and pin .gsy-enq to col 2.) ─── */
@media (min-width: 992px) {
    .gsy-vd {
        display: grid !important;
        grid-template-columns: 1fr 320px !important;
        column-gap: 40px !important;
        align-items: start !important;
    }
    .gsy-vd > * { grid-column: 1; }

    /* Enquire card → right column, sticky.
       grid-row: 2 / span 100 makes it occupy "row 2 down" while staying sticky. */
    .gsy-vd > .gsy-enq {
        grid-column: 2 !important;
        grid-row: 2 / 99 !important;
        position: sticky !important;
        top: 100px !important;
        align-self: start !important;
        margin: 0 !important;
        background: #fff !important;
        color: #0A2B50 !important;
        border: 1px solid #e6eaf0 !important;
        padding: 26px 24px !important;
        border-radius: 14px 14px 0 0 !important;     /* flat bottom — similar list joins below */
        box-shadow: 0 8px 24px rgba(10, 43, 80, .06) !important;
        border-bottom: 1px solid #eef1f5 !important;
    }
    .gsy-vd > .gsy-enq h2 {
        color: #5a6877 !important;
        font-size: 12px !important;
        letter-spacing: .14em !important;
        text-transform: uppercase !important;
        font-weight: 700 !important;
        margin: 0 0 14px !important;
    }
    .gsy-vd > .gsy-enq p {
        color: #5a6877 !important;
        font-size: 14px !important;
        line-height: 1.6 !important;
        margin: 0 0 20px !important;
        max-width: none !important;
    }
    .gsy-vd > .gsy-enq p strong { color: #0A2B50 !important; }
    .gsy-vd > .gsy-enq .gsy-enq__ref { display: none !important; }

    .gsy-vd > .gsy-enq .gsy-enq__ctas {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }
    .gsy-vd > .gsy-enq .gsy-enq__btn {
        width: 100% !important;
        justify-content: center !important;
        padding: 13px 20px !important;
    }
    /* Primary CTA — site primary navy (matches header / logo / footer) */
    .gsy-vd > .gsy-enq .gsy-enq__btn--primary {
        background: #0A2B50 !important;
        color: #fff !important;
    }
    .gsy-vd > .gsy-enq .gsy-enq__btn--primary:hover {
        background: #163d6e !important;
    }
    .gsy-vd > .gsy-enq .gsy-enq__btn--ghost {
        background: #fff !important;
        color: #0A2B50 !important;
        border: 1px solid #d8dee6 !important;
    }
    .gsy-vd > .gsy-enq .gsy-enq__btn--ghost:hover {
        background: #f4f7fb !important;
        border-color: #0A2B50 !important;
    }

    /* Similar vessels → right column, joined to bottom of enq card,
       restyled as plain link list (instead of card grid) */
    .gsy-vd > .gsy-similar {
        grid-column: 2 !important;
        grid-row: 2 / 99 !important;
        align-self: start !important;
        margin: 0 !important;
        margin-top: 360px !important;     /* sits below the sticky enq card height */
        position: sticky !important;
        top: 460px !important;             /* 100 (enq top) + ~360 (enq height) */
        padding: 22px 24px 24px !important;
        background: #fff !important;
        border: 1px solid #e6eaf0 !important;
        border-top: 0 !important;
        border-radius: 0 0 14px 14px !important;
        box-shadow: 0 8px 24px rgba(10, 43, 80, .06) !important;
    }
    .gsy-vd > .gsy-similar::before {
        content: "Similar vessels" !important;
        display: block !important;
        color: #5a6877 !important;
        font-size: 12px !important;
        letter-spacing: .14em !important;
        text-transform: uppercase !important;
        font-weight: 700 !important;
        margin: 0 0 14px !important;
    }
    /* Hide the section title (it's an h2 inside) and flatten the card grid into a link list */
    .gsy-vd > .gsy-similar > h2,
    .gsy-vd > .gsy-similar > .gsy-vd__section-title { display: none !important; }
    .gsy-vd > .gsy-similar .gsy-similar__grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 4px !important;
    }
    .gsy-vd > .gsy-similar .gsy-similar__card {
        display: block !important;
        padding: 10px 0 !important;
        background: transparent !important;
        border: 0 !important;
        border-bottom: 1px solid #eef1f5 !important;
        border-radius: 0 !important;
        min-height: 0 !important;
        box-shadow: none !important;
        transform: none !important;
    }
    .gsy-vd > .gsy-similar .gsy-similar__card:hover {
        box-shadow: none !important;
        transform: none !important;
        border-color: #0A2B50 !important;
        background: transparent !important;
    }
    .gsy-vd > .gsy-similar .gsy-similar__card:last-child { border-bottom: 0 !important; }
    .gsy-vd > .gsy-similar .gsy-similar__arrow { display: none !important; }
    .gsy-vd > .gsy-similar .gsy-similar__title {
        font-size: 14px !important;
        color: #0A2B50 !important;
        font-weight: 500 !important;
        margin: 0 !important;
    }
    .gsy-vd > .gsy-similar .gsy-similar__card:hover .gsy-similar__title {
        color: #e75c2f !important;
    }
}
@media (max-width: 991px) {
    /* Mobile/tablet: card returns to full-width below content, original styles take over */
    .gsy-vd > .gsy-enq { position: static !important; }
    .gsy-vd > .gsy-similar { position: static !important; }
}

/* ─── Hero (xb_hero_one) title: shrink from yacty's huge display size ─── */
.elementor-widget-xb_hero_one .xb-hero_content .title {
    font-size: clamp(34px, 4.5vw, 64px) !important;
    line-height: 1.12 !important;
    letter-spacing: -.01em !important;
}
.elementor-widget-xb_hero_one .xb-hero_content .sub-title {
    font-size: 13px !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    padding: 7px 18px !important;
}
@media (max-width: 991px) {
    .elementor-widget-xb_hero_one .xb-hero_content .title {
        font-size: clamp(26px, 7vw, 42px) !important;
    }
}

/* ─── Services page (939): photo-topped service cards (matched maritime image · navy gold badge) ───── */
body.page-id-939 .gsy-svc2 {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
    max-width: 1180px; margin: 64px auto 16px; padding: 0 24px;
}
.gsy-svc2-card {
    position: relative; overflow: hidden; border-radius: 16px; background: #fff;
    box-shadow: 0 14px 34px rgba(10,43,80,.09);
    transition: transform .28s ease, box-shadow .28s ease;
}
.gsy-svc2-card:hover { transform: translateY(-7px); box-shadow: 0 30px 52px rgba(10,43,80,.2); }
.gsy-svc2-ph { position: relative; height: 178px; }
.gsy-svc2-ph img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.gsy-svc2-card:hover .gsy-svc2-ph img { transform: scale(1.07); }
.gsy-svc2-ph::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(6,32,59,.15), rgba(6,32,59,.82)); }
.gsy-svc2-ic {
    position: absolute; left: 20px; bottom: 16px; z-index: 2;
    display: inline-flex; align-items: center; justify-content: center;
    width: 46px; height: 46px; border-radius: 12px;
    background: #0a2b50; color: #e4c47d; border: 1px solid rgba(228,196,125,.5);
    box-shadow: 0 6px 16px rgba(0,0,0,.3);
}
.gsy-svc2-ic i { font-size: 20px; color: inherit; }
.gsy-svc2-ic svg { width: 21px; height: 21px; fill: currentColor; color: inherit; }
.gsy-svc2-ic .elementor-icon, .gsy-svc2-ic span { background: none !important; border: 0 !important; color: inherit !important; }
.gsy-svc2-ttl {
    position: absolute; left: 78px; bottom: 20px; right: 18px; z-index: 2; margin: 0;
    color: #fff; font-family: 'Playfair Display', Georgia, serif; font-weight: 600; font-size: 19px; line-height: 1.16;
}
.gsy-svc2-bd { padding: 20px 24px 26px; }
.gsy-svc2-tags { font: 600 11px/1 'Jost', sans-serif; letter-spacing: .08em; text-transform: lowercase; color: #5d738c; margin: 0 0 11px; }
.gsy-svc2-tags::before { content: "\2913\00a0"; color: #c9a24b; font-weight: 700; }
.gsy-svc2-desc { color: #54637a; font: 400 14px/1.65 'Jost', sans-serif; margin: 0; }
@media (max-width: 860px) { body.page-id-939 .gsy-svc2 { grid-template-columns: 1fr; gap: 18px; } }

/* ─── Services page (939): transparent-pricing checklist + testimonial card ──────────────────────── */
body.page-id-939 .gsy-pricing {
    max-width: 1180px; margin: 0 auto; padding: 56px 24px 64px;
    display: grid; grid-template-columns: 1.05fr .95fr; gap: 60px; align-items: center;
}
.gsy-pricing__left { position: relative; padding-left: 28px; }
.gsy-pricing__left::before { content: ""; position: absolute; left: 0; top: 6px; bottom: 6px; width: 3px; border-radius: 3px; background: linear-gradient(180deg, #14365c, #0a2b50); }
.gsy-pricing__eyebrow { display: block; font: 700 12px/1 'Jost', sans-serif; letter-spacing: .2em; text-transform: uppercase; color: #c9a24b; margin: 0 0 15px; }
.gsy-pricing__title { font-family: 'Playfair Display', Georgia, serif; font-weight: 600; font-size: clamp(28px, 3vw, 38px); line-height: 1.12; color: #0a2b50; margin: 0 0 20px; }
.gsy-pricing__lead { color: #5c6b7e; font: 400 15.5px/1.7 'Jost', sans-serif; margin: 0 0 26px; max-width: 46ch; }
.gsy-pricing__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.gsy-pricing__list li { display: flex; gap: 14px; align-items: flex-start; font: 400 15px/1.55 'Jost', sans-serif; color: #5c6b7e; }
.gsy-pricing__list .ck { flex: 0 0 auto; width: 22px; height: 22px; border-radius: 50%; background: #0a2b50; color: #e4c47d; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; margin-top: 1px; }
.gsy-pricing__list strong { color: #0a2b50; font-weight: 600; }
.gsy-pricing__quote { position: relative; background: #fff; border: 1px solid #eef2f7; border-radius: 16px; padding: 34px 38px 28px; box-shadow: 0 20px 48px rgba(10,43,80,.1); }
.gsy-pricing__qmark { display: block; font: 700 58px/.5 Georgia, serif; color: #0a2b50; margin: 6px 0 12px; }
.gsy-pricing__qtext { font-family: Georgia, 'Times New Roman', serif; font-style: italic; font-size: 18px; line-height: 1.62; color: #1c3b5e; margin: 0 0 24px; }
.gsy-pricing__by { display: flex; align-items: center; gap: 14px; padding-top: 20px; border-top: 1px solid #edf0f5; }
.gsy-pricing__avatar { flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%; background: linear-gradient(180deg, #0e2c4d, #0a2b50); color: #e4c47d; display: inline-flex; align-items: center; justify-content: center; font: 700 14px/1 'Jost', sans-serif; letter-spacing: .04em; }
.gsy-pricing__by div strong { display: block; color: #0a2b50; font: 600 15px/1.3 'Jost', sans-serif; }
.gsy-pricing__by div span { display: block; color: #8a98a8; font: 400 13px/1.3 'Jost', sans-serif; }
@media (max-width: 860px) { body.page-id-939 .gsy-pricing { grid-template-columns: 1fr; gap: 34px; } }

/* ===== Vessel Enquiry (CF7) — keep validation/result inside the card, no layout shift ===== */
/* The about row is bottom-aligned (align-items:flex-end), so a growing form pushed the right
   "Why Golden Shipyard" column down. Top-align it so the right column stays put on validation errors. */
.yt__about_us .row { align-items: flex-start !important; }
.xb-about-form { height: auto !important; overflow: visible !important; }

/* Field error tip: one compact line, in the field's own spacing */
.xb-about-form .wpcf7-form-control-wrap { position: relative; display: block; }
.xb-about-form .wpcf7-not-valid-tip { display: block; margin-top: 5px; font-size: 12.5px; line-height: 1.3; color: #d63638; }
/* safety net: never show more than one tip per field */
.xb-about-form .wpcf7-form-control-wrap .wpcf7-not-valid-tip ~ .wpcf7-not-valid-tip { display: none !important; }

/* Result banner: refined alert in the brand's navy + coral tone, shown inside the card only when CF7 has a state */
.xb-about-form .wpcf7-response-output { margin: 20px 0 0 !important; padding: 0 !important; border: 0 !important; background: none !important; }
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.unaccepted .wpcf7-response-output,
.wpcf7-form.payment-required .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output,
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output,
.wpcf7-form.sent .wpcf7-response-output {
    display: flex !important; align-items: center; gap: 13px;
    padding: 15px 18px !important;
    border: 0 !important; border-left: 3px solid !important;
    border-radius: 6px !important;
    color: #0a2b50 !important;
    font: 500 13.5px/1.45 'Jost', system-ui, sans-serif !important;
    letter-spacing: .2px;
    box-shadow: 0 16px 34px -24px rgba(10,43,80,.6);
}
/* icon badge: filled circle in the state accent, white glyph */
.xb-about-form .wpcf7-response-output::before {
    content: ""; flex: 0 0 auto; width: 30px; height: 30px; border-radius: 50%;
    background-position: center; background-repeat: no-repeat; background-size: 17px 17px;
}
/* validation — muted amber */
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.unaccepted .wpcf7-response-output,
.wpcf7-form.payment-required .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output { background: #fbf5ea !important; border-left-color: #d49a2a !important; }
.wpcf7-form.invalid .wpcf7-response-output::before,
.wpcf7-form.unaccepted .wpcf7-response-output::before,
.wpcf7-form.payment-required .wpcf7-response-output::before,
.wpcf7-form.spam .wpcf7-response-output::before { background-color: #d49a2a; background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M12 3 2.5 19.5h19L12 3Z'/><path d='M12 10v4'/><path d='M12 17.4h.01'/></svg>"); }
/* failed — muted red */
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.aborted .wpcf7-response-output { background: #fbf0ef !important; border-left-color: #c0392b !important; }
.wpcf7-form.failed .wpcf7-response-output::before,
.wpcf7-form.aborted .wpcf7-response-output::before { background-color: #c0392b; background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M18 6 6 18'/><path d='m6 6 12 12'/></svg>"); }
/* sent — on-brand coral */
.wpcf7-form.sent .wpcf7-response-output { background: #fdf3ef !important; border-left-color: #ef5a38 !important; }
.wpcf7-form.sent .wpcf7-response-output::before { background-color: #ef5a38; background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m5 12.5 4.2 4.2L19 7'/></svg>"); }

/* Showcase tabs ("Vessels built for every trade"): always show the vessel-type
   icon on the right of each tab. The theme leaves the after-icon img hidden /
   zero-width (a .wow reveal state); force it visible at a fixed size. */
.elementor-widget-xb_service .service__after_icon { display: inline-flex; align-items: center; flex: 0 0 auto; }
.elementor-widget-xb_service .service__after_icon img {
    visibility: visible !important;
    width: 52px !important;
    height: 52px !important;
    max-width: 52px !important;
    opacity: 1 !important;
}

/* Vessel detail "Similar vessels": relocated by JS from the enquiry sidebar to the
   bottom of .gsy-vd, then laid out here as a full-width card grid (image on top). */
.gsy-enq__recs.gsy-recs-bottom {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 22px !important;
    max-width: 1230px !important;       /* align with .gsy-vd content width */
    margin: 56px auto 0 !important;
    padding: 44px 18px 72px !important; /* bottom space so the button clears the footer */
    border-top: 1px solid #e6eaf0 !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__recs-h {
    grid-column: 1 / -1 !important;
    font-family: 'Laginchy', var(--font-heading), Georgia, serif !important;
    font-size: 26px !important;
    font-weight: 400 !important;
    letter-spacing: .01em !important;
    text-transform: none !important;
    color: #0A2B50 !important;
    margin: 0 0 6px !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__recs-all {
    grid-column: 1 / -1 !important;
    justify-self: center !important;
    display: inline-flex !important;
    align-items: center !important;
    margin-top: 32px !important;
    padding: 13px 32px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    letter-spacing: .03em !important;
    color: #0A2B50 !important;
    background: #fff !important;
    border: 1.5px solid #0A2B50 !important;
    border-radius: 40px !important;
    text-decoration: none !important;
    transition: background .25s ease, color .25s ease, box-shadow .25s ease, transform .25s ease !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__recs-all:hover {
    background: #0A2B50 !important;
    color: #fff !important;
    box-shadow: 0 14px 28px rgba(10, 43, 80, .22) !important;
    transform: translateY(-2px) !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__rec {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding: 0 !important;
    border: 1px solid #e6eaf0 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #fff !important;
    transition: transform .2s, box-shadow .2s, border-color .2s !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__rec:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 16px 32px rgba(10, 43, 80, .12) !important;
    border-color: #0A2B50 !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__rec img {
    width: 100% !important;
    height: 156px !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    flex: none !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__rec .gsy-enq__rec-t {
    font-size: 15px !important;
    line-height: 1.35 !important;
    color: #0A2B50 !important;
    padding: 15px 16px 17px !important;
}
.gsy-enq__recs.gsy-recs-bottom > .gsy-enq__rec:hover .gsy-enq__rec-t { color: #e75c2f !important; }
@media (max-width: 991px) {
    .gsy-enq__recs.gsy-recs-bottom { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 520px) {
    .gsy-enq__recs.gsy-recs-bottom { grid-template-columns: 1fr !important; }
}

/* Header top bar: email + WhatsApp icon links (replaced the email/hours text).
   Wrapped in a translucent navy badge so they stay clearly visible over both the
   dark home hero and the lighter inner-page banners. */
.header-style .header__top .gsy-topbar-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    margin-left: 14px !important;
    border-radius: 50% !important;
    background: rgba(10, 43, 80, .55) !important;
    border: 1px solid rgba(255, 255, 255, .35) !important;
    line-height: 0 !important;
    transition: background .2s ease, border-color .2s ease, transform .2s ease !important;
}
.header-style .header__top .gsy-topbar-link:first-child { margin-left: 0 !important; }
.header-style .header__top .gsy-topbar-link:hover {
    background: rgba(10, 43, 80, .9) !important;
    border-color: rgba(255, 255, 255, .7) !important;
    transform: translateY(-1px) !important;
}
.header-style .header__top .gsy-topbar-ico {
    width: 21px !important;
    height: 21px !important;
    display: block !important;
}
.header-style .header__top .gsy-topbar-link[aria-label="WhatsApp"] .gsy-topbar-ico { width: 22px !important; height: 22px !important; }

/* Enquiry card: email / WhatsApp icon before the matching ghost button label.
   Uses the SVG as a CSS mask so the icon takes the button's text colour. */
.gsy-enq__btn--ghost[href^="mailto:"]::before,
.gsy-enq__btn--ghost[href*="wa.me"]::before {
    content: "";
    flex: none;
    width: 18px;
    height: 18px;
    background-color: currentColor;
    -webkit-mask: center / contain no-repeat;
    mask: center / contain no-repeat;
}
.gsy-enq__btn--ghost[href^="mailto:"]::before {
    -webkit-mask-image: url("/wp-content/uploads/2026/06/gsy-ico-email.svg");
    mask-image: url("/wp-content/uploads/2026/06/gsy-ico-email.svg");
}
.gsy-enq__btn--ghost[href*="wa.me"]::before {
    width: 19px;
    height: 19px;
    -webkit-mask-image: url("/wp-content/uploads/2026/06/gsy-ico-whatsapp.svg");
    mask-image: url("/wp-content/uploads/2026/06/gsy-ico-whatsapp.svg");
}

/* Inner-page banner refinements: breadcrumb above the (smaller) title; the three
   feature items removed (button + divider + tagline kept). Banner style unchanged. */
.breadcrumb.bg_img .gsy-hero-features { display: none !important; }
.breadcrumb.bg_img .gsy-hero-crumb {
    display: flex;
    align-items: center;
    gap: 11px;
    font-size: 16px;
    letter-spacing: .1em;
    text-transform: uppercase;
    margin: 0 0 18px;
}
.breadcrumb.bg_img .gsy-hero-crumb a { color: rgba(255,255,255,.66); text-decoration: none; transition: color .2s ease; }
.breadcrumb.bg_img .gsy-hero-crumb a:hover { color: #fff; }
.breadcrumb.bg_img .gsy-hero-crumb .sep { color: #c9a24b; }
.breadcrumb.bg_img .gsy-hero-crumb .cur { color: #fff; }

/* Inner-page banner — beautification pass (style unchanged, detail polish only) */
.breadcrumb.bg_img .breadcrumb__title {
    text-shadow: 0 2px 30px rgba(2, 14, 30, .45);
    letter-spacing: .015em;
}
.breadcrumb.bg_img .breadcrumb__text { color: rgba(255, 255, 255, .85) !important; }
.breadcrumb.bg_img .gsy-hero-crumb a { display: inline-flex; align-items: center; gap: 6px; }
.breadcrumb.bg_img .gsy-hero-crumb a svg { width: 17px; height: 17px; opacity: .9; }
.breadcrumb.bg_img .gsy-hero-crumb a:hover { color: #e4c47d; }
.breadcrumb.bg_img .gsy-hero-crumb a:hover svg { opacity: 1; }
.breadcrumb.bg_img .gsy-hero-crumb .cur { font-weight: 500; }
/* a touch tighter vertical rhythm now that the feature row is gone */
.breadcrumb.bg_img .gsy-hero-divider { margin: 16px 0 16px; width: 360px; }
.breadcrumb.bg_img .gsy-hero-btn { margin-top: 28px; }

/* Vessel detail page banner: same treatment as inner pages — smaller title +
   breadcrumb (injected by the hero JS). Titles are long, so a touch smaller. */
body.single-yacty_yacht .breadcrumb.bg_img .breadcrumb__title {
    font-size: clamp(28px, 3.4vw, 46px) !important;
    line-height: 1.06 !important;
    text-transform: uppercase !important;
    max-width: 20ch !important;
}
body.single-yacty_yacht .breadcrumb.bg_img .breadcrumb__text { max-width: 40ch !important; }

/* Vessel detail banner: apply the SAME strong left-navy scrim as the inner pages
   (the generic .breadcrumb rule's gradient is too weak, so the title sat on bright
   sky). Keeps the vessel photo (--gsy-banner) on the right. */
body.single-yacty_yacht .breadcrumb.bg_img {
    background-image:
        linear-gradient(95deg, #06203b 0%, #06203b 20%, rgba(7,32,59,.82) 34%, rgba(7,32,59,.45) 50%, rgba(7,32,59,.14) 66%, rgba(7,32,59,0) 82%),
        linear-gradient(to top, rgba(6,32,59,.6) 0%, rgba(7,32,59,0) 12%),
        var(--gsy-banner) !important;
    background-size: cover, cover, cover !important;
    background-position: center, center, center right !important;
    background-repeat: no-repeat, no-repeat, no-repeat !important;
}
/* the breadcrumb now ends with the (long) vessel name — let it wrap tidily */
body.single-yacty_yacht .breadcrumb.bg_img .gsy-hero-crumb { flex-wrap: wrap; row-gap: 4px; }

/* Banner beautify (方案 A) — airier vertical rhythm so the title + copy breathe
   (more gap above/below the title, divider and button; relaxed tagline leading). */
.breadcrumb.bg_img .gsy-hero-crumb { margin-bottom: 30px !important; }
.breadcrumb.bg_img .gsy-hero-divider { margin: 26px 0 24px !important; width: 360px !important; }
.breadcrumb.bg_img .breadcrumb__text { line-height: 1.75 !important; }
.breadcrumb.bg_img .gsy-hero-btn { margin-top: 36px !important; }

/* ─── Markets We Serve map: reposition the pins onto our actual markets
   (W/E/S Africa, Egypt, Gulf, South Asia, SE Asia, LatAm). Overrides the
   theme's demo positions; left/top are % of the world-map.png. ─── */
.xb-destination-img .loc-img--1  { left: 41.5% !important; top: 57% !important; right: auto !important; bottom: auto !important; }  /* Senegal */
.xb-destination-img .loc-img--2  { left: 50.5% !important; top: 64% !important; right: auto !important; bottom: auto !important; }  /* Nigeria */
.xb-destination-img .loc-img--3  { left: 56.5% !important; top: 50% !important; right: auto !important; bottom: auto !important; }  /* Egypt */
.xb-destination-img .loc-img--4  { left: 59.5% !important; top: 72% !important; right: auto !important; bottom: auto !important; }  /* Tanzania */
.xb-destination-img .loc-img--5  { left: 55.5% !important; top: 83% !important; right: auto !important; bottom: auto !important; }  /* South Africa */
.xb-destination-img .loc-img--6  { left: 62%   !important; top: 53% !important; right: auto !important; bottom: auto !important; }  /* Saudi / UAE */
.xb-destination-img .loc-img--7  { left: 66.5% !important; top: 58% !important; right: auto !important; bottom: auto !important; }  /* India */
.xb-destination-img .loc-img--8  { left: 70%   !important; top: 54% !important; right: auto !important; bottom: auto !important; }  /* Bangladesh */
.xb-destination-img .loc-img--9  { left: 74.5% !important; top: 61% !important; right: auto !important; bottom: auto !important; }  /* Vietnam */
.xb-destination-img .loc-img--10 { left: 77%   !important; top: 73% !important; right: auto !important; bottom: auto !important; }  /* Indonesia */
.xb-destination-img .loc-img--11 { left: 79.5% !important; top: 59% !important; right: auto !important; bottom: auto !important; }  /* Philippines */
.xb-destination-img .loc-img--12 { left: 25%   !important; top: 57% !important; right: auto !important; bottom: auto !important; }  /* Colombia / LatAm */
/* flagcdn flags vary slightly in ratio — keep carousel tidy; the border keeps
   flags with white panels (Nigeria, Côte d'Ivoire …) readable on the white bg */
.destination-slider-item .xb-item--img img {
    width: 64px; height: 42px; object-fit: cover; border-radius: 4px;
    border: 1px solid rgba(10, 43, 80, .25);
    box-shadow: 0 2px 8px rgba(10, 43, 80, .12);
    background: #fff;
}

/* News list + article sidebar: keep it pinned in view while the page scrolls
   (sticky inside its column; offset clears the sticky header). */
.layout-right-sidebar aside.sidebar-area,
.layout-left-sidebar aside.sidebar-area {
    position: sticky;
    top: 120px;
}

/* Generic static pages (privacy policy, terms, …): same banner treatment as the
   other inner pages — top-aligned below the nav, smaller uppercase title. The
   page-specific rules above still win for the main pages. */
body.page .breadcrumb.bg_img {
    align-items: flex-start !important;
    padding-top: 185px !important;
}
body.page .breadcrumb__title {
    font-size: clamp(32px, 4vw, 52px);
    line-height: 1.02;
    text-transform: uppercase;
    max-width: 18ch;
}

/* Search banner polish: tighter height; styled tagline (gold count, serif query) */
body.search .breadcrumb.search-banner.bg_img { min-height: 460px !important; padding-bottom: 46px !important; }
body.search .breadcrumb__text { font-size: 18px !important; color: rgba(255,255,255,.85) !important; margin-top: 0 !important; }
/* pull the divider + tagline up into one tight group under the title */
body.search .gsy-hero-divider { margin: 18px 0 14px !important; }
body.search .breadcrumb__text .gsy-search-n { color: #e4c47d; font-weight: 600; font-size: 22px; }
body.search .breadcrumb__text .gsy-search-q { font-family: 'Playfair Display', Georgia, serif; font-style: italic; color: #fff; }

/* All banners: align the banner content with the page content below — the theme
   widens the banner container to 1630px while body sections use the standard
   ~1320px container, so titles sat further left than the content. */
.breadcrumb.bg_img > .container.mxw_1630 { max-width: 1320px !important; }

/* Legal pages (privacy policy 1961 / terms 1962): readable long-form layout —
   shorter banner, ~readable measure, relaxed leading, plain headings instead
   of the decorative display face. */
body.page-id-1961 .breadcrumb.bg_img,
body.page-id-1962 .breadcrumb.bg_img {
    min-height: 460px !important;
    padding-bottom: 46px !important;
}
body.page-id-1961 .entry-content,
body.page-id-1962 .entry-content {
    max-width: 800px;
    margin: 0 auto;
    font-size: 16.5px;
    line-height: 1.85;
    color: #3e4a59;
}
body.page-id-1961 .entry-content h2, body.page-id-1962 .entry-content h2,
body.page-id-1961 .entry-content h3, body.page-id-1962 .entry-content h3 {
    font-family: 'Jost', system-ui, sans-serif !important;
    font-weight: 600 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: #13315c;
}
body.page-id-1961 .entry-content h3, body.page-id-1962 .entry-content h3 {
    font-size: 22px;
    margin: 36px 0 10px;
}
body.page-id-1961 .entry-content p, body.page-id-1962 .entry-content p { margin-bottom: 16px; }
body.page-id-1961 .entry-content ul, body.page-id-1962 .entry-content ul { padding-left: 22px; margin-bottom: 18px; }
body.page-id-1961 .entry-content li, body.page-id-1962 .entry-content li { margin-bottom: 8px; }
body.page-id-1961 .entry-content a, body.page-id-1962 .entry-content a { color: #13315c; text-decoration: underline; }

/* Home "Everything you need" ship: a slight bow-up tilt so the vessel reads as
   under way rather than parked flat. */
.xb-service-boat .boart-image img {
    transform: rotate(-2.5deg);
    transform-origin: 55% 60%;
}

/* Home stats cards section: breathing room above and below the four cards */
.elementor-element-1f96f36 {
    padding-top: 90px !important;
    padding-bottom: 90px !important;
    background: #fff;
}

/* News article banner: keep it modest — the article body is the focus, not a giant
   hero. Shorter height, smaller title, tighter rhythm. */
body.single-post .breadcrumb.bg_img {
    min-height: 440px !important;
    padding-top: 170px !important;
    padding-bottom: 40px !important;
}
body.single-post .breadcrumb__title {
    font-size: clamp(28px, 3.2vw, 44px) !important;
    line-height: 1.08 !important;
    max-width: 20ch !important;
}
body.single-post .gsy-hero-divider { margin: 14px 0 12px !important; }
body.single-post .breadcrumb__text { font-size: 16px !important; }
body.single-post .gsy-hero-btn { margin-top: 22px !important; }
