/* ============================================================
   index.php (homepage) — page-specific styles only.
   Common tokens, header, footer, modal, buttons live in main.css.
============================================================ */

/* HERO */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden;padding:80px 0}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,29,54,.94) 0%,rgba(8,29,54,.8) 42%,rgba(8,29,54,.35) 100%)}
.hero-inner{position:relative;z-index:5;max-width:720px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);padding:8px 16px;border-radius:50px;font-size:.82rem;font-weight:600;backdrop-filter:blur(8px);margin-bottom:24px;opacity:0;animation:rise .7s .1s forwards}
.hero-badge b{color:var(--coral);background:#fff;padding:1px 8px;border-radius:50px;margin-right:2px}
.hero h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:800;color:#fff;margin-bottom:22px;opacity:0;animation:rise .7s .25s forwards}
.hero h1 em{font-style:italic;color:#ffb3a3}
.hero-sub{font-size:clamp(1.05rem,1.8vw,1.2rem);color:#d3deea;max-width:580px;margin-bottom:32px;opacity:0;animation:rise .7s .4s forwards}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:rise .7s .55s forwards}
.hero-trust{display:flex;gap:34px;margin-top:48px;flex-wrap:wrap;opacity:0;animation:rise .7s .7s forwards}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-family:'Playfair Display';font-size:1.7rem;color:#fff;font-weight:700}
.hero-trust b span{color:var(--coral)}
.hero-trust small{font-size:.8rem;color:#9fb1c4}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* BOOKING BAR */
.bookbar{position:relative;z-index:20;margin-top:-50px}
.bookbar-inner{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:14px;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:10px;align-items:stretch;border:1px solid var(--line)}
.field{padding:10px 16px;border-radius:11px;transition:background .2s}
.field:hover{background:var(--bg-soft)}
.field label{display:block;font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-light);margin-bottom:4px}
.field select,.field input{width:100%;padding:4px 0;border:none;font-family:'Plus Jakarta Sans';font-size:.96rem;font-weight:600;color:var(--ink);background:transparent}
.field select:focus,.field input:focus{outline:none}
.bookbar-inner .btn{justify-content:center;border-radius:11px}

/* INTRO */
.intro{padding:64px 0;border-bottom:1px solid var(--line)}
.intro-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:center}
.intro p{color:var(--slate);font-size:1.06rem;margin-bottom:16px}
.intro p strong{color:var(--ink)}
.intro-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.istat{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:24px 22px}
.istat b{font-family:'Playfair Display';font-size:2rem;color:var(--navy);display:block;line-height:1}
.istat b i{color:var(--coral);font-style:normal}
.istat span{font-size:.86rem;color:var(--slate);font-weight:600;display:block;margin-top:6px}

/* DEALS */
.deals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.deal-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s;display:flex;flex-direction:column}
.deal-card:hover{transform:translateY(-7px);box-shadow:var(--sh-lg)}
.deal-img{height:210px;position:relative;overflow:hidden}
.deal-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.deal-card:hover .deal-img img{transform:scale(1.06)}
.deal-ribbon{position:absolute;top:16px;left:16px;background:var(--coral);color:#fff;padding:6px 14px;border-radius:7px;font-size:.76rem;font-weight:800;z-index:2;box-shadow:0 4px 12px rgba(232,80,58,.35)}
.deal-ribbon.navy{background:var(--navy)}
.deal-body{padding:24px;flex:1;display:flex;flex-direction:column}
.deal-body h3{font-size:1.4rem;margin-bottom:4px}
.deal-from{font-size:.84rem;color:var(--coral);font-weight:700;margin-bottom:14px}
.deal-list{list-style:none;margin-bottom:20px}
.deal-list li{font-size:.92rem;color:var(--slate);padding:7px 0;display:flex;gap:10px;align-items:flex-start;border-bottom:1px dashed var(--line)}
.deal-list li:last-child{border:none}
.deal-list li::before{content:'➜';color:var(--coral);font-size:.85rem;flex:none;margin-top:1px}
.deal-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:18px;border-top:1px solid var(--line)}
.deal-price b{font-family:'Playfair Display';font-size:1.5rem;color:var(--navy)}
.deal-price small{font-size:.74rem;color:var(--slate);display:block}

/* PRICE TRACKER */
.tracker{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.tracker::before{content:'';position:absolute;top:-20%;right:-8%;width:480px;height:480px;background:radial-gradient(circle,rgba(232,80,58,.16),transparent 65%)}
.tracker .wrap{position:relative;z-index:2}
.tracker .sec-head h2{color:#fff}
.tracker .sec-head p{color:#a9bccf}
.tracker .eyebrow{color:#ff9684}
.tracker .eyebrow::before,.tracker .eyebrow.c::after{background:#ff9684}
.price-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);backdrop-filter:blur(4px)}
.price-note{display:flex;align-items:center;gap:10px;background:rgba(232,80,58,.16);padding:14px 24px;font-size:.84rem;color:#ffd8d0;border-bottom:1px solid rgba(255,255,255,.08)}
.price-note .dot{width:9px;height:9px;background:#ff9684;border-radius:50%;animation:pulse 2s infinite;flex:none}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(255,150,132,.5)}50%{opacity:.4;box-shadow:0 0 0 6px rgba(255,150,132,0)}}
.tbl-scroll{overflow-x:auto}
table.price{width:100%;border-collapse:collapse;font-size:.95rem;min-width:560px}
table.price th{background:rgba(255,255,255,.06);text-align:left;padding:16px 24px;font-family:'Plus Jakarta Sans';font-weight:800;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:#a9bccf}
table.price td{padding:18px 24px;border-top:1px solid rgba(255,255,255,.08)}
table.price tr:hover td{background:rgba(255,255,255,.04)}
.cabin-name{font-weight:700;color:#fff}
.cabin-name small{display:block;font-weight:400;color:#8fa3b8;font-size:.8rem}
.price-from{font-family:'Playfair Display';font-size:1.4rem;color:#fff;font-weight:700}
.price-from span{font-size:.76rem;color:#8fa3b8;font-family:'Plus Jakarta Sans';font-weight:400}
.tag{display:inline-block;padding:5px 12px;border-radius:50px;font-size:.72rem;font-weight:800}
.tag-hot{background:rgba(232,80,58,.2);color:#ff9684}
.tag-best{background:rgba(255,255,255,.12);color:#fff}

/* DESTINATIONS */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.dest-card{position:relative;border-radius:var(--r-lg);overflow:hidden;height:300px;color:#fff;display:flex;align-items:flex-end;padding:24px;cursor:pointer}
.dest-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);z-index:0}
.dest-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(8,29,54,.88));z-index:1}
.dest-card:hover img{transform:scale(1.08)}
.dest-card .dc-body{position:relative;z-index:2}
.dest-card h3{color:#fff;font-size:1.4rem;margin-bottom:4px}
.dest-card p{font-size:.86rem;color:#d3deea}
.dest-card .dc-tag{position:absolute;top:18px;left:18px;z-index:2;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);padding:5px 12px;border-radius:50px;font-size:.74rem;font-weight:700}
.dest-tall{grid-row:span 2;height:auto}

/* FEATURES */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feat-card{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding:28px;color:#fff}
.feat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .6s var(--ease)}
.feat-card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,29,54,.1) 30%,rgba(8,29,54,.9));z-index:1}
.feat-card:hover img{transform:scale(1.06)}
.feat-card > *{position:relative;z-index:2}
.feat-card .fc-ico{width:48px;height:48px;border-radius:12px;background:var(--coral);display:grid;place-items:center;margin-bottom:14px}
.feat-card .fc-ico svg{width:24px;height:24px;stroke:#fff}
.feat-card h3{color:#fff;font-size:1.45rem;margin-bottom:8px}
.feat-card p{font-size:.94rem;color:#d3deea}

/* SHIP */
.ship{background:var(--bg-navy-tint)}
.ship-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center}
.ship-media{position:relative}
.ship-media .sm-main{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);height:440px}
.ship-media .sm-main img{width:100%;height:100%;object-fit:cover}
.ship-media .sm-badge{position:absolute;bottom:-22px;right:-12px;background:#fff;border-radius:16px;padding:18px 24px;box-shadow:var(--sh-md);border:1px solid var(--line)}
.ship-media .sm-badge b{font-family:'Playfair Display';font-size:1.8rem;color:var(--coral);display:block;line-height:1}
.ship-media .sm-badge span{font-size:.8rem;color:var(--slate);font-weight:600}
.feature-list{list-style:none;margin-top:24px}
.feature-list li{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.feature-list li:last-child{border:none}
.feat-ico2{width:46px;height:46px;flex:none;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--sh-sm)}
.feat-ico2 svg{width:22px;height:22px;stroke:var(--coral)}
.feature-list b{display:block;font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.02rem;color:var(--ink)}
.feature-list p{font-size:.92rem;color:var(--slate);margin:0}

/* CABINS */
.cabin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cabin-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s,box-shadow .3s}
.cabin-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md)}
.cabin-img{height:170px;overflow:hidden}
.cabin-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.cabin-card:hover .cabin-img img{transform:scale(1.07)}
.cabin-body{padding:22px}
.cabin-body h3{font-size:1.2rem;margin-bottom:6px}
.cabin-body .csz{font-size:.8rem;color:var(--slate-light);font-weight:600;margin-bottom:12px}
.cabin-body p{font-size:.88rem;color:var(--slate);margin-bottom:16px}
.cabin-body .cprice{font-family:'Playfair Display';font-size:1.35rem;color:var(--navy);font-weight:700}
.cabin-body .cprice small{font-size:.72rem;color:var(--slate);font-family:'Plus Jakarta Sans';font-weight:400}

/* STEPS */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding:32px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);transition:transform .3s,box-shadow .3s}
.step:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.step::before{counter-increment:step;content:"0" counter(step);font-family:'Playfair Display';font-size:2.6rem;font-weight:800;color:var(--coral-soft);position:absolute;top:18px;right:22px;line-height:1}
.step .s-ico{width:50px;height:50px;border-radius:13px;background:var(--navy);display:grid;place-items:center;margin-bottom:16px}
.step .s-ico svg{width:24px;height:24px;stroke:#fff}
.step h3{font-size:1.18rem;margin-bottom:8px}
.step p{font-size:.9rem;color:var(--slate)}

/* REVIEWS */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 28px;position:relative;transition:transform .3s,box-shadow .3s}
.rev-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md)}
.rev-stars{color:var(--coral);font-size:1rem;letter-spacing:2px;margin-bottom:14px}
.rev-card p{font-size:.97rem;color:var(--ink);margin-bottom:22px;font-style:italic}
.rev-who{display:flex;align-items:center;gap:13px}
.rev-who .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--coral));display:grid;place-items:center;font-family:'Playfair Display';font-weight:700;color:#fff;flex:none}
.rev-who b{display:block;font-family:'Plus Jakarta Sans';font-size:.95rem}
.rev-who span{font-size:.8rem;color:var(--slate)}

/* EEAT */
.eeat{position:relative;color:#fff;overflow:hidden}
.eeat-bg{position:absolute;inset:0;z-index:0}
.eeat-bg img{width:100%;height:100%;object-fit:cover}
.eeat-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,29,54,.95),rgba(8,29,54,.6))}
.eeat .wrap{position:relative;z-index:3;max-width:720px;padding-top:80px;padding-bottom:80px}
.eeat .eyebrow{color:#ff9684}.eeat .eyebrow::before{background:#ff9684}
.eeat h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.7rem);margin:14px 0 18px}
.eeat p{color:#d3deea;font-size:1.08rem;margin-bottom:16px}
.eeat-author{margin-top:26px;display:inline-flex;align-items:center;gap:14px}
.eeat-author .av{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--coral),var(--gold));display:grid;place-items:center;font-family:'Playfair Display';font-weight:700;font-size:1.2rem;flex:none}
.eeat-author b{display:block;font-family:'Plus Jakarta Sans';font-weight:700}
.eeat-author span{font-size:.84rem;color:#a9bccf}

/* AWARDS */
.awards-row{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.award{text-align:center;padding:30px 20px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-lg)}
.award .a-ico{font-size:2.2rem;margin-bottom:10px}
.award b{display:block;font-family:'Playfair Display';font-size:1.05rem;color:var(--navy)}
.award span{font-size:.82rem;color:var(--slate)}


/* LEAD SECTION */
.lead{background:var(--bg-soft)}
.lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md)}
.lead-media{position:relative;min-height:480px}
.lead-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.lead-form-wrap{padding:48px 44px 48px 0}
.lead-form-wrap .eyebrow{margin-bottom:12px}
.lead-form-wrap h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:10px}
.lead-form-wrap > p{color:var(--slate);margin-bottom:24px;font-size:.98rem}

/* HOMEPAGE RESPONSIVE */
@media(max-width:1000px){
  .deals-grid,.feat-grid,.rev-grid{grid-template-columns:1fr 1fr}
  .cabin-grid,.steps-grid{grid-template-columns:1fr 1fr}
  .dest-grid{grid-template-columns:1fr 1fr}
  .dest-tall{grid-row:span 1;height:300px}
}
@media(max-width:880px){
  .ship-grid,.intro-grid,.lead-grid{grid-template-columns:1fr;gap:40px}
  .ship-media .sm-main{height:340px}
  .lead-media{min-height:280px}
  .lead-media img{position:relative}
  .lead-form-wrap{padding:40px 32px}
  .awards-row{grid-template-columns:1fr 1fr}
  .bookbar-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .hero{padding:60px 0;min-height:auto}
  .hero-trust{gap:22px}
  .deals-grid,.feat-grid,.rev-grid,.cabin-grid,.steps-grid,.dest-grid,.awards-row{grid-template-columns:1fr}
}
@media(max-width:520px){
  .bookbar-inner{grid-template-columns:1fr}
  .hero-actions .btn{width:100%;justify-content:center}
}
