/* ==============================================================
   WIRITALY - MODERN DESIGN OVERRIDE
   Da includere DOPO style.css in tutti i file HTML
   ============================================================== */



/* --- CSS VARIABLES --- */
:root {
  --wir-blue:       #0057FF;
  --wir-blue-dark:  #003FBF;
  --wir-blue-light: #EEF3FF;
  --wir-accent:     #00C6FF;
  --wir-dark:       #0B1225;
  --wir-dark2:      #141E38;
  --wir-gray:       #F3F5FA;
  --wir-text:       #1C2340;
  --wir-muted:      #6B7280;
  --wir-border:     rgba(0,0,0,.07);
  --wir-radius:     14px;
  --wir-radius-sm:  8px;
  --wir-shadow:     0 4px 24px rgba(0,87,255,.10);
  --wir-shadow-lg:  0 12px 48px rgba(0,87,255,.16);
  --wir-font:       'Plus Jakarta Sans', sans-serif;
  --wir-body-font:  'DM Sans', sans-serif;
}

/* --- BASE --- */
*, *::before, *::after { box-sizing: border-box; }
body {
  font-family: var(--wir-body-font) !important;
  color: var(--wir-text) !important;
  background: #fff !important;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--wir-font) !important;
  color: var(--wir-text) !important;
  letter-spacing: -0.02em !important;
}

/* --- SPINNER --- */
#spinner { background: #fff !important; z-index: 9999; }
#spinner .spinner-grow.text-primary   { background-color: var(--wir-blue) !important; }
#spinner .spinner-grow.text-dark      { background-color: var(--wir-dark) !important; }
#spinner .spinner-grow.text-secondary { background-color: var(--wir-accent) !important; }

/* --- TOPBAR --- */
.container-fluid.bg-light.ps-5.pe-0 {
  background: #fff !important;
  border-bottom: 1px solid var(--wir-border) !important;
}
.container-fluid.bg-light.ps-5.pe-0 small {
  font-family: var(--wir-body-font) !important;
  font-size: .8rem !important;
  color: var(--wir-muted) !important;
}
.container-fluid.bg-light.ps-5.pe-0 .bg-primary.top-shape {
  background: linear-gradient(90deg, var(--wir-blue) 0%, var(--wir-blue-dark) 100%) !important;
  border-radius: 0 0 0 20px !important;
  clip-path: none !important;
  font-size: .82rem;
  font-family: var(--wir-body-font) !important;
}
.top-shape a { color: #fff !important; text-decoration: none !important; }

/* --- NAVBAR --- */
nav.navbar {
  background: #fff !important;
  box-shadow: 0 1px 0 var(--wir-border) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1030 !important;
  transition: box-shadow .3s ease;
}
.navbar-brand img { max-height: 130px !important; }
.navbar-nav .nav-link {
  font-family: var(--wir-font) !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  color: var(--wir-text) !important;
  padding: 1.4rem .9rem !important;
  letter-spacing: .01em;
  transition: color .2s !important;
  position: relative;
}
.navbar-nav .nav-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: .9rem; right: .9rem;
  height: 2px;
  background: var(--wir-blue);
  border-radius: 2px;
  transform: scaleX(0);
  transition: transform .25s ease;
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active { color: var(--wir-blue) !important; }
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after { transform: scaleX(1); }

/* --- BUTTONS --- */
.btn-primary {
  background: var(--wir-blue) !important;
  border-color: var(--wir-blue) !important;
  font-family: var(--wir-font) !important;
  font-weight: 600 !important;
  font-size: .85rem !important;
  border-radius: var(--wir-radius-sm) !important;
  letter-spacing: .01em;
  transition: background .2s, transform .15s, box-shadow .2s !important;
}
.btn-primary:hover {
  background: var(--wir-blue-dark) !important;
  border-color: var(--wir-blue-dark) !important;
  box-shadow: 0 4px 16px rgba(0,87,255,.30) !important;
  transform: translateY(-1px) !important;
}
.btn-outline-primary {
  border-color: var(--wir-blue) !important;
  color: var(--wir-blue) !important;
  font-family: var(--wir-font) !important;
  font-weight: 600 !important;
  font-size: .85rem !important;
  border-radius: var(--wir-radius-sm) !important;
  transition: all .2s !important;
}
.btn-outline-primary:hover {
  background: var(--wir-blue) !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(0,87,255,.25) !important;
  transform: translateY(-1px) !important;
}
.btn-light {
  background: #fff !important;
  color: var(--wir-blue) !important;
  font-family: var(--wir-font) !important;
  font-weight: 700 !important;
  border: none !important;
  border-radius: var(--wir-radius-sm) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.12) !important;
  transition: all .2s !important;
}
.btn-light:hover {
  background: #f0f4ff !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.15) !important;
  transform: translateY(-1px) !important;
}
.btn-outline-light {
  border-color: rgba(255,255,255,.6) !important;
  color: #fff !important;
  font-family: var(--wir-font) !important;
  font-weight: 600 !important;
  border-radius: var(--wir-radius-sm) !important;
  backdrop-filter: blur(4px);
  transition: all .2s !important;
}
.btn-outline-light:hover {
  background: rgba(255,255,255,.18) !important;
  border-color: #fff !important;
  transform: translateY(-1px) !important;
}
nav .btn-primary {
  font-size: .8rem !important;
  padding: .45rem 1rem !important;
  border-radius: 6px !important;
}

/* --- HERO --- */
.hero-header {
  background: linear-gradient(135deg, var(--wir-blue) 0%, var(--wir-dark2) 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  padding-top: 5rem !important;
  padding-bottom: 5rem !important;
}
.hero-header::before {
  content: '';
  position: absolute;
  top: -40%; right: -10%;
  width: 60vw; height: 60vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0,198,255,.18) 0%, transparent 70%);
  pointer-events: none;
}
.hero-header::after {
  content: '';
  position: absolute;
  bottom: -30%; left: -5%;
  width: 40vw; height: 40vw;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%);
  pointer-events: none;
}
.hero-header h1 {
  color: #fff !important;
  font-size: clamp(2rem, 5vw, 3.6rem) !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  letter-spacing: -.03em !important;
}
.hero-header p {
  color: rgba(255,255,255,.85) !important;
  font-size: 1.1rem !important;
  font-family: var(--wir-body-font) !important;
  font-weight: 400 !important;
}

/* --- SECTION TITLES --- */
.section-title h5 {
  font-family: var(--wir-font) !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--wir-blue) !important;
  background: var(--wir-blue-light) !important;
  display: inline-block !important;
  padding: .3rem .9rem !important;
  border-radius: 100px !important;
  margin-bottom: .75rem !important;
}
.section-title h5::before,
.section-title h5::after { display: none !important; }
.section-title h1 {
  font-size: clamp(1.6rem, 3vw, 2.4rem) !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  color: var(--wir-text) !important;
}
h5.position-relative.d-inline-block.text-primary.text-uppercase {
  font-family: var(--wir-font) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  color: var(--wir-blue) !important;
  background: var(--wir-blue-light) !important;
  display: inline-block !important;
  padding: .3rem .9rem !important;
  border-radius: 100px !important;
  margin-bottom: .75rem !important;
}
h5.position-relative.d-inline-block.text-primary.text-uppercase::before,
h5.position-relative.d-inline-block.text-primary.text-uppercase::after { display: none !important; }

/* --- BACKGROUNDS --- */
.container-fluid.bg-light { background: var(--wir-gray) !important; }

/* --- CARDS --- */
.bg-white.rounded.p-4,
.bg-light.rounded.p-4 {
  background: #fff !important;
  border-radius: var(--wir-radius) !important;
  border: 1px solid var(--wir-border) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.04) !important;
  transition: transform .2s, box-shadow .2s !important;
}
.bg-white.rounded.p-4:hover,
.bg-light.rounded.p-4:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 32px rgba(0,87,255,.10) !important;
}
.border.border-primary {
  border: 2px solid var(--wir-blue) !important;
  box-shadow: 0 4px 24px rgba(0,87,255,.12) !important;
}

/* --- FEATURE CARDS --- */
.feature-card {
  background: #fff !important;
  border: 1px solid var(--wir-border) !important;
  border-radius: var(--wir-radius) !important;
  padding: 24px !important;
  height: 100% !important;
  transition: transform .2s, box-shadow .2s !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.04) !important;
}
.feature-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 32px rgba(0,87,255,.10) !important;
}
.step-icon {
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  background: var(--wir-blue-light) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.step-icon i { color: var(--wir-blue) !important; font-size: 18px !important; }

/* --- PRICING --- */
.col-lg-4 .bg-light.rounded.p-4,
.col-lg-3 .bg-light.rounded.p-4 {
  background: #fff !important;
  border-radius: var(--wir-radius) !important;
  border: 1px solid var(--wir-border) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.05) !important;
}
.col-lg-4 .bg-light.rounded.p-4:hover,
.col-lg-3 .bg-light.rounded.p-4:hover {
  box-shadow: var(--wir-shadow-lg) !important;
  transform: translateY(-4px) !important;
}
h2.text-primary { color: var(--wir-blue) !important; font-weight: 800 !important; }
h4.text-primary { color: var(--wir-blue) !important; font-weight: 700 !important; }

/* --- BADGE --- */
.badge.bg-danger {
  background: linear-gradient(90deg, #FF3D71 0%, #FF6B35 100%) !important;
  font-family: var(--wir-font) !important;
  font-size: .68rem !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  border-radius: 100px !important;
  padding: .3rem .7rem !important;
}

/* --- PRIMARY BG BOX --- */
.bg-primary.rounded.p-4 {
  background: linear-gradient(135deg, var(--wir-blue) 0%, var(--wir-dark2) 100%) !important;
  border-radius: var(--wir-radius) !important;
  border: none !important;
  box-shadow: var(--wir-shadow-lg) !important;
}
.bg-primary.rounded.p-4 h3,
.bg-primary.rounded.p-4 h2,
.bg-primary.rounded.p-4 h5,
.bg-primary.rounded.p-4 p { color: #fff !important; }
.bg-primary.rounded.p-4 .text-white-50 { color: rgba(255,255,255,.55) !important; }

/* --- ICONS --- */
.fa.text-primary, .fas.text-primary, .far.text-primary,
.fa-check.text-primary { color: var(--wir-blue) !important; }

/* --- LISTS --- */
.list-unstyled li { font-family: var(--wir-body-font) !important; font-size: .92rem !important; }
.list-unstyled .fa-check { color: var(--wir-blue) !important; }
.list-unstyled .fa-plus  { color: var(--wir-accent) !important; }

/* --- ACCORDION --- */
.accordion-item {
  border: 1px solid var(--wir-border) !important;
  border-radius: var(--wir-radius-sm) !important;
  margin-bottom: .6rem !important;
  overflow: hidden;
}
.accordion-button {
  font-family: var(--wir-font) !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
  color: var(--wir-text) !important;
  background: #fff !important;
  border-radius: var(--wir-radius-sm) !important;
  box-shadow: none !important;
  padding: 1.1rem 1.25rem !important;
}
.accordion-button:not(.collapsed) {
  color: var(--wir-blue) !important;
  background: var(--wir-blue-light) !important;
}
.accordion-button::after { filter: none !important; }
.accordion-body {
  font-family: var(--wir-body-font) !important;
  font-size: .9rem !important;
  color: var(--wir-muted) !important;
  padding: 1rem 1.25rem !important;
  background: #fafbff !important;
}

/* --- FORMS --- */
.form-control, .form-select {
  font-family: var(--wir-body-font) !important;
  font-size: .9rem !important;
  border: 1.5px solid #D8DCE8 !important;
  border-radius: var(--wir-radius-sm) !important;
  padding: .6rem .9rem !important;
  transition: border-color .2s, box-shadow .2s !important;
  color: var(--wir-text) !important;
  background: #fff !important;
}
.form-control:focus, .form-select:focus {
  border-color: var(--wir-blue) !important;
  box-shadow: 0 0 0 3px rgba(0,87,255,.12) !important;
  outline: none !important;
}
.form-label {
  font-family: var(--wir-font) !important;
  font-size: .8rem !important;
  font-weight: 600 !important;
  color: var(--wir-text) !important;
  letter-spacing: .01em;
  margin-bottom: .35rem !important;
}
.form-check-input:checked {
  background-color: var(--wir-blue) !important;
  border-color: var(--wir-blue) !important;
}

/* --- CONTACT CARDS --- */
.contact-card {
  background: #fff !important;
  border: 1px solid var(--wir-border) !important;
  border-radius: var(--wir-radius) !important;
  padding: 28px !important;
  height: 100% !important;
}
.icon-badge {
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  background: var(--wir-blue-light) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.icon-badge i { color: var(--wir-blue) !important; font-size: 18px !important; }
.kpi {
  background: var(--wir-gray) !important;
  border: none !important;
  border-radius: var(--wir-radius-sm) !important;
  padding: 16px !important;
}

/* --- INFO ICON --- */
.info-icon {
  border-color: var(--wir-border) !important;
  background: var(--wir-blue-light) !important;
  border-radius: 6px !important;
}
.info-icon i { color: var(--wir-blue) !important; }

/* --- MODALS --- */
.modal-content {
  border: none !important;
  border-radius: var(--wir-radius) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.18) !important;
  overflow: hidden;
}
.modal-header {
  background: var(--wir-blue-light) !important;
  border-bottom: 1px solid var(--wir-border) !important;
}
.modal-title { font-family: var(--wir-font) !important; font-weight: 700 !important; color: var(--wir-blue) !important; }
.modal-body { font-family: var(--wir-body-font) !important; font-size: .92rem !important; }
.modal-body h6 { font-family: var(--wir-font) !important; font-weight: 700 !important; color: var(--wir-blue) !important; }

/* --- FOOTER --- */
.container-fluid.bg-dark {
  background: var(--wir-dark) !important;
  margin-top: 0 !important;
  padding-top: 4rem !important;
  padding-bottom: 3rem !important;
}
.container-fluid.bg-dark h3 {
  font-family: var(--wir-font) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: .03em;
  text-transform: uppercase !important;
}
.container-fluid.bg-dark .text-light,
.container-fluid.bg-dark p { color: rgba(255,255,255,.65) !important; font-size: .875rem !important; }
.container-fluid.bg-dark a.text-light {
  text-decoration: none !important;
  transition: color .2s !important;
  display: flex !important;
  align-items: center !important;
  gap: .4rem !important;
  padding: .2rem 0 !important;
}
.container-fluid.bg-dark a.text-light:hover { color: #fff !important; }
.container-fluid.bg-dark .bi-arrow-right { color: var(--wir-blue) !important; }
.container-fluid.bg-dark .btn-primary.btn-lg-square {
  background: rgba(255,255,255,.1) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: 10px !important;
  width: 40px !important;
  height: 40px !important;
  transition: background .2s, transform .2s !important;
}
.container-fluid.bg-dark .btn-primary.btn-lg-square:hover {
  background: var(--wir-blue) !important;
  border-color: var(--wir-blue) !important;
  transform: translateY(-2px) !important;
}
div[style*="background: #051225"] {
  background: #060e1e !important;
  border-top: 1px solid rgba(255,255,255,.05) !important;
}
div[style*="background: #051225"] p,
div[style*="background: #051225"] a { font-size: .8rem !important; color: rgba(255,255,255,.4) !important; }
div[style*="background: #051225"] a:hover { color: rgba(255,255,255,.75) !important; }
div[style*="background: #051225"] a.border-bottom { border-bottom: none !important; }

/* --- BACK TO TOP --- */
.back-to-top, .back-to-topMention {
  background: var(--wir-blue) !important;
  border: none !important;
  border-radius: 10px !important;
  width: 44px !important;
  height: 44px !important;
  box-shadow: 0 4px 16px rgba(0,87,255,.35) !important;
  bottom: 2rem !important;
  right: 1.5rem !important;
  transition: background .2s, transform .2s !important;
}
.back-to-top:hover, .back-to-topMention:hover {
  background: var(--wir-blue-dark) !important;
  transform: translateY(-3px) !important;
}

/* --- ALERT --- */
.alert-success {
  background: #edfaf3 !important;
  border: 1px solid #a3e6c0 !important;
  color: #166534 !important;
  border-radius: var(--wir-radius-sm) !important;
  font-family: var(--wir-font) !important;
  font-weight: 600 !important;
  font-size: .9rem !important;
}

/* --- FWA TOGGLE --- */
.blink-speed {
  font-family: var(--wir-font) !important;
  font-weight: 600 !important;
  font-size: .75rem !important;
  border-radius: 6px !important;
  padding: .25rem .6rem !important;
}
.btn-group .btn-outline-primary {
  font-size: .8rem !important;
  padding: .35rem .6rem !important;
}

/* --- TYPOGRAPHY --- */
.display-5 { font-weight: 800 !important; letter-spacing: -.025em !important; line-height: 1.2 !important; }
.display-3 { font-weight: 800 !important; letter-spacing: -.03em !important; }
.text-primary { color: var(--wir-blue) !important; }
.text-muted   { color: var(--wir-muted) !important; }
hr { border-color: var(--wir-border) !important; opacity: 1 !important; }

/* --- RESPONSIVE --- */
@media (max-width: 991px) {
  .navbar-collapse {
    background: #fff;
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--wir-border);
    box-shadow: 0 8px 24px rgba(0,0,0,.08);
  }
  .navbar-nav .nav-link { padding: .65rem 0 !important; border-bottom: 1px solid var(--wir-border); }
  .navbar-nav .nav-link::after { display: none !important; }
  nav .btn-primary { margin: .3rem 0 !important; display: block !important; width: 100% !important; }
}
@media (max-width: 575px) {
  .hero-header { padding-top: 3.5rem !important; padding-bottom: 3.5rem !important; }
  .hero-header h1 { font-size: 1.9rem !important; }
}

html { scroll-behavior: smooth; }
