/* ===========================================================
   CRUZ DÍAZ ABOGADOS — estilos compartidos
   Dirección "Tinta, Oro y Acero": negro carbón + hueso dominan;
   ORO #C9A227 solo como filo/credencial; ACERO/teal #2E7E8C = color vivo.
   Marca: oro + negro + hueso · Titulares serif (Cormorant) + Inter cuerpo.
   Todo bajo #cruzdiaz-app, clases .cd- para no chocar.
   =========================================================== */
#cruzdiaz-app, #cruzdiaz-app *{ box-sizing:border-box; margin:0; padding:0; }
#cruzdiaz-app{
  --cd-bg:#0B0B0D; --cd-bg2:#101015; --cd-surface:#15151A; --cd-surface2:#1C1C22;
  --cd-text:#F6F4EE; --cd-muted:#E2DED2;
  --cd-gold:#C9A227; --cd-gold-soft:#D8BC5E;
  --cd-steel:#2E7E8C; --cd-steel-soft:#56aab8;
  --cd-danger:#B4452F;
  --cd-line:rgba(201,162,39,0.18);
  --cd-line-soft:rgba(244,242,237,0.10);
  /* compat con clases viejas */
  --cd-cyan:#C9A227; --cd-ice:#F4F2ED; --cd-ink:#F4F2ED; --cd-amber:#C9A227; --cd-amber-ink:#14110E;
  --cd-glass:rgba(21,21,26,0.55); --cd-glass-2:rgba(28,28,34,0.7);
  --cd-display:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --cd-body:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  position:relative; min-height:100vh;
  font-family:var(--cd-body); color:var(--cd-text);
  background:
    radial-gradient(1100px 640px at 82% -12%, rgba(201,162,39,.07), transparent 60%),
    radial-gradient(900px 600px at 6% 8%, rgba(46,126,140,.06), transparent 60%),
    linear-gradient(180deg, var(--cd-bg) 0%, #08080a 50%, var(--cd-bg) 100%);
  overflow-x:hidden; line-height:1.65; -webkit-font-smoothing:antialiased;
}

/* Fondo 3D + viñeta + grano sutil (negro no plano) */
#cruzdiaz-app .cd-bg{ position:fixed; inset:0; width:100%; height:100%; z-index:0; display:block; }
#cruzdiaz-app .cd-vignette{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 0%, transparent 56%, rgba(0,0,0,.6) 100%),
    radial-gradient(80% 60% at 50% 120%, rgba(0,0,0,.9), transparent 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}
#cruzdiaz-app.cd-no3d .cd-bg{ display:none; }

/* Layout */
#cruzdiaz-app .cd-wrap{ width:min(1180px,92vw); margin:0 auto; position:relative; z-index:10; }
#cruzdiaz-app section, #cruzdiaz-app header, #cruzdiaz-app footer{ position:relative; z-index:10; }

/* ===== Nav ===== */
#cruzdiaz-app .cd-nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  padding:12px clamp(16px,4vw,40px);
  background:linear-gradient(180deg, rgba(11,11,13,.86), rgba(11,11,13,.4));
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--cd-line);
}
#cruzdiaz-app .cd-brand{ margin-right:auto; text-decoration:none; display:inline-flex; }
#cruzdiaz-app .cd-logo-chip{
  display:inline-flex; align-items:center; background:#FAFAF7; border:1px solid rgba(201,162,39,0.40);
  border-radius:9px; padding:7px 14px; box-shadow:0 6px 18px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.6);
}
#cruzdiaz-app .cd-logo-chip img{ height:36px; width:auto; display:block; }
#cruzdiaz-app .cd-logo-chip-sm img{ height:30px; }
/* wordmark viejo (por compatibilidad, casi no se usa) */
#cruzdiaz-app .cd-logo{ font-family:var(--cd-display); font-size:24px; letter-spacing:.02em; color:var(--cd-text); }
#cruzdiaz-app .cd-logo b{ color:var(--cd-gold); font-weight:600; }

#cruzdiaz-app .cd-menu{ display:flex; align-items:center; gap:4px; flex-wrap:wrap; }
#cruzdiaz-app .cd-menu a, #cruzdiaz-app .cd-tab{
  position:relative; font-family:var(--cd-body); font-weight:500; font-size:14px; letter-spacing:.01em;
  color:var(--cd-text); background:transparent; border:0; cursor:pointer;
  padding:9px 13px; border-radius:8px; transition:.22s; white-space:nowrap; text-decoration:none;
}
#cruzdiaz-app .cd-menu a::after, #cruzdiaz-app .cd-tab::after{
  content:""; position:absolute; left:13px; right:13px; bottom:4px; height:1.5px; background:var(--cd-steel); transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
#cruzdiaz-app .cd-menu a:hover, #cruzdiaz-app .cd-tab:hover{ color:#fff; }
#cruzdiaz-app .cd-menu a:hover::after, #cruzdiaz-app .cd-tab:hover::after{ transform:scaleX(1); }
#cruzdiaz-app .cd-menu a.cd-here{ color:var(--cd-gold-soft); }
#cruzdiaz-app .cd-tab.cd-active{ color:#fff; }
#cruzdiaz-app .cd-tab.cd-active::after{ transform:scaleX(1); background:var(--cd-gold); }

#cruzdiaz-app .cd-cta-sm{
  font-family:var(--cd-body); font-weight:600; font-size:13px; text-decoration:none; white-space:nowrap;
  color:var(--cd-text); background:transparent; border:1px solid var(--cd-gold);
  padding:10px 18px; border-radius:999px; transition:.25s;
}
#cruzdiaz-app .cd-cta-sm:hover{ background:rgba(201,162,39,.12); color:#fff; }

/* ===== Paneles ===== */
#cruzdiaz-app .cd-panel{ display:none; }
#cruzdiaz-app .cd-panel.cd-active{ display:block; animation:cdFade .5s ease; }
@keyframes cdFade{ from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;} }

/* ===== Hero ===== */
#cruzdiaz-app .cd-hero{ min-height:100vh; display:flex; align-items:center; padding:140px 0 90px; }
#cruzdiaz-app .cd-page-hero{ min-height:auto; padding:160px 0 40px; }
#cruzdiaz-app .cd-eyebrow{
  display:inline-flex; align-items:center; gap:9px; font-family:var(--cd-body); font-size:12px; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--cd-gold-soft);
}
#cruzdiaz-app .cd-eyebrow .cd-dot{ width:6px; height:6px; border-radius:50%; background:var(--cd-gold); box-shadow:0 0 10px var(--cd-gold); }
#cruzdiaz-app .cd-h1{
  font-family:var(--cd-display); font-weight:600; line-height:1.02;
  font-size:clamp(40px,6.6vw,84px); letter-spacing:.005em; margin:20px 0 20px; color:var(--cd-text);
}
#cruzdiaz-app .cd-h1 .cd-grad{ font-style:italic; color:var(--cd-text); }
#cruzdiaz-app .cd-h1 .cd-amberword{ color:var(--cd-gold); }
#cruzdiaz-app .cd-lead{ max-width:600px; font-size:clamp(16px,2vw,19px); color:var(--cd-muted); line-height:1.7; }
#cruzdiaz-app .cd-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:32px; }

#cruzdiaz-app .cd-btn{ font-family:var(--cd-body); font-weight:600; font-size:15px; text-decoration:none; cursor:pointer; padding:15px 28px; border-radius:10px; transition:.25s; border:1px solid transparent; display:inline-flex; align-items:center; gap:10px; }
#cruzdiaz-app .cd-btn-primary{ color:#14110E; background:var(--cd-text); }
#cruzdiaz-app .cd-btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 34px rgba(0,0,0,.5); background:#fff; }
#cruzdiaz-app .cd-btn-ghost{ color:var(--cd-text); background:transparent; border-color:var(--cd-line); }
#cruzdiaz-app .cd-btn-ghost:hover{ border-color:var(--cd-gold); background:rgba(201,162,39,.08); }

#cruzdiaz-app .cd-chips{ display:flex; flex-wrap:wrap; gap:9px; margin-top:34px; }
#cruzdiaz-app .cd-chip{ font-size:12.5px; font-weight:500; color:var(--cd-muted); padding:8px 14px; border-radius:999px; border:1px solid var(--cd-line-soft); background:rgba(21,21,26,.5); }

/* Credenciales */
#cruzdiaz-app .cd-creds{ display:flex; flex-wrap:wrap; gap:12px 26px; align-items:center; margin-top:38px; padding-top:24px; border-top:1px solid var(--cd-line); }
#cruzdiaz-app .cd-creds span{ display:inline-flex; align-items:center; gap:9px; font-size:12.5px; letter-spacing:.04em; color:var(--cd-muted); }
#cruzdiaz-app .cd-creds span::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--cd-gold); }

#cruzdiaz-app .cd-scrollhint{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); color:var(--cd-muted); font-size:11px; letter-spacing:.22em; text-transform:uppercase; text-align:center; }
#cruzdiaz-app .cd-scrollhint span{ display:block; width:1px; height:34px; margin:8px auto 0; background:linear-gradient(var(--cd-gold), transparent); animation:cdPulse 1.9s infinite; }
@keyframes cdPulse{ 0%,100%{opacity:.25; transform:scaleY(.6);} 50%{opacity:.9; transform:scaleY(1);} }

/* ===== Secciones ===== */
#cruzdiaz-app .cd-sec{ padding:110px 0; }
#cruzdiaz-app .cd-kicker{ font-family:var(--cd-body); font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--cd-gold-soft); }
#cruzdiaz-app .cd-h2{ font-family:var(--cd-display); font-weight:600; line-height:1.04; font-size:clamp(30px,4.4vw,50px); margin:14px 0 14px; color:var(--cd-text); }
#cruzdiaz-app .cd-h2::after{ content:""; display:block; width:54px; height:2px; margin-top:18px; background:linear-gradient(90deg, var(--cd-gold), transparent); }
#cruzdiaz-app .cd-sub{ max-width:64ch; color:var(--cd-muted); font-size:16px; }

/* Grid + tarjetas */
#cruzdiaz-app .cd-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:18px; margin-top:46px; }
#cruzdiaz-app .cd-card{ position:relative; padding:28px 26px 30px; border-radius:16px; background:var(--cd-glass); border:1px solid var(--cd-line-soft); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); transition:.3s; overflow:hidden; }
#cruzdiaz-app .cd-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg, transparent, var(--cd-gold), transparent); opacity:.5; }
#cruzdiaz-app .cd-card:hover{ transform:translateY(-5px); background:var(--cd-glass-2); border-color:var(--cd-line); box-shadow:0 18px 44px rgba(0,0,0,.5); }
#cruzdiaz-app .cd-ico{ width:46px; height:46px; border-radius:11px; display:flex; align-items:center; justify-content:center; background:rgba(46,126,140,.10); border:1px solid var(--cd-line-soft); margin-bottom:18px; }
#cruzdiaz-app .cd-ico svg{ width:23px; height:23px; stroke:var(--cd-steel-soft); fill:none; stroke-width:1.6; }
#cruzdiaz-app .cd-card h3{ font-family:var(--cd-display); font-size:23px; font-weight:600; margin-bottom:9px; color:#fff; }
#cruzdiaz-app .cd-card p{ font-size:14.5px; color:var(--cd-muted); line-height:1.6; }

/* Pasos */
#cruzdiaz-app .cd-steps{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; margin-top:46px; }
#cruzdiaz-app .cd-step{ padding:26px; border-radius:14px; border:1px solid var(--cd-line-soft); background:var(--cd-glass); }
#cruzdiaz-app .cd-step .cd-num{ font-family:var(--cd-display); font-size:44px; font-weight:600; font-style:italic; color:var(--cd-gold); line-height:1; }
#cruzdiaz-app .cd-step h4{ font-size:17px; font-weight:600; margin:10px 0 6px; color:#fff; }
#cruzdiaz-app .cd-step p{ font-size:13.5px; color:var(--cd-muted); }

/* Banda */
#cruzdiaz-app .cd-band{ margin-top:14px; padding:50px clamp(24px,4vw,56px); border-radius:20px; border:1px solid var(--cd-line); background:linear-gradient(135deg, rgba(28,28,34,.7), rgba(11,11,13,.5)); backdrop-filter:blur(14px); display:flex; flex-wrap:wrap; gap:26px; align-items:center; justify-content:space-between; }
#cruzdiaz-app .cd-band h3{ font-family:var(--cd-display); font-weight:600; font-size:clamp(26px,3.4vw,40px); line-height:1.06; color:var(--cd-text); }
#cruzdiaz-app .cd-band p{ color:var(--cd-muted); max-width:520px; margin-top:8px; }

/* Cifras */
#cruzdiaz-app .cd-stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); gap:20px; margin-top:46px; }
#cruzdiaz-app .cd-stat{ text-align:center; padding:24px 16px; border:1px solid var(--cd-line-soft); border-radius:14px; }
#cruzdiaz-app .cd-stat b{ display:block; font-family:var(--cd-display); font-weight:600; font-size:42px; color:var(--cd-gold); line-height:1; }
#cruzdiaz-app .cd-stat span{ font-size:13px; color:var(--cd-muted); margin-top:8px; display:block; }

/* FAQ (acordeón nativo) */
#cruzdiaz-app .cd-faq{ max-width:780px; margin-top:30px; }
#cruzdiaz-app .cd-faq details{ border-bottom:1px solid var(--cd-line-soft); }
#cruzdiaz-app .cd-faq summary{ cursor:pointer; list-style:none; padding:20px 0; font-weight:600; font-size:17px; color:var(--cd-text); display:flex; justify-content:space-between; align-items:center; gap:18px; }
#cruzdiaz-app .cd-faq summary::-webkit-details-marker{ display:none; }
#cruzdiaz-app .cd-faq summary::after{ content:"+"; color:var(--cd-gold); font-size:24px; line-height:1; transition:.2s; }
#cruzdiaz-app .cd-faq details[open] summary::after{ content:"\2013"; }
#cruzdiaz-app .cd-faq p{ color:var(--cd-muted); font-size:15px; padding:0 0 20px; max-width:66ch; }

/* CTA */
#cruzdiaz-app .cd-cta-sec{ padding:90px 0 110px; }
#cruzdiaz-app .cd-cta-box{ text-align:center; padding:64px clamp(20px,5vw,70px); border-radius:24px; border:1px solid var(--cd-line); background:radial-gradient(120% 140% at 50% 0%, rgba(201,162,39,.08), rgba(11,11,13,.6)); backdrop-filter:blur(16px); }
#cruzdiaz-app .cd-cta-box h2{ font-family:var(--cd-display); font-weight:600; font-size:clamp(30px,4.6vw,52px); line-height:1.05; color:var(--cd-text); }
#cruzdiaz-app .cd-cta-box p{ color:var(--cd-muted); max-width:560px; margin:14px auto 0; }
#cruzdiaz-app .cd-cta-box .cd-actions{ justify-content:center; }
#cruzdiaz-app .cd-contact-row{ display:flex; flex-wrap:wrap; gap:14px 34px; justify-content:center; margin-top:30px; font-size:14px; color:var(--cd-text); }
#cruzdiaz-app .cd-contact-row a{ color:var(--cd-text); text-decoration:none; border-bottom:1px solid var(--cd-line); padding-bottom:2px; transition:.2s; }
#cruzdiaz-app .cd-contact-row a:hover{ color:var(--cd-steel-soft); border-color:var(--cd-steel); }

/* Prosa */
#cruzdiaz-app .cd-prose{ max-width:72ch; }
#cruzdiaz-app .cd-prose h2{ font-family:var(--cd-display); font-weight:600; font-size:clamp(24px,3vw,34px); margin:36px 0 12px; color:#fff; }
#cruzdiaz-app .cd-prose h3{ font-size:18px; font-weight:600; margin:24px 0 8px; color:var(--cd-gold-soft); }
#cruzdiaz-app .cd-prose p, #cruzdiaz-app .cd-prose li{ color:var(--cd-muted); font-size:16px; margin-bottom:12px; line-height:1.7; }
#cruzdiaz-app .cd-prose ul{ padding-left:20px; }
#cruzdiaz-app .cd-prose strong{ color:var(--cd-text); }
#cruzdiaz-app .cd-note{ font-size:13px; color:#9d978a; border-left:2px solid var(--cd-line); padding:6px 0 6px 14px; margin:10px 0; }

/* Formulario */
#cruzdiaz-app .cd-form{ display:grid; gap:16px; max-width:620px; margin-top:30px; }
#cruzdiaz-app .cd-field{ display:flex; flex-direction:column; gap:7px; }
#cruzdiaz-app .cd-field label{ font-size:13px; font-weight:600; color:var(--cd-text); letter-spacing:.02em; }
#cruzdiaz-app .cd-field input, #cruzdiaz-app .cd-field textarea, #cruzdiaz-app .cd-field select{
  font-family:var(--cd-body); font-size:15px; color:var(--cd-text);
  background:rgba(11,11,13,.6); border:1px solid var(--cd-line-soft); border-radius:10px; padding:13px 15px; transition:.2s;
}
#cruzdiaz-app .cd-field input:focus, #cruzdiaz-app .cd-field textarea:focus, #cruzdiaz-app .cd-field select:focus{ outline:none; border-color:var(--cd-steel); box-shadow:0 0 0 3px rgba(46,126,140,.22); }
#cruzdiaz-app .cd-field textarea{ resize:vertical; min-height:120px; }
#cruzdiaz-app .cd-form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* Blog */
#cruzdiaz-app .cd-articles{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:20px; margin-top:46px; }
#cruzdiaz-app .cd-article{ display:flex; flex-direction:column; }
#cruzdiaz-app .cd-article .cd-tag{ align-self:flex-start; font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--cd-gold-soft); border:1px solid var(--cd-line); padding:4px 11px; border-radius:999px; margin-bottom:16px; }
#cruzdiaz-app .cd-article h3{ font-size:22px; }
#cruzdiaz-app .cd-article .cd-date{ font-size:12px; color:#9d978a; margin-top:auto; padding-top:16px; }

/* Footer */
#cruzdiaz-app .cd-footer{ border-top:1px solid var(--cd-line); background:rgba(8,8,10,.8); backdrop-filter:blur(10px); padding:56px 0 40px; }
#cruzdiaz-app .cd-foot-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:30px; }
#cruzdiaz-app .cd-footer h5{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--cd-gold-soft); margin-bottom:14px; }
#cruzdiaz-app .cd-footer p, #cruzdiaz-app .cd-footer a{ font-size:14px; color:var(--cd-muted); text-decoration:none; display:block; margin-bottom:8px; }
#cruzdiaz-app .cd-footer a:hover{ color:var(--cd-text); }
#cruzdiaz-app .cd-disclaimer{ margin-top:36px; padding-top:22px; border-top:1px solid var(--cd-line-soft); font-size:12px; color:#8d877a; line-height:1.6; }

/* Reveal */
#cruzdiaz-app .cd-reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
#cruzdiaz-app .cd-reveal.cd-in{ opacity:1; transform:none; }

/* Responsive */
@media (max-width:860px){
  #cruzdiaz-app .cd-nav{ gap:8px; padding:10px 16px; }
  #cruzdiaz-app .cd-cta-sm{ display:none; }
  #cruzdiaz-app .cd-menu{ justify-content:flex-end; gap:4px; }
  #cruzdiaz-app .cd-menu a, #cruzdiaz-app .cd-tab{ font-size:13px; padding:8px 9px; }
  #cruzdiaz-app .cd-logo-chip img{ height:30px; }
  #cruzdiaz-app .cd-foot-grid{ grid-template-columns:1fr 1fr; }
  #cruzdiaz-app .cd-form-row{ grid-template-columns:1fr; }
  #cruzdiaz-app .cd-band{ flex-direction:column; align-items:flex-start; }
  #cruzdiaz-app .cd-sec{ padding:80px 0; }
}
@media (max-width:480px){ #cruzdiaz-app .cd-foot-grid{ grid-template-columns:1fr; } }
@media (prefers-reduced-motion: reduce){
  #cruzdiaz-app .cd-reveal{ transition:none; opacity:1; transform:none; }
  #cruzdiaz-app .cd-scrollhint span{ animation:none; }
  #cruzdiaz-app .cd-ck.cd-ck-done .cd-ck-box{ animation:none; }
}

/* ===========================================================
   CHEKEA — identidad propia (teal/agua) + checklist + dashboard
   =========================================================== */
#cruzdiaz-app{ --ck-green:#3FB57A; --ck-amber:#E0A53D; --ck-red:#D45B4B; --cd-teal:#23A29A; --cd-teal-soft:#5FD0C6; }
/* el panel de Chekea reasigna el acento de oro -> teal (solo aquí dentro) */
#cruzdiaz-app #panel-chekea{ --cd-gold:#23A29A; --cd-gold-soft:#5FD0C6; --cd-steel:#23A29A; --cd-steel-soft:#5FD0C6; --cd-line:rgba(35,162,154,0.20); }

/* Checklist "Lo que revisamos" */
#cruzdiaz-app .cd-checklist{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:18px; margin-top:44px; }
#cruzdiaz-app .cd-ck-group{ background:var(--cd-surface); border:1px solid var(--cd-line-soft); border-radius:14px; padding:22px 22px 14px; }
#cruzdiaz-app .cd-ck-group h4{ font-family:var(--cd-body); font-size:12.5px; text-transform:uppercase; letter-spacing:.12em; color:var(--cd-teal-soft); margin-bottom:10px; }
#cruzdiaz-app .cd-ck-group ul{ list-style:none; }
#cruzdiaz-app .cd-ck{ display:flex; align-items:center; gap:12px; padding:8px 0; font-size:14.5px; color:var(--cd-muted); transition:color .3s; }
#cruzdiaz-app .cd-ck-box{ flex:none; width:22px; height:22px; border-radius:6px; border:2px solid var(--ck-red); position:relative; transition:border-color .3s, background .3s; }
#cruzdiaz-app .cd-ck-box::after{ content:"\2713"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; color:#06130d; opacity:0; transition:opacity .2s; }
#cruzdiaz-app .cd-ck.cd-ck-done{ color:var(--cd-text); }
#cruzdiaz-app .cd-ck.cd-ck-done .cd-ck-box{ border-color:var(--ck-green); background:var(--ck-green); animation:cdCkPop .42s ease; }
#cruzdiaz-app .cd-ck.cd-ck-done .cd-ck-box::after{ opacity:1; }
@keyframes cdCkPop{ 0%{transform:scale(.5)} 55%{transform:scale(1.22)} 100%{transform:scale(1)} }

/* Dashboard de reporte (colores SÓLIDOS) */
#cruzdiaz-app .cd-dash{ margin-top:44px; display:grid; gap:18px; }
#cruzdiaz-app .cd-dash-stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; }
#cruzdiaz-app .cd-dstat{ border-radius:14px; padding:24px 22px; }
#cruzdiaz-app .cd-dstat b{ display:block; font-family:var(--cd-display); font-size:46px; font-weight:600; line-height:1; }
#cruzdiaz-app .cd-dstat span{ font-size:13px; color:#cfcabb; margin-top:6px; display:block; }
#cruzdiaz-app .cd-dstat.cd-ok{ background:#123626; border:1px solid #2f6b49; } #cruzdiaz-app .cd-dstat.cd-ok b{ color:#5fd699; }
#cruzdiaz-app .cd-dstat.cd-warn{ background:#3a2c12; border:1px solid #7a5e2a; } #cruzdiaz-app .cd-dstat.cd-warn b{ color:#f0bd5e; }
#cruzdiaz-app .cd-dstat.cd-bad{ background:#3a1a16; border:1px solid #7a3a30; } #cruzdiaz-app .cd-dstat.cd-bad b{ color:#f08a78; }
#cruzdiaz-app .cd-dash-panel{ background:var(--cd-surface2); border:1px solid var(--cd-line-soft); border-radius:16px; padding:24px; }
#cruzdiaz-app .cd-dash-panel h4{ font-size:13px; text-transform:uppercase; letter-spacing:.1em; color:var(--cd-teal-soft); margin-bottom:14px; }
#cruzdiaz-app .cd-dash-rooms{ display:flex; flex-wrap:wrap; gap:10px; }
#cruzdiaz-app .cd-room{ display:flex; align-items:center; gap:8px; padding:9px 14px; border-radius:999px; font-size:13px; font-weight:600; }
#cruzdiaz-app .cd-room span{ font-size:10.5px; padding:2px 8px; border-radius:999px; background:rgba(0,0,0,.28); }
#cruzdiaz-app .cd-room.cd-s-ok{ background:#16402a; color:#aef0cd; }
#cruzdiaz-app .cd-room.cd-s-warn{ background:#3a2c12; color:#f4d79b; }
#cruzdiaz-app .cd-room.cd-s-bad{ background:#3a1a16; color:#f5b3a6; }
#cruzdiaz-app .cd-sev{ display:flex; height:14px; border-radius:999px; overflow:hidden; margin-top:8px; }
#cruzdiaz-app .cd-sev i{ display:block; height:100%; }
#cruzdiaz-app .cd-sev .cd-i-ok{ background:#3FB57A; } #cruzdiaz-app .cd-sev .cd-i-warn{ background:#E0A53D; } #cruzdiaz-app .cd-sev .cd-i-bad{ background:#D45B4B; }
#cruzdiaz-app .cd-sev-legend{ display:flex; gap:18px; margin-top:12px; font-size:12px; color:var(--cd-muted); }
#cruzdiaz-app .cd-sev-legend i{ display:inline-block; width:10px; height:10px; border-radius:3px; margin-right:6px; vertical-align:middle; }

/* ===== Tarjeta de precio (Propiedad Industrial) ===== */
#cruzdiaz-app .cd-price{ display:grid; grid-template-columns:1.2fr 1fr; border:1px solid var(--cd-line); border-radius:20px; overflow:hidden; margin-top:44px; background:var(--cd-surface); }
#cruzdiaz-app .cd-price-main{ padding:42px clamp(24px,4vw,48px); border-right:1px solid var(--cd-line-soft); }
#cruzdiaz-app .cd-price-tag{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--cd-gold-soft); }
#cruzdiaz-app .cd-price-amount{ display:flex; align-items:baseline; gap:10px; margin:12px 0 12px; }
#cruzdiaz-app .cd-price-amount b{ font-family:var(--cd-display); font-size:clamp(48px,8vw,78px); font-weight:600; color:var(--cd-text); line-height:1; }
#cruzdiaz-app .cd-price-amount span{ font-size:18px; color:var(--cd-muted); }
#cruzdiaz-app .cd-price-start{ color:var(--cd-muted); font-size:15.5px; margin-bottom:26px; line-height:1.6; }
#cruzdiaz-app .cd-price-start strong{ color:var(--cd-gold); font-weight:700; }
#cruzdiaz-app .cd-price-side{ padding:42px clamp(24px,4vw,40px); background:var(--cd-bg2); }
#cruzdiaz-app .cd-price-side h4{ font-size:12px; text-transform:uppercase; letter-spacing:.12em; color:var(--cd-gold-soft); margin-bottom:14px; }
#cruzdiaz-app .cd-price-side ul{ list-style:none; }
#cruzdiaz-app .cd-price-side li{ position:relative; padding:8px 0 8px 26px; color:var(--cd-text); font-size:14.5px; }
#cruzdiaz-app .cd-price-side li::before{ content:"\2713"; position:absolute; left:0; top:8px; color:var(--cd-gold); font-weight:700; }
#cruzdiaz-app .cd-price-note{ font-size:12px; color:#9d978a; margin-top:16px; }
@media (max-width:760px){ #cruzdiaz-app .cd-price{ grid-template-columns:1fr; } #cruzdiaz-app .cd-price-main{ border-right:0; border-bottom:1px solid var(--cd-line-soft); } }
#cruzdiaz-app .cd-stage{ display:flex; align-items:center; gap:16px; padding:18px 0; border-bottom:1px solid var(--cd-line-soft); }
#cruzdiaz-app .cd-stage:last-of-type{ border-bottom:0; }
#cruzdiaz-app .cd-stage-n{ font-family:var(--cd-display); font-size:22px; font-weight:600; color:var(--cd-gold); flex:none; width:34px; height:34px; border:1px solid var(--cd-line); border-radius:50%; display:flex; align-items:center; justify-content:center; }
#cruzdiaz-app .cd-stage-body{ flex:1; }
#cruzdiaz-app .cd-stage-body h5{ font-size:15.5px; color:var(--cd-text); font-weight:600; }
#cruzdiaz-app .cd-stage-body p{ font-size:13px; color:var(--cd-muted); margin-top:3px; line-height:1.5; }
#cruzdiaz-app .cd-stage-price{ font-family:var(--cd-display); font-size:30px; font-weight:600; color:var(--cd-text); flex:none; white-space:nowrap; }
#cruzdiaz-app .cd-stage-price small{ font-size:13px; color:var(--cd-muted); font-family:var(--cd-body); }

/* ===========================================================
   v5 — ganchos, menú colapsable formal, overlap & responsive
   =========================================================== */
/* Gancho bajo el hero (se auto-tematiza: oro en P.I., teal en Chekea) */
#cruzdiaz-app .cd-hero-note{ margin-top:16px; font-size:14.5px; color:var(--cd-muted); max-width:60ch; }
#cruzdiaz-app .cd-hero-note strong{ color:var(--cd-gold-soft); font-weight:600; }

/* Altura de nav dinámica → nada se mete bajo la barra fija */
#cruzdiaz-app{ --cd-nav-h:68px; scroll-padding-top:var(--cd-nav-h); }
#cruzdiaz-app .cd-hero{ padding-top:calc(var(--cd-nav-h) + 70px); }
#cruzdiaz-app .cd-page-hero{ padding-top:calc(var(--cd-nav-h) + 90px); }
#cruzdiaz-app .cd-sec[id], #cruzdiaz-app .cd-cta-sec[id]{ scroll-margin-top:calc(var(--cd-nav-h) + 16px); }

/* El 3D es decorativo: que no capture clics ni estorbe el scroll táctil */
#cruzdiaz-app .cd-bg{ pointer-events:none; }

/* Foco visible (teclado / web) */
#cruzdiaz-app a:focus-visible, #cruzdiaz-app button:focus-visible{ outline:2px solid var(--cd-gold); outline-offset:3px; border-radius:8px; }
/* Números alineados como estado de cuenta */
#cruzdiaz-app .cd-stage-price, #cruzdiaz-app .cd-dstat b, #cruzdiaz-app .cd-stat b{ font-variant-numeric:tabular-nums lining-nums; }
/* Filo dorado de la tarjeta al hover */
#cruzdiaz-app .cd-card:hover::before{ opacity:1; }

/* Grids que NUNCA desbordan en pantallas chicas */
#cruzdiaz-app .cd-grid{ grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr)); }
#cruzdiaz-app .cd-checklist{ grid-template-columns:repeat(auto-fit,minmax(min(100%,270px),1fr)); }
#cruzdiaz-app .cd-articles{ grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr)); }
#cruzdiaz-app .cd-dash-stats{ grid-template-columns:repeat(auto-fit,minmax(130px,1fr)); }
#cruzdiaz-app .cd-dstat b{ font-size:clamp(34px,9vw,46px); }

/* Botón disparador del menú (en la barra, lenguaje de .cd-cta-sm) */
#cruzdiaz-app .cd-menu-trigger{ display:inline-flex; align-items:center; gap:9px; cursor:pointer; font-family:var(--cd-body); font-weight:600; font-size:13px; letter-spacing:.04em; color:var(--cd-text); background:transparent; border:1px solid var(--cd-line); padding:10px 16px; border-radius:999px; transition:.25s; }
#cruzdiaz-app .cd-menu-trigger:hover{ border-color:var(--cd-gold); background:rgba(201,162,39,.08); }
#cruzdiaz-app .cd-menu-trigger__bars{ display:inline-flex; flex-direction:column; gap:3px; width:16px; }
#cruzdiaz-app .cd-menu-trigger__bars i{ display:block; height:1.6px; background:var(--cd-gold-soft); border-radius:2px; }
#cruzdiaz-app .cd-menu-trigger__bars i:nth-child(2){ width:72%; }

/* ===== Overlay del menú (portado a <body>: SIN scope #cruzdiaz-app, colores literales) ===== */
.cd-cm{ position:fixed; inset:0; z-index:100; }
.cd-cm[hidden]{ display:none !important; }
.cd-cm__panel{ position:absolute; inset:0; z-index:1; display:flex; flex-direction:column; padding:calc(22px + env(safe-area-inset-top,0px)) clamp(22px,6vw,72px) calc(28px + env(safe-area-inset-bottom,0px)); overflow-y:auto; color:#F4F2ED; font-family:'Inter', system-ui, sans-serif; opacity:0; }
.cd-cm__top{ display:flex; align-items:center; justify-content:space-between; }
.cd-cm__brand{ display:inline-flex; background:#FAFAF7; border:1px solid rgba(201,162,39,.40); border-radius:9px; padding:6px 12px; }
.cd-cm__brand img{ height:30px; width:auto; display:block; }
.cd-cm__close{ width:46px; height:46px; display:inline-flex; align-items:center; justify-content:center; border:1px solid rgba(244,242,237,.32); border-radius:50%; background:transparent; color:#F4F2ED; cursor:pointer; transition:.2s; }
.cd-cm__close:hover{ border-color:#C9A227; color:#fff; }
.cd-cm__close svg{ width:16px; height:16px; }
.cd-cm__nav{ margin:auto 0; padding:28px 0; }
.cd-cm__nav ul{ list-style:none; margin:0; padding:0; }
.cd-cm__nav li{ border-bottom:1px solid rgba(201,162,39,.16); }
.cd-cm__link{ display:block; padding:15px 0; text-decoration:none; color:#F4F2ED; font-family:'Cormorant Garamond', Georgia, serif; font-weight:600; font-size:clamp(26px,3.8vw,40px); line-height:1.1; letter-spacing:.005em; transition:color .2s, transform .2s; }
.cd-cm__link:hover{ color:#D8BC5E; transform:translateX(6px); }
.cd-cm__link[aria-current='page']{ color:#C9A227; }
.cd-cm__link:focus-visible, .cd-cm__close:focus-visible, .cd-cm__cta:focus-visible, .cd-cm__wa:focus-visible{ outline:2px solid #C9A227; outline-offset:4px; }
.cd-cm__foot{ display:flex; flex-wrap:wrap; gap:12px; padding-top:18px; }
.cd-cm__cta{ font-family:'Inter',sans-serif; font-weight:600; font-size:14px; text-decoration:none; color:#14110E; background:#C9A227; padding:13px 26px; border-radius:999px; transition:.25s; }
.cd-cm__cta:hover{ background:#D8BC5E; }
.cd-cm__wa{ font-family:'Inter',sans-serif; font-weight:600; font-size:14px; text-decoration:none; color:#F4F2ED; border:1px solid rgba(244,242,237,.25); padding:13px 26px; border-radius:999px; transition:.25s; }
.cd-cm__wa:hover{ border-color:#C9A227; }
.cd-cm__disc{ margin-top:20px; font-size:12px; color:#9d978a; line-height:1.6; max-width:60ch; }
@media (prefers-reduced-motion: reduce){ .cd-cm__panel{ opacity:1 !important; } .cd-cm__link, .cd-cm__link:hover{ transition:none; transform:none; } }

/* ===== Responsive: WEB (prioridad) ===== */
@media (min-width:1100px){ #cruzdiaz-app .cd-grid{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1024px){ #cruzdiaz-app .cd-price-side{ position:sticky; top:calc(var(--cd-nav-h) + 20px); align-self:start; } }

/* ===== Responsive: móvil ===== */
@media (max-width:860px){
  #cruzdiaz-app .cd-tab{ padding:11px 12px; min-height:44px; }
  #cruzdiaz-app .cd-menu-trigger{ padding:9px 13px; }
}
@media (max-width:600px){
  #cruzdiaz-app .cd-stage{ flex-wrap:wrap; }
  #cruzdiaz-app .cd-stage-body{ flex:1 1 60%; }
  #cruzdiaz-app .cd-stage-price{ font-size:clamp(22px,7vw,30px); }
}
@media (max-width:520px){
  #cruzdiaz-app #cd-precio .cd-actions{ flex-direction:column; align-items:stretch; }
  #cruzdiaz-app #cd-precio .cd-actions .cd-btn{ width:100%; justify-content:center; }
  #cruzdiaz-app .cd-sev-legend{ gap:12px; }
}

/* ===== v5.1 — legibilidad: calmar el orbe + sombra de texto sobre el fondo ===== */
/* Velo uniforme que empuja el 3D atrás (texto siempre gana, orbe menos saturado) */
#cruzdiaz-app .cd-vignette::after{ content:""; position:fixed; inset:0; background:rgba(7,7,10,0.34); pointer-events:none; }
/* Sombra suave para que ningún texto se pierda sobre el orbe/fondo */
#cruzdiaz-app .cd-h2, #cruzdiaz-app .cd-lead, #cruzdiaz-app .cd-sub, #cruzdiaz-app .cd-hero-note, #cruzdiaz-app .cd-prose p, #cruzdiaz-app .cd-prose li, #cruzdiaz-app .cd-chip, #cruzdiaz-app .cd-creds span{ text-shadow:0 1px 14px rgba(0,0,0,.65); }
/* H1 más legible sobre el orbe (sombra oscura + leve halo dorado) */
#cruzdiaz-app .cd-h1{ text-shadow:0 2px 22px rgba(0,0,0,.62), 0 0 46px rgba(201,162,39,.15); }

/* ===== Comparativa "lo que muchos hacen vs. lo que conviene" ===== */
#cruzdiaz-app .cd-vs{ margin-top:42px; border:1px solid var(--cd-line); border-radius:16px; overflow:hidden; background:var(--cd-surface); }
#cruzdiaz-app .cd-vs-head{ display:grid; grid-template-columns:1fr 1fr; }
#cruzdiaz-app .cd-vs-head span{ padding:14px 20px; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
#cruzdiaz-app .cd-vs-head span:first-child{ color:#d8a99e; background:rgba(180,69,47,.12); }
#cruzdiaz-app .cd-vs-head span:last-child{ color:var(--cd-gold-soft); background:rgba(201,162,39,.12); }
#cruzdiaz-app .cd-vs-row{ display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--cd-line-soft); }
#cruzdiaz-app .cd-vs-bad, #cruzdiaz-app .cd-vs-good{ padding:16px 20px 16px 46px; font-size:14.5px; line-height:1.5; position:relative; }
#cruzdiaz-app .cd-vs-bad{ color:var(--cd-muted); background:rgba(180,69,47,.06); }
#cruzdiaz-app .cd-vs-good{ color:var(--cd-text); background:rgba(201,162,39,.05); border-left:1px solid var(--cd-line-soft); }
#cruzdiaz-app .cd-vs-bad::before{ content:"\2717"; position:absolute; left:18px; top:16px; color:#c0563f; font-weight:700; }
#cruzdiaz-app .cd-vs-good::before{ content:"\2713"; position:absolute; left:18px; top:16px; color:var(--cd-gold); font-weight:700; }
@media (max-width:680px){
  #cruzdiaz-app .cd-vs-head{ display:none; }
  #cruzdiaz-app .cd-vs-row{ grid-template-columns:1fr; }
  #cruzdiaz-app .cd-vs-good{ border-left:0; border-top:1px solid var(--cd-line-soft); }
}

/* ===========================================================
   BANNER de apertura (estilo referencia): ® 3D + flow 2D + grid.
   Es OPACO y cubre el 3D fijo; al hacer scroll, se revela el 3D detrás.
   =========================================================== */
#cruzdiaz-app .cd-banner{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; background:#07070a; padding:calc(var(--cd-nav-h,68px) + 30px) 0 90px; }
#cruzdiaz-app .cd-banner-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; display:block; }
#cruzdiaz-app .cd-banner-grid{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background-image:linear-gradient(rgba(244,242,237,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(244,242,237,.05) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask:radial-gradient(ellipse 75% 65% at 62% 45%, #000 22%, transparent 80%);
  mask:radial-gradient(ellipse 75% 65% at 62% 45%, #000 22%, transparent 80%);
  animation:cdGridDrift 18s linear infinite; }
@keyframes cdGridDrift{ to{ background-position:64px 64px; } }
#cruzdiaz-app .cd-banner-r{ position:absolute; right:5%; top:50%; transform:translateY(-50%); z-index:1; width:min(46vw,440px); height:min(46vw,440px); display:flex; align-items:center; justify-content:center; pointer-events:none; }
#cruzdiaz-app .cd-r-glow{ position:absolute; inset:-12%; border-radius:50%; background:radial-gradient(circle, rgba(201,162,39,.42), rgba(201,162,39,.08) 45%, transparent 68%); filter:blur(20px); animation:cdGlowPulse 5s ease-in-out infinite; }
@keyframes cdGlowPulse{ 0%,100%{opacity:.7; transform:scale(.97);} 50%{opacity:1; transform:scale(1.05);} }
#cruzdiaz-app .cd-r-stage{ position:relative; width:72%; height:72%; transform-style:preserve-3d; transform:rotateX(var(--rx,-10deg)) rotateY(var(--ry,16deg)) scale(var(--sz,1)); transition:transform .25s ease-out; animation:cdRfloat 7s ease-in-out infinite; }
#cruzdiaz-app .cd-banner-copy{ transition:transform .1s linear; will-change:transform; }
#cruzdiaz-app .cd-banner-grid{ will-change:transform; }

/* ===== Banner Chekea: tema teal + hoja con checklist + sello ✓ ===== */
#cruzdiaz-app .cd-banner-chekea{ background:#06100f; }
#cruzdiaz-app .cd-banner-chekea .cd-r-glow{ background:radial-gradient(circle, rgba(35,162,154,.40), rgba(35,162,154,.08) 45%, transparent 68%); }
#cruzdiaz-app .cd-doc-stage{ position:relative; width:80%; height:80%; transform-style:preserve-3d; transform:rotateX(var(--rx,-8deg)) rotateY(var(--ry,14deg)) scale(var(--sz,1)); transition:transform .25s ease-out; animation:cdRfloat 7s ease-in-out infinite; display:flex; align-items:center; justify-content:center; }
#cruzdiaz-app .cd-doc{ position:relative; width:62%; aspect-ratio:3/4; background:linear-gradient(180deg, rgba(18,38,38,.94), rgba(10,24,24,.94)); border:1px solid rgba(95,208,198,.40); border-radius:12px; box-shadow:0 30px 60px rgba(0,0,0,.5); padding:14% 12%; display:flex; flex-direction:column; justify-content:center; gap:11%; }
#cruzdiaz-app .cd-doc-line{ display:flex; align-items:center; gap:9%; }
#cruzdiaz-app .cd-doc-line i{ flex:none; width:15%; aspect-ratio:1; border-radius:4px; background:#23A29A; position:relative; box-shadow:0 0 12px rgba(35,162,154,.5); }
#cruzdiaz-app .cd-doc-line i::after{ content:"\2713"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:#06130f; font-weight:800; font-size:clamp(9px,1.6vw,15px); }
#cruzdiaz-app .cd-doc-line span{ flex:1; height:8px; border-radius:3px; background:rgba(95,208,198,.35); }
#cruzdiaz-app .cd-doc-line:nth-child(2) span{ width:78%; }
#cruzdiaz-app .cd-doc-line:nth-child(4) span{ width:64%; }
#cruzdiaz-app .cd-doc-seal{ position:absolute; right:-16%; bottom:-12%; width:46%; aspect-ratio:1; border-radius:50%; border:2px solid #5FD0C6; background:radial-gradient(circle, rgba(35,162,154,.40), rgba(8,20,20,.92)); display:flex; align-items:center; justify-content:center; color:#bff3ec; font-weight:800; font-size:min(13vw,84px); transform:translateZ(46px); box-shadow:0 0 46px rgba(35,162,154,.5); }
@keyframes cdRfloat{ 0%,100%{ translate:0 -2%; } 50%{ translate:0 2%; } }
#cruzdiaz-app .cd-r-symbol, #cruzdiaz-app .cd-r-face{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--cd-display); font-weight:700; line-height:1; font-size:min(42vw,360px); }
#cruzdiaz-app .cd-r-symbol{ color:rgba(201,162,39,.20); transform:translateZ(-26px); }
#cruzdiaz-app .cd-r-face{ color:var(--cd-gold); transform:translateZ(26px); text-shadow:0 0 50px rgba(201,162,39,.45); }
#cruzdiaz-app .cd-banner-copy{ position:relative; z-index:3; max-width:660px; }
#cruzdiaz-app .cd-banner-copy .cd-h1{ font-size:clamp(40px,6.2vw,80px); margin:18px 0 18px; }
#cruzdiaz-app .cd-banner-copy > *{ animation:cdBannerUp .8s cubic-bezier(.2,.7,.2,1) both; }
#cruzdiaz-app .cd-banner-copy > *:nth-child(2){ animation-delay:.08s; }
#cruzdiaz-app .cd-banner-copy > *:nth-child(3){ animation-delay:.16s; }
#cruzdiaz-app .cd-banner-copy > *:nth-child(4){ animation-delay:.24s; }
@keyframes cdBannerUp{ from{ opacity:0; transform:translateY(22px); } to{ opacity:1; transform:none; } }
@media (max-width:820px){
  #cruzdiaz-app .cd-banner-r{ right:50%; transform:translate(50%,-50%); opacity:.30; width:min(82vw,360px); height:min(82vw,360px); }
}
@media (prefers-reduced-motion: reduce){
  #cruzdiaz-app .cd-banner-grid, #cruzdiaz-app .cd-r-glow, #cruzdiaz-app .cd-r-stage{ animation:none; }
  #cruzdiaz-app .cd-banner-copy > *{ animation:none; }
}
