/* ============================================
   app.css — Super-App Design System
   Tema Madera — Orgánico, Cálido, Premium
   Mobile-First — Amazon/Yummy Style
   ============================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  /* ── Paleta Madera ── */
  --wood-900:#2c1810;--wood-800:#3d2317;--wood-700:#5c3a24;--wood-600:#7a5233;
  --wood-500:#9a6b42;--wood-400:#b8864f;--wood-300:#d4a76a;--wood-200:#e8c89a;
  --wood-100:#f5e6d0;--wood-50:#fdf6ed;
  --cream:#fef9f0;--cream-dark:#f0e4d0;--parchment:#f8f0e3;
  --forest-900:#1a3a1a;--forest-700:#267326;--forest-500:#38a338;--forest-400:#4bb84b;
  --gold:#d4a34a;--gold-light:#f0cc72;--gold-dark:#a67c2e;
  --danger:#c0392b;--warning:#e67e22;--success:#27ae60;
  /* ── Textos ── */
  --text:#2c1810;--text-secondary:#6b5744;--text-muted:#9a8b7a;
  --white:#ffffff;
  /* ── UI ── */
  --bg:var(--cream);--bg-card:var(--white);--bg-elevated:var(--wood-50);--bg-input:var(--white);
  --border:rgba(44,24,16,.1);--border-light:rgba(44,24,16,.06);
  --accent:var(--wood-700);--accent-light:var(--wood-500);
  --radius:16px;--radius-sm:10px;--radius-xs:8px;--radius-pill:60px;
  --shadow-soft:0 2px 15px rgba(44,24,16,.06);--shadow-md:0 8px 30px rgba(44,24,16,.1);--shadow-lg:0 20px 60px rgba(44,24,16,.15);
  --font:'Outfit',system-ui,-apple-system,sans-serif;
  --font-display:'Playfair Display',Georgia,serif;
  --bottom-nav-height:64px;
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
html{height:100%;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100%;overflow-x:hidden;-webkit-tap-highlight-color:transparent;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-bottom) + 8px);line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:var(--font);cursor:pointer;border:none;outline:none}
input,select,textarea{font-family:var(--font);outline:none}

/* ═══ BOTTOM NAVIGATION BAR ═══ */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--safe-bottom));background:rgba(254,249,240,.96);backdrop-filter:blur(24px) saturate(1.5);border-top:1px solid var(--border);display:flex;align-items:flex-start;padding-top:6px;padding-bottom:var(--safe-bottom);z-index:1000;box-shadow:0 -2px 20px rgba(44,24,16,.06)}
.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;background:none;color:var(--text-muted);position:relative;transition:color .25s}
.bottom-nav-item.active{color:var(--wood-700)}
.bottom-nav-item .nav-icon{font-size:1.3rem;line-height:1;position:relative}
.bottom-nav-item .nav-label{font-size:.62rem;font-weight:600;letter-spacing:.3px}
.bottom-nav-item .badge{position:absolute;top:-6px;right:-10px;min-width:18px;height:18px;padding:0 5px;border-radius:10px;background:var(--danger);color:white;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;animation:badgePop .3s ease}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}
.bottom-nav-item.active::after{content:'';position:absolute;top:-1px;left:25%;right:25%;height:3px;border-radius:0 0 4px 4px;background:linear-gradient(90deg,var(--wood-600),var(--gold))}

/* ═══ TAB VIEWS ═══ */
.tab-view{display:none;min-height:calc(100vh - var(--bottom-nav-height))}.tab-view.active{display:block;animation:fadeTab .3s ease}
@keyframes fadeTab{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ═══ HEADER ═══ */
.app-header{position:sticky;top:0;z-index:100;padding:14px 16px;background:var(--wood-800);color:var(--white);border-bottom:3px solid var(--gold)}
.app-header-top{display:flex;align-items:center;justify-content:space-between}
.app-logo{display:flex;align-items:center;gap:10px}
.app-logo img{width:38px;height:38px;border-radius:50%;border:2px solid var(--gold-dark);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.app-logo-text{font-size:1.05rem;font-weight:700;color:var(--white)}
.app-logo-text span{display:block;font-size:.65rem;font-weight:400;color:rgba(255,255,255,.6)}
.header-rate{font-size:.75rem;font-weight:600;padding:5px 14px;border-radius:var(--radius-pill);background:rgba(212,163,74,.15);color:var(--gold-light);border:1px solid rgba(212,163,74,.25)}

/* ═══ SEARCH BAR ═══ */
.search-container{padding:12px 16px;background:var(--parchment)}
.search-bar{position:relative}
.search-bar input{width:100%;padding:13px 16px 13px 44px;border-radius:var(--radius);background:var(--white);border:1.5px solid var(--cream-dark);color:var(--text);font-size:.92rem;transition:border-color .2s;box-shadow:var(--shadow-soft)}
.search-bar input:focus{border-color:var(--wood-400);box-shadow:0 0 0 3px rgba(184,134,79,.15)}
.search-bar input::placeholder{color:var(--text-muted)}
.search-bar .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:1.1rem;pointer-events:none}

/* ═══ CATEGORIES SCROLL ═══ */
.categories-scroll{display:flex;gap:8px;padding:6px 16px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--parchment)}
.categories-scroll::-webkit-scrollbar{display:none}
.cat-chip{flex-shrink:0;padding:8px 18px;border-radius:var(--radius-pill);font-size:.8rem;font-weight:600;background:var(--white);border:1.5px solid var(--cream-dark);color:var(--text-secondary);transition:all .25s;white-space:nowrap;box-shadow:var(--shadow-soft)}
.cat-chip.active,.cat-chip:active{background:var(--wood-700);border-color:var(--wood-700);color:var(--white);box-shadow:0 4px 12px rgba(92,58,36,.25)}

/* ═══ SECTION HEADERS ═══ */
.section-header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px 10px}
.section-header h2{font-size:1.1rem;font-weight:800;color:var(--wood-900);font-family:var(--font)}
.section-header .see-all{font-size:.78rem;font-weight:600;color:var(--wood-500)}

/* ═══ PRODUCT GRID ═══ */
.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:0 16px 24px}
.product-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);overflow:hidden;transition:all .25s;position:relative;box-shadow:var(--shadow-soft)}
.product-card:active{transform:scale(.97);box-shadow:var(--shadow-md)}
.product-card-img{width:100%;height:100px;background:linear-gradient(135deg,var(--wood-50),var(--cream-dark));display:flex;align-items:center;justify-content:center;font-size:2.2rem}
.product-card-body{padding:10px 12px 44px}
.product-card-name{font-size:.82rem;font-weight:600;line-height:1.4;margin-bottom:4px;color:var(--wood-900);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-card-brand{font-size:.68rem;color:var(--text-muted);margin-bottom:6px}
.product-card-price{font-size:1.05rem;font-weight:800;color:var(--wood-700)}
.product-card-price-bs{font-size:.7rem;color:var(--text-muted)}
.product-card-weight{font-size:.65rem;color:var(--forest-700);font-weight:600}
.product-card-add{position:absolute;bottom:8px;right:8px;width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--wood-600),var(--wood-700));color:white;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 12px rgba(92,58,36,.3);transition:transform .2s}
.product-card-add:active{transform:scale(.88)}
.product-card-qty{position:absolute;bottom:6px;right:6px;display:flex;align-items:center;gap:0;border-radius:20px;overflow:hidden;background:var(--wood-50);border:1.5px solid var(--wood-300);z-index:2}
.product-card-qty button{width:28px;height:28px;background:var(--wood-600);color:white;font-size:.9rem;font-weight:700;border:none;display:flex;align-items:center;justify-content:center}
.product-card-qty span{min-width:24px;text-align:center;font-size:.8rem;font-weight:700;color:var(--wood-800)}
.product-stock-out{opacity:.45;pointer-events:none}
.product-stock-out .product-card-add{display:none}
.product-stock-badge{position:absolute;top:8px;left:8px;padding:2px 8px;border-radius:6px;font-size:.6rem;font-weight:700;text-transform:uppercase}
.badge-low{background:rgba(230,126,34,.12);color:var(--warning)}
.badge-out{background:rgba(192,57,43,.1);color:var(--danger)}
.badge-weight{background:rgba(38,115,38,.1);color:var(--forest-700)}

/* ═══ GRAM MODAL ═══ */
.gram-modal-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(44,24,16,.5);backdrop-filter:blur(6px);align-items:flex-end;justify-content:center;padding:0}
.gram-modal-overlay.active{display:flex}
.gram-modal{background:var(--white);border-radius:var(--radius) var(--radius) 0 0;padding:24px;width:100%;max-width:480px;animation:slideModal .3s ease;border-top:3px solid var(--gold)}
@keyframes slideModal{from{transform:translateY(100%)}to{transform:none}}
.gram-modal h3{font-size:1.1rem;font-weight:700;color:var(--wood-800);margin-bottom:4px}
.gram-modal-product{font-size:.88rem;color:var(--text-secondary);margin-bottom:4px}
.gram-modal-price{font-size:.82rem;color:var(--wood-500);margin-bottom:16px}
.gram-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.gram-option{padding:14px 8px;border-radius:var(--radius-sm);background:var(--wood-50);border:2px solid var(--cream-dark);text-align:center;font-weight:700;font-size:.9rem;color:var(--wood-700);transition:all .2s;cursor:pointer}
.gram-option.active{border-color:var(--wood-600);background:var(--wood-100);box-shadow:0 0 0 2px rgba(92,58,36,.15)}
.gram-option:active{transform:scale(.95)}
.gram-option small{display:block;font-size:.7rem;font-weight:500;color:var(--text-muted);margin-top:2px}
.gram-custom{display:flex;gap:8px;margin-bottom:16px;align-items:center}
.gram-custom input{flex:1;padding:12px 14px;border-radius:var(--radius-sm);background:var(--white);border:1.5px solid var(--cream-dark);font-size:1rem;color:var(--text);text-align:center}
.gram-custom input:focus{border-color:var(--wood-400)}
.gram-custom span{font-size:.9rem;color:var(--text-secondary);font-weight:600}
.gram-total{text-align:center;padding:12px;background:var(--wood-50);border-radius:var(--radius-sm);margin-bottom:16px;font-size:1rem;font-weight:700;color:var(--wood-800)}
.gram-actions{display:flex;gap:10px}
.gram-actions button{flex:1;padding:14px;border-radius:var(--radius-sm);font-weight:700;font-size:.95rem;font-family:var(--font);transition:transform .2s}
.gram-actions button:active{transform:scale(.96)}
.btn-gram-cancel{background:var(--wood-50);color:var(--text-secondary);border:1px solid var(--cream-dark)}
.btn-gram-add{background:linear-gradient(135deg,var(--wood-600),var(--wood-700));color:var(--white);box-shadow:0 4px 16px rgba(92,58,36,.25)}

/* ═══ CART ═══ */
.cart-items{padding:0 16px}
.cart-item{display:flex;align-items:center;gap:12px;padding:14px;background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);margin-bottom:8px;box-shadow:var(--shadow-soft)}
.cart-item-info{flex:1}
.cart-item-name{font-size:.88rem;font-weight:600;color:var(--wood-900)}
.cart-item-detail{font-size:.75rem;color:var(--text-muted);margin-top:2px}
.cart-item-price{font-size:.95rem;font-weight:800;color:var(--wood-700)}
.cart-item-qty{display:flex;align-items:center;gap:0;border-radius:20px;overflow:hidden;background:var(--wood-50);border:1.5px solid var(--cream-dark)}
.cart-item-qty button{width:32px;height:32px;background:var(--wood-50);color:var(--wood-700);font-size:1.1rem;font-weight:700;border:none;transition:background .2s}
.cart-item-qty button:active{background:var(--wood-200)}
.cart-item-qty span{min-width:28px;text-align:center;font-size:.9rem;font-weight:700;color:var(--wood-800)}
.cart-item-remove{width:28px;height:28px;border-radius:50%;background:rgba(192,57,43,.08);color:var(--danger);font-size:.9rem;display:flex;align-items:center;justify-content:center;border:none}
.cart-summary{margin:16px;padding:20px;background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);box-shadow:var(--shadow-soft)}
.cart-summary-row{display:flex;justify-content:space-between;padding:6px 0;font-size:.88rem;color:var(--text-secondary)}
.cart-summary-total{font-size:1.1rem;font-weight:800;color:var(--wood-900);border-top:2px solid var(--cream-dark);padding-top:10px;margin-top:8px}
.cart-summary-total span:last-child{color:var(--wood-700)}

/* ═══ CHECKOUT FORM ═══ */
.checkout-form{padding:0 16px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border-radius:var(--radius-sm);background:var(--white);border:1.5px solid var(--cream-dark);color:var(--text);font-size:.9rem;transition:border-color .2s}
.form-group input:focus,.form-group select:focus{border-color:var(--wood-400);box-shadow:0 0 0 3px rgba(184,134,79,.12)}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235c3a24' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.btn-checkout{width:100%;padding:16px;border-radius:var(--radius);background:linear-gradient(135deg,var(--wood-600),var(--wood-800));color:var(--white);font-size:1rem;font-weight:700;margin:16px 0;transition:transform .2s;box-shadow:0 6px 24px rgba(44,24,16,.2)}
.btn-checkout:active{transform:scale(.97)}
.btn-checkout:disabled{opacity:.5;pointer-events:none}
.cart-empty{text-align:center;padding:60px 24px;color:var(--text-muted)}
.cart-empty span{font-size:4rem;display:block;margin-bottom:16px}

/* ═══ ORDERS LIST ═══ */
.order-item{margin:0 16px 10px;padding:16px;background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);transition:all .3s;box-shadow:var(--shadow-soft)}
.order-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.order-item-id{font-size:.82rem;font-weight:700;color:var(--wood-700)}
.order-item-status{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:20px}
.status-pending{background:rgba(230,126,34,.1);color:var(--warning)}
.status-in_progress{background:rgba(155,89,182,.1);color:#8e44ad}
.status-completed,.status-in_delivery{background:rgba(39,174,96,.1);color:var(--success)}
.status-in_transit{background:rgba(38,115,38,.12);color:var(--forest-700)}
.status-delivered{background:rgba(39,174,96,.15);color:var(--success)}
.order-item-info{font-size:.82rem;color:var(--text-secondary);line-height:1.7}
.order-item-total{font-size:.95rem;font-weight:800;color:var(--wood-700);margin-top:8px}
.order-item-actions{display:flex;gap:8px;margin-top:12px}
.btn-track{flex:1;padding:10px;border-radius:var(--radius-sm);background:rgba(38,115,38,.08);color:var(--forest-700);font-size:.82rem;font-weight:700;text-align:center;border:1px solid rgba(38,115,38,.15)}
.btn-track:active{opacity:.7}
.btn-rate{flex:1;padding:10px;border-radius:var(--radius-sm);background:rgba(212,163,74,.1);color:var(--gold-dark);font-size:.82rem;font-weight:700;text-align:center;border:1px solid rgba(212,163,74,.2)}
.btn-rate:active{opacity:.7}
.btn-confirm-delivery{flex:1;padding:12px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;font-size:.9rem;font-weight:700;text-align:center;border:none;box-shadow:0 2px 8px rgba(39,174,96,.3);animation:pulse-green 2s infinite}
.btn-confirm-delivery:active{opacity:.7;transform:scale(.97)}
@keyframes pulse-green{0%,100%{box-shadow:0 2px 8px rgba(39,174,96,.3)}50%{box-shadow:0 2px 16px rgba(39,174,96,.6)}}

/* ═══ TRACKING MAP ═══ */
.tracking-view{margin:16px;padding:20px;background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);position:relative;overflow:hidden;box-shadow:var(--shadow-md)}
.tracking-view::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--wood-600),var(--gold),var(--forest-500))}
.tracking-map{width:100%;height:250px;border-radius:var(--radius-sm);overflow:hidden;margin:12px 0;background:var(--wood-50)}
.tracking-info{display:flex;flex-direction:column;gap:8px}
.tracking-rider{display:flex;align-items:center;gap:10px;padding:10px;background:var(--wood-50);border-radius:var(--radius-sm)}
.tracking-rider-name{font-weight:700;font-size:.92rem;color:var(--wood-800)}
.tracking-rider-rating{font-size:.8rem;color:var(--gold-dark)}
.tracking-timeline{display:flex;flex-direction:column;gap:0;margin-top:12px}
.timeline-step{display:flex;align-items:center;gap:12px;padding:8px 0;position:relative}
.timeline-step::before{content:'';position:absolute;left:10px;top:28px;bottom:-8px;width:2px;background:var(--cream-dark)}
.timeline-step:last-child::before{display:none}
.timeline-dot{width:22px;height:22px;border-radius:50%;background:var(--cream-dark);border:2px solid var(--cream-dark);display:flex;align-items:center;justify-content:center;font-size:.7rem;position:relative;z-index:1;flex-shrink:0}
.timeline-dot.done{background:var(--forest-500);border-color:var(--forest-500);color:white}
.timeline-dot.active{background:var(--wood-600);border-color:var(--wood-600);color:white;animation:pulseTimeline 2s infinite}
@keyframes pulseTimeline{0%,100%{box-shadow:0 0 0 0 rgba(92,58,36,.4)}50%{box-shadow:0 0 0 8px rgba(92,58,36,0)}}
.timeline-text{font-size:.82rem;color:var(--text-secondary)}.timeline-text strong{color:var(--text)}
.timeline-time{font-size:.7rem;color:var(--text-muted)}

/* ═══ RATING MODAL ═══ */
.modal-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(44,24,16,.5);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:24px}
.modal-overlay.active{display:flex}
.modal{background:var(--white);border-radius:var(--radius);padding:28px;max-width:380px;width:100%;border:1px solid var(--cream-dark);animation:modalIn .3s ease;box-shadow:var(--shadow-lg)}
@keyframes modalIn{from{opacity:0;transform:scale(.9) translateY(16px)}to{opacity:1;transform:none}}
.modal h3{font-size:1.2rem;font-weight:700;text-align:center;margin-bottom:16px;color:var(--wood-800)}
.stars-selector{display:flex;justify-content:center;gap:8px;margin-bottom:16px}
.star-btn{font-size:2.2rem;background:none;border:none;cursor:pointer;opacity:.3;transition:all .2s;filter:grayscale(1)}
.star-btn.active{opacity:1;filter:none;transform:scale(1.15)}
.modal textarea{width:100%;padding:12px;border-radius:var(--radius-sm);background:var(--white);border:1.5px solid var(--cream-dark);color:var(--text);font-size:.88rem;resize:none;height:80px;margin-bottom:16px}
.modal-actions{display:flex;gap:10px}
.modal-actions button{flex:1;padding:12px;border-radius:var(--radius-sm);font-weight:700;font-size:.9rem}
.btn-modal-cancel{background:var(--wood-50);color:var(--text-secondary);border:1px solid var(--cream-dark)}
.btn-modal-submit{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--white)}

/* ═══ PROFILE ═══ */
.profile-header{padding:32px 16px;text-align:center;background:linear-gradient(135deg,var(--wood-800),var(--wood-700));margin:0 16px;border-radius:var(--radius);border:1px solid var(--wood-600);margin-top:16px;color:var(--white)}
.profile-avatar{font-size:3.5rem;margin-bottom:12px}
.profile-name{font-size:1.3rem;font-weight:800;margin-bottom:4px}
.profile-phone{font-size:.85rem;color:rgba(255,255,255,.6)}
.profile-stats{display:flex;gap:1px;background:var(--cream-dark);margin:16px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft)}
.profile-stat{flex:1;padding:16px;text-align:center;background:var(--white)}
.profile-stat-value{display:block;font-size:1.4rem;font-weight:800;color:var(--wood-700)}
.profile-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.profile-section{margin:16px;padding:18px;background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);box-shadow:var(--shadow-soft)}
.profile-section h3{font-size:.9rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px;color:var(--wood-800)}
.profile-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--cream-dark);font-size:.85rem}
.profile-row:last-child{border-bottom:none}
.profile-row-label{color:var(--text-secondary)}

/* ═══ SKELETON LOADERS ═══ */
.skeleton{background:linear-gradient(90deg,var(--cream-dark) 25%,var(--wood-50) 50%,var(--cream-dark) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.skeleton-card{height:180px;border-radius:var(--radius)}

/* ═══ TOAST ═══ */
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);padding:14px 24px;border-radius:var(--radius-sm);background:var(--wood-800);color:var(--white);font-size:.88rem;font-weight:600;z-index:9999;transition:transform .4s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg);max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ═══ RESPONSIVE ═══ */
@media(min-width:480px){
  .products-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:768px){
  .products-grid{grid-template-columns:repeat(4,1fr);max-width:800px;margin:0 auto}
  .tab-view{max-width:600px;margin:0 auto}
  .bottom-nav{max-width:600px;left:50%;transform:translateX(-50%);border-radius:var(--radius) var(--radius) 0 0;border-left:1px solid var(--border);border-right:1px solid var(--border)}
}

.fade-in{animation:fadeIn .4s ease}.slide-up{animation:slideUp .4s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ═══ ORDER PROGRESS BAR ═══ */
.order-progress-bar{width:100%;height:4px;background:var(--cream-dark);border-radius:4px;margin:8px 0 4px;overflow:hidden}
.order-progress-fill{height:100%;border-radius:4px;transition:width .6s ease,background .3s}
.order-progress-labels{display:flex;justify-content:space-between;margin-bottom:10px}
.order-progress-labels span{font-size:.58rem;color:var(--text-muted);font-weight:500;text-align:center;flex:1}
.order-progress-labels span.active{color:var(--wood-700);font-weight:700}

/* ═══ SWIPE TO DELETE ═══ */
.cart-item.swipeable{position:relative;overflow:hidden;padding:0;border:none;box-shadow:none;background:transparent;margin-bottom:8px;border-radius:var(--radius)}
.cart-item-swipe-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#c0392b,#e74c3c);color:white;display:flex;align-items:center;justify-content:flex-end;padding-right:24px;font-weight:700;font-size:.82rem;border-radius:var(--radius)}
.cart-item-content{position:relative;z-index:1;display:flex;align-items:center;gap:10px;padding:14px;background:var(--white);border-radius:var(--radius);border:1px solid var(--cream-dark);box-shadow:var(--shadow-soft);width:100%;min-width:100%}

/* ═══ IMPROVED SKELETON ═══ */
.skeleton-card{border-radius:var(--radius);overflow:hidden;background:var(--white);border:1px solid var(--cream-dark)}

/* ═══════════════════════════════════════════════
   PAYMENT VIEW — MercadoLibre Style
   ═══════════════════════════════════════════════ */
.payment-overlay{position:fixed;inset:0;z-index:3000;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fadeIn .3s ease}
.payment-container{max-width:480px;margin:0 auto;padding:16px 16px 60px;position:relative}
.payment-close{position:absolute;top:12px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--wood-50);color:var(--text-secondary);font-size:1.1rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--cream-dark);z-index:10;transition:all .2s}
.payment-close:active{background:var(--wood-100)}

/* Step indicator */
.payment-steps{display:flex;align-items:center;justify-content:center;gap:0;padding:20px 8px 24px}
.payment-step{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}
.payment-step span{width:32px;height:32px;border-radius:50%;background:var(--cream-dark);color:var(--text-muted);font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .3s;border:2px solid var(--cream-dark)}
.payment-step small{font-size:.62rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}
.payment-step.active span{background:var(--wood-700);color:var(--white);border-color:var(--wood-700);box-shadow:0 3px 12px rgba(92,58,36,.3)}
.payment-step.active small{color:var(--wood-700)}
.payment-step.done span{background:var(--forest-500);color:var(--white);border-color:var(--forest-500)}
.payment-step.done small{color:var(--forest-500)}
.payment-step-line{flex:1;height:2px;background:var(--cream-dark);min-width:24px;max-width:48px;transition:background .3s}
.payment-step-line.done{background:var(--forest-500)}

/* Payment pages */
.payment-page{display:none;animation:fadeTab .4s ease}
.payment-page.active{display:block}
.payment-page h2{font-size:1.4rem;font-weight:800;text-align:center;color:var(--wood-900);margin-bottom:4px}
.payment-subtitle{text-align:center;font-size:.85rem;color:var(--text-secondary);margin-bottom:20px}
.payment-header-icon{text-align:center;font-size:3rem;margin-bottom:12px}

/* Info card */
.payment-info-card{background:var(--wood-50);border:1.5px solid var(--cream-dark);border-radius:var(--radius);padding:20px;text-align:center;margin-bottom:16px}
.payment-info-card h3{font-size:1rem;font-weight:700;color:var(--wood-800);margin-bottom:8px}
.payment-info-card p{font-size:.85rem;color:var(--text-secondary);line-height:1.6}
.payment-info-icon{font-size:2.2rem;margin-bottom:8px}
.payment-info-detail{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--white);border-radius:var(--radius-sm);margin:12px 0 8px;border:1px solid var(--cream-dark)}
.payment-info-detail span{font-size:.85rem;color:var(--text-secondary)}
.payment-info-detail strong{font-size:1.1rem;font-weight:800;color:var(--wood-700)}
.payment-note{font-size:.75rem;color:var(--text-muted);font-style:italic;margin-top:4px}

/* Wait animation */
.payment-wait-animation{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;margin-top:8px}
.payment-wait-animation span{font-size:.82rem;color:var(--text-muted);font-weight:500}
.dot-pulse{display:flex;gap:6px}
.dot-pulse div{width:10px;height:10px;border-radius:50%;background:var(--wood-400);animation:dotBounce 1.4s ease-in-out infinite}
.dot-pulse div:nth-child(2){animation-delay:.2s}
.dot-pulse div:nth-child(3){animation-delay:.4s}
@keyframes dotBounce{0%,80%,100%{transform:scale(.4);opacity:.3}40%{transform:scale(1);opacity:1}}

/* Spinner */
.payment-spinner{width:56px;height:56px;border:4px solid var(--cream-dark);border-top-color:var(--wood-600);border-radius:50%;margin:0 auto;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Amount card */
.payment-amount-card{background:linear-gradient(135deg,var(--wood-800),var(--wood-700));border-radius:var(--radius);padding:24px;text-align:center;color:var(--white);margin-bottom:20px;box-shadow:0 8px 32px rgba(44,24,16,.2)}
.payment-amount-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.6);margin-bottom:8px}
.payment-amount-usd{font-size:2.2rem;font-weight:900;margin-bottom:4px}
.payment-amount-bs{font-size:1rem;font-weight:600;color:var(--gold-light)}

/* Payment methods */
.payment-section-title{font-size:.9rem;font-weight:700;color:var(--wood-800);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.payment-methods{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.payment-method-btn{flex:1;min-width:90px;padding:14px 12px;border-radius:var(--radius-sm);background:var(--white);border:2px solid var(--cream-dark);color:var(--text-secondary);font-size:.8rem;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .2s;cursor:pointer}
.payment-method-btn span{font-size:1.5rem}
.payment-method-btn.active{border-color:var(--wood-600);background:var(--wood-50);color:var(--wood-800);box-shadow:0 0 0 2px rgba(92,58,36,.12)}
.payment-method-btn:active{transform:scale(.96)}

/* Bank details card */
.bank-details-card{background:var(--white);border:1.5px solid var(--cream-dark);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-soft)}
.bank-details-card h3{font-size:.92rem;font-weight:700;color:var(--wood-800);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--cream-dark)}
.bank-detail-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid rgba(44,24,16,.04)}
.bank-detail-row:last-child{border-bottom:none}
.bank-detail-label{font-size:.72rem;font-weight:600;color:var(--text-muted);min-width:60px;text-transform:uppercase;letter-spacing:.3px}
.bank-detail-value{flex:1;font-size:.88rem;font-weight:600;color:var(--wood-800);word-break:break-all}
.btn-copy{width:32px;height:32px;border-radius:8px;background:var(--wood-50);color:var(--wood-600);font-size:.85rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--cream-dark);transition:all .2s;flex-shrink:0}
.btn-copy:active{background:var(--wood-200);transform:scale(.9)}
.btn-copy.copied{background:var(--forest-500);color:white;border-color:var(--forest-500)}

/* Cash card */
.cash-details-card{background:var(--wood-50);border:1.5px solid var(--cream-dark);border-radius:var(--radius);padding:24px;text-align:center}
.cash-details-card h3{font-size:1rem;font-weight:700;color:var(--wood-800);margin-bottom:8px}
.cash-details-card p{font-size:.85rem;color:var(--text-secondary);line-height:1.6}

/* Payment form */
.payment-form{background:var(--white);border:1.5px solid var(--cream-dark);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-soft)}
.btn-payment-back{display:block;width:100%;padding:12px;margin-top:10px;background:none;border:none;color:var(--text-secondary);font-size:.85rem;font-weight:600;text-align:center;cursor:pointer;font-family:var(--font)}
.btn-payment-back:active{color:var(--wood-700)}

