/*
Theme Name: Cruise & Magic
Theme URI: https://www.cruiseandmagic.nl
Author: Cruise & Magic
Author URI: https://www.letscruise.nl
Description: Wit-eerst boekingsthema voor Disney cruises, vakanties en parktickets. Goud + midnight accenten, Cormorant Garamond + Outfit. Sterrenhemel-hero met foto-optie, zoekbalk, uitgelichte cruises en Let's Cruise-koppeling. Geconverteerd uit een Claude Design handoff. De sectie "Uitgelichte cruises" toont automatisch de Let's Cruise-feed wanneer de bijbehorende plugin actief is.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cruise-and-magic
Tags: business, travel, custom-colors, custom-logo, custom-menu, featured-images, sticky-post, threaded-comments
*/

/* ============================================================
   Cruise & Magic — Website system
   White-first, gold + midnight accents
   ============================================================ */
:root{
  --midnight:#0b1733;
  --midnight-2:#142347;
  --midnight-3:#1d3066;
  --gold:#b8923d;          /* deep gold — text/lines on white */
  --gold-bright:#e8c66a;   /* bright gold — fills on dark */
  --gold-soft:#f6e8c8;
  --teal:#4a8a93;
  --teal-deep:#2d5e66;
  --mist:#f4efe4;          /* warm section tint */
  --mist-2:#efe7d6;
  --line:rgba(11,23,51,0.12);
  --line-soft:rgba(11,23,51,0.07);
  --ink:#0b1733;
  --ink-60:rgba(11,23,51,0.62);
  --ink-45:rgba(11,23,51,0.45);
  --white:#ffffff;

  --serif:"Cormorant Garamond",Garamond,serif;
  --sans:"Outfit",-apple-system,system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;

  --maxw:1240px;
  --pad:40px;
  --radius:14px;
  --shadow-sm:0 2px 12px -6px rgba(11,23,51,0.18);
  --shadow-md:0 18px 40px -22px rgba(11,23,51,0.30);
  --shadow-lg:0 40px 80px -40px rgba(11,23,51,0.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--white);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
section{position:relative}
.section-pad{padding:96px 0}
.section-pad-sm{padding:64px 0}
.tint{background:var(--mist)}
.dark{background:var(--midnight);color:var(--mist)}

/* ---------- Type ---------- */
.eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:0.24em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;opacity:0.7}
.eyebrow.center{justify-content:center}
.dark .eyebrow{color:var(--gold-bright)}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-0.015em}
.display{font-size:clamp(44px,6vw,84px)}
.h1{font-size:clamp(38px,5vw,68px)}
.h2{font-size:clamp(30px,3.6vw,52px)}
.h3{font-size:clamp(22px,2.4vw,30px)}
.serif-it{font-style:italic}
.gold{color:var(--gold)}
.dark .gold{color:var(--gold-bright)}
.lead{font-size:clamp(17px,1.5vw,20px);line-height:1.65;color:var(--ink-60);max-width:60ch}
.dark .lead{color:rgba(244,239,228,0.78)}

.section-head{max-width:760px;margin-bottom:48px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{margin:18px 0 16px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:500;font-size:14px;letter-spacing:0.02em;
  padding:15px 26px;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease,border-color .25s ease;
  white-space:nowrap;
}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--midnight);color:var(--gold-bright)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 30px -16px rgba(184,146,61,0.7)}
.btn-outline{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{border-color:var(--midnight);background:var(--midnight);color:var(--gold-bright)}
.dark .btn-outline{border-color:rgba(244,239,228,0.35);color:var(--mist)}
.dark .btn-outline:hover{background:var(--gold-bright);color:var(--midnight);border-color:transparent}
.btn-ghost{padding:0;background:none;border:none;color:var(--gold);font-weight:500;gap:8px}
.btn-ghost svg{transition:transform .25s ease}
.btn-ghost:hover svg{transform:translateX(4px)}
.dark .btn-ghost{color:var(--gold-bright)}
.btn-lg{padding:18px 32px;font-size:15px}

/* ---------- Logo lockup ---------- */
.lockup{display:inline-flex;align-items:center;gap:0.46em;font-family:var(--serif);
  font-weight:500;letter-spacing:-0.02em;line-height:1;color:var(--midnight)}
.lockup .mark{flex:0 0 auto;height:0.92em;width:auto;display:block}
.lockup .wm{display:inline-flex;align-items:baseline;white-space:nowrap}
.lockup .amp{font-style:italic;color:var(--gold);padding:0 0.12em}
.lockup.on-dark{color:var(--mist)}
.lockup.on-dark .amp{color:var(--gold-bright)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,0.86);
  backdrop-filter:saturate(1.4) blur(14px);-webkit-backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.site-header .brand{font-size:25px}
.nav{display:flex;align-items:center;gap:30px;list-style:none}
.nav a{font-size:14.5px;font-weight:450;color:var(--ink);position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--gold);transition:right .28s ease}
.nav a:hover::after,.nav a.active::after,.nav .current-menu-item > a::after{right:0}
.header-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;align-items:center;justify-content:center}
.nav-toggle span{position:relative;width:22px;height:2px;background:var(--midnight);display:block;transition:.3s}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--midnight);transition:.3s}
.nav-toggle span::before{top:-7px}.nav-toggle span::after{top:7px}

/* ---------- Search dock ---------- */
.searchdock{
  background:var(--white);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow-lg);padding:14px;display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:8px;align-items:stretch;
}
.searchdock .field{display:flex;flex-direction:column;gap:3px;padding:10px 16px;border-radius:12px;transition:background .2s}
.searchdock .field:hover{background:var(--mist)}
.searchdock .field+.field{border-left:1px solid var(--line-soft)}
.searchdock .field .lab{font-family:var(--mono);font-size:9.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-45)}
.searchdock .field .val{font-family:var(--serif);font-size:19px;color:var(--ink);font-weight:500}
.searchdock .field select,.searchdock .field input{
  border:none;background:none;font-family:var(--serif);font-size:19px;color:var(--ink);font-weight:500;
  outline:none;cursor:pointer;width:100%;padding:0;-webkit-appearance:none;appearance:none;
}
.searchdock .go{align-self:stretch}
.searchdock .go .btn{height:100%;width:100%}

/* ---------- Cards ---------- */
.card-grid{display:grid;gap:26px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}

.cruise-card{
  background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  transition:transform .3s ease,box-shadow .3s ease;
}
.cruise-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.cruise-card .media{position:relative;aspect-ratio:4/3;background:var(--mist)}
.cruise-card .media .cm-slot{width:100%;height:100%}
.cruise-card .badge{
  position:absolute;top:14px;left:14px;z-index:3;background:var(--white);color:var(--midnight);
  font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;
  padding:7px 12px;border-radius:999px;box-shadow:var(--shadow-sm);
}
.cruise-card .badge.gold{background:var(--gold-bright);color:var(--midnight)}
.cruise-card .body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.cruise-card .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-45)}
.cruise-card .title{font-family:var(--serif);font-size:25px;font-weight:500;line-height:1.1}
.cruise-card .desc{font-size:13.5px;color:var(--ink-60);line-height:1.55}
.cruise-card .foot{margin-top:auto;padding-top:16px;border-top:1px solid var(--line-soft);display:flex;align-items:flex-end;justify-content:space-between}
.price .from{font-family:var(--mono);font-size:9.5px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-45)}
.price .amt{font-family:var(--serif);font-size:30px;font-weight:600;line-height:1}
.price .pp{font-size:12px;color:var(--ink-45)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;
  padding:6px 11px;border:1px solid var(--line);border-radius:999px;color:var(--ink-60)}
.chip .d{color:var(--gold)}

/* ---------- USP ---------- */
.usp{display:flex;flex-direction:column;gap:14px}
.usp .ic{width:52px;height:52px;border-radius:14px;background:var(--mist);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.usp .ic svg{width:26px;height:26px}
.usp h3{font-size:23px}
.usp p{font-size:14px;color:var(--ink-60);line-height:1.6}

/* ---------- Deal banner ---------- */
.deal{position:relative;border-radius:20px;overflow:hidden;background:var(--midnight);color:var(--mist);
  display:grid;grid-template-columns:1.1fr 1fr;min-height:340px}
.deal .copy{padding:56px;display:flex;flex-direction:column;justify-content:center;gap:18px;position:relative;z-index:2}
.deal .visual{position:relative}
.deal .visual .cm-slot{width:100%;height:100%}
.deal .stars{position:absolute;inset:0;pointer-events:none;opacity:.7}

/* ---------- Destinations ---------- */
.dest{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;color:#fff}
.dest .cm-slot{position:absolute;inset:0;width:100%;height:100%}
.dest .scrim{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(11,23,51,0.78) 100%);z-index:2}
.dest .lbl{position:relative;z-index:3;padding:24px;width:100%}
.dest .lbl .n{font-family:var(--serif);font-size:26px;font-weight:500}
.dest .lbl .c{font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;opacity:0.85}
.dest.tall{aspect-ratio:auto}

/* ---------- Footer ---------- */
.site-footer{background:var(--midnight);color:var(--mist);padding:80px 0 36px;position:relative;overflow:hidden}
.site-footer .stars{position:absolute;inset:0;opacity:.5;pointer-events:none}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;position:relative;z-index:2}
.footer-grid h4{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:18px}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer-grid a{font-size:14px;color:rgba(244,239,228,0.78)}
.footer-grid a:hover{color:var(--gold-bright)}
.footer-brand .lockup{font-size:30px;margin-bottom:18px}
.footer-brand p{font-size:14px;color:rgba(244,239,228,0.7);max-width:34ch;line-height:1.6}
.footer-bottom{margin-top:56px;padding-top:24px;border-top:1px solid rgba(244,239,228,0.16);
  display:flex;justify-content:space-between;align-items:center;gap:20px;position:relative;z-index:2;
  font-family:var(--mono);font-size:11px;letter-spacing:0.1em;color:rgba(244,239,228,0.6)}

/* ---------- Partner strip (Let's Cruise) ---------- */
.partner{display:flex;align-items:center;gap:16px;background:var(--mist);border:1px solid var(--line-soft);
  border-radius:14px;padding:18px 22px}
.partner .pmark{width:44px;height:44px;border-radius:11px;background:var(--midnight);color:var(--gold-bright);
  display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;flex:0 0 auto}
.partner .ptxt{font-size:13.5px;color:var(--ink-60);line-height:1.5}
.partner .ptxt strong{color:var(--ink);font-weight:600}

/* ---------- Stars background helper ---------- */
.starfield{position:absolute;inset:0;pointer-events:none}

/* ---------- Image slot (WP-editable image region) ---------- */
.cm-slot{position:relative;display:block;background:var(--mist);overflow:hidden}
.cm-slot.has-img{background-size:cover;background-position:center}
.cm-slot .cm-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:18px;gap:10px;flex-direction:column;
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink-45);background:
    repeating-linear-gradient(45deg,rgba(11,23,51,0.02) 0 12px,transparent 12px 24px),var(--mist)}
.cm-slot .cm-ph svg{width:26px;height:26px;opacity:.5;stroke:var(--gold)}
.cm-slot.has-img .cm-ph{display:none}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);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}}

/* ============================================================
   Hero (was inline in index.html)
   ============================================================ */
.hero{position:relative;color:var(--mist);overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-stars{background:radial-gradient(ellipse 90% 70% at 72% 18%,#1d3066 0%,#142347 45%,#0b1733 100%)}
.hero-photo{display:none}
.hero-photo .cm-slot{width:100%;height:100%;background:transparent}
.hero-photo .hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,23,51,0.45) 0%,rgba(11,23,51,0.30) 40%,rgba(11,23,51,0.72) 100%)}
body[data-hero="photo"] .hero-stars{display:none}
body[data-hero="photo"] .hero-photo{display:block}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,198,106,0.5),transparent);z-index:-1}
.hero-inner{padding:104px 0 92px;max-width:920px}
.hero h1{margin:22px 0 22px;text-wrap:balance}
.hero .lead{color:rgba(244,239,228,0.86)}
.hero .searchdock{margin-top:44px;color:var(--ink)}
.hero-trust{display:flex;gap:34px;flex-wrap:wrap;margin-top:30px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(244,239,228,0.7)}
.hero-trust span{display:flex;align-items:center;gap:9px}
.hero-trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold-bright)}
.hero-arc{position:absolute;right:-6%;top:8%;width:46%;max-width:560px;opacity:0.9;z-index:-1}

/* parks split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.parks-media{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:5/6;box-shadow:var(--shadow-md)}
.parks-media .cm-slot{width:100%;height:100%}
.park-list{display:flex;flex-direction:column;gap:0;margin-top:26px}
.park-row{display:flex;align-items:center;gap:18px;padding:18px 0;border-top:1px solid var(--line)}
.park-row:last-child{border-bottom:1px solid var(--line)}
.park-row .pn{font-family:var(--serif);font-size:23px;font-weight:500;flex:1}
.park-row .pc{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-45)}
.park-row .pa{color:var(--gold)}

/* contact / about CTA */
.cta-band{position:relative;border-radius:24px;overflow:hidden;background:var(--midnight);color:var(--mist);
  text-align:center;padding:84px 40px;isolation:isolate}
.cta-band .starfield{z-index:-1;opacity:0.55}
.cta-band h2{max-width:18ch;margin:18px auto 14px}
.cta-band .lead{margin:0 auto 30px;color:rgba(244,239,228,0.8)}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:860px){
  :root{--pad:22px}
  .nav,.header-cta .btn-outline{display:none}
  .nav-toggle{display:flex}
  .site-header.open .nav{display:flex;position:absolute;top:76px;left:0;right:0;flex-direction:column;
    background:#fff;padding:18px 22px;gap:6px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md)}
  .site-header.open .nav a{padding:12px 0;border-bottom:1px solid var(--line-soft)}
  .section-pad{padding:64px 0}
  .cols-3,.cols-4{grid-template-columns:1fr 1fr}
  .searchdock{grid-template-columns:1fr 1fr;gap:6px}
  .searchdock .field+.field{border-left:none}
  .searchdock .go{grid-column:1/-1}
  .deal{grid-template-columns:1fr}
  .deal .visual{min-height:220px}
  .deal .copy{padding:36px}
  .hero-inner{padding:64px 0 60px}
  .split{grid-template-columns:1fr;gap:36px}
  .hero-arc{display:none}
  .hero-trust{gap:18px}
}
@media (max-width:560px){
  .cols-3,.cols-4,.cols-2{grid-template-columns:1fr}
  .searchdock{grid-template-columns:1fr}
  .searchdock .field+.field{border-top:1px solid var(--line-soft)}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px}
}
