/* ============================================================
   ACTION IN LINE — Page layouts CSS
   Header, footer, hero, sezioni, card, form, responsive.
   ============================================================ */

/* ---- SMOOTH SCROLL ---- */
html { scroll-behavior: smooth; }

/* ---- RESET / WRAP ---- */
*, *::before, *::after { box-sizing: border-box; }
img { max-width: 100%; height: auto; display: block; }

.ail-wrap {
  max-width: var(--layout-max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
}

/* ---- HEADER ---- */
.ail-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(19,19,23,.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ail-600);
}
.ail-header__inner {
  display: flex; align-items: center; gap: var(--spacing-xl);
  height: 68px;
}
.ail-header__logo img { height: 46px; width: auto; }
.ail-header__logo { flex-shrink: 0; }

.ail-nav { margin-left: auto; }
.ail-nav__list {
  list-style: none; margin: 0; padding: 0;
  display: flex; align-items: center; gap: var(--spacing-sm);
}
.ail-nav__list > li > a,
.ail-nav__list > li > button {
  font-family: var(--font-body); font-size: 14px; font-weight: 600;
  color: var(--color-text-primary); text-decoration: none;
  padding: 8px 12px; border-radius: var(--radius-sm);
  background: none; border: none; cursor: pointer;
  transition: background var(--duration-fast);
  white-space: nowrap; outline: none;
  -webkit-appearance: none; appearance: none;
}
.ail-nav__list > li > a:hover,
.ail-nav__list > li > button:hover { background: var(--ail-650); }
.ail-nav__list > li > button:focus,
.ail-nav__list > li > button:active { background: var(--ail-650); outline: none; box-shadow: none; }
.ail-nav__list > li > a.active { color: var(--primitive-orange); }

/* Dropdown */
.ail-nav__dropdown { position: relative; }
.ail-nav__dropdown > button { position: relative; }
.ail-nav__dropdown > button::after { content: ' ▾'; font-size: 11px; }
/* Bridge invisibile che colma il gap tra button e sub-menu */
.ail-nav__dropdown > button::before {
  content: ''; position: absolute; bottom: -14px; left: 0; right: 0; height: 14px;
}
.ail-nav__sub {
  display: none; position: absolute; top: 100%; left: 0;
  padding-top: 10px; /* gap visivo senza rompere hover area */
  list-style: none; margin: 0; min-width: 240px; z-index: 200;
}
.ail-nav__sub-inner {
  background: var(--ail-650); border: 1px solid var(--ail-600);
  border-radius: var(--radius-md); padding: 8px 0;
  box-shadow: var(--shadow-lg);
}
.ail-nav__dropdown:hover .ail-nav__sub,
.ail-nav__dropdown.open .ail-nav__sub { display: block; }
.ail-nav__sub li a {
  display: block; padding: 10px 16px;
  font-size: 14px; color: var(--color-text-primary);
  text-decoration: none; font-family: var(--font-body);
  transition: background var(--duration-fast);
}
.ail-nav__sub li a:hover { background: var(--ail-600); border-radius: 4px; }

/* CTA button in nav */
.ail-nav__list .nav-cta {
  background-image: linear-gradient(45deg, var(--primitive-orange), var(--primitive-blue));
  color: #fff !important; border-radius: var(--radius-sm);
  padding: 9px 18px !important;
}
.ail-nav__list .nav-cta:hover { opacity: .9; background: none; }

/* Hamburger */
.ail-hamburger {
  display: none; margin-left: auto;
  background: none; border: 1px solid var(--ail-550);
  border-radius: var(--radius-sm); padding: 6px 10px;
  color: #fff; cursor: pointer; font-size: 18px; line-height: 1;
}

/* Mobile nav */
@media (max-width: 880px) {
  .ail-nav { display: none; position: fixed; inset: 68px 0 0 0;
    background: var(--ail-800); overflow-y: auto; padding: 24px 0; z-index: 99; }
  .ail-nav.open { display: block; }
  .ail-nav__list { flex-direction: column; align-items: stretch; gap: 0; }
  .ail-nav__list > li > a,
  .ail-nav__list > li > button { display: block; border-radius: 0; padding: 14px 24px; font-size: 16px; width: 100%; text-align: left; }
  .ail-nav__sub { display: none !important; position: static; border: none; background: var(--ail-750);
    border-radius: 0; box-shadow: none; padding: 0; }
  .ail-nav__dropdown.open .ail-nav__sub { display: block !important; }
  .ail-nav__sub li a { padding: 12px 36px; }
  .ail-nav__list .nav-cta { margin: 16px 24px; display: inline-flex; width: auto; border-radius: var(--radius-sm); }
  .ail-hamburger { display: flex; align-items: center; }
}

/* ---- FOOTER ---- */
.ail-footer {
  background: var(--ail-900);
  border-top: 1px solid var(--ail-600);
  padding: var(--spacing-3xl) 0 var(--spacing-xl);
  margin-top: auto;
}
.ail-footer__top {
  display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: var(--spacing-3xl); margin-bottom: var(--spacing-3xl);
}
.ail-footer__brand img { max-height: 44px; width: auto; margin-bottom: var(--spacing-md); }
.ail-footer__brand .accent-bar {
  width: 48px; height: 3px; border-radius: 99px;
  background: var(--gradient-accent); margin-bottom: var(--spacing-md);
}
.ail-footer__brand p { font-size: 14px; color: var(--color-text-secondary); line-height: 1.6; }
.ail-footer__col h4 {
  font-family: var(--font-body); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--color-text-secondary); margin: 0 0 var(--spacing-md);
}
.ail-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.ail-footer__col ul li a {
  font-size: 14px; color: var(--color-text-primary); text-decoration: none;
  transition: color var(--duration-fast);
}
.ail-footer__col ul li a:hover { color: var(--primitive-orange); }
.ail-footer__col ul li span { font-size: 14px; color: var(--color-text-secondary); }
.ail-footer__bottom {
  border-top: 1px solid var(--ail-600);
  padding-top: var(--spacing-lg);
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px; color: var(--color-text-secondary);
}
@media (max-width: 768px) {
  .ail-footer__top { grid-template-columns: 1fr 1fr; gap: var(--spacing-xl); }
  .ail-footer__brand { grid-column: 1 / -1; }
  .ail-footer__bottom { flex-direction: column; gap: 8px; text-align: center; }
}
@media (max-width: 480px) {
  .ail-footer__top { grid-template-columns: 1fr; }
}

/* ---- HERO FULL (homepage) ---- */
.hero-full {
  position: relative; min-height: 100svh;
  display: flex; align-items: flex-end; padding-bottom: var(--spacing-4xl);
  background: var(--ail-900);
  overflow: hidden;
}
.hero-full__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  background-color: var(--ail-900);
}
.hero-full__bg::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(19,19,23,.95) 0%, rgba(19,19,23,.50) 60%, rgba(19,19,23,.15) 100%),
    linear-gradient(0deg, var(--ail-750) 0%, rgba(30,30,36,.70) 30%, rgba(19,19,23,0) 60%);
}
.hero-full__content { position: relative; z-index: 2; max-width: 680px; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(19,19,23,.55); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--radius-full); padding: 6px 16px;
  font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: #fff; margin-bottom: var(--spacing-lg);
}
.hero-full__title {
  font-family: var(--font-display); font-weight: 400; text-transform: uppercase;
  font-size: clamp(54px, 9vw, 108px); line-height: 1.0;
  letter-spacing: .03em; color: #fff; margin: 0 0 var(--spacing-lg);
}
.hero-full__sub {
  font-size: 18px; line-height: 1.6; color: rgba(255,255,255,.8);
  max-width: 520px; margin-bottom: var(--spacing-2xl);
}
.hero-full__ctas { display: flex; gap: var(--spacing-md); flex-wrap: wrap; }

/* ---- HERO COMPACT (pagine interne) ---- */
.hero-compact {
  position: relative;
  padding: var(--spacing-4xl) 0 0;
  background: var(--ail-900);
  overflow: hidden;
}
.hero-compact__bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  background-color: var(--ail-900);
}
.hero-compact__bg::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(19,19,23,.95) 0%, rgba(19,19,23,.55) 55%, rgba(19,19,23,.15) 100%),
    linear-gradient(0deg, var(--ail-900) 0%, rgba(19,19,23,.4) 100%);
}

/* Layout a 2 colonne per hero corso */
.hero-compact__grid {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--spacing-3xl); align-items: end;
  padding-bottom: 0;
}
.hero-compact__content { position: relative; z-index: 2; padding-bottom: var(--spacing-3xl); }

/* Area destra hero: foto placeholder + mascotte */
.hero-compact__media {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: flex-end;
  padding-bottom: 0;
}
.hero-photo-placeholder {
  width: 100%; aspect-ratio: 4/3;
  background: var(--ail-700); border: 1px dashed var(--ail-500);
  border-radius: var(--radius-xl); display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px;
  color: var(--color-text-secondary); font-size: 13px; text-align: center;
  overflow: hidden;
}
.hero-photo-placeholder img { width: 100%; height: 100%; object-fit: cover; }
.hero-photo-placeholder--empty::before {
  content: '🖼';font-size: 32px; display: block;
}
.hero-compact__mascotte-wrap {
  position: relative; align-self: flex-end;
  margin-top: -60px; margin-right: -8px; z-index: 3;
}
.hero-compact__mascotte-wrap img { height: 200px; width: auto; display: block; }

/* Fallback: hero senza grid (chi siamo, gallery, ecc.) */
.hero-compact--simple .hero-compact__content { padding-bottom: var(--spacing-3xl); }

.crumbs {
  font-size: 13px; color: var(--color-text-secondary);
  margin-bottom: var(--spacing-lg); display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.crumbs a { color: var(--color-text-secondary); text-decoration: none; }
.crumbs a:hover { color: #fff; }
.crumbs span { opacity: .5; }
.hero-compact__title {
  font-family: var(--font-display); font-weight: 400; text-transform: uppercase;
  font-size: clamp(40px, 5.5vw, 76px); line-height: 1.0;
  letter-spacing: .03em; color: #fff; margin: var(--spacing-md) 0 var(--spacing-lg);
  white-space: nowrap;
}
.hero-compact__sub {
  font-size: 16px; line-height: 1.6; color: rgba(255,255,255,.75);
  max-width: 520px; margin-bottom: var(--spacing-xl);
}
.hero-compact__ctas { display: flex; gap: var(--spacing-md); flex-wrap: wrap; align-items: center; }
.hero-compact__cta-note { font-size: 13px; color: rgba(255,255,255,.5); }

@media (max-width: 900px) {
  .hero-compact__grid { grid-template-columns: 1fr; }
  .hero-compact__media { display: none; } /* nasconde media su mobile */
  .hero-compact { padding: var(--spacing-3xl) 0 0; }
  .hero-compact__content { padding-bottom: var(--spacing-2xl); }
  .hero-compact__title { white-space: normal; font-size: clamp(36px, 8vw, 56px); }
}

/* ---- SEZIONI ---- */
.ail-section { padding: var(--spacing-4xl) 0; }
.ail-section--sm { padding: var(--spacing-3xl) 0; }

.section-eyebrow {
  font-family: var(--font-body); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  color: var(--accent); margin-bottom: var(--spacing-sm); display: block;
}
.section-title {
  font-family: var(--font-display); font-weight: 400; text-transform: uppercase;
  font-size: clamp(32px, 4vw, 56px); line-height: 1.08; letter-spacing: .03em;
  color: #fff; margin: 0 0 var(--spacing-md);
}
.section-sub {
  font-size: 17px; line-height: 1.6; color: var(--color-text-secondary);
  max-width: 620px; margin-bottom: var(--spacing-3xl);
}

/* ---- CARD CORSI (homepage) ---- */
.courses-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xl);
}
@media (max-width: 900px) { .courses-grid { grid-template-columns: 1fr; } }

.course-card {
  border-radius: var(--radius-xl); border: 1px solid var(--color-border-default);
  padding: var(--spacing-2xl) var(--spacing-xl) var(--spacing-xl);
  display: flex; flex-direction: column; gap: var(--spacing-md);
  transition: transform var(--duration-normal) var(--ease-snap), border-color var(--duration-normal), box-shadow var(--duration-normal);
  text-decoration: none; color: inherit;
}
.course-card:hover { transform: translateY(-4px); }
.course-card--kids {
  background: linear-gradient(165deg, color-mix(in srgb, var(--primitive-orange) 18%, transparent), transparent 58%), var(--ail-650);
}
.course-card--kids:hover { border-color: var(--primitive-orange); box-shadow: var(--shadow-brand); }
.course-card--adults {
  background: linear-gradient(165deg, color-mix(in srgb, var(--primitive-blue) 18%, transparent), transparent 58%), var(--ail-650);
}
.course-card--adults:hover { border-color: var(--primitive-blue); box-shadow: var(--shadow-blue); }
.course-card--hockey {
  background: linear-gradient(165deg, color-mix(in srgb, var(--primitive-gray-400) 14%, transparent), transparent 58%), var(--ail-650);
}
.course-card--hockey:hover { border-color: var(--ail-500); box-shadow: var(--shadow-lg); }

.course-card__badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--radius-full);
  width: fit-content;
}
.badge--kids   { background: var(--primitive-orange); color: #fff; }
.badge--adults { background: var(--primitive-blue); color: #fff; }
.badge--hockey { background: var(--gradient-accent); color: #fff; }

.course-card__age { font-size: 13px; color: var(--color-text-secondary); }
.course-card__title {
  font-family: var(--font-display); font-size: 28px; font-weight: 400;
  text-transform: uppercase; letter-spacing: .03em; color: #fff; margin: 0;
}
.course-card__text { font-size: 15px; line-height: 1.6; color: var(--color-text-secondary); flex: 1; }
.course-card__cta {
  font-size: 14px; font-weight: 600; margin-top: var(--spacing-sm);
  display: inline-flex; align-items: center; gap: 6px;
}
.course-card--kids   .course-card__cta { color: var(--primitive-orange); }
.course-card--adults .course-card__cta { color: var(--primitive-blue); }
.course-card--hockey .course-card__cta { background: var(--gradient-accent); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }

/* ---- STATS ---- */
.stats-row {
  display: flex; gap: var(--spacing-3xl); margin-top: var(--spacing-3xl);
  flex-wrap: wrap;
}
.stat__num {
  font-family: var(--font-display); font-size: 48px; font-weight: 400;
  text-transform: uppercase; color: #fff; display: block; line-height: 1;
}
.stat__label { font-size: 13px; color: var(--color-text-secondary); margin-top: 4px; }

/* ---- 2 COLONNE ---- */
.two-col {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--spacing-3xl); align-items: center;
}
.two-col--reverse .two-col__media { order: -1; }
@media (max-width: 768px) {
  .two-col { grid-template-columns: 1fr; }
  .two-col--reverse .two-col__media { order: 0; }
}
.two-col__img-wrap { position: relative; border-radius: var(--radius-xl); overflow: hidden; }
.two-col__img-wrap img { width: 100%; height: 380px; object-fit: cover; }
.two-col__badge {
  position: absolute; bottom: var(--spacing-md); left: var(--spacing-md);
  background: rgba(19,19,23,.8); backdrop-filter: blur(8px);
  border: 1px solid var(--ail-550); border-radius: var(--radius-md);
  padding: 8px 14px; font-size: 13px; font-weight: 600; color: #fff;
}
.two-col__lead {
  font-size: 20px; font-weight: 600; color: #fff; line-height: 1.5;
  margin-bottom: var(--spacing-md);
}
.two-col__text { font-size: 16px; line-height: 1.7; color: var(--color-text-secondary); }
.two-col__text p { margin: 0 0 var(--spacing-md); }
.two-col__text a { color: var(--primitive-blue); }

/* ---- PILLS (Chi siamo) ---- */
.pills { display: flex; flex-wrap: wrap; gap: 10px; margin-top: var(--spacing-lg); }
.pill {
  padding: 6px 14px; border-radius: var(--radius-full);
  font-size: 13px; font-weight: 600; border: 1px solid var(--ail-550);
  color: var(--color-text-primary);
}
.pill--kids   { border-color: var(--primitive-orange); color: var(--primitive-orange); }
.pill--adults { border-color: var(--primitive-blue); color: var(--primitive-blue); }
.pill--mix    { background: var(--gradient-accent); -webkit-background-clip: text; -webkit-text-fill-color: transparent; border-color: transparent; }

/* ---- CTA SECTION ---- */
.cta-section {
  padding: var(--spacing-4xl) 0;
  background: var(--ail-900);
}
.cta-section__inner {
  display: flex; align-items: center; gap: var(--spacing-3xl);
}
.cta-section__text { flex: 1; }
.cta-section__mascotte img { height: 220px; }
.cta-section__ctas { display: flex; gap: var(--spacing-md); flex-wrap: wrap; margin-top: var(--spacing-xl); }
@media (max-width: 768px) {
  .cta-section__inner { flex-direction: column; text-align: center; }
  .cta-section__ctas { justify-content: center; }
}

/* ---- PAGINE CORSO: info pratiche ---- */
.info-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xl);
}
@media (max-width: 768px) { .info-grid { grid-template-columns: 1fr; } }

.info-card {
  background: var(--ail-650); border: 1px solid var(--ail-550);
  border-radius: var(--radius-lg); padding: var(--spacing-xl);
}
.info-card__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .12em; color: var(--accent); margin-bottom: 8px; display: block;
}
.info-card__value {
  font-family: var(--font-display); font-size: 28px; font-weight: 400;
  text-transform: uppercase; color: #fff; display: block; margin-bottom: 4px;
}
.info-card__note { font-size: 14px; color: var(--color-text-secondary); }

/* ---- PROGRAMMA STEPS ---- */
.steps { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-xl); }
.steps--3col { grid-template-columns: 1fr 1fr 1fr; }
.step {
  background: var(--ail-650); border: 1px solid var(--ail-550);
  border-top: 3px solid var(--accent);
  border-radius: var(--radius-lg); padding: var(--spacing-xl);
  display: flex; flex-direction: column;
}
.step__num {
  font-family: var(--font-display); font-size: 48px; font-weight: 400;
  text-transform: uppercase; color: var(--accent); line-height: 1;
  margin-bottom: var(--spacing-sm);
}
.step__title { font-size: 17px; font-weight: 700; color: #fff; margin: 0 0 4px; }
.step__sub { font-size: 14px; color: var(--color-text-secondary); margin: 0 0 var(--spacing-md); }
.step__list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px 16px; }
.step__list li {
  font-size: 13px; color: var(--color-text-secondary);
  padding-left: 14px; position: relative;
}
.step__list li::before {
  content: ''; position: absolute; left: 0; top: 6px;
  width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
}
@media (max-width: 640px) {
  .steps, .steps--3col { grid-template-columns: 1fr; }
}

/* ---- PUNTI ELENCO ---- */
.check-list { list-style: none; margin: var(--spacing-md) 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.check-list li {
  font-size: 15px; color: var(--color-text-secondary);
  padding-left: 22px; position: relative; line-height: 1.5;
}
.check-list li::before {
  content: ''; position: absolute; left: 0; top: 6px;
  width: 8px; height: 8px; border-radius: 50%; background: var(--accent);
}

/* ---- SEZIONE CORSO: layout testo + foto + mascotte ---- */
.corso-content-grid {
  display: grid; grid-template-columns: 1fr 380px;
  gap: var(--spacing-3xl); align-items: start;
}
.corso-content-right {
  display: flex; flex-direction: column; gap: var(--spacing-lg); align-items: flex-start;
}
.corso-photo {
  width: 100%; aspect-ratio: 4/3;
  background: var(--ail-700); border: 1px dashed var(--ail-500);
  border-radius: var(--radius-xl); overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  color: var(--color-text-secondary); font-size: 13px; text-align: center;
}
.corso-photo img { width: 100%; height: 100%; object-fit: cover; }
.corso-photo--empty { flex-direction: column; gap: 8px; }
.corso-photo--empty::before { content: '🖼'; font-size: 28px; display: block; }
.corso-mascotte {
  align-self: flex-end; margin-top: -20px;
}
.corso-mascotte img { height: 160px; width: auto; }
@media (max-width: 900px) {
  .corso-content-grid { grid-template-columns: 1fr; }
  .corso-content-right { flex-direction: row; flex-wrap: wrap; }
  .corso-photo { flex: 1 1 300px; }
  .corso-mascotte { flex: 0 0 auto; }
}

/* ---- BOX AVVISO ---- */
.alert-box {
  background: color-mix(in srgb, var(--primitive-orange) 12%, var(--ail-650));
  border: 1px solid color-mix(in srgb, var(--primitive-orange) 40%, transparent);
  border-radius: var(--radius-md); padding: var(--spacing-lg);
  margin-top: var(--spacing-xl);
}
.alert-box strong { color: var(--primitive-orange); }
.alert-box p { margin: 0; font-size: 15px; color: rgba(255,255,255,.85); line-height: 1.6; }

/* ---- HOCKEY: due orari ---- */
.schedule-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--spacing-xl); margin-top: var(--spacing-xl);
}
@media (max-width: 640px) { .schedule-grid { grid-template-columns: 1fr; } }
.schedule-card {
  background: var(--ail-650); border-radius: var(--radius-lg);
  border: 1px solid var(--ail-550); padding: var(--spacing-xl);
}
.schedule-card--adults { border-color: var(--primitive-blue); }
.schedule-card--kids   { border-color: var(--primitive-orange); }
.schedule-card__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  margin-bottom: 12px; display: block;
}
.schedule-card--adults .schedule-card__label { color: var(--primitive-blue); }
.schedule-card--kids   .schedule-card__label { color: var(--primitive-orange); }
.schedule-card__time {
  font-family: var(--font-display); font-size: 32px; color: #fff;
  text-transform: uppercase; margin-bottom: 6px;
}
.schedule-card__days { font-size: 15px; color: var(--color-text-secondary); }

/* ---- GALLERY PLACEHOLDER ---- */
.gallery-tabs { display: flex; gap: var(--spacing-sm); flex-wrap: wrap; margin-bottom: var(--spacing-xl); }
.gallery-tab {
  padding: 8px 20px; border-radius: var(--radius-full);
  font-size: 14px; font-weight: 600; border: 1px solid var(--ail-550);
  color: var(--color-text-secondary); background: var(--ail-650);
  cursor: pointer; transition: all var(--duration-fast);
}
.gallery-tab.active, .gallery-tab:hover {
  border-color: var(--primitive-orange); color: var(--primitive-orange);
}
.gallery-placeholder {
  background: var(--ail-650); border: 1px dashed var(--ail-500);
  border-radius: var(--radius-xl); padding: var(--spacing-4xl) var(--spacing-xl);
  text-align: center; color: var(--color-text-secondary); font-size: 15px;
}

/* ---- CONTATTI: layout form + info ---- */
.contact-layout {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: var(--spacing-3xl); align-items: start;
}
@media (max-width: 768px) { .contact-layout { grid-template-columns: 1fr; } }

.contact-info { display: flex; flex-direction: column; gap: var(--spacing-lg); }
.contact-card {
  background: var(--ail-650); border: 1px solid var(--ail-550);
  border-radius: var(--radius-lg); padding: var(--spacing-xl);
}
.contact-card h3 {
  font-family: var(--font-body); font-size: 16px; font-weight: 700;
  color: #fff; margin: 0 0 8px;
}
.contact-card p { font-size: 14px; color: var(--color-text-secondary); line-height: 1.6; margin: 0 0 8px; }
.contact-card a { color: var(--primitive-blue); text-decoration: none; font-weight: 600; }
.contact-card a:hover { color: var(--primitive-blue-light); }
.contact-row { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--color-text-secondary); }

/* CF7 custom styles */
.wpcf7-form { display: flex; flex-direction: column; gap: var(--spacing-md); }
.wpcf7-form label { font-size: 14px; font-weight: 600; color: rgba(255,255,255,.85); margin-bottom: 4px; display: block; }
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form select,
.wpcf7-form textarea {
  width: 100%; background: var(--ail-600); border: 1px solid var(--ail-500);
  border-radius: var(--radius-md); padding: 12px 14px;
  color: #fff; font-family: var(--font-body); font-size: 15px;
  transition: border-color var(--duration-fast);
}
.wpcf7-form input:focus, .wpcf7-form select:focus, .wpcf7-form textarea:focus {
  outline: none; border-color: var(--primitive-orange);
}
.wpcf7-form select option { background: var(--ail-700); }
.wpcf7-form textarea { min-height: 140px; resize: vertical; }
.wpcf7-form .wpcf7-acceptance label { display: flex; align-items: flex-start; gap: 10px; font-weight: 400; cursor: pointer; }
.wpcf7-form .wpcf7-acceptance input { width: auto; flex-shrink: 0; margin-top: 3px; accent-color: var(--primitive-orange); }
.wpcf7-form .wpcf7-submit {
  background-image: linear-gradient(45deg, var(--primitive-orange), var(--primitive-blue));
  color: #fff; border: none; border-radius: var(--radius-sm);
  padding: 14px 28px; font-size: 15px; font-weight: 700;
  cursor: pointer; font-family: var(--font-body);
  align-self: flex-start;
  transition: opacity var(--duration-fast);
}
.wpcf7-form .wpcf7-submit:hover { opacity: .9; }
.wpcf7-form p { margin: 0; display: flex; flex-direction: column; gap: 4px; }
.form-note { font-size: 12px; color: var(--color-text-secondary); margin-top: 4px; }
.wpcf7-not-valid-tip { color: var(--primitive-red); font-size: 13px; }
.wpcf7 .wpcf7-response-output { border: none; background: var(--ail-650); border-radius: var(--radius-md); padding: var(--spacing-md); font-size: 14px; }

/* ---- BUTTONS ---- */
.ail-btn { display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-body); font-weight: 600; font-size: 15px;
  padding: 13px 24px; border-radius: var(--radius-sm); text-decoration: none;
  border: none; cursor: pointer; transition: transform var(--duration-fast), box-shadow var(--duration-normal), opacity var(--duration-fast);
}
.ail-btn:active { transform: scale(.97); }
.ail-btn--primary { background: var(--primitive-orange); color: #fff; }
.ail-btn--primary:hover { background: var(--primitive-orange-dark); box-shadow: var(--shadow-brand); }
.ail-btn--secondary { background: var(--primitive-blue); color: #fff; }
.ail-btn--secondary:hover { background: var(--primitive-blue-dark); box-shadow: var(--shadow-blue); }
.ail-btn--ghost { background: transparent; color: #fff; box-shadow: inset 0 0 0 2px var(--ail-500); }
.ail-btn--ghost:hover { background: rgba(255,255,255,.06); }
.ail-btn--gradient { background-image: linear-gradient(45deg, var(--primitive-orange), var(--primitive-blue)); color: #fff; }
.ail-btn--gradient:hover { opacity: .9; box-shadow: var(--shadow-lg); }

/* ---- GALLERY CPT ---- */
.gallery-groups { display: flex; flex-direction: column; gap: var(--spacing-4xl); }
.gallery-group__head, .gallery-group__header {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: var(--spacing-xl); flex-wrap: wrap; gap: var(--spacing-md);
}
.gallery-group__title {
  font-family: var(--font-display); font-size: clamp(22px, 2.8vw, 34px);
  font-weight: 400; text-transform: uppercase; letter-spacing: .03em; color: #fff; margin: 0;
}
.gallery-group__count { font-size: 13px; color: var(--color-text-secondary); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
}
.gallery-grid__item {
  aspect-ratio: 4/3; overflow: hidden; border-radius: var(--radius-md);
  background: var(--ail-650); border: none; padding: 0;
  cursor: pointer;
  transition: transform var(--duration-normal) var(--ease-snap), box-shadow var(--duration-normal);
}
.gallery-grid__item:hover { transform: scale(1.02); box-shadow: var(--shadow-lg); }
.gallery-grid__item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Lightbox */
.ail-lightbox {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.92); display: flex; align-items: center; justify-content: center;
}
.ail-lightbox[hidden] { display: none; }
.ail-lightbox__wrap { position: relative; display: flex; flex-direction: column; align-items: center; }
.ail-lightbox__wrap img { max-width: 88vw; max-height: 85vh; object-fit: contain; border-radius: var(--radius-md); display: block; }
.ail-lightbox__caption { color: rgba(255,255,255,.7); font-size: 14px; margin: 10px 0 0; text-align: center; }
.ail-lightbox__close {
  position: absolute; top: 20px; right: 24px; font-size: 28px; color: #fff;
  background: rgba(255,255,255,.1); border: none; cursor: pointer; line-height: 1;
  width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  transition: background var(--duration-fast);
}
.ail-lightbox__close:hover { background: rgba(255,255,255,.25); }
.ail-lightbox__prev, .ail-lightbox__next {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.1); border: none; color: #fff;
  font-size: 26px; width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background var(--duration-fast);
}
.ail-lightbox__prev:hover, .ail-lightbox__next:hover { background: rgba(255,255,255,.22); }
.ail-lightbox__prev { left: 20px; }
.ail-lightbox__next { right: 20px; }

/* ---- UTILITY ---- */
.text-secondary { color: var(--color-text-secondary); }
.mb-sm { margin-bottom: var(--spacing-sm); }
.mb-md { margin-bottom: var(--spacing-md); }
.mb-lg { margin-bottom: var(--spacing-lg); }
.mt-xl { margin-top: var(--spacing-xl); }
