.home-header{background:linear-gradient(150deg,#0c2418,#1a4a30 55%,#0c7a5a);padding:calc(var(--safe-top) + 16px) 20px 24px;position:relative;overflow:hidden}.home-header:before{content:"";position:absolute;top:-50px;right:-50px;width:220px;height:220px;border-radius:50%;background:#ffffff0a;pointer-events:none}.home-header:after{content:"";position:absolute;bottom:-70px;right:10px;width:180px;height:180px;border-radius:50%;background:#0dc8961f;pointer-events:none}.home-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;position:relative;z-index:1}.home-brand{display:flex;align-items:center;gap:10px}.home-brand-logo{width:40px;height:40px;border-radius:12px;border:2px solid rgba(255,255,255,.25);object-fit:cover}.home-brand-info strong{display:block;font-size:.9rem;font-weight:800;color:#fff;line-height:1.2}.home-brand-info span{font-size:.67rem;color:#fff9}.home-topbar-right{display:flex;align-items:center;gap:8px}.home-online-badge{display:flex;align-items:center;gap:5px;background:#ffffff1f;border-radius:var(--radius-pill);padding:5px 10px;font-size:.68rem;font-weight:700;color:#ffffffe6}.home-online-dot{width:7px;height:7px;background:#4ade80;border-radius:50%;animation:livePulse 2s ease-in-out infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.3}}.home-bell-btn{position:relative;width:38px;height:38px;background:#ffffff1f;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.home-bell-badge{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#f97316;border-radius:50%;border:1.5px solid #1a4a30}.home-greeting{margin-bottom:20px;position:relative;z-index:1}.home-greeting h1{font-size:1.45rem;font-weight:800;color:#fff;line-height:1.25;margin-bottom:4px}.home-greeting p{font-size:.77rem;color:#fff9}.home-stats-strip{display:flex;background:#ffffff14;border-radius:16px;overflow:hidden;position:relative;z-index:1}.home-stat-item{flex:1;padding:10px 4px;text-align:center;border-right:1px solid rgba(255,255,255,.1)}.home-stat-item:last-child{border-right:none}.home-stat-val{display:block;font-size:.95rem;font-weight:800;color:#fff}.home-stat-lbl{display:block;font-size:.58rem;color:#ffffff8c;margin-top:1px;line-height:1.3}.home-body{padding:20px 16px 24px}.home-section-title{font-size:.88rem;font-weight:800;color:#1a2e23;margin-bottom:14px;letter-spacing:-.01em}.home-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.home-action-card{border-radius:20px;padding:20px 14px 16px;display:flex;flex-direction:column;align-items:flex-start;gap:10px;cursor:pointer;position:relative;box-shadow:0 4px 18px #0000002e;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent;min-height:110px;overflow:hidden}.home-action-card:after{content:"";position:absolute;bottom:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:#ffffff1a;pointer-events:none}.home-action-card:active{transform:scale(.95);box-shadow:0 2px 8px #0000001f}.home-action-icon{width:46px;height:46px;background:#fff3;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.home-action-label{font-size:.78rem;font-weight:800;color:#fff;line-height:1.25}.home-action-badge{position:absolute;top:10px;right:10px;min-width:20px;height:20px;background:#fff;border-radius:10px;font-size:.65rem;font-weight:800;color:#ea580c;display:flex;align-items:center;justify-content:center;padding:0 5px}.home-card{background:#fff;border-radius:20px;padding:18px;margin-bottom:14px;box-shadow:0 2px 12px #0000000f}.home-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.home-card-title{font-size:.9rem;font-weight:800;color:#1a2e23}.news-card-item{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid #f1f5f9}.news-card-item:last-child{border-bottom:none;padding-bottom:0}.news-card-dot{width:8px;height:8px;border-radius:50%;background:var(--g400);flex-shrink:0;margin-top:5px}.news-card-content{flex:1;min-width:0}.news-card-title{font-size:.85rem;font-weight:700;color:#1a2e23;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.news-card-date{font-size:.7rem;color:#94a3b8;margin-top:2px}.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}.qr-result{display:flex;flex-direction:column;align-items:center;gap:16px;padding:4px 0 8px}.qr-ok-banner{width:100%;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md);color:#166534;font-size:.82rem;font-weight:700;padding:10px 14px;display:flex;align-items:center;gap:8px}.qr-code-wrap{background:#fff;border-radius:20px;padding:20px;box-shadow:0 4px 20px #0000001a;display:flex;align-items:center;justify-content:center}.qr-visitor-card{width:100%;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:14px 16px;text-align:center}.qr-visitor-name{font-size:1.05rem;font-weight:800;color:var(--g900);margin-bottom:4px}.qr-visitor-detail{font-size:.8rem;color:var(--muted);margin-bottom:4px}.qr-expiry{display:flex;align-items:center;justify-content:center;gap:5px;font-size:.75rem;color:var(--muted);margin-top:6px}.btn-whatsapp{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:#25d366;color:#fff;border-radius:var(--radius-pill);padding:.85rem 1.5rem;font-size:.95rem;font-weight:700;box-shadow:0 4px 14px #25d36659;transition:background .15s,transform .1s}.btn-whatsapp:active{background:#1ebe5d;transform:scale(.98)}.btn-download{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:#fff;color:var(--g700);border:1.5px solid var(--border);border-radius:var(--radius-pill);padding:.72rem 1.5rem;font-size:.88rem;font-weight:600;transition:background .15s,transform .1s}.btn-download:active{background:var(--g50);transform:scale(.98)}.qr-form-icon{width:44px;height:44px;background:var(--g50);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--g600);flex-shrink:0}.qr-list-item{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border);padding:12px 14px;margin-bottom:8px}.qr-list-left{min-width:0;flex:1}.qr-list-name{font-size:.88rem;font-weight:700;color:var(--g900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.qr-list-detail{font-size:.72rem;color:var(--muted)}.qr-estado{flex-shrink:0;margin-left:10px;padding:4px 10px;border-radius:var(--radius-pill);font-size:.7rem;font-weight:700}.qr-estado-valido{background:#f0fdf4;color:#166534}.qr-estado-usado{background:#f1f5f9;color:#64748b}.qr-estado-expirado{background:#fef2f2;color:#991b1b}.access-toggle{display:flex;gap:8px}.access-btn{flex:1;padding:10px 8px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:#fff;color:var(--muted);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.access-btn.active{border-color:var(--g500);background:var(--g50);color:var(--g700);font-weight:700}.admin-tab{flex-shrink:0;padding:12px 14px;font-size:.8rem;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap;background:none;cursor:pointer}.admin-tab.active{color:var(--g700);border-bottom-color:var(--g600)}.stat-card{background:#fff;border:1px solid var(--border);border-top:3px solid;border-radius:var(--radius-lg);padding:16px 14px;box-shadow:var(--shadow-sm)}.stat-card-wide{grid-column:span 2}.stat-value{font-size:1.6rem;font-weight:800;line-height:1}.stat-label{font-size:.75rem;color:var(--muted);margin-top:4px;font-weight:600}.admin-list-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px;box-shadow:var(--shadow-sm)}.admin-item-main{flex:1;min-width:0}.admin-item-title{font-size:.88rem;font-weight:700;color:var(--g800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-item-sub{font-size:.72rem;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-sm-primary{background:var(--g600);color:#fff;border-radius:var(--radius-sm);padding:6px 12px;font-size:.78rem;font-weight:700;cursor:pointer;border:none}.btn-toggle{flex-shrink:0;padding:5px 10px;border-radius:20px;font-size:.72rem;font-weight:700;cursor:pointer;border:none}.btn-toggle.active{background:#dcfce7;color:#16a34a}.btn-toggle.blocked{background:#fee2e2;color:#dc2626}.btn-approve{flex:1;background:#dcfce7;color:#16a34a;border:none;border-radius:var(--radius-sm);padding:8px;font-size:.8rem;font-weight:700;cursor:pointer}.btn-reject{flex:1;background:#fee2e2;color:#dc2626;border:none;border-radius:var(--radius-sm);padding:8px;font-size:.8rem;font-weight:700;cursor:pointer}.admin-form-card{background:var(--g50);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.admin-form-title{font-weight:800;color:var(--g700);font-size:.9rem}.auth-ok{background:#dcfce7;color:#16a34a;padding:10px 14px;border-radius:var(--radius-md);font-size:.82rem;font-weight:600;text-align:center}.estado-badge{padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700}.emp-mi-card{background:linear-gradient(135deg,var(--g600),var(--g500));color:#fff;border-radius:var(--radius-lg);padding:18px 16px;margin-bottom:16px}.emp-mi-name{font-size:1.1rem;font-weight:800;margin-bottom:4px}.emp-mi-cats{font-size:.78rem;opacity:.8;margin-bottom:8px}.emp-mi-info{font-size:.8rem;opacity:.85;margin-top:2px}.emp-solicitud-card{background:#fff;border:1px solid var(--border);border-left:4px solid;border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.emp-sol-label{font-size:.72rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.emp-sol-nombre{font-size:1rem;font-weight:800;color:var(--g800)}.emp-sol-cats{font-size:.78rem;color:var(--muted);margin-top:2px}.emp-empty-card{background:var(--g50);border:2px dashed var(--border);border-radius:var(--radius-lg);padding:32px 20px;text-align:center;margin-bottom:16px}.cat-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.cat-chip{padding:5px 12px;border:1.5px solid var(--border);border-radius:20px;font-size:.78rem;font-weight:600;color:var(--muted);background:#fff;cursor:pointer}.cat-chip.selected{background:var(--g600);color:#fff;border-color:var(--g600)}.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}}.guard-screen{min-height:100dvh;background:#f1f5f9;display:flex;flex-direction:column;align-items:center;padding:0 0 32px}.guard-status-block{width:100%;padding:40px 24px 32px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.guard-valid{background:linear-gradient(145deg,#14532d,#166534)}.guard-invalid{background:linear-gradient(145deg,#7f1d1d,#991b1b)}.guard-status-emoji{font-size:3.5rem;line-height:1}.guard-status-title{font-size:1.5rem;font-weight:900;color:#fff;letter-spacing:.04em}.guard-status-sub{font-size:.85rem;color:#ffffffbf;max-width:280px;line-height:1.5}.guard-cards{width:100%;max-width:480px;padding:0 16px;display:flex;flex-direction:column;gap:12px;margin-top:-16px}.guard-card{background:#fff;border-radius:20px;padding:18px 20px;box-shadow:0 2px 12px #00000012}.guard-card-label{font-size:.65rem;font-weight:800;color:var(--muted);letter-spacing:.08em;margin-bottom:8px}.guard-visitor-name{font-size:1.35rem;font-weight:800;color:#0f172a;margin-bottom:8px}.guard-detail{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#475569;margin-top:4px}.guard-auth-name{font-size:1.1rem;font-weight:700;color:#0f172a;margin-bottom:8px}.guard-casa-badge{display:inline-flex;align-items:center;gap:5px;background:#f0fdf4;color:#166534;border:1px solid #bbf7d0;border-radius:999px;padding:5px 12px;font-size:.82rem;font-weight:700}.guard-time-card{background:#f8fafc}.guard-time-value{font-size:1.05rem;font-weight:700;color:#0f172a;margin-bottom:4px}.guard-single-use{font-size:.75rem;color:var(--muted)}.guard-acceso-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:700}.guard-acceso-badge.peatonal{background:#eff6ff;color:#1d4ed8}.guard-acceso-badge.vehicular{background:#fefce8;color:#92400e}.guard-placa-badge{display:inline-flex;align-items:center;background:#1e293b;color:#f8fafc;border-radius:6px;padding:4px 10px;font-size:.82rem;font-weight:800;letter-spacing:.08em}.guard-footer{margin-top:28px;font-size:.72rem;color:#94a3b8;text-align:center}:root{--g900: #0d1f17;--g800: #132b1f;--g700: #1a3326;--g600: #2a4f3d;--g500: #3d7259;--g400: #6aad8c;--g300: #8cc4a8;--g200: #c0dece;--g100: #daeee4;--g50: #f0f7f2;--blue: #2563eb;--blue-dark: #1d4ed8;--amber: #d97706;--amber-dark: #b45309;--teal: #0d9488;--teal-dark: #0f766e;--purple: #7c3aed;--purple-dark: #6d28d9;--lime: #16a34a;--lime-dark: #15803d;--orange: #ea580c;--orange-dark: #c2410c;--red: #dc2626;--warm: #f4f6f8;--muted: #64748b;--border: #e2e8f0;--radius-pill: 999px;--radius-xl: 24px;--radius-lg: 18px;--radius-md: 14px;--radius-sm: 10px;--shadow-sm: 0 1px 4px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.14);--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,select{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:3px;color:var(--muted);transition:color .18s;padding:8px 4px;position:relative}.nav-tab.active{color:var(--g700)}.nav-tab-icon{display:flex}.nav-tab-label{font-size:10px;font-weight:700;line-height:1}.nav-tab-bar{position:absolute;top:0;width:28px;height:3px;background:var(--g600);border-radius:0 0 3px 3px}.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-pill);padding:.85rem 1.5rem;font-size:.95rem;font-weight:700;width:100%;transition:background .15s,transform .1s;box-shadow:0 4px 12px #1a33264d}.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-pill);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:.78rem;font-weight:700;color:var(--muted);letter-spacing:.02em}.field input,.field select,.field textarea{padding:.82rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:.95rem;background:#fff;color:var(--g900);outline:none;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--g500);box-shadow:0 0 0 3px #3d72591f}.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)}}
