:root{--green-deep: #1a3a2a;--green-mid: #2d6a4f;--green-fresh: #52b788;--green-light: #b7e4c7;--earth: #8b5e3c;--cream: #f5f0e8;--white: #fafaf7;--text-dark: #0f1f16;--text-mid: #3a4f42;--gold: #c9a84c;--border-soft: rgba(45, 106, 79, .12)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:DM Sans,sans-serif;background:var(--white);color:var(--text-dark);overflow-x:hidden}body.menu-open{overflow:hidden}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}main{min-height:100vh}.site-header{position:fixed;inset:0 0 auto;z-index:100;background:#1a3a2af7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(82,183,136,.2)}.header-inner{max-width:1280px;margin:0 auto;padding:1.2rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.nav-logo{font-family:Playfair Display,serif;font-size:1.55rem;font-weight:900;color:var(--green-light);letter-spacing:.04em}.nav-logo span{color:var(--gold)}.nav-links{display:flex;align-items:center;gap:1.5rem;margin-left:auto}.nav-desktop-lang{display:inline-flex}.nav-mobile-lang,.menu-toggle{display:none}.nav-link{color:#b7e4c7cc;font-size:.82rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;transition:color .2s,background .2s}.nav-link:hover,.nav-link.active{color:var(--gold)}.nav-cta{background:var(--green-fresh);color:var(--green-deep);padding:.55rem 1.2rem;border-radius:2px}.nav-cta:hover,.nav-cta.active{color:var(--green-deep);background:var(--gold)}.lang-switcher{display:inline-flex;border:1px solid rgba(82,183,136,.35);border-radius:3px;overflow:hidden}.lang-btn{background:transparent;color:#b7e4c7b3;border:0;padding:.32rem .7rem;font-size:.72rem;font-family:inherit;font-weight:500;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .2s,color .2s}.lang-btn.active{background:var(--green-fresh);color:var(--green-deep)}.menu-toggle{width:48px;height:48px;border:1px solid rgba(82,183,136,.35);background:transparent;color:var(--green-light);padding:0;border-radius:4px;align-items:center;justify-content:center;flex-direction:column;gap:5px;cursor:pointer}.menu-toggle span{width:18px;height:2px;background:currentColor;transition:transform .2s ease,opacity .2s ease}.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.menu-toggle.open span:nth-child(2){opacity:0}.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.hero{min-height:100vh;padding:8rem 2rem 4rem;display:flex;align-items:center;position:relative;background:linear-gradient(to bottom,#0f1f16bd,#0f1f165c,#0f1f16d1),var(--hero-image) center / cover no-repeat}.hero:before{content:"";position:absolute;inset:auto 0 0;height:180px;background:linear-gradient(to top,var(--white),transparent)}.hero-compact{min-height:72vh}.hero-content{position:relative;z-index:1;max-width:1280px;width:100%;margin:0 auto}.hero-tag,.section-label{display:inline-block;font-size:.74rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase}.hero-tag{background:var(--gold);color:var(--green-deep);padding:.4rem 1rem;margin-bottom:1.5rem}.hero h1,.section-title,.cta-section h2{font-family:Playfair Display,serif}.hero h1{max-width:840px;margin:0 0 1.5rem;color:var(--cream);font-size:clamp(3rem,6vw,6rem);font-weight:900;line-height:.98}.hero p{max-width:560px;margin:0 0 2rem;color:#f5f0e8db;font-size:1.05rem;line-height:1.7}.hero-btns{display:flex;flex-wrap:wrap;gap:1rem}.hero-trust{margin-top:1.25rem;display:flex;flex-wrap:wrap;gap:.75rem}.hero-trust-item{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem .95rem;background:#0f1f1652;border:1px solid rgba(183,228,199,.18);color:#f5f0e8e0;font-size:.82rem;letter-spacing:.04em}.hero-trust-item span{color:var(--gold);font-weight:700}.btn-primary,.btn-outline{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:.95rem 1.9rem;font-size:.88rem;font-weight:500;letter-spacing:.05em;transition:transform .2s,background .2s,color .2s,border-color .2s}.btn-primary{border:0;background:var(--green-fresh);color:var(--green-deep)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:.95rem 1.9rem;border:1px solid rgba(45,106,79,.24);background:transparent;color:var(--green-deep);font-size:.88rem;font-weight:500;letter-spacing:.05em;cursor:pointer;transition:transform .2s,border-color .2s,color .2s}.btn-outline{border:1.5px solid rgba(183,228,199,.6);color:var(--green-light)}.btn-primary:hover,.btn-outline:hover,.btn-secondary:hover{transform:translateY(-2px)}.btn-primary:hover{background:var(--gold)}.btn-outline:hover{color:var(--gold);border-color:var(--gold)}.btn-secondary:hover{color:var(--green-mid);border-color:var(--green-mid)}.section{padding:6rem 2rem}.section-cream{background:var(--cream)}.section-light{background:var(--white)}.section-dark{background:var(--green-deep)}.section-zones{background:linear-gradient(135deg,var(--green-deep) 0%,#0f2a1e 100%);position:relative;overflow:hidden}.section-zones:before{content:"CATALUNYA";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:Playfair Display,serif;font-size:18vw;font-weight:900;color:#ffffff05;letter-spacing:-.05em;pointer-events:none}.container{position:relative;z-index:1;max-width:1200px;margin:0 auto}.section-heading p:last-child,.lead-paragraph:last-child{margin-bottom:0}.section-heading{margin-bottom:2rem}.section-heading.center{text-align:center}.section-label{color:var(--green-fresh);margin-bottom:.8rem}.section-title{margin:0;font-size:clamp(2rem,4vw,3.5rem);line-height:1.1;color:var(--green-deep)}.section-dark .section-label,.section-zones .section-label{color:var(--green-light)}.section-dark .section-title,.section-zones .section-title{color:var(--cream)}.lead-paragraph,.section-copy{font-size:1rem;line-height:1.8;color:var(--text-mid)}.centered{max-width:640px;margin:0 auto 2.5rem;text-align:center}.section-zones .section-copy{color:#b7e4c7b8}.split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4rem;align-items:start}.intro-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}.stat-box,.contact-card{background:var(--white);border:1px solid var(--border-soft);padding:1.8rem;position:relative}.stat-box:before{content:"";position:absolute;inset:auto 0 0;height:3px;background:var(--green-fresh)}.stat-num{font-family:Playfair Display,serif;font-size:3rem;font-weight:900;color:var(--green-mid);line-height:1}.stat-desc{margin-top:.35rem;color:var(--text-mid);font-size:.82rem;line-height:1.4}.cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px}.service-card{background:#ffffff0a;padding:2.25rem;position:relative;overflow:hidden;transition:background .25s}.service-card:hover{background:#52b7881f}.service-card:after{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .35s ease}.service-card:hover:after{transform:scaleY(1)}.service-icon{display:block;margin-bottom:1rem;font-size:2.2rem}.service-card h3{margin:0 0 .75rem;font-family:Playfair Display,serif;font-size:1.35rem;color:var(--cream)}.service-card p{margin:0;color:#b7e4c7bd;font-size:.9rem;line-height:1.7}.card-link{display:inline-block;margin-top:1.15rem;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid rgba(201,168,76,.3)}.fences-grid{align-items:center}.image-card{position:relative}.image-card img{width:100%;height:500px;object-fit:cover}.image-badge{position:absolute;right:-1rem;bottom:-1rem;max-width:160px;padding:1.2rem;background:var(--gold);color:var(--green-deep);font-family:Playfair Display,serif;font-weight:700;line-height:1.25}.vallados-types{display:grid;gap:.8rem;margin:2rem 0}.vallados-type{display:flex;align-items:center;gap:.8rem;color:var(--text-mid);font-size:.92rem}.vallados-type:before{content:"";width:20px;height:2px;background:var(--green-fresh);flex-shrink:0}.zones-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;background:#52b78826}.zone{background:#1a3a2ae6;padding:2rem 1.5rem;text-align:center;transition:background .25s,transform .25s}.zone:hover{background:#52b78826;transform:translateY(-3px)}.zone-name{margin-bottom:.35rem;font-family:Playfair Display,serif;font-size:1.1rem;color:var(--cream)}.zone-desc{color:#b7e4c78c;font-size:.78rem}.proceso-steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.5rem}.step{text-align:center}.step-num{width:4rem;height:4rem;margin:0 auto 1.2rem;border-radius:999px;display:grid;place-items:center;background:var(--green-mid);color:var(--cream);font-family:Playfair Display,serif;font-size:1.3rem;font-weight:900}.step h4{margin:0 0 .6rem;font-family:Playfair Display,serif;font-size:1.1rem;color:var(--green-deep)}.step p{margin:0;color:var(--text-mid);font-size:.86rem;line-height:1.6}.testimonios-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem}.testimonio{border:1px solid var(--border-soft);padding:2rem;position:relative}.testimonio:before{content:'"';position:absolute;top:1.2rem;left:1.25rem;font-family:Playfair Display,serif;font-size:5rem;line-height:.7;color:var(--green-light)}.testimonial-head{display:flex;align-items:center;gap:.9rem}.testimonial-avatar{width:54px;height:54px;display:grid;place-items:center;border-radius:999px;background:var(--green-light);color:var(--green-deep);font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700}.testimonio-text{margin-top:2rem;color:var(--text-mid);font-size:.92rem;line-height:1.7;font-style:italic}.testimonio-author{margin-top:1.5rem;color:var(--green-mid);font-size:.86rem;font-weight:700}.testimonio-loc{color:#3a4f4299;font-size:.76rem}.testimonial-badge{margin-top:1rem;display:inline-flex;padding:.35rem .7rem;background:#52b7881f;color:var(--green-mid);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase}.stars{margin-top:.3rem;color:var(--gold);font-size:.85rem}.cta-section{padding:7rem 2rem;text-align:center;background:linear-gradient(to right,#0f1f16eb,#1a3a2ad9),url(/scene-contact.svg) center / cover no-repeat}.cta-section .section-label{color:var(--green-light)}.cta-section h2{max-width:720px;margin:0 auto 1rem;font-size:clamp(2rem,4vw,3.5rem);color:var(--cream)}.cta-section p{max-width:520px;margin:0 auto 2rem;color:#b7e4c7bf;line-height:1.7}.contact-form{display:grid;gap:1rem}.contact-form.compact{max-width:760px;margin:0 auto}.contact-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.field{display:grid;gap:.45rem;text-align:left}.field span{font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.field-full{grid-column:1 / -1}.field-hidden{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.contact-form input,.contact-form select,.contact-form textarea{width:100%;min-height:54px;padding:.95rem 1rem;border:1px solid var(--border-soft);background:#fffffff5;color:var(--text-dark);font:inherit;outline:0;resize:vertical}.cta-section .contact-form input,.cta-section .contact-form select,.cta-section .contact-form textarea{border-color:#b7e4c74d;background:#ffffff14;color:var(--cream)}.cta-section .field span,.cta-section .form-hint,.cta-section .form-disclaimer,.cta-section .consent-row{color:#b7e4c7c7}.cta-section .contact-form input::placeholder,.cta-section .contact-form textarea::placeholder{color:#b7e4c76b}.cta-section .contact-form select{color:var(--cream)}.cta-section .contact-form option{color:var(--text-dark)}.cta-section .form-disclaimer a{color:var(--gold)}.contact-form-actions{display:flex;flex-wrap:wrap;gap:.75rem}.contact-form-actions button:disabled{cursor:wait;opacity:.8}.form-hint{margin:0;font-size:.82rem;color:#3a4f42b8}.form-hint.is-success{color:var(--green-fresh)}.form-disclaimer{margin:-.15rem 0 0;font-size:.8rem;line-height:1.6;color:#3a4f42c7}.form-disclaimer a,.footer-legal-links a{color:var(--green-mid)}.consent-row{display:flex;align-items:flex-start;gap:.75rem;font-size:.86rem;line-height:1.5;color:var(--text-mid)}.consent-row input{width:18px;min-width:18px;height:18px;min-height:18px;margin-top:.15rem}.cta-note{margin-top:1rem;font-size:.82rem}.cta-note strong{color:var(--green-light)}.contact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2rem}.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.5rem;margin-top:2rem}.project-card{border:1px solid var(--border-soft);background:var(--white);overflow:hidden}.project-card img{width:100%;aspect-ratio:16 / 10;object-fit:cover}.project-copy{padding:1.4rem}.project-meta{color:var(--green-mid);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase}.project-copy h3{margin:.55rem 0 .7rem;font-family:Playfair Display,serif;font-size:1.35rem;color:var(--green-deep)}.project-copy p{margin:0;color:var(--text-mid);line-height:1.7;font-size:.92rem}.contact-card h3{margin:1.2rem 0 .35rem;font-family:Playfair Display,serif;color:var(--green-deep)}.contact-card p{margin:0;color:var(--text-mid)}.site-footer{background:#0a1810;padding:4rem 2rem 2rem}.footer-grid{max-width:1200px;margin:0 auto;padding-bottom:3rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;border-bottom:1px solid rgba(82,183,136,.1)}.footer-brand p,.footer-col a,.footer-bottom p{color:#b7e4c780}.footer-brand p,.footer-col a{font-size:.85rem;line-height:1.7}.footer-col h5{margin:0 0 1rem;color:var(--gold);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase}.footer-col ul{padding:0;margin:0;list-style:none}.footer-col li+li{margin-top:.6rem}.footer-bottom{max-width:1200px;margin:0 auto;padding-top:2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.footer-bottom p{margin:0;font-size:.78rem}.footer-legal-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:1rem}.footer-legal-links a{font-size:.78rem}.legal-layout{display:grid;gap:1.25rem}.legal-card{background:var(--white);border:1px solid var(--border-soft);padding:2rem}.legal-card h2{margin:0 0 1rem;font-family:Playfair Display,serif;font-size:clamp(1.35rem,3vw,1.9rem);color:var(--green-deep)}.legal-card p{margin:0;color:var(--text-mid);line-height:1.8}.legal-card p+p{margin-top:.9rem}[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .45s ease,transform .45s ease}[data-reveal].is-visible{opacity:1;transform:translateY(0)}.whatsapp-btn{position:fixed;right:2rem;bottom:2rem;z-index:120;width:56px;height:56px;display:grid;place-items:center;border-radius:999px;background:#25d366;font-size:1.6rem;box-shadow:0 4px 20px #0000004d}@media (max-width: 1024px){.header-inner{padding:1rem 1.5rem}.cards-grid,.zones-grid,.proceso-steps,.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-grid,.contact-grid,.footer-grid,.testimonios-grid{grid-template-columns:1fr}}@media (max-width: 760px){.site-header{background:#132b1efb}.header-inner{padding:.9rem 1rem;display:grid;grid-template-columns:1fr auto;align-items:center;gap:.75rem}.nav-logo{font-size:1.3rem}.menu-toggle,.nav-mobile-lang{display:inline-flex}.nav-desktop-lang{display:none}.nav-links{position:absolute;top:calc(100% + 1px);left:0;right:0;display:flex;margin-left:0;padding:1rem;background:#11261bfb;border-bottom:1px solid rgba(82,183,136,.18);flex-direction:column;align-items:stretch;gap:.75rem;opacity:0;visibility:hidden;transform:translateY(-12px);pointer-events:none;transition:opacity .22s ease,transform .22s ease,visibility .22s ease}.nav-links.nav-links-open{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.nav-link{display:block;width:100%;padding:.85rem .95rem;border:1px solid rgba(82,183,136,.14);background:#ffffff05;text-align:center}.nav-cta{padding:.85rem .95rem}.nav-mobile-lang{justify-content:center;padding-top:.4rem}.hero,.hero-compact{min-height:88vh;padding:7rem 1rem 3rem;align-items:flex-end}.hero:before{height:110px}.hero h1{font-size:clamp(2.35rem,11vw,3.4rem);line-height:1.02;max-width:100%}.hero p{font-size:.97rem;max-width:100%}.hero-tag,.section-label{font-size:.68rem;letter-spacing:.14em}.hero-btns{flex-direction:column}.hero-trust{flex-direction:column;align-items:stretch}.btn-primary,.btn-outline{width:100%;min-height:50px;padding:.9rem 1rem}.section{padding:4.25rem 1rem}.section-title{font-size:clamp(1.8rem,8vw,2.4rem)}.split-grid{gap:2rem}.cards-grid,.zones-grid,.intro-stats,.proceso-steps,.projects-grid{grid-template-columns:1fr}.intro-stats{gap:1rem}.stat-box,.contact-card,.service-card,.testimonio{padding:1.4rem}.service-card h3{font-size:1.2rem}.image-card img{height:320px}.image-badge{right:.75rem;bottom:.75rem;max-width:132px;padding:.9rem;font-size:.88rem}.zone{padding:1.5rem 1rem}.proceso-steps{gap:1.25rem}.step{padding:1.25rem 1rem;border:1px solid var(--border-soft);background:#ffffff73}.testimonios-grid{gap:1rem}.cta-section{padding:4.5rem 1rem}.cta-section h2{font-size:clamp(1.9rem,8vw,2.6rem)}.cta-section p{font-size:.95rem}.contact-form-grid{grid-template-columns:1fr}.contact-form-actions,.contact-form-actions .btn-primary,.contact-form-actions .btn-secondary{width:100%}.contact-grid{gap:1rem}.site-footer{padding:3rem 1rem 2rem}.footer-grid{gap:2rem;padding-bottom:2rem}.footer-bottom{flex-direction:column;text-align:center}.footer-legal-links{justify-content:center}.whatsapp-btn{right:1rem;bottom:1rem;width:52px;height:52px}}
