:root{
  --bg:#07080d;--s1:#0d0f17;--s2:#13151f;--s3:#1a1d2a;
  --border:#1e2133;--text:#e2e8f6;--muted:#4a5270;--muted2:#6b7594;
  --income:#00d48a;--expense:#ff4560;--accent:#5b7fff;
  --income-dim:rgba(0,212,138,.12);--expense-dim:rgba(255,69,96,.12);--accent-dim:rgba(91,127,255,.12);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html, body { height: 100%; max-width: 100vw; overflow-x: hidden; position: relative; }
body { font-family: 'Outfit', sans-serif; background: var(--bg); color: var(--text); }

.header{padding:16px 20px; border-bottom:1px solid var(--border); background:var(--s1);display:flex; justify-content:space-between; align-items:center; position:sticky; top:0; z-index:20; flex-wrap: wrap; gap: 12px;}
.header-left{display:flex;align-items:center;gap:20px}
.header-title{font-size:20px;font-weight:800;letter-spacing:-.5px}
.header-title span{color:var(--accent)}
.header-right{display:flex;align-items:center;gap:12px;text-align:right}
.header-date{font-size:12px;color:var(--muted2);font-weight:500;display:none}
@media(min-width:600px){.header-date{display:block}}
.header-date b{display:block;font-family:'JetBrains Mono';font-size:11px;color:var(--muted)}


.logout-btn{background:none;border:1px solid var(--border);color:var(--expense);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;}
.logout-btn:hover{background:var(--expense-dim);border-color:var(--expense)}
.icon-btn{background:var(--s2);border:1px solid var(--border);color:var(--text);width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all .2s ease;}
.icon-btn:hover{background:var(--s3);border-color:var(--muted);transform:rotate(15deg)}

.desktop-nav{display:none;gap:4px}
.desktop-nav-btn{padding:7px 16px;border-radius:8px;border:none;background:none;font-size:13px;font-weight:600;font-family:'Outfit',sans-serif;color:var(--muted2);cursor:pointer;transition:all .2s;}
.desktop-nav-btn.active{background:var(--accent-dim);color:var(--accent)}
.desktop-nav-btn:hover:not(.active){background:var(--s2);color:var(--text)}

.mobile-nav{position:fixed;bottom:0;left:0;right:0; display:flex; background:var(--s1);border-top:1px solid var(--border); z-index:20; justify-content:space-around; padding:0 4px;}
.nav-btn{flex:1;padding:12px 0 14px; display:flex; flex-direction:column; align-items:center; gap:4px;font-size:9px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);cursor:pointer;border:none;background:none;transition:all .2s ease;}
.nav-btn.active{color:var(--accent);transform:translateY(-2px)}
.nav-icon{font-size:20px;line-height:1;transition:transform .2s;margin-bottom:2px}

.app-body{padding-bottom:72px; transition: opacity 0.3s ease;}
.panel{padding:20px;display:none; animation: fadeIn 0.3s ease; width: 100%; max-width: 100vw; overflow-x: hidden;}
@keyframes fadeIn { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }
.panel.active{display:block}

/* --- EL ÍCONO "i" --- */
.tooltip-wrapper { position: relative; display: inline-flex; align-items: center; }
.info-icon { display: flex; align-items: center; justify-content: center; width: 16px; height: 16px; background-color: var(--muted, #6b7280); color: #fff; border-radius: 50%; font-size: 11px; font-style: normal; font-weight: bold; cursor: help; transition: transform 0.2s ease, background-color 0.2s ease; }
.info-icon:hover { transform: scale(1.15) rotate(10deg); background-color: var(--income, #10b981); }
.custom-tooltip { visibility: hidden; opacity: 0; position: absolute; bottom: 140%; right: -5px; width: 240px; background-color: #1e1e1e; color: #ededed; text-align: left; padding: 10px 12px; border-radius: 8px; font-size: 12px; line-height: 1.4; box-shadow: 0 8px 16px rgba(0,0,0,0.4); border: 1px solid #333; transform: translateY(8px); transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease; z-index: 100; text-transform: none; font-weight: normal; }
.custom-tooltip::after { content: ""; position: absolute; top: 100%; right: 9px; border-width: 6px; border-style: solid; border-color: #1e1e1e transparent transparent transparent; }
.tooltip-wrapper:hover .custom-tooltip { visibility: visible; opacity: 1; transform: translateY(0); }

/* GRID ESCRITORIO */
@media(min-width:900px){
  body{height:100vh;display:flex;flex-direction:column}
  .header{flex-shrink:0}
  .desktop-nav{display:flex}
  .mobile-nav{display:none}
  .panel::-webkit-scrollbar{width:4px}
  .panel::-webkit-scrollbar-track{background:transparent}
  .panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
  
  .app-body.desktop-add { display: flex; justify-content: center; align-items: flex-start; gap: 24px; padding-top: 6vh; height: 100%; overflow-y: auto; }
  .app-body.desktop-add .panel-add { display: block !important; width: 100%; max-width: 440px; background: var(--s1); border: 1px solid var(--border); border-radius: 20px; padding: 32px; box-shadow: 0 10px 40px rgba(0,0,0,0.5); }
  .app-body.desktop-add .panel-reminders { display: none; width: 100%; max-width: 380px; background: transparent; padding: 0; }
  .app-body.desktop-add.with-fixed .panel-reminders { display: block !important; }
  
  .app-body.desktop-centered { display: flex; justify-content: center; padding-top: 6vh; height: 100%; overflow-y: auto; }
  .app-body.desktop-centered .panel.active { display: block !important; width: 100%; max-width: 600px; background: var(--s1); border: 1px solid var(--border); border-radius: 20px; padding: 32px; box-shadow: 0 10px 40px rgba(0,0,0,0.5); }
  
  .app-body.desktop-dashboard { display: grid; grid-template-columns: 1fr 380px; gap: 24px; max-width: 1200px; margin: 0 auto; width: 100%; height: 100%; padding-top: 30px;}
  .app-body.desktop-dashboard .panel-add, .app-body.desktop-dashboard .panel-fixed, .app-body.desktop-dashboard .panel-usd, .app-body.desktop-dashboard .panel-analytics, .app-body.desktop-dashboard .panel-reminders { display: none !important; }
  .app-body.desktop-dashboard .panel-movements { display: block !important; background: transparent; padding: 0; overflow-y: auto; padding-bottom: 60px; }
  .app-body.desktop-dashboard .panel-summary { display: block !important; background: transparent; padding: 0; overflow-y: auto; padding-bottom: 60px; }
}

.panel-title{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:18px;display:none;}
@media(min-width:900px){.panel-title{display:block}}

/* --- ESTILOS CUPONES --- */
.coupon-card { background: linear-gradient(135deg, rgba(255, 218, 0, 0.05) 0%, rgba(74, 144, 226, 0.05) 100%); border: 1px solid rgba(74, 144, 226, 0.3); border-radius: 14px; padding: 16px; margin-top: 12px; display: flex; justify-content: space-between; align-items: center; transition: transform 0.2s; }
.coupon-card:hover { transform: translateY(-2px); border-color: #4a90e2; }
.coupon-body { display: flex; flex-direction: column; gap: 4px; }
.coupon-amount { font-size: 18px; font-weight: 800; color: #4a90e2; }
.coupon-details { font-size: 12px; color: var(--text); font-weight: 600; }
.coupon-expiry { font-size: 11px; color: var(--muted2); }
.coupon-code-wrp { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.coupon-code-txt { font-family: 'JetBrains Mono'; font-size: 14px; font-weight: 700; background: var(--s3); padding: 4px 10px; border-radius: 6px; border: 1px dashed var(--border); color: var(--text); }
.copy-btn-coupon { background: #ffda00; color: #1a1d2a; border: none; font-size: 11px; font-weight: 700; padding: 6px 12px; border-radius: 20px; cursor: pointer; transition: all 0.2s; }
.copy-btn-coupon:hover { background: #e6c500; transform: translateY(-1px); }

.amount-wrap{background:var(--s2);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:14px;text-align:center; transition: border-color 0.3s;}
.amount-wrap:focus-within{border-color:var(--accent)}
.amount-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted2);margin-bottom:10px}
.amount-prefix{font-size:28px;font-weight:700;color:var(--muted2);font-family:'JetBrains Mono'}
.amount-input{background:none;border:none;outline:none;font-size:40px;font-weight:700;font-family:'JetBrains Mono';color:var(--text);width:calc(100% - 36px);text-align:center;caret-color:var(--accent);}

.type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.type-btn{padding:14px;border-radius:12px;border:1.5px solid var(--border);background:var(--s2);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;color:var(--muted2);display:flex;align-items:center;justify-content:center;gap:8px;}
.type-btn.active-income{border-color:var(--income);background:var(--income-dim);color:var(--income)}
.type-btn.active-expense{border-color:var(--expense);background:var(--expense-dim);color:var(--expense)}

.field{background:var(--s2);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;width:100%;font-size:15px;font-family:'Outfit',sans-serif;color:var(--text);outline:none;margin-bottom:10px;transition:all .2s;}
.field:focus{border-color:var(--accent);box-shadow: 0 0 0 3px var(--accent-dim);}
select.field option { background: var(--s2); color: var(--text); }

.submit-btn{width:100%;padding:16px;border-radius:14px;border:none;font-size:16px;font-weight:700;font-family:'Outfit',sans-serif;cursor:pointer;transition:all .2s;margin-top:4px;}
.submit-btn.btn-income{background:var(--income);color:#000}
.submit-btn.btn-expense{background:var(--expense);color:#fff}
.submit-btn.btn-neutral{background:var(--accent);color:#fff}
.submit-btn:hover{filter:brightness(1.1);transform:translateY(-2px)}
.submit-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none}

.movement{background:var(--s2);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:8px; margin-right:4px;cursor:pointer;transition:all .2s;}
.movement:hover{border-color:var(--s3);transform:translateX(2px)}
.movement.expanded{border-color:var(--accent); transform:none}
.mv-row{display:flex;align-items:center;gap:12px}
.mv-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.mv-info{flex:1;min-width:0}
.mv-concept{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mv-meta{display:flex;align-items:center;gap:6px;margin-top:3px;flex-wrap:wrap}
.mv-date{font-size:11px;color:var(--muted);font-family:'JetBrains Mono'}
.cat-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;letter-spacing:.3px}
.mv-amount{font-family:'JetBrains Mono';font-size:15px;font-weight:600;flex-shrink:0}

.mv-edit{padding:12px 0 4px;border-top:1px solid var(--border);margin-top:12px;display:flex;flex-direction:column;gap:8px; animation:fadeIn 0.2s ease}
.edit-row{display:flex;gap:8px;flex-wrap:wrap}
.edit-field{flex:1;min-width:120px;background:var(--s3);border:1.5px solid var(--border);border-radius:10px;padding:10px 12px;font-size:13px;font-family:'Outfit',sans-serif;color:var(--text);outline:none;}
.edit-field:focus{border-color:var(--accent)}
.edit-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}
.btn-sm{padding:8px 14px;border-radius:8px;border:none;font-size:12px;font-weight:700;cursor:pointer;font-family:'Outfit',sans-serif}
.btn-save{background:var(--accent);color:#fff}
.btn-del{background:var(--expense-dim);color:var(--expense);border:1px solid var(--expense)}
.btn-cancel{background:var(--s3);color:var(--muted2)}

.month-group{margin-bottom:24px}
.summary-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.summary-nav-btn{background:var(--s2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 16px;font-size:18px;cursor:pointer;transition:all .2s;}
.summary-nav-btn:hover{background:var(--s3);color:var(--accent)}
.summary-month-label{font-size:16px;font-weight:700;text-transform:capitalize}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.stat-card{background:var(--s2);border:1px solid var(--border);border-radius:14px;padding:16px}
.stat-card.full{grid-column:1/-1}
.stat-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted2);margin-bottom:8px}
.stat-value{font-family:'JetBrains Mono';font-size:20px;font-weight:600}
.stat-value.income{color:var(--income)}.stat-value.expense{color:var(--expense)}
.stat-value.pos{color:var(--income)}.stat-value.neg{color:var(--expense)}

.pie-section{background:var(--s2);border:1px solid var(--border);border-radius:14px;padding:18px;margin-top:10px}
.pie-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted2);margin-bottom:16px}
.pie-empty{text-align:center;color:var(--muted);padding:30px;font-size:14px}
.legend-item{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.legend-name{flex:1}
.legend-pct{color:var(--muted2);font-family:'JetBrains Mono';font-size:12px}
.legend-val{color:var(--expense);font-family:'JetBrains Mono';font-size:12px;font-weight:600}

.pdf-export-card { background: var(--s2); border: 1px dashed var(--border); border-radius: 14px; padding: 16px; margin-top: 10px; display: flex; align-items: center; gap: 16px; cursor: pointer; transition: all 0.3s ease; }
.pdf-export-card:hover { border-color: var(--expense); transform: translateY(-4px); background: var(--s1); box-shadow: 0 8px 20px rgba(255, 69, 96, 0.15); }
.pdf-icon-wrapper { background: var(--expense-dim); width: 44px; height: 44px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 22px; }
.pdf-text-wrapper { display: flex; flex-direction: column; }
.pdf-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 2px; }
.pdf-subtitle { font-size: 12px; color: var(--muted2); }

.chart-controls { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 20px; align-items: center; }
.chart-type-toggle { display: flex; background: var(--s2); border-radius: 10px; padding: 4px; border: 1px solid var(--border); }
.chart-type-btn { background: transparent; border: none; color: var(--muted2); padding: 8px 16px; font-size: 13px; font-weight: 600; border-radius: 6px; cursor: pointer; transition: all 0.2s; }
.chart-type-btn.active { background: var(--s3); color: var(--text); }
.chart-container { background: var(--s2); border: 1px solid var(--border); border-radius: 16px; padding: 24px 16px 16px; display: flex; flex-direction: column; gap: 10px; height: 280px; position: relative;}
.chart-area { flex: 1; display: flex; align-items: flex-end; justify-content: space-around; gap: 4px; padding-bottom: 10px; border-bottom: 1px dashed var(--border); position: relative; }

.module-menu { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; background: var(--s2); padding: 12px; border-radius: 14px; border: 1px solid var(--border); }
.module-menu-title { width: 100%; font-size: 11px; color: var(--muted2); text-transform: uppercase; font-weight: 700; letter-spacing: 1px; margin-bottom: 4px; }
.module-btn { padding: 8px 16px; border-radius: 20px; font-size: 12px; font-weight: 600; cursor: pointer; border: 1px solid var(--border); background: var(--s1); color: var(--muted2); transition: all 0.2s; }
.module-btn.active { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); }

.analytics-grid { display: flex; flex-wrap: wrap; gap: 20px; align-items: stretch; min-height: 200px; }
.analytics-module { flex: 1 1 calc(50% - 10px); min-width: 300px; max-width: 100%; background: var(--s1); border: 1px solid var(--border); border-radius: 16px; padding: 24px; display: flex; flex-direction: column; animation: fadeIn 0.3s ease; transition: all 0.3s; }
@media(min-width:700px){ .analytics-module:first-child:nth-last-child(1) { flex: 0 1 600px; margin: 0 auto; } }
@media(max-width: 700px) { .analytics-module { flex: 1 1 100%; } }

.heatmap-container { background: transparent; }
.heatmap-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-top: 10px; }
.heatmap-cell { aspect-ratio: 1; border-radius: 6px; background: var(--s3); display: flex; align-items: center; justify-content: center; position: relative; cursor: pointer; transition: transform 0.2s; border: 1px solid rgba(255,255,255,0.02); }
.heatmap-cell:hover { transform: scale(1.15); z-index: 2; border-color: var(--muted) !important; }
.heatmap-tooltip { position: absolute; bottom: 125%; left: 50%; transform: translateX(-50%); background: var(--text); color: var(--bg); padding: 4px 8px; border-radius: 6px; font-size: 11px; font-weight: 700; opacity: 0; pointer-events: none; white-space: nowrap; font-family: 'JetBrains Mono'; transition: opacity 0.2s; z-index: 10; box-shadow: 0 4px 10px rgba(0,0,0,0.5);}
.heatmap-cell:hover .heatmap-tooltip { opacity: 1; }
.heatmap-day-label { font-size: 9px; font-weight: 700; }

.top-x-container { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 24px; }
@media(max-width: 700px){ .top-x-container { grid-template-columns: 1fr; } }
.top-x-box { background: var(--s2); border: 1px solid var(--border); border-radius: 14px; padding: 16px; }
.top-x-title { font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 16px; }
.top-item { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border); }
.top-item:last-child { border-bottom: none; padding-bottom: 0; }
.top-item-name { font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.top-item-stats { text-align: right; }
.top-item-val { font-family: 'JetBrains Mono'; font-size: 13px; font-weight: 600; }
.top-item-pct { font-family: 'JetBrains Mono'; font-size: 11px; color: var(--muted2); }

.usd-balance-card { background: var(--s2); border: 1px solid var(--border); border-radius: 16px; padding: 24px; text-align: center; margin-bottom: 20px; }
.usd-balance-title { font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--muted2); margin-bottom: 10px; }
.usd-balance-amount { font-family: 'JetBrains Mono'; font-size: 40px; font-weight: 800; color: var(--income); }

.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.8);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s;}
.overlay.show{opacity:1;pointer-events:auto}
.modal{background:var(--s1);border:1px solid var(--border);border-radius:20px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;padding:24px;transform:translateY(20px);transition:transform .3s;box-shadow: 0 20px 40px rgba(0,0,0,0.6);}
.overlay.show .modal{transform:translateY(0)}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.modal-title{font-size:18px;font-weight:700}
.close-btn{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;line-height:1}
.setting-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border)}
.setting-info h4{font-size:15px;font-weight:600;margin-bottom:4px}
.setting-info p{font-size:12px;color:var(--muted2); padding-right: 10px;}

.toggle-switch{position:relative;width:44px;height:24px;background:var(--s3);border-radius:12px;cursor:pointer;transition:background .3s; flex-shrink:0;}
.toggle-switch.on{background:var(--income)}
.toggle-switch::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}
.toggle-switch.on::after{transform:translateX(20px)}
.toggle-switch.locked{opacity:0.5;}
.toggle-switch.locked::before{content:'🔒'; position:absolute; left:-24px; top:2px; font-size:14px;}

.cat-list{margin-top:10px;display:flex;flex-direction:column;gap:8px; max-height:220px; overflow-y:auto; padding-right:4px; animation: fadeIn 0.2s ease;}
.cat-item{display:flex;justify-content:space-between;align-items:center;background:var(--s2);padding:8px 14px;border-radius:10px;border:1px solid var(--border)}
.cat-actions { display: flex; gap: 6px; }
.cat-action-btn { background: var(--s3); border: none; padding: 6px 10px; border-radius: 6px; font-size: 12px; font-weight: 700; cursor: pointer; color: var(--text); }
.cat-action-btn.del { color: var(--expense); background: rgba(255,69,96,0.1); }
.add-cat-box{background:var(--s2);padding:14px;border-radius:12px;margin-top:12px;border:1px dashed var(--muted); animation: fadeIn 0.2s ease;}

.auth-container { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100vh; background: var(--bg); padding: 20px; }
.auth-card { background: var(--s1); border: 1px solid var(--border); border-radius: 20px; padding: 32px; width: 100%; max-width: 380px; }
.auth-title { font-size: 24px; font-weight: 800; color: var(--text); margin-bottom: 6px; text-align: center; }
.auth-title span { color: var(--accent); }
.auth-subtitle { font-size: 13px; color: var(--muted2); margin-bottom: 24px; text-align: center; }
.auth-toggle { display: flex; gap: 8px; margin-bottom: 20px; background: var(--s2); padding: 4px; border-radius: 12px; }
.auth-toggle button { flex: 1; padding: 8px; border-radius: 8px; border: none; background: transparent; color: var(--muted2); font-weight: 600; cursor: pointer; transition: all .2s; }
.auth-toggle button.active { background: var(--s3); color: var(--text); }
.error-bar{background:var(--expense-dim);border:1px solid rgba(255,69,96,0.2);border-radius:10px;padding:10px 14px;color:var(--expense);font-size:13px;margin-bottom:14px; text-align:center;}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--s3);border:1px solid var(--border);border-radius:12px;padding:10px 18px;font-size:13px;font-weight:600;z-index:99;opacity:0;transition:all .3s;pointer-events:none;}
@media(max-width:899px){.toast{bottom:86px}}
.toast.show{opacity:1;transform:translate(-50%, -10px)}
.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--muted2)}
.spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

/* MODAL UPSELL */
.modal.premium-upsell { max-width: 700px; padding: 32px; text-align: center; }
.upsell-header { margin-bottom: 24px; }
.premium-upsell .icon { font-size: 48px; margin-bottom: 12px; text-shadow: 0 0 20px var(--accent-dim); }
.premium-upsell h2 { font-size: 24px; font-weight: 800; color: var(--text); margin-bottom: 8px; }
.premium-upsell p { font-size: 14px; color: var(--muted2); line-height: 1.5; }

.billing-toggle { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 24px; }
.billing-label { font-size: 13px; font-weight: 600; color: var(--muted2); transition: color .2s; }
.billing-label.active { color: var(--accent); }

.pricing-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 24px; }
.price-card { background: var(--s2); border: 1px solid var(--border); border-radius: 20px; padding: 20px; text-align: center; display:flex; flex-direction:column; justify-content:space-between; transition: transform .2s; }
.price-card.pro { border-color: var(--accent); position: relative; }
.price-card.pro::before { content: 'RECOMENDADO'; position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--accent); color: #fff; font-size: 10px; font-weight: 800; padding: 4px 12px; border-radius: 12px; }
.price-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 16px; }
.price-amount { font-family: 'JetBrains Mono'; font-size: 32px; font-weight: 800; color: var(--income); margin-bottom: 4px; }
.price-period { font-size: 12px; color: var(--muted2); margin-bottom: 8px; }
.price-ars { font-size: 13px; font-weight: 600; color: var(--muted2); background: var(--s3); padding: 4px 10px; border-radius: 8px; align-self: center; margin-bottom: 12px; }
.price-desc { font-size: 12px; color: var(--muted2); line-height: 1.4; }

.payment-info { background: var(--s2); padding: 20px; border-radius: 16px; text-align: left; margin-bottom: 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media(max-width: 550px) { .payment-info { grid-template-columns: 1fr; } }
.payment-info-box h4 { font-size: 12px; color: var(--text); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 1px; }
.payment-info-box p { font-size: 12px; color: var(--muted2); line-height: 1.6; }
.payment-info-box b { color: var(--accent); font-family: 'JetBrains Mono'; font-size: 11px; word-break: break-all; }

.version-badge { position: fixed; bottom: 20px; right: 20px; font-family: 'JetBrains Mono'; font-size: 10px; color: var(--muted); z-index: 10; pointer-events: none; opacity: 0.8; }
@media(max-width:899px){ .version-badge { bottom: 85px; right: 15px; } }

@media(min-width:900px){
  .app-body.desktop-analytics { display: flex; justify-content: center; padding-top: 30px; height: 100%; overflow-y: auto; width: 100%; }
  .app-body.desktop-analytics .panel.active { display: block !important; width: 100%; max-width: 1200px; background: transparent; padding: 0; box-shadow: none; border: none; }
}

.dropdown-container { position: relative; display: inline-block; margin-bottom: 16px; margin-top: -10px; }
.dropdown-btn { background: var(--s2); border: 1px solid var(--border); padding: 10px 18px; border-radius: 12px; color: var(--text); font-size: 13px; font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 8px; transition: border-color 0.2s; }
.dropdown-btn:hover { border-color: var(--muted); }
.dropdown-content { position: absolute; top: 110%; left: 0; background: var(--s1); border: 1px solid var(--border); border-radius: 12px; min-width: 260px; z-index: 100; padding: 10px; box-shadow: 0 10px 40px rgba(0,0,0,0.8); display: none; flex-direction: column; gap: 6px;}
.dropdown-content.show { display: flex; animation: fadeIn 0.2s ease; }
.dropdown-item { padding: 12px 14px; border-radius: 8px; font-size: 13px; font-weight: 500; color: var(--muted2); cursor: pointer; display: flex; align-items: center; justify-content: space-between; transition: all 0.2s; border: 1px solid transparent;}
.dropdown-item:hover { background: var(--s2); color: var(--text); }
.dropdown-item.active { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); font-weight: 700;}

.multi-variable-selector { background: var(--s2); border-radius: 12px; border: 1px solid var(--border); padding: 10px; margin-bottom: 20px; display: flex; flex-wrap: wrap; gap: 8px;}
.multi-var-title { width: 100%; font-size: 11px; color: var(--muted2); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px;}
.multi-var-option { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border-radius: 10px; border: 1px solid var(--border); background: var(--s1); cursor: pointer; transition: 0.2s;}
.multi-var-option input { display: none; }
.multi-var-option span.icon-and-name { font-size: 13px; font-weight: 600; color: var(--text); }
.multi-var-option .var-dot { width: 10px; height: 10px; border-radius: 50%; border: 1px solid var(--border); transition: 0.2s; }
.multi-var-option:has(input:checked) { border-color: var(--accent); background: var(--accent-dim); }
.multi-var-option:has(input:checked) .var-dot { background: var(--accent); border-color: var(--accent); }
