/* ============================================================
   VENTO GARDA — Wind Machine Theme
   Tutto lo stile in un posto solo
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ============================================================
   VARIABILI
   ============================================================ */
:root {
  --bg:       #e8e4dc;
  --card:     #f2f0eb;
  --border:   #d8d4cc;
  --border-l: #ede9e0;
  --text:     #0a2540;
  --muted:    #7a7060;
  --faint:    #a09880;
  --accent:   #0a2540;
  --red:      #e63c1e;
  --radius:   4px;

  /* Font */
  --font-body: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ============================================================
   BASE
   ============================================================ */
html, body {
  min-height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
}

/* ============================================================
   HEADER
   ============================================================ */
header {
  padding: 1.5rem 0 .8rem;
  border-bottom: 2px solid var(--text);
  margin-bottom: 1.2rem;
  width: 100%;
  box-sizing: border-box;
}

header h1 {
  font-family: var(--font-body);
  font-size: clamp(1.4rem, 9.5vw, 3.4rem);
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1;
  margin-bottom: .55rem;
  text-align: center;
}

header h1 span {
  color: var(--red);
}

.header-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.header-sub-block {
  display: flex;
  flex-direction: column;
  gap: .15rem;
}

.header-sub {
  font-size: .6rem;
  font-weight: 600;
  color: var(--text);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.header-coords {
  font-size: .55rem;
  font-weight: 400;
  color: var(--muted);
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}



/* ============================================================
   TAB LOCALITÀ
   ============================================================ */
.loc-tabs {
  display: flex;
  gap: 0;
  flex-shrink: 0;
}

.loc-tab {
  font-family: var(--font-body);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .32rem 1.1rem;
  text-decoration: none;
  color: var(--text);
  background: none;
  border: 1.5px solid var(--text);
  cursor: pointer;
  transition: all .15s;
}

.loc-tab:first-child { border-radius: 0; }
.loc-tab:last-child  { border-radius: 0; border-left: none; }

.loc-tab.attiva {
  background: var(--text);
  color: var(--bg);
}

.loc-tab:not(.attiva) {
  color: #0a254060;
}

/* ============================================================
   LAYOUT MAIN
   ============================================================ */
.page-container {
  max-width: 700px;
  margin: 0 auto;
  background: var(--card);
  padding: 0 1.2rem 3rem;
}

@media (max-width: 420px) {
  .page-container {
    padding: 0 .75rem 3rem;
  }
  header {
    padding: 1rem 0 .6rem;
  }
  .header-location {
    display: none;
  }
  .header-meta {
    align-items: flex-start;
  }
}

main {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* ============================================================
   CARD
   ============================================================ */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  overflow: hidden;
  opacity: 0;
  transform: translateY(12px);
  animation: rise .4s ease forwards;
}

.card:nth-child(1) { animation-delay: .05s; }
.card:nth-child(2) { animation-delay: .15s; }
.card:nth-child(3) { animation-delay: .25s; }
.card:nth-child(4) { animation-delay: .35s; }
.card:nth-child(5) { animation-delay: .45s; }
.card:nth-child(6) { animation-delay: .55s; }

.card.card--red { border-left-color: var(--red); }

@keyframes rise { to { opacity: 1; transform: none; } }

/* Card header */
.card-header {
  padding: .55rem .9rem;
  display: flex;
  align-items: center;
  gap: .6rem;
  border-bottom: 1px solid var(--border-l);
}

.card-header--split {
  justify-content: space-between;
}

.card-header .label {
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
}

.card--red .card-header .label {
  color: var(--red);
}

.card-header .sub {
  font-size: .58rem;
  color: var(--faint);
  font-weight: 400;
  letter-spacing: .07em;
  text-transform: uppercase;
  margin-top: 1px;
}

/* Card body */
.card-body {
  padding: .7rem .9rem;
  background: #faf9f6;
}

/* Card footer */
.card-footer {
  padding: .35rem .9rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--border-l);
}

.card-footer span {
  font-size: .58rem;
  color: var(--faint);
  font-weight: 400;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* ============================================================
   IMMAGINI
   ============================================================ */
.img-wrap {
  width: 100%;
  background: #f2f0eb;
  min-height: 80px;
}

.img-wrap img {
  display: block;
  width: 100%;
  height: auto;
}

.img-scroll {
  overflow-x: scroll;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
  display: block;
}

/* ============================================================
   GRAFICO VENTO
   ============================================================ */
#grafico-vento-wrap {
  background: white;
  height: 450px;
}

#grafico-vento-wrap canvas {
  background: white;
}

/* ============================================================
   LEGENDA SPOTS
   ============================================================ */
.legenda-spots {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem 1rem;
  padding: .5rem .9rem;
  border-bottom: 1px solid var(--border-l);
}

.legenda-spots span {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .65rem;
  color: var(--muted);
  font-weight: 400;
}

.dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ============================================================
   PULSANTI MINIMAL (Orario/Giornaliero/Mappa)
   ============================================================ */
.btn-minimal {
  font-size: .65rem;
  font-family: var(--font-body);
  padding: 0;
  border: none;
  cursor: pointer;
  background: none;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--faint);
}

.btn-minimal.attivo {
  color: var(--red);
}

.btn-minimal--red {
  color: var(--red);
}

.btn-minimal-group {
  display: flex;
  gap: 12px;
}

.btn-minimal .chevron {
  display: inline-block;
  width: 10px;
  height: 7px;
  margin-left: 3px;
  vertical-align: middle;
}

/* ============================================================
   TIMELINE METEO (scroll wrapper)
   ============================================================ */
.timeline-wrap {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  padding: .4rem .6rem;
  background: #faf9f6;
}

/* ============================================================
   MAPPA FISARMONICA
   ============================================================ */
.mappa-layout {
  display: flex;
  gap: 0;
}

.legenda-mappa-col {
  flex-direction: column;
  gap: .5rem;
  padding: .6rem .9rem;
  min-width: 150px;
  border-bottom: none;
  border-right: 1px solid var(--border-l);
}

/* ============================================================
   PULSANTE APRI
   ============================================================ */
.btn-open {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .62rem;
  font-family: var(--font-body);
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text);
  background: none;
  border: 1.5px solid var(--border);
  border-radius: 0;
  padding: .2rem .6rem;
  text-decoration: none;
}

/* Card disclaimer */
.card-disclaimer {
  padding: .4rem .9rem;
  font-size: .6rem;
  color: var(--muted);
  letter-spacing: .04em;
  border-top: 1px solid var(--border-l);
  font-style: italic;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  text-align: center;
  padding: 1.2rem 0 2rem;
  font-size: .58rem;
  color: var(--faint);
  font-weight: 400;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

footer a {
  color: var(--text);
  text-decoration: none;
}

.footer-disclaimer {
  color: var(--muted);
  text-transform: none;
  letter-spacing: .02em;
  line-height: 1.5;
  font-style: italic;
}

.footer-sources {
  color: var(--faint);
}

.footer-links {
  color: var(--faint);
}

/* ============================================================
   PRIVACY PAGE
   ============================================================ */
.privacy-main {
  padding-top: .5rem;
}

.privacy-body {
  display: flex;
  flex-direction: column;
  gap: .8rem;
}

.privacy-body h2 {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: .4rem;
}

.privacy-body p {
  font-size: .82rem;
  color: var(--text);
  line-height: 1.6;
  letter-spacing: .01em;
}

.privacy-body a {
  color: var(--accent);
  text-decoration: underline;
}

.privacy-updated {
  color: var(--muted) !important;
  font-size: .65rem !important;
  margin-top: .5rem;
}
