/* APP.VANGUARDIA.TECH — estilos de la demo (FASE 4).
   Portado de maqueta/demo_1.0.html (D-013, diseño aprobado). Servido como estático
   ('self') para cumplir la CSP estricta sin estilos en línea. */
:root{
  --vg-orange:#c66a2a; --vg-orange-hover:#d4772f; --vg-orange-soft:rgba(198,106,42,.15);
  --vg-ink:#181614; --vg-white:#faf8f4; --vg-paper:#f3efe8;
  --vg-gray-500:#a8a195; --vg-gray-600:#555049; --vg-gray-700:#3a3632; --vg-gray-800:#1e1c1a;
  --vg-gray-muted:#8a8478; --vg-border:rgba(14,14,14,.10);
  --vg-teal:#12857a; --vg-amber:#b9851a;
  --vg-font:'Inter',-apple-system,'Segoe UI',Roboto,sans-serif; --vg-radius:2px;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--vg-font);background:var(--vg-paper);color:var(--vg-gray-800);line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
a{color:var(--vg-orange);text-decoration:none}
a:hover{color:var(--vg-orange-hover)}

.draftbar{background:#2a2622;color:#f1e8dd;font-size:12.5px;text-align:center;padding:7px 14px;
  font-family:'JetBrains Mono',monospace;letter-spacing:.03em;border-bottom:2px solid var(--vg-orange)}
.draftbar b{color:var(--vg-orange)}

header.hero{background:var(--vg-ink);color:var(--vg-white);padding:34px 0 30px;border-bottom:3px solid var(--vg-orange)}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.brand{font-family:'Poppins',sans-serif;font-weight:600;font-size:20px;color:#fff;display:flex;align-items:center;gap:9px}
.brand .tri{width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:16px solid var(--vg-orange)}
.brand .tech{font-family:'JetBrains Mono',monospace;color:var(--vg-orange);font-size:14px;font-weight:700}
.demo-badge{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--vg-orange);border:1px solid rgba(198,106,42,.5);border-radius:var(--vg-radius);padding:5px 10px;white-space:nowrap}
.eyebrow{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--vg-orange);margin:18px 0 12px}
header.hero h1{font-weight:300;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:-.02em;line-height:1.14;margin:0 0 .35em;color:#fff}
header.hero h1 b{font-weight:600;color:#fff}
header.hero .sub{color:#c0bab0;font-size:1.02rem;margin:0;max-width:720px}

main{padding:30px 0 10px}
.note{background:var(--vg-orange-soft);border:1px solid rgba(198,106,42,.3);border-radius:var(--vg-radius);padding:13px 18px;font-size:13.5px;color:var(--vg-gray-700);margin:0 0 26px}
.note strong{color:var(--vg-orange-hover)}
.note.rate{background:#fdeeec;border-color:#b03a2e55}

section.block{background:var(--vg-white);border:1px solid var(--vg-border);border-radius:var(--vg-radius);padding:26px;margin-bottom:24px}
.badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:var(--vg-radius);background:var(--vg-orange-soft);color:var(--vg-orange);margin-bottom:12px}
section.block h2{font-weight:600;font-size:1.18rem;color:var(--vg-ink);margin:0 0 4px}
section.block p.cap{color:var(--vg-gray-600);font-size:.88rem;margin:0 0 18px}

.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--vg-gray-600);margin-bottom:6px}
label .req{color:var(--vg-orange)}
label .opt{color:var(--vg-gray-muted);font-weight:500;text-transform:none;letter-spacing:0}
input,select,textarea{width:100%;background:var(--vg-paper);border:1px solid var(--vg-border);border-radius:var(--vg-radius);color:var(--vg-gray-800);padding:10px 12px;font-size:13.5px;font-family:var(--vg-font)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--vg-orange)}
textarea{resize:vertical;min-height:90px}
.hint{font-size:11.5px;color:var(--vg-gray-muted);margin-top:5px;line-height:1.4}
.hint.mt{margin-top:14px}
.counter{float:right;font-family:'JetBrains Mono',monospace}
.full{grid-column:1/-1}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;align-items:center}
.btn{border:none;border-radius:var(--vg-radius);padding:11px 22px;font-size:13.5px;font-weight:600;cursor:pointer;font-family:var(--vg-font);letter-spacing:.02em}
.btn-primary{background:var(--vg-orange);color:#fff}
.btn-primary:hover{background:var(--vg-orange-hover)}
.btn-ghost{background:transparent;color:var(--vg-gray-600);border:1px solid var(--vg-border)}
.btn-ghost:hover{border-color:var(--vg-orange);color:var(--vg-orange)}
.req-note{font-size:12px;color:var(--vg-gray-muted);margin-left:auto}

.results-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.results-head h2{margin:0}
.results-meta{font-family:'JetBrains Mono',monospace;color:var(--vg-gray-muted);font-size:12px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px;margin-top:14px}
.rcard{background:var(--vg-white);border:1px solid var(--vg-border);border-left:3px solid var(--vg-orange);border-radius:var(--vg-radius);padding:16px;display:flex;flex-direction:column;gap:11px}
.rcard .row1{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.rcard h3{margin:0;font-size:1rem;line-height:1.3;color:var(--vg-ink);font-weight:600}
.match{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:var(--vg-radius);white-space:nowrap}
.m-alta{background:var(--vg-orange-soft);color:var(--vg-orange-hover);border:1px solid rgba(198,106,42,.35)}
.m-media{background:var(--vg-paper);color:var(--vg-gray-600);border:1px solid var(--vg-border)}
.desc{font-size:13px;color:var(--vg-gray-700);margin:0}
.meta-row{display:flex;flex-wrap:wrap;gap:7px 16px;font-size:12px;color:var(--vg-gray-600)}
.meta-row span b{color:var(--vg-gray-800);font-weight:600}
.flag-urg{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--vg-amber);border:1px solid rgba(185,133,26,.45);border-radius:var(--vg-radius);padding:1px 7px}
.dates{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:11.5px;color:var(--vg-gray-600);border-top:1px dashed var(--vg-border);padding-top:9px}
.dates span b{color:var(--vg-gray-800);font-weight:600}
.reserved{font-family:'JetBrains Mono',monospace;color:var(--vg-gray-500);letter-spacing:.12em}
.lockline{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--vg-gray-muted);border-top:1px dashed var(--vg-border);padding-top:9px;margin-top:2px;flex-wrap:wrap}
.empty{background:var(--vg-paper);border:1px dashed var(--vg-border);border-radius:var(--vg-radius);padding:22px;text-align:center;color:var(--vg-gray-600);font-size:14px}
.cta{background:var(--vg-ink);color:#fff;border-radius:var(--vg-radius);padding:26px;text-align:center;margin-top:8px}
.trial-pill{display:inline-block;background:var(--vg-orange);color:#fff;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:999px;margin-bottom:14px}
.cta h2{color:#fff;font-weight:300;font-size:1.35rem;margin:0 0 6px}
.cta h2 b{font-weight:600}
.cta p{color:#c0bab0;font-size:.95rem;margin:0 0 16px}
footer{color:var(--vg-gray-muted);font-size:12px;text-align:center;margin:26px 0 14px;line-height:1.7}

.services{background:var(--vg-white);border:1px solid var(--vg-border);border-radius:var(--vg-radius);padding:26px;margin-bottom:24px}
.services h2{font-weight:600;font-size:1.18rem;color:var(--vg-ink);margin:0 0 4px}
.services p.cap{color:var(--vg-gray-600);font-size:.88rem;margin:0 0 18px}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px}
.svc{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--vg-gray-700);background:var(--vg-paper);border:1px solid var(--vg-border);border-radius:var(--vg-radius);padding:12px 14px}
.svc .ic{color:var(--vg-orange);font-weight:700;font-family:'JetBrains Mono',monospace;line-height:1.3}

.trust{background:#fbfaf7;border:1px solid var(--vg-border);border-radius:var(--vg-radius);padding:24px;margin-bottom:24px}
.trust h2{font-weight:600;font-size:1.1rem;color:var(--vg-ink);margin:0 0 4px}
.trust p.cap{color:var(--vg-gray-600);font-size:.86rem;margin:0 0 16px}
.legend{display:flex;flex-wrap:wrap;gap:8px 14px;margin:0 0 16px;font-size:12px}
.tag{display:inline-flex;align-items:center;gap:6px;font-weight:600}
.dot{width:11px;height:11px;border-radius:2px;display:inline-block}
.d-show{background:var(--vg-teal)} .d-part{background:var(--vg-amber)} .d-res{background:var(--vg-gray-500)} .d-hide{background:#b03a2e}
.b5table{width:100%;border-collapse:collapse;font-size:12.5px}
.b5table th,.b5table td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--vg-border);vertical-align:top}
.b5table th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--vg-gray-600);font-weight:600}
.b5table td.grp{font-weight:600;color:var(--vg-ink);white-space:nowrap}
.pill{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.03em;padding:2px 8px;border-radius:999px;color:#fff;white-space:nowrap}
.p-show{background:var(--vg-teal)} .p-part{background:var(--vg-amber)} .p-res{background:var(--vg-gray-500)} .p-hide{background:#b03a2e}
