/* Invierte con Claude — estilo editorial (branding Adrián Sáenz) sobre dashboard */
:root{
  --bg:#07080a; --panel:rgba(241,236,225,.035); --panel2:rgba(241,236,225,.055); --panel3:rgba(241,236,225,.085);
  --line:rgba(241,236,225,.08); --line2:rgba(241,236,225,.16);
  --text:#f1ece1; --muted:#a39d92; --muted2:#6a655c;
  --accent:#d8c9a3; --accent-warm:#c89b6c; --claude:#D97757;
  --info:#6ec1c9; --up:#6fbf73; --down:#d6695f;
  --gold-d:rgba(216,201,163,.14); --gold-line:rgba(216,201,163,.30);
  --radius:18px; --radius-sm:12px; --shadow:0 24px 60px -24px rgba(0,0,0,.8);
  --font-display:'Fraunces','Times New Roman',serif;
  --font-sans:'Inter',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;line-height:1.5;position:relative;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;line-height:1.15}
b,strong{font-weight:600}

/* ---- fondo aurora + mesh + viñeta + grano ---- */
.aurora,.mesh,.vignette,.grain{position:fixed;inset:0;z-index:-1;pointer-events:none}
.aurora{background:
  radial-gradient(closest-side at 78% 8%, rgba(200,155,108,.20), transparent),
  radial-gradient(closest-side at 12% 18%, rgba(216,201,163,.14), transparent),
  radial-gradient(closest-side at 60% 90%, rgba(217,119,87,.10), transparent)}
.mesh{background-image:radial-gradient(rgba(241,236,225,.06) 1px,transparent 1px);background-size:22px 22px;opacity:.5}
.vignette{background:radial-gradient(ellipse at 50% 40%, transparent 55%, rgba(0,0,0,.55))}
.grain{opacity:.025;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(241,236,225,.12);border-radius:20px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-track{background:transparent}

.main{padding:22px 28px 80px;max-width:1180px;margin:0 auto;width:100%}
/* ===== Footer (Skilio + aviso legal/disclaimer) ===== */
.site-footer{position:relative;z-index:2;border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(0,0,0,.25));padding:40px 28px 48px}
.footer__inner{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}
.footer__logo img{height:34px;filter:brightness(0) invert(1);opacity:.8;transition:.3s}
.footer__logo:hover img{opacity:1;transform:translateY(-2px)}
.footer__nav{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 22px}
.footer__nav a{color:var(--muted);text-decoration:none;font-size:13px;transition:color .25s}
.footer__nav a:hover{color:var(--text)}
.footer__credit{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:var(--muted2);margin:2px 0 0}
/* aviso legal estilo Trade Republic (letra pequeña pero legible, alineada a la izquierda) */
.footer__legal{max-width:900px;margin:10px auto 0;text-align:left;border-top:1px solid var(--line);padding-top:16px}
.footer__legal p{font-size:10.5px;line-height:1.6;color:var(--muted2);margin:0 0 7px}
.footer__legal p:last-child{margin-bottom:0}
.footer__legal b{color:var(--muted);font-weight:600}
@media(max-width:720px){.site-footer{padding:30px 16px 36px}.footer__legal p{font-size:10px}}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.topbar-right{display:flex;align-items:center;gap:10px}
.demo{font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);background:var(--gold-d);border:1px solid var(--gold-line);padding:5px 11px;border-radius:99px}
.curtoggle{display:inline-flex;border:1px solid var(--line2);border-radius:10px;overflow:hidden}
.curtoggle .ct{background:transparent;border:none;color:var(--muted);font-family:var(--font-sans);font-weight:700;font-size:14px;padding:7px 13px;cursor:pointer;transition:.15s}
.curtoggle .ct:hover{color:var(--text)}
.curtoggle .ct.on{background:var(--gold-d);color:var(--accent)}

/* marca */
.brandtop{display:flex;align-items:center;gap:11px}
.brandtop .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--accent),var(--accent-warm));
  display:grid;place-items:center;color:#1c130a;font-family:var(--font-display);font-weight:600;font-size:20px;flex:0 0 auto;
  box-shadow:0 10px 26px -10px rgba(200,155,108,.6)}
.brandtop b{font-family:var(--font-display);font-size:19px;font-weight:500;display:flex;align-items:center;gap:6px}
.claude-logo{width:.92em;height:.92em;color:var(--claude);vertical-align:-2px}
.brandtop .logo .brandmark{width:22px;height:22px}/* asterisco de Claude dentro del chip (hereda el color oscuro del chip) */
.claude-word{color:var(--claude)}

/* nav superior (pestañas de pantalla) */
.topnav{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:22px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.topnav::-webkit-scrollbar{display:none}
.topnav .tab{padding:11px 16px;cursor:pointer;color:var(--muted);font-weight:600;font-size:14px;white-space:nowrap;flex:0 0 auto;
  border-bottom:2px solid transparent;transition:.18s;display:flex;align-items:center;gap:8px}
.topnav .tab:hover{color:var(--text)}
.topnav .tab.active{color:var(--text);border-bottom-color:var(--accent)}
.topnav .tab svg{width:17px;height:17px;opacity:.8}

.screen{display:none;animation:fade .35s ease}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.head{margin-bottom:22px}
.head h1{font-size:32px;margin-bottom:6px;letter-spacing:-.025em}
.head h1 em{font-style:italic;color:var(--accent)}
.head p{color:var(--muted);font-size:14.5px;max-width:780px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px;backdrop-filter:blur(6px)}
.card.tight{padding:15px}
.grid{display:grid;gap:16px}
.grid>*{min-width:0}/* permite que el contenido encoja en vez de desbordar */
canvas{max-width:100%}/* ningún gráfico desborda su contenedor en ventanas estrechas */
.g2{grid-template-columns:repeat(2,minmax(0,1fr))}.g3{grid-template-columns:repeat(3,minmax(0,1fr))}.g4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:1080px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.g2,.g3,.g4{grid-template-columns:1fr}.main{padding:18px 16px 70px}}

.card-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}
.card-title h3{font-size:17px;font-weight:500}.card-title .sub{font-size:12px;color:var(--muted2);font-family:var(--font-mono)}
.muted{color:var(--muted)}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.up{color:var(--up)}.down{color:var(--down)}

.kv{display:flex;flex-direction:column;gap:6px;padding:15px;background:var(--panel2);border:1px solid var(--line);border-radius:var(--radius-sm)}
.kv .k{font-size:11px;color:var(--muted);font-family:var(--font-mono);letter-spacing:.03em}
.kv .v{font-size:22px;font-weight:600;font-family:var(--font-display)}.kv .v.sm{font-size:16px;font-family:var(--font-sans);font-weight:700}

/* distribución por sector de un ETF: nombre · barra · % */
.secrow{display:flex;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid var(--line)}
.secrow:last-child{border-bottom:none}
.secname{flex:0 0 38%;font-size:13px;color:var(--text)}
.secbar{flex:1;height:8px;border-radius:99px;background:var(--panel2);overflow:hidden}
.secfill{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent-warm),var(--accent))}
.secpct{flex:0 0 52px;text-align:right;font-size:13px;font-weight:700;font-family:var(--font-mono)}

.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:14px;padding:11px 19px;border-radius:11px;transition:.18s}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-warm));color:#1c130a;box-shadow:0 12px 28px -12px rgba(200,155,108,.7)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn-ghost{background:var(--panel2);color:var(--text);border:1px solid var(--line2)}
.btn-ghost:hover{background:var(--panel3)}
.btn-tr{background:var(--text);color:#0b0b0b}.btn-tr:hover{transform:translateY(-1px)}
/* Analiza con IA: botón y barra de progreso (acento violeta, integrado con el tema oscuro) */
.ai-btn{background:linear-gradient(135deg,#8b5cf6,#d946ef);color:#fff;border:none;box-shadow:0 10px 24px -12px rgba(168,85,247,.7)}
.ai-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}
.ai-loading{padding:6px 2px 4px}
.ai-loading>p{font-size:13.5px;color:var(--muted);margin-bottom:18px}
.ai-bar-wrap{height:10px;border-radius:99px;background:rgba(139,92,246,.16);overflow:hidden}
.ai-bar{height:100%;border-radius:99px;background:linear-gradient(90deg,#8b5cf6,#d946ef);transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;min-width:5%}
.ai-bar::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 20%,rgba(255,255,255,.5),transparent 80%);background-size:220% 100%;animation:aiShimmer 1.1s linear infinite}
@keyframes aiShimmer{from{background-position:160% 0}to{background-position:-160% 0}}
.ai-bar-meta{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--muted);margin-top:10px}
.ai-bar-meta span:first-child{color:#c4b5fd;font-weight:700;font-family:var(--font-mono)}
.ai-note{font-size:12.5px;color:#cbbaf2;background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.32);border-radius:10px;padding:10px 12px;margin-bottom:14px}
.ai-note-block{background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.35);color:#e7e2f5}
.btn-sm{padding:8px 14px;font-size:13px}.btn.tiny{padding:5px 10px;font-size:12px;border-radius:9px}

.q{margin-bottom:20px}
.q .qhead{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.q .qnum{width:26px;height:26px;border-radius:8px;background:var(--gold-d);color:var(--accent);display:grid;place-items:center;font-weight:700;font-size:13px;flex:0 0 auto;font-family:var(--font-mono)}
.q h4{font-size:16px;font-weight:500}
.opts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.opt{padding:13px 15px;border:1px solid var(--line);background:var(--panel2);border-radius:12px;cursor:pointer;font-size:13.5px;font-weight:600;transition:.15s;display:flex;flex-direction:column;gap:3px}
.opt small{color:var(--muted2);font-size:11.5px;font-weight:500}
.opt:hover{border-color:var(--line2);background:var(--panel3)}
.opt.sel{border-color:var(--accent);background:var(--gold-d);box-shadow:inset 0 0 0 1px var(--accent)}

.risk{display:inline-flex;gap:5px;align-items:center}
.risk .seg{width:24px;height:8px;border-radius:6px;background:var(--panel3)}
.risk.on1 .seg:nth-child(-n+1),.risk.on2 .seg:nth-child(-n+2),.risk.on3 .seg:nth-child(-n+3),.risk.on4 .seg:nth-child(-n+4),.risk.on5 .seg:nth-child(-n+5){background:linear-gradient(90deg,var(--accent),var(--claude))}

table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--muted2);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;padding:9px 10px;border-bottom:1px solid var(--line);font-family:var(--font-mono)}
td{padding:11px 10px;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
tr:last-child td{border-bottom:none}tr:hover td{background:rgba(241,236,225,.025)}
.tk{font-weight:700;font-size:12px}
.bar-cell{position:relative}
.bar-fill{position:absolute;left:10px;top:50%;transform:translateY(-50%);height:7px;border-radius:6px;background:linear-gradient(90deg,var(--accent-warm),var(--accent));opacity:.4}

.chip{font-size:11px;font-weight:600;padding:3px 9px;border-radius:7px;background:var(--panel3);color:var(--muted);font-family:var(--font-mono);white-space:nowrap}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:7px}
.field{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.field:last-child{border-bottom:none}.field .fl{color:var(--muted);flex:0 0 auto}.field .fv{font-weight:600;font-variant-numeric:tabular-nums;text-align:right;min-width:0;overflow-wrap:anywhere}

.inp{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:11px 13px;color:var(--text);font-family:inherit;font-size:14px}
/* el calendario nativo (input date) hereda el modo oscuro -> popup oscuro, no en blanco */
input[type=date]{color-scheme:dark}
input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.8);cursor:pointer}
.inp:focus{outline:none;border-color:var(--accent)}
.inp.mini{padding:5px 8px;font-size:12px;width:auto}
select.inp{appearance:none}
/* ocultar las flechas nativas (claras) de los inputs numéricos: desentonan con la UI */
input[type=number]{-moz-appearance:textfield}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
/* checkbox oscuro acorde a la UI (el nativo se ve blanco) */
input[type=checkbox]{-webkit-appearance:none;appearance:none;width:18px;height:18px;flex:0 0 auto;border:1.5px solid var(--line2);border-radius:5px;background:var(--panel2);cursor:pointer;position:relative;transition:.15s}
input[type=checkbox]:hover{border-color:var(--accent)}
input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}
input[type=checkbox]:checked::after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid #1c130a;border-width:0 2px 2px 0;transform:rotate(45deg)}
label.lbl{font-size:12px;color:var(--muted);font-weight:600;display:block;margin-bottom:7px}
input[type=range]{accent-color:var(--accent-warm);width:100%}

.filters{display:flex;gap:8px;flex-wrap:wrap}
/* subfiltros por sección (grupos toggleables antes del grid) — secundarios, más ligeros que los .apill */
.subfilters{display:flex;flex-direction:column;gap:9px;margin-bottom:16px}
.subgroup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.subgroup-lab{font-size:10px;font-weight:600;color:var(--muted2);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;flex:0 0 auto;min-width:58px}
.subpill{font-size:12px;font-weight:600;padding:6px 12px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:.15s}
.subpill:hover{border-color:var(--line2);color:var(--text)}
.subpill.active{border-color:var(--accent);background:var(--gold-d);color:var(--accent)}
.apill{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:11px;border:1px solid var(--line);background:var(--panel2);cursor:pointer;font-size:13px;font-weight:600;transition:.15s}
.apill .tag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:6px;background:var(--panel3);color:var(--muted);font-family:var(--font-mono)}
.apill:hover{border-color:var(--line2)}
.apill.active{border-color:var(--accent);background:var(--gold-d);color:var(--text)}.apill.active .tag{background:var(--accent);color:#1c130a}

.acard{cursor:pointer;transition:.16s}
.acard:hover{transform:translateY(-3px);border-color:var(--line2)}
.ticon{border-radius:11px;display:grid;place-items:center;font-weight:700;font-family:var(--font-display);flex:0 0 auto;overflow:hidden;background:var(--panel3)}
.ticon img{width:100%;height:100%;object-fit:contain;padding:14%}

.ahead{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}
.ahead .id{display:flex;gap:16px;align-items:center;min-width:0}
.ahead .id>div{min-width:0}
.ahead h2{font-size:26px;font-weight:500}
.ahead .meta{color:var(--muted);font-size:13px;margin-top:6px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ahead-side{text-align:right;margin-left:auto} /* pegado a la derecha aunque envuelva a su propia línea en ventanas estrechas */
.ahead-btns{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:10px}
/* campo con chips (p. ej. "Derivados disponibles"): que envuelvan limpio, sin partir el chip */
.field .fv.chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}
@media(max-width:560px){
  /* cabecera de ficha: apilar (nombre arriba; precio y botones debajo, a ancho completo) */
  .ahead{flex-direction:column;gap:14px}
  .ahead-side{text-align:left;width:100%}
  .price-now{text-align:left}
  .ahead-btns{margin-top:12px}
  .ahead-btns .btn{flex:1 1 0;justify-content:center} /* Añadir (izq) y Comprar (der) lado a lado */
  /* campo de chips: etiqueta arriba, chips debajo alineados a la izquierda */
  .field-chips{flex-direction:column;align-items:flex-start;gap:8px}
  .field-chips .fv.chips{justify-content:flex-start;text-align:left}
}
.backbtn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;color:var(--muted);font-size:13.5px;font-weight:600;margin-bottom:16px;padding:8px 12px;border-radius:10px;border:1px solid var(--line);background:var(--panel2)}
.backbtn:hover{color:var(--text);border-color:var(--line2)}

.note{display:flex;gap:11px;padding:14px 16px;border-radius:12px;background:rgba(110,193,201,.08);border:1px solid rgba(110,193,201,.25);font-size:13.5px;color:#cfeaed;align-items:flex-start}
.note svg{width:18px;height:18px;flex:0 0 auto;margin-top:1px;color:var(--info)}
.note.gold{background:var(--gold-d);border-color:var(--gold-line);color:#e9ddc2}
.note.gold svg{color:var(--accent)}

.placeholder{display:grid;place-items:center;text-align:center;gap:8px;min-height:200px;border:1px dashed var(--line2);border-radius:14px;background:var(--panel2);color:var(--muted);padding:24px}
.placeholder .ph-t{font-family:var(--font-display);font-size:18px;color:var(--text)}
.placeholder svg{width:30px;height:30px;color:var(--muted2)}

.calc-grid{display:grid;grid-template-columns:300px 1fr;gap:22px;align-items:start}
@media(max-width:880px){.calc-grid{grid-template-columns:1fr}}

.modal-bg{display:none;position:fixed;inset:0;background:rgba(4,4,6,.74);backdrop-filter:blur(5px);z-index:50;place-items:center;padding:20px}
.modal-bg.show{display:grid}
.modal{width:100%;max-width:460px;background:#0d0e11;border:1px solid var(--line2);border-radius:18px;padding:24px;box-shadow:var(--shadow)}
.modal.lg{max-width:640px;max-height:88vh;overflow-y:auto}

.watch{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:11px;cursor:pointer;transition:.15s;border:1px solid transparent}
.watch:hover{background:var(--panel2);border-color:var(--line)}

.banner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:20px 22px;border-radius:16px;border:1px solid var(--gold-line);background:var(--gold-d)}
.banner h3{font-size:21px;margin-bottom:5px;font-weight:500}
.banner.small{padding:14px 18px}
.prof-chip{display:flex;align-items:center;gap:10px;font-size:15px}
.prof-chip span{color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;font-family:var(--font-mono)}
.prof-chip b{font-family:var(--font-display);font-size:20px;color:var(--accent);font-weight:500}
.prof-meta{color:var(--muted);font-size:13px}

.cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:center}
@media(max-width:720px){.cmp-grid{grid-template-columns:1fr}}
.cmp-cap{font-size:11px;font-weight:600;color:var(--muted);text-align:center;margin-bottom:6px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}
.cmp-cta{display:flex;flex-direction:column;gap:10px;justify-content:center;align-items:flex-start;padding:16px;border-radius:12px;background:var(--panel2);border:1px dashed var(--line2)}
/* comparativa actual vs ideal: leyenda compartida a la izquierda + dos donuts */
.cmp-wrap{display:grid;grid-template-columns:minmax(140px,auto) minmax(0,1fr) minmax(0,1fr);gap:22px;align-items:center}
@media(max-width:900px){.cmp-wrap{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}.cmp-legend{grid-column:1/-1;flex-direction:row;flex-wrap:wrap;gap:9px 18px}}
@media(max-width:560px){.cmp-wrap{grid-template-columns:minmax(0,1fr)}.cmp-legend{justify-content:flex-start}}
.cmp-donut .h{min-width:0}
.cmp-legend{display:flex;flex-direction:column;gap:11px}
.cmp-legend .li{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--text);line-height:1.25}
.cmp-legend .li .dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto;margin:0}
.cmp-donut{display:flex;flex-direction:column;align-items:center;min-width:0}
.cmp-donut .h{height:170px;width:100%;position:relative}
.cmp-tbl th,.cmp-tbl td{text-align:right}
.cmp-tbl th:first-child,.cmp-tbl td:first-child{text-align:left}
.cmp-act{font-weight:600;white-space:nowrap}
.cmp-act.buy{color:var(--up)}.cmp-act.sell{color:var(--down)}.cmp-act.ok{color:var(--muted);font-weight:500}
.cmp-act.buy,.cmp-act.sell{cursor:pointer;border-bottom:1px dotted transparent}
.cmp-act.buy:hover,.cmp-act.sell:hover{border-bottom-color:currentColor}
.cmp-legend .li[data-cls]{cursor:pointer;transition:color .15s}
.cmp-legend .li[data-cls]:hover{color:var(--accent)}
.cmp-catcell{cursor:pointer}
.cmp-catcell:hover{color:var(--accent)}
.cmp-tbl th,.cmp-tbl td{white-space:nowrap}
.cmp-tbl td:first-child,.cmp-tbl th:first-child{white-space:normal}
@media(max-width:520px){.cmp-tbl th,.cmp-tbl td{padding-left:7px;padding-right:7px;font-size:12px}}
.cmp-fill{margin-top:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.fillchip{font-size:12px;font-weight:600;padding:6px 11px;border-radius:9px;background:var(--panel3);border:1px solid var(--line);cursor:pointer;transition:.15s}
.fillchip:hover{border-color:var(--accent);color:var(--accent)}
/* selector segmentado (origen del dinero en una compra) */
.seg{display:flex;gap:8px}
.segb{flex:1;font-size:12.5px;font-weight:600;padding:10px 12px;border-radius:10px;background:var(--panel2);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:.15s;text-align:center;line-height:1.2}
.segb:hover:not(:disabled){border-color:var(--line2);color:var(--text)}
.segb.on{border-color:var(--accent);background:var(--gold-d);color:var(--text)}
.segb:disabled{opacity:.45;cursor:not-allowed}
.segb b{display:block;font-weight:600}
.segb small{display:block;font-weight:500;font-size:11px;opacity:.72;margin-top:1px}
.seg.seg-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
/* badge manual / plan en la tabla de compras */
.txtag{font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:6px;border:1px solid var(--line);color:var(--muted);background:var(--panel3);margin-left:8px;white-space:nowrap}
.txtag.plan{color:var(--accent);border-color:var(--gold-line);background:var(--gold-d)}
.recchip{display:inline-block;font-size:11px;font-weight:600;padding:4px 9px;border-radius:8px;cursor:pointer;background:var(--panel3);color:var(--muted);border:1px solid var(--line);white-space:nowrap}
.recchip.on{background:var(--gold-d);color:var(--accent);border-color:var(--gold-line)}
.recchip:hover{border-color:var(--line2)}

.illus{font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-warm);background:rgba(200,155,108,.12);border:1px solid rgba(200,155,108,.28);padding:3px 8px;border-radius:6px}

.hint{position:relative}/* sin subrayado: el indicador es el icono ⓘ */
.hint .qm{display:inline-flex;vertical-align:middle;cursor:help}
.hint .qm svg{width:12px;height:12px;color:var(--accent-warm)}
.iico{width:13px;height:13px}
.hint .tip{display:none;position:absolute;z-index:70;bottom:140%;left:0;width:250px;max-width:70vw;background:#15161a;border:1px solid var(--line2);border-radius:10px;padding:11px 13px;font-size:11.5px;color:var(--text);line-height:1.55;box-shadow:var(--shadow);font-family:var(--font-sans);font-weight:400;text-transform:none;letter-spacing:normal;white-space:normal}
.hint .qm:hover ~ .tip{display:block}/* el tooltip solo aparece al pasar el ratón por el icono ⓘ, no por la etiqueta */
.hint .tip b{color:var(--accent);display:block;margin-bottom:3px}
.hint .tip .f{display:block;margin-top:7px;color:var(--accent-warm);font-family:var(--font-mono);font-size:10.5px}
.info{display:flex;gap:7px;align-items:flex-start;font-size:11px;color:var(--muted2);margin-top:12px;line-height:1.5}
/* icono de información ⓘ en cabeceras de sección */
.h3tip{display:flex;align-items:center;gap:7px;min-width:0}
.ttip{border-bottom:none;cursor:help;line-height:0}
.ttip .qm svg{width:15px;height:15px;opacity:.7}
.ttip:hover .qm svg{opacity:1}
.hint.down .tip{top:150%;bottom:auto}
/* comparativa: barras horizontales apiladas + leyenda en una fila */
.cmp-legend.cmp-row{flex-direction:row;flex-wrap:wrap;gap:9px 18px;margin-bottom:16px}
.cmp-bars{display:flex;flex-direction:column;gap:12px}
.cmpbar{display:flex;align-items:center;gap:12px}
.cmpbar-lab{flex:0 0 50px;text-align:right;font-size:10.5px;font-weight:600;color:var(--muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}
.bar{flex:1;display:flex;height:32px;border-radius:9px;overflow:hidden;background:var(--panel3);min-width:0}
.bar .seg{height:100%;display:flex;align-items:center;justify-content:center;min-width:0;overflow:hidden;transition:width .35s ease}
.bar .seg span{font-size:10px;font-weight:700;color:rgba(15,12,8,.85);white-space:nowrap;letter-spacing:-.2px}
/* botón sutil "Cómo se calcula" en la cabecera de la comparativa */
.method-link{background:none;border:none;color:var(--muted);font-family:var(--font-mono);font-size:12px;cursor:pointer;padding:2px 0;transition:color .2s}
.method-link:hover{color:var(--accent)}
/* etiqueta larga (escritorio) vs corta (móvil) en leyenda y celda de categoría de la comparativa */
.cmp-legend .li .lf,.cmp-catcell .lf{display:inline}
.cmp-legend .li .ls,.cmp-catcell .ls{display:none}
.prof-risk,.prof-hist{white-space:nowrap}
/* --- pulido móvil: banner de perfil, cabecera de comparativa, leyenda y tabla de categorías --- */
@media(max-width:560px){
  /* cabeceras de tarjeta: el elemento de la derecha (botón "Cómo se calcula", fuente, rangos…) baja a su línea */
  .card-title{flex-wrap:wrap;gap:6px 10px}
  /* banner: "Riesgo X/5" en una línea y el histórico, completo, en la de abajo más pequeño */
  .prof-meta{font-size:12px;line-height:1.5}
  .prof-sep{display:none}
  .prof-risk{display:block}
  .prof-hist{display:block;font-size:10.5px}
  /* leyenda y categorías: etiqueta corta para que quepan (leyenda en 2 líneas, categoría en 1) */
  .cmp-legend .li .lf,.cmp-catcell .lf{display:none}
  .cmp-legend .li .ls,.cmp-catcell .ls{display:inline}
  .cmp-legend.cmp-row{gap:7px 13px}
  .cmp-legend .li{font-size:12px}
  .cmp-tbl td:first-child,.cmp-tbl th:first-child{white-space:nowrap}
}
/* contenido del modal de metodología */
.method h4{font-family:var(--font-display);font-size:16px;font-weight:500;margin:20px 0 8px;color:var(--text)}
.method h4:first-child{margin-top:4px}
.method p,.method li{font-size:12.5px;line-height:1.6;color:var(--muted)}
.method b,.method strong{color:var(--text);font-weight:600}
.method ul{margin:6px 0 6px 2px;padding-left:16px;display:flex;flex-direction:column;gap:5px}
.method table{width:100%;border-collapse:collapse;font-size:11.5px;margin:8px 0}
.method table th,.method table td{padding:6px 8px;border-bottom:1px solid var(--line);text-align:right}
.method table th:first-child,.method table td:first-child{text-align:left}
.method table th{color:var(--muted2);font-family:var(--font-mono);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.04em}
.method .src{font-size:11px;color:var(--muted2);line-height:1.7}
.method .src a{color:var(--accent);text-decoration:none;word-break:break-word}
.method .fbox{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px 13px;margin:8px 0;font-family:var(--font-mono);font-size:11.5px;color:var(--text);line-height:1.7}
.q.q-miss .opts{outline:1px solid var(--down);outline-offset:6px;border-radius:10px}
/* progreso del test */
.quizprog{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.quizprog-bar{flex:1;height:6px;border-radius:6px;background:var(--panel3);overflow:hidden}
.quizprog-bar>div{height:100%;background:var(--accent);width:0;transition:width .25s}
#quizCount{font-size:12px;color:var(--muted);font-family:var(--font-mono);white-space:nowrap}
/* breve resalte de la sección al llegar del test */
.card.flash{animation:cardflash 1.6s ease}
@keyframes cardflash{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 2px var(--gold-line),0 0 26px -6px var(--accent)}}
.info>svg{flex:0 0 auto;width:13px;height:13px;color:var(--accent-warm);margin-top:1px}
.price-now{text-align:right}
.price-now .p{font-size:28px;font-weight:600;font-family:var(--font-display)}
.price-now .c{font-size:13.5px;font-weight:600;margin-top:2px}
.price-now .src{font-size:10px;color:var(--muted2);font-family:var(--font-mono);margin-top:3px}
.rangebtns{display:flex;gap:5px}
.rangebtns .rb{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:4px 9px;border-radius:8px;border:1px solid var(--line);color:var(--muted);cursor:pointer}
.rangebtns .rb:hover{border-color:var(--line2);color:var(--text)}
.rangebtns .rb.on{background:var(--gold-d);border-color:var(--gold-line);color:var(--accent)}
.rangebtns .rb.disabled{opacity:.3;cursor:not-allowed;pointer-events:none}/* rango sin datos para este activo */
/* aviso sutil en la calculadora cuando se usan datos estimados o faltan posiciones */
.calc-warn{display:flex;gap:7px;align-items:flex-start;font-size:11px;line-height:1.5;color:var(--accent-warm);margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.calc-warn svg{width:13px;height:13px;flex:0 0 auto;margin-top:1px}
.calc-warn b{color:var(--text);font-weight:600}
.loadmore{display:grid;place-items:center;padding:18px;color:var(--muted);font-size:13px;font-family:var(--font-mono)}
#toast{display:none;position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#15161a;border:1px solid var(--line2);color:var(--text);padding:12px 18px;border-radius:12px;font-weight:600;font-size:13.5px;z-index:80;box-shadow:var(--shadow)}
