/* ====================================================================
   DESIGN SYSTEM — extraído fielmente do "Catálogo Italia" (Italy's Wine)
   Paleta, tipografia e cores de seção absorvidas das páginas do PDF.
   ==================================================================== */
:root{
  /* Neutros do catálogo */
  --cream:        #F6EFD6;   /* fundo creme das páginas de Brancos */
  --paper:        #FBF7EC;   /* superfície dos cards (tom marfim mais claro) */
  --ink:          #2B2724;   /* texto principal */
  --ink-soft:     #6f675e;   /* texto secundário */
  --line:         #e4dcc4;   /* linhas/divisórias finas */
  --gold:         #B8893B;   /* dourado da marca / borda do preço */
  --gold-deep:    #9c6f28;

  /* Cores de SEÇÃO (uma por categoria, como os divisores do PDF) */
  --c-brancos:    #C9A24B;
  --c-espumantes: #D7A521;
  --c-frisantes:  #C6A86A;
  --c-moscatos:   #C3C73C;
  --c-proseccos:  #A8915C;
  --c-roses:      #D56A78;
  --c-tintos:     #6B1F38;

  --shadow:       0 1px 2px rgba(43,39,36,.05);
  --shadow-lift:  0 18px 40px -18px rgba(43,39,36,.45);
  --ease:         cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',sans-serif;
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- INTRO (vídeo da logo) ---------- */
body.intro-lock{overflow:hidden}
.intro{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:#ffffff;                 /* mesmo branco do vídeo — sem emenda */
  opacity:1;visibility:visible;
  transition:opacity .75s var(--ease),visibility .75s var(--ease);
}
.intro.is-out{opacity:0;visibility:hidden;pointer-events:none}
.intro__video{
  width:min(86vw,560px);height:auto;
  filter:drop-shadow(0 20px 50px rgba(43,39,36,.12));
}
.intro__skip{
  position:absolute;bottom:6vh;right:6vw;
  font-family:'Jost',sans-serif;font-weight:400;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:#b9a36a;background:transparent;border:none;cursor:pointer;
  padding:.5rem .25rem;transition:color .3s var(--ease),letter-spacing .3s var(--ease);
}
.intro__skip:hover{color:#8a7430;letter-spacing:.24em}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  /* Gradiente fiel à capa: bordô profundo → carmim → dourado/pêssego */
  background:linear-gradient(118deg,#2b0e1b 0%,#5d152f 30%,#b51c4b 58%,#e7a972 100%);
  color:#fff;
  padding:clamp(3rem,8vw,6.5rem) 1.5rem clamp(3.5rem,9vw,7rem);
  text-align:center;
  overflow:hidden;
}
.hero::after{ /* leve textura de brilho diagonal */
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 80% 110%,rgba(255,225,180,.35),transparent 55%);
  pointer-events:none;
}
.hero__logo{
  position:relative;z-index:1;
  display:block;
  width:min(860px,100%);height:auto;margin:0 auto;
}
.hero__script{
  position:relative;z-index:1;
  font-family:'Pinyon Script',cursive;
  font-size:clamp(1.7rem,5vw,2.4rem);
  color:#f8eccb;margin-top:1.6rem;
}
.hero__tag{
  position:relative;z-index:1;
  max-width:30rem;margin:1.1rem auto 0;
  font-size:clamp(.85rem,2.4vw,1rem);color:#fbeede;font-weight:300;
}
/* faixinha tricolor itália */
.tricolore{display:inline-flex;height:3px;width:62px;border-radius:3px;overflow:hidden;margin:1.6rem auto 0;position:relative;z-index:1;box-shadow:0 0 0 1px rgba(255,255,255,.15)}
.tricolore i{flex:1}
.tricolore i:nth-child(1){background:#0e7a3c}
.tricolore i:nth-child(2){background:#f4f1e8}
.tricolore i:nth-child(3){background:#c4233a}

/* ---------- BARRA DE FILTROS (sticky) ---------- */
.toolbar{
  position:sticky;top:0;z-index:50;
  background:rgba(246,239,214,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  padding:.85rem 1rem;
}
.toolbar__inner{max-width:1240px;margin:0 auto;display:flex;flex-direction:column;gap:.8rem}
.filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.filter{
  font-family:'Jost',sans-serif;font-weight:400;
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);background:transparent;
  border:1px solid var(--line);border-radius:999px;
  padding:.5rem 1.05rem;cursor:pointer;
  transition:all .3s var(--ease);white-space:nowrap;
}
.filter:hover{border-color:var(--gold);color:var(--ink)}
.filter.is-active{
  background:var(--ink);color:#fff;border-color:var(--ink);
}
.filter .count{opacity:.5;margin-left:.45em;font-size:.92em}
.search{position:relative;max-width:420px;width:100%;margin:0 auto}
.search input{
  width:100%;font-family:'Jost',sans-serif;font-weight:300;
  font-size:.9rem;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:.62rem 1.1rem .62rem 2.5rem;outline:none;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.search input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,137,59,.12)}
.search svg{position:absolute;left:.95rem;top:50%;transform:translateY(-50%);width:15px;height:15px;stroke:var(--ink-soft);fill:none;stroke-width:1.4}

/* ---------- SEÇÕES POR CATEGORIA ---------- */
main{max-width:1240px;margin:0 auto;padding:1rem 1.1rem 4rem}
.cat{margin-top:2.6rem;scroll-margin-top:140px}
.cat__divider{
  background:var(--accent,var(--gold));
  border-radius:6px;
  padding:1.1rem 1.5rem;
  margin-bottom:1.8rem;
  color:#fff;
}
.cat__divider small{
  display:block;font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;
  opacity:.85;font-weight:400;
}
.cat__divider h2{
  font-family:'Jost',sans-serif;font-weight:300;
  font-size:clamp(1.8rem,5vw,2.7rem);letter-spacing:.04em;text-transform:uppercase;line-height:1.05;
}
/* divisores claros precisam de texto escuro */
.cat--moscatos .cat__divider{color:#3a3a1e}
.cat--moscatos .cat__divider small{opacity:.7}

/* ---------- GRID ---------- */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:1.4rem;
}

/* ---------- CARD ---------- */
.card{
  position:relative;display:flex;flex-direction:column;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:12px;overflow:hidden;
  box-shadow:var(--shadow);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
  cursor:pointer;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:var(--accent)}
.card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

.card__media{
  position:relative;
  height:230px;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(120% 120% at 50% 0%,#fffdf7,#efe7d0);
  overflow:hidden;
}
/* quando há foto da garrafa (fundo branco), a área inteira fica branca p/ não criar emenda */
.card__media.has-photo{background:#fff}
.card__media img{
  position:relative;z-index:1;
  height:auto;max-height:86%;width:auto;max-width:72%;object-fit:contain;
  filter:drop-shadow(0 14px 22px rgba(43,39,36,.22));
  transition:transform .5s var(--ease);
}
.card:hover .card__media img{transform:scale(1.07)}
/* placeholder quando ainda não há imagem */
.card__ph{
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:#bfb392;text-align:center;padding:1rem;
}
.card__ph svg{width:42px;height:74px;stroke:#cabd98;fill:none;stroke-width:1.3}
.card__ph span{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase}

/* badges sobre a imagem */
.badges{position:absolute;top:.7rem;left:.7rem;z-index:3;display:flex;gap:.35rem;flex-wrap:wrap}
.badge{
  font-size:.56rem;letter-spacing:.13em;text-transform:uppercase;font-weight:500;
  padding:.28rem .55rem;border-radius:4px;line-height:1;
}
.badge--tier{background:#e7d6a8;color:#6a5118}
.badge--horeca{background:#f0d4dc;color:#9a3550}
.code{
  position:absolute;top:.7rem;right:.8rem;z-index:3;
  font-size:.6rem;letter-spacing:.1em;color:var(--ink-soft);
  background:rgba(255,255,255,.7);padding:.2rem .45rem;border-radius:4px;
}

.card__body{padding:1.15rem 1.25rem 1.3rem;display:flex;flex-direction:column;flex:1}
.card__type{display:flex;align-items:center;gap:.5rem;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.55rem}
.flag{display:inline-flex;width:18px;height:12px;border-radius:2px;overflow:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.06);flex:0 0 auto}
.flag i{flex:1}
.flag--it i:nth-child(1){background:#0e7a3c}.flag--it i:nth-child(2){background:#f4f1e8}.flag--it i:nth-child(3){background:#c4233a}
.flag--es i:nth-child(1){background:#c60b1e}.flag--es i:nth-child(2){background:#ffc400;flex:1.6}.flag--es i:nth-child(3){background:#c60b1e}

.card__name{
  font-family:'Cormorant Garamond',serif;font-weight:600;
  font-size:1.28rem;line-height:1.15;letter-spacing:.01em;color:var(--ink);
  margin-bottom:.5rem;
}
.card__desc{
  font-size:.82rem;color:var(--ink-soft);font-weight:300;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;
  margin-bottom:.9rem;
}

/* Características — réplica do bloco do PDF (linhas finas, sem ícones genéricos) */
.specs{
  display:grid;grid-template-columns:1fr 1fr;gap:.55rem .9rem;
  border-top:1px solid var(--line);padding-top:.85rem;margin-top:auto;
}
.spec{display:flex;gap:.45rem;align-items:flex-start}
.spec svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:1.3;flex:0 0 auto;margin-top:1px}
.spec div{min-width:0}
.spec dt{font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.spec dd{font-size:.72rem;color:var(--ink);line-height:1.3}

.card__foot{
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  margin-top:1.05rem;padding-top:.95rem;border-top:1px solid var(--line);
}
.price{
  font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.35rem;
  color:var(--ink);
  border:1.5px solid var(--accent);border-radius:999px;
  padding:.3rem 1rem;white-space:nowrap;
}
.cta{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  color:var(--accent);transition:gap .3s var(--ease);
}
.card:hover .cta{gap:.7rem}
.cta svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.6}

/* nenhum resultado */
.empty{text-align:center;color:var(--ink-soft);padding:4rem 1rem;font-size:1rem;display:none}
.empty.is-on{display:block}

/* ---------- MAPA INTERATIVO DA ITÁLIA ---------- */
.explore{position:relative;max-width:1100px;margin:0 auto;padding:3.2rem 1.2rem 2rem;border-radius:18px;overflow:hidden}
/* camada de paisagem da região (entra/sai com crossfade) */
.explore__bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity .9s var(--ease);
  transform:scale(1.04);
}
.explore.has-bg .explore__bg{opacity:1;animation:kenburns 16s ease-out forwards}
.explore__bg::after{ /* véu creme (leve) + vinheta nas bordas — paisagem protagonista, mas legível */
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(125% 95% at 50% 42%, transparent 38%, rgba(43,14,27,.26) 100%),
    linear-gradient(180deg,rgba(246,239,214,.60) 0%,rgba(246,239,214,.34) 46%,rgba(246,239,214,.72) 100%);
}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.13)}}
/* conteúdo acima da paisagem */
.explore__head,.explore__stage{position:relative;z-index:1}
.explore__head{position:relative;text-align:center;max-width:46rem;margin:0 auto 2rem;min-height:150px}
.explore__head small{display:block;font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);font-weight:500}
.explore__head h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:clamp(1.9rem,5vw,2.9rem);color:var(--ink);margin:.25rem 0 .5rem}
.explore__head p{font-weight:300;color:var(--ink-soft);font-size:clamp(.9rem,2.4vw,1rem)}

/* crossfade entre o título padrão e a legenda da região */
.explore__titles{transition:opacity .5s var(--ease)}
.explore__caption{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .6s var(--ease);
}
.explore.has-bg .explore__titles{opacity:0}
.explore.has-bg .explore__caption{opacity:1}
.explore__caption h2{
  font-size:clamp(2.6rem,8vw,4.4rem);line-height:1;letter-spacing:.015em;margin:.15rem 0 0;
  text-shadow:0 2px 18px rgba(246,239,214,.9);
}
.explore__rule{display:block;width:64px;height:2px;background:var(--gold);margin:.85rem auto .55rem;border-radius:2px}
.explore__caption p{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}

.explore__stage{
  display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:2rem;align-items:center;
}
.italy{display:flex;justify-content:center}
.italy svg{width:100%;max-width:400px;height:auto;overflow:visible;transition:filter .6s var(--ease)}
/* com a paisagem ao fundo, o mapa ganha sombra para "flutuar" */
.explore.has-bg .italy svg{filter:drop-shadow(0 10px 26px rgba(43,14,27,.45))}
.explore.has-bg .region{stroke:rgba(255,255,255,.85);stroke-width:1}
.region{
  fill:#eadfc0;stroke:#fbf7ec;stroke-width:.8;
  transition:fill .25s var(--ease),transform .25s var(--ease),filter .25s var(--ease);
  transform-box:fill-box;transform-origin:center;
}
.region.has-wines{fill:#d8b25a;cursor:pointer}
.region.has-wines:hover{fill:var(--c-tintos);filter:drop-shadow(0 6px 12px rgba(0,0,0,.25))}
.region.is-selected{fill:var(--c-tintos)}
.region.is-dim{opacity:.45}

/* painel lateral com o resumo da região */
.explore__panel{
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:1.6rem 1.5rem;min-height:230px;
  display:flex;flex-direction:column;justify-content:center;box-shadow:var(--shadow);
}
.rp__hint{color:var(--ink-soft);font-weight:300;font-size:.92rem;text-align:center}
.rp__region{font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:500}
.rp__name{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.9rem;line-height:1.05;color:var(--ink);margin:.15rem 0 .4rem}
.rp__count{font-size:.85rem;color:var(--ink-soft);font-weight:300}
.rp__list{list-style:none;margin:.9rem 0 1.1rem;padding:.9rem 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:.5rem;max-height:190px;overflow:auto}
.rp__item{display:flex;justify-content:space-between;gap:.8rem;font-size:.8rem}
.rp__item b{font-weight:500;color:var(--ink)}
.rp__item span{color:var(--gold);white-space:nowrap;font-family:'Cormorant Garamond',serif;font-size:1rem}
.rp__btn{
  align-self:flex-start;border:1.5px solid var(--c-tintos);color:var(--c-tintos);background:transparent;
  border-radius:999px;padding:.55rem 1.2rem;font-family:'Jost',sans-serif;font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s var(--ease);
}
.rp__btn:hover{background:var(--c-tintos);color:#fff}

/* chip da região ativa na barra de filtros */
.region-chip{
  display:none;align-items:center;gap:.5rem;justify-content:center;
  font-size:.72rem;letter-spacing:.08em;color:var(--ink);
}
.region-chip.is-on{display:flex}
.region-chip button{
  border:none;background:var(--c-tintos);color:#fff;border-radius:999px;
  width:18px;height:18px;line-height:1;cursor:pointer;font-size:.8rem;display:grid;place-items:center;
}

/* tooltip flutuante sobre o mapa */
.map-tip{
  position:fixed;z-index:80;pointer-events:none;
  background:var(--ink);color:#fff;font-size:.72rem;letter-spacing:.04em;
  padding:.4rem .7rem;border-radius:6px;transform:translate(-50%,-130%);white-space:nowrap;
  box-shadow:0 6px 16px rgba(0,0,0,.3);
}
.map-tip b{font-weight:500}
.map-tip i{font-style:normal;opacity:.7;margin-left:.35em}

@media (max-width:760px){
  .explore__stage{grid-template-columns:1fr;gap:1.4rem}
  .explore__panel{min-height:0}
  .italy svg{max-width:320px}
}

/* ---------- RODAPÉ ---------- */
.foot{
  background:#2b0e1b;color:#e9d6bd;text-align:center;
  padding:3rem 1.5rem 3.5rem;
}
.foot__script{font-family:'Pinyon Script',cursive;font-size:2rem;color:#f3d9a2}
.foot p{font-weight:300;font-size:.85rem;opacity:.85;margin-top:.5rem}
.foot a.wpp{
  display:inline-flex;align-items:center;gap:.5rem;margin-top:1.4rem;
  border:1px solid #6b4a3a;border-radius:999px;padding:.65rem 1.4rem;
  font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:#f3d9a2;
  transition:all .3s var(--ease);
}
.foot a.wpp:hover{background:#f3d9a2;color:#2b0e1b;border-color:#f3d9a2}
.foot small{display:block;margin-top:1.8rem;font-size:.66rem;opacity:.45;letter-spacing:.08em}

@media (max-width:640px){
  .grid{grid-template-columns:1fr;gap:1.1rem}
  .card__media{height:210px}
}

/* respeita preferências de movimento reduzido */
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto}
}
