/*
 * Villa Pojana — stile della pagina "Visita"
 * ------------------------------------------------------------------
 * Stili specifici di page-visita.php (caricati solo su questa pagina):
 * tabella orari, card biglietti, "come arrivare"/accessibilità,
 * servizi, visite guidate, FAQ.
 *
 * Variabili, reset, header/topbar, navigazione, .section base,
 * fascia di stato (.status-*) e newsletter/footer sono in main.css.
 * L'intestazione "page-hero" è in page-hero.css.
 */

/* TABELLA ORARI */
.hours-wrap { background: var(--paper); border: 1px solid var(--line); }
.hours-table { width: 100%; border-collapse: collapse; }
.hours-table th {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--stone);
  font-weight: 600; padding: 18px 28px; text-align: left;
  border-bottom: 1px solid var(--line); background: var(--bone);
}
.hours-table td { padding: 20px 28px; font-size: 15px; border-bottom: 1px solid var(--line); vertical-align: top; }
.hours-table tr:last-child td { border-bottom: none; }
.hours-table tr:hover td { background: var(--bone); }
.hours-season { font-family: var(--font-display); font-size: 17px; font-weight: 400; font-variation-settings: 'opsz' 24, 'SOFT' 30; }
.hours-note { font-size: 13px; color: var(--stone); margin-top: 6px; }
.hours-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600;
  padding: 4px 10px; border-radius: 1px;
}
.hours-badge.open { background: rgba(138,194,62,0.12); color: #4A7A10; }
.hours-badge.reduced { background: rgba(178,62,28,0.1); color: var(--terracotta-deep); }
.hours-badge.hours-closed { background: rgba(140,133,122,0.1); color: var(--stone); }
.hours-footer {
  padding: 18px 28px; font-size: 13px; color: var(--stone);
  border-top: 1px solid var(--line); display: flex; gap: 32px;
}
.hours-footer span::before { content: '— '; }

/* CARD BIGLIETTI */
.ticket-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.ticket-card {
  background: var(--paper); padding: 40px 32px 36px;
  display: flex; flex-direction: column; gap: 12px; position: relative;
  transition: background 0.3s;
}
.ticket-card:hover { background: var(--bone-soft); }
.ticket-card.featured { background: var(--ink); color: var(--paper); }
.ticket-card.featured:hover { background: var(--ink-soft); }
.ticket-price {
  font-family: var(--font-display); font-size: 56px; font-weight: 300; line-height: 1;
  letter-spacing: -0.03em; font-variation-settings: 'opsz' 60, 'SOFT' 30;
}
.ticket-currency { font-size: 28px; vertical-align: super; font-variation-settings: 'opsz' 36, 'SOFT' 30; }
.ticket-label { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 600; color: var(--stone); margin-bottom: 4px; }
.ticket-card.featured .ticket-label { color: var(--stone-light); }
.ticket-name { font-family: var(--font-display); font-size: 24px; font-weight: 400; font-variation-settings: 'opsz' 30, 'SOFT' 30; }
.ticket-desc { font-size: 13px; color: var(--ink-soft); line-height: 1.6; flex-grow: 1; margin-top: 6px; }
.ticket-card.featured .ticket-desc { color: var(--stone-light); }
.ticket-free { font-family: var(--font-display); font-size: 44px; font-weight: 300; letter-spacing: -0.02em; color: var(--terracotta); font-variation-settings: 'opsz' 60, 'SOFT' 100; font-style: italic; }
.ticket-note { font-size: 12px; color: var(--stone); margin-top: 4px; }
.ticket-card.featured .ticket-note { color: var(--stone-light); }
.ticket-info {
  margin-top: 24px; padding: 20px 28px; background: var(--bone-soft);
  border: 1px solid var(--line); font-size: 14px; color: var(--ink-soft);
  display: flex; align-items: center; gap: 16px;
}
.ticket-info::before { content: '→'; color: var(--terracotta); font-size: 16px; flex-shrink: 0; }

/* COME ARRIVARE */
.arrive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.arrive-card {
  background: var(--paper); border: 1px solid var(--line);
  padding: 40px 36px; display: flex; flex-direction: column; gap: 18px;
  transition: border-color 0.3s;
}
.arrive-card:hover { border-color: var(--ink); }
.arrive-icon { width: 56px; height: 56px; }
.arrive-title { font-family: var(--font-display); font-size: 26px; font-weight: 400; font-variation-settings: 'opsz' 36, 'SOFT' 30; }
.arrive-body { font-size: 14px; color: var(--ink-soft); line-height: 1.7; }
.arrive-detail { font-size: 12px; color: var(--terracotta); font-weight: 600; letter-spacing: 0.06em; margin-top: auto; padding-top: 16px; border-top: 1px solid var(--line); }
.arrive-address {
  font-size: 17px; color: var(--stone); margin-bottom: 40px;
  font-family: var(--font-display); font-style: italic;
  font-variation-settings: 'opsz' 24, 'SOFT' 50;
}
.arrive-address a { color: var(--terracotta); border-bottom: 1px solid currentColor; }

/* ACCESSIBILITÀ */
.access-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.access-card { background: var(--paper); border: 1px solid var(--line); padding: 44px 40px; }
.access-card h3 {
  font-family: var(--font-display); font-size: 28px; font-weight: 400;
  margin-bottom: 18px; font-variation-settings: 'opsz' 36, 'SOFT' 30;
}
.access-card p { font-size: 14px; color: var(--ink-soft); line-height: 1.75; margin-bottom: 16px; }
.access-card ul { list-style: none; display: flex; flex-direction: column; gap: 8px; font-size: 13px; color: var(--stone); }
.access-note { margin-top: 20px; font-size: 13px; color: var(--stone); }
.access-note a { color: var(--terracotta); }

/* SERVIZI */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.service-item { background: var(--paper); padding: 32px 28px; display: flex; gap: 18px; align-items: flex-start; }
.service-icon { width: 40px; height: 40px; flex-shrink: 0; margin-top: 4px; }
.service-name { font-family: var(--font-display); font-size: 20px; font-weight: 400; margin-bottom: 6px; font-variation-settings: 'opsz' 24, 'SOFT' 30; }
.service-desc { font-size: 13px; color: var(--ink-soft); line-height: 1.6; }

/* VISITE GUIDATE */
.tour-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.tour-card {
  border: 1px solid var(--line); padding: 40px 32px;
  display: flex; flex-direction: column; gap: 16px;
  position: relative; transition: border-color 0.3s, background 0.3s;
}
.tour-card:hover { border-color: var(--ink); background: var(--paper); }
.tour-num {
  font-family: var(--font-display); font-size: 13px; color: var(--stone);
  font-style: italic; font-variation-settings: 'opsz' 24, 'SOFT' 100;
}
.tour-name { font-family: var(--font-display); font-size: 30px; font-weight: 400; line-height: 1.1; font-variation-settings: 'opsz' 36, 'SOFT' 30; }
.tour-name em { font-style: italic; color: var(--terracotta); font-variation-settings: 'opsz' 36, 'SOFT' 100; }
.tour-desc { font-size: 14px; color: var(--ink-soft); line-height: 1.65; flex-grow: 1; }
.tour-meta { display: flex; gap: 20px; font-size: 12px; color: var(--stone); font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; padding-top: 16px; border-top: 1px solid var(--line); }
.tour-price { color: var(--terracotta); }

/* FAQ */
.faq-section { padding-bottom: 120px; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-question {
  width: 100%; padding: 24px 0; display: flex; justify-content: space-between; align-items: center;
  font-size: 16px; font-weight: 500; text-align: left; gap: 24px; cursor: pointer;
  transition: color 0.2s;
}
.faq-question:hover { color: var(--terracotta); }
.faq-toggle { font-size: 20px; color: var(--stone); flex-shrink: 0; transition: transform 0.3s, color 0.2s; }
.faq-item.open .faq-toggle { transform: rotate(45deg); color: var(--terracotta); }
.faq-answer { font-size: 14px; color: var(--ink-soft); line-height: 1.7; padding-bottom: 24px; display: none; max-width: 720px; }
.faq-item.open .faq-answer { display: block; }
.faq-answer a { color: var(--terracotta); }

/* RESPONSIVE */
@media (max-width: 1100px) {
  .arrive-grid, .tour-grid, .services-grid, .access-grid { grid-template-columns: 1fr 1fr; }
  .ticket-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .arrive-grid, .tour-grid, .ticket-grid, .services-grid, .access-grid { grid-template-columns: 1fr; }
  .hours-footer { flex-direction: column; gap: 8px; }
}
