/* ===========================================================
   Nerian Yachts — design tokens (from Stratos Greece guide)
   =========================================================== */
:root{
  --teal:#11434E;
  --teal-deep:#0C3038;
  --ink:#0A262C;
  --copper:#C79079;
  --copper-deep:#A86F57;
  --sand:#E9E2D6;
  --cream:#F6F2EA;
  --paper:#FAF7F1;

  --font-head: 'Cormorant Garamond', serif;
  --font-body: 'Hanken Grotesk', sans-serif;

  --content-w: 1280px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-body);
  font-weight:300;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head); font-weight:300; line-height:1.05; color:var(--teal);}
em{font-style:italic;}
.container{max-width:var(--content-w); margin:0 auto; padding:0 24px;}

.kicker{
  font-family:var(--font-body);
  font-weight:500;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.34em;
  color:var(--copper-deep);
}

.btn{
  display:inline-block;
  font-family:var(--font-body);
  font-weight:500;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.2em;
  background:var(--teal);
  color:#fff;
  border:none;
  padding:15px 38px;
  border-radius:0;
  cursor:pointer;
  transition:background .25s ease;
}
.btn:hover{background:var(--copper);}

section{padding:13vh 0;}
#home,#models,#sky,#interiors,#values,#enquire{scroll-margin-top:90px;}

/* ---------- reveal-on-scroll ---------- */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .9s ease, transform .9s ease;
}
.reveal.in-view{opacity:1; transform:translateY(0);}

/* never depend on JS for content to be visible: if scripts are blocked
   or fail to run, or the user prefers reduced motion, show everything
   immediately instead of leaving it stuck at opacity:0 */
.no-js .reveal{opacity:1; transform:none;}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1 !important; transform:none !important; transition:none !important;}
}

/* ===========================================================
   HEADER
   (nav classes below match WordPress's default wp_nav_menu()
   output: .menu-item-has-children on parent <li>, .sub-menu on
   the nested <ul> — no custom Walker needed)
   =========================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:22px 0;
  transition:background-color .35s ease, padding .35s ease, backdrop-filter .35s ease;
}
.site-header.scrolled{
  background-color:rgba(17,67,78,.96);
  backdrop-filter:blur(14px);
  padding:12px 0;
}
.header-inner{
  max-width:var(--content-w);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.logo-badge{
  display:inline-flex;
  align-items:center;
  background:#fff;
  border-radius:6px;
  padding:5px 10px;
  flex:0 0 auto;
  /* TODO: swap nerian-yachts-logo.jpg for a transparent SVG/PNG and remove this white chip */
}
.logo-badge img{height:34px; width:auto;}

.main-nav > ul{display:flex; align-items:center; gap:34px; list-style:none;}
.main-nav > ul > li{position:relative;}
.main-nav > ul > li > a{
  font-size:.78rem; font-weight:500; text-transform:uppercase; letter-spacing:.14em;
  color:#fff; display:flex; align-items:center; gap:4px;
  padding:8px 0;
}
.main-nav li.menu-item-has-children > a::after{content:"▾"; font-size:.7em; margin-left:2px;}

.sub-menu{
  position:absolute; top:100%; left:0;
  background:var(--paper);
  min-width:250px;
  padding:10px 0;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
  list-style:none;
  display:block;
  opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity .2s ease, transform .2s ease, visibility .2s;
}
.sub-menu li{width:100%;}
.menu-item-has-children:hover .sub-menu,
.menu-item-has-children.open .sub-menu{
  opacity:1; visibility:visible; transform:translateY(0);
}
.sub-menu li a{
  display:block; padding:11px 22px;
  font-size:.82rem; color:var(--ink); text-transform:none; letter-spacing:.02em;
  white-space:nowrap;
}
.sub-menu li a:hover{background:var(--cream); color:var(--copper-deep);}
/* Add a CSS class of "disabled" to a menu item (Appearance > Menus >
   Screen Options > CSS Classes) to grey it out, e.g. "Dutch Built 75"
   until real assets/pricing exist for it. WordPress puts custom
   classes on the <li>, not the <a>. */
.sub-menu li.disabled > a{color:#9aa; pointer-events:none;}

.btn-header{
  font-size:.72rem; padding:12px 26px;
  background:transparent; border:1px solid rgba(255,255,255,.55); color:#fff;
  flex:0 0 auto;
}
.btn-header:hover{background:var(--copper); border-color:var(--copper);}

.hamburger{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:32px; height:32px; background:none; border:none; cursor:pointer;
}
.hamburger span{display:block; width:100%; height:2px; background:#fff;}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative;
  min-height:100vh;
  background-size:cover; background-position:center;
  display:flex; align-items:flex-end; justify-content:flex-start;
  padding:0 7vw 13vh;
  color:#fff;
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(8,32,30,.55) 0%, rgba(8,32,30,.15) 45%, rgba(8,32,30,.75) 100%);
}
.hero-content{position:relative; max-width:760px;}
.hero h1{
  font-size:clamp(3.2rem, 9vw, 8.5rem);
  line-height:.94;
  color:#fff;
  margin:.3em 0 .35em;
}
.hero h1 em{color:var(--sand);}
.hero-sub{max-width:34ch; font-size:1.05rem; color:rgba(255,255,255,.88);}
.hero-meta{display:flex; gap:22px; margin-top:34px; flex-wrap:wrap;}
.hero-meta span{
  font-size:.72rem; text-transform:uppercase; letter-spacing:.12em;
  border-left:2px solid var(--copper); padding-left:10px;
}

/* ===========================================================
   STATEMENT
   =========================================================== */
.statement{background:var(--paper); text-align:center;}
.badge-line{display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:18px;}
.badge-line span{width:36px; height:1px; background:var(--copper);}
.statement h2{
  font-size:clamp(1.8rem,3.6vw,3.1rem);
  max-width:20ch; margin:14px auto 22px;
}
.statement h2 em{color:var(--copper-deep);}
.lead{max-width:58ch; margin:0 auto; color:rgba(10,38,44,.72); font-size:1.05rem;}

/* ===========================================================
   MODELS
   =========================================================== */
.models{background:var(--teal); color:var(--cream);}
.models-head{text-align:center; margin-bottom:60px;}
.models-head h2{color:var(--cream); margin-top:10px;}
.models-row{
  display:flex;
  border-top:1px solid rgba(233,226,214,.2);
}
.model-col{
  flex:1; padding:6vh 4vw; position:relative;
}
.model-col + .model-col{border-left:1px solid rgba(233,226,214,.2);}
.model-col--locked{opacity:.68;}
.badge{
  position:absolute; top:24px; right:24px;
  border:1px solid var(--copper); padding:5px 12px;
  font-size:.66rem; text-transform:uppercase; letter-spacing:.12em;
}
.badge--muted{border-color:rgba(233,226,214,.4); color:var(--sand);}
.model-outline{max-height:110px; display:flex; align-items:center; margin-bottom:24px; overflow:hidden; border-radius:4px;}
.model-outline img{
  width:100%; height:220px; object-fit:cover; object-position:top;
  filter:brightness(1.05);
}
.model-outline--placeholder{
  height:110px; width:100%; border:1px dashed rgba(233,226,214,.35);
  display:flex; align-items:center; justify-content:center;
}
.model-outline--placeholder p{font-size:.78rem; letter-spacing:.08em; color:var(--sand); text-transform:uppercase;}
.model-col h4{font-size:2.4rem; font-weight:400; color:#fff; margin-bottom:14px;}
.model-col p{color:rgba(233,226,214,.78); max-width:40ch; margin-bottom:20px;}
.mini-specs{display:flex; gap:18px; padding-top:14px; border-top:1px solid rgba(233,226,214,.2); flex-wrap:wrap;}
.mini-specs span{font-size:.78rem; text-transform:uppercase; letter-spacing:.06em; color:var(--copper);}

/* ===========================================================
   FEATURED · SKY
   =========================================================== */
.featured-sky{
  display:flex; min-height:86vh; padding:0; background:var(--cream);
}
.featured-media, .featured-text{flex:1 1 50%;}
.featured-media{position:relative; overflow:hidden;}
.featured-media img{width:100%; height:100%; object-fit:cover; transition:transform 1.4s;}
.featured-media:hover img{transform:scale(1.05);}
.media-badge{
  position:absolute; top:26px; left:26px;
  background:rgba(10,38,44,.55); backdrop-filter:blur(6px);
  color:#fff; padding:8px 16px; font-size:.68rem;
  text-transform:uppercase; letter-spacing:.1em;
}
.featured-text{
  padding:9vh 6vw; display:flex; flex-direction:column; justify-content:center;
}
.featured-text h2{font-size:clamp(2.6rem,5vw,4.4rem); margin:8px 0 4px;}
.model-sub{font-family:var(--font-head); font-style:italic; font-size:1.5rem; color:var(--copper-deep); margin-bottom:18px;}
.featured-text p{max-width:46ch; color:rgba(10,38,44,.78); margin-bottom:14px;}
.price-block{border-top:1px solid rgba(10,38,44,.15); margin:22px 0; padding-top:18px;}
.price-block h3{font-size:2.4rem; color:var(--teal);}
.price-block p{font-size:.82rem; color:rgba(10,38,44,.6); margin-top:4px;}

/* ===========================================================
   SPECS
   =========================================================== */
.specs{background:var(--ink); color:var(--cream);}
.specs-head{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:44px; flex-wrap:wrap; gap:10px;}
.specs-head h2{color:var(--cream);}
.specs-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:rgba(233,226,214,.13);
}
.spec-cell{background:var(--ink); padding:30px 24px; display:flex; flex-direction:column; gap:10px;}
.spec-cell .k{font-size:.64rem; text-transform:uppercase; letter-spacing:.1em; color:var(--copper);}
.spec-cell .v{font-family:var(--font-head); font-size:1.85rem; color:#fff;}
.specs-note{margin-top:24px; font-size:.76rem; color:rgba(233,226,214,.5);}

/* ===========================================================
   INTERIORS
   =========================================================== */
.interiors{background:var(--paper);}
.interiors-intro{text-align:center; max-width:60ch; margin:0 auto 12vh;}
.interiors-intro h2{margin:10px 0 16px;}
.interiors-row{
  display:flex; align-items:center; gap:6vw; margin-bottom:12vh;
}
.interiors-row--flip{flex-direction:row-reverse;}
.interiors-media{flex:1 1 50%; aspect-ratio:4/3; overflow:hidden;}
.interiors-media img{width:100%; height:100%; object-fit:cover; transition:transform 1.4s;}
.interiors-media:hover img{transform:scale(1.05);}
.interiors-text{flex:1 1 50%;}
.interiors-text h3{font-size:2rem; margin:8px 0 16px;}
.interiors-text p{max-width:44ch; color:rgba(10,38,44,.78); margin-bottom:16px;}
.partner-links{
  display:flex; flex-wrap:wrap; gap:14px; margin-top:22px; padding-top:18px;
  border-top:1px solid rgba(10,38,44,.15);
}
.partner-links a{
  font-size:.72rem; text-transform:uppercase; letter-spacing:.08em;
  color:var(--copper-deep); border-bottom:1px solid var(--copper-deep);
  padding-bottom:2px;
}
.partner-links a:hover{color:var(--teal); border-color:var(--teal);}

/* ===========================================================
   GALLERY
   =========================================================== */
.gallery{padding:0;}
.gallery-grid{display:grid; grid-template-columns:repeat(12,1fr); gap:0;}
.gallery-item{position:relative; height:46vh; overflow:hidden;}
.gallery-item img{width:100%; height:100%; object-fit:cover; transition:transform 1.4s;}
.gallery-item:hover img{transform:scale(1.05);}
.gallery-item .caption{
  position:absolute; bottom:18px; left:20px; color:#fff;
  font-size:.72rem; text-transform:uppercase; letter-spacing:.1em;
  text-shadow:0 2px 10px rgba(0,0,0,.6);
}
.span-7{grid-column:span 7;}
.span-5{grid-column:span 5;}

/* ===========================================================
   VALUES
   =========================================================== */
.values{background:var(--cream); text-align:center;}
.values-head h2{max-width:22ch; margin:10px auto 60px;}
.values-row{display:flex; gap:50px; text-align:left;}
.value-col{flex:1;}
.num{
  display:block; font-family:var(--font-head); font-size:1.3rem; color:var(--copper-deep);
  padding-bottom:12px; margin-bottom:16px; border-bottom:1px solid rgba(10,38,44,.15);
}
.value-col h5{font-size:1.5rem; font-weight:400; margin-bottom:10px;}
.value-col p{color:rgba(10,38,44,.72);}

/* ===========================================================
   ENQUIRE
   =========================================================== */
.enquire{
  position:relative; background-size:cover; background-position:center;
  padding:15vh 0; text-align:center; color:#fff;
}
.enquire-overlay{position:absolute; inset:0; background:#081C1E; opacity:.76;}
.enquire-content{position:relative; max-width:560px; margin:0 auto; padding:0 24px;}
.enquire-content h2{color:#fff; margin:10px 0 16px;}
.enquire-content p{color:rgba(255,255,255,.82); margin-bottom:34px;}
.enquire-form{text-align:left;}
.form-row{display:flex; gap:16px; margin-bottom:16px;}
.enquire-form input, .enquire-form select, .enquire-form textarea{
  width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.25);
  color:#fff; padding:14px 16px; font-family:var(--font-body); font-size:.9rem;
  margin-bottom:16px;
}
.enquire-form input::placeholder, .enquire-form textarea::placeholder{color:rgba(255,255,255,.5);}
.enquire-form input:focus, .enquire-form select:focus, .enquire-form textarea:focus{
  outline:none; border-color:var(--copper);
}
.enquire-form select option{color:#000;}
.enquire-form .btn{width:100%; border:none;}

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer{background:var(--teal-deep); color:rgba(233,226,214,.7); padding-top:9vh;}
.footer-top{display:flex; gap:60px; padding-bottom:6vh;}
.footer-brand{flex:2;}
.footer-logo{height:30px; margin-bottom:16px; background:#fff; padding:5px 8px; border-radius:6px; display:inline-block;}
.footer-brand p:last-child{max-width:42ch; margin-top:10px;}
.footer-col{flex:1; display:flex; flex-direction:column; gap:12px;}
.footer-col h6{color:var(--sand); font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; margin-bottom:6px;}
.footer-col a:hover{color:var(--copper);}
.footer-bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  border-top:1px solid rgba(233,226,214,.15);
  padding:26px 24px 40px;
  font-size:.76rem;
}
.footer-bottom .tagline{font-family:var(--font-head); font-style:italic; font-size:1rem; color:var(--sand);}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width: 900px){
  .main-nav{
    position:fixed; top:0; right:-100%; width:80%; max-width:340px; height:100vh;
    background:var(--teal-deep); padding:110px 32px 40px;
    transition:right .35s ease; overflow-y:auto;
  }
  .main-nav.open{right:0;}
  .main-nav > ul{flex-direction:column; align-items:flex-start; gap:6px;}
  .main-nav > ul > li{width:100%;}
  .main-nav > ul > li > a{padding:14px 0; width:100%;}
  .sub-menu{
    position:static; opacity:1; visibility:visible; transform:none;
    box-shadow:none; background:transparent; display:none; padding:0 0 0 14px;
  }
  .menu-item-has-children.open .sub-menu{display:block;}
  .sub-menu li a{color:var(--sand); padding:10px 0;}
  .btn-header{display:none;}
  .hamburger{display:flex;}

  .models-row{flex-direction:column;}
  .model-col + .model-col{border-left:none; border-top:1px solid rgba(233,226,214,.2);}

  .featured-sky{flex-direction:column;}
  .featured-media{aspect-ratio:4/3;}

  .specs-grid{grid-template-columns:repeat(2,1fr);}

  .interiors-row, .interiors-row--flip{flex-direction:column;}
  .interiors-media{width:100%;}

  .gallery-item{grid-column:span 12 !important; height:38vh;}

  .values-row{flex-direction:column; gap:34px;}

  .form-row{flex-direction:column; gap:0;}

  .footer-top{flex-direction:column; gap:34px;}
}
