/* MAPECO — Marbella Pest Control
   Palette: deep forest #13241a · lime #c1ff72 · off-white #f7f9f4
   Type: Barlow Condensed (display) · Fira Sans (body) */
:root{
  --ink:#13241a; --ink-2:#1c3326; --ink-3:#24402f;
  --lime:#c1ff72; --lime-d:#a6e84e;
  --paper:#f7f9f4; --soft:#eef3e6; --line:#dde7cb;
  --text:#33402f; --muted:#6b7363; --white:#fff;
  --r:14px; --r-lg:22px; --max:1160px;
  --shadow:0 18px 50px -24px rgba(19,36,26,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Fira Sans",system-ui,sans-serif;color:var(--text);background:var(--paper);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg,iframe{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:min(var(--max),92%);margin-inline:auto}
h1,h2,h3{font-family:"Barlow Condensed",sans-serif;line-height:1.04;color:var(--ink);font-weight:700;letter-spacing:.2px}
h1{font-size:clamp(2.5rem,6vw,4.4rem);text-transform:none}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:1.45rem;font-weight:600}
p{max-width:65ch}
.eyebrow{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.28em;
  font-weight:600;font-size:.82rem;color:var(--lime);margin-bottom:.6rem}
.eyebrow--c{color:var(--ink-3)}
.h2c{text-align:center;margin-inline:auto}
.h2c--l{text-align:left}
.lead-c{text-align:center;max-width:62ch;margin:.8rem auto 2.4rem;color:var(--muted)}
.section{padding:clamp(3.5rem,8vw,6rem) 0}
.section .eyebrow{text-align:center;display:block}
.section--dark{background:var(--ink);color:#cfe0c2}
.section--dark h2,.section--dark .eyebrow{color:var(--white)}
.section--dark .eyebrow{color:var(--lime)}
.section--soft{background:var(--soft)}

/* buttons */
.btn{--bg:var(--lime);display:inline-flex;align-items:center;gap:.5rem;font-family:"Barlow Condensed",sans-serif;
  font-weight:600;font-size:1.05rem;letter-spacing:.04em;text-transform:uppercase;padding:.85rem 1.5rem;
  border-radius:999px;background:var(--bg);color:var(--ink);border:2px solid var(--bg);cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s,background .2s,color .2s;line-height:1}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(19,36,26,.5)}
.btn--lime{--bg:var(--lime)}
.btn--wa{--bg:#25d366;border-color:#25d366;color:#06281a}
.btn--ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
.btn--ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn--full{width:100%;justify-content:center;padding:1rem;font-size:1.15rem}
.section .btn--ghost{color:var(--ink);border-color:var(--ink)}

/* header */
.skip{position:absolute;left:-999px}
.skip:focus{left:1rem;top:1rem;z-index:200;background:var(--lime);padding:.6rem 1rem;border-radius:8px}
.hdr{position:sticky;top:0;z-index:100;background:rgba(247,249,244,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.hdr__row{display:flex;align-items:center;gap:1.2rem;padding:.7rem 0;min-height:68px}
.brand{display:flex;align-items:center;gap:.6rem}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__txt strong{font-family:"Barlow Condensed",sans-serif;font-size:1.5rem;letter-spacing:.06em;color:var(--ink)}
.brand__txt small{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.nav{margin-left:auto}
.nav__toggle{display:none;align-items:center;gap:.5rem;background:none;border:0;font-family:"Barlow Condensed",sans-serif;
  font-size:1.1rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink)}
.nav__toggle span{width:22px;height:2px;background:var(--ink);position:relative}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--ink)}
.nav__toggle span::before{top:-6px}.nav__toggle span::after{top:6px}
.nav__menu{display:flex;gap:.3rem;list-style:none;align-items:center}
.nav__menu>li>a{display:block;padding:.5rem .8rem;border-radius:8px;font-weight:500;font-size:.97rem;color:var(--ink);transition:background .2s}
.nav__menu>li>a:hover{background:var(--soft)}
.has-sub{position:relative}
.sub{position:absolute;top:100%;left:0;min-width:230px;background:var(--white);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);padding:.5rem;list-style:none;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:.22s var(--ease)}
.has-sub:hover .sub,.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateY(0)}
.sub a{display:block;padding:.55rem .8rem;border-radius:8px;font-size:.94rem}
.sub a:hover{background:var(--soft);color:var(--ink-3)}
.hdr__cta{padding:.6rem 1.1rem;font-size:.95rem}

/* hero */
.hero{position:relative;background:var(--ink);color:#d8e6cd;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:
  radial-gradient(900px 500px at 80% -10%,rgba(193,255,114,.16),transparent 60%),
  radial-gradient(700px 600px at 0% 100%,rgba(36,64,47,.9),transparent 55%);}
.hero__bg::after{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(circle at 70% 30%,#000,transparent 70%)}
.hero__in{position:relative;padding:clamp(3.5rem,9vw,6.5rem) 0 clamp(3rem,7vw,5rem)}
.hero h1{color:var(--white);max-width:16ch}
.hero h1 span{color:var(--lime)}
.hero__lead{margin:1.4rem 0 2rem;font-size:1.18rem;max-width:54ch;color:#cadbbd}
.hero__btns{display:flex;gap:.9rem;flex-wrap:wrap}
.trust{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem;
  border-top:1px solid rgba(255,255,255,.14);padding-top:1.8rem;max-width:760px}
.trust li{display:flex;flex-direction:column}
.trust strong{font-family:"Barlow Condensed",sans-serif;font-size:1.7rem;color:var(--lime);line-height:1}
.trust span{font-size:.86rem;color:#aebfa1}

/* services grid */
.svc__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.1rem}
.svc{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem 1.5rem;
  display:flex;flex-direction:column;gap:.5rem;transition:transform .28s var(--ease),box-shadow .28s,border-color .28s;position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:var(--lime);transform:scaleY(0);transform-origin:top;transition:transform .3s var(--ease)}
.svc:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.svc:hover::before{transform:scaleY(1)}
.svc__ic{width:52px;height:52px;border-radius:12px;background:var(--soft);color:var(--ink-3);
  display:grid;place-items:center;transition:background .25s,color .25s}
.svc:hover .svc__ic{background:var(--ink);color:var(--lime)}
.svc h3{margin-top:.4rem}
.svc p{color:var(--muted);font-size:.95rem;flex:1}
.svc__more{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.05em;
  font-weight:600;color:var(--ink-3);font-size:.92rem}

/* about row */
.about__row{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:center}
.about__row p{color:#cfe0c2;margin:1rem 0 1.6rem}
.about__points{list-style:none;display:grid;gap:.8rem}
.about__points li{padding-left:2rem;position:relative;color:#e6f0dc}
.about__points li::before{content:"";position:absolute;left:0;top:.45em;width:1.1rem;height:1.1rem;
  border-radius:50%;background:var(--lime);box-shadow:0 0 0 4px rgba(193,255,114,.18)}

/* sectors */
.sector__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.sector{background:var(--paper);padding:1.6rem}
.sector h3{font-size:1.2rem;margin-bottom:.3rem}
.sector p{color:var(--muted);font-size:.93rem}

/* cta band */
.cta{background:var(--lime);color:var(--ink)}
.cta__in{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:2.6rem 0;flex-wrap:wrap}
.cta h2{font-size:clamp(1.7rem,3.5vw,2.4rem)}
.cta p{margin-top:.3rem;font-weight:500}
.cta__btns{display:flex;gap:.8rem;flex-wrap:wrap}
.cta .btn--ghost{color:var(--ink);border-color:var(--ink)}
.cta .btn--ghost:hover{background:rgba(19,36,26,.08)}

/* page hero (services/about/contact) */
.phero{background:var(--ink);color:#d3e3c7;padding:clamp(2.6rem,6vw,4.5rem) 0 clamp(2.4rem,5vw,3.5rem);position:relative;overflow:hidden}
.phero::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 90% -20%,rgba(193,255,114,.12),transparent 60%)}
.phero>.wrap{position:relative}
.phero h1{color:var(--white);max-width:18ch}
.phero__sub{color:var(--lime);font-weight:600;margin-top:.6rem;font-size:1.1rem}
.phero__lead{margin-top:1rem;max-width:60ch;color:#cadbbd;font-size:1.08rem}
.phero .hero__btns{margin-top:1.6rem}
.crumbs{font-size:.85rem;color:#9fb293;margin-bottom:1.2rem}
.crumbs a:hover{color:var(--lime)}
.crumbs span{opacity:.5;margin:0 .2rem}
.crumbs strong{color:#d3e3c7;font-weight:600}

/* split: signs + why */
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:start}
.checklist{list-style:none;display:grid;gap:.7rem;margin-top:1.4rem}
.checklist li{padding-left:2.1rem;position:relative;color:var(--text)}
.checklist li::before{content:"";position:absolute;left:0;top:.35em;width:1.25rem;height:1.25rem;border-radius:6px;
  background:var(--lime);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/80% no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/80% no-repeat;}
.why{background:var(--ink);color:#d3e3c7;border-radius:var(--r-lg);padding:2rem 1.9rem}
.why h2{color:var(--white);font-size:1.9rem;margin-bottom:1rem}
.why__list{list-style:none;display:grid;gap:.9rem}
.why__list li{padding-left:1.6rem;position:relative;font-size:.98rem}
.why__list li::before{content:"";position:absolute;left:0;top:.6em;width:.5rem;height:.5rem;border-radius:50%;background:var(--lime)}
.why__list em{color:var(--lime);font-style:italic}

/* process steps */
.steps{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem;counter-reset:s}
.step{display:flex;gap:1rem;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem}
.step__n{font-family:"Barlow Condensed",sans-serif;font-size:1.6rem;font-weight:700;color:var(--lime-d);
  background:var(--ink);width:auto;min-width:2.6rem;height:2.6rem;border-radius:10px;display:grid;place-items:center;flex:none}
.step h3{font-size:1.15rem;margin-bottom:.3rem}
.step p{color:var(--muted);font-size:.93rem}

/* faq */
.faq{max-width:820px;margin-inline:auto}
.faq__list{display:grid;gap:.7rem;margin-top:1.6rem}
.faq__item{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.faq__item summary{cursor:pointer;list-style:none;padding:1.1rem 1.4rem;font-family:"Barlow Condensed",sans-serif;
  font-size:1.25rem;font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-size:1.6rem;color:var(--lime-d);transition:transform .25s}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__a{padding:0 1.4rem 1.2rem}
.faq__a p{color:var(--muted)}

/* other links */
.otherlinks{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:1.5rem}
.otherlinks a{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:.6rem 1.2rem;
  font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.04em;font-weight:600;
  color:var(--ink);transition:.2s}
.otherlinks a:hover{background:var(--ink);color:var(--lime);border-color:var(--ink)}

/* contact */
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start}
.contact__info h2,.contact__form h2{font-size:1.9rem;margin-bottom:1.2rem}
.contact__list{list-style:none;display:grid;gap:.9rem;margin-bottom:1.6rem}
.contact__list li{display:grid;grid-template-columns:90px 1fr;gap:.6rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.contact__list span{font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:.85rem;padding-top:.15rem}
.contact__list a:hover{color:var(--ink-3)}
.map{border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.map iframe{width:100%;height:280px;border:0}

/* form */
.form{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem;display:grid;gap:1rem;box-shadow:var(--shadow)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form label{display:grid;gap:.35rem;font-size:.85rem;font-weight:600;color:var(--ink);font-family:"Barlow Condensed",sans-serif;
  text-transform:uppercase;letter-spacing:.05em}
.form input,.form select,.form textarea{font-family:inherit;font-size:1rem;padding:.75rem .85rem;border:1.5px solid var(--line);
  border-radius:10px;background:var(--paper);color:var(--text);width:100%;text-transform:none;letter-spacing:0;font-weight:400}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--lime-d);box-shadow:0 0 0 3px rgba(193,255,114,.35)}
.hp{position:absolute;left:-9999px;height:0;overflow:hidden}
.form__msg{font-size:.95rem;text-align:center;min-height:1.2em;font-weight:500}
.form__msg.ok{color:#1d7a3a}.form__msg.err{color:#b23a2e}
.form__alt{text-align:center;font-size:.9rem;color:var(--muted)}
.form__alt a{color:var(--ink-3);font-weight:600}

/* footer */
.ft{background:var(--ink);color:#aebfa1;padding-top:3.5rem}
.ft__grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:2.5rem;padding-bottom:2.5rem}
.brand--ft .brand__txt strong{color:var(--white)}
.brand--ft .brand__txt small{color:var(--lime)}
.ft__about{margin-top:1rem;font-size:.92rem;color:#9fb293}
.ft h3{color:var(--white);font-size:1.2rem;margin-bottom:1rem}
.ft__links,.ft__contact{list-style:none;display:grid;gap:.55rem;font-size:.92rem}
.ft__links a:hover{color:var(--lime)}
.ft__contact li{display:grid;grid-template-columns:80px 1fr;gap:.5rem}
.ft__contact span{color:#7d8f72;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em}
.ft__contact a:hover{color:var(--lime)}
.ft__bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.4rem 0;
  border-top:1px solid rgba(255,255,255,.12);font-size:.82rem;color:#7d8f72}
.ft__bottom a:hover{color:var(--lime)}

/* floating whatsapp */
.fab{position:fixed;right:18px;bottom:18px;z-index:90;width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;
  display:grid;place-items:center;box-shadow:0 10px 28px -8px rgba(0,0,0,.5);transition:transform .25s var(--ease)}
.fab:hover{transform:scale(1.08)}

/* reveal animation */
.section,.svc,.step,.faq__item{opacity:1}
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
  .reveal.in{opacity:1;transform:none}
}

/* responsive */
@media (max-width:900px){
  .about__row,.split,.contact__grid{grid-template-columns:1fr;gap:2rem}
  .trust{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .hdr__cta{display:none}
  .nav__toggle{display:inline-flex}
  .nav__menu{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--paper);
    border-bottom:1px solid var(--line);padding:.6rem 5%;gap:.1rem;transform:translateY(-130%);transition:transform .3s var(--ease);box-shadow:var(--shadow)}
  .nav__menu.open{transform:translateY(0)}
  .nav__menu>li>a{padding:.8rem .6rem;border-bottom:1px solid var(--line)}
  .sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:transparent;
    padding:.2rem 0 .6rem .8rem;display:grid}
  .sub a{padding:.5rem}
  .cta__in{flex-direction:column;align-items:flex-start}
}
@media (max-width:480px){
  .form__row{grid-template-columns:1fr}
  .trust{grid-template-columns:repeat(2,1fr)}
  .ft__grid{grid-template-columns:1fr}
}
.map__link{margin-top:.7rem;font-family:"Barlow Condensed",sans-serif;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.map__link a{color:var(--ink-3)}
.map__link a:hover{color:var(--lime-d)}

/* service hero with illustration */
.phero--media .phero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:2.5rem;align-items:center}
.phero__media{margin:0}
.phero__media img{width:100%;height:auto;border-radius:var(--r-lg);box-shadow:0 24px 60px -28px rgba(0,0,0,.65)}
@media (max-width:860px){
  .phero--media .phero__grid{grid-template-columns:1fr}
  .phero__media{order:-1;max-width:440px}
}
.brand__logo{border-radius:8px}
