@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Libre+Baskerville:wght@400;700&display=swap');

:root{
  --bg:#ffffff;
  --bg-soft:#f6f8f5;
  --bg-soft-2:#eef3ee;
  --text:#24362d;
  --muted:#5f7168;
  --muted-2:#7a8b83;
  --line:#d9e2db;
  --line-strong:#bfd0c3;
  --pine:#398c65;
  --pine-2:#2d5743;
  --pine-3:#4f8d6f;
  --accent:#6e8b79;
  --footer:#1f3a2d;
  --white:#ffffff;
  --shadow:0 12px 34px rgba(24,48,35,.08);
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-md:14px;
  --max:1440px;
  --content:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100%;
  display:flex;
  flex-direction:column;
  background:var(--bg);
  color:var(--text);
  font-family:'DM Sans', Arial, sans-serif;
  line-height:1.7;
}
main{flex:1}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
p{margin:0 0 18px}
h1,h2,h3,h4,h5,h6{
  margin:0;
  font-family:'Libre Baskerville', serif;
  font-weight:400;
  line-height:1.12;
  letter-spacing:.01em;
  color:#4e9773; /* #1f3f2f.verd principal tipus CIM */
}
button,input,textarea,select{font:inherit}

.page-intro-inner,.container,.legal-section,.thanks-box{
  max-width:var(--content);
  margin:0 auto;
  padding-left:48px;
  padding-right:48px;
}

.site-header{
  position:fixed;
  top:0;left:0;width:100%;
  z-index:100;
  background:rgba(255,255,255,.94);
  border-bottom:1px solid rgba(32,65,49,.08);
  backdrop-filter:blur(10px);
}
.header-inner{
  max-width:var(--max);
  margin:0 auto;
  min-height:84px;
  padding:0 34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}
.brand{display:flex;flex-direction:column;gap:2px}
.brand strong{
  font-family:'Montserrat','Manrope',sans-serif;
  font-size:24px;
  font-weight:500;
  color:var(--pine);
}
.brand span{font-size:13px;color:var(--muted)}

.nav-toggle{
  display:none;
  width:46px;height:46px;
  border:1px solid rgba(32,65,49,.18);
  background:#fff;
  border-radius:10px;
  cursor:pointer;
  padding:10px;
}
.nav-toggle span{
  display:block;
  width:100%;
  height:2px;
  margin:5px 0;
  background:var(--pine);
  transition:transform .2s ease, opacity .2s ease;
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.main-nav{display:flex;align-items:center;gap:22px}
.main-nav > a,.dropdown-toggle,.lang-switch a{
  font-size:16px;
  color:var(--muted);
  background:none;
  border:0;
  padding:10px 0;
  cursor:pointer;
}
.main-nav > a:hover,
.main-nav > a.active,
.dropdown-toggle:hover,
.dropdown.has-active > .dropdown-toggle,
.dropdown.is-open > .dropdown-toggle,
.lang-switch a:hover,
.lang-switch a.active{color:var(--pine)}

.lang-switch{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:6px;
  padding-left:10px;
  border-left:1px solid var(--line);
}
.dropdown{position:relative}
.dropdown-toggle{display:inline-flex;align-items:center;gap:8px}
.dropdown-toggle::after{content:'▾';font-size:12px;transform:translateY(1px)}
.dropdown-menu{
  position:absolute;
  top:100%;
  left:0;
  min-width:260px;
  display:none;
  padding:10px;
  background:#fff;
  border:1px solid rgba(32,65,49,.12);
  border-radius:16px;
  box-shadow:var(--shadow);
}
.dropdown:hover .dropdown-menu,
.dropdown.is-open .dropdown-menu{display:block}
.dropdown-menu a{
  display:block;
  padding:11px 13px;
  border-radius:10px;
  font-size:15px;
  color:var(--muted);
}
.dropdown-menu a:hover,
.dropdown-menu a.active{
  background:var(--bg-soft);
  color:var(--pine);
}

.page-shell,.home-main{padding-top:84px}
.page-intro{
  padding:46px 0 34px;
  background:#fff;
  border-bottom:1px solid var(--line);
}
.page-title{font-size:clamp(42px,6vw,70px);color:var(--pine)}
.page-subtitle{
  max-width:760px;
  margin-top:16px;
  font-size:19px;
  color:var(--muted);
}
.title-line{
  width:72px;
  height:2px;
  margin-top:18px;
  background:var(--pine-3);
}

.hero{
  max-width:var(--content);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  min-height:auto;
  padding:60px 48px;
}
.hero-copy{display:flex;align-items:center;padding:0px}
.hero-copy-inner{max-width:620px}
.eyebrow{
  display:inline-block;
  margin-bottom:18px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--accent);
}
.hero h1{
  font-size:clamp(60px,8vw,102px);
  line-height:.94;
  color:var(--pine);
}
.role{
  display:flex;
  align-items:center;
  gap:18px;
  margin:24px 0 28px;
  font-size:25px;
  color:var(--pine-3);
}
.role::before{
  content:'';
  width:64px;
  height:2px;
  background:var(--pine-3);
}
.subtitol{margin-bottom:14px;font-size:18px;color:var(--muted-2)}
.lead{
  max-width:560px;
  font-size:20px;
  color:var(--muted);
  line-height:1.85;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.button-line,.button-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:12px 22px;
  border-radius:999px;
  font-size:15px;
  transition:.2s ease;
}
.button-line{background:var(--pine);color:#fff;border:1px solid var(--pine)}
.button-line:hover{background:var(--pine-2);border-color:var(--pine-2)}
.button-ghost{background:#fff;color:var(--pine);border:1px solid var(--pine)}
.button-ghost:hover{background:var(--pine);color:#fff}

.hero-visual{
  justify-content:flex-end;
}
.hero-photo-wrap{
  position:relative;
  max-width:700px;
  min-height:100%;
  overflow:hidden;
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg,#406b56 0%, #8aa193 100%);
  box-shadow:var(--shadow);
}
.hero-photo-wrap img{width:100%;height:100%;object-fit:cover}
.hero-photo-wrap::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(rgba(32,65,49,.12), rgba(32,65,49,.34));
  pointer-events:none;
}
.hero-quote{
  position:absolute;
  left:28px;right:28px;bottom:28px;
  z-index:2;
  max-width:470px;
  padding:22px 24px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  border-radius:22px;
  backdrop-filter:blur(5px);
  color:#fff;
}
.hero-quote p{margin:0 0 10px;font-size:28px;line-height:1.32}
.hero-quote span{font-size:14px;opacity:.95}
.hero-photo-wrap.is-fallback::before{
  content:'Afegeix la teva imatge a /img/foto1.jpeg';
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:24px;text-align:center;color:#fff;font-size:18px;z-index:1;
}

.section{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
}
.section.soft{background:var(--bg-soft)}
.section.white{background:#fff}
.section-title-wrap{padding:68px 48px;}
.section-title{font-size:30px;color:var(--pine)}
.section-content{
  max-width:700px;
  padding:68px 48px;
}
.section-content p{font-size:19px;color:var(--muted)}

.section-title-wrap,
.section-content{
  padding:68px 0;
}

.band{
  padding:78px 0;
  background:#fff;
  border-top:1px solid var(--line);
}
.band.soft{background:var(--bg-soft)}
.band-header{max-width:780px;margin-bottom:34px}
.band-header h2{margin-bottom:14px;font-size:clamp(34px,5vw,54px);color:var(--pine)}
.band-header p{font-size:19px;color:var(--muted)}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.info-card{
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
}
.info-card h3{margin-bottom:14px;font-size:27px;color:var(--pine)}
.info-card p{margin-bottom:0;font-size:17px;color:var(--muted)}

.photo-frame{
  background:none;
  box-shadow:none;
  min-height:auto;
}

.photo-frame::after{
  display:none;
}

.photo-frame.small{
  width:100%;
  max-width:620px;
  aspect-ratio:4 / 3;
  height:auto;
  min-height:0;
  margin:0 auto;
  border-radius:28px;
  overflow:hidden;
}



.service-text{
  padding:0;
  justify-content:center;
}

.service-text-inner{
  max-width:680px;
}

.photo-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:28px;
}

.photo-frame::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(rgba(35,66,51,.10),rgba(35,66,51,.28));
  pointer-events:none;
}

.photo-frame.is-fallback::before{
  content:'Afegeix la teva imatge a /img/foto.jpeg';
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  text-align:center;
  color:#fff;
  font-size:18px;
  z-index:1;
}

.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:start}
.about-copy p{font-size:18px;color:var(--muted)}
.highlight-box{
  margin-top:22px;
  padding:22px 24px;
  border-left:3px solid var(--pine-3);
  background:var(--bg-soft);
  border-radius:0 16px 16px 0;
}

.services-list{
  max-width:1180px;
  margin:0 auto;
  padding:0 48px 78px;
  display:grid;
  gap:54px;
}
.service-row{
  display:grid;
  grid-template-columns:minmax(320px, 46%) minmax(0, 54%);
  gap:52px;
  align-items:center;
  background:#fff;
  border-top:1px solid var(--line);
  padding-top:54px;
  scroll-margin-top:120px;
}
.service-row:nth-child(even) .photo-frame{order:2}
.service-row:nth-child(even) .service-text{order:1}
.service-text{display:flex;align-items:center;padding:0}
.service-text-inner{max-width:680px}
.service-text h2{margin-bottom:20px;font-size:clamp(32px,4vw,44px);color:var(--pine)}
.service-text p{font-size:18px;color:var(--muted)}

.areas-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:44px;align-items:start}
.area-block{padding:24px 0;border-bottom:1px solid var(--line)}
.area-block:first-child{padding-top:0}
.area-block:last-child{border-bottom:0}
.area-block h3{margin-bottom:10px;font-size:27px;color:var(--pine)}
.area-block p{font-size:18px;color:var(--muted)}

.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.contact-panel{
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
}
.contact-copy p{font-size:18px;color:var(--muted)}
.contact-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-bottom:12px;
  font-size:17px;
  color:var(--muted);
}
.contact-form{margin-top:20px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.input,.textarea{
  width:100%;
  padding:15px 16px;
  background:#fff;
  color:var(--text);
  border:1px solid var(--line-strong);
  border-radius:14px;
  appearance:none;
}
.input::placeholder,.textarea::placeholder{color:#92a099}
.textarea{
  grid-column:1 / -1;
  min-height:170px;
  resize:vertical;
}
.submit-bar{
  width:100%;
  margin-top:16px;
  padding:15px;
  border:0;
  border-radius:999px;
  background:var(--pine);
  color:#fff;
  font-size:15px;
  cursor:pointer;
}
.submit-bar:hover{background:var(--pine-2)}
.form-note{margin-top:12px;font-size:14px;color:var(--muted-2)}

.legal-section{
  max-width:1100px;
  margin:0 auto;
  padding-top:42px;
  padding-bottom:78px;
}
.legal-block{max-width:820px;margin-bottom:34px}
.legal-block h3{margin-bottom:10px;font-size:27px;color:var(--pine)}
.legal-block p{font-size:18px;color:var(--muted)}
.faq-list{display:grid;gap:16px}
.faq-item{
  padding:22px 24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
}
.faq-item h3{margin-bottom:10px;font-size:23px;color:var(--pine)}
.faq-item p{font-size:18px;color:var(--muted)}

.thanks-box{
  max-width:760px;
  padding-top:84px;
  padding-bottom:84px;
  text-align:center;
}
.thanks-box h1{margin-bottom:16px;font-size:clamp(40px,5vw,66px);color:var(--pine)}
.thanks-box p{font-size:20px;color:var(--muted)}

.site-footer{margin-top:0}
.footer-bottom{
  padding:18px;
  background:var(--footer);
  color:#fff;
  text-align:center;
  font-size:13px;
  letter-spacing:.35px;
}
.footer-legal{margin-top:6px}
.footer-legal a{
  color:#fff;
  text-decoration:underline;
  opacity:.95;
}
.footer-legal a:hover{opacity:1}
.footer-only{display:none}

.contact-photo{
  max-width:420px;
  margin:0 auto;
  background:none;
  box-shadow:none;
  min-height:auto;
  height:auto;
  overflow:visible;
}

.contact-photo img{
  width:100%;
  height:auto;
  display:block;
  border-radius:28px;
  object-fit:unset;
}

.contact-photo::after{
  display:none;
}

@media (max-width:1080px){
  .page-intro-inner,.container,.legal-section,.thanks-box{
    padding-left:24px;
    padding-right:24px;
  }
  .header-inner{padding:0 24px}
  .hero,.section,.about-grid,.areas-layout,.contact-grid,.service-row{grid-template-columns:1fr}
  .services-list{padding-left:24px;padding-right:24px;gap:34px}
  .cards-grid{grid-template-columns:1fr}
  .hero{min-height:auto}
  .hero-copy{padding:56px 24px 28px}
  .hero-visual{padding:0 24px 28px}
  .section-title-wrap,.section-content{padding:48px 24px}
  .about-grid,.areas-layout,.contact-grid,.service-row{gap:28px}
  .service-row:nth-child(even) .photo-frame,
  .service-row:nth-child(even) .service-text{order:initial}
  .service-text{padding:38px 24px}
  .photo-frame{min-height:340px}
  .photo-frame.small{max-width:620px;min-height:300px}
}

@media (max-width:760px){
  .site-header{position:sticky}
  .header-inner{min-height:auto;padding:14px 18px}
  .brand strong{font-size:20px}
  .brand span{font-size:12px}
  .nav-toggle{display:block}
  .main-nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    width:100%;
    padding:14px 18px 20px;
    background:rgba(255,255,255,.99);
    border-bottom:1px solid rgba(32,65,49,.08);
    flex-direction:column;
    align-items:flex-start;
    gap:2px;
  }
  .main-nav.is-open{display:flex}
  .main-nav > a,.dropdown-toggle,.lang-switch a{
    width:100%;
    padding:12px 0;
    font-size:18px;
    text-align:left;
  }
  .dropdown{width:100%}
  .dropdown-menu{
    position:static;
    display:none;
    width:100%;
    min-width:0;
    margin:0 0 4px;
    padding:0 0 0 12px;
    border:0;
    border-radius:0;
    box-shadow:none;
    background:transparent;
  }
  .dropdown:hover .dropdown-menu{display:none}
  .dropdown.is-open .dropdown-menu{display:block}
  .dropdown-menu a{padding:9px 0;border-radius:0}
  .lang-switch{
    width:100%;
    gap:14px;
    margin-left:0;
    padding-left:0;
    border-left:0;
  }
  .footer-only{display:block}
  .page-shell,.home-main{padding-top:0}
  .page-intro{padding:24px 0 22px}
  .page-intro-inner,.container,.legal-section,.thanks-box{
    padding-left:20px;
    padding-right:20px;
  }
  .page-title{font-size:clamp(36px,12vw,54px)}
  .page-subtitle{font-size:16px;line-height:1.6}
  .hero h1{font-size:clamp(46px,14vw,72px)}
  .role{margin:20px 0 22px;font-size:21px}
  .role::before{width:52px}
  .subtitol{font-size:16px}
  .lead,.section-content p,.band-header p,.about-copy p,.contact-copy p,.area-block p,.service-text p,.legal-block p,.faq-item p{
    font-size:16px;line-height:1.7;
  }
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions a{width:100%;text-align:center}
  .hero-quote{left:18px;right:18px;bottom:18px;padding:18px;border-radius:18px}
  .hero-quote p{font-size:23px}
  .band{padding:54px 0}
  .band-header h2{font-size:34px}
  .section-title,.service-text h2,.area-block h3,.legal-block h3,.faq-item h3{font-size:24px}
  .photo-frame{min-height:280px;border-radius:20px}
  .photo-frame.small{min-height:230px}
  .services-list{padding-left:20px;padding-right:20px;padding-bottom:54px}
  .contact-panel,.faq-item{padding:20px}
  .form-grid{grid-template-columns:1fr}
  .thanks-box{padding-top:62px;padding-bottom:62px}
  .thanks-box p{font-size:18px}
}
