/*
Theme Name: Hawaii Luau Guide
Theme URI: https://hawaiiluaus.org/
Author: Makana
Description: Custom theme for Hawaii Luau Guide. A luau directory with a "luau" custom post type and an "island" taxonomy. Home island selector, island category pages, single luau pages, and a blog. Ported from the approved design prototype.
Version: 1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: hawaii-luau-guide
*/

/* ============================================================
   Base + tokens
   ============================================================ */
:root{
  --cream:#fbf4ea;--navy:#0f2230;--navy2:#13293a;--ink:#1f2d3a;
  --orange:#ef5b2b;--amber:#f59e3f;--teal:#16808f;--gold:#f5b301;
  --line:#e7ddcd;--muted:#6d7b86;--white:#fff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins','Segoe UI',system-ui,sans-serif;background:var(--cream);color:var(--ink);line-height:1.7}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
h1,h2,h3{font-family:'Playfair Display',Georgia,serif;line-height:1.18}
.wrap{max-width:1440px;margin:0 auto;padding:0 22px}
.wrap-narrow{max-width:1240px;margin:0 auto;padding:0 22px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:600;border-radius:8px;padding:14px 26px;cursor:pointer;border:0;font-size:1rem;transition:.2s;font-family:'Poppins',sans-serif}
.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:#d94c20}
.card-hidden{display:none}

/* ============================================================
   Nav
   ============================================================ */
header.nav{position:sticky;top:0;z-index:50;background:rgba(15,34,48,.94);backdrop-filter:blur(8px);border-bottom:solid 1px #ef5b2b}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:'Playfair Display',serif;font-weight:700;font-size:26px}
.brand img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{color:#eaf0f2;font-size:.94rem;font-weight:500;transition:.2s}
.nav-links a:hover{color:var(--amber)}
.nav-links .has-drop{position:relative}
.nav-links .has-drop>a .caret{font-size:.7em;margin-left:3px}
.nav-links .dropdown{position:absolute;top:100%;left:0;min-width:210px;background:var(--navy2);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px 0;list-style:none;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;box-shadow:0 14px 34px rgba(0,0,0,.35);z-index:60}
.nav-links .has-drop:hover>.dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-links .dropdown li{display:block}
.nav-links .dropdown a{display:block;padding:10px 18px;color:#eaf0f2;font-size:.92rem;white-space:nowrap}
.nav-links .dropdown a:hover{background:rgba(255,255,255,.06);color:var(--amber)}
.mob-label{color:#9fb1bd;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;padding:12px 0 4px}
/* WordPress-menu dropdowns (Appearance > Menus) */
.nav-links .menu-item-has-children{position:relative}
.nav-links .menu-item-has-children>a::after{content:" \25BE";font-size:.7em}
.nav-links .sub-menu{position:absolute;top:100%;left:0;min-width:210px;background:var(--navy2);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px 0;list-style:none;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;box-shadow:0 14px 34px rgba(0,0,0,.35);z-index:60}
.nav-links .menu-item-has-children:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-links .sub-menu li{display:block}
.nav-links .sub-menu a{display:block;padding:10px 18px;color:#eaf0f2;font-size:.92rem;white-space:nowrap}
.nav-links .sub-menu a:hover{background:rgba(255,255,255,.06);color:var(--amber)}
.mobile-menu .mob-list{list-style:none}
.mobile-menu .mob-list a{display:block;color:#eaf0f2;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-menu .mob-list .sub-menu{list-style:none;padding-left:14px}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-fav{color:#eaf0f2;font-size:.9rem;display:flex;align-items:center;gap:6px}
.nav-acct{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;color:#fff}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.hamb span{width:26px;height:3px;background:#fff;border-radius:2px}
.mobile-menu{display:none;flex-direction:column;background:var(--navy2);padding:10px 22px 18px}
.mobile-menu a{color:#eaf0f2;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08)}

/* ============================================================
   Home hero + island selector
   ============================================================ */
.hero{position:relative;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,24,34,.82) 0%,rgba(10,24,34,.5) 55%,rgba(10,24,34,.25) 100%)}
.hero-inner{position:relative;z-index:2;padding:486px 0 150px}
.hero h1{font-size:3.4rem;font-weight:800;max-width:770px;text-shadow:0 3px 16px rgba(0,0,0,.4)}
.hero p{font-size:1.18rem;max-width:520px;margin:18px 0 30px;color:#eef3f5}

#top-luaus{background-size:cover;background-position:center;background-repeat:no-repeat;padding-top:0}
.island-bar{position:relative;z-index:3;margin-top:-92px;margin-bottom:46px}
.island-panel{background:rgba(13,28,40,.86);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:18px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.island-card{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:.2s;aspect-ratio:16/10}
.island-card img{width:100%;height:100%;object-fit:cover;transition:.3s}
.island-card:hover img{transform:scale(1.06)}
.island-card .label{position:absolute;inset:auto 0 0 0;padding:26px 14px 12px;background:linear-gradient(transparent,rgba(8,20,28,.9));color:#fff;font-weight:600;text-align:center}
.island-card.active{border-color:var(--orange)}
.island-card .check{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;background:var(--orange);color:#fff;display:none;place-items:center;font-size:.85rem;font-weight:700}
.island-card.active .check{display:grid}

/* ============================================================
   Sections + headings
   ============================================================ */
section{padding:60px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:12px}
.sec-title{display:flex;align-items:center;gap:12px;font-size:2.1rem;font-weight:800;color:var(--ink)}
.sec-title img{height:34px}
.sec-link{color:var(--orange);font-weight:600;display:inline-flex;gap:6px;align-items:center}
.sec-link:hover{gap:10px}
.sec-sub{color:var(--muted);margin-bottom:30px}

/* Luau cards */
.luau-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.luau-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 26px rgba(20,40,55,.07);transition:.2s}
.luau-card:hover{transform:translateY(-6px);box-shadow:0 18px 38px rgba(20,40,55,.14)}
.luau-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.luau-media img{width:100%;height:100%;object-fit:cover}
.rank{position:absolute;top:12px;left:12px;width:34px;height:34px;border-radius:50%;background:var(--orange);color:#fff;font-weight:700;display:grid;place-items:center;box-shadow:0 4px 10px rgba(0,0,0,.25)}
.area-tag{position:absolute;top:12px;right:12px;background:rgba(15,34,48,.85);color:#fff;font-size:.72rem;font-weight:600;padding:5px 11px;border-radius:20px}
.luau-body{padding:18px 22px 8px;flex:1}
.luau-body h3{font-size:1.3rem;font-weight:800;color:var(--ink);margin-bottom:6px}
.luau-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.stars{color:var(--gold);letter-spacing:1px}
.rev{color:var(--muted);font-size:.84rem}
.avail{color:#1a9d63;font-weight:700;font-size:.74rem;display:inline-flex;align-items:center;gap:4px}
.luau-desc{color:var(--muted);font-size:.93rem;margin-bottom:12px}
.feat{list-style:none;margin:0;padding:12px 0 0;border-top:1px solid var(--line)}
.feat li{display:flex;align-items:flex-start;gap:9px;font-size:.88rem;color:#42525f;padding:4px 0}
.feat li::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--teal);flex:0 0 auto;margin-top:7px}
.luau-foot{padding:16px 22px 22px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.luau-price{font-weight:700;color:var(--ink)}.luau-price b{color:var(--orange);font-size:1.18rem}
.luau-price small{display:block;color:var(--muted);font-weight:400;font-size:.74rem}
.luau-foot .btn{padding:11px 18px;font-size:.92rem}

/* ============================================================
   Compare table
   ============================================================ */
.compare{background-color:var(--navy);background-size:cover;color:#fff}
.compare .sec-title{color:#fff}
.cmp-wrap{overflow-x:auto}
table.cmp{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}
table.cmp th,table.cmp td{padding:15px 13px;text-align:center;vertical-align:middle;border-bottom:1px solid rgba(255,255,255,.12)}
table.cmp thead th{font-family:'Playfair Display',serif;font-size:1.02rem;font-weight:700}
table.cmp tbody th{text-align:left;font-weight:500;color:#cdd9e0;font-family:'Poppins',sans-serif;font-size:.9rem}
table.cmp tbody th svg{width:20px;height:20px;stroke:var(--amber);fill:none;vertical-align:middle;margin-right:9px}
table.cmp tbody th span{vertical-align:middle}
.feature-col{color:#9fb1bd;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}
.best-col{background:rgba(22,128,143,.28)}
.best-tag{display:inline-block;background:var(--orange);color:#fff;font-size:.66rem;font-weight:700;text-transform:uppercase;padding:3px 9px;border-radius:20px;margin-top:6px}
td.price-cell{color:var(--amber);font-weight:700}
.check-y{color:#46c98a;font-weight:700}

/* ============================================================
   Articles (home) + Experiences (category)
   ============================================================ */
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.art-card{background:#fff;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:0 8px 20px rgba(20,40,55,.06);transition:.2s}
.art-card:hover{transform:translateY(-5px);box-shadow:0 14px 30px rgba(20,40,55,.12)}
.art-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.art-media img{width:100%;height:100%;object-fit:cover}
.art-tag{position:absolute;top:12px;left:12px;background:var(--teal);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:5px 11px;border-radius:6px}
.art-body{padding:18px 20px 20px}
.art-body h3{font-size:1.16rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.art-body .art-excerpt{color:var(--muted);font-size:.9rem;line-height:1.55;margin-bottom:10px}
.art-meta{color:var(--muted);font-size:.82rem}
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.exp-card{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:3/4;color:#fff;display:flex;align-items:flex-end}
.exp-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.3s}
.exp-card:hover img{transform:scale(1.06)}
.exp-card::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 35%,rgba(8,20,28,.9))}
.exp-body{position:relative;z-index:2;padding:22px 20px}
.exp-body h3{font-size:1.25rem;margin-bottom:6px}.exp-body p{font-size:.85rem;color:#e6edf0}

/* ============================================================
   Category hero + why + area pills
   ============================================================ */
.cat-hero{position:relative;color:#fff;overflow:hidden}
.cat-hero-bg{position:absolute;inset:0;background-size:cover;background-position:right;background-repeat:no-repeat}
.cat-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,24,34,.85),rgba(10,24,34,.45) 65%,rgba(10,24,34,.25))}
.cat-hero-inner{position:relative;z-index:2;padding:486px 0 150px;max-width:1383px;text-align:left}
.cat-hero h1{font-size:3.3rem;font-weight:800;text-shadow:0 3px 16px rgba(0,0,0,.4)}
.cat-hero h1 .o{color:var(--orange)}
.cat-hero p{font-size:1.15rem;color:#eef3f5;margin:16px 0 24px;max-width:620px}
.why{background-color:var(--navy);background-size:cover;color:#fff;padding:54px 0;border-top:solid 2px #ef5b2b}
.why-inner{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr 1fr;gap:26px;align-items:start}
.why-lead h2{font-size:1.9rem;margin-bottom:10px}
.why-lead p{color:#bccbd5;font-size:.95rem}
.why-ico{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center;margin-bottom:12px}
.why-ico svg{width:24px;height:24px;stroke:var(--amber);fill:none}
.why-feat h4{font-family:'Poppins',sans-serif;font-size:1rem;margin-bottom:6px;color:#fff}
.why-feat p{color:#aebcc6;font-size:.86rem}
.area-pills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.area-pill{background:#fff;border:1px solid var(--line);color:var(--ink);padding:9px 18px;border-radius:30px;font-size:.9rem;cursor:pointer;transition:.2s;font-weight:600}
.area-pill:hover{border-color:var(--teal);color:var(--teal)}
.area-pill.active{background:var(--teal);border-color:var(--teal);color:#fff}

/* ============================================================
   Single luau page
   ============================================================ */
.crumbs{font-size:.84rem;color:var(--muted);padding:14px 0}
.crumbs a{color:var(--teal)}.crumbs a:hover{color:var(--orange)}
.luau-hero{position:relative;color:#fff;overflow:hidden}
.luau-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat}
.luau-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,24,34,.86),rgba(10,24,34,.5) 60%,rgba(10,24,34,.3))}
.luau-hero-inner{position:relative;z-index:2;padding:80px 0 90px;max-width:1183px}
.rate{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:7px 15px;border-radius:30px;font-size:.9rem;margin-bottom:18px}
.rate .stars{color:var(--gold)}
.luau-hero h1{font-size:3rem;font-weight:800;text-shadow:0 3px 16px rgba(0,0,0,.4)}
.luau-hero .sub{font-size:1.15rem;color:#eef3f5;margin:16px 0 22px;max-width:620px}
.pills{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:8px 15px;border-radius:30px;font-size:.86rem}
.hero-price{font-size:1.25rem;font-weight:700;color:var(--gold);margin-bottom:22px}
.hero-price span{color:#dfe8ec;font-weight:400;font-size:.95rem}
.luau-grid-wrap{display:grid;grid-template-columns:1fr 391px;gap:22px;align-items:start;max-width:1240px;margin:0 auto;padding:54px 22px}
.lm-top{grid-column:1;grid-row:1}
.booking{grid-column:2;grid-row:1 / 3;align-self:start}
.lm-rest{grid-column:1;grid-row:2}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 32px;margin-bottom:26px;box-shadow:0 10px 26px rgba(20,40,55,.06)}
.card h2{font-size:1.8rem;color:var(--ink);margin-bottom:16px;position:relative;padding-bottom:10px}
.card h2::after{content:"";position:absolute;left:0;bottom:0;width:54px;height:4px;border-radius:3px;background:linear-gradient(90deg,var(--orange),var(--teal))}
.card p{margin-bottom:14px;color:#3a4853}.card p:last-child{margin-bottom:0}
.rotor{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:16/9;margin-bottom:22px;background:#0c1c28}
.rotor-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .7s ease}
.rotor-slide.on{opacity:1}
.rotor-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;border:0;background:rgba(15,34,48,.6);color:#fff;font-size:1.4rem;cursor:pointer;display:grid;place-items:center}
.rotor-btn:hover{background:var(--orange)}.rotor-btn.prev{left:12px}.rotor-btn.next{right:12px}
.rotor-dots{display:flex;gap:8px;justify-content:center;margin-top:14px}
.rotor-dots button{width:9px;height:9px;border-radius:50%;border:0;background:#cdbfa9;cursor:pointer}
.rotor-dots button.on{background:var(--orange);width:26px;border-radius:6px}
.ticks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 26px;margin-top:6px}
.ticks li{position:relative;padding-left:28px;color:#3a4853}
.ticks li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--orange);font-weight:800}
.atglance{margin:2px 0 20px}
.atglance li strong{color:var(--ink)}
.sched{list-style:none}
.sched li{display:flex;gap:18px;padding:12px 0;border-bottom:1px solid var(--line)}
.sched li:last-child{border-bottom:0}.sched .t{flex:0 0 130px;font-weight:700;color:var(--teal)}
.map-frame iframe{width:100%;height:360px;border:0;border-radius:12px}
.luau-menu h3{font-family:'Playfair Display',serif;color:var(--ink);font-size:1.2rem;margin:18px 0 8px}
.luau-menu ul{list-style:none;padding:0;margin:0 0 8px}
.luau-menu li{padding:5px 0;color:#3a4853;border-bottom:1px solid var(--line)}
.luau-menu li:last-child{border-bottom:0}
.luau-menu img{border-radius:12px;margin:6px 0 14px;width:100%;object-fit:cover}
.luau-menu .menu-cols{display:grid;grid-template-columns:1fr 1fr;gap:0 34px}
@media(max-width:560px){.luau-menu .menu-cols{grid-template-columns:1fr}}
.note{color:var(--muted);font-size:.88rem;margin-top:10px}
.booking-card{background:#fff;border:1px solid var(--line);border-top:5px solid var(--orange);border-radius:16px;padding:26px 26px 28px;box-shadow:0 16px 40px rgba(20,40,55,.12)}
.booking-card h3{font-size:1.3rem;margin-bottom:8px}
.booking-card .bsub{color:var(--muted);font-size:.88rem;margin-bottom:16px}
.bprice{font-size:2rem;font-weight:800;color:var(--ink);font-family:'Playfair Display',serif}
.bprice span{font-size:.9rem;font-weight:400;color:var(--muted);font-family:'Poppins',sans-serif}
.bdiv{border:0;border-top:1px solid var(--line);margin:18px 0}
.brow{display:flex;justify-content:space-between;font-size:.92rem;padding:6px 0;color:#3a4853}
.brow .l{color:var(--muted)}
.bfeature{background:#fff7f0;border:1px solid #f3d9c4;border-radius:12px;padding:16px 18px;margin:6px 0 18px}
.bfeature h4{font-family:'Poppins',sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;color:var(--orange);margin-bottom:10px}
.bfeature ul{list-style:none}
.bfeature li{position:relative;padding-left:22px;font-size:.9rem;color:#3a4853;margin-bottom:7px}
.bfeature li:last-child{margin-bottom:0}
.bfeature li::before{content:"\2713";position:absolute;left:0;color:var(--orange);font-weight:800}
.btn-book{width:100%;margin-top:4px}
.bguar{text-align:center;color:var(--muted);font-size:.82rem;margin-top:12px}
.booking-widget{background:#f6f1e8;border:1px dashed #cdbfa9;border-radius:12px;padding:18px;text-align:center;color:var(--muted);font-size:.85rem;margin:4px 0 14px}
/* Seating packages (Bronze / Silver / Gold) */
.pkg-chart{text-align:center;margin-bottom:14px}
.pkg-chart img{max-width:240px;width:100%;margin:0 auto;border-radius:12px}
.pkg-options{display:flex;flex-direction:column;gap:10px}
.pkg-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:13px 16px;border:2px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;font-family:'Poppins',sans-serif;transition:.15s}
.pkg-opt .pkg-name{font-weight:700;color:var(--ink)}
.pkg-opt .pkg-price{font-weight:800;font-size:1.05rem}
.pkg-opt:hover{transform:translateY(-2px)}
.pkg-bronze:hover{border-color:#a9743f}
.pkg-silver:hover{border-color:#aab0b5}
.pkg-gold:hover{border-color:#e0a52e}
@keyframes pkgPulseBronze{0%,100%{box-shadow:0 0 0 0 rgba(169,116,63,0)}50%{box-shadow:0 0 0 3px rgba(169,116,63,.85)}}
@keyframes pkgPulseSilver{0%,100%{box-shadow:0 0 0 0 rgba(154,161,166,0)}50%{box-shadow:0 0 0 3px rgba(154,161,166,.9)}}
@keyframes pkgPulseGold{0%,100%{box-shadow:0 0 0 0 rgba(224,165,46,0)}50%{box-shadow:0 0 0 3px rgba(224,165,46,.9)}}
.pkg-options:not(.chosen) .pkg-bronze{animation:pkgPulseBronze 2.2s ease-in-out infinite}
.pkg-options:not(.chosen) .pkg-silver{animation:pkgPulseSilver 2.2s ease-in-out infinite .35s}
.pkg-options:not(.chosen) .pkg-gold{animation:pkgPulseGold 2.2s ease-in-out infinite .7s}
@media(prefers-reduced-motion:reduce){.pkg-options .pkg-opt{animation:none}}
#pkgBook{margin-top:14px}
.pkg-opt.active{box-shadow:0 6px 16px rgba(20,40,55,.12)}
.pkg-bronze .pkg-price{color:#a9743f}
.pkg-bronze.active{border-color:#a9743f;background:#fbf1e8}
.pkg-silver .pkg-price{color:#7c848a}
.pkg-silver.active{border-color:#aab0b5;background:#f2f4f5}
.pkg-gold .pkg-price{color:#c8881a}
.pkg-gold.active{border-color:#e0a52e;background:#fdf6e1}
.pkg-cals{margin-top:4px}
.pkg-cal{min-height:60px}
.pkg-hint{color:var(--muted);font-size:.85rem;text-align:center;margin-top:8px}
.pkg-includes h4{margin-bottom:8px}
.video-frame{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#0c1c28}
.video-frame iframe{width:100%;height:100%;border:0}
.more{background:var(--navy);color:#fff;padding:54px 0;text-align:center}
.more h2{font-size:2rem;margin-bottom:10px}.more p{color:#bcccd6;margin-bottom:22px}

/* ============================================================
   Blog (home.php) + generic content
   ============================================================ */
.page-hero{background:var(--navy);color:#fff;padding:64px 0;text-align:center}
.page-hero h1{font-size:2.6rem}
.entry{background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 38px;margin:0 auto 26px;max-width:820px;box-shadow:0 10px 26px rgba(20,40,55,.06)}
.entry h1,.entry h2{color:var(--ink)}
.entry p{margin:0 0 16px;color:#3a4853}
.entry img{border-radius:12px;margin:10px 0}
.pagination{display:flex;gap:10px;justify-content:center;margin:30px 0}
.pagination .page-numbers{display:inline-block;padding:9px 15px;border-radius:10px;border:1px solid var(--line);color:var(--navy);font-weight:700;background:#fff}
.pagination .current,.pagination a.page-numbers:hover{background:linear-gradient(90deg,var(--orange),var(--teal));color:#fff;border-color:transparent}

/* ============================================================
   Footer
   ============================================================ */
footer.site-footer{background-color:var(--navy);background-size:cover;color:#c7d2da;padding:58px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.4fr;gap:34px}
.foot-brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;margin-bottom:14px}
.foot-brand img{height:32px}
.foot-col h4{color:#fff;margin-bottom:14px;font-family:'Poppins',sans-serif;font-size:1rem}
.foot-col ul{list-style:none}.foot-col li{padding:6px 0;font-size:.9rem}.foot-col a:hover{color:var(--amber)}
.news input{width:100%;padding:11px 14px;border-radius:8px;border:0;margin:10px 0}
.news .btn{width:100%;justify-content:center;padding:12px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:20px;text-align:center;font-size:.85rem;color:#8ea0ab}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1460px){.cat-hero-inner{padding:486px 22px 150px}}
@media(max-width:1100px){.why-inner{grid-template-columns:1fr 1fr 1fr}.exp-grid{grid-template-columns:1fr 1fr}}
@media(max-width:980px){
  .nav-links,.nav-fav{display:none}
  .hamb{display:flex}
  .hero h1{font-size:2.5rem}
  .island-panel{grid-template-columns:repeat(2,1fr)}
  .luau-grid,.art-grid{grid-template-columns:1fr 1fr}
  .cat-hero h1,.luau-hero h1{font-size:2.3rem}
  .luau-grid-wrap{grid-template-columns:1fr;gap:26px}
  .lm-top,.booking,.lm-rest{grid-column:1;grid-row:auto}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .hero h1{font-size:2rem}
  .hero-inner{padding:64px 0 130px}
  .luau-grid,.art-grid,.exp-grid,.why-inner{grid-template-columns:1fr}
  .sec-title{font-size:1.6rem}
  .ticks{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
