/* =============================================
   MSP Consulting – Stylesheet
   ============================================= */

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --red:#C8102E;--red-glow:#E8203F;
  --black:#0A0A0A;--dark:#111111;--card:#181818;
  --border:#2a2a2a;--text:#F0F0F0;--muted:#888;
  --font:'Barlow',sans-serif;--font-head:'Barlow Condensed',sans-serif;
}
html{scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--black);color:var(--text);line-height:1.6;overflow-x:hidden;}

/* ─── NAV ─────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(10,10,10,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 5%;}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px;}
.nav-logo{display:flex;align-items:center;text-decoration:none;}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{text-decoration:none;color:var(--muted);font-size:14px;font-weight:500;transition:color 0.2s;}
.nav-links a:hover{color:#fff;}
.nav-btns{display:flex;gap:10px;align-items:center;}
.nav-cta{background:var(--red);color:#fff;padding:8px 20px;border-radius:4px;text-decoration:none;font-size:13px;font-weight:600;transition:background 0.2s;white-space:nowrap;}
.nav-cta:hover{background:var(--red-glow);}
.nav-cta-ghost{background:transparent;border:1px solid var(--border);color:var(--text);padding:8px 16px;border-radius:4px;text-decoration:none;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;white-space:nowrap;transition:border-color 0.2s;}
.nav-cta-ghost:hover{border-color:#666;}

/* ─── HAMBURGER / MOBILE MENU ──────────────── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:transparent;border:none;}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:rgba(10,10,10,0.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:20px 5%;z-index:99;flex-direction:column;}
.mobile-menu a{display:block;padding:14px 0;color:var(--muted);text-decoration:none;font-size:15px;font-weight:500;border-bottom:1px solid var(--border);}
.mobile-menu a:last-child{border-bottom:none;color:var(--red);font-weight:700;}
.mobile-menu.open{display:flex;}

/* ─── HERO ─────────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;padding:80px 5% 60px;position:relative;overflow:hidden;}
.hero-bg{position:absolute;inset:0;opacity:0.07;background-image:radial-gradient(circle at 1px 1px,#C8102E 1px,transparent 0);background-size:40px 40px;}
.hero-line{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--red),transparent);}
.hero-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1;width:100%;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(200,16,46,0.12);border:1px solid rgba(200,16,46,0.3);border-radius:100px;padding:6px 16px;font-size:12px;color:var(--red);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:20px;}
.badge-dot{width:6px;height:6px;background:var(--red);border-radius:50%;animation:pulse 2s infinite;}

@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:0.5;transform:scale(1.3);}
}

h1{font-family:var(--font-head);font-weight:800;font-size:clamp(42px,5vw,64px);line-height:1.05;margin-bottom:20px;}
h1 .accent{color:var(--red);}
.hero-sub{font-size:17px;color:var(--muted);line-height:1.7;margin-bottom:36px;max-width:480px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}
.btn-primary{background:var(--red);color:#fff;padding:14px 28px;border-radius:4px;text-decoration:none;font-weight:600;font-size:15px;transition:all 0.2s;border:none;cursor:pointer;display:inline-block;}
.btn-primary:hover{background:var(--red-glow);transform:translateY(-1px);}
.btn-sec{background:transparent;color:#fff;padding:13px 28px;border-radius:4px;text-decoration:none;font-weight:600;font-size:15px;border:1px solid var(--border);transition:all 0.2s;display:inline-block;}
.btn-sec:hover{border-color:#555;background:rgba(255,255,255,0.04);}

/* Hero card */
.hero-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:28px;position:relative;overflow:hidden;}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--red),transparent);}
.threat-list{list-style:none;display:flex;flex-direction:column;gap:10px;}
.threat-item{display:flex;align-items:center;gap:12px;padding:11px 14px;background:rgba(255,255,255,0.03);border-radius:6px;border:1px solid var(--border);}
.t-ico{width:30px;height:30px;background:rgba(200,16,46,0.15);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.t-lbl{font-size:13px;font-weight:500;flex:1;}
.t-status{font-size:10px;padding:3px 9px;border-radius:100px;font-weight:600;}
.s-ok{background:rgba(34,197,94,0.1);color:#4ade80;border:1px solid rgba(34,197,94,0.2);}
.s-warn{background:rgba(234,179,8,0.1);color:#facc15;border:1px solid rgba(234,179,8,0.2);}
.s-crit{background:rgba(200,16,46,0.15);color:#f87171;border:1px solid rgba(200,16,46,0.3);}
.card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.card-ttl{font-family:var(--font-head);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.card-live{display:flex;align-items:center;gap:6px;font-size:11px;color:#4ade80;}
.live-dot{width:6px;height:6px;background:#4ade80;border-radius:50%;animation:pulse 2s infinite;}

/* ─── STATS ─────────────────────────────────── */
.stats{padding:56px 5%;background:var(--dark);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.stats-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);}
.stat-item{background:var(--dark);padding:28px 20px;text-align:center;}
.stat-num{font-family:var(--font-head);font-size:40px;font-weight:800;color:var(--red);line-height:1;}
.stat-lbl{font-size:12px;color:var(--muted);margin-top:7px;}

/* ─── SECTIONS ──────────────────────────────── */
section{padding:80px 5%;}
.sec{max-width:1200px;margin:0 auto;}
.sec-tag{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:12px;}
h2{font-family:var(--font-head);font-size:clamp(30px,4vw,46px);font-weight:800;line-height:1.1;margin-bottom:16px;}
.sec-sub{font-size:16px;color:var(--muted);max-width:560px;line-height:1.75;}

/* ─── SERVIZI ──────────────────────────────── */
#servizi{background:var(--black);}
.svc-magazine{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px;}
.svc-mag-card{background:var(--dark);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:transform 0.25s,border-color 0.25s;display:flex;flex-direction:column;}
.svc-mag-card:hover{transform:translateY(-4px);border-color:rgba(200,16,46,0.45);}
.svc-mag-img{position:relative;height:170px;overflow:hidden;background:#0d0d0d;}
.svc-mag-img img{width:100%;height:100%;object-fit:cover;opacity:0.82;transition:opacity 0.3s;}
.svc-mag-card:hover .svc-mag-img img{opacity:1;}
.svc-mag-img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(10,10,10,0.92) 100%);}
.svc-mag-body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column;}
.svc-mag-title{font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:10px;line-height:1.1;}
.svc-mag-desc{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:14px;}
.svc-mag-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.svc-mag-list li{font-size:12px;color:var(--muted);display:flex;align-items:flex-start;gap:7px;}
.svc-mag-list li::before{content:'→';color:var(--red);flex-shrink:0;}
.svc-mag-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto;}
.svc-mag-tag{font-size:11px;padding:3px 9px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:100px;color:var(--muted);}

/* ─── ASSESSMENT ────────────────────────────── */
#assessment{background:var(--dark);border-top:1px solid var(--border);}
.proc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:48px;}
.proc-step{text-align:center;padding:22px 10px;position:relative;}
.proc-step:not(:last-child)::after{content:'→';position:absolute;right:-8px;top:28px;color:var(--red);font-size:17px;}
.step-n{width:50px;height:50px;border-radius:50%;background:rgba(200,16,46,0.1);border:2px solid var(--red);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:19px;font-weight:800;color:var(--red);margin:0 auto 14px;}
.step-t{font-size:13px;font-weight:700;margin-bottom:7px;}
.step-d{font-size:12px;color:var(--muted);line-height:1.6;}

/* ─── PERCHE ────────────────────────────────── */
#perche{background:var(--black);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;margin-top:48px;}
.why-pts{display:flex;flex-direction:column;gap:14px;}
.why-pt{display:flex;gap:14px;padding:18px;background:var(--dark);border:1px solid var(--border);border-radius:8px;transition:border-color 0.2s;}
.why-pt:hover{border-color:rgba(200,16,46,0.4);}
.why-ico{width:38px;height:38px;background:rgba(200,16,46,0.1);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.why-pt h3{font-size:14px;font-weight:600;margin-bottom:3px;}
.why-pt p{font-size:13px;color:var(--muted);line-height:1.6;}
.cta-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:38px;position:relative;overflow:hidden;}
.cta-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--red);}
.cta-box h3{font-family:var(--font-head);font-size:26px;font-weight:800;margin-bottom:12px;}
.cta-box p{color:var(--muted);font-size:14px;line-height:1.7;margin-bottom:22px;}
.comp-bdgs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:26px;}
.cbdg{font-size:11px;padding:5px 12px;background:rgba(200,16,46,0.08);border:1px solid rgba(200,16,46,0.2);border-radius:4px;color:#f87171;font-weight:600;}

/* ─── TICKET ────────────────────────────────── */
.ticket-sec{padding:60px 5%;background:var(--black);border-top:1px solid var(--border);}
.ticket-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.ticket-steps{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:32px;position:relative;overflow:hidden;}
.ticket-steps::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--red);}
.ticket-step-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px;}
.ticket-step-item:last-child{margin-bottom:0;}
.step-circle{width:36px;height:36px;border-radius:50%;background:rgba(200,16,46,0.1);border:2px solid var(--red);display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;color:var(--red);font-size:15px;flex-shrink:0;}

/* ─── CONTATTI ──────────────────────────────── */
#contatti{background:var(--dark);border-top:1px solid var(--border);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:48px;}
.contact-form{background:var(--black);border:1px solid var(--border);border-radius:12px;padding:34px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-grp{display:flex;flex-direction:column;gap:7px;margin-bottom:14px;}
label{font-size:12px;font-weight:600;letter-spacing:0.3px;color:var(--muted);}
input,textarea,select{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:6px;padding:11px 13px;color:var(--text);font-family:var(--font);font-size:14px;transition:border-color 0.2s;outline:none;width:100%;}
input:focus,textarea:focus,select:focus{border-color:var(--red);}
select option{background:var(--dark);}
textarea{resize:vertical;min-height:100px;}
.contact-info{display:flex;flex-direction:column;gap:24px;justify-content:center;}
.info-item{display:flex;gap:14px;align-items:flex-start;}
.info-ico{width:42px;height:42px;background:rgba(200,16,46,0.1);border:1px solid rgba(200,16,46,0.2);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.info-item h4{font-size:13px;font-weight:600;margin-bottom:3px;}
.info-item p{font-size:13px;color:var(--muted);line-height:1.6;}
.info-item a{color:var(--red);text-decoration:none;}
.info-item a:hover{text-decoration:underline;}

/* ─── FOOTER ────────────────────────────────── */
footer{background:var(--black);border-top:1px solid var(--border);padding:40px 5%;}
.ft-inner{max-width:1200px;margin:0 auto;}
.ft-top{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:32px;margin-bottom:32px;}
.ft-brand p{font-size:13px;color:var(--muted);margin-top:8px;max-width:240px;line-height:1.6;}
.ft-col h5{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:12px;}
.ft-col a{display:block;font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:7px;transition:color 0.2s;}
.ft-col a:hover{color:#fff;}
.ft-bottom{border-top:1px solid var(--border);padding-top:22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.ft-copy{font-size:12px;color:var(--muted);}
.ft-legal{display:flex;gap:18px;}
.ft-legal a{font-size:12px;color:var(--muted);text-decoration:none;}
.ft-legal a:hover{color:#fff;}

/* ─── RESPONSIVE ─────────────────────────────── */
@media(max-width:960px){
  .nav-links{display:none;}
  .stats-inner{grid-template-columns:repeat(2,1fr);}
  .svc-magazine{grid-template-columns:1fr 1fr;}
  .proc-grid{grid-template-columns:repeat(3,1fr);}
  .proc-step:not(:last-child)::after{content:none;}
}
@media(max-width:600px){
  .nav-links{display:none;}
  .nav-btns{display:none !important;}
  .hamburger{display:flex !important;}
  .hero{padding:80px 4% 40px;}
  .hero-inner{grid-template-columns:1fr;}
  .hero-visual{display:none;}
  h1{font-size:clamp(30px,8vw,42px);}
  .hero-sub{font-size:15px;}
  .hero-actions{flex-direction:column;}
  .hero-actions a{text-align:center;width:100%;box-sizing:border-box;}
  .stats-inner{grid-template-columns:repeat(2,1fr);}
  .svc-magazine{grid-template-columns:1fr;}
  .proc-grid{grid-template-columns:1fr 1fr;}
  .proc-step:not(:last-child)::after{content:none;}
  .why-grid{grid-template-columns:1fr;}
  .ticket-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .ft-top{flex-direction:column;gap:24px;}
  .ft-bottom{flex-direction:column;text-align:center;}
  .ft-legal{justify-content:center;}
  section{padding:60px 4%;}
  .ticket-sec{padding:40px 4%;}
}

/* ─── NAV ACTIVE ────────────────────────────── */
.nav-links a.nav-active{color:#fff;}

/* ─── PAGE HERO (pagine interne) ─────────────── */
.page-hero{padding:140px 5% 80px;background:var(--black);position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;opacity:0.05;background-image:radial-gradient(circle at 1px 1px,#C8102E 1px,transparent 0);background-size:40px 40px;}
.page-hero-line{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--red),transparent);}
.page-h1{font-family:var(--font-head);font-weight:800;font-size:clamp(36px,4.5vw,58px);line-height:1.05;margin-bottom:18px;margin-top:10px;}
.page-h1 .accent{color:var(--red);}
.page-hero-sub{font-size:17px;color:var(--muted);line-height:1.75;max-width:600px;}

/* ─── CHI SIAMO ──────────────────────────────── */
.two-col-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.mission-values{display:flex;flex-direction:column;gap:14px;}
.mv-item{display:flex;gap:14px;padding:18px;background:var(--black);border:1px solid var(--border);border-radius:8px;transition:border-color 0.2s;}
.mv-item:hover{border-color:rgba(200,16,46,0.4);}
.mv-ico{width:38px;height:38px;background:rgba(200,16,46,0.1);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.mv-item h4{font-size:14px;font-weight:600;margin-bottom:3px;}
.mv-item p{font-size:13px;color:var(--muted);line-height:1.6;}
.approach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.approach-card{background:var(--dark);border:1px solid var(--border);border-radius:10px;padding:24px;transition:border-color 0.2s;}
.approach-card:hover{border-color:rgba(200,16,46,0.4);}
.approach-num{font-family:var(--font-head);font-size:40px;font-weight:800;color:rgba(200,16,46,0.2);line-height:1;margin-bottom:12px;}
.approach-card h3{font-size:15px;font-weight:700;margin-bottom:10px;}
.approach-card p{font-size:13px;color:var(--muted);line-height:1.65;}
.cert-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.cert-badge{background:var(--black);border:1px solid var(--border);border-radius:10px;padding:20px;display:flex;flex-direction:column;gap:10px;}
.cert-badge .cbdg{align-self:flex-start;}
.cert-badge p{font-size:13px;color:var(--muted);line-height:1.55;}

/* ─── SERVIZI (pagina dedicata) ──────────────── */
.svc-index{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px;}
.svc-index-item{font-size:13px;font-weight:600;padding:8px 16px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:4px;text-decoration:none;color:var(--muted);transition:all 0.2s;}
.svc-index-item:hover{border-color:var(--red);color:#fff;}
.svc-page-sec{padding:80px 5%;}
.svc-dark{background:var(--dark);border-top:1px solid var(--border);}
.svc-black{background:var(--black);border-top:1px solid var(--border);}
.svc-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.svc-reverse{direction:rtl;}
.svc-reverse>*{direction:ltr;}
.svc-page-img{border-radius:12px;overflow:hidden;border:1px solid var(--border);}
.svc-page-img img{width:100%;height:100%;object-fit:cover;display:block;}
.svc-num{font-family:var(--font-head);font-size:64px;font-weight:800;color:rgba(200,16,46,0.12);line-height:1;display:block;margin-bottom:-8px;}
.svc-page-desc{font-size:15px;color:var(--muted);line-height:1.8;margin:16px 0 20px;}
.svc-page-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.svc-page-list li{font-size:14px;color:var(--muted);display:flex;align-items:flex-start;gap:8px;}
.svc-page-list li::before{content:'→';color:var(--red);flex-shrink:0;}

/* VA steps inline */
.va-steps{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:20px;padding:16px;background:rgba(200,16,46,0.05);border:1px solid rgba(200,16,46,0.15);border-radius:8px;}
.va-step{display:flex;flex-direction:column;align-items:center;gap:4px;}
.va-n{width:28px;height:28px;border-radius:50%;background:rgba(200,16,46,0.15);border:1px solid var(--red);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--red);}
.va-step span:last-child{font-size:10px;color:var(--muted);white-space:nowrap;}
.va-arrow{color:var(--red);font-size:14px;}

/* Proattiva visual (usa gli stessi stili hero-card) */
.svc-page-img-proattiva{background:var(--dark);display:flex;align-items:center;justify-content:center;min-height:340px;}
.proattiva-visual{width:100%;padding:24px;}
.proattiva-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px;position:relative;overflow:hidden;}
.proattiva-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--red),transparent);}

/* ─── CONTATTI (pagina dedicata) ─────────────── */
.quick-contacts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);}
.qc-item{background:var(--dark);padding:20px 24px;display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--text);transition:background 0.2s;}
.qc-item:hover{background:rgba(200,16,46,0.05);}
.qc-label{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:0.5px;margin-bottom:2px;}
.qc-value{font-size:14px;font-weight:600;color:var(--red);}

/* ─── RESPONSIVE pagine interne ─────────────── */
@media(max-width:960px){
  .two-col-grid{grid-template-columns:1fr;}
  .approach-grid{grid-template-columns:repeat(2,1fr);}
  .cert-grid{grid-template-columns:repeat(2,1fr);}
  .svc-page-grid{grid-template-columns:1fr;}
  .svc-reverse{direction:ltr;}
  .quick-contacts{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .page-hero{padding:100px 4% 60px;}
  .page-h1{font-size:clamp(28px,8vw,38px);}
  .approach-grid{grid-template-columns:1fr;}
  .cert-grid{grid-template-columns:1fr;}
  .svc-index{gap:8px;}
  .quick-contacts{grid-template-columns:1fr 1fr;}
  .va-steps{display:none;}
}
