/* ============================================
   about-me.css — electrONIK Lab
   Stili specifici per la pagina "Chi sono".
   Usa le variabili CSS definite in main.css.
   Creato: 2026-04-16
   ============================================ */

/* ========== CONTAINER GENERICO ========== */
.am-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
}

/* ========== SEZIONI ========== */
.am-section{
  position:relative;
  z-index:2;
  padding:100px 40px;
}
.am-section-alt{background:var(--bg2)}

.section-sub{
  color:var(--text2);
  font-size:1.05rem;
  max-width:700px;
  margin:16px auto 0;
  line-height:1.7;
}

/* ========== HERO ========== */
.am-hero{
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:140px 40px 80px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 20% 10%,rgba(44,232,165,.08),transparent 50%),
    radial-gradient(circle at 80% 60%,rgba(91,107,158,.06),transparent 55%),
    var(--bg);
}

.am-hero-grid{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:80px;
  align-items:center;
  position:relative;
  z-index:2;
  width:100%;
}

.am-hero-title{
  font-family:'Orbitron',sans-serif;
  font-size:clamp(2.2rem,5.5vw,3.8rem);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-.02em;
  margin:16px 0 8px;
}
.am-hero-title .highlight{
  background:linear-gradient(135deg,var(--green),var(--green2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.am-hero-role{
  font-family:'Share Tech Mono',monospace;
  color:var(--blue);
  font-size:1rem;
  letter-spacing:2px;
  margin:0 0 28px;
}

.am-hero-lede{
  font-size:1.2rem;
  line-height:1.5;
  color:var(--text);
  margin:0 0 14px;
}

.am-hero-sub{
  color:var(--text2);
  font-size:1rem;
  line-height:1.7;
  margin:0 0 32px;
  max-width:560px;
}

.am-hero-ctas{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

/* Foto profilo */
.am-hero-photo{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:32px;
}

.am-photo-frame{
  position:relative;
  width:300px;
  height:300px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--blue));
  padding:4px;
  overflow:hidden;
  box-shadow:0 0 60px rgba(44,232,165,.2);
  animation:amFloat 6s ease-in-out infinite;
}
@keyframes amFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}
.am-photo-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:50%;
  display:block;
  background:var(--card2);
}
.am-photo-fallback{
  position:absolute;
  inset:4px;
  display:none;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--card2);
  color:var(--green);
  font-family:'Orbitron',sans-serif;
  font-size:5.5rem;
  font-weight:800;
  letter-spacing:-2px;
}
.am-photo-frame.no-photo .am-photo-fallback{display:flex}

/* Stats */
.am-stats{
  display:flex;
  gap:40px;
  justify-content:center;
  flex-wrap:wrap;
}
.am-stat{text-align:center;min-width:80px}
.am-stat-num{
  display:block;
  font-family:'Orbitron',sans-serif;
  font-size:2.4rem;
  font-weight:700;
  color:var(--green);
  line-height:1;
}
.am-stat-label{
  display:block;
  font-family:'Share Tech Mono',monospace;
  font-size:.75rem;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:2px;
  margin-top:8px;
}

/* ========== PROSE (bio) ========== */
.am-prose{
  max-width:780px;
  margin:0 auto;
  font-size:1.05rem;
  line-height:1.85;
  color:var(--text);
}
.am-prose p{margin:0 0 1.25rem}
.am-prose strong{color:var(--green)}

.am-quote{
  margin:2rem 0;
  padding:1.5rem 1.75rem;
  border-left:3px solid var(--green);
  background:rgba(44,232,165,.04);
  border-radius:0 var(--radius) var(--radius) 0;
  font-size:1.15rem;
  font-style:italic;
  color:var(--text);
}

.am-highlight{
  font-size:1.2rem!important;
  color:var(--green);
  font-weight:600;
  border-left:3px solid var(--green);
  padding-left:1rem;
  margin:2rem 0!important;
  font-family:'Orbitron',sans-serif;
  letter-spacing:.5px;
}

/* ========== SERVICES (3 cards) ========== */
.am-services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
  max-width:1100px;
  margin:0 auto;
}
.am-service-card{
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:36px 28px;
  transition:all .4s cubic-bezier(.23,1,.32,1);
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(10px);
}
.am-service-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--green),var(--green2));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s;
}
.am-service-card:hover{
  transform:translateY(-6px);
  border-color:var(--border);
  box-shadow:0 20px 50px rgba(0,0,0,.4),0 0 30px var(--green-glow);
}
.am-service-card:hover::before{transform:scaleX(1)}
.am-service-icon{font-size:2.2rem;margin-bottom:16px;display:block}
.am-service-card h3{
  font-family:'Orbitron',sans-serif;
  font-size:1.05rem;
  font-weight:700;
  margin:0 0 14px;
  color:var(--text);
}
.am-service-card p{
  color:var(--text2);
  font-size:.95rem;
  line-height:1.7;
  margin:0;
}
.am-service-card strong{color:var(--green)}

/* ========== SKILLS ========== */
.am-skills-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;
  max-width:1100px;
  margin:0 auto;
}
.am-skill-group{
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:28px 24px;
  backdrop-filter:blur(10px);
}
.am-skill-title{
  font-family:'Orbitron',sans-serif;
  font-size:1rem;
  font-weight:600;
  margin:0 0 20px;
  padding-bottom:12px;
  border-bottom:1px solid var(--border2);
  color:var(--text);
}
.am-skill-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.am-skill-list li{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  color:var(--text2);
  font-size:.92rem;
}
.am-skill-list em{
  font-style:normal;
  font-family:'Share Tech Mono',monospace;
  font-size:.7rem;
  padding:3px 10px;
  border-radius:4px;
  letter-spacing:1px;
  text-transform:uppercase;
  flex-shrink:0;
}
.lv-5{background:rgba(44,232,165,.15);color:var(--green);border:1px solid var(--border)}
.lv-4{background:rgba(91,107,158,.15);color:var(--blue);border:1px solid rgba(91,107,158,.3)}
.lv-3{background:rgba(138,158,146,.1);color:var(--text3);border:1px solid rgba(138,158,146,.2)}

/* ========== TIMELINE ORIZZONTALE ========== */
.am-swipe-hint{
  font-family:'Share Tech Mono',monospace;
  font-size:.8rem;
  color:var(--text3);
  letter-spacing:2px;
}
.am-timeline-wrapper{
  position:relative;
  max-width:1200px;
  margin:0 auto;
}
.am-timeline-track{
  display:flex;
  gap:20px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:30px 4px 40px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--green) var(--card2);
}
.am-timeline-track::-webkit-scrollbar{height:8px}
.am-timeline-track::-webkit-scrollbar-track{background:var(--card2);border-radius:4px}
.am-timeline-track::-webkit-scrollbar-thumb{
  background:linear-gradient(90deg,var(--green),var(--green2));
  border-radius:4px;
}
.am-timeline-track:focus-visible{
  outline:2px solid var(--green);
  outline-offset:4px;
  border-radius:var(--radius);
}
.am-tl-item{
  flex:0 0 280px;
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:24px;
  scroll-snap-align:start;
  transition:all .3s;
  backdrop-filter:blur(10px);
}
.am-tl-item:hover{
  transform:translateY(-4px);
  border-color:var(--border);
}
.am-tl-highlight{
  background:linear-gradient(135deg,rgba(44,232,165,.06),rgba(91,107,158,.06));
  border-color:var(--green);
}
.am-tl-year{
  font-family:'Orbitron',sans-serif;
  color:var(--green);
  font-size:1.5rem;
  font-weight:700;
  margin-bottom:8px;
}
.am-tl-item h4{
  font-family:'Orbitron',sans-serif;
  font-size:.95rem;
  font-weight:600;
  margin:0 0 10px;
  color:var(--text);
}
.am-tl-item p{
  color:var(--text2);
  font-size:.85rem;
  line-height:1.6;
  margin:0;
}
.am-timeline-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--green);
  font-size:1.4rem;
  cursor:pointer;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:3;
  transition:all .2s;
}
.am-timeline-nav:hover{
  background:var(--green);
  color:var(--bg);
}
.am-tl-prev{left:-10px}
.am-tl-next{right:-10px}
@media(min-width:768px){
  .am-timeline-nav{display:flex}
}

/* ========== CASES ========== */
.am-cases-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  max-width:1100px;
  margin:0 auto 30px;
}
.am-case{
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:28px 24px;
  transition:all .3s;
  backdrop-filter:blur(10px);
}
.am-case:hover{
  transform:translateY(-4px);
  border-color:var(--green);
}
.am-case-tag{
  display:inline-block;
  font-family:'Share Tech Mono',monospace;
  font-size:.7rem;
  padding:4px 10px;
  background:rgba(44,232,165,.1);
  color:var(--green);
  border:1px solid var(--border);
  border-radius:4px;
  margin-bottom:16px;
  letter-spacing:1px;
  text-transform:uppercase;
}
.am-case h3{
  font-family:'Orbitron',sans-serif;
  font-size:1rem;
  font-weight:700;
  margin:0 0 12px;
  color:var(--text);
}
.am-case p{
  color:var(--text2);
  font-size:.92rem;
  line-height:1.7;
  margin:0;
}
.am-case strong{color:var(--green)}
.am-cases-closing{
  text-align:center;
  font-size:1.05rem;
  color:var(--text2);
  margin-top:30px;
  font-style:italic;
}
.am-cases-closing strong{color:var(--green)}

/* ========== STEPS ========== */
.am-steps{
  list-style:none;
  padding:0;
  margin:0 auto;
  max-width:1100px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px;
}
.am-step{
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:28px 24px;
  transition:all .3s;
  backdrop-filter:blur(10px);
}
.am-step:hover{
  border-color:var(--blue);
  transform:translateY(-3px);
}
.am-step-num{
  font-family:'Orbitron',sans-serif;
  font-size:2rem;
  font-weight:800;
  background:linear-gradient(135deg,var(--green),var(--blue));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:12px;
  letter-spacing:-1px;
}
.am-step h3{
  font-family:'Orbitron',sans-serif;
  font-size:.95rem;
  font-weight:600;
  margin:0 0 10px;
  color:var(--text);
}
.am-step p{
  color:var(--text2);
  font-size:.88rem;
  line-height:1.7;
  margin:0;
}

/* ========== VALORI ========== */
.am-values-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  max-width:1100px;
  margin:0 auto;
}
.am-value{
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:32px 28px;
  transition:all .3s;
  backdrop-filter:blur(10px);
}
.am-value:hover{
  border-color:var(--green);
  transform:translateY(-3px);
}
.am-value-mark{
  width:44px;
  height:44px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:var(--bg);
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  font-size:1.3rem;
}
.am-value h3{
  font-family:'Orbitron',sans-serif;
  font-size:1rem;
  font-weight:700;
  margin:0 0 12px;
  color:var(--text);
  line-height:1.4;
}
.am-value p{
  color:var(--text2);
  font-size:.92rem;
  line-height:1.75;
  margin:0;
}

/* ========== CTA FINALE ========== */
.am-cta-final{
  background:
    radial-gradient(circle at 50% 0%,rgba(44,232,165,.08),transparent 60%),
    var(--bg);
}
.am-cta-box{
  max-width:900px;
  margin:0 auto;
  text-align:center;
}
.am-cta-lede{
  color:var(--text2);
  font-size:1.1rem;
  margin:20px auto 40px;
  max-width:680px;
  line-height:1.7;
}
.am-cta-lede strong{color:var(--green)}
.am-contact-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:16px;
  margin-bottom:36px;
}
.am-contact-card{
  background:var(--card);
  border:1px solid var(--border2);
  border-radius:12px;
  padding:24px 16px;
  text-decoration:none;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:center;
  transition:all .3s;
  color:var(--text)!important;
  backdrop-filter:blur(10px);
}
.am-contact-card:hover{
  transform:translateY(-4px);
  border-color:var(--green);
  box-shadow:0 8px 24px rgba(44,232,165,.1);
}
.am-contact-icon{font-size:1.8rem;margin-bottom:4px}
.am-contact-label{
  font-family:'Share Tech Mono',monospace;
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--text3);
}
.am-contact-value{
  font-family:'Rajdhani',sans-serif;
  font-size:.9rem;
  font-weight:600;
  color:var(--text);
  word-break:break-word;
  text-align:center;
}
.am-cta-closing{
  font-size:1rem;
  color:var(--text2);
  margin-top:16px;
  line-height:1.7;
}
.am-cta-closing strong{color:var(--green)}

/* ========== NAV: active state per About Us ========== */
.nav-links a.active{color:var(--green)}
.nav-links a.active::after{width:100%}

/* ========== RESPONSIVE ========== */
@media(max-width:960px){
  .am-hero{padding:120px 24px 60px}
  .am-hero-grid{grid-template-columns:1fr;gap:50px;text-align:center}
  .am-hero-ctas{justify-content:center}
  .am-hero-sub{margin-left:auto;margin-right:auto}
  .am-section{padding:70px 24px}
  .am-container{padding:0 24px}
}
@media(max-width:768px){
  .am-hero-title{font-size:2.2rem}
  .am-photo-frame{width:240px;height:240px}
  .am-photo-fallback{font-size:4rem}
  .am-stat-num{font-size:1.8rem}
  .am-stats{gap:24px}
  .am-tl-item{flex:0 0 250px}
  .am-prose{font-size:1rem}
  .am-quote{font-size:1rem;padding:1.2rem 1.4rem}
  .am-highlight{font-size:1rem!important}
}
@media(max-width:480px){
  .am-photo-frame{width:200px;height:200px}
  .am-photo-fallback{font-size:3.2rem}
  .am-contact-grid{grid-template-columns:1fr}
}
