/* ============================================================
   AI-Gen · componentes de página y maquetas de producto (v2)
   (carga después de site.css)
   ============================================================ */

/* ---------- HERO ---------- */
.hero{ padding-top:clamp(44px,6vw,80px); padding-bottom:clamp(56px,8vw,112px); }
.hero-grid{ gap:clamp(40px,5.5vw,72px); }
.hero-copy{ max-width:600px; }
.hero-copy .display{ margin-top:22px; }
.hero-copy .lead{ margin-top:24px; max-width:42ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:32px; }
.trust-note{ margin-top:26px; padding-top:18px; border-top:1px solid var(--line); display:flex; gap:11px; align-items:flex-start; color:var(--muted); font-size:0.9rem; max-width:46ch; }
.trust-note .ck{ color:var(--accent); flex:none; margin-top:2px; }

/* ---------- Product console (hero / reusable) ---------- */
.console{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lg); overflow:hidden; }
.console-bar{ display:flex; align-items:center; gap:10px; padding:13px 16px; border-bottom:1px solid var(--line); background:#FCFCFA; }
.console-bar .dots{ display:flex; gap:6px; }
.console-bar .dots i{ width:9px; height:9px; border-radius:50%; background:var(--line); display:block; }
.console-bar .ttl{ font-family:var(--font-mono); font-size:0.74rem; color:var(--muted); letter-spacing:0.02em; }
.console-bar .badge{ margin-left:auto; }
.console-body{ padding:18px; }
.doc-row{ display:flex; align-items:center; gap:12px; padding:13px 14px; border:1px solid var(--line-soft); border-radius:var(--radius-sm); margin-bottom:10px; }
.doc-row .fic{ color:var(--muted-2); flex:none; }
.doc-row .fname{ font-family:var(--font-mono); font-size:0.82rem; color:var(--ink); }
.doc-row .fmeta{ font-size:0.78rem; color:var(--muted-2); margin-top:2px; }
.doc-row .badge{ margin-left:auto; }
.kv{ display:grid; grid-template-columns:auto 1fr; gap:9px 14px; padding:14px 14px; }
.kv dt{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.04em; color:var(--muted-2); text-transform:uppercase; padding-top:2px; }
.kv dd{ margin:0; color:var(--slate); font-size:0.92rem; }
.kv dd.flag{ color:var(--risk-ink); font-weight:600; display:inline-flex; align-items:center; gap:7px; }
.kv dd.flag svg{ flex:none; }
.evidence-box{ margin-top:12px; background:var(--alabaster); border:1px solid var(--line-soft); border-radius:var(--radius-sm); padding:13px 14px; }
.evidence-box .eb-k{ font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent-ink); }
.evidence-box .eb-q{ font-family:var(--font-mono); font-size:0.82rem; color:var(--slate); margin-top:7px; line-height:1.5; }
.evidence-box .eb-src{ display:flex; gap:7px; flex-wrap:wrap; margin-top:11px; }
.tag-src{ font-family:var(--font-mono); font-size:0.7rem; color:var(--muted); border:1px solid var(--line); border-radius:6px; padding:3px 8px; }
.console-foot{ display:flex; align-items:center; gap:10px; padding:13px 16px; border-top:1px solid var(--line); }
.console-foot .who{ font-size:0.82rem; color:var(--muted); }
.console-foot .who b{ color:var(--ink); font-weight:600; }
.console-foot .acts{ margin-left:auto; display:flex; gap:8px; }

/* ---------- Problem bento ---------- */
.bento{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.prob{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:26px; }
.prob .pn{ font-family:var(--font-mono); font-size:0.8rem; color:var(--accent-ink); letter-spacing:0.04em; }
.prob b{ display:block; margin:16px 0 8px; font-size:1.1rem; font-weight:600; letter-spacing:-0.015em; color:var(--ink); }
.prob p{ margin:0; color:var(--muted); font-size:0.94rem; }

/* ---------- Method ---------- */
.method-flow{ grid-template-columns:repeat(6,1fr); }
.method-aux{ display:grid; grid-template-columns:1fr 1.25fr; gap:24px; margin-top:24px; }

/* Evidence Layer mini */
.evlayer{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }
.evlayer .el-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:16px; }
.evlayer .el-k{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted-2); }
.el-finding{ display:grid; grid-template-columns:auto 1fr; gap:11px; padding:12px 0; border-top:1px solid var(--line-soft); }
.el-finding:first-of-type{ border-top:0; }
.el-finding .ic{ flex:none; margin-top:2px; color:var(--accent); }
.el-finding .ic.warn{ color:var(--warning-ink); }
.el-finding b{ display:block; font-size:0.96rem; color:var(--ink); font-weight:600; }
.el-finding span{ font-size:0.84rem; color:var(--muted); }
.confbar{ height:5px; border-radius:3px; background:var(--neutral-soft); overflow:hidden; margin-top:7px; max-width:160px; }
.confbar i{ display:block; height:100%; background:var(--accent); border-radius:3px; }

/* Human-in-the-loop matrix */
.hitl{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.hitl .hitl-top{ padding:18px 22px; border-bottom:1px solid var(--line); }
.hitl .hitl-top .el-k{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted-2); }
.hitl .hitl-top p{ margin:8px 0 0; color:var(--muted); font-size:0.92rem; max-width:52ch; }
.mtx{ width:100%; border-collapse:collapse; font-size:0.9rem; }
.mtx th,.mtx td{ text-align:left; padding:13px 22px; border-top:1px solid var(--line-soft); vertical-align:middle; }
.mtx thead th{ font-family:var(--font-mono); font-size:0.68rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted-2); font-weight:500; border-top:0; }
.mtx tbody td{ color:var(--muted); }
.mtx .lvl{ font-family:var(--font-mono); color:var(--accent-ink); font-weight:500; }
.mtx .role{ color:var(--ink); font-weight:600; }
.mtx tbody tr:hover{ background:#FBFCFC; }

/* ---------- Pillars (3) ---------- */
.pillars{ grid-template-columns:repeat(3,1fr); align-items:stretch; }
.pillar{ display:flex; flex-direction:column; padding:32px; }
.pillar .p-aud{ font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted-2); }
.pillar .p-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:18px; }
.pillar .h-card{ margin-bottom:12px; }
.pillar > p{ color:var(--muted); margin:0 0 18px; font-size:0.96rem; }
.pillar .bullets{ margin-bottom:22px; }
.pillar .link-arrow{ margin-top:auto; }
.pillar .p-ic{ color:var(--accent); }

/* ---------- Responsible AI Assurance panel ---------- */
.assure-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(36px,5vw,72px); align-items:center; }
.assure-tags{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:32px; }
.assure-tag{ border:1px solid var(--on-navy-line); background:var(--on-navy-card); border-radius:var(--radius); padding:18px; }
.assure-tag .bar{ width:30px; height:5px; border-radius:3px; background:var(--accent); margin-bottom:13px; }
.assure-tag b{ display:block; font-size:0.96rem; color:var(--on-navy); font-weight:600; }
.assure-tag span{ font-size:0.84rem; color:var(--on-navy-muted); }
.apanel{ background:var(--navy-panel); border:1px solid var(--on-navy-line); border-radius:var(--radius); box-shadow:var(--shadow-lg); overflow:hidden; }
.apanel-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:18px 20px; border-bottom:1px solid var(--on-navy-line); }
.apanel-head b{ color:var(--on-navy); font-size:0.95rem; font-weight:600; }
.apanel-head p{ margin:3px 0 0; font-size:0.78rem; color:var(--on-navy-muted); }
.actrl{ padding:16px 20px; border-bottom:1px solid var(--on-navy-line-2); }
.actrl:last-child{ border-bottom:0; }
.actrl-row{ display:grid; grid-template-columns:64px 1fr auto; gap:12px; align-items:center; }
.actrl .cid{ font-family:var(--font-mono); font-size:0.74rem; color:var(--on-navy-muted); }
.actrl .clabel{ color:var(--on-navy); font-size:0.92rem; }
.actrl .cowner{ font-size:0.78rem; color:var(--on-navy-muted); margin-top:2px; }
.actrl-ev{ margin-top:10px; background:rgba(255,255,255,0.03); border-radius:8px; padding:8px 11px; font-family:var(--font-mono); font-size:0.74rem; color:var(--on-navy-muted); }
.apanel-note{ padding:14px 20px; font-size:0.78rem; color:var(--on-navy-muted); line-height:1.55; }

/* ---------- Services bento 2x2 ---------- */
.svc-bento{ grid-template-columns:1fr 1fr; }
.svc{ display:flex; flex-direction:column; padding:32px; }
.svc .idxnum{ display:block; margin-bottom:16px; }
.svc .h-card{ margin-bottom:10px; }
.svc .svc-for{ font-size:0.84rem; color:var(--muted-2); margin:0 0 18px; font-family:var(--font-mono); letter-spacing:0.02em; }
.svc .svc-sub{ font-weight:400; color:var(--muted-2); font-size:0.86rem; }
.svc .link-arrow{ margin-top:auto; padding-top:8px; }

/* ---------- C2Pro teaser mockup ---------- */
.c2-teaser{ align-items:center; gap:clamp(36px,5vw,72px); }
.c2-crit{ margin-top:24px; display:flex; gap:13px; align-items:flex-start; padding:16px 18px; border:1px solid var(--accent-line); border-radius:var(--radius-sm); background:var(--accent-soft); color:var(--accent-dark); font-size:0.96rem; }
.c2-crit .iso{ color:var(--accent); flex:none; margin-top:1px; }
.c2-crit strong{ font-weight:700; }
.c2-mock .console-body{ padding:14px; }
.c2-stack{ display:flex; flex-direction:column; gap:8px; }
.c2-line{ display:flex; align-items:center; gap:10px; padding:11px 12px; border:1px solid var(--line-soft); border-radius:var(--radius-sm); font-size:0.84rem; }
.c2-line .fname{ font-family:var(--font-mono); font-size:0.8rem; color:var(--ink); }
.c2-line .badge{ margin-left:auto; }

/* ---------- Founder ---------- */
.founder-split{ align-items:center; gap:clamp(36px,6vw,80px); }
.founder-media{ max-width:430px; }
.founder-stats{ display:flex; gap:44px; flex-wrap:wrap; margin-top:30px; padding-top:28px; border-top:1px solid var(--line); }
.trust-markers{ display:flex; flex-wrap:wrap; gap:9px; margin-top:26px; }
.tm{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.04em; color:var(--slate); border:1px solid var(--line); border-radius:var(--radius-pill); padding:6px 13px; background:var(--paper); }

/* ---------- Lead magnet ---------- */
.leadmag{ background:linear-gradient(180deg, #0C223F, #0A1B33); border:1px solid var(--on-navy-line); border-radius:var(--radius); padding:clamp(32px,5vw,64px); display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(32px,5vw,64px); align-items:center; }
.leadmag .lm-doc{ background:var(--on-navy-card); border:1px solid var(--on-navy-line); border-radius:var(--radius); padding:24px; }
.leadmag .lm-doc .lm-k{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent-on-navy); }
.leadmag .lm-doc h4{ color:var(--on-navy); font-size:1.05rem; margin:12px 0 16px; font-weight:600; }

/* ---------- Generic page header ---------- */
.page-hero{ padding-top:clamp(56px,8vw,104px); padding-bottom:clamp(40px,5vw,64px); }
.page-hero .display{ margin-top:20px; max-width:20ch; }
.page-hero .lead{ margin-top:22px; }
.page-hero .hero-cta{ margin-top:30px; }
.breadcrumb{ font-family:var(--font-mono); font-size:0.74rem; letter-spacing:0.04em; color:var(--muted-2); }
.breadcrumb a{ color:var(--muted-2); }
.breadcrumb a:hover{ color:var(--ink); }
.breadcrumb .sep{ margin:0 8px; opacity:0.6; }

/* ---------- /services detail rows ---------- */
.svc-detail{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(32px,5vw,72px); padding-block:clamp(44px,6vw,80px); border-top:1px solid var(--line); align-items:start; }
.svc-detail:first-of-type{ border-top:0; }
.sd-left .idxnum{ display:block; margin-bottom:14px; }
.sd-left .h3{ line-height:1.08; }
.sd-left .svc-for{ margin-top:16px; color:var(--muted); font-size:0.95rem; }
.sd-left .svc-for b{ color:var(--ink); font-weight:600; }
.sd-block{ margin-bottom:22px; }
.sd-block .sd-k{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted-2); display:block; margin-bottom:10px; }
.sd-block p{ margin:0; color:var(--muted); }
.sd-deliver{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; }
.regnote{ display:flex; gap:12px; align-items:flex-start; padding:15px 17px; border:1px dashed var(--line); border-radius:var(--radius-sm); margin-top:6px; font-size:0.9rem; color:var(--muted); }
.regnote .iso{ color:var(--accent); flex:none; margin-top:2px; }
.regnote em{ color:var(--muted-2); font-style:normal; font-family:var(--font-mono); font-size:0.8rem; }

/* who-for cards */
.whofor{ grid-template-columns:repeat(3,1fr); }
.whofor .card .wf-ic{ color:var(--accent); margin-bottom:16px; }
.whofor .card b{ display:block; font-size:1.06rem; color:var(--ink); margin-bottom:8px; font-weight:600; }
.whofor .card p{ margin:0; color:var(--muted); font-size:0.94rem; }

/* qualification form */
.formcard{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,4vw,44px); box-shadow:var(--shadow); }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-grid .full{ grid-column:1 / -1; }
.form-foot{ display:flex; flex-wrap:wrap; gap:16px 24px; align-items:center; justify-content:space-between; margin-top:26px; }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:0.83rem; color:var(--muted); max-width:48ch; }
.consent input{ margin-top:3px; accent-color:var(--accent); }

/* ---------- Mobile nav close button ---------- */
.mnav .close{ color:var(--muted); }

/* ---------- Terminal / demo console (Lab hero) ---------- */
.hero-panel{ display:flex; align-items:center; }
.termlog{ width:100%; background:var(--navy-2); border:1px solid var(--on-navy-line); border-radius:var(--radius); box-shadow:var(--shadow-lg); overflow:hidden; }
.tl-bar{ display:flex; align-items:center; gap:10px; padding:13px 16px; border-bottom:1px solid var(--on-navy-line); background:rgba(255,255,255,0.03); }
.tl-bar .dots{ display:flex; gap:6px; }
.tl-bar .dots i{ width:9px; height:9px; border-radius:50%; background:var(--on-navy-line); display:block; }
.tl-bar .ttl{ font-family:var(--font-mono); font-size:0.74rem; color:var(--on-navy-muted); letter-spacing:0.02em; }
.tl-body{ padding:20px; display:flex; flex-direction:column; gap:9px; font-family:var(--font-mono); font-size:0.86rem; line-height:1.6; }
.tl-body .ln{ color:var(--on-navy); }
.tl-body .ln.mut{ color:var(--on-navy-muted); }
.tl-body .ln.ok{ color:#5FC98B; }
.tl-body .ln.warn{ color:var(--warning-ink); filter:brightness(1.5); }
.tl-body .ln.risk{ color:#E88A7A; }

/* ---------- Standards badges row ---------- */
.lab-standards{ display:flex; flex-wrap:wrap; gap:9px; margin-top:26px; }
.std{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.04em; color:var(--slate); border:1px solid var(--line); border-radius:var(--radius-pill); padding:6px 13px; background:var(--paper); }

/* ---------- Bitácora / logbook ---------- */
.logbook{ display:flex; flex-direction:column; gap:0; }
.logentry{ display:grid; grid-template-columns:auto 1fr; gap:18px; padding:26px 0; border-top:1px solid var(--line); }
.logentry:first-child{ border-top:0; }
.logentry .le-ic{ color:var(--accent); flex:none; margin-top:2px; }
.logentry .le-tag{ display:block; font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--muted-2); margin-bottom:8px; }
.logentry b{ display:block; font-size:1.05rem; font-weight:600; letter-spacing:-0.01em; color:var(--ink); margin-bottom:8px; }
.logentry p{ margin:0; color:var(--muted); font-size:0.94rem; max-width:64ch; }

/* ---------- Formulas (métricas) ---------- */
.formula{ background:var(--on-navy-card); border:1px solid var(--on-navy-line); border-radius:var(--radius); padding:20px 22px; }
.formula .fx{ display:block; font-family:var(--font-mono); font-size:1rem; color:var(--accent-on-navy); letter-spacing:0.01em; }
.formula .leg{ display:block; margin-top:12px; font-size:0.86rem; line-height:1.55; color:var(--on-navy-muted); }

/* ---------- Prototype cards ---------- */
.proto-grid{ grid-template-columns:repeat(3,1fr); }
.card.proto{ display:flex; flex-direction:column; }
.proto .pr-phase{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:0.7rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--muted-2); }
.proto .h-card{ margin:14px 0 8px; }
.proto p{ margin:0; color:var(--muted); font-size:0.92rem; }
.proto .exp-note{ display:flex; gap:8px; align-items:flex-start; margin-top:auto; padding-top:16px; font-size:0.8rem; color:var(--muted-2); }
.proto .exp-note .iso{ flex:none; margin-top:1px; color:var(--warning-ink); }

/* ---------- Photo frame (founder portrait) ---------- */
.ph-frame{ overflow:hidden; }

/* ---------- CTA band ---------- */
.cta-band{ text-align:center; }
.cta-band .h2{ max-width:20ch; margin-inline:auto; }
.cta-band .lead{ margin-inline:auto; margin-top:18px; }
.cta-band .row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:30px; }

/* ---------- Responsive ---------- */
@media (max-width: 960px){
  .method-flow{ grid-template-columns:repeat(3,1fr); }
  .method-aux{ grid-template-columns:1fr; }
  .pillars{ grid-template-columns:1fr; }
  .assure-grid,.c2-teaser{ grid-template-columns:1fr; }
  .svc-bento{ grid-template-columns:1fr; }
  .leadmag{ grid-template-columns:1fr; }
  .svc-detail{ grid-template-columns:1fr; gap:22px; }
  .form-grid{ grid-template-columns:1fr; }
  .whofor{ grid-template-columns:1fr; }
  .founder-media{ max-width:none; }
  .bento{ grid-template-columns:1fr; }
}
@media (max-width: 620px){
  .method-flow{ grid-template-columns:1fr; }
  .assure-tags{ grid-template-columns:1fr; }
  .actrl-row{ grid-template-columns:54px 1fr; }
  .actrl-row .badge{ grid-column:2; justify-self:start; }
  .mtx thead{ display:none; }
  .mtx td{ display:block; padding:4px 18px; border:0; }
  .mtx tbody tr{ display:block; padding:14px 0; border-top:1px solid var(--line-soft); }
  .founder-stats{ gap:26px; }
  .proto-grid{ grid-template-columns:1fr; }
  .logentry{ grid-template-columns:1fr; }
}
