/* ============================================================
   VÊNUS STORE — Admin Panel Stylesheet
   ============================================================ */

:root {
  --bg: #0d0d12; --bg2: #131320; --bg3: #1a1a2e; --bg4: #22223a;
  --gold: #c9a96e; --gold-l: #e0c98f; --gold-d: #a38548; --gold-g: rgba(201,169,110,.12);
  --green: #4ade80; --green-bg: rgba(74,222,128,.1);
  --red: #f87171; --red-bg: rgba(248,113,113,.1);
  --blue: #60a5fa; --blue-bg: rgba(96,165,250,.1);
  --yellow: #fbbf24; --yellow-bg: rgba(251,191,36,.1);
  --purple: #a78bfa; --purple-bg: rgba(167,139,250,.1);
  --text: #e8e4df; --text2: #9a958e; --text3: #5e5a54;
  --border: rgba(201,169,110,.1); --border2: rgba(201,169,110,.2);
  --font: 'Outfit', system-ui, sans-serif;
  --display: 'Cormorant Garamond', serif;
  --ease: cubic-bezier(.16,1,.3,1);
  --sidebar-w: 260px;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { background:var(--bg); color:var(--text); font-family:var(--font); font-weight:300; font-size:14px; }
::-webkit-scrollbar { width:5px; } ::-webkit-scrollbar-track { background:var(--bg); } ::-webkit-scrollbar-thumb { background:var(--bg4); border-radius:5px; }

@keyframes fadeIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes shimmer { from{background-position:-400px 0} to{background-position:400px 0} }

.btn-spin { display:inline-block; width:14px; height:14px; border:2px solid rgba(255,255,255,.2); border-top-color:#fff; border-radius:50%; animation:spin .6s linear infinite; vertical-align:middle; }
.skeleton { background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%); background-size:800px 100%; animation:shimmer 1.4s infinite; border-radius:6px; }
.page-loading { padding:8px; animation:fadeIn .3s var(--ease); }

/* ─── LOGIN ──────────────────────────────── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center;
  background: radial-gradient(ellipse at 30% 40%, rgba(108,79,158,.08) 0%, transparent 55%), var(--bg); }
.login-box { width:400px; max-width:90vw; text-align:center; animation:fadeIn .5s var(--ease); }
.login-logo { width:80px; height:80px; border-radius:50%; object-fit:cover; margin:0 auto 20px; border:2px solid var(--border2); }
.login-title { font-family:var(--display); font-size:30px; color:var(--gold); letter-spacing:4px; text-transform:uppercase; margin-bottom:6px; font-weight:400; }
.login-sub { color:var(--text3); font-size:12px; letter-spacing:2px; text-transform:uppercase; margin-bottom:36px; }
.login-form { display:flex; flex-direction:column; gap:14px; }
.login-error { background:var(--red-bg); color:var(--red); padding:12px; font-size:13px; display:none; }
.login-error.show { display:block; }

/* ─── LAYOUT ─────────────────────────────── */
.admin-layout { display:flex; height:100vh; overflow:hidden; }
.sidebar { width:var(--sidebar-w); background:var(--bg2); border-right:1px solid var(--border); position:fixed; top:0; bottom:0; overflow-y:auto; z-index:50; display:flex; flex-direction:column; }
.sidebar-brand { padding:24px; display:flex; align-items:center; gap:12px; border-bottom:1px solid var(--border); }
.sidebar-brand img { width:36px; height:36px; border-radius:50%; border:1px solid var(--border2); }
.sidebar-brand span { font-family:var(--display); font-size:20px; color:var(--gold); letter-spacing:3px; }
.sidebar-nav { padding:16px 12px; flex:1; }
.sidebar-section { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--text3); padding:16px 12px 8px; }
.sidebar-link { display:flex; align-items:center; gap:12px; padding:11px 14px; color:var(--text2); cursor:pointer; transition:all .2s; border-radius:6px; margin-bottom:2px; font-size:13px; font-weight:400; }
.sidebar-link:hover { background:var(--gold-g); color:var(--text); }
.sidebar-link.active { background:var(--gold-g); color:var(--gold); font-weight:500; }
.sidebar-link .icon { font-size:16px; width:20px; text-align:center; }
.sidebar-badge { margin-left:auto; background:var(--red); color:#fff; font-size:10px; font-weight:700; padding:2px 7px; border-radius:10px; }
.sidebar-footer { padding:16px; border-top:1px solid var(--border); }
.sidebar-user { display:flex; align-items:center; gap:10px; }
.sidebar-user-avatar { width:32px; height:32px; border-radius:50%; background:var(--gold-g); display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:14px; font-weight:600; }
.sidebar-user-info { flex:1; }
.sidebar-user-name { font-size:13px; font-weight:500; }
.sidebar-user-role { font-size:11px; color:var(--text3); }

.main-content { flex:1; margin-left:var(--sidebar-w); display:flex; flex-direction:column; height:100vh; overflow:hidden; }
.main-header { flex-shrink:0; padding:20px 32px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; background:var(--bg); z-index:40; }
.main-title { font-family:var(--display); font-size:24px; font-weight:400; }
.main-body { flex:1; overflow-y:auto; padding:28px 32px; }

/* ─── CARDS ──────────────────────────────── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:28px; }
.stat-card { background:var(--bg2); border:1px solid var(--border); padding:24px; transition:all .3s var(--ease); }
.stat-card:hover { border-color:var(--border2); transform:translateY(-2px); }
.stat-label { font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); margin-bottom:8px; }
.stat-value { font-family:var(--display); font-size:32px; font-weight:500; color:var(--gold); }
.stat-sub { font-size:12px; color:var(--text2); margin-top:4px; }
.stat-card.alert .stat-value { color:var(--red); }
.stat-card.success .stat-value { color:var(--green); }

/* ─── TABLE ──────────────────────────────── */
.table-wrap { background:var(--bg2); border:1px solid var(--border); overflow-x:auto; }
.table-header { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.table-title { font-size:16px; font-weight:500; }
.table-actions { display:flex; gap:8px; align-items:center; }
table { width:100%; border-collapse:collapse; }
th { text-align:left; padding:12px 16px; font-size:10.5px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text3); border-bottom:1px solid var(--border); font-weight:500; white-space:nowrap; }
td { padding:14px 16px; border-bottom:1px solid var(--border); font-size:13px; vertical-align:middle; }
tr:hover td { background:rgba(201,169,110,.02); }
.tr-clickable { cursor:pointer; }
.tr-clickable:hover td { background:rgba(201,169,110,.06); }
.td-name { font-weight:500; color:var(--text); }
.td-sku { font-size:11px; color:var(--text3); letter-spacing:1px; }
.td-price { color:var(--gold); font-weight:500; }
.td-promo { color:var(--green); font-weight:500; }

/* ─── BADGES ─────────────────────────────── */
.badge { display:inline-block; padding:4px 10px; font-size:10.5px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; border-radius:3px; }
.badge-pending { background:var(--yellow-bg); color:var(--yellow); }
.badge-confirmed { background:var(--blue-bg); color:var(--blue); }
.badge-preparing { background:var(--purple-bg); color:var(--purple); }
.badge-transit { background:rgba(201,169,110,.1); color:var(--gold); }
.badge-delivered { background:var(--green-bg); color:var(--green); }
.badge-cancelled { background:var(--red-bg); color:var(--red); }
.badge-active { background:var(--green-bg); color:var(--green); }
.badge-inactive { background:var(--red-bg); color:var(--red); }

/* ─── BUTTONS ────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:10px 20px; font-family:var(--font); font-size:12px; font-weight:500; letter-spacing:1px; text-transform:uppercase; border:none; cursor:pointer; transition:all .3s; }
.btn-gold { background:var(--gold); color:var(--bg); }
.btn-gold:hover { background:var(--gold-l); }
.btn-outline { background:transparent; color:var(--text2); border:1px solid var(--border); }
.btn-outline:hover { border-color:var(--gold-d); color:var(--text); }
.btn-sm { padding:7px 14px; font-size:11px; }
.btn-danger { background:var(--red-bg); color:var(--red); border:1px solid rgba(248,113,113,.2); }
.btn-danger:hover { background:rgba(248,113,113,.2); }
.btn-green { background:var(--green-bg); color:var(--green); border:1px solid rgba(74,222,128,.2); }
.btn-green:hover { background:rgba(74,222,128,.2); }
.btn-icon { background:none; border:1px solid var(--border); color:var(--text2); width:34px; height:34px; display:flex; align-items:center; justify-content:center; cursor:pointer; border-radius:4px; transition:all .2s; font-size:14px; }
.btn-icon:hover { border-color:var(--gold-d); color:var(--gold); }
.btn-label { display:inline; }

/* ─── FORMS ──────────────────────────────── */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid.full { grid-template-columns:1fr; }
.form-group { margin-bottom:16px; }
.form-label { display:block; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text2); margin-bottom:6px; font-weight:400; }
.form-input, .form-select, .form-textarea {
  width:100%; padding:11px 14px; background:var(--bg3); border:1px solid var(--border); color:var(--text);
  font-family:var(--font); font-size:13px; outline:none; transition:border-color .3s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--gold-d); }
.form-input::placeholder { color:var(--text3); }
.form-select { cursor:pointer; appearance:none; }
.form-textarea { resize:vertical; min-height:80px; }
.form-check { display:flex; align-items:center; gap:8px; cursor:pointer; }
.form-check input[type="checkbox"] { accent-color:var(--gold); width:16px; height:16px; }

/* ─── TAG RADIO PILLS ────────────────────── */
.tag-radio-group { display:flex; flex-wrap:wrap; gap:8px; }
.tag-radio { cursor:pointer; }
.tag-radio input[type="radio"] { display:none; }
.tag-radio span { display:inline-block; padding:5px 14px; border-radius:20px; font-size:12px; letter-spacing:.8px; border:1px solid var(--border2); color:var(--text2); transition:all .2s; }
.tag-radio:hover span { border-color:var(--gold-d); color:var(--text); }
.tag-radio input:checked + span { background:var(--gold-g); border-color:var(--gold); color:var(--gold); }

/* ─── TOGGLE SWITCH ──────────────────────── */
.toggle-group { display:flex; gap:24px; flex-wrap:wrap; }
.form-toggle { display:flex; align-items:center; gap:10px; cursor:pointer; user-select:none; }
.form-toggle input[type="checkbox"] { display:none; }
.toggle-track { position:relative; width:40px; height:22px; background:var(--bg4); border-radius:11px; border:1px solid var(--border2); transition:all .2s; flex-shrink:0; }
.toggle-thumb { position:absolute; top:3px; left:3px; width:14px; height:14px; background:var(--text3); border-radius:50%; transition:all .2s; }
.form-toggle input:checked + .toggle-track { background:var(--gold-g); border-color:var(--gold-d); }
.form-toggle input:checked + .toggle-track .toggle-thumb { left:21px; background:var(--gold); }
.form-toggle > span:last-child { color:var(--text2); font-size:13px; }
.form-search { position:relative; }
.form-search input { padding-left:36px; }
.form-search::before { content:'⌕'; position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:16px; }

/* ─── MODAL ──────────────────────────────── */
.modal-bg { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:100; display:flex; align-items:center; justify-content:center; padding:20px; animation:fadeIn .2s; backdrop-filter:blur(4px); }
.modal-box { background:var(--bg); border:1px solid var(--border); width:640px; max-width:100%; max-height:90vh; overflow-y:auto; animation:fadeIn .3s var(--ease); }
.modal-top { padding:20px 24px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.modal-top h3 { font-family:var(--display); font-size:22px; font-weight:400; }
.modal-content { padding:24px; }
.modal-actions { padding:16px 24px; border-top:1px solid var(--border); display:flex; gap:10px; justify-content:flex-end; }

/* ─── IMAGE UPLOAD ───────────────────────── */
.img-section { margin-top:20px; padding-top:20px; border-top:1px solid var(--border); }
.img-list { display:flex; flex-wrap:wrap; gap:10px; min-height:36px; margin:10px 0; }
.img-empty, .img-loading { font-size:12px; color:var(--text3); align-self:center; }
.img-thumb { position:relative; width:80px; height:80px; border:1px solid var(--border2); overflow:hidden; flex-shrink:0; }
.img-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.img-thumb-actions { position:absolute; inset:0; background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center; gap:4px; opacity:0; transition:opacity .2s; }
.img-thumb:hover .img-thumb-actions { opacity:1; }
.img-btn-del, .img-btn-main { width:26px; height:26px; border:none; border-radius:50%; cursor:pointer; font-size:12px; display:flex; align-items:center; justify-content:center; }
.img-btn-del { background:var(--red-bg); color:var(--red); }
.img-btn-del:hover { background:var(--red); color:#fff; }
.img-btn-main { background:var(--gold-g); color:var(--gold); }
.img-btn-main:hover { background:var(--gold); color:var(--bg); }
.img-badge-main { position:absolute; bottom:0; left:0; right:0; text-align:center; font-size:9px; background:var(--gold); color:var(--bg); padding:2px 0; font-weight:600; letter-spacing:.5px; }
.img-upload-label { display:inline-flex; align-items:center; gap:8px; cursor:pointer; }
.img-upload-label input[type=file] { display:none; }
.img-upload-label span { padding:8px 16px; border:1px dashed var(--border2); color:var(--text2); font-size:12px; transition:all .2s; }
.img-upload-label:hover span, .img-upload-label.uploading span { border-color:var(--gold); color:var(--gold); }
.img-hint { font-size:11px; color:var(--text3); margin-top:6px; }

/* ─── FILTERS ────────────────────────────── */
.filter-row { display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.filter-chip { padding:8px 16px; font-size:11px; letter-spacing:1px; text-transform:uppercase; background:transparent; border:1px solid var(--border); color:var(--text2); cursor:pointer; transition:all .2s; font-family:var(--font); }
.filter-chip:hover { border-color:var(--gold-d); }
.filter-chip.active { background:var(--gold); color:var(--bg); border-color:var(--gold); font-weight:500; }

/* ─── ORDER DETAIL ───────────────────────── */
.order-detail-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:24px; }
.detail-section { background:var(--bg3); border:1px solid var(--border); padding:20px; }
.detail-section h4 { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:14px; }
.detail-row { display:flex; justify-content:space-between; padding:6px 0; font-size:13px; }
.detail-row .label { color:var(--text3); }
.detail-row .value { color:var(--text); font-weight:400; }
.timeline { border-left:2px solid var(--border); margin-left:8px; padding-left:20px; }
.timeline-item { margin-bottom:16px; position:relative; }
.timeline-item::before { content:''; position:absolute; left:-25px; top:4px; width:10px; height:10px; border-radius:50%; background:var(--bg4); border:2px solid var(--gold-d); }
.timeline-item:last-child::before { background:var(--gold); }
.timeline-time { font-size:11px; color:var(--text3); }
.timeline-text { font-size:13px; margin-top:2px; }
.timeline-admin { font-size:11px; color:var(--text3); font-style:italic; }

/* ─── STATUS SELECT ──────────────────────── */
.status-select { display:flex; gap:8px; flex-wrap:wrap; margin:12px 0; }
.status-opt { padding:8px 14px; font-size:11px; letter-spacing:1px; text-transform:uppercase; border:1px solid var(--border); background:transparent; color:var(--text2); cursor:pointer; transition:all .2s; font-family:var(--font); }
.status-opt:hover { border-color:var(--gold-d); }
.status-opt.active { background:var(--gold); color:var(--bg); border-color:var(--gold); }
.status-opt[data-s="cancelado"].active { background:var(--red); border-color:var(--red); color:#fff; }
.status-opt[data-s="entregue"].active { background:var(--green); border-color:var(--green); color:var(--bg); }

/* ─── SPINNER ────────────────────────────── */
.spinner { width:28px; height:28px; border:2px solid var(--border); border-top-color:var(--gold); border-radius:50%; animation:spin .7s linear infinite; margin:30px auto; }

/* ─── EMPTY ──────────────────────────────── */
.empty-state { text-align:center; padding:60px 20px; color:var(--text3); }
.empty-icon { font-size:40px; margin-bottom:12px; opacity:.3; }

/* ─── TOAST ──────────────────────────────── */
.admin-toast { position:fixed; bottom:24px; right:24px; background:var(--bg3); border:1px solid var(--gold-d); padding:14px 24px; z-index:500; animation:fadeIn .3s var(--ease); font-size:13px; display:flex; align-items:center; gap:10px; box-shadow:0 10px 40px rgba(0,0,0,.4); }
.admin-toast .t-icon { color:var(--gold); }

/* ─── HAMBURGER ──────────────────────────────── */
.btn-menu { display:none; }

/* ─── SIDEBAR OVERLAY ────────────────────────── */
.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:49; }
.sidebar-overlay.show { display:block; }

/* ─── RESPONSIVE ─────────────────────────── */
@media (max-width:900px) {
  .btn-menu { display:flex; }
  .sidebar { width:var(--sidebar-w); transform:translateX(-100%); transition:transform .3s var(--ease); }
  .sidebar.open { transform:translateX(0); }
  .main-content { margin-left:0; }
  .main-header { padding:16px 20px; }
  .main-body { padding:20px 16px; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .order-detail-grid { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .table-header { flex-direction:column; align-items:flex-start; }
  .filter-row { gap:6px; }
  /* tabelas: scroll interno, células menores */
  .table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  th { padding:10px 12px; font-size:10px; }
  td { padding:10px 12px; font-size:12px; }
  .stat-card { padding:16px; }
  .stat-value { font-size:26px; }
}

@media (max-width:480px) {
  /* botões: ocultar texto, manter ícone; aumentar fonte e reduzir padding */
  .btn-label { display:none; }
  .btn.btn-gold { font-size:15px; padding:10px 14px; letter-spacing:0; }
  .btn.btn-gold.btn-sm { font-size:14px; padding:9px 12px; }
  /* cards: mínimo 2 por linha sempre */
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .stat-card { padding:14px 12px; }
  .stat-value { font-size:22px; }
  .stat-label { font-size:10px; }
  /* main body sem padding lateral excessivo */
  .main-body { padding:14px 10px; }
  /* tabelas: colunas ainda menores */
  th { padding:8px 10px; font-size:9.5px; }
  td { padding:9px 10px; font-size:11.5px; }
  .modal-box { width:100%; max-height:100vh; }
  .modal-bg { padding:0; align-items:flex-end; }
  .table-header { gap:10px; }
  .table-actions { flex-wrap:wrap; }
}
