/*
Theme Name: Nura Landing
Author: Enrique
Version: 1.0
Text Domain: nura-landing
*/

:root{
  --bg: #ffffff;
  --ink: #0f1e1a;
  --muted:#50635d;
  --line:#e7efec;
  --soft:#eef6f3;
  --soft2:#f6fbf9;
  --brand:#0b6b4f;
  --brand2:#0a5f45;
  --pill:#f2f7f5;
  --shadow: 0 18px 45px rgba(12, 43, 33, .10);
  --shadow2: 0 12px 25px rgba(12, 43, 33, .08);
  --r1: 26px;
  --r2: 22px;
  --max: 1180px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
  letter-spacing:.1px;
}

a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max); margin:0 auto; padding:0 22px;}

/* --- Utility spacing for WP sections (avoid inline styles) --- */
.sectionPad{padding:0 0 92px}
.sectionPadTight{padding:0 0 76px}

/* --- Form + layout helpers (Pricing / Contact) --- */
.pricingTitle{margin-bottom:10px}
.leadWide{max-width:760px}
.btnRow{display:flex; gap:14px; flex-wrap:wrap; margin-top:18px}
.btn.pill{background:var(--pill); color:#163029}

.contactGrid{display:grid; grid-template-columns: 1.1fr .9fr; gap:18px; margin-top:18px}
.formCard{border:1px solid rgba(231,239,236,.95); border-radius:18px; padding:16px; background:#fff}
.sideCard{border:1px solid rgba(231,239,236,.95); border-radius:18px; padding:16px; background:linear-gradient(180deg, #fff, #fbfdfc)}
.formGrid{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.field label{font-size:12px; color:var(--muted); font-weight:700}
.field input,.field select,.field textarea{
  width:100%; margin-top:6px; padding:12px 12px;
  border-radius:12px; border:1px solid var(--line);
  outline:none; font:inherit; color:inherit; background:#fff;
}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color: rgba(11,107,79,.45);
  box-shadow: 0 0 0 4px rgba(11,107,79,.10);
}
.formActions{display:flex; gap:12px; flex-wrap:wrap; margin-top:12px}
.finePrint{margin:10px 0 0; color:var(--muted); font-size:12px; line-height:1.5}

/* --- Mobile menu overlay --- */
.mnavOverlay{position:fixed; inset:0; background:rgba(8,16,14,.45); z-index:55; display:grid; place-items:center; padding:22px}
.mnavCard{width:min(520px,100%); background:#fff; border:1px solid rgba(231,239,236,.95); border-radius:18px; box-shadow: 0 24px 70px rgba(0,0,0,.20); padding:12px}
.mnavTop{display:flex; align-items:center; justify-content:space-between; padding:6px 6px 10px}
.mnavClose{width:40px;height:40px;border-radius:12px;border:1px solid rgba(231,239,236,.95);background:#fff;cursor:pointer}
.mnavLinks{display:grid; gap:8px; padding:6px}
.mnavLinks a{padding:12px 12px;border-radius:14px;background:var(--pill)}

/* --- Header --- */
header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid rgba(231,239,236,.75);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  gap:18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:auto;
}
.logo{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  overflow:hidden;
  background:transparent;
}
.logoImg{width:56px;height:56px;display:block;object-fit:contain}

.menu{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px;
  border-radius:999px;
  background:transparent;
}

.menu .navlink, .menu .navbtn{
  font-family:Inter, sans-serif;
  font-size:15px;
  padding:10px 16px;
  border-radius:999px;
  border:0;
  background:transparent;
  color:#17302a;
  cursor:pointer;
  transition:background .18s ease, transform .12s ease;
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}

.menu .navlink.active, .menu .navbtn.active{ background:var(--pill); }
.menu a:hover, .menu button:hover{background:var(--pill)}
.menu a:active, .menu button:active{transform:translateY(1px)}

/* dropdown */
.dd{position:relative}

.ddpanel{
  position:absolute;
  top:52px;
  right:0;
  width:min(560px, calc(100vw - 40px));
  background:linear-gradient(180deg, #ffffff 0%, #fbfdfc 100%);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow2);
  padding:12px;
  display:none;
  z-index:80;
}
.ddpanel.open{display:block}

.ddMega{
  display:grid;
  grid-template-columns: 1fr 1.25fr;
  gap:12px;
}

.ddLeft{
  border:1px solid var(--line);
  border-radius:16px;
  background:linear-gradient(180deg, #ffffff, #fbfdfc);
  padding:14px;
}
.ddLeft .ttl{font-family:Poppins, Inter, sans-serif;font-weight:800;margin:0 0 6px;font-size:16px}
.ddLeft .sub{margin:0 0 12px;color:var(--muted);font-size:12.5px;line-height:1.5}
.ddLeft .mini{display:flex;gap:10px;flex-wrap:wrap}
.ddLeft .pillBtn{padding:10px 12px;border-radius:14px;background:var(--pill);border:1px solid var(--line);font-weight:700;font-size:12.5px}

.ddgrid{display:grid;grid-template-columns:1fr;gap:10px}
.dditem{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#fbfdfc);border-radius:14px;padding:12px;display:flex;gap:10px;align-items:flex-start}
.ddicon{width:36px;height:36px;border-radius:12px;background:var(--soft);display:grid;place-items:center;color:var(--brand);flex:0 0 36px;font-size:16px}
.dditem b{display:block;font-family:Poppins, Inter, sans-serif;font-size:14px;margin-bottom:2px}
.dditem small{display:block;color:var(--muted);font-size:12px;line-height:1.3}

.hamb{
  display:none;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
}

/* --- Hero --- */
.hero{
  padding:64px 0 28px;
  border-bottom:1px solid rgba(231,239,236,.85);
}

.heroGrid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:36px;
  align-items:center;
}

.kicker{
  color:var(--brand);
  font-weight:700;
  letter-spacing:.14em;
  font-size:13px;
}

h1{
  font-family:Poppins, Inter, sans-serif;
  font-size:64px;
  line-height:1.06;
  margin:16px 0 18px;
  letter-spacing:-.02em;
}

.lead{
  color:var(--muted);
  font-size:16px;
  line-height:1.9;
  max-width:520px;
  margin:0;
}

.ctaRow{
  display:flex;
  align-items:center;
  gap:18px;
  margin-top:28px;
  flex-wrap:wrap;
}

.btn{
  border:0;
  cursor:pointer;
  border-radius:12px;
  padding:14px 18px;
  font-weight:700;
  font-size:15px;
  transition:transform .12s ease, filter .18s ease;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--brand); color:#fff; box-shadow: 0 10px 22px rgba(11,107,79,.18)}
.btn.primary:hover{filter:brightness(.98)}
.btn.ghost{background:transparent; color:#163029}

.play{
  width:22px;height:22px;border-radius:999px;
  border:1px solid rgba(22,48,41,.30);
  display:grid;place-items:center;
}
.play svg{width:10px;height:10px;transform:translateX(1px)}

/* right hero card (image + quote) */
.heroCard{
  position:relative;
  background:linear-gradient(180deg, var(--soft), #e8f3ef);
  border-radius:34px;
  padding:24px;
  box-shadow:var(--shadow);
  overflow:hidden;
  min-height:420px;
}
.leaf{
  position:absolute;
  inset:0;
  opacity:.28;
  pointer-events:none;
}
.heroImg{
  width:100%;
  height:330px;
  border-radius:26px;
  overflow:hidden;
  display:block;
  background:#dfeee8;
}
.heroImg img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
}

.quoteBox{
  position:absolute;
  left:24px;
  right:24px;
  bottom:22px;
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(231,239,236,.85);
  box-shadow:var(--shadow2);
  padding:18px 18px 18px 62px;
}

.quoteMark{
  position:absolute;
  left:18px;
  top:16px;
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  color:var(--brand);
}

.quoteBox p{
  margin:0;
  color:var(--muted);
  font-size:14px;
  line-height:1.8;
}

/* logos row */
.logos{ padding:26px 0 46px; }
.logoRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:22px 0;
  opacity:.9;
  flex-wrap:wrap;
}
.miniLogo{
  width:160px;
  min-width:140px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:#2c4a42;
  padding:10px 12px;
}
.miniLogo svg{width:38px;height:38px; opacity:.9}
.miniLogo span{font-weight:700; letter-spacing:.25em; font-size:11px}

/* Section card */
.sectionCard{
  background:linear-gradient(180deg, var(--soft), #e7f2ee);
  border-radius:34px;
  padding:38px 44px;
  box-shadow:var(--shadow2);
  border:1px solid rgba(231,239,236,.85);
}

/* Expertise */
.expertise{padding:22px 0 54px}
.expGrid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:34px;
  align-items:start;
}
.hLabel{
  color:var(--brand);
  font-weight:700;
  letter-spacing:.14em;
  font-size:12px;
  margin-bottom:10px;
}
.expTitle{
  font-family:Poppins, Inter, sans-serif;
  font-size:44px;
  line-height:1.1;
  margin:0;
  letter-spacing:-.02em;
}

.bars{padding-top:10px}
.bar{
  display:grid;
  grid-template-columns: 1fr auto;
  gap:10px;
  align-items:center;
  padding:14px 0;
  border-bottom:1px solid rgba(231,239,236,.75);
}
.bar:last-child{border-bottom:0}
.bar label{font-weight:600}
.bar .val{color:#1e3a33; font-weight:700}
.track{grid-column:1 / -1; height:6px; background:rgba(11,107,79,.12); border-radius:999px; overflow:hidden}
.fill{height:100%; background:var(--brand); border-radius:999px}

/* Video block */
.video{padding:0 0 54px}
.videoFrame{
  margin-top:22px;
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(231,239,236,.85);
  box-shadow:var(--shadow);
  position:relative;
  background:#ddebe6;
  height:420px;
}
.videoFrame img{width:100%; height:100%; object-fit:cover; display:block; filter:saturate(1.05)}
.bigPlay{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
}
.bigPlay button{
  width:66px;height:66px;
  border-radius:999px;
  border:0;
  cursor:pointer;
  background:#fff;
  box-shadow: 0 16px 35px rgba(0,0,0,.16);
  display:grid;place-items:center;
}
.bigPlay svg{width:18px;height:18px; transform:translateX(2px)}

/* Testimonials */
.testimonials{padding:10px 0 70px}
.tGrid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:34px;
  align-items:start;
}
.stats{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding-top:6px;
  flex-wrap:wrap;
}
.stat{
  min-width:160px;
  text-align:center;
}
.stat .ico{
  width:44px;height:44px;border-radius:16px;
  background:rgba(11,107,79,.10);
  display:grid;place-items:center;
  margin:0 auto 10px;
  color:var(--brand);
}
.stat b{
  display:block;
  font-family:Poppins, Inter, sans-serif;
  font-size:42px;
  letter-spacing:-.02em;
}
.stat small{color:var(--muted); font-weight:600}

.tCard{
  position:relative;
  border-radius:34px;
  overflow:hidden;
  border:1px solid rgba(231,239,236,.85);
  box-shadow:var(--shadow);
  background:linear-gradient(180deg, var(--soft), #e8f3ef);
  min-height:420px;
}
.tCard .leaf{opacity:.26}
.tImg{
  position:absolute;
  left:0; right:0;
  bottom:-18px;
  height:310px;
}
.tImg img{width:100%; height:100%; object-fit:cover; object-position:center 20%; display:block}
.tQuote{
  position:absolute;
  right:20px;
  left:46%;
  top:52%;
  transform:translateY(-10%);
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(231,239,236,.85);
  box-shadow:var(--shadow2);
  padding:18px 18px 18px 62px;
}
.tQuote .quoteMark{top:14px}
.tQuote p{margin:0; color:var(--muted); font-size:14px; line-height:1.85}
.tQuote strong{display:block; margin-top:10px; color:#163029}

/* Services list */
.services{padding:0 0 90px}
.servicesHead{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  margin-bottom:18px;
}

.pillLink{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  background:var(--mint);
  border:1px solid var(--line);
  color:var(--ink);
  font-weight:700;
  text-decoration:none;
  white-space:nowrap;
}
.pillLink:hover{filter:brightness(0.98)}
.servicesHead h2{
  font-family:Poppins, Inter, sans-serif;
  font-size:44px;
  line-height:1.05;
  margin:0;
  letter-spacing:-.02em;
}
.servicesHead .btn{padding:12px 16px; border-radius:10px}

.serviceCard{
  background:#fff;
  border:1px solid rgba(231,239,236,.95);
  border-radius:22px;
  box-shadow:var(--shadow2);
  padding:18px 20px;
  display:grid;
  grid-template-columns: 90px 120px 1fr 52px;
  gap:16px;
  align-items:center;
  margin:16px 0;
}
.num{
  font-family:Poppins, Inter, sans-serif;
  font-size:34px;
  font-weight:800;
  color:#1f3c34;
  opacity:.85;
}
.thumb{
  width:120px;
  height:74px;
  border-radius:12px;
  overflow:hidden;
  background:#e6f1ed;
  border:1px solid rgba(231,239,236,.95);
}
.thumb img{width:100%; height:100%; object-fit:cover; display:block}
.svc b{display:block; font-size:18px; font-family:Poppins, Inter, sans-serif; margin-bottom:6px}
.svc p{margin:0; color:var(--muted); font-size:14px; line-height:1.65; max-width:620px}
.go{
  width:42px;height:42px;border-radius:999px;
  border:1px solid rgba(231,239,236,.95);
  display:grid;place-items:center;
  background:linear-gradient(180deg, #fff, #fbfdfc);
  cursor:pointer;
  transition:transform .12s ease, background .18s ease;
}
.go:hover{background:var(--soft2)}
.go:active{transform:translateY(1px)}

/* Footer */
footer{
  border-top:1px solid rgba(231,239,236,.85);
  padding:26px 0 34px;
  color:var(--muted);
}
.foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}

/* Modal */
.modal{
  position:fixed;
  inset:0;
  background:rgba(8, 16, 14, .55);
  display:none;
  place-items:center;
  padding:22px;
  z-index:60;
}
.modal.open{display:grid}
.modalCard{
  width:min(920px, 100%);
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(231,239,236,.25);
  box-shadow:0 24px 70px rgba(0,0,0,.25);
  background:#000;
  position:relative;
}
.modalClose{
  position:absolute;
  right:12px;
  top:12px;
  width:40px;height:40px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
  display:grid;place-items:center;
}
.modalClose:hover{background:rgba(255,255,255,.12)}
.modalInner{aspect-ratio: 16/9; width:100%;}
.modalInner iframe{width:100%; height:100%; border:0}

/* Responsive */
@media (max-width: 980px){
  h1{font-size:50px}
  .heroGrid, .expGrid, .tGrid{grid-template-columns:1fr;}
  .heroCard{min-height:460px}
  .tQuote{left:22px; right:22px; top:58%; transform:none}
  .serviceCard{grid-template-columns: 70px 110px 1fr 52px}
  .brand{min-width:auto}
  .contactGrid{grid-template-columns:1fr}
}

@media (max-width: 760px){
  .menu{display:none}
  .hamb{display:inline-flex}
  /* Logos m¨¢s visibles en m¨®vil */
  .logoImg{width:46px;height:46px}
  .hero{padding:38px 0 18px}
  h1{font-size:42px}
  .sectionCard{padding:26px 20px}
  .videoFrame{height:320px}
  .serviceCard{grid-template-columns: 1fr; align-items:start}
  .thumb{width:100%; height:170px}
  .go{justify-self:flex-end}
  .num{font-size:26px}
  .ctaRow{gap:10px}
  .btn{width:fit-content}
  .ddpanel{width:min(520px, calc(100vw - 24px)); right:-6px}
  .ddMega{grid-template-columns:1fr}

  /* Head de servicios: evitar que el CTA se salga de pantalla */
  .servicesHead{flex-wrap:wrap;gap:14px}
  .pillLink{margin-left:0}

  /* Pricing/Contact on mobile */
  .btnRow .btn{width:100%; justify-content:center}
  .contactGrid{grid-template-columns:1fr}
  .formGrid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important; transition:none !important; animation:none !important}
}

html{scroll-behavior:smooth}

/* ================================
   FIX: Submen¨² m¨®vil "Servicios"
   (details/summary) sin overlays
   ================================ */

.mnavLinks details.mnavDetails{
  display:block;
  width:100%;
}

/* Que "Servicios" se vea como los dem¨¢s botones del men¨² */
.mnavLinks details.mnavDetails > summary{
  list-style:none;
  background: var(--pill);
  padding: 12px 14px;
  border-radius: 14px;
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight: 600;
  user-select: none;
}

/* Quita el marcador default */
.mnavLinks details.mnavDetails > summary::-webkit-details-marker{ display:none; }

/* Flecha SIN caracteres raros (hecha con bordes CSS) */
.mnavLinks details.mnavDetails > summary::after{
  content:"";
  width:10px;
  height:10px;
  margin-left:12px;
  border-right:2px solid rgba(15,30,26,.65);
  border-bottom:2px solid rgba(15,30,26,.65);
  transform: rotate(-45deg);
  transition: transform .18s ease;
  flex: 0 0 10px;
}

/* Al abrir: rota para verse como flecha hacia abajo */
.mnavLinks details.mnavDetails[open] > summary::after{
  transform: rotate(45deg);
}

/* Contenedor de links del submen¨² */
.mnavLinks .mnavSub{
  display:grid;
  gap: 8px;
  margin-top: 8px;
  padding: 0 6px 6px;
}

/* Links del submen¨²: separados, sin encimarse */
.mnavLinks .mnavSub a{
  background:#fff;
  border:1px solid var(--line);
  box-shadow:none;
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 14px;
}
