/* ===== Pattaya Pool Villa — Mockup (Design variation #1) ===== */
:root{
  --navy:#062b63; --navy-2:#0b3f8e; --navy-grad-a:#03245a; --navy-grad-b:#093b84;
  --gold:#f0c54d; --gold-deep:#e0ad2e;
  --bg:#f5f7fb; --card:#fff; --text:#12233f; --muted:#6e7a8c; --line:#e6ebf3;
  --shadow:0 10px 30px rgba(8,29,73,.08); --shadow-h:0 16px 40px rgba(8,29,73,.16);
  --radius:18px;
  --kakao:#ffe000; --kakao-t:#3c1e1e; --line-g:#06c755; --wa:#25d366; --call:#2f80ff;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Pretendard","Apple SD Gothic Neo","Malgun Gothic",system-ui,sans-serif;
  color:var(--text);background:linear-gradient(180deg,#f9fbff 0%,#f4f7fb 100%);line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{width:min(1320px,calc(100% - 40px));margin:0 auto}
.img-fallback{background:linear-gradient(135deg,#cdd9e6,#9fb6cd);position:relative}
.img-fallback::after{content:"PATTAYA POOL VILLA";position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;color:#fff;font-weight:700;font-size:12px;letter-spacing:1px;opacity:.7}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:50;background:linear-gradient(90deg,var(--navy-grad-a),var(--navy-grad-b));
  color:#fff;box-shadow:0 6px 18px rgba(4,23,56,.18)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:86px}
.logo{font-weight:800;line-height:1.05;font-size:20px;letter-spacing:.4px;color:#fff}
.logo b{color:var(--gold)}
.logo small{display:block;font-size:12px;font-weight:600;opacity:.92;margin-top:6px;font-style:italic;color:var(--gold)}
.nav{display:flex;gap:30px;align-items:center}
.nav-item{position:relative;padding:32px 0;font-size:15px;font-weight:700;color:rgba(255,255,255,.96);display:flex;align-items:center;gap:6px}
.nav-item .caret{font-size:10px;opacity:.8}
.nav-item.active::after,.nav-item:hover::after{content:"";position:absolute;left:0;right:0;bottom:18px;height:3px;background:var(--gold);border-radius:2px}
.nav-wrap{position:relative}
.submenu{position:absolute;top:78px;left:-14px;min-width:190px;background:#fff;border-radius:12px;box-shadow:var(--shadow-h);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:60}
.nav-wrap:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:11px 14px;border-radius:8px;color:var(--text);font-weight:600;font-size:14.5px}
.submenu a:hover{background:#f1f5fb;color:var(--navy)}
.icons{display:flex;gap:10px}
.icon-btn{width:38px;height:38px;border-radius:50%;background:#fff;color:#0b2d63;text-align:center;line-height:38px;font-size:15px;transition:.15s}
.icon-btn i{vertical-align:middle;line-height:inherit}
.icon-btn:hover{background:var(--gold);color:#fff}
.mobile-toggle{display:none;background:none;border:0;color:#fff;font-size:26px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:15px 26px;border-radius:999px;
  border:1px solid transparent;cursor:pointer;font-weight:800;font-size:15px;transition:.16s}
.btn-outline{border-color:rgba(255,255,255,.75);color:#fff;background:rgba(255,255,255,.08)}
.btn-outline:hover{background:rgba(255,255,255,.2)}
.btn-gold{background:var(--gold);color:#3a2c00}.btn-gold:hover{background:var(--gold-deep)}
.btn-navy{background:linear-gradient(90deg,#0b2f67,#093d88);color:#fff}.btn-navy:hover{filter:brightness(1.08)}
.btn-kakao{background:var(--kakao);color:var(--kakao-t)}.btn-kakao:hover{filter:brightness(.96)}
.btn-line{background:var(--line-g);color:#fff}
.btn-block{width:100%}.btn-sm{padding:11px 18px;font-size:14px}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:740px;color:#fff;
  background:linear-gradient(rgba(4,22,61,.25),rgba(4,22,61,.2)),url('../img/hero.jpg') center/cover no-repeat}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,18,53,.5) 0%,rgba(0,18,53,.25) 38%,rgba(0,18,53,0) 72%)}
.hero-content{position:relative;z-index:2;padding:140px 0 120px;max-width:760px}
.hero-kicker{font-family:"Nanum Pen Script","Pretendard",cursive;color:#f3dc76;font-size:42px;line-height:1;margin-bottom:14px}
.hero h1{font-size:64px;line-height:1.12;margin:0 0 18px;font-weight:900;word-break:keep-all;text-shadow:0 3px 20px rgba(0,0,0,.25)}
.hero p{font-size:21px;line-height:1.55;color:rgba(255,255,255,.94);margin:0 0 32px;max-width:580px;word-break:keep-all}

/* ---------- Search ---------- */
.search-panel{position:relative;z-index:3;margin-top:-46px}
.search-box{background:#fff;border-radius:20px;box-shadow:var(--shadow-h);padding:18px;display:grid;
  grid-template-columns:repeat(4,1fr) 200px;gap:14px}
.field{border:1px solid var(--line);border-radius:14px;padding:12px 16px;min-height:74px;display:flex;flex-direction:column;justify-content:center}
.field label{font-size:12px;color:var(--muted);margin-bottom:7px;font-weight:700}
.field .value,.field select,.field input{font-size:15px;color:#41506a;border:0;background:transparent;padding:0;outline:none}
.search-button{border:none;border-radius:14px;background:linear-gradient(90deg,#0b2f67,#093d88);color:#fff;font-size:17px;font-weight:800;
  display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}

/* ---------- Sections ---------- */
.section{padding:60px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px}
.section-title{font-size:40px;margin:0;display:flex;align-items:center;gap:12px;color:var(--navy);font-weight:800}
.section-title i{color:var(--gold-deep);font-size:32px}
.section-desc{margin:10px 0 0;color:var(--muted);font-size:16px}
.more-link{padding:13px 20px;border:1px solid #cbd6e5;border-radius:12px;background:#fff;font-weight:700;color:#1e3358;white-space:nowrap}
.more-link:hover{border-color:var(--navy);color:var(--navy)}

/* ---------- Cards ---------- */
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cards-5{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.card{background:#fff;border:1px solid #e7edf6;border-radius:18px;overflow:hidden;box-shadow:0 8px 20px rgba(21,40,77,.05);
  transition:.18s;display:block}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-h)}
.thumb{position:relative;aspect-ratio:1.35/1;overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .thumb img{transform:scale(1.05)}
.badge{position:absolute;left:12px;top:12px;background:var(--navy-2);color:#fff;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:800}
.fav{position:absolute;right:12px;top:12px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.92);color:#e2566c;font-size:15px;border:0;cursor:pointer}
.fav.on{background:#e2566c;color:#fff}
.card-body{padding:15px 17px 19px}
.card-body h4{margin:0 0 8px;font-size:19px;line-height:1.3;color:var(--navy)}
.meta{color:#69768a;font-size:13.5px;display:flex;align-items:center;gap:6px}
.meta i{color:var(--gold-deep)}
.specs{display:flex;gap:14px;flex-wrap:wrap;color:#69768a;font-size:13.5px;margin-top:8px}
.specs i{color:var(--navy-2);margin-right:4px}
.tags{display:flex;gap:8px;flex-wrap:wrap;color:#7c8aa0;font-size:13px;margin-top:6px}
.tag-cat{display:inline-block;background:#eef3fb;color:var(--navy);font-weight:700;font-size:12px;padding:4px 11px;border-radius:30px;margin-bottom:8px}
.price{margin-top:12px;font-size:17px;font-weight:800;color:var(--navy)}
.price small{color:var(--muted);font-weight:500;font-size:12.5px}

/* ---------- Feature band ---------- */
.feature-band{background:linear-gradient(90deg,#072a64,#0b3c85);color:#fff;margin-top:10px}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:32px 0}
.feature-item{display:flex;align-items:center;gap:16px;padding:6px 10px}
.feature-icon{width:58px;height:58px;border:1px solid rgba(255,255,255,.25);border-radius:16px;display:grid;place-items:center;
  font-size:24px;color:var(--gold);flex-shrink:0}
.feature-item strong{font-size:16px}.feature-item span{color:#b9cbe6;font-size:13.5px}

/* ---------- Footer ---------- */
.footer{background:linear-gradient(90deg,#04255b,#07367d);color:#fff;padding-top:44px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1.2fr 1fr;gap:26px;padding-bottom:30px}
.footer .logo{color:#fff}
.footer-col h5{margin:0 0 14px;font-size:17px;color:#fff}
.footer-col a{display:block;color:rgba(255,255,255,.82);margin:9px 0;font-size:14px}
.footer-col a:hover{color:var(--gold)}
.footer-col p{margin:6px 0;color:rgba(255,255,255,.82);font-size:14px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.16);padding:18px 0 26px;display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;color:rgba(255,255,255,.8);font-size:13px}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social .icon-btn{width:38px;height:38px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.22);font-size:15px}
.footer-social .icon-btn:hover{background:var(--gold);color:#06294e;border-color:var(--gold)}

/* ---------- Quick panel ---------- */
.quick-panel{position:fixed;right:20px;top:120px;z-index:45;width:184px;background:#fff;border-radius:18px;
  box-shadow:0 14px 32px rgba(17,31,59,.24);overflow:hidden;transition:.25s}
.quick-head{padding:16px 16px 13px;font-weight:800;text-align:center;color:var(--navy);border-bottom:1px solid #eef1f7}
.quick-head i{color:var(--gold-deep);margin-right:6px}
.quick-item{display:flex;align-items:center;gap:11px;padding:12px 16px;border-top:1px solid #f0f3f8;font-size:13px;font-weight:700;color:var(--text)}
.quick-item:first-of-type{border-top:0}
.quick-item small{display:block;color:var(--muted);font-weight:500;font-size:11.5px}
.quick-bubble{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:16px;flex-shrink:0}
.qb-kakao{background:var(--kakao);color:#3c1e1e}.qb-line{background:var(--line-g)}.qb-call{background:var(--call)}.qb-wa{background:var(--wa)}
.quick-item:hover{background:#f7faff}
.quick-top{display:block;background:var(--navy);color:#fff;padding:13px;text-align:center;font-weight:800;font-size:13px;cursor:pointer}
.quick-top:hover{background:var(--navy-2)}
/* collapse / expand */
.quick-collapse{position:absolute;top:8px;right:9px;background:none;border:0;color:var(--muted-2,#9aa8bb);cursor:pointer;font-size:17px;line-height:1;padding:4px;border-radius:6px}
.quick-collapse:hover{color:var(--navy);background:#f1f5fb}
.quick-tab{position:fixed;right:0;top:150px;z-index:46;display:none;flex-direction:column;align-items:center;gap:7px;
  background:var(--navy);color:#fff;border:0;cursor:pointer;padding:15px 9px;border-radius:14px 0 0 14px;
  box-shadow:-5px 6px 18px rgba(8,29,73,.25);font-weight:800;font-size:12px;letter-spacing:1px;writing-mode:vertical-rl}
.quick-tab i{font-size:17px;writing-mode:horizontal-tb;color:var(--gold)}
.quick-tab:hover{background:var(--navy-2)}
body.qp-collapsed .quick-panel{transform:translateX(calc(100% + 34px));opacity:0;visibility:hidden;pointer-events:none}
body.qp-collapsed .quick-tab{display:flex}

/* mobile floating fallback */
.fab-mobile{display:none}

/* ---------- Page hero (sub) ---------- */
.page-hero{position:relative;padding:54px 0 44px;color:#fff;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,28,68,.82),rgba(6,28,68,.5)),var(--ph,linear-gradient(#0b3c85,#062b63));
  background-size:cover;background-position:center}
.page-hero>.container{position:relative;z-index:2}
.breadcrumb{font-size:13px;color:rgba(255,255,255,.8);margin-bottom:14px}
.breadcrumb a:hover{color:#fff}.breadcrumb span{margin:0 7px;opacity:.6}
.page-hero h1{font-size:46px;margin:0 0 10px;font-weight:800}
.page-hero p{font-size:18px;color:rgba(255,255,255,.9);margin:0;max-width:760px;line-height:1.6;word-break:keep-all}

/* ---------- Tabs / filters ---------- */
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 24px}
.tab{padding:11px 20px;border-radius:999px;background:#eff4fb;color:#506078;font-weight:700;border:0;cursor:pointer;font-size:14px}
.tab.active{background:var(--navy);color:#fff}
.search-row{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:24px;flex-wrap:wrap}
.search-inline{display:flex;gap:10px;min-width:300px}
.search-inline input{border:1px solid #dce5f2;border-radius:12px;padding:12px 16px;background:#fff;min-width:240px}
.filter-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px 22px;margin-bottom:26px}
.filter-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:7px 0}
.filter-row .f-label{width:80px;font-weight:700;color:var(--navy);font-size:14px}
.fchip{padding:8px 16px;border-radius:30px;background:#f1f5f9;border:1px solid transparent;font-size:13.5px;font-weight:600;color:var(--text);cursor:pointer}
.fchip.active{background:var(--navy);color:#fff}
.filter-actions{display:flex;justify-content:flex-end;gap:10px;align-items:center;margin-top:8px;border-top:1px solid var(--line);padding-top:14px}

/* ---------- Pagination ---------- */
.pagination{display:flex;gap:6px;justify-content:center;margin-top:38px}
.pagination a{min-width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px;
  background:#fff;border:1px solid var(--line);font-weight:700;color:var(--muted)}
.pagination a.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.pagination a:hover:not(.active){border-color:var(--navy);color:var(--navy)}

/* ---------- Villa detail ---------- */
.grid-main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:26px;align-items:start}
.detail-hero{position:relative;border-radius:22px;overflow:hidden;min-height:480px;color:#fff;background:#0b2545}
.detail-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.detail-hero .overlay{position:relative;z-index:2;padding:0;min-height:480px;display:flex;flex-direction:column;justify-content:flex-end}
.detail-hero .overlay::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(6,22,56,.1),rgba(6,22,56,.55))}
.detail-hero .d-title{position:relative;padding:34px}
.detail-hero .d-title h1{font-size:36px;margin:0 0 8px;font-weight:800}
.detail-hero .d-meta{display:flex;gap:14px;font-size:14px;color:#e3edf9;flex-wrap:wrap}
.gallery-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-top:14px}
.gallery-strip img{height:84px;width:100%;object-fit:cover;border-radius:10px;cursor:pointer;opacity:.8;border:2px solid transparent}
.gallery-strip img.active,.gallery-strip img:hover{opacity:1;border-color:var(--gold)}
.price-box{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow);position:sticky;top:104px}
.price-box .pb-price{font-size:26px;font-weight:800;color:var(--navy)}
.price-box .pb-price small{font-size:13px;color:var(--muted);font-weight:500}
.price-box ul{list-style:none;padding:0;margin:16px 0;display:grid;gap:10px;font-size:14px}
.price-box li{display:flex;justify-content:space-between;color:var(--muted)}.price-box li b{color:var(--text)}
.detail-section{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 20px rgba(21,40,77,.04);padding:30px;margin-top:24px}
.detail-section h3{font-size:22px;color:var(--navy);margin:0 0 20px;display:flex;align-items:center;gap:10px}
.detail-section h3::before{content:"";width:5px;height:22px;background:var(--gold);border-radius:3px}
.info-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.info-item{padding:16px 18px;border:1px solid var(--line);border-radius:14px;background:#f9fbff;display:flex;gap:12px;align-items:center}
.info-item i{font-size:20px;color:var(--navy-2);width:26px;text-align:center}
.info-item .lbl{font-size:12px;color:var(--muted)}.info-item .val{font-weight:700}
.room-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.room-card{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}
.room-card img{aspect-ratio:1.25/1;object-fit:cover;width:100%}
.room-card .pad{padding:14px}.room-card h4{margin:0 0 5px;font-size:16px;color:var(--navy)}.room-card p{margin:0;font-size:13px;color:var(--muted)}
.icon-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:14px}
.icon-tile{padding:20px 10px;border:1px solid var(--line);border-radius:14px;background:#f9fbff;text-align:center}
.icon-tile i{font-size:24px;color:var(--navy)}.icon-tile span{display:block;margin-top:9px;font-size:13px;font-weight:600}
.table-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.usage-table{width:100%;border-collapse:collapse;font-size:14.5px;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.usage-table td{padding:14px 16px;border-bottom:1px solid #eef2f8}.usage-table tr:last-child td{border-bottom:0}
.usage-table td:first-child{width:42%;background:#f7faff;font-weight:700;color:var(--navy)}
.map-embed{border-radius:16px;overflow:hidden;height:340px;border:1px solid var(--line)}.map-embed iframe{width:100%;height:100%;border:0}
.review-summary{display:flex;align-items:center;gap:18px;margin-bottom:20px}
.review-summary .big{font-size:46px;font-weight:800;color:var(--navy)}.stars{color:var(--gold-deep)}
.review-item{display:flex;gap:14px;padding:16px 0;border-top:1px solid var(--line)}
.review-item .avatar{width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:700;flex-shrink:0}
.review-item .r-name{font-weight:700;font-size:14.5px}.review-item .r-date{font-size:12px;color:var(--muted);margin-left:8px}
.review-item p{margin:6px 0 0;font-size:14px}
.review-form{display:flex;gap:10px;margin-top:18px}.review-form input{flex:1;border:1px solid var(--line);border-radius:12px;padding:13px 16px}

/* ---------- Post detail ---------- */
.post-head h1{font-size:30px;color:var(--navy);margin:8px 0 12px}
.post-meta{display:flex;gap:16px;color:var(--muted);font-size:13.5px;padding-bottom:16px;border-bottom:2px solid var(--navy);margin-bottom:24px;flex-wrap:wrap}
.post-body{font-size:16px;line-height:1.9;color:#39495b}.post-body p{margin:0 0 18px}
.post-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:8px 0 24px}
.post-gallery img{aspect-ratio:4/3;object-fit:cover;border-radius:12px}
.quote-box{background:#fbf6e8;border-left:4px solid var(--gold);border-radius:8px;padding:18px 22px;margin:0 0 24px;color:#5a4a17;font-weight:600}
.cta-band{background:linear-gradient(90deg,#062a65,#0d458f);border-radius:16px;padding:28px 32px;display:flex;align-items:center;
  justify-content:space-between;gap:20px;color:#fff;margin:28px 0}
.cta-band h3{margin:0;font-size:21px}.cta-band p{margin:5px 0 0;color:#bcd0e6;font-size:14px}

/* ---------- Contact ---------- */
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:34px}
.contact-card{padding:26px;border-radius:18px;background:#fff;border:1px solid var(--line);text-align:center;box-shadow:0 8px 20px rgba(21,40,77,.04)}
.contact-card .circle{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;margin:0 auto 14px;font-size:26px;color:#fff}
.contact-card h4{margin:0 0 4px;color:var(--navy)}.contact-card .cid{font-size:13.5px;color:var(--muted);margin-bottom:14px}
.contact-cols{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start}
.panel{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 20px rgba(21,40,77,.04);padding:26px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid .full{grid-column:1/-1}
.field-b label{display:block;font-size:13.5px;font-weight:700;margin-bottom:6px;color:var(--navy)}
.input,.field-b input,.field-b select,.field-b textarea{width:100%;border:1px solid #d9e2ef;border-radius:12px;padding:13px 15px;background:#fff}
.field-b textarea{min-height:150px;resize:vertical}
.agree{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin:4px 0 16px}
.info-line{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);font-size:14px}
.info-line i{color:var(--gold-deep);width:20px;text-align:center}.info-line .l-label{color:var(--muted);width:70px}

/* ---------- FAQ ---------- */
.faq-banner{background:linear-gradient(90deg,#062a65,#0d458f);color:#fff;border-radius:18px;overflow:hidden;display:grid;
  grid-template-columns:1.4fr 1fr;align-items:center;margin-top:34px}
.faq-banner .pad{padding:34px}.faq-banner h3{margin:0 0 6px;font-size:22px}.faq-banner p{margin:0;color:#bcd0e6}
.faq-banner .pic{min-height:160px;background:url('../img/hero.jpg') center/cover}
.accordion{display:grid;gap:14px}
.acc-item{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.acc-head{width:100%;text-align:left;padding:20px 22px;font-weight:700;font-size:17px;background:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;gap:14px;color:var(--navy)}
.acc-head .qm{width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:13px;flex-shrink:0}
.acc-head .arr{margin-left:auto;color:var(--muted);transition:.2s}
.acc-item.open .arr{transform:rotate(180deg)}
.acc-body{max-height:0;overflow:hidden;transition:.25s;color:#54637a;font-size:14.5px;line-height:1.7}
.acc-item.open .acc-body{max-height:420px}
.acc-body-inner{padding:0 22px 22px 64px}

/* ---------- Responsive ---------- */
@media (max-width:1200px){
  .cards-5{grid-template-columns:repeat(3,1fr)}.cards-4{grid-template-columns:repeat(2,1fr)}
  .icon-grid{grid-template-columns:repeat(4,1fr)}.room-grid{grid-template-columns:repeat(2,1fr)}
  .info-grid-4{grid-template-columns:repeat(2,1fr)}.search-box{grid-template-columns:repeat(2,1fr)}
  .grid-main{grid-template-columns:1fr}.price-box{position:static}
  .quick-panel{transform:scale(.94);transform-origin:top right}
  .hero h1{font-size:52px}.section-title{font-size:32px}
  .footer-grid{grid-template-columns:1fr 1fr 1fr}
}
@media (max-width:760px){
  .topbar-inner{height:64px}.nav{display:none}.mobile-toggle{display:block}
  .nav.open{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:var(--navy-grad-b);padding:10px 20px;gap:0}
  .nav.open .nav-item{padding:14px 0}
  .hero{min-height:600px;background-position:66% center}.hero-content{padding:90px 0 90px}
  .hero-kicker{font-size:30px}.hero h1{font-size:38px}.hero p{font-size:17px}
  .section{padding:42px 0}.section-head{flex-direction:column;align-items:flex-start}.section-title{font-size:28px}
  .cards-4,.cards-5,.contact-cards,.feature-grid,.info-grid-4,.gallery-strip,.icon-grid,.room-grid,.table-2,.footer-grid,.form-grid,.post-gallery,.contact-cols{grid-template-columns:1fr}
  .search-box{grid-template-columns:1fr}.review-summary{flex-wrap:wrap}
  .faq-banner{grid-template-columns:1fr}.faq-banner .pic{min-height:120px}
  .cta-band{flex-direction:column;text-align:center}.footer-bottom{flex-direction:column}
  .page-hero h1{font-size:32px}
  .quick-panel{display:none}
  .quick-tab{display:none!important}
  .fab-mobile{display:flex;flex-direction:column;gap:10px;position:fixed;right:14px;bottom:18px;z-index:46}
  .fab-mobile a,.fab-mobile button{width:50px;height:50px;border-radius:50%;border:0;color:#fff;display:grid;place-items:center;
    font-size:20px;box-shadow:0 8px 18px rgba(0,0,0,.22)}
}
