/*
Theme Name: Hiyaa Voyages
Theme URI: https://hiyaavoyages.com
Description: Custom Maldives tour & hotel booking design for Hiyaa Voyages. Child theme of Ultimate Hotel Booking — keeps Tourfic/WooCommerce booking working while replacing the look with a bespoke design.
Author: Hiyaa Voyages
Template: ultimate-hotel-booking
Version: 1.1.0
*/

:root{
  --ocean:#07b6c9; --ocean-d:#048fa0; --ocean-l:#5fd6e3;
  --teal:#08323c; --teal-2:#0d5160;
  --sand:#fcf5ea; --sand-2:#f3e7d2;
  --gold:#e1a93f; --gold-d:#c68f29;
  --ink:#0f2a31; --muted:#5e7a83; --line:#e9e0d2; --white:#fff;
  --shadow:0 18px 45px -18px rgba(8,50,60,.45);
  --radius:22px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;color:var(--ink);background:var(--sand);overflow-x:hidden;line-height:1.65}
h1,h2,h3,.serif{font-family:'Playfair Display',serif}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{width:min(1200px,92%);margin-inline:auto}
.script{font-family:'Dancing Script',cursive;color:var(--gold);font-weight:700}
.btn{display:inline-flex;align-items:center;gap:.55rem;border:none;cursor:pointer;font-family:'Poppins';font-weight:600;font-size:.95rem;padding:.95rem 1.7rem;border-radius:50px;transition:.35s cubic-bezier(.2,.8,.2,1);letter-spacing:.2px}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff;box-shadow:0 12px 26px -10px rgba(225,169,63,.8)}
.btn-gold:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 20px 34px -10px rgba(225,169,63,.9)}
.btn-ocean{background:linear-gradient(135deg,var(--ocean),var(--ocean-d));color:#fff;box-shadow:0 12px 26px -10px rgba(7,182,201,.75)}
.btn-ocean:hover{transform:translateY(-4px) scale(1.03)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:#fff;color:var(--teal);transform:translateY(-4px)}
.btn-wa{background:#25d366;color:#fff;box-shadow:0 12px 26px -10px rgba(37,211,102,.8)}
.btn-wa:hover{transform:translateY(-4px) scale(1.03)}

/* ===== TOP BAR ===== */
.topbar{background:var(--teal);color:#cfe7ec;font-size:.82rem;padding:.5rem 0}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.topbar a{color:#cfe7ec;transition:.3s}.topbar a:hover{color:#fff}
.topbar .tinfo{display:flex;gap:1.4rem;flex-wrap:wrap}
.topbar .socials{display:flex;gap:.9rem}
.topbar .socials a:hover{color:var(--gold)}

/* ===== HEADER ===== */
header{position:fixed;top:33px;left:0;right:0;z-index:50;transition:.4s}
header.solid{top:0;background:rgba(255,255,255,.96);box-shadow:0 8px 30px -14px rgba(8,50,60,.3);backdrop-filter:blur(10px)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.logo{display:flex;align-items:center;gap:.6rem;font-family:'Playfair Display';font-weight:800;font-size:1.5rem;color:#fff;transition:.4s}
header.solid .logo{color:var(--teal)}
.logo .mark{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--gold));display:grid;place-items:center;flex:0 0 auto;box-shadow:0 6px 16px -6px rgba(7,182,201,.7)}
.logo .mark svg{width:24px;height:24px}
.logo small{display:block;font-family:'Poppins';font-weight:400;font-size:.6rem;letter-spacing:3px;text-transform:uppercase;opacity:.8;margin-top:-3px}
.menu{display:flex;gap:2rem;list-style:none;font-weight:500;font-size:.95rem}
.menu a{color:#fff;position:relative;padding:.2rem 0;transition:.3s}
header.solid .menu a{color:var(--teal)}
.menu a::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;background:var(--gold);transition:.3s}
.menu a:hover::after{width:100%}
.menu a:hover{color:var(--gold)}
.nav-cta{display:flex;align-items:center;gap:1rem}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none}
.burger span{width:26px;height:2.5px;background:#fff;border-radius:3px;transition:.3s}
header.solid .burger span{background:var(--teal)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('assets/img1.jpg') center/cover no-repeat;animation:kenburns 22s ease-in-out infinite alternate;z-index:-2}
@keyframes kenburns{from{transform:scale(1.08) translateY(0)}to{transform:scale(1.18) translate(-2%,-2%)}}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,50,60,.55) 0%,rgba(8,50,60,.25) 40%,rgba(8,50,60,.78) 100%);z-index:-1}
.hero-inner{width:100%;padding:120px max(1.5rem,calc((100% - 1200px)/2)) 60px}
.hero .eyebrow{font-size:1.8rem;line-height:1;opacity:0;transform:translateY(20px);animation:rise .8s .2s forwards}
.hero h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:800;line-height:1.05;margin:.4rem 0 1rem;max-width:14ch;text-shadow:0 6px 30px rgba(0,0,0,.3);opacity:0;transform:translateY(28px);animation:rise .9s .35s forwards}
.hero h1 .hl{color:var(--gold)}
.hero p.lede{font-size:clamp(1rem,1.6vw,1.25rem);max-width:48ch;opacity:0;transform:translateY(20px);animation:rise .9s .5s forwards;font-weight:300}
.hero .hero-cta{display:flex;gap:1rem;margin-top:1.8rem;flex-wrap:wrap;opacity:0;transform:translateY(20px);animation:rise .9s .65s forwards}
@keyframes rise{to{opacity:1;transform:translateY(0)}}

/* search bar */
.searchbar{margin-top:2.6rem;background:rgba(255,255,255,.16);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.3);border-radius:26px;padding:.6rem;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:.4rem;max-width:920px;box-shadow:0 24px 50px -20px rgba(0,0,0,.5);opacity:0;transform:translateY(24px);animation:rise 1s .8s forwards}
.field{background:rgba(255,255,255,.92);border-radius:18px;padding:.7rem 1rem;color:var(--ink);text-align:left}
.field label{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:1.4px;color:var(--ocean-d);font-weight:600;margin-bottom:2px}
.field .val{font-weight:600;font-size:.95rem;color:var(--teal)}
.field .val small{color:var(--muted);font-weight:400}
.search-go{background:linear-gradient(135deg,var(--gold),var(--gold-d));border-radius:18px;color:#fff;display:grid;place-items:center;cursor:pointer;transition:.3s;min-width:64px}
.search-go:hover{filter:brightness(1.08);transform:scale(1.04)}
.search-go svg{width:26px;height:26px}
.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;opacity:.85;display:flex;flex-direction:column;align-items:center;gap:6px}
.scroll-hint span{width:24px;height:38px;border:2px solid #fff;border-radius:14px;position:relative}
.scroll-hint span::after{content:"";position:absolute;top:7px;left:50%;width:4px;height:8px;background:#fff;border-radius:3px;transform:translateX(-50%);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;top:7px}40%{opacity:1}80%{opacity:0;top:20px}}

/* ===== STATS ===== */
.stats{background:var(--white);margin-top:-1px}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2.6rem 0}
.stat{text-align:center;padding:.6rem}
.stat .num{font-family:'Playfair Display';font-size:2.4rem;font-weight:800;color:var(--ocean-d);line-height:1}
.stat .lbl{font-size:.85rem;color:var(--muted);margin-top:.3rem;font-weight:500}

/* ===== SECTION SHELL ===== */
section{padding:5rem 0}
.sec-head{text-align:center;max-width:640px;margin:0 auto 3rem}
.sec-head .script{font-size:1.7rem;display:block}
.sec-head h2{font-size:clamp(2rem,4vw,2.9rem);font-weight:800;color:var(--teal);margin-top:.2rem}
.sec-head p{color:var(--muted);margin-top:.7rem}

/* reveal */
.reveal{opacity:0;transform:translateY(40px);transition:.8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== RESORT CARDS ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.4s cubic-bezier(.2,.8,.2,1);transform-style:preserve-3d;will-change:transform}
.card:hover{transform:translateY(-12px)}
.card .ph{position:relative;height:230px;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.7s}
.card:hover .ph img{transform:scale(1.12)}
.card .price{position:absolute;bottom:12px;right:12px;background:rgba(255,255,255,.95);color:var(--teal);font-weight:700;padding:.4rem .8rem;border-radius:30px;font-size:.9rem;box-shadow:var(--shadow)}
.card .price small{font-weight:400;color:var(--muted);font-size:.72rem}
.card .tag{position:absolute;top:12px;left:12px;background:linear-gradient(135deg,var(--ocean),var(--ocean-d));color:#fff;font-size:.7rem;font-weight:600;padding:.3rem .7rem;border-radius:30px;letter-spacing:.5px}
.card .body{padding:1.3rem 1.4rem 1.5rem}
.card .loc{font-size:.78rem;color:var(--ocean-d);font-weight:600;display:flex;align-items:center;gap:.3rem;text-transform:uppercase;letter-spacing:.5px}
.card h3{font-size:1.3rem;color:var(--teal);margin:.3rem 0 .5rem}
.card .stars{color:var(--gold);font-size:.95rem;letter-spacing:2px}
.card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;border-top:1px solid var(--line);padding-top:1rem}
.card .book{font-weight:600;color:var(--ocean-d);display:inline-flex;align-items:center;gap:.4rem;transition:.3s}
.card .book:hover{gap:.7rem;color:var(--gold-d)}

/* ===== ATOLLS ===== */
.atolls{background:linear-gradient(180deg,var(--sand),var(--sand-2))}
.atoll-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.atoll{position:relative;height:300px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:pointer}
.atoll img{width:100%;height:100%;object-fit:cover;transition:.8s}
.atoll:hover img{transform:scale(1.15)}
.atoll::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,50,60,.85))}
.atoll .cap{position:absolute;left:0;right:0;bottom:0;padding:1.3rem;color:#fff;z-index:2}
.atoll .cap h3{font-size:1.35rem}
.atoll .cap span{font-size:.8rem;opacity:.85}

/* ===== WHY ===== */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.feature{background:#fff;border-radius:var(--radius);padding:2rem 1.5rem;text-align:center;box-shadow:var(--shadow);transition:.4s;border-bottom:3px solid transparent}
.feature:hover{transform:translateY(-10px);border-color:var(--gold)}
.feature .ic{width:64px;height:64px;margin:0 auto 1rem;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(7,182,201,.15),rgba(225,169,63,.18));color:var(--ocean-d)}
.feature .ic svg{width:32px;height:32px}
.feature h3{font-size:1.18rem;color:var(--teal);margin-bottom:.4rem}
.feature p{font-size:.9rem;color:var(--muted)}

/* ===== EXPERIENCES ===== */
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.exp{position:relative;height:340px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.exp img{width:100%;height:100%;object-fit:cover;transition:.8s}
.exp:hover img{transform:scale(1.12)}
.exp::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(8,50,60,.8))}
.exp .cap{position:absolute;bottom:0;padding:1.3rem;color:#fff;z-index:2}
.exp .cap h3{font-size:1.25rem}

/* ===== HOW ===== */
.how{background:var(--teal);color:#fff}
.how .sec-head h2{color:#fff}
.how .sec-head p{color:#bcd9df}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.step{text-align:center;padding:1rem}
.step .n{width:74px;height:74px;margin:0 auto 1.2rem;border-radius:50%;display:grid;place-items:center;font-family:'Playfair Display';font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,var(--ocean),var(--gold));color:#fff;box-shadow:0 14px 30px -12px rgba(7,182,201,.8)}
.step h3{font-size:1.3rem;margin-bottom:.5rem}
.step p{color:#bcd9df;font-size:.92rem}

/* ===== TESTIMONIALS ===== */
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.tcard{background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);position:relative}
.tcard .q{font-family:'Playfair Display';font-size:4rem;color:var(--ocean-l);line-height:.6;height:30px}
.tcard p{color:#444;font-style:italic;margin:.6rem 0 1.2rem}
.tcard .who{display:flex;align-items:center;gap:.8rem}
.tcard .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--gold));color:#fff;display:grid;place-items:center;font-weight:700}
.tcard .who b{color:var(--teal)}.tcard .who span{font-size:.8rem;color:var(--muted)}

/* ===== CTA ===== */
.cta{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta-bg{position:absolute;inset:0;background:url('assets/img7.jpg') center/cover fixed;z-index:-2}
.cta::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,140,160,.85),rgba(8,50,60,.85));z-index:-1}
.cta h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:800;max-width:18ch;margin:0 auto 1rem}
.cta p{max-width:50ch;margin:0 auto 2rem;opacity:.92}
.cta .row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ===== FOOTER ===== */
footer{background:#06262d;color:#9fc0c7;padding:4rem 0 1.5rem;font-size:.9rem}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:2rem}
footer h4{color:#fff;margin-bottom:1rem;font-family:'Poppins';font-weight:600;font-size:1rem}
footer a{display:block;padding:.25rem 0;transition:.3s}footer a:hover{color:var(--gold);padding-left:5px}
footer .brand{font-family:'Playfair Display';font-weight:800;font-size:1.5rem;color:#fff;margin-bottom:.6rem}
footer .soc{display:flex;gap:.7rem;margin-top:1rem}
footer .soc a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;padding:0}
footer .soc a:hover{background:var(--gold);color:#fff;padding:0}
.copy{border-top:1px solid rgba(255,255,255,.1);margin-top:2.5rem;padding-top:1.5rem;text-align:center;font-size:.8rem;opacity:.7}

/* float WA */
.wa-float{position:fixed;right:22px;bottom:92px;z-index:60;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(37,211,102,.8);animation:pulse 2.2s infinite}
.wa-float svg{width:32px;height:32px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.6)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* slogan + AI chat assistant */
.slogan-foot{font-family:'Dancing Script',cursive;color:var(--gold);font-size:1.5rem;font-weight:700;margin:-.3rem 0 .5rem}
.ai-launch{position:fixed;right:22px;bottom:22px;z-index:61;display:flex;align-items:center;gap:.55rem;background:linear-gradient(135deg,var(--ocean),var(--teal-2));color:#fff;border:none;cursor:pointer;padding:.65rem 1.1rem .65rem .8rem;border-radius:50px;box-shadow:0 14px 30px -8px rgba(7,182,201,.7);font-weight:600;font-family:'Poppins';font-size:.92rem}
.ai-launch svg{width:24px;height:24px}
.ai-launch .dot,.ai-head .dot{width:9px;height:9px;border-radius:50%;background:#36d399;display:inline-block;animation:pulse 2s infinite}
.ai-panel{position:fixed;right:22px;bottom:22px;z-index:62;width:min(380px,92vw);height:560px;max-height:80vh;background:#fff;border-radius:24px;box-shadow:0 30px 70px -18px rgba(8,50,60,.55);display:flex;flex-direction:column;overflow:hidden;transform:translateY(24px) scale(.96);opacity:0;pointer-events:none;transition:.35s cubic-bezier(.2,.8,.2,1)}
.ai-panel.open{transform:none;opacity:1;pointer-events:auto}
.ai-head{background:linear-gradient(135deg,var(--ocean),var(--teal));color:#fff;padding:1rem 1.1rem;display:flex;align-items:center;gap:.7rem}
.ai-head .av{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:1.3rem}
.ai-head h4{font-family:'Poppins';font-weight:600;font-size:1rem;color:#fff;margin:0}
.ai-head small{opacity:.9;font-size:.72rem;display:flex;align-items:center;gap:.35rem}
.ai-head .x{margin-left:auto;cursor:pointer;font-size:1.4rem;background:none;border:none;color:#fff;line-height:1}
.ai-body{flex:1;overflow-y:auto;padding:1rem;background:var(--sand);display:flex;flex-direction:column;gap:.6rem}
.msg{max-width:84%;padding:.65rem .9rem;border-radius:16px;font-size:.88rem;line-height:1.5;animation:rise .4s}
.msg.bot{background:#fff;color:var(--ink);align-self:flex-start;border-bottom-left-radius:5px;box-shadow:0 4px 14px -8px rgba(8,50,60,.3)}
.msg.user{background:linear-gradient(135deg,var(--ocean),var(--ocean-d));color:#fff;align-self:flex-end;border-bottom-right-radius:5px}
.chips{display:flex;flex-wrap:wrap;gap:.45rem;padding:.5rem .9rem .3rem;background:var(--sand)}
.chip{background:#fff;border:1.5px solid var(--ocean-l);color:var(--ocean-d);font-size:.78rem;padding:.35rem .75rem;border-radius:30px;cursor:pointer;transition:.25s;font-family:'Poppins'}
.chip:hover{background:var(--ocean);color:#fff;border-color:var(--ocean)}
.ai-input{display:flex;gap:.5rem;padding:.7rem;border-top:1px solid var(--line);background:#fff}
.ai-input input{flex:1;border:1.5px solid var(--line);border-radius:30px;padding:.6rem 1rem;font-family:'Poppins';font-size:.88rem;outline:none}
.ai-input input:focus{border-color:var(--ocean)}
.ai-input button{background:linear-gradient(135deg,var(--ocean),var(--ocean-d));border:none;color:#fff;width:42px;height:42px;border-radius:50%;cursor:pointer;display:grid;place-items:center;flex:0 0 auto}
.ai-wa{display:block;text-align:center;background:#25d366;color:#fff;padding:.55rem;font-size:.82rem;font-weight:600;text-decoration:none}

.demo-flag{position:fixed;left:14px;bottom:14px;z-index:60;background:rgba(8,50,60,.9);color:#cfe7ec;font-size:.72rem;padding:.4rem .8rem;border-radius:30px;border:1px solid rgba(255,255,255,.15)}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .menu,.nav-cta .btn{display:none}
  .burger{display:flex}
  .searchbar{grid-template-columns:1fr 1fr;}
  .cards,.why-grid,.atoll-grid,.exp-grid,.steps,.tcards{grid-template-columns:repeat(2,1fr)}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .cards,.why-grid,.atoll-grid,.exp-grid,.steps,.tcards,.fgrid{grid-template-columns:1fr}
  .searchbar{grid-template-columns:1fr}
  .topbar .tinfo{font-size:.72rem;gap:.8rem}
}

/* === lead popups (trip planner + exit intent) === */
.hv-modal{position:fixed;inset:0;z-index:80;background:rgba(8,50,60,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:.3s}
.hv-modal.open{opacity:1;pointer-events:auto}
.hv-modal-card{background:#fff;border-radius:24px;max-width:560px;width:100%;max-height:92vh;overflow:auto;box-shadow:0 30px 80px -20px rgba(0,0,0,.5);position:relative;transform:translateY(20px) scale(.98);transition:.35s}
.hv-modal.open .hv-modal-card{transform:none}
.hv-modal-sm{max-width:430px}
.hv-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:1.9rem;color:var(--muted);cursor:pointer;line-height:1;z-index:2}
.hv-close:hover{color:var(--teal)}
.hv-form-wrap{padding:2rem}
.hv-form-wrap h3{font-family:'Playfair Display';font-size:1.55rem;color:var(--teal);margin-bottom:.3rem}
.hv-sub{color:var(--muted);font-size:.92rem;margin-bottom:1.1rem}
.hv-form label{display:block;font-size:.8rem;font-weight:600;color:var(--teal);margin-bottom:.7rem}
.hv-form input,.hv-form select,.hv-form textarea{width:100%;margin-top:.25rem;border:1.5px solid var(--line);border-radius:12px;padding:.6rem .8rem;font-family:'Poppins';font-size:.9rem;font-weight:400;color:var(--ink);outline:none;background:#fff}
.hv-form input:focus,.hv-form select:focus,.hv-form textarea:focus{border-color:var(--ocean)}
.hv-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.hv-check{display:flex !important;align-items:center;gap:.5rem;font-weight:500 !important;background:var(--sand);padding:.55rem .8rem;border-radius:12px;cursor:pointer}
.hv-check input{width:auto !important;margin:0 !important}
.hv-submit{width:100%;justify-content:center;margin-top:.5rem}
.hv-privacy{font-size:.72rem;color:var(--muted);text-align:center;margin-top:.7rem}
.hv-thanks{text-align:center;padding:1.5rem .5rem}
.hv-thanks h3{text-align:center}
.hv-tick{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--gold));color:#fff;font-size:2rem;display:grid;place-items:center;margin:0 auto 1rem}
@media(max-width:560px){.hv-row{grid-template-columns:1fr}.hv-form-wrap{padding:1.4rem}}
.searchbar,.searchbar .field{cursor:pointer}
.logo .mark{background:#fff;overflow:hidden}
.logo .mark img{width:84%;height:84%;object-fit:contain;display:block}

/* === resorts directory page === */
.rdir-hero{background:linear-gradient(135deg,var(--ocean),var(--teal));color:#fff;text-align:center;padding:8rem 1.5rem 3rem}
.rdir-hero .script{font-size:1.6rem;color:#ffe6b0}
.rdir-hero h1{font-family:'Playfair Display';font-size:clamp(2rem,4vw,3rem);font-weight:800;margin:.2rem 0 .4rem;color:#fff}
.rdir-hero p{opacity:.9;margin-bottom:1.3rem}
.rdir-search{max-width:560px;margin:0 auto}
.rdir-search input{width:100%;border:none;border-radius:50px;padding:1rem 1.3rem;font-family:'Poppins';font-size:1rem;box-shadow:0 16px 40px -16px rgba(0,0,0,.4);outline:none}
.rdir-count{text-align:center;color:var(--muted);font-weight:500;margin:1.6rem 0 .5rem}
.rdir-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;padding:1rem 0 4rem}
.rdir-card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:.35s}
.rdir-card:hover{transform:translateY(-8px)}
.rdir-ph{position:relative;height:150px;overflow:hidden}
.rdir-ph img{width:100%;height:100%;object-fit:cover;transition:.6s}
.rdir-card:hover .rdir-ph img{transform:scale(1.1)}
.rdir-tag{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.92);color:var(--ocean-d);font-size:.68rem;font-weight:600;padding:.25rem .6rem;border-radius:30px}
.rdir-body{padding:.9rem 1rem 1.1rem}
.rdir-loc{font-size:.72rem;color:var(--ocean-d);font-weight:600}
.rdir-body h3{font-family:'Playfair Display';font-size:1.05rem;color:var(--teal);margin:.2rem 0;line-height:1.25;min-height:2.4em}
.rdir-stars{color:var(--gold);font-size:.85rem;min-height:1em}
.rdir-btn{display:inline-block;margin-top:.5rem;color:var(--ocean-d);font-weight:600;font-size:.85rem;cursor:pointer}
.rdir-btn:hover{color:var(--gold-d)}
@media(max-width:980px){.rdir-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.rdir-grid{grid-template-columns:1fr}}
