:root{
  --bg:#f6f7f9; --card:#fff; --ink:#1f2933; --muted:#555; --dim:#888;
  --line:#e3e7ec; --accent:#e0345a; --accent-d:#b81f44; --head:#2c3e50;
  --ok:#1a8a1a; --okbg:#e3f7e3; --warn:#8a6d00; --warnbg:#fff8e6;
  --radius:14px; --shadow:0 2px 10px rgba(20,30,50,.07);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',system-ui,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:24px 20px}
.muted{color:var(--muted)} .dim{color:var(--dim)}

/* nav */
.nav{display:flex;align-items:center;gap:18px;padding:12px 20px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;white-space:nowrap}
.brand{font-size:22px;font-weight:800;color:var(--head);flex-shrink:0}
.brand span{color:var(--accent)}
.nav-search{flex:1;min-width:0}
.nav-search input{width:100%;max-width:420px;padding:9px 14px;border:1px solid var(--line);border-radius:999px;font-size:14px;background:#fff}
.nav-links{display:flex;align-items:center;gap:16px;flex-shrink:0}
.nav-links a{font-size:14px;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
.nav-links a.btn-primary{color:#fff}
.nav-links a.btn-primary:hover{color:#fff}
.nav-links a.btn-ghost{color:var(--muted)}
.nav-user{font-weight:600;font-size:14px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;border-radius:10px;border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;background:#eef1f4;color:var(--ink);transition:.15s}
.btn:hover{filter:brightness(.97)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-d)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--muted)}
.btn-block{width:100%}
.btn-sm{padding:6px 11px;font-size:13px}

/* flash */
.flash{max-width:1180px;margin:14px auto 0;padding:11px 18px;border-radius:10px;font-size:14px}
.flash-success{background:var(--okbg);color:var(--ok)}
.flash-error{background:#fde3e3;color:#c0392b}
.flash-info{background:#e7f0fb;color:#1c5aa6}

/* hero */
.hero{background:linear-gradient(135deg,#2c3e50,#3d5a73);color:#fff;border-radius:var(--radius);padding:40px 36px;margin-bottom:28px}
.hero h1{margin:0 0 8px;font-size:30px}
.hero p{margin:0;opacity:.9}

/* grid + cards */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:22px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.15s}
.card:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(20,30,50,.12)}
.card .ph{aspect-ratio:3/2;background:#dde;overflow:hidden}
.card .ph img,.card .ph svg{width:100%;height:100%;object-fit:cover}
.card .body{padding:14px 16px}
.card .ttl{font-weight:700;font-size:16px;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .loc{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .meta{display:flex;gap:10px;color:var(--dim);font-size:12px;margin-top:8px}
.card .price{margin-top:10px;font-size:15px}
.card .price b{font-size:18px}

.section-title{font-size:20px;margin:0 0 16px;font-weight:700}

/* villa detail */
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:150px;gap:8px;border-radius:var(--radius);overflow:hidden;margin-bottom:22px}
.gallery .g0{grid-row:span 2;grid-column:1}
.gallery button{position:relative;overflow:hidden;background:#dde;border:0;padding:0;cursor:pointer}
.gallery button img,.gallery a img,.gallery a svg{width:100%;height:100%;object-fit:cover;transition:.2s}
.gallery button:hover img{transform:scale(1.05)}
.g-more{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(15,23,35,.5);color:#fff;font-weight:700;font-size:15px}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(10,14,20,.92);display:flex;align-items:center;justify-content:center}
.lb[hidden]{display:none}
.lb-img{max-width:90vw;max-height:86vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 50px rgba(0,0,0,.6)}
.lb-close{position:absolute;top:18px;right:24px;background:transparent;border:0;color:#fff;font-size:38px;line-height:1;cursor:pointer}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:0;color:#fff;font-size:34px;width:54px;height:54px;border-radius:50%;cursor:pointer}
.lb-nav:hover{background:rgba(255,255,255,.25)}
.lb-prev{left:24px}.lb-next{right:24px}
.lb-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;font-size:14px;background:rgba(0,0,0,.4);padding:5px 14px;border-radius:999px}
.detail{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start}
@media(max-width:880px){.detail{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}}
.detail h1{margin:0 0 4px;font-size:26px}
.tagline{margin:0 0 6px;font-size:16px;font-style:italic;color:var(--accent);font-weight:600}
.highlights{list-style:none;padding:0;margin:16px 0;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.highlights li{position:relative;padding-left:24px;font-size:14px;color:var(--ink)}
.highlights li::before{content:"✓";position:absolute;left:0;top:0;color:#1a8a1a;font-weight:800}
@media(max-width:560px){.highlights{grid-template-columns:1fr}}
.villa-desc{font-size:15px;line-height:1.7;color:#333}
.villa-desc br+br{display:block;content:"";margin-top:8px}
.card-tag{margin:2px 0 2px;font-size:12.5px;color:var(--accent);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.amen{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.amen span{background:#eef1f4;border-radius:999px;padding:5px 12px;font-size:13px;color:var(--muted)}
.specs{display:flex;gap:18px;color:var(--muted);font-size:14px;margin:8px 0 14px}
.video{aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;margin-top:18px;border:1px solid var(--line)}
.video iframe{width:100%;height:100%;border:0}

/* booking widget */
.widget{position:sticky;top:84px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.widget .from{font-size:14px;color:var(--muted);margin-bottom:14px}
.widget .from b{font-size:22px;color:var(--ink)}
.field{margin-bottom:12px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-family:inherit;background:#fff}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quote{border-top:1px solid var(--line);margin-top:14px;padding-top:14px;font-size:14px}
.quote .ln{display:flex;justify-content:space-between;margin:4px 0;color:var(--muted)}
.quote .tot{display:flex;justify-content:space-between;font-weight:700;font-size:16px;color:var(--ink);margin-top:8px}
.note{font-size:12px;color:var(--dim);margin-top:8px}
.reserve-at{margin-top:10px;text-align:center;font-size:14px;color:#7a2233;
  background:linear-gradient(135deg,#fff1f4,#ffe3ea);border:1px solid #f6c9d5;border-radius:10px;padding:10px 12px}
.reserve-at b{color:var(--accent);font-size:17px}
.reserve-sub{display:block;font-size:11.5px;color:var(--muted);margin-top:2px}
.unavail{font-size:12px;color:#c0392b;margin-top:6px}

/* tables */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;margin-bottom:22px}
.panel-h{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;white-space:nowrap}
.panel-h h2{margin:0;font-size:16px;flex-shrink:0}
.panel-h .spacer{flex:1;min-width:0}
table{width:100%;border-collapse:collapse;table-layout:fixed}
th,td{text-align:left;padding:11px 14px;font-size:14px;border-bottom:1px solid var(--line);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
th{background:#fafbfc;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}
tbody tr:hover{background:#fafcff}
.right{text-align:right}

/* pills */
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}
.pill-paid{background:var(--okbg);color:var(--ok)}
.pill-pending{background:var(--warnbg);color:var(--warn)}
.pill-cancelled{background:#fde3e3;color:#c0392b}
.pill-completed{background:#e7f0fb;color:#1c5aa6}
.pill-active{background:var(--okbg);color:var(--ok)}
.pill-inactive{background:#eee;color:#777}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.stat .k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.stat .v{font-size:24px;font-weight:800;margin-top:4px}
.stat.accent{background:linear-gradient(135deg,#2c3e50,#3d5a73);color:#fff}
.stat.accent .k{color:#cdd6e0}
.stat.gold{background:linear-gradient(135deg,#8a6d00,#c9a227);color:#fff}
.stat.gold .k{color:#f3ead0}

/* auth */
.auth-wrap{max-width:420px;margin:40px auto}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px}
.auth-card h1{margin:0 0 4px;font-size:24px}
.auth-card .sub{color:var(--muted);font-size:14px;margin-bottom:20px}
.auth-alt{text-align:center;margin-top:16px;font-size:14px;color:var(--muted)}
.seed-hint{margin-top:18px;font-size:12px;color:var(--dim);background:#fafbfc;border:1px dashed var(--line);border-radius:9px;padding:10px 12px}

/* diff (approvals) */
.diff{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:10px 0}
.diff .old,.diff .new{border-radius:9px;padding:12px;font-size:13px}
.diff .old{background:#fde3e3}.diff .new{background:var(--okbg)}
.kv{margin:3px 0}

.tabbar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.tabbar a{padding:8px 14px;border-radius:9px;background:var(--card);border:1px solid var(--line);font-size:14px;color:var(--muted)}
.tabbar a.active{background:var(--head);color:#fff;border-color:var(--head)}
.empty{padding:40px;text-align:center;color:var(--dim)}
.breadcrumb{font-size:13px;color:var(--muted);margin-bottom:12px}

/* ===== impressive home ===== */
.home-hero{position:relative;border-radius:20px;overflow:hidden;margin-bottom:30px;min-height:440px;display:flex;align-items:center;
  background-image:linear-gradient(180deg,rgba(15,23,35,.35),rgba(15,23,35,.78)),var(--hero);background-size:cover;background-position:center}
.home-hero-inner{padding:48px 40px;color:#fff;max-width:820px}
.eyebrow{display:inline-block;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;background:rgba(255,255,255,.15);padding:6px 14px;border-radius:999px;backdrop-filter:blur(4px)}
.home-hero h1{font-size:44px;line-height:1.1;margin:16px 0 10px;font-weight:800;text-shadow:0 2px 18px rgba(0,0,0,.3)}
.home-hero p{font-size:17px;opacity:.94;margin:0 0 26px;max-width:620px}
.searchbar{display:flex;gap:0;background:#fff;border-radius:14px;padding:8px;box-shadow:0 14px 40px rgba(0,0,0,.25);max-width:760px;flex-wrap:nowrap;white-space:nowrap}
.sb-field{flex:1;min-width:0;padding:6px 14px;border-right:1px solid var(--line);display:flex;flex-direction:column}
.sb-field:last-of-type{border-right:0}
.sb-field label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.sb-field input,.sb-field select{border:0;outline:0;font-size:14px;padding:4px 0;background:transparent;color:var(--ink);font-family:inherit;min-width:0}
.sb-guests{max-width:120px}
.sb-go{flex-shrink:0;margin-left:6px;border-radius:10px;padding:0 24px}
.chips{display:flex;gap:9px;margin-top:18px;flex-wrap:wrap}
.chip{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);color:#fff;padding:7px 15px;border-radius:999px;font-size:13px;backdrop-filter:blur(4px)}
.chip:hover{background:rgba(255,255,255,.28)}
@media(max-width:760px){.home-hero h1{font-size:32px}.searchbar{flex-wrap:wrap}.sb-field{border-right:0;flex-basis:46%}.sb-go{width:100%;margin:6px 0 0;padding:12px}}

.valueprops{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:6px 0 34px}
.vp{display:flex;gap:13px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.vp-i{font-size:24px;flex-shrink:0}
.vp b{display:block;font-size:15px}
.vp span{font-size:13px;color:var(--muted)}

.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 16px;white-space:nowrap}
.badge{position:absolute;top:10px;left:10px;background:#fff;color:var(--ink);font-size:12px;font-weight:700;padding:5px 11px;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.card .ph{position:relative}

.steps{margin:44px 0}
.steps-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.step-n{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;font-size:18px;margin-bottom:10px}
.step b{display:block;font-size:17px;margin-bottom:4px}
.step p{margin:0;color:var(--muted);font-size:14px}

.testi{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin:40px 0}
.t-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.t-card p{margin:0 0 12px;font-size:15px;line-height:1.6}
.t-card span{color:var(--muted);font-size:13px;font-weight:600}

.cta-band{display:flex;align-items:center;justify-content:space-between;gap:20px;background:linear-gradient(135deg,#2c3e50,#3d5a73);color:#fff;border-radius:20px;padding:32px 36px;margin:40px 0 10px;white-space:nowrap}
.cta-band h2{margin:0 0 4px;font-size:24px}
.cta-band p{margin:0;opacity:.9}
@media(max-width:680px){.cta-band{flex-direction:column;text-align:center}}

/* ===== payment options ===== */
.btn-gold{background:linear-gradient(135deg,#8a6d00,#c9a227);color:#fff}
.btn-gold:hover{filter:brightness(.96)}
.pay-opts{margin-top:6px}
.pay-opt{position:relative;border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:4px}
.pay-opt-best{border-color:#c9a227;background:#fffdf5}
.pay-opt-head{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:15px}
.pay-amt{font-size:18px}
.pay-opt-sub{font-size:12.5px;color:var(--muted);margin:4px 0 12px}
.pay-opt-sub s{color:var(--dim)}
.pay-or{text-align:center;color:var(--dim);font-size:12px;margin:8px 0;text-transform:uppercase;letter-spacing:1px}
.pay-badge{position:absolute;top:-9px;right:12px;background:#c9a227;color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px}

/* ===== notify box ===== */
.notify-box{margin-top:18px;border-top:1px solid var(--line);padding-top:16px;text-align:left}
.notify-btns{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.btn-wa{background:#25d366;color:#fff}
.btn-wa:hover{filter:brightness(.95)}
.btn-tg{background:#229ed9;color:#fff}
.btn-tg:hover{filter:brightness(.95)}
.notify-msg{background:#fafbfc;border:1px solid var(--line);border-radius:9px;padding:12px;font-size:12.5px;white-space:pre-wrap;color:var(--muted);font-family:inherit;margin:0;max-height:180px;overflow:auto}

/* ===== site footer ===== */
.site-footer{margin-top:50px;background:var(--head);color:#cdd6e0}
.footer-inner{max-width:1180px;margin:0 auto;padding:40px 20px 28px;display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:30px}
.footer-brand .brand{color:#fff;font-size:22px}
.footer-brand .brand span{color:var(--accent)}
.footer-brand p{margin:12px 0 0;font-size:13.5px;line-height:1.6;color:#aebaccd6;color:#a9b4c2;max-width:340px}
.footer-col h4{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:#fff}
.footer-col a,.footer-col span{display:block;font-size:14px;color:#a9b4c2;margin-bottom:9px;text-decoration:none}
.footer-col a:hover{color:#fff}
.footer-bar{border-top:1px solid rgba(255,255,255,.12)}
.footer-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  max-width:1180px;margin:0 auto;padding:16px 20px;font-size:13px;color:#8c98a8;white-space:nowrap}
.footer-legal a{color:#a9b4c2;text-decoration:none}
.footer-legal a:hover{color:#fff}
@media(max-width:780px){.footer-inner{grid-template-columns:1fr 1fr;gap:24px}.footer-bar{flex-direction:column;text-align:center}}
@media(max-width:460px){.footer-inner{grid-template-columns:1fr}}

/* ===== toasts ===== */
.toast-wrap{position:fixed;top:18px;right:18px;z-index:200;display:flex;flex-direction:column;gap:10px}
.toast{min-width:220px;max-width:340px;padding:12px 16px;border-radius:10px;font-size:14px;color:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.18);opacity:0;transform:translateX(20px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast-success{background:#1a8a1a}.toast-error{background:#c0392b}.toast-info{background:#2c3e50}

/* ===== modal ===== */
.modal-ov{position:fixed;inset:0;z-index:210;background:rgba(15,23,35,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:.2s}
.modal-ov.show{opacity:1}
.modal{background:#fff;border-radius:14px;max-width:420px;width:92%;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:translateY(10px);transition:.2s}
.modal-ov.show .modal{transform:none}
.modal h3{margin:0 0 8px;font-size:19px;color:var(--head)}
.modal p{margin:0 0 20px;color:var(--muted);font-size:14px;line-height:1.5}
.modal-btns{display:flex;justify-content:flex-end;gap:10px}
.btn-danger{background:#c0392b;color:#fff}
.btn-danger:hover{background:#a5311f}
.btn-danger-text{color:#c0392b}

/* ===== dropzone + photo grid ===== */
.photo-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.photo-thumb{position:relative;width:120px}
.photo-thumb img{width:120px;height:80px;object-fit:cover;border-radius:7px;border:1px solid var(--line);display:block}
.photo-thumb button{position:absolute;top:4px;right:4px;background:rgba(192,57,43,.92);color:#fff;border:0;border-radius:50%;width:22px;height:22px;cursor:pointer;line-height:1;font-size:15px}
.photo-thumb button:hover{background:#c0392b}
.dropzone{border:2px dashed var(--line);border-radius:12px;padding:26px;text-align:center;cursor:pointer;background:#fafbfc;transition:.15s}
.dropzone:hover{border-color:#9db4d0;background:#f2f6fb}
.dropzone.dz-over{border-color:var(--accent);background:#fff1f4}
.dropzone.dz-busy{opacity:.6;pointer-events:none}
.dz-inner b{display:block;font-size:15px;color:var(--ink)}
.dz-hint{font-size:13px;color:var(--muted)}

/* ===== flatpickr theme ===== */
.flatpickr-day.selected,.flatpickr-day.selected:hover,.flatpickr-day.startRange,.flatpickr-day.endRange,
.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.flatpickr-day.inRange{background:#fdeef2;border-color:#fdeef2;box-shadow:-5px 0 0 #fdeef2,5px 0 0 #fdeef2}
.flatpickr-day:hover{background:#fdeef2}
.flatpickr-day.today{border-color:var(--accent)}
.flatpickr-day.today:hover{background:var(--accent);color:#fff}
.flatpickr-current-month .flatpickr-monthDropdown-months,.flatpickr-current-month input.cur-year{color:var(--head);font-weight:700}
span.flatpickr-weekday{color:var(--muted);font-weight:600}
.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:var(--accent)}
.flatpickr-calendar{box-shadow:0 10px 40px rgba(20,30,50,.18);border-radius:12px;font-family:inherit}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover{color:#cfd4da}

/* ===== UPI pay ===== */
.upi-pay{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}
@media(max-width:640px){.upi-pay{grid-template-columns:1fr}}
.upi-qr{text-align:center}
.upi-qr img{border:1px solid var(--line);border-radius:12px;padding:8px;background:#fff;width:220px;height:220px}
.upi-intent{margin-top:12px}
.upi-info .ln{display:flex;justify-content:space-between;margin:7px 0;color:var(--muted);font-size:14px}
.upi-info .ln b{color:var(--ink)}
