:root{
  --bg:#0d1226;
  --bg-2:#0a1647;
  --primary:#2a7fff;
  --primary-2:#00c3ff;
  --accent:#34d399;
  --text:#e6eaf5;
  --muted:#9aa4b2;
  --card:#101836;
  --danger:#ff5f6d;
  --wa:#25D366;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 500px at 80% -50%, #227dff33, transparent 60%),
    linear-gradient(140deg, var(--bg) 0%, var(--bg-2) 60%, #061034 100%);
}

/* Layout */
.layout{display:flex;min-height:100vh;position:relative}
.sidebar{
  width:220px;
  background:linear-gradient(180deg, #0c1f61 0%, #0b2c8d 36%, #0a1e6c 100%);
  position:sticky;top:0;height:100vh;padding:26px 16px;border-right:1px solid #0f2a7a;z-index:1;
}
@media (max-width: 900px){
  .sidebar{position:static;height:auto}
}
@media (max-width: 900px){
  .layout{flex-direction:column}
  .sidebar{width:100%;border-right:none;border-bottom:1px solid #0f2a7a;padding:16px 14px}
  .content{width:100%}
}
.menu-toggle{display:none;align-items:center;gap:8px;background:#0a1e6c;border:1px solid #1b4bd8;color:#cfe3ff;padding:10px 12px;border-radius:12px;cursor:pointer}
@media (max-width: 900px){
  .menu-toggle{display:flex}
}
.brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:18px;text-align:center}
.brand-logo{width:120px;height:120px;border-radius:50%;background:radial-gradient(120px 120px at 50% 50%, #173b9e 0%, #0f2b8f 60%);display:grid;place-items:center;box-shadow:0 0 0 8px #0a1e6c,0 18px 40px #0008;margin:0 auto}
.brand-logo img{width:92px;height:92px;border-radius:50%;object-fit:cover}
.brand-name{font-weight:800;letter-spacing:1px;font-size:18px}

.search-box{display:flex;align-items:center;gap:10px;background:#0a1e6c;border:1px solid #1643b4;padding:10px;border-radius:14px;color:#cfe3ff;box-shadow:0 8px 20px #0006}
.search-box input{flex:1;background:transparent;border:none;color:#cfe3ff;font-size:14px;outline:none}

.side-actions{margin:16px 0}
.currency-select{margin:10px 0}
.currency-select select{width:100%;padding:10px;border-radius:12px;background:#0a1e6c;border:1px solid #1b4bd8;color:#cfe3ff}

.side-nav{margin:12px 0 8px;display:grid;gap:8px}
.nav-item{display:block;padding:10px 12px;border-radius:12px;text-decoration:none;color:#e2ebff;background:#0a1e6c;border:1px solid #1b4bd8;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.nav-item i{margin-right:8px}
.nav-item:hover{filter:brightness(1.08)}

.wallet-chip{display:flex;align-items:center;gap:8px;margin:12px 0;padding:10px;border-radius:12px;background:#0a1e6c;border:1px solid #1b4bd8;color:#cfe3ff;font-weight:700;justify-content:center}

.floating-cart{position:fixed;right:18px;bottom:18px;width:44px;height:44px;border-radius:12px;background:#0a1e6c;border:1px solid #1b4bd8;color:#cfe3ff;display:grid;place-items:center;box-shadow:0 10px 26px #0008;text-decoration:none;z-index:1000}
.floating-cart .cart-badge{position:absolute;top:-6px;right:-6px;background:#ff4d4d;color:#fff;border-radius:999px;padding:2px 6px;font-size:11px;border:1px solid #8b0000}
.link-auth{display:inline-flex;align-items:center;gap:10px;color:#e2ebff;text-decoration:none;background:#0a1e6c;border:1px solid #1b4bd8;padding:10px 12px;border-radius:12px}

.side-contact{margin-top:auto;color:#cfe3ff}
.side-contact a{color:#cfe3ff}
.social{display:flex;gap:10px;margin-top:10px}

/* Topbar */
.topbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin:0 0 16px;padding:10px 14px;border:1px solid #1b4bd8;background:#0a1e6c;color:#cfe3ff;border-radius:12px;position:relative;z-index:3}
.topbar-left,.topbar-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.topbar-right{margin-right:22px}
@media (max-width: 900px){
  .topbar-right{margin-right:0;margin-top:8px}
}
@media (max-width: 900px){
  .topbar{margin-top:36px}
  .topbar-left,.topbar-right{gap:6px}
  .chip{padding:5px 8px}
  .content{padding-top:24px}
  .menu-toggle{margin-bottom:12px}
}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-weight:600;border:1px solid #1b4bd8;background:#091a5a;color:#cfe3ff;text-decoration:none}
.chip-blue{background:#0b2586}
.chip-green{background:#0b8618}
.chip-gray{background:#2f2f2f}
.chip-purple{background:#5a0b86}

/* Avisos (flash messages) */
.flash{margin:8px 0 16px;padding:10px 12px;border-radius:12px;border:1px solid #1b4bd8;background:#0a1e6c;color:#cfe3ff}
.flash.info{border-color:#1b4bd8;background:#0a1e6c;color:#cfe3ff}
.flash.success{border-color:#34d399;background:#19311b;color:#c9f5d9}
.flash.error{border-color:#ff7a7a;background:#311b1b;color:#ffd7d7}
.user-label{font-weight:700}
.social a{display:grid;place-items:center;width:28px;height:28px;background:#0a1e6c;border:1px solid #1749cf;border-radius:8px;color:#cfe3ff;text-decoration:none}
/* Admin nav */
.admin-nav{display:flex;gap:8px;margin-bottom:12px}

.content{flex:1;padding-bottom:20px;display:flex;flex-direction:column;position:relative;z-index:2}

/* Hero */
.hero{height:340px;background:
    radial-gradient(700px 260px at 30% -20%, #00c3ff44, transparent 60%),
    linear-gradient(120deg,#081641 0%, #091a52 45%, #0a215f 100%);
  border-bottom:1px solid #173b9e;position:relative;overflow:hidden}
.hero-inner{max-width:1200px;margin:0 auto;padding:36px 28px;position:relative;z-index:2}
.hero-title{font-size:72px;margin:0;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;text-shadow:0 6px 28px #1f6bff66}
.hero-sub{margin:12px 0 8px;color:#d6e6ff}
.hero-url{display:inline-block;padding:6px 10px;border-radius:10px;background:#0a1e6c;border:1px solid #1b4bd8;color:#bcd6ff;font-size:12px}

/* Hero slider */
.hero-slider{position:absolute;left:50%;transform:translateX(-50%);bottom:100px;width:calc(100% - 56px);max-width:1100px;height:150px;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}
.slides{position:relative;width:100%;height:100%;overflow:hidden}
.slide{position:absolute;inset:0;background-size:cover;background-repeat:no-repeat;background-position:center;border-radius:22px;box-shadow:0 12px 40px #0006;border:1px solid #173b9e;opacity:0;transition:opacity .6s ease}
.slide-fallback{display:grid;place-items:center;font-weight:800;letter-spacing:1px;background:linear-gradient(120deg,#0f7fdc,#0f2b8f)}
/* Mostrar la slide del hero por defecto */
.hero-slider .slide{opacity:1}

/* Desktop: ocupar el ancho disponible y mayor altura */
@media (min-width: 901px){
  .hero-slider{width:calc(100% - 56px);max-width:1200px;height:180px}
}

/* Categories */
.categories{max-width:1200px;margin:-52px auto 18px;display:flex;gap:18px;padding:0 28px}
.categories-slider{max-width:1200px;margin:16px auto 18px;overflow:hidden;padding:0 28px}
.cat-track{display:flex;gap:18px;animation:cat-scroll 28s linear infinite;will-change:transform}
@keyframes cat-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.categories-slider:hover .cat-track{animation-play-state:paused}
.cat-card{flex:0 0 auto;width:124px;height:124px;border-radius:24px;background:var(--card);border:1px solid #1b4bd8;display:grid;place-items:center;color:#fff;box-shadow:0 10px 30px #0006;position:relative;overflow:hidden}
.cat-card span{font-size:15px;text-align:center;padding:0 6px}
.cat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 40%,#1b4bd822 60%,transparent)}
.cat-disney{background:linear-gradient(140deg,#0b3aa1,#0a62c9)}
.cat-prime{background:linear-gradient(140deg,#243b55,#141e30)}
.cat-hbo{background:linear-gradient(140deg,#6b46c1,#3b2466)}
.cat-crunchy{background:linear-gradient(140deg,#ff8c00,#f75f00)}
.cat-paramount{background:linear-gradient(140deg,#2d6cdf,#1a46a5)}
.cat-plex{background:linear-gradient(140deg,#2b2b2b,#101010)}
.cat-spotify{background:linear-gradient(140deg,#1db954,#117a38)}

/* Toolbar */
.toolbar{max-width:1120px;margin:6px auto 12px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;color:#cfe3ff}
.toolbar-right select{background:#0a1e6c;border:1px solid #1b4bd8;border-radius:10px;color:#cfe3ff;padding:6px 10px}

/* Products grid */
.products{max-width:1200px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product-card{background:var(--card);border:1px solid #173b9e;border-radius:20px;overflow:hidden;box-shadow:0 12px 40px #0006}
.product-cover{display:block;height:200px;position:relative;background:#0a1e6c}
.product-cover .ribbon{position:absolute;left:14px;top:14px;background:#ffcc00;color:#141e30;font-weight:700;padding:4px 10px;border-radius:8px;font-size:12px}
.product-cover .badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#111a3a;color:#fff;border:1px solid #445bff;padding:8px 12px;border-radius:14px;font-size:12px;box-shadow:0 10px 30px #0008}

/* Simulaciones de imagem con gradientes */
.img-chatgpt{background:linear-gradient(120deg,#0f7fdc,#0f2b8f)}
.img-universal{background:linear-gradient(120deg,#d97706,#b45309)}
.img-chatgpt2{background:linear-gradient(120deg,#9333ea,#6d28d9)}
.img-appletv{background:linear-gradient(120deg,#0f172a,#1f2937)}
.img-capcut{background:linear-gradient(120deg,#0e7490,#075985)}
.img-paramount{background:linear-gradient(120deg,#1f4fd6,#102f9e)}

.product-body{padding:14px}
.product-title{margin:0 0 6px;font-size:17px}
.rating{color:#ffd369}
.rating i{margin-right:2px}
.price{display:flex;gap:10px;align-items:center;margin:8px 0 12px}
.price .old{color:#8aa0c9;text-decoration:line-through}
.price .new{color:#fff;font-weight:700}
.actions{display:flex;gap:10px}
.btn{border:none;border-radius:14px;padding:10px 14px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.btn-white{color:#fff;border:1px solid #fff;background:transparent}
.btn-primary{background:linear-gradient(100deg,var(--primary),var(--primary-2));color:#fff}
.btn-wa{background:#25D366;color:#06220f}
.btn:hover{filter:brightness(1.08)}

/* Footer */
.site-footer{max-width:1200px;margin:24px auto 0;padding:12px 16px;border-top:1px solid #173b9e;color:#cfe3ff;opacity:.92;display:flex;justify-content:center;background:#0a1e6c;border-radius:12px;margin-top:auto}
.site-footer .footer-inner{font-size:13px;text-align:center}

/* Product detail */
.product-detail{max-width:1200px;margin:26px auto;padding:0 28px;display:grid;grid-template-columns:480px 1fr;gap:26px}
.pd-media{background:linear-gradient(140deg,#071338,#0a1e6c);border:1px solid #0f2a7a;border-radius:12px;display:grid;place-items:center;overflow:hidden;box-shadow:0 12px 40px #0006}
.pd-poster{padding:20px}
.poster{height:460px;width:100%;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:800;letter-spacing:1px}
.poster-img{object-fit:cover}
.poster-paramount{background:linear-gradient(120deg,#1f4fd6,#102f9e)}
.pd-info{background:var(--card);border:1px solid #173b9e;border-radius:20px;padding:20px}
.pd-title{margin:0 0 4px}
.pd-rating{display:flex;align-items:center;gap:10px;color:#ffd369}
.pd-price{font-size:24px;font-weight:800;margin:16px 0}
.pd-includes{list-style:none;padding:0;margin:0 0 14px}
.pd-includes li{margin:8px 0;color:#d7e6ff}
.pd-includes i{color:#39e28f;margin-right:8px}
.pd-important h3{margin:6px 0 8px}
.pd-important ul{margin:0;padding-left:18px;color:#cfe3ff}
.pd-actions{display:flex;align-items:center;gap:12px;margin:14px 0}
.qty{display:flex;align-items:center;gap:6px;background:#0a1e6c;border:1px solid #1b4bd8;border-radius:12px;padding:6px}
.qty-btn{background:transparent;border:none;color:#cfe3ff;font-size:18px;cursor:pointer}
.qty input{width:36px;background:transparent;border:none;color:#fff;text-align:center}

/* Floating WhatsApp */
.wa-fab{position:fixed;right:18px;bottom:78px;width:44px;height:44px;border-radius:50%;background:var(--wa);color:#fff;display:grid;place-items:center;box-shadow:0 18px 40px #0006;text-decoration:none;font-size:20px;z-index:1000}
.wa-fab:hover{filter:brightness(1.1)}

/* Responsive */
@media (max-width:1100px){
  .products{grid-template-columns:repeat(2,1fr)}
  .product-detail{grid-template-columns:1fr !important}
}

@media (max-width:860px){
  .sidebar{position:fixed;left:0;top:0;height:auto;width:100%;z-index:10;padding:12px 14px;border-right:none;border-bottom:1px solid #173b9e}
  .layout{flex-direction:column}
  .content{padding-top:82px}
  .categories{margin-top:0;flex-wrap:nowrap;overflow:auto}
  /* Menú compacto en móvil */
  .sidebar .search-box,
  .sidebar .side-contact{display:none}
  /* Mostrar moneda y saldo en móvil */
  .sidebar .currency-select{display:block}
  .sidebar .wallet-chip{display:flex}
  .menu-toggle{display:flex}
  .sidebar .side-nav{display:none}
  /* Mostrar menú cuando se activa el toggle */
  #menuToggle:checked ~ .side-nav{display:grid}
  .brand{margin:0}
  /* Compactar logo + texto en el header móvil */
  .brand{gap:8px;align-items:center;flex-direction:row}
  .brand-logo{margin:0}
  .brand-name{letter-spacing:.5px}
  /* WhatsApp más pequeño en móvil */
  .wa-fab{width:44px;height:44px;font-size:18px;right:16px;bottom:76px}
  .brand-logo{width:48px;height:48px;box-shadow:none}
  .brand-logo img{width:40px;height:40px}
  .brand-name{font-size:16px}
  /* Grid de productos en móvil */
  .products{grid-template-columns:repeat(2,1fr);gap:14px;padding:0 14px}
  .hero{height:200px}
  .hero-inner{padding:28px 18px}
  .hero-title{font-size:34px;letter-spacing:1px}
  .hero-sub{font-size:13px}
  .hero-url{font-size:11px}
  .hero-slider{height:120px;bottom:42px;width:calc(100% - 28px)}
  .categories-slider{margin:12px auto 12px}
  .poster-img{object-fit:contain}
  .poster{height:300px}
  .cart-dropdown{right:14px;bottom:100px;width:94%;max-width:380px;max-height:calc(100vh - 160px)}
  .site-footer{margin:18px auto;padding:10px 12px}
}
.cart-dropdown{position:fixed;right:18px;bottom:78px;width:320px;max-height:70vh;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:#0a1e6c;border:1px solid #1b4bd8;color:#cfe3ff;border-radius:16px;box-shadow:0 18px 40px #0008;z-index:1100;display:none}
.cd-header{font-weight:800;padding:10px 12px;border-bottom:1px solid #173b9e}
.cd-items{list-style:none;margin:0;padding:0}
.cd-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid #0f2a7a}
.cd-item:last-child{border-bottom:none}
.cd-thumb{width:42px;height:42px;border-radius:10px;object-fit:cover;border:1px solid #173b9e}
.cd-info{display:flex;flex-direction:column;gap:6px;flex:1}
.cd-name{font-weight:700}
.cd-qty{color:#9aa4b2;font-size:12px;min-width:20px;text-align:center}
.cd-subtotal{font-weight:700}
.cd-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-top:1px solid #173b9e}
.cd-actions{display:flex;gap:8px}
/* Controles de cantidad y eliminar */
.cd-qty-controls{display:flex;align-items:center;gap:8px}
.cd-qty-btn{background:#0a1e6c;border:1px solid #1b4bd8;color:#cfe3ff;width:26px;height:26px;border-radius:8px;cursor:pointer}
.cd-remove{background:#0a1e6c;border:1px solid #8b0000;color:#fff;width:28px;height:28px;border-radius:8px;cursor:pointer}
/* Toggle del dropdown del carrito */
#cartToggle:checked ~ .cart-dropdown{display:block}
.cart-dropdown.open{display:block}
.btn:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.1)}
/* Input oculto pero accesible para toggles controlados por label */
.visually-hidden{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
