/* Booking Wolf — SEO page styles. Matches the live site: brand purple
   hsl(262 83% 58%), white surfaces, gray borders (hsl 214 32% 91%), shadcn-style
   cards. Pure CSS, zero JS (AI/search bots index server-rendered HTML). */
:root{
  --primary:hsl(262 83% 58%);
  --primary-600:hsl(262 72% 50%);
  --primary-50:hsl(262 83% 97%);
  --fg:hsl(222 47% 11%);
  --muted-fg:hsl(215 16% 47%);
  --border:hsl(214 32% 91%);
  --muted:hsl(210 40% 97%);
  --card:#fff;
  --radius:14px;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 1px 3px rgba(16,24,40,.06);
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--fg);background:var(--muted);line-height:1.55;font-size:16px;}
a{color:var(--primary-600);text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%;display:block;}
h1,h2,h3{line-height:1.25;margin:0;}

/* ---------- Header (white bar, purple accent, gray bottom border) ---------- */
.bw-header{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border);}
.bw-header-inner{max-width:1080px;margin:0 auto;padding:.6rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.bw-header-logo img{height:34px;width:auto;}
.bw-header-nav{display:flex;align-items:center;gap:1.4rem;}
.bw-header-nav a{color:var(--fg);font-weight:500;font-size:.92rem;}
.bw-header-nav a:hover{color:var(--primary-600);text-decoration:none;}
.bw-header-nav .bw-header-cta{background:var(--primary);color:#fff;padding:.5rem 1rem;
  border-radius:9px;font-weight:600;}
.bw-header-nav .bw-header-cta:hover{background:var(--primary-600);color:#fff;}

/* ---------- Main column ---------- */
.bw-main{max-width:1080px;margin:0 auto;padding:1.5rem 1.25rem 3rem;}
.breadcrumb{font-size:.8rem;color:var(--muted-fg);margin:.25rem 0 1rem;}
.breadcrumb a{color:var(--muted-fg);}
.breadcrumb a:hover{color:var(--primary-600);}

/* ---------- Hero ---------- */
.attraction-hero h1{font-size:2rem;letter-spacing:-.02em;margin-bottom:.35rem;}
.attraction-hero .location{color:var(--muted-fg);font-size:1rem;margin-bottom:.5rem;}
.attraction-hero .rating{display:inline-flex;align-items:center;gap:.4rem;
  font-weight:600;color:var(--fg);}
.hero-image{margin:1.1rem 0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);}
.hero-image img{width:100%;height:auto;object-fit:cover;}

/* ---------- Generic card sections ---------- */
.admission-table,.facts,.contact,.faq,.related-tours,.news,.gallery,.video,.related-searches{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.25rem 1.4rem;margin:1.1rem 0;}
h2{font-size:1.15rem;letter-spacing:-.01em;margin-bottom:.9rem;}
.quick-answer{background:var(--primary-50);border:1px solid hsl(262 60% 90%);
  border-radius:var(--radius);padding:1rem 1.25rem;margin:1.1rem 0;font-size:1.02rem;}

/* ---------- Interim commerce CTA (direct-booking slot) ---------- */
.direct-cta{background:linear-gradient(180deg,var(--primary-50),#fff);
  border:1px solid hsl(262 60% 88%);border-radius:var(--radius);
  padding:1.25rem 1.4rem;margin:1.1rem 0;box-shadow:var(--shadow);}
.direct-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap;}
.direct-cta-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;
  font-weight:700;color:var(--primary-600);margin:0 0 .25rem;}
.direct-cta-head{font-size:1.2rem;letter-spacing:-.01em;margin:0 0 .35rem;}
.direct-cta-sub{color:var(--muted-fg);font-size:.95rem;margin:0;max-width:560px;}
.direct-cta-btn{flex:none;background:var(--primary);color:#fff;font-weight:600;
  padding:.7rem 1.3rem;border-radius:10px;white-space:nowrap;}
.direct-cta-btn:hover{background:var(--primary-600);color:#fff;text-decoration:none;}
@media (max-width:600px){.direct-cta-btn{width:100%;text-align:center;}}

/* ---------- Admission comparison table (the hero feature) ---------- */
.admission-table table{width:100%;border-collapse:collapse;font-size:.95rem;}
.admission-table th{text-align:left;font-size:.72rem;text-transform:uppercase;
  letter-spacing:.04em;color:var(--muted-fg);padding:.5rem .6rem;border-bottom:1px solid var(--border);}
.admission-table td{padding:.7rem .6rem;border-bottom:1px solid var(--muted);vertical-align:middle;}
.admission-table tr:last-child td{border-bottom:none;}
.offer-provider{font-weight:600;}
.offer-price{font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums;}
.offer-action a{display:inline-block;border:1px solid var(--primary);color:var(--primary-600);
  padding:.35rem .85rem;border-radius:8px;font-weight:600;font-size:.85rem;}
.offer-action a:hover{background:var(--primary);color:#fff;text-decoration:none;}
.badge{display:inline-block;font-size:.68rem;font-weight:600;padding:.12rem .5rem;
  border-radius:6px;margin-left:.4rem;vertical-align:middle;}
.badge-official{background:hsl(152 60% 95%);color:hsl(152 60% 28%);}
.badge-flex{background:hsl(38 92% 95%);color:hsl(30 80% 35%);}

/* ---------- Facts / contact ---------- */
.facts dl,.contact{font-size:.95rem;}
.facts dt{font-weight:600;color:var(--muted-fg);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;}
.facts dd{margin:0 0 .7rem;}
.contact p{margin:.3rem 0;}

/* ---------- Related tours grid ---------- */
.related-context{color:var(--muted-fg);font-size:.92rem;margin-bottom:1rem;}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.9rem;}
.related-card{display:flex;flex-direction:column;gap:.25rem;border:1px solid var(--border);
  border-radius:11px;padding:.85rem .95rem;background:var(--card);color:var(--fg);transition:border-color .15s;}
.related-card:hover{border-color:var(--primary);text-decoration:none;box-shadow:var(--shadow);}
.related-price{font-weight:700;color:var(--primary-600);}
.related-supplier{font-size:.8rem;color:var(--muted-fg);}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.6rem;}
.gallery-grid img{border-radius:10px;border:1px solid var(--border);aspect-ratio:4/3;object-fit:cover;width:100%;}

/* ---------- Related searches ---------- */
.related-searches ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem;}
.related-searches li a{display:inline-block;background:var(--muted);border:1px solid var(--border);
  padding:.35rem .8rem;border-radius:999px;font-size:.85rem;color:var(--fg);}
.related-searches li a:hover{border-color:var(--primary);color:var(--primary-600);text-decoration:none;}

.data-attribution{color:var(--muted-fg);font-size:.78rem;margin:1.5rem 0 .5rem;}
.map-link a{font-weight:600;}

/* ---------- Footer ---------- */
.bw-footer{background:var(--card);border-top:1px solid var(--border);margin-top:2rem;}
.bw-footer-inner{max-width:1080px;margin:0 auto;padding:2.25rem 1.25rem 1.25rem;}
.bw-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:1.75rem;}
.bw-footer-brand img{height:34px;margin-bottom:.6rem;}
.bw-footer-tag{color:var(--muted-fg);font-size:.9rem;max-width:240px;}
.bw-footer-col h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted-fg);margin-bottom:.7rem;}
.bw-footer-col ul{list-style:none;padding:0;margin:0;}
.bw-footer-col li{margin-bottom:.45rem;}
.bw-footer-col a{color:var(--fg);font-size:.9rem;}
.bw-footer-col a:hover{color:var(--primary-600);text-decoration:none;}
.bw-footer-bottom{border-top:1px solid var(--border);margin-top:1.75rem;padding-top:1.1rem;
  color:var(--muted-fg);font-size:.82rem;}
.bw-footer-bottom p{margin:0;}

/* ---------- Responsive ---------- */
@media (max-width:760px){
  .attraction-hero h1{font-size:1.55rem;}
  .bw-header-nav{gap:.85rem;}
  .bw-header-nav a{font-size:.85rem;}
  .bw-header-nav a:not(.bw-header-cta){display:none;}
  .bw-footer-grid{grid-template-columns:1fr 1fr;gap:1.25rem;}
  .bw-main{padding:1rem .9rem 2rem;}
}
