/* ============================================================
   GSQ CheckList — Sistema de diseño "Industrial Confident"
   Tipografía: Archivo (display) · Manrope (body) · JetBrains Mono (datos)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@600;700;800;900&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600&display=swap');

:root{
  /* Brand */
  --red:        #E30613;
  --red-deep:   #B0040E;
  --red-soft:   #FBE7E9;

  /* Ink scale (charcoal cálido, no negro frío) */
  --ink-900:    #1A1614;
  --ink-700:    #3A332E;
  --ink-500:    #6B635C;
  --ink-300:    #A39B92;
  --ink-100:    #D9D2C7;

  /* Superficies (crema cálido, no gris cold) */
  --bg:         #F8F4ED;
  --surface:    #FFFFFF;
  --surface-2:  #FAF7F1;
  --border:     #E8DFD2;
  --border-strong:#D4C9B8;

  /* Acentos categorías */
  --metal:      #6B6B6B;
  --obra:       #2B2622;
  --madera:     #C97B4A;

  /* Estado */
  --ok:         #2F7D52;
  --ok-soft:    #DEEFE3;
  --warn:       #B26A0E;
  --warn-soft:  #FAEDD3;

  /* Tipografía */
  --font-display: 'Archivo', sans-serif;
  --font-body:    'Manrope', sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* Sistema */
  --radius-sm: 8px;
  --radius:    12px;
  --radius-lg: 18px;
  --shadow-sm: 0 1px 2px rgba(26,22,20,.04), 0 1px 3px rgba(26,22,20,.06);
  --shadow:    0 2px 6px rgba(26,22,20,.04), 0 8px 24px rgba(26,22,20,.06);
  --shadow-lg: 0 12px 40px rgba(26,22,20,.10);
  --shadow-red:0 6px 20px rgba(227,6,19,.28);
  --ease:      cubic-bezier(.22,.61,.36,1);

  /* Compat (variables viejas reusadas en HTML inline) */
  --gsg-red:       var(--red);
  --gsg-red-dark:  var(--red-deep);
  --gsg-gray:      var(--ink-900);
  --gsg-gray-2:    var(--ink-500);
  --gsg-bg:        var(--bg);
  --gsg-card:      var(--surface);
  --gsg-border:    var(--border);
}

*{box-sizing:border-box}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}
*::-webkit-scrollbar-track{background:transparent}

html,body{
  margin:0;padding:0;background:var(--bg);color:var(--ink-900);
  font-family:var(--font-body);font-size:15px;line-height:1.5;
  font-feature-settings:"ss01","cv11","cv02";
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
/* textura crema sutil de fondo */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background:
    radial-gradient(1200px 600px at 100% -10%, rgba(227,6,19,.04), transparent 70%),
    radial-gradient(900px 500px at -10% 100%, rgba(201,123,74,.06), transparent 70%);
}

a{color:var(--red);text-decoration:none;transition:color .15s var(--ease)}
a:hover{color:var(--red-deep)}
img{max-width:100%}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;letter-spacing:-.01em;color:var(--ink-900);margin:0}
h1{font-size:32px;letter-spacing:-.02em}
h2{font-size:22px}
h3{font-size:17px;font-weight:700}
h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--red)}

.num,.stat .num{font-family:var(--font-display);font-variant-numeric:tabular-nums}
.mono{font-family:var(--font-mono)}

/* ============================================================
   LOGIN
   ============================================================ */
.login-wrap{
  min-height:100vh;display:grid;place-items:center;padding:24px;
  background:
    radial-gradient(800px 500px at 80% 20%, rgba(227,6,19,.10), transparent 70%),
    linear-gradient(135deg,#F8F4ED 0%, #EDE5D7 100%);
}
.login-card{
  background:var(--surface);width:100%;max-width:400px;padding:44px 36px 36px;
  border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  border:1px solid var(--border);text-align:center;position:relative;overflow:hidden;
}
.login-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--red) 0%, var(--madera) 100%)}
.login-card .logo{max-width:180px;margin:0 auto 20px;display:block}
.login-card h1{font-size:18px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-900)}
.login-card p.sub{color:var(--ink-500);margin:6px 0 28px;font-size:13px;letter-spacing:.02em}
.login-card .err{
  background:var(--red-soft);color:var(--red-deep);padding:11px 14px;
  border-radius:var(--radius-sm);margin-bottom:16px;font-size:13px;font-weight:500;
  border:1px solid #f5c6cb;text-align:left;
}

/* ============================================================
   FORMULARIOS — inputs unificados, foco rojo, alturas táctiles
   ============================================================ */
.field{margin-bottom:16px;text-align:left}
.field label{
  display:block;font-size:11px;font-weight:700;color:var(--ink-700);
  margin-bottom:7px;text-transform:uppercase;letter-spacing:.08em;
}

.input,select,textarea,input[type=text],input[type=password],input[type=number],input[type=email],input[type=tel],input[type=file]{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--border);background:var(--surface);
  border-radius:var(--radius-sm);font:500 14px var(--font-body);color:var(--ink-900);
  transition:border-color .15s var(--ease), box-shadow .15s var(--ease), background .15s;
  appearance:none;-webkit-appearance:none;
}
textarea{min-height:72px;resize:vertical;line-height:1.5}
.input:hover,select:hover,textarea:hover{border-color:var(--border-strong)}
.input:focus,select:focus,textarea:focus,input:focus{
  outline:none;border-color:var(--red);
  box-shadow:0 0 0 4px rgba(227,6,19,.10);
}
.input:disabled,select:disabled,input:disabled{background:var(--surface-2);color:var(--ink-300);cursor:not-allowed}
::placeholder{color:var(--ink-300);font-weight:400}

/* Select con flecha custom */
select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%231A1614' stroke-width='1.8' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
  cursor:pointer;
}

/* File input */
input[type=file]{padding:10px 14px;cursor:pointer;font-weight:500}
input[type=file]::-webkit-file-upload-button{
  background:var(--ink-900);color:#fff;border:0;padding:8px 14px;border-radius:6px;
  font:600 12px var(--font-body);text-transform:uppercase;letter-spacing:.05em;
  margin-right:12px;cursor:pointer;transition:background .15s;
}
input[type=file]::-webkit-file-upload-button:hover{background:var(--red)}

/* Checkbox & Radio refinados */
input[type=checkbox],input[type=radio]{
  appearance:none;width:18px;height:18px;border:1.5px solid var(--border-strong);
  border-radius:4px;cursor:pointer;background:#fff;flex-shrink:0;
  transition:all .15s var(--ease);position:relative;vertical-align:middle;
}
input[type=radio]{border-radius:50%}
input[type=checkbox]:checked,input[type=radio]:checked{background:var(--red);border-color:var(--red)}
input[type=checkbox]:checked::after{
  content:"";position:absolute;top:2px;left:5px;width:5px;height:9px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);
}
input[type=radio]:checked::after{
  content:"";position:absolute;top:4px;left:4px;width:8px;height:8px;
  border-radius:50%;background:#fff;
}

/* Range slider — track con relleno usando --val (0..100) */
input[type=range]{
  -webkit-appearance:none;width:100%;height:6px;outline:none;padding:0;
  background:linear-gradient(to right,var(--red) 0%,var(--red) var(--val,0%),var(--border) var(--val,0%),var(--border) 100%);
  border-radius:99px;transition:background .12s var(--ease);
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:var(--red);cursor:pointer;border:3px solid #fff;
  box-shadow:0 2px 6px rgba(227,6,19,.35);transition:transform .12s var(--ease);
}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.12)}
input[type=range]::-moz-range-thumb{
  width:20px;height:20px;border-radius:50%;background:var(--red);
  cursor:pointer;border:3px solid #fff;box-shadow:0 2px 6px rgba(227,6,19,.35);
}
input[type=range]:focus{box-shadow:0 0 0 4px rgba(227,6,19,.10)}

/* Switch / Toggle — usa <input type=checkbox class="switch"> */
input[type=checkbox].switch{
  appearance:none;width:42px;height:24px;border-radius:99px;
  background:var(--border-strong);border:0;position:relative;cursor:pointer;
  transition:background .18s var(--ease);
}
input[type=checkbox].switch::after{
  content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;
  border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);
  transition:transform .2s var(--ease);
}
input[type=checkbox].switch:checked{background:var(--red)}
input[type=checkbox].switch:checked::after{transform:translateX(18px)}
input[type=checkbox].switch:checked::before{content:none}

/* Color picker */
input[type=color]{
  width:48px;height:40px;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  cursor:pointer;padding:3px;background:#fff;
}

/* ============================================================
   BOTONES — sistema unificado
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--red);color:#fff;border:0;
  padding:11px 18px;border-radius:var(--radius-sm);
  font:700 13px var(--font-body);letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;transition:transform .12s var(--ease), background .15s, box-shadow .2s;
  box-shadow:0 1px 0 rgba(0,0,0,.06), 0 4px 12px rgba(227,6,19,.18);
  white-space:nowrap;text-decoration:none;
}
.btn:hover{background:var(--red-deep);box-shadow:var(--shadow-red);text-decoration:none;color:#fff}
.btn:active{transform:translateY(1px);box-shadow:0 1px 4px rgba(227,6,19,.25)}
.btn:disabled{background:var(--ink-300);box-shadow:none;cursor:not-allowed}

.btn.block{width:100%}
.btn.sm{padding:7px 12px;font-size:11px;letter-spacing:.05em}
.btn.lg,.btn.big{padding:14px 24px;font-size:14px}

.btn.ghost{
  background:transparent;color:var(--ink-900);
  border:1.5px solid var(--border-strong);box-shadow:none;
}
.btn.ghost:hover{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}

.btn.dark{background:var(--ink-900);box-shadow:0 4px 12px rgba(26,22,20,.18)}
.btn.dark:hover{background:#000}

.btn.danger-outline{background:transparent;color:var(--red);border:1.5px solid var(--red);box-shadow:none}
.btn.danger-outline:hover{background:var(--red);color:#fff}

/* Tonal — fondo rojo suave, texto rojo profundo (acción secundaria suave) */
.btn.tonal{background:var(--red-soft);color:var(--red-deep);box-shadow:none}
.btn.tonal:hover{background:#f6d3d6;color:var(--red-deep)}

/* Soft / quiet — sin fondo, hover suave (acciones terciarias en cards/tablas) */
.btn.soft{background:transparent;color:var(--ink-700);box-shadow:none;font-weight:600}
.btn.soft:hover{background:var(--surface-2);color:var(--ink-900)}

/* Icon-only redondo */
.btn.icon{
  width:40px;height:40px;padding:0;border-radius:50%;
  background:#fff;color:var(--ink-700);border:1px solid var(--border);box-shadow:none;
}
.btn.icon:hover{border-color:var(--red);color:var(--red);background:#fffafa}
.btn.icon.sm{width:32px;height:32px}

/* Grupo de botones — alineación coherente (ej. footer modal) */
.btn-group{display:inline-flex;gap:8px;flex-wrap:wrap}

/* ============================================================
   SEGMENTED — control segmentado tipo iOS para 2-4 opciones
   ============================================================ */
.segmented{
  display:inline-flex;background:var(--surface-2);border:1px solid var(--border);
  border-radius:99px;padding:3px;gap:2px;
}
.segmented button,.segmented a{
  border:0;background:transparent;padding:7px 16px;border-radius:99px;
  font:700 12px var(--font-body);text-transform:uppercase;letter-spacing:.05em;
  color:var(--ink-500);cursor:pointer;transition:all .15s var(--ease);
  text-decoration:none;
}
.segmented button:hover,.segmented a:hover{color:var(--ink-900)}
.segmented button.active,.segmented a.active{
  background:#fff;color:var(--red);box-shadow:0 1px 3px rgba(26,22,20,.10);
}

/* ============================================================
   APP LAYOUT — sidebar + main
   ============================================================ */
.app{display:flex;min-height:100vh}

.sidebar{
  width:248px;flex-shrink:0;padding:24px 14px;
  background:linear-gradient(175deg,var(--ink-900) 0%, #110D0B 100%);
  color:#fff;display:flex;flex-direction:column;position:relative;
}
.sidebar::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--red) 0%, var(--madera) 100%);
}

.sidebar .brand{
  display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:28px;
  background:rgba(255,255,255,.04);border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.06);
}
.sidebar .brand img{width:36px;height:36px;object-fit:contain;background:#fff;padding:4px;border-radius:8px}
.sidebar .brand span{font:800 15px var(--font-display);letter-spacing:.02em;color:#fff}

.sidebar nav{display:flex;flex-direction:column;gap:2px}
.sidebar nav a{
  display:flex;align-items:center;gap:10px;padding:11px 14px;
  color:rgba(255,255,255,.65);font:600 13px var(--font-body);letter-spacing:.02em;
  border-radius:var(--radius-sm);transition:all .15s var(--ease);
  position:relative;
}
.sidebar nav a:hover{color:#fff;background:rgba(255,255,255,.05);text-decoration:none}
.sidebar nav a.active{color:#fff;background:var(--red);box-shadow:0 4px 14px rgba(227,6,19,.35)}
.sidebar nav a.active::before{
  content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;
  background:var(--madera);border-radius:0 3px 3px 0;
}

.sidebar .spacer{flex:1}
.sidebar .role{
  text-align:center;font-size:10px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.4);margin:14px 0 8px;
}
.sidebar .logout{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 14px;border-radius:var(--radius-sm);
  background:rgba(255,255,255,.06);color:#fff;font:600 12px var(--font-body);
  letter-spacing:.04em;text-transform:uppercase;transition:background .15s;
}
.sidebar .logout:hover{background:var(--red);text-decoration:none;color:#fff}
.sidebar .logout-short{display:none}
.sidebar .logout-full{display:inline}

.main{flex:1;padding:32px 36px;min-width:0;max-width:100%}

.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:14px;flex-wrap:wrap}
.topbar h2{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--ink-900);letter-spacing:-.01em}
.topbar .user{display:flex;align-items:center;gap:12px;font-size:13px}
.topbar .avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--red) 0%, var(--red-deep) 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font:800 15px var(--font-display);box-shadow:var(--shadow-red);
}

/* ============================================================
   CARDS
   ============================================================ */
.card{
  background:var(--surface);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:22px;margin-bottom:18px;
  border:1px solid var(--border);
  transition:box-shadow .2s var(--ease), transform .2s;
}
.card:hover{box-shadow:var(--shadow)}
.card h3{margin:0 0 16px;color:var(--ink-900)}

.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}

/* KPI */
.kpi{display:flex;align-items:center;gap:14px}
.kpi .num{font:800 36px var(--font-display);color:var(--ink-900);letter-spacing:-.02em;line-height:1}
.kpi .lbl{font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-top:6px}

/* ============================================================
   TABLAS
   ============================================================ */
table.tbl{width:100%;border-collapse:collapse}
table.tbl th,table.tbl td{padding:13px 14px;text-align:left;border-bottom:1px solid var(--border);font-size:14px}
table.tbl th{
  background:transparent;font:700 10px var(--font-body);text-transform:uppercase;
  color:var(--ink-500);letter-spacing:.1em;border-bottom:2px solid var(--border-strong);
}
table.tbl tr:last-child td{border-bottom:0}
table.tbl tr:hover td{background:var(--surface-2)}

/* ============================================================
   BADGES & ALERTS
   ============================================================ */
.badge{
  display:inline-block;padding:4px 10px;border-radius:99px;
  font:700 10px var(--font-body);text-transform:uppercase;letter-spacing:.08em;
}
.badge.admin{background:var(--red-soft);color:var(--red-deep)}
.badge.vendedor{background:#E1ECFB;color:#1d4ed8}
.badge.supervisor{background:#EDE4FB;color:#5B21B6}
.badge.operativo{background:#FFF1D6;color:#92580B}

/* Estados de pedido */
.badge.dot{display:inline-flex;align-items:center;gap:6px}
.badge.dot::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.badge.estado-borrador {background:#EEE9DD;color:#6B635C}
.badge.estado-enviado  {background:var(--ok-soft);color:var(--ok)}
.badge.estado-bloqueado{background:var(--warn-soft);color:var(--warn)}
.badge.estado-cancelado{background:var(--red-soft);color:var(--red-deep)}

.alert{
  padding:13px 16px;border-radius:var(--radius-sm);margin-bottom:16px;
  font-size:14px;font-weight:500;border:1px solid transparent;
  display:flex;align-items:center;gap:10px;
}
.alert::before{font-size:16px}
.alert.ok{background:var(--ok-soft);color:var(--ok);border-color:#bfd9c8}
.alert.ok::before{content:"✓"}
.alert.err{background:var(--red-soft);color:var(--red-deep);border-color:#f5c6cb}
.alert.err::before{content:"⚠"}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .main{padding:22px 22px}
  .sidebar{width:118px;padding:18px 10px}
  .sidebar .brand span{display:none}
  .sidebar .role{display:none}
  .sidebar .brand{justify-content:center;padding:8px}
  .sidebar nav a{
    justify-content:center;
    padding:10px 8px;
    min-height:52px;
    text-align:center;
  }
  .sidebar nav a span{
    display:block;
    font-size:10px;
    line-height:1.15;
    letter-spacing:.03em;
    white-space:normal;
    max-width:86px;
  }
  .sidebar nav a.active::before{display:none}
  .sidebar .logout{
    flex-direction:column;
    gap:3px;
    padding:10px 6px;
    min-height:54px;
    text-align:center;
    border:1px solid rgba(255,255,255,.08);
  }
  .sidebar .logout-short{
    display:block;
    font-size:11px;
    line-height:1;
    font-weight:800;
    letter-spacing:.08em;
  }
  .sidebar .logout-full{
    display:block;
    font-size:10px;
    line-height:1.15;
    letter-spacing:.03em;
    text-transform:uppercase;
  }
}
@media(max-width:680px){
  body{font-size:14px}
  .app{flex-direction:column}
  .sidebar{
    width:100%;flex-direction:row;align-items:center;flex-wrap:wrap;
    padding:10px 12px;gap:8px;overflow-x:hidden;position:sticky;top:0;z-index:10;
  }
  .sidebar::before{height:2px}
  .sidebar .brand{margin:0;padding:6px 0;flex:1 1 auto;min-width:0;background:transparent;border:0}
  .sidebar .brand img{width:34px;height:34px}
  .sidebar .brand span{display:inline}
  .sidebar nav{order:3;flex-direction:row;gap:6px;flex:0 0 100%;overflow-x:auto;padding:2px 0 0}
  .sidebar nav a{padding:8px 12px;white-space:nowrap;font-size:11px;min-height:34px}
  .sidebar nav a span{display:inline}
  .sidebar nav a.active::before{display:none}
  .sidebar .spacer,.sidebar .role{display:none}
  .sidebar .logout{flex:0 0 auto;padding:8px 10px;font-size:10px;background:rgba(255,255,255,.08)}
  .sidebar .logout-short{display:none}
  .sidebar .logout-full{display:inline}
  .main{padding:16px 14px}
  .topbar{margin-bottom:14px}
  .topbar h2{font-size:18px}
  .card{padding:16px;border-radius:var(--radius-sm)}
  h1{font-size:24px}
}

/* ============================================================
   UTILITY: foco accesible visible
   ============================================================ */
:focus-visible{outline:none}
button:focus-visible,a:focus-visible{box-shadow:0 0 0 3px rgba(227,6,19,.30)}

/* ============================================================
   KICKERS — eyebrows uppercase reutilizables
   ============================================================ */
.kicker{font:800 11px var(--font-body);letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:5px;display:block}
.kicker.muted{color:var(--ink-500)}
.kicker.light{color:rgba(255,255,255,.85)}

/* ============================================================
   LOGO TILE — slot reusable para logos / iniciales
   ============================================================ */
.logo-tile{
  display:grid;place-items:center;background:#f4f5f7;border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;padding:6px;flex-shrink:0;
}
.logo-tile img{max-width:100%;max-height:100%;object-fit:contain}
.logo-tile b,.logo-tile span{font:800 18px var(--font-display);color:var(--red);letter-spacing:.04em}
.logo-tile.sm{width:54px;height:54px;border-radius:10px;padding:5px}
.logo-tile.sm b,.logo-tile.sm span{font-size:14px}
.logo-tile.md{width:70px;height:70px;border-radius:12px}
.logo-tile.lg{width:88px;height:88px;border-radius:14px;padding:8px}
.logo-tile.lg b,.logo-tile.lg span{font-size:22px}
.logo-tile.xl{width:112px;height:112px;border-radius:14px;padding:10px}

/* ============================================================
   MODAL — sistema unificado (backdrop + sheet + close + head + actions)
   ============================================================ */
.gsg-modal[hidden]{display:none}
.gsg-modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:18px}
.gsg-modal__backdrop{position:absolute;inset:0;background:rgba(26,22,20,.58);backdrop-filter:blur(3px);animation:gsg-fade .18s var(--ease)}
.gsg-modal__sheet{
  position:relative;width:min(760px,100%);max-height:min(88vh,780px);overflow:auto;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:0 24px 80px rgba(26,22,20,.30);padding:22px;
  animation:gsg-rise .22s var(--ease);
}
.gsg-modal__sheet.sm{width:min(560px,100%)}
.gsg-modal__sheet.md{width:min(680px,100%)}
.gsg-modal__sheet.lg{width:min(900px,100%)}
.gsg-modal__close{
  position:absolute;top:12px;right:12px;width:40px;height:40px;border:1px solid var(--border);
  border-radius:50%;background:#fff;font-size:22px;cursor:pointer;
  color:var(--ink-700);transition:background .15s, color .15s, border-color .15s, transform .12s;
  line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0;
}
.gsg-modal__close:hover{background:var(--red-soft);color:var(--red);border-color:#f3c4c8}
.gsg-modal__close:active{transform:scale(.96)}
.gsg-modal__head{display:flex;gap:14px;align-items:flex-start;padding-right:42px}
.gsg-modal__head h3{margin:0}
.gsg-modal__head p{margin:4px 0 0;color:var(--ink-500);font-size:13px}
.gsg-modal__body{margin-top:18px}
.gsg-modal__actions{
  position:sticky;bottom:-22px;display:flex;justify-content:flex-end;gap:10px;
  margin-top:18px;padding:14px 0 0;background:#fff;border-top:1px solid var(--border);
}
body.gsg-modal-open{overflow:hidden}

@keyframes gsg-fade{from{opacity:0}to{opacity:1}}
@keyframes gsg-rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

@media(max-width:720px){
  .gsg-modal{align-items:end;padding:0}
  .gsg-modal__sheet{width:100%;max-height:92vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:18px}
  .gsg-modal__actions{bottom:-18px;padding:12px 0 0}
}

/* ============================================================
   CHOICE BUTTONS — selectores (presentación, color, sucursal…)
   ============================================================ */
.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}
.choice-btn{
  min-height:46px;border:1.5px solid var(--border);background:#fff;
  border-radius:var(--radius-sm);color:var(--ink-900);
  font:700 13px var(--font-body);cursor:pointer;text-align:left;padding:10px 12px;
  transition:border-color .15s var(--ease), box-shadow .15s, background .15s;
  display:flex;align-items:center;gap:10px;
}
.choice-btn small{display:block;margin-top:2px;color:var(--ink-500);font-size:11px;line-height:1.2}
.choice-btn:hover{border-color:var(--border-strong)}
.choice-btn.active{border-color:var(--red);box-shadow:0 0 0 3px rgba(227,6,19,.12);background:#fffafa}
.choice-btn .swatch{
  width:26px;height:26px;border-radius:7px;flex:0 0 auto;
  border:1px solid rgba(0,0,0,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.4);
}
.empty-choice{border:1px dashed var(--border-strong);border-radius:var(--radius-sm);padding:13px;color:var(--ink-500);font-size:13px;background:var(--surface-2)}

.swatch{width:26px;height:26px;border-radius:7px;border:1px solid rgba(0,0,0,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.4);flex:0 0 auto}
.swatch.sm{width:18px;height:18px;border-radius:5px}
.swatch.xs{width:14px;height:14px;border-radius:4px}

/* ============================================================
   QTY CONTROL — stepper táctil
   ============================================================ */
.qty-control{display:grid;grid-template-columns:48px minmax(80px,130px) 48px;gap:8px;align-items:center}
.qty-control button{
  width:48px;height:48px;border:1.5px solid var(--border);border-radius:var(--radius);
  background:#fff;font:800 22px var(--font-display);cursor:pointer;color:var(--ink-900);
  transition:border-color .12s, color .12s;
}
.qty-control button:hover{border-color:var(--red);color:var(--red)}
.qty-control input{text-align:center;height:48px;font:800 20px var(--font-display);border-radius:var(--radius)}

/* ============================================================
   SELECTION CHIP — resumen presentación + color + cantidad
   ============================================================ */
.selection-chip{
  display:grid;grid-template-columns:18px 1fr auto 26px;align-items:center;gap:8px;
  background:var(--surface-2);border:1px solid var(--border);border-radius:10px;
  padding:7px 7px 7px 9px;font-size:12px;
}
.selection-chip .swatch{width:18px;height:18px;border-radius:5px}
.selection-chip strong{display:block;color:var(--ink-900);font-size:12px;line-height:1.2}
.selection-chip small{display:block;color:var(--ink-500);font-size:11px;line-height:1.2;margin-top:2px}
.selection-chip .qty{font:800 13px var(--font-display);color:var(--red)}
.selection-chip .x{
  width:26px;height:26px;border:0;border-radius:50%;background:#fff;color:var(--ink-500);
  cursor:pointer;padding:0;font-size:14px;box-shadow:0 0 0 1px var(--border);
}
.selection-chip .x:hover{background:var(--red-soft);color:var(--red)}

/* ============================================================
   PILL TABS — categorías con color contextual via --tab-color
   ============================================================ */
.pill-tabs{display:flex;gap:6px;overflow-x:auto;flex-wrap:wrap}
.pill-tab{
  background:transparent;border:2px solid var(--border);color:var(--ink-700);
  padding:10px 18px;border-radius:var(--radius);font-weight:700;cursor:pointer;
  font-size:13px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;
  transition:all .15s var(--ease);position:relative;
}
.pill-tab:hover{border-color:var(--border-strong)}
.pill-tab.active{background:var(--tab-color,var(--red));color:#fff;border-color:var(--tab-color,var(--red));box-shadow:0 4px 14px rgba(227,6,19,.22)}
.pill-tab .pill-count{
  display:none;margin-left:6px;background:var(--red);color:#fff;
  border-radius:10px;padding:1px 7px;font-size:11px;
}
.pill-tab.has-items .pill-count{display:inline-block}
.pill-tab.active .pill-count{background:#fff;color:var(--tab-color,var(--red))}

/* ============================================================
   FILTER BAR — barras de filtros inline (form get)
   ============================================================ */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.filter-bar .field{margin:0;min-width:170px}
.filter-bar .field.grow{flex:1;min-width:200px}

/* ============================================================
   TOPBAR EXTENSIONS — bell + cluster derecho
   ============================================================ */
.topbar-right{display:flex;align-items:center;gap:14px}

.notif-bell{position:relative}
.notif-trigger{
  position:relative;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--border);background:#fff;cursor:pointer;
  display:grid;place-items:center;color:var(--ink-700);
  transition:border-color .15s var(--ease), color .15s, background .15s, transform .15s;
}
.notif-trigger:hover{border-color:var(--red);color:var(--red);background:#fffafa}
.notif-bell.has-unread .notif-trigger{color:var(--red);border-color:var(--red);animation:bell-shake .8s var(--ease) 1}
@keyframes bell-shake{
  0%,100%{transform:rotate(0)}
  20%{transform:rotate(-9deg)}40%{transform:rotate(7deg)}
  60%{transform:rotate(-5deg)}80%{transform:rotate(3deg)}
}
.notif-badge{
  position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;
  padding:0 6px;border-radius:99px;background:var(--red);color:#fff;
  font:800 11px var(--font-body);display:grid;place-items:center;
  border:2px solid #fff;box-shadow:0 2px 6px rgba(227,6,19,.4);
}

.notif-panel{
  position:absolute;top:calc(100% + 10px);right:0;width:min(360px,90vw);
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:0 18px 50px rgba(26,22,20,.22);overflow:hidden;z-index:80;
  animation:gsg-rise .18s var(--ease);
}
.notif-panel[hidden]{display:none}
.notif-panel__head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.notif-panel__head strong{font:700 13px var(--font-body);color:var(--ink-900);text-transform:uppercase;letter-spacing:.06em}
.notif-mark-all{background:none;border:0;color:var(--red);font:700 11px var(--font-body);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;padding:4px 0}
.notif-mark-all:hover{color:var(--red-deep)}
.notif-list{max-height:380px;overflow:auto}
.notif-item{
  display:grid;grid-template-columns:14px 1fr;gap:10px;align-items:flex-start;
  padding:12px 14px;border-bottom:1px solid var(--border);text-decoration:none;color:var(--ink-900);
  transition:background .12s;
}
.notif-item:last-child{border-bottom:0}
.notif-item:hover{background:var(--surface-2);text-decoration:none}
.notif-dot{width:9px;height:9px;border-radius:50%;background:var(--ink-300);margin-top:6px}
.notif-item.unread{background:#fff7f7}
.notif-item.unread .notif-dot{background:var(--red);box-shadow:0 0 0 3px rgba(227,6,19,.15)}
.notif-body strong{display:block;font-size:13px;font-weight:600;line-height:1.3}
.notif-body small{display:block;color:var(--ink-500);font-size:11px;margin-top:3px;font-family:var(--font-mono)}
.notif-empty{padding:28px 14px;text-align:center;color:var(--ink-500);font-size:13px}
.notif-panel__foot{padding:10px 14px;border-top:1px solid var(--border);background:var(--surface-2);text-align:center}
.notif-panel__foot a{font:700 12px var(--font-body);color:var(--red);text-transform:uppercase;letter-spacing:.06em}

@media(max-width:680px){
  .topbar-right{gap:10px}
  .topbar-right .user>div:not(.avatar){display:none}
  .notif-panel{position:fixed;right:8px;left:8px;top:auto;width:auto;max-height:70vh}
}

/* ============================================================
   HONDURAS MAP — SVG inline interactivo
   ============================================================ */
.hn-map-wrap{position:relative;width:100%;background:linear-gradient(180deg,#fff,#fafaf6);border:1px solid var(--border);border-radius:var(--radius);padding:10px}
.hn-map{width:100%;display:block}
.hn-map svg{width:100%;height:auto;display:block;max-height:520px}
@media(max-width:900px){
  .hn-map svg{max-height:380px}
}
.hn-map .hn-path{
  fill:#fff;stroke:var(--ink-700);stroke-width:1.6;
  transition:fill .18s var(--ease), stroke .12s, transform .12s;
  cursor:pointer;transform-origin:center;transform-box:fill-box;
}
.hn-map .hn-path:hover{stroke:var(--red);stroke-width:2.4;filter:drop-shadow(0 4px 8px rgba(227,6,19,.25))}
.hn-map .hn-label{
  font:800 18px var(--font-display);fill:var(--ink-900);
  paint-order:stroke;stroke:#fff;stroke-width:5px;stroke-linejoin:round;
  pointer-events:none;
}
.hn-map .hn-label.active{fill:var(--red-deep);font-size:22px}
.hn-map-tip{
  position:absolute;background:var(--ink-900);color:#fff;padding:8px 11px;border-radius:8px;
  font:600 12px var(--font-body);pointer-events:none;z-index:5;
  box-shadow:0 6px 18px rgba(0,0,0,.25);max-width:200px;line-height:1.35;
}
.hn-map-tip strong{color:#fff;font-weight:700}
@media(max-width:680px){
  .hn-map .hn-label{font-size:24px;stroke-width:6px}
  .hn-map .hn-label.active{font-size:30px}
}

/* ============================================================
   TOOLTIP — data-tip="texto" sobre cualquier elemento
   ============================================================ */
[data-tip]{position:relative}
[data-tip]::after{
  content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;
  transform:translateX(-50%) translateY(4px);
  background:var(--ink-900);color:#fff;padding:5px 9px;border-radius:6px;
  font:600 11px var(--font-body);letter-spacing:.02em;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .15s var(--ease), transform .15s var(--ease);
  z-index:90;box-shadow:0 4px 12px rgba(0,0,0,.18);
}
[data-tip]:hover::after,[data-tip]:focus-visible::after{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================================
   SKELETON — placeholder shimmer mientras carga
   ============================================================ */
.skel{
  display:block;background:linear-gradient(90deg,var(--surface-2) 0%,#f0eadf 50%,var(--surface-2) 100%);
  background-size:200% 100%;animation:skel 1.2s linear infinite;border-radius:6px;height:14px;
}
.skel.lg{height:22px}.skel.sm{height:10px}.skel.circle{border-radius:50%}
@keyframes skel{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ============================================================
   DIVIDER & UTILITIES
   ============================================================ */
.divider{height:1px;background:var(--border);margin:18px 0;border:0}
.divider.dashed{border-top:1px dashed var(--border-strong);background:transparent;height:0}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.row.between{justify-content:space-between}
.row.end{justify-content:flex-end}
.muted{color:var(--ink-500)}
.tnum{font-variant-numeric:tabular-nums}
@media(max-width:680px){.hide-sm{display:none !important}}

/* ============================================================
   SLIDER auto-fill — JS pequeño que actualiza --val
   (Carga este snippet una vez en layout o en cada página con sliders)
   ============================================================ */
