/* ===========================================================
   e-Punto · layout.css
   Estructura de componentes por sección (compartida entre variantes)
   El color/mood lo define variants.css
   =========================================================== */

/* ---------- NAVBAR ---------- */
.nav{ position:sticky; top:0; z-index:50; background:var(--page-bg);
  border-bottom:1px solid var(--hairline); backdrop-filter:saturate(120%) blur(6px); }
.nav-inner{ display:flex; align-items:center; gap:24px; height:72px; }
.nav-logo{ display:flex; align-items:center; gap:10px; }
.nav-logo .iso{ height:30px; }
.nav-logo .wm{ font-family:var(--font-brand); font-weight:700; font-size:1.32rem; letter-spacing:-.01em; color:var(--page-fg); }
.nav-links{ display:flex; gap:28px; margin-left:18px; }
.nav-links a{ font-size:.94rem; font-weight:600; color:var(--page-fg-dim); transition:color .18s; }
.nav-links a:hover{ color:var(--accent); }
.nav-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.nav-burger{ display:none; width:42px; height:42px; border-radius:10px; border:1px solid var(--border);
  align-items:center; justify-content:center; }
.nav-burger span{ width:18px; height:2px; background:var(--page-fg); position:relative; }
.nav-burger span::before,.nav-burger span::after{ content:""; position:absolute; left:0; width:18px; height:2px; background:var(--page-fg); }
.nav-burger span::before{ top:-6px; } .nav-burger span::after{ top:6px; }

/* ---------- HERO ---------- */
.hero{ padding-top:clamp(48px,7vw,96px); padding-bottom:var(--section-py); position:relative; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; }
.hero-copy h1{ margin:.35em 0 .55em; }
.hero-copy .slug{ color:var(--accent); }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero-note{ margin-top:20px; font-size:.92rem; color:var(--page-fg-dim); display:flex; align-items:center; gap:10px; }
.hero-note .dot{ width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px color-mix(in oklab, var(--accent) 25%, transparent); }
.hero-visual{ position:relative; }
.hero-visual .ph{ aspect-ratio:4/5; min-height:340px; }
.hero-float{ position:absolute; left:-6%; bottom:8%; background:var(--surface); color:var(--surface-fg);
  border:1px solid var(--border); border-radius:var(--radius); padding:16px 18px; box-shadow:var(--shadow); backdrop-filter:blur(8px); }
.hero-float .stat-num{ font-size:2rem; }
.hero-float small{ display:block; font-size:.74rem; color:var(--surface-dim); text-transform:uppercase; letter-spacing:.14em; margin-top:2px; }

/* ---------- BANDA CREDIBILIDAD ---------- */
.band-inner{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--hairline);
  border:1px solid var(--hairline); border-radius:var(--radius-lg); overflow:hidden; }
.band-item{ background:var(--page-bg); padding:26px clamp(16px,2vw,28px); }
.band-item .stat-num{ font-size:clamp(1.9rem,3vw,2.6rem); }
.band-item p{ font-size:.86rem; color:var(--page-fg-dim); margin-top:8px; line-height:1.4; }

/* ---------- SPLIT (B2C / B2B genérico) ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.split.rev .split-media{ order:-1; }
.split-copy h2{ margin:.3em 0 .5em; }
.split-media .ph{ aspect-ratio:4/3; min-height:300px; }
.feature-list{ display:flex; flex-direction:column; gap:18px; margin-top:30px; }
.feature{ display:flex; gap:16px; align-items:flex-start; }
.feature .fico{ flex:none; width:42px; height:42px; border-radius:11px; display:flex; align-items:center; justify-content:center;
  background:color-mix(in oklab, var(--accent) 16%, transparent); color:var(--accent); }
.feature .fico svg{ width:22px; height:22px; }
.feature h4{ font-size:1.06rem; font-weight:800; color:var(--page-fg); margin-bottom:3px; }
.feature p{ font-size:.95rem; color:var(--page-fg-dim); }

/* ---------- CÓMO FUNCIONA ---------- */
.section-head{ max-width:54ch; margin-bottom:clamp(36px,4vw,56px); }
.section-head h2{ margin:.3em 0 .4em; }
.seg{ display:inline-flex; padding:5px; gap:4px; border:1px solid var(--border); border-radius:100px; background:var(--surface); }
.seg button{ font-weight:700; font-size:.92rem; padding:.6em 1.2em; border-radius:100px; color:var(--page-fg-dim); transition:.2s; }
.seg button[aria-selected="true"]{ background:var(--accent); color:var(--accent-ink); }
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); margin-top:36px; }
.step{ position:relative; display:grid; grid-template-columns:42px 1fr; column-gap:14px; row-gap:4px; }
.step.step--img{ display:block; }
.step .num{ font-family:var(--font-ui); font-weight:900; font-size:1rem; width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; background:var(--accent); color:var(--accent-ink); align-self:center; }
.step h4{ font-size:1.18rem; font-weight:800; color:var(--page-fg); margin-bottom:0; align-self:center; }
.step p{ grid-column:2; font-size:.95rem; color:var(--page-fg-dim); }

/* ---------- ALIADOS / CÁLCULO ---------- */
.aliados-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,56px); align-items:start; }
.ley-card{ border-left:3px solid var(--accent); padding:22px 26px; background:var(--surface); border-radius:var(--radius);
  margin-top:28px; }
.ley-card strong{ color:var(--accent); }
.calc{ padding:clamp(24px,3vw,36px); }
.calc h4{ font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); font-weight:800; margin-bottom:6px; }
.calc-row{ display:flex; justify-content:space-between; align-items:baseline; padding:14px 0; border-bottom:1px solid var(--hairline); }
.calc-row:last-of-type{ border-bottom:0; }
.calc-row .k{ font-size:.95rem; color:var(--page-fg-dim); }
.calc-row .v{ font-weight:800; color:var(--surface-fg); font-variant-numeric:tabular-nums; }
.calc-total{ margin-top:18px; padding-top:20px; border-top:2px solid var(--accent); }
.calc-total .stat-num{ font-size:clamp(2rem,3.4vw,2.8rem); }
.calc-total small{ display:block; color:var(--page-fg-dim); font-size:.84rem; margin-top:4px; }
.calc-foot{ font-size:.78rem; color:var(--page-fg-dim); margin-top:14px; line-height:1.5; }

/* zero capex chips */
.zeros{ display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.zero{ display:flex; align-items:center; gap:10px; border:1px solid var(--border); border-radius:100px; padding:.55em 1.05em;
  font-weight:700; font-size:.92rem; color:var(--page-fg); }
.zero b{ color:var(--accent); }

/* ---------- INFRAESTRUCTURA TÉCNICA ---------- */
.infra-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,2.6vw,32px); }
.spec{ display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:start; padding:22px 24px; }
.spec .fico{ width:46px; height:46px; border-radius:12px; background:color-mix(in oklab, var(--accent) 16%, transparent);
  color:var(--accent); display:flex; align-items:center; justify-content:center; }
.spec .fico svg{ width:24px; height:24px; }
.spec h4{ font-size:1.08rem; font-weight:800; color:var(--surface-fg); margin-bottom:5px; }
.spec p{ font-size:.92rem; color:var(--page-fg-dim); }
.spec-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.tag{ font-family:'Courier New',monospace; font-size:.72rem; letter-spacing:.04em; color:var(--page-fg-dim);
  border:1px solid var(--hairline); border-radius:6px; padding:.3em .6em; }
.pay-row{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:18px; }
.pay-chip{ font-weight:800; font-size:.9rem; letter-spacing:.02em; padding:.5em 1em; border-radius:10px;
  background:var(--surface); border:1px solid var(--border); color:var(--surface-fg); }
/* payment logos */
.pay-logos{ display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; align-items:center; }
.pay-logos .pay-chip{ height:40px; padding:0 14px; display:inline-flex; align-items:center; justify-content:center; background:#fff; border:1px solid #e7e9ee; border-radius:10px; flex:none; }
.pay-logos .pay-chip img{ height:26px; width:auto; max-width:94px; object-fit:contain; display:block; }
.pay-visa{ background:#1A1F71; color:#fff; font-style:italic; letter-spacing:.08em; font-size:.9rem; }
.pay-mc{ background:#f9f9f9; border:1px solid #e0e0e0; padding:0 8px; }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin-inline:auto; border-top:1px solid var(--hairline); }
.faq-item{ border-bottom:1px solid var(--hairline); }
.faq-q{ width:100%; display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:24px 4px; text-align:left; font-family:var(--font-brand); font-weight:700; font-size:clamp(1.05rem,1.7vw,1.32rem);
  color:var(--page-fg); }
.faq-q .pm{ flex:none; width:30px; height:30px; border-radius:50%; border:1px solid var(--border); position:relative; transition:.25s; }
.faq-q .pm::before,.faq-q .pm::after{ content:""; position:absolute; inset:0; margin:auto; background:var(--accent); }
.faq-q .pm::before{ width:12px; height:2px; } .faq-q .pm::after{ width:2px; height:12px; transition:transform .25s; }
.faq-item.open .faq-q .pm{ border-color:var(--accent); } 
.faq-item.open .faq-q .pm::after{ transform:scaleY(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .35s ease; }
.faq-a p{ padding:0 4px 26px; color:var(--page-fg-dim); font-size:1rem; max-width:68ch; }

/* ---------- CONTACTO / FORM ---------- */
.contact-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,64px); align-items:start; }
.form-card{ padding:clamp(24px,3vw,38px); }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:.82rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  color:var(--page-fg-dim); margin-bottom:8px; }
.field input,.field select{ width:100%; font:inherit; font-size:1rem; color:var(--surface-fg);
  background:var(--page-bg); border:1.5px solid var(--border); border-radius:var(--radius); padding:.85em 1em; transition:border-color .2s; }
.field input::placeholder{ color:var(--page-fg-dim); opacity:.7; }
.field input:focus,.field select:focus{ border-color:var(--accent); outline:none; }
.profile-toggle{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.profile-toggle label{ text-transform:none; letter-spacing:0; margin:0; }
.profile-toggle .opt{ display:flex; align-items:center; gap:10px; border:1.5px solid var(--border); border-radius:var(--radius);
  padding:.9em 1em; font-weight:700; font-size:.96rem; color:var(--page-fg); cursor:pointer; transition:.2s; }
.profile-toggle input{ position:absolute; opacity:0; pointer-events:none; }
.profile-toggle .opt .mk{ width:18px; height:18px; border-radius:50%; border:2px solid var(--border); flex:none; transition:.2s; }
.profile-toggle input:checked + .opt{ border-color:var(--accent); background:color-mix(in oklab,var(--accent) 10%,transparent); }
.profile-toggle input:checked + .opt .mk{ border-color:var(--accent); background:var(--accent); box-shadow:inset 0 0 0 3px var(--page-bg); }
.form-submit{ width:100%; margin-top:8px; }
.contact-aside h3{ margin-bottom:14px; }
.contact-list{ display:flex; flex-direction:column; gap:14px; margin-top:26px; }
.contact-list .ci{ display:flex; gap:14px; align-items:flex-start; }
.contact-list .ci .fico{ width:40px;height:40px;border-radius:10px;background:color-mix(in oklab,var(--accent) 16%,transparent);
  color:var(--accent); display:flex; align-items:center; justify-content:center; flex:none; }
.contact-list .ci .fico svg{ width:20px; height:20px; }
.contact-list .ci b{ display:block; color:var(--page-fg); font-size:.98rem; }
.contact-list .ci span{ font-size:.9rem; color:var(--page-fg-dim); }

/* ---------- FOOTER ---------- */
.foot{ padding-block:clamp(48px,6vw,80px) 40px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.foot-brand .iso{ height:34px; margin-bottom:16px; }
.foot-brand p{ color:var(--page-fg-dim); font-size:.92rem; max-width:34ch; }
.foot-col h5{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); font-weight:800; margin-bottom:16px; }
.foot-col a{ display:block; color:var(--page-fg-dim); font-size:.94rem; padding:5px 0; transition:color .18s; }
.foot-col a:hover{ color:var(--accent); }
.foot-bot{ margin-top:48px; padding-top:24px; border-top:1px solid var(--hairline);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.82rem; color:var(--page-fg-dim); }

/* ---------- DIRECTION SWITCHER (in-page) ---------- */
.switcher{ position:fixed; right:18px; bottom:18px; z-index:80; display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.switch-panel{ background:var(--navy); color:#EAF1F8; border:1px solid rgba(255,255,255,.14); border-radius:16px;
  padding:16px; width:248px; box-shadow:0 24px 60px -20px rgba(0,0,0,.6); transform-origin:bottom right;
  transition:opacity .2s, transform .2s; }
.switch-panel.hidden{ opacity:0; transform:scale(.92); pointer-events:none; }
.switch-panel h6{ font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:#16C7D1; font-weight:800; margin:0 0 10px; }
.switch-panel h6:not(:first-child){ margin-top:18px; }
.sw-row{ display:flex; flex-direction:column; gap:6px; }
.sw-row button{ text-align:left; font-size:.9rem; font-weight:700; padding:.6em .8em; border-radius:10px;
  border:1px solid rgba(255,255,255,.12); color:#EAF1F8; transition:.15s; }
.sw-row button[aria-pressed="true"]{ background:#16C7D1; color:#04222a; border-color:#16C7D1; }
.sw-swatches{ display:flex; gap:8px; }
.sw-swatches button{ width:30px; height:30px; border-radius:50%; border:2px solid transparent; }
.sw-swatches button[aria-pressed="true"]{ border-color:#fff; }
.sw-seg{ display:flex; gap:6px; }
.sw-seg button{ flex:1; text-align:center; font-size:.8rem; padding:.5em; }
.switch-fab{ width:54px; height:54px; border-radius:50%; background:#16C7D1; color:#04222a;
  display:flex; align-items:center; justify-content:center; box-shadow:0 14px 34px -10px rgba(22,199,209,.7); transition:transform .2s; }
.switch-fab:hover{ transform:scale(1.06) rotate(8deg); }
.switch-fab svg{ width:24px; height:24px; }
body[data-embed="1"] .switcher{ display:none; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ display:none; }
  body[data-v="producto"] .hero-visual{ display:block; }
  .aliados-grid{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:820px){
  body{ --section-py:clamp(40px,8vw,56px); }
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .split{ grid-template-columns:1fr; }
  .split.rev .split-media{ order:0; }
  .split-media{ display:none; }
  .band-inner{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr; }
  .infra-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr; gap:28px; }
}
@media (max-width:460px){
  .band-inner{ grid-template-columns:1fr; }
  .hero-ctas{ flex-direction:column; align-items:stretch; }
  .hero-ctas .btn{ width:100%; }
  .profile-toggle{ grid-template-columns:1fr; }
}
