/* Laura Ramírez Insolvencia — Landing
   Palette: ink + gold. Display: Cormorant. Body: Inter.
*/
:root{
  --ink:        #0B0F1A;
  --ink-2:      #0E1422;
  --panel:      #11172A;
  --panel-2:    #161D34;
  --line:       rgba(201,168,106,.22);
  --line-soft:  rgba(241,233,214,.08);
  --parchment:  #F1E9D6;
  --parchment-d:#C9C0A8;
  --muted:      #8C8773;
  --gold:       #C9A86A;
  --gold-deep:  #8C6A2F;
  --gold-light: #E6C887;
  --whats:      #25D366;
  --whats-d:    #128C7E;
  --alert:      #C2402F;

  --serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, Menlo, monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--ink);color:var(--parchment)}
body{
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* ---- texture: subtle brick grain on body ---- */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(1200px 600px at 50% -200px, rgba(201,168,106,.10), transparent 60%),
    radial-gradient(800px 400px at 100% 120%, rgba(201,168,106,.06), transparent 60%);
  pointer-events:none;
  z-index:0;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 3px),
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.04) 50%, transparent 51%),
    radial-gradient(1px 1px at 70% 80%, rgba(255,255,255,.03) 50%, transparent 51%);
  background-size: auto, 240px 240px, 320px 320px;
  mix-blend-mode:overlay;
  pointer-events:none;
  opacity:.6;
  z-index:0;
}

.shell{max-width:480px;margin:0 auto;position:relative;z-index:1}
@media (min-width: 900px){
  .shell{max-width:1120px}
}

/* ============ TOP BAR ============ */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;
  background:rgba(11,15,26,.78);
  backdrop-filter: blur(10px);
  z-index:50;
}
.brand{display:flex;align-items:center;gap:12px}
.crest{
  width:44px;height:44px;flex-shrink:0;
  display:block;
  position:relative;
  background:#000;
  overflow:hidden;
}
.crest img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter: contrast(1.05) brightness(1.05);
}
.brand-name{
  font-family:var(--serif);
  font-size:18px;letter-spacing:.04em;
  color:var(--parchment);
  line-height:1;
}
.brand-name em{font-style:italic;color:var(--gold);font-weight:500}
.brand-sub{
  font-family:var(--sans);
  font-size:9.5px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--muted);
  margin-top:5px;
}
.topbar .top-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;
  border:1px solid var(--gold);
  color:var(--gold);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  border-radius:999px;
  transition:all .25s ease;
}
.topbar .top-cta:hover{background:var(--gold);color:var(--ink)}
.topbar .top-cta svg{width:14px;height:14px}
@media (max-width: 480px){
  .topbar .top-cta span{display:none}
  .topbar .top-cta{padding:9px 10px}
}

/* ============ ORNAMENT (rule with center diamond) ============ */
.ornament{
  display:flex;align-items:center;justify-content:center;gap:14px;
  color:var(--gold);
  margin: 18px 0;
}
.ornament .line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent)}
.ornament .diamond{
  width:8px;height:8px;background:var(--gold);
  transform:rotate(45deg);
  box-shadow:0 0 0 4px rgba(201,168,106,.08);
}
.ornament.tight{margin:8px 0}
.ornament.short .line{max-width:80px}

/* deco corner frame for hero / cards */
.deco-frame{position:relative}
.deco-frame::before,.deco-frame::after{
  content:"";position:absolute;width:22px;height:22px;
  border:1px solid var(--gold);
  opacity:.7;
}
.deco-frame::before{top:10px;left:10px;border-right:0;border-bottom:0}
.deco-frame::after{bottom:10px;right:10px;border-left:0;border-top:0}
.deco-frame .corner-tr,.deco-frame .corner-bl{
  position:absolute;width:22px;height:22px;border:1px solid var(--gold);opacity:.7;
}
.deco-frame .corner-tr{top:10px;right:10px;border-left:0;border-bottom:0}
.deco-frame .corner-bl{bottom:10px;left:10px;border-right:0;border-top:0}

/* ============ HERO ============ */
.hero{
  position:relative;
  padding:36px 22px 32px;
  overflow:hidden;
}
.hero-eyebrow{
  font-size:10.5px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:22px;
}
.hero-eyebrow::before,.hero-eyebrow::after{content:"";width:18px;height:1px;background:var(--gold)}
.hero h1{
  font-family:var(--serif);
  font-weight:500;
  font-size:42px;
  line-height:1.04;
  letter-spacing:-.005em;
  color:var(--parchment);
  margin-bottom:18px;
  text-wrap:balance;
}
.hero h1 .accent{
  font-style:italic;
  color:var(--gold);
}
.hero h1 .stroke{
  display:inline-block;
  position:relative;
}
.hero h1 .stroke::after{
  content:"";position:absolute;left:0;right:0;bottom:.05em;height:2px;
  background:var(--gold);opacity:.85;
}
.hero p.lede{
  font-size:16.5px;
  color:var(--parchment-d);
  line-height:1.6;
  max-width:36ch;
  margin-bottom:26px;
}

.hero-portrait{
  position:relative;
  border:1px solid var(--gold);
  background:var(--panel);
  aspect-ratio: 4/5;
  margin-bottom:26px;
  overflow:hidden;
  box-shadow: 0 30px 60px -30px rgba(0,0,0,.8), 0 0 0 1px rgba(201,168,106,.15) inset;
}
.hero-portrait img{
  width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block;
}
.hero-portrait::after{
  content:"";position:absolute;inset:0;
  background: linear-gradient(180deg, rgba(11,15,26,.05) 0%, rgba(11,15,26,0) 30%, rgba(11,15,26,.85) 100%);
  pointer-events:none;
}
.hero-portrait .corner{
  position:absolute;width:28px;height:28px;border:1px solid var(--gold);z-index:2
}
.hero-portrait .corner.tl{top:10px;left:10px;border-right:0;border-bottom:0}
.hero-portrait .corner.tr{top:10px;right:10px;border-left:0;border-bottom:0}
.hero-portrait .corner.bl{bottom:10px;left:10px;border-right:0;border-top:0}
.hero-portrait .corner.br{bottom:10px;right:10px;border-left:0;border-top:0}
.hero-portrait .badge{
  position:absolute;left:0;right:0;bottom:18px;text-align:center;z-index:2;
  font-family:var(--serif);font-style:italic;font-size:18px;color:var(--parchment);
  text-shadow:0 2px 16px rgba(0,0,0,.7);
}
.hero-portrait .badge small{
  display:block;font-family:var(--sans);font-style:normal;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  margin-top:6px;
}
.hero-portrait .ribbon{
  position:absolute;left:14px;top:14px;
  display:inline-flex;gap:8px;align-items:center;
  background:rgba(11,15,26,.88);
  border:1px solid var(--gold);
  padding:7px 12px;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
}
.hero-portrait .ribbon-dot{width:6px;height:6px;background:var(--gold);transform:rotate(45deg)}

.cta-row{
  display:flex;flex-direction:column;gap:12px;
}
.cta-whats{
  display:flex;align-items:center;justify-content:center;gap:14px;
  background:linear-gradient(180deg, #2BD171, #1FA85B);
  color:#06180D;
  font-weight:700;
  letter-spacing:.04em;
  padding:18px 22px;
  font-size:16px;
  border-radius:2px;
  border:1px solid rgba(0,0,0,.3);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 14px 30px -10px rgba(37,209,102,.45);
  position:relative;
  transition:transform .15s ease, box-shadow .25s ease;
}
.cta-whats:hover{transform:translateY(-1px);box-shadow:0 18px 40px -10px rgba(37,209,102,.55)}
.cta-whats svg{width:22px;height:22px;flex-shrink:0}
.cta-whats .number{font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:.05em}
.cta-whats .pulse{
  position:absolute;left:24px;top:50%;transform:translateY(-50%);
  width:10px;height:10px;border-radius:50%;background:#fff;opacity:0;
  animation: pulse 2.4s infinite;
}
@keyframes pulse{
  0%{opacity:.7;transform:translateY(-50%) scale(.6)}
  60%,100%{opacity:0;transform:translateY(-50%) scale(2.4)}
}
@media (max-width: 480px){
  .cta-whats{
    flex-wrap:wrap;
    column-gap:10px;
    row-gap:4px;
    padding:14px 18px;
    font-size:15px;
  }
  .cta-whats .number{
    flex-basis:100%;
    text-align:center;
    font-size:13px;
    opacity:.9;
    letter-spacing:.08em;
  }
}

.cta-secondary{
  display:flex;align-items:center;justify-content:center;gap:10px;
  border:1px solid var(--gold);
  color:var(--gold);
  padding:15px 22px;
  font-size:13px;letter-spacing:.22em;text-transform:uppercase;
  transition: all .25s ease;
}
.cta-secondary:hover{background:rgba(201,168,106,.08)}

.hero-trust{
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--line);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  flex-wrap:wrap;
  text-align:center;
}
.hero-trust .lock{color:var(--gold)}
.hero-trust .dot{width:3px;height:3px;background:var(--gold);border-radius:50%}

/* ============ SECTION ============ */
section{
  position:relative;
  padding:54px 22px;
  z-index:1;
}
.eyebrow{
  font-size:10.5px;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--gold)}
.h2{
  font-family:var(--serif);
  font-weight:500;
  font-size:32px;line-height:1.1;
  color:var(--parchment);
  margin-bottom:14px;
  text-wrap:balance;
}
.h2 em{font-style:italic;color:var(--gold);font-weight:500}
.section-lede{
  font-size:15px;
  color:var(--parchment-d);
  max-width:42ch;
  margin-bottom:28px;
  line-height:1.6;
}

/* ============ BENEFITS ============ */
.benefits{
  background:linear-gradient(180deg,var(--ink) 0%, var(--ink-2) 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.benefit-grid{
  display:grid;grid-template-columns:1fr;gap:14px;
}
@media (min-width:720px){
  .benefit-grid{grid-template-columns:1fr 1fr}
}
.benefit{
  position:relative;
  display:flex;gap:16px;align-items:flex-start;
  padding:22px 22px 22px 22px;
  background:var(--panel);
  border:1px solid var(--line);
  transition: border-color .25s ease, transform .25s ease;
}
.benefit:hover{border-color:var(--gold);transform:translateY(-2px)}
.benefit::before{
  content:"";position:absolute;left:0;top:0;width:3px;height:34px;
  background:var(--gold);
}
.benefit-icon{
  width:46px;height:46px;flex-shrink:0;
  border:1px solid var(--gold);
  display:grid;place-items:center;
  color:var(--gold);
  position:relative;
}
.benefit-icon::before{
  content:"";position:absolute;inset:3px;border:1px solid var(--gold);opacity:.4
}
.benefit-icon svg{width:22px;height:22px;stroke-width:1.4}
.benefit h3{
  font-family:var(--serif);
  font-weight:500;font-size:20px;
  color:var(--parchment);
  margin-bottom:5px;
}
.benefit h3 .gold{color:var(--gold);font-style:italic}
.benefit p{
  font-size:13.5px;
  color:var(--parchment-d);
  line-height:1.55;
}

/* ============ AUDIENCE ============ */
.audience-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
@media (min-width:720px){
  .audience-grid{grid-template-columns:repeat(4,1fr)}
}
.audience-card{
  position:relative;
  padding:26px 16px 22px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel) 0%, transparent 120%);
  text-align:center;
  transition: all .25s ease;
}
.audience-card:hover{border-color:var(--gold);background:var(--panel-2)}
.audience-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;color:var(--gold);
  letter-spacing:.1em;
  margin-bottom:10px;
}
.audience-card h4{
  font-family:var(--serif);
  font-weight:500;font-size:18px;
  color:var(--parchment);
  margin-bottom:6px;
}
.audience-card p{
  font-size:12px;color:var(--muted);line-height:1.5;
}

/* ============ PROCESS ============ */
.process{
  background:var(--ink-2);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.steps{
  display:grid;grid-template-columns:1fr;gap:0;
  margin-top:10px;
}
.step{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:22px;
  padding:24px 0;
  border-bottom:1px solid var(--line-soft);
  align-items:flex-start;
}
.step:last-child{border-bottom:0}
.step-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:46px;line-height:1;
  color:var(--gold);
  text-align:center;
  position:relative;
  padding-top:6px;
}
.step-num::after{
  content:"";display:block;width:30px;height:1px;
  background:var(--gold);
  margin:12px auto 0;
  opacity:.4;
}
.step h3{
  font-family:var(--serif);font-weight:500;font-size:21px;
  color:var(--parchment);
  margin-bottom:6px;
}
.step p{
  font-size:14px;color:var(--parchment-d);line-height:1.6;
  max-width:50ch;
}
.step .duration{
  display:inline-block;margin-top:10px;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
  border:1px solid var(--gold);
  padding:5px 10px;
}

/* ============ MID CTA ============ */
.midcta{
  position:relative;
  padding:40px 22px;
  margin: 0 22px;
  border:1px solid var(--gold);
  text-align:center;
  background:
    radial-gradient(60% 80% at 50% 0%, rgba(201,168,106,.10), transparent 70%),
    var(--panel);
}
.midcta::before,.midcta::after{
  content:"";position:absolute;width:18px;height:18px;border:1px solid var(--gold);
}
.midcta::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.midcta::after{bottom:-1px;right:-1px;border-left:0;border-top:0}
.midcta-portrait{
  position:relative;
  width:160px;height:200px;
  margin: 0 auto 22px;
  border:1px solid var(--gold);
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(201,168,106,.18) inset, 0 20px 40px -20px rgba(0,0,0,.7);
}
.midcta-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 25%;display:block}
.midcta-portrait::after{
  content:"";position:absolute;inset:0;
  background: linear-gradient(180deg, transparent 50%, rgba(11,15,26,.7) 100%);
}

.final-portrait{
  position:relative;
  width:120px;height:120px;border-radius:50%;
  margin: 0 auto 8px;
  overflow:hidden;
  border:1px solid var(--gold);
  box-shadow:0 0 0 4px rgba(201,168,106,.10), 0 14px 30px -10px rgba(0,0,0,.6);
}
.final-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}

.midcta .quote{
  font-family:var(--serif);
  font-style:italic;
  font-size:24px;
  color:var(--parchment);
  line-height:1.3;
  margin-bottom:8px;
  text-wrap:balance;
}
.midcta .quote em{color:var(--gold)}
.midcta .sub{
  font-size:13px;color:var(--parchment-d);margin-bottom:22px;
}

/* ============ TRUST ============ */
.trust{
  background: linear-gradient(180deg, var(--ink-2), var(--ink));
}
.metrics{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin: 28px 0 36px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.metric{
  text-align:center;padding:24px 8px;
  border-right:1px solid var(--line);
}
.metric:last-child{border-right:0}
.metric .num{
  font-family:var(--serif);
  font-size:38px;line-height:1;
  color:var(--gold);
  margin-bottom:6px;
  font-weight:500;
}
.metric .num sup{font-size:18px;vertical-align:super;margin-left:1px;font-style:italic}
.metric .label{
  font-size:10px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--muted);
}

.testimonials{
  display:grid;gap:14px;
}
@media (min-width:720px){
  .testimonials{grid-template-columns:1fr 1fr 1fr}
}
.testi{
  position:relative;
  padding:26px 22px 22px;
  border:1px solid var(--line);
  background:var(--panel);
}
.testi::before{
  content:"\201C";
  position:absolute;top:-2px;left:14px;
  font-family:var(--serif);
  font-size:60px;line-height:1;
  color:var(--gold);
  opacity:.5;
}
.testi p{
  font-family:var(--serif);
  font-style:italic;
  font-size:15.5px;
  color:var(--parchment);
  line-height:1.5;
  margin-bottom:18px;
  margin-top:8px;
}
.testi .who{
  display:flex;align-items:center;gap:10px;
  padding-top:14px;
  border-top:1px solid var(--line-soft);
}
.testi .avatar{
  width:36px;height:36px;
  background:linear-gradient(135deg,var(--gold-deep),var(--gold));
  display:grid;place-items:center;
  color:var(--ink);font-family:var(--serif);font-weight:600;font-size:14px;
}
.testi .who-meta .name{
  font-size:12.5px;color:var(--parchment);font-weight:500;
}
.testi .who-meta .role{
  font-size:10.5px;color:var(--muted);letter-spacing:.1em;
}

.credentials{
  margin-top:32px;
  padding:22px;
  border:1px solid var(--line);
  display:grid;grid-template-columns:1fr;gap:14px;
}
@media (min-width:720px){
  .credentials{grid-template-columns:repeat(4,1fr);gap:0}
}
.cred{
  text-align:center;padding:8px 14px;
  border-right:1px solid var(--line-soft);
}
.cred:last-child{border-right:0}
@media (max-width:719px){
  .cred{border-right:0;border-bottom:1px solid var(--line-soft);padding:10px 0}
  .cred:last-child{border-bottom:0}
}
.cred .icon{color:var(--gold);margin-bottom:6px;display:flex;justify-content:center}
.cred .icon svg{width:22px;height:22px}
.cred .label{
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}
.cred .val{
  font-family:var(--serif);font-size:15px;color:var(--parchment);margin-top:2px;
}

/* ============ FAQ ============ */
.faq-list{
  border-top:1px solid var(--line);
}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:22px 4px;
  text-align:left;
  font-family:var(--serif);
  font-size:18px;
  color:var(--parchment);
  transition: color .25s ease;
}
.faq-q:hover{color:var(--gold)}
.faq-q .plus{
  width:28px;height:28px;flex-shrink:0;
  border:1px solid var(--gold);
  display:grid;place-items:center;
  color:var(--gold);
  position:relative;
  transition: transform .35s ease, background .25s ease;
}
.faq-q .plus::before,.faq-q .plus::after{
  content:"";position:absolute;background:var(--gold);
}
.faq-q .plus::before{width:11px;height:1px}
.faq-q .plus::after{width:1px;height:11px;transition:transform .25s ease}
.faq-item.open .faq-q .plus{background:var(--gold)}
.faq-item.open .faq-q .plus::before,
.faq-item.open .faq-q .plus::after{background:var(--ink)}
.faq-item.open .faq-q .plus::after{transform:scaleY(0)}
.faq-a{
  max-height:0;overflow:hidden;
  transition: max-height .35s ease;
}
.faq-a-inner{
  padding:0 4px 22px;
  font-size:14.5px;color:var(--parchment-d);line-height:1.65;
  max-width:60ch;
}
.faq-item.open .faq-a{max-height:280px}

/* ============ FINAL CTA ============ */
.final{
  position:relative;
  padding:64px 22px 48px;
  text-align:center;
  border-top:1px solid var(--line);
  background:
    radial-gradient(50% 80% at 50% 0%, rgba(201,168,106,.14), transparent 70%),
    var(--ink);
}
.final h2{
  font-family:var(--serif);
  font-weight:500;font-size:36px;line-height:1.05;
  color:var(--parchment);
  margin: 14px 0 14px;
  text-wrap:balance;
}
.final h2 em{font-style:italic;color:var(--gold)}
.final p.sub{
  font-size:15.5px;color:var(--parchment-d);
  max-width:42ch;margin: 0 auto 28px;
}
.final .cta-whats{max-width:380px;margin:0 auto}
.final .small{
  margin-top:20px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);
}

/* ============ FOOTER ============ */
footer{
  padding:32px 22px 110px; /* room for sticky bar */
  border-top:1px solid var(--line);
  background:var(--ink-2);
  text-align:center;
  position:relative;z-index:1;
}
footer .brand{justify-content:center;margin-bottom:16px}
footer .meta{
  font-size:11.5px;color:var(--muted);letter-spacing:.04em;line-height:1.7;
}
footer .meta a{color:var(--parchment-d);border-bottom:1px solid var(--line)}
footer .legal{
  margin-top:14px;font-size:10.5px;color:var(--muted);letter-spacing:.06em;
}

/* ============ STICKY WHATSAPP ============ */
.sticky-bar{
  position:fixed;left:0;right:0;bottom:0;
  z-index:60;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg, rgba(11,15,26,.4), rgba(11,15,26,.96) 50%);
  backdrop-filter: blur(8px);
  display:flex;justify-content:center;
  pointer-events:none;
}
.sticky-bar .cta-whats{
  pointer-events:auto;
  width:100%;max-width:480px;
  padding:14px 18px;
  font-size:14.5px;
}

/* ============ ANIM ON SCROLL ============ */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}
