@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Space+Mono&display=swap');

:root{
  --bg:#F6F1EB;
  --bg2:#FBF8F4;
  --surface:#FFFFFF;
  --surface2:#F0EAE2;
  --text:#1C1815;
  --text2:#827A72;
  --text3:#A8A099;
  --accent:#E15A26;
  --accent2:#C2440F;
  --accent-light:#FDEEE7;
  --accent-glow:rgba(225,90,38,.25);
  --green:#1F9D55;
  --green-light:#E7F6EC;
  --border:#E8E1D8;
  --border2:#D9D0C5;
  --shadow-sm:0 1px 2px rgba(28,24,21,.04),0 1px 3px rgba(28,24,21,.06);
  --shadow:0 2px 4px rgba(28,24,21,.04),0 4px 12px rgba(28,24,21,.08);
  --shadow-lg:0 8px 16px rgba(28,24,21,.08),0 16px 40px rgba(28,24,21,.12);
  --shadow-accent:0 4px 14px var(--accent-glow);
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:20px;
  --font:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:"Space Mono",monospace;
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
button{font-family:inherit}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.app{min-height:100vh}
.container{max-width:1320px;margin:0 auto;padding:28px 24px 60px}

/* ===== HEADER ===== */
.header{
  background:rgba(28,24,21,.92);
  -webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  color:#fff;padding:0 28px;height:72px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-brand{display:flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .2s}
.header-brand:hover{opacity:.85}
.header-brand img{height:44px;border-radius:8px}
.header-brand h1{font-size:18px;font-weight:800;letter-spacing:-.02em;white-space:nowrap}
.header-brand span{
  font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  padding:4px 9px;border-radius:6px;color:#fff;
}
.header-actions{display:flex;align-items:center;gap:10px}
.header-nav{display:flex;gap:4px}

/* Buttons in header */
.btn-cart{
  position:relative;background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;border:none;padding:10px 18px;border-radius:12px;cursor:pointer;
  display:flex;align-items:center;gap:7px;font-size:14px;font-weight:700;
  transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-accent);
}
.btn-cart:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}
.btn-cart:active{transform:translateY(0) scale(.97)}
.cart-badge{
  position:absolute;top:-7px;right:-7px;background:#fff;color:var(--accent2);
  font-size:11px;font-weight:800;min-width:20px;height:20px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;padding:0 5px;
  box-shadow:0 2px 6px rgba(0,0,0,.2);
}
.btn-admin-link,.gate-admin-link{
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);border:none;
  padding:9px 14px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;
  transition:all .2s;
}
.btn-admin-link:hover{background:rgba(255,255,255,.15);color:#fff}

/* ===== MINIMUM ORDER BANNER ===== */
.min-order-banner{
  background:linear-gradient(120deg,var(--accent-light),rgba(253,238,231,.3));
  border:1px solid var(--accent-light);border-left:4px solid var(--accent);
  padding:13px 20px;margin-bottom:22px;border-radius:12px;
  font-size:14px;color:var(--accent2);font-weight:700;
  display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;
}

/* ===== SEARCH ===== */
.search-wrap{position:relative;margin-bottom:18px}
.search-wrap input,.input{
  width:100%;background:var(--surface);border:1.5px solid var(--border);
  border-radius:12px;padding:13px 16px;font-size:15px;font-family:inherit;
  color:var(--text);transition:all .2s;
}
.search-wrap input:focus,.input:focus,.select:focus,.textarea:focus,.gate-input:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light);
}
.search-wrap input::placeholder{color:var(--text3)}

/* ===== CATEGORY PILLS ===== */
.cat-pills{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:26px}
.cat-pill{
  background:var(--surface);border:1.5px solid var(--border);color:var(--text2);
  padding:9px 17px;border-radius:24px;font-size:13.5px;font-weight:600;cursor:pointer;
  transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;
}
.cat-pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.cat-pill:active{transform:scale(.96)}
.cat-pill.active{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  border-color:transparent;color:#fff;box-shadow:var(--shadow-accent);
}

/* ===== PRODUCT GRID ===== */
.product-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:20px;padding-bottom:40px;
}

/* ===== PRODUCT CARD ===== */
.product-card{
  background:var(--surface);border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow-sm);
  transition:all .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;position:relative;
}
.product-card:hover{
  transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border2);
}
.product-img{
  aspect-ratio:1/1;height:auto;background:var(--surface2);
  display:flex;align-items:center;justify-content:center;color:var(--border2);
  overflow:hidden;cursor:pointer;position:relative;
}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.product-card:hover .product-img img{transform:scale(1.06)}
.product-info{padding:15px 15px 16px;flex:1;display:flex;flex-direction:column}
.product-cat{
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);margin-bottom:6px;
}
.product-name{
  font-size:14.5px;font-weight:600;margin-bottom:10px;line-height:1.35;cursor:pointer;
  color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;min-height:2.7em;
}
.product-name:hover{color:var(--accent)}
.product-price{font-size:21px;font-weight:800;color:var(--text);margin-bottom:2px;letter-spacing:-.02em}
.product-iva{font-size:11px;color:var(--text3);font-weight:600;margin-bottom:12px}
.product-min{font-size:12px;color:var(--text2);margin-bottom:10px}
.product-qty-row{display:flex;gap:9px;align-items:center;margin-top:auto}

/* Qty controls */
.qty-control{display:flex;align-items:center;background:var(--surface2);border-radius:10px;overflow:hidden}
.product-qty-row{display:flex;gap:7px;align-items:center;margin-top:auto;flex-wrap:wrap}
.qty-btn{
  width:38px;height:40px;border:1.5px solid var(--border);background:var(--surface);color:var(--text);
  font-size:18px;font-weight:600;cursor:pointer;transition:all .15s;border-radius:10px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
}
.qty-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}
.qty-btn:active{transform:scale(.9)}
.qty-input,.qty-val{
  flex:1 1 auto;min-width:0;height:40px;text-align:center;border:1.5px solid var(--border);background:var(--surface);border-radius:10px;
  font-size:14px;font-weight:700;font-family:inherit;color:var(--text);
}
.product-add-btn{
  flex:1 0 100%;width:100%;padding:11px;background:var(--text);color:#fff;border:none;border-radius:11px;
  font-family:inherit;font-size:13.5px;font-weight:700;cursor:pointer;
  transition:all .2s cubic-bezier(.4,0,.2,1);
}
.product-add-btn:hover{background:var(--accent);box-shadow:var(--shadow-accent);transform:translateY(-1px)}
.product-add-btn:active{transform:scale(.97)}

/* ===== BADGES ===== */
.featured-badge,.preventa-badge{
  position:absolute;top:10px;left:10px;z-index:2;
  font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  padding:5px 10px;border-radius:8px;color:#fff;
  display:flex;align-items:center;gap:4px;backdrop-filter:blur(4px);
}
.featured-badge{background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:var(--shadow-accent)}
.preventa-badge{background:rgba(28,24,21,.85)}

/* ===== BUTTONS ===== */
.btn{
  padding:12px 22px;border-radius:12px;font-family:inherit;font-size:14.5px;
  font-weight:700;cursor:pointer;border:none;transition:all .2s cubic-bezier(.4,0,.2,1);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;letter-spacing:-.01em;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:var(--shadow-accent)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}
.btn-success{background:linear-gradient(135deg,var(--green),#178a47);color:#fff;box-shadow:0 4px 14px rgba(31,157,85,.25)}
.btn-success:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(31,157,85,.35)}
.btn-secondary{background:var(--surface);color:var(--text);border:1.5px solid var(--border)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{background:transparent;color:var(--text2);padding:10px 16px}
.btn-ghost:hover{background:var(--surface2);color:var(--text)}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}

/* ===== CART ===== */
.cart-item{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:15px;display:flex;gap:14px;align-items:center;margin-bottom:12px;
  transition:all .2s;box-shadow:var(--shadow-sm);
}
.cart-item:hover{box-shadow:var(--shadow);border-color:var(--border2)}
.cart-item-img{width:68px;height:68px;border-radius:11px;object-fit:cover;background:var(--surface2);flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:14.5px;font-weight:600;margin-bottom:4px;line-height:1.3}
.cart-item-price{font-size:13px;color:var(--text2)}
.cart-item-total{font-weight:800;font-size:16px;letter-spacing:-.01em}
.cart-item-remove{
  background:transparent;border:none;color:var(--text3);cursor:pointer;padding:8px;
  border-radius:9px;transition:all .2s;display:flex;align-items:center;
}
.cart-item-remove:hover{background:#FDEDEA;color:#D63A2E}
.cart-summary{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;margin-top:18px;box-shadow:var(--shadow);
}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;font-size:14.5px;color:var(--text2)}
.cart-total-row.final{
  border-top:2px solid var(--border);margin-top:8px;padding-top:16px;
  font-size:20px;font-weight:800;color:var(--text);
}

/* ===== CHECKOUT ===== */
.checkout-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.checkout-form h3,.checkout-form h4{margin-bottom:18px;font-size:17px;font-weight:800;letter-spacing:-.02em}
.checkout-form h4{font-size:15px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-full{grid-column:1/-1}
.input-group{display:flex;flex-direction:column;gap:7px}
.input-group label{font-size:13px;font-weight:600;color:var(--text2)}
.select{
  width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;
  padding:13px 16px;font-size:15px;font-family:inherit;color:var(--text);cursor:pointer;transition:all .2s;
}
.textarea{
  width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;
  padding:13px 16px;font-size:15px;font-family:inherit;color:var(--text);transition:all .2s;resize:vertical;
}
.radio-group{display:flex;gap:12px;flex-wrap:wrap}
.radio-opt{
  flex:1;min-width:140px;display:flex;align-items:center;gap:10px;padding:14px 16px;
  border:1.5px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;background:var(--surface);
}
.radio-opt:hover{border-color:var(--border2)}
.radio-opt.selected{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 3px var(--accent-light)}
.radio-opt input{accent-color:var(--accent);width:18px;height:18px}

/* ===== GATE / LOGIN ===== */
.gate-wrap{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(150deg,#1A1714 0%,#2A2420 50%,#3D332A 100%);
  position:relative;overflow:hidden;padding:20px;
}
.gate-wrap::before{
  content:"";position:absolute;top:-30%;right:-20%;width:600px;height:600px;
  background:radial-gradient(circle,var(--accent-glow),transparent 70%);opacity:.4;
}
.gate-box{
  background:rgba(255,255,255,.04);-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);
  border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:52px 44px;width:440px;max-width:92vw;
  text-align:center;position:relative;z-index:1;box-shadow:0 24px 80px rgba(0,0,0,.5);
}
.gate-box h1{color:#fff;font-size:26px;font-weight:800;letter-spacing:-.03em;margin-bottom:12px}
.gate-subtitle,.gate-box p{color:rgba(255,255,255,.6);font-size:15px;line-height:1.6;margin-bottom:24px}
.gate-lock-icon{
  width:64px;height:64px;border-radius:18px;margin:0 auto 24px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-accent);
}
.gate-input{
  width:100%;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);
  border-radius:12px;padding:14px 16px;font-size:15px;color:#fff;font-family:inherit;margin-bottom:14px;
}
.gate-input::placeholder{color:rgba(255,255,255,.4)}
.gate-input:focus{outline:none;border-color:var(--accent);background:rgba(255,255,255,.1)}
.gate-btn{
  width:100%;padding:14px;background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;
  transition:all .2s;box-shadow:var(--shadow-accent);
}
.gate-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px var(--accent-glow)}
.gate-error-msg,.error{color:#FF8A6B;font-size:13px;margin-top:10px}
.gate-admin-link{margin-top:20px;color:rgba(255,255,255,.4);font-size:13px;background:transparent}

/* Gate showcase carousel */
.gate-showcase{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:440px;margin-top:28px;position:relative;z-index:1}
.gate-showcase-item{aspect-ratio:1;border-radius:12px;overflow:hidden;opacity:.85;transition:opacity .3s}
.gate-showcase-item img{width:100%;height:100%;object-fit:cover}
.gate-carousel-section{width:100%;max-width:900px;margin-top:32px;overflow:hidden;position:relative;z-index:1}
.gate-carousel-track{display:flex;gap:14px;animation:scroll 40s linear infinite}
.gate-carousel-card{flex-shrink:0;width:140px;border-radius:14px;overflow:hidden;background:rgba(255,255,255,.05)}
.gate-carousel-img{width:140px;height:140px;object-fit:cover}
.gate-carousel-name{padding:8px;font-size:11px;color:rgba(255,255,255,.7);text-align:center}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== MODAL ===== */
.modal-overlay{
  position:fixed;inset:0;background:rgba(28,24,21,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .25s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal,.product-detail-modal{
  background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;
  overflow-y:auto;padding:32px;box-shadow:var(--shadow-lg);animation:modalUp .35s cubic-bezier(.16,1,.3,1);position:relative;
}
.product-detail-modal{max-width:720px}
@keyframes modalUp{from{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-close-btn{
  position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:11px;border:none;
  background:var(--surface2);color:var(--text2);font-size:18px;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;z-index:2;
}
.modal-close-btn:hover{background:#FDEDEA;color:#D63A2E;transform:rotate(90deg)}
.product-detail-img{width:100%;border-radius:14px;margin-bottom:18px;background:var(--surface2)}
.product-detail-img-placeholder{width:100%;aspect-ratio:1;border-radius:14px;background:var(--surface2);margin-bottom:18px;display:flex;align-items:center;justify-content:center;color:var(--border2)}
.thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;cursor:pointer;border:2px solid transparent;transition:all .2s;background:var(--surface2)}
.thumb:hover,.thumb.active{border-color:var(--accent)}

/* ===== ADMIN ===== */
.admin-layout{display:flex;min-height:calc(100vh - 72px)}
.admin-sidebar{
  width:240px;background:var(--surface);border-right:1px solid var(--border);
  padding:24px 16px;flex-shrink:0;
}
.admin-content{flex:1;padding:32px;overflow-x:auto}
.admin-nav-item{
  display:flex;align-items:center;gap:11px;padding:12px 15px;border-radius:11px;
  font-size:14.5px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .18s;margin-bottom:4px;
}
.admin-nav-item:hover{background:var(--surface2);color:var(--text)}
.admin-nav-item.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:var(--shadow-accent)}

/* Stat cards */
.stat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 22px;box-shadow:var(--shadow-sm);flex:1;min-width:140px;
}
.stat-accent{border-left:4px solid var(--accent)}
.stat-green{border-left:4px solid var(--green)}
.stat-label{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.stat-val{font-size:26px;font-weight:800;letter-spacing:-.02em}

/* Table */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;padding:14px 16px;background:var(--surface2);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text2);white-space:nowrap}
.table td{padding:14px 16px;border-top:1px solid var(--border)}
.table tr:hover td{background:var(--bg2)}

/* Status badges */
.status-badge,.badge-active,.badge-inactive,.badge-preventa,.pending-badge{
  display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:8px;
  font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.02em;
}
.status-pending,.pending-badge{background:#FFF4E0;color:#B8740A}
.status-confirmed{background:var(--green-light);color:#147a3d}
.status-shipped{background:#E6F0FD;color:#1a5fb4}
.status-cancelled{background:#FDEDEA;color:#C0392B}
.badge-active{background:var(--green-light);color:#147a3d}
.badge-inactive{background:var(--surface2);color:var(--text2)}
.badge-preventa{background:#F0E6FD;color:#7B3FB8}

/* Category tags (import) */
.cat-tag{display:inline-flex;align-items:center;gap:6px;background:var(--accent-light);color:var(--accent2);padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600;margin:3px}
.cat-tag-x{cursor:pointer;font-weight:800;opacity:.6}
.cat-tag-x:hover{opacity:1}
.detail-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text2)}

/* ===== SUCCESS / EMPTY / LOADING ===== */
.success-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:20px}
.success-box{background:var(--surface);border-radius:var(--radius-lg);padding:48px 40px;text-align:center;max-width:460px;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.success-icon{
  width:80px;height:80px;border-radius:50%;margin:0 auto 24px;
  background:linear-gradient(135deg,var(--green),#178a47);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 8px 24px rgba(31,157,85,.3);animation:pop .5s cubic-bezier(.16,1,.3,1);
}
@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.12)}100%{transform:scale(1)}}
.empty-state{padding:80px 20px;text-align:center;color:var(--text2)}
.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--text2);font-size:15px}

/* ===== CONDITIONS ===== */
.conditions-page{max-width:820px;margin:0 auto;padding:32px 24px 60px}
.conditions-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;line-height:1.7;box-shadow:var(--shadow-sm);white-space:pre-wrap}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.login-box{background:var(--surface);border-radius:var(--radius-lg);padding:40px;width:400px;max-width:92vw;box-shadow:var(--shadow-lg);border:1px solid var(--border)}

/* ===== TOAST ===== */
.toast{
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%);
  background:var(--text);color:#fff;padding:14px 24px;border-radius:13px;
  font-size:14.5px;font-weight:600;z-index:2000;box-shadow:var(--shadow-lg);
  animation:toastUp .35s cubic-bezier(.16,1,.3,1);
}
@keyframes toastUp{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%,0)}}

/* ===== WHATSAPP FLOAT ===== */
.wa-float{
  position:fixed;bottom:24px;right:24px;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,#25D366,#1da851);color:#fff;
  display:flex;align-items:center;justify-content:center;z-index:900;
  box-shadow:0 6px 20px rgba(37,211,102,.4);transition:all .25s;animation:waPulse 2.8s ease-in-out infinite;
}
.wa-float:hover{transform:scale(1.1)}
@keyframes waPulse{0%,100%{box-shadow:0 6px 20px rgba(37,211,102,.4)}50%{box-shadow:0 6px 30px rgba(37,211,102,.7)}}

.mono{font-family:var(--mono)}

/* ===== TABLET ===== */
@media(max-width:1024px){
  .product-grid{grid-template-columns:repeat(3,1fr);gap:16px}
  .admin-sidebar{width:200px}
  .container{padding:24px 18px 50px}
}

/* ===== MOBILE ===== */
@media(max-width:768px){
  .header{padding:0 16px;height:64px}
  .header-brand img{height:38px}
  .header-brand h1{font-size:15px;max-width:130px;overflow:hidden;text-overflow:ellipsis}
  .header-brand span{display:none}
  .header-nav{display:none}
  .btn-cart{padding:9px 14px;font-size:13px}
  .container{padding:18px 14px 50px}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .product-info{padding:12px 12px 14px}
  .product-name{font-size:13px;min-height:2.6em;margin-bottom:8px}
  .product-price{font-size:17px}
  .product-cat{font-size:9px}
  .qty-input,.qty-val{flex:1 1 auto;min-width:0;width:auto}
  .qty-btn{width:44px;height:42px}
  .product-add-btn{font-size:13px;padding:11px}
  .form-grid{grid-template-columns:1fr;gap:14px}
  .cat-pills{gap:7px;margin-bottom:20px}
  .cat-pill{padding:8px 14px;font-size:13px}
  /* Modal becomes bottom sheet */
  .modal-overlay{align-items:flex-end;padding:0}
  .modal,.product-detail-modal{
    max-width:100%;max-height:92vh;border-radius:24px 24px 0 0;padding:24px 20px 32px;
    animation:sheetUp .38s cubic-bezier(.16,1,.3,1);
  }
  @keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
  .cart-item{padding:12px;gap:11px}
  .cart-item-img{width:58px;height:58px}
  .cart-summary{padding:20px}
  .checkout-form{padding:20px}
  .admin-layout{flex-direction:column}
  .admin-sidebar{width:100%;display:flex;gap:6px;overflow-x:auto;padding:14px;border-right:none;border-bottom:1px solid var(--border)}
  .admin-nav-item{white-space:nowrap;margin-bottom:0}
  .admin-content{padding:18px 14px}
  .stat-val{font-size:22px}
  .gate-box{padding:36px 24px}
  .gate-box h1{font-size:22px}
  .gate-showcase{grid-template-columns:repeat(3,1fr)}
  .wa-float{width:54px;height:54px;bottom:18px;right:18px}
}

/* ===== SMALL MOBILE ===== */
@media(max-width:380px){
  .product-grid{gap:9px}
  .product-name{font-size:12.5px}
  .product-price{font-size:16px}
  .container{padding:16px 11px 40px}
}

/* v60: gate = splash de un clic (clave pre-cargada, campo oculto) */
.gate-input{display:none!important}
