/* =====================================================================
   DarkShoppe UI — capa visual común para la app principal.
   Objetivo: unificar la apariencia sin cambiar rutas, vistas ni base de datos.
   ===================================================================== */
:root{
  --ds-bg:#070b14;--ds-bg-soft:#0b1220;--ds-panel:#0f172a;--ds-panel-2:#111827;
  --ds-card:#ffffff;--ds-card-soft:#f8fafc;--ds-line:rgba(148,163,184,.22);
  --ds-text:#eef4ff;--ds-muted:#a8b3c7;--ds-dark:#0f172a;--ds-dark-muted:#64748b;
  --ds-primary:#20c997;--ds-primary-2:#3aa2ff;--ds-orange:#f59e0b;--ds-red:#ef4444;
  --ds-radius:22px;--ds-radius-sm:14px;--ds-shadow:0 22px 60px rgba(0,0,0,.38);
  --ds-shadow-soft:0 14px 34px rgba(15,23,42,.12);--ds-font:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth}body.ds-body{margin:0;min-height:100vh;font-family:var(--ds-font);color:var(--ds-text);background:radial-gradient(900px 520px at 12% 0%,rgba(58,162,255,.20),transparent 58%),radial-gradient(800px 500px at 86% 8%,rgba(32,201,151,.16),transparent 58%),linear-gradient(180deg,#06101f 0%,#070b14 42%,#05070d 100%);line-height:1.5;overflow-x:hidden}body.ds-body a{color:inherit}img{max-width:100%;display:block}.ds-shell{width:min(1880px,100%);margin:0 auto;padding:18px clamp(12px,2vw,28px) 0}.ds-layout{display:grid;grid-template-columns:minmax(210px,330px) minmax(0,1fr) minmax(260px,360px);gap:22px;align-items:start;margin-top:18px}.ds-main{min-width:0;background:rgba(255,255,255,.96);color:var(--ds-dark);border-radius:var(--ds-radius);box-shadow:var(--ds-shadow);border:1px solid rgba(255,255,255,.88);overflow:hidden}.ds-main-inner{padding:clamp(16px,2vw,28px)}.ds-sidebar{display:grid;gap:18px;min-width:0}.ds-section{margin-bottom:24px}.ds-glass{background:rgba(15,23,42,.72);border:1px solid rgba(148,163,184,.20);box-shadow:var(--ds-shadow);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:var(--ds-radius);overflow:hidden}.ds-eyebrow{display:inline-flex;align-items:center;gap:8px;color:#c7fff0;background:rgba(32,201,151,.12);border:1px solid rgba(32,201,151,.22);border-radius:999px;padding:7px 12px;font-weight:900;font-size:.8rem;letter-spacing:.3px}.ds-hero{position:relative;overflow:hidden;padding:clamp(24px,4vw,48px);border-radius:var(--ds-radius);background:radial-gradient(720px 340px at 0% 0%,rgba(58,162,255,.22),transparent 60%),radial-gradient(620px 340px at 100% 0%,rgba(32,201,151,.18),transparent 60%),linear-gradient(135deg,#111827,#0b1220);color:#fff;box-shadow:var(--ds-shadow-soft);border:1px solid rgba(255,255,255,.10)}.ds-hero h1{margin:16px 0 10px;font-size:clamp(2rem,4.5vw,4.2rem);line-height:.98;letter-spacing:-.06em}.ds-hero p{max-width:760px;color:#cbd5e1;font-weight:700;font-size:clamp(1rem,1.5vw,1.15rem);margin:0}.ds-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:0;text-decoration:none;border-radius:999px;padding:12px 17px;font-weight:950;letter-spacing:.1px;cursor:pointer;transition:transform .2s ease,filter .2s ease,box-shadow .2s ease}.ds-btn:hover{transform:translateY(-2px)}.ds-btn-primary{background:linear-gradient(135deg,var(--ds-primary),#10b981);color:#03130e;box-shadow:0 14px 30px rgba(16,185,129,.28)}.ds-btn-secondary{background:rgba(255,255,255,.10);color:#fff;border:1px solid rgba(255,255,255,.18)}.ds-btn-orange{background:linear-gradient(135deg,#ffd166,#f59e0b);color:#1f1300}.ds-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:24px}.ds-stat{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px}.ds-stat strong{display:block;font-size:1.4rem;color:#fff}.ds-stat span{color:#cbd5e1;font-weight:800;font-size:.82rem}.ds-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:24px 0 18px}.ds-title{margin:0;color:var(--ds-dark);font-size:clamp(1.5rem,2.3vw,2.1rem);letter-spacing:-.04em}.ds-subtitle{margin:4px 0 0;color:var(--ds-dark-muted);font-weight:800}.ds-filter-panel{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;align-items:end;background:var(--ds-card-soft);border:1px solid #e2e8f0;border-radius:20px;padding:14px;box-shadow:var(--ds-shadow-soft);margin-bottom:22px}.ds-filter-group label{display:block;color:#334155;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:950;margin-bottom:8px}.ds-pill-row{display:flex;flex-wrap:wrap;gap:8px}.ds-pill{display:inline-flex;align-items:center;gap:7px;text-decoration:none;border-radius:999px;padding:10px 13px;background:#fff;border:1px solid #e2e8f0;color:#0f172a;font-weight:950;box-shadow:0 8px 18px rgba(15,23,42,.06);transition:transform .18s ease,background .18s ease,border-color .18s ease}.ds-pill:hover,.ds-pill.is-active{transform:translateY(-1px);border-color:rgba(32,201,151,.45);background:#ecfdf5}.ds-order{display:flex;flex-wrap:wrap;gap:8px}.ds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(235px,1fr));gap:18px}.ds-card{position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:22px;overflow:hidden;box-shadow:0 16px 34px rgba(15,23,42,.10);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.ds-card:hover{transform:translateY(-6px);box-shadow:0 28px 60px rgba(15,23,42,.18);border-color:rgba(32,201,151,.35)}.ds-card a{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.ds-card-media{height:185px;background:#0f172a;position:relative;overflow:hidden}.ds-card-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s ease,transform 5s ease}.ds-card-media img.active,.ds-card-media img:first-child{opacity:1}.ds-card:hover .ds-card-media img.active,.ds-card:hover .ds-card-media img:first-child{transform:scale(1.05)}.ds-badge{display:inline-flex;align-items:center;gap:6px;position:absolute;border-radius:999px;padding:7px 10px;font-weight:950;font-size:.78rem;border:1px solid rgba(255,255,255,.28);box-shadow:0 12px 24px rgba(0,0,0,.20)}.ds-badge-cat{top:10px;left:10px;color:#fff;background:rgba(15,23,42,.74);backdrop-filter:blur(8px)}.ds-badge-price{right:10px;bottom:10px;color:#111827;background:linear-gradient(135deg,#ffd166,#f59e0b)}.ds-card-body{padding:16px;display:flex;flex-direction:column;gap:10px;flex:1}.ds-card-title{font-size:1.02rem;line-height:1.25;margin:0;color:#0f172a;letter-spacing:-.02em}.ds-card-meta{color:#64748b;font-weight:800;font-size:.88rem}.ds-card-cta{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:14px;background:#0f172a;color:#fff;padding:10px 12px;font-weight:950}.ds-empty{padding:24px;border:1px dashed #cbd5e1;border-radius:18px;background:#f8fafc;color:#64748b;text-align:center;font-weight:900}.ds-pagination{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin:26px 0 4px}.ds-pagination a,.ds-pagination span{display:inline-flex;align-items:center;justify-content:center;padding:10px 13px;border-radius:999px;background:#fff;border:1px solid #e2e8f0;color:#0f172a;font-weight:950;text-decoration:none}.ds-pagination a:hover{background:#ecfdf5;border-color:rgba(32,201,151,.45)}.ds-page-card{background:#fff;border:1px solid #e5e7eb;border-radius:24px;box-shadow:var(--ds-shadow-soft);overflow:hidden}.ds-page-head{padding:clamp(18px,2.4vw,30px);background:radial-gradient(560px 260px at 0% 0%,rgba(58,162,255,.12),transparent 60%),linear-gradient(135deg,#0f172a,#111827);color:#fff}.ds-page-head h1{margin:10px 0 6px;font-size:clamp(1.8rem,4vw,3rem);letter-spacing:-.05em}.ds-page-head p{margin:0;color:#cbd5e1;font-weight:750}.ds-page-body{padding:clamp(18px,2.4vw,30px)}.ds-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:18px 0}.ds-feature{border:1px solid #e2e8f0;border-radius:18px;background:#f8fafc;padding:16px}.ds-feature .material-icons{color:var(--ds-primary);background:#dcfce7;border-radius:14px;padding:8px}.ds-feature h3{margin:10px 0 6px;color:#0f172a}.ds-feature p{margin:0;color:#64748b;font-weight:750}.ds-table-wrap{overflow-x:auto;border:1px solid #e5e7eb;border-radius:18px}.ds-table{width:100%;border-collapse:collapse;background:#fff}.ds-table th,.ds-table td{padding:13px 14px;border-bottom:1px solid #e5e7eb;text-align:left}.ds-table th{background:#0f172a;color:#fff}.ds-footer{margin-top:24px;padding:22px clamp(14px,2vw,28px);border-top:1px solid rgba(255,255,255,.10);background:rgba(5,7,13,.72)}.ds-footer-inner{width:min(1880px,100%);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.ds-footer-brand{display:flex;align-items:center;gap:10px;font-weight:950}.ds-footer-dot{width:12px;height:12px;border-radius:50%;background:var(--ds-primary);box-shadow:0 0 0 6px rgba(32,201,151,.14)}.ds-footer-links{display:flex;gap:10px;flex-wrap:wrap}.ds-footer-links a{text-decoration:none;color:#dbeafe;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:999px;padding:8px 11px;font-weight:900}.ds-mobile-only{display:none}@media(max-width:1180px){.ds-layout{grid-template-columns:1fr}.ds-sidebar{grid-template-columns:repeat(2,minmax(0,1fr))}.ds-main{order:1}.ds-sidebar-left{order:2}.ds-sidebar-right{order:3}}@media(max-width:780px){.ds-shell{padding-inline:10px}.ds-sidebar{grid-template-columns:1fr}.ds-main-inner{padding:14px}.ds-filter-panel{grid-template-columns:1fr}.ds-stats,.ds-feature-grid{grid-template-columns:1fr}.ds-grid{grid-template-columns:1fr}.ds-card-media{height:210px}.ds-hero-actions .ds-btn{width:100%}.ds-mobile-only{display:block}}@media(max-width:480px){.ds-layout{gap:12px;margin-top:12px}.ds-hero{padding:22px 16px}.ds-card-media{height:180px}.ds-pill,.ds-order a{width:100%;justify-content:center}.ds-footer-inner{align-items:flex-start}.ds-footer-links a{width:100%;justify-content:center;display:flex}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
