/* ═══════════════════════════════════════════════
   BARBERÍA L&O HÉROES — admin.css
   ═══════════════════════════════════════════════ */
:root {
  --black:  #0a0a0a; --dark:  #111; --dark2: #181818; --dark3: #1e1e1e;
  --dark4:  #252525; --dark5: #333; --gray:  #888;    --gray2: #555;
  --white:  #f5f5f5; --white2:#e0e0e0;
  --gold:   #c9a84c; --gold2: #e6c06a; --gold3:#a07030;
  --gold-bg:rgba(201,168,76,.06); --gold-glow:rgba(201,168,76,.25);
  --danger: #e74c3c; --success:#25D366;
  --sw: 240px;
  --ff-d:'Bebas Neue',sans-serif; --ff-c:'Barlow Condensed',sans-serif; --ff:'Barlow',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94); --r:4px; --rl:10px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--dark);color:var(--white2);font-family:var(--ff);font-size:14px;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none} button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}
.hidden{display:none!important}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--dark5);border-radius:2px}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--gold),var(--gold3));color:var(--black);font-family:var(--ff-c);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.7rem 1.5rem;border:none;border-radius:var(--r);cursor:pointer;transition:all .25s}
.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 15px var(--gold-glow)}
.btn-primary.full-w{width:100%;justify-content:center}
.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:var(--white2);font-family:var(--ff-c);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.7rem 1.5rem;border:1px solid var(--dark5);border-radius:var(--r);cursor:pointer;transition:all .25s}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-danger{display:inline-flex;align-items:center;gap:.5rem;background:rgba(231,76,60,.12);color:var(--danger);border:1px solid rgba(231,76,60,.3);font-family:var(--ff-c);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.7rem 1.5rem;border-radius:var(--r);cursor:pointer;transition:all .25s}
.btn-danger:hover{background:rgba(231,76,60,.2)}
.btn-danger-sm{display:inline-flex;align-items:center;gap:.4rem;background:transparent;color:var(--danger);border:1px solid rgba(231,76,60,.25);font-family:var(--ff-c);font-size:.75rem;font-weight:600;padding:.5rem 1rem;border-radius:var(--r);cursor:pointer;transition:all .2s}
.btn-danger-sm:hover{background:rgba(231,76,60,.1)}

/* FORM */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-family:var(--ff-c);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);margin-bottom:.4rem}
.input-hint{font-size:.72rem;color:var(--gray2);margin-bottom:.4rem;line-height:1.4}
.form-group input,.form-group select{width:100%;background:var(--dark3);border:1px solid var(--dark5);color:var(--white);padding:.7rem .9rem;border-radius:var(--r);font-size:.9rem;transition:border-color .2s}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--gold3);box-shadow:0 0 0 3px rgba(201,168,76,.1)}

/* LOGOS */
.logo-l{font-family:var(--ff-d);font-size:1.8rem;color:var(--gold);letter-spacing:.05em;line-height:1}
.logo-sub{font-family:var(--ff-c);font-size:.55rem;letter-spacing:.4em;color:var(--gray);text-transform:uppercase;display:block}

/* ── LOGIN ── */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 50%,rgba(201,168,76,.05)0%,transparent 60%),var(--black);padding:1.5rem}
.login-card{background:var(--dark2);border:1px solid var(--dark5);border-radius:var(--rl);padding:3rem 2.5rem;width:100%;max-width:420px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo .logo-sub{text-align:center;margin-top:.25rem}
.pass-wrap{position:relative}
.pass-wrap input{padding-right:3rem}
.eye-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6;transition:opacity .2s}
.eye-btn:hover{opacity:1}
.login-error{color:var(--danger);font-size:.82rem;margin-bottom:.75rem;min-height:1.2rem}
.login-back{text-align:center;margin-top:1.5rem;font-size:.8rem;color:var(--gray)}
.login-back a:hover{color:var(--gold)}

/* ── DASHBOARD ── */
.dashboard{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--dark2);border-right:1px solid var(--dark5);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;overflow-y:auto;transition:transform .3s var(--ease)}
.sidebar-logo{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--dark5);margin-bottom:.5rem}
.sidebar-nav{flex:1;padding:.5rem;display:flex;flex-direction:column;gap:.2rem}
.snav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.7rem 1rem;border-radius:var(--r);background:transparent;border:none;color:var(--gray);font-family:var(--ff-c);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500;transition:all .2s;text-align:left;cursor:pointer;position:relative}
.snav-item:hover,.snav-item.active{background:var(--gold-bg);color:var(--white)}
.snav-item.active{color:var(--gold);border-left:2px solid var(--gold)}
.snav-icon{font-size:1rem;flex-shrink:0}
.snav-badge{background:var(--gold);color:var(--black);font-size:.65rem;font-weight:700;padding:.15rem .4rem;border-radius:10px;min-width:18px;text-align:center;margin-left:.25rem}
.sidebar-bottom{padding:.5rem;border-top:1px solid var(--dark5);display:flex;flex-direction:column;gap:.2rem}
.logout-btn{color:var(--danger)!important}
.logout-btn:hover{background:rgba(231,76,60,.08)!important}
.dash-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--dark2);border-bottom:1px solid var(--dark5);z-index:99;align-items:center;padding:0 1rem;gap:1rem}
.sidebar-toggle{background:none;border:none;color:var(--white);font-size:1.2rem;cursor:pointer;padding:.25rem}
.dash-title{font-family:var(--ff-c);font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;color:var(--white);flex:1}
.dash-user{font-family:var(--ff-c);font-size:.75rem;color:var(--gold);letter-spacing:.1em}
.dash-main{margin-left:var(--sw);flex:1;padding:2rem;min-height:100vh}
.tab{display:block}.tab.hidden{display:none}
.tab-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}
.dash-section-title{font-family:var(--ff-d);font-size:1.6rem;color:var(--white);letter-spacing:.04em;margin-bottom:1.5rem}
.tab-actions{display:flex;gap:.75rem;align-items:center}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}
.kpi-card{background:var(--dark3);border:1px solid var(--dark5);border-radius:var(--rl);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:border-color .2s}
.kpi-card:hover{border-color:rgba(201,168,76,.2)}
.kpi-icon{font-size:1.8rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--gold-bg);border-radius:var(--r);flex-shrink:0}
.kpi-num{font-family:var(--ff-d);font-size:1.8rem;color:var(--gold);line-height:1}
.kpi-label{font-family:var(--ff-c);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}

/* Quick actions */
.quick-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}
.qa-btn{background:var(--dark3);border:1px solid var(--dark5);color:var(--white2);font-family:var(--ff-c);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;padding:.6rem 1.2rem;border-radius:var(--r);cursor:pointer;transition:all .2s}
.qa-btn:hover{border-color:var(--gold3);color:var(--gold);background:var(--gold-bg)}

/* TABLE */
.table-wrap{background:var(--dark3);border:1px solid var(--dark5);border-radius:var(--rl);overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead th{padding:.9rem 1rem;text-align:left;font-family:var(--ff-c);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray);border-bottom:1px solid var(--dark5);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--dark5);transition:background .15s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:rgba(255,255,255,.02)}
tbody td{padding:.9rem 1rem;font-size:.88rem;color:var(--white2);vertical-align:middle}
.empty-row td{text-align:center;color:var(--gray);padding:2.5rem;font-style:italic}
.badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-family:var(--ff-c);font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.badge-pending{background:rgba(255,180,0,.1);color:#ffb400;border:1px solid rgba(255,180,0,.2)}
.badge-confirmed{background:rgba(37,211,102,.1);color:#25D366;border:1px solid rgba(37,211,102,.2)}
.badge-cancelled{background:rgba(231,76,60,.1);color:#e74c3c;border:1px solid rgba(231,76,60,.2)}
.row-actions{display:flex;gap:.4rem;align-items:center}
.action-btn{background:transparent;border:1px solid var(--dark5);color:var(--gray);padding:.3rem .6rem;border-radius:var(--r);font-size:.75rem;cursor:pointer;transition:all .15s}
.action-btn:hover{border-color:var(--gold3);color:var(--gold)}
.action-btn.danger:hover{border-color:rgba(231,76,60,.4);color:var(--danger)}
.filter-row{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}
.search-input{flex:1;min-width:200px;background:var(--dark3);border:1px solid var(--dark5);color:var(--white);padding:.65rem .9rem;border-radius:var(--r);font-size:.88rem;transition:border-color .2s}
.search-input:focus{outline:none;border-color:var(--gold3)}
.filter-select{background:var(--dark3);border:1px solid var(--dark5);color:var(--white);padding:.65rem .9rem;border-radius:var(--r);font-size:.88rem;cursor:pointer}

/* SETTINGS CARD */
.settings-card{background:var(--dark3);border:1px solid var(--dark5);border-radius:var(--rl);padding:2rem;margin-bottom:1.5rem}
.settings-card h3{font-family:var(--ff-d);font-size:1.3rem;color:var(--white);margin-bottom:1.5rem;letter-spacing:.04em}
.settings-desc{color:var(--gray);font-size:.88rem;line-height:1.6;margin-bottom:1.5rem;padding:1rem;background:rgba(255,255,255,.03);border-radius:var(--r);border-left:3px solid var(--gold3)}
.settings-msg{margin-top:.75rem;font-size:.82rem;padding:.6rem .9rem;border-radius:var(--r);display:none}
.settings-msg.success{display:block;background:rgba(37,211,102,.1);color:#25D366;border:1px solid rgba(37,211,102,.2)}
.settings-msg.error{display:block;background:rgba(231,76,60,.1);color:#e74c3c;border:1px solid rgba(231,76,60,.2)}
.danger-card{border-color:rgba(231,76,60,.2)}
.danger-card h3{color:var(--danger)}
.danger-card p{color:var(--gray);margin-bottom:1.25rem;font-size:.9rem}

/* WA PREVIEW */
.wa-preview{background:var(--dark4);border:1px solid var(--dark5);border-radius:var(--r);padding:.75rem 1rem;margin-bottom:1.25rem}
.wa-preview-label{font-family:var(--ff-c);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray);display:block;margin-bottom:.25rem}
.wa-preview-link{font-size:.8rem;color:var(--gold);word-break:break-all}

/* RADIO GROUP (Instagram mode) */
.radio-group{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:.5rem}
.radio-option{cursor:pointer}
.radio-option input{display:none}
.radio-card{background:var(--dark4);border:2px solid var(--dark5);border-radius:var(--rl);padding:1.25rem;display:flex;flex-direction:column;gap:.4rem;transition:all .2s;cursor:pointer}
.radio-option input:checked + .radio-card{border-color:var(--gold);background:var(--gold-bg)}
.radio-card:hover{border-color:var(--gold3)}
.radio-icon{font-size:1.5rem}
.radio-card strong{color:var(--white);font-size:.9rem}
.radio-card small{color:var(--gray);font-size:.78rem;line-height:1.4}

/* UPLOAD ZONE */
.upload-zone{border:2px dashed var(--dark5);border-radius:var(--rl);padding:3rem;text-align:center;cursor:pointer;transition:all .3s;background:var(--dark3);margin-bottom:1.5rem}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--gold3);background:var(--gold-bg)}
.upload-icon{font-size:3rem;margin-bottom:1rem}
.upload-text{color:var(--gray);margin-bottom:1rem;font-size:.9rem}
.upload-label{cursor:pointer}
.upload-hint{color:var(--gray2);font-size:.75rem;margin-top:.75rem}

/* GALLERY ADMIN GRID */
.gallery-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}
.admin-gallery-item{position:relative;aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--dark3);border:1px solid var(--dark5)}
.admin-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}
.admin-gallery-item .item-actions{position:absolute;inset:0;background:rgba(0,0,0,.7);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;opacity:0;transition:opacity .2s}
.admin-gallery-item:hover .item-actions{opacity:1}

/* IG ADMIN GRID */
.ig-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;margin-top:1rem}
.ig-admin-item{position:relative;border-radius:var(--r);overflow:hidden;background:var(--dark4);border:1px solid var(--dark5)}
.ig-admin-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.ig-admin-item .ig-item-bar{display:flex;align-items:center;justify-content:space-between;padding:.4rem .5rem;background:var(--dark3);gap:.25rem}
.ig-reel-toggle{display:flex;align-items:center;gap:.3rem;font-family:var(--ff-c);font-size:.65rem;color:var(--gray);letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.ig-reel-toggle input{width:12px;height:12px;accent-color:var(--gold)}

/* VIDEO ADMIN */
.video-admin-list{display:flex;flex-direction:column;gap:1rem}
.video-admin-item{background:var(--dark3);border:1px solid var(--dark5);border-radius:var(--rl);padding:1rem;display:flex;align-items:center;gap:1rem}
.video-admin-thumb{width:100px;height:60px;border-radius:var(--r);overflow:hidden;flex-shrink:0;background:var(--dark4)}
.video-admin-thumb video{width:100%;height:100%;object-fit:cover}
.video-admin-info{flex:1}
.video-admin-name{font-weight:600;color:var(--white);font-size:.9rem;margin-bottom:.2rem}
.video-admin-size{font-size:.75rem;color:var(--gray)}
.video-badge-active{background:rgba(37,211,102,.1);color:#25D366;border:1px solid rgba(37,211,102,.2);font-family:var(--ff-c);font-size:.65rem;padding:.15rem .4rem;border-radius:3px;letter-spacing:.08em;text-transform:uppercase}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:9999;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);padding:1rem}
.modal-box{background:var(--dark2);border:1px solid var(--dark5);border-radius:var(--rl);padding:2rem;max-width:400px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-title{font-family:var(--ff-d);font-size:1.3rem;color:var(--white);margin-bottom:.75rem}
.modal-body{color:var(--gray);font-size:.9rem;margin-bottom:1.5rem;line-height:1.6}
.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}

/* RESPONSIVE */
@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:8px 0 30px rgba(0,0,0,.5)}
  .dash-header{display:flex}
  .dash-main{margin-left:0;padding:5rem 1rem 2rem}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .filter-row{flex-direction:column}
  .search-input{min-width:unset}
  table{font-size:.8rem}
  tbody td,thead th{padding:.7rem .6rem}
  .radio-group{grid-template-columns:1fr}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .login-card{padding:2rem 1.5rem}
  .settings-card{padding:1.5rem}
}
