/* ===========================
   DS SPORT — UI MODERNA V2
   =========================== */

/* --------- Design tokens --------- */
:root{
  /* Colores */
  --bg:#0b0e13;
  --panel:#121622;
  --card:#0f1420;
  --line:#1b2132;
  --ink:#e9eefc;
  --muted:#96a0b6;
  --brand:#00f0ff;
  --brand2:#5cff96;
  --danger:#ff5c7a;
  --ok:#78ffcf;

  /* Efectos */
  --ring: 0 0 0 3px rgba(0,240,255,.25);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --glass: rgba(18,22,34,.72);

  /* Espaciado / radios */
  --r-sm:10px; --r:14px; --r-lg:20px;
  --pad:12px;
}

/* --------- Reset & base --------- */
*{box-sizing:border-box}
html,body{height:100%}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; color:var(--ink);
  font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,240,255,.10), transparent),
    radial-gradient(1200px 600px at -10% 120%, rgba(92,255,150,.10), transparent),
    linear-gradient(180deg,#0b0e13,#0a0c11);
}
::selection{background:rgba(0,240,255,.2)}
a{color:var(--ink); text-decoration:none}
.wrap{max-width:1100px; margin:0 auto; padding:20px}
h1,h2,h3{margin:.2em 0 .4em}
h1{font-size:42px} h2{font-size:26px} h3{font-size:18px}
.muted{color:var(--muted)}

/* --------- Botones --------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px; border-radius:var(--r);
  font-weight:700; border:1px solid transparent; cursor:pointer;
  background:linear-gradient(90deg,var(--brand),var(--brand2)); color:#001018;
  transition:transform .08s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.6; cursor:not-allowed}
.btn.ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn.small{padding:6px 10px; border-radius:var(--r-sm); font-size:12px}
.btn.full{width:100%}

/* --------- Inputs / Formularios --------- */
label{display:block; margin:12px 0 6px; font-weight:600}
input,select,textarea{
  width:100%; padding:12px; border-radius:var(--r);
  background:#0e1320; color:var(--ink);
  border:1px solid var(--line); outline:0; transition:box-shadow .2s ease,border-color .2s ease;
}
input:focus,select:focus,textarea:focus{box-shadow:var(--ring); border-color:var(--brand)}
input::placeholder{color:#7e8aa6}

.row{display:flex; gap:10px; align-items:center}
.grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:12px}
.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}

/* --------- NAV --------- */
.nav{
  position:sticky; top:0; z-index:20;
  background:rgba(11,14,19,.75); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)
}
.nav .wrap{display:flex; align-items:center; gap:16px}
.logo{font-weight:800; letter-spacing:.3px}
.logo span{color:var(--brand)}
.menu{margin-left:auto; display:flex; gap:12px; align-items:center}
.menu a{padding:10px 12px; border-radius:var(--r)}
.menu .btn{box-shadow:0 6px 20px rgba(0,240,255,.15)}
.menu .cart{background:#161a26; border:1px solid var(--line)}
.nav-toggle{display:none; background:#151a26; color:var(--ink); border:1px solid var(--line); padding:8px 10px; border-radius:var(--r-sm)}

/* --------- HERO --------- */
.hero{padding:40px 0; border-bottom:1px solid var(--line)}
.hero .wrap{display:grid; grid-template-columns:1.2fr .8fr; gap:22px; align-items:center}
.hero p{color:var(--muted)}
.cta{display:flex; gap:10px; margin-top:10px}

.hero-3d{height:320px; position:relative; perspective:800px}
.hero-3d .boot{
  position:absolute; inset:0; margin:auto; width:90%; max-width:420px; height:90%;
  background:
    radial-gradient(120px 60px at 60% 40%, rgba(92,255,150,.25), transparent),
    linear-gradient(135deg,#141c2b,#0e1420);
  border-radius:40px; transform:rotateY(-18deg) rotateX(8deg);
  box-shadow:0 20px 60px rgba(0,240,255,.12) inset, 0 20px 60px rgba(0,0,0,.55);
  animation:float 5s ease-in-out infinite;
}
@keyframes float{
  0%,100%{transform:rotateY(-18deg) rotateX(8deg) translateY(0)}
  50%{transform:rotateY(-15deg) rotateX(6deg) translateY(-8px)}
}

/* --------- HOME CARDS --------- */
.cols{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:20px auto}
.col{
  background:linear-gradient(135deg,#111728,#0d1220);
  padding:24px; border:1px solid var(--line); border-radius:16px;
  text-align:center; font-weight:700; transition:border-color .15s ease, transform .08s ease;
}
.col:hover{border-color:var(--brand); transform:translateY(-2px)}

/* --------- SHOP (filtros + grid) --------- */
.shop{display:grid; grid-template-columns:260px 1fr; gap:20px}
.filters{
  background:var(--panel); border:1px solid var(--line); padding:16px; border-radius:16px;
  position:sticky; top:74px; height:fit-content; box-shadow:var(--shadow)
}
.filters h3{margin:0 0 8px}
.filters .btn{width:100%; margin-top:8px}
.grid{
  display:grid; gap:16px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.card{
  background:var(--card); border:1px solid var(--line); border-radius:16px; overflow:hidden;
  display:flex; flex-direction:column; transition:border-color .15s ease, transform .08s ease;
}
.card:hover{border-color:var(--brand); transform:translateY(-2px)}
.card img{width:100%; aspect-ratio:4/3; object-fit:cover; background:#0b0e13}
.card .p{padding:12px}
.card .name{font-weight:700; line-height:1.25; min-height:2.5em}
.card .meta{color:var(--muted); font-size:12px; margin-top:4px}
.card .price{display:flex; gap:8px; align-items:center; margin-top:8px}
.card .was{text-decoration:line-through; color:var(--muted)}
.card .now{font-weight:800}

/* --------- PRODUCT --------- */
.product{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.gallery{display:grid; gap:10px}
.gallery img{width:100%; border-radius:12px; border:1px solid var(--line)}
.info .meta{color:var(--muted); margin:8px 0}
.price{display:flex; gap:10px; align-items:baseline}
.price .was{color:var(--muted); text-decoration:line-through}
.info form{display:grid; gap:10px; max-width:420px}

/* --------- CART / CHECKOUT / DOC --------- */
.cart .cart-actions{display:flex; gap:10px; margin-top:12px}
.doc .tbl{width:100%}

/* --------- Tablas --------- */
.tbl{
  width:100%; border-collapse:separate; border-spacing:0; margin:10px 0;
  border:1px solid var(--line); border-radius:14px; overflow:hidden;
}
.tbl th,.tbl td{padding:10px 12px; border-bottom:1px solid var(--line)}
.tbl thead th{background:#0f1526; text-align:left}
.tbl tr:last-child td{border-bottom:none}

/* --------- Admin layout (legacy) --------- */
.admin{display:grid; grid-template-columns:220px 1fr; gap:18px}
.aside{
  background:var(--panel); border:1px solid var(--line); border-radius:16px; padding:12px; height:fit-content;
}
.aside a{display:block; padding:10px 12px; border-radius:12px; color:var(--ink)}
.aside a.active, .aside a:hover{background:#0f1424; border:1px solid var(--line)}
.board{background:var(--panel); border:1px solid var(--line); border-radius:16px; padding:18px}
.kpis{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:16px 0}
.kpi{background:#0f1420; border:1px solid var(--line); border-radius:14px; padding:16px}
.kpi span{font-size:22px; font-weight:800; display:block}

/* --------- Uploads / imágenes en admin --------- */
.dropzone{
  background:#0e1320; border:1px dashed var(--line); border-radius:16px; padding:20px; text-align:center;
  color:var(--muted);
}
.imgs{display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-top:10px}
.imgs figure{margin:0; background:#0e1320; border:1px solid var(--line); border-radius:12px; overflow:hidden}
.imgs img{width:100%; display:block}
.imgs .danger{display:block; text-align:center; padding:8px; color:#ffdbe4; background:#2b1520}

/* --------- AUTH (login moderno) --------- */
.auth{
  min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px;
  background:
    radial-gradient(900px 500px at 110% -10%, rgba(92,255,150,.12), transparent),
    radial-gradient(900px 500px at -10% 110%, rgba(0,240,255,.10), transparent);
}
.card{
  background:var(--glass); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:24px; width:100%; max-width:420px; box-shadow:var(--shadow);
  backdrop-filter: blur(12px);
}
.card h1{font-size:26px; margin:0 0 4px}
.subtle{color:var(--muted); font-size:13px; margin:0 0 12px}

/* Inputs con iconos en login */
.input{position:relative; margin:12px 0}
.input input{padding-left:44px; height:46px}
.input .ico{
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  width:18px; height:18px; color:var(--muted); opacity:.9;
}
.input .eye{
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  background:transparent; border:0; color:var(--muted); cursor:pointer; font-size:16px;
}

/* Alerts */
.alert{
  background:#2b1520; color:#ffd9e0; border:1px solid #4b1c2b;
  padding:10px; border-radius:12px; margin:10px 0;
}

/* --------- Footer --------- */
.foot{border-top:1px solid var(--line); margin-top:30px}
.fcols{display:flex; justify-content:space-between; align-items:center; gap:12px}

/* --------- Responsive (general) --------- */
@media (max-width:1100px){
  .wrap{padding:16px}
}
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr}
  .cols{grid-template-columns:repeat(2,1fr)}
  .nav-toggle{display:block}
  .menu{
    position:absolute; left:0; right:0; top:58px; background:#0d111c; border-bottom:1px solid var(--line);
    display:none; padding:10px 20px; flex-wrap:wrap; gap:8px
  }
  .menu.show{display:flex}
  .shop{grid-template-columns:1fr}
  .filters{position:relative; top:auto}
  .grid{grid-template-columns:repeat(2,1fr)}
  .product{grid-template-columns:1fr}
  .admin{grid-template-columns:1fr}
}
@media (max-width:560px){
  .cols{grid-template-columns:1fr}
  .btn{width:100%}
  .grid{grid-template-columns:1fr}
}

/* ====== ADMIN MODERNO ====== */
.admin-body{background:
  radial-gradient(1200px 700px at 90% -10%, rgba(0,240,255,.08), transparent),
  radial-gradient(1200px 700px at -10% 110%, rgba(92,255,150,.08), transparent),
  linear-gradient(180deg,#0b0e13,#0a0c11);}

.topbar{
  position:sticky; top:0; z-index:50; display:flex; gap:12px; align-items:center;
  padding:10px 16px; backdrop-filter:blur(10px);
  background:rgba(11,14,19,.65); border-bottom:1px solid var(--line);
}
.bolt{color:var(--brand)}
.brand{font-weight:800}
.sb-toggle{display:none; background:#161a26; color:var(--ink); border:1px solid var(--line); border-radius:10px; padding:8px 10px}
.top-fill{flex:1}
.top-search{
  width:100%; max-width:520px; border:1px solid var(--line); background:#0d1320; color:var(--ink);
  padding:10px 12px; border-radius:12px;
}
.top-actions .btn{margin-left:auto}

/* Layout */
.admin-shell{display:grid; grid-template-columns:260px 1fr; gap:18px; padding:16px}
.aside-nav{
  background:rgba(17,20,30,.7); border:1px solid var(--line); border-radius:16px; padding:12px; height:fit-content;
}
.aside-nav .group{margin-bottom:14px}
.aside-nav .gt{color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.08em; margin:6px 8px}
.aside-nav a{
  display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:12px; color:var(--ink);
  border:1px solid transparent; transition:.15s ease;
}
.aside-nav a .ico{width:18px}
.aside-nav a:hover{background:#0f1424; border-color:var(--line)}
.aside-nav a.active{background:linear-gradient(180deg,#0f1526,#0d1220); border-color:var(--line)}
.aside-nav a.disabled{opacity:.5; pointer-events:none}

.admin-main{min-height:60vh}
.panel{
  background:rgba(18,22,34,.72); border:1px solid var(--line); border-radius:16px; padding:18px; box-shadow:var(--shadow);
}

/* KPIs y accesos rápidos */
.kpis-4{grid-template-columns:repeat(4,1fr)}
.kpi{position:relative}
.kpi-ico{position:absolute; right:12px; top:12px; opacity:.35}
.quick{display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:14px}
.qa{
  display:flex; flex-direction:column; gap:4px; padding:14px; border:1px solid var(--line);
  background:linear-gradient(180deg,#111728,#0d1220); border-radius:14px; font-weight:600;
}
.qa span{color:var(--muted); font-weight:500}
.qa.disabled{opacity:.55; pointer-events:none}

/* Responsive admin */
@media (max-width:980px){
  .admin-shell{grid-template-columns:1fr}
  .sb-toggle{display:inline-flex}
  .aside-nav{display:none; position:fixed; left:12px; right:12px; top:64px; z-index:60}
  .aside-nav.show{display:block}
  .quick{grid-template-columns:repeat(2,1fr)}
  .kpis-4{grid-template-columns:repeat(2,1fr)}
}

/* ====== POLISH VISUAL ADMIN FORMS ====== */

/* Panel y títulos */
.admin-main .panel{ padding:22px 20px; border-radius:20px }
.admin-main .panel h2{ margin:6px 0 12px }

/* Formularios en 2 columnas (12 columnas reales para mejor control) */
.admin-main .panel form.grid2{
  display:grid;
  grid-template-columns:repeat(12, minmax(0,1fr));
  gap:14px 16px; /* vertical / horizontal */
}

/* Cada label ocupa media anchura (6 de 12) */
.admin-main .panel form.grid2 > label{ grid-column:span 6 }
.admin-main .panel form.grid2 > label.grid2{ grid-column:1 / -1 }

/* Textarea más cómoda */
.admin-main .panel form.grid2 textarea{ min-height:160px }

/* Fila del checkbox "Activo" alineada con inputs */
.admin-main .panel form.grid2 .row{
  grid-column:span 6;
  align-items:center; gap:10px; padding-top:26px;
}

/* Botón de acción: que NO se estire a 100% en el grid */
.admin-main .panel form.grid2 > button.btn{
  grid-column:1 / -1 !important; /* que quede al final del form */
  justify-self:start;            /* evita el stretch horizontal */
  width:auto; padding-inline:18px;
}

/* Inputs con feedback suave */
input,select,textarea{
  background:#0f1322; border-color:var(--line);
  box-shadow:none;
}
input:hover,select:hover,textarea:hover{ border-color:#263049 }
input:focus,select:focus,textarea:focus{ border-color:var(--brand); box-shadow:var(--ring) }

/* Checkbox en color del tema */
input[type="checkbox"]{ accent-color:var(--brand2) }

/* Dropzone más visible */
.dropzone{
  border-radius:16px; padding:22px;
  border:1px dashed #273148; color:var(--muted);
}
.dropzone:hover{ border-color:var(--brand) }

/* Tabla de stock: filas aireadas */
.tbl td, .tbl th{ padding:12px 14px }

/* Sidebar y topbar un poco más compactos */
.topbar{ padding:10px 14px }
.aside-nav{ padding:12px }
.aside-nav a{ padding:10px 12px }

/* Feedback dropzone */
.dropzone{ cursor:pointer; position:relative; }
.dropzone.drag{
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(0,240,255,.12) inset;
}

/* Skeleton loader */
.skeleton{
  position:relative; overflow:hidden; border-radius:12px; background:#0f1420;
}
.skeleton::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.06), transparent);
  transform:translateX(-100%); animation:sweep 1.2s linear infinite;
}
@keyframes sweep{ to{ transform:translateX(100%); } }

/* ===== Brand logo (más grande + acento neón) ===== */
.logo{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:900; letter-spacing:.4px;
  font-size:26px; line-height:1;
}
.logo .l1{
  color:#fff;
  filter: drop-shadow(0 0 8px rgba(255,255,255,.10));
}
.logo .l2{
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: 0 0 18px rgba(0,240,255,.20);
}
.logo::before{
  content:""; width:10px; height:10px; border-radius:50%;
  background: var(--brand2);
  box-shadow: 0 0 14px rgba(92,255,150,.8), 0 0 30px rgba(92,255,150,.35);
}

/* tamaños responsivos */
@media (min-width: 1024px){
  .logo{ font-size:30px }
}
@media (min-width: 1440px){
  .logo{ font-size:34px }
}
@media (max-width: 520px){
  .logo{ font-size:22px }
}

/* ===== SHOP WIDE ===== */
.wrap-xl{max-width:1380px;margin:0 auto;padding:20px}
@media (max-width:1480px){ .wrap-xl{max-width:1340px} }
@media (max-width:1320px){ .wrap-xl{max-width:1200px} }

.logo{font-size:28px; font-weight:800; letter-spacing:.2px}
.logo .l1{color:#e9eefc}
.logo .l2{
  margin-left:2px;
  background:linear-gradient(90deg,#00f0ff,#5cff96);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Hero de tienda ancho */
.shop-hero{
  background:radial-gradient(900px 450px at 90% -20%, rgba(0,240,255,.14), transparent),
             radial-gradient(900px 450px at -10% 120%, rgba(92,255,150,.12), transparent),
             linear-gradient(180deg,#111728,#0f1522);
  border:1px solid var(--line);
  border-radius:18px;
  padding:20px 22px;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.shop-hero h1{margin:.1em 0 .3em; font-size:32px}
@media (max-width:560px){ .shop-hero h1{font-size:26px} }

/* Chips fila */
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 10px; border-radius:999px; font-weight:600;
  background:#0c1220; border:1px solid var(--line); color:var(--ink); font-size:12px;
}

/* Shell: filtros + grid (más ancho) */
.shop-shell{display:grid; grid-template-columns:280px 1fr; gap:16px; margin-top:12px}
@media (max-width:980px){ .shop-shell{grid-template-columns:1fr} }

/* Filtros sticky */
.filters-card{
  position:sticky; top:72px;
  background:rgba(17,20,30,.72);
  border:1px solid var(--line); border-radius:16px; padding:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
}
.filters-card h3{margin:0 0 10px}

/* Grid ancho con 4–5 columnas según viewport */
.shop-grid{
  display:grid; gap:16px;
  grid-template-columns:repeat(4, minmax(0,1fr));
}
@media (min-width:1500px){
  .shop-grid{grid-template-columns:repeat(5, minmax(0,1fr))}
}
@media (max-width:1100px){
  .shop-grid{grid-template-columns:repeat(3, minmax(0,1fr))}
}
@media (max-width:760px){
  .shop-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width:520px){
  .shop-grid{grid-template-columns:1fr}
}

/* Cards grandes */
.card{
  background:linear-gradient(180deg,#0f1524,#0c1220);
  border:1px solid var(--line); border-radius:16px; overflow:hidden;
  transition:transform .08s ease, border-color .15s ease;
}
.card:hover{transform:translateY(-2px); border-color:var(--brand)}
.card img{width:100%; aspect-ratio:4/3; object-fit:cover; background:#0b0e13}
.card .p{padding:12px}
.card .name{font-weight:700; line-height:1.25; min-height:2.5em}
.card .meta{color:var(--muted); font-size:12px; margin-top:4px}
.card .price{display:flex; gap:8px; align-items:center; margin-top:8px}
.card .was{text-decoration:line-through; color:var(--muted)}
.card .now{font-weight:800}

/* Barra control derecha de la hero */
.shop-controls{display:flex; gap:8px; align-items:center; flex-wrap:wrap}
.shop-controls .btn{padding:10px 12px; border-radius:12px}

/* assets/admin.css */
:root{
  --aside-w: 250px;
}

/* ===== Layout base admin ===== */
body.admin{background:#0b0e13;color:var(--ink, #e9eefc);}
.wrap-admin{max-width:1100px;margin:0 auto;padding:16px;}

/* Topbar */
.admin-topbar{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:10px; justify-content:space-between;
  height:56px; padding:0 12px;
  background:linear-gradient(180deg,#101520,#0c111a); border-bottom:1px solid var(--line,#19202e);
}
.admin-topbar .logo{font-weight:800; letter-spacing:.2px; text-decoration:none; color:#e9eefc}
.admin-topbar .logo span{color:#32ffd0}
.admin-topbar .sb-toggle{
  appearance:none; border:1px solid var(--line); background:#0f1420; color:#e9eefc;
  width:40px;height:40px;border-radius:12px;font-size:18px;display:inline-grid;place-items:center;
}
.admin-topbar .btn.small{padding:8px 10px;font-size:12px}

/* Aside (desktop) */
.admin-aside{
  position:fixed; left:0; top:56px; bottom:0; width:var(--aside-w);
  background:#0f1420; border-right:1px solid var(--line); padding:12px; overflow:auto;
}
.admin-aside nav{display:grid; gap:6px}
.admin-aside a{display:block; padding:10px 12px; border-radius:10px; color:#cdd5ea; text-decoration:none; border:1px solid transparent}
.admin-aside a:hover{background:#0c1220; border-color:#1b2537}
.admin-aside a.danger{color:#ff6b6b}

/* Main */
.admin-main{padding-left:var(--aside-w); min-height:calc(100dvh - 56px);}

/* ===== Responsivo ===== */
@media (max-width: 1000px){
  .admin-aside{transform:translateX(-100%); transition:transform .25s ease;}
  .admin-aside.show{transform:translateX(0);}
  .admin-main{padding-left:0}
}

/* Formularios: .grid2 pasa a una columna */
.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.grid2 > *[style*="grid-column:1/-1"]{grid-column:1/-1}
@media (max-width: 760px){
  .grid2{grid-template-columns:1fr}
}

/* Inputs “tocables” */
.panel input, .panel select, .panel textarea{
  background:#0f1322;border:1px solid var(--line);color:#e9eefc;
  border-radius:12px;padding:10px 12px; width:100%;
}
.panel textarea{min-height:120px}

/* Botones */
.btn{background:linear-gradient(90deg,#1cf2ae,#34ffd3); color:#07211a;border:0;border-radius:12px;padding:10px 14px;font-weight:700;cursor:pointer}
.btn.ghost{background:transparent;border:1px solid var(--line);color:#e9eefc}
.btn.small{padding:6px 10px;border-radius:10px;font-size:12px}
a.danger, .btn.danger{background:#2a0f15;color:#ff8f8f;border:1px solid #3b1620}

/* Paneles */
.panel{
  background:rgba(18,22,34,.72); border:1px solid var(--line);
  border-radius:16px; padding:16px; box-shadow:0 10px 30px rgba(0,0,0,.35);
}

/* ===== Tabla -> Cards en móvil ===== */
.tbl{width:100%;border-collapse:separate;border-spacing:0}
.tbl th,.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left}
.tbl thead th{background:#0f1526;position:sticky;top:0;z-index:1}

@media (max-width:760px){
  .tbl.responsive thead{display:none}
  .tbl.responsive tbody{display:grid; gap:10px}
  .tbl.responsive tr{
    display:grid; gap:6px;
    border:1px solid var(--line); border-radius:12px; padding:10px; background:#0f1420;
  }
  .tbl.responsive td{
    display:flex; justify-content:space-between; align-items:center; gap:10px;
    border:0; padding:6px 0;
  }
  .tbl.responsive td::before{
    content:attr(data-label);
    color:#9aa6c0; font-weight:600;
  }
  .tbl.responsive .row-actions{display:flex;gap:8px; justify-content:flex-end}
}

