* {
  margin: 0%;
  padding: 0%;
  box-sizing: border-box;
}

body {
  font-family: 'Inter', sans-serif;
  line-height: 1.2;
  letter-spacing: -0.5px;
}

a {
  list-style: none;
  text-decoration: none;
  color: #000;
}

ul {
  list-style: none;
}

li{
list-style: none;
}
img {
  max-width: 100%;
}

.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 2rem;
}

.container-lg {
  max-width: 1440px;
}

.container.sm {
  max-width: 900px;
}

.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.header {
  padding:2rem;
}

.header .logo {
  width: 120px;
}

.header .header-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header .nav-bar {
  display: flex;
  gap: 30px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 18px;
}

.nav-bar a:hover{
  color: #333333;
}

.hamburger-btn {
  display: none; 
  background: none;
  border: none;
  cursor: pointer;
  padding: 10px;
  z-index: 200; 
}

.hamburger-btn .bar {
  display: block;
  width: 25px;
  height: 3px;
  margin: 5px 0;
  background-color: black; 
  transition: 0.4s;
}

hr {
  border: none;
  height: 0.1px;
  background-color: #000000;
  margin-left: 25px; margin-right: 25px; margin-top: 25px;
}

.footer {
  padding:2rem;
  font-size: 12px;
  text-align: left;
}

.footer .policies{
 display: flex;
 justify-content: left;
 gap: 0.5rem
}

.footer .policies a{
  text-transform: initial;
  font-weight: 400;
}

.policy .par-pol {
  line-height: 1.4;
  text-align: center;
}

.pp-section {
  margin: 30px;
  line-height: 2rem;

}

.pp-section h3{
  text-transform:uppercase;
  
}

.pp-section ul{
  list-style:disc;
  margin-left: 20px;
}

.pp-section a{
  text-transform: lowercase;
  font-weight: 550;
}

.hero-section {
  position: relative; 
  display: flex;
  align-items: flex-end;   /* spinge tutto in basso */
  justify-content: flex-start; /* sinistra */
  padding: 0; /* tolgo padding per controllare meglio il layout */
  height: 90vh; /* hero piena e moderna */
  background: #ffffff;
}

/* wrapper del contenuto */
.hero-section .conteiner {
  position: absolute;
  bottom: 60px;   /* distanza dal fondo */
  left: 60px;     /* distanza dal lato sinistro */
  max-width: 1200px;
  text-align: left; /* allineamento sinistro */
}

/* HERO MAIN HEADING */
.hero-heading {
  font-size: 7rem;
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: -2px;
  color: #000;
  margin-bottom: 25px;
}

/* SUBTITLE */
.hero-section h2 {
  font-size: 1.3rem;
  font-weight: 400;
  color: #333;
  opacity: 0.85;
  margin-bottom: 30px;
  max-width: 520px;
}

/* CTA BUTTON (identico al final CTA) */
.discover-service .discover-more {
  display: inline-block;
  padding: 0.85rem 1.8rem;
  border: 1px solid #000;
  color: #000;
  text-decoration: none;
  font-size: 1rem;
  letter-spacing: 0;
  transition: all 0.25s ease;
}

/* Hover — identico */
.discover-service .discover-more:hover {
  background-color: #000;
  color: #fff;
  transform: translateY(-2px);
}

.why {
  padding: 100px 20px;
  background-color: #ffffff;
}

.why .conteiner {
  max-width: 1200px;
  margin: 0 auto;
}

/* =========================================
 5. HOME SERVICES (Why Choose Us)
 ========================================= */
.home-services {
padding: 6rem 0;
}

.section-heading {
font-size: clamp(2rem, 4vw, 3rem);
text-align: center;
margin-bottom: 1rem;
}

.section-description {
text-align: center;
max-width: 700px;
margin: 0 auto 4rem auto;
color: #555555;
font-size: 1.1rem;
}

.home-services-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
}

/* Card Style aligned with Services Page */
.home-card {
display: flex;
flex-direction: column;
padding: 2.5rem 2rem;
border: 1px solid #e5e5e5;
background: #ffffff;
transition: all 0.4s ease;
height: 100%;
}

.home-card h3 {
font-size: 1.5rem;
margin-bottom: 1rem;
transition: color 0.4s;
}

.home-card p {
color: #555555;
font-size: 1rem;
transition: color 0.4s;
}

/* Hover Effect */
.home-card:hover {
background: #050505;
border-color: #050505;
transform: translateY(-5px);
}
.home-card:hover h3 { color: #ffffff; }
.home-card:hover p { color: #cccccc; }

@media (max-width: 900px) {
.home-services-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}
/* =========================================
 TIMELINE — Modern, minimal, alternating
 ========================================= */


.timeline {
  position: relative;
  max-width: 900px;
  margin: 80px auto 0;
}

.timeline::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 1px;
  height: 95%;
  background: #e5e5e5;
  transform: translateX(-1px);
}

/* Step wrapper */
.timeline-step {
  position: relative;
  width: 50%;
  padding: 0 30px 60px;
  box-sizing: border-box;
}

/* Left column items */
.timeline-step:nth-child(odd) {
  left: 0;
  text-align: right;
}

/* Right column items */
.timeline-step:nth-child(even) {
  left: 50%;
  text-align: left;
}


/* =========================================
   TIMELINE CARD (same style as service-card)
   ========================================= */

.timeline-content {
  background: #fff;
  padding: 40px 30px;
  border: 1px solid #e5e5e5;
  transition: 0.25s ease;
  position: relative;
}

.timeline-content:hover {
  border-color: #000;
  transform: translateY(-4px);
}


/* Typography */
.timeline-content h3 {
  font-size: 20px;
  margin-bottom: 10px;
  font-weight: 700;
}

.timeline-content p {
  font-size: 16px;
  line-height: 1.6;
  opacity: 0.85;
}

.technologies1 {
  width: 100%;
  overflow: hidden;
  padding: 30px 0;
  background: #000000;
}

.tech-track1 {
  overflow: hidden;
  width: 100%;
}

.tech-grid1 {
  display: flex;
  width: max-content;
  animation: scroll-tech 18s linear infinite;
}

.tech-item1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 200px;
  opacity: 0.85;
  transition: opacity .25s ease;
}

.tech-item1:hover {
  opacity: 1;
}

.tech-item1 img {
  width: 60px;
  height: 60px;
  object-fit: contain;
  filter: grayscale(100%);
  transition: filter .25s;
}

.tech-item1:hover img {
  filter: grayscale(0%);
}



/* ============================
 FAQ SECTION
============================ */

.faq {
  padding: 50px 20px;
  background: #ffffff;
}

.faq .conteiner {
  max-width: 900px;
  margin: 0 auto;
}

/* FAQ List Wrapper */
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.faq h2{
  padding-bottom: 30px;
}

/* FAQ CARD (details) */
.faq-list details {
  background: #fff;
  border: 1px solid #e5e5e5;      /* thin minimal border */
  padding: 20px 25px;
  cursor: pointer;
  transition: all 0.25s ease;
}

.faq-list details:hover {
  border-color: #000;             /* same hover effect as service cards */
  transform: translateY(-3px);
}

/* Summary (question) */
.faq-list summary {
  font-size: 1.1rem;
  font-weight: 600;
  list-style: none;
  cursor: pointer;
  color: #000;
  position: relative;
  padding-right: 25px;
}

/* Remove default arrow */
.faq-list summary::-webkit-details-marker {
  display: none;
}

/* Custom arrow */
.faq-list summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.3rem;
  transition: 0.25s ease;
  opacity: 0.7;
}

/* Rotate arrow when open */
.faq-list details[open] summary::after {
  content: "-";
  opacity: 1;
}

/* FAQ Answer */
.faq-list details p {
  margin-top: 15px;
  font-size: 0.95rem;
  color: #333;
  line-height: 1.6;
  padding-right: 15px;
  opacity: 0.9;
}

/* ============================
 FINAL CTA SECTION
============================ */

.final-cta {
  padding: 60px 20px;
  background: #ffffff;
  text-align: center;
}

.final-cta .conteiner {
  max-width: 800px;
  margin: 0 auto;
}

/* Heading */
.final-cta .section-heading {
  font-size: 2.4rem;
  font-weight: 700;
  color: #000;
  margin-bottom: 15px;
  letter-spacing: -0.5px;
}

/* Description */
.final-cta .section-description {
  font-size: 1.1rem;
  color: #333;
  opacity: 0.9;
  margin-bottom: 40px;
}

/* CTA Button (same style as your global CTA button) */
.final-cta .cta-btn {
  padding: 14px 35px;
  border: 1px solid #e5e5e5;
  color: #000;
  font-size: 1rem;
  font-weight: 500;
  text-decoration: none;
  display: inline-block;
  transition: all 0.25s ease;
}

/* Hover = Coodie style */
.final-cta .cta-btn:hover {
  border-color: #000;
  background-color: #000;
  color: #fff;
  transform: translateY(-3px);
}

 /* =========================================
 CONTACT PAGE — MINIMAL, CLEAN, BLACK/WHITE
 ========================================= */

.contact-section {
  padding: 70px 20px 90px;
  background: #ffffff;
  text-align: center;
}

.contact-heading {
  font-size: 3rem;
  line-height: 1.05;
  font-weight: 700;
  letter-spacing: -2px;
  color: #000;
  margin-bottom: 25px;
}

.contact-paragraph {
  max-width: 650px;
  margin: 0 auto 30px auto;
  font-size: 1rem;
  line-height: 1.7;
  color: #333;
  opacity: 0.8;
}

/* FORM WRAPPER */
.form-wrapper {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 10px;
}

/* FORM */
.contact-form {
  max-width: 650px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 18px 20px;
  border: 1px solid #e5e5e5;
  background: transparent;
  font-size: 1rem;
  font-family: 'Inter', sans-serif;
  transition: all .25s ease;
}

.contact-form textarea {
  height: 140px;
  resize: none;
}

/* INPUT HOVER + FOCUS */
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form input:hover,
.contact-form textarea:hover {
  border-color: #000;
  outline: none;
}

/* SUBMIT BUTTON — SAME STYLE AS CTA SITE-WIDE */
#contact-submit {
  display: inline-block;
  padding: 16px 32px;
  background: #000;
  color: #fff;
  border: 1px solid #000;
  letter-spacing: 0.8px;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all .25s ease;
}

#contact-submit:hover {
  background: #000;
  color: #fff;
  transform: translateY(-4px);
}

/* ACCESSIBILITY */
.sr-only {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ============================================================
 ABOUT PAGE STYLES (.ab-) - STRATEGIC V2
 ============================================================ */

/* 1. HERO */
.ab-hero {
padding: 11rem 0 8rem;
background: #ffffff;
text-align: center;
}

.ab-eyebrow {
display: inline-block;
font-size: 0.85rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 2px;
margin-bottom: 15px;
color: #888;
}

.ab-title-main {
font-size: clamp(3rem, 6vw, 5.5rem);
font-weight: 800;
letter-spacing: -2px;
line-height: 1.05;
color: #000;
margin-bottom: 1.5rem;
}

.ab-subtitle-main {
max-width: 600px;
margin: 0 auto;
font-size: 1.25rem;
color: #444;
line-height: 1.6;
font-weight: 400;
}

/* 2. MISSION SECTION */
.ab-mission {
padding: 6rem 20px;
background: #fff;
border-bottom: 1px solid #f0f0f0;
}

.ab-mission-layout {
display: flex;
justify-content: space-between;
align-items: center;
max-width: 1000px;
margin: 0 auto;
gap: 60px;
}

.ab-mission-text {
flex: 2;
}

.ab-mission-text p {
font-size: 1.15rem;
line-height: 1.7;
margin-bottom: 1.5rem;
color: #333;
}



/* 3. MANIFESTO (The Anti-Agency) - Dark Section */
.ab-manifesto {
background: #111;
color: #fff;
padding: 100px 20px;
}

.ab-manifesto .ab-section-title {
color: #fff;
text-align: center;
}

.ab-manifesto .ab-section-desc {
color: #aaa;
text-align: center;
}

.ab-manifesto-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 50px;
max-width: 1100px;
margin: 60px auto 0;
}

.ab-manifesto-item {
text-align: left;
}

.ab-icon {
display: block;
font-size: 2rem;
color: #fff;
margin-bottom: 20px;
opacity: 0.5;
}

.ab-manifesto-item h3 {
font-size: 1.5rem;
font-weight: 700;
margin-bottom: 15px;
color: #fff;
}

.ab-manifesto-item p {
font-size: 1rem;
line-height: 1.6;
color: #ccc;
}

/* 4. VALUES & SHARED TITLES */
.ab-values {
padding: 100px 20px;
}

.ab-section-title {
font-size: 2.5rem;
font-weight: 800;
margin-bottom: 15px;
letter-spacing: -1px;
line-height: 1.1;
}

.ab-section-title-small {
font-size: 1.2rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 1.5px;
text-align: center;
margin-bottom: 40px;
color: #999;
}

.ab-section-desc {
max-width: 600px;
margin: 0 auto 50px auto;
font-size: 1.1rem;
color: #555;
text-align: center;
}

.ab-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 30px;
padding: 0;
list-style: none;
max-width: 1200px;
margin: 0 auto;
}

.ab-card {
background: #fff;
padding: 40px 30px;
border: 1px solid #e5e5e5;
/* Transition gestita globalmente */
}

.ab-card h3 {
font-size: 1.4rem;
font-weight: 700;
margin-bottom: 1rem;
}

.ab-card p {
font-size: 1rem;
color: #444;
line-height: 1.6;
}

/* 5. TECH STACK (Tags) */
.ab-tech {
padding: 20px 20px 100px;
text-align: center;
}

.ab-tech-list {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 15px;
max-width: 800px;
margin: 0 auto;
}

.ab-tech-tag {
padding: 10px 25px;
border: 1px solid #e5e5e5;
font-size: 0.9rem;
font-weight: 600;
color: #333;
background: #fff;
transition: all 0.3s ease;
}

.ab-tech-tag:hover {
border-color: #000;
background: #000;
color: #fff;
transform: translateY(-2px);
}

/* 6. PROCESS */
.ab-process {
padding: 80px 20px;
background: #fafafa;
}

.ab-process-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 40px;
padding: 0;
list-style: none;
max-width: 1100px;
margin: 0 auto;
}

.ab-step {
padding: 20px;
}

.ab-step-number {
display: block;
font-size: 3.5rem;
font-weight: 800;
color: #ddd;
line-height: 1;
margin-bottom: 1rem;
}

.ab-step h3 {
font-size: 1.4rem;
font-weight: 700;
margin-bottom: 10px;
}

.ab-step p {
font-size: 1rem;
color: #555;
line-height: 1.6;
}

/* 7. CTA */
.ab-cta {
padding: 100px 20px;
text-align: center;
}

.ab-btn {
display: inline-block;
  padding: 16px 32px;
  border: 1px solid #000;
  background: transparent;
  letter-spacing: 0.8px;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all .25s ease;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
}

/* RESPONSIVE ABOUT PAGE */
@media (max-width: 900px) {
.ab-mission-layout {
    flex-direction: column;
    text-align: left;
    gap: 40px;
}

.ab-mission-stat {
    width: 100%;
    padding: 30px;
}

.ab-manifesto-grid {
    gap: 40px;
}
}

@media (max-width: 768px) {
.ab-hero { padding: 7rem 0 3rem; text-align: left; }
.ab-title-main { font-size: 3rem; }
.ab-section-title, .ab-section-desc { text-align: left; margin-left: 0; }
.ab-mission, .ab-manifesto, .ab-values, .ab-tech, .ab-process, .ab-cta {
    padding: 60px 20px;
}

.ab-tech-list { justify-content: flex-start; }
}




/* =========================================
 HERO (srv-hero)
 ========================================= */
.srv-hero {
padding: 8rem 0 4rem;
}

.srv-eyebrow {
display: block;
font-size: 0.9rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 2px;
margin-bottom: 1.5rem;
color: #888;
}

.srv-title-main {
font-size: clamp(3rem, 6vw, 5.5rem);
font-weight: 800;
letter-spacing: -2px;
line-height: 1.05;
color: #000;
margin-bottom: 1.5rem;
}

.srv-subtitle-main {
font-size: 1.25rem;
font-weight: 400;
color: #555555;
max-width: 650px;
line-height: 1.7;
}

/* =========================================
 SERVICES GRID (srv-list-section)
 ========================================= */
.srv-list-section {
padding: 4rem 0 8rem;
}

.srv-grid-layout {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 2rem;
}

.srv-card {
display: flex;
flex-direction: column;
padding: 2.5rem 2rem;
border: 1px solid #e5e5e5; /* Contorno Card */
background: #ffffff;
transition: all 0.4s ease;
height: 100%;
}

.srv-card-number {
font-size: 1rem;
font-weight: 700;
color: #e5e5e5;
margin-bottom: 3rem;
display: block;
transition: color 0.4s;
}

.srv-card-content h3 {
font-size: 1.5rem;
margin-bottom: 1rem;
transition: color 0.4s;
}

.srv-card-content p {
font-size: 1rem;
color: #555555;
margin-bottom: 2rem;
transition: color 0.4s;
}

.srv-card-link {
margin-top: auto;
font-size: 0.9rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1px;
display: flex;
align-items: center;
gap: 5px;
}

/* Hover: Card diventa nera */
.srv-card:hover {
background: #050505;
border-color: #050505;
transform: translateY(-5px);
}
.srv-card:hover .srv-card-number { color: #444444; }
.srv-card:hover h3 { color: #ffffff; }
.srv-card:hover p { color: #cccccc; }
.srv-card:hover .srv-card-link { color: #ffffff; gap: 10px; }


/* =========================================
 STANDARD SECTION (srv-standard-section)
 ========================================= */
.srv-standard-section {
padding: 4rem 0 8rem;
}

.srv-title {
font-size: 2.5rem;
margin-bottom: 1rem;
letter-spacing: -1px;
}

.srv-subtitle {
font-size: 1.1rem;
color: #555555;
margin-bottom: 4rem;
max-width: 500px;
}

.srv-standard-layout {
display: flex;
justify-content: space-between;
align-items: center;
gap: 5rem;
}

.srv-standard-content { flex: 1; }

.srv-std-item {
display: flex;
gap: 1.5rem;
margin-bottom: 2rem;
}

.srv-std-num {
font-weight: 700;
font-size: 0.9rem;
color: #050505;
padding-top: 2px;
}

.srv-std-text strong {
display: block;
font-size: 1.1rem;
font-weight: 700;
margin-bottom: 0.5rem;
}

.srv-std-text p { color: #555555; }

.srv-standard-img { flex: 0 3 40%; }


/* =========================================
 WORK SECTION (srv-work-section)
 ========================================= */
.srv-work-section {
padding: 4rem 0 8rem;
}

.srv-work-header {
display: flex;
justify-content: space-between;
align-items: flex-end;
margin-bottom: 3rem;
}

.srv-link-arrow {
font-weight: 700;
border-bottom: 1px solid #e5e5e5;
}
.srv-link-arrow:hover { border-bottom-color: #050505; }

.srv-work-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 3rem;
}

/* Stile Card Lavori con Contorno */
.srv-work-card { 
display: block; 
border: 1px solid #e5e5e5; /* Contorno aggiunto */
padding: 1.5rem; /* Spazio interno */
background: #ffffff;
transition: all 0.3s ease;
}

.srv-work-card:hover {
border-color: #050505; /* Bordo nero all'hover */
}

.srv-work-img {
width: 100%;
aspect-ratio: 16/10;
overflow: hidden;
margin-bottom: 1.5rem;
background: #f9f9f9;
}

.srv-work-img img {
width: 100%; height: 100%; object-fit: cover;
transition: transform 0.6s ease;
}

.srv-work-card:hover .srv-work-img img {
transform: scale(1.05);
}

.srv-work-details h3 {
font-size: 1.4rem;
margin-bottom: 0.5rem;
}
.srv-work-details span {
font-size: 0.9rem;
color: #555555;
text-transform: uppercase;
}

/* =========================================
 FAQ SECTION (srv-faq-section)
 ========================================= */
.srv-faq-section {
padding: 4rem 0 8rem;
}

.srv-faq-layout {
display: grid;
grid-template-columns: 1fr;
gap: 4rem;
}

.srv-faq-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 4rem 3rem;
}

.srv-faq-item h3 {
font-size: 1.2rem;
margin-bottom: 1rem;
}
.srv-faq-item p {
color: #555555;
}

/* =========================================
 TECH SECTION (srv-tech-section)
 ========================================= */
.srv-tech-section {
padding: 6rem 0;
text-align: center;
}

.srv-tech-title {
font-size: 2rem;
margin-bottom: 1rem;
}

.srv-tech-subtitle {
color: #555555;
margin-bottom: 4rem;
max-width: 600px;
margin: 0 auto 4rem auto;
}

.srv-tech-grid {
display: flex;
justify-content: center;
flex-wrap: wrap;
gap: 4rem;
}

.srv-tech-item {
width: 150px;
text-align: center;
}

.srv-tech-icon {
margin-bottom: 1.5rem;
opacity: 0.9;
}

.srv-tech-name {
font-size: 1rem;
margin-bottom: 0.5rem;
}

.srv-tech-desc {
font-size: 0.85rem;
color: #555555;
line-height: 1.4;
}

/* =========================================
 CTA SECTION (srv-cta)
 ========================================= */
.srv-cta {
padding: 6rem 0 10rem;
text-align: center;
}

.srv-cta h2 {
font-size: clamp(2rem, 4vw, 3rem);
margin-bottom: 1rem;
}

.srv-cta p {
font-size: 1.2rem;
color: #555555;
margin-bottom: 3rem;
}

.srv-cta-btn {
display: inline-block;
padding: 16px 32px;
border: 1px solid #000;
background: transparent;
letter-spacing: 0.8px;
font-size: 0.9rem;
cursor: pointer;
transition: all .25s ease;
box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
}
.srv-cta-btn:hover {
background: #000;
color: #fff;
transform: translateY(-2px);
}

/* =========================================
 MOBILE & TABLET RESPONSIVE (MAX 900px)
 ========================================= */
 @media (max-width: 900px) {

  /* --- Navigation --- */
  .hamburger-btn { 
    display: flex; 
  }
  
  .nav-bar {
    display: none; /* Nascondi menu di default */
    position: absolute; 
    top: 100%; 
    left: 0; 
    width: 100%;
    background: #ffffff; 
    padding: 2rem; 
    flex-direction: column;
    border-bottom: 1px solid #e5e5e5;
    z-index: 100;
  }

  .nav-bar.active {
    display: flex; /* Classe per JS per mostrare il menu */
  }

  /* --- Layout & Grid Collapsing --- */
  /* Trasforma le griglie a 2 o 3 colonne in 1 colonna */
  .srv-grid-layout, 
  .srv-work-grid, 
  .srv-faq-grid,
  .srv-standard-layout {
    grid-template-columns: 1fr;
    flex-direction: column; /* Per il flex di standard-layout */
    gap: 3rem;
  }

  /* --- Sezioni Specifiche --- */
  
  /* Hero: meno padding */
  .srv-hero { 
    padding: 5rem 0 3rem; 
  }

  /* Standard Section: Immagine sopra il testo */
  .srv-standard-img { 
    order: -1; 
    width: 100%;
  }

  /* Work: Header in colonna */
  .srv-work-header {
    flex-direction: column; 
    align-items: flex-start; 
    gap: 1rem;
  }

  /* Tech: meno spazio tra le icone */
  .srv-tech-grid {
    gap: 2rem;
  }

  /* --- Spaziature Generali --- */
  .srv-list-section, 
  .srv-standard-section, 
  .srv-work-section, 
  .srv-faq-section,
  .srv-cta {
    padding: 3rem 0; /* Padding ridotto per mobile */
  }

  /* --- Tipografia Mobile --- */
  .srv-title {
    font-size: 2rem; /* Titoli più piccoli su mobile */
  }
  
  .srv-tech-title, .srv-cta h2 {
    font-size: 2rem;
  }
}
/* ================================
 ONEPAGE HERO
================================ */

.onepage-hero {
padding: 10rem 0 8rem;
background: #ffffff;
color: #000000;
}

.onepage-hero .container {
max-width: 1200px;
margin: 0 auto;
padding: 0 2rem;
text-align: left; /* Allineamento a sinistra */
}

/* TITLE */
.onepage-title {
font-size: 4.5rem;
font-weight: 800;
letter-spacing: -1px;
line-height: 1.1;
margin-bottom: 1.5rem;
max-width: 700px;
}

/* SUBTITLE */
.onepage-subtitle {
font-size: 1.25rem;
line-height: 1.7;
max-width: 650px;
opacity: 0.8;
margin-bottom: 2.5rem;
}

/* CTA BUTTON — same style as your main CTA */
.btn-cta {
display: inline-block;
padding: 16px 32px;
border: 1px solid #000;
background: transparent;
letter-spacing: 0.8px;
font-size: 0.9rem;
cursor: pointer;
transition: all .25s ease;
box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
}

.btn-cta:hover {
background: #000;
color: #fff;
transform: translateY(-3px);
}

/* ------------------------------------------
 ONEPAGE INTRO — COODIE SPLIT LAYOUT
-------------------------------------------*/

.onepage-intro {
background: #fff;
color: #000;
padding: 8rem 0;
}

.intro-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 6rem;
align-items: start;
}

/* LEFT SIDE */
.intro-left h2 {
font-size: 3rem;
font-weight: 700;
margin-bottom: 1.5rem;
}

.intro-left .intro-text {
font-size: 1.15rem;
line-height: 1.7;
max-width: 550px;
opacity: 0.9;
}

/* RIGHT SIDE — FEATURES */
.intro-features {
display: flex;
flex-direction: column;
gap: 2.5rem;
padding-left: 0;
margin: 0;
}

.intro-features li {
list-style: none;
padding-bottom: 2rem;
border-bottom: 1px solid #e8e8e8;
}

.feat-title {
display: block;
font-size: 1.1rem;
font-weight: 600;
margin-bottom: .3rem;
}

.feat-desc {
display: block;
font-size: .95rem;
opacity: 0.75;
}

/* BENEFITS SECTION */
.onepage-benefits {
background: #fff;
color: #000;
padding: 9rem 0;
}

.onepage-benefits h2 {
font-size: clamp(2.2rem, 4vw, 3rem);
font-weight: 700;
margin-bottom: 4rem;
}

/* LIST */
.benefits-list {
display: flex;
flex-direction: column;
gap: 3.5rem;
}

/* SINGLE ITEM */
.benefit-item {
display: flex;
align-items: flex-start;
gap: 2rem;
padding: 2.5rem 0;
border-bottom: 1px solid #000;
}

.benefit-item:last-child {
border-bottom: none;
}

/* ICON */
.benefit-icon {
width: 50px;
height: 50px;
object-fit: contain;
filter: grayscale(100%) brightness(0%);
}

/* TEXTS */
.benefit-item h3 {
font-size: 1.4rem;
font-weight: 600;
margin-bottom: 0.5rem;
}

.benefit-item p {
font-size: 1rem;
line-height: 1.7;
opacity: 0.8;
max-width: 600px;
}

/* ============================
 PROCESS – MEGA BLOCKS
============================ */

.onepage-process {
padding: 0px 0;
}

.onepage-process h2 {
font-size: 3rem;
font-weight: 700;
text-transform: none;
text-align: left;
margin-bottom: 60px;
}

.process-megablocks {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 32px;
}

.mega-block {
border: 1px solid #e8e8e8;   /* bordo iniziale grigio chiaro */
padding: 32px;
transition: border-color 0.25s ease, border-width 0.25s ease;
display: flex;
flex-direction: column;
gap: 12px;
cursor: pointer;
}

.mega-block:hover {
border-color: #000;       /* diventa nero */
border-width: 1px;
transform: scale(1.02);
}

.mega-block .block-header {
display: flex;
justify-content: space-between;
align-items: center;
}

.block-number {
font-size: 32px;
font-weight: 800;
}

.block-icon {
width: 48px;
height: 48px;
object-fit: contain;
}

.mega-block h3 {
font-size: 24px;
font-weight: 700;
margin: 0;
}

.mega-block p {
font-size: 16px;
color: #333;
max-width: 85%;
}

/* SECTION */
.onepage-pricing {
padding: 5rem 0;
}

.onepage-pricing h2 {
text-align: center;
font-size: 3rem;
margin-bottom: 3rem;
}

/* CARD */
.pricing-card {
max-width: 480px;
margin: 0 auto;
background: #fff;
border: 1px solid #e6e6e6;
padding: 3rem;
transition: border-color .3s ease;
}

.pricing-card:hover {
border-color: #000;

}

/* HEADER */
.pricing-header {
margin-bottom: 2rem;
text-align: left;
}

.pricing-label {
font-size: 1rem;
text-transform: uppercase;
opacity: 0.6;
}

/* PRICE */
.pricing-amount {
margin-top: 1.4rem;
font-size: 1.2rem;
}

.pricing-amount strong {
font-size: 3rem;
display: inline-block;
}

.per-project {
font-size: 1rem;
opacity: 0.6;
margin-left: .2rem;
}

/* FEATURES */
.pricing-features {
list-style: none;
padding: 0;
margin: 2rem 0;
}

.pricing-features li {
padding: 0.75rem 0;
font-size: 1.1rem;
display: flex;
align-items: center;
gap: 0.7rem;
border-bottom: 1px solid #eee;
}

.pricing-features li::before {
content: "";
font-weight: 600;
display: inline-block;
}

/* BUTTON */
.pricing-btn {
display: block;
width: 100%;
text-align: center;
padding: 1.5rem 0;
background: #000;
color: #fff;
font-size: 1.1rem;
text-decoration: none;
transition: background .3s ease, transform .2s ease;
}

.pricing-btn:hover {
background: #000;
transform: translateY(-2px);
}

/* SECTION */
.onepage-faq {
padding: 6rem 0;
}

.onepage-faq h2 {
text-align: center;
font-size: 3rem;
margin-bottom: 4rem;
}

/* FAQ WRAPPER */
.onepage-faq details {
border-top: 1px solid #000;
padding: 1.8rem 0;
cursor: pointer;
transition: background 0.3s ease;
}

.onepage-faq details:last-of-type {
border-bottom: 1px solid #000;
}

/* SUMMARY */
.onepage-faq summary {
list-style: none;
font-size: 1.4rem;
font-weight: 500;
position: relative;
padding-right: 2rem;
}

.onepage-faq summary::-webkit-details-marker {
display: none;
}

/* ICON (PLUS → MINUS) */
.onepage-faq summary::after {
content: "+";
position: absolute;
right: 0;
top: 2px;
font-size: 1.6rem;
transition: transform 0.3s ease, opacity 0.3s ease;
}

.onepage-faq details[open] summary::after {
content: "–";
transform: rotate(180deg);
}

/* TEXT */
.onepage-faq p {
margin: 1.2rem 0 0 0;
font-size: 1.2rem;
line-height: 1.6;
opacity: 0.8;
max-width: 650px;
}

/* SMOOTH OPENING ANIMATION */
.onepage-faq details[open] p {
animation: fadeInFaq 0.25s ease;
}

/* FINAL CTA SECTION */
.onepage-final-cta {
background: #000;
padding: 3rem 0;
text-align: center;
color: #fff;
}

.onepage-final-cta h2 {
font-size: 3rem;
margin-bottom: 3rem;
font-weight: 600;
}

/* CTA BUTTON (Coodie style) */
.onepage-final-cta .cta-btn {
display: inline-block;
padding: 1.4rem 2rem;
border: 1px solid #fff;
color: #fff;
text-decoration: none;
font-size: 1.3rem;
font-weight: 500;
transition: background 0.3s ease, color 0.3s ease;
}

.onepage-final-cta .cta-btn:hover {
background: #fff;
color: #000;
}


@keyframes fadeInFaq {
from { opacity: 0; transform: translateY(-4px); }
to { opacity: 1; transform: translateY(0); }
}


/* ============================================================
 E-COMMERCE HERO — versione centrata
============================================================ */

.shop-hero {
padding: 10rem 0 8rem;
background: #fff;
color: #000;
text-align: center;
}

.shop-hero .container {
max-width: 900px;
margin: 0 auto;
padding: 0 2rem;
}

.shop-title {
font-size: 4.2rem;
font-weight: 800;
letter-spacing: -1px;
line-height: 1.1;
margin-bottom: 1.5rem;
}

.shop-subtitle {
font-size: 1.25rem;
line-height: 1.7;
opacity: 0.8;
max-width: 650px;
margin: 0 auto 2.5rem;
}

/* CTA style identical to Onepage */
.btn-cta,
.shop-hero .btn-cta {
display: inline-block;
padding: 0.85rem 1.8rem;
border: 1px solid #000;
color: #000;
text-decoration: none;
font-size: 1rem;
transition: all 0.25s ease;
}

.btn-cta:hover {
background: #000;
color: #fff;
transform: translateY(-3px);
}


/* ============================================================
 INTRO SECTION — Split layout centrato
============================================================ */

.shop-intro {
background: #fff;
color: #000;
padding: 8rem 0;
}

.shop-intro-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 6rem;
align-items: start;
}

.shop-intro-center h2 {
font-size: 3rem;
font-weight: 700;
margin-bottom: 1.5rem;
}

.shop-intro-text {
font-size: 1.15rem;
line-height: 1.7;
opacity: 0.9;
max-width: 550px;
}

.shop-intro-features-wrapper {
padding-left: 0;
}

.shop-intro-features {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 2.5rem;
}

.shop-intro-features li {
padding-bottom: 2rem;
border-bottom: 1px solid #e8e8e8;
}

.shop-intro-features .feat-title {
display: block;
font-size: 1.1rem;
font-weight: 600;
margin-bottom: .3rem;
}

.shop-intro-features .feat-desc {
display: block;
font-size: .95rem;
opacity: 0.75;
}


/* ============================================================
 BENEFITS — identiche alle Onepage benefits
============================================================ */

/* ===============================
 SHOP BENEFITS — ULTRA MINIMAL
 =============================== */

 .shop-benefits {
  background: #fff;
  padding: 6rem 0;
}

.shop-benefits .container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 2rem;
  text-align: center;
}

/* Section Heading */
.shop-benefits h2 {
  font-size: 2.6rem;
  font-weight: 800;
  letter-spacing: -0.8px;
  color: #000;
  margin-bottom: 3.5rem;
  line-height: 1.1;
}

/* GRID */
.shop-benefits-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.5rem 4rem;
  align-items: start;
}

/* SINGLE ITEM */
.shop-benefit {
  display: flex;
  align-items: flex-start;
  gap: 1.4rem;
  text-align: left;
}

/* ICON */
.benefit-icon {
  width: 46px;
  height: 46px;
  flex-shrink: 0;
  opacity: 0.9;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.shop-benefit:hover .benefit-icon {
  transform: translateY(-4px);
  opacity: 1;
}

/* TITLE */
.shop-benefit h3 {
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.3px;
  margin-bottom: 0.4rem;
  color: #000;
}

/* TEXT */
.shop-benefit p {
  font-size: 1.05rem;
  line-height: 1.55;
  color: #333;
  opacity: 0.85;
}

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

@media (max-width: 900px) {
  .shop-benefits-list {
    grid-template-columns: 1fr;
    gap: 2.8rem;
  }

  .benefit-icon {
    width: 42px;
    height: 42px;
  }
}

@media (max-width: 600px) {
  .shop-benefit h3 {
    font-size: 1.25rem;
  }

  .shop-benefit p {
    font-size: 1rem;
  }
}



/* ============================================================
 PROCESS — Mega Blocks come Onepage
============================================================ */

.shop-process {
padding: 8rem 0;
}

.shop-process h2 {
font-size: 3rem;
font-weight: 700;
margin-bottom: 60px;
text-align: center; /* centrato */
}

.shop-process-megablocks {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 32px;
max-width: 900px;
margin: 0 auto;
}

.shop-mega-block {
border: 1px solid #e8e8e8;
padding: 32px;
transition: border-color 0.25s ease, transform 0.25s ease;
display: flex;
flex-direction: column;
gap: 12px;
}

.shop-mega-block:hover {
border-color: #000;
transform: scale(1.02);
}

.shop-block-header {
display: flex;
justify-content: space-between;
align-items: center;
}

.shop-block-number {
font-size: 32px;
font-weight: 800;
}

.shop-block-icon {
width: 48px;
height: 48px;
object-fit: contain;
}

.shop-mega-block h3 {
font-size: 24px;
font-weight: 700;
}

.shop-mega-block p {
font-size: 16px;
opacity: 0.8;
max-width: 80%;
}


/* ============================================================
 PRICING — Card come Onepage
============================================================ */

.shop-pricing {
padding: 6rem 0 7rem;
}

.shop-pricing h2 {
text-align: center;
font-size: 3rem;
margin-bottom: 3rem;
}

.shop-pricing-card {
max-width: 480px;
margin: 0 auto;
border: 1px solid #e6e6e6;
padding: 3rem;
transition: border-color .3s ease;
}

.shop-pricing-card:hover {
border-color: #000;
}

.shop-pricing-header {
margin-bottom: 2rem;
}

.shop-pricing-label {
font-size: 1rem;
text-transform: uppercase;
opacity: 0.6;
}

.shop-pricing-amount {
margin-top: 1.4rem;
font-size: 1.2rem;
}

.shop-pricing-amount strong {
font-size: 3rem;
}

.per-project {
opacity: .6;
}

/* FEATURES */
.shop-pricing-features {
list-style: none;
padding: 0;
margin: 2rem 0;
}

.shop-pricing-features li {
padding: .75rem 0;
border-bottom: 1px solid #eee;
font-size: 1.1rem;
}

/* BUTTON */
.shop-pricing-btn {
display: block;
width: 100%;
padding: 1.5rem 0;
text-align: center;
background: #000;
color: #fff;
text-decoration: none;
font-size: 1.1rem;
transition: transform .25s ease;
}

.shop-pricing-btn:hover {
transform: translateY(-2px);
}


/* ============================================================
 FAQ — identical to Onepage FAQ
============================================================ */

.shop-faq {
padding: 6rem 0;
}

.shop-faq h2 {
text-align: center;
font-size: 3rem;
margin-bottom: 4rem;
}

.shop-faq details {
border-top: 1px solid #000;
padding: 1.8rem 0;
cursor: pointer;
}

.shop-faq details:last-of-type {
border-bottom: 1px solid #000;
}

.shop-faq summary {
font-size: 1.4rem;
font-weight: 500;
padding-right: 2rem;
position: relative;
}

.shop-faq summary::-webkit-details-marker {
display: none;
}

.shop-faq summary::after {
content: "+";
position: absolute;
right: 0;
top: 4px;
font-size: 1.6rem;
}

.shop-faq details[open] summary::after {
content: "–";
}

.shop-faq p {
margin-top: 1.2rem;
font-size: 1.2rem;
opacity: 0.8;
}


/* ============================================================
 FINAL CTA — Black background identical to Onepage
============================================================ */

.shop-final-cta {
background: #000;
padding: 3rem 0;
text-align: center;
color: #fff;
}

.shop-final-cta h2 {
font-size: 3rem;
margin-bottom: 3rem;
}

.shop-final-cta .cta-btn {
display: inline-block;
padding: 1.4rem 2rem;
border: 1px solid #fff;
color: #fff;
text-decoration: none;
font-size: 1.3rem;
}

.shop-final-cta .cta-btn:hover {
background: #fff;
color: #000;
}

/* ============================================================
 COODIE ONE-PAGE EXPANSION (Strict Coodie Design System)
 ============================================================ */

/* ============================================================
 UNIVERSAL SERVICE PAGES STYLES
 Gestisce: OnePage (.op-), E-Commerce (.e-), MultiPage (.mp-)
 ============================================================ */

/* 1. HERO SECTIONS */
.op-hero, .e-hero, .mp-hero { 
padding: 10.5rem 0 10.5rem; 
background: #ffffff; 
text-align: center; 
}

.op-eyebrow, .e-eyebrow, .mp-eyebrow { 
display: inline-block; 
font-size: 0.85rem; 
font-weight: 600; 
text-transform: uppercase; 
letter-spacing: 2px; 
margin-bottom: 10px; 
color: #555; 
}

.op-title-main, .e-title-main, .mp-title-main { 
font-size: clamp(3rem, 6vw, 5rem); 
font-weight: 700; 
letter-spacing: -1.5px; 
line-height: 1.1; 
color: #000; 
margin-bottom: 1.5rem; 
}

.op-subtitle-main, .e-subtitle-main, .mp-subtitle-main { 
max-width: 650px; 
margin: 0 auto; 
font-size: 1.15rem; 
color: #333; 
line-height: 1.6; 
opacity: 0.85; 
font-weight: 600; 
}

/* 2. SECTION HEADINGS COMUNI */
.op-section-title, .e-section-title, .mp-section-title { 
font-family: 'Inter', sans-serif; 
font-size: 2.5rem; 
font-weight: 700; 
color: #000; 
text-align: center; 
margin-bottom: 20px; 
letter-spacing: -0.5px; 
}

.op-section-desc, .e-section-desc, .mp-section-desc { 
max-width: 700px; 
margin: 0 auto 20px auto; 
text-align: center; 
font-size: 1.1rem; 
color: #444; 
line-height: 1.7; 
}

/* 3. BENEFITS GRID */
.op-benefits, .e-benefits, .mp-benefits { 
padding: 80px 20px; 
background: #fff; 
}

.op-grid, .e-grid, .mp-grid { 
display: grid; 
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); 
gap: 30px; 
}

.op-card, .e-card, .mp-card { 
background: #ffffff; 
padding: 40px 30px; 
border: 1px solid #e5e5e5; 
height: 100%; 
/* La transizione è gestita nel Global Interactive System */
}

.op-card h3, .e-card h3, .mp-card h3 { 
font-size: 1.5rem; 
font-weight: 700; 
color: #000; 
margin-bottom: 1rem; 
letter-spacing: -0.5px; 
}

.op-card p, .e-card p, .mp-card p { 
font-size: 1rem; 
color: #333; 
line-height: 1.6; 
}

/* 4. PORTFOLIO */
.op-portfolio, .e-portfolio, .mp-portfolio { 
padding: 80px 20px; 
}

.op-project-card, .e-project-card, .mp-project-card { 
display: block; 
border: 1px solid transparent; 
}

.op-project-img, .e-project-img, .mp-project-img { 
width: 100%; 
height: 350px; 
background-color: #f4f4f4; 
border: 1px solid #e5e5e5; 
margin-bottom: 1.2rem; 
transition: border-color 0.3s ease; 
}

.op-project-card:hover .op-project-img,
.e-project-card:hover .e-project-img,
.mp-project-card:hover .mp-project-img { 
border-color: #000; 
}

.op-project-card h3, .e-project-card h3, .mp-project-card h3 { 
font-size: 1.25rem; 
font-weight: 700; 
color: #000; 
margin-bottom: 0.2rem; 
}

.op-project-card p, .e-project-card p, .mp-project-card p { 
font-size: 0.95rem; 
color: #666; 
}

/* 5. WORKFLOW / TIMELINE */
.op-workflow, .e-workflow, .mp-workflow { 
padding: 80px 20px; 
}

.op-timeline, .e-timeline, .mp-timeline { 
position: relative; 
max-width: 900px; 
margin: 40px auto 0; 
}

.op-timeline::before, .e-timeline::before, .mp-timeline::before { 
content: ""; 
position: absolute; 
top: 0; 
left: 50%; 
width: 1px; 
height: 100%; 
background: #e5e5e5; 
transform: translateX(-50%); 
}

.op-timeline-step, .e-timeline-step, .mp-timeline-step { 
position: relative; 
width: 50%; 
padding: 0 40px 60px; 
box-sizing: border-box; 
}

/* Alternanza sinistra/destra */
.op-timeline-step:nth-child(odd), .e-timeline-step:nth-child(odd), .mp-timeline-step:nth-child(odd) { 
left: 0; 
text-align: right; 
}
.op-timeline-step:nth-child(even), .e-timeline-step:nth-child(even), .mp-timeline-step:nth-child(even) { 
left: 50%; 
text-align: left; 
}

.op-timeline-content, .e-timeline-content, .mp-timeline-content { 
background: #fff; 
padding: 30px; 
border: 1px solid #e5e5e5; 
}

.op-timeline-content h3, .e-timeline-content h3, .mp-timeline-content h3 { 
font-size: 1.2rem; 
font-weight: 700; 
margin-bottom: 10px; 
}

/* 6. PRICING SHEET */
.op-pricing, .e-pricing, .mp-pricing { 
padding: 80px 20px; 
}

.op-pricing-sheet, .e-pricing-sheet, .mp-pricing-sheet { 
display: grid; 
grid-template-columns: 1fr 1.5fr; 
border: 1px solid #e5e5e5; 
background: #fff; 
max-width: 1000px; 
margin: 0 auto; 
}

.op-sheet-main, .e-sheet-main, .mp-sheet-main { 
padding: 3rem; 
border-right: 1px solid #e5e5e5; 
display: flex; 
flex-direction: column; 
justify-content: center; 
}

.op-sheet-label, .e-sheet-label, .mp-sheet-label { 
font-size: 0.8rem; 
text-transform: uppercase; 
letter-spacing: 1.5px; 
font-weight: 600; 
color: #666; 
margin-bottom: 1rem; 
}

.op-sheet-main h3, .e-sheet-main h3, .mp-sheet-main h3 { 
font-size: 1.8rem; 
font-weight: 700; 
margin-bottom: 0.5rem; 
letter-spacing: -0.5px; 
}

.op-sheet-price, .e-sheet-price, .mp-sheet-price { 
font-size: 3.5rem; 
font-weight: 700; 
color: #000; 
margin-bottom: 0.5rem; 
letter-spacing: -1px; 
}

.op-sheet-note, .e-sheet-note, .mp-sheet-note { 
font-size: 0.95rem; 
color: #555; 
margin-bottom: 2rem; 
font-style: italic; 
}

.op-btn-full, .e-btn-full, .mp-btn-full { 
display: inline-block; 
width: 100%; 
text-align: center; 
padding: 1rem; 
border: 1px solid #000; 
background: transparent; 
color: #000; 
font-weight: 600; 
text-transform: uppercase; 
transition: all 0.25s ease; 
}
.op-btn-full:hover, .e-btn-full:hover, .mp-btn-full:hover { 
background: #000; 
color: #fff; 
}

.op-detail-group, .e-detail-group, .mp-detail-group { 
padding: 2.5rem; 
}

.op-detail-group h4, .e-detail-group h4, .mp-detail-group h4 { 
font-size: 0.9rem; 
text-transform: uppercase; 
font-weight: 700; 
margin-bottom: 1.5rem; 
border-bottom: 1px solid #eee; 
padding-bottom: 10px; 
}

.op-check-list li, .e-check-list li, .mp-check-list li { 
display: flex; 
justify-content: space-between; 
margin-bottom: 12px; 
font-size: 1rem; 
color: #333; 
}

.op-tick, .e-tick, .mp-tick { font-weight: 700; color: #000; }

.op-addons-group, .e-addons-group, .mp-addons-group { 
background: #fafafa; 
border-top: 1px solid #e5e5e5; 
flex-grow: 1; 
}

.op-addon-list, .e-addon-list, .mp-addon-list { 
display: flex; 
flex-wrap: wrap; 
gap: 10px; 
}

.op-addon-list li, .e-addon-list li, .mp-addon-list li { 
font-size: 0.9rem; 
background: #fff; 
border: 1px solid #e5e5e5; 
padding: 6px 12px; 
color: #555; 
}

/* 7. FAQ */
.op-faq, .e-faq, .mp-faq { 
padding: 80px 20px; 
max-width: 900px; 
margin: 0 auto; 
}

.op-faq-list details, .e-faq-list details, .mp-faq-list details { 
background: #fff; 
border: 1px solid #e5e5e5; 
padding: 20px 25px; 
margin-bottom: 15px; 
cursor: pointer;
}

.op-faq-list summary, .e-faq-list summary, .mp-faq-list summary { 
font-size: 1.1rem; 
font-weight: 600; 
list-style: none; 
position: relative; 
padding-right: 25px; 
}
.op-faq-list summary::-webkit-details-marker,
.e-faq-list summary::-webkit-details-marker,
.mp-faq-list summary::-webkit-details-marker { display: none; }

.op-faq-list summary::after, .e-faq-list summary::after, .mp-faq-list summary::after { 
content: "+"; 
position: absolute; 
right: 0; 
top: 0; 
font-size: 1.3rem; 
font-weight: 400; 
}
.op-faq-list details[open] summary::after, 
.e-faq-list details[open] summary::after, 
.mp-faq-list details[open] summary::after { content: "-"; }

.op-faq-list p, .e-faq-list p, .mp-faq-list p { 
margin-top: 15px; 
font-size: 0.95rem; 
line-height: 1.6; 
color: #333; 
}

/* 8. ALTERNATIVES */
.op-alternatives, .e-alternatives, .mp-alternatives { 
padding: 80px 20px; 
border-top: 1px solid #e5e5e5; 
}

.op-alt-grid, .e-alt-grid, .mp-alt-grid { 
display: grid; 
grid-template-columns: 1fr 1fr; 
gap: 30px; 
}

.op-alt-card, .e-alt-card, .mp-alt-card { 
background: #fff; 
padding: 40px; 
border: 1px solid #e5e5e5; 
display: flex; 
flex-direction: column; 
justify-content: space-between; 
text-decoration: none; 
color: inherit; 
min-height: 280px; 
}

.op-alt-header, .e-alt-header, .mp-alt-header { 
display: flex; 
justify-content: space-between; 
margin-bottom: 2rem; 
}

.op-alt-label, .e-alt-label, .mp-alt-label { 
font-size: 0.75rem; 
text-transform: uppercase; 
font-weight: 600; 
opacity: 0.6; 
}

.op-arrow, .e-arrow, .mp-arrow { 
font-size: 1.5rem; 
transition: transform 0.3s; 
}
.op-alt-card:hover .op-arrow,
.e-alt-card:hover .e-arrow,
.mp-alt-card:hover .mp-arrow { 
transform: translateX(5px); 
}

.op-alt-card h3, .e-alt-card h3, .mp-alt-card h3 { 
font-size: 1.8rem; 
font-weight: 700; 
margin-bottom: 1rem; 
}
.op-alt-card p, .e-alt-card p, .mp-alt-card p { 
font-size: 1rem; 
color: #555; 
}

/* 9. CTA FINAL */
.op-cta, .e-cta, .mp-cta { 
padding: 30px 20px; 
text-align: center; 
background: #fff; 
padding-bottom: 70px; 
}

.op-cta .cta-btn, .e-cta .cta-btn, .mp-cta .cta-btn { 
display: inline-block; 
padding: 14px 35px; 
border: 1px solid #000; 
color: #000; 
text-decoration: none; 
font-weight: 600; 
}
.op-cta .cta-btn:hover, .e-cta .cta-btn:hover, .mp-cta .cta-btn:hover { 
background: #000; 
color: #fff; 
}

/* =========================================
   PORTFOLIO SLIDER SECTION (Fixed 3 Columns)
   ========================================= */

 /* =========================================
   STILI GENERALI E DESKTOP
   ========================================= */
.srv-work-section {
  padding: 4rem 0;
  overflow: hidden;
  position: relative;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
  position: relative;
}

.srv-work-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 2rem;
}

.srv-title { font-size: 2rem; font-weight: 600; margin: 0; }
.srv-link-arrow { text-decoration: none; color: inherit; border-bottom: 1px solid currentColor; }

/* Wrapper Slider */
.slider-wrapper-controls {
  position: relative;
  width: 100%;
}

/* GRIGLIA (Contenitore scorrevole) */
.srv-work-grid {
  display: flex;
  flex-wrap: nowrap; /* Impedisce a capo */
  gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  padding: 1rem 0;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.srv-work-grid::-webkit-scrollbar { display: none; }

/* CARD DESKTOP (3 per volta) */
.srv-work-card {
  flex: 0 0 calc((100% - 40px) / 3);
  min-width: calc((100% - 40px) / 3); /* Importante */
  scroll-snap-align: start;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform 0.3s;
}

.srv-work-img { width: 100%; aspect-ratio: 4/3; background: #eee; overflow: hidden; }
.srv-work-img img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s; }
.srv-work-card:hover .srv-work-img img { transform: scale(1.05); }

/* FRECCE (Stile Base) */
.slider-btn {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px;
  background: #fff; border: 1px solid #ddd; border-radius: 50%;
  cursor: pointer; z-index: 100; /* Z-index alto! */
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}
.prev-btn { left: -25px; }
.next-btn { right: -25px; }


/* =========================================
 TABLET (Max 1024px) - 2 CARD
 ========================================= */
@media (max-width: 1024px) {
  .srv-work-card {
      flex: 0 0 calc((100% - 20px) / 2);
      min-width: calc((100% - 20px) / 2);
  }
  .prev-btn { left: 0; }
  .next-btn { right: 0; }
}


/* =========================================
 MOBILE (Max 768px) - IL FIX DEFINITIVO
 ========================================= */
@media (max-width: 768px) {
  
  .srv-work-header { flex-direction: column; align-items: flex-start; gap: 10px; }

  /* Forziamo il contenitore a non mandare mai a capo */
  .srv-work-grid {
      display: flex;
      flex-direction: row; /* Direzione orizzontale esplicita */
      flex-wrap: nowrap;   /* VIETATO andare a capo */
      overflow-x: auto;    /* Scroll orizzontale */
      gap: 0;              /* Gap gestito dal padding della card */
      width: 100%;
  }

  /* CARD MOBILE */
  .srv-work-card {
      /* LA PARTE MAGICA: */
      flex: 0 0 100%;      /* Non crescere, non restringere, base 100% */
      flex-shrink: 0;      /* VIETATO RESTRINGERSI (Risolve l'impilamento) */
      width: 100%;         /* Larghezza forzata */
      min-width: 100%;     /* Larghezza minima forzata */
      
      padding: 20px ;     /* Spazio laterale */
      box-sizing: border-box;
      scroll-snap-align: center;
  }

  /* FRECCE MOBILE */
  .slider-btn {
      display: flex;
      width: 35px; height: 35px;
      background: rgba(255,255,255,0.9);
      top: 35%; /* Sull'immagine */
      color: #000 !important; /* Forza il nero */
  }
  .prev-btn { left: 10px; }
  .next-btn { right: 10px; }
}







/* --- Portfolio Layout Styles --- */


.portfolio-section {
  padding: 50px 0;
  background-color: #ffffff;
}

/* Titoli della pagina */
.page-title {
  font-family: 'Inter', sans-serif;
  font-size: 3rem;
  font-weight: 800;
  color: #111;
  margin-bottom: 10px;
  text-align: center;
}

.page-subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 1.2rem;
  color: #666;
  text-align: center;
  margin-bottom: 60px;
}

/* Titoli delle categorie */
.category-title {
  font-family: 'Inter', sans-serif;
  font-size: 1.8rem;
  font-weight: 600;
  margin-bottom: 30px;
  color: #111;
  border-left: 4px solid #111; /* Accento di stile Coodie */
  padding-left: 15px;
}

.section-divider {
  border: 0;
  height: 1px;
  background: #eee;
  margin: 60px 0;
}

/* --- Grid System (3 colonne) --- */
.portfolio-grid {
  display: grid;
  /* 3 colonne di larghezza uguale */
  grid-template-columns: repeat(3, 1fr); 
  /* Spazio tra le card */
  gap: 30px; 
  width: 100%;
}

/* --- Portfolio Card Style --- */
.portfolio-card {
  display: block;
  padding: 20px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  background: #fff;
  overflow: hidden;
}

.portfolio-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

.portfolio-img-wrapper {
  margin: 0;
  padding: 0;
  width: 100%;
  aspect-ratio: 4 / 3; /* Mantiene le immagini rettangolari uniformi */
  overflow: hidden;
  background-color: #f4f4f4; /* Placeholder colore mentre carica */
}

.portfolio-img-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Taglia l'immagine per riempire lo spazio senza deformare */
  transition: transform 0.5s ease;
}

.portfolio-card:hover .portfolio-img-wrapper img {
  transform: scale(1.05); /* Zoom leggero sull'immagine all'hover */
}

.portfolio-details {
  padding: 20px 5px;
}

.portfolio-details h3 {
  font-family: 'Inter', sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0 0 5px 0;
  color: #111;
}

.portfolio-details span {
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  color: #666;
  font-weight: 400;
}

/* --- Coming Soon Section Style --- */
.coming-soon-wrapper {
  background-color: #f9f9f9;
  border: 1px dashed #ccc;
  padding: 60px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 15px;
}

.coming-soon-badge {
  background-color: #545454;
  color: #fff;
  padding: 6px 12px;
  font-size: 0.8rem;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 1px;
}

.coming-soon-wrapper p {
  color: #555;
  font-family: 'Inter', sans-serif;
}

/* --- Responsiveness --- */

/* Tablet: 2 colonne */
@media (max-width: 992px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile: 1 colonna */
@media (max-width: 600px) {
  .portfolio-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  
  .page-title {
    font-size: 2.2rem;
  }
}

/* MOBILE RESPONSIVE UNIVERSALE */
@media (max-width: 900px) {
.op-pricing-sheet, .e-pricing-sheet, .mp-pricing-sheet { grid-template-columns: 1fr; }
.op-sheet-main, .e-sheet-main, .mp-sheet-main { border-right: none; border-bottom: 1px solid #e5e5e5; text-align: center; }
.op-alt-grid, .e-alt-grid, .mp-alt-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
.op-title-main, .e-title-main, .mp-title-main { font-size: 3rem; }
.op-timeline::before, .e-timeline::before, .mp-timeline::before { left: 0; }
.op-timeline-step, .e-timeline-step, .mp-timeline-step { 
  width: 100%; 
  left: 0 !important; 
  text-align: left !important; 
  padding-left: 30px; 
  padding-right: 0; 
  margin-bottom: 20px; 
}
.op-grid, .e-grid, .mp-grid { grid-template-columns: 1fr; }
}







 














@media (max-width: 768px) {
  .hamburger-btn {
      display: block;
  }

  .header {
      margin:1rem;
  }

  .header .nav-bar {
      display: none; 
      position: absolute;
      top: 0%; 
      left: 0;
      width: 100%;
      background-color: white; 
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
      padding: 1rem 0;
      flex-direction: column; 
      text-align: center;
      z-index: 100;
  }

  .header .nav-bar li {
      margin: 15px 0;
  }

  .header .nav-bar.open {
      display: flex; 
  }

  .header .header-flex {
      justify-content: space-between; 
  }
  .hamburger-btn.active .bar:nth-child(1) {
      transform: translateY(8px) rotate(45deg);
  }

  .hamburger-btn.active .bar:nth-child(2) {
      opacity: 0;
  }

  .hamburger-btn.active .bar:nth-child(3) {
      transform: translateY(-8px) rotate(-45deg);
  }

  .footer .footer-flex {
      flex-direction: column;
      gap: 2rem;
  }

  .footer-nav ul{
      flex-direction: column;
      gap: 1rem;
  }

  .footer .cards-wrapper{
      flex-direction: column;
      gap: 0.52rem;
  }
  .section-heading {
    font-size: 2.2rem;
  }

  .service-card {
    padding: 30px 25px;
  }

  .service-card h3 {
    font-size: 1.4rem;
  }

  /* Move timeline line to the left */
  .timeline::before {
      align-items: center;
      height: 85%;
  }
  .faq {
      padding: 80px 20px;
    }
  
    .faq-list details {
      padding: 18px 20px;
    }
  
    .faq-list summary {
      font-size: 1rem;
    }
    .final-cta {
      padding: 90px 20px;
    }
  
    .final-cta .section-heading {
      font-size: 2rem;
    }
  
    .final-cta .section-description {
      font-size: 1rem;
    }

    .hero-section {
padding-top: 20px;
padding-bottom: 50px;
    }

    .hero-heading{
      font-size: 4.4rem;
    }
  
    .hero-section .conteiner {
      position: relative;
      bottom: 0;
      left: 0;
      padding: 0 20px;
    }
  
    .contact-heading {
      font-size: 2rem;
    }

    .header {
      padding: 1rem; /* o 0.8rem se lo vuoi più attaccato */
    }

    .process-list {
      grid-template-columns: 1fr 1fr;
      gap: 3.5rem;
    }

    .final-cta2 h2 {
      font-size: 2.2rem;
    }
  
    .final-cta2 p {
      font-size: 1.05rem;
    }

    .service-btn {
      margin: 0 auto;
    }

    .tech-stack-grid {
      grid-template-columns: repeat(3, 1fr);
    }

    .final-cta3 {
      justify-content: right;
      align-items: right;
      text-align: right;
    }
  
    .final-cta3 .container {
      align-items: right;
    }
  
    .final-cta3 p {
      text-align: right;
    }

    .intro-grid {
      grid-template-columns: 1fr;
      gap: 4rem;
    }
  
    .onepage-title
     {
      font-size: 2.6rem;
    }
  
    .onepage-subtitle {
      font-size: 1.1rem;
    }

      .benefit-item {
  flex-direction: column;
  gap: 1rem;
}

.benefit-icon {
  width: 40px;
  height: 40px;
}

.process-megablocks {
  grid-template-columns: 1fr;
}

.mega-block:hover {
  transform: scale(1.02);
}
  }
  
  @media (max-width: 700px) {
    .tech-stack-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  
  @media (max-width: 480px) {
    .tech-stack-grid {
      grid-template-columns: 1fr;
    }
  }
  




  
  @media (max-width: 700px) {
    .process-list {
      grid-template-columns: 1fr;
      gap: 4.5rem;
    }
  
    .process-list li::before {
      font-size: 5rem;
    }
  
    .process-list li {
      padding-top: 4.5rem;
    }
  /* Full width steps */
  .timeline-step {
      width: 100%;
      left: 0 !important;
      text-align: left !important;
      align-items: center;
  }
.shop-title {
  font-size: 3.4rem;
}

.shop-subtitle {
  font-size: 1.15rem;
}

/* Intro grid */
.shop-intro-grid {
  gap: 4rem;
}

/* Mega blocks */
.shop-process-megablocks {
  gap: 24px;
}
}


/* ============================================================
 RESPONSIVE — fino a 900px
============================================================ */
@media (max-width: 900px) {

/* Typography scale */
.shop-title {
  font-size: 3rem;
}

.shop-intro-center h2,
.shop-process h2,
.shop-benefits h2,
.shop-pricing h2,
.shop-faq h2 {
  font-size: 2.5rem;
}

/* Mega-block grid becomes 1 column */
.shop-process-megablocks {
  grid-template-columns: 1fr;
  max-width: 600px;
}

/* Benefit layout still ok */
.shop-benefit {
  gap: 1.5rem;
}

/* Pricing card less wide */
.shop-pricing-card {
  padding: 2.4rem;
}
}


/* ============================================================
 RESPONSIVE — fino a 768px (tablet)
============================================================ */
@media (max-width: 768px) {

/* Hero */
.shop-hero {
  padding: 7rem 0 6rem;
}

.shop-title {
  font-size: 2.7rem;
}

.shop-subtitle {
  font-size: 1.1rem;
}

/* Intro becomes single column */
.shop-intro-grid {
  grid-template-columns: 1fr;
  gap: 3rem;
  text-align: center;
}

.shop-intro-text {
  margin-left: auto;
  margin-right: auto;
}

.shop-intro-features-wrapper {
  padding: 0;
}

.shop-intro-features li {
  text-align: left; /* mantiene ordine visivo */
}

/* Benefits */
.shop-benefits {
  padding: 7rem 0;
}

.shop-benefit {
  flex-direction: column;
  text-align: center;
  padding: 2rem 0;
}

.benefit-icon {
  margin: 0 auto;
}

/* Mega blocks already 1 column */
.shop-mega-block {
  padding: 28px;
}

/* Pricing */
.shop-pricing-card {
  padding: 2.2rem;
}

.shop-pricing-amount strong {
  font-size: 2.4rem;
}

/* FAQ */
.shop-faq summary {
  font-size: 1.25rem;
}

.shop-faq p {
  font-size: 1.05rem;
}
}


/* ============================================================
 RESPONSIVE — fino a 600px (mobile large)
============================================================ */
@media (max-width: 600px) {

.shop-title {
  font-size: 2.35rem;
}

.shop-subtitle {
  font-size: 1rem;
}

/* Benefits tighter */
.shop-benefit h3 {
  font-size: 1.25rem;
}

/* Pricing */
.shop-pricing-card {
  padding: 1.8rem;
}

.shop-pricing-btn {
  padding: 1.3rem 0;
  font-size: 1.05rem;
}

/* FAQ */
.shop-faq summary {
  font-size: 1.2rem;
}

.shop-faq p {
  font-size: 1rem;
}
}


/* ============================================================
 RESPONSIVE — fino a 480px (mobile standard)
============================================================ */
@media (max-width: 480px) {

/* Global spacing */
.shop-hero,
.shop-intro,
.shop-benefits,
.shop-process,
.shop-pricing,
.shop-faq {
  padding-left: 1.4rem;
  padding-right: 1.4rem;
}

/* Hero */
.shop-title {
  font-size: 2.05rem;
  line-height: 1.15;
}

.shop-subtitle {
  font-size: .95rem;
}

/* Benefits */
.shop-benefits h2 {
  font-size: 2.1rem;
}

/* Mega blocks */
.shop-block-number {
  font-size: 26px;
}

.shop-mega-block h3 {
  font-size: 20px;
}

.shop-mega-block p {
  font-size: .95rem;
}

/* Pricing */
.shop-pricing h2 {
  font-size: 2.2rem;
}

.shop-pricing-amount strong {
  font-size: 2rem;
}

/* FAQ */
.shop-faq h2 {
  font-size: 2.2rem;
}

.shop-faq summary {
  font-size: 1.1rem;
}

/* Final CTA */
.shop-final-cta h2 {
  font-size: 2.3rem;
}
}


/* ============================================================
 RESPONSIVE — fino a 380px (mobile small)
============================================================ */
@media (max-width: 380px) {

.shop-title {
  font-size: 1.85rem;
}

.shop-intro-center h2 {
  font-size: 1.9rem;
}

.shop-benefits h2 {
  font-size: 1.9rem;
}

.shop-process h2 {
  font-size: 1.9rem;
}

.shop-pricing h2 {
  font-size: 2rem;
}

.shop-faq h2 {
  font-size: 2rem;
}

.shop-final-cta h2 {
  font-size: 2rem;
}  

}

/* ============================================================
 RESPONSIVE OPTIMIZATION (MOBILE & TABLET)
 ============================================================ */

/* ============================================================
 RESPONSIVE MEDIA QUERIES (Universal: OP, E, MP)
 ============================================================ */

/* --- TABLET / SMALL LAPTOPS (Max 1024px) --- */
@media (max-width: 1024px) {
.op-hero, .e-hero, .mp-hero {
    padding: 6rem 0 4rem; /* Riduciamo un po' il padding verticale */
}

.op-title-main, .e-title-main, .mp-title-main {
    font-size: 3.5rem; /* Font leggermente più contenuto */
}

/* Griglie che diventano un po' più strette */
.op-grid, .e-grid, .mp-grid {
    gap: 20px;
}
}

/* --- TABLET PORTRAIT (Max 900px) --- */
@media (max-width: 900px) {
/* PRICING SHEET: Da laterale a verticale */
.op-pricing-sheet, .e-pricing-sheet, .mp-pricing-sheet {
    grid-template-columns: 1fr; /* Una sola colonna */
    max-width: 500px; /* Limitiamo la larghezza */
    margin: 0 auto;
}

.op-sheet-main, .e-sheet-main, .mp-sheet-main {
    border-right: none;
    border-bottom: 1px solid #e5e5e5; /* Linea separatrice orizzontale */
    text-align: center; 
    padding: 2.5rem 2rem;
}

.op-sheet-details, .e-sheet-details, .mp-sheet-details {
    padding: 0;
}

/* ALTERNATIVES: Una sotto l'altra */
.op-alt-grid, .e-alt-grid, .mp-alt-grid {
    grid-template-columns: 1fr;
}
}

/* --- MOBILE (Max 768px) --- */
@media (max-width: 768px) {

/* 1. RIDUZIONE PADDING GLOBALE & HERO LAYOUT */
.op-hero, .e-hero, .mp-hero {
  text-align: left;
  position: relative; 
  display: flex;
  align-items: center;   /* Spinge tutto in basso */
  justify-content: flex-start; /* Sinistra */
  padding: 0; 
  height: 78vh;
  padding-bottom: 1rem;
}

.e-hero, .mp-hero {
  text-align: center;
  position: relative; 
  display: flex;
  align-items: center;   /* Spinge tutto in basso */
  padding: 0; 
  height: 78vh;
  padding-bottom: 1rem;
}

.mp-hero {
  text-align: right;
  position: relative; 
  display: flex;
  align-items: center;   /* Spinge tutto in basso */
  padding: 0; 
  height: 78vh;
  padding-bottom: 1rem;
}


/* Risparmiamo spazio prezioso su schermi piccoli per tutte le sezioni */
.op-benefits, .op-portfolio, .op-workflow, .op-pricing, .op-faq, .op-alternatives, .op-cta,
.e-benefits, .e-portfolio, .e-workflow, .e-pricing, .e-faq, .e-alternatives, .e-cta,
.mp-benefits, .mp-portfolio, .mp-workflow, .mp-pricing, .mp-faq, .mp-alternatives, .mp-cta {
    padding: 50px 20px; 
}

/* 2. HERO ADJUSTMENTS */
.op-title-main, .e-title-main, .mp-title-main {
    font-size: 2.5rem; 
    letter-spacing: -1px;
}

.op-eyebrow, .e-eyebrow, .mp-eyebrow {
    margin-bottom: 1rem;
    font-size: 0.75rem;
}

.op-section-title, .e-section-title, .mp-section-title {
    font-size: 2rem;
    margin-bottom: 15px;
}

.op-section-desc, .e-section-desc, .mp-section-desc {
    font-size: 1rem;
    margin-bottom: 20px;
}

/* 3. TIMELINE (WORKFLOW) - CAMBIAMENTO CRITICO */
/* La linea si sposta tutta a sinistra e i box si impilano */
.op-timeline::before, .e-timeline::before, .mp-timeline::before {
    left: 0px; 
}

.op-timeline-step, .e-timeline-step, .mp-timeline-step {
    width: 100%; 
    padding: 0 0 30px 30px; /* Spazio a sinistra per la linea */
    margin-bottom: 10px;
}

/* Override forzato per entrambi i lati (pari e dispari) su tutti i layout */
.op-timeline-step:nth-child(odd), .op-timeline-step:nth-child(even),
.e-timeline-step:nth-child(odd), .e-timeline-step:nth-child(even),
.mp-timeline-step:nth-child(odd), .mp-timeline-step:nth-child(even) {
    left: 0 !important; /* Importante per sovrascrivere regole precedenti */
    text-align: left !important;
}

/* Rimuoviamo l'hover effect traslante su mobile */
.op-card:hover, .op-timeline-content:hover, .op-pricing-sheet:hover, .op-alt-card:hover,
.e-card:hover, .e-timeline-content:hover, .e-pricing-sheet:hover, .e-alt-card:hover,
.mp-card:hover, .mp-timeline-content:hover, .mp-pricing-sheet:hover, .mp-alt-card:hover {
    transform: none !important; 
}

/* 4. PORTFOLIO & IMMAGINI */
.op-project-img, .e-project-img, .mp-project-img {
    height: 250px; 
}

/* 5. PRICING FONT SIZE */
.op-sheet-price, .e-sheet-price, .mp-sheet-price {
    font-size: 3rem;
}

/* 6. FAQ & DETAILS */
.op-faq-list details, .e-faq-list details, .mp-faq-list details {
    padding: 15px 20px;
}
.op-faq-list summary, .e-faq-list summary, .mp-faq-list summary {
    font-size: 1rem;
    padding-right: 35px; 
}
}


@keyframes scroll-tech {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  } 
}

/* ============================================================
 GLOBAL INTERACTIVE SYSTEM (REPAIR KIT)
 Gestisce: Animazioni e Hovers per OP, E, MP
 ============================================================ */

/* 1. DEFINIZIONE DELLE TRANSIZIONI (La fluidità) */
.op-card, .e-card, .mp-card,
.op-alt-card, .e-alt-card, .mp-alt-card,
.op-timeline-content, .e-timeline-content, .mp-timeline-content,
.op-pricing-sheet, .e-pricing-sheet, .mp-pricing-sheet,
.op-project-img, .e-project-img, .mp-project-img,
.cta-btn, .op-btn-full, .e-btn-full, .mp-btn-full,
.op-faq-list details, .e-faq-list details, .mp-faq-list details {
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
  backface-visibility: hidden;
}

/* 2. ATTIVAZIONE EFFETTI HOVER (Desktop) */

/* Zoom sulle Card Servizi e Pricing */
.op-card:hover, .e-card:hover, .mp-card:hover,
.op-alt-card:hover, .e-alt-card:hover, .mp-alt-card:hover,
.op-timeline-content:hover, .e-timeline-content:hover, .mp-timeline-content:hover,
.op-pricing-sheet:hover, .e-pricing-sheet:hover, .mp-pricing-sheet:hover {
  transform: scale(1.02);
  border-color: #000 !important;
  background-color: #fff;
  z-index: 10;
}

/* Effetto Bordo Scuro sulle Immagini Portfolio */
.op-project-card:hover .op-project-img,
.e-project-card:hover .e-project-img,
.mp-project-card:hover .mp-project-img {
  border-color: #000;
  transform: translateY(-2px);
}

/* Effetto Zoom Piccolo su FAQ */
.op-faq-list details:hover, .e-faq-list details:hover, .mp-faq-list details:hover {
  transform: scale(1.02);
  border-color: #000;
}

/* Effetto Bottoni (Saltello) */
.cta-btn:hover, 
.op-btn-full:hover, .e-btn-full:hover, .mp-btn-full:hover {
  transform: translateY(-2px) scale(1.05);
}

/* ============================================================
 GLOBAL INTERACTIVE SYSTEM (FINAL: OP, E, MP, AB)
 ============================================================ */

/* 1. DEFINIZIONE TRANSIZIONI */
.op-card, .e-card, .mp-card, .ab-card,
.op-alt-card, .e-alt-card, .mp-alt-card,
.op-timeline-content, .e-timeline-content, .mp-timeline-content,
.op-pricing-sheet, .e-pricing-sheet, .mp-pricing-sheet,
.op-project-img, .e-project-img, .mp-project-img,
.cta-btn, .op-btn-full, .e-btn-full, .mp-btn-full, .ab-btn,
.op-faq-list details, .e-faq-list details, .mp-faq-list details {
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
  backface-visibility: hidden;
}

/* 2. HOVER EFFECTS (Desktop) */
.op-card:hover, .e-card:hover, .mp-card:hover, .ab-card:hover,
.op-alt-card:hover, .e-alt-card:hover, .mp-alt-card:hover,
.op-timeline-content:hover, .e-timeline-content:hover, .mp-timeline-content:hover,
.op-pricing-sheet:hover, .e-pricing-sheet:hover, .mp-pricing-sheet:hover {
  transform: scale(1.03);
  border-color: #000 !important;
  background-color: #fff;
  z-index: 10;
}

.op-project-card:hover .op-project-img,
.e-project-card:hover .e-project-img,
.mp-project-card:hover .mp-project-img {
  border-color: #000;
  transform: translateY(-5px);
}

.op-faq-list details:hover, .e-faq-list details:hover, .mp-faq-list details:hover {
  transform: scale(1.015);
  border-color: #000;
}

.cta-btn:hover, .ab-btn:hover,
.op-btn-full:hover, .e-btn-full:hover, .mp-btn-full:hover {
  transform: translateY(-2px) scale(1.05);
  background: #000;
  color: #fff;
}

/* 3. MOBILE RESET */
@media (max-width: 900px) {
  .op-card:hover, .e-card:hover, .mp-card:hover, .ab-card:hover,
  .op-alt-card:hover, .e-alt-card:hover, .mp-alt-card:hover,
  .op-timeline-content:hover, .e-timeline-content:hover, .mp-timeline-content:hover,
  .op-pricing-sheet:hover, .e-pricing-sheet:hover, .mp-pricing-sheet:hover,
  .op-faq-list details:hover, .e-faq-list details:hover, .mp-faq-list details:hover,
  .op-project-card:hover .op-project-img,
  .e-project-card:hover .e-project-img,
  .mp-project-card:hover .mp-project-img {
      transform: none !important;
      box-shadow: none !important;
      z-index: 1;
      border-color: #e5e5e5;
  }
  .cta-btn:hover, .ab-btn:hover, .op-btn-full:hover, .e-btn-full:hover, .mp-btn-full:hover {
      transform: none !important;
      box-shadow: none !important;
  }
}