.home-hero{background:linear-gradient(160deg,var(--g700) 0%,var(--g600) 100%);padding:24px 20px 28px;color:#fff;position:relative;overflow:hidden}.home-hero:after{content:"";position:absolute;right:-30px;bottom:-40px;width:180px;height:180px;border-radius:50%;background:#ffffff0d}.home-hero-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.home-logo{display:flex;align-items:center;gap:10px}.home-logo img{width:38px;height:38px;border-radius:10px;border:2px solid rgba(255,255,255,.3);object-fit:cover}.home-logo-text strong{display:block;font-size:.95rem;font-weight:800;letter-spacing:-.01em}.home-logo-text span{font-size:.72rem;opacity:.7}.home-live-badge{display:flex;align-items:center;gap:5px;background:#ffffff1f;border-radius:20px;padding:5px 10px;font-size:.72rem;font-weight:600}.home-live-dot{width:6px;height:6px;background:#4ade80;border-radius:50%;animation:livePulse 1.8s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.3}}.home-greeting h1{font-size:1.5rem;font-weight:800;line-height:1.2;margin-bottom:4px}.home-greeting h1 em{font-style:normal;color:var(--g300)}.home-greeting p{font-size:.82rem;opacity:.7;max-width:240px;line-height:1.5}.home-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border);margin:16px -20px -28px}.home-stat{background:#ffffff0f;padding:10px 4px;text-align:center}.home-stat-val{font-size:1rem;font-weight:800;color:#fff}.home-stat-lbl{font-size:.65rem;opacity:.65;margin-top:1px}.home-actions{padding:20px 16px 0}.home-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.action-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;cursor:pointer;-webkit-tap-highlight-color:transparent}.action-card:active{transform:scale(.97);box-shadow:none}.action-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.action-icon.green{background:var(--g50);color:var(--g600)}.action-icon.teal{background:#e0f4f0;color:#0d8575}.action-icon.indigo{background:#ede9fe;color:#6d28d9}.action-icon.amber{background:#fef3c7;color:#d97706}.action-card h3{font-size:.88rem;font-weight:700;color:var(--g800);line-height:1.3}.action-card p{font-size:.75rem;color:var(--muted);line-height:1.4}.home-news{padding:20px 16px 0}.news-item{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;box-shadow:var(--shadow-sm)}.news-item-stripe{width:3px;min-height:40px;border-radius:2px;flex-shrink:0;background:var(--g400)}.news-item-body{flex:1;min-width:0}.news-item-cat{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--g500);margin-bottom:3px}.news-item-title{font-size:.88rem;font-weight:700;color:var(--g800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.news-item-date{font-size:.72rem;color:var(--muted);margin-top:3px}.mp-topbar{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--border);padding:12px 16px}.mp-topbar h1{font-size:1.1rem;font-weight:800;color:var(--g800);margin-bottom:10px}.mp-search-wrap{display:flex;align-items:center;gap:8px;background:var(--g50);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:0 12px}.mp-search-wrap svg{color:var(--muted);flex-shrink:0}.mp-search-wrap input{flex:1;border:none;background:transparent;padding:10px 0;font-size:.9rem;color:var(--g900);outline:none}.mp-search-clear{font-size:.8rem;color:var(--muted);padding:4px}.mp-cats{display:flex;gap:8px;overflow-x:auto;padding:12px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.mp-cats::-webkit-scrollbar{display:none}.mp-cat-chip{flex-shrink:0;padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:600;border:1.5px solid var(--border);background:#fff;color:var(--muted);transition:all .15s}.mp-cat-chip.active{background:var(--g700);border-color:var(--g700);color:#fff}.mp-toggle{display:flex;margin:0 16px 12px;background:var(--g50);border-radius:var(--radius-sm);padding:3px}.mp-toggle-btn{flex:1;padding:7px;border-radius:6px;font-size:.8rem;font-weight:600;color:var(--muted);transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px}.mp-toggle-btn.active{background:#fff;color:var(--g700);box-shadow:var(--shadow-sm)}.biz-card{margin:0 16px 12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.biz-card-top{display:flex;align-items:center;gap:12px;padding:14px 14px 12px;position:relative}.biz-card-accent{position:absolute;left:0;top:0;bottom:0;width:3px}.biz-info{flex:1;min-width:0;padding-left:8px}.biz-cats{display:flex;gap:5px;margin-bottom:4px;flex-wrap:wrap}.biz-cat-tag{font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:10px;border:1px solid transparent}.biz-name{font-size:.95rem;font-weight:800;color:var(--g800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.biz-desc{font-size:.78rem;color:var(--muted);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.biz-meta{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:.72rem;color:var(--muted)}.biz-wa-btn{margin:0 14px 14px;display:flex;align-items:center;justify-content:center;gap:7px;background:#25d366;color:#fff;border-radius:var(--radius-md);padding:10px;font-size:.85rem;font-weight:700}.prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px}.prod-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.prod-img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--g50);display:flex;align-items:center;justify-content:center;color:var(--g200)}.prod-img img{width:100%;height:100%;object-fit:cover}.prod-body{padding:10px}.prod-cat{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--g500);margin-bottom:3px}.prod-name{font-size:.85rem;font-weight:700;color:var(--g800);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.prod-price{font-size:.92rem;font-weight:800;color:var(--g600);margin-top:5px}.prod-origin{font-size:.7rem;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-screen{min-height:100%;display:flex;flex-direction:column}.auth-header{background:linear-gradient(160deg,var(--g700) 0%,var(--g600) 100%);padding:28px 24px 36px;color:#fff;text-align:center}.auth-header-logo{width:56px;height:56px;border-radius:16px;border:2px solid rgba(255,255,255,.25);object-fit:cover;margin:0 auto 12px;display:block}.auth-header h1{font-size:1.2rem;font-weight:800}.auth-header p{font-size:.8rem;opacity:.7;margin-top:4px}.auth-card{flex:1;background:var(--warm);border-radius:24px 24px 0 0;margin-top:-16px;padding:24px 20px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-error{background:#fee2e2;color:#b91c1c;padding:10px 14px;border-radius:var(--radius-md);font-size:.82rem;font-weight:600;text-align:center}.portal-header{background:linear-gradient(160deg,var(--g700) 0%,var(--g600) 100%);padding:20px 20px 28px;color:#fff}.portal-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.portal-greeting strong{display:block;font-size:1rem;font-weight:800}.portal-greeting span{font-size:.78rem;opacity:.7}.btn-logout-sm{display:flex;align-items:center;gap:5px;background:#ffffff1f;color:#fff;border-radius:var(--radius-sm);padding:6px 10px;font-size:.78rem;font-weight:600}.payment-status-card{background:#ffffff1f;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:14px 16px}.payment-status-card .label{font-size:.72rem;opacity:.7;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.payment-status-card .amount{font-size:1.8rem;font-weight:800;line-height:1}.payment-status-card .period{font-size:.78rem;opacity:.65;margin-top:2px}.badge-al-dia{display:inline-flex;align-items:center;gap:5px;background:#4ad47233;color:#4ade80;border-radius:20px;padding:4px 10px;font-size:.72rem;font-weight:700;margin-top:8px}.badge-pendiente{background:#fbbf2433;color:#fbbf24}.portal-content{padding:0 16px;margin-top:-12px}.portal-tabs{display:flex;gap:8px;margin-bottom:16px;background:var(--g50);border-radius:var(--radius-md);padding:3px}.portal-tab{flex:1;padding:8px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;color:var(--muted);transition:all .15s;text-align:center}.portal-tab.active{background:#fff;color:var(--g700);box-shadow:var(--shadow-sm)}.pago-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;box-shadow:var(--shadow-sm)}.pago-left{display:flex;flex-direction:column;gap:3px}.pago-period{font-size:.88rem;font-weight:700;color:var(--g800)}.pago-date{font-size:.72rem;color:var(--muted)}.pago-right{text-align:right}.pago-amount{font-size:.95rem;font-weight:800;color:var(--g600)}.pago-tipo{font-size:.68rem;color:var(--muted);margin-top:2px;text-transform:capitalize}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;box-shadow:var(--shadow-sm)}.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--g400);flex-shrink:0;margin-top:5px}.notif-dot.read{background:var(--border)}.notif-title{font-size:.88rem;font-weight:700;color:var(--g800);margin-bottom:3px}.notif-body{font-size:.78rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.chat-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.chat-sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:85dvh;background:#fff;border-radius:24px 24px 0 0;z-index:201;display:flex;flex-direction:column;animation:slideUp .28s cubic-bezier(.32,.72,0,1)}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}.chat-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-header-drag{width:36px;height:4px;background:var(--border);border-radius:2px;position:absolute;top:8px;left:50%;transform:translate(-50%)}.chat-icon{width:40px;height:40px;border-radius:12px;background:var(--g700);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-header-text strong{display:block;font-size:.95rem;font-weight:800;color:var(--g800)}.chat-header-text span{font-size:.75rem;color:var(--g500);display:flex;align-items:center;gap:4px}.chat-status-dot{width:6px;height:6px;background:#4ade80;border-radius:50%}.chat-close{margin-left:auto;width:32px;height:32px;border-radius:50%;background:var(--g50);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:1rem}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}.chat-msg{display:flex;flex-direction:column;max-width:80%}.chat-msg.bot{align-self:flex-start}.chat-msg.user{align-self:flex-end}.chat-bubble{padding:10px 14px;border-radius:18px;font-size:.88rem;line-height:1.5}.chat-msg.bot .chat-bubble{background:var(--g50);color:var(--g800);border-bottom-left-radius:4px;border:1px solid var(--border)}.chat-msg.user .chat-bubble{background:var(--g700);color:#fff;border-bottom-right-radius:4px}.chat-time{font-size:.65rem;color:var(--muted);margin-top:3px;padding:0 4px}.chat-msg.user .chat-time{text-align:right}.chat-suggestions{display:flex;gap:7px;flex-wrap:wrap;padding:0 16px 12px}.chat-suggestion{padding:6px 12px;border-radius:20px;border:1.5px solid var(--g200);background:var(--g50);color:var(--g600);font-size:.78rem;font-weight:600;transition:all .15s}.chat-suggestion:active{background:var(--g100)}.chat-input-row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-top:1px solid var(--border);padding-bottom:calc(12px + var(--safe-bottom));flex-shrink:0}.chat-input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:22px;font-size:.9rem;outline:none;background:var(--g50);transition:border-color .15s}.chat-input:focus{border-color:var(--g400)}.chat-send{width:40px;height:40px;border-radius:50%;background:var(--g700);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .1s}.chat-send:active{transform:scale(.9)}.chat-send:disabled{background:var(--border)}.typing-dots{display:flex;gap:4px;align-items:center;padding:4px 0}.typing-dots span{width:6px;height:6px;background:var(--g300);border-radius:50%;animation:dot 1.2s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes dot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}:root{--g900: #0d1f17;--g800: #132b1f;--g700: #1a3326;--g600: #2a4f3d;--g500: #3d7259;--g400: #6aad8c;--g300: #8cc4a8;--g200: #c0dece;--g100: #daeee4;--g50: #f0f7f2;--warm: #f5f7f4;--muted: #5a7060;--border: #d4e6db;--radius-xl: 20px;--radius-lg: 16px;--radius-md: 12px;--radius-sm: 8px;--shadow-sm: 0 1px 4px rgba(13,31,23,.07);--shadow-md: 0 4px 16px rgba(13,31,23,.1);--shadow-lg: 0 8px 32px rgba(13,31,23,.15);--nav-h: 64px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overscroll-behavior:none}body{font-family:var(--font);background:var(--warm);color:var(--g900);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}button{font-family:inherit;cursor:pointer;border:none;background:none}a{text-decoration:none;color:inherit}input,textarea{font-family:inherit}.app-root{display:flex;flex-direction:column;height:100dvh;max-width:480px;margin:0 auto;background:var(--warm);position:relative;overflow:hidden}.screen{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav-h) + var(--safe-bottom) + 16px);padding-top:var(--safe-top)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:calc(var(--nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#fff;border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:100;box-shadow:0 -4px 20px #0d1f1712}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--muted);transition:color .18s;min-height:44px;padding:8px 4px;position:relative}.nav-tab.active{color:var(--g700)}.nav-tab svg{transition:transform .18s}.nav-tab.active svg{transform:translateY(-1px)}.nav-tab-label{font-size:10px;font-weight:600;letter-spacing:.02em;line-height:1}.nav-tab-dot{position:absolute;top:8px;width:5px;height:5px;background:var(--g500);border-radius:50%;opacity:0;transition:opacity .18s}.nav-tab.active .nav-tab-dot{opacity:1}.chat-fab{position:fixed;bottom:calc(var(--nav-h) + var(--safe-bottom) + 16px);right:20px;width:52px;height:52px;border-radius:50%;background:var(--g700);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:99;transition:transform .18s,box-shadow .18s}.chat-fab:active{transform:scale(.92)}.chat-fab-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--g400);opacity:.5;animation:fabPulse 2.4s ease-in-out infinite}@keyframes fabPulse{0%,to{transform:scale(1);opacity:.5}50%{transform:scale(1.1);opacity:0}}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-primary{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--g700);color:#fff;border-radius:var(--radius-md);padding:.85rem 1.5rem;font-size:.95rem;font-weight:700;width:100%;transition:background .15s,transform .1s}.btn-primary:active{background:var(--g600);transform:scale(.98)}.btn-outline{display:flex;align-items:center;justify-content:center;gap:6px;background:transparent;color:var(--g700);border:1.5px solid var(--g700);border-radius:var(--radius-md);padding:.8rem 1.5rem;font-size:.95rem;font-weight:600;width:100%;transition:background .15s}.btn-outline:active{background:var(--g50)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.field input{padding:.85rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:1rem;background:#fff;color:var(--g900);outline:none;transition:border-color .15s}.field input:focus{border-color:var(--g500)}.section-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px;margin-bottom:12px}.section-header h2{font-size:1rem;font-weight:700;color:var(--g800)}.section-header a{font-size:.8rem;font-weight:600;color:var(--g500)}.state-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center;color:var(--muted);font-size:.88rem}.spinner{width:32px;height:32px;border:3px solid var(--g100);border-top-color:var(--g500);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
