/* ============================================================
   Mira Data · "Expediente" — refined investigative-dossier theme
   Light, editorial, restrained. Fraunces + Newsreader + Plex Mono.
   ============================================================ */

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }

:root{
  /* Paper & ink */
  --paper:#faf7f0;
  --paper-2:#f3eee2;
  --card:#fffdf8;
  --ink:#1c1a16;
  --ink-soft:#56514a;
  --ink-faint:#928b7d;
  --rule:#e7dfcf;
  --rule-strong:#d8cfba;

  /* Single disciplined accent — classified vermilion */
  --accent:#bf3b26;
  --accent-deep:#9c2c1a;
  --accent-soft:#f5e4dd;

  --green:#3f7d4f;

  /* Type */
  --display:"Fraunces",Georgia,serif;
  --body:"Newsreader",Georgia,serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;

  /* Form */
  --radius:14px;
  --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(28,26,22,.05), 0 1px 1px rgba(28,26,22,.04);
  --shadow:0 2px 4px rgba(28,26,22,.04), 0 18px 40px -22px rgba(28,26,22,.22);
  --shadow-lg:0 4px 10px rgba(28,26,22,.05), 0 40px 80px -36px rgba(28,26,22,.30);

  --maxw:1140px;
  --gutter:clamp(1.25rem,5vw,3rem);
}

html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }

body{
  font-family:var(--body);
  font-size:1.075rem;
  line-height:1.65;
  color:var(--ink);
  background-color:var(--paper);
  /* faint paper grain */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
strong{ font-weight:600; }
.mono{ font-family:var(--mono); }

.section, .hero, .stats, .cta__inner, .nav, .footer{
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

/* ---------- Classification strip ---------- */
.strip{
  background:var(--ink);
  color:#e9e3d6;
  font-family:var(--mono);
  font-size:.66rem;
  letter-spacing:.16em;
}
.strip__inner{
  max-width:var(--maxw); margin-inline:auto; padding:.5rem var(--gutter);
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
}
.strip__mid{ color:#a39a87; }
.strip__ref{ color:#cfc6b3; display:flex; align-items:center; gap:.1rem; white-space:nowrap; }
.strip__live{
  display:inline-block; width:.42rem; height:.42rem; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 0 rgba(191,59,38,.6);
  animation:pulse 2.4s infinite;
}
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(191,59,38,.55);} 70%{box-shadow:0 0 0 6px rgba(191,59,38,0);} 100%{box-shadow:0 0 0 0 rgba(191,59,38,0);} }
@media(max-width:680px){ .strip__mid{ display:none; } }

/* ---------- Nav ---------- */
.nav{
  display:flex; align-items:center; gap:1.5rem;
  padding-top:1.5rem; padding-bottom:1.5rem;
}
.brand{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--display); font-weight:600; font-size:1.3rem; letter-spacing:-.01em; }
.brand__mark{
  width:1.05rem; height:1.05rem; border-radius:3px;
  background:var(--accent); position:relative; transform:rotate(45deg);
  box-shadow:inset 0 0 0 2px var(--paper), 0 0 0 1.5px var(--accent);
}
.brand__dot{ color:var(--accent); }
.nav__links{ margin-left:auto; display:flex; gap:2rem; font-size:.95rem; }
.nav__links a{ color:var(--ink-soft); transition:color .2s; position:relative; }
.nav__links a:hover{ color:var(--ink); }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-4px; width:0; height:1.5px; background:var(--accent); transition:width .25s ease; }
.nav__links a:hover::after{ width:100%; }
@media(max-width:760px){ .nav__links{ display:none; } }

/* ---------- Buttons ---------- */
.btn{
  --b:var(--ink);
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--mono); font-size:.82rem; font-weight:500; letter-spacing:.04em;
  text-transform:uppercase;
  padding:.7rem 1.25rem; border-radius:var(--radius-sm);
  background:var(--ink); color:var(--paper);
  border:1px solid var(--ink);
  cursor:pointer; transition:transform .18s ease, box-shadow .22s ease, background .2s, color .2s;
  box-shadow:var(--shadow-sm);
}
.btn:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.btn--sm{ padding:.55rem 1rem; font-size:.76rem; }
.btn--lg{ padding:.95rem 1.7rem; font-size:.86rem; }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--rule-strong); box-shadow:none; }
.btn--ghost:hover{ border-color:var(--ink); box-shadow:var(--shadow-sm); }
.btn--block{ width:100%; }
.btn--invert{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ---------- Hero ---------- */
.hero{
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4.5rem);
  align-items:center;
  padding-top:clamp(3rem,7vw,6rem); padding-bottom:clamp(3.5rem,8vw,7rem);
}
.eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent-deep);
  padding:.35rem .7rem; border:1px solid var(--accent-soft); border-radius:100px;
  background:var(--accent-soft);
}
.eyebrow__dot{ width:.45rem; height:.45rem; border-radius:50%; background:var(--accent); }
.hero__title{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(2.6rem,5.6vw,4.4rem);
  line-height:1.04; letter-spacing:-.025em;
  margin:1.4rem 0 1.4rem;
  font-optical-sizing:auto;
}
.hero__title em{ color:var(--accent); font-weight:500; }
.hero__sub{
  font-size:clamp(1.08rem,1.6vw,1.3rem); color:var(--ink-soft);
  max-width:34rem; line-height:1.6;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:.8rem; margin:2rem 0 1.1rem; }
.hero__trust{ font-family:var(--mono); font-size:.74rem; letter-spacing:.05em; color:var(--ink-faint); }

/* ---------- Dossier evidence card ---------- */
.dossier{
  position:relative; background:var(--card);
  border:1px solid var(--rule); border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  padding:0;
  transform:rotate(-1.1deg);
  transition:transform .4s cubic-bezier(.2,.7,.3,1);
}
.dossier:hover{ transform:rotate(0deg); }
.dossier::before{ /* punch holes / tab feel */
  content:""; position:absolute; left:1.4rem; top:-7px; width:46px; height:7px;
  background:var(--accent); border-radius:2px 2px 0 0;
}
.dossier__head{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.12em;
  padding:1rem 1.3rem; border-bottom:1px solid var(--rule); color:var(--ink-soft);
}
.dossier__ref{ color:var(--ink-faint); }
.dossier__body{ padding:1.3rem 1.4rem .4rem; }
.row{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; padding:.5rem 0; border-bottom:1px dotted var(--rule); }
.row:last-of-type{ border-bottom:none; }
.row__k{ font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }
.row__v{ font-size:1.05rem; }
.row__v.mono{ font-family:var(--mono); font-size:.95rem; }
.sources{ list-style:none; padding:.6rem 0 .4rem; font-size:.98rem; }
.sources li{ display:flex; align-items:center; gap:.55rem; padding:.18rem 0; color:var(--ink-soft); }
.tick{ color:var(--green); font-weight:600; }
.src{ margin-left:auto; font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); border:1px solid var(--rule); border-radius:100px; padding:.05rem .5rem; }
.verif{ color:var(--green); font-weight:500; font-style:italic; }

/* Redaction bars — declassify on hover/focus */
.redact{
  background:var(--ink); color:transparent; border-radius:2px;
  padding:0 .18em; cursor:help; user-select:none;
  transition:background .25s, color .25s;
  outline:none;
}
.redact--wide{ letter-spacing:.05em; }
.redact:hover,.redact:focus,.redact--open{ background:var(--accent-soft); color:var(--ink); }

.stamp{
  position:absolute; right:1.1rem; bottom:3.2rem;
  font-family:var(--display); font-style:italic; font-size:1.45rem;
  color:var(--accent); border:2.5px solid var(--accent); border-radius:6px;
  padding:.1rem .7rem; transform:rotate(-9deg); opacity:.78;
  letter-spacing:.02em; pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(191,59,38,.25);
  mix-blend-mode:multiply;
}
.dossier__foot{ font-size:.64rem; color:var(--ink-faint); padding:.2rem 1.4rem 1.1rem; letter-spacing:.04em; }

/* ---------- Sections ---------- */
.section{ padding-top:clamp(3.5rem,7vw,6rem); padding-bottom:clamp(3.5rem,7vw,6rem); }
.section--alt{
  position:relative; max-width:none; padding-inline:0;
  background:var(--paper-2);
  border-block:1px solid var(--rule);
}
.section--alt > *{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section__head{ max-width:42rem; margin-bottom:3rem; }
.kicker{ font-family:var(--mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); }
.section__title{ font-family:var(--display); font-weight:500; font-size:clamp(1.9rem,3.6vw,2.9rem); letter-spacing:-.02em; line-height:1.1; margin:.6rem 0 .5rem; }
.section__lead{ color:var(--ink-soft); font-size:1.15rem; }

/* Steps */
.steps{ list-style:none; display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; counter-reset:s; }
.step{ background:var(--card); border:1px solid var(--rule); border-radius:var(--radius); padding:2rem 1.6rem; box-shadow:var(--shadow-sm); transition:transform .25s, box-shadow .25s; }
.step:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.step__no{ font-family:var(--mono); font-size:.85rem; color:var(--accent); border:1px solid var(--accent-soft); background:var(--accent-soft); border-radius:7px; padding:.2rem .55rem; }
.step__title{ font-family:var(--display); font-weight:500; font-size:1.45rem; letter-spacing:-.01em; margin:1.1rem 0 .5rem; }
.step p{ color:var(--ink-soft); font-size:1.02rem; }

/* Stats */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; padding-top:1rem; padding-bottom:1rem; text-align:center; }
.stat{ padding:1.5rem 1rem; border-right:1px solid var(--rule); }
.stat:last-child{ border-right:none; }
.stat__num{ font-family:var(--display); font-weight:500; font-size:clamp(2.6rem,5vw,3.8rem); letter-spacing:-.03em; }
.stat__suf{ font-family:var(--display); font-size:clamp(1.6rem,3vw,2.2rem); color:var(--accent); }
.stat__lab{ display:block; font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); margin-top:.4rem; }
@media(max-width:680px){ .stats{ grid-template-columns:1fr; } .stat{ border-right:none; border-bottom:1px solid var(--rule); } .stat:last-child{ border-bottom:none; } }

/* Why */
.why{ display:grid; grid-template-columns:repeat(2,1fr); gap:2.5rem 3rem; }
.why__item{ border-top:2px solid var(--ink); padding-top:1.1rem; }
.why__title{ font-family:var(--display); font-weight:500; font-size:1.45rem; margin-bottom:.4rem; letter-spacing:-.01em; }
.why__item p{ color:var(--ink-soft); }
@media(max-width:680px){ .why{ grid-template-columns:1fr; gap:1.8rem; } }

/* Plans */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; align-items:start; }
.plan{ position:relative; background:var(--card); border:1px solid var(--rule); border-radius:var(--radius); padding:2rem 1.7rem; box-shadow:var(--shadow-sm); transition:transform .25s, box-shadow .25s; }
.plan:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.plan--featured{ background:var(--ink); color:var(--paper); border-color:var(--ink); box-shadow:var(--shadow-lg); }
.plan--featured .plan__period,.plan--featured .plan__list li{ color:#cfc7b6; }
.plan--featured .plan__list li::before{ color:var(--paper); }
.plan__ribbon{ position:absolute; top:1.3rem; right:1.3rem; font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; background:var(--accent); color:#fff; padding:.22rem .6rem; border-radius:100px; }
.plan__name{ font-family:var(--mono); font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.plan--featured .plan__name{ color:#e89a8b; }
.plan__price{ margin:.7rem 0 .1rem; }
.plan__amt{ font-family:var(--display); font-weight:500; font-size:2.6rem; letter-spacing:-.03em; }
.plan__period{ font-size:.92rem; color:var(--ink-faint); }
.plan__strike{ font-size:.85rem; color:var(--ink-faint); text-decoration:line-through; margin-top:.5rem; }
.plan__list{ list-style:none; margin:1.4rem 0; display:grid; gap:.6rem; }
.plan__list li{ position:relative; padding-left:1.4rem; color:var(--ink-soft); font-size:1rem; }
.plan__list li::before{ content:"—"; position:absolute; left:0; color:var(--accent); }
.plan__note{ font-family:var(--mono); font-size:.68rem; letter-spacing:.04em; color:var(--ink-faint); margin-top:.9rem; text-align:center; }
.plan--featured .plan__note{ color:#a79e8d; }
@media(max-width:880px){ .plans,.steps{ grid-template-columns:1fr; } }

/* FAQ */
.faq{ max-width:46rem; }
.faq__item{ border-bottom:1px solid var(--rule-strong); padding:.4rem 0; }
.faq__item summary{
  list-style:none; cursor:pointer; display:flex; justify-content:space-between; gap:1rem; align-items:center;
  font-family:var(--display); font-weight:500; font-size:1.25rem; letter-spacing:-.01em; padding:1rem 0;
  transition:color .2s;
}
.faq__item summary:hover{ color:var(--accent); }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:"+"; font-family:var(--mono); font-size:1.4rem; color:var(--accent); transition:transform .25s; line-height:1; }
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__item p{ color:var(--ink-soft); padding:0 0 1.2rem; max-width:42rem; }

/* CTA */
.cta{ background:var(--ink); color:var(--paper); }
.cta__inner{ text-align:center; padding-top:clamp(4rem,8vw,6.5rem); padding-bottom:clamp(4rem,8vw,6.5rem); }
.cta__title{ font-family:var(--display); font-weight:500; font-size:clamp(2.1rem,4.5vw,3.4rem); letter-spacing:-.02em; }
.cta__text{ color:#cfc7b6; font-size:1.2rem; max-width:34rem; margin:1rem auto 2rem; }

/* Footer */
.footer{ padding-top:3rem; padding-bottom:3rem; }
.footer__top{ display:flex; justify-content:space-between; align-items:center; gap:1.5rem; flex-wrap:wrap; padding-bottom:1.5rem; border-bottom:1px solid var(--rule); }
.brand--footer{ font-size:1.15rem; }
.footer__links{ display:flex; gap:1.8rem; font-size:.95rem; flex-wrap:wrap; }
.footer__links a{ color:var(--ink-soft); transition:color .2s; }
.footer__links a:hover{ color:var(--accent); }
.footer__legal{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.7rem; letter-spacing:.04em; color:var(--ink-faint); padding-top:1.3rem; }

/* ---------- Entrance animation ---------- */
@media(prefers-reduced-motion:no-preference){
  .reveal{ opacity:0; transform:translateY(18px); }
  .reveal.in{ opacity:1; transform:none; transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.3,1); }
  .hero__copy > *{ opacity:0; transform:translateY(16px); animation:rise .8s cubic-bezier(.2,.7,.3,1) forwards; }
  .hero__copy > *:nth-child(1){ animation-delay:.05s; }
  .hero__copy > *:nth-child(2){ animation-delay:.16s; }
  .hero__copy > *:nth-child(3){ animation-delay:.27s; }
  .hero__copy > *:nth-child(4){ animation-delay:.38s; }
  .hero__copy > *:nth-child(5){ animation-delay:.49s; }
  .dossier{ opacity:0; animation:rise .9s cubic-bezier(.2,.7,.3,1) .5s forwards; }
  @keyframes rise{ to{ opacity:1; transform:none; } }
}
