/* ============================================================
   CEAON · Super Admin — UI
   Marca CEAON tal cual: monocromático (negro/blanco/grises),
   rojo --domicilio SOLO donde ya se usa. Fuente Roboto (la de la app).
   Autocontenido: única hoja de estilos del admin.
   ============================================================ */

:root {
  --black:#0d0d0d;
  --ink:#1a1a1a;
  --white:#ffffff;
  --gray-50:#fafafa;
  --gray-100:#f5f5f5;
  --gray-200:#ececec;
  --gray-300:#d9d9d9;
  --gray-500:#8a8a8a;
  --gray-700:#4a4a4a;
  --domicilio:#e63946;       /* rojo Manos Expertas (marca) */
  --line:#e8e8e8;
  --sidebar-w:252px;
  --sidebar-w-collapsed:76px;
  --font:'Roboto',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --radius:10px;
  --radius-lg:14px;
}

* { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font);
  background:var(--gray-50);
  color:var(--ink);
  font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
.tnum { font-variant-numeric:tabular-nums; }

/* ============================================================
   SHELL + SIDEBAR (negro CEAON)
   ============================================================ */
.shell { min-height:100vh; }

.sidebar {
  position:fixed; top:0; left:0;
  width:var(--sidebar-w); height:100vh;
  background:var(--black); color:var(--white);
  display:flex; flex-direction:column;
  padding:22px 16px 16px;
  transition:width .18s ease;
  z-index:40;
}

.sidebar__brand { display:flex; align-items:center; gap:10px; padding:6px; margin:-4px; border:0; background:transparent; color:inherit; width:calc(100% + 8px); text-align:left; font-family:inherit; cursor:pointer; border-radius:10px; transition:background .15s; }
.sidebar__brand:hover { background:rgba(255,255,255,.06); }
.sidebar__brand img { width:30px; height:30px; object-fit:contain; }
.sidebar__brand-text { display:flex; flex-direction:column; line-height:1.1; }
.sidebar__brand-name { font-weight:700; font-size:15px; letter-spacing:.02em; }
.sidebar__brand-sub { font-size:10.5px; color:rgba(255,255,255,.45); letter-spacing:.14em; text-transform:uppercase; }

.nav { margin-top:26px; flex:1; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.nav__section { font-size:10px; text-transform:uppercase; letter-spacing:.16em; color:rgba(255,255,255,.32); padding:16px 10px 6px; }
.nav__item {
  display:flex; align-items:center; gap:12px;
  padding:9px 11px; border-radius:9px;
  font-size:14px; color:rgba(255,255,255,.6);
  transition:background .15s,color .15s; white-space:nowrap;
}
.nav__item:hover { background:rgba(255,255,255,.07); color:var(--white); }
.nav__item.is-active { background:rgba(255,255,255,.13); color:var(--white); font-weight:500; }
.nav__item svg { width:18px; height:18px; flex-shrink:0; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.nav__badge { margin-left:auto; font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.4); border:1px solid rgba(255,255,255,.18); border-radius:999px; padding:1px 7px; }
.nav__item--new { margin-top:6px; color:#fff; background:rgba(255,255,255,.07); border:1px dashed rgba(255,255,255,.22); }
.nav__item--new:hover { background:rgba(255,255,255,.13); border-style:solid; color:#fff; }

.sidebar__foot { margin-top:10px; border-top:1px solid rgba(255,255,255,.1); padding-top:12px; }
.sidebar__user { padding:0 8px 8px; }
.sidebar__user-name { font-size:13.5px; font-weight:500; }
.sidebar__user-mail { font-size:11.5px; color:rgba(255,255,255,.4); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sidebar__action { display:flex; align-items:center; gap:12px; width:100%; padding:9px 11px; border-radius:9px; border:0; background:transparent; color:rgba(255,255,255,.55); font-size:13.5px; transition:background .15s,color .15s; }
.sidebar__action:hover { background:rgba(255,255,255,.07); color:var(--white); }
.sidebar__action svg { width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }

/* Colapsado (desktop) */
.shell.is-collapsed .sidebar { width:var(--sidebar-w-collapsed); padding-left:14px; padding-right:14px; }
.shell.is-collapsed .side-label,
.shell.is-collapsed .sidebar__brand-text,
.shell.is-collapsed .sidebar__user,
.shell.is-collapsed .nav__section,
.shell.is-collapsed .nav__badge { display:none; }
.shell.is-collapsed .nav__item,
.shell.is-collapsed .sidebar__action { justify-content:center; gap:0; }
.shell.is-collapsed .sidebar__brand { justify-content:center; }
.toggle-chevron { transition:transform .18s ease; }
.shell.is-collapsed .toggle-chevron { transform:rotate(180deg); }

/* ============================================================
   MAIN
   ============================================================ */
.main { margin-left:var(--sidebar-w); min-width:0; transition:margin-left .18s ease; }
.shell.is-collapsed .main { margin-left:var(--sidebar-w-collapsed); }
.main__inner { max-width:1120px; margin:0 auto; padding:36px 40px 80px; }
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:28px; flex-wrap:wrap; }
.page-title { font-size:30px; font-weight:700; letter-spacing:-.02em; color:var(--black); }
.page-sub { color:var(--gray-500); font-size:14px; margin-top:3px; }
.topbar { display:none; }

/* ============================================================
   STATS
   ============================================================ */
.stat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; margin-bottom:28px; }
.stat { background:var(--white); padding:20px 22px; }
.stat__k { font-size:11px; text-transform:uppercase; letter-spacing:.13em; color:var(--gray-500); display:flex; align-items:center; gap:7px; }
.stat__k svg { width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:1.7; }
.stat__v { font-size:30px; font-weight:700; letter-spacing:-.025em; margin-top:8px; color:var(--black); }
.stat__n { font-size:12px; color:var(--gray-500); margin-top:2px; }

/* ============================================================
   PANEL / CARD / TABLA
   ============================================================ */
.panel { background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.panel__head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 22px; border-bottom:1px solid var(--line); }
.panel__title { font-size:15px; font-weight:600; }
.card { background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px; }

.table-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
.table { width:100%; border-collapse:collapse; font-size:14px; }
.table thead th { text-align:left; font-size:10.5px; text-transform:uppercase; letter-spacing:.1em; color:var(--gray-500); font-weight:600; padding:11px 22px; border-bottom:1px solid var(--line); }
.table tbody td { padding:13px 22px; border-bottom:1px solid var(--gray-100); vertical-align:middle; }
.table tbody tr:last-child td { border-bottom:0; }
.table tbody tr { transition:background .12s; }
.table tbody tr:hover { background:var(--gray-50); }
.col-right { text-align:right; }

.prov { display:flex; align-items:center; gap:12px; }
.prov__avatar { width:38px; height:38px; border-radius:50%; object-fit:cover; background:var(--gray-100); flex-shrink:0; }
.prov__ph { width:38px; height:38px; border-radius:50%; background:var(--black); color:var(--white); display:flex; align-items:center; justify-content:center; font-weight:600; font-size:14px; flex-shrink:0; }
.prov__name { font-weight:500; color:var(--black); }
.prov__meta { font-size:12px; color:var(--gray-500); }

/* Chips (monocromático; rojo solo domicilio) */
.chip { display:inline-flex; align-items:center; gap:5px; font-size:11px; text-transform:uppercase; letter-spacing:.04em; font-weight:500; padding:3px 9px; border-radius:999px; border:1px solid var(--line); color:var(--gray-700); white-space:nowrap; }
.chip__dot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.chip--active { color:var(--black); background:var(--gray-100); border-color:transparent; }
.chip--pending { color:var(--gray-700); background:var(--white); border-color:var(--gray-300); }
.chip--inactive { color:var(--gray-500); background:var(--white); border-color:var(--line); }
.chip--presencial { color:var(--black); background:var(--gray-100); border-color:transparent; }
.chip--domicilio { color:var(--domicilio); background:rgba(230,57,70,.08); border-color:transparent; }
button.chip { font-family:inherit; }
.js-status { cursor:pointer; }
.js-status:hover { filter:brightness(.97); }
.chip__caret { width:12px; height:12px; fill:none; stroke:currentColor; stroke-width:2.4; margin-left:2px; opacity:.55; }

/* Búsqueda en tablas */
.tsearch { display:flex; align-items:center; gap:8px; background:var(--white); border:1px solid var(--line); border-radius:999px; padding:7px 14px; min-width:230px; }
.tsearch:focus-within { border-color:var(--gray-300); }
.tsearch svg { width:16px; height:16px; fill:none; stroke:var(--gray-500); stroke-width:1.8; flex-shrink:0; }
.tsearch input { border:0; outline:0; background:transparent; font-family:inherit; font-size:13.5px; width:100%; color:var(--ink); }

/* Menú inline de estado */
.status-menu { position:absolute; z-index:300; background:var(--white); border:1px solid var(--line); border-radius:11px; box-shadow:0 12px 32px rgba(13,13,13,.16); padding:6px; display:flex; flex-direction:column; gap:2px; animation:modalIn .14s ease; }
.status-menu__item { display:flex; align-items:center; padding:6px 10px 6px 8px; border:0; background:transparent; border-radius:8px; cursor:pointer; }
.status-menu__item:hover, .status-menu__item.is-current { background:var(--gray-100); }

/* Reseñas: tarjetas cuadradas (2 columnas) */
.folder-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:24px; }
.folder-card { display:flex; flex-direction:column; gap:7px; padding:22px; min-height:150px; border:1.5px solid var(--line); border-radius:var(--radius-lg); background:var(--white); cursor:pointer; text-align:left; font-family:inherit; transition:border-color .15s, background .15s, box-shadow .15s; }
.folder-card:hover { border-color:var(--gray-300); }
.folder-card.is-active { border-color:var(--black); background:var(--gray-50); box-shadow:0 6px 22px rgba(13,13,13,.06); }
.folder-card__ic { width:48px; height:48px; border-radius:12px; background:var(--gray-100); display:flex; align-items:center; justify-content:center; color:var(--black); }
.folder-card__ic svg { width:24px; height:24px; }
.folder-card.is-active .folder-card__ic { background:var(--black); color:var(--white); }
.folder-card__name { font-weight:700; font-size:18px; color:var(--black); margin-top:auto; letter-spacing:-.01em; }
.folder-card__meta { font-size:13px; color:var(--gray-500); }
.cat-panel { display:none; animation:modalIn .18s ease; }
.cat-panel.is-active { display:block; }
@media (max-width:640px) { .folder-grid { grid-template-columns:1fr; } }

/* Reseñas: folders por punto */
.folder { border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--white); overflow:hidden; margin-bottom:12px; }
.folder__head { display:flex; align-items:center; gap:14px; width:100%; padding:14px 18px; border:0; background:transparent; cursor:pointer; text-align:left; font-family:inherit; transition:background .12s; }
.folder__head:hover { background:var(--gray-50); }
.folder__info { flex:1; min-width:0; display:flex; flex-direction:column; }
.folder__name { font-weight:600; color:var(--black); }
.folder__meta { font-size:12.5px; color:var(--gray-500); }
.folder__ic { width:36px; height:36px; border-radius:9px; background:var(--gray-100); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--black); }
.folder__ic svg { width:19px; height:19px; }
.folder__chev { width:18px; height:18px; stroke-width:2; color:var(--gray-500); transition:transform .2s; }
/* Folder de categoría (nivel 1) */
.folder--type { border-color:var(--gray-300); }
.folder__body--type { padding:14px 16px; background:var(--gray-50); border-top-color:var(--gray-300); }
.folder__body--type .folder { margin-bottom:10px; }
.folder__body--type .folder:last-child { margin-bottom:0; }
.folder.is-open .folder__chev { transform:rotate(180deg); }
.folder__body { display:none; border-top:1px solid var(--line); padding:4px 18px 8px; }
.folder.is-open .folder__body { display:block; }
.review-item { padding:14px 2px; border-bottom:1px solid var(--gray-100); }
.review-item:last-child { border-bottom:0; }
.review-item__top { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.review-item__user { font-weight:500; color:var(--black); }
.review-item__date { margin-left:auto; font-size:12px; color:var(--gray-500); }
.review-item__text { color:var(--gray-700); font-size:14px; line-height:1.5; }
.review-item__reply { margin-top:8px; padding:10px 12px; background:var(--gray-50); border-radius:8px; font-size:13px; color:var(--gray-700); }
.review-item__reply b { color:var(--black); }

/* Tarjetas de reservas (tipo personas) */
.res-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:16px; }
.res-card { background:var(--white); border:1px solid var(--line); border-radius:16px; padding:20px; transition:box-shadow .2s, border-color .2s; }
.res-card:hover { box-shadow:0 10px 30px rgba(13,13,13,.06); border-color:var(--gray-300); }
.res-card__head { display:flex; gap:13px; align-items:center; }
.res-card__av { width:52px; height:52px; border-radius:50%; object-fit:cover; background:var(--gray-100); flex-shrink:0; }
.res-card__ph { width:52px; height:52px; border-radius:50%; background:var(--black); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:19px; flex-shrink:0; }
.res-card__name { font-weight:600; color:var(--black); font-size:15.5px; line-height:1.2; }
.res-card__svc { font-size:13px; color:var(--gray-500); margin-top:2px; }
.res-card__meta { margin-top:15px; padding-top:14px; border-top:1px solid var(--gray-100); display:flex; flex-direction:column; gap:9px; }
.res-card__row { display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--gray-700); }
.res-card__row svg { width:15px; height:15px; flex-shrink:0; fill:none; stroke:var(--gray-500); stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.res-card__foot { margin-top:16px; }

/* Modal de ÉXITO animado (check tipo confirmación de pago) */
.dp-success { position:fixed; inset:0; z-index:600; display:grid; place-items:center; padding:24px; background:rgba(13,13,13,.6); backdrop-filter:blur(2px); animation:dpFade .2s ease; }
.dp-success.is-closing { opacity:0; transition:opacity .25s ease; }
.dp-success-card { width:100%; max-width:320px; border-radius:22px; padding:38px 28px; text-align:center; background:var(--white); box-shadow:0 30px 80px rgba(0,0,0,.3); animation:dpPop .35s cubic-bezier(.16,1,.3,1); }
.dp-check { display:block; margin:0 auto 18px; width:80px; height:80px; }
.dp-check circle { fill:none; stroke:var(--black); stroke-width:3; stroke-dasharray:226; stroke-dashoffset:226; animation:dpDraw .5s ease forwards; }
.dp-check path { fill:none; stroke:var(--black); stroke-width:5; stroke-linecap:round; stroke-linejoin:round; stroke-dasharray:50; stroke-dashoffset:50; animation:dpDraw .32s .42s ease forwards; }
.dp-success-title { font-size:19px; font-weight:700; letter-spacing:-.01em; color:var(--black); }
.dp-success-sub { margin-top:6px; font-size:13.5px; color:var(--gray-500); }
@keyframes dpDraw { to { stroke-dashoffset:0; } }
@keyframes dpPop { from { opacity:0; transform:scale(.9); } to { opacity:1; transform:none; } }
@keyframes dpFade { from { opacity:0; } to { opacity:1; } }

.stars { display:inline-flex; align-items:center; gap:5px; }
.stars svg { width:14px; height:14px; fill:var(--black); }
.stars__v { font-weight:600; }
.stars__c { font-size:12px; color:var(--gray-500); }

/* ============================================================
   BOTONES
   ============================================================ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; background:var(--black); color:var(--white); border:1px solid var(--black); border-radius:var(--radius); padding:11px 18px; font-size:14px; font-weight:500; transition:opacity .15s,transform .1s; }
.btn:hover { opacity:.88; }
.btn:active { transform:scale(.98); }
.btn svg { width:17px; height:17px; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.btn--ghost { background:transparent; color:var(--black); border-color:var(--line); }
.btn--ghost:hover { background:var(--gray-100); opacity:1; border-color:var(--gray-300); }
.btn--sm { padding:8px 14px; font-size:13px; }
.link { color:var(--black); font-weight:500; border-bottom:1px solid transparent; transition:border-color .15s; }
.link:hover { border-color:var(--black); }
.row-actions { display:flex; gap:10px; justify-content:flex-end; align-items:center; }

/* ============================================================
   FORM
   ============================================================ */
.form-grid { display:flex; flex-direction:column; gap:18px; max-width:760px; }
.row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field { display:flex; flex-direction:column; gap:7px; }
.field__label { font-size:11.5px; text-transform:uppercase; letter-spacing:.09em; color:var(--gray-500); font-weight:500; }
.input, .select, .textarea { width:100%; font-family:inherit; font-size:15px; color:var(--ink); background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:11px 13px; transition:border-color .15s,box-shadow .15s; }
.input:focus, .select:focus, .textarea:focus { outline:none; border-color:var(--black); box-shadow:0 0 0 3px rgba(13,13,13,.06); }
.input[readonly] { background:var(--gray-100); color:var(--gray-500); }
.textarea { resize:vertical; min-height:84px; }
.fieldset { border:1px solid var(--line); border-radius:var(--radius-lg); padding:20px; display:flex; flex-direction:column; gap:16px; }
.fieldset > legend { font-size:12px; text-transform:uppercase; letter-spacing:.08em; color:var(--gray-500); font-weight:600; padding:0 8px; }
.pick-map { height:300px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); position:relative; z-index:0; }

/* --- Selector de tipo (segmented) --- */
.seg { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.seg__opt { display:flex; align-items:center; gap:12px; padding:16px; border:1.5px solid var(--line); border-radius:var(--radius-lg); background:var(--white); cursor:pointer; transition:border-color .15s, background .15s; }
.seg__opt:hover { border-color:var(--gray-300); }
.seg__opt.is-on { border-color:var(--black); background:var(--gray-50); }
.seg__opt input { position:absolute; opacity:0; pointer-events:none; }
.seg__ic { width:42px; height:42px; flex-shrink:0; border-radius:10px; background:var(--gray-100); display:flex; align-items:center; justify-content:center; color:var(--black); }
.seg__opt.is-on .seg__ic { background:var(--black); color:var(--white); }
.seg__ic svg { width:22px; height:22px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.seg__txt { display:flex; flex-direction:column; gap:2px; }
.seg__label { font-weight:600; font-size:14.5px; color:var(--black); }
.seg__sub { font-size:12px; color:var(--gray-500); }

/* Badge de modo automático */
.mode-badge { display:inline-flex; align-items:center; gap:7px; font-size:12.5px; color:var(--gray-700); background:var(--gray-100); border-radius:999px; padding:6px 13px; }
.mode-badge b { color:var(--black); font-weight:600; }
.mode-badge.is-domicilio b { color:var(--domicilio); }
.mode-badge svg { width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:1.7; }

/* --- Uploader de foto --- */
.uploader { display:flex; align-items:center; gap:18px; }
.uploader__preview { width:96px; height:96px; border-radius:50%; object-fit:cover; background:var(--gray-100); border:1px solid var(--line); flex-shrink:0; }
.uploader__ph { width:96px; height:96px; border-radius:50%; background:var(--gray-100); border:1px dashed var(--gray-300); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.uploader__ph svg { width:30px; height:30px; fill:none; stroke:var(--gray-500); stroke-width:1.5; }
.uploader__side { display:flex; flex-direction:column; gap:6px; }
.uploader__hint { font-size:12.5px; color:var(--gray-500); max-width:280px; }

/* --- Autocompletado de dirección --- */
.ac { position:relative; z-index:50; }
.ac__list { position:absolute; z-index:60; top:calc(100% + 4px); left:0; right:0; background:var(--white); border:1px solid var(--line); border-radius:var(--radius); box-shadow:0 8px 24px rgba(13,13,13,.1); overflow:hidden; display:none; max-height:280px; overflow-y:auto; }
.ac__list.is-open { display:block; }
.ac__item { display:flex; align-items:flex-start; gap:10px; padding:11px 13px; cursor:pointer; border-bottom:1px solid var(--gray-100); }
.ac__item:last-child { border-bottom:0; }
.ac__item:hover, .ac__item.is-active { background:var(--gray-50); }
.ac__item svg { width:16px; height:16px; margin-top:2px; flex-shrink:0; fill:none; stroke:var(--gray-500); stroke-width:1.7; }
.ac__main { font-size:14px; color:var(--black); }
.ac__sub { font-size:12px; color:var(--gray-500); }
.ac__loading { font-size:12px; color:var(--gray-500); padding:10px 13px; }

/* --- Redes con íconos --- */
.social-field { position:relative; }
.social-field__icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); width:18px; height:18px; color:var(--gray-700); pointer-events:none; }
.social-field__icon svg { width:18px; height:18px; }
.social-field .input { padding-left:40px; }

/* --- Recortador de foto (mover + zoom) --- */
.cropper { position:relative; width:160px; height:160px; border-radius:50%; overflow:hidden; background:var(--gray-100); border:1px solid var(--line); cursor:grab; touch-action:none; user-select:none; flex-shrink:0; }
.cropper.is-empty { cursor:default; }
.cropper:active { cursor:grabbing; }
.cropper img { position:absolute; top:0; left:0; transform-origin:0 0; pointer-events:none; -webkit-user-drag:none; max-width:none; }
.cropper__empty { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:6px; color:var(--gray-500); }
.cropper__empty svg { width:30px; height:30px; fill:none; stroke:var(--gray-500); stroke-width:1.5; }
.cropper__empty span { font-size:11px; }
.cropper__hintmove { position:absolute; bottom:8px; left:50%; transform:translateX(-50%); font-size:10px; background:rgba(13,13,13,.6); color:#fff; padding:2px 8px; border-radius:999px; pointer-events:none; opacity:0; transition:opacity .2s; }
.cropper:hover .cropper__hintmove { opacity:1; }
.crop-zoom { display:flex; align-items:center; gap:8px; width:160px; margin-top:10px; }
.crop-zoom svg { width:15px; height:15px; fill:none; stroke:var(--gray-500); stroke-width:1.8; flex-shrink:0; }
.crop-zoom input[type=range] { width:100%; accent-color:var(--black); }
.crop-zoom.is-hidden { display:none; }

/* --- Modal de confirmación (marca) --- */
.modal { position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:24px; }
.modal.is-open { display:flex; }
.modal__bg { position:absolute; inset:0; background:rgba(13,13,13,.45); }
.modal__card { position:relative; overflow:hidden; background:var(--white); border:1px solid var(--line); border-radius:18px; padding:28px 26px 22px; max-width:400px; width:100%; box-shadow:0 24px 70px rgba(13,13,13,.22); animation:modalIn .2s cubic-bezier(.16,1,.3,1); }
@keyframes modalIn { from { opacity:0; transform:translateY(12px) scale(.97) } to { opacity:1; transform:none } }
.modal__wm { position:absolute; top:-34px; right:-34px; width:210px; height:210px; opacity:.05; pointer-events:none; z-index:0; }
.modal__wm svg { width:100%; height:100%; fill:none; stroke:var(--black); stroke-width:1.4; stroke-linecap:round; stroke-linejoin:round; }
.modal__title { position:relative; z-index:1; font-size:19px; font-weight:700; letter-spacing:-.01em; color:var(--black); }
.modal__msg { position:relative; z-index:1; color:var(--gray-700); font-size:14px; margin:8px 0 22px; line-height:1.55; }
.modal__actions { position:relative; z-index:1; display:flex; gap:10px; }
.modal__actions .btn { flex:1; }
.modal__discard { background:transparent; color:var(--domicilio); border-color:var(--line); }
.modal__discard:hover { background:rgba(230,57,70,.07); border-color:var(--domicilio); opacity:1; }

.alert { font-size:13.5px; border-left:3px solid var(--black); background:var(--gray-100); padding:11px 14px; border-radius:0 var(--radius) var(--radius) 0; }
.alert--error { border-color:var(--domicilio); background:rgba(230,57,70,.07); color:var(--domicilio); }

.empty { text-align:center; color:var(--gray-500); padding:54px 20px; }
.empty__icon { width:42px; height:42px; margin:0 auto 14px; opacity:.4; fill:none; stroke:var(--gray-500); stroke-width:1.4; }
.empty__title { font-size:16px; font-weight:600; color:var(--gray-700); }
.empty__sub { font-size:13.5px; margin-top:4px; }

.soon { display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:80px 24px; }
.soon__badge { font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--gray-700); background:var(--gray-100); padding:4px 12px; border-radius:999px; font-weight:600; }
.soon__title { font-size:24px; font-weight:700; letter-spacing:-.02em; margin-top:16px; color:var(--black); }
.soon__sub { color:var(--gray-500); margin-top:8px; max-width:420px; }

/* ============================================================
   LOGIN
   ============================================================ */
.login { min-height:100vh; display:grid; place-items:center; padding:24px; background:var(--gray-50); }
.login__card { width:100%; max-width:380px; background:var(--white); border:1px solid var(--line); border-radius:var(--radius-lg); padding:38px 34px; }
.login__brand { display:flex; align-items:center; gap:10px; margin-bottom:26px; }
.login__brand img { height:32px; width:auto; object-fit:contain; }
.login__brand-name { font-weight:700; letter-spacing:.02em; }
.login__brand-sub { font-size:10.5px; text-transform:uppercase; letter-spacing:.12em; color:var(--gray-500); }
.login__title { font-size:22px; font-weight:700; letter-spacing:-.02em; color:var(--black); }
.login__sub { color:var(--gray-500); font-size:14px; margin:4px 0 24px; }
.login .field { margin-bottom:16px; }
.login .btn { width:100%; margin-top:6px; padding:12px; }

/* ============================================================
   LOGIN 2 COLUMNAS (video + form)
   ============================================================ */
.login2 { display:grid; grid-template-columns:1.05fr 1fr; min-height:100vh; background:var(--gray-50); }
.login2__media { position:relative; overflow:hidden; background:#0d0d0d url('../img/logo-mark-white.png') center 38% / 132px auto no-repeat; }
.login2__video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.login2__overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(13,13,13,.15) 0%, rgba(13,13,13,.35) 45%, rgba(13,13,13,.82) 100%); z-index:1; }
.login2__brandbox { position:absolute; left:0; right:0; bottom:0; padding:48px 46px; color:#fff; z-index:2; }
.login2__logo { width:auto; height:66px; margin-bottom:20px; display:block; object-fit:contain; }
.login2__quote { font-family:var(--font); font-weight:300; font-size:26px; line-height:1.4; letter-spacing:-.01em; max-width:440px; }
.login2__sign { margin-top:18px; font-size:11px; text-transform:uppercase; letter-spacing:.18em; opacity:.55; }

.login2__panel { display:flex; align-items:center; justify-content:center; padding:40px 28px; }
.login2__form { width:100%; max-width:380px; }
.login2__formlogo { width:auto; height:40px; margin-bottom:24px; display:block; object-fit:contain; }
.login2__head { margin-bottom:24px; }
.login2__chip { display:inline-block; font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--gray-700); background:var(--gray-100); padding:5px 12px; border-radius:999px; font-weight:600; }
.login2__title { font-size:30px; font-weight:700; letter-spacing:-.02em; margin-top:16px; color:var(--black); }
.login2__sub { color:var(--gray-500); font-size:14.5px; margin-top:6px; }
.login2 .field { margin-bottom:16px; }
.login2__foot { text-align:center; color:var(--gray-500); font-size:12.5px; margin-top:26px; }

@media (max-width:820px) {
  .login2 { grid-template-columns:1fr; }
  /* Video de fondo con baja opacidad (se ven las manitos detrás del form) */
  .login2__media { display:block; position:fixed; inset:0; z-index:0; background:var(--gray-50); }
  .login2__video { opacity:.14; }
  .login2__overlay { background:linear-gradient(180deg, rgba(250,250,248,.5), rgba(250,250,248,.82)); }
  .login2__brandbox { display:none; }
  .login2__panel { position:relative; z-index:1; min-height:100vh; padding:32px 22px; background:transparent; }
}

/* ============================================================
   RESPONSIVE (móvil): sidebar como drawer
   ============================================================ */
.backdrop { display:none; }
@media (max-width:860px) {
  .topbar { display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:30; background:rgba(255,255,255,.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); padding:12px 18px; }
  .topbar__brand { display:flex; align-items:center; gap:9px; font-weight:700; letter-spacing:.02em; }
  .topbar__brand img { width:26px; height:26px; }
  .topbar__burger { border:1px solid var(--line); background:var(--white); border-radius:9px; width:40px; height:40px; display:flex; align-items:center; justify-content:center; }
  .topbar__burger svg { width:20px; height:20px; fill:none; stroke:var(--black); stroke-width:1.8; stroke-linecap:round; }

  .sidebar { position:fixed; left:0; top:0; height:100dvh; width:var(--sidebar-w); transform:translateX(-102%); transition:transform .22s ease; box-shadow:0 0 40px rgba(0,0,0,.3); }
  .shell.drawer-open .sidebar { transform:translateX(0); }
  .shell.is-collapsed .sidebar { width:var(--sidebar-w); }
  .shell.is-collapsed .side-label,
  .shell.is-collapsed .sidebar__brand-text,
  .shell.is-collapsed .sidebar__user,
  .shell.is-collapsed .nav__section { display:block; }

  .backdrop { display:block; position:fixed; inset:0; background:rgba(0,0,0,.4); opacity:0; pointer-events:none; transition:opacity .22s; z-index:35; }
  .shell.drawer-open .backdrop { opacity:1; pointer-events:auto; }

  .main, .shell.is-collapsed .main { margin-left:0; }
  .main__inner { padding:22px 18px 90px; }
  .page-title { font-size:24px; }
  .stat-grid { grid-template-columns:repeat(2,1fr); }
  .row-2 { grid-template-columns:1fr; }
  .table { min-width:560px; }
}
