/*
Theme Name: NauticScale — Linssen Marina Premium Presence Network
Theme URI: https://nauticscale.com
Author: NauticScale
Author URI: https://nauticscale.com
Description: One-page landing page for the Linssen Marina Premium Presence Network. Navy/cream/brass design, ACF-ready image fields, language switcher to .com / .nl.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: nauticscale
*/

/* ============================================================
   NAUTICSCALE × LINSSEN — Marina Premium Presence Network
   Palette: navy #2E4C64 · cream #F1EACF · brass #BFA15C
   ============================================================ */

:root{
  --navy:#2E4C64;
  --navy-700:#264056;
  --navy-deep:#1B2F3F;
  --cream:#F1EACF;
  --cream-soft:#F8F4E6;
  --brass:#F1EACF;
  --brass-dark:#8C6F33;
  --brass-line:#C9AE6B;
  --ink:#1F2E39;
  --ink-soft:#465562;
  --white:#FFFFFF;
  --line:#E5DFC9;        /* warm hairline */
  --line-cool:#D5DCE2;   /* cool hairline */
  --line-onnavy:rgba(241,234,207,.22);

  --font-display:'Archivo',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;

  --maxw:1240px;
  --gut:clamp(20px,5vw,72px);
  --sect:clamp(72px,9vw,128px);
  --r:4px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- shared layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.section{padding-top:var(--sect);padding-bottom:var(--sect)}
.section--cream{background:var(--cream-soft)}
.section--navy{background:var(--navy);color:var(--cream)}

/* eyebrow / technical label */
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--brass-dark);
  display:inline-flex;align-items:center;gap:.7em;
  font-weight:500;
}
.eyebrow::before{
  content:"";width:34px;height:1px;background:var(--brass-line);display:inline-block;
}
.section--navy .eyebrow{color:var(--brass-line)}
.section--navy .eyebrow::before{background:var(--brass-line);opacity:.7}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.05;letter-spacing:-.02em;color:var(--navy)}
.section--navy h1,.section--navy h2,.section--navy h3{color:var(--cream)}
h2{font-size:clamp(2rem,4.2vw,3.3rem);margin-top:.5rem}
.lead{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--ink-soft);max-width:60ch}
.section--navy .lead{color:rgba(241,234,207,.78)}

/* dimension marker — the signature motif */
.dim{
  display:inline-flex;align-items:center;gap:0;font-family:var(--font-mono);
  font-size:.7rem;letter-spacing:.12em;color:var(--brass-dark);
}
.dim__rule{position:relative;height:1px;background:var(--brass-line);flex:1 1 auto}
.dim__rule::before,.dim__rule::after{content:"";position:absolute;top:-4px;width:1px;height:9px;background:var(--brass-line)}
.dim__rule::before{left:0}.dim__rule::after{right:0}
.dim__val{padding:0 .85em;white-space:nowrap}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-mono);font-size:.82rem;font-weight:500;letter-spacing:.04em;
  padding:.95em 1.6em;border-radius:var(--r);border:1px solid transparent;
  transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease;
}
.btn:focus-visible{outline:2px solid var(--brass);outline-offset:3px}
.btn--brass{background:var(--brass);color:var(--navy-deep);font-weight:600}
.btn--brass:hover{background:var(--brass-line);transform:translateY(-2px)}
.btn--navy{background:var(--navy);color:var(--cream)}
.btn--navy:hover{background:var(--navy-700);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line-cool)}
.btn--ghost:hover{border-color:var(--navy);transform:translateY(-2px)}
.section--navy .btn--ghost{color:var(--cream);border-color:var(--line-onnavy)}
.section--navy .btn--ghost:hover{border-color:var(--cream)}
.btn__arrow{transition:transform .18s ease}
.btn:hover .btn__arrow{transform:translateX(3px)}

/* ---------- nav ---------- */
.site-header__logo{display:inline-flex;align-items:center;line-height:0}
.site-header__logo img{
  width:auto;
  height:auto;
  max-width:auto;   /* ~100px wide cap */
  max-height:72px;   /* keeps it inside the 72px bar, no distortion */
  display:block;
}

.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .3s ease,box-shadow .3s ease,border-color .3s ease;
  border-bottom:1px solid transparent;
  background:rgba(255,255,255,.92);
}
.nav--scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom-color:var(--line);box-shadow:0 1px 24px rgba(31,46,57,.05)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:baseline;gap:.5em;font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;font-size:1.18rem;color:var(--navy)}
.nav--scrolled .brand{color:var(--navy)}
.brand b{font-weight:800}
.brand small{font-family:var(--font-mono);font-weight:400;font-size:.58rem;letter-spacing:.18em;opacity:.7;text-transform:uppercase;align-self:center}
.nav__right{display:flex;align-items:center;gap:.85rem}
.langsw{position:relative}
.langsw__btn{display:inline-flex;align-items:center;gap:.5em;background:transparent;border:1px solid var(--line-onnavy);border-radius:var(--r);padding:.55em .8em;font-family:var(--font-mono);font-size:.76rem;font-weight:500;letter-spacing:.08em;color:var(--navy);transition:border-color .2s ease,color .2s ease}
.nav--scrolled .langsw__btn{color:var(--navy);border-color:var(--line-cool)}
.langsw__btn:hover{border-color:var(--brass)}
.langsw__btn:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.langsw__chev{transition:transform .2s ease}
.langsw.open .langsw__chev{transform:rotate(180deg)}
.langsw__menu{position:absolute;top:calc(100% + 8px);right:0;min-width:168px;list-style:none;background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 14px 34px rgba(31,46,57,.14);padding:.4rem;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease,visibility .2s}
.langsw.open .langsw__menu{opacity:1;visibility:visible;transform:none}
.langsw__menu a,.langsw__current{display:block;padding:.6rem .8rem;border-radius:2px;font-family:var(--font-body);font-size:.9rem;color:var(--ink)}
.langsw__menu a:hover{background:var(--cream-soft);color:var(--navy)}
.langsw__current{color:var(--brass-dark);font-weight:600;cursor:default;font-family:var(--font-mono);font-size:.8rem}

/* ---------- HERO ---------- */
.hero{position:relative;background:var(--navy);color:var(--cream);padding-top:140px;padding-bottom:0;overflow:hidden}
.hero__grid-bg{position:absolute;inset:0;
  background-image:linear-gradient(var(--line-onnavy) 1px,transparent 1px),linear-gradient(90deg,var(--line-onnavy) 1px,transparent 1px);
  background-size:64px 64px;opacity:.5;mask-image:radial-gradient(120% 90% at 75% 30%,#000 30%,transparent 75%)}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center;padding-bottom:var(--sect)}
.hero h1{font-size:clamp(1.81rem, 4.29vw, 3.62rem);font-weight:800;color:var(--white)}
.hero h1 .accent{color:var(--brass)}
.hero__lead{margin:1.6rem 0 2.2rem;font-size:clamp(1.05rem,1.6vw,1.3rem);color:rgba(241,234,207,.82);max-width:48ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem}
.hero__ticker{margin-top:2.6rem;border-top:1px solid var(--line-onnavy);padding-top:1.3rem;display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem}
.hero__ticker div{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;color:rgba(241,234,207,.62)}
.hero__ticker b{display:block;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--cream);letter-spacing:-.01em}

.hero__stage{position:relative}
.hero__frame{position:relative;border:1px solid var(--line-onnavy);background:rgba(255,255,255,.03);padding:18px}
.hero__frame .corner{position:absolute;width:10px;height:10px;border:1px solid var(--brass)}
.hero__frame .corner.tl{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hero__frame .corner.tr{top:-1px;right:-1px;border-left:0;border-bottom:0}
.hero__frame .corner.bl{bottom:-1px;left:-1px;border-right:0;border-top:0}
.hero__frame .corner.br{bottom:-1px;right:-1px;border-left:0;border-top:0}
.hero__scale{position:absolute;right:-14px;top:50%;transform:translateY(-50%) rotate(180deg);writing-mode:vertical-rl;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;color:var(--brass-line);text-transform:uppercase}
.hero__dim{margin-top:14px}

/* ---------- image placeholder (ACF) ---------- */
.ph{
  position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  background:var(--cream-soft);border:1.5px dashed var(--navy);border-radius:var(--r);
  color:var(--navy);text-align:center;padding:1.4rem;aspect-ratio:4/3;overflow:hidden;
}
.ph svg{opacity:.45}
.ph__tag{font-family:var(--font-mono);font-size:.82rem;font-weight:600;letter-spacing:.02em}
.ph__hint{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.08em;color:var(--ink-soft);text-transform:uppercase}
.ph--dark{background:rgba(255,255,255,.04);border-color:var(--line-onnavy);color:var(--cream)}
.ph--dark .ph__hint{color:rgba(241,234,207,.6)}
.ph--dark svg{opacity:.35}

/* ---------- generic two-col ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center}
.section-head{max-width:64ch;margin-bottom:clamp(36px,4vw,56px)}

/* ---------- intro images ---------- */
.intro__imgs{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.intro__imgs .ph:first-child{margin-top:34px}

/* ---------- about / vision-mission ---------- */
.vm{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:36px}
.vm__card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:2rem;position:relative;overflow:hidden}
.vm__card::before{content:attr(data-k);position:absolute;top:1.4rem;right:1.4rem;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;color:var(--brass-dark)}
.vm__card h3{font-size:1.35rem;margin-bottom:.7rem}
.vm__card p{color:var(--ink-soft);font-size:.98rem}
.about__facts{list-style:none;margin-top:1.4rem;display:grid;gap:.9rem}
.about__facts li{display:flex;gap:.8rem;align-items:flex-start;font-size:.97rem;color:var(--ink-soft)}
.about__facts .k{font-family:var(--font-mono);font-size:.72rem;color:var(--brass-dark);min-width:34px;padding-top:.2em;letter-spacing:.06em}

/* ---------- audiences ---------- */
.aud{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.aud__card{border:1px solid var(--line-cool);border-radius:var(--r);padding:1.8rem 1.6rem;background:var(--white);transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;position:relative}
.aud__card:hover{border-color:var(--brass);transform:translateY(-4px);box-shadow:0 16px 40px rgba(31,46,57,.08)}
.aud__ico{width:42px;height:42px;color:var(--navy);margin-bottom:1.1rem}
.aud__num{position:absolute;top:1.5rem;right:1.5rem;font-family:var(--font-mono);font-size:.7rem;color:var(--line-cool)}
.aud__card h3{font-size:1.18rem;margin-bottom:.55rem}
.aud__card p{font-size:.93rem;color:var(--ink-soft)}
.aud__benefit{margin-top:1.1rem;padding-top:1.1rem;border-top:1px dashed var(--line);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.02em;color:var(--navy);display:flex;gap:.5em;align-items:center}
.aud__benefit::before{content:"→";color:var(--brass-dark)}
.aud__linssen{margin-top:24px;background:var(--navy);color:var(--cream);border-radius:var(--r);padding:1.6rem 2rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.aud__linssen p{font-family:var(--font-display);font-weight:600;font-size:1.15rem}
.aud__linssen span{font-family:var(--font-mono);font-size:.78rem;color:var(--brass-line);letter-spacing:.04em}

/* ---------- stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line-onnavy);border:1px solid var(--line-onnavy);border-radius:var(--r);overflow:hidden;margin-top:clamp(36px,4vw,52px)}
.stats__cell{background:var(--navy);padding:2.2rem 1.4rem;text-align:left}
.stats__num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.9rem,3.4vw,2.9rem);color:var(--cream);letter-spacing:-.02em;line-height:1}
.stats__num span{color:var(--brass)}
.stats__lab{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:rgba(241,234,207,.6);margin-top:.7rem;text-transform:uppercase;line-height:1.4}
.stats__foot{margin-top:1.4rem;font-family:var(--font-mono);font-size:.74rem;color:rgba(241,234,207,.55);letter-spacing:.03em}

/* ---------- marinas slider ---------- */
.slider{position:relative;margin-top:clamp(32px,4vw,48px)}
.slider__track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.slider__track::-webkit-scrollbar{display:none}
.marina{flex:0 0 clamp(260px,30vw,340px);scroll-snap-align:start;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--white)}
.marina .ph{aspect-ratio:3/2;border-radius:0;border-width:0 0 1.5px 0}
.marina__body{padding:1.3rem 1.4rem}
.marina__loc{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;color:var(--brass-dark);text-transform:uppercase}
.marina__name{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--navy);margin-top:.35rem}
.marina__meta{margin-top:.7rem;font-size:.84rem;color:var(--ink-soft);display:flex;gap:1rem}
.slider__nav{display:flex;gap:.6rem;margin-top:1.4rem;align-items:center}
.slider__btn{width:46px;height:46px;border-radius:50%;border:1px solid var(--line-cool);background:var(--white);display:flex;align-items:center;justify-content:center;color:var(--navy);transition:all .18s ease}
.slider__btn:hover{border-color:var(--navy);background:var(--navy);color:var(--cream)}
.slider__btn:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.slider__hint{margin-left:auto;font-family:var(--font-mono);font-size:.72rem;color:var(--ink-soft);letter-spacing:.04em}

/* ---------- process ---------- */
.process{position:relative}
.process__grid-bg{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:48px 48px;opacity:.5;mask-image:radial-gradient(110% 80% at 50% 40%,#000 35%,transparent 80%)}
.process__inner{position:relative}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);margin-top:clamp(40px,4vw,60px);position:relative}
.step__head{display:flex;align-items:baseline;gap:.8rem;margin-bottom:1.1rem}
.step__num{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--brass);line-height:1;letter-spacing:-.03em}
.step__title{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--navy)}
.step p{margin-top:1rem;margin-bottom: 16px;font-size:.92rem;color:var(--ink-soft)}
.step__dim{margin-top:1rem}
.step .ph + .ph { margin-top: 16px; }      /* gap between consecutive images */

.process__rule{margin-top:clamp(34px,4vw,48px)}

/* ---------- faq ---------- */
.faq{max-width:880px;margin:clamp(36px,4vw,52px) auto 0;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;background:none;border:0;text-align:left;padding:1.5rem 0;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;font-family:var(--font-display);font-weight:600;font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--navy)}
.faq__q:focus-visible{outline:2px solid var(--brass);outline-offset:3px}
.faq__sign{flex:0 0 auto;width:26px;height:26px;position:relative;transition:transform .3s ease}
.faq__sign::before,.faq__sign::after{content:"";position:absolute;background:var(--brass-dark);transition:opacity .3s ease}
.faq__sign::before{top:12px;left:3px;right:3px;height:1.5px}
.faq__sign::after{left:12px;top:3px;bottom:3px;width:1.5px}
.faq__item[open] .faq__sign::after{opacity:0}
.faq__a{overflow:hidden;max-height:0;transition:max-height .35s ease}
.faq__a-inner{padding:0 0 1.5rem;color:var(--ink-soft);font-size:.98rem;max-width:68ch}
.faq__item[open] .faq__sign{transform:rotate(180deg)}

/* ---------- contact ---------- */
.contact__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(32px,5vw,72px);align-items:start}
.contact__aside h2{margin-bottom:1rem}
.contact__points{list-style:none;margin-top:1.8rem;display:grid;gap:1.1rem}
.contact__points li{display:flex;gap:.9rem;font-size:.95rem;color:rgba(241,234,207,.8)}
.contact__points .k{color:var(--brass-line);font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;min-width:24px}
.form{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field--full{grid-column:1/-1}
.field label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brass-line)}
.field input,.field textarea{
  background:rgba(255,255,255,.04);border:1px solid var(--line-onnavy);border-radius:var(--r);
  padding:.85rem 1rem;color:var(--cream);font-family:var(--font-body);font-size:.95rem;transition:border-color .2s ease,background .2s ease;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(241,234,207,.35)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass);background:rgba(255,255,255,.07)}
.field textarea{resize:vertical;min-height:120px}
.form__submit{grid-column:1/-1;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.form__note{font-family:var(--font-mono);font-size:.72rem;color:rgba(241,234,207,.5)}
.form__ok{grid-column:1/-1;display:none;font-family:var(--font-mono);font-size:.85rem;color:var(--brass-line);border:1px solid var(--line-onnavy);border-radius:var(--r);padding:1rem 1.2rem;background:rgba(191,161,92,.08)}

/* ---------- footer ---------- */
.footer{background:var(--navy-deep);color:rgba(241,234,207,.7);padding:clamp(56px,7vw,84px) 0 2rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line-onnavy)}
.footer .brand{color:var(--cream);font-size:1.3rem;margin-bottom:1rem}
.footer__col h4{font-family:var(--font-mono);font-weight:500;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-line);margin-bottom:1rem}
.footer__col ul{list-style:none;display:grid;gap:.6rem}
.footer__col a{font-size:.9rem;color:rgba(241,234,207,.7)}
.footer__col a:hover{color:var(--cream)}
.footer__about{font-size:.92rem;max-width:34ch;color:rgba(241,234,207,.6)}
.footer__bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding-top:1.6rem;font-family:var(--font-mono);font-size:.72rem;color:rgba(241,234,207,.45);letter-spacing:.03em}
.footer__swatch{display:flex;gap:.5rem;align-items:center}
.footer__swatch i{width:14px;height:14px;border-radius:2px;display:inline-block;border:1px solid rgba(255,255,255,.15)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .stats__cell:last-child{grid-column:1/-1}
  .aud{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .hero__inner,.split,.contact__grid,.steps,.vm,.intro__imgs{grid-template-columns:1fr}
  .hero__stage{order:-1;max-width:480px}
  .form{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .intro__imgs .ph:first-child{margin-top:0}
}
@media (max-width:520px){
  .brand small{display:none}
  .aud{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .hero__ticker{gap:1.2rem 1.8rem}
}

/* ---------- filled ACF image (replaces placeholder) ---------- */
.ph--filled{border:0;padding:0;background:none;margin-bottom:20px;margin-top:12px}
.ph--filled img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
