:root {
  --black: #0a0a0a;
  --black-soft: #141414;
  --gold: #C9A227;
  --gold-light: #E8D48B;
  --gold-dark: #9A7B1A;
  --cream: #F7F5F0;
  --cream-dark: #EDE9E0;
  --rose: var(--gold);
  --rose-dark: var(--gold-dark);
  --rose-light: var(--gold-light);
  --glass: rgba(255,255,255,0.88);
  --glass-dark: linear-gradient(180deg, #0a0a0a 0%, #1a1810 100%);
  --shadow: 0 8px 40px rgba(0,0,0,0.12);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Outfit', system-ui, sans-serif;
  --sidebar-w: 260px;
}
[data-theme="dark"] {
  --cream: #0a0a0a;
  --glass: rgba(20,20,20,0.92);
  --shadow: 0 8px 32px rgba(0,0,0,0.5);
  color-scheme: dark;
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--font-body);background:var(--cream);color:#1a1a1a;transition:background .3s,color .3s}
[data-theme="dark"] body{color:#e8e4dc}
h1,h2,h3{font-family:var(--font-display);font-weight:300;letter-spacing:.02em}
.glass{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.4);border-radius:20px;box-shadow:var(--shadow)}
.glass-dark{background:var(--glass-dark);backdrop-filter:blur(20px);color:#f5eef2}
.glass-inner{background:rgba(201,162,39,0.08);border:1px solid rgba(201,162,39,0.2);border-radius:14px;padding:1.25rem}
[data-theme="dark"] .glass{border-color:rgba(255,255,255,0.08)}

/* Loader */
.loader-overlay{position:fixed;inset:0;background:var(--cream);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .4s}
.loader-overlay.hidden{opacity:0;pointer-events:none}
.loader-spinner{width:48px;height:48px;border:3px solid var(--gold-light);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* App layout */
.app-body{overflow-x:hidden}
.app-wrapper{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);min-height:100vh;padding:1.5rem 1rem;display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;background:var(--glass-dark)!important;border-right:1px solid rgba(201,162,39,0.25)}
.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:0 .5rem 1.5rem;border-bottom:1px solid rgba(255,255,255,0.1)}
.sidebar-brand h1{font-size:1.5rem;margin:0;color:#fff}
.sidebar-brand small{opacity:.7;font-size:.7rem}
.brand-icon{font-size:1.5rem;color:var(--gold)}
.sidebar-nav{flex:1;margin-top:1.5rem}
.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:rgba(255,255,255,.75);text-decoration:none;border-radius:12px;margin-bottom:.25rem;transition:all .2s}
.nav-item:hover,.nav-item.active{background:rgba(201,162,39,0.2);color:var(--gold-light)}
.sidebar-footer{border-top:1px solid rgba(255,255,255,.1);padding-top:1rem}
.user-mini{display:flex;align-items:center;gap:.75rem;padding:.5rem;margin-bottom:.5rem}
.user-mini .avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-dark));display:flex;align-items:center;justify-content:center;color:var(--black);font-weight:600}
.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh}
.topbar{padding:1.25rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;margin:1rem 1rem 0;border-radius:16px}
.page-title{margin:0;font-size:1.75rem}
.content-area{padding:1rem 2rem 2rem}
.topbar-actions{display:flex;align-items:center;gap:.75rem}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}
.stat-card{padding:1.5rem;position:relative;overflow:hidden}
.stat-label{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7;margin-bottom:.5rem}
.stat-value{font-family:var(--font-display);font-size:2rem;color:var(--gold-dark)}
.text-gold{color:var(--gold)!important}
.stat-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:2.5rem;opacity:.15}
.animate-in{animation:fadeUp .5s ease backwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}}

/* Charts */
.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}
.chart-card{padding:1.5rem}
.chart-card h3{margin-top:0;font-size:1.1rem}

/* Cards & forms */
.card-vic{padding:1.5rem;margin-bottom:1.5rem}
.card-header-vic{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}
.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(201,169,184,0.2)}
.form-section h3{font-size:1.1rem;margin-bottom:1rem;color:var(--black)}
.form-label-vic{display:block;font-size:.85rem;margin-bottom:.35rem;font-weight:500}
.form-control-vic{width:100%;padding:.75rem 1rem;border:1px solid rgba(201,162,39,0.35);border-radius:12px;background:rgba(255,255,255,0.8);font-family:inherit;transition:border .2s}
.form-control-vic:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,0.2)}
[data-theme="dark"] .form-control-vic{background:rgba(0,0,0,0.2);color:#f5eef2;border-color:rgba(255,255,255,0.1)}
.btn-victoria{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--black)!important;border:none;border-radius:30px;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .2s,box-shadow .2s}
.btn-victoria:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,162,39,0.4);color:var(--black)!important}
.btn-outline-vic{display:inline-flex;align-items:center;padding:.6rem 1.2rem;border:1px solid var(--gold);color:var(--gold-dark);border-radius:30px;text-decoration:none;background:transparent;cursor:pointer}
.btn-outline-vic.active,.btn-outline-vic:hover{background:rgba(201,162,39,0.12)}
.btn-icon{width:40px;height:40px;border:none;background:rgba(201,162,39,0.15);border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--gold-dark)}
.btn-whatsapp{background:#25D366!important;color:#fff!important;border-radius:30px;padding:.75rem 1.5rem;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;font-weight:500}
.comision-preview{background:linear-gradient(135deg,rgba(10,10,10,0.04),rgba(201,162,39,0.1));border:1px solid rgba(201,162,39,0.3);border-radius:14px;padding:1rem;margin-top:1rem}
.ticket-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.completada-venta .success-icon{font-size:3rem;color:var(--gold)}
.completada-venta .total-line{font-family:var(--font-display);font-size:2rem;color:var(--gold-dark)}
.pedidos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.pedido-card{display:block;padding:1.25rem;text-decoration:none;color:inherit;transition:transform .2s,border-color .2s}
.pedido-card:hover{transform:translateY(-4px);border-color:var(--gold)!important}
.pedido-card h4{margin:.5rem 0;font-family:var(--font-display);color:var(--black)}
.pedido-meta{font-size:.85rem;opacity:.85;margin:.25rem 0}
.pedido-detalles{font-size:.8rem;opacity:.7;margin-top:.5rem}
.filters-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.filters-row .form-control-vic{width:auto;min-width:140px}

/* Payment UI */
.payment-methods{display:flex;flex-wrap:wrap;gap:.75rem}
.pay-option{padding:.75rem 1.25rem;border:2px solid rgba(201,162,39,0.3);border-radius:12px;cursor:pointer;transition:all .2s}
.pay-option:has(input:checked){border-color:var(--gold);background:rgba(201,162,39,0.12)}
.pay-option input{margin-right:.5rem}
.bank-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}
.bank-grid small{display:block;opacity:.7;font-size:.75rem}
.progress-bar-vic{height:10px;background:rgba(201,169,184,0.2);border-radius:10px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-light),var(--gold));border-radius:10px;transition:width .5s ease}
.hint-vic{font-size:.85rem;opacity:.8;margin-top:.75rem}

/* Tables */
.table-vic{width:100%;border-collapse:separate;border-spacing:0}
.table-vic th{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;padding:1rem;color:var(--gold-dark);border-bottom:1px solid rgba(201,162,39,0.25)}
.table-vic td{padding:1rem;border-bottom:1px solid rgba(0,0,0,0.06)}
.badge-estado,.badge-pago{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}
.badge-estado.pendiente,.badge-pago.pendiente{background:#fff3cd;color:#856404}
.badge-estado.en_proceso,.badge-estado.en_revision{background:#cce5ff;color:#004085}
.badge-estado.confirmado,.badge-estado.entregado,.badge-pago.pagado{background:#d4edda;color:#155724}
.badge-estado.rechazado,.badge-estado.cancelado{background:#f8d7da;color:#721c24}
.badge-estado.activo{background:#d4edda;color:#155724}
.badge-estado.inactivo{background:#e2e3e5}

/* Timeline */
.timeline{list-style:none;padding:0;margin:0}
.timeline li{padding:.75rem 0 .75rem 1.5rem;border-left:2px solid rgba(201,169,184,0.3);position:relative;margin-left:.5rem}
.timeline li::before{content:'';width:10px;height:10px;border-radius:50%;background:#ccc;position:absolute;left:-6px;top:1rem}
.timeline li.active::before{background:var(--gold)}
.timeline li.active{border-color:var(--gold)}

/* Guest / Auth */
.guest-body{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative}
.guest-bg{position:fixed;inset:0;background:linear-gradient(145deg,#0a0a0a 0%,#1a1810 40%,#0a0a0a 100%);z-index:-1}
.guest-bg::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23C9A227' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.guest-container{width:100%;max-width:440px;padding:2rem}
.auth-card{padding:2.5rem}
.auth-header{text-align:center;margin-bottom:2rem}
.auth-header h1{font-size:2.5rem;margin:.25rem 0;color:var(--gold)}
.brand-mark{color:var(--gold);font-size:2rem}
.auth-card h2,.auth-header p{color:#e8e4dc}
.auth-card .text-muted{color:rgba(255,255,255,0.6)!important}
.tagline{font-family:var(--font-display);font-size:1.5rem;color:var(--gold-light)}
.landing-hero h1,.landing-hero .tagline{color:var(--gold-light)}
.landing-hero .desc{color:rgba(255,255,255,0.75)}
.landing-hero{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}
.landing-hero .brand-mark.large{font-size:4rem}
.form-floating-vic{position:relative;margin-bottom:1.25rem}
.form-floating-vic input{width:100%;padding:1rem;border:1px solid rgba(201,169,184,0.4);border-radius:12px;background:rgba(255,255,255,0.8)}
.form-floating-vic label{position:absolute;left:1rem;top:1rem;color:#999;transition:all .2s;pointer-events:none}
.form-floating-vic input:focus+label,.form-floating-vic input:not(:placeholder-shown)+label{top:-.5rem;font-size:.75rem;background:var(--cream);padding:0 .25rem;color:var(--rose-dark)}
.form-check-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;font-size:.9rem}
.back-link{display:block;text-align:center;margin-top:1rem;color:var(--rose-dark)}

/* Portal */
.portal-body{background:var(--cream)}
.portal-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;margin:1rem;position:sticky;top:0;z-index:50}
.portal-nav .brand{font-family:var(--font-display);font-size:1.75rem;color:var(--gold-dark);text-decoration:none}
.portal-links{display:flex;gap:1.5rem}
.portal-links a{text-decoration:none;color:#666;font-weight:500}
.portal-links a.active,.portal-links a:hover{color:var(--gold-dark)}
.portal-main{max-width:900px;margin:0 auto;padding:0 1rem 3rem}
.portal-hero{text-align:center;padding:2.5rem;margin-bottom:1.5rem}
.quick-action{display:flex;align-items:center;gap:1rem;padding:1.25rem;text-decoration:none;color:inherit;margin-bottom:1rem;transition:transform .2s}
.quick-action:hover{transform:translateX(4px)}

/* Toast */
.toast-alert{position:fixed;top:1.5rem;right:1.5rem;padding:1rem 1.5rem;border-radius:12px;z-index:10000;animation:slideIn .3s ease;box-shadow:var(--shadow)}
.toast-alert.success{background:#d4edda;color:#155724}
.toast-alert.error{background:#f8d7da;color:#721c24}
.toast-alert.warning{background:#fff3cd;color:#856404}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}}

/* Modal */
.modal-vic{border:none;border-radius:20px}
.modal-vic .modal-header{border:none}
.abono-item{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(201,169,184,0.2)}
.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1.5rem 0}
.detail-grid label{display:block;font-size:.75rem;opacity:.7}
.upload-mini{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.upload-mini input[type=file]{font-size:.75rem}

/* Responsive */
@media(max-width:992px){
  .sidebar{transform:translateX(-100%);transition:transform .3s}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}
}
[x-cloak]{display:none!important}
