/* ===========================================================
   CERT.O — Landing webinar
   File convertito da wireframe React a statico (HTML/CSS/JS).
   =========================================================== */
:root{
  --teal:#0196ad;
  --teal-dark:#017a8c;
  --teal-deep:#0e6b78;
  --teal-light:#5abacb;
  --teal-wash:#e9f4f6;
  --magenta:#ec0a7e;
  --magenta-dark:#c80668;
  --navy:#0e2e4f;
  --navy-panel:#2f415c;
  --ink:#13314f;
  --slate:#5b6b7a;
  --gray-bg:#f4f7f8;
  --line:#e2eaec;
  --white:#ffffff;
  --radius:6px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  /* Font del sito: Montserrat per i titoli, Open Sans per il body.
     Identici al wireframe React originale. */
  --head:'Montserrat',system-ui,sans-serif;
  --body:'Open Sans',system-ui,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--head);font-weight:300;color:var(--navy);margin:0;line-height:1.12;letter-spacing:-.01em;}
h2{font-size:clamp(30px,4vw,46px);}
h3{font-size:22px;font-weight:500;}
.eyebrow{
  font-family:var(--body);font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;font-size:12.5px;color:var(--teal);margin:0 0 18px;
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--teal);display:inline-block;}
p{line-height:1.7;color:var(--slate);margin:0 0 16px;font-size:16px;}
.lead{font-size:18px;color:var(--slate);line-height:1.75;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:.06em;
  text-transform:uppercase;border:none;border-radius:var(--radius);
  padding:15px 28px;white-space:nowrap;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s;
}
.btn-primary{background:var(--magenta);color:#fff;box-shadow:0 10px 24px -10px rgba(236,10,126,.6);}
.btn-primary:hover{background:var(--magenta-dark);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(236,10,126,.7);}
.btn-ghost{background:transparent;color:var(--teal);border:1.5px solid var(--teal);}
.btn-ghost:hover{background:var(--teal);color:#fff;transform:translateY(-2px);}
.btn-white{background:#fff;color:var(--navy);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(0,0,0,.4);}
.btn-outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7);}
.btn-outline-white:hover{background:#fff;color:var(--navy);}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand .mark{width:46px;height:46px;flex:none;}
.brand .logo{height:54px;width:auto;flex:none;display:block;}
.brand .name{font-family:var(--head);font-weight:600;color:var(--navy);font-size:18px;line-height:1;letter-spacing:-.01em;}
.brand .name small{display:block;font-weight:400;font-size:9.5px;letter-spacing:.08em;color:var(--teal);text-transform:lowercase;margin-top:2px;}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0;}
.nav-links a{font-size:14.5px;color:var(--ink);font-weight:400;position:relative;padding:6px 0;transition:color .2s;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--teal);transition:width .25s var(--ease);}
.nav-links a:hover{color:var(--teal);}
.nav-links a:hover::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:18px;}
.nav-toggle{display:none;}

/* ---------- Generic section ---------- */
section{position:relative;}
.sec{padding:96px 0;}
.sec-head{margin-bottom:54px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.sec-head.center .eyebrow{justify-content:center;}

/* ---------- HERO base ---------- */
.hero{overflow:hidden;}
.scroll-cue{display:inline-flex;flex-direction:column;align-items:center;gap:10px;margin-top:8px;color:var(--teal);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;}
.scroll-cue .ring{width:42px;height:42px;border-radius:50%;border:1.5px solid currentColor;display:grid;place-items:center;animation:bob 1.8s var(--ease) infinite;}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* Variant B — immersivo: two columns (form left, copy right) */
.hero-b{display:grid;align-items:center;color:#fff;}
/* Immagine di sfondo dell'hero: copre tutta l'area, centrata */
.hero-b .bg{position:absolute;inset:0;z-index:0;overflow:hidden;background:#0e6b78;}
.hero-b .bg image-slot{width:100%;height:100%;}
.hero-b .bg .hero-bg-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}
.hero-b .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(1,150,173,.95) 0%,rgba(1,150,173,.82) 46%,rgba(14,46,79,.72) 100%);}
.hero-b-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:54px;align-items:center;padding:72px 0 80px;}
.hero-b .eyebrow{color:#bfeaf0;}
.hero-b .eyebrow::before{background:#bfeaf0;}
.hero-b-copy h1{color:#fff;font-size:clamp(28px,4.4vw,56px);font-weight:300;margin-bottom:22px;line-height:1.18;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;}
.hero-b-copy h1 b{font-weight:500;}
.hero-b-copy .lead{color:rgba(255,255,255,.92);max-width:520px;font-size:18px;margin-bottom:0;}
.hero-b-points{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:13px;}
.hero-b-points li{display:flex;gap:11px;align-items:flex-start;color:#eafafb;font-size:15.5px;line-height:1.45;}
.hero-b-points .tick{flex:none;width:23px;height:23px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;display:grid;place-items:center;margin-top:1px;}

/* compact hero form card */
.hero-form{padding:30px 30px 28px;box-shadow:0 44px 90px -34px rgba(8,30,52,.62);}
.hero-form .hf-head{margin-bottom:18px;}
.hero-form .hf-head h3{font-size:23px;color:var(--navy);font-weight:600;margin-bottom:6px;}
.hero-form .hf-head p{font-size:13px;line-height:1.5;margin:0;}
.hero-form .field{margin-bottom:13px;}
.hero-form .field input{padding:11px 13px;font-size:14.5px;}
.hero-form .field .msg{min-height:0;font-size:11px;margin-top:4px;}
.hero-form .field .msg:empty{display:none;}
.hero-form .field.row2{gap:12px;}
.hero-form .field label{font-size:11.5px;margin-bottom:6px;}
.hero-form .consent{margin:6px 0 14px;font-size:12px;}
.hero-form .btn{width:100%;padding:14px;font-size:13px;}

/* ---------- Trust strip ---------- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--gray-bg);}
.trust .row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1%;
    flex-wrap: wrap;
    padding: 24px 0;
}
.trust .item{display:flex;align-items:center;gap:12px;color:var(--slate);font-size:13.5px;}
.trust .item b{color:var(--navy);font-weight:600;}
.trust .dotsep{width:5px;height:5px;border-radius:50%;background:var(--teal);}

/* ---------- Vantaggi cards ---------- */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:32px 26px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 44px -26px rgba(14,46,79,.3);border-color:#cfe4e8;}
.card .ico{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;background:var(--teal-wash);color:var(--teal);margin-bottom:22px;transition:background .3s,color .3s;}
.card:hover .ico{background:var(--teal);color:#fff;}
.card h3{margin-bottom:10px;color:var(--navy);}
.card p{font-size:14.5px;margin:0;}
/* variant B cards: teal top accent */
.page[data-variant="b"] .card{border-top:3px solid var(--teal);}

/* ---------- Come funziona (steps) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;counter-reset:step;}
.step{position:relative;padding-top:6px;}
.step .num{font-family:var(--head);font-weight:300;font-size:54px;color:var(--teal-light);line-height:1;margin-bottom:14px;}
.step h3{font-size:18px;margin-bottom:8px;}
.step p{font-size:14.5px;margin:0;}
.step::after{content:"";position:absolute;top:24px;left:54px;right:-13px;height:1px;background:linear-gradient(90deg,var(--line),transparent);}
.step:last-child::after{display:none;}

/* ---------- Criteri (numbered list, like site) ---------- */
.criteria-sec{background:var(--gray-bg);}
.criteria{max-width:760px;}
.crit{display:grid;grid-template-columns:64px 1fr;gap:22px;align-items:start;padding:24px 0;border-bottom:1px solid var(--line);}
.crit:last-child{border-bottom:none;}
.crit .n{font-family:var(--head);font-weight:300;font-size:46px;color:var(--teal);line-height:.9;}
.crit p{margin:0;color:var(--ink);font-size:16.5px;padding-top:6px;}
.crit p a{color:var(--teal);font-weight:600;border-bottom:1px solid currentColor;}

/* ---------- Teal value band ---------- */
.band{background:var(--teal);color:#fff;text-align:center;padding:84px 0;}
.band h2{color:#fff;max-width:840px;margin:0 auto 10px;font-weight:300;}
.band h2 b{font-weight:500;}
.band p{color:rgba(255,255,255,.85);max-width:620px;margin:18px auto 0;}
.band .watermark{position:absolute;right:6%;bottom:-10%;font-family:var(--head);font-weight:300;font-size:280px;color:rgba(255,255,255,.06);pointer-events:none;line-height:1;}

/* ---------- hero meta chips ---------- */
.hero-meta{list-style:none;margin:28px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:10px;}
.hero-meta li{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--navy);background:var(--teal-wash);border-radius:30px;padding:8px 15px;}
.hero-meta li svg{color:var(--teal);}
.hero-meta.light li{color:#fff;background:rgba(255,255,255,.14);}
.hero-meta.light li svg{color:#bfeaf0;}

/* ---------- webinar facts bar ---------- */
.facts-bar{background:var(--navy);color:#fff;}
.facts-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:26px 0;}
.fact{display:flex;align-items:center;gap:14px;padding:6px 8px;}
.fact .fi{width:44px;height:44px;flex:none;border-radius:10px;background:rgba(255,255,255,.08);color:var(--teal-light);display:grid;place-items:center;}
.fact .ft{display:flex;flex-direction:column;line-height:1.3;font-size:15px;}
.fact .ft b{font-family:var(--head);font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-light);margin-bottom:3px;}

/* ---------- programma ---------- */
.prog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.prog-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:34px 32px;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;}
.prog-card:hover{transform:translateY(-5px);box-shadow:0 26px 50px -28px rgba(14,46,79,.32);border-color:#cfe4e8;}
.pc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.pc-num{font-family:var(--head);font-weight:300;font-size:40px;color:var(--teal-light);line-height:1;}
.pc-ico{width:50px;height:50px;border-radius:12px;background:var(--teal-wash);color:var(--teal);display:grid;place-items:center;transition:background .3s,color .3s;}
.prog-card:hover .pc-ico{background:var(--teal);color:#fff;}
.prog-card h3{color:var(--navy);font-size:21px;margin-bottom:10px;}
.prog-card p{font-size:15px;margin:0;}
.prog-card p b{color:var(--navy);font-weight:600;}
.prog-card ul{font-size:16px;color:var(--slate);margin:14px 0 0;padding-left:22px;line-height:1.7;}
.prog-card ul li{margin-bottom:8px;}
.prog-card ul li:last-child{margin-bottom:0;}
.prog-card ul li b{color:var(--navy);font-weight:600;}
.pillars{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.pillars span{font-size:12.5px;font-weight:600;color:var(--teal-deep);background:var(--teal-wash);border-radius:6px;padding:6px 12px;}
.speakers{list-style:none;margin:18px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:9px 18px;}
.speakers li{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:var(--ink);flex-direction:column;}
.speakers .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);flex:none;}

/* ---------- chiusura: fact list aside ---------- */
.fact-list{list-style:none;margin:28px 0 0;padding:0;display:grid;gap:14px;}
.fact-list li{display:flex;align-items:center;gap:13px;color:var(--ink);font-size:15.5px;}
.fact-list .fi{width:42px;height:42px;flex:none;border-radius:10px;background:var(--teal-wash);color:var(--teal);display:grid;place-items:center;}
.fact-list b{display:block;font-family:var(--head);font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:2px;}

/* ---------- 3-column field (città / prov / cap) ---------- */
.field.row3{display:grid;grid-template-columns:1fr 74px 96px;gap:12px;}
.field.row3 input{text-align:left;}

/* ---------- Form ---------- */
.form-sec{background:var(--white);}
.form-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start;}
.form-aside h2{margin-bottom:18px;}
.form-aside .checklist{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:14px;}
.form-aside .checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink);font-size:15px;}
.form-aside .checklist .tick{flex:none;width:22px;height:22px;border-radius:50%;background:var(--teal-wash);color:var(--teal);display:grid;place-items:center;margin-top:1px;}
.form-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:38px;box-shadow:0 30px 60px -40px rgba(14,46,79,.4);}
.field{margin-bottom:18px;}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field label{display:block;font-size:12.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--navy);margin-bottom:7px;}
.field input,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:7px;padding:13px 14px;font-family:var(--body);font-size:15px;color:var(--ink);background:#fcfdfd;transition:border-color .2s,box-shadow .2s;}
.field textarea{resize:vertical;min-height:96px;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(1,150,173,.12);background:#fff;}
.field input.err,.field textarea.err{border-color:var(--magenta);box-shadow:0 0 0 3px rgba(236,10,126,.1);}
.field .msg{color:var(--magenta);font-size:12px;margin-top:6px;display:block;min-height:14px;}
.consent{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--slate);margin:6px 0 22px;}
.consent input{margin-top:3px;width:16px;height:16px;accent-color:var(--teal);flex:none;}
.consent a{color:var(--teal);font-weight:600;}
.form-card .btn{width:100%;padding:17px;font-size:14px;}
/* success */
.form-success{text-align:center;padding:30px 10px;animation:pop .5s var(--ease);}
.form-success .check{width:76px;height:76px;border-radius:50%;background:var(--teal-wash);color:var(--teal);display:grid;place-items:center;margin:0 auto 22px;}
.form-success .check svg{stroke-dasharray:60;stroke-dashoffset:60;animation:draw .7s .15s var(--ease) forwards;}
.form-success h3{font-size:26px;margin-bottom:10px;}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}

/* ---------- Footer (stile sito) ---------- */
.foot{display:grid;grid-template-columns:1fr 1.6fr;}
.foot-contact{background:var(--navy-panel);color:#fff;padding:72px 7% 72px 0;}
.foot-contact-inner{max-width:480px;margin-left:auto;padding-left:28px;}
.foot-contact h2{color:rgba(255,255,255,.5);font-weight:300;font-size:46px;margin-bottom:34px;}
.foot-line{display:flex;align-items:center;gap:16px;color:rgba(255,255,255,.92);font-size:15px;padding:14px 0;}
.foot-line .fi{width:34px;height:34px;flex:none;color:var(--teal-light);display:grid;place-items:center;}
.foot-contact .btn{margin:24px 0 26px;}
.socials{display:flex;gap:12px;}
.socials a{width:42px;height:42px;border:1px solid rgba(255,255,255,.25);border-radius:8px;display:grid;place-items:center;color:#fff;transition:background .2s,border-color .2s,transform .2s;}
.socials a:hover{background:var(--teal);border-color:var(--teal);transform:translateY(-2px);}
.newsletter{display:flex;gap:10px;margin-top:26px;}
.newsletter input{flex:1;background:transparent;border:none;border-bottom:1.5px solid rgba(255,255,255,.3);color:#fff;padding:10px 2px;font-family:var(--body);font-size:14px;}
.newsletter input::placeholder{color:rgba(255,255,255,.5);}
.newsletter input:focus{outline:none;border-color:var(--teal-light);}
.newsletter button{background:var(--magenta);color:#fff;border:none;border-radius:6px;padding:0 20px;font-weight:700;font-size:12px;letter-spacing:.05em;text-transform:uppercase;}
.foot-nav{background:var(--navy);color:#fff;padding:72px 0 0 64px;}
.foot-nav ul{list-style:none;margin:0;padding:0;max-width:420px;}
.foot-nav li a{display:block;padding:16px 0;font-family:var(--head);font-weight:500;letter-spacing:.04em;color:rgba(255,255,255,.82);border-bottom:1px solid rgba(255,255,255,.1);transition:color .2s,padding-left .2s;}
.foot-nav li:first-child a{font-weight:400;color:rgba(255,255,255,.6);}
.foot-nav li a:hover{color:#fff;padding-left:8px;}
.copyright{grid-column:1 / -1;background:var(--navy);color:rgba(255,255,255,.5);font-size:11.5px;text-align:center;padding:22px;border-top:1px solid rgba(255,255,255,.08);}
.copyright a{color:rgba(255,255,255,.7);}

/* ---------- reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .hero-b-grid{grid-template-columns:1fr;gap:34px;padding:48px 0 56px;}
  .hero-b-form{order:2;}
  .hero-b-copy{order:1;margin:0 20px;}
  .form-grid,.foot{grid-template-columns:1fr;}
  .facts-row{grid-template-columns:repeat(2,1fr);gap:16px 8px;}
  .prog-grid{grid-template-columns:1fr;}
  .cards,.steps{grid-template-columns:repeat(2,1fr);}
  .step::after{display:none;}
  .foot-contact{padding:56px 28px;}
  .foot-contact-inner{padding-left:0;}
  .foot-nav{padding:48px 28px;}
  .nav-links{display:none;}
  .nav-toggle{display:grid;}

  /* Margini laterali uniformi su mobile (20px) per allineare i testi */
  .sec-head{padding:0 20px;margin-left:0;margin-right:0;}
  .hero-b-copy p.lead{padding:0;margin:0 0 16px;}
  .hero-b-copy ul.hero-meta{padding:0;margin:28px 0 0;}
  .form-aside{padding:0 20px;}
  .form-aside .fact-list{padding:0;}
  .band h2, .band p{padding:0 20px;}
  .trust{padding-left:20px;padding-right:20px;}
  .prog-card{margin:0 20px;}
  .sec>.wrap{padding-left:20px;padding-right:20px;}
  .foot-contact-inner{padding:0 20px;}
  .foot-nav ul{padding:0 20px;}

  /* Nav mobile: nascondi brand name per dare spazio al bottone */
  .brand .name{display:none;}
  .nav-cta .btn{padding:11px 18px;font-size:12px;white-space:nowrap;}
  .nav-inner{height:64px;gap:12px;}
  .brand .logo{height:42px;}

  /* h1 mobile: più piccolo, word-wrap ok */
  .hero-b-copy h1{font-size:32px;line-height:1.18;letter-spacing:-.005em;word-wrap:break-word;overflow-wrap:break-word;}
  .hero-b-copy .lead{font-size:16px;}

  /* Bottone teal band su mobile */
  .band{padding:64px 0;}
  .band h2{font-size:28px;}
  .band .watermark{font-size:160px;}
}

/* --- Mobile piccolo (≤560px) --- */
@media(max-width:560px){
  .cards,.steps,.field.row2{grid-template-columns:1fr;}
  .speakers{grid-template-columns:1fr;}
  .facts-row{grid-template-columns:1fr;}
  .sec{padding:64px 0;}

  /* Margini uniformi a 20px su tutti i testi */
  .sec-head{padding:0 20px;}
  .hero-b-copy{margin:0 20px;}
  .hero-b-copy h1{padding:0;}
  .hero-b-copy .lead{padding:0;}
  .hero-meta{padding:0 !important;margin:24px 0 0 !important;}
  .form-aside{padding:0 20px;}
  .form-aside .fact-list{padding:0;}
  .form-card{padding:24px 20px;margin:0;}
  .hero-form{padding:24px 20px;margin:0;}
  .prog-card{margin:0 20px;padding:24px 20px;}
  .band h2, .band p{padding:0 20px;}
  .trust{padding:18px 20px;}
  .trust .row{padding:0;}
  .trust{display:none;}
  .foot-contact-inner{padding:0 20px;}
  .foot-nav ul{padding:0 20px;}
  .copyright{padding:18px 20px;}
  .mc-wrap{margin:0;}

  /* Wrap con padding ridotto */
  .wrap{padding:18px;}

  /* Nav ancora più compatto */
  .nav-inner{height:60px;}
  .brand .logo{height:38px;}
  .nav-cta .btn{padding:10px 14px;font-size:11px;}

  /* h1 ancora più piccolo */
  .hero-b-copy h1{font-size:26px;}
  .hero-b-grid{padding:32px 0 40px;}

  /* Card del programma più compatte */
  .prog-card{padding:24px 20px;}
  .pc-num{font-size:32px;}
  .pc-ico{width:42px;height:42px;}

  /* Bottone "Riserva il posto" full-width nel band */
  .band .btn{width:100%;max-width:340px;}

  /* Footer compatto */
  .foot-contact-inner{padding-left:0;}
  .foot-contact h2{font-size:32px;margin-bottom:24px;}
  .foot-nav{padding:32px 18px;}
  .foot-nav li a{padding:12px 0;font-size:14px;}

  /* Trust strip: stack verticale */
  .trust .row{flex-direction:column;gap:12px;padding:18px 0;}
  .trust .item{font-size:13px;}

  /* Form hero/panel */
  .form-card{padding:24px 20px;}
  .hero-form{padding:24px 20px;}

  /* h2 sezioni */
  .sec-head{margin-bottom:32px;}
  h2{font-size:28px;}

  /* Watermark band più piccolo per non sovrapporre */
  .band .watermark{font-size:120px;right:-5%;}

  /* Bottone "Riserva il posto gratuito" */
  .btn{padding:14px 20px;}
}

/* --- Mobile molto piccolo (≤380px) --- */
@media(max-width:380px){
  .hero-b-copy h1{font-size:22px;}
  .brand .logo{height:34px;}
  .nav-cta .btn{padding:9px 12px;font-size:10.5px;}
}

/* ===========================================================
   MAILCHIMP IFRAME — skin CERT.O
   Sovrascrive lo stile classico di Mailchimp per matchare
   il brand (colori, font, bottoni, focus).
   =========================================================== */
.mc-wrap{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:38px;
  box-shadow:0 30px 60px -40px rgba(14,46,79,.4);
  position:relative;
}
.mc-wrap::before{
  content:"Iscriviti al webinar";
  display:block;
  font-family:var(--head);
  font-weight:600;
  font-size:23px;
  color:var(--navy);
  margin-bottom:6px;
}
.mc-wrap::after{
  content:"Webinar gratuito · posti limitati · link di accesso via email";
  display:block;
  font-size:13px;
  color:var(--slate);
  margin-bottom:24px;
  line-height:1.5;
}
.mc-wrap iframe{
  width:100%;
  border:0;
  display:block;
  min-height:620px;
  background:transparent;
}
.mc-loading{
  text-align:center;
  padding:30px 0;
  color:var(--slate);
  font-size:14px;
}
.mc-loading::before{
  content:"";
  display:inline-block;
  width:14px;height:14px;
  border:2px solid var(--teal-light);
  border-top-color:var(--teal);
  border-radius:50%;
  animation:mc-spin .8s linear infinite;
  margin-right:8px;
  vertical-align:middle;
}
@keyframes mc-spin{to{transform:rotate(360deg)}}

/* responsive */
@media(max-width:560px){
  .mc-wrap{padding:24px;}
  .mc-wrap::before{font-size:20px;}
  .mc-wrap iframe{min-height:680px;}
}

/* ===========================================================
   MAILCHIMP SKIN — rende il form identico al wireframe
   Nasconde intestazioni di default, riorganizza in 2-colonne,
   rilabel i campi in italiano, applica i colori del brand.
   =========================================================== */

/* Nascondi elementi di default di Mailchimp */
.mc-wrap #mc_embed_signup_scroll > h2,
.mc-wrap .indicates-required,
.mc-wrap #mc_embed_signup h2,
.mc-wrap div.mc-field-group input[type="text"]#mce-EMAIL + .helper_text,
.mc-wrap #mce-responses,
.mc-wrap .asterisk + .helper_text,
.mc-wrap .brandingLogo,
.mc-wrap #mc_embed_signup .refferal_badge{
  display:none !important;
}

/* Intestazione custom sopra il form (sostituisce l'h2 Mailchimp) */
.mc-wrap::before{
  content:"Riserva il tuo posto";
  display:block;
  font-family:var(--head);
  font-weight:500;
  font-size:23px;
  color:var(--navy);
  margin-bottom:6px;
  letter-spacing:-.01em;
}
.mc-wrap::after{
  content:"Webinar gratuito · posti limitati. Il link di accesso arriverà via email.";
  display:block;
  font-size:13px;
  line-height:1.5;
  color:var(--slate);
  margin:0 0 24px;
}

/* Il blocco del form vero e proprio */
#mc_embed_signup{
  background:transparent !important;
  clear:none !important;
  font:14px 'Open Sans',system-ui,sans-serif !important;
  width:100% !important;
}
#mc_embed_signup_scroll{
  padding:0 !important;
}
#mc_embed_signup form{
  margin:0 !important;
  padding:0 !important;
}
#mc_embed_signup .mc-field-group{
  display:block !important;
  margin-bottom:14px !important;
  padding:0 !important;
  width:100% !important;
}
#mc_embed_signup label{
  display:block !important;
  font-family:var(--head) !important;
  font-size:11.5px !important;
  font-weight:600 !important;
  letter-spacing:.06em !important;
  text-transform:uppercase !important;
  color:var(--navy) !important;
  margin-bottom:6px !important;
  float:none !important;
  width:auto !important;
}
#mc_embed_signup label .asterisk{
  color:var(--magenta) !important;
  margin-left:2px;
}
#mc_embed_signup input[type="email"],
#mc_embed_signup input[type="text"],
#mc_embed_signup input[type="tel"],
#mc_embed_signup input[type="zip"]{
  display:block !important;
  width:100% !important;
  border:1.5px solid var(--line) !important;
  border-radius:7px !important;
  padding:11px 13px !important;
  font-family:'Open Sans',system-ui,sans-serif !important;
  font-size:14.5px !important;
  color:var(--ink) !important;
  background:#fcfdfd !important;
  height:auto !important;
  line-height:1.4 !important;
  box-sizing:border-box !important;
  transition:border-color .2s,box-shadow .2s,background .2s !important;
}
#mc_embed_signup input:focus{
  outline:none !important;
  border-color:var(--teal) !important;
  box-shadow:0 0 0 3px rgba(1,150,173,.12) !important;
  background:#fff !important;
}
#mc_embed_signup .mc-field-group.size1of2,
#mc_embed_signup .mc-field-group.size3of4,
#mc_embed_signup .mc-field-group.size1of3{
  width:100% !important;
  margin-right:0 !important;
  clear:none !important;
  float:none !important;
}

/* Submit button = stile .btn .btn-primary */
#mc_embed_signup #mc-embedded-subscribe,
#mc_embed_signup input.button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:9px !important;
  background:var(--magenta) !important;
  color:#fff !important;
  font-family:'Open Sans',system-ui,sans-serif !important;
  font-weight:700 !important;
  font-size:13px !important;
  letter-spacing:.06em !important;
  text-transform:uppercase !important;
  border:none !important;
  border-radius:6px !important;
  padding:15px 28px !important;
  width:100% !important;
  height:auto !important;
  line-height:1.2 !important;
  cursor:pointer !important;
  margin:18px 0 0 !important;
  box-shadow:0 10px 24px -10px rgba(236,10,126,.6) !important;
  transition:background .2s,transform .25s var(--ease),box-shadow .25s var(--ease) !important;
}
#mc_embed_signup #mc-embedded-subscribe:hover,
#mc_embed_signup input.button:hover{
  background:var(--magenta-dark) !important;
  transform:translateY(-2px) !important;
  box-shadow:0 16px 30px -12px rgba(236,10,126,.7) !important;
}
#mc_embed_signup #mc-embedded-subscribe::after{
  content:" →";
  display:inline-block;
  font-weight:700;
  letter-spacing:0;
}
#mc_embed_signup .clear{
  display:block !important;
  clear:none !important;
  margin:0 !important;
  padding:0 !important;
}

/* Messaggi di errore / successo */
#mc_embed_signup div.mce_inline_error,
#mc_embed_signup .mce_inline_error{
  background:transparent !important;
  color:var(--magenta) !important;
  font-size:12px !important;
  font-weight:400 !important;
  margin-top:4px !important;
  padding:0 !important;
  display:block !important;
  text-align:left !important;
}
#mc_embed_signup div#mce-success-response,
#mc_embed_signup #mce-success-response{
  background:var(--teal-wash) !important;
  color:var(--teal-deep) !important;
  border:1px solid #cfe4e8 !important;
  border-radius:8px !important;
  padding:18px !important;
  font-size:14.5px !important;
  text-align:center !important;
  margin:8px 0 0 !important;
  display:block !important;
  font-weight:600 !important;
}
#mc_embed_signup #mce-error-response{
  background:#fde7ee !important;
  color:var(--magenta-dark) !important;
  border:1px solid #f5b8cf !important;
  border-radius:8px !important;
  padding:12px !important;
  font-size:13.5px !important;
  margin:8px 0 !important;
  display:block !important;
}

/* Nascondi l'honeypot (campo anti-spam) */
#mc_embed_signup div[style*="position: absolute"][style*="left: -5000px"]{
  position:absolute !important;
  left:-5000px !important;
}

/* Responsive: 2-colonne per nome/cognome e città/prov/CAP */
@media(min-width:520px){
  .mc-wrap #mc_embed_signup .mc-field-group.doppia{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:12px !important;
    margin-bottom:14px !important;
  }
  .mc-wrap #mc_embed_signup .mc-field-group.doppia > *{
    display:contents !important;
  }
  .mc-wrap #mc_embed_signup .mc-field-group.tripla{
    display:grid !important;
    grid-template-columns:1fr 70px 95px !important;
    gap:12px !important;
    margin-bottom:14px !important;
  }
  .mc-wrap #mc_embed_signup .mc-field-group.tripla > *{
    display:contents !important;
  }
}

/* Mobile: nessuna multi-colonna */
@media(max-width:519px){
  #mc_embed_signup .mc-field-group,
  #mc_embed_signup .mc-field-group.doppia,
  #mc_embed_signup .mc-field-group.tripla{
    display:block !important;
    margin-bottom:14px !important;
  }
  #mc_embed_signup .mc-field-group.doppia > *,
  #mc_embed_signup .mc-field-group.tripla > *{
    display:block !important;
    margin-bottom:14px !important;
  }
  #mc_embed_signup .mc-field-group.doppia > *:last-child,
  #mc_embed_signup .mc-field-group.tripla > *:last-child{
    margin-bottom:0 !important;
  }
}

/* ===========================================================
   CERT FORM — form custom identico al wireframe
   Stile per .cert-form (form nel hero + form nel pannello iscrizione)
   =========================================================== */

.cert-form .req{
  color:var(--magenta) !important;
  margin-left:2px;
}
.cert-form .opt{
  text-transform:none !important;
  font-weight:400 !important;
  color:var(--slate) !important;
  font-size:11px !important;
  letter-spacing:0 !important;
  font-style:normal;
  margin-left:4px;
}
.cert-form .arr{
  display:inline-block;
  margin-left:6px;
  transform:translateX(0);
  transition:transform .2s var(--ease);
}
.cert-form .btn-primary:hover .arr{
  transform:translateX(3px);
}

/* Status message sopra il bottone */
.form-status{
  display:none;
  margin:0 0 16px;
  padding:12px 14px;
  border-radius:8px;
  font-size:13.5px;
  line-height:1.5;
  font-weight:500;
}
.form-status.error{
  display:block;
  background:#fde7ee;
  color:var(--magenta-dark);
  border:1px solid #f5b8cf;
}
.form-status.loading{
  display:block;
  background:var(--teal-wash);
  color:var(--teal-deep);
  border:1px solid #cfe4e8;
}
.form-status.success{
  display:block;
  background:var(--teal-wash);
  color:var(--teal-deep);
  border:1px solid #cfe4e8;
}

/* Form success state (sostituisce l'intero form) */
.cert-form .form-success{
  text-align:center;
  padding:30px 10px;
  animation:pop .5s var(--ease);
}
.cert-form .form-success .check{
  width:76px;
  height:76px;
  border-radius:50%;
  background:var(--teal-wash);
  color:var(--teal);
  display:grid;
  place-items:center;
  margin:0 auto 22px;
}
.cert-form .form-success .check svg{
  stroke-dasharray:60;
  stroke-dashoffset:60;
  animation:draw .7s .15s var(--ease) forwards;
}
.cert-form .form-success h3{
  font-size:26px;
  margin-bottom:10px;
}
.cert-form .form-success p{
  margin:0;
  color:var(--slate);
}
.cert-form .form-success p b{
  color:var(--navy);
}

/* Consent message inline */
.cert-form .consent .msg{
  color:var(--magenta);
  font-style:normal;
  font-weight:500;
  display:block;
  margin-top:4px;
}

/* Bottone disabilitato */
.cert-form .btn:disabled{
  opacity:.7;
  cursor:not-allowed;
  transform:none !important;
  box-shadow:0 6px 16px -10px rgba(236,10,126,.4) !important;
}

/* Layout identico allo screenshot nel form pannello (più spazioso) */
#certFormPanel.hero-form,
#certFormPanel{
  padding:30px 30px 28px;
}
#certFormPanel.hero-form{
  padding:30px 30px 28px;
}

/* Nel pannello "iscrizione" il form è già dentro .form-card */
.form-sec .cert-form.form-card{
  padding:38px;
}

/* ---------- Speakers con titoli accademici ---------- */
.speakers li small{
  display:block;
  font-size:12px;
  font-weight:400;
  color:var(--slate);
  font-style:italic;
  line-height:1.4;
  margin-top:2px;
}
.speakers li b{
  color:var(--ink);
  font-weight:600;
}

/* ---------- Speakers con titoli accademici ---------- */
.speakers li small{
  display:block;
  font-size:12px;
  font-weight:400;
  color:var(--slate);
  font-style:italic;
  line-height:1.4;
  margin-top:2px;
}
.speakers li b{
  color:var(--ink);
  font-weight:600;
}

#comitato .speakers:first-of-type{
  margin-top:18px;
}
#comitato .speakers + .speakers{
  margin-top:24px;
}
@media(min-width:720px){
  /* Desktop: 2 colonne affiancate */
  #comitato .speakers{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:9px 32px;
  }
  #comitato .speakers + .speakers{
    margin-top:18px;
  }
}
