    :root {
      --primary:#6366f1; --primary-dark:#4f46e5; --primary-light:#e0e7ff;
      --success:#22c55e; --warning:#f59e0b; --danger:#ef4444; --gray:#6b7280;
      --bg:#f8fafc; --surface:#fff; --border:#e2e8f0;
      --text:#1e293b; --text-muted:#64748b;
      --shadow-sm:0 1px 3px rgba(0,0,0,0.08);
      --shadow-md:0 4px 16px rgba(0,0,0,0.10);
      --shadow-lg:0 8px 32px rgba(0,0,0,0.14);
      --radius:12px;
    }
    *{margin:0;padding:0;box-sizing:border-box;}
    body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);}

    /* NOTIF PAGOS DROPDOWN */
    .notif-pagos-wrap{position:relative;}


    /* ── PLAN AVISO ── */
    .plan-aviso{display:none;padding:10px 28px;font-size:13px;font-weight:600;text-align:center;position:sticky;top:60px;z-index:49;}
    .plan-aviso.trial{background:#fef9c3;color:#92400e;border-bottom:1px solid #fde68a;}
    .plan-aviso.gracia{background:#fee2e2;color:#b91c1c;border-bottom:1px solid #fecaca;}
    .plan-aviso.limite{background:#fff7ed;color:#c2410c;border-bottom:1px solid #fed7aa;}
    .plan-aviso a{color:inherit;font-weight:700;text-decoration:underline;cursor:pointer;}
    .plan-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#e0e7ff;color:#4338ca;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;}
    .plan-badge:hover{background:#c7d2fe;}
    /* TOUR */
    .tour-highlight{position:fixed;z-index:1001;border-radius:10px;box-shadow:0 0 0 4px var(--primary),0 0 0 9999px rgba(0,0,0,0.55);pointer-events:none;transition:all 0.3s ease;}
    .tour-tooltip{position:fixed;z-index:1002;background:white;border-radius:14px;padding:20px 22px;width:300px;box-shadow:0 8px 32px rgba(0,0,0,0.18);animation:tourFade 0.2s ease;}
    @keyframes tourFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
    .tour-tooltip-step{font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;}
    .tour-tooltip-titulo{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;}
    .tour-tooltip-desc{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:16px;}
    .tour-tooltip-footer{display:flex;align-items:center;justify-content:space-between;}
    .tour-tooltip-dots{display:flex;gap:5px;}
    .tour-dot{width:6px;height:6px;border-radius:50%;background:var(--border);}
    .tour-dot.active{background:var(--primary);width:18px;border-radius:3px;transition:width 0.2s;}
    .tour-tooltip-btns{display:flex;gap:8px;align-items:center;}
    .btn-tour-skip{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;font-family:inherit;padding:0;}
    .btn-tour-skip:hover{text-decoration:underline;}
    .btn-tour-next{padding:8px 18px;background:var(--primary);color:white;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;}
    .btn-tour-next:hover{background:var(--primary-dark);}
    .notif-pagos-btn{background:transparent;border:1.5px solid var(--border);cursor:pointer;padding:7px 10px;border-radius:8px;display:flex;align-items:center;justify-content:center;position:relative;transition:all 0.15s;}
    .notif-pagos-btn:hover{background:var(--bg);border-color:#c7d2fe;}
    .notif-pagos-btn svg{width:17px;height:17px;stroke:var(--text-muted);transition:stroke 0.15s;}
    .notif-pagos-btn:hover svg{stroke:var(--primary);}
    .notif-pagos-badge{position:absolute;top:-6px;right:-6px;background:#ef4444;color:white;font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:none;align-items:center;justify-content:center;padding:0 4px;line-height:1;border:2px solid white;box-shadow:0 1px 4px rgba(239,68,68,0.4);}
    .notif-pagos-badge.visible{display:flex;}
    .notif-pagos-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:320px;background:white;border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,0.15);border:1px solid var(--border);z-index:200;display:none;overflow:hidden;}
    .notif-pagos-dropdown.visible{display:block;animation:dropFade 0.15s ease;}
    @keyframes dropFade{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
    .notif-pagos-header{padding:14px 16px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
    .notif-pagos-header h3{font-size:14px;font-weight:700;color:var(--text);}
    .notif-pagos-header span{font-size:12px;color:var(--text-muted);}
    .notif-pagos-lista{max-height:320px;overflow-y:auto;}
    .notif-pago-item{padding:12px 16px;border-bottom:1px solid #f8fafc;display:flex;justify-content:space-between;align-items:center;transition:background 0.1s;}
    .notif-pago-item:hover{background:#fafbff;}
    .notif-pago-item:last-child{border-bottom:none;}
    .notif-pago-nuevo{background:#f0f4ff;}
    .notif-pago-nuevo:hover{background:#e8eeff !important;}
    .notif-pago-nombre{font-size:13px;font-weight:600;color:var(--text);}
    .notif-pago-sub{font-size:11px;color:var(--text-muted);margin-top:2px;}
    .notif-pago-monto{font-size:14px;font-weight:700;color:#15803d;white-space:nowrap;margin-left:12px;}
    .notif-pagos-empty{padding:24px 16px;text-align:center;color:var(--text-muted);font-size:13px;}


    .login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#faf5ff);}
    .login-box{background:var(--surface);padding:44px;border-radius:20px;width:100%;max-width:400px;box-shadow:var(--shadow-lg);}
    .login-brand{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
    .login-brand-icon{width:40px;height:40px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:white;font-weight:800;font-size:18px;}
    .login-brand h1{font-size:24px;font-weight:800;}
    .login-box>p{color:var(--text-muted);font-size:14px;margin-bottom:32px;}
    .campo{margin-bottom:18px;}
    .campo label{display:block;font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:6px;}
    .campo input,.campo select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:inherit;transition:border-color 0.15s;}
    .campo input:focus,.campo select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,0.1);}
    .btn-full{width:100%;padding:12px;background:var(--primary);color:white;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:background 0.15s;}
    .btn-full:hover{background:var(--primary-dark);}
    .divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#cbd5e1;font-size:13px;}
    .divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border);}
    .btn-google{width:100%;padding:11px;background:var(--surface);color:var(--text);border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;font-family:inherit;transition:all 0.15s;}
    .btn-google:hover{background:var(--bg);border-color:#c7d2fe;}
    .btn-google svg{width:20px;height:20px;}
    .error-msg{color:var(--danger);font-size:13px;margin-top:12px;text-align:center;}
    .link-btn{background:none;border:none;color:var(--primary);font-size:13px;cursor:pointer;font-family:inherit;margin-top:12px;display:block;text-align:center;width:100%;}
    .link-btn:hover{text-decoration:underline;}

    /* WIZARD */
    .wizard-wrap{min-height:100vh;display:none;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#faf5ff);padding:24px;}
    .wizard-wrap.visible{display:flex;}
    .wizard-box{background:var(--surface);border-radius:20px;width:100%;max-width:560px;box-shadow:var(--shadow-lg);overflow:hidden;}
    .wizard-header{background:var(--primary);padding:28px 32px;}
    .wizard-header h2{color:white;font-size:22px;font-weight:800;}
    .wizard-header p{color:rgba(255,255,255,0.75);font-size:14px;margin-top:4px;}
    .wizard-steps{display:flex;gap:0;padding:0 32px;background:white;border-bottom:1px solid var(--border);}
    .wizard-step{flex:1;padding:14px 0;text-align:center;font-size:13px;font-weight:600;color:var(--text-muted);border-bottom:3px solid transparent;transition:all 0.15s;cursor:default;}
    .wizard-step.active{color:var(--primary);border-bottom-color:var(--primary);}
    .wizard-step.done{color:var(--success);}
    .wizard-body{padding:32px;}
    .wizard-footer{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;border-top:1px solid var(--border);background:#fafbff;}
    .btn-wiz-next{padding:11px 28px;background:var(--primary);color:white;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;}
    .btn-wiz-next:hover{background:var(--primary-dark);}
    .btn-wiz-skip{background:none;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;font-family:inherit;}
    .btn-wiz-skip:hover{text-decoration:underline;}
    .btn-wiz-back{background:#f1f5f9;color:var(--text-muted);border:none;border-radius:10px;padding:11px 20px;font-size:14px;cursor:pointer;font-family:inherit;}

    /* País selector */
    .pais-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;}
    .pais-card{border:2px solid var(--border);border-radius:12px;padding:16px 12px;text-align:center;cursor:pointer;transition:all 0.15s;}
    .pais-card:hover{border-color:var(--primary);}
    .pais-card.selected{border-color:var(--primary);background:var(--primary-light);}
    .pais-flag{font-size:28px;margin-bottom:6px;}
    .pais-nombre{font-size:13px;font-weight:600;color:var(--text);}
    .pais-prefijo{font-size:11px;color:var(--text-muted);margin-top:2px;}

    /* Importar alumnos */
    .import-area{border:2px dashed var(--border);border-radius:12px;padding:20px;transition:border-color 0.15s;}
    .import-area:focus-within{border-color:var(--primary);}
    .import-textarea{width:100%;border:none;outline:none;font-family:'Inter',monospace;font-size:13px;color:var(--text);resize:vertical;min-height:140px;background:transparent;}
    .import-preview{margin-top:16px;}
    .import-table{width:100%;border-collapse:collapse;font-size:13px;}
    .import-table th{background:#f8fafc;padding:8px 10px;text-align:left;font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;border-bottom:1px solid var(--border);}
    .import-table td{padding:8px 10px;border-bottom:1px solid #f1f5f9;color:var(--text);}
    .import-table tr:last-child td{border-bottom:none;}
    .import-badge{display:inline-block;padding:2px 7px;border-radius:6px;font-size:11px;font-weight:600;}
    .import-badge.ok{background:#dcfce7;color:#15803d;}
    .import-badge.sin-contacto{background:#fef9c3;color:#92400e;}

    /* APP */
    .app-wrap{display:none;min-height:100vh;}
    .app-wrap.visible{display:flex;flex-direction:column;}
    .topnav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm);}
    .topnav-brand{display:flex;align-items:center;gap:10px;}
    .topnav-logo{width:32px;height:32px;border-radius:8px;object-fit:cover;display:none;}
    .topnav-logo.visible{display:block;}
    .topnav-icon{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:white;font-weight:800;font-size:14px;}
    .topnav-nombre{font-size:17px;font-weight:700;}
    .topnav-actions{display:flex;align-items:center;gap:10px;}
    .btn-nav{padding:7px 16px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;transition:all 0.15s;}
    .btn-nav-outline{background:transparent;color:var(--text-muted);border:1.5px solid var(--border);}
    .btn-nav-outline:hover{background:var(--bg);color:var(--text);}
    .main-content{padding:28px;flex:1;}
    .resumen{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:28px;}
    .stat-card{background:var(--surface);border-radius:var(--radius);padding:20px 22px;cursor:pointer;transition:all 0.15s;border:2px solid transparent;box-shadow:var(--shadow-sm);}
    .stat-card:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-md);}
    .stat-card .num{font-size:34px;font-weight:800;line-height:1;margin-bottom:4px;}
    .stat-card .lbl{font-size:12px;font-weight:500;color:var(--text-muted);}
    .stat-card.total .num{color:var(--primary);}
    .stat-card.activo .num{color:var(--success);}
    .stat-card.por_vencer .num{color:var(--warning);}
    .stat-card.vencido .num{color:var(--danger);}
    .stat-card.inactivo .num{color:var(--gray);}
    .controles{display:flex;gap:10px;align-items:center;margin-bottom:20px;flex-wrap:wrap;}
    .input-busqueda{flex:1;min-width:200px;padding:9px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:inherit;background:var(--surface);}
    .input-busqueda:focus{outline:none;border-color:var(--primary);}
    .select-ctrl{padding:9px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;background:var(--surface);cursor:pointer;font-family:inherit;}
    .btn-nuevo{padding:9px 20px;border-radius:10px;border:none;cursor:pointer;font-size:14px;font-weight:600;background:var(--primary);color:white;font-family:inherit;transition:background 0.15s;}
    .btn-nuevo:hover{background:var(--primary-dark);}
    .tabla-wrap{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
    table{width:100%;border-collapse:collapse;}
    thead{background:#f8fafc;}
    th{text-align:left;padding:13px 18px;font-size:12px;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:0.5px;}
    td{padding:13px 18px;font-size:14px;border-bottom:1px solid #f1f5f9;}
    tr:last-child td{border-bottom:none;}
    tr:hover td{background:#fafbff;}
    tr.fila-inactiva td{opacity:0.45;}
    .nombre-link{color:var(--primary);cursor:pointer;font-weight:600;}
    .nombre-link:hover{text-decoration:underline;}
    .alumno-foto{width:34px;height:34px;border-radius:50%;object-fit:cover;margin-right:8px;vertical-align:middle;cursor:zoom-in;transition:transform 0.15s;border:2px solid var(--primary-light);}
    .alumno-foto:hover{transform:scale(1.1);}
    .alumno-inicial{width:34px;height:34px;border-radius:50%;background:var(--primary-light);color:var(--primary);font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-right:8px;vertical-align:middle;}
    .badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;}
    .badge::before{content:'';width:6px;height:6px;border-radius:50%;}
    .badge.activo{background:#dcfce7;color:#15803d;}.badge.activo::before{background:#22c55e;}
    .badge.por_vencer{background:#fef9c3;color:#92400e;}.badge.por_vencer::before{background:#f59e0b;}
    .badge.vencido{background:#fee2e2;color:#b91c1c;}.badge.vencido::before{background:#ef4444;}
    .badge.sin_pago,.badge.inactivo{background:#f1f5f9;color:#475569;}.badge.sin_pago::before,.badge.inactivo::before{background:#94a3b8;}
    .precio-tag{font-size:12px;color:var(--primary);background:var(--primary-light);padding:3px 9px;border-radius:8px;font-weight:600;}
    .precio-base-tag{font-size:12px;color:var(--text-muted);background:#f1f5f9;padding:3px 9px;border-radius:8px;}
    .btn-xs{font-size:11px;padding:4px 10px;border-radius:6px;cursor:pointer;font-weight:600;font-family:inherit;border:none;transition:all 0.12s;}
    .btn-xs-ghost{background:none;color:var(--primary);border:1px solid var(--primary-light);margin-left:4px;}
    .btn-xs-ghost:hover{background:var(--primary-light);}
    .btn-xs-success{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0;}
    .btn-xs-success:hover{background:#dcfce7;}
    .btn-xs-warn{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;}
    .btn-xs-warn:hover{background:#ffedd5;}
    .btn-xs-danger{background:#fff1f2;color:#be123c;border:1px solid #fecdd3;}
    .btn-xs-danger:hover{background:#ffe4e6;}
    .btn-xs-reactivar{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0;}
    .foto-zoom-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.88);z-index:500;align-items:center;justify-content:center;cursor:zoom-out;}
    .foto-zoom-overlay.visible{display:flex;}
    .foto-zoom-overlay img{max-width:80vw;max-height:80vh;border-radius:16px;}
    .overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,0.45);z-index:200;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(2px);}
    .overlay.visible{display:flex;}
    .modal{background:var(--surface);border-radius:18px;padding:28px;width:100%;max-width:520px;box-shadow:var(--shadow-lg);max-height:92vh;overflow-y:auto;}
    .modal-header{margin-bottom:20px;}
    .modal-header h2{font-size:19px;font-weight:700;}
    .modal-header p{font-size:13px;color:var(--text-muted);margin-top:4px;}
    .modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);}
    .btn-cancel{background:#f1f5f9;color:var(--text-muted);padding:10px 20px;border-radius:10px;border:none;cursor:pointer;font-size:14px;font-family:inherit;}
    .btn-save{background:var(--primary);color:white;padding:10px 20px;border-radius:10px;border:none;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;}
    .btn-save:hover{background:var(--primary-dark);}
    .hint{font-size:12px;color:var(--text-muted);margin-top:5px;}
    .required{color:var(--danger);}
    .config-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:24px;overflow-x:auto;}
    .config-tab{padding:10px 18px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;font-family:inherit;background:none;border-left:none;border-right:none;border-top:none;transition:all 0.15s;}
    .config-tab.active{color:var(--primary);border-bottom-color:var(--primary);}
    .config-panel{display:none;}.config-panel.active{display:block;}
    .config-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #f1f5f9;}
    .config-row:last-child{border-bottom:none;}
    .config-row-col{flex-direction:column;align-items:flex-start;gap:10px;}
    .config-label{font-size:14px;font-weight:500;}
    .config-sublabel{font-size:12px;color:var(--text-muted);margin-top:2px;}
    .config-input{width:110px;padding:7px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:14px;text-align:right;font-family:inherit;}
    .config-input-full{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;font-family:inherit;}
    .config-input:focus,.config-input-full:focus{outline:none;border-color:var(--primary);}
    .config-unit{font-size:13px;color:var(--text-muted);margin-left:6px;}
    .config-checks{display:flex;gap:18px;}
    .col-menu-item{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:13px;cursor:pointer;color:var(--text)}
    .col-menu-item:hover{background:#f8fafc}
    .config-check{display:flex;align-items:center;gap:7px;font-size:14px;cursor:pointer;}
    .config-check input{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;}
    .img-preview-row{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
    .img-preview{width:64px;height:64px;border-radius:10px;object-fit:cover;border:2px solid var(--border);display:none;}
    .img-preview.visible{display:block;}
    .btn-del-img{background:#fee2e2;color:#b91c1c;border:none;border-radius:8px;padding:6px 12px;font-size:12px;cursor:pointer;font-family:inherit;}
    .img-tabs{display:flex;gap:8px;margin-bottom:10px;}
    .img-tab{padding:6px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;cursor:pointer;background:var(--surface);color:var(--text-muted);font-family:inherit;}
    .img-tab.active{background:var(--primary);color:white;border-color:var(--primary);}
    .img-panel{display:none;}.img-panel.active{display:block;}
    .upload-area{border:2px dashed var(--border);border-radius:10px;padding:18px;text-align:center;cursor:pointer;transition:all 0.15s;}
    .upload-area:hover{border-color:var(--primary);background:#fafbff;}
    .upload-area input{display:none;}
    .upload-area p{font-size:13px;color:var(--text-muted);margin-top:4px;}
    .upload-progress{font-size:12px;color:var(--primary);margin-top:6px;}
    .links-lista{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
    .link-item{display:flex;gap:12px;align-items:center;background:#f8fafc;border-radius:10px;padding:12px 14px;border:1px solid var(--border);}
    .link-item-icon{font-size:22px;}
    .link-item-info{flex:1;}
    .link-item-nombre{font-size:14px;font-weight:600;}
    .link-item-tipo{font-size:12px;color:var(--text-muted);margin-top:2px;}
    .tipo-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600;margin-left:6px;}
    .tipo-badge.api{background:#dcfce7;color:#15803d;}
    .tipo-badge.link{background:var(--primary-light);color:var(--primary);}
    .btn-agregar-medio{width:100%;padding:11px;border:2px dashed #c7d2fe;border-radius:10px;background:var(--surface);color:var(--primary);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s;}
    .btn-agregar-medio:hover{background:#fafbff;border-color:var(--primary);}
    .medios-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
    .medio-card{border:2px solid var(--border);border-radius:12px;padding:14px 12px;cursor:pointer;text-align:center;transition:all 0.15s;}
    .medio-card:hover{border-color:var(--primary);background:#fafbff;}
    .medio-card.selected{border-color:var(--primary);background:var(--primary-light);}
    .medio-card-icon{font-size:28px;margin-bottom:6px;height:56px;display:flex;align-items:center;justify-content:center;}
    .medio-card-icon img{height:40px;width:auto;max-width:110px;object-fit:contain;}
    .medio-card-icon img.logo-mercadopago{height:auto;width:100%;max-width:100%;object-fit:contain;}
    .medio-card-nombre{font-size:13px;font-weight:700;}
    .medio-card-desc{font-size:11px;color:var(--text-muted);margin-top:2px;}
    .medio-form{background:#f8fafc;border-radius:10px;padding:16px;margin-top:4px;border:1px solid var(--border);}
    .historial-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid #f1f5f9;}
    .historial-row:last-child{border-bottom:none;}
    .historial-plan{font-size:14px;font-weight:600;}
    .historial-fecha{font-size:12px;color:var(--text-muted);margin-top:2px;}
    .historial-venc{font-size:12px;color:var(--text-muted);}
    .historial-monto{font-size:15px;font-weight:700;white-space:nowrap;margin-left:12px;}
    .btn-mostrar-mas{width:100%;padding:10px;background:none;border:none;border-top:1px solid var(--border);color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;}
    .planes-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
    .plan-card{border:2px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;text-align:center;transition:all 0.15s;}
    .plan-card:hover{border-color:var(--primary);}
    .plan-card.selected{border-color:var(--primary);background:var(--primary-light);}
    .plan-card .plan-nombre{font-size:13px;font-weight:600;}
    .plan-card .plan-precio{font-size:22px;font-weight:800;color:var(--primary);margin:8px 0 3px;}
    .plan-card .plan-descuento{font-size:11px;color:var(--success);font-weight:600;}
    .plan-card .plan-meses{font-size:11px;color:var(--text-muted);margin-top:2px;}
    .plan-card.personalizado{border-style:dashed;}
    .plan-card.personalizado .plan-precio{font-size:14px;color:var(--text-muted);}
    .fecha-manual-wrap{display:none;background:var(--primary-light);border-radius:10px;padding:14px;margin-bottom:14px;}
    .fecha-manual-wrap.visible{display:block;}
    .fecha-manual-wrap label{font-size:13px;display:block;margin-bottom:6px;font-weight:500;}
    .fecha-manual-wrap input{width:100%;padding:9px 12px;border:1.5px solid #c7d2fe;border-radius:8px;font-size:14px;font-family:inherit;}
    .empty-state{text-align:center;padding:48px;color:var(--text-muted);font-size:14px;}
    .empty-state-icon{font-size:36px;margin-bottom:10px;}
