:root {
  --lime: #c5ef14;
  --red: #ff4d4d;
  --white: #ffffff;
  --off-white: #f7f6f2;
  --light-gray: #eeede9;
  --mid-gray: #9b9b9b;
  --dark-gray: #333333;
  --black: #111111;
  --rio-gold: #f5a623;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Glacial Indifference', sans-serif;
  background: var(--white);
  color: var(--black);
  overflow-x: hidden;
  padding-top: 50px;
}
h1, h2, h3, h4, h5, h6 { font-family: 'Fira Sans', sans-serif; }

.progress-bar {
  position: fixed;
  top: 50px;
  left: 0;
  z-index: 999;
  height: 3px;
  background: var(--lime);
  width: 0;
}

/* Header styles are provided by css/style.css for parity with all other pages. */

.article-hero {
  height: clamp(520px, calc(100vh - 50px), 880px);
  min-height: 520px;
  position: relative;
  overflow: hidden;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
.hero-frame {
  position: relative;
  width: 100%;
  max-width: none;
  height: 100%;
  border-radius: 0;
  box-shadow: none;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
#articleHero .hero-frame > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 38%;
}
.hero-dim {
  position: absolute; inset: 0;
}
.article-hero .hero-dim{
  background: linear-gradient(to bottom,rgba(0,0,0,.05) 0%,rgba(0,0,0,.4) 50%,rgba(0,0,0,.88) 100%);
}
.article-hero-copy {
  position: relative;
  z-index: 2;
  width: min(860px, calc(100% - 32px));
  max-width: 860px;
  margin: 0;
  padding: 0 16px clamp(44px, 10vh, 90px);
  text-align: left;
}

@media (min-width: 900px) {
  .article-hero-copy {
    transform: translateX(-2in);
  }
}
.article-breadcrumb { display: flex; align-items: center; justify-content: flex-start; gap: 10px; margin-bottom: 20px; }
.article-breadcrumb a, .article-breadcrumb span {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  text-decoration: none;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.breadcrumb-sep { color: rgba(255,255,255,0.3); }
.hero-cat {
  display: inline-flex;
  align-items: center;
  background: var(--red);
  color: var(--white);
  font: 700 11px 'Fira Sans', sans-serif;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 2px;
  margin-bottom: 20px;
}
.article-hero-title {
  position: static;
  left: auto;
  bottom: auto;
  transform: none;
  width: auto;
  padding: 0;
  text-shadow: none;
  font-size: clamp(38px,5.5vw,74px);
  line-height: .95;
  letter-spacing: -2px;
  color: var(--white);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.article-hero-subtitle {
  font-size: 17px;
  color: rgba(255,255,255,.75);
  max-width: 680px;
  line-height: 1.65;
  margin-bottom: 24px;
  margin-left: 0;
  margin-right: 0;
}
.article-hero-byline {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 10px;
  color: rgba(255,255,255,.88);
}
.article-hero-initials {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--rio-gold);
  color: var(--black);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font: 900 14px 'Fira Sans', sans-serif;
}
.article-hero-sep { color: rgba(255,255,255,.45); }

.article-page { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
.article-layout { display: grid; grid-template-columns: 220px 1fr; gap: 0; align-items: start; }

.article-toc {
  position: sticky;
  top: 100px;
  align-self: start;
  max-height: none;
  overflow: visible;
  padding: 40px 32px 40px 0;
  border-right: 1px solid var(--light-gray);
}
.article-toc-title {
  display: block;
  font: 700 10px 'Fira Sans', sans-serif;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--mid-gray);
  margin-bottom: 16px;
}
.article-toc-nav { display: block; }
.article-toc-link {
  display: block;
  font: 400 13px 'Glacial Indifference', sans-serif;
  color: var(--mid-gray);
  text-decoration: none;
  line-height: 1.4;
  letter-spacing: .2px;
  padding: 6px 0 6px 12px;
  border-left: 2px solid transparent;
}
.article-toc-link:hover,
.article-toc-link.is-active { color: var(--black); border-left-color: var(--lime); }
.article-toc-link.is-active { font-family: 'Fira Sans', sans-serif; font-weight: 700; }

.toc-share { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--light-gray); }
.toc-share-label {
  display: block;
  font: 700 10px 'Fira Sans', sans-serif;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--mid-gray);
  margin-bottom: 12px;
}
.share-btns { display: flex; flex-direction: column; gap: 8px; }
.share-btn {
  font: 400 12px 'Glacial Indifference', sans-serif;
  color: var(--dark-gray);
  border: 1px solid var(--light-gray);
  border-radius: 6px;
  background: none;
  text-align: left;
  padding: 8px 10px;
  cursor: pointer;
}
.share-btn:hover { border-color: var(--black); background: var(--off-white); }

.article-body { padding: 60px 0 80px 60px; max-width: 760px; }
.article-body .article-intro {
  font-size: 20px;
  color: var(--dark-gray);
  line-height: 1.7;
  margin-bottom: 48px;
  font-style: italic;
  border-left: 4px solid var(--lime);
  padding-left: 24px;
  font-family: 'Fira Sans', sans-serif;
}
.article-body h2 { font-size: clamp(24px,2.5vw,36px); line-height: 1.1; letter-spacing: -1px; margin: 0 0 20px; }
.article-body h3 { font-size: 20px; letter-spacing: -.5px; margin: 32px 0 14px; }
.article-body p { font-size: 16px; color: #444; line-height: 1.8; margin-bottom: 18px; letter-spacing: .1px; }

.article-body ul, .article-body ol { list-style: none; margin: 20px 0 24px; display: flex; flex-direction: column; gap: 8px; }
.article-body li {
  font-size: 15px;
  color: #444;
  line-height: 1.6;
  padding: 10px 14px;
  background: var(--off-white);
  border-radius: 6px;
  border-left: 3px solid var(--lime);
}
.article-body li::before { content: '→ '; color: var(--lime); font-weight: 700; }

.article-body figure { margin: 24px 0; border-radius: 10px; overflow: hidden; border: 1px solid var(--light-gray); }
.article-body figure img { display: block; width: 100%; }
.article-body figcaption { font-size: 12px; color: var(--mid-gray); padding: 10px 12px; background: var(--white); }

.article-body blockquote {
  background: var(--black);
  color: var(--white);
  padding: 40px 44px;
  border-radius: 10px;
  margin: 40px 0;
  position: relative;
  overflow: hidden;
  border: none;
}
.article-body blockquote::before {
  content: '"';
  position: absolute;
  top: -20px;
  left: 28px;
  font: 900 140px/1 'Fira Sans', sans-serif;
  color: var(--rio-gold);
  opacity: .15;
}
.article-body blockquote p {
  font: 700 italic clamp(18px,2vw,24px)/1.4 'Fira Sans', sans-serif;
  color: var(--white);
  margin: 0;
}

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .55s ease, transform .55s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

.lightbox {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(0,0,0,.92);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .25s;
}
.lightbox.open { opacity: 1; pointer-events: all; }
.lightbox-inner { background: var(--black); border-radius: 12px; padding: 32px; max-width: 600px; width: 90%; text-align: center; }
.lightbox-emoji { font-size: 80px; display: block; margin-bottom: 12px; }
.lightbox-caption { color: rgba(255,255,255,.72); line-height: 1.55; }
.lightbox-close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: #fff;
  cursor: pointer;
}

@media (max-width: 900px) {
  .article-hero {
    min-height: 500px;
  }
  .article-hero-copy {
    width: min(760px, calc(100% - 24px));
    padding: 0 12px 44px;
  }
}

@media (max-width: 760px) {
  body { padding-top: 50px; }
  .article-layout { grid-template-columns: 1fr; }
  .article-toc {
    position: static;
    max-height: none;
    overflow: visible;
    border-right: 0;
    padding: 20px 0 8px;
  }
  .article-body { padding: 28px 0 60px; max-width: 100%; }
  .article-page { padding: 0 16px; }
  .article-hero {
    min-height: 440px;
    height: auto;
  }
  .article-hero-copy {
    width: 100%;
    padding: 0 16px 32px;
  }
  .article-hero-title {
    font-size: clamp(30px, 10vw, 44px);
    letter-spacing: -1px;
  }
}

/* ---- Content Component Styles (restored) ---- */
.article-section{margin-bottom:64px;scroll-margin-top:110px}
.section-eyebrow{font:700 10px 'Fira Sans',sans-serif;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:10px;display:block}

.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0}
.stat-box{background:var(--off-white);border:1px solid var(--light-gray);border-radius:10px;padding:24px 20px;text-align:center}
.stat-num{font:900 36px/1 'Fira Sans',sans-serif;color:var(--black);letter-spacing:-2px;display:block}
.stat-num .unit{font-size:18px;color:var(--lime)}
.stat-desc{font-size:13px;color:var(--mid-gray);margin-top:6px}

.feature-list{list-style:none;margin:20px 0 24px;display:flex;flex-direction:column;gap:8px}
.feature-list li{display:flex;gap:12px;font-size:15px;color:#444;line-height:1.6;padding:10px 14px;background:var(--off-white);border-radius:6px;border-left:3px solid var(--lime)}
.feature-list li::before{content:'→';color:var(--lime);font-weight:700}

.img-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:32px 0}
.img-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:32px 0}
.img-grid-feature{display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:200px 200px;gap:12px;margin:32px 0}
.img-grid-feature .img-block:first-child{grid-row:1/3}
.img-block{border-radius:8px;overflow:hidden;position:relative;cursor:pointer;background:var(--light-gray)}
.img-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s}
.img-block:hover .img-overlay{opacity:1}
.img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .35s}
.img-block:hover .img-ph{transform:scale(1.04)}
.img-ph-tall{height:280px}.img-ph-med{height:220px}.img-ph-sm{height:160px}
.img-caption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:20px 16px 12px;font-size:12px;color:rgba(255,255,255,.88)}
.ph-emoji{font-size:44px;display:block;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}

.ph-rio-night{background:linear-gradient(135deg,#0a0a2e,#1a0a3d)}
.ph-copacabana{background:linear-gradient(135deg,#0a1a3d,#1a2d5e)}
.ph-ipanema{background:linear-gradient(135deg,#1a0a2e,#3d1a0a)}
.ph-lapa{background:linear-gradient(135deg,#2e0a0a,#5e1a1a)}
.ph-santa{background:linear-gradient(135deg,#1a2e0a,#2d4a1a)}
.ph-botafogo{background:linear-gradient(135deg,#0a2e2e,#1a4a4a)}
.ph-samba{background:linear-gradient(135deg,#2e1a0a,#5e3a0a)}
.ph-food{background:linear-gradient(135deg,#2e0a1a,#5e1a3d)}
.ph-soccer{background:linear-gradient(135deg,#0a2e0a,#1a5e1a)}
.ph-sunset{background:linear-gradient(135deg,#3d1a00,#8b3a0d)}
.ph-drinks{background:linear-gradient(135deg,#1a0a2e,#4a1a5e)}

.neighborhood-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:28px 0}
.nbhd-card{border:1px solid var(--light-gray);border-radius:10px;overflow:hidden;background:var(--white);transition:.25s}
.nbhd-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.08);border-color:var(--lime)}
.nbhd-img{height:140px;display:flex;align-items:center;justify-content:center;font-size:40px;position:relative}
.nbhd-vibe{position:absolute;top:10px;left:10px;font:700 9px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;background:rgba(0,0,0,.5);color:#fff;padding:3px 9px;border-radius:2px}
.nbhd-body{padding:16px 18px 20px}
.nbhd-name{font:900 18px 'Fira Sans',sans-serif;letter-spacing:-.5px;margin-bottom:6px}
.nbhd-tag{display:block;font:700 10px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.nbhd-desc{font-size:13px;color:var(--mid-gray);line-height:1.55;margin-bottom:12px}
.nbhd-best{display:flex;flex-wrap:wrap;gap:5px}
.nbhd-pill{font:700 9px 'Fira Sans',sans-serif;letter-spacing:1px;text-transform:uppercase;background:var(--off-white);border:1px solid var(--light-gray);padding:3px 8px;border-radius:2px}

.quiz-box{background:var(--black);border-radius:12px;padding:36px;margin:40px 0;position:relative;overflow:hidden}
.quiz-box::before{content:'';position:absolute;top:-80px;right:-80px;width:260px;height:260px;background:var(--lime);opacity:.04;border-radius:50%}
.quiz-box::after{content:'';position:absolute;bottom:-60px;left:-60px;width:200px;height:200px;background:var(--red);opacity:.05;border-radius:50%}
.quiz-title{font:900 22px 'Fira Sans',sans-serif;color:#fff;letter-spacing:-.5px;margin-bottom:6px;position:relative;z-index:1}
.quiz-sub{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:28px;position:relative;z-index:1}
.quiz-step{display:none}.quiz-step.active{display:block}
.quiz-q{font:700 16px 'Fira Sans',sans-serif;color:#fff;margin-bottom:16px}
.quiz-options{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.quiz-opt{font:700 12px 'Fira Sans',sans-serif;padding:10px 18px;border-radius:4px;border:1.5px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);background:transparent;cursor:pointer}
.quiz-opt:hover,.quiz-opt.selected{border-color:var(--lime);color:var(--lime);background:rgba(197,239,20,.08)}
.quiz-progress-dots{display:flex;gap:6px;margin-bottom:20px}.q-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.2)}.q-dot.active{background:var(--lime)}
.quiz-result{display:none;padding:24px;background:rgba(255,255,255,.06);border-radius:8px;border:1px solid rgba(197,239,20,.3)}.quiz-result.show{display:block}
.result-label{display:block;font:700 11px 'Fira Sans',sans-serif;letter-spacing:2px;text-transform:uppercase;color:var(--lime);margin-bottom:8px}
.result-nbhd{font:900 28px 'Fira Sans',sans-serif;color:#fff;letter-spacing:-1px;margin-bottom:8px}
.result-desc{font-size:14px;color:rgba(255,255,255,.65);line-height:1.6;margin-bottom:16px}
.result-tags{display:flex;flex-wrap:wrap;gap:6px}
.result-tag{font:700 9px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:2px;background:rgba(197,239,20,.15);color:var(--lime);border:1px solid rgba(197,239,20,.3)}
.quiz-restart{margin-top:14px;font:700 11px 'Fira Sans',sans-serif;letter-spacing:1px;text-transform:uppercase;background:none;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.6);padding:8px 16px;border-radius:4px;cursor:pointer}

.samba-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:28px 0}
.samba-card{border:1px solid var(--light-gray);border-radius:10px;padding:24px 20px;background:#fff;position:relative;overflow:hidden;transition:.25s}
.samba-card::after{content:'';position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.samba-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.samba-card:hover::after,.samba-card.active-card::after{transform:scaleX(1)}
.samba-icon{font-size:32px;display:block;margin-bottom:14px}
.samba-type{display:block;font:700 10px 'Fira Sans',sans-serif;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.samba-name{font:700 16px 'Fira Sans',sans-serif;letter-spacing:-.3px;margin-bottom:8px}
.samba-desc{font-size:13px;color:var(--mid-gray);line-height:1.55}

.food-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:28px 0}
.food-card{display:flex;align-items:center;gap:16px;padding:16px 18px;background:var(--off-white);border:1px solid var(--light-gray);border-radius:8px;transition:.2s}
.food-card:hover{border-color:var(--lime);background:#fff;transform:translateX(4px)}
.food-emoji{font-size:30px;flex-shrink:0}
.food-name{font:700 14px 'Fira Sans',sans-serif;margin-bottom:2px}.food-desc{font-size:12px;color:var(--mid-gray);line-height:1.4}

.drinks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:28px 0}
.drink-card{background:var(--off-white);border:1px solid var(--light-gray);border-radius:10px;padding:20px 16px;text-align:center;transition:.25s}
.drink-card:hover{border-color:var(--lime);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08);background:#fff}
.drink-emoji{font-size:32px;display:block;margin-bottom:8px}.drink-name{font:700 14px 'Fira Sans',sans-serif;margin-bottom:4px}.drink-note{font-size:11px;color:var(--mid-gray)}

.slang-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:28px 0}
.slang-card{background:var(--black);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:18px 16px;transition:.25s}
.slang-card:hover{border-color:var(--lime);transform:translateY(-2px)}
.slang-word{display:block;font:900 18px 'Fira Sans',sans-serif;color:var(--lime);margin-bottom:4px}
.slang-meaning{font-size:12px;color:rgba(255,255,255,.55)}
.slang-example{font-size:11px;color:rgba(255,255,255,.35);margin-top:8px;font-style:italic;line-height:1.5;display:none}
.slang-card:hover .slang-example{display:block}

.timeline{position:relative;margin:32px 0}
.timeline::before{content:'';position:absolute;left:28px;top:0;bottom:0;width:2px;background:var(--light-gray)}
.tl-item{display:flex;gap:24px;margin-bottom:28px;position:relative}
.tl-dot{width:56px;height:56px;border-radius:50%;background:var(--off-white);border:2px solid var(--light-gray);display:flex;align-items:center;justify-content:center;flex-shrink:0;font:900 12px 'Fira Sans',sans-serif;cursor:pointer;z-index:1}
.tl-item:hover .tl-dot,.tl-item.active-tl .tl-dot{background:var(--lime);border-color:var(--lime)}
.tl-content{flex:1;padding:14px 0}.tl-time{display:block;font:700 10px 'Fira Sans',sans-serif;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.tl-activity{font:700 16px 'Fira Sans',sans-serif;letter-spacing:-.3px;margin-bottom:6px}.tl-detail{font-size:14px;color:var(--mid-gray);line-height:1.6;max-height:0;overflow:hidden;opacity:0;transition:.35s}
.tl-item.active-tl .tl-detail,.tl-item:hover .tl-detail{max-height:220px;opacity:1}

.safety-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:28px 0}
.safety-card{border-radius:10px;padding:20px 18px;border:1px solid var(--light-gray);transition:.25s}
.safety-card.green{background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.2)}
.safety-card.yellow{background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.2)}
.safety-card.red-card{background:rgba(255,77,77,.06);border-color:rgba(255,77,77,.15)}
.safety-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.06)}
.safety-status{display:block;font:700 9px 'Fira Sans',sans-serif;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.safety-icon{font-size:24px;display:block;margin-bottom:8px}.safety-title{font:700 14px 'Fira Sans',sans-serif;margin-bottom:6px}.safety-text{font-size:12px;color:var(--mid-gray);line-height:1.55}

.club-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:24px 0}
.club-card{background:var(--off-white);border:1px solid var(--light-gray);border-radius:8px;padding:20px 16px;text-align:center;transition:.25s}
.club-card:hover{border-color:var(--lime);transform:translateY(-3px);background:#fff}
.club-emoji{font-size:28px;display:block;margin-bottom:8px}.club-name{font:700 13px 'Fira Sans',sans-serif;margin-bottom:4px}.club-note{font-size:11px;color:var(--mid-gray)}

.itinerary-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:28px 0}
.itin-card{border-radius:10px;overflow:hidden;border:1px solid var(--light-gray);background:#fff;transition:.25s}
.itin-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.1)}
.itin-header{padding:20px 22px;display:flex;align-items:center;justify-content:space-between}.itin-title{font:700 17px 'Fira Sans',sans-serif;color:#fff;letter-spacing:-.3px}.itin-emoji{font-size:28px}
.itin-body{padding:20px 22px}.itin-stops{list-style:none}.itin-stop{display:flex;gap:10px;padding:6px 0;border-bottom:1px solid var(--light-gray)}.itin-stop:last-child{border-bottom:none}
.itin-stop-time{font:700 10px 'Fira Sans',sans-serif;color:var(--mid-gray);width:44px;flex-shrink:0;margin-top:2px}.itin-stop-name{font:700 13px 'Fira Sans',sans-serif}.itin-stop-detail{font-size:11px;color:var(--mid-gray)}

.itinerary-builder{background:var(--off-white);border-radius:12px;padding:36px;margin:40px 0;border:1px solid var(--light-gray)}
.ib-title{font:900 22px 'Fira Sans',sans-serif;letter-spacing:-.5px;margin-bottom:6px}.ib-sub{font-size:14px;color:var(--mid-gray);margin-bottom:28px}
.ib-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.ib-filter-label{width:100%;font:700 10px 'Fira Sans',sans-serif;letter-spacing:2px;text-transform:uppercase;color:var(--mid-gray);margin-top:8px}
.ib-chip{font:700 11px 'Fira Sans',sans-serif;padding:8px 16px;border-radius:4px;border:1.5px solid var(--light-gray);background:#fff;cursor:pointer}
.ib-chip.active{border-color:var(--lime);background:rgba(197,239,20,.1)}
.ib-gen-btn{background:var(--lime);color:var(--black);border:none;font:700 12px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;padding:14px 28px;border-radius:4px;cursor:pointer}
.ib-result{display:none;background:#fff;border:1px solid var(--light-gray);border-radius:8px;overflow:hidden;margin-top:16px}.ib-result.show{display:block}
.ib-result-header{background:var(--black);padding:16px 22px;display:flex;justify-content:space-between;align-items:center}.ib-result-title{font:700 14px 'Fira Sans',sans-serif;color:#fff}.ib-result-badge{font:700 9px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;background:var(--lime);padding:4px 10px;border-radius:2px}
.ib-stops{list-style:none}.ib-stop{display:flex;gap:16px;padding:14px 22px;border-bottom:1px solid var(--light-gray);align-items:center}.ib-stop:last-child{border-bottom:none}
.ib-stop-time{font:700 12px 'Fira Sans',sans-serif;color:var(--mid-gray);width:56px;flex-shrink:0}.ib-stop-dot{width:8px;height:8px;border-radius:50%;background:var(--lime)}.stop-name{font:700 14px 'Fira Sans',sans-serif}.stop-detail{font-size:12px;color:var(--mid-gray)}

.related-tours{background:var(--black);border-radius:12px;padding:36px;margin:48px 0;position:relative;overflow:hidden}
.related-tours::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:var(--lime);opacity:.06;border-radius:50%}
.related-tours-title{font:900 22px 'Fira Sans',sans-serif;color:#fff;letter-spacing:-.5px;margin-bottom:6px}.related-tours-sub{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:28px}
.mini-tours{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.mini-tour{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden;transition:.25s}
.mini-tour:hover{border-color:var(--lime);transform:translateY(-3px);background:rgba(255,255,255,.1)}
.mini-tour-img{height:100px;display:flex;align-items:center;justify-content:center;font-size:30px}.mini-tour-body{padding:14px}
.mini-tour-cat{display:block;font:700 9px 'Fira Sans',sans-serif;letter-spacing:2px;text-transform:uppercase;color:var(--lime);margin-bottom:4px}
.mini-tour-name{font:700 13px 'Fira Sans',sans-serif;color:#fff;line-height:1.2;margin-bottom:10px}.mini-tour-meta{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.08);padding-top:10px}.mini-tour-price{font:900 14px 'Fira Sans',sans-serif;color:#fff}.mini-tour-dur{font-size:11px;color:rgba(255,255,255,.45)}

.info-box{background:var(--off-white);border-left:4px solid var(--lime);border-radius:10px;padding:28px 32px;margin:32px 0}
.info-box-title{font:700 13px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.warn-box{background:rgba(255,77,77,.06);border-left:4px solid var(--red);border-radius:10px;padding:24px 28px;margin:28px 0}
.warn-box-title{font:700 12px 'Fira Sans',sans-serif;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin-bottom:10px}

.article-compare-wrap{margin:24px 0}
.article-compare-table{width:100%;border-collapse:collapse;border:1px solid var(--light-gray);background:#fff}
.article-compare-table th,.article-compare-table td{border:1px solid var(--light-gray);padding:10px 12px;text-align:center;font-size:13px}
.article-compare-table th:first-child,.article-compare-table td:first-child{text-align:left}
.article-compare-table thead th{background:var(--black);color:#fff;font-family:'Fira Sans',sans-serif}
.article-compare-table .is-recommended{color:var(--lime)}
.status{font-weight:700}.status-ok{color:#16a34a}.status-partial{color:#d97706}.status-no{color:#dc2626}
.article-compare-legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.article-compare-chip{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid var(--light-gray);background:#fff}.article-compare-chip.ok{color:#166534}.article-compare-chip.partial{color:#92400e}.article-compare-chip.no{color:#991b1b}

.article-warning{background:rgba(255,77,77,.06);border-left:4px solid var(--red);border-radius:10px;padding:20px 22px;margin:24px 0}
.article-warning-title{font:700 12px 'Fira Sans',sans-serif;letter-spacing:1.2px;text-transform:uppercase;color:var(--red);margin-bottom:8px}

.article-wildlife-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:24px 0}
.article-wildlife-card{background:var(--off-white);border:1px solid var(--light-gray);border-radius:8px;padding:14px 12px;text-align:center}
.article-wildlife-emoji{display:block;font-size:24px;margin-bottom:6px}.article-wildlife-name{display:block;font:700 12px 'Fira Sans',sans-serif;margin-bottom:4px}.article-wildlife-note{font-size:11px;color:var(--mid-gray)}

.article-accordion{display:grid;gap:10px;margin:18px 0}
.article-accordion-item{border:1px solid var(--light-gray);border-radius:10px;overflow:hidden;background:#fff}
.article-accordion-head{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;background:var(--off-white)}
.article-accordion-badge{font:700 10px 'Fira Sans',sans-serif;letter-spacing:1px;text-transform:uppercase;background:var(--black);color:#fff;padding:4px 7px;border-radius:999px;flex-shrink:0}
.article-accordion-title{font:700 14px 'Fira Sans',sans-serif;line-height:1.3;flex:1}
.article-accordion-toggle{font:900 16px 'Fira Sans',sans-serif;color:var(--mid-gray)}
.article-accordion-body{display:none;padding:14px 16px 16px}.article-accordion-item.is-open .article-accordion-body{display:block}

.article-pack-tabs{margin:20px 0}
.article-pack-tablist{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.article-pack-tab{font:700 12px 'Fira Sans',sans-serif;background:#fff;border:1px solid var(--light-gray);padding:8px 12px;border-radius:6px;cursor:pointer}
.article-pack-tab.active{background:var(--black);color:#fff;border-color:var(--black)}
.article-pack-panel[hidden]{display:none}
.article-pack-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.article-pack-item{display:flex;align-items:flex-start;gap:8px;text-align:left;background:var(--off-white);border:1px solid var(--light-gray);border-radius:8px;padding:10px;cursor:pointer}
.article-pack-item.is-checked{border-color:#22c55e;background:rgba(34,197,94,.08)}
.article-pack-check{width:14px;height:14px;border:2px solid var(--mid-gray);border-radius:3px;flex-shrink:0;margin-top:2px}
.article-pack-item.is-checked .article-pack-check{background:#22c55e;border-color:#22c55e}

@media (max-width: 1000px){
  .neighborhood-grid,.samba-cards,.drinks-grid,.safety-grid,.mini-tours,.club-grid,.article-wildlife-grid{grid-template-columns:repeat(2,1fr)}
  .itinerary-cards{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .img-grid-2,.img-grid-3,.img-grid-feature,.food-grid,.slang-grid,.article-pack-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr}
  .article-wildlife-grid,.neighborhood-grid,.samba-cards,.drinks-grid,.safety-grid,.mini-tours,.club-grid{grid-template-columns:1fr}
}
