/* ══════════════════════════════════════════════
   Pawinée — Modern Thai Wedding Platform
   Redesign 2026 — Solid, Warm, Informative
   ══════════════════════════════════════════════ */

:root {
  --cream: #faf7f2;
  --cream-dark: #f0ebe0;
  --gold: #c9a96e;
  --gold-light: #e0c88a;
  --gold-dark: #a8884a;
  --charcoal: #2c2416;
  --charcoal-light: #4a3f2e;
  --text: #3d3528;
  --text-light: #7a7060;
  --white: #ffffff;
  --sand: #e8dfd0;
  --shadow: 0 2px 24px rgba(44,36,22,0.08);
  --shadow-lg: 0 8px 48px rgba(44,36,22,0.12);
  --radius: 12px;
  --radius-sm: 8px;
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-thai: 'Noto Sans Thai', sans-serif;
  --font-zh: 'Noto Sans SC', 'Noto Sans', sans-serif;
  --font-mono: 'DM Mono', monospace;
  --max-width: 1200px;
  --header-h: 72px;
  --border: #e8dfd0;
  --bg-alt: #faf7f2;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --text-muted: #b0a898;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 24px)}
body{
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font:inherit;border:none;background:none}
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 24px}

/* ── Typography ── */
h1,h2,h3,h4{font-family:var(--font-serif);color:var(--charcoal);font-weight:600;line-height:1.2}
h1{font-size:clamp(2.4rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1rem}
h3{font-size:clamp(1.2rem,2vw,1.5rem);margin-bottom:.5rem}
h4{font-size:1.1rem}
.section-label{
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--gold-dark);
  margin-bottom:.75rem;
}
.section-header{
  text-align:center;
  max-width:680px;
  margin:0 auto 3rem;
}
.section-header p{color:var(--text-light);font-size:1.05rem;line-height:1.6}
p{color:var(--text-light);line-height:1.7}

/* ── Skip Link ── */
.skip-link{position:fixed;top:-100%;left:0;z-index:9999;padding:.5rem 1rem;background:var(--charcoal);color:var(--white);font-size:.85rem;transition:top .2s}
.skip-link:focus{top:0}

/* ═══════════════════════════════
   HEADER / NAV
   ═══════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--header-h);
  background:rgba(250,247,242,.92);
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid rgba(201,169,110,.15);
  transition:background var(--transition);
}
.header-inner{
  max-width:var(--max-width);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
}
.logo{
  font-family:var(--font-serif);
  font-size:1.5rem;
  font-weight:600;
  color:var(--charcoal);
  letter-spacing:-.02em;
}
.logo em{color:var(--gold);font-style:italic}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{
  font-size:.85rem;
  font-weight:500;
  color:var(--text-light);
  transition:color var(--transition);
  position:relative;
}
.nav-links a:hover,.nav-links a.active{color:var(--charcoal)}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;
  height:2px;background:var(--gold);
  transform:scaleX(0);transition:transform var(--transition);
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}

.header-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5rem 1.25rem;
  background:var(--gold);color:var(--white);
  border-radius:100px;
  font-size:.82rem;font-weight:600;
  transition:background var(--transition),transform var(--transition);
}
.header-cta:hover{background:var(--gold-dark);transform:translateY(-1px)}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:4px;background:none}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--charcoal);border-radius:2px;transition:var(--transition)}

.langs{display:flex;gap:4px}
.langs button{
  font-size:.7rem;font-weight:600;padding:3px 8px;
  border-radius:4px;color:var(--text-light);transition:var(--transition);
  text-transform:uppercase;letter-spacing:.05em;
}
.langs button.active{background:var(--gold);color:var(--white)}
.langs button:not(.active):hover{color:var(--charcoal)}

/* ── Mobile Nav ── */
@media(max-width:860px){
  .nav-toggle{display:flex}
  .nav-links{
    position:fixed;top:var(--header-h);left:0;right:0;
    background:var(--cream);
    flex-direction:column;gap:0;padding:1rem 0;
    border-bottom:1px solid var(--sand);
    transform:translateY(-110%);opacity:0;
    transition:var(--transition);pointer-events:none;
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a{padding:.9rem 24px;width:100%;font-size:.95rem}
  .nav-links a::after{display:none}
  .header-cta{display:none}
  .header-cta-mobile{display:inline-flex!important;margin:.5rem 24px}
}
.header-cta-mobile{display:none}

/* ═══════════════════════════════
   HERO
   ═══════════════════════════════ */
.hero{
  min-height:100vh;
  display:flex;align-items:center;
  position:relative;
  overflow:hidden;
  margin-top:0;
  padding-top:var(--header-h);
}
.hero-bg{
  position:absolute;inset:0;
  z-index:0;
}
.hero-bg img{
  width:100%;height:100%;
  object-fit:cover;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,
    rgba(44,36,22,.7) 0%,
    rgba(44,36,22,.4) 40%,
    rgba(44,36,22,.15) 70%,
    rgba(44,36,22,.1) 100%
  );
  z-index:1;
}
.hero-content{
  position:relative;z-index:2;
  max-width:720px;
  padding:4rem 24px;
  color:var(--white);
}
.hero-content .section-label{color:var(--gold-light)}
.hero-content h1{color:var(--white);margin-bottom:1.25rem}
.hero-content .hero-desc{
  font-size:1.15rem;line-height:1.7;
  color:rgba(255,255,255,.85);
  margin-bottom:2rem;
  max-width:560px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 2rem;
  border-radius:100px;
  font-size:.9rem;font-weight:600;
  transition:var(--transition);
  cursor:pointer;
}
.btn-primary{
  background:var(--gold);color:var(--white);
}
.btn-primary:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 4px 20px rgba(201,169,110,.4)}
.btn-outline-light{
  border:1.5px solid rgba(255,255,255,.4);color:var(--white);
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(4px);
}
.btn-outline-light:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.6);transform:translateY(-2px)}
.btn-whatsapp{
  background:#25D366;color:var(--white);
}
.btn-whatsapp:hover{background:#1da851;transform:translateY(-2px);box-shadow:0 4px 20px rgba(37,211,102,.35)}


/* ── Hero Trust Badge ── */
.hero-badge{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.45rem 1.25rem .45rem .55rem;
  background:linear-gradient(135deg,rgba(201,169,110,.18),rgba(201,169,110,.06));
  border:1px solid rgba(201,169,110,.35);
  border-radius:100px;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 2px 16px rgba(201,169,110,.12),inset 0 1px 0 rgba(255,255,255,.1);
  margin-bottom:1.5rem;
  font-size:.82rem;
  letter-spacing:.01em;
}
.badge-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#fff;font-size:.75rem;flex-shrink:0;
  box-shadow:0 1px 6px rgba(201,169,110,.3);
  line-height:1;
}
.badge-text{
  color:rgba(255,255,255,.95);
  font-weight:500;
}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  z-index:2;
  font-family:var(--font-mono);font-size:.65rem;letter-spacing:.2em;
  color:rgba(255,255,255,.5);
  animation:bounce 2s infinite;
}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-8px)}}

/* ── Trust Bar ── */
.trust-bar{
  display:flex;gap:2.5rem;margin-top:2.5rem;
  padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.15);
}
.trust-item .num{font-family:var(--font-serif);font-size:1.8rem;color:var(--white);font-weight:600;line-height:1}
.trust-item .label{font-size:.78rem;color:rgba(255,255,255,.6);margin-top:.25rem}

/* ═══════════════════════════════
   SECTIONS (shared)
   ═══════════════════════════════ */
section{padding:5rem 0}
section.alt{background:var(--white)}
.gold-accent{
  width:60px;height:3px;background:var(--gold);
  margin:0 auto 1.5rem;border-radius:2px;
}

/* ═══════════════════════════════
   WHY THAILAND
   ═══════════════════════════════ */
.why-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.5rem;
}
.why-card{
  background:var(--white);
  padding:2rem;
  border-radius:var(--radius);
  border:1px solid var(--sand);
  transition:var(--transition);
}
.why-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.why-icon{font-size:2rem;margin-bottom:1rem;line-height:1}
.why-card h3{color:var(--charcoal);margin-bottom:.5rem}
.why-card p{font-size:.92rem;color:var(--text-light)}

/* ═══════════════════════════════
   LEGAL GUIDE
   ═══════════════════════════════ */
.legal-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:1.5rem;
}
.legal-step{
  background:var(--white);
  padding:2rem;
  border-radius:var(--radius);
  border:1px solid var(--sand);
  display:flex;gap:1.25rem;
  align-items:flex-start;
}
.legal-step .step-num{
  flex-shrink:0;
  width:44px;height:44px;
  border-radius:50%;
  background:var(--gold);
  color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:1.1rem;font-weight:600;
}
.legal-step h4{color:var(--charcoal);margin-bottom:.3rem;font-family:var(--font-serif)}
.legal-step p{font-size:.88rem;color:var(--text-light);line-height:1.6}
.legal-note{
  background:rgba(201,169,110,.1);
  border-left:3px solid var(--gold);
  padding:1.25rem 1.5rem;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  margin-top:2rem;
  font-size:.9rem;
  color:var(--text);
}
.legal-note strong{color:var(--charcoal)}

/* ═══════════════════════════════
   TRADITIONAL CEREMONY (Timeline)
   ═══════════════════════════════ */
.ceremony-timeline{
  max-width:720px;
  margin:0 auto;
  position:relative;
}
.ceremony-timeline::before{
  content:'';position:absolute;left:24px;top:0;bottom:0;
  width:2px;background:var(--sand);
}
.ceremony-step{
  display:flex;gap:1.5rem;
  margin-bottom:2.5rem;
  position:relative;
}
.ceremony-step:last-child{margin-bottom:0}
.cs-num{
  flex-shrink:0;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--gold);
  color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-serif);font-size:1.2rem;font-weight:600;
  position:relative;z-index:1;
}
.cs-content{
  padding-top:6px;
}
.cs-content h3{font-size:1.2rem;margin-bottom:.2rem}
.cs-thai{
  font-family:var(--font-thai);
  font-size:.85rem;
  color:var(--gold-dark);
  font-weight:400;
  display:block;
}
.cs-content .cs-desc{font-size:.92rem;color:var(--text-light);line-height:1.6;margin-top:.35rem}

/* ═══════════════════════════════
   FEATURES / SERVICES
   ═══════════════════════════════ */
.features-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
}
.feature-card{
  background:var(--white);
  padding:2rem;
  border-radius:var(--radius);
  border:1px solid var(--sand);
  transition:var(--transition);
}
.feature-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.feature-icon{font-size:1.8rem;margin-bottom:.8rem;line-height:1}
.feature-card h3{color:var(--charcoal);margin-bottom:.4rem}
.feature-card p{font-size:.88rem;color:var(--text-light);line-height:1.6}

/* ═══════════════════════════════
   PRICING
   ═══════════════════════════════ */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
  align-items:start;
}
.pricing-card{
  background:var(--white);
  padding:2.5rem 2rem;
  border-radius:var(--radius);
  border:1px solid var(--sand);
  text-align:center;
  transition:var(--transition);
  position:relative;
}
.pricing-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.pricing-card.featured{
  border-color:var(--gold);
  box-shadow:0 0 0 1px var(--gold);
  transform:scale(1.03);
}
.pricing-card.featured:hover{transform:scale(1.03) translateY(-4px)}
.pkg-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--white);
  padding:.25rem 1rem;
  border-radius:100px;
  font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
}
.pc-name{font-family:var(--font-serif);font-size:1.2rem;color:var(--charcoal);font-weight:600;margin-bottom:.5rem}
.pc-price{font-family:var(--font-serif);font-size:2.8rem;color:var(--charcoal);font-weight:600;line-height:1;letter-spacing:-0.02em}
.pc-price span{font-size:.9rem;font-family:var(--font-sans);color:var(--text-light);font-weight:400}
.pc-price .currency{font-size:1.2rem;vertical-align:super;color:var(--gold-dark);font-weight:500}
.pc-desc{font-size:.85rem;color:var(--text-light);margin:1rem 0 1.5rem}
.pricing-card ul{text-align:left;margin-bottom:1.5rem}
.pricing-card ul li{padding:.4rem 0;font-size:.85rem;color:var(--text);display:flex;align-items:center;gap:.6rem}
.pricing-card ul li .check{color:var(--gold);font-weight:700}
.pc-btn{
  width:100%;padding:.75rem;border-radius:100px;
  font-size:.85rem;font-weight:600;
  transition:var(--transition);
  cursor:pointer;
}
.pc-btn.primary{background:var(--gold);color:var(--white)}
.pc-btn.primary:hover{background:var(--gold-dark)}
.pc-btn.outline{border:1.5px solid var(--sand);color:var(--text-light)}
.pc-btn.outline:hover{border-color:var(--gold);color:var(--gold-dark)}

/* ═══════════════════════════════
   COST CALCULATOR
   ═══════════════════════════════ */
.calc-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:2rem;
  align-items:start;
}
.calc-form{
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--sand);
  padding:2rem;
}
.calc-section-title{
  font-family:var(--font-serif);
  font-size:1rem;
  font-weight:600;
  color:var(--charcoal);
  margin-bottom:1rem;
  padding-bottom:.5rem;
  border-bottom:1px solid var(--sand);
}
.calc-section-title:not(:first-child){margin-top:1.5rem}

/* Tier buttons */
.calc-tiers{display:flex;gap:.75rem;flex-wrap:wrap}
.calc-tier{
  flex:1;min-width:160px;
  padding:1.25rem 1rem;
  border:2px solid var(--sand);
  border-radius:var(--radius);
  background:var(--cream);
  cursor:pointer;
  transition:var(--transition);
  text-align:center;
  position:relative;
}
.calc-tier:hover{border-color:var(--gold-light)}
.calc-tier.calc-tier-active{
  border-color:var(--gold);
  background:rgba(201,169,110,.06);
  box-shadow:0 0 0 1px var(--gold);
}
.calc-tier input[type="radio"]{
  position:absolute;opacity:0;pointer-events:none;
}
.calc-tier-name{
  display:block;
  font-family:var(--font-serif);
  font-size:1.1rem;
  font-weight:600;
  color:var(--charcoal);
  margin-bottom:.25rem;
}
.calc-tier-price{
  display:block;
  font-size:1.3rem;
  font-weight:700;
  color:var(--gold-dark);
  font-family:var(--font-mono);
}
.calc-tier-desc{
  display:block;
  font-size:.78rem;
  color:var(--text-light);
  margin-top:.25rem;
}

/* Add-ons list */
.calc-addons{display:flex;flex-direction:column;gap:.75rem}
.calc-addon{
  display:flex;align-items:center;gap:1rem;
  padding:.85rem 1rem;
  border:1px solid var(--sand);
  border-radius:var(--radius-sm);
  background:var(--cream);
  cursor:pointer;
  transition:var(--transition);
}
.calc-addon:hover{border-color:var(--gold-light)}
.calc-addon input[type="checkbox"]{
  width:18px;height:18px;
  accent-color:var(--gold);
  cursor:pointer;
  flex-shrink:0;
}
.calc-addon-info{flex:1;min-width:0}
.calc-addon-name{
  display:block;
  font-size:.88rem;
  font-weight:600;
  color:var(--charcoal);
}
.calc-addon-desc{
  display:block;
  font-size:.78rem;
  color:var(--text-light);
  margin-top:2px;
}
.calc-addon-price{
  font-size:.85rem;
  font-weight:600;
  color:var(--gold-dark);
  white-space:nowrap;
  font-family:var(--font-mono);
}

/* Total sidebar */
.calc-total{
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--sand);
  padding:2rem;
  position:sticky;
  top:calc(var(--header-h) + 24px);
}
.calc-total h3{
  font-family:var(--font-serif);
  font-size:1.1rem;
  color:var(--charcoal);
  margin-bottom:1rem;
  text-align:center;
}
.calc-total-line{
  display:flex;justify-content:space-between;
  font-size:.85rem;
  color:var(--text-light);
  padding:.5rem 0;
}
.calc-total-line.total{
  border-top:2px solid var(--gold);
  margin-top:.5rem;
  padding-top:1rem;
  font-size:1.1rem;
  font-weight:700;
  color:var(--charcoal);
}
.calc-total-line .value{
  font-weight:600;
  font-family:var(--font-mono);
  color:var(--charcoal);
}
.calc-total-line.total .value{
  color:var(--gold-dark);
  font-size:1.3rem;
}
.calc-flower-promise{
  display:flex;align-items:center;gap:.5rem;
  justify-content:center;
  padding:.6rem;
  background:rgba(201,169,110,.08);
  border-radius:var(--radius-sm);
  font-size:.78rem;
  color:var(--gold-dark);
  margin:.75rem 0;
}
.calc-info{display:flex;flex-direction:column;gap:.55rem;margin:1rem 0 .5rem;border-top:1px solid var(--border);padding-top:1rem}
.calc-info-field{width:100%}
.calc-input{width:100%;padding:.65rem .75rem;border:1px solid var(--border);border-radius:8px;font-family:var(--font-body);font-size:.9rem;background:var(--cream);color:var(--text);transition:border .2s,box-shadow .2s;outline:none;box-sizing:border-box}
.calc-input:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,169,110,.2)}
.calc-textarea{resize:vertical;min-height:48px;font-family:var(--font-body)}
.calc-input::placeholder{color:var(--text-muted)}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.calc-book-btn{
  width:100%;
  padding:.9rem;
  background:var(--gold);
  color:var(--white);
  border:none;
  border-radius:100px;
  font-size:1rem;
  font-weight:600;
  cursor:pointer;
  transition:var(--transition);
  margin-top:1rem;
}
.calc-book-btn:disabled{opacity:.6;cursor:not-allowed}
.calc-book-btn:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 4px 20px rgba(201,169,110,.4)}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}

/* Calculator Layout */
.calc-panel{flex:1;min-width:0}
.calc-section{margin-bottom:2rem}
.calc-section h3{font-family:var(--font-serif);font-size:1.05rem;color:var(--charcoal);font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--sand)}
.calc-tier-options{display:flex;gap:.75rem;flex-wrap:wrap}
.calc-tier-options .calc-tier{flex:1;min-width:160px}

/* Total Panel */
.calc-total-panel{
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--sand);
  padding:2rem;
  position:sticky;
  top:calc(var(--header-h) + 24px);
}
.calc-total-header{
  font-family:var(--font-serif);
  font-size:1.1rem;
  font-weight:600;
  color:var(--charcoal);
  margin-bottom:1rem;
  text-align:center;
}
.calc-total-breakdown{margin-bottom:1rem}
.calc-line{
  display:flex;justify-content:space-between;
  font-size:.85rem;
  color:var(--text-light);
  padding:.5rem 0;
}
.calc-line-flower{color:var(--gold-dark);font-size:.82rem}
.calc-divider{
  height:1px;
  background:var(--sand);
  margin:.25rem 0;
}
.calc-line-total{
  border-top:2px solid var(--gold);
  margin-top:.5rem;
  padding-top:1rem;
  font-size:1.1rem;
  font-weight:700;
  color:var(--charcoal);
}
.calc-grand-total{
  color:var(--gold-dark);
  font-size:1.3rem;
  font-weight:700;
  font-family:var(--font-mono);
}
.calc-book-btn small{
  display:block;
  font-size:.7rem;
  font-weight:400;
  opacity:.85;
  margin-top:2px;
}

.calc-deposit-note{
  text-align:center;
  font-size:.72rem;
  color:var(--text-light);
  margin-top:.5rem;
}
.calc-note{
  text-align:center;
  font-size:.72rem;
  color:var(--text-light);
  margin-top:.25rem;
  opacity:.7;
}

/* ═══════════════════════════════
   BOOKING SECTION
   ═══════════════════════════════ */
.booking-wrap{
  max-width:600px;
  margin:0 auto;
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--sand);
  padding:2.5rem;
}
.booking-summary{
  background:rgba(201,169,110,.06);
  border:1px solid var(--gold-light);
  border-radius:var(--radius);
  padding:1.25rem;
  margin-bottom:1.5rem;
}
.booking-summary .bs-line{
  display:flex;justify-content:space-between;
  padding:.35rem 0;
  font-size:.88rem;
  color:var(--text);
}
.booking-summary .bs-line.bs-total{
  border-top:1px solid var(--gold-light);
  margin-top:.5rem;
  padding-top:.75rem;
  font-weight:700;
  font-size:1rem;
}
.booking-form .bf-group{
  margin-bottom:1.25rem;
}
.booking-form label{
  display:block;
  font-size:.82rem;
  font-weight:600;
  color:var(--charcoal);
  margin-bottom:.35rem;
}
.booking-form input,
.booking-form textarea,
.booking-form select{
  width:100%;
  padding:.7rem .9rem;
  border:1px solid var(--sand);
  border-radius:var(--radius-sm);
  font-size:.9rem;
  font-family:var(--font-sans);
  color:var(--text);
  background:var(--cream);
  transition:var(--transition);
}
.booking-form input:focus,
.booking-form textarea:focus,
.booking-form select:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,169,110,.15);
}
.booking-form textarea{resize:vertical;min-height:80px}
.bf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.bf-submit{
  width:100%;
  padding:.9rem;
  background:var(--gold);
  color:var(--white);
  border:none;
  border-radius:100px;
  font-size:1rem;
  font-weight:600;
  cursor:pointer;
  transition:var(--transition);
  margin-top:.5rem;
}
.bf-submit:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 4px 20px rgba(201,169,110,.4)}
.bf-secure{
  text-align:center;
  font-size:.72rem;
  color:var(--text-light);
  margin-top:.75rem;
}

/* ═══════════════════════════════
   FAQ
   ═══════════════════════════════ */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--sand);
  padding:1.25rem 0;
}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  font-weight:500;color:var(--charcoal);cursor:pointer;
  gap:1rem;user-select:none;
}
.faq-q .toggle{
  font-size:1.3rem;color:var(--gold);
  transition:transform var(--transition);
  flex-shrink:0;
}
.faq-item.open .faq-q .toggle{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .4s ease,padding .3s ease;
}
.faq-item.open .faq-a{max-height:400px;padding-top:1rem}
.faq-a p{font-size:.9rem;color:var(--text-light);line-height:1.7}

/* ═══════════════════════════════
   CONTACT
   ═══════════════════════════════ */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
}
.contact-info h2{text-align:left}
.contact-info p{font-size:.95rem;margin-bottom:1.5rem}
.contact-methods{display:flex;flex-direction:column;gap:1rem}
.contact-method{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.25rem;
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--sand);
  transition:var(--transition);
}
.contact-method:hover{border-color:var(--gold);box-shadow:var(--shadow)}
.cm-icon{
  width:44px;height:44px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.cm-icon.gold{background:rgba(201,169,110,.12);color:var(--gold)}
.cm-icon.green{background:rgba(37,211,102,.12);color:#1da851}
.cm-text{font-size:.88rem}
.cm-text strong{display:block;color:var(--charcoal);font-weight:600;font-size:.95rem}
.cm-text span{color:var(--text-light);font-size:.82rem}

.contact-image{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.contact-image img{width:100%;height:400px;object-fit:cover}

/* ═══════════════════════════════
   FOOTER
   ═══════════════════════════════ */
footer{
  background:var(--charcoal);
  color:rgba(255,255,255,.7);
  padding:4rem 0 2rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;
  margin-bottom:3rem;
}
.footer-brand .logo{color:var(--white);font-size:1.6rem;margin-bottom:.75rem}
.footer-brand p{font-size:.88rem;color:rgba(255,255,255,.5);max-width:300px;line-height:1.6}
.footer-col h4{font-family:var(--font-sans);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-light);margin-bottom:1rem;font-weight:600}
.footer-col a{display:block;padding:.35rem 0;font-size:.85rem;color:rgba(255,255,255,.55);transition:color var(--transition)}
.footer-col a:hover{color:rgba(255,255,255,.9)}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:1.5rem;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.35)}

/* ═══════════════════════════════
   WHATSAPP FLOAT
   ═══════════════════════════════ */
.whatsapp-float{
  position:fixed;bottom:1.5rem;right:1.5rem;
  z-index:500;
  width:56px;height:56px;
  border-radius:50%;
  background:#25D366;
  color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:1.8rem;
  box-shadow:0 4px 24px rgba(37,211,102,.4);
  cursor:pointer;
  transition:var(--transition);
  border:none;
}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.5)}

/* ═══════════════════════════════
   TOAST
   ═══════════════════════════════ */
.toast{
  position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(20px);
  z-index:9998;
  background:var(--charcoal);color:var(--white);
  padding:.75rem 1.5rem;
  border-radius:100px;
  font-size:.85rem;
  opacity:0;pointer-events:none;
  transition:var(--transition);
  white-space:nowrap;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══════════════════════════════
   RESPONSIVE
   ═══════════════════════════════ */
@media(max-width:860px){
  .hero{min-height:auto;padding:5rem 0 3rem}
  .hero-content{padding:2rem 24px}
  .hero-content .hero-desc{font-size:1rem}
  .trust-bar{gap:1.5rem;flex-wrap:wrap}
  .trust-item .num{font-size:1.4rem}
  .hero-badge{font-size:.72rem;padding:.35rem .85rem .35rem .45rem;gap:.4rem}
  .hero-badge .badge-icon{width:22px;height:22px;font-size:.62rem}
  .contact-grid{grid-template-columns:1fr}
  .contact-image{order:-1}
  .contact-image img{height:250px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .calc-layout{grid-template-columns:1fr}
  .calc-total{position:static}
  .bf-row{grid-template-columns:1fr}
}
@media(max-width:600px){
  section{padding:3rem 0}
  .why-grid,.features-grid{grid-template-columns:1fr}
  .legal-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .pricing-card.featured{transform:none}
  .pricing-card.featured:hover{transform:translateY(-4px)}
  .footer-grid{grid-template-columns:1fr}
  .calc-tier{min-width:100%}
}

/* ── Utility ── */
.hidden{display:none!important}
.text-center{text-align:center}

/* ── Reveal animation (lightweight) ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── No-js fallback ── */
html.no-js .reveal{opacity:1;transform:none}
