/*
Theme Name:   Astra Child
Theme URI:    https://germino.quarantadue.digital
Description:  Child theme di Astra per Exclusive Service - Evento Custom
Author:       Open Dynamics
Author URI:   https://germino.quarantadue.digital
Template:     astra
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  astra-child
*/

/* ══════════════════════════════════════════════════════════════
   DESIGN TOKENS — Exclusive Service
══════════════════════════════════════════════════════════════ */
:root {
  --es-gold:       #C9A96E;
  --es-gold-light: #E8D5A8;
  --es-gold-dark:  #9A7340;
  --es-black:      #000000;
  --es-dark:       #1A1A1A;
  --es-charcoal:   #2C2C2C;
  --es-white:      #FAFAF7;
  --es-grey:       #F0EEE8;
  --es-grey-mid:   #9E9E8E;
  --es-text:       #2C2C2C;
  --es-radius:     6px;
  --es-shadow:     0 8px 40px rgba(0,0,0,.14);
  --es-shadow-lg:  0 20px 80px rgba(0,0,0,.20);
  --es-transition: .3s cubic-bezier(.4,0,.2,1);
  --es-font-serif: 'Playfair Display', Georgia, serif;
  --es-font-sans:  'Inter', 'Segoe UI', Arial, sans-serif;
}

/* ══════════════════════════════════════════════════════════════
   GOOGLE FONTS IMPORT
══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@300;400;500;600&display=swap');

/* ══════════════════════════════════════════════════════════════
   BASE RESET & TYPOGRAPHY
══════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--es-font-sans);
  font-size: 16px;
  line-height: 1.75;
  color: var(--es-text);
  background: var(--es-white);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: var(--es-font-serif);
  color: var(--es-dark);
  line-height: 1.25;
  font-weight: 700;
}

h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.8rem); }

a { color: var(--es-gold-dark); text-decoration: none; transition: color var(--es-transition); }
a:hover { color: var(--es-gold); }

p { margin-bottom: 1.25rem; }
img { max-width: 100%; height: auto; display: block; }

/* ══════════════════════════════════════════════════════════════
   HEADER & NAVIGATION
══════════════════════════════════════════════════════════════ */
.site-header,
#masthead,
.ast-site-header-wrap {
  background: var(--es-black) !important;
  border-bottom: 1px solid rgba(201,169,110,.25) !important;
}

.site-header .ast-primary-header-bar {
  background: var(--es-black) !important;
  padding: 0 !important;
}

/* Logo testuale */
.site-branding .site-title a,
.ast-site-name,
#site-title a {
  font-family: var(--es-font-serif) !important;
  font-size: 1.5rem !important;
  color: var(--es-gold) !important;
  letter-spacing: .08em;
  font-weight: 700;
}

.site-branding .site-description,
.ast-site-description {
  color: var(--es-gold-light) !important;
  font-size: .7rem !important;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family: var(--es-font-sans);
}

/* Navigation links */
.ast-primary-nav ul li a,
.main-navigation ul li a,
#ast-hf-menu-1 li a {
  font-family: var(--es-font-sans) !important;
  font-size: .82rem !important;
  font-weight: 500 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: rgba(250,250,247,.85) !important;
  padding: 8px 16px !important;
  transition: color var(--es-transition) !important;
}

.ast-primary-nav ul li a:hover,
.main-navigation ul li a:hover,
#ast-hf-menu-1 li a:hover {
  color: var(--es-gold) !important;
}

/* Dropdown */
.ast-primary-nav ul ul,
.main-navigation ul ul {
  background: var(--es-charcoal) !important;
  border: 1px solid rgba(201,169,110,.2) !important;
  border-radius: var(--es-radius) !important;
  box-shadow: var(--es-shadow) !important;
}

/* ══════════════════════════════════════════════════════════════
   HERO SECTION
══════════════════════════════════════════════════════════════ */
.es-hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background: var(--es-black);
}

.es-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(160deg, rgba(201,169,110,.08) 0%, transparent 60%),
    linear-gradient(to bottom, rgba(13,13,13,.4) 0%, rgba(13,13,13,.72) 100%);
  z-index: 1;
}

.es-hero-bg {
  position: absolute;
  inset: 0;
  background-image: url('https://images.unsplash.com/photo-1519225421980-715cb0215aed?w=1920&q=80');
  background-size: cover;
  background-position: center 40%;
  filter: brightness(.55) saturate(.9);
  transform: scale(1.04);
  transition: transform 8s ease;
}
.es-hero:hover .es-hero-bg { transform: scale(1.0); }

.es-hero-content {
  position: relative;
  z-index: 2;
  max-width: 820px;
  padding: 0 24px;
}

.es-hero-label {
  display: inline-block;
  font-family: var(--es-font-sans);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--es-gold);
  border: 1px solid rgba(201,169,110,.4);
  padding: 7px 20px;
  border-radius: 40px;
  margin-bottom: 28px;
}

.es-hero h1 {
  font-family: var(--es-font-serif) !important;
  color: var(--es-white) !important;
  font-size: clamp(2.4rem, 6vw, 4.5rem) !important;
  line-height: 1.12 !important;
  margin-bottom: 24px;
  text-shadow: 0 2px 24px rgba(0,0,0,.4);
}

.es-hero h1 em {
  font-style: italic;
  color: var(--es-gold);
}

.es-hero p {
  font-size: 1.15rem;
  color: rgba(250,250,247,.82);
  max-width: 560px;
  margin: 0 auto 36px;
  line-height: 1.7;
}

.es-btn {
  display: inline-block;
  padding: 15px 36px;
  background: var(--es-gold);
  color: var(--es-black) !important;
  font-family: var(--es-font-sans);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-radius: var(--es-radius);
  border: 2px solid var(--es-gold);
  cursor: pointer;
  transition: all var(--es-transition);
  text-decoration: none !important;
}
.es-btn:hover {
  background: transparent;
  color: var(--es-gold) !important;
}

.es-btn-outline {
  display: inline-block;
  padding: 13px 34px;
  background: transparent;
  color: var(--es-white) !important;
  font-family: var(--es-font-sans);
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  border-radius: var(--es-radius);
  border: 2px solid rgba(250,250,247,.5);
  cursor: pointer;
  transition: all var(--es-transition);
  margin-left: 14px;
  text-decoration: none !important;
}
.es-btn-outline:hover {
  border-color: var(--es-gold);
  color: var(--es-gold) !important;
}

.es-hero-scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(250,250,247,.5);
  font-size: .68rem;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.es-hero-scroll::after {
  content: '';
  width: 1px;
  height: 42px;
  background: linear-gradient(to bottom, rgba(201,169,110,.6), transparent);
  animation: scrollPulse 2s ease infinite;
}
@keyframes scrollPulse { 0%,100%{opacity:.4;transform:scaleY(1)} 50%{opacity:1;transform:scaleY(1.15)} }

/* ══════════════════════════════════════════════════════════════
   SECTION UTILITIES
══════════════════════════════════════════════════════════════ */
.es-section {
  padding: 96px 0;
}

.es-section-sm { padding: 64px 0; }

.es-container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
}

.es-section-label {
  display: inline-block;
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--es-gold);
  margin-bottom: 12px;
}

.es-section-title {
  font-family: var(--es-font-serif) !important;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem) !important;
  color: var(--es-dark) !important;
  margin-bottom: 16px !important;
}

.es-section-subtitle {
  font-size: 1.05rem;
  color: var(--es-grey-mid);
  max-width: 580px;
  line-height: 1.7;
}

.es-divider {
  width: 56px;
  height: 2px;
  background: var(--es-gold);
  margin: 20px 0 36px;
}

.es-divider.center { margin: 20px auto 36px; }

/* ══════════════════════════════════════════════════════════════
   SERVICES GRID
══════════════════════════════════════════════════════════════ */
.es-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 28px;
  margin-top: 56px;
}

.es-service-card {
  background: var(--es-white);
  border: 1px solid #E8E4D8;
  border-radius: 10px;
  padding: 36px 32px;
  transition: all var(--es-transition);
  position: relative;
  overflow: hidden;
}
.es-service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--es-gold), var(--es-gold-light));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--es-transition);
}
.es-service-card:hover { box-shadow: var(--es-shadow); transform: translateY(-4px); }
.es-service-card:hover::before { transform: scaleX(1); }

.es-service-icon {
  font-size: 2.2rem;
  margin-bottom: 20px;
  display: block;
}

.es-service-card h3 {
  font-size: 1.25rem !important;
  margin-bottom: 12px !important;
  color: var(--es-dark) !important;
}
.es-service-card p { color: var(--es-grey-mid); font-size: .93rem; margin-bottom: 20px; }

.es-service-price {
  font-family: var(--es-font-serif);
  font-size: 1.5rem;
  color: var(--es-gold-dark);
  font-weight: 700;
}

/* ══════════════════════════════════════════════════════════════
   STATS BAR
══════════════════════════════════════════════════════════════ */
.es-stats {
  background: var(--es-dark);
  padding: 64px 0;
}

.es-stats-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 24px;
  text-align: center;
}

@media(max-width:768px){ .es-stats-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:480px){ .es-stats-grid { grid-template-columns: 1fr; } }

.es-stat-number {
  font-family: var(--es-font-serif);
  font-size: clamp(2.2rem,4vw,3.2rem);
  color: var(--es-gold);
  font-weight: 700;
  line-height: 1;
  display: block;
}
.es-stat-label {
  font-size: .8rem;
  color: rgba(250,250,247,.6);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-top: 8px;
  display: block;
}

/* ══════════════════════════════════════════════════════════════
   ABOUT / SPLIT SECTION
══════════════════════════════════════════════════════════════ */
.es-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
@media(max-width:900px){ .es-split { grid-template-columns:1fr; gap:48px; } }

.es-split-image {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}
.es-split-image img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  border-radius: 10px;
}
.es-split-image::after {
  content: '';
  position: absolute;
  bottom: -16px; right: -16px;
  width: 60%;
  height: 60%;
  border: 2px solid var(--es-gold);
  border-radius: 10px;
  z-index: -1;
}

.es-check-list {
  list-style: none;
  padding: 0;
  margin: 24px 0 32px;
}
.es-check-list li {
  padding: 8px 0 8px 28px;
  position: relative;
  color: var(--es-text);
  font-size: .95rem;
  border-bottom: 1px solid #eee;
}
.es-check-list li:last-child { border-bottom: none; }
.es-check-list li::before {
  content: '✦';
  position: absolute;
  left: 0;
  color: var(--es-gold);
  font-size: .7rem;
  top: 12px;
}

/* ══════════════════════════════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════════════════════════════ */
.es-testimonials {
  background: var(--es-grey);
}

.es-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px,1fr));
  gap: 28px;
  margin-top: 52px;
}

.es-testimonial-card {
  background: var(--es-white);
  border-radius: 10px;
  padding: 32px;
  border: 1px solid #E8E4D8;
  position: relative;
}
.es-testimonial-card::before {
  content: '\201C';
  font-family: var(--es-font-serif);
  font-size: 5rem;
  color: var(--es-gold);
  opacity: .18;
  position: absolute;
  top: 8px; left: 20px;
  line-height: 1;
}

.es-testimonial-text {
  font-size: .95rem;
  color: var(--es-text);
  line-height: 1.7;
  margin-bottom: 20px;
  font-style: italic;
}
.es-testimonial-author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.es-testimonial-avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--es-gold);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--es-font-serif);
  font-size: 1.1rem;
  color: var(--es-black);
  font-weight: 700;
  flex-shrink: 0;
}
.es-testimonial-name { font-weight: 600; font-size: .9rem; color: var(--es-dark); }
.es-testimonial-role { font-size: .78rem; color: var(--es-grey-mid); }

.es-stars { color: var(--es-gold); font-size: .85rem; letter-spacing: 2px; margin-bottom: 12px; }

/* ══════════════════════════════════════════════════════════════
   CTA BAND
══════════════════════════════════════════════════════════════ */
.es-cta-band {
  background: linear-gradient(135deg, var(--es-dark) 0%, var(--es-charcoal) 100%);
  padding: 88px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.es-cta-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('https://images.unsplash.com/photo-1464366400600-7168b8af9bc3?w=1600&q=60') center/cover;
  opacity: .08;
}
.es-cta-band > * { position: relative; }
.es-cta-band h2 {
  font-family: var(--es-font-serif) !important;
  color: var(--es-white) !important;
  font-size: clamp(1.8rem,3.5vw,3rem) !important;
  margin-bottom: 16px !important;
}
.es-cta-band p {
  color: rgba(250,250,247,.75);
  font-size: 1.05rem;
  max-width: 540px;
  margin: 0 auto 36px;
}

/* ══════════════════════════════════════════════════════════════
   GALLERY GRID
══════════════════════════════════════════════════════════════ */
.es-gallery {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  margin-top: 52px;
}
@media(max-width:768px){ .es-gallery { grid-template-columns: repeat(2,1fr); } }
@media(max-width:480px){ .es-gallery { grid-template-columns: 1fr; } }

.es-gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  aspect-ratio: 4/3;
}
.es-gallery-item:nth-child(1) { grid-row: span 2; aspect-ratio: auto; }
.es-gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}
.es-gallery-item:hover img { transform: scale(1.06); }

.es-gallery-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13,13,13,.6), transparent);
  opacity: 0;
  transition: opacity var(--es-transition);
  display: flex;
  align-items: flex-end;
  padding: 20px;
}
.es-gallery-item:hover .es-gallery-overlay { opacity: 1; }
.es-gallery-overlay span {
  color: var(--es-white);
  font-size: .82rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 600;
}

/* ══════════════════════════════════════════════════════════════
   WOOCOMMERCE OVERRIDES
══════════════════════════════════════════════════════════════ */

/* Bottone "Aggiungi al carrello" */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce .button,
.woocommerce-page .button {
  background: var(--es-gold) !important;
  color: var(--es-black) !important;
  font-family: var(--es-font-sans) !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  border-radius: var(--es-radius) !important;
  border: 2px solid var(--es-gold) !important;
  padding: 12px 24px !important;
  transition: all var(--es-transition) !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce .button:hover {
  background: transparent !important;
  color: var(--es-gold-dark) !important;
}

/* Prezzi */
.woocommerce .price,
.woocommerce-page .price {
  font-family: var(--es-font-serif) !important;
  color: var(--es-gold-dark) !important;
  font-size: 1.4rem !important;
  font-weight: 700 !important;
}

/* Product card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  border: 1px solid #E8E4D8 !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  transition: all var(--es-transition) !important;
  background: var(--es-white) !important;
}
.woocommerce ul.products li.product:hover {
  box-shadow: var(--es-shadow) !important;
  transform: translateY(-4px) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--es-font-serif) !important;
  font-size: 1.1rem !important;
  color: var(--es-dark) !important;
  font-weight: 600 !important;
}

/* Shop header */
.woocommerce .woocommerce-products-header__title,
.woocommerce-page h1.page-title {
  font-family: var(--es-font-serif) !important;
  color: var(--es-dark) !important;
}

/* Checkout & Cart inputs */
.woocommerce .input-text,
.woocommerce textarea,
.woocommerce select {
  border: 1px solid #ddd !important;
  border-radius: var(--es-radius) !important;
  padding: 12px 16px !important;
  font-family: var(--es-font-sans) !important;
  transition: border-color var(--es-transition) !important;
}
.woocommerce .input-text:focus,
.woocommerce textarea:focus {
  border-color: var(--es-gold) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(201,169,110,.15) !important;
}

/* Order total */
.woocommerce-cart .cart-collaterals .cart_totals h2,
.woocommerce .order-total .amount {
  color: var(--es-dark) !important;
  font-family: var(--es-font-serif) !important;
}

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
.site-footer,
#colophon,
.ast-site-footer {
  background: var(--es-black) !important;
  color: rgba(250,250,247,.7) !important;
  border-top: 1px solid rgba(201,169,110,.2) !important;
}

.ast-site-footer .ast-footer-logo,
.ast-site-footer .ast-footer-site-title {
  font-family: var(--es-font-serif) !important;
  color: var(--es-gold) !important;
  font-size: 1.4rem !important;
}

.ast-site-footer a {
  color: rgba(250,250,247,.65) !important;
  transition: color var(--es-transition) !important;
}
.ast-site-footer a:hover { color: var(--es-gold) !important; }

/* Footer widget headings */
.ast-site-footer .widget-title,
.ast-site-footer h3 {
  font-family: var(--es-font-sans) !important;
  font-size: .72rem !important;
  letter-spacing: .22em !important;
  text-transform: uppercase !important;
  color: var(--es-gold) !important;
  margin-bottom: 18px !important;
}

.ast-site-footer .ast-footer-copyright {
  color: rgba(250,250,247,.35) !important;
  font-size: .78rem !important;
  border-top: 1px solid rgba(201,169,110,.12) !important;
  padding-top: 20px !important;
}

/* Footer custom — es_footer_widgets() */
.es-footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 48px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 64px 28px 40px;
}

.es-footer-brand-name {
  font-family: var(--es-font-serif);
  font-size: 1.4rem;
  color: var(--es-gold);
  font-weight: 700;
  margin-bottom: 12px;
}

.es-footer-tagline {
  font-size: .85rem;
  color: rgba(250,250,247,.6);
  line-height: 1.7;
  margin-bottom: 20px;
}

.es-footer-cta {
  display: inline-block;
  padding: 10px 22px;
  border: 1px solid rgba(201,169,110,.4);
  color: var(--es-gold);
  border-radius: 4px;
  font-size: .78rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none;
  transition: border-color var(--es-transition), background var(--es-transition);
}
.es-footer-cta:hover {
  border-color: var(--es-gold);
  background: rgba(201,169,110,.08);
  color: var(--es-gold);
}

.es-footer-heading {
  font-family: var(--es-font-sans);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--es-gold);
  font-weight: 600;
  margin: 0 0 18px;
}

.es-footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}
.es-footer-nav li {
  margin-bottom: 8px;
}
.es-footer-nav a {
  color: rgba(250,250,247,.58) !important;
  font-size: .875rem;
  text-decoration: none;
  transition: color var(--es-transition);
}
.es-footer-nav a:hover {
  color: var(--es-gold) !important;
}

.es-footer-info-row {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 14px;
}
.es-footer-info-icon {
  font-size: .95rem;
  flex-shrink: 0;
  line-height: 1.6;
}
.es-footer-info-text {
  font-size: .85rem;
  color: rgba(250,250,247,.6);
  line-height: 1.6;
}

.es-footer-divider {
  border: none;
  border-top: 1px solid rgba(201,169,110,.12);
  margin: 0;
}

/* ══════════════════════════════════════════════════════════════
   PAGE HERO (pagine interne)
══════════════════════════════════════════════════════════════ */
.es-page-hero {
  background: var(--es-dark);
  padding: 100px 0 72px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.es-page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(201,169,110,.08) 0%, transparent 70%);
}
.es-page-hero-label {
  font-size: .68rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--es-gold);
  font-weight: 600;
  display: block;
  margin-bottom: 16px;
}
.es-page-hero h1 {
  font-family: var(--es-font-serif) !important;
  color: var(--es-white) !important;
  font-size: clamp(2rem,4vw,3.2rem) !important;
  margin-bottom: 16px !important;
}
.es-page-hero p {
  color: rgba(250,250,247,.72);
  font-size: 1.05rem;
  max-width: 600px;
  margin: 0 auto;
}

/* ══════════════════════════════════════════════════════════════
   CONTACT FORM
══════════════════════════════════════════════════════════════ */
.es-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 72px;
  align-items: start;
}
@media(max-width:860px){ .es-contact-grid { grid-template-columns:1fr; gap:48px; } }

.es-contact-info h3 {
  font-size: 1.3rem !important;
  margin-bottom: 20px !important;
}
.es-contact-item {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
  align-items: flex-start;
}
.es-contact-icon {
  width: 44px; height: 44px;
  background: rgba(201,169,110,.12);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
  color: var(--es-gold);
}
.es-contact-detail strong { display: block; color: var(--es-dark); font-size: .88rem; }
.es-contact-detail span { color: var(--es-grey-mid); font-size: .88rem; }

.es-form input,
.es-form textarea,
.es-form select {
  width: 100%;
  padding: 13px 16px;
  border: 1px solid #ddd;
  border-radius: var(--es-radius);
  font-family: var(--es-font-sans);
  font-size: .95rem;
  color: var(--es-text);
  background: var(--es-white);
  transition: border-color var(--es-transition), box-shadow var(--es-transition);
  margin-bottom: 16px;
}
.es-form input:focus,
.es-form textarea:focus {
  border-color: var(--es-gold);
  outline: none;
  box-shadow: 0 0 0 3px rgba(201,169,110,.15);
}
.es-form textarea { min-height: 150px; resize: vertical; }
.es-form label { font-size: .82rem; font-weight: 600; color: var(--es-dark); display: block; margin-bottom: 6px; }
.es-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media(max-width:600px){ .es-form-row { grid-template-columns:1fr; } }

/* ══════════════════════════════════════════════════════════════
   BREADCRUMBS
══════════════════════════════════════════════════════════════ */
.ast-breadcrumbs, .breadcrumbs {
  background: var(--es-grey) !important;
  padding: 10px 0 !important;
  font-size: .8rem !important;
  color: var(--es-grey-mid) !important;
}
.ast-breadcrumbs a { color: var(--es-gold-dark) !important; }

/* ══════════════════════════════════════════════════════════════
   UTILITY CLASSES
══════════════════════════════════════════════════════════════ */
.text-center { text-align: center; }
.text-gold { color: var(--es-gold) !important; }
.bg-dark { background: var(--es-dark) !important; color: var(--es-white) !important; }
.bg-grey { background: var(--es-grey) !important; }
.mt-0 { margin-top: 0 !important; }
.mb-0 { margin-bottom: 0 !important; }

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════════════════════════ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
.animate-fade-up { animation: fadeInUp .7s ease both; }
.animate-delay-1 { animation-delay: .1s; }
.animate-delay-2 { animation-delay: .22s; }
.animate-delay-3 { animation-delay: .36s; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media(max-width:768px) {
  .es-section { padding: 64px 0; }
  .es-hero { min-height: 80vh; }
  .es-btn-outline { margin-left: 0; margin-top: 12px; display: block; text-align: center; }
}


/* ══════════════════════════════════════════════════
   EXCLUSIVE SERVICE — Design System
   Palette: Oro (#B8960C), Avorio (#FAF6EE), Antracite (#1C1C1C)
   Accent:  Champagne (#D4AF37), Bianco (#FFFFFF), Grigio (#6B6B6B)
══════════════════════════════════════════════════ */

:root {
  --es-gold:        #B8960C;
  --es-gold-light:  #D4AF37;
  --es-gold-dark:   #8B6914;
  --es-ivory:       #FAF6EE;
  --es-cream:       #F2EBD9;
  --es-charcoal:    #1C1C1C;
  --es-dark:        #0F0F0F;
  --es-gray:        #6B6B6B;
  --es-gray-light:  #E8E4DC;
  --es-white:       #FFFFFF;
  --es-font-serif:  'Playfair Display', 'Georgia', serif;
  --es-font-sans:   'Lato', 'Helvetica Neue', sans-serif;
  --es-radius:      6px;
  --es-shadow:      0 4px 24px rgba(0,0,0,.12);
  --es-shadow-lg:   0 12px 48px rgba(0,0,0,.18);
}

/* ── Google Fonts ─────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Lato:wght@300;400;600;700&display=swap');

/* ── Reset & Base ─────────────────────────────── */
body {
  font-family: var(--es-font-sans);
  color: var(--es-charcoal);
  background: var(--es-white);
  font-size: 16px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--es-font-serif);
  color: var(--es-charcoal);
  line-height: 1.25;
  font-weight: 700;
}

a { color: var(--es-gold); text-decoration: none; transition: color .2s; }
a:hover { color: var(--es-gold-dark); }

/* ── Header ───────────────────────────────────── */
.site-header,
.ast-primary-header-bar {
  background: var(--es-dark) !important;
  border-bottom: 2px solid var(--es-gold) !important;
}

.site-header .site-title a,
.ast-site-identity .site-title a {
  font-family: var(--es-font-serif) !important;
  color: var(--es-gold-light) !important;
  font-size: 28px !important;
  letter-spacing: 1px;
}

.ast-primary-nav .menu-item > a,
#site-navigation .menu-item > a {
  color: var(--es-white) !important;
  font-family: var(--es-font-sans);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .5px;
  text-transform: uppercase;
  padding: 8px 16px !important;
  transition: color .2s;
}

.ast-primary-nav .menu-item > a:hover,
.ast-primary-nav .menu-item.current-menu-item > a {
  color: var(--es-gold-light) !important;
}

/* ── Hero Section ─────────────────────────────── */
.es-hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background: linear-gradient(135deg, var(--es-dark) 0%, #2a1f0a 50%, var(--es-dark) 100%);
}

.es-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M30 5 L55 50 L5 50 Z' fill='none' stroke='rgba(184,150,12,0.05)' stroke-width='1'/%3E%3C/svg%3E") repeat;
  pointer-events: none;
}

.es-hero-content { position: relative; z-index: 2; max-width: 800px; padding: 40px 24px; }

.es-hero-eyebrow {
  display: inline-block;
  font-family: var(--es-font-sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--es-gold);
  border: 1px solid var(--es-gold);
  padding: 6px 20px;
  border-radius: 20px;
  margin-bottom: 28px;
}

.es-hero h1 {
  font-family: var(--es-font-serif);
  font-size: clamp(36px, 6vw, 72px);
  color: var(--es-white);
  line-height: 1.1;
  margin-bottom: 24px;
}

.es-hero h1 em {
  font-style: italic;
  color: var(--es-gold-light);
}

.es-hero p {
  font-size: 18px;
  color: rgba(255,255,255,.75);
  max-width: 560px;
  margin: 0 auto 40px;
  line-height: 1.7;
}

.es-gold-divider {
  width: 80px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--es-gold), transparent);
  margin: 24px auto;
}

/* ── Buttons ──────────────────────────────────── */
.es-btn,
.wp-block-button__link,
.button,
.wc-block-components-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--es-font-sans) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  padding: 14px 32px !important;
  border-radius: var(--es-radius) !important;
  transition: all .3s ease !important;
  cursor: pointer;
}

.es-btn-primary,
.wp-block-button.is-style-fill .wp-block-button__link {
  background: var(--es-gold) !important;
  color: var(--es-dark) !important;
  border: 2px solid var(--es-gold) !important;
}

.es-btn-primary:hover,
.wp-block-button.is-style-fill .wp-block-button__link:hover {
  background: var(--es-gold-light) !important;
  color: var(--es-dark) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(184,150,12,.35) !important;
}

.es-btn-outline {
  background: transparent !important;
  color: var(--es-gold-light) !important;
  border: 2px solid var(--es-gold) !important;
}

.es-btn-outline:hover {
  background: var(--es-gold) !important;
  color: var(--es-dark) !important;
}

/* ── Section layout ───────────────────────────── */
.es-section {
  padding: 96px 24px;
}

.es-section-ivory { background: var(--es-ivory); }
.es-section-dark  { background: var(--es-dark); color: var(--es-white); }
.es-section-dark h2, .es-section-dark h3 { color: var(--es-white); }
.es-section-cream { background: var(--es-cream); }

.es-container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 24px;
}

.es-section-title {
  font-family: var(--es-font-serif);
  font-size: clamp(28px, 4vw, 46px);
  text-align: center;
  margin-bottom: 16px;
}

.es-section-sub {
  text-align: center;
  color: var(--es-gray);
  font-size: 17px;
  max-width: 560px;
  margin: 0 auto 56px;
  line-height: 1.7;
}

/* ── Service Cards ────────────────────────────── */
.es-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 32px;
}

.es-card {
  background: var(--es-white);
  border-radius: 12px;
  padding: 40px 32px;
  box-shadow: var(--es-shadow);
  transition: transform .3s, box-shadow .3s;
  border-top: 3px solid var(--es-gold);
  position: relative;
  overflow: hidden;
}

.es-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--es-gold-dark), var(--es-gold-light));
}

.es-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--es-shadow-lg);
}

.es-card-icon {
  font-size: 40px;
  margin-bottom: 20px;
  display: block;
}

.es-card h3 {
  font-size: 22px;
  margin-bottom: 12px;
  color: var(--es-charcoal);
}

.es-card p { color: var(--es-gray); font-size: 15px; line-height: 1.7; }

.es-card-price {
  margin-top: 20px;
  font-family: var(--es-font-serif);
  font-size: 24px;
  font-weight: 700;
  color: var(--es-gold);
}

/* ── Stats Counter ────────────────────────────── */
.es-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 24px;
  text-align: center;
  padding: 64px 0;
}

.es-stat-num {
  font-family: var(--es-font-serif);
  font-size: 52px;
  font-weight: 700;
  color: var(--es-gold-light);
  line-height: 1;
  display: block;
}

.es-stat-label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: rgba(255,255,255,.6);
  margin-top: 8px;
  display: block;
}

/* ── Testimonial ──────────────────────────────── */
.es-testimonial {
  background: var(--es-white);
  border-left: 4px solid var(--es-gold);
  padding: 32px 36px;
  border-radius: 0 12px 12px 0;
  box-shadow: var(--es-shadow);
  position: relative;
}

.es-testimonial::before {
  content: '\201C';
  font-family: var(--es-font-serif);
  font-size: 80px;
  color: var(--es-gold);
  opacity: .2;
  position: absolute;
  top: -10px; left: 16px;
  line-height: 1;
}

.es-testimonial p { font-size: 17px; font-style: italic; color: var(--es-gray); line-height: 1.8; }
.es-testimonial cite { font-style: normal; font-weight: 700; color: var(--es-charcoal); font-size: 14px; }

/* ── Process Steps ────────────────────────────── */
.es-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 40px;
  counter-reset: steps;
}

.es-step {
  text-align: center;
  padding: 0 16px;
  counter-increment: steps;
  position: relative;
}

.es-step::before {
  content: counter(steps);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background: var(--es-gold);
  color: var(--es-dark);
  font-family: var(--es-font-serif);
  font-size: 24px;
  font-weight: 700;
  border-radius: 50%;
  margin: 0 auto 24px;
  box-shadow: 0 4px 16px rgba(184,150,12,.3);
}

.es-step h4 { font-size: 18px; margin-bottom: 10px; }
.es-step p  { font-size: 14px; color: var(--es-gray); }

/* ── WooCommerce ──────────────────────────────── */
.woocommerce .products .product {
  background: var(--es-white);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--es-shadow);
  transition: transform .3s, box-shadow .3s;
  border: 1px solid var(--es-gray-light);
}

.woocommerce .products .product:hover {
  transform: translateY(-4px);
  box-shadow: var(--es-shadow-lg);
}

.woocommerce .products .product .price {
  color: var(--es-gold) !important;
  font-family: var(--es-font-serif);
  font-size: 22px !important;
  font-weight: 700;
}

.woocommerce a.added_to_cart,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--es-gold) !important;
  color: var(--es-dark) !important;
  border-radius: var(--es-radius) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  transition: all .3s !important;
}

.woocommerce a.added_to_cart:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  background: var(--es-gold-dark) !important;
  color: var(--es-white) !important;
  transform: translateY(-1px);
}

/* ── Footer ───────────────────────────────────── */
.site-footer,
.ast-small-footer {
  background: var(--es-black) !important;
  color: rgba(255,255,255,.65) !important;
  border-top: 2px solid var(--es-gold) !important;
}

.site-footer a,
.ast-small-footer a {
  color: var(--es-gold-light) !important;
}

.site-footer .widget-title,
.ast-footer-widget-title {
  color: var(--es-white) !important;
  font-family: var(--es-font-serif) !important;
  border-bottom: 1px solid var(--es-gold) !important;
  padding-bottom: 10px !important;
}

/* ── Utility ──────────────────────────────────── */
.es-gold-text { color: var(--es-gold) !important; }
.es-white-text { color: var(--es-white) !important; }
.es-text-center { text-align: center; }
.es-mb-0 { margin-bottom: 0 !important; }

/* ── Responsive ───────────────────────────────── */
@media (max-width: 768px) {
  .es-section { padding: 64px 16px; }
  .es-hero     { min-height: 70vh; }
  .es-steps    { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 480px) {
  .es-steps { grid-template-columns: 1fr; }
  .es-cards-grid { grid-template-columns: 1fr; }
}

/* ── Gutenberg wp-block alignment ─────────────── */
.wp-block-cover.es-hero-cover {
  min-height: 90vh !important;
}

.wp-block-cover__inner-container {
  max-width: 800px;
  margin: 0 auto;
}

/* ── Channel Manager in pagina ────────────────── */
.entry-content { max-width: 100%; }

/* ── Animazione scroll fade ───────────────────── */
.es-fade-in {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s ease, transform .6s ease;
}
.es-fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}
