/* ==========================================================================
   Noesis — sistema de diseño (hecho a mano, sin frameworks externos).
   Estética: profesional, minimalista cálida, mucho aire, jerarquía clara.
   ========================================================================== */
:root {
  /* Paleta de marca Noesis: verde bosque + teal sobre crema. */
  --bg: #f4f1e8;
  --surface: #ffffff;
  --surface-2: #faf8f1;
  --border: #e9e5d9;
  --border-strong: #ddd8c8;
  --text: #16271f;
  --muted: #5f6b63;
  --faint: #96a09a;
  --brand: #14463b;          /* verde bosque (acciones, nav activo) */
  --brand-2: #2e8b74;        /* teal (acentos, gráficos) */
  --brand-soft: #e4efe9;     /* sage muy claro (fondos suaves) */
  --brand-ink: #0f3d34;      /* verde más profundo (texto sobre soft) */
  --green: #1f8a6d;  --green-soft: #e2f1ea;
  --red: #c0533f;    --red-soft: #f7e8e3;
  --amber: #b7831f;  --amber-soft: #f5edd6;
  --radius: 12px;
  --radius-sm: 10px;
  --shadow: 0 1px 2px rgba(20,22,31,.04), 0 4px 14px rgba(20,22,31,.05);
  --shadow-sm: 0 1px 2px rgba(20,22,31,.05);
  --sidebar-w: 248px;
  --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  /* Serif editorial para titulares (Fraunces, autoalojada, sin CDN). */
  --serif: "Fraunces", "Iowan Old Style", "Palatino Linotype", Georgia, serif;
}

/* Fraunces variable (latin). Da el aire editorial/premium de los titulares. */
@font-face {
  font-family: "Fraunces";
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url("/static/fonts/fraunces-latin.woff2") format("woff2");
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  font-size: 14.5px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
h1, h2, h3 { margin: 0; font-weight: 650; letter-spacing: 0; }

/* ---------- Layout ---------- */
.app { display: flex; min-height: 100vh; }

.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: #0e302a;
  color: #b9c9c2;
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  height: 100vh;
}
.sidebar .brand {
  padding: 22px 22px 18px;
  color: #fff;
  font-size: 21px;
  font-weight: 700;
  letter-spacing: -.02em;
  display: flex; align-items: center; gap: 9px;
}
.sidebar .brand .mark { width: 34px; height: 34px; background: #f4f1e8;
  border-radius: 9px; padding: 4px; box-shadow: 0 1px 4px rgba(0,0,0,.25); }
.sidebar .section { padding: 6px 14px; }
.sidebar .section-label {
  font-size: 11px; text-transform: uppercase; letter-spacing: .07em;
  color: #5c7068; padding: 14px 10px 6px;
}
.nav-item {
  display: flex; align-items: center; gap: 11px;
  padding: 9px 11px; border-radius: 10px; margin: 2px 0;
  color: #a9bcb4; font-weight: 500; font-size: 14px;
  transition: background .12s, color .12s;
}
.nav-item .ic { width: 18px; height: 18px; display: inline-flex;
  align-items: center; justify-content: center; opacity: .82; }
.nav-item .ic svg { width: 18px; height: 18px; }
.nav-item.active .ic, .nav-item:hover .ic { opacity: 1; }
.nav-item:hover { background: #15403a; color: #fff; }
.nav-item.active { background: #1d4c43; color: #fff; }
.nav-item.active .ic { opacity: 1; }
.sidebar .spacer { flex: 1; }
.sidebar .foot { padding: 14px; border-top: 1px solid #1a443c; }
.sidebar .biz { font-size: 13px; color: #fff; font-weight: 600; }
.sidebar .biz small { display:block; color: #6d847b; font-weight: 500; }

.main { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.topbar {
  height: 60px; background: rgba(255,255,255,.8);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 28px; position: sticky; top: 0; z-index: 20;
}
.topbar .crumb { color: var(--muted); font-size: 13.5px; }
.topbar .crumb b { color: var(--text); font-weight: 600; }
.wa-pill { display:inline-flex; align-items:center; gap:7px; font-size:12.5px;
  padding: 5px 11px; border-radius: 999px; font-weight: 600; }
.wa-on { background: var(--green-soft); color: var(--green); }
.wa-off { background: var(--amber-soft); color: var(--amber); }
.wa-pill .dot { width:7px; height:7px; border-radius:50%; background:currentColor; }

.content { padding: 28px; max-width: 1200px; width: 100%; margin: 0 auto; }
.page-head { margin-bottom: 22px; display:flex; align-items:flex-start; justify-content:space-between; gap:18px; }
.page-title { min-width:0; }
.page-actions { display:flex; align-items:center; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.page-head h1 { font-family: var(--serif); font-weight: 500; font-size: 28px; letter-spacing: -.01em; }
.page-head p { color: var(--muted); margin: 8px 0 0; max-width: 60ch; line-height: 1.55; }
.kicker { color: var(--brand-2); font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; }
.meta { color: var(--faint); font-size: 12.5px; }
.muted { color: var(--muted); }
.nowrap { white-space: nowrap; }

/* ---------- Grids ---------- */
.grid { display: grid; gap: 16px; }
.grid > *, .split > * { min-width: 0; }
.g2 { grid-template-columns: repeat(2, 1fr); }
.g3 { grid-template-columns: repeat(3, 1fr); }
.g4 { grid-template-columns: repeat(4, 1fr); }
.col-2 { grid-column: span 2; }
@media (max-width: 900px) { .g3,.g4 { grid-template-columns: repeat(2,1fr); }
  .col-2 { grid-column: span 1; } }
@media (max-width: 600px) { .g2,.g3,.g4 { grid-template-columns: 1fr; } }

/* ---------- Móvil: menú lateral deslizable ---------- */
.burger { display: none; background: none; border: none; cursor: pointer;
  color: var(--text); padding: 5px; line-height: 1; width:32px; height:32px; }
.burger span { display:block; width:18px; height:2px; background:currentColor;
  border-radius:999px; margin:4px auto; }
.nav-overlay { display: none; }
@media (max-width: 820px) {
  .burger { display: block; }
  .sidebar { position: fixed; left: 0; top: 0; z-index: 60;
    transform: translateX(-100%); transition: transform .22s ease; }
  body.nav-open .sidebar { transform: translateX(0);
    box-shadow: 0 0 40px rgba(0,0,0,.3); }
  body.nav-open .nav-overlay { display: block; position: fixed; inset: 0;
    background: rgba(8,20,16,.45); z-index: 50; }
  .content { padding: 18px; }
  .page-head { display:block; }
  .page-actions { justify-content:flex-start; margin-top:12px; }
}

/* ---------- Cards ---------- */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow-sm); min-width: 0;
}
.card.pad { padding: 20px; }
.card-h { display:flex; align-items:center; justify-content:space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border); }
.card-h h2 { font-size: 15px; }
.card-h .hint { color: var(--faint); font-size: 12.5px; }
.card-b { padding: 18px 20px; }
.card.subtle { background: var(--surface-2); box-shadow: none; }
.card-action { border-color: #cfe2da; background: var(--surface-2); }
.split { display:grid; grid-template-columns: minmax(0,1fr) 320px; gap:16px; align-items:start; }
@media (max-width: 980px) { .split { grid-template-columns: 1fr; } }

/* ---------- Metric ---------- */
.metric { background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px; box-shadow: var(--shadow-sm); }
.metric .label { color: var(--muted); font-size: 12.5px; font-weight: 500;
  display:flex; align-items:center; gap:7px; }
.metric .value { font-size: 27px; font-weight: 700; letter-spacing: -.02em;
  margin-top: 8px; }
.metric .sub { font-size: 12.5px; color: var(--faint); margin-top: 4px; }
.metric .value.green { color: var(--green); }
.metric .value.red { color: var(--red); }
.metric .value.amber { color: var(--amber); }
.metric.feature { background: var(--brand); color: #fff; border: none; }
.metric.feature .value { font-family: var(--serif); font-weight: 500; }
.metric.feature .label, .metric.feature .sub { color: rgba(255,255,255,.78); }
.metric.compact { padding: 14px 16px; }
.metric.compact .value { font-size: 22px; }

/* ---------- Tables ---------- */
table { width: 100%; border-collapse: collapse; font-size: 13.8px; }
thead th { text-align: left; color: var(--faint); font-weight: 600;
  font-size: 11.5px; text-transform: uppercase; letter-spacing: .04em;
  padding: 0 12px 10px; }
tbody td { padding: 12px; border-top: 1px solid var(--border); }
tbody tr:hover { background: var(--surface-2); }
.t-right { text-align: right; }
.num { font-variant-numeric: tabular-nums; }
.table-wrap { width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.table-wrap table { min-width: 760px; }
.table-actions { white-space:nowrap; }
@media (max-width: 720px) {
  .table-wrap { margin: 0 -12px; padding: 0 12px; }
  .card-b.table-pad { padding-left: 12px; padding-right: 12px; }
}

/* ---------- Badges ---------- */
.badge { display:inline-block; padding: 3px 9px; border-radius: 999px;
  font-size: 11.5px; font-weight: 600; }
.b-green { background: var(--green-soft); color: var(--green); }
.b-amber { background: var(--amber-soft); color: var(--amber); }
.b-gray { background: #f0f1f4; color: #6b7280; }
.b-red { background: var(--red-soft); color: var(--red); }

/* ---------- Buttons / forms ---------- */
.btn { display:inline-flex; align-items:center; gap:7px; cursor:pointer;
  font-family: inherit; font-size: 13.5px; font-weight: 600;
  padding: 9px 15px; border-radius: 10px; border: 1px solid var(--border-strong);
  background: var(--surface); color: var(--text); transition: .12s; }
.btn:hover { background: var(--surface-2); }
.btn.primary { background: var(--brand); border-color: var(--brand); color:#fff; }
.btn.primary:hover { background: #0f3d34; }
.btn.green { background: var(--green); border-color: var(--green); color:#fff; }
.btn.sm { padding: 6px 10px; font-size: 12.5px; }
.btn.ghost { background: transparent; }
.btn.full { width:100%; justify-content:center; }
.iconbtn { background: none; border: none; cursor: pointer; color: var(--faint);
  padding: 5px 6px; border-radius: 8px; display: inline-flex; align-items: center; }
.iconbtn:hover { color: var(--red); background: var(--red-soft); }
.row { display:flex; gap: 10px; flex-wrap: wrap; }
.input, select, textarea {
  width: 100%; font-family: inherit; font-size: 14px;
  padding: 10px 12px; border: 1px solid var(--border-strong);
  border-radius: 10px; background: #fff; color: var(--text); outline: none;
}
.input:focus, select:focus, textarea:focus {
  border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
label.fld { display:block; font-size: 13px; font-weight: 600; margin: 0 0 6px; }

/* ---------- List rows ---------- */
.lrow { display:flex; align-items:center; justify-content:space-between;
  padding: 11px 0; border-top: 1px solid var(--border); }
.lrow:first-child { border-top: none; }
.lrow .meta { color: var(--faint); font-size: 12.5px; }
.empty { color: var(--faint); font-size: 13.5px; padding: 18px 0; text-align:center; }
.empty-state { text-align:center; padding: 28px 18px; color: var(--muted); }
.empty-state b { display:block; color: var(--text); margin-bottom:4px; font-size:15px; }
.empty-state .btn { margin-top:14px; }
.action-list { display:flex; flex-direction:column; gap:10px; }
.action-item { display:flex; justify-content:space-between; gap:12px; padding:12px;
  border:1px solid var(--border); border-radius:var(--radius-sm); background:#fff; }
.action-item strong { display:block; font-size:13.5px; }
.action-item small { display:block; color:var(--faint); margin-top:2px; }
.priority { display:inline-flex; align-items:center; height:22px; padding:0 8px;
  border-radius:999px; font-size:11px; font-weight:700; }
.priority.high { background:var(--red-soft); color:var(--red); }
.priority.medium { background:var(--amber-soft); color:var(--amber); }
.priority.low { background:var(--brand-soft); color:var(--brand-ink); }
.steps-list { display:grid; gap:10px; margin:0; padding:0; list-style:none; }
.steps-list li { display:flex; gap:10px; align-items:flex-start; }
.step-dot { flex:0 0 24px; width:24px; height:24px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; background:var(--brand-soft);
  color:var(--brand); font-size:12px; font-weight:700; }
.progress { height:8px; background:var(--border); border-radius:999px; overflow:hidden; }
.progress > span { display:block; height:100%; background:var(--brand-2); border-radius:999px; }
.demo { background:var(--brand-soft); color:var(--brand-ink); border-radius:8px;
  padding:10px 12px; font-size:12.5px; margin-top:14px; text-align:center; }

/* ---------- Insight / explanation boxes ---------- */
.insight { background: var(--brand-soft); border: 1px solid #cfe2da;
  border-radius: var(--radius-sm); padding: 14px 16px; font-size: 13.3px;
  color: var(--brand-ink); }
.insight b { font-weight: 700; }

/* ---------- Páginas legales (públicas) ---------- */
.legal-wrap { max-width: 820px; margin: 0 auto; padding: 40px 24px 72px; }
.legal-back { display:inline-flex; align-items:center; gap:7px; color:var(--brand);
  font-size:13.5px; font-weight:600; margin-bottom:22px; }
.legal h1 { font-family:var(--serif); font-weight:500; font-size:34px; color:var(--brand);
  letter-spacing:-.01em; margin-bottom:6px; }
.legal .updated { color:var(--faint); font-size:13px; margin-bottom:24px; }
.legal h2 { font-family:var(--serif); font-weight:500; font-size:21px; color:var(--brand);
  margin:30px 0 10px; }
.legal h3 { font-size:15px; margin:18px 0 6px; }
.legal p, .legal li { color:var(--text); font-size:15px; line-height:1.7; }
.legal ul { padding-left:20px; margin:8px 0; }
.legal li { margin:4px 0; }
.legal a { color:var(--brand-2); text-decoration:underline; }
.legal .note { background:var(--amber-soft); border:1px solid #e8d9b0; color:#7a5a14;
  border-radius:var(--radius-sm); padding:14px 16px; font-size:13.5px; line-height:1.6; margin:18px 0; }
.legal .meta-box { background:var(--surface-2); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:14px 16px; font-size:14px; margin:10px 0; }

/* ---------- Modal ---------- */
.modal-overlay { position:fixed; inset:0; background:rgba(8,20,16,.5); z-index:100;
  display:flex; align-items:center; justify-content:center; padding:20px;
  animation:fade .12s ease; }
@keyframes fade { from { opacity:0; } to { opacity:1; } }
.modal { background:var(--surface); border-radius:16px; width:100%; max-width:440px;
  box-shadow:0 24px 60px rgba(8,20,16,.32); overflow:hidden; }
.modal-h { display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px; border-bottom:1px solid var(--border); }
.modal-h h2 { font-family:var(--serif); font-weight:500; font-size:19px; }
.modal-x { font-size:15px; }
.modal-x:hover { color:var(--text); background:var(--surface-2); }
.modal-b { padding:6px 20px 18px; }
.modal-f { display:flex; justify-content:flex-end; gap:8px; padding:14px 20px;
  border-top:1px solid var(--border); background:var(--surface-2); }

/* ---------- Ratios / análisis financiero ---------- */
.ratios { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width: 720px) { .ratios { grid-template-columns:1fr; } }
.ratio { border:1px solid var(--border); border-radius:var(--radius-sm); padding:14px 16px;
  background:var(--surface-2); }
.ratio-top { display:flex; align-items:center; gap:10px; }
.ratio-name { font-weight:600; font-size:13.5px; flex:1; }
.ratio-val { font-size:18px; font-weight:700; font-family:var(--serif); letter-spacing:-.01em; }
.ratio-text { color:var(--muted); font-size:12.8px; margin-top:7px; line-height:1.5; }
.health { font-size:11px; font-weight:700; padding:3px 9px; border-radius:999px;
  text-transform:uppercase; letter-spacing:.04em; }
.h-good { background:var(--green-soft); color:var(--green); }
.h-ok { background:var(--amber-soft); color:var(--amber); }
.h-bad { background:var(--red-soft); color:var(--red); }
.dot-help { display:inline-flex; align-items:center; justify-content:center; width:15px; height:15px;
  border-radius:50%; background:var(--border); color:var(--muted); font-size:10px; font-weight:700; cursor:help; }

/* ---------- Calendario (vista de mes) ---------- */
.cal-head { display:flex; align-items:center; gap:12px; }
.cal-head h2 { font-family:var(--serif); font-weight:500; font-size:19px; text-transform:capitalize;
  min-width:170px; }
.cal-nav { display:inline-flex; gap:6px; }
.cal-nav button { width:32px; height:32px; border:1px solid var(--border-strong); background:#fff;
  border-radius:9px; cursor:pointer; color:var(--muted); display:inline-flex; align-items:center;
  justify-content:center; font-size:15px; }
.cal-nav button:hover { border-color:var(--brand); color:var(--brand); }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-wd { font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:var(--faint);
  font-weight:700; text-align:center; padding:2px 0 6px; }
.cal-cell { min-height:88px; border:1px solid var(--border); border-radius:10px; padding:6px 7px;
  background:#fff; cursor:pointer; text-align:left; transition:border-color .12s; overflow:hidden; }
.cal-cell:hover { border-color:#c7d6cd; }
.cal-cell.out { background:var(--surface-2); }
.cal-cell.out .cal-date { color:var(--faint); }
.cal-cell.today { border-color:var(--brand-2); }
.cal-cell.sel { border-color:var(--brand); box-shadow:0 0 0 2px var(--brand-soft); }
.cal-date { font-size:12.5px; font-weight:700; color:var(--text); display:inline-flex;
  align-items:center; justify-content:center; min-width:22px; height:22px; }
.cal-cell.today .cal-date { background:var(--brand); color:#fff; border-radius:50%; }
.cal-ev { font-size:10.5px; line-height:1.4; background:var(--brand-soft); color:var(--brand-ink);
  border-radius:5px; padding:2px 6px; margin-top:3px; white-space:nowrap; overflow:hidden;
  text-overflow:ellipsis; }
.cal-ev b { font-weight:700; }
.cal-more { font-size:10px; color:var(--faint); margin-top:3px; padding-left:2px; }
@media (max-width: 640px) {
  .cal-cell { min-height:56px; padding:4px; }
  .cal-ev { display:none; }
  .cal-cell.has::after { content:''; display:block; width:6px; height:6px; border-radius:50%;
    background:var(--brand-2); margin:4px auto 0; }
}

/* ---------- Chat ---------- */
.chat-wrap { display:flex; flex-direction:column; height: calc(100vh - 60px - 56px);
  max-width: 820px; margin: 0 auto; }
.chat-log { flex:1; overflow-y:auto; padding: 8px 4px; display:flex;
  flex-direction:column; gap: 12px; }
.bubble { max-width: 78%; padding: 11px 15px; border-radius: 16px;
  font-size: 14px; white-space: pre-wrap; line-height: 1.45; }
.bubble.me { align-self: flex-end; background: var(--brand); color:#fff;
  border-bottom-right-radius: 5px; }
.bubble.bot { align-self: flex-start; background: #fff; border: 1px solid var(--border);
  border-bottom-left-radius: 5px; box-shadow: var(--shadow-sm); }
.bubble .src { display:block; margin-top: 6px; font-size: 11px; opacity: .6; }
.chat-input { display:flex; gap: 8px; align-items: center; margin: 10px 0 6px;
  padding: 7px 7px 7px 10px; background:#fff; border: 1px solid var(--border-strong);
  border-radius: 16px; box-shadow: var(--shadow-sm); }
.chat-input:focus-within { border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-soft); }
.chat-input .input { border: none; background: transparent; padding: 8px; }
.chat-input .input:focus { box-shadow: none; }
.chips { display:flex; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
.chip { font-size: 12.5px; padding: 7px 12px; border-radius: 999px;
  background:#fff; border: 1px solid var(--border-strong); cursor: pointer; color: var(--muted); }
.chip:hover { border-color: var(--brand); color: var(--brand); }

/* ---------- Landing pública ---------- */
.landing-body { background: var(--bg); }
.site-nav { max-width:1180px; margin:0 auto; padding:18px 24px; display:flex;
  align-items:center; justify-content:space-between; gap:18px; }
.site-brand { display:flex; align-items:center; gap:9px; font-size:20px; font-weight:750;
  color:var(--brand); }
.site-brand img { width:34px; height:34px; }
.site-links { display:flex; gap:18px; color:var(--muted); font-size:13.5px; }
.site-links a:hover { color:var(--brand); }
.site-actions { display:flex; gap:8px; align-items:center; }
.landing-hero { max-width:1180px; margin:0 auto; min-height:calc(100vh - 86px);
  display:grid; grid-template-columns:minmax(0, .92fr) minmax(0, 1.08fr); gap:34px;
  align-items:center; padding:32px 24px 56px; }
.landing-copy h1 { font-family:var(--serif); font-weight:500; font-size: clamp(40px, 5.6vw, 66px);
  line-height:1.04; color:var(--brand); max-width:13ch; letter-spacing:-.01em; margin:18px 0 0; }
.landing-copy p { color:var(--muted); font-size:18px; max-width:48ch; margin:18px 0 0; line-height:1.6; }
.landing-cta { display:flex; gap:10px; flex-wrap:wrap; margin-top:26px; }
.trust-row { display:flex; gap:8px; flex-wrap:wrap; margin-top:24px; }
.trust-row span { border:1px solid var(--border); background:rgba(255,255,255,.65);
  border-radius:999px; padding:6px 10px; color:var(--muted); font-size:12.5px; font-weight:650; }
.hero-product { background:#fff; border:1px solid var(--border-strong); border-radius:16px;
  box-shadow:0 10px 30px rgba(20,40,33,.08); overflow:hidden; padding:8px; }
.hero-product img { display:block; width:100%; height:auto; min-height:340px; object-fit:cover;
  object-position:left top; border-radius:10px; }
.logo-strip { max-width:1180px; margin:-18px auto 0; padding:0 24px 36px; display:flex;
  gap:10px; flex-wrap:wrap; color:var(--faint); }
.logo-strip span { padding:8px 12px; border:1px solid var(--border); border-radius:999px;
  background:rgba(255,255,255,.55); font-weight:650; font-size:13px; }
.landing-section, .landing-band, .final-cta { max-width:1180px; margin:0 auto; padding:72px 24px; }
.section-intro { max-width:760px; margin-bottom:24px; }
.section-intro h2, .landing-band h2, .final-cta h2 { font-family:var(--serif); font-weight:500;
  font-size: clamp(26px, 3.4vw, 40px); line-height:1.08; color:var(--brand); letter-spacing:-.01em; }
.landing-band h2 { color:#fff; }
.section-intro p, .landing-band p, .final-cta p { color:var(--muted); font-size:16px; }
.feature-grid, .pricing-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.feature-card, .price-card, .flow-step, .faq-grid details { background:#fff; border:1px solid var(--border);
  border-radius:14px; padding:22px; box-shadow:none; }
.feature-card { transition:border-color .15s ease, transform .15s ease; }
.feature-card:hover { border-color:#c7d6cd; transform:translateY(-2px); }
.feature-ic { width:40px; height:40px; border-radius:11px; background:var(--brand-soft);
  display:inline-flex; align-items:center; justify-content:center; color:var(--brand); margin-bottom:14px; }
.feature-ic svg { width:21px; height:21px; }
.feature-card h3, .price-card h3 { font-size:17px; margin-top:0; }
.feature-card p, .price-card p { color:var(--muted); margin-bottom:0; line-height:1.55; }
.feature-num { color:var(--brand-2); font-size:12px; font-weight:800; }
.landing-band { background:var(--brand); color:#fff; border-radius:12px; padding:44px;
  display:grid; grid-template-columns:.75fr 1.25fr; gap:28px; }
.landing-band .kicker, .landing-band p { color:rgba(255,255,255,.76); }
.landing-band h2, .landing-band h3 { color:#fff; }
.mission-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.flow-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.flow-step { display:flex; align-items:flex-start; gap:12px; }
.flow-step b { background:var(--brand-soft); color:var(--brand); width:28px; height:28px;
  border-radius:50%; display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.price-card { position:relative; }
.price-card .badge { position:absolute; top:-10px; left:22px; font-size:11px;
  padding:4px 11px; border-radius:999px; font-weight:700; }
.price-card.featured { background:var(--brand); border-color:var(--brand); }
.price-card.featured h3 { color:#cfe2d8; }
.price-card.featured .price { color:#fff; }
.price-card.featured p { color:#bcd2c8; }
.price-card.featured .badge { background:var(--brand-2); color:#f4f1e8; }
.price-card.featured .btn.primary { background:#fff; border-color:#fff; color:var(--brand); }
.price { font-family:var(--serif); font-size:32px; font-weight:500; color:var(--brand); margin:8px 0 10px; }
.price-card .btn { margin-top:18px; }
.faq-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.faq-grid summary { cursor:pointer; font-weight:750; }
.faq-grid p { color:var(--muted); }
.final-cta { text-align:center; }
.final-cta p { max-width:620px; margin:14px auto 24px; }
.site-footer { max-width:1180px; margin:0 auto; padding:26px 24px 40px; display:flex;
  justify-content:space-between; gap:16px; color:var(--faint); border-top:1px solid var(--border); }
@media (max-width: 900px) {
  .site-links { display:none; }
  .landing-hero { grid-template-columns:1fr; min-height:auto; padding-top:20px; }
  .landing-copy h1 { max-width:12ch; }
  .feature-grid, .pricing-grid, .mission-grid, .flow-grid, .faq-grid { grid-template-columns:1fr; }
  .landing-band { grid-template-columns:1fr; margin-left:18px; margin-right:18px; padding:28px; }
}
@media (max-width: 560px) {
  .site-nav { align-items:flex-start; padding:14px 18px; }
  .site-actions { flex-wrap:wrap; justify-content:flex-end; }
  .site-actions .btn { padding:7px 10px; font-size:12.5px; }
  .landing-hero, .landing-section, .final-cta { padding-left:18px; padding-right:18px; }
  .landing-copy h1 { font-size:42px; }
  .hero-product img { min-height:230px; }
  .site-footer { display:block; padding-left:18px; padding-right:18px; }
  .site-footer span { display:block; margin-top:6px; }
}

/* ---- Impuestos: filas de liquidación ---- */
.taxrow { display:flex; justify-content:space-between; align-items:center; gap:16px;
  padding:11px 2px; border-bottom:1px solid var(--border); font-size:14px; }
.taxrow:last-child { border-bottom:none; }
.taxrow span { color:var(--muted); }
.taxrow b { font-variant-numeric:tabular-nums; font-size:15px; }
.taxrow.total { margin-top:6px; border-top:2px solid var(--border-strong); border-bottom:none;
  padding-top:13px; }
.taxrow.total span { color:var(--text); font-weight:600; }
.taxrow.total b { font-family:var(--serif); font-size:20px; color:var(--brand); }

/* ---- Suscripción: planes ---- */
.plan-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:8px; }
@media (max-width:720px){ .plan-grid { grid-template-columns:1fr; } }
.plan { border:1px solid var(--border); border-radius:var(--radius); padding:22px;
  background:var(--surface); box-shadow:var(--shadow-sm); }
.plan.featured { border-color:var(--brand-2); box-shadow:0 6px 24px rgba(20,70,59,.10); }
.plan h3 { margin:0 0 4px; font-size:18px; }
.plan .price { font-size:34px; margin:6px 0 4px; }
.plan .price small { font-size:14px; color:var(--muted); font-family:var(--font); }
.plan ul { list-style:none; padding:0; margin:14px 0 18px; }
.plan li { padding:6px 0 6px 24px; position:relative; color:var(--muted); font-size:13.8px; }
.plan li::before { content:"✓"; position:absolute; left:0; color:var(--green); font-weight:700; }
.sub-state { display:inline-flex; align-items:center; gap:8px; padding:7px 14px;
  border-radius:999px; font-size:13px; font-weight:600; }
.sub-state.trial { background:var(--amber-soft); color:var(--amber); }
.sub-state.active { background:var(--green-soft); color:var(--green); }
.sub-state.past_due, .sub-state.canceled { background:var(--red-soft); color:var(--red); }

/* ---- Panel admin (fundador) ---- */
.admin-wrap { max-width:1100px; margin:40px auto; padding:0 24px; }
.admin-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:20px 0; }
@media (max-width:720px){ .admin-grid { grid-template-columns:1fr 1fr; } }
.danger-zone { border:1px solid var(--red); border-radius:var(--radius); padding:18px 20px;
  background:var(--red-soft); margin-top:20px; }
.danger-zone h3 { margin:0 0 6px; color:var(--red); }
