/* ===== Pereira Festival Dance 2026 — Design System ===== */
:root{
  --orange:#ff9100; --orange-2:#ffb300; --orange-soft:#ffa726;
  --bg:#0b0b0c; --bg-2:#151517; --card:#1a1a1d; --line:#2a2a2e;
  --text:#f5f5f5; --muted:#a8a8ad; --ok:#16a34a; --warn:#d97706; --err:#dc2626;
  --radius:16px; --shadow:0 10px 40px -12px rgba(255,145,0,.25);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Montserrat',system-ui,sans-serif;
  background:radial-gradient(1200px 600px at 50% -10%,#1a1206 0%,var(--bg) 55%);
  color:var(--text);min-height:100vh;
}
a{color:var(--orange-soft);text-decoration:none}
a:hover{color:var(--orange-2)}
.container{max-width:1180px;margin:0 auto;padding:0 20px}
.section{padding:64px 0}
h1,h2,h3{font-weight:900;letter-spacing:.5px;margin:0 0 .4em}
.text-orange{color:var(--orange)}
.muted{color:var(--muted)}

/* Brand */
.brand{font-weight:900;font-size:1.15rem;color:var(--orange);letter-spacing:1px;display:flex;align-items:center;gap:10px;text-decoration:none}
.brand img{height:40px;border-radius:10px}

/* ===== Barra lateral deslizable ===== */
.edge-trigger{position:fixed;top:0;left:0;width:20px;height:100vh;z-index:55}
.menu-toggle{position:fixed;top:16px;left:16px;z-index:60;width:48px;height:48px;border:none;cursor:pointer;
  border-radius:13px;font-size:1.5rem;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(90deg,var(--orange),var(--orange-2));color:#1a1100;
  box-shadow:0 6px 20px -6px var(--orange);transition:.2s}
.menu-toggle:hover{transform:scale(1.06)}
.sidebar-nav{position:fixed;top:0;left:0;width:265px;height:100vh;z-index:70;
  background:linear-gradient(180deg,#141416,#0e0e10);border-right:2px solid var(--orange);
  transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  padding:22px 14px;display:flex;flex-direction:column;box-shadow:8px 0 40px -10px #000a}
.sidebar-nav.open{transform:translateX(0)}
.sidebar-nav .brand{padding:0 8px 6px;margin-bottom:14px}
.sidebar-links{display:flex;flex-direction:column;gap:3px;flex:1}
.sidebar-links a{display:flex;align-items:center;gap:12px;color:#d6d6da;padding:12px 14px;border-radius:11px;font-weight:600;transition:.18s}
.sidebar-links a:hover{background:#ff910016;color:#fff;transform:translateX(3px)}
.sidebar-links a.sidebar-cta{background:linear-gradient(90deg,var(--orange),var(--orange-2));color:#1a1100;font-weight:800;margin-top:6px;justify-content:center}
.sidebar-links a.sidebar-cta:hover{transform:translateX(0) scale(1.02);color:#000}
.sidebar-sep{height:1px;background:var(--line);margin:10px 6px}
.sidebar-foot{display:flex;gap:16px;justify-content:center;font-size:1.4rem;padding-top:14px;border-top:1px solid var(--line)}
.sidebar-foot a{color:var(--orange-soft)}
.sidebar-backdrop{position:fixed;inset:0;background:#000a;z-index:65;opacity:0;visibility:hidden;transition:.28s}
.sidebar-backdrop.open{opacity:1;visibility:visible}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;
  font-weight:800;border-radius:12px;padding:12px 22px;font-size:.98rem;transition:.2s;
  text-decoration:none;line-height:1}
.btn-primary{background:linear-gradient(90deg,var(--orange),var(--orange-2));color:#1a1100;
  box-shadow:0 6px 20px -6px var(--orange)}
.btn-primary:hover{transform:translateY(-2px);color:#000;box-shadow:0 10px 28px -6px var(--orange)}
.btn-ghost{background:transparent;color:var(--orange-soft);border:1.5px solid #ff910066}
.btn-ghost:hover{background:#ff910014;color:#fff}
.btn-dark{background:#26262b;color:#fff;border:1px solid var(--line)}
.btn-dark:hover{background:#303036}
.btn-sm{padding:7px 14px;font-size:.85rem;border-radius:9px}
.btn-block{width:100%;justify-content:center}
.btn-ok{background:var(--ok);color:#fff}
.btn-err{background:var(--err);color:#fff}

/* Cards */
.card{background:linear-gradient(180deg,#1c1c20,#161619);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.card-hover:hover{border-color:#ff910066;transform:translateY(-3px);transition:.2s}
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Hero — video de fondo a pantalla completa, contenido centrado */
.hero{position:relative;text-align:center;overflow:hidden;border-bottom:3px solid var(--orange);
  min-height:76vh;display:flex;align-items:center;justify-content:center;padding:54px 0}
.hero-video{position:absolute;inset:0;z-index:0}
.hero-video video{width:100%;height:100%;object-fit:cover;opacity:.42}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:radial-gradient(75% 75% at 50% 32%,rgba(11,11,12,.30),rgba(11,11,12,.93))}
.hero-content{position:relative;z-index:2;padding:20px;width:100%;max-width:860px;margin:0 auto}
.hero-content img.hero-logo{height:118px}
@media(max-width:768px){.hero{min-height:auto;padding:40px 0}.hero-content img.hero-logo{height:88px}}
.hero h1{font-size:clamp(2rem,5vw,3.6rem);color:#fff;text-shadow:0 4px 30px #ff910066}
.hero .lead{font-size:1.15rem;color:#ffcf9e;max-width:640px;margin:0 auto 26px}
.badge-live{display:inline-flex;align-items:center;gap:8px;background:#ff910020;color:var(--orange);
  border:1px solid #ff910055;padding:7px 16px;border-radius:999px;font-weight:800;font-size:.9rem;margin-bottom:18px}
.badge-live .dot{width:9px;height:9px;border-radius:50%;background:var(--orange);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* Pricing */
.price-table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:14px}
.price-table th,.price-table td{padding:14px 16px;text-align:center;border-bottom:1px solid var(--line)}
.price-table th{background:var(--orange);color:#1a1100;font-weight:800}
.price-table td:first-child{text-align:left;font-weight:700}
.price-table tr:hover td{background:#ff91000a}
.price-now{color:var(--orange);font-weight:900;font-size:1.05rem}

/* Forms */
.field{margin-bottom:16px}
.label{display:block;color:var(--orange-soft);font-weight:700;font-size:.9rem;margin-bottom:6px}
.input,.select,textarea.input{width:100%;background:#232328;color:#fff;border:1.5px solid #3a3a40;
  border-radius:11px;padding:12px 14px;font-size:.98rem;font-family:inherit;transition:.15s}
.input:focus,.select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px #ff910022}
.help{font-size:.8rem;color:var(--muted);margin-top:4px}

/* Alerts */
.alert{padding:13px 18px;border-radius:12px;margin-bottom:18px;font-weight:600;border:1px solid}
.alert-ok{background:#16a34a18;color:#86efac;border-color:#16a34a55}
.alert-err{background:#dc262618;color:#fca5a5;border-color:#dc262655}
.alert-info{background:#ff910014;color:#ffcf9e;border-color:#ff910044}

/* Steps */
.steps{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.step{flex:1;min-width:120px;padding:10px;border-radius:10px;background:#1d1d21;border:1px solid var(--line);
  text-align:center;font-size:.85rem;color:var(--muted)}
.step.active{border-color:var(--orange);color:var(--orange);background:#ff91000f;font-weight:800}
.step.done{border-color:var(--ok);color:#86efac}

/* Tables (admin) */
.table{width:100%;border-collapse:collapse;font-size:.92rem}
.table th,.table td{padding:11px 12px;text-align:left;border-bottom:1px solid var(--line)}
.table th{color:var(--orange-soft);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px}
.table tr:hover td{background:#ffffff05}
.table img.thumb{height:42px;border-radius:8px;border:1px solid var(--line)}

/* KPI */
.kpi{padding:22px;border-radius:14px;background:linear-gradient(135deg,#1d1d21,#161619);border:1px solid var(--line)}
.kpi .num{font-size:2.1rem;font-weight:900;color:var(--orange)}
.kpi .lbl{color:var(--muted);font-size:.85rem;font-weight:600;margin-top:4px}

/* Admin layout */
.admin{display:flex;min-height:100vh}
.sidebar{width:240px;background:#121214;border-right:1px solid var(--line);padding:20px 14px;position:sticky;top:0;height:100vh}
.sidebar .brand{font-size:1.05rem;margin-bottom:22px;padding:0 8px}
.sidebar a{display:flex;align-items:center;gap:11px;color:#cfcfd4;padding:11px 14px;border-radius:10px;font-weight:600;margin-bottom:3px}
.sidebar a:hover{background:#ff910012;color:#fff}
.sidebar a.active{background:linear-gradient(90deg,#ff910022,transparent);color:var(--orange);border-left:3px solid var(--orange)}
.admin-main{flex:1;padding:28px 32px;min-width:0}
.admin-head{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.admin-head h1{margin:0;font-size:1.6rem}
@media(max-width:820px){.admin{flex-direction:column}.sidebar{width:100%;height:auto;position:static;display:flex;flex-wrap:wrap;gap:4px}.sidebar a{margin:0}}

/* Filters bar */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:20px}
.filters .field{margin:0;min-width:150px}

/* QR card */
/* Lista de categorías */
.cat-list{list-style:none;margin:0;padding:0;columns:2;column-gap:24px}
@media(max-width:760px){.cat-list{columns:1}}
.cat-list li{break-inside:avoid;display:flex;align-items:center;gap:9px;padding:9px 4px;border-bottom:1px solid var(--line);font-size:.92rem}
.cat-list li .cat-name{flex:1;font-weight:600}
.cat-list li .cat-tipo{font-size:.72rem;color:var(--muted);background:#ffffff08;padding:2px 8px;border-radius:999px;white-space:nowrap}

.qr-box{text-align:center;padding:22px;border:1.5px dashed #ff910055;border-radius:14px;background:#ff91000a}
.qr-box img{max-width:220px;border-radius:12px;background:#fff;padding:8px}
.chip{display:inline-block;padding:4px 11px;border-radius:999px;background:#ff910018;color:var(--orange);
  border:1px solid #ff910044;font-size:.8rem;font-weight:700}

footer.ft{border-top:1px solid var(--line);padding:26px 0;text-align:center;color:var(--muted);font-size:.88rem;margin-top:40px}
.divider{height:1px;background:var(--line);margin:22px 0}
.center{text-align:center}
.mt{margin-top:18px}.mb{margin-bottom:18px}
.flex{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.between{justify-content:space-between}
