/*
Theme Name: IO CABLO
Theme URI: https://www.iocablo.com
Author: Io Misuro di Magarò Dionigi
Author URI: https://www.iomisuro.com
Description: Tema custom — Brand di Io Misuro per l'installazione di reti dati e cablaggio strutturato.
Version: 2.8-debug-v3
Text Domain: iocablo
*/

@import url('https://fonts.googleapis.com/css2?family=Antonio:wght@400;600;700&family=Bricolage+Grotesque:opsz,wght@12..96,300;400;500;600&display=swap');

:root {
  --blue: #1050E8;
  --blue-light: #3A6FFF;
  --blue-pale: #EBF0FF;
  --yellow: #FFC000;
  --ink: #0C1428;
  --ink-mid: #2E3A55;
  --ink-soft: #5A6880;
  --white: #FFFFFF;
  --off-white: #F5F7FC;
  --line: #DDE3F0;
  --font-display: 'Antonio', sans-serif;
  --font-body: 'Bricolage Grotesque', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--off-white); }
::-webkit-scrollbar-thumb { background: var(--blue); border-radius: 2px; }

body {
  font-family: var(--font-body);
  background: var(--white);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
  border-top: 4px solid var(--yellow);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

p, li, input, textarea, label { font-size: 15px; line-height: 1.65; }
a { text-underline-offset: 2px; }

/* ─── UTILITIES ─── */
.container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }
.tag {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--blue);
  background: var(--blue-pale);
  padding: 4px 12px;
  border-radius: 2px;
  margin-bottom: 20px;
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--ink);
  margin-bottom: 16px;
}

/* ─── HERO ANIMAZIONI ─── */

/* ─── STRIP IO MISURO ─── */
.iomisuro-strip {
  background: var(--off-white);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 0;
}
.iomisuro-strip-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.iomisuro-strip-left {
  display: flex;
  align-items: center;
  gap: 20px;
}
.iomisuro-strip-bar {
  width: 3px;
  height: 48px;
  background: var(--yellow);
  flex-shrink: 0;
}
.iomisuro-strip-label {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 4px;
}
.iomisuro-strip-brand {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--ink);
}
.iomisuro-strip-brand span { color: var(--blue); }
.iomisuro-strip-desc {
  font-size: 14px;
  color: var(--ink-soft);
  margin-top: 3px;
  max-width: 480px;
  line-height: 1.5;
}
.iomisuro-strip-cta {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  border: 1px solid var(--ink);
  color: var(--ink);
  padding: 12px 22px;
  border-radius: 2px;
  white-space: nowrap;
  transition: all .2s;
  text-decoration: none;
  flex-shrink: 0;
}
.iomisuro-strip-cta:hover { background: var(--ink); color: var(--white); }

/* ─── HEADER ─── */
header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--ink);
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: 16px;
}
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}
.header-tagline {
  font-family: var(--font-body);
  font-size: 13px;
  color: rgba(255,255,255,.5);
  letter-spacing: .04em;
  display: none;
}
@media (min-width: 900px) { .header-tagline { display: block; } }

/* Nav desktop */
.nav-desktop {
  display: none;
  align-items: center;
  gap: 0;
}
@media (min-width: 768px) { .nav-desktop { display: flex; } }
.nav-desktop a {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
  text-decoration: none;
  margin-left: 28px;
  transition: color .2s;
  border-bottom: 2px solid transparent;
  padding-bottom: 2px;
}
.nav-desktop a:hover,
.nav-desktop a.active { color: var(--white); border-bottom-color: var(--blue-light); }
.nav-cta {
  font-family: var(--font-display);
  font-size: 13px !important;
  letter-spacing: .05em;
  background: var(--blue) !important;
  color: var(--white) !important;
  padding: 8px 18px;
  border-radius: 3px;
  transition: background .2s !important;
  text-decoration: none;
}
.nav-cta:hover { background: var(--blue-light) !important; }

/* Hamburger mobile */
.nav-toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  flex-shrink: 0;
}
@media (min-width: 768px) { .nav-toggle { display: none; } }
.nav-toggle span {
  display: block;
  width: 100%;
  height: 2px;
  background: rgba(255,255,255,.7);
  border-radius: 2px;
  transition: all .25s;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Menu mobile overlay */
.nav-mobile {
  display: none;
  position: fixed;
  inset: 64px 0 0 0;
  background: var(--ink);
  z-index: 99;
  flex-direction: column;
  padding: 32px 24px;
  gap: 8px;
  border-top: 1px solid rgba(255,255,255,.07);
}
.nav-mobile.open { display: flex; }
.nav-mobile a {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: .04em;
  color: rgba(255,255,255,.7);
  text-decoration: none;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  transition: color .2s;
}
.nav-mobile a:hover { color: var(--white); }
.nav-mobile .nav-cta {
  margin-top: 16px;
  font-size: 16px !important;
  padding: 14px 24px;
  text-align: center;
  border-radius: 4px;
  border: none;
}

.dark-grid { position: relative; }
.dark-grid::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
  z-index: 1;
}
/* Il canvas hero sta a z-index 1, il before anche — ma il canvas viene prima nel DOM
   quindi il before si sovrappone correttamente. Per le altre sezioni dark-grid
   il contenuto deve stare sopra la griglia */
.comelavoriamo.dark-grid > .container,
.contatti.dark-grid > .container { position: relative; z-index: 2; }

/* ─── HERO ─── */
.hero {
  background: var(--ink);
  padding: 110px 0 90px;
  position: relative;
  overflow: hidden;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 100% at 30% 50%, rgba(12,20,40,.85) 30%, rgba(12,20,40,.55) 100%);
  z-index: 2;
}
.hero-inner { position: relative; z-index: 3; max-width: 680px; }
.hero-eyebrow {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--yellow);
  margin-bottom: 28px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 2px;
  background: var(--yellow);
}
.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(42px, 6.5vw, 80px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -.02em;
  color: var(--white);
  margin-bottom: 24px;
}
.hero h1 em {
  font-style: normal;
  color: var(--blue-light);
}
.hero p {
  font-size: 18px;
  font-weight: 300;
  color: rgba(255,255,255,.75);
  max-width: 520px;
  margin-bottom: 40px;
  line-height: 1.65;
}
.btn-group { display: flex; gap: 14px; flex-wrap: wrap; }
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: .07em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 14px 28px;
  border-radius: 3px;
  transition: all .2s;
  font-weight: 600;
}
.btn-primary {
  background: var(--blue);
  color: var(--white);
}
.btn-primary:hover { background: var(--blue-light); transform: translateY(-1px); }
.btn-ghost {
  background: transparent;
  color: rgba(255,255,255,.85);
  border: 1px solid rgba(255,255,255,.35);
}
.btn-ghost:hover { border-color: rgba(255,255,255,.7); color: var(--white); }
.btn-dark {
  background: var(--ink);
  color: var(--white);
  border: 1px solid rgba(255,255,255,.1);
}
.btn-dark:hover { background: var(--ink-mid); }

/* ─── CHI SIAMO ─── */
.chisiamo {
  padding: 96px 0;
  background: var(--white);
  border-bottom: 1px solid var(--line);
}
.chisiamo-inner {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 768px) {
  .chisiamo-inner { grid-template-columns: 1fr; gap: 32px; }
}
.chisiamo-right p {
  font-size: 16px;
  color: var(--ink-mid);
  line-height: 1.75;
  margin-bottom: 20px;
}
.chisiamo-right p:last-child {
  margin-bottom: 0;
  color: var(--ink);
  font-weight: 500;
  border-left: 3px solid var(--yellow);
  padding-left: 14px;
}

/* ─── COME LAVORIAMO ─── */
.comelavoriamo {
  padding: 96px 0;
  background: var(--ink);
}
.comelavoriamo-inner {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 768px) {
  .comelavoriamo-inner { grid-template-columns: 1fr; gap: 32px; }
}
.comelavoriamo-left .section-title { color: var(--white); }
.comelavoriamo-steps { display: flex; flex-direction: column; }
.step-light {
  display: flex;
  gap: 24px;
  padding: 28px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  align-items: flex-start;
}
.step-light:first-child { border-top: 1px solid rgba(255,255,255,.07); }
.step-num-dark {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  border: 2px solid var(--blue-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--blue-light);
  transition: all .25s;
}
.step-light:hover .step-num-dark {
  background: var(--blue);
  border-color: var(--blue);
  color: var(--white);
}
.step-title-dark {
  font-size: 16px;
  font-weight: 600;
  color: var(--white);
  margin-bottom: 6px;
}
.step-text-dark {
  font-size: 15px;
  color: rgba(255,255,255,.65);
  line-height: 1.6;
}

/* ─── LAVORI ─── */
.lavori { padding: 96px 0; background: var(--off-white); }
.lavori-header { margin-bottom: 56px; }
.lavori-desc {
  font-size: 16px;
  color: var(--ink-mid);
  line-height: 1.7;
  margin-bottom: 32px;
  max-width: 600px;
}
.servizi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 4px;
}
@media (max-width: 640px) {
  .servizi-grid { grid-template-columns: 1fr 1fr; }
}
a.servizio-tile-link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
a.servizio-tile-link:hover {
  border-color: var(--blue);
  background: var(--blue-pale);
}
a.servizio-tile-link:hover .servizio-arrow {
  color: var(--blue);
  transform: translateX(3px);
}
.servizio-arrow {
  margin-left: auto;
  flex-shrink: 0;
  color: var(--ink-soft);
  transition: color .2s, transform .2s;
}
.servizio-tile {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 0;
  padding: 24px 32px;
  display: grid;
  grid-template-columns: 72px 1fr auto;
  gap: 28px;
  align-items: center;
  min-height: 130px;
  transition: border-color .2s, box-shadow .2s;
  position: relative;
  overflow: hidden;
}
.servizio-tile:hover { box-shadow: 0 6px 24px rgba(16,80,232,.08); border-color: rgba(20,86,217,.20); }
.servizio-icon {
  width: 48px;
  height: 48px;
  min-width: 48px;
  background: #EEF3FF;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  flex-shrink: 0;
}
.servizio-tile-title {
  font-family: var(--font-display);
  font-size: clamp(14px, 1.5vw, 18px);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.01em;
  text-transform: uppercase;
  line-height: 1.1;
}
.servizio-tile-desc {
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.6;
}
.lavori-area { display: none; }
.lavori-subheader {
  margin-bottom: 28px;
  padding-top: 40px;
  border-top: 1px solid var(--line);
}
.lavori-sub-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -.01em;
}
.cards {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 16px;
  cursor: grab;
}
.cards:active { cursor: grabbing; }
.cards::-webkit-scrollbar { height: 4px; }
.cards::-webkit-scrollbar-track { background: var(--line); border-radius: 2px; }
.cards::-webkit-scrollbar-thumb { background: var(--blue); border-radius: 2px; }
.card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  transition: box-shadow .25s, transform .25s;
  flex: 0 0 300px;
  scroll-snap-align: start;
}
.card:hover {
  box-shadow: 0 12px 40px rgba(16,80,232,.1);
  transform: translateY(-3px);
}
.card-num {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .15em;
  color: var(--blue);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.card-num::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--line);
}
.card h3 {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 20px;
  line-height: 1.2;
}
.card-row {
  margin-bottom: 12px;
}
.card-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 3px;
}
.card-text {
  font-size: 15px;
  color: var(--ink-mid);
  line-height: 1.55;
}
.card-result {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.card-result .card-text {
  color: var(--blue);
  font-weight: 500;
}
.card-icon {
  position: absolute;
  top: 28px;
  right: 28px;
  width: 36px;
  height: 36px;
  background: var(--blue-pale);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.card-icon svg { color: var(--blue); }

.card-img {
  width: calc(100% + 64px);
  margin: -32px -32px 24px -32px;
  height: 180px;
  object-fit: cover;
  display: block;
  border-radius: 6px 6px 0 0;
}

/* ─── FAQ ─── */
.faq {
  padding: 96px 0;
  background: var(--white);
  border-top: 1px solid var(--line);
}
.faq-header {
  margin-bottom: 48px;
}
.faq-list {
  max-width: 760px;
}
.faq-item {
  border-bottom: 1px solid var(--line);
}
.faq-item:first-child {
  border-top: 1px solid var(--line);
}
.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 0;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  text-align: left;
}
.faq-question:hover { color: var(--blue); }
.faq-icon {
  flex-shrink: 0;
  color: var(--blue);
  transition: transform .25s;
}
.faq-item.open .faq-icon {
  transform: rotate(180deg);
}
.faq-answer {
  display: none;
  padding-bottom: 22px;
}
.faq-item.open .faq-answer {
  display: block;
}
.faq-answer p {
  font-size: 15px;
  color: var(--ink-mid);
  line-height: 1.7;
}

/* ─── RECENSIONI ─── */
.recensioni {
  padding: 96px 0;
  background: var(--white);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.recensioni-header { margin-bottom: 48px; }
.recensioni-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
}
.recensione {
  background: var(--off-white);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 28px;
  position: relative;
}
.recensione::before {
  content: '"';
  position: absolute;
  top: 16px;
  right: 24px;
  font-family: var(--font-display);
  font-size: 80px;
  line-height: 1;
  color: var(--blue-pale);
  pointer-events: none;
}
.recensione-stelle {
  color: var(--yellow);
  font-size: 16px;
  letter-spacing: 2px;
  margin-bottom: 16px;
}
.recensione-testo {
  font-size: 15px;
  color: var(--ink-mid);
  line-height: 1.7;
  margin-bottom: 20px;
  font-style: italic;
}
.recensione-autore {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.recensione-nome {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: .04em;
}
.recensione-tipo {
  font-size: 11px;
  color: var(--ink-soft);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-family: var(--font-display);
}

/* ─── MARCHI ─── */
.marchi {
  padding: 64px 0;
  background: var(--off-white);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.marchi-header { text-align: center; margin-bottom: 40px; }
.marchi-track-wrapper {
  overflow: hidden;
  position: relative;
  /* fade sui bordi */
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}
.marchi-track {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: marquee 20s linear infinite;
}
.marchi-track:hover { animation-play-state: paused; }
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.brand-placeholder {
  width: 160px;
  height: 70px;
  border: 1.5px dashed var(--line);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-soft);
  font-size: 11px;
  letter-spacing: .1em;
  font-family: var(--font-display);
  flex-shrink: 0;
  transition: border-color .2s, color .2s;
}
.brand-placeholder:hover {
  border-color: var(--blue);
  color: var(--blue);
}

.contact-form-note {
  font-size: 13px;
  color: rgba(255,255,255,.4);
  margin-bottom: 24px;
}
.contact-form { display: flex; flex-direction: column; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
}
.form-group input,
.form-group textarea {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 4px;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--white);
  outline: none;
  transition: border-color .2s;
  resize: vertical;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: rgba(255,255,255,.25); }
.form-group input:focus,
.form-group textarea:focus { border-color: var(--blue-light); }
.form-privacy {
  font-size: 12px;
  color: rgba(255,255,255,.25);
  margin-top: 4px;
  line-height: 1.5;
}

.file-upload-wrapper {
  position: relative;
  border: 1px dashed rgba(255,255,255,.2);
  border-radius: 4px;
  transition: border-color .2s;
}
.file-upload-wrapper:hover { border-color: var(--blue-light); }
.file-upload-wrapper input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  background: none;
  border: none;
  padding: 0;
}
.file-upload-ui {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  color: rgba(255,255,255,.35);
  font-size: 14px;
  pointer-events: none;
}
.file-upload-ui svg { flex-shrink: 0; color: var(--blue-light); }
.file-upload-wrapper.has-file { border-color: var(--blue-light); }
.file-upload-wrapper.has-file .file-upload-ui { color: rgba(255,255,255,.8); }
.file-upload-wrapper.error { border-color: #e83010; }
.file-error { font-size: 12px; color: #e83010; margin-top: 4px; min-height: 16px; }

/* ─── CONTATTI ─── */
.contatti {
  padding: 96px 0;
  background: var(--white);
  border-top: 1px solid var(--line);
  position: relative;
}
.contatti-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 768px) {
  .contatti-inner { grid-template-columns: 1fr; gap: 48px; }
}
.contatti-left .section-title { color: var(--ink); }
.contatti-left p {
  font-size: 16px;
  color: var(--ink-soft);
  line-height: 1.7;
  margin-bottom: 36px;
}
.contact-list { list-style: none; margin-bottom: 36px; }
.contact-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  font-size: 15px;
}
.contact-list li:first-child { border-top: 1px solid var(--line); }
.contact-icon {
  width: 36px;
  height: 36px;
  background: var(--blue-pale);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.contact-icon svg { color: var(--blue); }
.contact-detail { display: flex; flex-direction: column; }
.contact-label {
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-family: var(--font-display);
}
.contact-value { font-size: 15px; color: var(--ink); font-weight: 500; }
.cta-row { display: flex; gap: 12px; flex-wrap: wrap; }

.contatti-right {}
.steps-title {
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: 20px;
}
.contact-form-note { font-size: 13px; color: var(--ink-soft); margin-bottom: 20px; }
.contact-form { display: flex; flex-direction: column; gap: 14px; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group label {
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.form-group input,
.form-group textarea {
  background: var(--off-white);
  border: 1px solid var(--line);
  border-radius: 2px;
  padding: 12px 14px;
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--ink);
  outline: none;
  transition: border-color .2s, background .2s;
  resize: vertical;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--ink-soft); }
.form-group input:focus,
.form-group textarea:focus { border-color: var(--blue); background: var(--white); }
.form-privacy { font-size: 12px; color: var(--ink-soft); margin-top: 4px; line-height: 1.5; }

.file-upload-wrapper {
  position: relative;
  border: 1px dashed var(--line);
  border-radius: 2px;
  background: var(--off-white);
  transition: border-color .2s;
}
.file-upload-wrapper:hover { border-color: var(--blue); }
.file-upload-wrapper input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  background: none;
  border: none;
  padding: 0;
}
.file-upload-ui {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  color: var(--ink-soft);
  font-size: 14px;
  pointer-events: none;
}
.file-upload-ui svg { flex-shrink: 0; color: var(--blue); }
.file-upload-wrapper.has-file { border-color: var(--blue); background: var(--blue-pale); }
.file-upload-wrapper.has-file .file-upload-ui { color: var(--ink); }
.file-upload-wrapper.error { border-color: #e83010; }
.file-error { font-size: 12px; color: #e83010; margin-top: 4px; min-height: 16px; }

.site-footer {
  background: #060D1F;
  padding: 52px 0 28px;
  border-top: 1px solid rgba(255,255,255,.05);
  border-bottom: 4px solid var(--yellow);
}

.card-cliente {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 11px;
  font-family: var(--font-display);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  display: flex;
  align-items: center;
  gap: 8px;
}
.card-cliente::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--yellow);
  flex-shrink: 0;
}

/* ─── WHATSAPP FISSO ─── */
.wa-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 999;
  width: 56px;
  height: 56px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
}
.wa-float:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 28px rgba(37,211,102,.5);
}
.wa-float svg { display: block; }

.lavori-sub-intro {
  margin: 10px 0 0;
  max-width: 760px;
  color: var(--ink-soft);
}
.gallery-single .gallery-prev,
.gallery-single .gallery-next,
.gallery-single .gallery-dots { display: none; }

/* ─── GALLERIA CARD ─── */
.card-gallery {
  width: calc(100% + 64px);
  margin: -32px -32px 24px -32px;
  height: 200px;
  position: relative;
  overflow: hidden;
  border-radius: 6px 6px 0 0;
  background: var(--line);
}
.gallery-track {
  display: flex;
  height: 100%;
  transition: transform .4s ease;
}
.gallery-slide {
  flex: 0 0 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
.gallery-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gallery-caption {
  position: absolute;
  bottom: 10px;
  left: 10px;
  background: rgba(0,0,0,.55);
  color: var(--white);
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 2px;
  backdrop-filter: blur(4px);
}
.gallery-prev,
.gallery-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,.45);
  color: var(--white);
  border: none;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
  z-index: 2;
  backdrop-filter: blur(4px);
}
.gallery-prev { left: 8px; }
.gallery-next { right: 8px; }
.gallery-prev:hover,
.gallery-next:hover { background: var(--blue); }
.gallery-dots {
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 5px;
  z-index: 2;
}
.gallery-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,.5);
  cursor: pointer;
  transition: background .2s;
}
.gallery-dot.active { background: var(--white); }

/* ─── SCROLL REVEAL — allineato a Io Misuro ─── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .65s ease, transform .65s ease;
}
.reveal.up {
  opacity: 1;
  transform: none;
}
.card.reveal { transform: translateY(20px) scale(.99); }
.card.reveal.up { transform: none; }
.step-light.reveal { transform: translateX(-12px); opacity: 0; }
.step-light.reveal.up { transform: none; opacity: 1; }
.faq-item.reveal { transform: translateY(10px); opacity: 0; }
.faq-item.reveal.up { transform: none; opacity: 1; }
.chisiamo-right p.reveal {
  transform: translateY(14px);
  opacity: 0;
  transition: opacity .5s ease, transform .5s ease;
}
.chisiamo-right p.reveal.up { transform: none; opacity: 1; }
.d1 { transition-delay: .1s; }
.d2 { transition-delay: .2s; }
.d3 { transition-delay: .3s; }

/* ─── ANIMATIONS ─── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-inner > * {
  animation: fadeUp .65s ease both;
}
.hero-eyebrow { animation-delay: .05s; }
.hero h1      { animation-delay: .15s; }
.hero p       { animation-delay: .25s; }
.btn-group    { animation-delay: .35s; }

/* ─── FOOTER STRUTTURATO ─── */
.site-footer {
  background: #060D1F;
  padding: 52px 0 28px;
  border-top: 1px solid rgba(255,255,255,.05);
  border-bottom: 4px solid var(--yellow);
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  margin-bottom: 24px;
}
@media (max-width: 768px) {
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
}
.footer-brand-desc {
  font-size: 13px;
  color: rgba(255,255,255,.3);
  line-height: 1.7;
  margin-top: 10px;
}
.footer-col h5 {
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.3);
  margin-bottom: 14px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
.footer-col a {
  font-size: 13px;
  color: rgba(255,255,255,.45);
  transition: color .2s;
  text-decoration: none;
}
.footer-col a:hover { color: var(--white); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-bottom p {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .05em;
  color: rgba(255,255,255,.25);
}
.footer-bottom a { color: var(--yellow); text-decoration: none; }

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  /* Nascondi canvas su mobile — troppo pesante */
  #heroCanvas { display: none !important; }
  .hero { padding: 72px 0 60px; }
  .hero h1 { font-size: clamp(36px, 9vw, 56px); }
  .hero p { font-size: 16px; }

  /* Sezioni */
  .chisiamo-inner,
  .comelavoriamo-inner,
  .contatti-inner { grid-template-columns: 1fr; gap: 40px; }

  /* Padding ridotto */
  .chisiamo,
  .comelavoriamo,
  .lavori,
  .recensioni,
  .faq,
  .contatti { padding: 64px 0; }

  .marchi { padding: 48px 0; }

  /* Cards scroll */
  .card { flex: 0 0 280px; }

  /* Iomisuro strip */
  .iomisuro-strip-inner { flex-direction: column; align-items: flex-start; gap: 20px; }

  /* FAQ */
  .faq-list { max-width: 100%; }

  /* Form grid */
  .contatti-inner { gap: 32px; }
}

@media (max-width: 640px) {
  .container { padding: 0 18px; }
  .btn-group { flex-direction: column; }
  .btn { justify-content: center; }
  .card { flex: 0 0 260px; }
  .recensioni-grid { grid-template-columns: 1fr; }
  .chisiamo-inner { gap: 28px; }
}
/* ─── FORM STATUS ─── */
.form-status { font-size:14px; font-weight:500; min-height:20px; transition:opacity .3s; opacity:0; }
.form-status.show { opacity:1; }


/* ===== IO CABLO 404 ===== */
.iocablo-404-hero{position:relative;background:radial-gradient(circle at center, rgba(16,80,232,.15) 0%, rgba(12,20,40,0) 42%), #07112b;padding:96px 0 88px;overflow:hidden}
.iocablo-404-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);background-size:48px 48px;opacity:.35;pointer-events:none}
.iocablo-404-inner{position:relative;z-index:1;text-align:center;max-width:980px}
.iocablo-404-kicker{font-family:'Antonio',sans-serif;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:#f2c300;margin-bottom:24px}
.iocablo-404-title{font-family:'Antonio',sans-serif;font-size:clamp(48px,8vw,92px);line-height:.95;letter-spacing:-.03em;color:#fff;margin:0 0 28px}
.iocablo-404-text{max-width:760px;margin:0 auto;color:rgba(255,255,255,.62);font-size:clamp(18px,2vw,22px);line-height:1.55}
.iocablo-404-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:34px}
.iocablo-404-links{padding:64px 0 84px;background:#f5f7fc;border-top:1px solid rgba(16,80,232,.08)}
.iocablo-404-links-head{margin-bottom:24px}
.iocablo-404-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.iocablo-404-card{position:relative;display:block;padding:24px;border:1px solid #dde3f0;background:#fff;text-decoration:none;color:var(--ink);min-height:220px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.iocablo-404-card:hover{transform:translateY(-2px);border-color:#c8d5ef;box-shadow:0 10px 24px rgba(12,20,40,.06)}
.iocablo-404-card-num{display:block;font-family:'Antonio',sans-serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#1050E8;margin-bottom:18px}
.iocablo-404-card h3{font-family:'Antonio',sans-serif;font-size:24px;line-height:1.05;margin:0 0 12px;color:#0c1428}
.iocablo-404-card p{margin:0;color:#5d6678;line-height:1.65}
@media (max-width: 900px){.iocablo-404-cards{grid-template-columns:1fr}.iocablo-404-hero{padding:80px 0 72px}}
@media (max-width: 640px){.iocablo-404-grid{background-size:32px 32px}.iocablo-404-kicker{margin-bottom:18px}.iocablo-404-text{font-size:17px}.iocablo-404-actions .btn{width:100%;justify-content:center}}


/* Uniformità leggibilità */
.section-kicker, .tag, .iomisuro-strip-label, .card-num, .card-label { letter-spacing: .12em; }
input, textarea { font-size: 16px; }
@media (max-width: 768px) {
  body { font-size: 15px; }
  p, li, input, textarea, label { font-size: 15px; }
  .header-tagline { font-size: 12px; }
  .nav-mobile a { font-size: 20px; }
  .faq-question { font-size: 16px; }
  .faq-answer p { font-size: 15px; }
}



/* === FOOTER LEGGIBILITA' MIGLIORATA === */
.site-footer,
.site-footer p,
.site-footer li,
.site-footer a,
.footer-brand-desc,
.footer-col p,
.footer-col li,
.footer-col a {
  font-size: 15px !important;
  line-height: 1.65 !important;
}

.site-footer h3,
.site-footer h4,
.footer-col h3,
.footer-col h4 {
  font-size: 16px !important;
  line-height: 1.35 !important;
  margin-bottom: 12px !important;
}

.site-footer ul,
.footer-col ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.site-footer .footer-brand-desc {
  font-size: 15px !important;
  line-height: 1.7 !important;
}

.site-footer .subfooter,
.site-footer .subfooter p,
.site-footer .subfooter a {
  font-size: 13px !important;
  line-height: 1.55 !important;
}

@media (max-width: 768px) {
  .site-footer,
  .site-footer p,
  .site-footer li,
  .site-footer a,
  .footer-brand-desc,
  .footer-col p,
  .footer-col li,
  .footer-col a {
    font-size: 15px !important;
    line-height: 1.7 !important;
  }

  .site-footer h3,
  .site-footer h4,
  .footer-col h3,
  .footer-col h4 {
    font-size: 17px !important;
  }

  .site-footer .subfooter,
  .site-footer .subfooter p,
  .site-footer .subfooter a {
    font-size: 13px !important;
  }
}



/* === LOGHI: RAPPORTI PRESERVATI E CONTENITORI ELASTICI === */
.site-header,
.header-inner,
.site-footer .footer-top,
.iomisuro-strip-inner {
  min-height: unset;
}

.site-header .header-inner {
  min-height: 84px;
  align-items: center;
}

.iomisuro-strip .iomisuro-strip-inner,
.iomisuro-strip-inner {
  align-items: center;
  gap: 18px;
  min-height: 88px;
}

.iocablo-logo-header,
.iocablo-logo-footer,
.iomisuro-logo-strip {
  object-fit: contain;
}

.site-footer .footer-brand a,
.site-footer .footer-brand img {
  max-width: 100%;
}

@media (max-width: 768px) {
  .site-header .header-inner {
    min-height: 78px;
  }

  .iocablo-logo-header {
    max-width: min(56vw, 220px) !important;
  }

  .iomisuro-strip .iomisuro-strip-inner,
  .iomisuro-strip-inner {
    min-height: 0;
    align-items: flex-start;
  }

  .iomisuro-logo-strip {
    max-width: min(58vw, 220px) !important;
  }
}



/* === SUBFOOTER PIÙ LEGGIBILE === */
.site-footer .subfooter,
.site-footer .subfooter p,
.site-footer .subfooter a {
  font-size: 14px !important;
  line-height: 1.6 !important;
  opacity: 0.88;
}

.site-footer .subfooter {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 16px;
  margin-top: 24px;
}

.site-footer .subfooter p + p {
  margin-top: 8px;
}

@media (max-width: 768px) {
  .site-footer .subfooter,
  .site-footer .subfooter p,
  .site-footer .subfooter a {
    font-size: 14px !important;
    line-height: 1.7 !important;
  }
}




/* =========================================================
   IO CABLO — DESIGN SYSTEM v3
   Blocco unico, nessuna sovrapposizione.
   Sostituisce tutte le sessioni di redesign precedenti.
   ========================================================= */

/* ─── VARIABILI AGGIUNTIVE ─── */
:root {
  --ic-ink:   #07111F;
  --ic-navy:  #0B1628;
  --ic-blue:  #1456D9;
  --ic-cyan:  #21A7C8;
  --ic-line:  #DDE3F0;
  --ic-soft:  #5A6880;
  --ic-bg:    #F5F7FC;
}

/* ─── GLOBALE ─── */
.section, section { scroll-margin-top: 96px; }
.btn, .nav-cta, .iomisuro-strip-cta { border-radius: 0 !important; }

a, button,
.servizio-tile-link, .card,
.ic-crit-card, .ic-srv-box, .ic-problem-card {
  transition: transform .24s ease, border-color .24s ease,
              background .24s ease, color .24s ease, opacity .24s ease;
}

/* ─── HEADER ─── */
.site-header { backdrop-filter: blur(10px); }
.nav-cta { letter-spacing: .10em; text-transform: uppercase; }

/* ─── HERO ─── */
.hero { position: relative; overflow: hidden; }
.hero::after {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}
.hero-inner { position: relative; z-index: 2; }
.hero h1 { letter-spacing: -.055em; max-width: 980px; }
.hero-eyebrow { letter-spacing: .20em; }

/* ─── SEZIONE SERVIZI ─── */
#servizi, .lavori, .servizi {
  padding-top: 110px;
  padding-bottom: 110px;
  position: relative;
}
#servizi::after, .servizi::after {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(20,86,217,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20,86,217,.025) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}
#servizi > *, .servizi > * { position: relative; z-index: 2; }

#servizi h2, .lavori h2, .servizi h2 {
  max-width: 820px;
  font-size: clamp(42px, 5.4vw, 76px);
  line-height: .94;
  letter-spacing: -.055em;
  margin-bottom: 26px;
}
#servizi p, .lavori p, .servizi p {
  max-width: 780px;
  font-size: 18px;
  line-height: 1.85;
  color: var(--ic-soft);
}

/* ─── GRIGLIA SERVIZI: righe orizzontali ─── */
.servizi-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
  background: rgba(7,17,31,.10);
  border: 1px solid rgba(7,17,31,.10);
  margin-top: 56px;
}

/* Tile: griglia 3 colonne — icona | corpo | descrizione */
.servizio-tile,
.servizio-tile-link {
  display: grid !important;
  grid-template-columns: 80px 1fr 260px;
  gap: 36px;
  align-items: center;
  min-height: 140px;
  padding: 28px 36px;
  background: #fff;
  border: 0;
  border-left: 4px solid transparent;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}
.servizio-tile:nth-child(even),
.servizio-tile-link:nth-child(even) { background: #FAFBFF; }

/* Hover */
.servizio-tile-link:hover,
.card:hover, .ic-crit-card:hover, .ic-srv-box:hover, .ic-problem-card:hover {
  transform: translateY(-2px);
  border-color: rgba(20,86,217,.30) !important;
}

/* Accento colore per servizio (border-left) */
.servizio-tile:nth-child(1), .servizio-tile-link:nth-child(1) { border-left-color: #1456D9; }
.servizio-tile:nth-child(2), .servizio-tile-link:nth-child(2) { border-left-color: #21A7C8; }
.servizio-tile:nth-child(3), .servizio-tile-link:nth-child(3) { border-left-color: #F5B301; }
.servizio-tile:nth-child(4), .servizio-tile-link:nth-child(4) { border-left-color: #3654A3; }
.servizio-tile:nth-child(5), .servizio-tile-link:nth-child(5) { border-left-color: #0B1628; }


/* Icona */
.servizio-icon {
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  margin: 0 !important;
  background: #EEF3FF !important;
  border-radius: 6px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--blue) !important;
}

/* Corpo centrale */
.servizio-tile-body { display: block; min-width: 0; }
.servizio-tile-title {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(17px, 1.8vw, 22px);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--ink);
  text-transform: uppercase;
  margin: 0;
  word-break: normal;
  hyphens: none;
}

/* Descrizione (colonna destra) */
.servizio-tile-desc {
  display: block;
  font-size: 15px;
  color: var(--ic-soft);
  line-height: 1.75;
  margin: 0;
}

/* Freccia */
.servizio-arrow {
  position: absolute !important;
  right: 28px !important;
  bottom: 20px !important;
  margin: 0 !important;
  color: var(--ic-blue) !important;
  transition: transform .2s !important;
}
.servizio-tile-link:hover .servizio-arrow { transform: translateX(4px) !important; }

/* ─── IC-PROBLEMS ─── */
.ic-problems {
  padding: 110px 0;
  background: #F5F7FC;
  border-top: 1px solid var(--ic-line);
  border-bottom: 1px solid var(--ic-line);
  position: relative;
  overflow: hidden;
}
.ic-problems::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(20,86,217,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20,86,217,.035) 1px, transparent 1px);
  background-size: 42px 42px;
  pointer-events: none;
}
.ic-problems .container { position: relative; z-index: 2; }
.ic-problems-head { max-width: 900px; margin-bottom: 54px; }
.ic-kicker {
  font-family: var(--font-display);
  font-size: 12px; letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ic-blue);
  margin-bottom: 16px;
}
.ic-problems-head h2 {
  font-size: clamp(42px, 6vw, 86px);
  line-height: .92; letter-spacing: -.055em;
  margin: 0 0 22px;
}
.ic-problems-head p {
  max-width: 760px;
  color: var(--ic-soft);
  line-height: 1.85; font-size: 18px; margin: 0;
}
.ic-problems-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  background: rgba(7,17,31,.12);
  border: 1px solid rgba(7,17,31,.12);
  margin-top: 52px;
}
.ic-problem-card {
  background: #fff;
  padding: 34px;
  min-height: 310px;
  overflow-wrap: anywhere;
}
.ic-problem-card span {
  font-family: var(--font-display);
  font-size: 14px; letter-spacing: .16em;
  color: var(--ic-blue);
  display: block; margin-bottom: 32px;
}
.ic-problem-card h3 {
  font-size: clamp(25px, 2.5vw, 36px);
  line-height: .98; letter-spacing: -.04em;
  margin: 0 0 18px;
}
.ic-problem-card p { color: var(--ic-soft); line-height: 1.85; margin: 0; }

/* ─── CARDS (CASE STUDY) ─── */
.cards { margin-top: 48px; }

/* ─── PAGINE SERVIZIO ─── */
.ic-srv-hero {
  padding-top: 110px;
  padding-bottom: 82px;
}
.ic-srv-hero h1 {
  font-size: clamp(44px, 6vw, 84px);
  line-height: .95; letter-spacing: -.055em;
  max-width: 980px;
}
.ic-srv-sub {
  font-size: 18px;
  line-height: 1.85;
  max-width: 760px;
}
.ic-srv-section { padding-top: 96px; padding-bottom: 96px; }
.ic-srv-grid {
  grid-template-columns: minmax(0, 1fr) 360px !important;
  gap: 72px !important;
}
.ic-srv-box, .ic-srv-side, .ic-crit-card {
  border-color: rgba(7,17,31,.12) !important;
  overflow-wrap: anywhere;
}
.ic-srv-box h2, .ic-srv-box h3, .ic-crit-card h3 { letter-spacing: -.035em; }
.ic-srv-box p, .ic-crit-card p, .ic-srv-side p { line-height: 1.82; }

.ic-crit-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 1px !important;
  background: rgba(7,17,31,.12) !important;
  border: 1px solid rgba(7,17,31,.12) !important;
}
.ic-crit-card {
  padding: 32px !important;
  min-height: 220px !important;
  background: #fff !important;
  border: 0 !important;
}
.ic-crit-card h3 {
  font-size: clamp(24px, 2.4vw, 34px) !important;
  line-height: .98 !important;
  margin-bottom: 16px !important;
}
.ic-srv-side {
  background: #fff;
  border: 1px solid rgba(7,17,31,.12);
  padding: 28px;
}
.ic-srv-side .btn, .ic-srv-side a { max-width: 100%; }

/* Service strip */
.ic-service-strip { background: #fff; border-bottom: 1px solid rgba(7,17,31,.10); }
.ic-service-strip-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  background: rgba(7,17,31,.10);
  border-left: 1px solid rgba(7,17,31,.10);
  border-right: 1px solid rgba(7,17,31,.10);
}
.ic-service-strip-grid span {
  display: flex; align-items: center;
  min-height: 64px;
  background: #fff;
  padding: 0 22px;
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ic-soft);
}

/* Lavori nelle pagine servizio */
.ic-service-works {
  padding: 96px 0;
  background: #F5F7FC;
  border-top: 1px solid rgba(7,17,31,.10);
  border-bottom: 1px solid rgba(7,17,31,.10);
}
.ic-works-head { max-width: 920px; margin-bottom: 46px; }
.ic-works-head h2 {
  font-size: clamp(40px, 5vw, 72px);
  line-height: .95; letter-spacing: -.05em; margin: 0 0 20px;
}
.ic-works-head p {
  max-width: 720px; color: var(--ic-soft);
  line-height: 1.85; font-size: 17px; margin: 0;
}
.ic-works-grid { display: grid; gap: 24px; }
.ic-work-card {
  background: #fff;
  border: 1px solid rgba(7,17,31,.12);
  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 360px;
}
.ic-work-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: rgba(7,17,31,.10);
  min-height: 360px;
}
.ic-work-gallery figure { margin: 0; position: relative; overflow: hidden; background: #E8EDF5; }
.ic-work-gallery img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ic-work-gallery figcaption {
  position: absolute; left: 14px; bottom: 14px;
  background: rgba(7,17,31,.82); color: #fff;
  font-family: var(--font-display);
  font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; padding: 7px 9px;
}
.ic-work-body { padding: 40px; }
.ic-work-meta {
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ic-blue); margin-bottom: 18px;
}
.ic-work-body h3 {
  font-size: clamp(30px, 3vw, 48px);
  line-height: .96; letter-spacing: -.045em; margin: 0 0 26px;
}
.ic-work-row {
  border-top: 1px solid rgba(7,17,31,.10);
  padding: 18px 0;
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 24px;
}
.ic-work-row span {
  font-family: var(--font-display);
  font-size: 11px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ic-soft);
}
.ic-work-row p { margin: 0; line-height: 1.75; color: var(--ic-soft); }

/* ─── FOOTER ─── */
.site-footer { position: relative; overflow: hidden; }
.site-footer::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}
.site-footer > * { position: relative; z-index: 2; }
.footer-grid { gap: 72px !important; }
.footer-brand-desc { max-width: 360px; line-height: 1.75; }
.site-footer .subfooter {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 16px; margin-top: 24px;
}

/* Strip Io Misuro */
.iomisuro-strip {
  border-top: 1px solid rgba(7,17,31,.08);
  border-bottom: 1px solid rgba(7,17,31,.08);
}
.iomisuro-strip-cta { white-space: nowrap; }

/* ─── LOGO CONTAINERS ─── */
.site-header .header-inner { min-height: 84px; align-items: center; }
.iomisuro-strip .iomisuro-strip-inner { align-items: center; gap: 18px; min-height: 88px; }
.iocablo-logo-header, .iocablo-logo-footer, .iomisuro-logo-strip { object-fit: contain; }

/* ─── FRECCE ─── */
.servizio-arrow, .card-arrow, .btn-arrow { font-weight: 700; }


/* =========================================================
   RESPONSIVE
   ========================================================= */

/* 1366px */
@media (max-width: 1366px) {
  .container { max-width: 1120px; }
}

/* 1280px */
@media (max-width: 1280px) {
  .hero h1 { max-width: 880px; }
  .ic-problems-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* 1100px — tablet orizzontale */
@media (max-width: 1100px) {
  .ic-problems-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .servizio-tile, .servizio-tile-link {
    grid-template-columns: 64px 1fr;
    gap: 24px;
    padding: 24px 28px 60px;
    min-height: auto;
  }
  .servizio-tile-desc { grid-column: 2; max-width: 500px; }
  .ic-service-strip-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* 900px */
@media (max-width: 900px) {
  #servizi, .lavori, .servizi {
    padding-top: 78px;
    padding-bottom: 78px;
  }
  #servizi h2, .lavori h2, .servizi h2 {
    font-size: clamp(38px, 10vw, 56px);
  }
  #servizi p, .lavori p, .servizi p { font-size: 16px; }
  .ic-problems { padding: 78px 0; }
  .ic-problems-head h2 { font-size: clamp(36px, 10vw, 54px); }
  .ic-crit-grid { grid-template-columns: 1fr !important; }
  .ic-srv-hero { padding-top: 92px; padding-bottom: 72px; }
  .ic-srv-section { padding-top: 72px; padding-bottom: 72px; }
  .footer-grid { gap: 40px !important; }
  .iomisuro-strip .container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }
}

/* 768px — tablet verticale */
@media (max-width: 768px) {
  .iocablo-logo-header { max-width: min(56vw, 220px) !important; }
  .iomisuro-logo-strip { max-width: min(58vw, 220px) !important; }
  .iomisuro-strip .iomisuro-strip-inner { min-height: 0; align-items: flex-start; }
  .site-header .header-inner { min-height: 78px; }
  .ic-srv-grid { grid-template-columns: 1fr !important; }
  .ic-srv-side { position: relative !important; top: auto !important; }
  .servizio-tile, .servizio-tile-link { padding: 24px 24px 60px; }
}

/* 640px — mobile */
@media (max-width: 640px) {
  .container { padding-left: 20px; padding-right: 20px; }
  .hero h1 { font-size: clamp(44px, 14vw, 64px); }
  .servizi-grid { gap: 10px; margin-top: 38px; }
  .servizio-tile, .servizio-tile-link {
    display: block !important;
    padding: 24px 20px 64px;
    min-height: auto;
  }
  .servizio-icon { margin: 0 0 24px !important; }
  .servizio-tile-title { font-size: 18px; }
  .servizio-tile-desc { max-width: none; margin-top: 10px !important; }
  .servizio-arrow { right: 20px !important; bottom: 20px !important; }
  .ic-problems { padding: 64px 0; }
  .ic-problems-grid { grid-template-columns: 1fr; }
  .ic-problem-card { min-height: auto; padding: 28px; }
  .ic-crit-grid { grid-template-columns: 1fr !important; }
  .ic-problem-card, .ic-crit-card, .card { padding: 26px !important; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .ic-service-strip-grid { grid-template-columns: 1fr; }
  .ic-work-card { grid-template-columns: 1fr; }
  .ic-work-gallery { grid-template-columns: 1fr; min-height: 260px; }
  .ic-work-body { padding: 28px; }
  .ic-work-row { grid-template-columns: 1fr; gap: 8px; }
  .ic-service-works { padding: 72px 0; }
}


/* =========================================================
   DEBUG HOTFIX 2026-05-10
   Servizi home: struttura stabile e icone controllate
   ========================================================= */
.lavori .servizi-grid{
  grid-template-columns:1fr !important;
  gap:14px !important;
  background:transparent !important;
  border:0 !important;
}
.lavori .servizio-tile,
.lavori .servizio-tile-link{
  display:grid !important;
  grid-template-columns:96px minmax(0,1fr) 34px !important;
  align-items:center !important;
  gap:28px !important;
  min-height:154px !important;
  padding:32px 38px !important;
  overflow:hidden !important;
  border:1px solid rgba(7,17,31,.12) !important;
  border-left-width:4px !important;
  background:#fff !important;
}
.lavori .servizio-tile:nth-child(even),
.lavori .servizio-tile-link:nth-child(even){background:#FAFBFF !important;}
.lavori .servizio-icon{
  width:58px !important;
  height:58px !important;
  min-width:58px !important;
  max-width:58px !important;
  flex:0 0 58px !important;
  margin:0 !important;
  position:relative !important;
  overflow:hidden !important;
  border-radius:8px !important;
  background:#EEF3FF !important;
  color:var(--blue) !important;
  transform:none !important;
}
.lavori .servizio-icon::before,
.lavori .servizio-icon::after{content:none !important;}
.lavori .servizio-icon svg{
  width:26px !important;
  height:26px !important;
  max-width:26px !important;
  max-height:26px !important;
  display:block !important;
  transform:none !important;
}
.lavori .servizio-tile-body{min-width:0 !important;}
.lavori .servizio-tile-title{
  font-size:clamp(30px,3.2vw,52px) !important;
  line-height:.96 !important;
  letter-spacing:-.045em !important;
  max-width:620px !important;
}
.lavori .servizio-tile-desc{
  margin-top:12px !important;
  max-width:360px !important;
  font-size:16px !important;
  line-height:1.65 !important;
}
.lavori .servizio-arrow{
  position:static !important;
  justify-self:end !important;
  width:20px !important;
  height:20px !important;
}
@media (max-width:900px){
  .lavori .servizio-tile,
  .lavori .servizio-tile-link{
    grid-template-columns:72px minmax(0,1fr) !important;
    gap:22px !important;
    padding:28px 26px 58px !important;
  }
  .lavori .servizio-arrow{position:absolute !important;right:24px !important;bottom:24px !important;}
  .lavori .servizio-tile-title{font-size:clamp(28px,7vw,44px) !important;}
}
@media (max-width:640px){
  .lavori .servizio-tile,
  .lavori .servizio-tile-link{display:block !important;padding:24px 22px 58px !important;}
  .lavori .servizio-icon{width:48px !important;height:48px !important;min-width:48px !important;margin-bottom:22px !important;}
  .lavori .servizio-icon svg{width:23px !important;height:23px !important;}
  .lavori .servizio-tile-title{font-size:30px !important;}
  .lavori .servizio-tile-desc{font-size:15px !important;}
}

/* =========================================================
   DEEP DEBUG V2 2026-05-10
   Home servizi: classi isolate per evitare collisioni con vecchie regole
   ========================================================= */
.ic-home-work{
  background:var(--off-white) !important;
  padding:clamp(76px,8vw,116px) 0 !important;
  overflow:hidden !important;
}
.ic-home-work .ic-home-work-header{
  margin:0 0 clamp(34px,4vw,56px) !important;
  max-width:780px !important;
}
.ic-home-work .section-title{
  margin:0 0 24px !important;
  max-width:820px !important;
  font-size:clamp(44px,5.4vw,76px) !important;
  line-height:.94 !important;
  letter-spacing:-.055em !important;
}
.ic-home-work .lavori-desc{
  margin:0 !important;
  max-width:720px !important;
  font-size:18px !important;
  line-height:1.8 !important;
  color:var(--ink-mid) !important;
}
.ic-home-services{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:14px !important;
  margin:0 !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
}
.ic-home-service-card{
  isolation:isolate !important;
  display:grid !important;
  grid-template-columns:78px minmax(0,1fr) 32px !important;
  align-items:center !important;
  gap:32px !important;
  min-height:148px !important;
  padding:30px 36px !important;
  position:relative !important;
  overflow:hidden !important;
  text-decoration:none !important;
  color:inherit !important;
  background:#fff !important;
  border:1px solid rgba(7,17,31,.12) !important;
  border-left:4px solid var(--blue) !important;
  box-shadow:none !important;
  transform:none !important;
}
.ic-home-service-card:nth-child(even){background:#FAFBFF !important;}
.ic-home-service-card::before,
.ic-home-service-card::after{content:none !important;display:none !important;}
.ic-home-service-card:hover{
  border-color:rgba(30,111,255,.32) !important;
  border-left-color:var(--blue) !important;
  box-shadow:0 18px 48px rgba(7,17,31,.08) !important;
  transform:translateY(-1px) !important;
}
.ic-home-service-mark{
  width:58px !important;
  height:58px !important;
  min-width:58px !important;
  max-width:58px !important;
  min-height:58px !important;
  max-height:58px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  position:relative !important;
  overflow:hidden !important;
  z-index:1 !important;
  flex:none !important;
  margin:0 !important;
  padding:0 !important;
  color:var(--blue) !important;
  background:#EEF3FF !important;
  border-radius:10px !important;
  transform:none !important;
  clip-path:none !important;
}
.ic-home-service-mark::before,
.ic-home-service-mark::after{content:none !important;display:none !important;}
.ic-home-service-mark svg{
  width:26px !important;
  height:26px !important;
  max-width:26px !important;
  max-height:26px !important;
  display:block !important;
  flex:none !important;
  overflow:visible !important;
  transform:none !important;
  color:currentColor !important;
  stroke:currentColor !important;
  fill:none !important;
  stroke-width:1.6 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}
.ic-home-service-mark svg circle[fill],
.ic-home-service-mark svg path[fill]{fill:currentColor !important;}
.ic-home-service-copy{
  display:block !important;
  min-width:0 !important;
  margin:0 !important;
  padding:0 !important;
}
.ic-home-service-title{
  display:block !important;
  max-width:690px !important;
  font-family:var(--font-display) !important;
  font-size:clamp(32px,3.35vw,56px) !important;
  font-weight:700 !important;
  line-height:.96 !important;
  letter-spacing:-.05em !important;
  text-transform:uppercase !important;
  color:var(--ink) !important;
  margin:0 !important;
  overflow-wrap:normal !important;
  word-break:normal !important;
  hyphens:none !important;
}
.ic-home-service-desc{
  display:block !important;
  max-width:420px !important;
  margin:12px 0 0 !important;
  font-size:16px !important;
  line-height:1.65 !important;
  color:var(--ink-mid) !important;
}
.ic-home-service-arrow{
  justify-self:end !important;
  align-self:center !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:32px !important;
  height:32px !important;
  margin:0 !important;
  color:var(--blue) !important;
  font-size:28px !important;
  line-height:1 !important;
  font-weight:700 !important;
  transform:none !important;
  transition:transform .2s ease !important;
}
.ic-home-service-card:hover .ic-home-service-arrow{transform:translateX(4px) !important;}
@media (max-width:900px){
  .ic-home-service-card{
    grid-template-columns:64px minmax(0,1fr) !important;
    gap:22px !important;
    min-height:auto !important;
    padding:28px 26px 60px !important;
  }
  .ic-home-service-arrow{
    position:absolute !important;
    right:24px !important;
    bottom:22px !important;
  }
  .ic-home-service-title{font-size:clamp(30px,7vw,46px) !important;}
}
@media (max-width:640px){
  .ic-home-work{padding:64px 0 !important;}
  .ic-home-work .lavori-desc{font-size:16px !important;line-height:1.7 !important;}
  .ic-home-services{gap:12px !important;}
  .ic-home-service-card{
    display:block !important;
    padding:24px 22px 58px !important;
  }
  .ic-home-service-mark{
    width:48px !important;height:48px !important;min-width:48px !important;min-height:48px !important;margin-bottom:22px !important;
  }
  .ic-home-service-mark svg{width:23px !important;height:23px !important;}
  .ic-home-service-title{font-size:30px !important;line-height:1 !important;}
  .ic-home-service-desc{font-size:15px !important;max-width:none !important;}
}

/* IO CABLO DEBUG V4 — guardia finale servizi home */
#ic-services-v4{margin:0 !important;}
#ic-services-v4 + .faq{clear:both !important;position:relative !important;z-index:1 !important;}
.comelavoriamo{position:relative !important;z-index:1 !important;overflow:hidden !important;}

/* =========================================================
   IO CABLO V6 — Rifiniture grafiche e tecniche
   Obiettivo: coerenza con IO MISURO, gerarchie più pulite,
   componenti meno aggressivi e migliore stabilità responsive.
   ========================================================= */
:root{
  --ic-radius-soft: 14px;
  --ic-line: rgba(7,17,31,.10);
  --ic-line-strong: rgba(16,80,232,.22);
  --ic-shadow-soft: 0 18px 50px rgba(7,17,31,.075);
  --ic-section-y: clamp(72px, 7vw, 116px);
}

body{ text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }
.container{ width:min(100% - 48px, 1140px); }
.section-title{ letter-spacing:-.045em; }
.tag,.ic-kicker,.hero-eyebrow{ letter-spacing:.15em; }

/* Nota editoriale: sostituisce gli inline style troppo rigidi */
.ic-note{
  border-left:3px solid var(--yellow);
  padding-left:16px;
  margin-left:0;
}

/* Header: più ordinato e coerente con lo stile studio */
.site-header{
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-header .header-inner{ min-height:78px; }
.main-nav a{ transition: color .18s ease, opacity .18s ease; }
.main-nav a:hover{ color:var(--blue); }

/* Sezioni principali: ritmo verticale unico */
.chisiamo,.ic-problems,.comelavoriamo,.ic-service-works,.faq,.recensioni,.contatti{
  padding-top:var(--ic-section-y);
  padding-bottom:var(--ic-section-y);
}

/* Home servizi: meno manifesto, più premium tecnico */
#ic-services-v4{
  padding:var(--ic-section-y) 0 !important;
  background:linear-gradient(180deg,#F7F9FD 0%,#F2F5FB 100%) !important;
  border-top:1px solid var(--ic-line) !important;
  border-bottom:1px solid var(--ic-line) !important;
}
#ic-services-v4 .icv4-wrap{ width:min(100% - 48px, 1140px) !important; padding:0 !important; }
#ic-services-v4 .icv4-head{ max-width:780px !important; margin-bottom:44px !important; }
#ic-services-v4 .icv4-title{
  font-size:clamp(40px,4.7vw,68px) !important;
  line-height:.98 !important;
  letter-spacing:-.05em !important;
  margin-bottom:20px !important;
}
#ic-services-v4 .icv4-desc{
  font-size:clamp(16px,1.25vw,18px) !important;
  line-height:1.72 !important;
  color:#34405A !important;
}
#ic-services-v4 .icv4-list{ gap:12px !important; }
#ic-services-v4 .icv4-card{
  grid-template-columns:68px minmax(0,1fr) 34px !important;
  gap:28px !important;
  min-height:132px !important;
  padding:28px 34px !important;
  border:1px solid var(--ic-line) !important;
  border-left:3px solid #1050E8 !important;
  border-radius:0 !important;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease !important;
}
#ic-services-v4 .icv4-card:hover,
#ic-services-v4 .icv4-card:focus-visible{
  border-color:var(--ic-line-strong) !important;
  box-shadow:var(--ic-shadow-soft) !important;
  transform:translateY(-2px) !important;
  outline:none !important;
}
#ic-services-v4 .icv4-num{
  width:52px !important;
  height:52px !important;
  min-width:52px !important;
  border-radius:12px !important;
  background:#EDF3FF !important;
}
#ic-services-v4 .icv4-name{
  font-size:clamp(28px,2.65vw,44px) !important;
  line-height:1.02 !important;
  letter-spacing:-.04em !important;
}
#ic-services-v4 .icv4-text{ margin-top:10px !important; font-size:15.5px !important; line-height:1.58 !important; }
#ic-services-v4 .icv4-arrow{ font-size:25px !important; opacity:.9 !important; transition:transform .2s ease, opacity .2s ease !important; }

/* Card problemi e metodi: stessa famiglia visiva delle card servizi */
.ic-problem-card,.step,.faq-item,.recensione,.contact-card,.info-card{
  border-color:var(--ic-line) !important;
}
.ic-problem-card,.step,.faq-item,.recensione,.contact-card,.info-card,.ic-work-card{
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.ic-problem-card:hover,.faq-item:hover,.ic-work-card:hover{
  border-color:var(--ic-line-strong) !important;
  box-shadow:0 14px 38px rgba(7,17,31,.06);
}

/* Lavori eseguiti nelle pagine servizio: pulizia e coerenza */
.ic-service-works{
  padding:var(--ic-section-y) 0;
  background:linear-gradient(180deg,#F7F9FD 0%,#F2F5FB 100%);
}
.ic-works-head{ max-width:820px; margin-bottom:40px; }
.ic-works-head h2{
  font-size:clamp(38px,4.4vw,64px);
  line-height:.98;
  letter-spacing:-.045em;
}
.ic-works-head p{ font-size:16.5px; line-height:1.72; max-width:680px; }
.ic-works-grid{ gap:18px; }
.ic-work-card{
  border-radius:0;
  overflow:hidden;
  border:1px solid var(--ic-line);
  box-shadow:none;
}
.ic-work-body{ padding:clamp(28px,3.4vw,40px); }
.ic-work-body h3{
  font-size:clamp(28px,2.8vw,42px);
  line-height:1;
  letter-spacing:-.04em;
}
.ic-work-row{ grid-template-columns:112px 1fr; gap:20px; padding:16px 0; }
.ic-work-gallery figcaption{ border-radius:8px; }

/* FAQ: riduce effetto blocco tecnico pesante */
.faq-question{ min-height:64px; }
.faq-icon{ color:var(--blue); }

/* Footer / strip: maggiore leggibilità dei testi piccoli */
.site-footer,.site-footer p,.footer-brand-desc{ line-height:1.72; }
.subfooter{ font-size:13px; }
.iomisuro-strip{ background:#fff; }
.iomisuro-strip-cta{ font-weight:700; }

/* Responsive polishing */
@media (max-width:900px){
  .container{ width:min(100% - 36px, 1140px); }
  #ic-services-v4 .icv4-wrap{ width:min(100% - 36px, 1140px) !important; }
  #ic-services-v4 .icv4-card{
    grid-template-columns:58px minmax(0,1fr) !important;
    padding:24px 24px 56px !important;
    gap:20px !important;
  }
  #ic-services-v4 .icv4-name{ font-size:clamp(28px,6.4vw,40px) !important; }
  .ic-work-card{ grid-template-columns:1fr; }
  .ic-work-gallery{ min-height:260px; }
}
@media (max-width:640px){
  .container{ width:min(100% - 32px, 1140px); }
  #ic-services-v4 .icv4-wrap{ width:min(100% - 32px, 1140px) !important; }
  #ic-services-v4 .icv4-title{ font-size:38px !important; }
  #ic-services-v4 .icv4-card{ padding:22px 20px 54px !important; }
  #ic-services-v4 .icv4-name{ font-size:28px !important; }
  #ic-services-v4 .icv4-text{ font-size:15px !important; }
  .ic-work-row{ grid-template-columns:1fr; gap:6px; }
  .ic-work-gallery{ grid-template-columns:1fr; }
  .ic-work-gallery figure:nth-child(n+2){ display:none; }
}

/* =========================================================
   v9 - Rifinitura premium criticità ricorrenti
   - hover con evidenza invece di perdita delle linee
   - spazi verticali più compatti
   - bordi gestiti sulle singole card per evitare sparizioni
   ========================================================= */

.ic-crit-grid,
.ic-problems-grid{
  gap:14px !important;
  background:transparent !important;
  border:0 !important;
  margin-top:34px !important;
}

.ic-crit-card,
.ic-problem-card{
  position:relative !important;
  border:1px solid rgba(7,17,31,.13) !important;
  background:#fff !important;
  box-shadow:0 1px 0 rgba(7,17,31,.02) !important;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease !important;
}

.ic-crit-card::before,
.ic-problem-card::before{
  content:"" !important;
  position:absolute !important;
  left:-1px !important;
  top:-1px !important;
  bottom:-1px !important;
  width:3px !important;
  background:#1456D9 !important;
  opacity:0 !important;
  transform:scaleY(.55) !important;
  transform-origin:center !important;
  transition:opacity .22s ease, transform .22s ease !important;
}

.ic-crit-card:hover,
.ic-problem-card:hover,
.ic-crit-card:focus-within,
.ic-problem-card:focus-within{
  border-color:rgba(20,86,217,.45) !important;
  background:linear-gradient(180deg,#FFFFFF 0%,#F8FAFF 100%) !important;
  box-shadow:0 18px 42px rgba(7,17,31,.075) !important;
  transform:translateY(-2px) !important;
}

.ic-crit-card:hover::before,
.ic-problem-card:hover::before,
.ic-crit-card:focus-within::before,
.ic-problem-card:focus-within::before{
  opacity:1 !important;
  transform:scaleY(1) !important;
}

.ic-crit-card{
  padding:26px 28px !important;
  min-height:185px !important;
}

.ic-crit-idx,
.ic-problem-card span{
  color:#1456D9 !important;
  letter-spacing:.14em !important;
  margin-bottom:20px !important;
}

.ic-crit-card h3{
  font-size:clamp(21px,2vw,28px) !important;
  line-height:1.04 !important;
  margin-bottom:12px !important;
}

.ic-crit-card p{
  font-size:15px !important;
  line-height:1.68 !important;
}

.ic-problems{
  padding-top:82px !important;
  padding-bottom:82px !important;
}

.ic-problems-head{
  margin-bottom:34px !important;
}

.ic-problems-head h2{
  font-size:clamp(38px,5vw,68px) !important;
  line-height:.98 !important;
  margin-bottom:16px !important;
}

.ic-problems-head p{
  font-size:17px !important;
  line-height:1.68 !important;
}

.ic-problem-card{
  padding:28px !important;
  min-height:245px !important;
}

.ic-problem-card h3{
  font-size:clamp(23px,2.15vw,31px) !important;
  line-height:1.03 !important;
  margin-bottom:14px !important;
}

.ic-problem-card p{
  font-size:15.5px !important;
  line-height:1.68 !important;
}

@media (max-width: 900px){
  .ic-crit-grid,
  .ic-problems-grid{
    gap:12px !important;
  }
  .ic-problems{
    padding-top:68px !important;
    padding-bottom:68px !important;
  }
  .ic-problem-card{
    min-height:auto !important;
  }
}

@media (max-width: 640px){
  .ic-crit-card,
  .ic-problem-card{
    padding:24px !important;
  }
  .ic-problems-head{
    margin-bottom:28px !important;
  }
}


/* ===== IO CABLO V10 PREMIUM SYSTEM ===== */

:root{
    --ioc-space-xs:24px;
    --ioc-space-sm:40px;
    --ioc-space-md:80px;
    --ioc-space-lg:120px;
    --ioc-space-xl:160px;
}

body{
    line-height:1.7;
    -webkit-font-smoothing:antialiased;
}

h1{
    letter-spacing:-0.04em;
    line-height:1.05;
}

h2{
    letter-spacing:-0.03em;
    line-height:1.15;
}

h3{
    letter-spacing:-0.02em;
    line-height:1.35;
}

section{
    padding-top:var(--ioc-space-md);
    padding-bottom:var(--ioc-space-md);
}

.service-card,
.criticality-card{
    border-radius:24px;
    transition:all .28s ease;
    overflow:hidden;
}

.service-card:hover,
.criticality-card:hover{
    transform:translateY(-4px);
    border-color:rgba(80,140,255,.45);
    box-shadow:0 18px 40px rgba(0,0,0,.18);
}

.criticality-card{
    position:relative;
}

.criticality-card::before{
    content:"";
    position:absolute;
    left:0;
    top:18px;
    bottom:18px;
    width:3px;
    background:rgba(80,140,255,.18);
    transition:all .25s ease;
}

.criticality-card:hover::before{
    background:rgba(80,140,255,.9);
}

.premium-editorial-note{
    padding-top:40px;
    padding-bottom:20px;
}

.premium-editorial-note p{
    max-width:72ch;
    opacity:.82;
}

.site-footer{
    border-top:1px solid rgba(255,255,255,.08);
}

.site-footer p,
.site-footer li,
.site-footer a{
    opacity:.78;
}

@media(max-width:768px){

    section{
        padding-top:64px;
        padding-bottom:64px;
    }

    h1{
        line-height:1.08;
    }

    .service-card,
    .criticality-card{
        padding:1.4rem;
    }
}

/* ===== IO CABLO V11 — CHIUSURA ISTITUZIONALE FOOTER ===== */
.footer-tech-line{display:none!important;}
.iomisuro-strip{display:none!important;}

.site-footer.institutional-footer{
    background:#071126!important;
    color:rgba(255,255,255,.82)!important;
    padding:0!important;
    border-top:1px solid rgba(255,255,255,.08)!important;
}

.site-footer.institutional-footer .container{
    max-width:1180px;
}

.footer-institutional-bridge{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center;
    gap:32px;
    padding:34px 0 32px;
    border-bottom:1px solid rgba(255,255,255,.10);
}

.footer-bridge-eyebrow,
.site-footer.institutional-footer h5,
.footer-documents span{
    display:block;
    margin:0 0 12px;
    font-family:'Antonio',system-ui,sans-serif;
    font-size:11px;
    line-height:1.2;
    font-weight:700;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(255,255,255,.48)!important;
}

.footer-bridge-content{
    display:grid;
    grid-template-columns:126px minmax(0,560px);
    align-items:center;
    gap:28px;
}

.footer-iomisuro-logo{
    width:126px!important;
    height:auto!important;
    display:block;
    filter:none!important;
}

.footer-bridge-content p{
    margin:0!important;
    max-width:58ch;
    color:rgba(255,255,255,.74)!important;
    font-size:15px!important;
    line-height:1.65!important;
}

.footer-bridge-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 20px!important;
    border:1px solid rgba(255,255,255,.28)!important;
    color:rgba(255,255,255,.86)!important;
    text-decoration:none!important;
    font-family:'Antonio',system-ui,sans-serif;
    font-size:12px!important;
    font-weight:700;
    letter-spacing:.16em;
    text-transform:uppercase;
    background:transparent!important;
    transition:background .22s ease,border-color .22s ease,transform .22s ease,color .22s ease;
    white-space:nowrap;
}

.footer-bridge-cta:hover{
    background:rgba(255,255,255,.06)!important;
    border-color:rgba(255,255,255,.48)!important;
    color:#fff!important;
    transform:translateY(-2px);
}

.footer-grid-institutional{
    display:grid!important;
    grid-template-columns:1.25fr 1fr .85fr .95fr!important;
    gap:48px!important;
    align-items:start!important;
    padding:48px 0 38px!important;
}

.footer-logo-link{
    display:inline-flex!important;
    margin:0 0 20px!important;
}

.footer-iocablo-logo{
    height:74px!important;
    width:auto!important;
    max-width:230px!important;
    display:block!important;
    filter:brightness(0) invert(1)!important;
}

.site-footer.institutional-footer .footer-brand-desc{
    max-width:330px!important;
    margin:0!important;
    color:rgba(255,255,255,.70)!important;
    font-size:14px!important;
    line-height:1.7!important;
}

.site-footer.institutional-footer h5{
    margin-bottom:16px!important;
    color:rgba(255,255,255,.58)!important;
}

.site-footer.institutional-footer ul{
    margin:0!important;
    padding:0!important;
    list-style:none!important;
    display:grid!important;
    gap:9px!important;
}

.site-footer.institutional-footer li{
    margin:0!important;
    padding:0!important;
    color:rgba(255,255,255,.76)!important;
}

.site-footer.institutional-footer a{
    color:rgba(255,255,255,.76)!important;
    text-decoration:none!important;
    font-size:14px!important;
    line-height:1.5!important;
    transition:color .2s ease,opacity .2s ease;
}

.site-footer.institutional-footer a:hover{
    color:#fff!important;
}

.footer-operativity{
    margin:18px 0 0!important;
    color:rgba(255,255,255,.52)!important;
    font-size:13px!important;
    line-height:1.6!important;
}

.footer-documents{
    display:flex!important;
    align-items:center!important;
    flex-wrap:wrap!important;
    gap:8px 20px!important;
    padding:17px 0!important;
    border-top:1px solid rgba(255,255,255,.08)!important;
}

.footer-documents span{margin:0 6px 0 0!important;}
.footer-documents a{font-size:12px!important;color:rgba(255,255,255,.56)!important;}

.footer-bottom-institutional{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto!important;
    align-items:center!important;
    gap:24px!important;
    padding:20px 0 24px!important;
    border-top:1px solid rgba(255,255,255,.08)!important;
}

.footer-bottom-institutional p{
    margin:0!important;
    color:rgba(255,255,255,.50)!important;
    font-size:12px!important;
    line-height:1.55!important;
}
.footer-bottom-institutional p+p{margin-top:5px!important;color:rgba(255,255,255,.34)!important;}
.footer-bottom-institutional strong{color:rgba(255,255,255,.68)!important;font-weight:600!important;}

.footer-social{
    display:flex!important;
    align-items:center!important;
    gap:10px!important;
}
.footer-social .social-icon{
    width:34px!important;
    height:34px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    border:1px solid rgba(255,255,255,.16)!important;
    color:rgba(255,255,255,.70)!important;
    background:rgba(255,255,255,.03)!important;
}
.footer-social .social-icon:hover{
    border-color:rgba(255,255,255,.35)!important;
    color:#fff!important;
    background:rgba(255,255,255,.07)!important;
}

@media(max-width:980px){
    .footer-institutional-bridge,
    .footer-bottom-institutional{
        grid-template-columns:1fr!important;
        align-items:start!important;
    }
    .footer-grid-institutional{
        grid-template-columns:1fr 1fr!important;
        gap:34px!important;
    }
}

@media(max-width:640px){
    .footer-institutional-bridge{padding:28px 0 26px!important;gap:22px!important;}
    .footer-bridge-content{grid-template-columns:1fr!important;gap:18px!important;}
    .footer-iomisuro-logo{width:118px!important;}
    .footer-bridge-cta{width:100%;justify-content:center;}
    .footer-grid-institutional{grid-template-columns:1fr!important;padding:34px 0 30px!important;gap:28px!important;}
    .footer-iocablo-logo{height:66px!important;}
    .footer-bottom-institutional{padding:18px 0 22px!important;}
}


/* ===== IO CABLO V12 - FOOTER LOGO BALANCE ===== */

/* Ridimensionamento logo footer / blocco IO MISURO: evita effetto hero secondario */
.site-footer img,
.footer img,
footer img {
    max-width: 180px;
    height: auto;
}

.footer-brand img,
.site-footer .footer-brand img,
.footer-logo img,
.site-footer .footer-logo img,
.footer-iocablo img,
.site-footer .footer-iocablo img {
    max-width: 180px !important;
    height: auto !important;
}

/* Logo/visual IO MISURO nella chiusura istituzionale */
.closing-institutional img,
.iomisuro-closing img,
.footer-iomisuro img,
.site-footer .iomisuro img,
.iomisuro-brand img {
    max-width: 220px !important;
    height: auto !important;
}

/* Se il logo viene usato come background, ne impediamo l'effetto gigante */
.closing-institutional,
.footer-institutional,
.iomisuro-closing,
.footer-iomisuro {
    background-size: min(420px, 46vw) auto !important;
    background-position: center top !important;
    background-repeat: no-repeat !important;
}

/* Footer più compatto e controllato */
.site-footer,
.footer,
footer.site-footer {
    padding-top: 56px !important;
    padding-bottom: 34px !important;
}

.site-footer .container,
.footer .container,
footer .container {
    align-items: start;
}

/* Evita che eventuali marchi enormi spingano sotto la griglia */
.footer-institutional,
.closing-institutional {
    min-height: auto !important;
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}

/* Allineamento CTA IO MISURO più discreto */
.footer-institutional a,
.closing-institutional a,
.iomisuro-closing a,
.footer-iomisuro a {
    font-size: .78rem;
    letter-spacing: .13em;
    text-transform: uppercase;
}

/* Mobile */
@media (max-width: 768px) {
    .site-footer img,
    .footer img,
    footer img,
    .footer-brand img,
    .footer-logo img,
    .footer-iocablo img {
        max-width: 150px !important;
    }

    .closing-institutional img,
    .iomisuro-closing img,
    .footer-iomisuro img,
    .iomisuro-brand img {
        max-width: 180px !important;
    }

    .closing-institutional,
    .footer-institutional,
    .iomisuro-closing,
    .footer-iomisuro {
        background-size: min(300px, 72vw) auto !important;
        padding-top: 36px !important;
        padding-bottom: 36px !important;
    }

    .site-footer,
    .footer,
    footer.site-footer {
        padding-top: 44px !important;
        padding-bottom: 28px !important;
    }
}


/* ===== IO CABLO V13 - IO MISURO TEXT CONTRAST ===== */

.iomisuro-closing,
.footer-iomisuro,
.closing-institutional{
    color: rgba(255,255,255,.88) !important;
}

.iomisuro-closing p,
.footer-iomisuro p,
.closing-institutional p{
    color: rgba(255,255,255,.74) !important;
}

.iomisuro-closing .eyebrow,
.footer-iomisuro .eyebrow,
.closing-institutional .eyebrow{
    color: rgba(255,255,255,.52) !important;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.iomisuro-closing a,
.footer-iomisuro a,
.closing-institutional a{
    color: #f3c300 !important;
    text-decoration: none;
    transition: opacity .2s ease;
}

.iomisuro-closing a:hover,
.footer-iomisuro a:hover,
.closing-institutional a:hover{
    opacity: .82;
}


/* ===== IO CABLO V14 - IO MISURO STRIP PREMIUM CONTRAST ===== */

.iomisuro-closing,
.footer-iomisuro,
.closing-institutional,
.footer-institutional {
    position: relative;
    background: linear-gradient(135deg, rgba(5,13,31,.98), rgba(8,20,44,.96)) !important;
    border-top: 1px solid rgba(255,255,255,.08);
    border-bottom: 1px solid rgba(255,255,255,.08);
    color: rgba(255,255,255,.92) !important;
    padding-top: 42px !important;
    padding-bottom: 42px !important;
}

.iomisuro-closing::before,
.footer-iomisuro::before,
.closing-institutional::before,
.footer-institutional::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 20% 50%, rgba(30,86,230,.18), transparent 34%),
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
        linear-gradient(0deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size: auto, 72px 72px, 72px 72px;
    opacity: .55;
}

.iomisuro-closing > *,
.footer-iomisuro > *,
.closing-institutional > *,
.footer-institutional > * {
    position: relative;
    z-index: 1;
}

.iomisuro-closing .container,
.footer-iomisuro .container,
.closing-institutional .container,
.footer-institutional .container {
    display: grid !important;
    grid-template-columns: 180px 1fr auto;
    gap: 34px;
    align-items: center;
}

.iomisuro-closing img,
.footer-iomisuro img,
.closing-institutional img,
.footer-institutional img,
.iomisuro-brand img {
    max-width: 170px !important;
    height: auto !important;
    opacity: 1 !important;
    filter: none !important;
}

.iomisuro-closing .eyebrow,
.footer-iomisuro .eyebrow,
.closing-institutional .eyebrow,
.footer-institutional .eyebrow,
.iomisuro-closing small,
.footer-iomisuro small,
.closing-institutional small,
.footer-institutional small {
    display: block;
    margin-bottom: 8px;
    color: rgba(255,255,255,.68) !important;
    font-size: .72rem;
    line-height: 1.2;
    letter-spacing: .18em;
    text-transform: uppercase;
    font-weight: 700;
}

.iomisuro-closing p,
.footer-iomisuro p,
.closing-institutional p,
.footer-institutional p {
    color: rgba(255,255,255,.86) !important;
    max-width: 68ch;
    margin: 0;
    font-size: .98rem;
    line-height: 1.65;
}

.iomisuro-closing a,
.footer-iomisuro a,
.closing-institutional a,
.footer-institutional a {
    color: #ffffff !important;
    border: 1px solid rgba(255,255,255,.48);
    padding: 14px 22px;
    text-decoration: none !important;
    font-size: .76rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    transition: all .22s ease;
}

.iomisuro-closing a:hover,
.footer-iomisuro a:hover,
.closing-institutional a:hover,
.footer-institutional a:hover {
    border-color: rgba(255,255,255,.85);
    background: rgba(255,255,255,.08);
    transform: translateY(-1px);
}

.iomisuro-closing .container > *:first-child,
.footer-iomisuro .container > *:first-child,
.closing-institutional .container > *:first-child,
.footer-institutional .container > *:first-child {
    position: relative;
}

.iomisuro-closing .container > *:first-child::after,
.footer-iomisuro .container > *:first-child::after,
.closing-institutional .container > *:first-child::after,
.footer-institutional .container > *:first-child::after {
    content: "";
    position: absolute;
    right: -17px;
    top: 8px;
    bottom: 8px;
    width: 3px;
    background: #ffc400;
}

@media (max-width: 768px) {
    .iomisuro-closing,
    .footer-iomisuro,
    .closing-institutional,
    .footer-institutional {
        padding-top: 34px !important;
        padding-bottom: 34px !important;
    }

    .iomisuro-closing .container,
    .footer-iomisuro .container,
    .closing-institutional .container,
    .footer-institutional .container {
        grid-template-columns: 1fr !important;
        gap: 18px;
        align-items: start;
    }

    .iomisuro-closing img,
    .footer-iomisuro img,
    .closing-institutional img,
    .footer-institutional img,
    .iomisuro-brand img {
        max-width: 160px !important;
    }

    .iomisuro-closing .container > *:first-child::after,
    .footer-iomisuro .container > *:first-child::after,
    .closing-institutional .container > *:first-child::after,
    .footer-institutional .container > *:first-child::after {
        display: none;
    }

    .iomisuro-closing a,
    .footer-iomisuro a,
    .closing-institutional a,
    .footer-institutional a {
        width: fit-content;
    }
}


/* ===== IO CABLO V15 - FORCE IO MISURO STRIP VISIBILITY ===== */

/*
   Fix definitivo: la strip IO MISURO prima del footer aveva testi troppo scuri
   perché ereditava opacity/color dalle regole footer precedenti.
*/

section[class*="misuro"],
div[class*="misuro"],
section[class*="iomisuro"],
div[class*="iomisuro"],
section[class*="institutional"],
div[class*="institutional"],
section[class*="closing"],
div[class*="closing"]{
    opacity: 1 !important;
}

section[class*="misuro"] *,
div[class*="misuro"] *,
section[class*="iomisuro"] *,
div[class*="iomisuro"] *,
section[class*="institutional"] *,
div[class*="institutional"] *,
section[class*="closing"] *,
div[class*="closing"] *{
    opacity: 1 !important;
}

/* Strip alta IO MISURO */
section[class*="misuro"],
div[class*="misuro"],
section[class*="iomisuro"],
div[class*="iomisuro"],
section[class*="institutional"],
div[class*="institutional"]{
    background: linear-gradient(135deg, #071225 0%, #0a1730 100%) !important;
    color: #ffffff !important;
    border-top: 1px solid rgba(255,255,255,.10) !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
}

/* Testi strip IO MISURO */
section[class*="misuro"] p,
div[class*="misuro"] p,
section[class*="iomisuro"] p,
div[class*="iomisuro"] p,
section[class*="institutional"] p,
div[class*="institutional"] p{
    color: rgba(255,255,255,.86) !important;
}

section[class*="misuro"] small,
div[class*="misuro"] small,
section[class*="misuro"] span,
div[class*="misuro"] span,
section[class*="iomisuro"] small,
div[class*="iomisuro"] small,
section[class*="iomisuro"] span,
div[class*="iomisuro"] span,
section[class*="institutional"] small,
div[class*="institutional"] small,
section[class*="institutional"] span,
div[class*="institutional"] span{
    color: rgba(255,255,255,.70) !important;
}

/* Link/bottone IO MISURO */
section[class*="misuro"] a,
div[class*="misuro"] a,
section[class*="iomisuro"] a,
div[class*="iomisuro"] a,
section[class*="institutional"] a,
div[class*="institutional"] a{
    color: #ffffff !important;
    border-color: rgba(255,255,255,.55) !important;
    text-decoration: none !important;
}

/* Logo IO MISURO: resta visibile, pronto per versione bianca */
section[class*="misuro"] img,
div[class*="misuro"] img,
section[class*="iomisuro"] img,
div[class*="iomisuro"] img,
section[class*="institutional"] img,
div[class*="institutional"] img{
    opacity: 1 !important;
    filter: none !important;
    max-width: 180px !important;
    height: auto !important;
}

/* Se la strip usa classi del tema precedente */
.iomisuro-strip,
.iomisuro-closing,
.footer-iomisuro,
.closing-institutional,
.footer-institutional,
.io-misuro-strip,
.io-misuro-closing{
    background: linear-gradient(135deg, #071225 0%, #0a1730 100%) !important;
    color: #fff !important;
}

.iomisuro-strip *,
.iomisuro-closing *,
.footer-iomisuro *,
.closing-institutional *,
.footer-institutional *,
.io-misuro-strip *,
.io-misuro-closing *{
    opacity: 1 !important;
}

.iomisuro-strip p,
.iomisuro-closing p,
.footer-iomisuro p,
.closing-institutional p,
.footer-institutional p,
.io-misuro-strip p,
.io-misuro-closing p{
    color: rgba(255,255,255,.86) !important;
}

.iomisuro-strip .eyebrow,
.iomisuro-closing .eyebrow,
.footer-iomisuro .eyebrow,
.closing-institutional .eyebrow,
.footer-institutional .eyebrow,
.io-misuro-strip .eyebrow,
.io-misuro-closing .eyebrow{
    color: rgba(255,255,255,.72) !important;
}

.iomisuro-strip a,
.iomisuro-closing a,
.footer-iomisuro a,
.closing-institutional a,
.footer-institutional a,
.io-misuro-strip a,
.io-misuro-closing a{
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.55) !important;
    padding: 13px 22px;
}



/* ===== IO CABLO V16 - FOOTER COMPACT INSTITUTIONAL LAYOUT ===== */

/* Strip IO MISURO più compatta e orizzontale */
.footer-institutional-bridge,
.footer-bridge,
.footer-iomisuro,
.iomisuro-closing,
.closing-institutional,
.footer-institutional {
    padding-top: 34px !important;
    padding-bottom: 34px !important;
    min-height: 0 !important;
    background: linear-gradient(135deg, #071225 0%, #0a1730 100%) !important;
    border-top: 1px solid rgba(255,255,255,.10) !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
}

.footer-institutional-bridge .container,
.footer-bridge .container,
.footer-iomisuro .container,
.iomisuro-closing .container,
.closing-institutional .container,
.footer-institutional .container {
    display: grid !important;
    grid-template-columns: 190px 1fr auto !important;
    gap: 38px !important;
    align-items: center !important;
}

.footer-iomisuro-logo,
.footer-bridge-brand,
.footer-institutional-bridge img,
.footer-bridge img,
.footer-iomisuro img,
.iomisuro-closing img,
.closing-institutional img,
.footer-institutional img {
    max-width: 175px !important;
    height: auto !important;
    margin: 0 !important;
}

.footer-bridge-content,
.footer-iomisuro-content {
    max-width: 680px !important;
}

.footer-bridge-eyebrow,
.footer-iomisuro .eyebrow,
.iomisuro-closing .eyebrow,
.closing-institutional .eyebrow,
.footer-institutional .eyebrow {
    margin: 0 0 8px 0 !important;
    color: rgba(255,255,255,.70) !important;
    font-size: .72rem !important;
    letter-spacing: .18em !important;
    line-height: 1.2 !important;
}

.footer-bridge-content p,
.footer-iomisuro p,
.iomisuro-closing p,
.closing-institutional p,
.footer-institutional p {
    margin: 0 !important;
    color: rgba(255,255,255,.88) !important;
    font-size: .96rem !important;
    line-height: 1.55 !important;
}

.footer-bridge-cta,
.footer-iomisuro-cta {
    justify-self: end !important;
}

.footer-bridge-cta a,
.footer-iomisuro a,
.iomisuro-closing a,
.closing-institutional a,
.footer-institutional a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    padding: 12px 22px !important;
    white-space: nowrap !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.52) !important;
    background: transparent !important;
}

/* Separatore verticale più controllato */
.footer-bridge-brand,
.footer-iomisuro-logo,
.footer-institutional-bridge .container > *:first-child,
.footer-bridge .container > *:first-child,
.footer-iomisuro .container > *:first-child,
.iomisuro-closing .container > *:first-child,
.closing-institutional .container > *:first-child,
.footer-institutional .container > *:first-child {
    position: relative !important;
}

.footer-bridge-brand::after,
.footer-iomisuro-logo::after,
.footer-institutional-bridge .container > *:first-child::after,
.footer-bridge .container > *:first-child::after,
.footer-iomisuro .container > *:first-child::after,
.iomisuro-closing .container > *:first-child::after,
.closing-institutional .container > *:first-child::after,
.footer-institutional .container > *:first-child::after {
    content: "" !important;
    position: absolute !important;
    right: -20px !important;
    top: 10px !important;
    bottom: 10px !important;
    width: 2px !important;
    background: #ffc400 !important;
}

/* Footer principale: più basso, griglia reale, niente effetto colonna lunghissima */
.site-footer,
.institutional-footer,
footer.site-footer {
    padding-top: 46px !important;
    padding-bottom: 28px !important;
    min-height: 0 !important;
}

.site-footer .container,
.institutional-footer .container,
footer.site-footer .container {
    max-width: 1240px !important;
}

.footer-grid,
.footer-grid-institutional {
    display: grid !important;
    grid-template-columns: minmax(280px, 1.25fr) minmax(180px,.75fr) minmax(170px,.65fr) minmax(220px,.8fr) !important;
    gap: 52px !important;
    align-items: start !important;
}

.footer-brand {
    max-width: 360px !important;
}

.footer-iocablo-logo,
.footer-brand img,
.site-footer .footer-brand img {
    max-width: 300px !important;
    height: auto !important;
    margin-bottom: 22px !important;
}

.footer-brand-desc,
.footer-brand p {
    max-width: 36ch !important;
    margin-top: 0 !important;
    margin-bottom: 22px !important;
    font-size: .96rem !important;
    line-height: 1.65 !important;
    color: rgba(255,255,255,.78) !important;
}

.footer-col h3,
.footer-col-title,
.footer-grid h3,
.site-footer h3 {
    margin: 0 0 18px 0 !important;
    color: rgba(255,255,255,.78) !important;
    font-size: .72rem !important;
    line-height: 1.2 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
}

.footer-col h3::after,
.footer-col-title::after,
.site-footer h3::after {
    content: "" !important;
    display: block !important;
    width: 28px !important;
    height: 2px !important;
    margin-top: 14px !important;
    background: #1858ff !important;
}

.footer-col ul,
.site-footer ul {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.footer-col li,
.site-footer li {
    margin: 0 0 11px 0 !important;
    line-height: 1.35 !important;
}

.footer-col a,
.site-footer a,
.footer-col p,
.site-footer p {
    color: rgba(255,255,255,.76) !important;
    font-size: .96rem !important;
    line-height: 1.55 !important;
}

.footer-col a:hover,
.site-footer a:hover {
    color: #fff !important;
}

.footer-contact p,
.footer-operativity,
.footer-social {
    margin-bottom: 12px !important;
}

.footer-bottom,
.footer-bottom-institutional,
.footer-documents {
    margin-top: 36px !important;
    padding-top: 22px !important;
    border-top: 1px solid rgba(255,255,255,.12) !important;
    display: flex !important;
    justify-content: space-between !important;
    gap: 24px !important;
    align-items: center !important;
    color: rgba(255,255,255,.58) !important;
    font-size: .86rem !important;
}

/* Riduce eventuali blocchi contatti duplicati o spazi eccessivi ereditati */
.site-footer [class*="contact"] {
    min-height: 0 !important;
}

@media (max-width: 1024px) {
    .footer-institutional-bridge .container,
    .footer-bridge .container,
    .footer-iomisuro .container,
    .iomisuro-closing .container,
    .closing-institutional .container,
    .footer-institutional .container {
        grid-template-columns: 170px 1fr !important;
    }

    .footer-bridge-cta,
    .footer-iomisuro-cta {
        grid-column: 2 !important;
        justify-self: start !important;
    }

    .footer-grid,
    .footer-grid-institutional {
        grid-template-columns: 1fr 1fr !important;
        gap: 36px !important;
    }
}

@media (max-width: 768px) {
    .footer-institutional-bridge,
    .footer-bridge,
    .footer-iomisuro,
    .iomisuro-closing,
    .closing-institutional,
    .footer-institutional {
        padding-top: 28px !important;
        padding-bottom: 28px !important;
    }

    .footer-institutional-bridge .container,
    .footer-bridge .container,
    .footer-iomisuro .container,
    .iomisuro-closing .container,
    .closing-institutional .container,
    .footer-institutional .container {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .footer-bridge-brand::after,
    .footer-iomisuro-logo::after,
    .footer-institutional-bridge .container > *:first-child::after,
    .footer-bridge .container > *:first-child::after,
    .footer-iomisuro .container > *:first-child::after,
    .iomisuro-closing .container > *:first-child::after,
    .closing-institutional .container > *:first-child::after,
    .footer-institutional .container > *:first-child::after {
        display: none !important;
    }

    .footer-grid,
    .footer-grid-institutional {
        grid-template-columns: 1fr !important;
        gap: 28px !important;
    }

    .footer-iocablo-logo,
    .footer-brand img,
    .site-footer .footer-brand img {
        max-width: 240px !important;
    }

    .site-footer,
    .institutional-footer,
    footer.site-footer {
        padding-top: 36px !important;
        padding-bottom: 24px !important;
    }

    .footer-bottom,
    .footer-bottom-institutional,
    .footer-documents {
        flex-direction: column !important;
        align-items: flex-start !important;
        margin-top: 28px !important;
    }
}





/* ===== IO CABLO V32 — FOOTER FILO CONDUTTORE IO MISURO ===== */
/* Struttura compatta, ispirata al footer IO MISURO, con identità scura IO CABLO. */

.iocablo-v32-bridge,
.iocablo-v32-footer{
  font-family:var(--font-body, 'Bricolage Grotesque', sans-serif);
}

.iocablo-v32-bridge{
  background:var(--off-white, #F5F7FC);
  border-top:1px solid var(--line, #DDE3F0);
  border-bottom:1px solid var(--line, #DDE3F0);
  color:var(--ink, #0C1428);
}

.iocablo-v32-bridge-inner{
  padding:24px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}

.iocablo-v32-bridge-content{
  display:flex;
  align-items:center;
  gap:28px;
  min-width:0;
}

.iocablo-v32-bridge-logo{
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
  text-decoration:none;
}

.iocablo-v32-bridge-logo img{
  display:block;
  height:auto;
  max-height:56px;
  object-fit:contain;
}

.iocablo-v32-bridge-desc{
  position:relative;
  padding-left:28px;
  max-width:620px;
}

.iocablo-v32-bridge-desc:before{
  content:"";
  position:absolute;
  left:0;
  top:4px;
  bottom:4px;
  width:2px;
  background:var(--blue, #1050E8);
}

.iocablo-v32-bridge-desc span{
  display:block;
  margin-bottom:4px;
  font-family:var(--font-display, 'Antonio', sans-serif);
  color:var(--blue, #1050E8);
  font-size:11px;
  line-height:1.2;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.iocablo-v32-bridge-desc p{
  margin:0;
  color:var(--ink-soft, #5A6880);
  font-size:14px;
  line-height:1.6;
}

.iocablo-v32-bridge-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 18px;
  border:1px solid var(--line, #DDE3F0);
  color:var(--ink, #0C1428);
  background:#fff;
  text-decoration:none;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
  transition:all .2s ease;
}

.iocablo-v32-bridge-cta:hover{
  border-color:var(--blue, #1050E8);
  color:var(--blue, #1050E8);
  transform:translateY(-1px);
}

/* Footer coerente con IO MISURO ma in versione IO CABLO */
.iocablo-v32-footer{
  background:
    radial-gradient(circle at 18% 12%, rgba(16,80,232,.10), transparent 30%),
    linear-gradient(135deg,#050d1f 0%,#081427 100%);
  color:rgba(255,255,255,.72);
  padding:46px 0 24px;
  overflow:hidden;
  position:relative;
}

.iocablo-v32-footer:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:72px 72px;
  opacity:.45;
}

.iocablo-v32-footer > .container{
  position:relative;
  z-index:1;
}

.iocablo-v32-footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:44px;
  align-items:start;
}

.iocablo-v32-footer-logo{
  display:inline-flex;
  margin-bottom:16px;
  text-decoration:none;
}

.iocablo-v32-footer-logo img{
  display:block;
  max-height:64px;
  height:auto;
  object-fit:contain;
}

.iocablo-v32-footer-brand p{
  max-width:42ch;
  margin:0;
  color:rgba(255,255,255,.64);
  font-size:14px;
  line-height:1.65;
}

.iocablo-v32-footer-col h5{
  margin:0 0 14px;
  font-family:var(--font-display, 'Antonio', sans-serif);
  color:rgba(255,255,255,.42);
  font-size:11px;
  line-height:1.2;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:700;
}

.iocablo-v32-footer-col ul{
  list-style:none;
  padding:0;
  margin:0;
}

.iocablo-v32-footer-col li{
  margin:0 0 9px;
  color:rgba(255,255,255,.58);
  font-size:14px;
  line-height:1.45;
}

.iocablo-v32-footer-col a{
  color:rgba(255,255,255,.68);
  text-decoration:none;
  transition:color .18s ease;
}

.iocablo-v32-footer-col a:hover{
  color:#fff;
}

.iocablo-v32-footer-bottom{
  margin-top:34px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.iocablo-v32-footer-bottom p{
  margin:0;
  color:rgba(255,255,255,.42);
  font-size:12px;
  line-height:1.5;
}

.iocablo-v32-footer-links{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}

.iocablo-v32-footer-links a{
  color:rgba(255,255,255,.44);
  font-size:12px;
  text-decoration:none;
}

.iocablo-v32-footer-links a:hover{
  color:rgba(255,255,255,.78);
}

/* Logo footer ad alto contrasto — sicurezza dimensioni */
.iocablo-v32-bridge img,
.iocablo-v32-footer img{
  max-width:100%;
  height:auto;
}
/* Se il logo footer è svg/png con sfondo trasparente e colori chiari
   non serve filter — viene gestito lato admin (caricando la versione giusta) */
.iocablo-v32-footer-logo img,
.iocablo-v32-bridge-logo img {
  display: block;
  height: auto;
  object-fit: contain;
}


/* Social icons footer IO CABLO */
.iocablo-v32-footer-right{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
}
.iocablo-v32-footer-social{
  display:flex;
  gap:6px;
  align-items:center;
}
.iocablo-v32-social-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.52);
  border-radius:4px;
  text-decoration:none;
  transition:border-color .18s ease, color .18s ease, background .18s ease;
}
.iocablo-v32-social-icon:hover{
  border-color:rgba(255,255,255,.45);
  color:#fff;
  background:rgba(255,255,255,.06);
}
/* Responsive */
@media(max-width:1024px){
  .iocablo-v32-bridge-inner{
    align-items:flex-start;
    flex-direction:column;
  }

  .iocablo-v32-bridge-content{
    align-items:flex-start;
  }

  .iocablo-v32-footer-grid{
    grid-template-columns:1.4fr 1fr 1fr;
  }

  .iocablo-v32-footer-col:last-child{
    grid-column:2 / span 2;
  }
}

@media(max-width:768px){
  .iocablo-v32-bridge-inner{
    padding:22px 0;
    gap:18px;
  }

  .iocablo-v32-bridge-content{
    flex-direction:column;
    gap:16px;
  }

  .iocablo-v32-bridge-desc{
    padding-left:0;
  }

  .iocablo-v32-bridge-desc:before{
    display:none;
  }

  .iocablo-v32-footer{
    padding:36px 0 22px;
  }

  .iocablo-v32-footer-grid{
    grid-template-columns:1fr;
    gap:26px;
  }

  .iocablo-v32-footer-col:last-child{
    grid-column:auto;
  }

  .iocablo-v32-footer-bottom{
    flex-direction:column;
    align-items:flex-start;
    margin-top:28px;
  }
}

/* ─── COOKIE BANNER ─── */
.io-cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99999;
  padding: 0;
  box-shadow: 0 -4px 32px rgba(0,0,0,.18);
}
.io-cookie-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 16px 24px;
  max-width: 1200px;
  margin: 0 auto;
  flex-wrap: wrap;
}
.io-cookie-text {
  flex: 1;
  min-width: 260px;
}
.io-cookie-text p {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
}
.io-cookie-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.io-cookie-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 18px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: 0;
  cursor: pointer;
  white-space: nowrap;
  transition: all .18s ease;
  border: 1px solid transparent;
}
@media (max-width: 600px) {
  .io-cookie-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    padding: 16px;
  }
  .io-cookie-actions {
    width: 100%;
  }
  .io-cookie-btn {
    flex: 1;
    justify-content: center;
  }
}

/* Banner IO CABLO — sfondo scuro, toni blu */
.io-cookie-banner--cablo {
  background: #071225;
  border-top: 1px solid rgba(255,255,255,.10);
}
.io-cookie-banner--cablo .io-cookie-text p {
  color: rgba(255,255,255,.72);
}
.io-cookie-banner--cablo .io-cookie-text a {
  color: rgba(255,255,255,.85);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.io-cookie-btn--secondary {
  background: transparent;
  border-color: rgba(255,255,255,.28);
  color: rgba(255,255,255,.72);
}
.io-cookie-btn--secondary:hover {
  border-color: rgba(255,255,255,.55);
  color: #fff;
}
.io-cookie-btn--primary {
  background: var(--blue, #1050E8);
  border-color: var(--blue, #1050E8);
  color: #fff;
}
.io-cookie-btn--primary:hover {
  background: #0c40c0;
  border-color: #0c40c0;
}


/* ===== IO CABLO V41 MERGED CONSOLIDATED LAYER ===== */

:root{
  --blue:#1050E8;
  --blue-light:#4D83FF;
  --yellow:#FFC000;
  --ink:#0C1428;
  --ink-soft:#5A6880;
  --off-white:#F4F7FC;
  --line:#DDE3F0;
  --dark:#050D1F;
  --dark-2:#081427;
  --display:'Antonio',system-ui,sans-serif;
  --body:'Bricolage Grotesque',system-ui,sans-serif;
  --max:1180px;
}

body.iocablo-v41-active{overflow-x:hidden}
.ioc-container,.container{width:min(var(--max),calc(100% - 48px));margin-left:auto;margin-right:auto}

.ioc-hero__canvas{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  pointer-events:none!important;
  z-index:1!important;
  opacity:1!important;
}
.ioc-hero > .ioc-container{position:relative!important;z-index:3!important}
.ioc-hero{
  background:
    radial-gradient(circle at 72% 26%, rgba(16,80,232,.34), transparent 34%),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(135deg,#050d1f 0%,#081427 58%,#071225 100%)!important;
  background-size:auto,72px 72px,72px 72px,auto!important;
}

/* Service experience */
.ioc-service-hero--experience{
  position:relative;
  overflow:hidden;
  min-height:560px;
  display:flex;
  align-items:center;
  background:
    radial-gradient(circle at 76% 28%, rgba(16,80,232,.30), transparent 34%),
    linear-gradient(135deg,#050d1f 0%,#081427 58%,#071225 100%)!important;
  padding:clamp(92px,9vw,140px) 0 82px!important;
  color:#fff;
}
.ioc-service-hero--experience:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.036) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.026) 1px, transparent 1px);
  background-size:72px 72px;
  opacity:.28;
}
.ioc-service-hero__bg{position:absolute;inset:0;pointer-events:none;opacity:.7}
.ioc-service-hero__bg span{position:absolute;display:block;height:2px;background:linear-gradient(90deg,transparent,rgba(77,131,255,.75),transparent)}
.ioc-service-hero__bg span:nth-child(1){left:5%;right:8%;top:32%}
.ioc-service-hero__bg span:nth-child(2){left:18%;right:18%;top:47%;opacity:.55}
.ioc-service-hero__bg span:nth-child(3){left:42%;right:4%;top:62%;opacity:.42}
.ioc-service-hero__bg span:nth-child(4){left:60%;right:10%;top:22%;background:linear-gradient(90deg,transparent,rgba(255,192,0,.8),transparent)}
.ioc-service-hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.55fr);gap:70px;align-items:center}
.ioc-service-hero__copy .ioc-eyebrow{color:var(--blue-light)}
.ioc-service-hero__copy h1{font-family:var(--display);font-size:clamp(48px,7vw,96px);line-height:.9;letter-spacing:-.055em;max-width:920px;margin:0 0 24px;color:#fff}
.ioc-service-hero__copy p{max-width:780px;color:rgba(255,255,255,.76);font-size:clamp(18px,1.35vw,22px);line-height:1.62;margin:0}
.ioc-service-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.ioc-service-badges span{display:inline-flex;align-items:center;min-height:36px;padding:8px 12px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.055);color:rgba(255,255,255,.82);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.ioc-service-diagram{position:relative;min-height:320px;border:1px solid rgba(255,255,255,.10);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025));box-shadow:0 24px 80px rgba(0,0,0,.22)}
.ioc-diagram-line{position:absolute;left:12%;right:12%;top:50%;height:3px;background:linear-gradient(90deg,rgba(77,131,255,.2),rgba(77,131,255,.85),rgba(255,192,0,.85))}
.ioc-diagram-node{position:absolute;width:18px;height:18px;border-radius:999px;background:var(--blue-light);box-shadow:0 0 0 12px rgba(77,131,255,.12)}
.ioc-diagram-node.node-a{left:18%;top:calc(50% - 8px)}
.ioc-diagram-node.node-b{left:48%;top:calc(50% - 8px)}
.ioc-diagram-node.node-c{right:18%;top:calc(50% - 8px);background:var(--yellow);box-shadow:0 0 0 12px rgba(255,192,0,.12)}
.ioc-diagram-rack{position:absolute;left:50%;top:19%;width:74px;height:96px;transform:translateX(-50%);border:2px solid rgba(255,255,255,.28);background:repeating-linear-gradient(180deg,rgba(255,255,255,.12) 0 8px,transparent 8px 16px)}
.ioc-service-strip{background:rgba(255,255,255,.96);border-bottom:1px solid var(--line)}
.ioc-service-strip__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(12,20,40,.08)}
.ioc-service-strip__grid span{min-height:66px;display:flex;align-items:center;padding:16px 18px;background:rgba(255,255,255,.96);color:var(--ink);font-weight:800;font-size:13px}
.ioc-service-experience{background:rgba(244,247,252,.94);padding:76px 0}
.ioc-service-problems{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ioc-service-problems article{position:relative;background:rgba(255,255,255,.96);border:1px solid var(--line);padding:26px;min-height:220px;box-shadow:0 12px 34px rgba(12,20,40,.05)}
.ioc-service-problems article:before{content:"";position:absolute;left:0;top:22px;bottom:22px;width:3px;background:var(--yellow)}
.ioc-service-problems h3{font-family:var(--display);font-size:28px;line-height:1.02;letter-spacing:-.035em;margin:0 0 14px;color:var(--ink)}
.ioc-service-problems p{color:var(--ink-soft);margin:0;line-height:1.68}
.ioc-service-process{background:rgba(255,255,255,.96);padding:76px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ioc-service-process__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:70px;align-items:start}
.ioc-service-process h2{font-family:var(--display);font-size:clamp(38px,4.4vw,64px);line-height:.98;letter-spacing:-.045em;margin:0 0 18px}
.ioc-service-process p{color:var(--ink-soft);font-size:18px}
.ioc-service-steps{display:grid;gap:14px}
.ioc-service-steps article{display:grid;grid-template-columns:64px 1fr;gap:18px;padding:22px;background:rgba(244,247,252,.94);border:1px solid var(--line)}
.ioc-service-steps article span{display:flex;align-items:center;justify-content:center;width:52px;height:52px;background:#EBF0FF;color:var(--blue);font-weight:900}
.ioc-service-steps h3{margin:0 0 5px;font-family:var(--display);font-size:24px;line-height:1.1}
.ioc-service-steps p{margin:0;font-size:15px}
.ioc-service-body{background:rgba(244,247,252,.94);padding:76px 0!important}
.ioc-service-content{box-shadow:0 14px 44px rgba(12,20,40,.06)}
.ioc-service-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:54px;align-items:start}
.ioc-service-sidebar{position:sticky;top:96px;display:grid;gap:14px}
.ioc-service-box{background:rgba(255,255,255,.96);border:1px solid var(--line);padding:24px}
.ioc-service-box:first-child{background:linear-gradient(135deg,var(--dark),var(--dark-2));color:#fff;border-color:rgba(255,255,255,.08)}
.ioc-service-box h3{margin:0 0 12px;font-family:var(--display);font-size:24px}
.ioc-service-box p{color:inherit;opacity:.72;margin:0 0 14px}
.ioc-service-box a{color:var(--blue-light);font-weight:900;text-decoration:none}

/* Footer lock */
.ioc-bridge{background:rgba(244,247,252,.94);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ioc-bridge__inner{padding:24px 0;display:flex;align-items:center;justify-content:space-between;gap:30px}
.ioc-bridge__content{display:flex;align-items:center;gap:30px;min-width:0}
.ioc-bridge__logo{display:inline-flex;flex:0 0 auto;text-decoration:none}
.ioc-bridge__logo img{display:block;max-height:60px;object-fit:contain}
.ioc-bridge__text{position:relative;padding-left:30px;max-width:660px}
.ioc-bridge__text:before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:2px;background:var(--blue)}
.ioc-bridge__text span{display:block;color:var(--blue);font-family:var(--display);font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:4px}
.ioc-bridge__text p{margin:0;color:var(--ink-soft);font-size:14px}
.ioc-bridge__cta{border:1px solid var(--line);background:rgba(255,255,255,.96);color:var(--ink);text-decoration:none;padding:12px 18px;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.ioc-footer{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--dark),var(--dark-2));color:rgba(255,255,255,.72);padding:48px 0 24px}
.ioc-footer:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(255,255,255,.024) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:72px 72px;opacity:.28}
.ioc-footer > .ioc-container{position:relative;z-index:1}
.ioc-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px}
.ioc-footer__brand img{display:block;max-height:74px;object-fit:contain;margin-bottom:18px}
.ioc-footer__brand p{max-width:42ch;margin:0;color:rgba(255,255,255,.64);font-size:14px}
.ioc-footer__col h5{margin:0 0 14px;color:rgba(255,255,255,.42);font-family:var(--display);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.ioc-footer__col ul{list-style:none;margin:0;padding:0}
.ioc-footer__col li{margin:0 0 9px;color:rgba(255,255,255,.58);font-size:14px}
.ioc-footer__col a{color:rgba(255,255,255,.68);text-decoration:none}
.ioc-footer__col a:hover{color:#fff}
.ioc-footer__bottom{margin-top:34px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;gap:24px}
.ioc-footer__bottom p{margin:0;color:rgba(255,255,255,.42);font-size:12px}
.ioc-footer__bottom div{display:flex;gap:20px}
.ioc-footer__bottom a{color:rgba(255,255,255,.44);font-size:12px;text-decoration:none}
.ioc-whatsapp{position:fixed;right:22px;bottom:22px;z-index:60;width:58px;height:58px;border-radius:999px;display:grid;place-items:center;background:#20d466;color:#fff;text-decoration:none;font-size:26px;box-shadow:0 14px 34px rgba(32,212,102,.32)}

@media(max-width:1024px){
  .ioc-service-hero__grid,.ioc-service-process__grid,.ioc-service-layout{grid-template-columns:1fr}
  .ioc-service-diagram{min-height:240px}
  .ioc-service-problems{grid-template-columns:1fr}
  .ioc-service-strip__grid{grid-template-columns:1fr 1fr}
  .ioc-service-sidebar{position:static}
  .ioc-footer__grid{grid-template-columns:1.4fr 1fr 1fr}
  .ioc-footer__col:last-child{grid-column:2 / span 2}
}
@media(max-width:768px){
  .ioc-container,.container{width:min(100% - 32px,var(--max))}
  .ioc-service-hero--experience{min-height:auto;padding:78px 0 58px!important}
  .ioc-service-strip__grid{grid-template-columns:1fr}
  .ioc-service-steps article{grid-template-columns:1fr}
  .ioc-footer__grid{grid-template-columns:1fr}
  .ioc-footer__col:last-child{grid-column:auto}
  .ioc-bridge__inner,.ioc-bridge__content{flex-direction:column;align-items:flex-start}
  .ioc-bridge__text{padding-left:0}
  .ioc-bridge__text:before{display:none}
  .ioc-footer__bottom{flex-direction:column;align-items:flex-start}
}


/* ===== IO CABLO V43 FOOTER DEBUG LOCK ===== */
/* Footer isolato: non usa .site-footer, footer a, footer ul o selettori globali. */

.ioc-v43-bridge,
.ioc-v43-footer{
  font-family:var(--body,'Bricolage Grotesque',system-ui,sans-serif);
}

.ioc-v43-bridge{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(16,80,232,.07), transparent 42%),
    #F4F7FC;
  border-top:1px solid #DDE3F0;
  border-bottom:1px solid #DDE3F0;
  color:#0C1428;
}

.ioc-v43-bridge__inner{
  display:grid;
  grid-template-columns:210px minmax(0,1fr) auto;
  gap:34px;
  align-items:center;
  padding:24px 0;
}

.ioc-v43-bridge__brand{
  position:relative;
  min-height:58px;
  display:flex;
  align-items:center;
}

.ioc-v43-bridge__brand:after{
  content:"";
  position:absolute;
  right:-18px;
  top:4px;
  bottom:4px;
  width:2px;
  background:#1050E8;
}

.ioc-v43-bridge__brand a{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
}

.ioc-v43-bridge__brand img{
  display:block;
  max-width:100%;
  max-height:60px;
  width:auto;
  height:auto;
  object-fit:contain;
}

.ioc-v43-bridge__copy span{
  display:block;
  margin:0 0 6px;
  font-family:var(--display,'Antonio',system-ui,sans-serif);
  color:#1050E8;
  font-size:11px;
  line-height:1.2;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:800;
}

.ioc-v43-bridge__copy p{
  margin:0;
  max-width:720px;
  color:#5A6880;
  font-size:14px;
  line-height:1.62;
}

.ioc-v43-bridge__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:11px 18px;
  border:1px solid #DDE3F0;
  background:#fff;
  color:#0C1428;
  text-decoration:none;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
  transition:all .18s ease;
}

.ioc-v43-bridge__cta:hover{
  border-color:#1050E8;
  color:#1050E8;
  transform:translateY(-1px);
}

.ioc-v43-footer{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 18% 12%, rgba(16,80,232,.10), transparent 30%),
    linear-gradient(135deg,#050d1f 0%,#081427 100%);
  color:rgba(255,255,255,.72);
  padding:46px 0 24px;
}

.ioc-v43-footer:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:72px 72px;
  opacity:.28;
}

.ioc-v43-footer > .container{
  position:relative;
  z-index:1;
}

.ioc-v43-footer__grid{
  display:grid;
  grid-template-columns:minmax(300px,1.7fr) minmax(170px,.85fr) minmax(160px,.75fr) minmax(220px,.9fr);
  gap:44px;
  align-items:start;
}

.ioc-v43-footer__brand a{
  display:inline-flex;
  align-items:center;
  margin:0 0 18px;
  text-decoration:none;
}

.ioc-v43-footer__brand img{
  display:block;
  max-width:100%;
  max-height:76px;
  width:auto;
  height:auto;
  object-fit:contain;
}

.ioc-v43-footer__brand p{
  margin:0;
  max-width:42ch;
  color:rgba(255,255,255,.64);
  font-size:14px;
  line-height:1.65;
}

.ioc-v43-footer__col h5{
  margin:0 0 16px;
  color:rgba(255,255,255,.44);
  font-family:var(--display,'Antonio',system-ui,sans-serif);
  font-size:11px;
  line-height:1.2;
  letter-spacing:.17em;
  text-transform:uppercase;
  font-weight:800;
}

.ioc-v43-footer__col h5:after{
  content:"";
  display:block;
  width:28px;
  height:2px;
  margin-top:12px;
  background:#1050E8;
}

.ioc-v43-footer__col ul{
  list-style:none;
  margin:0;
  padding:0;
}

.ioc-v43-footer__col li{
  margin:0 0 10px;
  color:rgba(255,255,255,.58);
  font-size:14px;
  line-height:1.45;
}

.ioc-v43-footer__col a{
  color:rgba(255,255,255,.70);
  text-decoration:none;
  transition:color .18s ease;
}

.ioc-v43-footer__col a:hover{
  color:#fff;
}

.ioc-v43-footer__bottom{
  margin-top:34px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.ioc-v43-footer__bottom p{
  margin:0;
  color:rgba(255,255,255,.42);
  font-size:12px;
  line-height:1.5;
}

.ioc-v43-footer__bottom div{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
}

.ioc-v43-footer__bottom a{
  color:rgba(255,255,255,.46);
  font-size:12px;
  text-decoration:none;
}

.ioc-v43-footer__bottom a:hover{
  color:rgba(255,255,255,.82);
}

.ioc-v43-whatsapp{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:80;
  width:58px;
  height:58px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:#20d466;
  color:#fff;
  text-decoration:none;
  font-size:26px;
  box-shadow:0 14px 34px rgba(32,212,102,.32);
}

@media(max-width:1024px){
  .ioc-v43-bridge__inner{
    grid-template-columns:190px 1fr;
    gap:30px;
  }

  .ioc-v43-bridge__cta{
    grid-column:2;
    justify-self:start;
  }

  .ioc-v43-footer__grid{
    grid-template-columns:1.35fr 1fr 1fr;
    gap:36px;
  }

  .ioc-v43-footer__col:last-child{
    grid-column:2 / span 2;
  }
}

@media(max-width:768px){
  .ioc-v43-bridge__inner{
    grid-template-columns:1fr;
    gap:16px;
    padding:24px 0;
  }

  .ioc-v43-bridge__brand:after{
    display:none;
  }

  .ioc-v43-bridge__cta{
    grid-column:auto;
  }

  .ioc-v43-footer{
    padding:38px 0 24px;
  }

  .ioc-v43-footer__grid{
    grid-template-columns:1fr;
    gap:28px;
  }

  .ioc-v43-footer__col:last-child{
    grid-column:auto;
  }

  .ioc-v43-footer__bottom{
    flex-direction:column;
    align-items:flex-start;
    margin-top:28px;
  }
}


/* ===== IO CABLO V44 SERVICE PAGES RESTORE LOCK ===== */
/* Compatibilità per pagine servizio V32, senza toccare footer V43. */

.ic-srv-hero{
  background:
    radial-gradient(circle at 78% 20%, rgba(16,80,232,.22), transparent 34%),
    linear-gradient(135deg,#0C1428 0%,#081427 100%) !important;
  padding:72px 0 56px !important;
  border-bottom:3px solid #1050E8 !important;
  position:relative !important;
  overflow:hidden !important;
}

.ic-srv-hero:before{
  content:"" !important;
  position:absolute !important;
  right:-80px !important;
  top:-80px !important;
  width:420px !important;
  height:420px !important;
  border:1px solid rgba(255,255,255,.06) !important;
  border-radius:50% !important;
}

.ic-srv-hero:after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  background:
    linear-gradient(90deg, rgba(255,255,255,.030) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.022) 1px, transparent 1px) !important;
  background-size:72px 72px !important;
  opacity:.22 !important;
}

.ic-srv-hero .container{
  position:relative !important;
  z-index:2 !important;
}

.ic-srv-kicker{
  font-family:var(--display,'Antonio',sans-serif) !important;
  font-size:11px !important;
  letter-spacing:.2em !important;
  text-transform:uppercase !important;
  color:#FFC000 !important;
  margin-bottom:20px !important;
}

.ic-srv-hero h1{
  font-family:var(--display,'Antonio',sans-serif) !important;
  font-size:clamp(36px,5.5vw,70px) !important;
  font-weight:700 !important;
  letter-spacing:-.03em !important;
  color:#fff !important;
  line-height:1.02 !important;
  margin:0 0 18px !important;
}

.ic-srv-sub{
  font-size:17px !important;
  color:rgba(255,255,255,.62) !important;
  max-width:620px !important;
  line-height:1.7 !important;
  margin:0 !important;
}

.ic-service-strip{
  background:#fff !important;
  border-bottom:1px solid #DDE3F0 !important;
}

.ic-service-strip-grid{
  display:grid !important;
  grid-template-columns:repeat(4,1fr) !important;
  gap:1px !important;
  background:rgba(12,20,40,.08) !important;
}

.ic-service-strip-grid span{
  display:flex !important;
  align-items:center !important;
  min-height:58px !important;
  padding:14px 18px !important;
  background:#fff !important;
  color:#0C1428 !important;
  font-weight:700 !important;
  font-size:13px !important;
}

.ic-srv-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) 360px !important;
  gap:56px !important;
  align-items:start !important;
}

.ic-srv-side{
  position:sticky !important;
  top:90px !important;
  display:flex !important;
  flex-direction:column !important;
  gap:14px !important;
}

.ic-tag{
  font-family:var(--display,'Antonio',sans-serif) !important;
  font-size:10px !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  color:#1050E8 !important;
  background:#EBF0FF !important;
  padding:4px 12px !important;
  display:inline-flex !important;
  margin-bottom:18px !important;
}

.ic-section-title{
  font-family:var(--display,'Antonio',sans-serif) !important;
  font-size:clamp(24px,3vw,36px) !important;
  font-weight:700 !important;
  letter-spacing:-.02em !important;
  color:#0C1428 !important;
  line-height:1.08 !important;
  margin:0 0 24px !important;
}

.ic-box{
  background:#F5F7FC !important;
  border:1px solid #DDE3F0 !important;
  padding:24px !important;
}

.ic-box-dark{
  background:#0C1428 !important;
  border:1px solid rgba(255,255,255,.08) !important;
  padding:24px !important;
  color:#fff !important;
}

.ic-crit-grid{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:1px !important;
  background:rgba(12,20,40,.1) !important;
  border:1px solid rgba(12,20,40,.1) !important;
}

.ic-crit-card{
  background:#fff !important;
  padding:28px !important;
  min-height:180px !important;
}

.ic-crit-card h3{
  font-family:var(--display,'Antonio',sans-serif) !important;
  font-size:18px !important;
  font-weight:700 !important;
  color:#0C1428 !important;
  margin:0 0 10px !important;
}

.ic-crit-card p,
.ic-item-desc{
  font-size:13px !important;
  color:#5A6880 !important;
  line-height:1.65 !important;
  margin:0 !important;
}

.ic-btn{
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  font-family:var(--display,'Antonio',sans-serif) !important;
  font-size:12px !important;
  font-weight:700 !important;
  letter-spacing:.1em !important;
  text-transform:uppercase !important;
  padding:14px 24px !important;
  min-height:48px !important;
  text-decoration:none !important;
  border:2px solid transparent !important;
  cursor:pointer !important;
}

.ic-btn-w{
  background:#fff !important;
  color:#1050E8 !important;
}

.ic-cta-strip{
  background:#1050E8 !important;
  padding:48px 0 !important;
}

.ic-altri-grid{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:6px !important;
}

@media(max-width:900px){
  .ic-srv-grid{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  .ic-srv-side{
    position:static !important;
  }
  .ic-service-strip-grid{
    grid-template-columns:1fr 1fr !important;
  }
}

@media(max-width:600px){
  .ic-crit-grid,
  .ic-altri-grid,
  .ic-service-strip-grid{
    grid-template-columns:1fr !important;
  }
}


/* IO CABLO V45 FOOTER AREA FIX FALLBACK */
.ioc-v43-footer__col ul{list-style:none!important;margin:0!important;padding:0!important}
.ioc-v43-footer__col a{text-decoration:none!important}
.ioc-v43-footer__grid{display:grid!important}
.ioc-v43-bridge__inner{display:grid!important}



/* =========================================================
   IO CABLO V46 PROFESSIONAL POLISH
   Rifiniture responsive + leggibilità + gerarchie
========================================================= */

/* ---------- CONTAINER ---------- */
.container{
  width:min(1180px, calc(100% - 48px));
}

/* ---------- HERO ---------- */
.ioc-hero,
.hero,
.hero-section{
  position:relative;
  overflow:hidden;
}

.ioc-hero h1,
.hero h1,
.hero-section h1{
  line-height:.96;
  letter-spacing:-.04em;
  text-wrap:balance;
}

.ioc-hero p,
.hero p,
.hero-section p{
  max-width:720px;
  line-height:1.7;
}

/* ---------- NAV ---------- */
header nav a,
.site-header nav a{
  transition:opacity .18s ease, color .18s ease;
}

header nav a:hover,
.site-header nav a:hover{
  opacity:1;
}

/* ---------- CARD SERVIZI ---------- */
.ioc-service-card,
.service-card,
.card-servizio{
  transition:
    transform .22s ease,
    border-color .22s ease,
    box-shadow .22s ease;
}

.ioc-service-card:hover,
.service-card:hover,
.card-servizio:hover{
  transform:translateY(-3px);
}

/* ---------- CRITICITÀ ---------- */
.ic-crit-card{
  transition:
    transform .18s ease,
    background .18s ease,
    border-color .18s ease;
}

.ic-crit-card:hover{
  transform:translateY(-2px);
}

/* ---------- FOOTER MICRO POLISH ---------- */
.ioc-v43-footer{
  padding-bottom:20px!important;
}

.ioc-v43-footer__grid{
  align-items:start!important;
}

.ioc-v43-footer__brand p{
  text-wrap:pretty;
}

.ioc-v43-footer__col li{
  margin-bottom:12px!important;
}

.ioc-v43-footer__bottom{
  margin-top:28px!important;
}

/* ---------- WHATSAPP ---------- */
.ioc-v43-whatsapp{
  transition:
    transform .18s ease,
    box-shadow .18s ease;
}

.ioc-v43-whatsapp:hover{
  transform:translateY(-2px) scale(1.02);
}

/* =========================================================
   BREAKPOINT CLEANUP
========================================================= */

@media (max-width:1280px){

  .container{
    width:min(100% - 56px, 1180px);
  }

  .ioc-v43-footer__grid{
    gap:36px!important;
  }
}

@media (max-width:1024px){

  .container{
    width:min(100% - 48px, 1180px);
  }

  .ioc-hero,
  .hero,
  .hero-section{
    padding-top:96px;
    padding-bottom:72px;
  }

  .ioc-v43-footer__grid{
    grid-template-columns:1.3fr 1fr 1fr!important;
  }
}

@media (max-width:900px){

  .ioc-v43-bridge__inner{
    gap:24px!important;
  }

  .ic-srv-grid{
    grid-template-columns:1fr!important;
    gap:32px!important;
  }

  .ic-srv-side{
    position:static!important;
  }
}

@media (max-width:768px){

  .container{
    width:min(100% - 36px, 1180px);
  }

  .ioc-hero h1,
  .hero h1,
  .hero-section h1{
    line-height:1.02;
  }

  .ioc-v43-footer{
    padding-top:34px!important;
  }

  .ioc-v43-footer__grid{
    grid-template-columns:1fr!important;
    gap:28px!important;
  }

  .ioc-v43-footer__brand img{
    max-height:68px!important;
  }

  .ioc-v43-footer__bottom{
    flex-direction:column!important;
    align-items:flex-start!important;
    gap:12px!important;
  }

  .ioc-v43-whatsapp{
    width:54px!important;
    height:54px!important;
    right:16px!important;
    bottom:16px!important;
    font-size:24px!important;
  }
}

@media (max-width:640px){

  .container{
    width:min(100% - 28px, 1180px);
  }

  .ioc-hero,
  .hero,
  .hero-section{
    padding-top:84px;
    padding-bottom:56px;
  }

  .ioc-hero p,
  .hero p,
  .hero-section p{
    font-size:15px;
  }

  .ioc-v43-bridge__inner{
    padding:20px 0!important;
  }

  .ioc-v43-bridge__copy p{
    font-size:13px!important;
    line-height:1.6!important;
  }

  .ioc-v43-footer__brand p{
    font-size:13px!important;
  }

  .ioc-v43-footer__col li{
    font-size:13px!important;
  }

  .ic-crit-card{
    min-height:auto!important;
    padding:22px!important;
  }
}



/* =========================================================
   IO CABLO V47 — DENSITY & RHYTHM REFINEMENT
   Riduzione vuoti verticali senza cambiare identità grafica
========================================================= */

/* ---------- HERO SERVIZI PIÙ COMPATTA ---------- */
.ic-srv-hero{
  padding-top:58px!important;
  padding-bottom:44px!important;
}

.ic-srv-hero h1{
  margin-bottom:16px!important;
}

.ic-srv-sub{
  max-width:660px!important;
}

/* fascia subito più collegata alla hero */
.ic-service-strip-grid span{
  min-height:50px!important;
  padding-top:12px!important;
  padding-bottom:12px!important;
}

/* ---------- CONTENUTO SERVIZIO: MENO PAGINA INFINITA ---------- */

/* blocchi principali creati inline nei template V32 */
.ic-srv-hero + .ic-service-strip + div,
.ic-service-strip + div{
  padding-top:54px!important;
  padding-bottom:54px!important;
}

/* riduzione margini verticali sezioni interne */
.ic-srv-grid > div > div{
  margin-bottom:42px!important;
}

.ic-item{
  padding-top:13px!important;
  padding-bottom:13px!important;
}

.ic-section-title{
  margin-bottom:18px!important;
}

/* sidebar più compatta */
.ic-box,
.ic-box-dark{
  padding:22px!important;
}

.ic-srv-side{
  gap:12px!important;
}

/* ---------- CRITICITÀ PIÙ DENSE ---------- */
.ic-crit-card{
  min-height:150px!important;
  padding:24px!important;
}

.ic-crit-idx{
  margin-bottom:14px!important;
}

.ic-crit-card h3{
  margin-bottom:8px!important;
}

/* blocco criticità: meno aria sopra e sotto */
section:has(.ic-crit-grid){
  padding-top:58px!important;
  padding-bottom:58px!important;
}

/* ---------- LAVORI ESEGUITI PIÙ COMPATTI ---------- */
section:has(.ic-work-card),
section:has(.ic-lavori-grid),
section:has(.ic-altri-grid){
  padding-top:58px!important;
  padding-bottom:58px!important;
}

.ic-work-card,
.ic-lavoro-card{
  padding-top:30px!important;
  padding-bottom:30px!important;
}

.ic-altri-grid{
  gap:10px!important;
}

/* ---------- CTA BLU PIÙ PREMIUM ---------- */
.ic-cta-strip{
  padding-top:38px!important;
  padding-bottom:38px!important;
}

.ic-cta-strip .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:36px;
}

/* ---------- STRIP IO MISURO + FOOTER PIÙ COMPATTI ---------- */
.ioc-v43-bridge__inner{
  padding-top:18px!important;
  padding-bottom:18px!important;
}

.ioc-v43-footer{
  padding-top:38px!important;
  padding-bottom:20px!important;
}

.ioc-v43-footer__grid{
  gap:36px!important;
}

.ioc-v43-footer__brand a{
  margin-bottom:14px!important;
}

.ioc-v43-footer__brand img{
  max-height:68px!important;
}

.ioc-v43-footer__col h5{
  margin-bottom:13px!important;
}

.ioc-v43-footer__col li{
  margin-bottom:9px!important;
}

.ioc-v43-footer__bottom{
  margin-top:26px!important;
  padding-top:16px!important;
}

/* ---------- GENERALE DESKTOP ---------- */
@media(min-width:1025px){
  .container{
    width:min(1120px, calc(100% - 64px))!important;
  }

  .ic-srv-grid{
    gap:48px!important;
  }
}

/* ---------- TABLET ---------- */
@media(max-width:1024px){
  .ic-srv-hero{
    padding-top:54px!important;
    padding-bottom:42px!important;
  }

  .ic-srv-hero + .ic-service-strip + div,
  .ic-service-strip + div{
    padding-top:46px!important;
    padding-bottom:46px!important;
  }

  .ic-crit-card{
    min-height:auto!important;
  }

  .ioc-v43-footer{
    padding-top:34px!important;
  }
}

/* ---------- MOBILE ---------- */
@media(max-width:768px){
  .ic-srv-hero{
    padding-top:46px!important;
    padding-bottom:36px!important;
  }

  .ic-service-strip-grid span{
    min-height:44px!important;
  }

  .ic-srv-hero + .ic-service-strip + div,
  .ic-service-strip + div{
    padding-top:38px!important;
    padding-bottom:38px!important;
  }

  .ic-srv-grid > div > div{
    margin-bottom:34px!important;
  }

  .ic-cta-strip{
    padding-top:32px!important;
    padding-bottom:32px!important;
  }

  .ic-cta-strip .container{
    flex-direction:column;
    align-items:flex-start;
    gap:22px;
  }

  .ioc-v43-bridge__inner{
    padding-top:18px!important;
    padding-bottom:18px!important;
  }

  .ioc-v43-footer{
    padding-top:32px!important;
  }
}

@media(max-width:640px){
  .ic-srv-hero h1{
    font-size:clamp(34px,11vw,48px)!important;
  }

  .ic-srv-sub{
    font-size:15px!important;
  }

  .ic-item{
    padding-top:11px!important;
    padding-bottom:11px!important;
  }
}



/* =========================================================
   IO CABLO V48 — HOME RHYTHM & HIERARCHY REFINEMENT
   Meno respiro inutile, gerarchie più professionali
========================================================= */

/* ---------- RITMO GENERALE HOME ---------- */

/* riduzione sezioni troppo alte */
.home section,
body.home section{
  scroll-margin-top:82px;
}

/* sezioni chiare/scure più dense */
.home .section,
.home .ic-section,
.home .home-section,
.home .ioc-section,
body.home .section,
body.home .ic-section,
body.home .home-section,
body.home .ioc-section{
  padding-top:clamp(58px,5.8vw,82px)!important;
  padding-bottom:clamp(58px,5.8vw,82px)!important;
}

/* sezioni che arrivavano troppo lunghe */
.home .ic-problems,
.home .ic-services,
.home .ic-method,
.home .ic-brands,
.home .ic-contact,
body.home .ic-problems,
body.home .ic-services,
body.home .ic-method,
body.home .ic-brands,
body.home .ic-contact{
  padding-top:clamp(56px,5vw,76px)!important;
  padding-bottom:clamp(56px,5vw,76px)!important;
}

/* ---------- HERO HOME ---------- */

.home .hero,
.home .ioc-hero,
body.home .hero,
body.home .ioc-hero{
  min-height:calc(100vh - 88px)!important;
  padding-top:clamp(92px,8vw,124px)!important;
  padding-bottom:clamp(68px,6vw,96px)!important;
}

.home .hero h1,
.home .ioc-hero h1,
body.home .hero h1,
body.home .ioc-hero h1{
  font-size:clamp(54px,7vw,92px)!important;
  line-height:.94!important;
  max-width:840px!important;
}

.home .hero p,
.home .ioc-hero p,
body.home .hero p,
body.home .ioc-hero p{
  max-width:650px!important;
  font-size:clamp(16px,1.18vw,19px)!important;
  line-height:1.62!important;
}

/* eyebrow hero più ordinato */
.home .hero .eyebrow,
.home .ioc-hero .ioc-eyebrow,
body.home .hero .eyebrow,
body.home .ioc-hero .ioc-eyebrow{
  margin-bottom:18px!important;
  letter-spacing:.18em!important;
}

/* ---------- TITOLI SEZIONE ---------- */

.home h2,
body.home h2{
  text-wrap:balance;
}

/* titoli giganti: meno urlati */
.home .section-title,
.home .ic-section-title-xl,
.home .home-section h2,
.home .ioc-section h2,
body.home .section-title,
body.home .ic-section-title-xl,
body.home .home-section h2,
body.home .ioc-section h2{
  font-size:clamp(38px,4.8vw,68px)!important;
  line-height:.98!important;
  letter-spacing:-.045em!important;
}

/* sezione "Come lavoriamo": troppo dominante, la abbassiamo */
.home #come-lavoriamo h2,
.home .come-lavoriamo h2,
.home .ic-method h2,
body.home #come-lavoriamo h2,
body.home .come-lavoriamo h2,
body.home .ic-method h2{
  font-size:clamp(38px,4.2vw,58px)!important;
  line-height:1!important;
  max-width:620px!important;
}

/* sezione ambiti: titolo molto grande ma più controllato */
.home #ambiti-intervento h2,
.home .ambiti-intervento h2,
body.home #ambiti-intervento h2,
body.home .ambiti-intervento h2{
  font-size:clamp(44px,5.2vw,72px)!important;
  line-height:.96!important;
}

/* ---------- TESTI ---------- */

.home p,
body.home p{
  text-wrap:pretty;
}

.home .section-intro,
.home .ic-section-intro,
body.home .section-intro,
body.home .ic-section-intro{
  max-width:680px!important;
  font-size:16px!important;
  line-height:1.68!important;
}

/* ---------- CARD PROBLEMI REALI ---------- */

.home .problem-card,
.home .ic-problem-card,
.home .problems-grid > *,
body.home .problem-card,
body.home .ic-problem-card,
body.home .problems-grid > *{
  min-height:auto!important;
  padding:24px!important;
}

.home .problem-card h3,
.home .ic-problem-card h3,
body.home .problem-card h3,
body.home .ic-problem-card h3{
  font-size:clamp(24px,2.2vw,34px)!important;
  line-height:1.02!important;
  margin-bottom:12px!important;
}

.home .problem-card p,
.home .ic-problem-card p,
body.home .problem-card p,
body.home .ic-problem-card p{
  font-size:15px!important;
  line-height:1.58!important;
}

/* ---------- METODO ---------- */

.home .method-step,
.home .ic-method-step,
body.home .method-step,
body.home .ic-method-step{
  margin-bottom:28px!important;
}

.home .method-step p,
.home .ic-method-step p,
body.home .method-step p,
body.home .ic-method-step p{
  max-width:640px!important;
}

/* ---------- AMBITI / SERVIZI HOME ---------- */

.home .service-card,
.home .ic-service-card,
.home .services-grid > *,
body.home .service-card,
body.home .ic-service-card,
body.home .services-grid > *{
  padding:28px!important;
}

.home .service-card h3,
.home .ic-service-card h3,
body.home .service-card h3,
body.home .ic-service-card h3{
  font-size:clamp(28px,2.8vw,42px)!important;
  line-height:1.02!important;
}

.home .service-card p,
.home .ic-service-card p,
body.home .service-card p,
body.home .ic-service-card p{
  font-size:15px!important;
  line-height:1.58!important;
}

/* riduce lo stacco prima delle FAQ */
.home #faq,
.home .faq,
.home .ic-faq,
body.home #faq,
body.home .faq,
body.home .ic-faq{
  padding-top:52px!important;
}

/* ---------- MARCHI TRATTATI ---------- */

.home .brands,
.home .ic-brands,
.home #marchi-trattati,
body.home .brands,
body.home .ic-brands,
body.home #marchi-trattati{
  padding-top:50px!important;
  padding-bottom:54px!important;
}

.home .brands h2,
.home .ic-brands h2,
.home #marchi-trattati h2,
body.home .brands h2,
body.home .ic-brands h2,
body.home #marchi-trattati h2{
  font-size:clamp(34px,3.8vw,52px)!important;
  margin-bottom:28px!important;
}

.home .brand-grid,
.home .brands-grid,
.home .ic-brand-grid,
body.home .brand-grid,
body.home .brands-grid,
body.home .ic-brand-grid{
  gap:14px!important;
  align-items:center!important;
}

.home .brand-grid img,
.home .brands-grid img,
.home .ic-brand-grid img,
body.home .brand-grid img,
body.home .brands-grid img,
body.home .ic-brand-grid img{
  max-height:44px!important;
  object-fit:contain!important;
  opacity:.72;
  filter:grayscale(1);
  transition:opacity .18s ease, filter .18s ease, transform .18s ease;
}

.home .brand-grid img:hover,
.home .brands-grid img:hover,
.home .ic-brand-grid img:hover,
body.home .brand-grid img:hover,
body.home .brands-grid img:hover,
body.home .ic-brand-grid img:hover{
  opacity:1;
  filter:grayscale(0);
  transform:translateY(-1px);
}

/* ---------- CONTATTI ---------- */

.home #contatti,
.home .contatti,
.home .contact,
.home .ic-contact,
body.home #contatti,
body.home .contatti,
body.home .contact,
body.home .ic-contact{
  padding-top:64px!important;
  padding-bottom:64px!important;
}

.home #contatti h2,
.home .contatti h2,
.home .contact h2,
body.home #contatti h2,
body.home .contatti h2,
body.home .contact h2{
  font-size:clamp(40px,4.6vw,64px)!important;
}

/* ---------- STRIP IO MISURO / FOOTER ---------- */

.ioc-v43-bridge__inner{
  padding-top:16px!important;
  padding-bottom:16px!important;
}

.ioc-v43-bridge__copy p{
  line-height:1.5!important;
}

.ioc-v43-footer{
  padding-top:34px!important;
}

.ioc-v43-footer__grid{
  gap:32px!important;
}

.ioc-v43-footer__brand img{
  max-height:64px!important;
}

.ioc-v43-footer__brand p,
.ioc-v43-footer__col li{
  font-size:13px!important;
}

.ioc-v43-footer__bottom{
  margin-top:22px!important;
}

/* ---------- WHATSAPP FLOATING COERENTE ---------- */

.ioc-v43-whatsapp{
  width:52px!important;
  height:52px!important;
  background:#1050E8!important;
  border:1px solid rgba(255,255,255,.28)!important;
  box-shadow:
    0 0 0 7px rgba(16,80,232,.12),
    0 14px 34px rgba(16,80,232,.34)!important;
  font-size:0!important;
}

.ioc-v43-whatsapp:before{
  content:""!important;
  width:22px!important;
  height:22px!important;
  display:block!important;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.5 11.8a8.5 8.5 0 0 1-12.6 7.4L3 20.5l1.3-4.7A8.5 8.5 0 1 1 20.5 11.8Z'/%3E%3Cpath d='M8.8 8.9c.2-.4.4-.4.7-.4h.5c.2 0 .4 0 .5.4l.7 1.7c.1.3.1.5-.1.7l-.4.5c.6 1 1.4 1.8 2.5 2.4l.6-.4c.2-.2.5-.2.7-.1l1.6.7c.4.2.4.4.4.7v.4c0 .4-.2.7-.5.9-.5.3-1.3.5-2.4.2-2.8-.7-5.2-3-6-5.8-.3-1 0-1.8.3-2.3Z'/%3E%3C/svg%3E") center/contain no-repeat!important;
}

.ioc-v43-whatsapp:hover{
  background:#0C1428!important;
  transform:translateY(-2px) scale(1.02)!important;
}

/* ---------- RESPONSIVE ---------- */

@media(max-width:1024px){
  .home .hero h1,
  .home .ioc-hero h1,
  body.home .hero h1,
  body.home .ioc-hero h1{
    font-size:clamp(48px,8vw,76px)!important;
  }

  .home .section,
  .home .ic-section,
  .home .home-section,
  body.home .section,
  body.home .ic-section,
  body.home .home-section{
    padding-top:54px!important;
    padding-bottom:54px!important;
  }
}

@media(max-width:768px){
  .home .hero,
  .home .ioc-hero,
  body.home .hero,
  body.home .ioc-hero{
    min-height:auto!important;
    padding-top:78px!important;
    padding-bottom:56px!important;
  }

  .home .hero h1,
  .home .ioc-hero h1,
  body.home .hero h1,
  body.home .ioc-hero h1{
    font-size:clamp(42px,11vw,58px)!important;
    line-height:.98!important;
  }

  .home .section,
  .home .ic-section,
  .home .home-section,
  body.home .section,
  body.home .ic-section,
  body.home .home-section{
    padding-top:46px!important;
    padding-bottom:46px!important;
  }

  .ioc-v43-whatsapp{
    width:48px!important;
    height:48px!important;
    right:14px!important;
    bottom:14px!important;
  }
}

@media(max-width:640px){
  .home .hero p,
  .home .ioc-hero p,
  body.home .hero p,
  body.home .ioc-hero p{
    font-size:15px!important;
  }

  .home .service-card,
  .home .ic-service-card,
  .home .problem-card,
  .home .ic-problem-card,
  body.home .service-card,
  body.home .ic-service-card,
  body.home .problem-card,
  body.home .ic-problem-card{
    padding:22px!important;
  }

  .home #contatti,
  .home .contatti,
  .home .contact,
  body.home #contatti,
  body.home .contatti,
  body.home .contact{
    padding-top:48px!important;
    padding-bottom:48px!important;
  }
}



/* =========================================================
   IO CABLO V49 — SURGICAL HOME POLISH
   Correzione su classi reali V32/home, non selettori generici
========================================================= */

/* ---------- HOME SECTION RHYTHM, CLASSI REALI ---------- */

body.home .ic-hero,
body.home .ic-home-hero,
body.home .hero{
  min-height:calc(100vh - 78px)!important;
  padding-top:86px!important;
  padding-bottom:62px!important;
}

body.home .ic-hero-title,
body.home .hero-title,
body.home .ic-hero h1,
body.home .hero h1{
  font-size:clamp(54px,6.6vw,88px)!important;
  line-height:.94!important;
  max-width:820px!important;
}

body.home .ic-hero-text,
body.home .hero-text,
body.home .ic-hero p,
body.home .hero p{
  max-width:620px!important;
  font-size:clamp(16px,1.08vw,18px)!important;
  line-height:1.58!important;
}

/* sezioni home V32: meno distacco */
body.home .ic-section,
body.home .ic-section-light,
body.home .ic-section-dark,
body.home .ic-section-grid,
body.home .ic-problems-section,
body.home .ic-method-section,
body.home .ic-services-section,
body.home .ic-faq-section,
body.home .ic-brands-section,
body.home .ic-contact-section{
  padding-top:58px!important;
  padding-bottom:58px!important;
}

/* fallback: sezioni dirette del main quando non hanno classi coerenti */
body.home main > section{
  padding-top:58px!important;
  padding-bottom:58px!important;
}

/* prima sezione dopo hero: avvicinata */
body.home main > section:first-child + section,
body.home .ic-hero + section,
body.home .hero + section{
  padding-top:54px!important;
}

/* ---------- GERARCHIE TITOLI REALI ---------- */

body.home .ic-title-xl,
body.home .ic-section-title-xl,
body.home .ic-big-title,
body.home .ic-problems-title,
body.home .ic-method-title,
body.home .ic-services-title{
  font-size:clamp(42px,5vw,68px)!important;
  line-height:.96!important;
  letter-spacing:-.05em!important;
}

/* "Qui non prende..." troppo grande */
body.home .ic-problems-section h2,
body.home #problemi h2,
body.home #problemi-reali h2,
body.home .problemi-reali h2{
  font-size:clamp(44px,5.2vw,72px)!important;
  line-height:.96!important;
  max-width:880px!important;
}

/* "Come lavoriamo" troppo dominante */
body.home .ic-method-section h2,
body.home #come-lavoriamo h2,
body.home .come-lavoriamo h2{
  font-size:clamp(38px,4vw,56px)!important;
  line-height:1!important;
  max-width:560px!important;
}

/* "Infrastrutture ordinate..." troppo pesante */
body.home #ambiti-intervento h2,
body.home .ic-services-section h2,
body.home .ambiti-intervento h2{
  font-size:clamp(42px,4.8vw,66px)!important;
  line-height:.98!important;
  max-width:620px!important;
}

/* "Parliamo della tua rete" ok ma più compatto */
body.home #contatti h2,
body.home .ic-contact-section h2,
body.home .ic-contact h2{
  font-size:clamp(40px,4.4vw,60px)!important;
  margin-bottom:18px!important;
}

/* ---------- PROBLEMI REALI ---------- */

body.home .ic-problems-grid{
  gap:14px!important;
}

body.home .ic-problem-card,
body.home .ic-problems-grid > article,
body.home .ic-problems-grid > div{
  min-height:auto!important;
  padding:24px!important;
}

body.home .ic-problem-card h3,
body.home .ic-problems-grid h3{
  font-size:clamp(25px,2.1vw,32px)!important;
  line-height:1.02!important;
  margin-bottom:12px!important;
}

body.home .ic-problem-card p,
body.home .ic-problems-grid p{
  font-size:15px!important;
  line-height:1.58!important;
}

/* ---------- COME LAVORIAMO ---------- */

body.home .ic-method-section{
  padding-top:58px!important;
  padding-bottom:56px!important;
}

body.home .ic-method-grid,
body.home .ic-method-layout{
  gap:46px!important;
}

body.home .ic-method-step{
  margin-bottom:22px!important;
}

body.home .ic-method-step p{
  font-size:15px!important;
  line-height:1.55!important;
}

/* ---------- AMBITI / CARDS SERVIZI ---------- */

body.home .ic-services-section{
  padding-top:60px!important;
  padding-bottom:62px!important;
}

body.home .ic-services-grid{
  gap:16px!important;
}

body.home .ic-service-card,
body.home .ic-services-grid > article,
body.home .ic-services-grid > div{
  padding:26px!important;
  min-height:300px!important;
}

body.home .ic-service-card h3,
body.home .ic-services-grid h3{
  font-size:clamp(30px,2.7vw,40px)!important;
  line-height:1.02!important;
}

body.home .ic-service-card p,
body.home .ic-services-grid p{
  font-size:15px!important;
  line-height:1.56!important;
}

/* ---------- FAQ / SOPRALLUOGO ---------- */

body.home .ic-faq-section,
body.home #faq,
body.home .faq{
  padding-top:46px!important;
  padding-bottom:46px!important;
}

body.home .ic-faq-section h2,
body.home #faq h2{
  font-size:clamp(34px,3.8vw,52px)!important;
  margin-bottom:22px!important;
}

body.home .ic-faq-item,
body.home .faq-item{
  padding-top:16px!important;
  padding-bottom:16px!important;
}

/* ---------- MARCHI TRATTATI ---------- */

body.home .ic-brands-section,
body.home #marchi,
body.home #marchi-trattati{
  padding-top:44px!important;
  padding-bottom:46px!important;
}

body.home .ic-brands-section h2,
body.home #marchi h2,
body.home #marchi-trattati h2{
  font-size:clamp(32px,3.3vw,46px)!important;
  margin-bottom:24px!important;
}

body.home .ic-brand-card,
body.home .ic-brands-grid > *,
body.home .brand-card{
  min-height:72px!important;
  padding:14px 18px!important;
}

/* ---------- NEWS / TICKER SETTORE ---------- */

body.home .ic-news-section,
body.home .ic-sector-section,
body.home .ic-ticker-section{
  padding-top:38px!important;
  padding-bottom:38px!important;
}

body.home .ic-news-grid,
body.home .ic-sector-grid{
  min-height:auto!important;
}

/* ---------- CONTATTI ---------- */

body.home .ic-contact-section,
body.home #contatti{
  padding-top:54px!important;
  padding-bottom:54px!important;
}

body.home .ic-contact-grid,
body.home .contact-grid{
  gap:54px!important;
  align-items:start!important;
}

body.home .ic-contact-info,
body.home .contact-info{
  padding-top:0!important;
}

body.home .ic-contact-form,
body.home .contact-form{
  margin-top:0!important;
}

/* contatti -> strip IO MISURO: togli vuoto */
body.home #contatti + .ioc-v43-bridge,
body.home .ic-contact-section + .ioc-v43-bridge{
  margin-top:0!important;
}

/* ---------- STRIP / FOOTER ---------- */

.ioc-v43-bridge__inner{
  padding-top:15px!important;
  padding-bottom:15px!important;
}

.ioc-v43-footer{
  padding-top:32px!important;
}

.ioc-v43-footer__grid{
  gap:30px!important;
}

.ioc-v43-footer__brand img{
  max-height:60px!important;
}

.ioc-v43-footer__bottom{
  margin-top:20px!important;
}

/* ---------- WHATSAPP: FIX ANCHE PER CLASSI DIVERSE ---------- */

.ioc-v43-whatsapp,
.ioc-whatsapp,
.whatsapp-float,
.whatsapp-button,
a[href*="wa.me"]{
  width:50px!important;
  height:50px!important;
  border-radius:999px!important;
  background:#1050E8!important;
  border:1px solid rgba(255,255,255,.28)!important;
  box-shadow:
    0 0 0 7px rgba(16,80,232,.12),
    0 14px 34px rgba(16,80,232,.34)!important;
}

/* limita il reset solo ai floating, non ai link testuali WhatsApp nel footer */
.ioc-v43-footer a[href*="wa.me"]{
  width:auto!important;
  height:auto!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  border-radius:0!important;
}

.ioc-v43-whatsapp,
.ioc-whatsapp,
.whatsapp-float,
.whatsapp-button{
  font-size:0!important;
}

.ioc-v43-whatsapp:before,
.ioc-whatsapp:before,
.whatsapp-float:before,
.whatsapp-button:before{
  content:""!important;
  width:22px!important;
  height:22px!important;
  display:block!important;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.5 11.8a8.5 8.5 0 0 1-12.6 7.4L3 20.5l1.3-4.7A8.5 8.5 0 1 1 20.5 11.8Z'/%3E%3Cpath d='M8.8 8.9c.2-.4.4-.4.7-.4h.5c.2 0 .4 0 .5.4l.7 1.7c.1.3.1.5-.1.7l-.4.5c.6 1 1.4 1.8 2.5 2.4l.6-.4c.2-.2.5-.2.7-.1l1.6.7c.4.2.4.4.4.7v.4c0 .4-.2.7-.5.9-.5.3-1.3.5-2.4.2-2.8-.7-5.2-3-6-5.8-.3-1 0-1.8.3-2.3Z'/%3E%3C/svg%3E") center/contain no-repeat!important;
}

/* se plugin esterno inserisce svg/immagine verde */
.ioc-v43-whatsapp svg,
.ioc-v43-whatsapp img,
.ioc-whatsapp svg,
.ioc-whatsapp img,
.whatsapp-float svg,
.whatsapp-float img,
.whatsapp-button svg,
.whatsapp-button img{
  display:none!important;
}

/* ---------- RESPONSIVE CHIRURGICO ---------- */

@media(max-width:1024px){
  body.home .ic-hero,
  body.home .ic-home-hero,
  body.home .hero{
    min-height:auto!important;
    padding-top:78px!important;
    padding-bottom:56px!important;
  }

  body.home .ic-title-xl,
  body.home .ic-section-title-xl,
  body.home .ic-big-title,
  body.home .ic-problems-title,
  body.home .ic-method-title,
  body.home .ic-services-title{
    font-size:clamp(38px,6vw,58px)!important;
  }

  body.home .ic-section,
  body.home .ic-section-light,
  body.home .ic-section-dark,
  body.home main > section{
    padding-top:48px!important;
    padding-bottom:48px!important;
  }
}

@media(max-width:768px){
  body.home .ic-hero,
  body.home .ic-home-hero,
  body.home .hero{
    padding-top:70px!important;
    padding-bottom:48px!important;
  }

  body.home .ic-hero-title,
  body.home .hero-title,
  body.home .ic-hero h1,
  body.home .hero h1{
    font-size:clamp(40px,11vw,56px)!important;
    line-height:.98!important;
  }

  body.home .ic-section,
  body.home .ic-section-light,
  body.home .ic-section-dark,
  body.home main > section{
    padding-top:42px!important;
    padding-bottom:42px!important;
  }

  body.home .ic-problems-section h2,
  body.home #problemi h2,
  body.home #problemi-reali h2,
  body.home .problemi-reali h2,
  body.home .ic-method-section h2,
  body.home #come-lavoriamo h2,
  body.home .come-lavoriamo h2,
  body.home #ambiti-intervento h2,
  body.home .ic-services-section h2,
  body.home .ambiti-intervento h2{
    font-size:clamp(34px,9vw,48px)!important;
  }

  body.home .ic-service-card,
  body.home .ic-services-grid > article,
  body.home .ic-services-grid > div,
  body.home .ic-problem-card,
  body.home .ic-problems-grid > article,
  body.home .ic-problems-grid > div{
    padding:22px!important;
    min-height:auto!important;
  }

  .ioc-v43-whatsapp,
  .ioc-whatsapp,
  .whatsapp-float,
  .whatsapp-button{
    width:46px!important;
    height:46px!important;
    right:14px!important;
    bottom:14px!important;
  }
}

@media(max-width:640px){
  body.home .ic-section,
  body.home .ic-section-light,
  body.home .ic-section-dark,
  body.home main > section{
    padding-top:36px!important;
    padding-bottom:36px!important;
  }

  body.home .ic-contact-section,
  body.home #contatti{
    padding-top:42px!important;
    padding-bottom:42px!important;
  }
}


/* IO CABLO V50 STYLE MARKER — if visible in inspector, style.css is updated */
body.iocablo-v50-activation-cleanup:before{content:none!important}


/* =========================================================
   IO CABLO V51 — WHATSAPP DEDUPE
   Il tema non genera più il floating WhatsApp: evita doppioni con plugin esterni.
========================================================= */

/* Nasconde eventuali vecchi pulsanti floating del tema se rimasti in cache/markup */
.ioc-v43-whatsapp,
.ioc-whatsapp{
  display:none!important;
}

/* Ripristina link WhatsApp normali nei testi, bottoni e footer */
a[href*="wa.me"]{
  width:auto;
  height:auto;
  border-radius:inherit;
  box-shadow:inherit;
  font-size:inherit;
}

/* Se esiste un plugin esterno, non lo forziamo con CSS del tema.
   Evitiamo però che il tema aggiunga pseudo-icone sopra. */
a[href*="wa.me"]:before{
  content:normal;
}

/* Solo i link testuali/footer restano puliti */
.ioc-v43-footer a[href*="wa.me"],
.ioc-footer a[href*="wa.me"]{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  color:rgba(255,255,255,.70)!important;
  text-decoration:none!important;
}


/* =========================================================
   IO CABLO V52 — TOTAL POLISH MARKER
========================================================= */
body.iocablo-v50-activation-cleanup{}


/* IO CABLO V53 STYLE BACKUP — critical CSS is also injected in header.php */


/* IO CABLO V54 — Hero background cleanup backup */
body.home .hero,
body.home .ic-hero,
body.home .ic-home-hero{
  background:radial-gradient(circle at 72% 28%, rgba(16,80,232,.12), transparent 34%),linear-gradient(135deg,#050d1f 0%,#081427 100%)!important;
  background-size:auto!important;
}
body.home .hero-overlay{background:none!important;opacity:.18!important}
body.home #iocHeroCanvas,
body.home .ioc-hero__canvas,
body.home .hero canvas{opacity:.72!important;mix-blend-mode:screen!important}


/* IO CABLO V55 — Hero layer fix backup */
body.home .hero,body.home .ic-hero,body.home .ic-home-hero{position:relative!important;isolation:isolate!important;overflow:hidden!important}
body.home .hero canvas,body.home .ic-hero canvas,body.home #iocHeroCanvas,body.home .ioc-hero__canvas,body.home .hero-overlay{position:absolute!important;inset:0!important;z-index:0!important;pointer-events:none!important}
body.home .hero>.container,body.home .ic-hero>.container,body.home .ic-home-hero>.container,body.home .hero-inner,body.home .hero-content{position:relative!important;z-index:3!important}
body.home .hero h1,body.home .hero p,body.home .hero a,body.home .hero .btn{position:relative!important;z-index:4!important}


/* IO CABLO V56 — Ambiti di intervento layout fix backup */
body.home .ic-services-section{padding-top:38px!important;padding-bottom:42px!important}
body.home .icv4-card{min-height:230px!important;padding:24px!important;border-radius:14px!important;display:flex!important;flex-direction:column!important;justify-content:space-between!important}
body.home .icv4-card:first-child{min-height:210px!important}
body.home .icv4-title{font-size:clamp(25px,2.45vw,36px)!important;line-height:1.02!important;margin-bottom:12px!important}
body.home .icv4-foot{margin-top:28px!important;padding-top:18px!important}


/* IO CABLO V57 — Section headers + cards fix backup */
body.home .icv4-card{min-height:unset!important;height:auto!important;padding:26px!important;display:grid!important;grid-template-rows:auto 1fr auto!important}
body.home .icv4-title{font-size:clamp(25px,2.25vw,34px)!important;line-height:1.04!important;margin:0 0 10px!important}
body.home .icv4-foot{margin:22px 0 0!important;padding-top:16px!important;align-self:end!important}
@media(min-width:1025px){body.home .icv4-card:first-child{min-height:260px!important;grid-template-columns:minmax(0,.95fr) minmax(260px,.65fr)!important;column-gap:42px!important}}


/* IO CABLO V58 — Problemi reali header fix backup */
body.home .ic-problems-section{padding-top:52px!important;padding-bottom:50px!important}
@media(min-width:1025px){body.home .ic-problems-section .container>div:first-child{max-width:1040px!important;display:grid!important;grid-template-columns:minmax(0,720px) minmax(280px,360px)!important;column-gap:54px!important;align-items:end!important;margin-bottom:34px!important}body.home .ic-problems-section h2{max-width:720px!important;font-size:clamp(40px,4.05vw,58px)!important;line-height:.98!important;margin:0!important}body.home .ic-problems-section .container>div:first-child p{grid-column:2!important;max-width:360px!important;margin:0 0 8px!important}}


/* IO CABLO V59 — Ambiti + Chiarimenti backup */
body.home .ic-services-section,body.home .ic-faq-section{padding-top:46px!important;padding-bottom:46px!important}
@media(min-width:1025px){body.home .ic-services-section .container>div:first-child,body.home .ic-faq-section .container>div:first-child{max-width:1040px!important;display:grid!important;grid-template-columns:minmax(0,660px) minmax(280px,370px)!important;column-gap:58px!important;align-items:end!important;margin-bottom:30px!important}body.home .ic-services-section h2,body.home .ic-faq-section h2{max-width:660px!important;margin:0!important}body.home .ic-services-section .container>div:first-child p,body.home .ic-faq-section .container>div:first-child p{grid-column:2!important;max-width:370px!important;margin:0 0 8px!important}}


/* IO CABLO V61 — menu impianti fix */
.site-header a[href*="#problemi"],.header a[href*="#problemi"],.nav a[href*="#problemi"],.main-navigation a[href*="#problemi"]{display:none!important}
.site-header a[href*="#impianti"],.header a[href*="#impianti"],.nav a[href*="#impianti"],.main-navigation a[href*="#impianti"]{white-space:nowrap!important}

/* IO CABLO V66 — clean merge backup */
#chi-siamo,#criticita-ricorrenti,#come-lavoriamo,#ambiti-intervento,#chiarimenti-operativi,#marchi-trattati,#contatti{scroll-margin-top:92px!important}
.site-header a[href*="#impianti"],.site-header a[href*="#servizi"],.site-header a[href*="#ambiti"]{display:none!important}


/* ═══════════════════════════════════════
   DIAGNOSTICA RETE GUIDATA — v68
   ═══════════════════════════════════════ */
.ioc-diag{
  padding:80px 0;
  background:var(--white,#fff);
  border-top:3px solid var(--yellow,#FFC000);
}
.ioc-diag-head{text-align:center;max-width:560px;margin:0 auto 52px}
.ioc-diag-head h2{
  font-family:var(--font-display,'Antonio',sans-serif);
  font-size:clamp(26px,3.5vw,38px);
  font-weight:700;
  color:var(--ink,#0C1428);
  margin:10px 0 12px;
}
.ioc-diag-head p{color:var(--ink-soft,#5A6880);font-size:15px;line-height:1.6}
/* step */
.ioc-ds{display:none}
.ioc-ds.on{display:block;animation:iDIn .22s ease both}
@keyframes iDIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.ioc-dq{font-family:var(--font-display);font-size:clamp(17px,2.2vw,22px);font-weight:700;color:var(--ink);text-align:center;margin:0 0 .2rem}
.ioc-dqs{font-size:13px;color:var(--ink-soft);text-align:center;margin:0 0 1.1rem;line-height:1.5}
/* griglie */
.ioc-dg{display:grid;gap:9px;max-width:720px;margin:0 auto}
.ioc-dg.g3{grid-template-columns:repeat(3,1fr)}
.ioc-dg.g2{grid-template-columns:repeat(2,1fr)}
/* card opzione */
.ioc-db{
  background:var(--white,#fff);
  border:1px solid var(--line,#DDE3F0);
  border-radius:10px;
  padding:14px 11px 12px;
  display:flex;flex-direction:column;align-items:center;gap:5px;
  font-family:var(--font-body,sans-serif);
  font-size:13px;font-weight:600;color:var(--ink);text-align:center;
  cursor:pointer;line-height:1.3;
  transition:border-color .14s,background .14s,transform .14s;
}
.ioc-db:hover{border-color:var(--blue,#1050E8);background:var(--blue-pale,#EBF0FF);transform:translateY(-2px)}
.ioc-db.sel{border:2px solid var(--blue,#1050E8);background:var(--blue,#1050E8);color:#fff}
.ioc-db small{font-size:11px;color:var(--ink-soft);font-weight:400;display:block}
.ioc-db.sel small{color:rgba(255,255,255,.78)}
/* icona — visibile solo su hover/sel */
.ioc-di{
  width:30px;height:30px;border-radius:50%;background:transparent;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  opacity:.4;transition:opacity .14s,background .14s;
}
.ioc-db:hover .ioc-di{background:rgba(16,80,232,.1);opacity:1}
.ioc-db.sel .ioc-di{background:rgba(255,255,255,.18);opacity:1}
/* ultimo step - campo libero */
.ioc-dl-other{display:flex;gap:8px;align-items:center;margin-top:10px;max-width:720px;margin-left:auto;margin-right:auto}
.ioc-dl-other input{flex:1;height:38px;border:1px solid var(--line);border-radius:6px;padding:0 12px;font-size:13px;color:var(--ink);background:var(--white);outline:none}
.ioc-dl-other input:focus{border-color:var(--blue)}
.ioc-dl-other button{height:38px;padding:0 16px;background:var(--blue);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .14s;white-space:nowrap}
.ioc-dl-other button:hover{background:var(--blue-light,#3A6FFF)}
/* progress */
.ioc-dprog{height:2px;background:var(--line);border-radius:2px;overflow:hidden;margin:1.6rem auto 0;max-width:720px}
.ioc-dprog-bar{height:100%;background:var(--blue);border-radius:2px;width:0;transition:width .33s ease}
.ioc-dprog-lbl{text-align:center;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin:.4rem 0 .6rem}
.ioc-diag-back-btn{display:block;margin:0 auto;background:none;border:1px solid var(--line);border-radius:6px;padding:5px 14px;font-size:12px;color:var(--ink-soft);cursor:pointer}
.ioc-diag-back-btn:hover{background:var(--off-white)}
/* ---- RISULTATO ---- */
.ioc-dr{padding:.5rem 0}
.ioc-dr-inner{
  max-width:820px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;
}
.ioc-dr-left{padding:28px;background:var(--off-white,#F5F7FC);border-radius:12px}
.ioc-dr-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink,#0C1428);background:var(--white,#fff);
  border:1px solid var(--line);padding:5px 12px;border-radius:6px;margin-bottom:.8rem;
}
.ioc-dr-title{font-family:var(--font-display);font-size:clamp(18px,2.2vw,24px);font-weight:700;color:var(--ink);margin-bottom:.3rem}
.ioc-dr-svc{
  display:inline-block;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--blue);background:var(--blue-pale);
  padding:3px 10px;border-radius:5px;margin-bottom:.8rem;text-decoration:none;
}
.ioc-dr-svc:hover{background:var(--blue);color:#fff}
.ioc-dr-note{font-size:13px;color:var(--ink-soft);line-height:1.65;margin-bottom:.85rem}
.ioc-dr-msg{background:var(--white);border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-size:13px;color:var(--ink-soft);line-height:1.7;margin-bottom:.8rem}
.ioc-dr-msg-label{display:block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:5px}
.ioc-dr-reset{background:none;border:none;font-size:12px;color:var(--ink-soft);cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}
/* mini-form */
.ioc-dr-right{padding:28px;background:var(--white);border:1px solid var(--line);border-radius:12px}
.ioc-dr-form-head{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.ioc-dr-form-sub{font-size:13px;color:var(--ink-soft);margin-bottom:1.2rem}
.ioc-df-group{margin-bottom:14px}
.ioc-df-group label{display:block;font-size:13px;font-weight:600;color:var(--ink-mid,#2E3A55);margin-bottom:5px}
.ioc-df-group input{width:100%;height:40px;border:1px solid var(--line);border-radius:6px;padding:0 12px;font-size:13px;color:var(--ink);background:var(--white);outline:none}
.ioc-df-group input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(16,80,232,.12)}
.ioc-df-check{display:flex;align-items:flex-start;gap:9px;margin-bottom:14px}
.ioc-df-check input[type=checkbox]{margin-top:3px;flex-shrink:0}
.ioc-df-check label{font-size:13px;color:var(--ink-soft);line-height:1.5}
.ioc-df-check a{color:var(--blue)}
.ioc-df-status{font-size:13px;min-height:20px;margin-bottom:8px}
.ioc-df-status.ok{color:#2A7F2F}
.ioc-df-status.err{color:#B33030}
.ioc-df-submit{width:100%;justify-content:center;gap:8px}
.ioc-df-submit:disabled{opacity:.5;cursor:not-allowed}
.ioc-df-alt{font-size:12px;color:var(--ink-soft);margin-top:10px;text-align:center}
.ioc-df-alt a{color:var(--blue)}
/* noscript */
.ioc-diag-noscript{padding:24px;background:var(--off-white);border-radius:8px;max-width:640px;margin:24px auto 0}
.ioc-diag-noscript h3{font-family:var(--font-display);margin-bottom:10px}
.ioc-diag-noscript ul{padding-left:20px;margin:10px 0}
.ioc-diag-noscript li{margin-bottom:6px;font-size:14px;color:var(--ink-soft)}
.ioc-diag-noscript a{color:var(--blue)}
/* responsive */
@media(max-width:720px){
  .ioc-dr-inner{grid-template-columns:1fr}
  .ioc-dg.g3{grid-template-columns:1fr 1fr}
}
@media(max-width:400px){
  .ioc-dg.g3,.ioc-dg.g2{grid-template-columns:1fr}
  .ioc-db{flex-direction:row;text-align:left;gap:10px;padding:11px 13px}
  .ioc-di{flex-shrink:0}
}
