
:root{--forest:#2d6b48;--forest-hero:#dff0db;--green-mid:#3d8a62;--green-light:#6dbf85;--green-dark1:#a8cca5;--green-dark2:#8eba8b;--green-pale:#98be95;--cream:#d4e8d0;--card:#ffffff;--white:#f5f0e8;--text:#2a3d28;--text-muted:#4a6858;--sidebar-w:260px;--topbar-h:42px;--footer-h:auto;--T:.35s cubic-bezier(.4,0,.2,1)}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:clip;}
body{font-family:'DM Sans',sans-serif;background:#f5f0e8;color:var(--text);min-height:100vh;}
.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--cream);position:fixed;left:0;top:var(--topbar-h);display:flex;flex-direction:column;z-index:100;transition:transform var(--T);overflow:hidden}
.sidebar-logo{padding:32px 22px 22px;border-bottom:1px solid rgba(109,191,133,.15);display:flex;align-items:center;gap:12px}
.sidebar-logo img{width:54px;height:54px;object-fit:contain}
.logo-name{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:#0f2d1e;letter-spacing:.04em;line-height:1}
.logo-sub{font-size:9px;color:#2a3d28;letter-spacing:.1em;text-transform:uppercase;opacity:1;margin-top:4px;line-height:1.4;font-weight:500}
nav{flex:1;padding:18px 0}
nav a{display:flex;align-items:center;padding:12px 22px;color:#2a3d28;text-decoration:none;font-size:15px;font-weight:400;letter-spacing:.02em;transition:all var(--T);position:relative;cursor:pointer}
nav a:hover,nav a.active{color:var(--green-mid);background:rgba(13,112,64,.08);font-weight:500}
nav a.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--green-mid);border-radius:0 3px 3px 0;box-shadow:0 0 6px rgba(13,112,64,0.3)}
.sidebar-footer{padding:14px 22px;border-top:1px solid rgba(45,107,72,.12);font-size:10.5px;color:#4a6858;line-height:1.7}
.sidebar-footer a{color:#2d6b48;text-decoration:none}
.main{margin-left:var(--sidebar-w);min-height:100vh;margin-top:var(--topbar-h);background:#f5f0e8;}
section{display:none;animation:fadeIn .4s ease;}
section.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
#inici{position:relative;background:#f5f0e8}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(223,240,219,.82) 0%,rgba(223,240,219,.58) 38%,rgba(223,240,219,.18) 65%,rgba(223,240,219,0) 100%)}
.hero-content{position:relative;z-index:2;padding:80px 64px 60px;max-width:740px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.hero-tag{display:inline-flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--green-mid);border:1px solid rgba(13,112,64,.25);padding:6px 14px;margin-bottom:28px}
.hero-tag img{width:18px;height:18px;object-fit:contain}
.hero-title{font-family:'League Spartan',sans-serif;font-size:clamp(54px,7.5vw,98px);font-weight:500;color:var(--text);line-height:1;margin-bottom:10px;letter-spacing:-0.01em;-webkit-font-smoothing:antialiased}
.hero-sub{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,2vw,26px);font-weight:400;font-style:italic;color:var(--forest);margin-bottom:28px;letter-spacing:.04em}
.hero-title em{font-style:italic;color:var(--green-mid)}
.hero-desc{font-family:'Cormorant Garamond',serif;font-size:18px;line-height:1.9;color:#2a3d28;max-width:520px;margin-bottom:40px;font-weight:400;font-style:italic}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{background:#2d6b48;color:#fff;padding:14px 32px;border:none;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-block;transition:all .3s;border-radius:40px;box-shadow:0 6px 24px rgba(13,112,64,0.25)}
.btn-primary:hover{background:rgba(30,90,56,0.55);backdrop-filter:blur(6px);transform:translateY(-2px);box-shadow:0 6px 20px rgba(45,107,72,0.18)}
.btn-outline{background:rgba(152,190,149,0.88);color:var(--forest);padding:14px 32px;border:1.5px solid rgba(45,107,72,0.4);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-block;transition:all .3s;border-radius:40px}
.btn-outline:hover{background:rgba(45,107,72,0.08);backdrop-filter:blur(6px);border-color:rgba(45,107,72,0.35);color:#2d6b48;transform:translateY(-2px);box-shadow:0 6px 18px rgba(45,107,72,0.08)}
.hero-stats{position:relative;z-index:1;display:flex;border-top:1px solid rgba(255,255,255,.1);background:rgba(194,221,191,.92);margin-bottom:0;border-bottom:3px solid var(--green-mid);}
.stat{flex:1;padding:26px 44px;border-right:1px solid rgba(45,107,72,.15);cursor:default;transition:all .3s;position:relative;}
.stat:last-child{border-right:none}
.stat::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:var(--green-mid);transition:width .35s ease;}
.stat:hover::after{width:100%;}
.stat:hover{background:rgba(45,107,72,.08);}
.stat:hover .stat-num{color:var(--forest);}
.stat:hover .stat-label{color:var(--forest);}
.stat-num{font-family:'League Spartan',sans-serif;font-size:40px;font-weight:400;color:#2d6b48;line-height:1;margin-bottom:5px;transition:color .25s;letter-spacing:-0.01em;}
.stat-label{font-size:11px;color:#4a6858;letter-spacing:.08em;text-transform:uppercase;transition:color .25s;}
.page-header{background:var(--forest-hero);padding:52px 64px 40px;position:relative;overflow:hidden}
.page-header-bg{position:absolute;right:0;top:0;bottom:0;width:45%;background-size:cover;background-position:center;opacity:.55}
.page-header::after{content:'';position:absolute;right:0;top:0;bottom:0;width:45%;background:linear-gradient(to right,var(--forest-hero) 0%,transparent 40%)}
.page-header-tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#0d7040;font-weight:600;margin-bottom:12px;display:block;position:relative;z-index:1}
.page-header h1{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,48px);font-weight:400;color:#0f2d1e;line-height:1.1;position:relative;z-index:1}
.page-header h1 em{font-style:italic;color:#2d6b48}
.page-header p{margin-top:12px;font-size:14px;color:var(--text-muted);max-width:640px;line-height:1.7;position:relative;z-index:1}
.content{padding:52px 56px;background:#f5f0e8}
.content-alt{padding:52px 64px;background:#f5f0e8}
.section-title{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:400;color:#0f2d1e;line-height:1.2;margin-bottom:6px}
.section-title em{font-style:italic;color:#2d6b48;font-weight:400}
.section-lead{font-size:14px;color:var(--text-muted);line-height:1.7;max-width:720px}
.divider{width:48px;height:2px;background:var(--green-mid);margin:16px 0 32px}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:32px}
.mv-block{background:var(--card);padding:36px 32px;position:relative;overflow:hidden}
.mv-block::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--green-mid),var(--green-light))}
.mv-label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--green-mid);margin-bottom:10px;display:block}
.mv-block h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:#0f2d1e;margin-bottom:10px;line-height:1.2}
.mv-block p{font-size:13.5px;line-height:1.8;color:var(--text-muted)}
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.photo-strip-item{height:200px;background-size:cover;background-position:center;position:relative;overflow:hidden}
.photo-strip-item::after{content:'';position:absolute;inset:0;background:rgba(18,32,41,.06);transition:background .3s}
.photo-strip-item:hover::after{background:rgba(18,32,41,.0)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;margin-top:32px}
.team-card{background:#f0f9ed;border:1px solid rgba(45,107,72,.1);overflow:hidden;transition:all .3s}
.team-card:hover{border-color:var(--green-mid);box-shadow:0 8px 28px rgba(18,32,41,.08)}
.team-avatar{height:155px;display:flex;align-items:center;justify-content:center}
.team-initials{font-family:'Cormorant Garamond',serif;font-size:46px;font-weight:300;color:#2a3d28}
.team-info{padding:22px 22px 26px}
.team-info h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:var(--forest);margin-bottom:3px}
.team-role{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--green-mid);margin-bottom:10px}
.team-bio{font-size:13px;line-height:1.7;color:var(--text-muted)}
.servei-block{display:grid;grid-template-columns:220px 1fr;border:1px solid rgba(45,107,72,.12);margin-bottom:14px;background:#f0f9ed;transition:all .3s;overflow:hidden}
.servei-block:hover{border-color:var(--green-mid);box-shadow:0 4px 20px rgba(18,32,41,.06)}
.servei-photo{background-size:cover;background-position:center;position:relative;min-height:190px}
.servei-photo-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(18,32,41,.65),rgba(45,107,72,.45));display:flex;flex-direction:column;justify-content:flex-end;padding:22px 18px}
.servei-cat-name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:300;color:#fff;line-height:1.1}
.servei-cat-tag{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-top:3px}
.servei-items{padding:28px 32px}
.servei-items h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:var(--forest);margin-bottom:14px}
.servei-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:7px}
.servei-list li{font-size:12.5px;color:var(--text-muted);padding-left:13px;position:relative;line-height:1.5}
.servei-list li::before{content:'→';position:absolute;left:0;color:var(--green-mid);font-size:11px}
.diagnostic-hero{position:relative;overflow:hidden;min-height:280px;display:flex;align-items:center}
.diagnostic-hero-img{position:absolute;inset:0;background-size:cover;background-position:center}
.diagnostic-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,232,208,.8) 0%,rgba(212,232,208,.5) 60%,rgba(212,232,208,.1) 100%)}
.diagnostic-hero-content{position:relative;z-index:2;padding:48px 64px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;width:100%}
.diagnostic-hero h2{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:400;color:#0f2d1e;line-height:1.15}
.diagnostic-hero h2 em{font-style:italic;color:var(--green-mid)}
.form-container{padding:48px 64px;background:#f5f0e8}
.form-wrapper{max-width:620px;background:#ffffff;border:1px solid rgba(45,107,72,.1);padding:40px}
.form-wrapper h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:#0f2d1e;margin-bottom:6px}
.form-sub{font-size:13px;color:var(--text-muted);margin-bottom:28px}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);margin-bottom:7px;font-weight:500}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 13px;border:1px solid rgba(45,107,72,.18);background:var(--white);font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--text);outline:none;transition:border-color .2s;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--green-mid);background:#f5f0e8}
.form-group textarea{resize:vertical;min-height:85px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-note{margin-top:12px;font-size:12px;color:var(--text-muted);line-height:1.6;padding:10px 13px;border-left:2px solid var(--green-light);background:#f0f9ed}
.gform-placeholder{background:#e8f5e4;border:2px dashed var(--green-mid);padding:32px;text-align:center;color:var(--forest)}
.values-strip{display:flex;background:#d4e8d0;padding:24px 20px;gap:16px}
.value-item{flex:1;background:#f5f0e8;border-radius:10px;padding:28px 20px;text-align:center;border:1px solid rgba(45,107,72,0.08);box-shadow:0 4px 18px rgba(45,107,72,0.12);transition:all .3s;cursor:default}
.value-item:hover{background:#fff;box-shadow:0 16px 40px rgba(45,107,72,0.22);transform:translateY(-5px)}
.value-icon{display:none}
.value-item h4{font-family:'Cormorant Garamond',serif;font-size:19px;color:#0f2d1e;margin-bottom:6px;font-weight:500}
.value-item p{font-size:11.5px;color:#4a6858;line-height:1.6}
.oferta{background:#ffffff;border:1px solid rgba(45,107,72,.1);padding:26px 30px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:18px;transition:all .3s}
.oferta:hover{border-color:var(--green-mid);transform:translateX(4px)}
.oferta-info h3{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;color:var(--forest);margin-bottom:4px}
.oferta-meta{display:flex;gap:12px;font-size:11px;color:var(--text-muted)}
.oferta-badge{font-size:10.5px;padding:5px 11px;background:#f0f9ed;color:var(--forest);border-radius:2px;white-space:nowrap}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;min-height:calc(100vh - 156px)}
.contact-info{background:#f5f0e8;padding:48px 40px;position:relative;overflow:hidden}
.contact-info-bg{position:absolute;inset:0;background-size:70%;background-position:center center;background-repeat:no-repeat;opacity:0.1;transform:scale(1.0)}
.contact-info h2{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:600;color:#0f2d1e;margin-bottom:5px;position:relative;z-index:1}
.contact-info h2 em{font-style:italic;color:#2d6b48}
.contact-info>p{font-size:13px;color:#4a6858;line-height:1.7;margin-bottom:36px;position:relative;z-index:1}
.contact-item{margin-bottom:24px;position:relative;z-index:1}
.contact-item-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#2d6b48;margin-bottom:4px;opacity:1}
.contact-item-val{font-size:14px;color:#2a3d28;font-weight:300}
.contact-item-val a{color:#2d6b48;text-decoration:none;border-bottom:1px solid rgba(45,107,72,.25);transition:border-color .2s}
.contact-item-val a:hover{border-color:#0d7040}
.contact-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px;position:relative;z-index:1}
.contact-logo img{width:34px;height:34px;object-fit:contain;opacity:.8;filter:none}
.contact-logo span{font-family:'Cormorant Garamond',serif;font-size:15px;color:#4a6858;letter-spacing:.04em}
.contact-form{background:#f5f0e8;padding:48px 40px}
.contact-form h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:#0f2d1e;margin-bottom:24px}
.mobile-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;background:var(--cream);border:1px solid rgba(45,107,72,.15);color:#2a3d28;width:40px;height:40px;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.mobile-toggle span{display:block;width:20px;height:2px;background:#2a3d28}
.overlay{display:none;position:fixed;inset:0;background:rgba(14,30,22,.6);z-index:99}

/* ═══════════════════════════════════════════
   PORTÀTIL / TABLET — max-width: 1100px
   ═══════════════════════════════════════════ */
@media(max-width:1100px){
  /* Sidebar més estret */
  :root{--sidebar-w:220px}
  
  /* Padding de contingut reduït */
  .content,.content-alt,.form-container{padding-left:32px;padding-right:32px}
  .page-header{padding:40px 32px 32px}
  
  /* Hero title més petit */
  
.hero-title{font-size:clamp(42px,6vw,72px) !important}
  .hero-content{padding:60px 40px 48px !important}
  
  /* Grids de 4 col → 2 col */
  .footer-top{grid-template-columns:1fr 1fr !important}
  
  /* Stats hero wrap */
  .hero-stats .stat{padding:14px 18px}
}

/* ═══════════════════════════════════════════
   TABLET — max-width: 900px
   ═══════════════════════════════════════════ */
@media(max-width:900px){
  :root{--sidebar-w:200px}
  
  /* Grids 3 col → 2 col */
  div[style*="grid-template-columns:repeat(3,1fr)"]:not(.bloc-emocional div){
    grid-template-columns:1fr 1fr !important;
  }
  
  /* Grids 4 col → 2 col */
  div[style*="grid-template-columns:repeat(4,1fr)"]{
    grid-template-columns:1fr 1fr !important;
  }
  
  /* Contact grid → 1 col */
  .contact-grid{grid-template-columns:1fr !important}
  
  /* Gestalt grid → apilat */
    
  /* Area cards → apilades */
  .area-card{grid-template-columns:1fr !important}
  .area-card-img{min-height:220px !important}
  
  /* Servei blocks → apilats */
  .servei-block{grid-template-columns:1fr !important}
  
  /* Padding reduït */
  .content,.content-alt{padding-left:24px;padding-right:24px}
  .page-header{padding:32px 24px 28px !important}
  
    .hero-content{padding:48px 32px 40px !important}
  
.hero-title{font-size:clamp(38px,5.5vw,62px) !important}
  
  /* Diagnostic hero */
  .diagnostic-hero-content{grid-template-columns:1fr !important}
  
  /* Footer */
  .footer-top{grid-template-columns:1fr 1fr !important}
  
  /* mv-grid → 1 col */
  .mv-grid{grid-template-columns:1fr !important}
  
  /* srv-cols */
  .srv-cols{grid-template-columns:1fr 1fr !important}
}

@media(max-width:768px){
.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
.main{margin-left:0;margin-top:var(--topbar-h)}.mobile-toggle{display:flex}.overlay.show{display:block}
.hero-content,.page-header,.content,.content-alt,.form-container{padding-left:18px;padding-right:18px}
.content[style*="padding:40px 48px"],.content[style*="padding: 40px 48px"]{padding-left:18px !important;padding-right:18px !important;padding-top:28px !important;}
.hero-stats .stat{padding:18px 14px}
.mv-grid,.form-row,.servei-block,.contact-grid,.diagnostic-hero-content{grid-template-columns:1fr}
.values-strip{flex-direction:column}.servei-photo{min-height:130px}
.photo-strip{grid-template-columns:1fr 1fr}

.hero-content{padding:40px 18px 32px !important;}
.hero-cta{flex-direction:column;gap:10px;}
.hero-stats{flex-wrap:wrap;}
.stat{flex:1 1 45%;border-right:none !important;border-bottom:1px solid rgba(255,255,255,.07);}

/* Page headers */
.page-header{padding:36px 18px 28px !important;}
.page-header-bg{display:none;}
.page-header::after{display:none;}

/* Grids inline de 3-4 columnes → 1 columna */
div[style*="grid-template-columns:repeat(3"],
div[style*="grid-template-columns:repeat(4"],
div[style*="grid-template-columns: repeat(3"],
div[style*="grid-template-columns: repeat(4"]{
  grid-template-columns:1fr !important;
}

/* Grids inline de 2 columnes → 1 columna (excepte els que ja funcionen) */
div[style*="grid-template-columns:1fr 1fr"],
div[style*="grid-template-columns: 1fr 1fr"],
div[style*="grid-template-columns:1fr 380px"],
div[style*="grid-template-columns:1fr 1.5fr"],
div[style*="grid-template-columns:220px 1fr"],
div[style*="grid-template-columns:280px 1fr"],
div[style*="grid-template-columns:1fr 380px"]{
  grid-template-columns:1fr !important;
}

/* Galeries de fotos → 1 columna */
div[style*="grid-template-columns:1.2fr 1fr 0.9fr"],
div[style*="grid-template-columns:1.6fr 1fr 1fr 1fr"]{
  grid-template-columns:1fr !important;
  height:auto !important;
}

/* Padding excessiu en blocs inline */
div[style*="padding:36px 40px"],
div[style*="padding:48px 64px"],
div[style*="padding:40px 44px"],
div[style*="padding:28px 44px"]{
  padding-left:18px !important;
  padding-right:18px !important;
}

/* Alçades fixes d'imatges → reduir */
div[style*="height:280px"],
div[style*="height:260px"],
div[style*="height:320px"]{
  height:180px !important;
}

/* CTAs en fila → columna */
div[style*="display:flex"][style*="justify-content:space-between"]{
  flex-direction:column;
  gap:16px;
}

/* Mida de text gran en mòbil */
div[style*="font-size:52px"],
div[style*="font-size:80px"]{
  font-size:38px !important;
}
div[style*="font-size:38px"]{font-size:26px !important;}
div[style*="font-size:32px"]{font-size:22px !important;}

/* ── INICI: desactivar sticky stack al mòbil ── */
.stack-item{position:static !important;top:auto !important;z-index:auto !important;border-radius:0 !important;}

#inici div[style*="height:600px;overflow:hidden"]{height:auto !important;min-height:380px !important;overflow:hidden !important;}
.hero-content{padding:32px 18px 28px !important;}
.hero-title{font-size:48px !important;}

.hero-desc{font-size:13px !important;margin-bottom:24px !important;}
.hero-cta{flex-direction:column !important;gap:10px !important;}
.btn-primary,.btn-outline{text-align:center !important;}
.hero-stats{position:relative !important;z-index:5 !important;}

/* Bloc serveis: eliminar padding gegant */
#inici div[style*="padding:36px 64px 600px"]{padding:28px 18px 48px !important;}
#inici div[style*="padding-bottom:120px"]{padding-bottom:40px !important;}
#inici div[style*="padding:32px 32px 48px"]{padding:22px 18px 36px !important;}

/* Bloc emocional */
.bloc-emocional{overflow:visible !important;}
.bloc-emocional-text{padding:28px 18px 36px !important;}
#inici div[style*="padding:64px 64px 100px"]{padding:28px 18px 36px !important;}
#inici div[style*="min-height:420px"]{min-height:auto !important;}
.bloc-emocional div[style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:1fr 1fr !important;}

/* Gestalt: tot visible i apilat */

/* Cards inici: grids → 1 col */
#inici div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important;}
#inici div[style*="grid-template-columns:1fr 400px"]{grid-template-columns:1fr !important;}
#inici div[style*="grid-template-columns:repeat(5,1fr)"]{grid-template-columns:1fr 1fr !important;}
#inici div[style*="height:260px"]{height:200px !important;}

/* Stats */
.stat-num{font-size:26px !important;}
.stat-label{font-size:12px !important;}

/* Subnav lateral */
#subnav-serveis a{padding-left:28px !important;color:#1e3028 !important;}

/* srv-block i srv-cols */
.srv-block{margin-bottom:32px !important;padding-bottom:32px !important;}
.srv-cols{grid-template-columns:1fr !important;}
.srv-col-box{padding:16px !important;}
.srv-block-title{font-size:22px !important;}
.srv-block-desc{max-width:100% !important;}

/* NexAcompanya / NexGestio: content padding */
#nexacompanya .content,#nexgestio .content{padding:24px 18px 40px !important;}


/* Footer */
.footer-top{grid-template-columns:1fr !important;}




.hero-sub{font-size:clamp(16px,4vw,20px) !important;}
}


.tsec-head{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:#fff;background:#2d6b48;padding:7px 12px;margin:18px 0 12px;font-weight:600}
.tfield{margin-bottom:12px}
.tlabel{display:block;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:#2d6b48;margin-bottom:5px;font-weight:500}
.tinput{width:100%;padding:10px 13px;border:1px solid rgba(45,107,72,0.2);background:#f5f0e8;font-family:'DM Sans',sans-serif;font-size:14px;color:#0f2d1e;outline:none;box-sizing:border-box}
.tarea{width:100%;padding:10px 13px;border:1px solid rgba(45,107,72,0.2);background:#f5f0e8;font-family:'DM Sans',sans-serif;font-size:13px;color:#0f2d1e;outline:none;resize:vertical;box-sizing:border-box;min-height:70px}
.tinput:focus,.tarea:focus{border-color:#0d7040}

/* === TOPBAR === */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--cream);z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 18px 0 calc(var(--sidebar-w) + 18px);border-bottom:1px solid rgba(45,107,72,.15)}
.topbar-left{display:flex;align-items:center;gap:20px}
.topbar-logo-wrap{display:flex;align-items:center;gap:8px}
.topbar-logo-wrap img{height:24px;width:auto;object-fit:contain}
.topbar-brand{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:400;color:#2a3d28;letter-spacing:0.04em}
.topbar-tagline{font-size:11px;color:#4a6858;letter-spacing:0.05em;display:block}
.topbar-right{display:flex;align-items:center;gap:8px}
.topbar-btn{display:flex;align-items:center;gap:5px;padding:5px 11px;border:1px solid rgba(45,107,72,.25);color:#2d6b48;font-size:11px;text-decoration:none;letter-spacing:0.05em;transition:all .2s;cursor:pointer;background:transparent;white-space:nowrap}
.topbar-btn:hover,.topbar-btn:focus{background:rgba(45,107,72,0.08);backdrop-filter:blur(6px);border-color:rgba(45,107,72,0.3);color:#2d6b48;transform:translateY(-1px)}
.topbar-btn.urgent{border-color:rgba(239,68,68,.4);color:rgba(239,68,68,.8)}
.topbar-btn.urgent:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.7);color:#ef4444}
.topbar-btn svg{width:12px;height:12px;flex-shrink:0}
.lang-select{appearance:none;background:transparent;border:1px solid rgba(45,107,72,.25);color:#2d6b48;font-size:11px;font-family:'DM Sans',sans-serif;letter-spacing:0.05em;padding:5px 24px 5px 10px;cursor:pointer;transition:all .2s;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(45,107,72,0.6)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;}
.lang-select:hover{border-color:rgba(45,107,72,.5);color:var(--green-mid)}
.lang-select option{background:#f5f0e8;color:#2a3d28;}

@media(max-width:1100px){.topbar-tagline{display:none}.topbar{padding-left:calc(var(--sidebar-w) + 14px)}}
@media(max-width:768px){.topbar{padding-left:58px}.topbar-tagline,.topbar-brand{display:block}.topbar-btn span{display:none}.topbar-btn{padding:5px 7px}}

/* === FOOTER === */
.site-footer{background:#d4e8d0;color:#4a6858;padding:28px 24px 20px;}
.footer-inner{max-width:820px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.3fr 1fr 1fr 0.8fr 0.9fr;gap:20px;padding-bottom:20px;border-bottom:1px solid rgba(109,191,133,.08)}
.footer-col-title{font-size:9.5px;letter-spacing:0.15em;text-transform:uppercase;color:#2d6b48;margin-bottom:14px;font-weight:600}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.footer-brand img{height:32px;width:auto;object-fit:contain;opacity:.85}
.footer-brand-name{font-family:'Cormorant Garamond',serif;font-size:18px;color:#2a3d28;letter-spacing:0.04em}
.footer-desc{font-size:12px;line-height:1.8;color:#4a6858;max-width:220px}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:12px;color:#2a3d28;text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--forest);font-weight:500}
.footer-social{display:flex;flex-direction:column;gap:8px}
.footer-social a{display:flex;align-items:center;gap:7px;font-size:12px;color:#4a6858;text-decoration:none;transition:color .2s}
.footer-social a:hover{color:var(--forest);font-weight:500}
.footer-social svg{width:14px;height:14px;flex-shrink:0}
.footer-denuncia{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(239,68,68,.3);color:rgba(239,68,68,.7);font-size:11px;text-decoration:none;letter-spacing:0.06em;transition:all .2s;margin-top:4px}
.footer-denuncia:hover{background:rgba(239,68,68,.08);border-color:rgba(239,68,68,.6);color:#ef4444}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:20px;font-size:11px;color:#2a3d28;flex-wrap:wrap;gap:8px}
.footer-bottom a{color:#2a3d28;text-decoration:none}
.footer-bottom a:hover{color:var(--forest)}
@media(max-width:768px){.site-footer{padding:24px 18px 16px}.footer-top{grid-template-columns:1fr 1fr}.footer-col--brand{grid-column:1/-1}}

.site-footer{display:block !important;}

.servei-block:nth-child(even){background:#e8f5e4 !important;}

.footer-links a, .footer-social a, .footer-bottom a {
  transition: color .2s, font-weight .1s;
}
.team-card, .servei-block, .mv-block {
  transition: transform .25s, box-shadow .25s;
}
.team-card:hover, .servei-block:hover {
  transform: translateY(-3px);
}
nav a {
  transition: all .2s;
}


/* === ALTERNANÇA GLOBAL CARDS === */
/* srv-col-box */
.srv-col-box:nth-child(odd) { background: #f0f9ed !important; }
.srv-col-box:nth-child(even) { background: #e8f5e4 !important; }

/* area-card alternada */
.area-card:nth-child(odd) .area-card-body { background: #f0f9ed !important; }
.area-card:nth-child(even) .area-card-body { background: #e8f5e4 !important; }

/* oferta alternada */
.oferta:nth-child(odd) { background: #f0f9ed !important; }
.oferta:nth-child(even) { background: #e8f5e4 !important; }

/* team-card alternada */
.team-card:nth-child(odd) { background: #f0f9ed !important; }
.team-card:nth-child(even) { background: #e8f5e4 !important; }

/* mv-block alternada */
.mv-block:nth-child(odd) { background: #f0f9ed !important; }
.mv-block:nth-child(even) { background: #e8f5e4 !important; }

/* dopt (diagnòstic) alternada */
.dopt:nth-child(odd) { background: #f0f9ed !important; }
.dopt:nth-child(even) { background: #e8f5e4 !important; }
.dopt:hover, .dopt.selected { background: #98be95 !important; }

/* srv-detail-nav-item alternada */
.srv-detail-nav-item:nth-child(odd) { background: transparent; }
.srv-detail-nav-item:nth-child(even) { background: rgba(13,112,64,.04); }


#subnav-entitats a, #subnav-serveis a { color:#1e3028 !important; font-size:14px; opacity:1 !important; border-left-color:#3d8a62 !important; }

.mv-card:nth-child(odd) { background: #f0f9ed !important; }
.mv-card:nth-child(even) { background: #e8f5e4 !important; }
.cas-card:nth-child(odd) { background: #f0f9ed !important; }
.cas-card:nth-child(even) { background: #e8f5e4 !important; }


img{max-width:100%;height:auto;}

/* Em cursiva sobre fons verd → color fosc per contrast */
[style*="background:#98be95"] em,
[style*="background:var(--forest-hero)"] em,
[style*="background:#dff0db"] em,
[style*="background:#d4e8d0"] em {
  color: #2d6b48 !important;
}
.page-header em { color: #2d6b48 !important; }
.hero-title em { color: #2d6b48 !important; }


/* Green-light sobre fons clar → fosc */
[style*="background:#98be95"] [style*="color:var(--green-light)"],
.srv-col-box [style*="color:var(--green-light)"] {
  color: #2d6b48 !important;
}

/* ── REGLA OR BRANDING: --green-light NOMÉS sobre fons fosc ──────────────
   Sobre qualsevol fons clar de la web, forcem --forest per garantir contrast.
   Excepció: botons amb background:var(--forest) i overlays de foto (ok per disseny).
   ──────────────────────────────────────────────────────────────────────── */
.content [style*="color:var(--green-light)"],
.page-header:not(.dark-overlay) [style*="color:var(--green-light)"],
.site-footer [style*="color:var(--green-light)"] {
  color: var(--forest) !important;
}


/* Espai extra bottom NexAcompanya/NexGestió cards inici */
.stack-item { margin-bottom: 24px; }
@media(max-width:768px){
  .stack-item { margin-bottom: 16px; }
}




  
  
}



  
  
  
}
@media(max-width:860px){}
@media(max-width:600px){
/* Gestalt intro block */
.gestalt-grid{display:block !important;grid-template-columns:1fr !important;min-height:auto !important;}
.gestalt-foto{display:block !important;height:220px !important;position:relative !important;overflow:hidden !important;}
.gestalt-foto img{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;object-fit:cover !important;object-position:top center !important;}
.gestalt-text{display:block !important;padding:28px 18px 32px !important;}
}

@media(max-width:768px){
/* Taula trimestral → amagar i mostrar cards */
.gs-trimestral-table{ display:none !important; }
.gs-mobile-plans{ display:flex !important; }

/* Foto individual card sota: apilat */
div[style*="grid-template-columns:1fr 1fr"][style*="padding:20px 28px"],
div[style*="grid-template-columns:1fr 1fr"][style*="gap:24px"]{
  grid-template-columns:1fr !important;
}

/* Formulari primera trucada: apilat */
div[style*="grid-template-columns:1fr 1.4fr"]{
  grid-template-columns:1fr !important;
}

/* Títol trimestral */
div[style*="padding:18px 24px 14px"]{
  flex-direction:column !important;
  gap:4px !important;
}
}
@keyframes lfa0{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(3.5px,-5px) rotate(1.3deg)}62%{transform:translate(-2.5px,-2.5px) rotate(-0.8deg)}}.lf0{animation:lfa0 5.8s ease-in-out infinite;animation-delay:0s}@keyframes lfa1{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(4px,-4px) rotate(-1.0deg)}62%{transform:translate(-2px,-2.0px) rotate(0.7deg)}}.lf1{animation:lfa1 6.4s ease-in-out infinite;animation-delay:-1.2s}@keyframes lfa2{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(2.5px,-5.5px) rotate(1.6deg)}62%{transform:translate(-3.2px,-2.8px) rotate(-1.0deg)}}.lf2{animation:lfa2 7.1s ease-in-out infinite;animation-delay:-2.8s}@keyframes lfa3{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(3.8px,-4.5px) rotate(-1.2deg)}62%{transform:translate(-2px,-2.2px) rotate(0.8deg)}}.lf3{animation:lfa3 5.5s ease-in-out infinite;animation-delay:-0.5s}@keyframes lfa4{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(4.5px,-6px) rotate(0.9deg)}62%{transform:translate(-1.5px,-3.0px) rotate(-0.6deg)}}.lf4{animation:lfa4 6.9s ease-in-out infinite;animation-delay:-3.4s}@keyframes lfa5{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(2px,-3.8px) rotate(-1.5deg)}62%{transform:translate(-3.5px,-1.9px) rotate(1.0deg)}}.lf5{animation:lfa5 7.6s ease-in-out infinite;animation-delay:-1.8s}@keyframes lfa6{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(3.2px,-5.2px) rotate(1.1deg)}62%{transform:translate(-2.2px,-2.6px) rotate(-0.7deg)}}.lf6{animation:lfa6 6.2s ease-in-out infinite;animation-delay:-4.1s}@keyframes lfa7{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(4.2px,-3.5px) rotate(-0.8deg)}62%{transform:translate(-1.8px,-1.8px) rotate(0.5deg)}}.lf7{animation:lfa7 5.9s ease-in-out infinite;animation-delay:-0.9s}@keyframes lfa8{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(2.8px,-4.8px) rotate(1.4deg)}62%{transform:translate(-2.8px,-2.4px) rotate(-0.9deg)}}.lf8{animation:lfa8 7.3s ease-in-out infinite;animation-delay:-2.3s}@keyframes lfa9{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(3.6px,-5.5px) rotate(-1.1deg)}62%{transform:translate(-2.2px,-2.8px) rotate(0.7deg)}}.lf9{animation:lfa9 6.7s ease-in-out infinite;animation-delay:-3.9s}@keyframes lfa10{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(2.4px,-4px) rotate(1.0deg)}62%{transform:translate(-3px,-2.0px) rotate(-0.7deg)}}.lf10{animation:lfa10 5.6s ease-in-out infinite;animation-delay:-1.5s}@keyframes lfa11{0%,100%{transform:translate(0,150.0) rotate(0deg)}28%{transform:translate(4px,-5px) rotate(-1.4deg)}62%{transform:translate(-1.8px,-2.5px) rotate(0.9deg)}}.lf11{animation:lfa11 7.8s ease-in-out infinite;animation-delay:-4.7s}@keyframes logo_bounce{0%{transform:translate(0,150.0) rotate(0deg)}25%{transform:translate(8px,-4px) rotate(1.2deg)}50%{transform:translate(-6px,-3px) rotate(-1deg)}75%{transform:translate(5px,3px) rotate(0.8deg)}100%{transform:translate(0,150.0) rotate(0deg)}}.lf_logo{animation:logo_bounce 12s ease-in-out infinite;animation-delay:-2s}
.sidebar-leaves{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;}.sidebar>*:not(.sidebar-leaves){position:relative;z-index:1;}

.stack-wrap { position:relative; }
.stack-item { will-change:transform; }
.stack-item:nth-child(1){ position:sticky; top:42px; z-index:10; }
.stack-item:nth-child(2){ position:sticky; top:46px; z-index:20; border-radius:12px 12px 0 0; margin-top:-2px; }
.stack-item:nth-child(3){ position:sticky; top:50px; z-index:30; border-radius:12px 12px 0 0; }
.stack-item:nth-child(4){ position:sticky; top:54px; z-index:40; border-radius:12px 12px 0 0; }


  .mv-card { transition: transform .25s ease, box-shadow .25s ease, background .25s ease; cursor:default; }
  .mv-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(18,32,41,0.12); background: var(--green-pale) !important; z-index:1; position:relative; }
  .mv-card:hover .mv-title { color: var(--green-mid) !important; }
  

.area-card { display:grid; grid-template-columns:1fr 1fr; gap:0; margin-bottom:32px; border:1px solid rgba(45,107,72,0.2); overflow:hidden; transition:box-shadow .3s; }
.area-card:hover { box-shadow:0 8px 32px rgba(18,32,41,0.1); }
.area-card-img { min-height:320px; background-size:cover; background-position:center; position:relative; }
.area-card-img-overlay { position:absolute; inset:0; background:rgba(18,32,41,0.35); }
.area-card-body { padding:40px 36px; display:flex; flex-direction:column; justify-content:space-between; }
.area-card-tag { font-size:9px; letter-spacing:0.2em; text-transform:uppercase; color:var(--green-mid); margin-bottom:10px; }
.area-card-title { font-family:"Cormorant Garamond",serif; font-size:30px; font-weight:500; color:#0f2d1e; margin-bottom:14px; line-height:1.2; }
.area-card-desc { font-size:13px; color:#4a5e46; line-height:1.8; margin-bottom:24px; }
.area-card-list { list-style:none; padding:0; margin:0 0 28px; }
.area-card-list li { font-size:12px; color:#4a6858; padding:5px 0; border-bottom:1px solid rgba(45,107,72,0.1); display:flex; align-items:center; gap:8px; }
.area-card-list li::before { content:""; width:5px; height:5px; border-radius:50%; background:var(--green-mid); flex-shrink:0; }
.area-btn { display:inline-flex; align-items:center; justify-content:center; background:#2d6b48; color:#fff; border:none; padding:13px 28px; font-family:"DM Sans",sans-serif; font-size:11px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; cursor:pointer; transition:all .3s; text-align:center; border-radius:40px; box-shadow:0 4px 16px rgba(45,107,72,0.25); }
.area-btn:hover { background:rgba(30,90,56,0.55); backdrop-filter:blur(6px); color:#fff; transform:translateY(-2px); box-shadow:0 6px 18px rgba(45,107,72,0.15); }
.area-btn-outline { background:rgba(255,255,255,0.55); backdrop-filter:blur(8px); color:var(--forest); border:1px solid rgba(45,107,72,0.25); }
.area-btn-outline:hover { background:rgba(45,107,72,0.08); backdrop-filter:blur(6px); color:#2d6b48; transform:translateY(-2px); box-shadow:0 6px 18px rgba(45,107,72,0.08); border-color:rgba(45,107,72,0.3); }
@media(max-width:768px){ .area-card { grid-template-columns:1fr; } .area-card-img { min-height:200px; } }


.srv-detail-grid { display:grid; grid-template-columns:280px 1fr; gap:32px; margin-bottom:48px; }
.srv-detail-nav { position:sticky; top:24px; }
.srv-detail-nav-item { display:block; padding:12px 16px; font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:#4a6858; border-left:2px solid rgba(45,107,72,0.2); cursor:pointer; transition:all .2s; margin-bottom:4px; }
.srv-detail-nav-item:hover, .srv-detail-nav-item.active { color:var(--forest); border-left-color:var(--green-mid); background:#f0f9ed; }
.srv-block { margin-bottom:56px; padding-bottom:56px; border-bottom:1px solid rgba(45,107,72,0.12); }
.srv-block:last-child { border-bottom:none; }
.srv-block-tag { font-size:9px; letter-spacing:0.2em; text-transform:uppercase; color:var(--green-mid); margin-bottom:10px; }
.srv-block-title { font-family:"Cormorant Garamond",serif; font-size:30px; color:#0f2d1e; margin-bottom:14px; font-weight:500; }
.srv-block-desc { font-size:13px; color:#4a5e46; line-height:1.85; margin-bottom:24px; max-width:100%; }
.srv-cols { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; }
.srv-col-box { background:#f5f0e8; border:1px solid rgba(45,107,72,0.15); padding:20px; }
.srv-col-box-title { font-size:12px; font-weight:600; color:#0f2d1e; letter-spacing:0.06em; text-transform:uppercase; margin-bottom:10px; }
.srv-col-box ul { list-style:none; padding:0; margin:0; }
.srv-col-box li { font-size:12px; color:#4a6858; padding:4px 0; border-bottom:1px solid rgba(45,107,72,0.08); display:flex; gap:8px; align-items:flex-start; }
.srv-col-box li::before { content:"–"; color:var(--green-mid); flex-shrink:0; }
.col-dark { background:#98be95 !important; }
.col-dark .srv-col-box-title { color:#0f2d1e !important; }
.srv-col-box.col-dark { background:#98be95 !important; }
.srv-col-box.col-dark .srv-col-box-title { color:#0f2d1e !important; }
.srv-col-box.col-dark li { color:#4a6858 !important; border-bottom-color:rgba(45,107,72,0.15) !important; }
.srv-col-box.col-dark li::before { color:#2d6b48 !important; }
.col-dark li { color:#4a6858 !important; border-bottom-color:rgba(45,107,72,0.15) !important; }
.col-dark li::before { color:#2d6b48 !important; }
@media(max-width:768px){ .srv-detail-grid { grid-template-columns:1fr; } .srv-detail-nav { display:none; } }


.dstep{display:none;} .dopt{display:flex;align-items:flex-start;gap:14px;padding:14px 18px;border:1px solid rgba(45,107,72,0.2);margin-bottom:10px;cursor:pointer;transition:all .2s;background:#f5f0e8;}
.dopt:hover,.dopt.selected{border-color:var(--green-mid);background:#e8f5e4;}
.dopt-circle{width:20px;height:20px;border-radius:50%;border:2px solid rgba(45,107,72,0.4);flex-shrink:0;margin-top:2px;transition:all .2s;}
.dopt.selected .dopt-circle{background:var(--green-mid);border-color:var(--green-mid);}
.dstep-num{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green-mid);margin-bottom:8px;}
.dstep-q{font-family:"Cormorant Garamond",serif;font-size:24px;color:var(--forest);margin-bottom:8px;line-height:1.3;}
.dstep-d{font-size:12px;color:#4a6858;margin-bottom:24px;line-height:1.6;font-style:italic;}
.dopt span{font-size:14px;color:var(--forest);line-height:1.5;}
.dres-header{padding:28px 32px;margin-bottom:24px;}
.dres-label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;opacity:.7;margin-bottom:8px;}
.dres-title{font-family:"Cormorant Garamond",serif;font-size:32px;font-weight:300;margin-bottom:10px;}
.dres-desc{font-size:13px;line-height:1.7;opacity:.85;}
.dres-recs{margin-bottom:24px;} .drecs-title{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green-mid);margin-bottom:14px;}
.dres-recs ul{list-style:none;padding:0;margin:0;} .dres-recs li{font-size:13px;color:#4a5e46;line-height:1.7;padding:6px 0;border-bottom:1px solid rgba(45,107,72,0.1);}
.dres-cta{background:#f0f9ed;border:1px solid rgba(45,107,72,0.2);padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.dres-cta-t{font-family:"Cormorant Garamond",serif;font-size:18px;color:var(--forest);margin-bottom:4px;}
.dres-cta-s{font-size:12px;color:#4a6858;}
.dres-reset{margin-top:16px;background:transparent;color:#4a6858;border:1px solid rgba(45,107,72,0.3);padding:10px 20px;font-family:"DM Sans",sans-serif;font-size:12px;cursor:pointer;letter-spacing:0.08em;text-transform:uppercase;}


  @keyframes pulse-dot {
    0%,100%{box-shadow:0 0 6px rgba(45,107,72,0.6);}
    50%{box-shadow:0 0 14px rgba(45,107,72,0.9),0 0 24px rgba(109,191,133,0.3);}
  }
  

    .cas-card { transition: transform .25s ease, box-shadow .25s ease, background .25s ease; cursor:default; }
    .cas-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(18,32,41,0.12); background: var(--green-pale) !important; z-index:1; position:relative; }
    .cas-card:hover .cas-title { color: var(--green-mid) !important; }
    

.modal-overlay{display:none;position:fixed;inset:0;background:rgba(18,32,41,0.7);z-index:1000;align-items:center;justify-content:center;padding:24px;}
.modal-overlay.open{display:flex;}
.modal-box{background:#fff;max-width:720px;width:100%;max-height:85vh;overflow-y:auto;padding:48px 52px;position:relative;}
.modal-close{position:absolute;top:20px;right:24px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-muted);line-height:1;}
.modal-box h2{font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:300;color:#0f2d1e;margin-bottom:8px;}
.modal-box h3{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:#0f2d1e;margin:28px 0 8px;}
.modal-box p,.modal-box li{font-size:13.5px;color:#4a5e46;line-height:1.8;}
.modal-box ul{padding-left:20px;margin:8px 0 16px;}
.modal-tag{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green-mid);margin-bottom:16px;display:block;}



/* Subpàgines: forçar visibilitat quan hi ha una sola section */
body:not(.home) section { display:block !important; animation:none !important; }

/* ── CTAs: sense subratllat i hover translúcid ─────────────── */
a[style*="background:#2d6b48"],
a[style*="background: #2d6b48"],
a.btn-primary, a.btn-outline,
a.area-btn {
  text-decoration: none !important;
}

a[style*="background:#2d6b48"]:hover,
a[style*="background: #2d6b48"]:hover,
a.btn-primary:hover,
a.area-btn:hover {
  background: rgba(45,107,72,0.72) !important;
  backdrop-filter: blur(4px) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(45,107,72,0.18) !important;
  transition: all .3s !important;
}

a.btn-outline:hover {
  background: rgba(45,107,72,0.08) !important;
  transform: translateY(-2px) !important;
}

/* Eliminar subratllat nav i footer */
nav a, .footer-links a, .topbar-btn, .sidebar-footer a {
  text-decoration: none !important;
}
