/* UI — carbón + ámbar, Plus Jakarta Sans, bordes suaves (sin marcos neón) */
.app-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing);padding:var(--spacing);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow)}
.app-logo{font-family:var(--font-display);font-weight:700;font-size:var(--font-title);color:var(--color-text);letter-spacing:-0.02em;margin:0}
.app-main{max-width:min(36rem,100%);margin:0 auto;padding:var(--spacing);padding-bottom:calc(var(--spacing)*3)}
.view{display:none}
.view.is-active{display:block}
.card{background:var(--color-surface);border-radius:var(--radius);padding:calc(var(--spacing)*1.25);box-shadow:var(--shadow);border:1px solid var(--color-border)}
.card__title{font-family:var(--font-display);font-size:var(--font-title);font-weight:700;margin:0 0 var(--spacing);color:var(--color-text);letter-spacing:-0.02em}
.muted{color:var(--color-muted);font-size:0.9rem;margin:0 0 var(--spacing)}
.stack{display:flex;flex-direction:column;gap:var(--spacing)}
.field{display:flex;flex-direction:column;gap:0.35rem}
.field__label{font-weight:600;font-size:0.95rem;color:var(--color-text)}
.field__hint{font-size:0.8rem;color:var(--color-muted);min-height:1.1em}
.input{width:100%;min-height:48px;padding:0 0.85rem;border:1px solid var(--color-border);border-radius:10px;background:var(--color-surface-2);font-size:1.05rem;color:var(--color-text)}
.input::placeholder{color:#71717a}
.input:focus{border-color:rgba(var(--color-primary-rgb),0.65);outline:none;box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),0.2)}
.input.is-invalid{border-color:var(--color-danger)}
.input.is-valid{border-color:var(--color-success)}
.pin-input{letter-spacing:0.35em;font-variant-numeric:tabular-nums}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 1.1rem;border:none;border-radius:10px;font-weight:600;font-size:1rem;cursor:pointer;text-decoration:none;width:100%}
.btn--lg{min-height:56px;font-size:1.1rem;padding:0 1.25rem;border-radius:12px}
/* Estado del pedido: chip legible, no titular gigante */
.estado-badge{
  font-family:var(--font-sans);
  font-size:0.8125rem;
  font-weight:600;
  letter-spacing:0.01em;
  line-height:1.3;
  margin:0 0 var(--spacing);
  padding:0.45rem 0.85rem;
  border-radius:999px;
  display:inline-block;
  max-width:100%;
  color:var(--color-on-primary);
  background:rgba(var(--color-primary-rgb),0.95);
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:0 1px 2px rgba(0,0,0,0.2);
}
.btn--primary{background:var(--color-primary);color:var(--color-on-primary)}
.btn--primary:hover{background:var(--color-primary-hover);color:var(--color-on-primary)}
.btn--primary:disabled{opacity:0.55;cursor:not-allowed}
.btn--ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border-strong)}
.btn--ghost:hover{background:rgba(255,255,255,0.06);border-color:#52525b}
.link-btn{background:none;border:none;padding:0;min-height:auto;width:auto;color:var(--color-link);font-weight:600;cursor:pointer;text-decoration:underline}
.msg{padding:0.65rem 0.85rem;border-radius:10px;font-size:0.9rem}
.msg--error{background:var(--color-danger-bg);color:#fecaca;border:1px solid rgba(239,68,68,0.35)}
.msg--ok{background:var(--color-success-bg);color:#bbf7d0;border:1px solid rgba(34,197,94,0.35)}
.loading-wrap{position:relative;min-height:3rem}
.spinner{width:2rem;height:2rem;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:mandao-spin 0.75s linear infinite;margin:var(--spacing) auto}
@keyframes mandao-spin{to{transform:rotate(360deg)}}
.loading-overlay{position:fixed;inset:0;background:rgba(20,20,22,0.88);display:flex;align-items:center;justify-content:center;z-index:50}
.loading-overlay[hidden]{display:none}
.text-center{text-align:center}
.mt{margin-top:var(--spacing)}
/* Destacado: acento lateral, sin contorno neón completo */
.card--solid{
  background:var(--color-surface);
  border:1px solid var(--color-border);
  border-left:4px solid var(--color-primary);
  box-shadow:var(--shadow);
}
.app-header--catalog{flex-wrap:wrap;align-items:center}
.app-header--catalog .app-logo{flex:1;text-align:center;font-size:1.1rem}
.app-header--catalog .header-lead{min-width:48px;flex-shrink:0}
.header-actions{display:flex;align-items:center;gap:0.5rem;flex-shrink:0}
.home-intro{margin-top:var(--spacing)}
.home-pedidos-heading{margin-top:var(--spacing)}
.home-pedidos-mount{margin-top:0.35rem}
.tab-btn--icon{min-height:48px;padding:0 0.35rem;border-radius:10px}
.cart-badge-btn{
  position:relative;
  min-width:48px;
  min-height:48px;
  padding:0;
  border:1px solid var(--color-border-strong);
  border-radius:9999px;
  background:var(--color-surface-2);
  box-shadow:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.cart-badge-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
.cart-badge{min-width:1.5rem;height:1.5rem;padding:0 0.35rem;border-radius:999px;background:var(--color-primary);color:var(--color-on-primary);font-size:0.8rem;font-weight:700;line-height:1.5rem;text-align:center}
.catalog-tabs{margin-bottom:var(--spacing)}
.tabs-label{font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;color:var(--color-muted);margin:0 0 0.35rem}
.tabs-scroll{display:flex;gap:0.5rem;overflow-x:auto;padding-bottom:0.25rem;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}
.tab-btn{flex:0 0 auto;scroll-snap-align:start;min-height:48px;padding:0 1rem;border-radius:10px;border:1px solid var(--color-border);background:var(--color-surface-2);color:var(--color-text);font-weight:600;font-size:0.95rem;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.tab-btn:hover{background:rgba(255,255,255,0.05)}
.tab-btn.is-active{background:var(--color-primary);color:var(--color-on-primary);border-color:transparent;box-shadow:var(--shadow-primary)}
.catalog-mount{min-height:4rem}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:var(--spacing)}
.card--product{display:flex;flex-direction:column;gap:0.5rem;min-height:100%}
.product-card__title{font-size:1rem;font-weight:600;margin:0;color:var(--color-text);line-height:1.25}
.product-card__price{font-size:1.05rem;font-weight:700;margin:0;color:var(--color-primary)}
.btn--add{margin-top:auto;min-height:48px}
.skeleton{pointer-events:none}
.sk-line{height:0.85rem;border-radius:6px;background:linear-gradient(90deg,#3f3f46 25%,#52525b 50%,#3f3f46 75%);background-size:200% 100%;animation:sk 1.1s ease-in-out infinite}
.sk-line--t{width:85%}
.sk-line--p{width:55%}
.sk-line--b{width:100%;height:48px;border-radius:10px;margin-top:0.25rem}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.cart-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing)}
.cart-line{display:flex;align-items:center;justify-content:space-between;gap:0.75rem}
.cart-line.line-item{
  padding:0.85rem 1rem;
  border-radius:10px;
  background:var(--color-surface-2);
  border:1px solid var(--color-border);
}
.line-item__text{font-size:0.95rem;line-height:1.4;color:var(--color-text)}
.cart-line__main{display:flex;flex-direction:column;gap:0.25rem;flex:1;min-width:0}
.cart-line__name{font-weight:600;font-size:0.98rem}
.cart-line__actions{display:flex;gap:0.5rem;flex-shrink:0}
.cart-line__actions .btn{width:auto;min-width:48px;padding:0 0.75rem}
.ops-header{
  background:linear-gradient(135deg,#1c1c1f 0%,#252528 100%);
  border-bottom:1px solid var(--color-border);
  box-shadow:var(--shadow);
}
.ops-header .app-logo{color:var(--color-text)}
.ops-brand{font-family:var(--font-display);font-weight:700;color:var(--color-primary);letter-spacing:0.02em}
.ops-mount{display:flex;flex-direction:column;gap:var(--spacing)}
.ops-card{border-left:4px solid var(--color-primary)}
.ops-card__top{display:flex;justify-content:space-between;align-items:center;gap:0.5rem;margin-bottom:0.35rem;flex-wrap:wrap}
.ops-k{font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--color-primary)}
.ops-sum{margin:0 0 0.5rem;font-size:0.92rem;line-height:1.35}
.ops-ul{margin:0 0 var(--spacing);padding-left:1.1rem;font-size:0.88rem;color:var(--color-muted)}
.ops-btns{display:flex;flex-wrap:wrap;gap:0.4rem}
.btn--ops{min-height:40px;width:auto;padding:0 0.55rem;font-size:0.8rem;border-radius:8px;background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text);font-weight:600;cursor:pointer}
.btn--ops:hover{background:rgba(255,255,255,0.06)}
.btn--ops.is-active{background:var(--color-primary);color:var(--color-on-primary);border-color:transparent}
.ops-as{margin-top:0.35rem}
.ops-as .input{min-height:44px;font-size:0.95rem}
.muted--small{font-size:0.82rem;line-height:1.35}
.geocode-list{list-style:none;margin:0;padding:0}
.btn--block{white-space:normal;text-align:left;height:auto;min-height:48px;padding:0.65rem 0.85rem}
.geo-results{margin-top:0.5rem}
.pedidos-list{display:flex;flex-direction:column;gap:var(--spacing)}
.pedido-card{cursor:pointer;text-align:left;width:100%;transition:transform 0.12s ease,box-shadow 0.12s ease}
.pedido-card:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,0.35)}
.pedido-card__meta{display:flex;justify-content:space-between;align-items:flex-start;gap:0.5rem;flex-wrap:wrap;margin-bottom:0.35rem}
.pedido-card__est{font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.04em;color:var(--color-primary)}
.pedido-card__date{font-size:0.85rem;color:var(--color-muted)}
.pedido-card__sum{font-weight:700;color:var(--color-text);margin:0}

/* Catálogo: elección de local en grid + banner del restaurante */
.catalog-step__title{font-size:1.1rem;font-weight:700;margin:0 0 0.35rem;color:var(--color-text)}
.catalog-step__lead{margin:0 0 var(--spacing);font-size:0.9rem}
.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:0.75rem}
.store-card{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:0.4rem;
  width:100%;
  min-height:100%;
  padding:1rem 0.9rem;
  margin:0;
  border:1px solid var(--color-border);
  border-radius:var(--radius);
  background:var(--color-surface-2);
  color:var(--color-text);
  cursor:pointer;
  font:inherit;
  transition:background 0.15s ease,border-color 0.15s ease,transform 0.12s ease;
}
.store-card:hover{background:rgba(255,255,255,0.04);border-color:var(--color-border-strong);transform:translateY(-1px)}
.store-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
.store-card__name{font-weight:700;font-size:1rem;line-height:1.25;color:var(--color-text)}
.store-card__desc{
  font-size:0.8rem;
  line-height:1.35;
  color:var(--color-muted);
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.catalog-est-banner{margin-bottom:var(--spacing)}
.est-banner__inner{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:0.75rem;
  padding:1rem 1.05rem;
  border-radius:var(--radius);
  background:var(--color-surface);
  border:1px solid var(--color-border);
}
@media(min-width:480px){
  .est-banner__inner{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:1rem}
}
.est-banner__text{min-width:0;flex:1}
.est-banner__title{font-size:1.15rem;font-weight:700;margin:0 0 0.35rem;color:var(--color-text)}
.est-banner__desc{font-size:0.88rem;line-height:1.45;margin:0;color:var(--color-muted)}
.btn--banner{width:auto;min-height:44px;align-self:flex-start;padding:0 1rem;font-size:0.9rem}
/* Scroll horizontal más discreto (categorías); el arrastre sigue funcionando */
.tabs-scroll--subtle{
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,0.22) transparent;
  padding-bottom:6px;
}
.tabs-scroll--subtle::-webkit-scrollbar{height:5px}
.tabs-scroll--subtle::-webkit-scrollbar-track{background:transparent}
.tabs-scroll--subtle::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.2);border-radius:999px}
.tabs-scroll--subtle::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.32)}

/* Modal in-app (reemplaza confirm() del navegador) */
.app-dialog{
  position:fixed;
  inset:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:var(--spacing);
}
.app-dialog[hidden]{display:none!important}
.app-dialog__backdrop{
  position:absolute;
  inset:0;
  background:rgba(10,10,12,0.82);
  backdrop-filter:blur(2px);
}
.app-dialog__panel{
  position:relative;
  z-index:1;
  width:100%;
  max-width:22rem;
  margin:0;
  padding:calc(var(--spacing)*1.25);
  box-shadow:0 12px 40px rgba(0,0,0,0.55);
}
.app-dialog__title{
  font-size:1.1rem;
  font-weight:700;
  margin:0 0 0.65rem;
  color:var(--color-text);
}
.app-dialog__body{
  margin:0 0 0.65rem;
  font-size:0.95rem;
  line-height:1.45;
  color:var(--color-text);
}
.app-dialog__note{
  margin:0 0 1.1rem;
  padding-top:0.65rem;
  border-top:1px solid var(--color-border);
  font-size:0.82rem;
  line-height:1.4;
  color:var(--color-muted);
}
.app-dialog__note[hidden]{display:none!important}
.app-dialog__actions{
  display:flex;
  flex-wrap:wrap;
  gap:0.5rem;
  justify-content:flex-end;
}
.app-dialog__btn{width:auto;min-width:7rem;flex:1 1 auto}
@media(min-width:400px){
  .app-dialog__btn{flex:0 1 auto}
}
