:root {
  --ink: #111310;
  --paper: #f7f7f4;
  --line: #d8d9d4;
  --muted: #666a63;
  --signal: #e5ff16;
  --page: min(1280px, calc(100vw - 48px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fff; font-family: Arial, Helvetica, sans-serif; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, select { color: inherit; font: inherit; }
button { cursor: pointer; }
img { display: block; max-width: 100%; }
svg { width: 18px; fill: none; stroke: currentColor; stroke-width: 1.6; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.eyebrow { margin: 0 0 14px; font-size: 11px; font-weight: 700; letter-spacing: .14em; line-height: 1.2; text-transform: uppercase; }

.announcement {
  padding: 7px 24px;
  color: white;
  background: var(--ink);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-align: center;
  text-transform: uppercase;
}

.site-header {
  position: sticky;
  z-index: 20;
  top: 0;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  width: 100%;
  min-height: 66px;
  padding: 0 max(24px, calc((100vw - 1280px) / 2));
  border-bottom: 1px solid #e5e6e1;
  background: rgba(255,255,255,.97);
}
.brand { display: inline-flex; align-items: center; justify-self: start; }
.brand-mark { width: 55px; height: 31px; object-fit: contain; }
.desktop-nav { display: flex; align-self: stretch; align-items: center; gap: 31px; }
.desktop-nav a { position: relative; display: flex; align-items: center; height: 100%; font-size: 12px; font-weight: 700; text-transform: uppercase; }
.desktop-nav a::after { position: absolute; right: 0; bottom: -1px; left: 0; height: 2px; background: var(--ink); content: ""; opacity: 0; transform: scaleX(.3); transition: .2s ease; }
.desktop-nav a:hover::after, .desktop-nav a.active::after { opacity: 1; transform: scaleX(1); }
.header-actions { display: flex; align-items: center; justify-self: end; gap: 13px; }
.language-switcher { width: 104px; padding: 8px 25px 8px 9px; border: 1px solid var(--line); border-radius: 0; background: white; font-size: 11px; }
.icon-link, .menu-button, .menu-close { display: grid; width: 37px; height: 37px; place-items: center; border: 0; background: transparent; }
.menu-button { display: none; }

.home-hero { position: relative; height: min(800px, calc(100vh - 96px)); min-height: 580px; overflow: hidden; color: white; background: #171a15; }
.home-hero-image { width: 100%; height: 100%; object-fit: cover; object-position: center 34%; transition: transform 1.2s ease; }
.home-hero:hover .home-hero-image { transform: scale(1.015); }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.7) 0, rgba(0,0,0,.22) 50%, rgba(0,0,0,.03)), linear-gradient(0deg, rgba(0,0,0,.36), transparent 45%); }
.home-hero-copy { position: absolute; bottom: clamp(50px, 9vw, 120px); left: max(24px, calc((100vw - 1280px) / 2)); width: min(620px, calc(100vw - 48px)); }
.home-hero h1 { max-width: 620px; margin: 0 0 22px; font-size: clamp(45px, 6vw, 86px); font-weight: 500; letter-spacing: -.065em; line-height: .94; }
.home-hero-copy > p:not(.eyebrow) { max-width: 490px; margin: 0 0 29px; font-size: 16px; line-height: 1.5; }
.button-row { display: flex; flex-wrap: wrap; gap: 8px; }
.button { display: inline-flex; min-height: 48px; padding: 0 19px; align-items: center; justify-content: center; gap: 18px; border: 1px solid transparent; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; transition: .2s ease; }
.button:hover { gap: 25px; }
.button-light { color: var(--ink); background: white; }
.button-ghost { border-color: rgba(255,255,255,.65); color: white; background: transparent; }
.button-dark { color: white; background: var(--ink); }
.button-wide { width: 100%; margin: 20px 0 12px; }
.proof-row { display: grid; grid-template-columns: repeat(3, 1fr); width: var(--page); margin: auto; padding: 17px 0; border-bottom: 1px solid var(--line); gap: 20px; font-size: 10px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; }
.proof-row span:nth-child(2) { text-align: center; }
.proof-row span:last-child { text-align: right; }

.page-section { width: var(--page); margin: 0 auto; padding: 110px 0; }
.section-heading { display: grid; grid-template-columns: 1fr 1fr; align-items: end; margin-bottom: 35px; gap: 30px; }
.section-heading h2, .editorial-copy h2, .material-feature h2 { margin: 0; font-size: clamp(36px, 4.8vw, 72px); font-weight: 500; letter-spacing: -.055em; line-height: .98; }
.section-heading > p { max-width: 480px; margin: 0; color: var(--muted); font-size: 14px; line-height: 1.55; }
.category-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.category-card { position: relative; min-height: 570px; overflow: hidden; color: white; background: #171a15; }
.category-card > img { width: 100%; height: 100%; object-fit: cover; transition: transform .65s cubic-bezier(.2,.7,.2,1); }
.category-card:hover > img { transform: scale(1.035); }
.card-shade { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.85), rgba(0,0,0,.02) 70%); }
.category-card-copy { position: absolute; right: 22px; bottom: 22px; left: 22px; display: flex; flex-direction: column; }
.category-card-copy small { margin-bottom: 8px; font-size: 10px; font-style: normal; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.category-card-copy strong { font-size: 27px; font-weight: 600; letter-spacing: -.04em; }
.category-card-copy em { min-height: 38px; margin-top: 7px; color: rgba(255,255,255,.78); font-size: 12px; font-style: normal; line-height: 1.45; }
.category-card-copy b { display: flex; margin-top: 18px; align-items: center; gap: 8px; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }
.category-card-copy b svg { width: 15px; transition: transform .2s; }
.category-card:hover b svg { transform: translateX(5px); }

.editorial-grid { display: grid; grid-template-columns: 1.3fr .7fr; min-height: 750px; background: var(--paper); }
.editorial-image { min-height: 650px; overflow: hidden; }
.editorial-image img { width: 100%; height: 100%; object-fit: cover; object-position: center 38%; }
.editorial-copy { display: flex; padding: clamp(40px, 7vw, 105px); flex-direction: column; align-items: flex-start; justify-content: center; }
.editorial-copy p:not(.eyebrow), .material-feature p:not(.eyebrow) { color: var(--muted); font-size: 14px; line-height: 1.65; }
.text-link { display: flex; margin-top: 20px; align-items: center; gap: 12px; font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.material-feature { position: relative; display: grid; height: 680px; color: white; place-items: center; overflow: hidden; text-align: center; background: #111; }
.material-feature > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .58; }
.material-feature > div { position: relative; width: min(600px, calc(100vw - 48px)); }
.material-feature p:not(.eyebrow) { color: rgba(255,255,255,.75); }

.page-width { width: var(--page); margin: 0 auto; }
.collection-page { padding-bottom: 110px; }
.breadcrumbs { display: flex; padding: 26px 0 22px; align-items: center; gap: 8px; border-bottom: 1px solid var(--line); font-size: 10px; }
.breadcrumbs a { text-decoration: underline; text-underline-offset: 3px; }
.breadcrumbs strong { font-weight: 500; }
.collection-title { display: grid; grid-template-columns: 1fr 1fr; align-items: end; padding: 42px 0 27px; gap: 30px; }
.collection-title .eyebrow { grid-column: 1 / -1; margin-bottom: -12px; }
.collection-title h1 { margin: 0; font-size: clamp(45px, 6vw, 80px); font-weight: 500; letter-spacing: -.065em; line-height: .95; }
.collection-title > p:last-child { max-width: 440px; margin: 0 0 5px; color: var(--muted); font-size: 13px; line-height: 1.55; }
.category-cards-compact .category-card { min-height: 410px; }
.category-cards-compact .category-card-copy em { display: none; }
.filter-row { display: flex; margin: 35px 0 23px; align-items: center; border-block: 1px solid var(--line); overflow-x: auto; }
.filter-row strong, .filter-row button { min-height: 49px; padding: 0 15px; flex: 0 0 auto; border: 0; border-right: 1px solid var(--line); background: transparent; font-size: 11px; font-weight: 700; }
.filter-row button { display: flex; align-items: center; gap: 8px; }
.filter-row svg { width: 13px; }
.filter-row .sort-button { margin-left: auto; border-right: 0; border-left: 1px solid var(--line); }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.product-card { display: flex; min-width: 0; flex-direction: column; }
.product-image { position: relative; display: block; aspect-ratio: .78; overflow: hidden; background: var(--paper); }
.product-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.product-card:hover .product-image img { transform: scale(1.025); }
.product-image b { position: absolute; top: 10px; left: 10px; padding: 6px 7px; background: white; font-size: 8px; letter-spacing: .08em; text-transform: uppercase; }
.product-meta { display: flex; padding: 14px 2px 25px; flex-direction: column; }
.product-meta small { color: var(--muted); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; }
.product-meta strong { margin: 8px 0 5px; font-size: 14px; }
.product-meta em { color: var(--muted); font-size: 10px; font-style: normal; }
.product-price { margin-top: 12px; font-size: 13px; font-weight: 700; }
.product-meta span { margin-top: 12px; color: var(--muted); font-size: 11px; line-height: 1.4; }

.product-page { padding-bottom: 0; }
.product-layout { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(320px, .75fr); align-items: start; gap: 44px; }
.product-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px; }
.gallery-item { padding: 0; border: 0; aspect-ratio: .78; overflow: hidden; background: var(--paper); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s; }
.gallery-item:hover img { transform: scale(1.02); }
.product-panel { position: sticky; top: 100px; padding: 42px 0 60px; }
.product-panel h1 { margin: 0; font-size: clamp(42px, 4.5vw, 66px); font-weight: 500; letter-spacing: -.06em; line-height: .98; }
.product-intro, .product-panel > p:not(.eyebrow) { color: var(--muted); font-size: 12px; line-height: 1.55; }
.product-intro { margin: 20px 0 27px; }
.product-main-price { display: flex; margin: 0 0 25px; flex-direction: column; align-items: flex-start; }
.product-main-price small { margin-bottom: 6px; color: var(--muted); font-size: 9px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.product-main-price strong { font-size: 29px; font-weight: 500; letter-spacing: -.04em; }
.product-main-price span { margin-top: 5px; color: var(--muted); font-size: 9px; }
.product-rule { height: 1px; margin: 0 0 22px; background: var(--line); }
.inquiry { font-size: 13px; }
.colour-row { display: flex; margin: 19px 0 4px; gap: 7px; }
.colour-row button { width: 27px; height: 27px; border: 4px solid white; outline: 1px solid var(--line); border-radius: 50%; }
.colour-row button.active { outline-color: var(--ink); }
.colour-row .red { background: #d83b22; }.colour-row .blue { background: #164b76; }.colour-row .yellow { background: #dff315; }.colour-row .sand { background: #cfbe9b; }
.accordion-list { border-top: 1px solid var(--line); }
.accordion-list details { border-bottom: 1px solid var(--line); }
.accordion-list summary { display: flex; padding: 17px 0; align-items: center; justify-content: space-between; font-size: 11px; font-weight: 700; letter-spacing: .06em; list-style: none; text-transform: uppercase; }
.accordion-list summary::-webkit-details-marker { display: none; }
.accordion-list summary svg { width: 14px; transition: transform .2s; }
.accordion-list details[open] summary svg { transform: rotate(180deg); }
.accordion-list p, .accordion-list ul { margin: 0 0 18px; color: var(--muted); font-size: 11px; line-height: 1.55; }
.accordion-list ul { padding-left: 17px; }
.related-section { padding-top: 135px; }

.bestsellers-section { padding: 105px max(24px, calc((100vw - 1280px) / 2)); overflow: hidden; background: #fff; }
.carousel-heading { display: flex; margin-bottom: 28px; align-items: end; justify-content: space-between; gap: 30px; }
.carousel-heading h2 { margin: 0; font-size: clamp(38px, 4.8vw, 70px); font-weight: 500; letter-spacing: -.055em; line-height: .98; }
.carousel-heading p { max-width: 470px; margin: 12px 0 0; color: var(--muted); font-size: 13px; line-height: 1.55; }
.carousel-controls { display: flex; gap: 8px; }
.carousel-controls button { display: grid; width: 49px; height: 49px; padding: 0; border: 0; border-radius: 50%; background: #e9edf0; place-items: center; transition: background .2s, transform .2s; }
.carousel-controls button:hover { background: #dfe4e7; transform: translateY(-2px); }
.carousel-controls svg { width: 20px; }
.bestseller-track { display: grid; grid-auto-columns: minmax(250px, 22vw); grid-auto-flow: column; gap: 14px; padding-bottom: 5px; overflow-x: auto; scroll-behavior: smooth; scroll-snap-type: x mandatory; scrollbar-width: none; }
.bestseller-track::-webkit-scrollbar { display: none; }
.bestseller-card { display: flex; min-width: 0; flex-direction: column; scroll-snap-align: start; }
.bestseller-image { position: relative; display: block; aspect-ratio: .86; overflow: hidden; background: #f0f1ef; }
.bestseller-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.bestseller-card:hover .bestseller-image img { transform: scale(1.025); }
.bestseller-image b { position: absolute; top: 10px; left: 10px; padding: 6px 8px; border-radius: 2px; background: white; font-size: 9px; letter-spacing: .08em; text-transform: uppercase; }
.colour-dots { display: flex; min-height: 19px; margin: 13px 0 9px; align-items: center; gap: 7px; }
.dot { width: 17px; height: 17px; border: 3px solid white; border-radius: 50%; box-shadow: 0 0 0 1px #d5d7d2; }
.bestseller-card > strong { font-size: 13px; line-height: 1.35; }
.bestseller-card .price { margin-top: 8px; color: var(--muted); font-size: 12px; }
.bestseller-card small { margin-top: 8px; color: var(--muted); font-size: 10px; }
.stars { color: #252923; font-size: 11px; letter-spacing: 1px; }
.carousel-progress { height: 3px; margin-top: 22px; background: #e2e3df; }
.carousel-progress span { display: block; width: 55%; height: 100%; background: #4c504a; }

.sailing-story { position: relative; height: 720px; overflow: hidden; color: white; background: #13202a; }
.sailing-story > img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.sailing-story::after { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.7), rgba(0,0,0,.03) 70%), linear-gradient(0deg, rgba(0,0,0,.35), transparent 45%); content: ""; }
.sailing-story > div { position: absolute; z-index: 1; bottom: clamp(45px, 8vw, 100px); left: max(24px, calc((100vw - 1280px) / 2)); width: min(570px, calc(100vw - 48px)); }
.sailing-story h2, .reflective-copy h2, .policy-hero h1 { margin: 0; font-size: clamp(42px, 5.8vw, 82px); font-weight: 500; letter-spacing: -.06em; line-height: .96; }
.sailing-story p:not(.eyebrow) { max-width: 460px; margin: 22px 0 28px; color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.6; }
.reflective-story { display: grid; grid-template-columns: .72fr 1.28fr; min-height: 700px; background: var(--paper); }
.reflective-story > div:last-child { min-height: 700px; overflow: hidden; }
.reflective-story > div:last-child img { width: 100%; height: 100%; object-fit: cover; }
.reflective-copy { display: flex; padding: clamp(45px, 7vw, 105px); flex-direction: column; align-items: flex-start; justify-content: center; }
.reflective-copy p:not(.eyebrow) { margin: 22px 0 7px; color: var(--muted); font-size: 14px; line-height: 1.65; }

.policy-page { width: var(--page); margin: 0 auto; padding: 35px 0 110px; }
.policy-hero { max-width: 860px; padding: 70px 0 60px; }
.policy-hero p:not(.eyebrow) { max-width: 700px; margin: 25px 0 0; color: var(--muted); font-size: 14px; line-height: 1.7; }
.policy-body { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--line); }
.policy-body section { padding: 35px 35px 35px 0; border-bottom: 1px solid var(--line); }
.policy-body section:nth-child(even) { padding-right: 0; padding-left: 35px; border-left: 1px solid var(--line); }
.policy-body h2 { margin: 0 0 15px; font-size: 20px; letter-spacing: -.025em; }
.policy-body p, .policy-body li { color: var(--muted); font-size: 12px; line-height: 1.7; }
.policy-body ul { margin: 0; padding-left: 17px; }
.policy-body a { text-decoration: underline; text-underline-offset: 3px; }

.image-dialog { width: min(920px, calc(100vw - 30px)); padding: 0; border: 0; background: #eee; }
.image-dialog::backdrop { background: rgba(0,0,0,.82); }
.image-dialog img { width: 100%; max-height: 88vh; object-fit: contain; }
.dialog-close { position: absolute; z-index: 2; top: 10px; right: 10px; display: grid; width: 42px; height: 42px; place-items: center; border: 0; background: white; }
.image-error { background: #f5dddd !important; }

.site-footer { position: relative; display: grid; grid-template-columns: 2fr repeat(3, 1fr); padding: 65px max(24px, calc((100vw - 1280px) / 2)) 95px; color: white; background: var(--ink); gap: 40px; }
.site-footer > div { display: flex; flex-direction: column; align-items: flex-start; gap: 12px; }
.site-footer strong { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }
.site-footer a, .site-footer p { margin: 0; color: #afb2aa; font-size: 11px; line-height: 1.55; }
.footer-brand strong { font-size: 25px; }
.footer-brand img { width: 88px; height: 50px; object-fit: contain; }
.footer-brand p { max-width: 250px; }
.site-footer small { position: absolute; right: max(24px, calc((100vw - 1280px) / 2)); bottom: 25px; color: #777b74; font-size: 9px; }
.mobile-menu, .menu-scrim { display: none; }

@media (max-width: 980px) {
  :root { --page: min(100% - 32px, 720px); }
  .site-header { grid-template-columns: 1fr auto; padding: 0 16px; }
  .desktop-nav, .header-actions .language-label, .header-actions .icon-link { display: none; }
  .menu-button { display: grid; }
  .mobile-menu { position: fixed; z-index: 50; top: 0; right: 0; display: flex; width: min(390px, 92vw); height: 100dvh; padding: 22px; flex-direction: column; background: white; transform: translateX(102%); transition: transform .3s ease; }
  .mobile-menu.open { transform: translateX(0); }
  .mobile-menu-top { display: flex; align-items: center; justify-content: space-between; }
  .mobile-menu-top strong { letter-spacing: .14em; }
  .mobile-menu nav { display: flex; margin-top: 55px; flex-direction: column; border-top: 1px solid var(--line); }
  .mobile-menu nav a { display: flex; padding: 19px 0; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); font-size: 16px; }
  .mobile-language { width: 100%; margin-top: auto; }
  .menu-scrim { position: fixed; z-index: 40; inset: 0; display: block; visibility: hidden; background: rgba(0,0,0,.45); opacity: 0; transition: .3s; }
  .menu-scrim.open { visibility: visible; opacity: 1; }
  .home-hero { min-height: 650px; }
  .category-cards, .product-grid { grid-template-columns: repeat(2, 1fr); }
  .category-card:last-child { grid-column: 1 / -1; }
  .category-card { min-height: 490px; }
  .category-card:last-child { aspect-ratio: 1.45; min-height: 400px; }
  .editorial-grid { grid-template-columns: 1fr; }
  .editorial-image { min-height: 650px; }
  .editorial-copy { padding: 70px 30px; }
  .bestseller-track { grid-auto-columns: minmax(260px, 42vw); }
  .reflective-story { grid-template-columns: 1fr; }
  .reflective-story > div:last-child { min-height: 620px; }
  .reflective-copy { padding: 75px 30px; }
  .product-layout { grid-template-columns: 1fr; }
  .product-panel { position: static; max-width: 650px; padding: 40px 0 80px; }
  .site-footer { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  :root { --page: calc(100% - 24px); }
  .announcement { padding-inline: 10px; font-size: 8px; }
  .site-header { min-height: 58px; }
  .brand-mark { width: 27px; height: 27px; }
  .home-hero { height: calc(100svh - 84px); min-height: 590px; }
  .home-hero-image { object-position: 54% center; }
  .home-hero h1 { font-size: clamp(45px, 15vw, 65px); }
  .home-hero-copy { bottom: 34px; left: 16px; width: calc(100vw - 32px); }
  .button-row { flex-direction: column; align-items: stretch; }
  .proof-row { grid-template-columns: 1fr; gap: 8px; }
  .proof-row span, .proof-row span:nth-child(2), .proof-row span:last-child { text-align: left; }
  .page-section { padding: 70px 0; }
  .section-heading, .collection-title { grid-template-columns: 1fr; }
  .section-heading h2, .editorial-copy h2, .material-feature h2 { font-size: 45px; }
  .bestsellers-section { padding: 70px 12px; }
  .carousel-heading { align-items: flex-end; }
  .carousel-heading p { display: none; }
  .carousel-controls button { width: 43px; height: 43px; }
  .bestseller-track { grid-auto-columns: 78vw; }
  .sailing-story { height: 600px; }
  .sailing-story h2, .reflective-copy h2, .policy-hero h1 { font-size: 48px; }
  .reflective-story > div:last-child { min-height: 450px; }
  .reflective-copy { padding: 65px 20px; }
  .policy-page { padding-bottom: 75px; }
  .policy-hero { padding: 50px 0 40px; }
  .policy-body { grid-template-columns: 1fr; }
  .policy-body section, .policy-body section:nth-child(even) { padding: 27px 0; border-left: 0; }
  .category-cards, .product-grid { grid-template-columns: 1fr; }
  .category-card, .category-cards-compact .category-card, .category-card:last-child { grid-column: auto; aspect-ratio: .82; min-height: 0; }
  .category-card-copy { right: 15px; bottom: 17px; left: 15px; }
  .editorial-image { min-height: 520px; }
  .material-feature { height: 580px; }
  .breadcrumbs { white-space: nowrap; overflow-x: auto; }
  .collection-title { padding-top: 32px; }
  .collection-title .eyebrow { grid-column: auto; margin-bottom: -10px; }
  .filter-row { margin-top: 25px; }
  .filter-row .sort-button { margin-left: 0; }
  .product-gallery { grid-template-columns: 1fr 1fr; gap: 2px; }
  .product-panel h1 { font-size: 47px; }
  .related-section { padding-top: 80px; }
  .site-footer { grid-template-columns: 1fr 1fr; padding: 50px 20px 85px; gap: 35px 20px; }
  .footer-brand { grid-column: 1 / -1; }
  .site-footer small { right: 20px; }
}
