/*
Theme Name: Termales Don Grimaldo
Template: termales-base
Version: 1.0.23
Author: Termales Don Grimaldo
Description: Tema personalizado para Termales Don Grimaldo — oasis de bienestar en la selva peruana. Hijo de Termales Base.
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&display=swap');

:root{
  --green:#057429;
  --green-light:#1AAD5A;
  --green-dark:#044A1A;
  --green-pale:#E8F5ED;
  --green-soft:#C8E6D4;
  --orange:#ef7c00;
  --orange-light:#F5A04A;
  --orange-dark:#C45F00;
  --orange-pale:#FDF2E8;
  --orange-soft:#F5E0CC;
  --red:#e3000f;
  --red-pale:#FDEBEC;
  --yellow:#F4C430;
  --yellow-pale:#FEF8E8;
  --logo-green:#057429;
  --logo-orange:#ef7c00;
  --logo-red:#e3000f;
  --bg:#FDFCF9;
  --bg-warm:#F8F5F0;
  --surface:#fff;
  --sand:#E8E2D9;
  --text:#2C1810;
  --text-muted:#7A6B5F;
  --text-light:#A89B8F;
  --accent:var(--green);
  --accent-soft:var(--green-soft);
  --border:var(--green-soft);
  --radius:16px;
  --radius-sm:10px;
  --radius-xs:6px;
  --shadow:0 4px 24px rgba(5,116,41,.08);
  --shadow-lg:0 12px 40px rgba(5,116,41,.12);
  --shadow-orange:0 8px 24px rgba(239,124,0,.30);
  --shadow-xl:0 20px 60px rgba(0,0,0,.12);
  --transition:all .25s cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:1rem;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;letter-spacing:-.02em;line-height:1.15}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.lazy-bg{background:var(--bg-warm)}

/* Header */
@keyframes headerIn{
  from{opacity:0;transform:translateY(-12px)}
  to{opacity:1;transform:translateY(0)}
}
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(253,251,247,.96);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);border-bottom:1px solid rgba(27,157,92,.08);padding:0 40px;height:88px;display:flex;align-items:center;justify-content:space-between;transition:height .5s cubic-bezier(.22,1,.36,1),background .5s cubic-bezier(.22,1,.36,1),box-shadow .5s cubic-bezier(.22,1,.36,1),backdrop-filter .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1),opacity .45s cubic-bezier(.22,1,.36,1);animation:headerIn .6s ease-out}
header.scrolled{background:rgba(253,251,247,.97);box-shadow:0 4px 24px rgba(0,0,0,.06);height:76px}
header.hidden{transform:translateY(-100%);opacity:0}
body.admin-bar header{top:32px}
.logo{display:flex;align-items:center;transition:transform .35s ease}
.logo img{height:58px;width:auto;display:block}
nav.desktop{display:flex;gap:6px;align-items:center;font-size:15px;font-weight:500;color:var(--text-muted)}
nav.desktop a{position:relative;padding:10px 16px;border-radius:20px;transition:color .2s,background .2s}
nav.desktop a:hover{color:var(--green-dark);background:var(--green-pale)}
nav.desktop a.nav-cta:hover{background:var(--green-dark);color:#fff}
.nav-cta{background:var(--green);color:#fff;padding:11px 24px;border-radius:30px;font-weight:600;font-size:14px;transition:background .2s,transform .2s,box-shadow .2s;display:inline-flex;align-items:center;gap:6px;box-shadow:0 2px 8px rgba(27,157,92,.25)}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(27,157,92,.35)}
.menu-btn{display:none;background:none;border:none;color:var(--green);cursor:pointer;padding:6px;border-radius:8px;transition:background .2s}
.menu-btn:hover{background:var(--green-pale)}
.menu-btn svg{display:block}

.mobile-nav{position:fixed;inset:0;background:rgba(253,252,249,.98);backdrop-filter:blur(20px);z-index:999;display:flex;flex-direction:column;gap:0;padding:0;font-size:16px;font-weight:500;overflow-y:auto;visibility:hidden;opacity:0;pointer-events:none;transition:opacity .3s ease,visibility .3s ease}
.mobile-nav.open{visibility:visible;opacity:1;pointer-events:auto}
.mobile-nav-header{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:rgba(253,252,249,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--green-soft)}
.mobile-nav-logo{height:40px;width:auto;display:block}
.mobile-nav-links{display:flex;flex-direction:column;padding:8px 20px 12px}
.mobile-nav a{color:var(--text);border-bottom:1px solid var(--green-soft);padding:14px 0;display:flex;align-items:center;justify-content:space-between;transition:color .2s}
.mobile-nav a:hover{color:var(--green)}
.mobile-nav a::after{content:'';display:inline-block;width:8px;height:8px;border-right:2px solid var(--orange);border-bottom:2px solid var(--orange);transform:rotate(-45deg);margin-left:8px;opacity:.6}
.mobile-nav .nav-cta{background:var(--green);color:#fff;text-align:center;margin:12px 20px 20px;justify-content:center;padding:14px 20px;border-radius:30px;font-weight:600;font-size:15px;box-shadow:0 2px 10px rgba(27,157,92,.25);transition:transform .2s,box-shadow .2s;display:flex;align-items:center;gap:6px;border-bottom:none}
.mobile-nav .nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(27,157,92,.35)}
.mobile-nav .nav-cta::after{display:none}
.close-menu{background:var(--green-pale);border:none;color:var(--green);cursor:pointer;width:40px;height:40px;display:grid;place-items:center;border-radius:50%;transition:background .2s,transform .2s;padding:0}
.close-menu:hover{background:var(--green-soft);transform:rotate(90deg)}

/* Buttons */
.btn-primary{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;padding:14px 28px;border-radius:30px;font-weight:600;font-size:15px;border:none;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow);transition:var(--transition);position:relative;overflow:hidden}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{background:#fff;color:var(--green);border:2px solid var(--green-light);padding:14px 28px;border-radius:30px;font-weight:600;font-size:15px;transition:var(--transition);display:inline-flex;align-items:center;gap:8px}
.btn-secondary:hover{background:var(--green-pale)}
.btn-orange{background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;padding:14px 28px;border-radius:30px;font-weight:600;font-size:15px;border:none;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow-orange);transition:var(--transition);position:relative;overflow:hidden}
.btn-orange:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(232,119,34,.40)}
.btn-orange:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--green);border:1px solid var(--green-soft);padding:10px 20px;border-radius:30px;font-weight:500;font-size:13px;transition:var(--transition)}
.btn-ghost:hover{background:var(--green-pale);border-color:var(--green-light)}

/* Hero — portrait image showcased in card, clean light background */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:linear-gradient(135deg,var(--bg) 0%,var(--bg-warm) 100%);max-width:none;margin:0;padding:0}
.hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%231B9D5C' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");z-index:0;opacity:.6}

.hero-inner{position:relative;z-index:2;max-width:1160px;margin:0 auto;padding:120px 32px 80px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}

/* Left content — dark text on light bg */
.hero-left{animation:fadeInUp .7s ease both;display:flex;flex-direction:column;gap:0}
.hero-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;align-items:center}
.hero-pill{display:inline-flex;align-items:center;gap:6px;background:var(--orange-pale);border:1px solid var(--orange-soft);padding:6px 14px;border-radius:30px;font-size:12px;font-weight:600;color:var(--orange-dark)}
.hero-location{display:inline-flex;align-items:center;gap:6px;background:var(--green-pale);border:1px solid var(--green-soft);padding:6px 14px;border-radius:30px;font-size:12px;font-weight:600;color:var(--green-dark)}
.hero h1{font-size:clamp(30px,4.2vw,48px);line-height:1.1;color:var(--text);max-width:540px;margin-bottom:20px}
.hero h1 em{color:var(--green);font-style:italic}
.hero-sub{font-size:clamp(15px,1.5vw,18px);color:var(--text-muted);max-width:500px;margin-bottom:16px;line-height:1.65}
.hero-price{color:var(--green);font-weight:700}
.hero-family{display:flex;align-items:flex-start;gap:10px;max-width:500px;margin-bottom:24px;font-size:15px;color:var(--text);line-height:1.5;background:var(--green-pale);padding:14px 16px;border-radius:var(--radius-sm)}
.hero-family svg{flex-shrink:0;margin-top:2px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.hero-link{margin:0 0 24px;font-size:14px}
.hero-link a{color:var(--text-muted);text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.hero-link a:hover{color:var(--green)}
.trust-hero{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center}
.trust-pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-warm);border:1px solid var(--sand);padding:6px 14px;border-radius:30px;font-size:12px;font-weight:500;color:var(--text-muted)}
.trust-pill svg{vertical-align:middle;margin-right:4px}

/* Right image card — portrait showcased */
.hero-right{animation:fadeInUp .7s .15s ease both;position:relative}
.hero-img-wrap{position:relative;max-width:460px;margin-left:auto;margin-right:auto;width:100%}
.hero-img-wrap::before{content:'';position:absolute;top:-32px;right:-32px;width:100%;height:100%;background:linear-gradient(135deg,var(--green-soft) 0%,var(--orange-soft) 100%);border-radius:var(--radius);z-index:-1;transform:rotate(6deg);box-shadow:0 6px 20px rgba(27,157,92,.08);opacity:.6}
.hero-img-card{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:3/4;max-height:640px;background:var(--surface);border:1px solid var(--green-soft)}
.hero-img-card img{width:100%;height:100%;object-fit:cover;display:block}
.hero-img-badge{position:absolute;bottom:20px;left:20px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);padding:10px 16px;border-radius:30px;font-size:13px;font-weight:600;color:var(--green);box-shadow:0 4px 12px rgba(0,0,0,.1);display:inline-flex;align-items:center;gap:6px}
.hero-img-wrap{position:relative;max-width:460px;margin-left:auto;margin-right:auto;width:100%}
.tripadvisor-badge{position:absolute;top:-14px;right:-14px;width:84px;height:84px;z-index:3;padding:3px;background:#fff;border-radius:50%;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.tripadvisor-badge img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;image-rendering:-webkit-optimize-contrast}


@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* Responsive hero */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;padding:100px 24px 60px;gap:56px;text-align:center;max-width:640px}
  .hero h1{max-width:none;text-align:center}
  .hero-sub{text-align:center;margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .hero-meta{justify-content:center}
  .hero-img-wrap{max-width:400px;margin:0 auto}
  .hero-img-wrap::before{top:-20px;right:-20px}
}

/* Trust bar */
.trust-bar{background:var(--green-pale);border-top:1px solid var(--green-soft);border-bottom:1px solid var(--green-soft);padding:14px 24px}
.trust-inner{max-width:1200px;margin:0 auto;display:flex;gap:32px;align-items:center;justify-content:center;flex-wrap:wrap;font-size:12px;color:var(--green-dark);font-weight:600}
.trust-inner span{display:inline-flex;align-items:center;gap:8px}
.trust-inner span::before{content:'';width:18px;height:18px;display:inline-block;background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0;opacity:.9}
.trust-inner span:nth-child(1)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F7A45' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z'/%3E%3C/svg%3E")}
.trust-inner span:nth-child(2)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F7A45' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E")}
.trust-inner span:nth-child(3)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F7A45' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 4 1 10 7 10'/%3E%3Cpath d='M3.51 15a9 9 0 1 0 2.13-9.36L1 10'/%3E%3C/svg%3E")}
.trust-inner span:nth-child(4)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F7A45' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2.69l5.66 5.66a8 8 0 1 1-11.31 0z'/%3E%3C/svg%3E")}
.trust-inner span:nth-child(5)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F7A45' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9H4.5a2.5 2.5 0 0 1 0-5H6'/%3E%3Cpath d='M18 9h1.5a2.5 2.5 0 0 0 0-5H18'/%3E%3Cpath d='M4 22h16'/%3E%3Cpath d='M10 14.66V17c0 .55-.47.98-.97 1.21C7.85 18.75 7 20.24 7 22'/%3E%3Cpath d='M14 14.66V17c0 .55.47.98.97 1.21C16.15 18.75 17 20.24 17 22'/%3E%3Cpath d='M18 2H6v7a6 6 0 0 0 12 0V2z'/%3E%3C/svg%3E")}
.trust-inner span:nth-child(6)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F7A45' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z'/%3E%3Cpath d='M5 13.5a1.5 1.5 0 1 0 3 0a1.5 1.5 0 1 0 -3 0'/%3E%3Cpath d='M16 13.5a1.5 1.5 0 1 0 3 0a1.5 1.5 0 1 0 -3 0'/%3E%3Cpath d='M17.5 9a4.5 4.5 0 1 0 3.5 1.671l1 -1.671h-4.5'/%3E%3Cpath d='M6.5 9a4.5 4.5 0 1 1 -3.5 1.671l-1 -1.671h4.5'/%3E%3Cpath d='M10.5 15.5l1.5 2l1.5 -2'/%3E%3Cpath d='M9 6.75c2 -.667 4 -.667 6 0'/%3E%3C/svg%3E")}

/* Social Proof Band */
.proof-band{background:var(--bg);padding:48px 24px 32px}
.proof-inner{max-width:1200px;margin:0 auto;display:flex;gap:48px;align-items:center;justify-content:center;flex-wrap:wrap;text-align:center}
.proof-item{min-width:120px}
.proof-item h4{font-size:clamp(28px,3vw,36px);color:var(--green);font-family:'Playfair Display',serif;line-height:1}
.proof-item p{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:6px;font-weight:600}
.proof-div{width:1px;height:48px;background:var(--green-soft);display:none}
@media(min-width:768px){.proof-div{display:block}}

/* As seen on */
.seen-band{background:var(--bg-warm);border-bottom:1px solid var(--green-soft);padding:24px;text-align:center}
.seen-inner{max-width:1200px;margin:0 auto;display:flex;align-items:baseline;justify-content:center;gap:16px;flex-wrap:wrap}
.seen-label{font-size:12px;color:var(--text-light);font-weight:500;letter-spacing:.02em;flex-shrink:0}
.seen-logos{display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:center}
.seen-logos a{font-size:13px;font-weight:600;color:var(--text-muted);transition:color .2s;position:relative;white-space:nowrap}
.seen-logos a:hover{color:var(--green)}
.seen-logos a::after{content:'↗';display:inline-block;margin-left:3px;font-size:10px;color:var(--text-light);opacity:0;transition:opacity .2s}
.seen-logos a:hover::after{opacity:1;color:var(--green)}

/* Sections */
section{padding:80px 24px;max-width:none;margin:0 auto}

/* Host section */
.host-section{background:#fff;padding:80px 24px;border-top:1px solid var(--green-soft);border-bottom:1px solid var(--green-soft)}
.host-inner{max-width:720px;margin:0 auto;text-align:center}
.host-text{font-size:16px;line-height:1.7;color:var(--text);max-width:600px;margin:20px auto 0}
.host-quote{margin:28px auto 0;max-width:640px;padding:20px 24px;background:rgba(255,255,255,.7);border-left:3px solid var(--green);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.host-quote p{font-size:15px;line-height:1.7;color:var(--text-muted);font-style:italic;margin:0;position:relative}
.host-quote p::before{content:'"';color:var(--orange);font-size:20px;font-family:'Playfair Display',serif;line-height:0;vertical-align:-4px;margin-right:2px;font-weight:700}
.host-quote p::after{content:'"';color:var(--orange);font-size:20px;font-family:'Playfair Display',serif;line-height:0;vertical-align:-4px;margin-left:2px;font-weight:700}
.host-stats{margin-top:36px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.host-stat{text-align:center;background:var(--green-pale);border-radius:var(--radius-sm);padding:20px 28px;min-width:120px}
.host-stat span:first-child{font-size:30px;font-weight:700;color:var(--green-dark);font-family:'Playfair Display',serif;line-height:1;display:block}
.host-stat span:last-child{font-size:11px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-top:6px;display:block}
.section-title{font-size:clamp(28px,3.2vw,40px);color:var(--text);margin-bottom:12px;text-align:center}
.section-sub{color:var(--text-muted);text-align:center;max-width:600px;margin:0 auto 52px;font-size:16px;line-height:1.6}
.section-badge{display:inline-flex;align-items:center;gap:6px;background:var(--orange-pale);color:var(--orange-dark);font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em}

/* Experience cards */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.cards-grid{grid-template-columns:1fr}}
/* Experience cards */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.cards-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.exp-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;transition:var(--transition);position:relative;box-shadow:var(--shadow);display:flex;flex-direction:column;border:1px solid var(--green-soft)}
.exp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green) 0%,var(--green-light) 50%,var(--orange) 100%);z-index:3}
.exp-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:var(--shadow-xl);border-color:var(--green-light)}
.exp-card .thumb{height:200px;background-size:cover;background-position:center;position:relative}
.exp-card .thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.35) 100%)}
.exp-card .tag{position:absolute;top:20px;left:20px;background:var(--orange);color:#fff;font-size:11px;font-weight:800;padding:6px 14px;border-radius:20px;z-index:2;box-shadow:0 4px 12px rgba(239,124,0,.3);letter-spacing:.02em}
.exp-card .tag-green{background:var(--green);box-shadow:0 4px 12px rgba(5,116,41,.25)}
.exp-card .tag-soft{background:#fff;color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,.1);border:1px solid var(--green-soft)}
.exp-card .body{padding:26px 28px 22px;flex:1;display:flex;flex-direction:column}
.exp-card h3{font-size:21px;color:var(--text);margin-bottom:10px;font-weight:700;letter-spacing:-.01em}
.exp-card p{font-size:14.5px;color:var(--text-muted);margin-bottom:20px;line-height:1.6;flex:1}
.exp-card .meta{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;font-size:11px;color:var(--green);margin-bottom:4px;font-weight:600}
.exp-card .meta span{display:inline-flex;align-items:center;justify-content:center;gap:4px;background:var(--green-pale);padding:6px 8px;border-radius:20px;line-height:1;text-align:center;min-width:0}
.exp-card .meta span svg{flex-shrink:0}
.exp-card .card-foot{display:flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(90deg,var(--green-pale) 0%,rgba(5,116,41,.04) 100%);border-top:1px solid var(--green-soft);font-size:13px;font-weight:700;color:var(--green-dark)}
.exp-card .foot-soft{background:linear-gradient(90deg,var(--orange-pale) 0%,rgba(239,124,0,.04) 100%);border-top-color:var(--orange-soft);color:var(--orange-dark)}

/* Route Section */
.route-section{padding:100px 24px;background:var(--bg)}

/* Vertical timeline on the left */
.route-timeline{position:relative;max-width:900px;margin:0 auto;padding-left:60px;counter-reset:step}
.route-timeline::before{content:'';position:absolute;top:130px;bottom:40px;left:26px;width:4px;background:linear-gradient(180deg,var(--green) 0%,var(--green-light) 20%,var(--orange) 45%,var(--orange-light) 55%,var(--green-light) 75%,var(--green) 88%,transparent 100%);border-radius:2px;box-shadow:0 0 0 3px var(--green-pale),0 0 20px rgba(5,116,41,.15),0 0 40px rgba(5,116,41,.08)}

/* Timeline start / end caps */

/* Scroll reveal */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
[data-reveal].revealed{opacity:1;transform:translateY(0)}

/* Stagger */
.exp-card[data-reveal]:nth-child(1){transition-delay:0s}
.exp-card[data-reveal]:nth-child(2){transition-delay:.12s}
.exp-card[data-reveal]:nth-child(3){transition-delay:.24s}
.ugc-item[data-reveal]:nth-child(1){transition-delay:0s}
.ugc-item[data-reveal]:nth-child(2){transition-delay:.08s}
.ugc-item[data-reveal]:nth-child(3){transition-delay:.16s}
.ugc-item[data-reveal]:nth-child(4){transition-delay:.24s}
.faq-item[data-reveal]:nth-child(1){transition-delay:0s}
.faq-item[data-reveal]:nth-child(2){transition-delay:.06s}
.faq-item[data-reveal]:nth-child(3){transition-delay:.12s}
.faq-item[data-reveal]:nth-child(4){transition-delay:.18s}
.faq-item[data-reveal]:nth-child(5){transition-delay:.24s}
.faq-item[data-reveal]:nth-child(6){transition-delay:.30s}
.faq-item[data-reveal]:nth-child(7){transition-delay:.36s}
.faq-item[data-reveal]:nth-child(8){transition-delay:.42s}
.faq-item[data-reveal]:nth-child(9){transition-delay:.48s}
.faq-item[data-reveal]:nth-child(10){transition-delay:.54s}

@media(prefers-reduced-motion:reduce){
  [data-reveal],.rt-step{opacity:1;transform:none;transition:none}
}

/* Each step — single card with image+text inside */
.rt-step{position:relative;margin-bottom:56px;opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease;counter-increment:step}
.rt-step.revealed{opacity:1;transform:translateY(0)}

/* Dot on the left line */
.rt-dot{position:absolute;left:-54px;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#fff 0%,var(--green-pale) 100%);border:3px solid var(--green);color:var(--green);font-size:14px;font-weight:800;display:grid;place-items:center;box-shadow:0 0 0 6px var(--green-pale),0 4px 12px rgba(5,116,41,.15);z-index:2;transition:var(--transition)}
.rt-dot.rt-mud{background:linear-gradient(135deg,var(--orange-light) 0%,var(--orange) 100%);border-color:#fff;color:#fff;box-shadow:0 0 0 6px var(--orange-pale),0 4px 16px rgba(239,124,0,.25);width:52px;height:52px;font-size:16px;left:-58px;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 6px var(--orange-pale),0 4px 16px rgba(239,124,0,.25)}50%{box-shadow:0 0 0 12px rgba(239,124,0,.12),0 4px 24px rgba(239,124,0,.35)}}

/* Unified card */
.rt-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--green-soft);box-shadow:var(--shadow);overflow:hidden;transition:var(--transition);display:grid;grid-template-columns:1fr 1fr;align-items:stretch;min-height:260px}
.rt-step:hover .rt-card{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--green-light)}

/* Odd: image left, text right */
.rt-step:nth-child(odd) .rt-card{grid-template-areas:"visual text"}
/* Even: text left, image right */
.rt-step:nth-child(even) .rt-card{grid-template-areas:"text visual"}

/* Visual (image) inside card */
.rt-visual{grid-area:visual;position:relative;overflow:hidden;min-height:260px}
.rt-img{width:100%;height:100%;background-size:cover;background-position:center;position:relative}

.rt-time{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.96);padding:8px 16px;border-radius:20px;font-size:12px;font-weight:700;color:var(--green);box-shadow:0 2px 10px rgba(0,0,0,.10);z-index:2;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--green-soft)}
.rt-time::before{content:'';width:7px;height:7px;background:var(--green);border-radius:50%;display:inline-block}

/* Text side inside card */
.rt-text{grid-area:text;padding:36px 40px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.rt-text::before{content:counter(step,decimal-leading-zero);position:absolute;top:50%;right:20px;transform:translateY(-50%);font-size:120px;font-weight:700;color:var(--green);opacity:.03;font-family:'Playfair Display',serif;line-height:1;pointer-events:none;z-index:0}
.rt-tag{display:inline-flex;align-items:center;gap:5px;background:var(--orange-pale);color:var(--orange-dark);font-size:11px;font-weight:700;padding:5px 14px;border-radius:20px;margin-bottom:14px;width:fit-content;border:1px solid var(--orange-soft);letter-spacing:.02em}
.rt-num{display:block;font-size:11px;font-weight:700;color:var(--text-light);letter-spacing:.1em;margin-bottom:8px;text-transform:uppercase}
.rt-body h4{font-size:clamp(22px,2.4vw,28px);color:var(--text);margin-bottom:12px;font-family:'Playfair Display',serif;line-height:1.2}
.rt-body p{font-size:15px;color:var(--text-muted);margin-bottom:18px;line-height:1.65}
.rt-benefits{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0;margin:0}
.rt-benefits li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text);font-weight:500;line-height:1.5}
.rt-benefits li::before{content:'';width:22px;height:22px;display:block;background-size:14px;background-repeat:no-repeat;background-position:center;flex-shrink:0;margin-top:1px;border-radius:50%;background-color:var(--green-pale);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23057429' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}

/* Mobile — stacked card with dot on left timeline */
@media(max-width:768px){
  .route-timeline{padding-left:52px}
  .route-timeline::before{left:18px;transform:none;top:38px;bottom:40px}
  .rt-step{margin-bottom:40px}
  .rt-dot{left:-50px;top:20px;transform:none;width:36px;height:36px;font-size:13px;box-shadow:0 0 0 4px var(--green-pale);background:#fff}
  .rt-dot.rt-mud{width:42px;height:42px;font-size:14px;left:-53px;box-shadow:0 0 0 4px var(--orange-pale);animation:none;background:var(--orange)}
  .rt-card{grid-template-columns:1fr !important;grid-template-areas:"visual" "text" !important}
  .rt-visual{min-height:200px}
  .rt-text{padding:24px}
  .rt-text::before{font-size:90px;right:12px}
  .rt-step:hover .rt-card{transform:translateY(-4px)}
}


/* UGC Gallery */
.ugc-section{padding:80px 20px 60px;background:var(--bg)}
.ugc-wrap{max-width:1100px;margin:0 auto}
.ugc-header{text-align:center;margin-bottom:40px}
.ugc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
a.ugc-item{display:block}
.ugc-item{aspect-ratio:1;background-size:cover;background-position:center;position:relative;overflow:hidden;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}
.ugc-item:hover{transform:scale(1.02);z-index:2;box-shadow:0 12px 32px rgba(0,0,0,.2)}
.ugc-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;gap:18px;opacity:0;transition:opacity .3s ease}
.ugc-item:hover .ugc-overlay{opacity:1}
.ugc-overlay span{color:#fff;font-size:14px;font-weight:600}
.ugc-footer{text-align:center;margin-top:36px;display:flex;flex-direction:column;align-items:center;gap:14px}
.ugc-follow{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);color:#fff;border-radius:30px;font-weight:600;font-size:14px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px rgba(220,39,67,.3)}
.ugc-follow:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(220,39,67,.4)}
.ugc-hashtag{font-size:14px;color:var(--text-muted);margin:0}
@media(max-width:768px){
  .ugc-grid{grid-template-columns:repeat(2,1fr);gap:3px}
  .ugc-section{padding:60px 12px 48px}
  .ugc-follow{font-size:13px;padding:11px 20px}
}

/* How to Arrive */
.tour-intro{margin:0 0 16px;color:var(--text-muted);line-height:1.6}
.tour-thumb{position:relative;padding-top:56.25%;border-radius:var(--radius-sm);overflow:hidden;background:var(--sand);margin-bottom:12px;border:2px solid var(--green-soft);box-shadow:var(--shadow);cursor:pointer}
.tour-thumb img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.tour-thumb:hover img{transform:scale(1.04)}
.tour-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.45) 100%)}
.tour-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;display:inline-flex;align-items:center;gap:10px;padding:12px 24px;background:var(--orange);color:#fff;border:none;border-radius:100px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.25);transition:var(--transition);font-family:inherit}
.tour-play:hover{background:var(--orange-dark);transform:translate(-50%,-50%) translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.35)}
.tour-play:active{transform:translate(-50%,-50%) translateY(0)}
.tour-play svg{fill:#fff}
.tour-embed{position:relative;padding-top:56.25%;border-radius:var(--radius-sm);overflow:hidden;background:var(--sand);margin-bottom:12px;border:2px solid var(--green-soft);box-shadow:var(--shadow)}
.tour-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.tour-external{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:var(--surface);border:1px solid var(--green);color:var(--green);border-radius:100px;font-weight:500;text-decoration:none;font-size:13px;transition:var(--transition)}
.tour-external:hover{background:var(--green);color:#fff}

.arrive-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.arrive-map-card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--green-soft)}
.arrive-map-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.arrive-map-header .pin{width:36px;height:36px;border-radius:50%;background:var(--green-pale);display:grid;place-items:center;color:var(--green);flex-shrink:0}
.arrive-map-header h3{margin:0;font-size:18px;color:var(--text);font-family:'Inter',sans-serif}
.arrive-address{font-size:15px;color:var(--text);line-height:1.7;margin-bottom:16px}
.arrive-address strong{color:var(--green-dark)}
.map-frame{border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--green-soft);box-shadow:0 4px 16px rgba(5,116,41,.08);margin-bottom:16px}
.map-frame iframe{display:block;width:100%;border:0}
.map-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--green-pale);color:var(--green-dark);border-radius:30px;font-size:13px;font-weight:600;text-decoration:none;border:1px solid var(--green-soft);transition:var(--transition)}
.map-cta:hover{background:var(--green-soft)}

.option-card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--green-soft)}
.tour-card{grid-column:1 / -1}
.option-card h3{margin:0 0 16px;font-size:18px;color:var(--text);font-family:'Inter',sans-serif;display:flex;align-items:center;gap:8px}
.transport-list{display:flex;flex-direction:column;gap:10px}
.transport-row{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-warm);border-radius:var(--radius-sm);border:1px solid var(--sand)}
.transport-row .name{font-weight:600;color:var(--text)}
.transport-row .detail{font-size:13px;color:var(--text-muted)}
.transport-row .price{font-weight:700;color:var(--green);font-size:15px;white-space:nowrap;flex-shrink:0}
.transport-row.recommended{background:var(--orange-pale);border-color:var(--orange-soft)}
.transport-row.recommended .name{color:var(--orange-dark)}
.transport-row.recommended .price{color:var(--orange)}
.more-link{display:block;margin-top:12px;text-align:center;color:var(--green);font-size:13px;font-weight:600;text-decoration:none;transition:color .2s}
.more-link:hover{color:var(--orange)}

@media(max-width:900px){
  .arrive-grid{grid-template-columns:1fr}
  .map-frame iframe{height:220px}
}

/* Booking section */
.booking-section{padding:100px 24px;background:var(--surface)}
.booking-container{max-width:640px;margin:0 auto}
.booking-header{text-align:center;margin-bottom:24px}
.booking-sub{font-size:16px;color:var(--text-muted);max-width:440px;margin:12px auto 0;line-height:1.6}
/* Booking card summary (compact inside card) */
.booking-summary{padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--green-soft)}
.summary-price{display:flex;align-items:baseline;gap:8px;line-height:1;margin-bottom:4px}
.summary-price .price-tag{font-size:38px;font-weight:800;color:var(--green);font-family:'Inter',sans-serif;letter-spacing:-.02em}
.summary-price .unit{font-size:14px;color:var(--text-muted);font-weight:500;font-family:'Inter',sans-serif}
.summary-sub{font-size:12px;color:var(--text-muted);margin-bottom:10px}
.summary-trust{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--text-muted);margin-bottom:10px}
.summary-trust svg{flex-shrink:0}
.summary-activity{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted);margin-top:8px}
.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--green);position:relative;flex-shrink:0}
.activity-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;background:var(--green);opacity:.35;animation:pulseDot 2.2s ease-out infinite}
@keyframes pulseDot{0%{transform:scale(.7);opacity:.4}100%{transform:scale(2.2);opacity:0}}
/* Mini FAQ (compact inside card) */
.mini-faq{margin-bottom:20px;display:flex;flex-direction:column;gap:8px}
.mini-faq-item{background:var(--bg-warm);border:1px solid var(--green-soft);border-radius:var(--radius-xs);overflow:hidden}
.mini-faq-q{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:13px;color:var(--text);gap:10px;transition:background .2s}
.mini-faq-q:hover{background:var(--surface)}
.mini-faq-icon{width:20px;height:20px;border-radius:50%;background:var(--orange-pale);color:var(--orange);display:grid;place-items:center;transition:transform .25s;flex-shrink:0}
.mini-faq-icon svg{width:12px;height:12px}
.mini-faq-item.open .mini-faq-icon{transform:rotate(180deg);background:var(--orange);color:#fff}
.mini-faq-a{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1),padding .35s;padding:0 14px;font-size:12px;color:var(--text-muted);line-height:1.65}
.mini-faq-item.open .mini-faq-a{max-height:260px;padding:0 14px 10px}

/* Booking card */
.booking-card{background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.b-field{margin-bottom:20px}
.b-label{display:block;font-size:13px;font-weight:700;color:var(--green);margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em}
.b-input{width:100%;background:var(--bg-warm);border:2px solid var(--green-soft);border-radius:var(--radius-sm);padding:14px 16px;font-size:15px;color:var(--text);font-family:inherit;outline:none;transition:border-color .2s}
.b-input:focus{border-color:var(--green)}
.b-input.field-error{border-color:var(--orange);animation:fieldShake .4s ease}
#groupQty.field-error{border:2px solid var(--orange);animation:fieldShake .4s ease}
.field-error-msg{color:var(--orange);font-size:13px;margin-top:6px;display:none}
.field-error-msg.visible{display:block}
@keyframes fieldShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
.b-date-wrap{position:relative;display:flex;align-items:center;background:var(--bg-warm);border:2px solid var(--green-soft);border-radius:var(--radius-sm);transition:border-color .2s}
.b-date-wrap:focus-within{border-color:var(--green)}
.b-date-input{flex:1;border:none;background:transparent;padding:14px 16px;font-size:15px;color:var(--text);font-family:inherit;outline:none;-webkit-appearance:none;appearance:none}
.b-date-input::-webkit-calendar-picker-indicator{position:absolute;right:0;top:0;width:100%;height:100%;margin:0;padding:0;opacity:0;cursor:pointer}
.b-date-icon{position:absolute;right:14px;pointer-events:none;opacity:.65}
.b-calendar{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:10;background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:16px;display:none;max-width:320px}
.b-calendar.open{display:block}
.b-cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-title{font-size:15px;font-weight:700;color:var(--text)}
.cal-nav{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-warm);color:var(--text);cursor:pointer;display:grid;place-items:center;transition:var(--transition)}
.cal-nav:hover{background:var(--green-pale);color:var(--green)}
.b-cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.b-cal-weekdays span{text-align:center;font-size:11px;font-weight:600;color:var(--text-light);text-transform:uppercase}
.b-cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.b-cal-days button{width:100%;aspect-ratio:1;border:none;border-radius:50%;background:transparent;color:var(--text);font-size:13px;cursor:pointer;transition:var(--transition);display:grid;place-items:center;font-family:inherit}
.b-cal-days button:hover:not(:disabled){background:var(--green-pale)}
.b-cal-days button.today{color:var(--green);font-weight:700}
.b-cal-days button.selected{background:var(--orange);color:#fff;font-weight:700}
.b-cal-days button:disabled{color:var(--text-light);cursor:default;opacity:.5}
.b-cal-days button:disabled:hover{background:transparent}
.b-hint{font-size:12px;color:var(--text-light);margin-top:6px}
.promo-banner{display:flex;align-items:center;gap:10px;margin-top:10px;padding:10px 14px;background:var(--green-pale);border:1px solid var(--green-soft);border-radius:var(--radius-sm);font-size:13px;color:var(--green-dark);line-height:1.4}
.promo-banner svg{flex-shrink:0;color:var(--green)}
.promo-banner strong{color:var(--green);font-weight:800}
.promo-active{background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;margin-left:auto;white-space:nowrap;animation:pulse .6s ease}

/* People stepper */
.people-stepper{display:inline-flex;align-items:center;gap:6px;background:var(--bg-warm);border:2px solid var(--green-soft);border-radius:12px;padding:4px}
.people-stepper .step-btn{width:40px;height:40px;border-radius:8px;border:none;background:var(--surface);color:var(--text);cursor:pointer;display:grid;place-items:center;transition:var(--transition);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.people-stepper .step-btn:hover{background:var(--green-pale);color:var(--green)}
.people-stepper .step-btn:active{transform:scale(.95)}
.people-stepper .step-value{min-width:28px;text-align:center;font-weight:800;font-size:18px;color:var(--text)}
.people-stepper .step-label{font-size:14px;color:var(--text-muted);padding-right:10px}

/* Kids toggle */
.kids-toggle{display:flex;align-items:center;gap:10px;margin-top:12px;cursor:pointer}
.kids-toggle input{width:18px;height:18px;accent-color:var(--green);cursor:pointer}
.kids-toggle span{font-size:14px;color:var(--text-muted)}
.kids-stepper{display:none;align-items:center;gap:6px;margin-top:10px;padding:8px 12px;background:var(--green-pale);border:2px solid var(--green-soft);border-radius:12px}
.kids-stepper.show{display:inline-flex}
.kids-stepper .step-btn{width:32px;height:32px;border-radius:8px;border:none;background:var(--surface);color:var(--text);cursor:pointer;display:grid;place-items:center;transition:var(--transition);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.kids-stepper .step-btn:hover{background:var(--green-pale);color:var(--green)}
.kids-stepper .step-btn:active{transform:scale(.95)}
.kids-stepper .step-value{min-width:24px;text-align:center;font-weight:800;font-size:16px;color:var(--text)}
.kids-stepper .step-label{font-size:13px;color:var(--text-muted);padding-right:8px}

/* Addon toggle */
.addon-toggle{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-sm);border:2px solid var(--green-soft);cursor:pointer;transition:var(--transition);background:var(--bg-warm);margin-bottom:10px}
.addon-toggle:last-child{margin-bottom:0}
.addon-toggle:hover{border-color:var(--green-light);background:var(--green-pale)}
.addon-toggle.selected{border-color:var(--orange);background:var(--orange-pale)}
.addon-info{flex:1;min-width:0}
.addon-name{font-size:14px;font-weight:700;color:var(--text);line-height:1.3;display:flex;align-items:center;gap:10px}
.addon-icon{flex-shrink:0}
.addon-detail{font-size:12px;color:var(--text-muted);margin-top:2px}
.addon-price{font-size:14px;font-weight:700;color:var(--orange);white-space:nowrap;flex-shrink:0}
.addon-check{width:22px;height:22px;border:2px solid var(--green-soft);border-radius:50%;display:grid;place-items:center;transition:var(--transition);flex-shrink:0}
.addon-toggle.selected .addon-check{background:var(--orange);border-color:var(--orange)}
.addon-toggle.selected .addon-check::after{content:'';width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-2px}
.addon-stepper{cursor:default}
.addon-stepper:hover{border-color:var(--green-soft);background:var(--bg-warm)}
.addon-stepper.selected{border-color:var(--orange);background:var(--orange-pale)}
.addon-qty-stepper{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--green-soft);border-radius:8px;padding:3px;margin-right:8px}
.addon-q-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text);cursor:pointer;display:grid;place-items:center;transition:var(--transition)}
.addon-q-btn:hover{background:var(--green-pale);color:var(--green)}
.addon-q-btn:active{transform:scale(.95)}
.addon-qty-stepper span{min-width:20px;text-align:center;font-weight:700;font-size:14px;color:var(--text)}

/* Payment methods */
.payment-grid{display:flex;flex-direction:column;gap:10px}
.pay-method{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:var(--radius-sm);border:2px solid var(--green-soft);cursor:pointer;transition:var(--transition);background:var(--bg-warm);position:relative}
.pay-method:hover{border-color:var(--green-light);background:var(--green-pale)}
.pay-method.selected{border-color:var(--orange);background:var(--orange-pale)}
.pay-method-icon{width:44px;height:44px;border-radius:10px;display:grid;place-items:center;color:#fff;font-size:15px;font-weight:800;flex-shrink:0;overflow:hidden}
.pay-method-text{flex:1;min-width:0}
.pay-method-name{font-size:14px;font-weight:700;color:var(--text)}
.pay-method-desc{font-size:12px;color:var(--text-muted);margin-top:1px}
.pay-method-badge{position:absolute;top:8px;right:8px;background:var(--orange);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px}

/* Total */
.b-total{background:var(--bg-warm);border-radius:var(--radius);padding:20px;margin:4px 0 20px;border:1px solid var(--green-soft)}
.b-total-title{font-size:12px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.b-total-lines{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.t-line{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;color:var(--text-muted)}
.t-line span:first-child{flex:1;min-width:0;padding-right:16px}
.t-line span:last-child{font-weight:600;color:var(--text);white-space:nowrap;font-variant-numeric:tabular-nums}
.t-divider{height:1px;background:var(--green-soft);margin:0}
.t-line.t-bold{padding:14px 0 4px;font-size:15px;color:var(--text);font-weight:700;border-top:1px solid var(--green-soft)}
.t-line.t-bold span:last-child{font-size:22px;color:var(--green);font-weight:800}
.t-pay-now{background:#fff;border:2px solid var(--orange);border-radius:var(--radius-sm);padding:18px 20px;margin-top:16px;display:flex;flex-direction:column;gap:10px;box-shadow:0 2px 8px rgba(239,124,0,.08)}
.t-line.t-now{font-size:15px;color:var(--text);font-weight:700}
.t-line.t-now span:last-child{font-size:24px;color:var(--orange);font-weight:800;font-variant-numeric:tabular-nums}
.t-line.t-later{font-size:14px;color:var(--text-muted);border-top:1px dashed var(--orange-soft);padding-top:10px;margin-top:2px}
.t-line.t-later span:last-child{font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}
.b-total-hint{font-size:12px;color:var(--text-light);margin-top:12px;text-align:center}
.t-discount{color:var(--orange);font-weight:700}
.t-discount span:last-child{color:var(--orange);font-weight:800;font-size:15px}

/* CTA */
.btn-book{width:100%;background:var(--orange);color:#fff;border:none;border-radius:var(--radius-sm);padding:18px 24px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:var(--transition);font-family:inherit;box-shadow:0 4px 16px rgba(239,124,0,.35)}
.btn-book:hover{background:var(--orange-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(239,124,0,.4)}
.btn-book:active{transform:translateY(0)}
.btn-book .btn-arrow{transition:transform .2s}
.btn-book:hover .btn-arrow{transform:translateX(4px)}

/* Trust bar */
.booking-trust{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:16px;font-size:12px;color:var(--text-light)}
.booking-trust span{display:flex;align-items:center;gap:5px}
.booking-trust svg{vertical-align:middle}

/* Direct WA */
.booking-wa-direct{text-align:center;margin-top:18px;font-size:13px;color:var(--text-muted)}
.booking-wa-direct a{color:var(--orange);font-weight:700;text-decoration:none;margin-left:6px}
.booking-wa-direct a:hover{text-decoration:underline}

/* Reviews carousel */
.reviews-section{background:var(--bg);padding:80px 24px;border-top:1px solid var(--green-soft)}
.reviews-header{max-width:1100px;margin:0 auto 48px;text-align:center}
.reviews-rating{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}
.rating-num{font-size:64px;font-weight:800;color:var(--green);font-family:'Playfair Display',serif;line-height:1}
.rating-meta{display:flex;flex-direction:column;gap:4px;text-align:left}
.rating-stars{display:flex;gap:3px}
.rating-count{font-size:13px;color:var(--text-muted);font-weight:500}
.reviews-title-block .section-badge{display:inline-flex;align-items:center;gap:6px;margin-bottom:10px}
.reviews-title-block .section-title{text-align:center;margin:0 auto;max-width:600px}
.reviews-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:768px){.reviews-grid{grid-template-columns:1fr}}
.review{background:var(--bg-warm);border:1px solid var(--green-soft);border-radius:var(--radius);padding:28px;transition:var(--transition);position:relative;display:flex;flex-direction:column}
.review:hover{border-color:var(--green-light);box-shadow:var(--shadow-lg)}
.review-stars{display:flex;gap:3px;margin-bottom:14px}
.review p{font-size:15px;color:var(--text);margin-bottom:20px;line-height:1.65;flex:1}
.review p::before{content:'"';color:var(--orange);font-size:20px;font-family:'Playfair Display',serif;line-height:0;vertical-align:-4px;margin-right:2px;font-weight:700}
.review-author{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:16px;border-top:1px solid var(--green-soft)}
.review-author .ava{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0}
.review-author .name{font-size:14px;font-weight:700;color:var(--text)}
.review-author .from{font-size:12px;color:var(--text-muted)}
.reviews-cta{max-width:1100px;margin:40px auto 0;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.review-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:100px;font-size:14px;font-weight:600;text-decoration:none;transition:var(--transition)}
.review-btn.outline{border:1px solid var(--green-soft);color:var(--text);background:var(--bg-warm)}
.review-btn.outline:hover{border-color:var(--green);background:var(--green-pale)}
.review-btn.solid{background:#1a5c3a;color:#fff}
.review-btn.solid:hover{background:#144d30;transform:translateY(-1px)}
.review-btn.yellow{background:#f8e4c8;color:#1a1a1a}
.review-btn.yellow:hover{background:#f3d6b0;transform:translateY(-1px)}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto}
.faq-col .faq-list{max-width:none}
.faq-section{padding:60px 20px;background:var(--surface)}
.faq-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
@media(max-width:980px){.faq-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:768px){.faq-grid{grid-template-columns:1fr;gap:24px}}
.faq-col{background:var(--bg-warm);border-radius:var(--radius);padding:28px;border:1px solid var(--sand)}
.faq-col-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;font-weight:700;font-size:14px;color:var(--green);text-transform:uppercase;letter-spacing:.5px}
.faq-col-header svg{width:20px;height:20px;stroke:var(--green);stroke-width:2;fill:none;flex-shrink:0}
.faq-cta{max-width:600px;margin:56px auto 0;text-align:center;padding:28px;background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius-sm)}
.faq-cta p{font-size:15px;color:var(--text-muted);margin-bottom:16px;line-height:1.6}
.faq-item{background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius-sm);margin-bottom:14px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04);transition:var(--transition)}
.faq-item:hover{border-color:var(--green-light)}
.faq-item.open{border-color:var(--orange);box-shadow:0 4px 16px rgba(239,124,0,.1)}
.faq-q{padding:18px 20px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:15px;color:var(--text);gap:12px;transition:background .2s;min-height:78px}
.faq-q:hover{background:var(--bg-warm)}
.faq-icon{transition:var(--transition);color:var(--orange);width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:var(--orange-pale);flex-shrink:0}
.faq-icon svg{width:16px;height:16px}
.faq-item.open .faq-icon{transform:rotate(180deg);background:var(--orange);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .4s;padding:0 20px;font-size:15px;color:var(--text-muted);line-height:1.7}
.faq-item.open .faq-a{max-height:400px;padding:0 20px 20px}

/* Newsletter */
.newsletter-section{padding-top:40px}
.newsletter{background:linear-gradient(135deg,var(--green),var(--green-dark));border-radius:var(--radius);padding:36px 32px;text-align:center;color:#fff;position:relative;overflow:hidden;margin:0 auto 80px;max-width:900px}
.newsletter::before{content:'';position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:rgba(255,255,255,.05);border-radius:50%}
.news-icon{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;margin:0 auto 16px;position:relative}
.news-icon svg{width:22px;height:22px;stroke:#fff}
.newsletter h3{font-size:24px;margin-bottom:8px;position:relative}
.newsletter p{font-size:14px;opacity:.85;margin-bottom:24px;max-width:480px;margin-left:auto;margin-right:auto;position:relative;line-height:1.6}
.group-inline{font-size:18px;font-weight:500;color:#fff;display:flex;align-items:center;gap:6px;margin-bottom:12px;position:relative;justify-content:center;line-height:1.4}
.group-inline input{width:50px;padding:6px 2px;background:rgba(255,255,255,.15);border:none;border-radius:6px;color:#fff;font-size:18px;font-weight:700;text-align:center;font-family:inherit;outline:none;transition:background .2s;-moz-appearance:textfield}
.group-inline input:focus{background:rgba(255,255,255,.25)}
.group-inline input::placeholder{color:rgba(255,255,255,.4);font-weight:400}
.group-inline input::-webkit-inner-spin-button,.group-inline input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.group-cta{background:var(--orange);color:#fff;padding:13px 32px;border-radius:30px;font-weight:700;font-size:14px;border:none;cursor:pointer;position:relative;transition:background .2s;margin-bottom:12px}
.group-cta:hover{background:var(--orange-dark)}
.news-trust{font-size:12px;opacity:.7;display:flex;align-items:center;gap:6px;position:relative;justify-content:center}

/* Footer */
footer{background:var(--bg-warm);border-top:1px solid var(--green-soft);padding:40px 24px 24px}
.foot-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:32px}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot-brand .logo{margin-bottom:10px}
.foot-brand .logo img{height:52px}
.foot-brand p{font-size:13px;color:var(--text-muted);max-width:260px;line-height:1.6;margin-bottom:14px}
.foot-legal{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.foot-legal span{font-size:11px;color:var(--text-muted);display:inline-flex;align-items:center;gap:5px}
.foot-legal span svg{flex-shrink:0}
.foot-social{display:flex;gap:8px}
.foot-social a{width:36px;height:36px;border-radius:50%;background:var(--surface);border:1px solid var(--green-soft);display:grid;place-items:center;transition:var(--transition);color:var(--green)}
.foot-social a:hover{background:var(--green);color:#fff;border-color:var(--green)}
.foot-social a svg{width:16px;height:16px}
.foot-col h5{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--green);margin-bottom:14px;font-weight:700}
.foot-col a{display:block;font-size:13px;color:var(--text-muted);margin-bottom:8px;transition:color .2s}
.foot-col a:hover{color:var(--orange)}
.foot-contact-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px;font-size:13px;color:var(--text-muted)}
.foot-contact-row svg{width:14px;height:14px;stroke:var(--green);stroke-width:2;fill:none;flex-shrink:0;margin-top:2px}
.foot-contact-row a{color:var(--text-muted);transition:color .2s}
.foot-contact-row a:hover{color:var(--orange)}
.foot-rating{margin-top:14px;padding-top:12px;border-top:1px solid var(--green-soft)}
.foot-rating{display:flex;align-items:center;gap:8px}
.foot-rating svg{width:18px;height:18px;fill:#ef7c00;stroke:none;flex-shrink:0}
.foot-rating span{font-size:13px;color:var(--text)}
.foot-rating .sub{font-size:11px;color:var(--text-muted)}
.foot-bottom{max-width:1100px;margin:28px auto 0;padding-top:20px;border-top:1px solid var(--green-soft);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-light)}
.foot-bottom a{color:var(--text-muted);transition:color .2s}
.foot-bottom a:hover{color:var(--orange)}

/* Floating WhatsApp */
.fab-wa-wrap{position:fixed;bottom:28px;right:28px;z-index:998;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.fab-menu{position:absolute;bottom:72px;right:0;background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:16px;min-width:260px;opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity .25s ease,transform .25s ease}
.fab-menu.show{opacity:1;transform:translateY(0);pointer-events:auto}
.fab-menu-title{font-size:13px;font-weight:700;color:var(--green);margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
.fab-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;transition:var(--transition);text-align:left;color:var(--text)}
.fab-menu-item:hover{background:var(--green-pale)}
.fab-menu-item svg{flex-shrink:0;color:var(--green);stroke-width:2}
.fab-menu-text{flex:1;min-width:0}
.fab-menu-label{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}
.fab-menu-desc{font-size:12px;color:var(--text-muted);line-height:1.4;margin-top:2px}
.fab-menu-hint{display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:12px;padding:10px 12px;background:var(--green-pale);border-radius:var(--radius-sm);font-size:11px;color:var(--green-dark);line-height:1.4;text-align:center}
.fab-menu-hint svg{flex-shrink:0;color:var(--green);stroke-width:2}
.fab-wa{width:60px;height:60px;background:#25D366;border-radius:50%;display:grid;place-items:center;box-shadow:0 8px 24px rgba(37,211,102,.4);transition:var(--transition);border:none;animation:bounceIn .6s 1s both;position:relative}
.fab-wa:hover{transform:scale(1.1) rotate(-5deg);box-shadow:0 12px 32px rgba(37,211,102,.5)}
.fab-wa svg{width:30px;height:30px;fill:#fff}
.fab-label{position:absolute;right:72px;top:50%;transform:translateY(-50%);background:var(--text);color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;white-space:nowrap;opacity:0;transition:opacity .3s;pointer-events:none}
.fab-wa:hover .fab-label{opacity:1}
@keyframes bounceIn{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}

/* Sticky mobile bar */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:997;background:#fff;border-top:1px solid var(--green-soft);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 -4px 20px rgba(0,0,0,.06);transform:translateY(100%);opacity:0;visibility:hidden;transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .3s ease,visibility .3s ease}
.sticky-bar.visible{transform:translateY(0);opacity:1;visibility:visible}
.sticky-dismiss{width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--text-light);display:grid;place-items:center;cursor:pointer;transition:background .2s;flex-shrink:0;margin-left:-4px}
.sticky-dismiss:hover{background:var(--green-pale);color:var(--green)}
.sticky-info{flex:1;min-width:0}
.sticky-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.sticky-price{font-size:20px;font-weight:800;color:var(--green);font-family:'Playfair Display',serif;line-height:1}
.sticky-unit{font-size:12px;color:var(--text-muted);font-weight:500}
.sticky-badge{display:inline-flex;align-items:center;background:var(--orange-pale);color:var(--orange-dark);font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;border:1px solid var(--orange-soft)}
.sticky-hint{font-size:11px;color:var(--text-light);margin-top:2px}
.sticky-cta{padding:10px 20px;font-size:13px;border-radius:30px;flex-shrink:0;box-shadow:0 4px 12px rgba(239,124,0,.2) !important}

/* Back to top */
.back-top{position:fixed;bottom:28px;left:28px;z-index:996;width:48px;height:48px;background:var(--surface);border:1px solid var(--green-soft);border-radius:50%;display:none;place-items:center;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow);color:var(--green);font-size:20px}
.back-top:hover{background:var(--green);color:#fff;border-color:var(--green)}
.back-top.show{display:grid}
@media(max-width:640px){.back-top,.back-top.show{display:none!important}}

/* Exit modal */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(44,24,16,.55);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease,visibility .25s}
.modal-overlay.show{opacity:1;visibility:visible;pointer-events:auto}
.modal-box{background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius);max-width:460px;width:100%;padding:40px;text-align:center;position:relative;box-shadow:var(--shadow-lg);transform:scale(.95);transition:transform .3s}
.modal-overlay.show .modal-box{transform:scale(1)}
.modal-box .gift-icon{width:64px;height:64px;background:var(--orange-pale);border-radius:50%;display:grid;place-items:center;margin:0 auto 20px}
.modal-box h3{font-size:24px;color:var(--text);margin-bottom:10px}
.modal-box p{font-size:15px;color:var(--text-muted);margin-bottom:24px;line-height:1.6}
.modal-box input{width:100%;background:var(--bg-warm);border:2px solid var(--green-soft);border-radius:var(--radius-sm);padding:14px 16px;color:var(--text);font-size:15px;outline:none;margin-bottom:14px;transition:border-color .2s;font-family:inherit}
.modal-box input:focus{border-color:var(--green)}
.modal-box .close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-light);font-size:24px;cursor:pointer;width:40px;height:40px;display:grid;place-items:center;border-radius:50%;transition:background .2s}
.modal-box .close:hover{background:var(--bg-warm)}
.modal-box .timer{font-size:13px;color:var(--red);font-weight:600;margin-top:12px}

/* Hero location badge */
.hero-location{display:inline-flex;align-items:center;gap:6px;background:var(--green-pale);border:1px solid var(--green-soft);padding:6px 14px;border-radius:30px;font-size:12px;font-weight:600;color:var(--green-dark)}

/* Mishki Chuchu product section */
.mishki-section{padding:80px 24px;background:var(--surface);border-top:1px solid var(--sand);border-bottom:1px solid var(--sand)}
.mishki-container{max-width:900px;margin:0 auto;text-align:center}
.mishki-badge{display:inline-flex;align-items:center;gap:6px;background:#FFF0D6;color:var(--orange);font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--orange-soft)}
.mishki-hero{max-width:560px;margin:0 auto 28px;border-radius:var(--radius);overflow:hidden;background:var(--bg-warm);border:1px solid var(--sand);box-shadow:0 4px 20px rgba(0,0,0,.06)}
.mishki-hero img{width:100%;height:auto;display:block}
.mishki-caption{padding:16px;display:flex;flex-direction:column;gap:4px;background:var(--bg-warm)}
.mishki-caption-tag{font-size:14px;font-weight:700;color:var(--orange)}
.mishki-caption-sub{font-size:13px;color:var(--text-muted)}
.mishki-digemid{display:inline-flex;align-items:center;gap:6px;background:var(--green-pale);border:1px solid var(--green-soft);border-radius:20px;padding:6px 14px;font-size:12px;color:var(--green-dark);font-weight:600;margin-bottom:28px}
.mishki-digemid svg{flex-shrink:0;color:var(--green)}
.mishki-digemid-dash{display:inline}
.mishki-digemid-line{display:inline}
.mishki-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:720px;margin-left:auto;margin-right:auto}
.mishki-card{background:var(--surface);border:1px solid var(--sand);border-radius:var(--radius);padding:32px;text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.08);display:flex;flex-direction:column;align-items:center}
.mishki-card-pop{box-shadow:0 6px 24px rgba(239,124,0,.15);position:relative}
.mishki-pop-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:5px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em;box-shadow:0 2px 8px rgba(227,0,15,.30);white-space:nowrap;z-index:2}
.mishki-label{font-size:13px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.08em}
.mishki-price{font-size:36px;font-weight:700;color:var(--green);font-family:'Playfair Display',serif;margin:8px 0;line-height:1}
.mishki-desc{font-size:14px;color:var(--text-muted);line-height:1.6;flex:1}
.mishki-footer{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:28px;font-size:13px;color:var(--text-light)}
.mishki-footer svg{flex-shrink:0;color:var(--green)}

.video-wrap{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-lg);aspect-ratio:16/9;max-width:960px;margin:0 auto;border:1px solid var(--green-soft);user-select:none;-webkit-user-select:none}
.exp-video{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.video-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .35s ease,visibility .35s ease}
.video-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.video-play-btn{position:relative;display:grid;place-items:center;background:rgba(239,124,0,.9);border:none;border-radius:50%;width:160px;height:160px;cursor:pointer;transition:opacity .3s,transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px rgba(239,124,0,.35),0 0 0 4px rgba(255,255,255,.2)}
.video-play-btn:hover{transform:scale(1.08);background:var(--orange);box-shadow:0 12px 40px rgba(239,124,0,.5),0 0 0 6px rgba(255,255,255,.35)}
.video-play-btn:active{transform:scale(.96)}
.video-play-btn svg{width:52px;height:52px;margin-left:6px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.25))}
.video-play-label{margin-top:18px;color:#fff;font-size:14px;font-weight:700;letter-spacing:.02em;pointer-events:none;background:rgba(0,0,0,.55);padding:8px 18px;border-radius:30px;backdrop-filter:blur(4px)}
.video-play-btn::before{content:'';position:absolute;inset:-12px;border-radius:50%;border:2px solid rgba(255,255,255,.6);opacity:0;animation:playPulse 2.2s ease-out infinite}
@keyframes playPulse{0%{transform:scale(.9);opacity:.6}60%{opacity:0}100%{transform:scale(1.4);opacity:0}}
.video-controls{position:absolute;bottom:0;left:0;right:0;z-index:3;padding:12px 14px 14px;background:linear-gradient(to top,rgba(0,0,0,.65),rgba(0,0,0,0));opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}
.video-wrap.playing .video-controls,.video-wrap:hover .video-controls,.video-wrap.seeking .video-controls{opacity:1;visibility:visible}
.video-progress-wrap{position:relative;height:16px;margin-bottom:6px;display:flex;align-items:center;cursor:pointer}
.video-progress-bg{position:absolute;left:0;right:0;height:4px;background:rgba(255,255,255,.25);border-radius:2px;overflow:hidden}
.video-buffer-bar{position:absolute;left:0;height:100%;background:rgba(255,255,255,.25);width:0;transition:width .15s linear}
.video-progress-bar{position:absolute;left:0;height:100%;background:#fff;width:0;transition:width .05s linear}
.video-progress-thumb{position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.35);transform:translate(-50%,-50%) scale(0);top:50%;transition:transform .15s ease;pointer-events:none;margin-top:1px}
.video-progress-wrap:hover .video-progress-thumb,.video-wrap.seeking .video-progress-thumb{transform:translate(-50%,-50%) scale(1)}
.video-controls-row{display:flex;align-items:center;gap:10px}
.video-pp-btn{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);border:none;display:grid;place-items:center;cursor:pointer;transition:background .2s}
.video-pp-btn:hover{background:rgba(255,255,255,.35)}
.video-pp-btn svg{vertical-align:middle}
.video-time{color:rgba(255,255,255,.9);font-size:12px;font-weight:500;font-variant-numeric:tabular-nums;flex:1}
.video-mute-btn{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);border:none;display:grid;place-items:center;cursor:pointer;transition:background .2s}
.video-mute-btn:hover{background:rgba(255,255,255,.35)}
.video-mute-btn svg{vertical-align:middle}
@media(max-width:640px){.video-wrap{aspect-ratio:9/16}.video-play-btn{width:130px;height:130px;gap:6px;transform:none!important;background:rgba(239,124,0,.9)!important;box-shadow:0 8px 32px rgba(239,124,0,.35),0 0 0 4px rgba(255,255,255,.2)!important}.video-play-btn svg{width:42px;height:42px;margin-left:4px}.video-play-label{font-size:12px;margin-top:14px}.video-play-btn::before{inset:-8px}.video-controls{padding:10px 12px 12px}.video-progress-wrap{height:20px;margin-bottom:4px}.video-progress-bg{height:3px}.video-progress-thumb{width:12px;height:12px}.video-pp-btn{width:36px;height:36px}.video-mute-btn{width:36px;height:36px}}
/* Before / After */
.before-after{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;max-width:960px;margin:0 auto;align-items:center}
@media(max-width:768px){.before-after{grid-template-columns:1fr;gap:24px}}
.ba-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);text-align:center;transition:var(--transition);border:1px solid var(--border)}
.ba-before{border-top:4px solid var(--sand)}
.ba-after{border-top:4px solid var(--green)}
.ba-header{padding:36px 24px 24px;display:flex;flex-direction:column;align-items:center;gap:16px}
.ba-icon{display:grid;place-items:center;width:72px;height:72px;border-radius:50%;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.ba-before .ba-icon{color:var(--orange);background:var(--bg-warm)}
.ba-after .ba-icon{color:var(--green);background:var(--green-pale)}
.ba-card .ba-label{display:inline-block;padding:6px 18px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.ba-before .ba-label{background:var(--sand);color:#5c4f42}
.ba-after .ba-label{background:var(--green);color:#fff}
.ba-card .ba-body{padding:0 32px 36px}
.ba-card .ba-body h4{font-size:18px;color:var(--text);margin-bottom:14px;font-family:'Playfair Display',serif}
.ba-list{list-style:none;display:flex;flex-direction:column;gap:12px;text-align:left;padding:0}
.ba-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--text-muted);line-height:1.6}
.ba-list li::before{content:'';width:18px;height:18px;display:block;background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0;margin-top:1px}
.ba-before .ba-list li::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A89B8F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='15' y1='9' x2='9' y2='15'/%3E%3Cline x1='9' y1='9' x2='15' y2='15'/%3E%3C/svg%3E")}
.ba-after .ba-list li::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23057429' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E")}
.ba-connector{display:flex;flex-direction:column;align-items:center;gap:8px}
@media(max-width:768px){.ba-connector{display:none}}
.ba-arrow{width:0;height:0;border-top:10px solid transparent;border-bottom:10px solid transparent;border-left:14px solid var(--orange);filter:drop-shadow(0 2px 4px rgba(239,124,0,.3))}
.ba-time{background:var(--orange);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap;box-shadow:0 2px 8px rgba(239,124,0,.3)}

/* Confirm modal */
body.modal-active{overflow:hidden;position:fixed;width:100%;touch-action:none}
.confirm-box{opacity:0;transform:scale(.92) translateY(12px);transition:opacity .3s ease,transform .3s cubic-bezier(.34,1.56,.64,1)}
.modal-overlay.show .confirm-box{opacity:1;transform:scale(1) translateY(0)}
.modal-box .wa-input{width:100%;background:var(--bg-warm);border:2px solid var(--green-soft);border-radius:var(--radius-sm);padding:14px 16px;color:var(--text);font-size:15px;outline:none;margin-bottom:14px;transition:border-color .2s;font-family:inherit;text-align:center}
.modal-box .wa-input:focus{border-color:var(--green)}
.confirm-box{background:var(--surface);border:1px solid var(--green-soft);border-radius:var(--radius);max-width:420px;width:100%;max-height:90vh;display:flex;flex-direction:column;padding:24px;text-align:center;position:relative;box-shadow:var(--shadow-lg)}
.confirm-box .close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-light);cursor:pointer;width:36px;height:36px;display:grid;place-items:center;border-radius:50%;transition:background .2s}
.confirm-box .close:hover{background:var(--bg-warm)}
.confirm-icon{width:56px;height:56px;background:var(--green-pale);border-radius:50%;display:grid;place-items:center;margin:0 auto 16px}
.confirm-box h3{font-size:22px;color:var(--text);margin-bottom:6px}
.confirm-sub{font-size:14px;color:var(--text-muted);margin-bottom:20px;line-height:1.5}
.confirm-body{background:var(--bg-warm);border-radius:var(--radius-sm);padding:16px 20px;text-align:left;margin-bottom:20px}
.confirm-row{display:flex;justify-content:space-between;gap:12px;font-size:14px;line-height:1.5;padding:6px 0;border-bottom:1px solid var(--sand)}
.confirm-row:last-child{border-bottom:none}
.confirm-row .c-label{color:var(--text-muted);flex-shrink:0}
.confirm-row .c-val{color:var(--text);font-weight:500;text-align:right}
.confirm-row .c-highlight{color:var(--green);font-weight:600}
.btn-ghost{width:100%;margin-top:10px;padding:12px 20px;border-radius:var(--radius-sm);border:1.5px solid var(--sand);background:transparent;color:var(--text-muted);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-ghost:hover{border-color:var(--green-soft);color:var(--text)}

/* Confirm Modal Redesign */
.confirm-header{flex-shrink:0;margin-bottom:2px;padding-bottom:10px;border-bottom:1px solid var(--sand)}
.confirm-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--green-pale) 0%,#e8f5e9 100%);border-radius:50%;display:grid;place-items:center;margin:0 auto 10px;box-shadow:0 4px 12px rgba(5,116,41,.12)}
.confirm-box h3{font-size:20px;color:var(--text);margin-bottom:4px;font-weight:600}
.confirm-sub{font-size:13px;color:var(--text-muted);margin-bottom:0;line-height:1.5;max-width:340px;margin-left:auto;margin-right:auto}
.confirm-body{flex:1;overflow-y:auto;min-height:0;background:transparent;border-radius:0;padding:0 4px;text-align:left;margin-bottom:8px;margin-top:8px;-webkit-overflow-scrolling:touch}
.confirm-body::-webkit-scrollbar{width:4px}
.confirm-body::-webkit-scrollbar-thumb{background:transparent;border-radius:4px;transition:background .4s ease}
.confirm-body.scrolling::-webkit-scrollbar-thumb{background:var(--sand)}
.confirm-section{margin-bottom:12px}
.confirm-section-title{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-light);font-weight:600;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--sand)}
.confirm-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px;line-height:1.35;border-bottom:1px solid rgba(0,0,0,.04)}
.confirm-item:last-child{border-bottom:none}
.confirm-item-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;display:grid;place-items:center}
.confirm-item-icon svg{width:14px;height:14px}
.confirm-item-text{flex:1;min-width:0;padding-right:12px}
.confirm-item-name{color:var(--text);font-weight:500}
.confirm-item-desc{color:var(--text-light);font-size:11px;margin-top:1px}
.confirm-item-price{font-weight:600;color:var(--text);font-size:13px;white-space:nowrap}
.confirm-item-price.free{color:var(--green);font-weight:600}
.confirm-badge{display:inline-flex;align-items:center;gap:3px;background:var(--green-pale);color:var(--green);font-size:10px;font-weight:600;padding:2px 6px;border-radius:100px;margin-left:5px;vertical-align:middle}
.confirm-badge svg{width:10px;height:10px}
.confirm-total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--green-pale);border-radius:var(--radius-sm);margin-top:2px}
.confirm-total-label{font-size:13px;color:var(--green);font-weight:600}
.confirm-total-val{font-size:16px;color:var(--green);font-weight:700}
.confirm-payment-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;border-bottom:1px solid rgba(0,0,0,.04)}
.confirm-payment-row:last-child{border-bottom:none}
.confirm-payment-row.now .c-val{color:var(--green);font-weight:600}
.confirm-payment-row .c-label{color:var(--text-muted)}
.confirm-payment-row .c-val{font-weight:500;color:var(--text)}
.confirm-trust{flex-shrink:0;display:flex;justify-content:center;gap:12px;margin:8px 0 14px;font-size:11px;color:var(--text-light)}
.confirm-trust span{display:inline-flex;align-items:center;gap:4px}

/* Confirm success screen */
.confirm-success{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;flex:1;min-height:0;overflow-y:auto;padding:20px 8px}
.confirm-success-icon{width:72px;height:72px;background:linear-gradient(135deg,var(--green-pale) 0%,#e8f5e9 100%);border-radius:50%;display:grid;place-items:center;margin-bottom:16px;box-shadow:0 6px 20px rgba(5,116,41,.15);animation:successPop .5s cubic-bezier(.34,1.56,.64,1)}
.confirm-success-icon svg{width:36px;height:36px}
.confirm-success-name{font-size:15px;color:var(--text-light);margin-bottom:2px;font-weight:500}
.confirm-success h3{font-size:22px;color:var(--text);margin-bottom:6px;font-weight:700}
.confirm-success p{font-size:14px;color:var(--text-muted);margin-bottom:8px;line-height:1.5;max-width:280px}
.confirm-code{display:inline-flex;align-items:center;gap:8px;background:var(--bg-warm);border:2px dashed var(--green-soft);border-radius:var(--radius-sm);padding:14px 24px;margin-bottom:20px;font-family:'Inter',monospace;font-size:20px;font-weight:700;color:var(--green);letter-spacing:1px}
.confirm-code-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-light);font-weight:600;margin-bottom:6px}
.btn-close{width:100%;padding:12px 20px;border-radius:var(--radius-sm);border:1.5px solid var(--sand);background:transparent;color:var(--text-muted);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-close:hover{border-color:var(--green-soft);color:var(--text)}
@keyframes successPop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}

/* Responsive additions */
@media(max-width:980px){
  nav.desktop{display:none}.menu-btn{display:block;padding:10px}
  header{padding:0 20px;height:72px}
  header.scrolled{height:64px}
  .logo img{height:48px}
  .float-book{grid-template-columns:1fr;position:relative;bottom:auto;left:auto;transform:none;margin-top:32px;padding:24px}
  .float-book .btn-orange{width:100%;justify-content:center}
  .step-content{grid-template-columns:1fr}
  .booking-card{padding:24px}
  .price-amount{font-size:44px}
  .hero{min-height:auto;padding-top:72px}
  .hero-inner{padding:32px 20px 40px;gap:32px}
  .hero-img-wrap{max-width:320px}
  .spacer{height:60px}
  .newsletter{padding:36px 24px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .share-bar{display:none}
  .reviews-header .left{text-align:center;width:100%}
  .reviews-header .left h2,.reviews-header .left p{text-align:center}
  .reviews-header{flex-direction:column;align-items:center}
}
@media(max-width:768px){
  .hero h1{font-size:32px;line-height:1.1;margin-bottom:20px}
  .hero-sub{font-size:16px;line-height:1.55;margin-bottom:12px;color:var(--text)}
  .hero-price{font-size:17px;color:var(--green)}
  .hero-family{font-size:14px;line-height:1.45;padding:14px;margin-bottom:20px}
  .hero-family svg{width:18px;height:18px}
  .hero-inner{padding:20px 16px 28px;gap:20px}
  .hero-img-wrap{max-width:380px}
  .hero-img-card{aspect-ratio:4/5;max-height:460px}
  .hero-img-wrap::before{top:-18px;right:-18px}
  .hero-actions{flex-direction:column;align-items:center;margin-bottom:12px}
  .hero-actions .btn-orange,.hero-actions .btn-secondary{width:100%;max-width:none;justify-content:center;font-size:16px;padding:16px}
  .hero-link{font-size:14px;margin-bottom:20px;padding-top:10px}
  .trust-hero{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-top:16px;margin-bottom:20px}
  .trust-pill{font-size:13px;padding:8px 14px;background:var(--bg-warm);border:1px solid var(--sand);border-radius:30px;justify-content:center;color:var(--text-muted);font-weight:500}
  .trust-bar{padding:16px}
  .trust-inner{gap:8px;font-size:12px}
  .trust-inner span{background:#d8f0e1;border:1px solid #c0decf;border-radius:20px;padding:8px 14px;color:var(--green-dark);gap:8px}
  .trust-inner span::before{width:18px;height:18px;opacity:1}
  .proof-band{padding:32px 16px 24px}
  .proof-inner{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-width:400px;margin:0 auto}
  .proof-item{background:var(--surface);border:1px solid var(--sand);border-radius:var(--radius-sm);padding:18px 12px;min-width:auto}
  .proof-item h4{font-size:28px}
  .proof-item p{font-size:13px;text-transform:none;letter-spacing:0;color:var(--text);margin-top:8px;font-weight:500}
  .proof-item:last-child{grid-column:1 / -1;background:var(--green-pale);border-color:var(--green-soft)}
  .proof-div{display:none}
  .seen-band{padding:20px 16px}
  .seen-inner{gap:10px}
  .seen-label{font-size:11px;color:var(--text-light);margin-bottom:4px;width:100%;text-align:center}
  .seen-logos{gap:8px}
  .seen-logos a{font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-warm);border:1px solid var(--sand);border-radius:8px;padding:6px 12px;transition:all .2s}
  .seen-logos a:hover{color:var(--green);border-color:var(--green-soft);background:var(--green-pale)}
  .seen-logos a::after{display:none}
  .host-section{padding:48px 16px}
  .host-stats{gap:8px;margin-top:24px}
  .host-stat{flex:1;padding:12px 8px;min-width:auto;background:var(--green-pale);border:1px solid var(--green-soft);border-radius:var(--radius-sm)}
  .host-stat span:first-child{font-size:22px}
  .host-stat span:last-child{font-size:10px;letter-spacing:.06em}
}
@media(max-width:640px){
  body.sticky-active{padding-bottom:72px}
  body.sticky-active .fab-wa-wrap{bottom:82px}
  header{padding:0 16px;height:64px}
  header.scrolled{height:56px}
  .logo img{height:42px}
  .foot-grid{grid-template-columns:1fr;gap:20px;padding:0 16px;text-align:center}
  .foot-brand .logo img{height:44px;margin:0 auto;display:block}
  .foot-brand p{max-width:none;margin-bottom:8px;font-size:12px;color:var(--text-muted)}
  .foot-legal{display:flex;flex-direction:row;justify-content:center;flex-wrap:wrap;gap:6px;margin-bottom:10px}
  .foot-legal span{font-size:10px;gap:4px}
  .foot-social{justify-content:center;gap:12px}
  .foot-social a{width:40px;height:40px}
  .foot-social a svg{width:18px;height:18px}
  .foot-col h5{font-size:11px;margin-bottom:8px;text-align:center}
  .foot-col a{font-size:13px;margin-bottom:6px;text-align:center;display:block}
  .foot-contact-row{font-size:13px;margin-bottom:6px;gap:8px;justify-content:center}
  .foot-rating{justify-content:center;margin-top:10px;padding-top:10px}
  .sticky-bar{display:flex}
  .newsletter{padding:28px 20px;margin-bottom:48px}
  .newsletter h3{font-size:20px}
  .group-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px}
  .group-inline{display:inline-flex;font-size:16px;margin:0}
  .group-inline input{width:44px;font-size:16px}
  .group-cta{display:inline-flex;padding:12px 24px;width:auto;margin:0}
  .news-trust{margin:0;display:inline-flex}
  .ugc-grid{grid-template-columns:repeat(2,1fr)}
  .booking-card{padding:20px}
  .booking-price-bar{padding:20px}
  .price-amount{font-size:40px}
  .booking-trust{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;align-items:start;margin-top:14px}
  .booking-trust span{flex-direction:column;gap:4px;font-size:11px;text-align:center;line-height:1.3;color:var(--text-muted)}
  .booking-trust svg{width:16px;height:16px;color:var(--green)}
  .promo-banner{padding:8px 10px;gap:8px;font-size:12px}
  .promo-banner svg{display:none}
  .promo-active{font-size:10px;padding:2px 8px}
  .transport-row{padding:12px 14px;gap:12px}
  .transport-row .name{font-size:13px}
  .transport-row .detail{font-size:12px;line-height:1.3}
  .transport-row .detail .transport-suffix{display:block;margin-top:1px}
  .transport-row .price{font-size:15px;white-space:nowrap;min-width:60px;text-align:right}
  .addon-toggle{display:grid;grid-template-columns:1fr auto;gap:4px 10px;align-items:center;padding:12px}
  .addon-info{display:contents}
  .addon-name{grid-column:1 / 2;grid-row:1 / 2;font-size:13px;gap:8px;line-height:1.25;align-self:center}
  .addon-name svg{width:20px;height:20px}
  .addon-detail{grid-column:1 / 2;grid-row:2 / 3;font-size:13px;margin-top:0;align-self:start}
  .addon-price{grid-column:2 / 3;grid-row:1 / 2;font-size:13px;text-align:right;align-self:center;margin-left:0;padding-left:0;white-space:nowrap}
  .addon-qty-stepper,.addon-check{grid-column:2 / 3;grid-row:2 / 3;justify-self:end;align-self:start;margin-right:0}
  .addon-q-btn{width:32px;height:32px}

  /* Summary / total mobile polish */
  .b-total{padding:16px}
  .b-total-lines{gap:10px}
  .t-line{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;font-size:13px}
  .t-line span:first-child{padding-right:0;line-height:1.35;min-width:0}
  .t-line span:last-child{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
  .t-line.t-discount{color:var(--orange)}
  .t-line.t-discount span:first-child{font-weight:700}
  /* Total de-emphasized: Peruvians feel sticker-shock on big totals. Deposit is the hero. */
  .t-line.t-bold{padding:12px 0 2px;font-size:13px;font-weight:600;color:var(--text-muted)}
  .t-line.t-bold span:last-child{font-size:15px;color:var(--text);font-weight:700}
  .t-pay-now{padding:10px 12px;gap:8px}
  .t-line.t-now{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;font-size:13px}
  .t-line.t-now span:first-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:0}
  .t-line.t-now span:last-child{font-size:16px;white-space:nowrap}
  .t-line.t-later{padding-top:8px;margin-top:0}
  .b-total-hint{font-size:11px}

  .modal-box{padding:28px 24px}

  /* iOS Safari needs cursor:pointer on non-buttons for :active to fire */
  .addon-toggle,.pay-method,.mini-faq-q,.fab-menu-item{cursor:pointer}

  /* Remove blue tap flash so custom active animations are visible */
  .addon-toggle,.addon-q-btn,.step-btn,.cal-nav,.pay-method,.mini-faq-q,.fab-wa,.menu-btn,.close-menu,.btn-book,.fab-menu-item{-webkit-tap-highlight-color:transparent}

  .fab-wa-wrap{right:16px;bottom:72px}
  .fab-menu{right:0;min-width:240px;padding:12px}
  .fab-menu-label{font-size:13px}
  .fab-wa{width:52px;height:52px}
  .fab-label{display:none}

  /* Tap-optimize: remove sticky hover states on touch */
  .addon-toggle:hover{border-color:var(--green-soft);background:var(--bg-warm)}
  .addon-toggle.selected:hover{border-color:var(--orange);background:var(--orange-pale)}
  .addon-stepper:hover{border-color:var(--green-soft);background:var(--bg-warm)}
  .addon-stepper.selected:hover{border-color:var(--orange);background:var(--orange-pale)}
  .addon-q-btn:hover{background:transparent;color:var(--text)}
  .people-stepper .step-btn:hover{background:var(--surface);color:var(--text)}
  .kids-stepper .step-btn:hover{background:var(--surface);color:var(--text)}
  .pay-method:hover{border-color:var(--green-soft);background:var(--bg-warm)}
  .pay-method.selected:hover{border-color:var(--orange);background:var(--orange-pale)}
  .mini-faq-q,.mini-faq-q:hover,.mini-faq-item.open .mini-faq-q,.mini-faq-item.open .mini-faq-q:hover{background:var(--bg-warm)}
  .faq-q,.faq-q:hover{background:transparent}
  .cal-nav:hover{background:var(--bg-warm);color:var(--text)}
  .b-cal-days button:hover:not(:disabled){background:transparent}
  .btn-book:hover{background:var(--orange);transform:none;box-shadow:0 4px 16px rgba(239,124,0,.35)}
  .btn-book:hover .btn-arrow{transform:none}
  .booking-wa-direct a:hover{text-decoration:none}
  .mobile-nav a:hover{color:var(--green-dark)}
  .close-menu:hover{background:transparent;transform:none}
  .menu-btn:hover{background:transparent}
  .fab-menu-item:hover{background:transparent}
  .fab-wa:hover{transform:none;box-shadow:0 4px 16px rgba(37,211,102,.4)}

  /* Subtle tap feedback */
  .addon-toggle:active{transform:scale(.98);transition:transform .08s ease}
  .addon-q-btn:active{transform:scale(.90);transition:transform .06s ease}
  .people-stepper .step-btn:active{transform:scale(.90);transition:transform .06s ease}
  .kids-stepper .step-btn:active{transform:scale(.90);transition:transform .06s ease}
  .pay-method:active{transform:scale(.98);transition:transform .08s ease}
  .mini-faq-q:active{transform:scale(.98);transition:transform .08s ease}
  .cal-nav:active{transform:scale(.90);transition:transform .06s ease}
  .b-cal-days button:active:not(:disabled){transform:scale(.92);transition:transform .06s ease}
  .btn-book:active{transform:scale(.97);transition:transform .08s ease}
  .fab-menu-item:active{transform:scale(.96);transition:transform .08s ease}
  .fab-wa:active{transform:scale(.92);transition:transform .08s ease}
  .menu-btn:active{transform:scale(.90);transition:transform .06s ease}
  .close-menu:active{transform:scale(.90);transition:transform .06s ease}
  .review:hover{border-color:var(--green-soft);box-shadow:none}

  /* Reviews horizontal carousel */
  .reviews-section{padding:48px 0;border-top:1px solid var(--green-soft)}
  .reviews-header{padding:0 16px;margin-bottom:28px}
  .reviews-rating{gap:10px;margin-bottom:14px}
  .rating-num{font-size:48px}
  .rating-stars svg{width:14px;height:14px}
  .rating-count{font-size:12px}
  .reviews-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:12px;padding:0 16px;scroll-padding-left:16px}
  .reviews-grid::-webkit-scrollbar{display:none}
  .review{flex:0 0 auto;width:85%;min-width:260px;max-width:320px;scroll-snap-align:start;padding:20px;min-height:auto}
  .review p{font-size:14px;margin-bottom:14px}
  .review-author{padding-top:12px}
  .review-author .ava{width:36px;height:36px;font-size:12px}
  .review-author .name{font-size:13px}
  .review-author .from{font-size:11px}
  .reviews-cta{padding:0 16px;margin-top:24px;flex-direction:column;gap:8px}
  .review-btn{width:100%;justify-content:center;padding:12px 20px;font-size:13px}

  /* Mishki mobile */
  .mishki-section{padding:48px 16px}
  .mishki-hero{margin-bottom:20px;border-radius:var(--radius-sm)}
  .mishki-caption{padding:12px}
  .mishki-caption-tag{font-size:13px}
  .mishki-caption-sub{font-size:12px}
  .mishki-digemid{font-size:11px;padding:5px 10px;margin-bottom:20px;flex-direction:column;gap:2px}
  .mishki-digemid-dash{display:none}
  .mishki-digemid-line{display:block}
  .mishki-grid{grid-template-columns:1fr;gap:36px}
  .mishki-card{padding:24px}
  .mishki-card .mishki-desc{margin-bottom:8px}
  .mishki-card .btn-orange{margin-top:0}
  .mishki-price{font-size:32px}
  .mishki-footer{font-size:12px;flex-direction:column;gap:4px;text-align:center;margin-top:24px}

  /* Footer mobile */
  .foot-bottom{padding:0 16px;flex-direction:column;align-items:center;text-align:center;gap:8px;margin-top:24px;padding-top:16px;font-size:11px}
}

.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-book:disabled{opacity:.7;cursor:not-allowed}
