:root {
  --black: #1a0f14;
  --black-soft: #2a121c;
  --silver: #e8c4cf;
  --silver-light: #f8e8ed;
  --rose: #e8a4b8;
  --rose-light: #fce8ef;
  --rose-dark: #c97b92;
  --rose-deep: #5c2a3a;
  --rose-muted: #f5d0dc;
  --gold: var(--rose);
  --gold-light: var(--rose-light);
  --gold-dark: var(--rose-dark);
  --champagne: #f5d0dc;
  --cream: #fdf7f9;
  --cream-dark: #f5e6eb;
  --text-main: #2d1a22;
  --text-soft: #7a5c66;
  --card-bg: rgba(255,255,255,0.96);
  --card-border: rgba(232,164,184,0.32);
  --accent-rgb: 232, 164, 184;
  --line-soft: rgba(45,26,34,0.08);
  --glass-dark: linear-gradient(180deg, #1a0f14 0%, #2d1520 50%, #3a1a28 100%);
  --shadow: 0 8px 40px rgba(201,123,146,0.14);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Outfit', system-ui, sans-serif;
  --sidebar-w: 260px;
}

html[data-theme="dark"] {
  --rose: #f0b8ca;
  --rose-light: #fce8ef;
  --rose-dark: #e8a4b8;
  --rose-muted: #f5d0dc;
  --gold: var(--rose);
  --gold-light: var(--rose-light);
  --gold-dark: var(--rose-dark);
  --accent-rgb: 240, 180, 198;
  --cream: #12090d;
  --text-main: #fce8ef;
  --text-soft: #e0b0c0;
  --card-bg: rgba(32,18,26,0.97);
  --card-border: rgba(240,180,198,0.18);
  --line-soft: rgba(255,255,255,0.08);
  --glass-dark: linear-gradient(180deg, #12090d 0%, #2a1520 48%, #351a26 100%);
  --shadow: 0 8px 32px rgba(0,0,0,0.55);
  color-scheme: dark;
}

*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--font-body);background:var(--cream);color:var(--text-main);transition:background .3s,color .3s}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:300;letter-spacing:.02em}
a{color:inherit}
.text-muted{color:var(--text-soft)!important}
.text-gold,.text-rose{color:var(--rose)!important}
.glass,.card-vic,.chart-card,.stat-card,.topbar,.portal-nav,.quick-action{background:var(--card-bg)}
.glass{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow)}
.glass-dark{background:var(--glass-dark);backdrop-filter:blur(20px);color:#f5eef2}
.glass-inner{background:rgba(var(--accent-rgb),0.08);border:1px solid rgba(var(--accent-rgb),0.2);border-radius:14px;padding:1.25rem}
.page-title,.chart-card h3,.card-vic h3,.card-vic h4,.portal-hero h1{color:var(--text-main)}

/* 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-body.sidebar-open{overflow: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(var(--accent-rgb),0.3)}
.sidebar-backdrop{position:fixed;inset:0;background:rgba(10,10,10,0.45);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:95}
.sidebar-backdrop.show{opacity:1;pointer-events:auto}
.sidebar-brand{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:0 .5rem 1.5rem;border-bottom:1px solid rgba(255,255,255,0.1);text-align:center}
.sidebar-brand small{opacity:.75;font-size:.72rem;color:rgba(255,255,255,0.75);letter-spacing:.14em;text-transform:uppercase}
.brand-wordmark{display:block;width:100%;max-width:190px;height:auto;border-radius:12px;box-shadow:0 12px 28px rgba(0,0,0,0.3);margin:0 auto}
.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:linear-gradient(90deg,rgba(var(--accent-rgb),0.32) 0%,rgba(var(--accent-rgb),0.1) 100%);
  color:#fff;
  box-shadow:inset 3px 0 0 var(--rose);
}
.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,#f5d0dc,#e8a4b8);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh}
.main-shell{width:min(100%,1680px);margin:0 auto}
.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}
.topbar-left{display:flex;align-items:center;gap:.9rem;min-width:0}
.page-title{margin:0;font-size:1.75rem}
.content-area{padding:1rem 2rem 2rem}
.topbar-actions{display:flex;align-items:center;gap:.75rem}
.mobile-nav-toggle{display:none}

/* Stats and charts */
.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;color:var(--text-soft);margin-bottom:.5rem}
.stat-value{font-family:var(--font-display);font-size:2rem;color:var(--gold-dark)}
.stat-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:2.5rem;opacity:.12}
.animate-in{animation:fadeUp .5s ease backwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}}
.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 and forms */
.card-vic{padding:1.5rem;margin-bottom:1.5rem;color:var(--text-main);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow)}
.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(var(--accent-rgb),0.18)}
.form-section h3{font-size:1.1rem;margin-bottom:1rem;color:var(--text-main)}
.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(var(--accent-rgb),0.35);border-radius:12px;background:rgba(255,255,255,0.92);font-family:inherit;transition:border .2s,color .2s,background .2s;color:var(--text-main)}
.form-control-vic:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(var(--accent-rgb),0.2)}
html[data-theme="dark"] .form-control-vic{background:rgba(255,255,255,0.04);color:var(--text-main);border-color:rgba(255,255,255,0.12)}
.btn-sharlott{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#f5d0dc 0%,#e8a4b8 45%,#d4849a 100%);color:#fff!important;border:none;border-radius:30px;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(201,123,146,0.35)}
.btn-sharlott:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(201,123,146,0.45);color:#fff!important}
.btn-outline-vic{display:inline-flex;align-items:center;padding:.6rem 1.2rem;border:1px solid rgba(var(--accent-rgb),0.75);color:var(--gold-dark);border-radius:30px;text-decoration:none;background:rgba(255,255,255,0.5);cursor:pointer}
.btn-outline-vic.active,.btn-outline-vic:hover{background:rgba(var(--accent-rgb),0.12);color:var(--gold-dark);box-shadow:0 6px 18px rgba(var(--accent-rgb),0.16)}
.btn-icon{width:40px;height:40px;border:none;background:rgba(var(--accent-rgb),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.03),rgba(var(--accent-rgb),0.12));border:1px solid rgba(var(--accent-rgb),0.28);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)}
.credenciales-box{max-width:480px;margin-left:auto;margin-right:auto}
.cred-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px dashed rgba(var(--accent-rgb),0.25);gap:1rem;flex-wrap:wrap}
.cred-row span{font-size:.85rem;opacity:.75}

/* Lists and uploads */
.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(--text-main)}
.pedido-meta{font-size:.85rem;opacity:.85;margin:.25rem 0}
.pedido-detalles{font-size:.8rem;opacity:.7;margin-top:.5rem}
.review-card .review-qr-img{max-width:200px;border-radius:12px;border:2px solid rgba(var(--accent-rgb),0.3)}
.review-card .btn-sharlott{display:inline-flex}
.event-upload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem}
.event-photo-card{overflow:hidden}
.event-photo-thumb{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px;margin-bottom:.75rem;border:1px solid rgba(var(--accent-rgb),0.18)}
.terms-box{padding:1rem;border-radius:14px;background:rgba(var(--accent-rgb),0.08);border:1px solid rgba(var(--accent-rgb),0.18)}

/* Filters and payments */
.filters-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.filters-row .form-control-vic{width:auto;min-width:140px;flex:1 1 180px}
.payment-methods{display:flex;flex-wrap:wrap;gap:.75rem}
.pay-option{padding:.75rem 1.25rem;border:2px solid rgba(var(--accent-rgb),0.3);border-radius:12px;cursor:pointer;transition:all .2s}
.pay-option:has(input:checked){border-color:var(--gold);background:rgba(var(--accent-rgb),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(var(--accent-rgb),0.18);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:.85;margin-top:.75rem}
.progress-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.progress-caption{display:block;font-size:.78rem;color:var(--text-soft);margin-bottom:.45rem}
.progress-bar-order{height:8px}
.progress-card-mini{margin-top:.75rem}

/* Tables */
.table-vic,
.card-vic .table,
table.dataTable.table-vic{
  --bs-table-bg:transparent;
  --bs-table-color:var(--text-main);
  --bs-table-border-color:var(--line-soft);
  --bs-table-striped-bg:rgba(var(--accent-rgb),0.06);
  --bs-table-hover-bg:rgba(var(--accent-rgb),0.12);
  --bs-table-active-bg:rgba(var(--accent-rgb),0.14);
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:transparent!important;
  color:var(--text-main)!important;
  margin-bottom:0!important;
}
.table-vic thead th,
table.dataTable.table-vic thead th,
.table-vic > thead > tr > th{
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:1rem;
  color:var(--rose-dark)!important;
  background:rgba(var(--accent-rgb),0.14)!important;
  border-bottom:1px solid rgba(var(--accent-rgb),0.3)!important;
  border-top:none!important;
  vertical-align:middle;
}
.table-vic tbody td,
table.dataTable.table-vic tbody td{
  padding:1rem;
  border-bottom:1px solid var(--line-soft)!important;
  vertical-align:middle;
  background:transparent!important;
  color:var(--text-main)!important;
  box-shadow:none!important;
}
.table-vic tbody tr,
table.dataTable.table-vic tbody tr{background:transparent!important}
.table-vic tbody tr:nth-child(even) td,
table.dataTable.table-vic.stripe tbody tr:nth-child(even) td,
table.dataTable.table-vic tbody tr.even td{
  background:rgba(var(--accent-rgb),0.05)!important;
}
.table-vic tbody tr:hover td,
table.dataTable.table-vic.hover tbody tr:hover td,
table.dataTable.table-vic tbody tr:hover td{
  background:rgba(var(--accent-rgb),0.1)!important;
  color:var(--text-main)!important;
}
.table-vic tbody tr td strong{color:var(--text-main)}
.table-progress{min-width:180px}
.table-responsive,.table-vic-wrap{width:100%;overflow-x:auto!important;-webkit-overflow-scrolling:touch}
.dataTables_wrapper{width:100%;color:var(--text-main)}
.dataTables_scroll,.dataTables_scrollBody,.dataTables_scrollHead{background:transparent!important}
.dataTables_scrollHeadInner table{background:transparent!important}
.dataTables_scrollBody table{background:transparent!important}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info{
  color:var(--text-soft)!important;
  font-size:.85rem;
  margin:.5rem 0 1rem;
}
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label{
  color:var(--text-soft)!important;
  display:flex;
  align-items:center;
  gap:.5rem;
  flex-wrap:wrap;
}
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input{
  background:var(--card-bg)!important;
  color:var(--text-main)!important;
  border:1px solid rgba(var(--accent-rgb),0.35)!important;
  border-radius:10px!important;
  padding:.45rem .75rem!important;
  min-height:38px;
}
.dataTables_wrapper .dataTables_filter input{min-width:180px}
.dataTables_wrapper .dataTables_filter input:focus,
.dataTables_wrapper .dataTables_length select:focus{
  outline:none!important;
  border-color:var(--rose)!important;
  box-shadow:0 0 0 3px rgba(var(--accent-rgb),0.22)!important;
}
.dataTables_wrapper .dataTables_paginate{
  margin-top:1rem!important;
  padding-top:.5rem;
}
.dataTables_wrapper .dataTables_paginate .paginate_button{
  color:var(--text-main)!important;
  background:rgba(var(--accent-rgb),0.08)!important;
  border:1px solid rgba(var(--accent-rgb),0.25)!important;
  border-radius:8px!important;
  margin:0 .15rem!important;
  padding:.35rem .65rem!important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled:hover{
  opacity:.45!important;
  color:var(--text-soft)!important;
}
.dataTables_wrapper .dataTables_empty,
table.dataTable.table-vic td.dataTables_empty{
  background:transparent!important;
  color:var(--text-soft)!important;
  padding:2rem 1rem!important;
  text-align:center;
}
.badge-estado,.badge-pago{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}
.badge-estado.pendiente,.badge-pago.pendiente{background:#fce8ef;color:#8b4a62}
.badge-estado.en_proceso,.badge-estado.en_revision{background:#cce5ff;color:#004085}
.badge-estado.listo{background:#efe3ff;color:#5f2d91}
.badge-estado.confirmado,.badge-estado.entregado,.badge-pago.pagado{background:#d4edda;color:#155724}
.badge-pago.parcial{background:#f5d0dc;color:#7a3d52}
.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(var(--accent-rgb),0.22);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 and 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,#1a0f14 0%,#3d1f2b 45%,#2a121c 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='%23d4849a' fill-opacity='0.08'%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:560px;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)}
.auth-card h2,.auth-header p{color:var(--text-main)}
.tagline{font-family:var(--font-display);font-size:1.5rem;color:var(--gold-light)}
.landing-hero h1,.landing-hero .tagline{color:var(--gold-dark)}
.landing-hero .desc{color:var(--text-soft)}
.landing-hero{text-align:center;padding:4rem 2rem;max-width:700px;margin:0 auto}
.form-floating-vic{position:relative;margin-bottom:1.25rem}
.form-floating-vic input{width:100%;padding:1rem;border:1px solid rgba(var(--accent-rgb),0.35);border-radius:12px;background:rgba(255,255,255,0.9);color:var(--text-main)}
.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(--gold-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(--gold-dark)}
.landing-logo,.auth-logo{display:block;width:min(100%,420px);height:auto;margin:0 auto 1rem;border-radius:18px;box-shadow:0 16px 34px rgba(0,0,0,0.28)}
html[data-theme="dark"] .auth-card,
html[data-theme="dark"] .landing-hero{background:rgba(255,255,255,0.03);color:var(--text-main)}
html[data-theme="dark"] .auth-card h2,
html[data-theme="dark"] .auth-header p,
html[data-theme="dark"] .landing-hero .desc{color:#e8e4dc}

/* 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;gap:1rem;flex-wrap:wrap}
.portal-nav .brand{display:inline-flex;align-items:center;text-decoration:none}
.portal-logo{display:block;width:180px;max-width:100%;height:auto;border-radius:12px;box-shadow:0 10px 24px rgba(0,0,0,0.18)}
.portal-links{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}
.portal-links a{text-decoration:none;color:var(--text-soft);font-weight:500}
.portal-links a.active,.portal-links a:hover{color:var(--gold-dark)}
.portal-main{max-width:1100px;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)}

/* Portal inicio — acciones uniformes */
.portal-actions{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.75rem;
  padding:1.25rem;
  margin-top:1.25rem;
}
.portal-action{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  min-height:96px;
  padding:1rem .65rem;
  border-radius:16px;
  text-decoration:none;
  color:inherit;
  border:1px solid var(--card-border);
  background:var(--card-bg);
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.portal-action:hover{
  transform:translateY(-2px);
  border-color:var(--gold);
  box-shadow:0 8px 24px rgba(var(--accent-rgb),.12);
  color:inherit;
}
.portal-action__icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:2.5rem;
  height:2.5rem;
  border-radius:50%;
  background:linear-gradient(145deg,rgba(var(--accent-rgb),.18),rgba(var(--accent-rgb),.06));
  color:var(--gold-dark);
  font-size:1.25rem;
}
.portal-action__label{
  font-size:.82rem;
  font-weight:600;
  text-align:center;
  line-height:1.2;
}
.portal-action--whatsapp .portal-action__icon{
  background:linear-gradient(145deg,rgba(37,211,102,.25),rgba(18,140,126,.12));
  color:#128c7e;
}
.portal-action--factura .portal-action__icon{
  background:linear-gradient(145deg,rgba(var(--accent-rgb),.22),rgba(var(--accent-rgb),.08));
}
.portal-pedido-status .portal-timeline{margin-bottom:0}
.datos-fiscales-form__actions{display:flex;justify-content:flex-end}
.datos-fiscales-page-form .form-label-vic{font-size:.85rem;margin-bottom:.35rem}
@media (max-width:576px){
  .portal-actions{grid-template-columns:repeat(2,1fr)}
}
@media (min-width:768px){
  .portal-actions{grid-template-columns:repeat(3,1fr);max-width:720px;margin-left:auto;margin-right:auto}
}
.portal-footer{margin:2rem 1rem 5rem;padding:1.5rem}
.portal-footer__copy{text-align:center;font-size:.8rem;color:var(--text-soft);margin:1rem 0 0}
.portal-footer__copy a{color:var(--gold-dark)}
.portal-wa-float{
  position:fixed;right:1.25rem;bottom:1.25rem;z-index:80;
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#25D366;color:#fff!important;font-size:1.6rem;
  box-shadow:0 8px 28px rgba(37,211,102,.45);
  text-decoration:none;transition:transform .2s;
}
.portal-wa-float:hover{transform:scale(1.06);color:#fff!important}

/* Calendar */
.calendar-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.25rem}
.delivery-calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.5rem}
.calendar-head,.calendar-day{padding:.8rem;border-radius:14px}
.calendar-head{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-dark);text-align:center;background:rgba(var(--accent-rgb),0.08)}
.calendar-day{min-height:98px;background:rgba(255,255,255,0.82);border:1px solid rgba(var(--accent-rgb),0.12);display:flex;flex-direction:column;gap:.35rem}
.calendar-day.is-other{opacity:.35}
.calendar-day.is-today{border-color:var(--gold);box-shadow:0 0 0 2px rgba(var(--accent-rgb),0.12)}
.calendar-day.has-deliveries{background:linear-gradient(180deg,rgba(252,228,236,0.55),rgba(255,255,255,0.9))}
.calendar-day-number{font-size:.9rem;font-weight:700;color:var(--black)}
.calendar-chip{display:block;font-size:.72rem;line-height:1.25;padding:.3rem .45rem;border-radius:10px;background:rgba(var(--accent-rgb),0.18);color:#7a3d52;text-decoration:none}
.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.calendar-nav{display:flex;gap:.5rem}
html[data-theme="dark"] .calendar-day{background:rgba(255,255,255,0.03);color:var(--text-main)}
html[data-theme="dark"] .calendar-head{background:rgba(var(--accent-rgb),0.12)}
html[data-theme="dark"] .calendar-chip{background:rgba(var(--accent-rgb),0.22);color:#f4c9d4}
html[data-theme="dark"] .glass,
html[data-theme="dark"] .card-vic,
html[data-theme="dark"] .chart-card,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .quick-action,
html[data-theme="dark"] .portal-nav{background:var(--card-bg)!important;color:var(--text-main)}
html[data-theme="dark"] .glass-inner{background:rgba(var(--accent-rgb),0.1);border-color:rgba(244,201,212,0.16)}
html[data-theme="dark"] .btn-outline-vic{background:rgba(255,255,255,0.03);color:var(--rose-light);border-color:rgba(var(--accent-rgb),0.45)}
html[data-theme="dark"] .btn-outline-vic.active,
html[data-theme="dark"] .btn-outline-vic:hover{color:#fff;background:rgba(var(--accent-rgb),0.18);border-color:var(--rose)}
html[data-theme="dark"] .btn-icon{background:rgba(var(--accent-rgb),0.15);color:var(--rose-light)}
html[data-theme="dark"] .table-vic thead th,
html[data-theme="dark"] table.dataTable.table-vic thead th{
  color:var(--rose-light)!important;
  background:rgba(var(--accent-rgb),0.24)!important;
  border-bottom-color:rgba(var(--accent-rgb),0.35)!important;
}
html[data-theme="dark"] .table-vic tbody td,
html[data-theme="dark"] table.dataTable.table-vic tbody td{
  color:var(--text-main)!important;
  border-color:var(--line-soft)!important;
}
html[data-theme="dark"] .table-vic tbody tr:nth-child(even) td,
html[data-theme="dark"] table.dataTable.table-vic tbody tr:nth-child(even) td{
  background:rgba(var(--accent-rgb),0.08)!important;
}
html[data-theme="dark"] .dataTables_wrapper .dataTables_length select,
html[data-theme="dark"] .dataTables_wrapper .dataTables_filter input{
  background:rgba(255,255,255,0.06)!important;
  color:var(--text-main)!important;
  border-color:rgba(var(--accent-rgb),0.35)!important;
}
html[data-theme="dark"] .dataTables_wrapper .dataTables_paginate .paginate_button{
  color:var(--text-main)!important;
  background:rgba(var(--accent-rgb),0.1)!important;
}
html[data-theme="dark"] .landing-hero h1,
html[data-theme="dark"] .landing-hero .tagline,
html[data-theme="dark"] .back-link,
html[data-theme="dark"] .text-gold{color:var(--rose-light)!important}
html[data-theme="dark"] .nav-item:hover,
html[data-theme="dark"] .nav-item.active{
  background:linear-gradient(90deg,rgba(var(--accent-rgb),0.38) 0%,rgba(var(--accent-rgb),0.08) 100%);
  color:#fff;
  box-shadow:inset 3px 0 0 var(--rose);
}
html[data-theme="dark"] .sidebar{border-right-color:rgba(var(--accent-rgb),0.25)!important}
html[data-theme="dark"] .page-title,
html[data-theme="dark"] .card-vic h3,
html[data-theme="dark"] .card-vic h4{color:var(--text-main)}
html[data-theme="dark"] .stat-value{color:var(--rose-light)}
html[data-theme="dark"] .form-control-vic:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(var(--accent-rgb),0.25)}
html[data-theme="dark"] .btn-sharlott{background:linear-gradient(135deg,#f5d0dc,#e8a4b8 50%,#d4849a);color:#fff!important}
html[data-theme="dark"] .form-floating-vic input{background:rgba(255,255,255,0.04);color:var(--text-main)}
html[data-theme="dark"] .form-control-vic option{background:#151515;color:var(--text-main)}

/* Toast and modal */
.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:#fce8ef;color:#8b4a62}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}}
.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(var(--accent-rgb),0.18)}
.abono-item--portal{align-items:center;gap:.75rem;flex-wrap:wrap}
.quick-action--whatsapp{border-color:rgba(37,211,102,.35)}
.quick-action--whatsapp:hover{color:#128c7e}
.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(min-width:1600px){
  .content-area{padding:1.25rem 2.25rem 3rem}
}
@media(max-width:1200px){
  .topbar{padding:1rem 1.25rem}
  .content-area{padding:1rem 1.25rem 2rem}
}
@media(max-width:992px){
  .mobile-nav-toggle{display:inline-flex}
  .sidebar{transform:translateX(-100%);transition:transform .3s}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}
  .main-shell{width:100%}
  .topbar{margin:0;padding:1rem 1rem .75rem;border-radius:0;top:0}
  .content-area{padding:1rem}
  .page-title{font-size:1.4rem}
  .portal-logo{width:140px}
}
@media(max-width:768px){
  .card-vic,.glass-inner,.chart-card,.stat-card{padding:1rem}
  .topbar,.portal-nav{padding:1rem}
  .topbar{align-items:flex-start;flex-wrap:wrap;gap:.75rem}
  .topbar-left,.topbar-actions{width:100%}
  .topbar-actions{justify-content:flex-end}
  .filters-row > *{width:100%}
  .filters-row .form-control-vic,.filters-row .btn-sharlott,.filters-row .btn-outline-vic{width:100%}
  .portal-nav{justify-content:center}
  .portal-links{width:100%;justify-content:center;gap:.75rem}
  .detail-grid{grid-template-columns:1fr}
  .delivery-calendar{min-width:720px}
  .calendar-toolbar{align-items:flex-start}
  .calendar-nav{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .ticket-actions,.form-check-row{flex-direction:column;align-items:stretch}
  .ticket-actions > *, .form-check-row > *{width:100%}
  .table-vic{min-width:720px}
}
@media(max-width:480px){
  .guest-container{padding:1rem}
  .auth-card,.landing-hero{padding:1.35rem}
  .page-title{font-size:1.2rem}
  .stats-grid,.charts-row,.pedidos-grid,.event-upload-grid{grid-template-columns:1fr}
  .portal-links a{font-size:.92rem}
}
[x-cloak]{display:none!important}

/* Bootstrap — acentos rosa */
.page-link:focus{box-shadow:0 0 0 .2rem rgba(var(--accent-rgb),0.25)}
.page-item.active .page-link,
.active>.page-link{
  background:linear-gradient(135deg,#f5d0dc,#e8a4b8)!important;
  border-color:var(--rose)!important;
  color:#fff!important;
}
.page-link{color:var(--rose-dark);background:var(--card-bg);border-color:rgba(var(--accent-rgb),0.3)}
.pagination{--bs-pagination-bg:var(--card-bg);--bs-pagination-color:var(--text-main);--bs-pagination-border-color:rgba(var(--accent-rgb),0.3);--bs-pagination-hover-bg:rgba(var(--accent-rgb),0.12);--bs-pagination-hover-color:var(--rose-dark);--bs-pagination-active-bg:var(--rose);--bs-pagination-active-border-color:var(--rose);--bs-pagination-active-color:#fff}
.form-check-input:checked{background-color:var(--rose);border-color:var(--rose)}
.form-check-input:focus{border-color:var(--rose);box-shadow:0 0 0 .2rem rgba(var(--accent-rgb),0.25)}
.form-select,.form-control{background:var(--card-bg);color:var(--text-main);border-color:rgba(var(--accent-rgb),0.35)}
.form-select:focus,.form-control:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(var(--accent-rgb),0.2)}
html[data-theme="dark"] .form-select,
html[data-theme="dark"] .form-control{background:rgba(255,255,255,0.06);color:var(--text-main);border-color:rgba(var(--accent-rgb),0.35)}
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover{
  background:linear-gradient(135deg,#f5d0dc,#e8a4b8)!important;
  border-color:var(--rose)!important;
  color:#fff!important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover:not(.current):not(.disabled){
  background:rgba(var(--accent-rgb),0.2)!important;
  border-color:var(--rose)!important;
  color:var(--rose-dark)!important;
}
html[data-theme="dark"] .dataTables_wrapper .dataTables_paginate .paginate_button:hover:not(.current):not(.disabled){
  color:var(--rose-light)!important;
}
table.dataTable thead .sorting,
table.dataTable thead .sorting_asc,
table.dataTable thead .sorting_desc{background-image:none!important;position:relative;padding-right:1.5rem!important}
table.dataTable thead .sorting:before,
table.dataTable thead .sorting_asc:before,
table.dataTable thead .sorting_desc:before{
  position:absolute;right:.5rem;top:50%;transform:translateY(-50%);
  font-size:.65rem;opacity:.75;color:var(--rose);
}
table.dataTable thead .sorting:before{content:"⇅"}
table.dataTable thead .sorting_asc:before{content:"↑"}
table.dataTable thead .sorting_desc:before{content:"↓"}

/* Páginas admin — grillas responsivas */
.admin-config-grid .col-lg-6,
.content-area > .row > [class*="col-"]{min-width:0}
.config-qr-preview img{max-width:160px;width:100%;height:auto}
.review-card .review-qr-img{max-width:min(200px,100%)}

/* Tablet (768px – 1199px) */
@media(min-width:768px) and (max-width:1199px){
  .content-area{padding:1rem 1.5rem 2rem}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .charts-row{grid-template-columns:1fr}
  .topbar-actions .btn-sharlott{padding:.65rem 1.1rem;font-size:.9rem}
  .brand-wordmark{max-width:160px}
}

/* Móvil y tablet pequeña */
@media(max-width:767px){
  .content-area > .row.g-4{--bs-gutter-y:1rem}
  .content-area > .row > [class*="col-"]{flex:0 0 100%;max-width:100%}
  .card-vic .btn-sharlott,
  .card-vic .btn-outline-vic{width:100%;justify-content:center}
  .topbar-actions{flex-wrap:wrap;gap:.5rem}
  .topbar-actions .btn-sharlott,
  .topbar-actions .btn-outline-vic{flex:1 1 auto;min-width:calc(50% - .25rem);justify-content:center;font-size:.85rem;padding:.6rem .85rem}
  .topbar-actions .btn-icon{flex:0 0 auto}
  .page-title{font-size:1.25rem;line-height:1.2}
  .sidebar-brand small{font-size:.65rem}
  .brand-wordmark{max-width:150px}
  .glass-inner.text-center{padding:1rem!important}
  .config-qr-preview img,.review-card .review-qr-img{max-width:140px}
  .portal-footer{margin:1rem .75rem 4.5rem;padding:1rem}
  .portal-wa-float{right:1rem;bottom:1rem;width:52px;height:52px}
  .vic-redes__grid{grid-template-columns:1fr}
  .card-header-vic{flex-direction:column;align-items:flex-start;gap:.75rem}
  .comision-preview,.bank-grid{grid-template-columns:1fr}
  .dataTables_wrapper .dataTables_length,
  .dataTables_wrapper .dataTables_filter{width:100%}
  .dataTables_wrapper .dataTables_filter input{width:100%;max-width:100%}
  .dataTables_wrapper .dataTables_length select{max-width:100%}
  .dataTables_wrapper .dataTables_paginate{text-align:center}
  .dataTables_wrapper .dataTables_paginate .paginate_button{margin:.2rem!important}
}

/* Móvil pequeño */
@media(max-width:480px){
  .topbar-actions .btn-sharlott{min-width:100%}
  .mobile-nav-toggle{width:44px;height:44px}
  .nav-item{padding:.85rem 1rem;font-size:.95rem}
  .auth-logo,.landing-logo{max-width:min(100%,280px)}
  .portal-actions{grid-template-columns:1fr;gap:.5rem}
  .portal-action{min-height:72px}
  .toast-alert{left:1rem;right:1rem;top:1rem}
  .sidebar{width:min(100%,300px)}
}

/* Escritorio grande */
@media(min-width:1400px){
  .main-shell{max-width:1680px}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
}

/* Panel admin — forzar tablas DataTables (Bootstrap 5 pinta fondo blanco) */
.content-area table.dataTable,
.card-vic table.dataTable{
  --bs-table-bg:transparent!important;
  --bs-table-striped-bg:rgba(var(--accent-rgb),0.06)!important;
  --bs-table-hover-bg:rgba(var(--accent-rgb),0.12)!important;
  --bs-table-active-color:var(--text-main)!important;
  --bs-table-color:var(--text-main)!important;
  background:transparent!important;
  border-color:var(--line-soft)!important;
}
.content-area table.dataTable > :not(caption) > * > *,
.card-vic table.dataTable > :not(caption) > * > *{
  background-color:transparent!important;
  color:var(--text-main)!important;
  box-shadow:none!important;
}
.content-area table.dataTable thead > tr > th,
.card-vic table.dataTable thead > tr > th{
  background:rgba(var(--accent-rgb),0.14)!important;
  color:var(--rose-dark)!important;
  border-bottom-color:rgba(var(--accent-rgb),0.3)!important;
}
.content-area table.dataTable tbody tr:nth-child(even) > *,
.card-vic table.dataTable tbody tr:nth-child(even) > *,
.content-area table.dataTable.stripe tbody tr.odd > *,
.card-vic table.dataTable.stripe tbody tr.odd > *{
  background-color:rgba(var(--accent-rgb),0.05)!important;
}
.content-area table.dataTable tbody tr:hover > *,
.card-vic table.dataTable tbody tr:hover > *{
  background-color:rgba(var(--accent-rgb),0.1)!important;
}
html[data-theme="dark"] .content-area .dataTables_wrapper,
html[data-theme="dark"] .card-vic .dataTables_wrapper{color:var(--text-main)}
html[data-theme="dark"] table.dataTable.display tbody tr.odd > .sorting_1,
html[data-theme="dark"] table.dataTable.display tbody tr.even > .sorting_1,
html[data-theme="dark"] table.dataTable.stripe tbody tr.odd > *,
html[data-theme="dark"] table.dataTable.stripe tbody tr.even > *{
  background-color:transparent!important;
}
html[data-theme="dark"] table.dataTable.display tbody tr.odd,
html[data-theme="dark"] table.dataTable.display tbody tr.even{background:transparent!important}
html[data-theme="dark"] table.dataTable.display tbody tr:hover > *,
html[data-theme="dark"] table.dataTable.hover tbody tr:hover > *{
  background-color:rgba(var(--accent-rgb),0.12)!important;
}
html[data-theme="dark"] .dataTables_wrapper .dataTables_scrollBody,
html[data-theme="dark"] .dataTables_wrapper .dataTables_scrollHead,
html[data-theme="dark"] .dataTables_wrapper .dataTables_scrollFoot{
  background:transparent!important;
  border:none!important;
}

/* Safe area iOS */
@supports(padding:max(0px)){
  .portal-wa-float{bottom:max(1rem,env(safe-area-inset-bottom))}
  .content-area{padding-bottom:max(2rem,env(safe-area-inset-bottom))}
}
