/* assets/css/chisiamo.css - TEMA 2026 */

/* =========================================
   1. FONTS & VARIABILI
   ========================================= */
@font-face {
  font-family: 'DrukWide';
  src: url('/assets/doc/DrukTextWide-MediumItalic-Trial.otf') format('opentype');
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: 'HelveticaBold';
  src: url('/assets/doc/HelveticaBold.ttf') format('truetype');
  font-weight: bold;
  font-style: normal;
}

:root {
  --rosa-neon: #ff19ff;
  --viola: #790cfd; 
  --bianco: #ffffff;
  --nero-transp: rgba(18, 0, 40, 0.85); /* Vinaccia semitrasparente */
  --verde: #00ff66;
  --rosso: #ff3333;
  --bordo: rgba(255, 25, 255, 0.15); /* Bordo rosato per il glow */
}

/* =========================================
   2. BASE GLOBALE
   ========================================= */
body {
  color: var(--bianco);
  font-family: 'HelveticaBold', sans-serif;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  background-color: #120028; /* Vinaccia */
}

body::before {
  content: "";
  position: fixed;
  top: 0; 
  left: 0;
  width: 100%; 
  height: 100vh;
  z-index: -2; /* Portato piÃ¹ indietro per le colonne laterali */
  transform: translateZ(0);
  will-change: transform;

  background:
    linear-gradient(rgba(18, 0, 40, 0.5), rgba(18, 0, 40, 0.5)),
    url('/assets/imm/gradiente26.jpg') center/cover no-repeat;
}

/* Utility Classi Font */
.druk-font { 
  font-family: 'DrukWide', sans-serif; 
  letter-spacing: 0; 
  text-transform: uppercase;
}
.helvetica-font { 
  font-family: 'HelveticaBold', sans-serif; 
  letter-spacing: 0; 
  text-transform: uppercase;
}

.neon-text { color: var(--rosa-neon); text-shadow: 0 0 7px rgba(255, 25, 255, 0.4); }


/* =========================================
   3. COLONNE LATERALI SCORREVOLI
   ========================================= */
/*
.side-marquee {
    position: fixed;
    top: 0;
    bottom: 0;
    width: 20vw; 
    max-width: 188px; 
    z-index: -1;  
    overflow: hidden;
    pointer-events: none;
}

.left-marquee { left: 1%; }
.right-marquee { right: 1%; }

.marquee-track-vertical {
    display: flex;
    flex-direction: column;
    gap: 54px; 
    padding: 13px 0;
    width: 100%;
}

.marquee-track-vertical img {
    width: 100%;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0px 7px 13px rgba(0, 0, 0, 0.6));
}


.track-down {
    animation: scrollDown 60s linear infinite; 
}
.track-up {
    
    transform: translateY(-50%);
    animation: scrollUp 60s linear infinite;
}

@keyframes scrollDown {
    0% { transform: translateY(0); }
    100% { transform: translateY(-50%); }
}
@keyframes scrollUp {
    0% { transform: translateY(-50%); }
    100% { transform: translateY(0); }
}

@media (max-width: 905px) {
    .side-marquee { display: none; }
}
*/

/* =========================================
   4. LAYOUT E STRUTTURA CENTRALE
   ========================================= */
.container.main-content-layer {
    position: relative;
    z-index: 10; /* Assicura che il contenuto principale sia sempre cliccabile e in primo piano */
    max-width: 871px; 
    width: 90%; 
    margin: 27px auto; 
    animation: fadeIn 0.8s ease-out;
}

@keyframes fadeIn { from { opacity: 0; transform: translateY(13px); } to { opacity: 1; transform: translateY(0); } }

/* HERO */
.hero-about { text-align: center; margin-bottom: 40px; padding: 13px; }
.main-title { 
    font-size: 2rem; color: var(--rosa-neon); line-height: 1.1; margin-bottom: 10px; 
    text-shadow: 0 0 17px rgba(255, 25, 255, 0.4);
}
.hero-desc { font-size: 0.74rem; color: #ddd; max-width: 469px; margin: 0 auto; line-height: 1.6; }

/* PANNELLI CONTENUTO */
.content-block {
    margin-bottom: 27px; padding: 23px;
    background: var(--nero-transp); border: 1px solid var(--bordo);
    border-radius: 11px; backdrop-filter: blur(5px);
}
.block-title {
    font-size: 0.94rem; color: #fff; margin-top: 0; margin-bottom: 13px;
    border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 10px;
    display: flex; align-items: center; gap: 7px;
}
.block-title i { color: var(--rosa-neon); }
.block-text p { font-size: 0.67rem; line-height: 1.7; color: #ddd; margin-bottom: 10px; }
.block-text strong { color: #fff; }
.block-text em { color: var(--rosa-neon); font-style: italic; }

/* BOX FANTAUML */
.fanta-box {
    background: linear-gradient(135deg, rgba(121, 12, 253, 0.2), rgba(0,0,0,0.9)); 
    border: 1px solid var(--viola); border-radius: 11px;
    padding: 27px; margin-bottom: 40px; text-align: center;
    box-shadow: 0 0 20px rgba(121, 12, 253, 0.15);
}
.fanta-content h3 { font-size: 1.68rem; margin: 0 0 13px 0; }
.fanta-content p { font-size: 0.74rem; line-height: 1.6; color: #eee; max-width: 536px; margin: 0 auto; }

/* STATISTICHE (IMPATTO DIGITALE) */
.social-flex-box {
    text-align: center; margin-bottom: 40px; padding: 27px 13px;
    background: linear-gradient(180deg, rgba(255,25,255,0.05), rgba(18,0,40,0.8));
    border: 1px solid var(--rosa-neon); border-radius: 13px;
    backdrop-filter: blur(5px);
}
.flex-header { margin-bottom: 20px; }
.flex-header h2 { font-size: 1.34rem; color: #fff; margin: 0 0 3px 0; }
.flex-header p { color: #aaa; font-size: 0.6rem; }

.stats-wrapper { display: flex; justify-content: center; flex-wrap: wrap; gap: 27px; }
.stat-box { flex: 1; min-width: 134px; }

.stat-number-wrap { 
    display: block; font-size: 2rem; color: var(--rosa-neon); 
    line-height: 1; margin-bottom: 3px; text-shadow: 0 0 10px rgba(255,25,255,0.5); 
}
.stat-number { display: inline-block; }
.stat-label { display: block; font-size: 0.6rem; font-weight: bold; color: #fff; margin-bottom: 3px; }


/* ORGANIZZAZIONE */
.org-section {
    display: flex; align-items: center; gap: 20px;
    background: rgba(255, 255, 255, 0.05); border-radius: 11px;
    padding: 27px; margin-bottom: 40px; border-left: 3px solid var(--rosa-neon);
    backdrop-filter: blur(5px);
}
.org-logo { flex-shrink: 0; }
.org-text h3 { font-size: 0.8rem; color: #fff; margin: 0 0 10px 0; }
.org-text p { font-size: 0.64rem; color: #ccc; line-height: 1.6; margin-bottom: 7px; }

/* TALENT SECTION */
.talent-section { text-align: center; margin-bottom: 54px; }
.talent-grid { display: flex; justify-content: center; gap: 27px; flex-wrap: wrap; margin-top: 27px; }

.talent-card {
    width: 168px; text-align: center;
    background: var(--nero-transp);
    padding: 17px; border-radius: 11px;
    border: 1px solid var(--bordo);
    transition: transform 0.3s, border-color 0.3s;
    backdrop-filter: blur(5px);
}
.talent-card:hover { transform: translateY(-3px); border-color: var(--rosa-neon); background: rgba(255, 255, 255, 0.05); }

/* Cornice quadrata con angoli arrotondati */
.talent-img-wrap {
    width: 94px; height: 94px; margin: 0 auto 10px auto;
    border-radius: 11px; 
    padding: 3px;
    border: 1px solid var(--rosa-neon); 
    box-shadow: 0 0 10px rgba(255, 25, 255, 0.3);
}
.talent-img-wrap img {
    width: 100%; height: 100%; object-fit: cover; 
    border-radius: 8px; 
    filter: grayscale(100%); transition: filter 0.3s;
}
.talent-card:hover img { filter: grayscale(0%); }

.talent-name { color: #fff; font-size: 0.67rem; margin: 7px 0 3px 0; }
.talent-role { display: block; color: var(--rosa-neon); font-size: 0.5rem; font-weight: bold; margin-bottom: 7px; }
.talent-desc { font-size: 0.57rem; color: #aaa; line-height: 1.4; margin: 0; }

/* RASSEGNA STAMPA */
.press-section { text-align: center; margin-bottom: 40px; }
.press-links { display: flex; flex-direction: column; align-items: center; gap: 10px; margin-top: 17px; }
.press-item {
    display: flex; align-items: center; justify-content: space-between;
    width: 100%; max-width: 335px; padding: 10px 17px;
    background: var(--nero-transp); border: 1px solid var(--bordo);
    border-radius: 7px; color: #fff; text-decoration: none;
    transition: all 0.3s;
}
.press-item:hover { background: rgba(255,255,255,0.1); border-color: var(--rosa-neon); }
.press-item span { font-weight: bold; flex: 1; text-align: left; padding-left: 10px; font-family: 'DrukWide', sans-serif; font-size: 0.6rem; }
.arrow { color: var(--rosa-neon); }

/* FOUNDERS */
.founders-section { text-align: center; margin-bottom: 27px; padding-top: 20px; border-top: 1px solid var(--bordo); }
.founders-list { display: flex; flex-wrap: wrap; justify-content: center; gap: 27px; margin-top: 13px;}
.founder-item { padding: 3px; }
.f-name { font-weight: normal; color: #fff; font-size: 0.74rem; font-family: 'HelveticaBold', sans-serif; letter-spacing: 0.67px; }

/* MOBILE RESPONSIVE */
@media (max-width: 515px) {
    .main-title { font-size: 1.47rem; }
    .content-block { padding: 17px; }
    .org-section { flex-direction: column; text-align: center; padding: 20px; border-left: none; border-top: 3px solid var(--rosa-neon); }
    .fanta-content h3 { font-size: 1.34rem; }
    .talent-card { width: 100%; max-width: 201px; }
}