/* ============================================================
   DreamCruiseBooking.com — Common stylesheet
   Tokens · base · header · footer · modal · utilities · buttons
   Page-specific styles live in /assets/css/<page>.css
============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --navy:#0c2a4d; --navy-deep:#081d36; --navy-mid:#16436e;
  --coral:#e8503a; --coral-deep:#cf3f2b; --coral-soft:#fff1ee;
  --gold:#c79a4b;
  --ink:#16202e; --slate:#5d6b7c; --slate-light:#8896a6;
  --line:#e9edf2; --line-soft:#f2f5f8;
  --bg:#ffffff; --bg-soft:#f7f9fc; --bg-navy-tint:#f4f7fb;
  --sh-sm:0 2px 10px rgba(12,42,77,.05);
  --sh-md:0 10px 34px rgba(12,42,77,.09);
  --sh-lg:0 24px 64px rgba(12,42,77,.15);
  --r:12px; --r-lg:20px;
  --maxw:1200px;
  --ease:cubic-bezier(.16,.84,.44,1);
}

/* ---------- RESET / BASE ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html,body{overflow-x:clip}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--ink);background:var(--bg);
  line-height:1.7;font-size:16.5px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.15;font-weight:700;letter-spacing:-.01em;color:var(--navy)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---------- LAYOUT UTILITIES ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.sec{padding:90px 0}
.sec-soft{background:var(--bg-soft)}
.sec-head{max-width:660px;margin-bottom:52px}
.sec-head.center{margin:0 auto 52px;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.8vw,2.85rem);margin:16px 0 14px}
.sec-head p{color:var(--slate);font-size:1.07rem}
.eyebrow{font-family:'Plus Jakarta Sans';font-size:.76rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:'';width:24px;height:2px;background:var(--coral)}
.eyebrow.c{justify-content:center}
.eyebrow.c::after{content:'';width:24px;height:2px;background:var(--coral)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:9px;font-family:'Plus Jakarta Sans';font-weight:700;font-size:.95rem;cursor:pointer;border:none;transition:transform .25s var(--ease),box-shadow .25s,background .25s;white-space:nowrap}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 8px 22px rgba(232,80,58,.28)}
.btn-coral:hover{background:var(--coral-deep);transform:translateY(-2px);box-shadow:0 12px 28px rgba(232,80,58,.36)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-2px)}
.btn-outline-w{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px)}
.btn-outline-w:hover{background:rgba(255,255,255,.18);transform:translateY(-2px)}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--navy-deep);color:#bcccdc;font-size:.82rem;padding:9px 0}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar a{color:#bcccdc;transition:color .2s}
.topbar a:hover{color:#fff}
.topbar-l{display:flex;gap:22px;flex-wrap:wrap}
.topbar-l span,.topbar-l a{display:inline-flex;align-items:center;gap:7px}
.tb-badge{background:var(--coral);color:#fff;padding:2px 10px;border-radius:50px;font-weight:700;font-size:.74rem}

/* ---------- HEADER ---------- */
header.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
header.site-header.scrolled{box-shadow:var(--sh-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:15px 0}
.logo{display:flex;align-items:center;gap:12px;font-family:'Playfair Display';font-weight:800;font-size:1.3rem;color:var(--navy)}
.logo-mark{width:44px;height:44px;flex:none;border-radius:12px;background:linear-gradient(140deg,var(--navy),var(--navy-mid));display:grid;place-items:center;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.logo-mark::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40%;background:var(--coral);opacity:.9;clip-path:polygon(0 60%,100% 30%,100% 100%,0 100%)}
.logo-mark svg{width:24px;height:24px;position:relative;z-index:2}
.logo small{display:block;font-family:'Plus Jakarta Sans';font-size:.58rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--coral);margin-top:-3px}
.navlinks{display:flex;align-items:center;gap:28px;list-style:none}
.navlinks > li > a{font-family:'Plus Jakarta Sans';font-weight:600;font-size:.94rem;color:var(--ink);transition:color .2s;position:relative;padding:6px 0}
.navlinks > li > a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--coral);transition:width .25s}
.navlinks > li > a:hover,.navlinks > li > a.active{color:var(--coral)}
.navlinks > li > a:hover::after,.navlinks > li > a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--navy);border-radius:2px;transition:.3s}

/* FAQ */
.faq-list{max-width:860px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);margin-bottom:13px;overflow:hidden;transition:box-shadow .2s,border-color .2s}
.faq-item[open]{box-shadow:var(--sh-sm);border-color:#dfe5ec}
.faq-item summary{padding:22px 26px;cursor:pointer;font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.04rem;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:16px;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .pm{flex:none;width:30px;height:30px;border-radius:50%;background:var(--coral-soft);display:grid;place-items:center;transition:transform .3s,background .3s;font-size:1.4rem;color:var(--coral);line-height:1}
.faq-item[open] summary .pm{transform:rotate(45deg);background:var(--coral);color:#fff}
.faq-item .ans{padding:0 26px 24px;color:var(--slate);font-size:.97rem}
.faq-item .ans strong{color:var(--ink)}

/* ---------- FOOTER ---------- */
footer.site-footer{background:var(--navy-deep);color:#a9bccf;padding:70px 0 0}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand .logo{color:#fff;margin-bottom:16px}
.foot-brand p{font-size:.92rem;line-height:1.75;max-width:340px;color:#94a7bb}
.foot-contact{margin-top:18px;font-size:.9rem;line-height:1.95}
.foot-contact a{color:#c2d2e2;transition:color .2s}
.foot-contact a:hover{color:#fff}
.foot-col h4{font-family:'Plus Jakarta Sans';font-weight:800;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:11px}
.foot-col a{font-size:.92rem;transition:color .2s;color:#94a7bb}
.foot-col a:hover{color:#fff}
.disclaimer{padding:30px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.disclaimer h5{font-family:'Plus Jakarta Sans';font-weight:800;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:#6f8298;margin-bottom:10px}
.disclaimer p{font-size:.81rem;line-height:1.8;color:#6f8298}
.foot-bottom{padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:.84rem;color:#6f8298}
.foot-bottom a{color:#94a7bb}
.foot-bottom a:hover{color:#fff}

/* ---------- FLOATING ENQUIRE BUTTON ---------- */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:90;width:58px;height:58px;border-radius:50%;background:var(--coral);display:grid;place-items:center;box-shadow:0 8px 28px rgba(232,80,58,.45);transition:transform .25s;animation:bob 2.6s ease-in-out infinite;border:none;cursor:pointer}
.wa-float:hover{transform:scale(1.1);background:var(--coral-deep)}
.wa-float svg{width:30px;height:30px}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ---------- ENQUIRY MODAL ---------- */
.modal-ov{position:fixed;inset:0;background:rgba(8,29,54,.62);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.modal-ov.show{opacity:1;visibility:visible}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:460px;max-height:92vh;overflow-y:auto;box-shadow:var(--sh-lg);transform:translateY(24px) scale(.97);transition:transform .35s var(--ease);position:relative}
.modal-ov.show .modal{transform:none}
.modal-head{background:linear-gradient(120deg,var(--navy-deep),var(--navy-mid));color:#fff;padding:30px 32px 26px;border-radius:var(--r-lg) var(--r-lg) 0 0;position:relative;overflow:hidden}
.modal-head::before{content:'';position:absolute;top:-40%;right:-10%;width:240px;height:240px;background:radial-gradient(circle,rgba(232,80,58,.28),transparent 65%)}
.modal-head > *{position:relative;z-index:2}
.modal-head .eyebrow{color:#ff9684;margin-bottom:10px}
.modal-head .eyebrow::before{background:#ff9684}
.modal-head h3{color:#fff;font-size:1.55rem;line-height:1.2;margin-bottom:6px}
.modal-head p{color:#cdd9e5;font-size:.92rem}
.modal-close{position:absolute;top:16px;right:16px;z-index:5;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:1.4rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s}
.modal-close:hover{background:rgba(255,255,255,.3)}
.modal-body{padding:26px 32px 32px}
.modal-body .mf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.modal-body input,.modal-body textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;font-family:'Plus Jakarta Sans';font-size:.94rem;color:var(--ink);background:var(--bg-soft);transition:border .2s;margin-bottom:12px}
.modal-body .mf-row input{margin-bottom:0}
.modal-body input:focus,.modal-body textarea:focus{outline:none;border-color:var(--coral)}
.modal-body textarea{resize:vertical;min-height:84px}
.modal-body .btn{width:100%;justify-content:center}
.modal-trust{display:flex;align-items:center;gap:7px;justify-content:center;margin-top:14px;font-size:.8rem;color:var(--slate-light)}

/* ---------- MOBILE NAV / OVERLAY ---------- */
.menu-overlay{position:fixed;inset:0;background:rgba(8,29,54,.5);z-index:250;opacity:0;visibility:hidden;transition:.3s}
.menu-overlay.show{opacity:1;visibility:visible}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  body{font-size:16px}
  header.site-header.menu-open{z-index:90}
  .navlinks{position:fixed;top:0;right:-110%;height:100vh;width:80%;max-width:330px;background:#fff;flex-direction:column;align-items:flex-start;padding:90px 32px;gap:6px;box-shadow:var(--sh-lg);transition:right .35s;z-index:300}
  .navlinks.open{right:0}
  .navlinks li{width:100%}
  .navlinks > li > a{display:block;padding:13px 0;width:100%;border-bottom:1px solid var(--line);font-size:1.05rem}
  .navlinks > li > a::after{display:none}
  .burger{display:flex;z-index:310}
  .burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .nav-cta .btn{display:none}
  .sec{padding:60px 0}
  .foot-grid{grid-template-columns:1fr}
}
@media(max-width:520px){
  .modal-body .mf-row{grid-template-columns:1fr}
  .modal-head{padding:26px 24px 22px}
  .modal-body{padding:22px 24px 26px}
}

/* ============================================================
   QUICK-NAV scroller with auto arrows (desktop overflow fix)
   Used by .qnav on ship/cabins/restaurants/reviews/deck-plan pages.
============================================================ */

/* Wrapper that holds the scroll track + arrow buttons */
.qnav-wrap{ position:relative; padding:10px 44px;}

/* The scrolling track (replaces what .wrap was doing) */
.qnav-track{ display:flex; gap:10px; overflow-x:auto; padding:14px 4px; scrollbar-width:none; scroll-behavior:smooth; -webkit-overflow-scrolling:touch; }
.qnav-track::-webkit-scrollbar{display:none}

/* Arrow buttons — hidden by default, JS toggles .show */
.qnav-arrow{ position:absolute; top:50%; transform:translateY(-50%); width:34px; height:34px; border-radius:50%; border:1px solid var(--line); background:#fff; color:var(--navy); cursor:pointer; display:none; /* hidden by default */ align-items:center; justify-content:center; font-size:1rem; font-weight:800; z-index:5; box-shadow:0 2px 8px rgba(0,0,0,.08); transition:all .2s var(--ease); }
.qnav-arrow:hover{color:var(--coral); border-color:var(--coral);box-shadow:0 4px 14px rgba(232,80,58,.18);}
.qnav-arrow.show{display:flex}
.qnav-arrow.qnav-prev{left:6px}
.qnav-arrow.qnav-next{right:6px}

/* Subtle fade edges so cut-off items look intentional, not broken */
.qnav-wrap::before,.qnav-wrap::after{ content:''; position:absolute; top:0; bottom:0; width:36px; pointer-events:none; z-index:4; opacity:0; transition:opacity .2s var(--ease); } 
.qnav-wrap::before{ left:36px; background:linear-gradient(to right,rgba(255,255,255,.95),transparent); } 
.qnav-wrap::after{ right:36px; background:linear-gradient(to left,rgba(255,255,255,.95),transparent); } 
.qnav-wrap.show-prev::before{opacity:1} .qnav-wrap.show-next::after{opacity:1}

/* Mobile — hide arrows & fades, let users swipe naturally */
@media(max-width:768px){
  .qnav-wrap{padding:0} .qnav-arrow{display:none !important} .qnav-wrap::before, .qnav-wrap::after{display:none} .qnav-track{padding:14px 26px}
}
