/* STILI SPECIFICI PER LA PAGINA STORIA/IMPATTO */

.storia-hero { padding: clamp(64px,9vw,110px) 0 clamp(40px,6vw,70px); }
.storia-hero-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(32px,5vw,72px); align-items: start; }
.storia-hero h1 { font-family: var(--serif); font-weight: 400; font-size: clamp(2.6rem,5.8vw,4.8rem); line-height: 1.02; letter-spacing: -0.028em; margin-top: 22px; }
.storia-hero h1 em { font-style: italic; color: var(--gold); }
.storia-hero .byline { font-size: 12.5px; color: var(--gray); margin-top: 28px; letter-spacing: 0.06em; text-transform: uppercase; }

.storia-photos { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.storia-photo { aspect-ratio: 3/4; border-radius: 14px; overflow: hidden; position: relative; }
.storia-photo.ph {
    background: linear-gradient(180deg, #efe8d3 0%, #d9cfae 100%);
}
.storia-photo.ph::before {
    content: ''; position: absolute; inset: 0;
    background: repeating-linear-gradient(135deg, rgba(184,149,42,0.08) 0 8px, transparent 8px 16px);
}
.storia-photo.ph .cap {
    position: absolute; inset: auto 14px 14px; color: var(--gold-mid);
    font-family: ui-monospace, monospace; font-size: 10.5px;
    background: rgba(255,255,255,0.7); padding: 8px 10px; border-radius: 8px;
}

.photo-main { aspect-ratio: 0.95; border-radius: 14px; overflow: hidden; background: #f3ede0; }
.photo-main img { width: 100%; height: 100%; object-fit: cover; }

.photo-main2 { aspect-ratio: 0.75; border-radius: 14px; overflow: hidden; background: #f3ede0; }
.photo-main2 img { width: 100%; height: 100%; object-fit: cover;   object-position: center center;
 }


@media (max-width: 820px) {
    .storia-hero-grid { grid-template-columns: 1fr; }
}


/* LONGFORM */
.longform { max-width: 720px; margin: 0 auto; padding: clamp(48px,6vw,80px) 28px; }
.longform p {
    font-family: var(--serif); font-weight: 400;
    font-size: 1.3rem; line-height: 1.55; color: var(--ink);
    margin-bottom: 28px; letter-spacing: -0.005em;
}
.longform p.first::first-letter {
    font-size: 3.6rem; float: left; line-height: 0.9;
    color: var(--gold); margin-right: 10px; font-weight: 400;
    margin-top: 4px;
}
.longform blockquote {
    border-top: 1px solid var(--gray-mid); border-bottom: 1px solid var(--gray-mid);
    padding: 32px 0; margin: 40px 0;
    font-family: var(--serif); font-style: italic;
    font-size: 1.7rem; line-height: 1.3; color: var(--ink);
    letter-spacing: -0.01em;
    text-align: center;
}
.longform h3 {
    font-family: var(--serif); font-weight: 500;
    font-size: 1.6rem; margin: 36px 0 16px;
    letter-spacing: -0.01em;
}

/* TIMELINE */
.timeline-wrap { padding: clamp(56px,8vw,100px) 0; background: #fff; border-top: 1px solid var(--gray-mid); border-bottom: 1px solid var(--gray-mid); }
.timeline-head { max-width: 640px; margin-bottom: 48px; }
.timeline-head h2 { margin-top: 14px; }
.timeline {
    position: relative;
    display: grid; grid-template-columns: repeat(5, 1fr);
    gap: 14px;
}
.tl-line {
    position: absolute; top: 16px; left: 0; right: 0; height: 1px;
    background: linear-gradient(to right, transparent, var(--gold-soft) 15%, var(--gold-soft) 85%, transparent);
}
.tl-step {
    position: relative; padding-top: 44px;
    display: flex; flex-direction: column; gap: 8px;
}
.tl-dot {
    position: absolute; top: 8px; left: 0; width: 16px; height: 16px; border-radius: 50%;
    background: #fff; border: 2px solid var(--gold-soft); z-index: 1;
}
.tl-step.active .tl-dot { background: var(--gold); border-color: var(--gold); box-shadow: 0 0 0 5px rgba(184,149,42,0.15); }
.tl-date { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); }
.tl-title { font-family: var(--serif); font-size: 1.25rem; font-weight: 500; line-height: 1.15; }
.tl-desc { font-size: 13.5px; color: var(--gray); line-height: 1.55; }

@media (max-width: 820px) {
    .timeline { grid-template-columns: 1fr; gap: 24px; }
    .tl-line { left: 7px; top: 0; right: auto; bottom: 0; width: 1px; height: auto; background: linear-gradient(to bottom, transparent, var(--gold-soft) 10%, var(--gold-soft) 90%, transparent); }
    .tl-step { padding-left: 32px; padding-top: 0; }
    .tl-dot { left: 0; top: 4px; }
}

/* INSTRUMENT BAND */
.instrument { padding: clamp(56px,8vw,100px) 0; }

.inst-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
.inst-card { background: var(--ink); color: #fff; border-radius: 18px; padding: 36px; }
.inst-card h3 { font-family: var(--serif); font-weight: 400; font-size: 1.9rem; color: #fff; margin: 12px 0 10px; letter-spacing: -0.015em; }
.inst-card h3 em { font-style: italic; color: var(--gold-soft); }
.inst-card p { color: #C9C6BE; margin-bottom: 20px; font-size: 14.5px; line-height: 1.6; }
.inst-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(255,255,255,0.1); border-radius: 10px; overflow: hidden; margin-top: 20px; }
.inst-spec { background: rgba(255,255,255,0.02); padding: 14px 16px; }
.inst-spec .k { font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #8A8782; }
.inst-spec .v { font-family: var(--serif); font-size: 1.1rem; color: #fff; margin-top: 4px; }
.inst-spec .v.gold { color: var(--gold-soft); font-style: italic; }
.color-gold-soft { color: var(--gold-soft) !important; }

@media (max-width: 820px) {
    .inst-grid { grid-template-columns: 1fr; }
}

/* TEAM */
/* .team-wrap { padding: clamp(56px,8vw,100px) 0; background: var(--gray-light); } */
.team-wrap {
    background-image: url("../assets/sfondo-uku.jpg");
    background-repeat: repeat;
    background-size: auto;
}

.team-head { margin-bottom: 36px; max-width: 640px; }
.team-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center; /* Centra gli elementi avanzati */
  gap: 20px;
}

.team-grid > div {
  /* Calcolo per simulare le 3 colonne: (100% / 3) - gap */
  flex: 0 1 calc(33.333% - 20px); 
  min-width: 250px; /* Opzionale: per rendere il tutto responsive */
}


.team-card { background: #fff; border-radius: 16px; padding: 28px; border: 1px solid var(--gray-mid); }
.team-avatar {
    width: 60px; height: 60px; border-radius: 50%;
    background: linear-gradient(135deg, #efe8d3, #d9cfae);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--serif); font-size: 1.4rem; color: var(--gold-mid);
    margin-bottom: 18px;
}
.team-name { font-family: var(--serif); font-size: 1.4rem; font-weight: 500; letter-spacing: -0.01em; }
.team-role { color: var(--gold); font-size: 13px; margin-top: 3px; letter-spacing: 0.02em; }
.team-bio { color: var(--gray); font-size: 14px; margin-top: 14px; line-height: 1.6; }

@media (max-width: 820px) { .team-grid { grid-template-columns: 1fr; } }

/* CTA BOTTOM */
.cta-strip { padding: clamp(56px,8vw,100px) 0; text-align: center; }
.cta-strip h2 { margin-bottom: 18px; }
.cta-strip p { color: var(--gray); max-width: 520px; margin: 0 auto 32px; font-size: 1.05rem; }
.cta-btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }