:root{--ink:#0A0A0A;--muted:#5f6368;--sub:#374151;--bg:#ffffff;--paper:#f6f7fb;--border:#e5e7eb;--accent:#0a84ff;--accent2:#0ea5a3;--accent3:#6b8e23;--cta:#111}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;overflow-x:hidden;background:#fff;color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,'Inter','Segoe UI',Roboto,Arial,sans-serif;line-height:1.65}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.container{max-width:1160px;margin:0 auto;padding:0 24px}
.reveal{opacity:0;transform:translateY(10px);transition:opacity .6s ease, transform .6s ease}.reveal.in{opacity:1;transform:none}
header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.7);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}
nav a{font-weight:600;color:#1f2937;opacity:.85;padding:10px;border-radius:10px}nav a:hover{background:#f6f7fb;opacity:1}
.nav-cta{display:none}
.hamb{display:none}
@media (min-width:981px){.nav-cta{display:inline-flex;align-items:center;gap:10px;border-radius:10px;padding:8px 12px;background:#fff;color:#111;border:1px solid var(--border);font-weight:800}.nav-cta:hover{background:#f6f7fb}}
.hero{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center;padding:56px 0 40px;min-height:92vh}
.kicker{text-transform:uppercase;letter-spacing:.06em;color:var(--accent2);font-weight:800;font-size:12px;margin-bottom:6px}
h1.title{font-weight:900;font-size:clamp(34px,5vw,68px);line-height:1.06;margin:8px 0 12px;letter-spacing:-.01em;transform-origin:left top}
h1.title.grad{color:transparent;background-image:linear-gradient(90deg, rgba(14,165,163,var(--title-alpha,.45)), rgba(10,132,255,var(--title-alpha,.45)));-webkit-background-clip:text;background-clip:text}
.lead{font-size:clamp(16px,2.2vw,20px);color:#1f2937;max-width:760px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.chip{border:1px solid var(--border);border-radius:999px;padding:6px 10px;font-size:12px;color:#374151;background:#fff}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn{display:inline-flex;align-items:center;gap:10px;border-radius:14px;padding:12px 16px;font-weight:800;border:1px solid #111;transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease}
.btn.primary{background:var(--cta);color:#fff;border-color:var(--cta)}.btn.primary:hover{transform:translateY(-1px);box-shadow:0 10px 30px rgba(0,0,0,.12)}
.btn.ghost{background:#fff;color:#111;border-color:var(--border)}.btn.ghost:hover{background:#f6f7fb}
.meta{font-size:13px;color:#6b7280;margin-top:8px}
.hero-figure{position:relative;isolation:isolate}.hero-figure .blob{position:absolute;inset:auto -10% -8% -10%;height:58%;background:radial-gradient(60% 60% at 50% 50%, #0ea5a31a 0%, transparent 70%)}
.hero-figure .frame{position:relative;border:1px solid var(--border);border-radius:28px;overflow:hidden;background:linear-gradient(180deg,#fafafa,#f3f4f6);
  -webkit-mask-image: radial-gradient(70% 70% at 50% 50%, #000 98%, transparent 100%); mask-image: radial-gradient(70% 70% at 50% 50%, #000 98%, transparent 100%)}
.hero-figure img{width:100%;height:100%;object-fit:cover;opacity:1}
.photo{position:relative;border-radius:32px;overflow:hidden;border:1px solid var(--border);background:#fff}
.photo img{display:block;width:100%;height:auto;max-height:420px;object-fit:cover}
@media (max-width:640px){.photo img{max-height:320px}}
.media{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}
.media .text{order:1}.media .photo{order:2}
.selfcheck{padding:44px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.selfcheck .head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}
.selfcheck h2{margin:0;font-weight:800;font-size:clamp(22px,3.2vw,36px)}
.bar{height:10px;background:#f3f4f6;border-radius:999px;overflow:hidden;border:1px solid var(--border)}.bar .fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent3),var(--accent2))}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.opt{user-select:none;border:1px solid var(--border);border-radius:16px;padding:14px;background:#fff;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start;line-height:1.5;transition:background .2s ease,border-color .2s ease, box-shadow .2s ease}
.opt input{appearance:none;width:20px;height:20px;border:2px solid #9ca3af;border-radius:6px;margin-top:2px;display:grid;place-items:center;transition:border-color .2s ease, background .2s ease}
.opt input:checked{border-color:#2563eb;background:#2563eb}.opt input:checked::after{content:'✓';font-size:14px;color:#fff;line-height:1}
.opt[aria-checked="true"]{border-color:#c7d2fe;background:#f8fafc;box-shadow:0 8px 22px rgba(0,0,0,.06)}
.score{display:flex;align-items:center;gap:10px;margin-top:12px;color:#374151}.score .pill{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:800}.score .pill .num{color:#6b8e23}
.self-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
section{padding:48px 0}.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:12px}
.section-head h2{font-weight:800;font-size:clamp(22px,3.2vw,36px);margin:0}.section-head .underline{height:3px;background:linear-gradient(90deg,var(--accent3),var(--accent2));flex:1;margin-left:16px;border-radius:2px;opacity:.4}
.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start}
.card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px}
.benefits{columns:2;column-gap:20px;margin:6px 0 0 0}
.benefits li{break-inside:avoid;margin:6px 0}
.faq details{background:#fff;border:1px solid var(--border);border-radius:12px;margin:10px 0;overflow:hidden}
.faq summary{cursor:pointer;font-weight:800;list-style:none;padding:14px 16px}.faq summary::-webkit-details-marker{display:none}
.faq .content{padding:0 16px 14px 16px;max-height:0;transition:max-height .35s ease}details[open] .content{max-height:320px}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.form{display:grid;gap:10px} .form input,.form textarea{padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.form button{background:#111;color:#fff;border:1px solid #111;border-radius:12px;padding:12px 16px;font-weight:800}
.map iframe{width:100%;height:380px;border:0;border-radius:12px;border:1px solid var(--border)}
.map .fallback{display:none}.map.fallback-active .fallback{display:block}
.sticky-whatsapp{position:fixed;right:16px;bottom:16px;z-index:50}
.sticky-whatsapp a{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#062;padding:12px 14px;border-radius:999px 999px 999px 12px;font-weight:900;border:0;box-shadow:0 10px 30px rgba(0,0,0,.15)}
.sticky-whatsapp a .badge{width:16px;height:16px;border-radius:999px;background:#fff;color:#25D366;display:grid;place-items:center;font-size:11px;font-weight:900}
.sticky-whatsapp a:hover{transform:translateY(-1px);box-shadow:0 14px 36px rgba(0,0,0,.18)}
footer{padding:36px 0;color:#6b7280;border-top:1px solid var(--border)}.site-footer{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.f-brand{font-weight:900;color:#111}.sns{display:flex;gap:12px;margin-top:8px}.sns a{width:36px;height:36px;border:1px solid var(--border);border-radius:999px;display:grid;place-items:center;background:#fff}
.sns a:hover{background:#f6f7fb}
@media (max-width:980px){
  .brand{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
  .hamb{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:#fff;font-weight:800}
  header.site .nav{position:relative}
  header.site nav{display:none;position:absolute;left:0;right:0;top:64px;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 10px 30px rgba(0,0,0,.06);padding:8px 16px}
  header.site nav.open{display:block}
  header.site nav a{display:block;padding:12px 8px;margin:2px 0}
  .nav-cta{display:none}
  .selfcheck .grid{grid-template-columns:repeat(2,1fr)}
  #testimonios .grid-2{grid-template-columns:1fr!important}
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:24px}
  .media{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .container{padding:0 18px}
  h1.title{font-size: clamp(32px,10vw,46px);line-height:1.08}
  .selfcheck .grid{grid-template-columns:1fr}
}

@media (max-width:640px){
  .selfcheck .head{flex-direction:column; align-items:flex-start}
  .score{width:100%; display:grid; grid-template-columns:auto 1fr; gap:8px; text-align:left}
  .guidance{white-space:normal; overflow-wrap:anywhere}
}

@media (max-width:640px){
  .site-footer{grid-template-columns:1fr}
  .sns{flex-direction:column; align-items:flex-start}
  .sns a{width:42px;height:42px}
}

.cookiebar{position:fixed;left:0;right:0;bottom:0;z-index:70;background:#0a0a0a;color:#fff}
.cookiebar .cookie-inner{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:10px 16px}
.cookiebar .cookie-text{font-size:13px;opacity:.9}
.cookiebar .cookie-more{color:#fff;text-decoration:underline}
.cookiebar .cookie-accept{background:#fff;color:#111;border:0;font-weight:900;border-radius:12px;padding:8px 12px}
@media (max-width:640px){ .cookiebar .cookie-inner{flex-direction:column;align-items:flex-start} }


/* v1.2.4: mobile fix for #como-funciona overflow */
@media (max-width:980px){
  #como-funciona .grid-2{grid-template-columns:1fr!important}
}
@media (max-width:640px){
  #como-funciona .photo,
  #como-funciona .card{max-width:100%!important;width:100%!important;overflow:hidden!important}
  #como-funciona .photo img{display:block;max-width:100%!important;width:100%!important;height:auto!important;object-fit:cover}
  /* extra safety against any inline spacing */
  #como-funciona .grid-2{gap:18px!important}
}
