:root{
  --primary:#b08d57; --primary-dark:#937239; --accent:#7fa99b;
  --bg:#fdfbf7; --bg-alt:#f5efe6; --text:#2f2a25; --muted:#8a8178;
  --white:#ffffff; --border:#e8e0d4; --radius:16px; --shadow:0 8px 30px rgba(120,100,70,.08);
  --serif:'Playfair Display',serif; --sans:'Be Vietnam Pro',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--bg);line-height:1.65;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.25;color:var(--text)}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section-alt{background:var(--bg-alt)}
.section-head{text-align:center;max-width:680px;margin:0 auto 44px;display:flex;flex-direction:column;gap:8px;align-items:center}
.section-head h1,.section-head h2{font-size:clamp(1.8rem,3.5vw,2.6rem)}
.section-head p{color:var(--muted)}
.muted{color:var(--muted)}
.text-success{color:#2e7d52}.text-danger{color:#c0392b}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:999px;
  font-weight:600;font-family:var(--sans);border:none;cursor:pointer;transition:.25s;font-size:.95rem;background:var(--bg-alt);color:var(--text)}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 18px rgba(176,141,87,.35)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-outline{background:transparent;border:1.5px solid var(--primary);color:var(--primary)}
.btn-light{background:#fff;color:var(--primary)}
.btn-lg{padding:15px 34px;font-size:1.05rem}
.btn-sm{padding:6px 14px;font-size:.82rem}
.btn-danger{background:#fbeae8;color:#c0392b}
.link{color:var(--primary);font-weight:600}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(253,251,247,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);transition:.3s}
.site-header.scrolled{box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:72px}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:700}
.brand-mark{color:var(--primary)}
.main-nav ul{display:flex;gap:26px;list-style:none}
.main-nav a{font-weight:500;font-size:.95rem;position:relative;padding:4px 0}
.main-nav a:hover{color:var(--primary)}
.header-actions{display:flex;align-items:center;gap:14px}
.lang-switch{border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:.8rem;font-weight:600}
.nav-toggle{display:none;font-size:1.6rem;background:none;border:none;cursor:pointer}

/* Hero */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;
  background:linear-gradient(120deg,#efe6d8,#e3ece8);overflow:hidden}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(176,141,87,.12),transparent 60%)}
.hero-content{position:relative;max-width:680px}
.hero-content h1{font-size:clamp(2.2rem,5vw,3.8rem);margin-bottom:18px}
.hero-content p{font-size:1.15rem;color:var(--muted);margin-bottom:28px}

/* Grid + cards */
.grid{display:grid;gap:26px}
.grid-services{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.grid-combos{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.3s;border:1px solid var(--border)}
.card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(120,100,70,.14)}
.card-img{display:block;aspect-ratio:4/3;overflow:hidden;background:var(--bg-alt)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:20px}
.card-body h3{font-size:1.18rem;margin-bottom:8px}
.card-body p{color:var(--muted);font-size:.92rem;margin-bottom:14px}
.card-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.price{color:var(--primary);font-weight:700;font-family:var(--sans)}

/* Combo */
.combo-card{padding:26px;text-align:center;position:relative;display:flex;flex-direction:column;gap:10px;align-items:center}
.badge{display:inline-block;padding:3px 12px;border-radius:999px;font-size:.72rem;font-weight:600;background:var(--bg-alt);color:var(--muted)}
.tier-gold{background:#f5e6c8;color:#9b7d2f}.tier-vip{background:#efe0f0;color:#7a3d86}.tier-silver{background:#e8ecef;color:#586b78}
.combo-price{font-family:var(--serif);font-size:1.8rem;color:var(--primary);font-weight:700}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.gallery-item{aspect-ratio:1;border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery-item:hover img{transform:scale(1.08)}

/* Testimonials */
.testimonial-carousel{overflow:hidden}
.testimonial-track{display:flex;gap:24px;transition:transform .5s ease}
.testimonial{flex:0 0 min(360px,85%);background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);border:1px solid var(--border)}
.testimonial blockquote{font-style:italic;color:var(--text);margin-bottom:16px}
.stars{color:#e0a93b;margin-bottom:4px}

/* CTA */
.cta-band{background:linear-gradient(120deg,var(--primary),var(--accent));color:#fff;text-align:center;padding:64px 0}
.cta-band h2{color:#fff;font-size:2.2rem;margin-bottom:10px}
.cta-band p{margin-bottom:24px;opacity:.92}

/* Filter / chips */
.filter-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:36px}
.chip{padding:8px 18px;border-radius:999px;background:#fff;border:1px solid var(--border);font-size:.9rem;font-weight:500;transition:.2s}
.chip:hover,.chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Breadcrumb */
.breadcrumb{padding:18px 20px;font-size:.88rem;color:var(--muted)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb .sep{margin:0 8px}
.breadcrumb .current{color:var(--text)}

/* Detail */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;margin-bottom:36px}
.detail-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.detail-info h1{font-size:2.2rem;margin-bottom:12px}
.detail-info .lead{color:var(--muted);font-size:1.1rem;margin-bottom:20px}
.spec{list-style:none;margin-bottom:24px}
.spec li{padding:8px 0;border-bottom:1px dashed var(--border)}
.rich{line-height:1.8}.rich p{margin-bottom:14px}.rich h2,.rich h3{margin:24px 0 12px}
.detail-content{max-width:820px}

/* Posts */
.post-card .card-body time{color:var(--muted);font-size:.82rem}
.tag{display:inline-block;background:var(--bg-alt);color:var(--primary);padding:2px 10px;border-radius:999px;font-size:.75rem;margin:4px 4px 0 0}
.post-detail{max-width:820px}
.post-head h1{font-size:2.4rem;margin-bottom:10px}
.post-cover{border-radius:var(--radius);margin:20px 0;box-shadow:var(--shadow)}
.share{margin-top:24px;display:flex;gap:12px;align-items:center}
.share a{color:var(--primary);font-weight:600}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:36px}
.pagination a{padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:#fff}
.pagination a.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Team */
.team-card{text-align:center;padding:26px}
.team-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto 16px;background:var(--bg-alt)}
.team-avatar img{width:100%;height:100%;object-fit:cover}
.team-card .role{color:var(--primary);font-weight:600;font-size:.88rem;display:block;margin-bottom:8px}

/* Pricing table */
.price-block{margin-bottom:48px}
.price-block h2{margin-bottom:18px}
.price-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.price-table th,.price-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border)}
.price-table th{background:var(--bg-alt);font-family:var(--sans);font-weight:600}
.table-wrapper{overflow-x:auto}

/* Forms */
form label{display:block;margin-bottom:16px;font-weight:500;font-size:.92rem}
input,select,textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:.95rem;margin-top:6px;background:#fff;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(176,141,87,.15)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp{position:absolute;left:-9999px}
.booking-form,.contact-form{max-width:760px;margin:0 auto;padding:32px}
fieldset{border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:22px}
legend{padding:0 10px;font-family:var(--serif);font-weight:600;color:var(--primary)}
.hint{font-size:.85rem;color:var(--muted);margin-top:6px}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:36px;align-items:start;margin-bottom:36px}
.contact-info p{margin-bottom:10px}
.social{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}
.social a{font-weight:600;color:var(--primary)}
.map-wrap iframe{width:100%;height:380px;border:0;border-radius:var(--radius);box-shadow:var(--shadow)}

/* Success */
.success-box{max-width:560px;margin:0 auto;text-align:center;padding:48px 32px}
.success-icon{width:72px;height:72px;border-radius:50%;background:#e6f4ec;color:#2e7d52;font-size:2.4rem;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.booking-code{background:var(--bg-alt);border-radius:10px;padding:14px;margin:18px 0;font-size:1.1rem}
.summary{list-style:none;text-align:left;max-width:380px;margin:0 auto 18px}
.summary li{padding:8px 0;border-bottom:1px dashed var(--border)}

/* Footer */
.site-footer{background:#2f2a25;color:#d8cfc2;padding-top:56px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding-bottom:36px}
.footer-brand{color:#fff;font-size:1.4rem;margin-bottom:14px}
.site-footer h4{color:#fff;margin-bottom:14px;font-family:var(--sans);font-size:1rem}
.footer-links{list-style:none}.footer-links li{margin-bottom:8px}
.footer-links a:hover,.site-footer .social a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;font-size:.85rem;text-align:center}

/* Float call */
.float-call{position:fixed;right:20px;bottom:20px;width:54px;height:54px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 8px 24px rgba(176,141,87,.5);z-index:90;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(176,141,87,.5)}70%{box-shadow:0 0 0 16px rgba(176,141,87,0)}100%{box-shadow:0 0 0 0 rgba(176,141,87,0)}}

/* Flash */
.flash-wrap{margin:18px auto}
.flash{padding:14px 18px;border-radius:10px;margin-bottom:10px;font-size:.95rem}
.flash-success{background:#e6f4ec;color:#256b44;border:1px solid #b7e0c6}
.flash-error{background:#fbeae8;color:#a5311f;border:1px solid #f1c4bd}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
  .detail-grid,.contact-grid,.footer-grid{grid-template-columns:1fr}
  .main-nav{position:fixed;inset:72px 0 auto 0;background:#fff;border-bottom:1px solid var(--border);
    transform:translateY(-120%);transition:.3s;box-shadow:var(--shadow)}
  .main-nav.open{transform:none}
  .main-nav ul{flex-direction:column;padding:18px 20px;gap:4px}
  .main-nav li{border-bottom:1px solid var(--border)}.main-nav a{display:block;padding:12px 0}
  .nav-toggle{display:block}
  .header-actions .btn-book{display:none}
}
@media(max-width:600px){.form-row{grid-template-columns:1fr}.section{padding:48px 0}}
