/* =========================================================
   OURO PRETO 360  -  Sistema visual (publico + viewer)
   ========================================================= */

:root {
  --paper:      #f4ede0;
  --paper-2:    #ebe3d4;
  --paper-3:    #ddd1bb;
  --ink:        #1c1a17;
  --ink-soft:   #3a3530;
  --ink-mute:   #6b6258;
  --gold:       #a67b3a;
  --gold-deep:  #7d5a26;
  --terracotta: #8c4b2a;
  --moss:       #5e6b3e;
  --line:       #c9bda5;

  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;

  --c-1: .5rem; --c-2: 1rem; --c-3: 1.5rem; --c-4: 2rem;
  --c-5: 3rem;  --c-6: 4rem; --c-7: 6rem;   --c-8: 8rem;

  --max-w: 1320px;
  --gutter: clamp(1.5rem, 4vw, 3rem);
  --radius: 2px;
  --ease: cubic-bezier(.2,.6,.2,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  font-size: 16px; line-height: 1.6;
  color: var(--ink); background: var(--paper);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
::selection { background: var(--gold); color: var(--paper); }

h1,h2,h3,h4,.serif { font-family: var(--serif); font-weight: 500; letter-spacing: -.01em; line-height: 1.05; }
h1 em,h2 em,h3 em,h4 em { font-style: italic; font-weight: 400; color: var(--gold); }

.eyebrow {
  display: inline-block; font-size: .7rem; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase; color: var(--ink-mute);
}
.lead { font-size: 1.25rem; line-height: 1.55; color: var(--ink-soft); }

/* ============= NAV ============= */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 1.15rem var(--gutter);
  background: rgba(244,237,224,.85); backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--line);
}
.nav__inner { max-width: var(--max-w); margin: 0 auto; display: grid;
  grid-template-columns: auto 1fr auto; align-items: center; gap: var(--c-5); }
.brand { display: inline-flex; align-items: center; gap: .7rem; }
.brand__mark { display: inline-grid; place-items: center; width: 38px; height: 38px;
  border: 1.5px solid var(--ink); font-family: var(--serif); font-size: 1rem; font-weight: 600; }
.brand__text { font-family: var(--serif); font-size: 1.15rem; font-weight: 600; }
.brand__text em { font-style: italic; color: var(--gold); font-weight: 400; }
.nav__menu { display: flex; justify-content: center; gap: 2.2rem; font-size: .85rem; letter-spacing: .06em; }
.nav__menu a { position: relative; padding: .3rem 0; transition: color .2s; }
.nav__menu a:hover { color: var(--gold); }
.nav__menu a::after { content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background: var(--gold); transition: width .3s; }
.nav__menu a:hover::after { width: 100%; }
.nav__lang { display:flex; align-items:center; gap:.4rem; font-size:.75rem; letter-spacing:.12em; }
.lang { color: var(--ink-mute); padding: .3rem .4rem; transition: color .2s; }
.lang:hover { color: var(--ink); }
.lang--active { color: var(--ink); font-weight: 600; }
.lang[disabled] { opacity: .38; cursor: not-allowed; }
.lang[disabled]:hover { color: var(--ink-mute); }

/* ============= BOTOES ============= */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding: 1rem 2rem; font-size:.8rem; font-weight:500; letter-spacing:.16em;
  text-transform: uppercase; transition: all .3s var(--ease); border: 1px solid transparent; }
.btn--primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.btn--primary:hover { background: var(--gold); border-color: var(--gold); transform: translateY(-2px); }
.btn--ghost { border-color: var(--ink); color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--paper); }
.btn--sm { padding: .6rem 1.1rem; font-size: .72rem; }

/* ============= HERO ============= */
.hero { position: relative; min-height: 100vh; display:flex; align-items:flex-end;
  padding: var(--c-7) var(--gutter) var(--c-6); overflow:hidden; color: var(--paper); }
.hero__media { position:absolute; inset:0; z-index:0; background-size: cover; background-position: center; }
.hero__media--gradient {
  background:
    radial-gradient(ellipse 60% 70% at 70% 30%, rgba(166,123,58,.4), transparent 70%),
    radial-gradient(ellipse 80% 60% at 20% 80%, rgba(140,75,42,.5), transparent 60%),
    linear-gradient(160deg, #2d2419 0%, #4a3825 35%, #6e5235 65%, #8c4b2a 100%);
}
.hero__media::after { content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 50% 0%, transparent 30%, rgba(28,26,23,.72) 100%); }
.hero__overlay { position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(28,26,23,.2) 0%, transparent 45%, rgba(28,26,23,.65) 100%); }
.hero__content { position:relative; z-index:2; max-width: var(--max-w); margin:0 auto; width:100%; }
.hero__content .eyebrow { color: rgba(244,237,224,.7); margin-bottom: var(--c-3); }
.hero__title { font-size: clamp(3rem, 9vw, 8rem); line-height:.95; margin-bottom: var(--c-4); max-width: 16ch; }
.hero__title em { display:inline-block; color: var(--paper-2); opacity:.92; }
.hero__lead { max-width: 50ch; font-size: 1.15rem; line-height:1.55; color: rgba(244,237,224,.85); margin-bottom: var(--c-5); }
.hero__actions { display:flex; gap:1rem; flex-wrap:wrap; }
.hero .btn--ghost { border-color: rgba(244,237,224,.5); color: var(--paper); }
.hero .btn--ghost:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.hero__scroll { position:absolute; right: var(--gutter); bottom: var(--c-5); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:1rem;
  font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color: rgba(244,237,224,.6); }
.hero__scroll-line { width:1px; height:60px; background: linear-gradient(to bottom, rgba(244,237,224,.6), transparent);
  animation: scrollHint 2.4s ease-in-out infinite; }
@keyframes scrollHint { 0%,100%{ transform: scaleY(.6); transform-origin: top; } 50%{ transform: scaleY(1); transform-origin: top; } }

/* ============= SECOES ============= */
.section { max-width: var(--max-w); margin:0 auto; padding: var(--c-7) var(--gutter);
  display:grid; grid-template-columns: 80px 1fr; gap: var(--c-5); position:relative;
  opacity:0; transform: translateY(20px); transition: opacity .8s ease, transform .8s var(--ease); }
.section.is-visible { opacity:1; transform: translateY(0); }
.section__num { font-family: var(--serif); font-size:.95rem; color: var(--gold); letter-spacing:.1em;
  padding-top:.4rem; border-top: 1px solid var(--line); align-self:flex-start; font-style: italic; }
.section__head { grid-column: 2; margin-bottom: var(--c-5); }
.section__title { font-size: clamp(2.4rem, 6vw, 4.8rem); margin-bottom: var(--c-3); max-width: 14ch; }
.section__sub { font-size: 1.1rem; color: var(--ink-mute); max-width: 50ch; font-style: italic; font-family: var(--serif); }
.section__body { grid-column: 2; max-width: 70ch; }
.section__body p + p { margin-top: 1.1rem; }
.section--full { grid-template-columns: 1fr; }
.section--full .section__head, .section--full .section__body,
.section--full .grid, .section--full .cities { grid-column: 1; }

/* ============= STATS ============= */
.stats { display:grid; grid-template-columns: repeat(4,1fr); gap: var(--c-4);
  margin-top: var(--c-6); padding-top: var(--c-4); border-top: 1px solid var(--line); }
.stat__num { display:block; font-family: var(--serif); font-size: 3rem; line-height:1; color: var(--gold); margin-bottom: var(--c-1); font-style: italic; }
.stat__lbl { display:block; font-size:.75rem; letter-spacing:.16em; text-transform:uppercase; color: var(--ink-mute); line-height:1.4; }

/* ============= GRID / CARDS ============= */
.grid { grid-column: 2; display:grid; grid-template-columns: repeat(6,1fr); gap: var(--c-4); }
.section--full .grid { grid-column: 1; }
.card { grid-column: span 2; opacity:0; transform: translateY(20px);
  transition: opacity .8s ease, transform .8s var(--ease); }
.card.is-visible { opacity:1; transform: translateY(0); }
.card--featured { grid-column: span 3; }
.card a, .card > div { display:block; height:100%; }
.card__media { width:100%; aspect-ratio: 4/5; background-size:cover; background-position:center;
  background-color: var(--paper-3); overflow:hidden; position:relative;
  transition: transform .6s var(--ease); filter: grayscale(.12) contrast(1.04); }
.card--featured .card__media { aspect-ratio: 4/3; }
.card__media::after { content:''; position:absolute; inset:0;
  background: linear-gradient(to bottom, transparent 55%, rgba(28,26,23,.4)); opacity:0; transition: opacity .4s; }
.card a:hover .card__media { transform: scale(1.03); }
.card a:hover .card__media::after { opacity:1; }
.card__badge { position:absolute; top:1rem; left:1rem; z-index:2; background: rgba(28,26,23,.78);
  color: var(--paper); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; padding:.35rem .6rem; }
.card__badge--soon { background: rgba(140,75,42,.85); }
.card__body { padding-top: var(--c-3); }
.card__cat { display:block; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color: var(--gold); margin-bottom:.8rem; }
.card__title { font-size: clamp(1.4rem, 2.4vw, 2rem); margin-bottom:.8rem; line-height:1.1; }
.card--featured .card__title { font-size: clamp(1.8rem, 3.2vw, 2.8rem); }
.card__desc { color: var(--ink-mute); font-size:.95rem; margin-bottom:1.1rem; line-height:1.55; }
.card__cta { display:inline-block; font-size:.75rem; letter-spacing:.16em; text-transform:uppercase;
  border-bottom: 1px solid var(--ink); padding-bottom:.25rem; transition: all .25s; }
.card a:hover .card__cta { color: var(--gold); border-bottom-color: var(--gold); padding-left:.3rem; }

/* ============= CIDADES (home) ============= */
.cities { grid-column: 1; display:grid; grid-template-columns: repeat(2,1fr); gap: var(--c-4); }
.citycard { position:relative; min-height: 420px; overflow:hidden; display:flex; align-items:flex-end;
  color: var(--paper); border: 1px solid var(--line); }
.citycard__media { position:absolute; inset:0; background-size:cover; background-position:center;
  transition: transform .8s var(--ease); filter: grayscale(.1) contrast(1.05); }
.citycard:hover .citycard__media { transform: scale(1.05); }
.citycard::after { content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent 30%, rgba(28,26,23,.85)); }
.citycard__body { position:relative; z-index:2; padding: var(--c-4); width:100%; }
.citycard__state { font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color: var(--gold); }
.citycard__name { font-size: clamp(2rem,3.5vw,3rem); margin:.4rem 0 .6rem; }
.citycard__meta { font-size:.85rem; color: rgba(244,237,224,.8); display:flex; gap:1rem; align-items:center; }
.citycard__cta { margin-top: var(--c-3); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  border-bottom:1px solid var(--paper); padding-bottom:.2rem; display:inline-block; transition: all .25s; }
.citycard:hover .citycard__cta { color: var(--gold); border-color: var(--gold); padding-left:.3rem; }
.citycard--soon { pointer-events:none; }
.citycard--soon .citycard__body::before { content:'Em breve'; position:absolute; top:var(--c-4); right:var(--c-4);
  background: rgba(140,75,42,.9); padding:.35rem .7rem; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; }

/* ============= BREADCRUMB ============= */
.crumb { max-width: var(--max-w); margin: 0 auto; padding: 1.5rem var(--gutter) 0;
  font-size:.78rem; letter-spacing:.08em; color: var(--ink-mute); display:flex; gap:.5rem; align-items:center; }
.crumb a { transition: color .2s; } .crumb a:hover { color: var(--gold); }
.crumb span { opacity:.5; }

/* ============= QUOTE ============= */
.quote-band { padding: var(--c-7) var(--gutter); background: var(--ink); color: var(--paper); text-align:center; }
.quote-band .quote { max-width: 60ch; margin:0 auto; }
.quote-band p { font-family: var(--serif); font-size: clamp(1.8rem,4vw,3rem); line-height:1.3; font-style: italic; margin-bottom: var(--c-3); }
.quote-band cite { display:block; font-size:.8rem; font-style:normal; letter-spacing:.22em; text-transform:uppercase; color: var(--gold); padding-top:1.2rem; position:relative; }
.quote-band cite::before { content:''; position:absolute; top:0; left:50%; transform: translateX(-50%); width:30px; height:1px; background: var(--gold); }

/* ============= FOOTER ============= */
.footer { background: var(--ink); color: var(--paper); padding: var(--c-7) var(--gutter) var(--c-4); }
.footer__inner { max-width: var(--max-w); margin:0 auto; display:grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--c-5); margin-bottom: var(--c-6); }
.brand--light .brand__mark { border-color: var(--paper); }
.brand--light .brand__text { color: var(--paper); }
.footer__text { font-size:.85rem; color: rgba(244,237,224,.6); line-height:1.6; max-width: 38ch; margin-top: var(--c-3); }
.footer__col h4 { font-size:.75rem; letter-spacing:.2em; text-transform:uppercase; color: var(--gold); margin-bottom: var(--c-3); font-family: var(--sans); font-weight:500; }
.footer__col ul { list-style:none; }
.footer__col li { padding:.4rem 0; font-size:.9rem; }
.footer__col a { color: rgba(244,237,224,.8); transition: color .2s; }
.footer__col a:hover { color: var(--gold); }
.footer__base { max-width: var(--max-w); margin:0 auto; padding-top: var(--c-4); border-top:1px solid rgba(244,237,224,.1);
  display:flex; justify-content:space-between; font-size:.75rem; color: rgba(244,237,224,.5); letter-spacing:.06em; }

/* ============= LOADING / EMPTY ============= */
.loading { display:grid; place-items:center; min-height: 50vh; gap:1rem; color: var(--ink-mute); }
.spinner { width:42px; height:42px; border:2px solid var(--line); border-top-color: var(--gold); border-radius:50%; animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.empty { text-align:center; padding: var(--c-6); color: var(--ink-mute); font-family: var(--serif); font-size:1.3rem; font-style:italic; }

/* =========================================================
   VIEWER (tour 360)
   ========================================================= */
body.viewer-body { background: #0d0c0b; overflow: hidden; }
.viewer { position: fixed; inset: 0; }
#panorama { width:100%; height:100%; background:#0d0c0b; }

/* top bar */
.vbar { position:absolute; top:0; left:0; right:0; z-index:30; display:flex; align-items:center; justify-content:space-between;
  padding: 1rem 1.4rem; gap:1rem;
  background: linear-gradient(to bottom, rgba(13,12,11,.75), transparent); color: var(--paper);
  pointer-events:none; }
.vbar > * { pointer-events:auto; }
.vbar__left { display:flex; align-items:center; gap:1rem; min-width:0; }
.vback { display:inline-grid; place-items:center; width:42px; height:42px; border:1px solid rgba(244,237,224,.25);
  background: rgba(13,12,11,.4); backdrop-filter: blur(6px); transition: all .2s; flex-shrink:0; }
.vback:hover { background: var(--gold); border-color: var(--gold); }
.vtitles { min-width:0; }
.vtitles__place { font-family: var(--serif); font-size: 1.25rem; line-height:1.1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.vtitles__scene { font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color: var(--gold); margin-top:.15rem; }
.vbar__right { display:flex; gap:.5rem; }
.vbtn { display:inline-grid; place-items:center; width:42px; height:42px; border:1px solid rgba(244,237,224,.25);
  background: rgba(13,12,11,.4); backdrop-filter: blur(6px); transition: all .2s; font-size:1.1rem; }
.vbtn:hover { background: var(--gold); border-color: var(--gold); }
.vbtn svg { width:18px; height:18px; }

/* scene switcher (bottom) */
.vscenes { position:absolute; bottom:0; left:0; right:0; z-index:30;
  display:flex; gap:.6rem; padding: 1.4rem; justify-content:center; flex-wrap:wrap;
  background: linear-gradient(to top, rgba(13,12,11,.8), transparent); pointer-events:none; }
.vscene { pointer-events:auto; display:flex; align-items:center; gap:.5rem; padding:.55rem 1rem;
  background: rgba(13,12,11,.5); backdrop-filter: blur(8px); border:1px solid rgba(244,237,224,.18);
  color: rgba(244,237,224,.85); font-size:.78rem; letter-spacing:.04em; transition: all .25s; cursor:pointer; }
.vscene:hover { border-color: var(--gold); color: var(--paper); }
.vscene--active { background: var(--gold); border-color: var(--gold); color: var(--paper); }
.vscene__dot { width:7px; height:7px; border-radius:50%; background: currentColor; opacity:.6; }
.vscene--active .vscene__dot { opacity:1; }

/* hint toast */
.vhint { position:absolute; bottom: 6rem; left:50%; transform: translateX(-50%); z-index:25;
  background: rgba(13,12,11,.7); backdrop-filter: blur(8px); color: rgba(244,237,224,.9);
  padding:.7rem 1.2rem; font-size:.82rem; font-family: var(--serif); font-style:italic;
  border:1px solid rgba(166,123,58,.4); border-radius: 40px; transition: opacity .6s; pointer-events:none; }
.vhint strong { color: var(--gold); font-style: normal; }

/* transition overlay (crossfade/zoom feel) */
.vfade { position:absolute; inset:0; z-index:40; background:#0d0c0b; opacity:0; pointer-events:none;
  transition: opacity .55s ease; }
.vfade--active { opacity:1; }

/* ====== Pannellum hotspot markers ====== */
.ohs { width: 34px; height: 34px; cursor: pointer; transform: translate(-50%,-50%); }
.ohs__pin { position:absolute; inset:0; display:grid; place-items:center; border-radius:50%;
  border: 2px solid var(--paper); color: var(--paper); font-size:1rem;
  box-shadow: 0 2px 12px rgba(0,0,0,.4); transition: transform .25s ease, background .25s; }
.ohs:hover .ohs__pin { transform: scale(1.18); }
.ohs__pulse { position:absolute; inset:-6px; border-radius:50%; border:2px solid currentColor; opacity:.5;
  animation: ohsPulse 2.2s ease-out infinite; }
@keyframes ohsPulse { 0%{ transform: scale(.7); opacity:.6; } 100%{ transform: scale(1.5); opacity:0; } }
.ohs--scene .ohs__pin { background: rgba(166,123,58,.92); color: var(--gold); }
.ohs--info  .ohs__pin { background: rgba(28,26,23,.82); color: #d8c39a; }
.ohs--image .ohs__pin { background: rgba(94,107,62,.9); color: #cdd6ad; }
.ohs--video .ohs__pin { background: rgba(140,75,42,.92); color: #e7b99c; }

/* tooltip label */
.ohs__label { position:absolute; left:50%; bottom: 40px; transform: translateX(-50%);
  white-space:nowrap; background: rgba(13,12,11,.85); color: var(--paper); padding:.35rem .7rem;
  font-size:.72rem; letter-spacing:.03em; border-radius: 3px; opacity:0; transition: opacity .2s; pointer-events:none; }
.ohs:hover .ohs__label { opacity:1; }

/* ====== Modais (info / imagem / video) ====== */
.modal { position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center;
  padding: var(--gutter); background: rgba(13,12,11,.82); backdrop-filter: blur(6px); }
.modal.is-open { display:flex; animation: modalIn .35s var(--ease); }
@keyframes modalIn { from { opacity:0; } to { opacity:1; } }
.modal__box { position:relative; max-width: 920px; width:100%; max-height: 86vh; overflow:auto;
  background: var(--paper); color: var(--ink); animation: modalUp .4s var(--ease); }
@keyframes modalUp { from { transform: translateY(20px); opacity:0; } to { transform: translateY(0); opacity:1; } }
.modal__close { position:absolute; top:1rem; right:1rem; z-index:3; width:40px; height:40px; display:grid; place-items:center;
  background: rgba(13,12,11,.6); color: var(--paper); border-radius:50%; font-size:1.3rem; transition: background .2s; }
.modal__close:hover { background: var(--terracotta); }
.modal__media { width:100%; background:#000; }
.modal__media img { width:100%; height:auto; display:block; }
.modal__media video { width:100%; display:block; max-height: 70vh; background:#000; }
.modal__body { padding: var(--c-4) var(--c-5); }
.modal__cat { font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color: var(--gold); }
.modal__title { font-size: clamp(1.6rem,3vw,2.4rem); margin:.5rem 0 1rem; }
.modal__text { font-size: 1.05rem; line-height:1.7; color: var(--ink-soft); }
.modal__caption { padding: var(--c-2) var(--c-5); font-style: italic; font-family: var(--serif); color: var(--ink-mute); border-top:1px solid var(--line); }
/* modal "info" (plaquinha) sem media: estilo carta */
.modal__box--info { max-width: 560px; border-top: 4px solid var(--gold); }

/* ====== info lateral do monumento ====== */
.vinfo { position:fixed; top:0; right:0; bottom:0; width: min(420px, 90vw); z-index:110;
  background: var(--paper); color: var(--ink); transform: translateX(100%); transition: transform .45s var(--ease);
  overflow:auto; box-shadow: -10px 0 40px rgba(0,0,0,.3); }
.vinfo.is-open { transform: translateX(0); }
.vinfo__head { padding: var(--c-4) var(--c-4) var(--c-3); border-bottom:1px solid var(--line); position:relative; }
.vinfo__close { position:absolute; top:1.1rem; right:1.1rem; width:34px; height:34px; display:grid; place-items:center; font-size:1.2rem; color: var(--ink-mute); }
.vinfo__close:hover { color: var(--terracotta); }
.vinfo__cat { font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color: var(--gold); }
.vinfo__title { font-size: 2rem; margin:.4rem 0; }
.vinfo__body { padding: var(--c-4); }
.vinfo__desc { color: var(--ink-soft); line-height:1.7; margin-bottom: var(--c-4); }
.vinfo dl { display:grid; gap:0; }
.vinfo dt { font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color: var(--ink-mute); margin-top:1.1rem; }
.vinfo dd { font-family: var(--serif); font-size:1.1rem; margin-top:.15rem; }

/* ============= RESPONSIVE ============= */
@media (max-width: 960px) {
  .nav__inner { grid-template-columns: auto auto; }
  .nav__menu { display:none; }
  .section { grid-template-columns: 1fr; padding: var(--c-6) var(--gutter); gap: var(--c-3); }
  .section__num { grid-column:1; }
  .section__head, .section__body, .grid, .cities { grid-column:1; }
  .grid { grid-template-columns: 1fr 1fr; }
  .card, .card--featured { grid-column: span 1; }
  .stats { grid-template-columns: 1fr 1fr; }
  .cities { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .grid { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr; }
  .footer__base { flex-direction:column; gap:.6rem; }
  .hero__title { font-size: 3rem; }
  .vtitles__place { font-size: 1.05rem; }
}

/* =========================================================
   POLIMENTO — textura editorial, vignette, refinos
   ========================================================= */

/* grão de filme sutil nas áreas escuras (sensação editorial/fotográfica) */
.hero__media::before,
.quote-band::before,
.citycard__media::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: .4; mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero__media::before { z-index: 1; }
.quote-band { position: relative; overflow: hidden; }
.quote-band::before { opacity: .35; }
.quote-band .quote { position: relative; z-index: 2; }

/* hero: brilho dourado mais cinematográfico no topo */
.hero__overlay { background: linear-gradient(180deg, rgba(28,26,23,.35) 0%, transparent 40%, rgba(28,26,23,.7) 100%); }
.hero__title { text-shadow: 0 2px 40px rgba(0,0,0,.25); }

/* vignette imersivo no viewer 360 */
.viewer::after { content: ''; position: absolute; inset: 0; z-index: 20; pointer-events: none;
  box-shadow: inset 0 0 220px 60px rgba(0,0,0,.55); }

/* marcadores de hotspot mais nítidos e com brilho */
.ohs__pin { box-shadow: 0 3px 16px rgba(0,0,0,.5), 0 0 0 4px rgba(13,12,11,.25); }
.ohs--scene .ohs__pin { box-shadow: 0 3px 18px rgba(166,123,58,.6), 0 0 0 4px rgba(13,12,11,.25); }

/* barra inferior de cenas: pílula com leve elevação */
.vscene { box-shadow: 0 4px 16px rgba(0,0,0,.25); }

/* cards do grid com leve realce no hover */
.card a:hover .card__title { color: var(--gold-deep); }

/* botões: brilho sutil no primário */
.btn--primary { box-shadow: 0 6px 20px rgba(28,26,23,.18); }
.btn--primary:hover { box-shadow: 0 10px 28px rgba(166,123,58,.35); }

/* =========================================================
   MAPA (Leaflet)
   ========================================================= */
body.map-body { overflow: hidden; height: 100vh; }
#map { position: fixed; top: 0; left: 340px; right: 0; bottom: 0; background: #cfd8c5; z-index: 1; }

/* ===== Barra lateral de locais (filtro) ===== */
.mapside { position: fixed; top: 0; left: 0; bottom: 0; width: 340px; z-index: 1000;
  background: var(--paper); border-right: 1px solid var(--line); display: flex; flex-direction: column; }
.mapside__head { display: flex; align-items: center; gap: .8rem; padding: 1.1rem 1.2rem; border-bottom: 1px solid var(--line); }
.mapside__back { display: inline-grid; place-items: center; width: 40px; height: 40px; border: 1px solid var(--line); flex-shrink: 0; transition: all .2s; }
.mapside__back:hover { border-color: var(--gold); color: var(--gold); }
.mapside__brand { font-family: var(--serif); font-weight: 600; font-size: .9rem; }
.mapside__brand em { font-style: italic; color: var(--gold); }
.mapside__city { font-family: var(--serif); font-size: 1.5rem; line-height: 1; margin-top: .15rem; }

.mapside__tools { padding: 1rem 1.2rem .7rem; border-bottom: 1px solid var(--line); }
.mapside__search { width: 100%; padding: .7rem .9rem; border: 1px solid var(--line); background: var(--paper-2); font-family: var(--sans); font-size: .9rem; color: var(--ink); }
.mapside__search:focus { outline: none; border-color: var(--gold); background: var(--paper); }
.mapside__base { display: flex; margin-top: .7rem; border: 1px solid var(--line); }
.mapside__base button { flex: 1; padding: .5rem; font-size: .78rem; letter-spacing: .04em; color: var(--ink-mute); transition: all .2s; }
.mapside__base button + button { border-left: 1px solid var(--line); }
.mapside__base button.is-active { background: var(--gold); color: var(--paper); }
.mapside__cats { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .8rem; }
.catchip { font-size: .72rem; padding: .3rem .65rem; border: 1px solid var(--line); color: var(--ink-mute); border-radius: 40px; transition: all .2s; }
.catchip:hover { border-color: var(--gold); color: var(--ink); }
.catchip.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.mapside__count { font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-mute); margin-top: .8rem; }

.mapside__list { flex: 1; overflow-y: auto; padding: .55rem; }
.mapitem { width: 100%; display: flex; align-items: center; gap: .7rem; padding: .55rem; text-align: left; background: none; border: 1px solid transparent; border-radius: 3px; transition: all .15s; cursor: pointer; }
.mapitem:hover { background: var(--paper-2); }
.mapitem.is-active { border-color: var(--gold); background: var(--paper-2); }
.mapitem__num { width: 23px; height: 23px; flex-shrink: 0; display: grid; place-items: center; background: var(--gold); color: var(--paper); font-family: var(--serif); font-size: .78rem; font-weight: 600; border-radius: 50%; }
.mapitem__thumb { width: 46px; height: 46px; flex-shrink: 0; background-size: cover; background-position: center; background-color: var(--paper-3); border-radius: 3px; }
.mapitem__txt { min-width: 0; flex: 1; }
.mapitem__name { display: block; font-family: var(--serif); font-size: 1.05rem; line-height: 1.1; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mapitem__cat { display: block; font-size: .72rem; color: var(--ink-mute); margin-top: .12rem; }
.mapitem__cat em { color: var(--terracotta); font-style: normal; }
.mapside__empty { padding: 2.5rem 1rem; text-align: center; color: var(--ink-mute); font-style: italic; font-family: var(--serif); }
.mapside__foot { padding: .9rem 1.2rem; border-top: 1px solid var(--line); }
.mapside__foot a { font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-mute); transition: color .2s; }
.mapside__foot a:hover { color: var(--gold); }

@media (max-width: 760px) {
  .mapside { width: auto; left: 0; right: 0; bottom: auto; height: 46vh; border-right: none; border-bottom: 1px solid var(--line); }
  #map { left: 0; top: 46vh; }
  .mapside__city { font-size: 1.25rem; }
}

.mapbar { position: fixed; top: 1rem; left: 1rem; right: 1rem; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; pointer-events: none; }
.mapbar__left, .mapbar__right { display: flex; align-items: center; gap: .6rem; pointer-events: auto; }
.mapchip { display: inline-flex; align-items: center; gap: .6rem; background: rgba(244,237,224,.96);
  border: 1px solid var(--line); padding: .6rem 1rem; box-shadow: 0 6px 24px rgba(0,0,0,.14);
  backdrop-filter: blur(6px); transition: all .2s; }
.mapchip--btn:hover { border-color: var(--gold); color: var(--gold); }
.mapchip__brand { font-family: var(--serif); font-weight: 600; }
.mapchip__brand em { font-style: italic; color: var(--gold); }
.mapchip__title { font-family: var(--serif); font-size: 1.05rem; line-height: 1; }
.mapchip__count { font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-mute); }
.mapchip svg { width: 17px; height: 17px; }

/* pino teardrop dourado */
.mappin { width: 34px; height: 44px; position: relative; cursor: pointer; transition: transform .2s var(--ease); }
.mappin:hover { transform: translateY(-3px) scale(1.06); }
.mappin::before { content: ''; position: absolute; left: 50%; top: 2px; width: 30px; height: 30px;
  background: var(--gold); border: 2px solid var(--paper); border-radius: 50% 50% 50% 0;
  transform: translateX(-50%) rotate(-45deg); box-shadow: 0 5px 14px rgba(0,0,0,.4); }
.mappin span { position: absolute; left: 50%; top: 15px; transform: translate(-50%, -50%);
  color: var(--paper); font-family: var(--serif); font-weight: 600; font-size: .85rem; z-index: 2; }
.mappin--soon::before { background: var(--ink-mute); }

/* popup como card */
.mappop .leaflet-popup-content-wrapper { padding: 0; border-radius: 0; overflow: hidden; box-shadow: 0 12px 44px rgba(0,0,0,.28); }
.mappop .leaflet-popup-content { margin: 0; width: 260px !important; }
.mappop .leaflet-popup-tip { background: var(--paper); }
.mappop .leaflet-popup-close-button { color: var(--paper); right: 8px; top: 8px; font-size: 20px; z-index: 3; }
.mappop__media { height: 132px; background-size: cover; background-position: center; background-color: var(--paper-3); }
.mappop__body { padding: .9rem 1.1rem 1.1rem; }
.mappop__cat { font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); }
.mappop__title { font-family: var(--serif); font-size: 1.35rem; margin: .25rem 0 .35rem; line-height: 1.08; }
.mappop__desc { font-size: .82rem; color: var(--ink-mute); margin-bottom: .85rem; line-height: 1.45; }
.mappop__btn { display: inline-block; background: var(--ink); color: var(--paper); padding: .6rem 1rem;
  font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; transition: background .2s; }
.mappop__btn:hover { background: var(--gold); }

/* botão flutuante "explorar no mapa" na página da cidade */
.map-cta { display: inline-flex; align-items: center; gap: .6rem; }
.map-cta svg { width: 18px; height: 18px; }

@media (max-width: 600px) {
  .mapchip__title { display: none; }
  .mappop .leaflet-popup-content { width: 220px !important; }
}

/* ===== MapLibre (mapa 3D) ===== */
.maplibregl-map { font-family: var(--sans); }
.mappop.maplibregl-popup .maplibregl-popup-content { padding: 0; border-radius: 0; overflow: hidden;
  box-shadow: 0 12px 44px rgba(0,0,0,.28); width: 260px; }
.mappop .maplibregl-popup-tip { border-top-color: var(--paper) !important; border-bottom-color: var(--paper) !important; }
.mappop .maplibregl-popup-close-button { color: var(--paper); right: 6px; top: 4px; font-size: 20px; z-index: 3; padding: 0 7px; }

.mapctrls { position: fixed; left: 1rem; bottom: 1rem; z-index: 1000; display: flex; flex-direction: column; gap: .6rem; align-items: flex-start; }
.mapstyle { display: flex; background: rgba(244,237,224,.96); border: 1px solid var(--line);
  box-shadow: 0 6px 24px rgba(0,0,0,.14); backdrop-filter: blur(6px); overflow: hidden; }
.mapstyle button { padding: .55rem .85rem; font-size: .75rem; letter-spacing: .04em; color: var(--ink-mute);
  border-right: 1px solid var(--line); transition: all .2s; }
.mapstyle button:last-child { border-right: none; }
.mapstyle button:hover { color: var(--ink); background: var(--paper-2); }
.mapstyle button.is-active { background: var(--gold); color: var(--paper); }
.mapctrls__btn { display: inline-flex; align-items: center; gap: .5rem; font-size: .78rem; }
.mapctrls__btn.is-on { background: var(--gold); border-color: var(--gold); color: var(--paper); }
.mapctrls__hint { font-size: .72rem; color: var(--ink-mute); max-width: 240px; line-height: 1.35; }
.maplibregl-ctrl-group { border: 1px solid var(--line) !important; box-shadow: 0 6px 24px rgba(0,0,0,.14) !important; }
.maplibregl-ctrl-attrib { font-size: .65rem; }

@media (max-width: 600px) {
  .mapctrls__hint { display: none; }
  .mapstyle button { padding: .5rem .6rem; font-size: .7rem; }
}
