
* {box-sizing:border-box;}
body {margin:0;font-family:Arial, Helvetica, sans-serif;color:#333;line-height:1.6;background:#fff;scroll-behavior:smooth;}
header {display:flex;align-items:center;justify-content:space-between;padding:15px 20px;background:#ffffff;box-shadow:0 2px 8px rgba(0,0,0,0.06);position:sticky;top:0;z-index:1000;}
.logo {font-size:22px;font-weight:bold;}
nav {display:flex;flex-wrap:wrap;}
nav a {margin:8px 10px;text-decoration:none;color:#333;font-weight:600;position:relative;border-bottom:2px solid transparent;transition:border-color 0.3s;}
nav a:hover {border-bottom-color:#009688;}

.hero {height:75vh;background:url('../img/hero.jpg') center/cover no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;color:white;}
.hero h1 {font-size:38px;max-width:900px;background:rgba(0,0,0,0.45);padding:20px;border-radius:10px;animation:fadeInUp 1s ease forwards;}

.section {padding:30px 20px;max-width:1100px;margin:auto;animation:fadeIn 1.2s ease both;}
.section h2 {text-align:center;margin-bottom:30px;font-size:30px;}
.center {text-align:center;}

.cards {display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:30px;}
.card {flex:1 1 260px;border:1px solid #eee;padding:20px;border-radius:10px;text-align:center;transition:0.3s;background:white;animation:fadeIn 1.2s ease both;}
.card:hover {transform:translateY(-6px);box-shadow:0 10px 25px rgba(0,0,0,0.08);}

.button {display:inline-block;margin-top:15px;padding:10px 18px;background:#009688;color:white;text-decoration:none;border-radius:5px;transition:0.3s;}
.button:hover {background:#00796b;transform:scale(1.05);}

img.responsive {width:100%;border-radius:10px;margin-top:20px;}

footer {text-align:center;padding:30px;background:#f5f5f5;margin-top:40px;font-size:14px;}

details {margin:10px 0;padding:10px;border:1px solid #ddd;border-radius:6px;background:#fafafa;}

/* Animations */
@keyframes fadeIn {from {opacity:0;} to {opacity:1;}}
@keyframes fadeInUp {from {opacity:0; transform:translateY(40px);} to {opacity:1; transform:translateY(0);}}

.fade-in {opacity:0; transform:translateY(18px); transition:opacity 0.7s ease, transform 0.7s ease;}
.fade-in.is-visible {opacity:1; transform:none;}

@media (prefers-reduced-motion: reduce) {
  .fade-in {opacity:1; transform:none; transition:none;}
}

/* Mobile */
@media(max-width:768px){
  .hero h1 {font-size:26px;padding:15px;}
  nav {justify-content:center;}
  .cards {flex-direction:column;}
}

/* Global header overrides */
header {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  text-align: left !important;
  padding: 2px 8px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
}

header nav {
  flex: 1 !important;
  width: auto !important;
  margin-top: 0 !important;
  gap: 28px !important;
  justify-content: center !important;
  display: flex !important;
}

header nav a {
  font-size: 17px !important;
  font-weight: 600 !important;
  letter-spacing: 0.2px;
  padding: 8px 0 !important;
  margin: 0 !important;
}

header .logo-link {
  margin-left: 70px !important;
  margin-right: 20px !important;
}

header img[src*="logo"] {
  height: 160px !important;
  width: auto !important;
}

@media(max-width:768px) {
  header img[src*="logo"] {
    height: 80px !important;
  }
  
  header nav {
    gap: 12px !important;
  }
  
  header nav a {
    font-size: 13px !important;
  }
  
  header .logo-link {
    margin-left: 0 !important;
    margin-right: 10px !important;
  }
}

@media(max-width:480px) {
  header img[src*="logo"] {
    height: 70px !important;
  }
  
  header {
    padding: 4px 6px !important;
  }
  
  header nav {
    gap: 8px !important;
  }
  
  header nav a {
    font-size: 11px !important;
    padding: 4px 6px !important;
  }
  
  header .logo-link {
    margin-left: 0 !important;
    margin-right: 5px !important;
  }
}

/* Styling for blue bars with bold and italic text */
div[style*="linear-gradient(142deg"]:not(.logo),
div[style*="linear-gradient(151deg"]:not(.logo) {
  color: white !important;
}

div[style*="linear-gradient(142deg"] strong,
div[style*="linear-gradient(151deg"] strong {
  font-weight: 700 !important;
  font-style: italic !important;
}

div[style*="linear-gradient(142deg"] strong em,
div[style*="linear-gradient(151deg"] strong em {
  font-weight: 700 !important;
  font-style: italic !important;
}

/* Shared page intro (affidati template) */
.hero-intro {
  background: linear-gradient(125deg, #4dd0e1 0%, #00897b 100%);
  color: white;
  padding: 33px 18px;
  text-align: center;
  margin: 0;
  animation: fadeIn 1s ease both;
}

.hero-intro h2 {
  margin: 0 0 13px 0;
  font-size: 27px;
  text-shadow: 0 1px 3px rgba(0,0,0,0.12);
  font-family: Georgia, serif;
}

.hero-intro p {
  margin: 0;
  font-size: 16px;
  opacity: 0.93;
}

@media (max-width: 768px) {
  .hero-intro {
    padding: 25px 16px;
  }

  .hero-intro h2 {
    font-size: 24px;
  }
}

@media (max-width: 480px) {
  .hero-intro h2 {
    font-size: 22px;
  }

  .hero-intro p {
    font-size: 14px;
  }
}

/* Shared boxed page layout */
.riquadro-page {
  max-width: 1150px;
  margin: 0 auto 20px;
  padding: 26px 22px;
  background: #ffffff;
  border: 1px solid #e4ecea;
  border-radius: 14px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
  animation: fadeIn 1.2s ease both;
}

@media (max-width: 768px) {
  .riquadro-page {
    margin: 16px;
    padding: 20px 16px;
    border-radius: 12px;
  }
}

/* Extra mobile optimization across pages */
@media (max-width: 768px) {
  body {
    line-height: 1.5;
  }

  .section {
    padding: 20px 14px !important;
  }

  .section h2 {
    font-size: 24px !important;
    margin-bottom: 18px !important;
  }

  .content-box,
  .riquadro-page {
    margin: 14px 10px !important;
    padding: 16px 14px !important;
    border-radius: 12px !important;
  }

  .category-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 10px !important;
    margin: 14px auto 20px !important;
  }

  .category-card {
    padding: 18px 14px !important;
  }

  .main-content,
  .chi-siamo-content,
  .contatti-content {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    margin: 18px auto !important;
    padding: 16px 12px !important;
  }

  .contatti-item {
    flex-direction: column !important;
    align-items: flex-start !important;
    font-size: 14px !important;
  }

  .hero {
    min-height: 46vh !important;
    padding: 18px 12px !important;
  }

  .hero h1 {
    font-size: 20px !important;
    padding: 12px !important;
  }
}

@media (max-width: 480px) {
  .hero-intro {
    padding: 18px 10px !important;
  }

  .hero-intro h2 {
    font-size: 20px !important;
  }

  .hero-intro p {
    font-size: 13px !important;
  }

  .section h2 {
    font-size: 21px !important;
  }
}

/* Proposte Migliori - Sections */
.pm-section-urgent-wrapper {
  margin-bottom: 80px;
  width: 100%;
}

.pm-section-regular-wrapper {
  margin-bottom: 20px;
  width: 100%;
}

.pm-section-title-urgent {
  font-size: 32px;
  font-weight: 700;
  color: #ff0000;
  margin: 0 0 30px 0;
  padding: 25px;
  background: linear-gradient(135deg, rgba(255, 0, 0, 0.08) 0%, rgba(255, 100, 100, 0.12) 100%);
  border: 3px solid #ff0000;
  border-radius: 12px;
  text-transform: uppercase;
  letter-spacing: 2px;
  animation: pulse-title 2s infinite;
  text-align: center;
}

.pm-section-title-regular {
  font-size: 28px;
  font-weight: 700;
  color: #0097a7;
  margin: 0 0 30px 0;
  padding-left: 15px;
  border-left: 5px solid #0097a7;
}

/* SEZIONE URGENT - ORIZZONTALE SCROLLABILE */
.pm-cards-urgent {
  display: flex;
  flex-wrap: nowrap;
  gap: 20px;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 15px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

.pm-cards-urgent::-webkit-scrollbar {
  height: 8px;
}

.pm-cards-urgent::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 10px;
}

.pm-cards-urgent::-webkit-scrollbar-thumb {
  background: #ff0000;
  border-radius: 10px;
}

.pm-cards-urgent::-webkit-scrollbar-thumb:hover {
  background: #cc0000;
}

/* SEZIONE REGULAR - GRIGLIA VERTICALE */
.pm-cards-regular {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: flex-start;
}

/* CARD NELLA SEZIONE URGENT - LARGHEZZA FISSA PER NON AVVOLGERE */
.pm-cards-urgent .pm-card {
  flex: 0 0 380px;
  border: 1px solid #eee;
  padding: 20px;
  border-radius: 10px;
  background: white;
  transition: 0.3s;
  display: flex;
  flex-direction: column;
}

/* CARD NELLA SEZIONE REGULAR - LARGHEZZA PROPORZIONALE */
.pm-cards-regular .pm-card {
  flex: 0 1 calc(33.333% - 14px);
  border: 1px solid #eee;
  padding: 20px;
  border-radius: 10px;
  background: white;
  transition: 0.3s;
  display: flex;
  flex-direction: column;
  min-width: 250px;
}

.pm-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}

@media (max-width: 1200px) {
  .pm-cards-urgent .pm-card {
    flex: 0 0 320px;
  }
  
  .pm-cards-regular .pm-card {
    flex: 0 1 calc(50% - 10px);
  }
}

@media (max-width: 900px) {
  .pm-cards-urgent .pm-card {
    flex: 0 0 280px;
  }
  
  .pm-cards-regular .pm-card {
    flex: 0 1 calc(50% - 10px);
    min-width: 220px;
  }
}

@media (max-width: 600px) {
  .pm-cards-urgent .pm-card {
    flex: 0 0 280px;
  }
  
  .pm-cards-regular .pm-card {
    flex: 0 1 100%;
    min-width: 100%;
  }
  
  .pm-section-title-urgent {
    font-size: 24px;
  }
  
  .pm-section-title-regular {
    font-size: 20px;
  }
}

@keyframes pulse-title {
  0%, 100% {
    text-shadow: 0 0 0px transparent;
  }
  50% {
    text-shadow: 0 0 10px rgba(255, 0, 0, 0.3);
  }
}

/* Proposte Migliori - Badge Styling */
.pm-badge {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 700;
  background: #e0e0e0;
  color: #333;
  margin-bottom: 10px;
}

.pm-badge-urgent {
  background: #ff0000;
  color: white;
  animation: pulse-badge 1.5s infinite;
}

@keyframes pulse-badge {
  0% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.7);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 10px rgba(255, 0, 0, 0);
  }
}
