/* app.css — SuperTicket Sucursales */
:root {
  --brand:#0558f6;--brand-dark:#0344c4;--brand-light:#e8f0fe;
  --ink:#0f1523;--ink-2:#3d4760;--ink-3:#8892aa;
  --surface:#f7f9fc;--surface-2:#eef1f7;--surface-3:#e4e9f2;
  --white:#fff;--border:rgba(15,21,35,.09);--border-2:rgba(15,21,35,.16);
  --success:#16a34a;--success-bg:#f0fdf4;--success-bdr:#bbf7d0;
  --radius:10px;--font:'Inter',sans-serif;
  --shadow-lg:0 8px 32px rgba(15,21,35,.13);--shadow:0 2px 12px rgba(15,21,35,.08);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font);background:var(--surface);color:var(--ink);display:flex;flex-direction:column;min-height:100vh}

/* ─── LOADER ─── */
.loader{position:fixed;inset:0;background:var(--brand);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:1.25rem;transition:opacity .45s}
.loader-img{height:34px;width:auto}
.loader-bar{width:180px;height:3px;background:rgba(255,255,255,.2);border-radius:99px;overflow:hidden}
.loader-fill{height:100%;background:#fff;border-radius:99px;animation:lf 1.1s ease forwards}
@keyframes lf{from{width:0}to{width:100%}}
.loader-sub{font-size:.78rem;color:rgba(255,255,255,.55)}

/* ─── WELCOME OVERLAY ─── */
.welcome-overlay{position:fixed;inset:0;background:linear-gradient(160deg,#0558f6 0%,#022b9a 100%);z-index:9990;display:flex;align-items:center;justify-content:center;padding:1.25rem;overflow-y:auto}
.welcome-card{background:#fff;border-radius:20px;padding:2rem 1.75rem;width:100%;max-width:440px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.welcome-logo{text-align:center;margin-bottom:1.25rem}
.welcome-logo img{height:26px}
.welcome-title{font-size:1.1rem;font-weight:700;color:var(--ink);text-align:center;letter-spacing:-.02em;margin-bottom:.3rem}
.welcome-sub{font-size:.8rem;color:var(--ink-3);text-align:center;margin-bottom:1.4rem;line-height:1.5}
.welcome-btn{display:flex;align-items:center;gap:.85rem;width:100%;background:var(--surface);border:1.5px solid var(--border-2);border-radius:12px;padding:.9rem 1rem;cursor:pointer;font-family:var(--font);text-align:left;transition:all .15s;margin-bottom:.65rem;text-decoration:none;color:var(--ink)}
.welcome-btn:hover{border-color:var(--brand);background:var(--brand-light)}
.welcome-btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.welcome-btn.primary:hover{background:var(--brand-dark)}
.wb-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.wb-icon.green{background:var(--success-bg)}
.wb-icon.blue{background:var(--brand-light)}
.welcome-btn.primary .wb-icon{background:rgba(255,255,255,.2)}
.wb-text{flex:1;min-width:0}
.wb-label{font-size:.88rem;font-weight:600;line-height:1.2}
.wb-desc{font-size:.73rem;color:var(--ink-3);margin-top:.15rem}
.welcome-btn.primary .wb-desc{color:rgba(255,255,255,.7)}
/* city picker */
.city-select-wrap{display:none;padding:.75rem 1rem;background:var(--brand-light);border:1.5px solid var(--brand);border-top:none;border-radius:0 0 12px 12px;margin-top:-12px;margin-bottom:.65rem}
.city-select-wrap.show{display:block}
.city-select{width:100%;border:1.5px solid var(--border-2);border-radius:8px;padding:.58rem .75rem;font-family:var(--font);font-size:.85rem;color:var(--ink);background:#fff;outline:none;cursor:pointer;margin-bottom:.55rem}
.city-select:focus{border-color:var(--brand)}
.btn-go-city{width:100%;background:var(--brand);color:#fff;border:none;border-radius:8px;padding:.58rem;font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .14s}
.btn-go-city:hover{background:var(--brand-dark)}
/* dept chips */
.welcome-divider{display:flex;align-items:center;gap:.65rem;margin:.75rem 0;color:var(--ink-3);font-size:.72rem}
.welcome-divider::before,.welcome-divider::after{content:'';flex:1;height:1px;background:var(--border-2)}
.dept-grid{display:flex;flex-wrap:wrap;gap:.4rem}
.dept-chip{display:inline-flex;align-items:center;padding:.3rem .75rem;background:var(--surface);border:1px solid var(--border-2);border-radius:99px;font-size:.74rem;font-weight:500;color:var(--ink-2);text-decoration:none;transition:all .14s}
.dept-chip:hover{background:var(--brand-light);border-color:var(--brand);color:var(--brand)}

/* ─── HEADER ─── */
header{background:#fff;border-bottom:1px solid var(--border);height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;position:sticky;top:0;z-index:500;flex-shrink:0}
.logo-img{height:26px;width:auto;display:block}
.header-right{display:flex;align-items:center;gap:.75rem}
.header-pill{font-size:.7rem;font-weight:500;color:var(--brand);background:var(--brand-light);padding:4px 11px;border-radius:99px;letter-spacing:.02em}
.header-back{display:none;font-size:.75rem;font-weight:500;color:var(--ink-2);text-decoration:none;align-items:center;gap:4px;transition:color .14s}
.header-back.show{display:flex}
.header-back:hover{color:var(--brand)}

/* ─── DEPT BAR ─── */
.dept-bar{background:var(--white);border-bottom:1px solid var(--border);padding:.45rem 1.25rem;display:none;align-items:center;gap:.45rem;font-size:.78rem;color:var(--ink-2);flex-shrink:0}
.dept-bar.show{display:flex}
.dept-bar a{color:var(--brand);text-decoration:none;font-weight:500}
.dept-bar a:hover{text-decoration:underline}
.dept-bar-sep{color:var(--ink-3)}
.dept-bar-current{font-weight:600;color:var(--ink)}

/* ─── HERO ─── */
.hero{background:linear-gradient(135deg,var(--brand) 0%,#0344c4 60%,#022b9a 100%);padding:1.75rem 1.25rem 1.5rem;position:relative;overflow:hidden;flex-shrink:0}
.hero::after{content:'';position:absolute;right:-80px;bottom:-80px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.hero-inner{max-width:900px;margin:0 auto;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.hero-text{flex:1;min-width:220px}
.hero-eyebrow{font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.4rem}
.hero h1{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:700;color:#fff;letter-spacing:-.03em;line-height:1.15;margin-bottom:.35rem}
.hero-sub{font-size:.82rem;color:rgba(255,255,255,.6);line-height:1.5}
.search-wrap{flex:1;min-width:260px;max-width:400px}
.search-box{display:flex;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.22)}
.search-box input{flex:1;border:none;outline:none;font-family:var(--font);font-size:.88rem;color:var(--ink);padding:.7rem .9rem;background:transparent;min-width:0}
.search-box input::placeholder{color:var(--ink-3)}
.btn-locate{background:#4ca846;color:#fff;border:none;padding:0 .9rem;font-family:var(--font);font-size:.8rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .15s;white-space:nowrap;flex-shrink:0}
.btn-locate:hover{background:#3a9034}

/* ─── STATS BAR ─── */
.stats-bar{background:var(--white);border-bottom:1px solid var(--border);padding:0 1.25rem;display:flex;align-items:center;height:40px;flex-shrink:0;overflow-x:auto;gap:0}
.stat-item{display:flex;align-items:center;gap:5px;font-size:.76rem;color:var(--ink-3);padding-right:1rem;margin-right:1rem;border-right:1px solid var(--border);white-space:nowrap;flex-shrink:0}
.stat-item:last-child{border-right:none;margin-left:auto}
.stat-item strong{color:var(--ink);font-weight:600}
.stat-dot{width:6px;height:6px;border-radius:50%;background:var(--brand);flex-shrink:0}
.stat-dot.green{background:var(--success)}
.stat-nearest{color:var(--success);font-weight:500;display:none}

/* ─── MOBILE TABS ─── */
.mobile-tabs{display:none;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}
.mt-btn{flex:1;padding:.6rem;border:none;background:transparent;font-family:var(--font);font-size:.82rem;font-weight:500;color:var(--ink-3);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .14s;display:flex;align-items:center;justify-content:center;gap:5px}
.mt-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}

/* ─── MAIN LAYOUT ─── */
.main-layout{display:grid;grid-template-columns:340px 1fr;flex:1;min-height:0;overflow:hidden}

/* ─── SIDEBAR ─── */
.sidebar{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--white);overflow:hidden;min-height:0}
.sidebar-top{flex-shrink:0}
.sidebar-header{padding:.75rem 1rem .65rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.sidebar-title{font-weight:600;font-size:.83rem;color:var(--ink)}
.count-pill{background:var(--brand-light);color:var(--brand);font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:99px}
.nearest-banner{background:var(--success-bg);border-bottom:1px solid var(--success-bdr);padding:.6rem 1rem;display:none;align-items:center;gap:8px}
.nearest-banner.show{display:flex}
.nb-icon{width:28px;height:28px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nb-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--success)}
.nb-name{font-size:.8rem;font-weight:600;color:var(--ink);line-height:1.2}
.nb-dist{margin-left:auto;font-size:.73rem;font-weight:700;color:var(--success);flex-shrink:0}
.filter-row{padding:.5rem 1rem;border-bottom:1px solid var(--border);display:flex;gap:5px;overflow-x:auto;flex-wrap:nowrap}
.filter-row::-webkit-scrollbar{height:0}
.filter-btn{font-family:var(--font);font-size:.7rem;font-weight:500;padding:4px 10px;border-radius:99px;border:1px solid var(--border-2);background:transparent;color:var(--ink-2);cursor:pointer;transition:all .14s;white-space:nowrap;flex-shrink:0}
.filter-btn:hover{border-color:var(--brand);color:var(--brand)}
.filter-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}
.branch-list{flex:1;overflow-y:auto;min-height:0}
.branch-list::-webkit-scrollbar{width:4px}
.branch-list::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:99px}
.branch-card{padding:.85rem 1rem;border-bottom:.5px solid var(--border);cursor:pointer;transition:background .14s}
.branch-card:hover{background:var(--surface)}
.branch-card.active{background:var(--brand-light);border-left:3px solid var(--brand)}
.branch-card.nearest-card{background:var(--success-bg);border-left:3px solid var(--success)}
.bc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;margin-bottom:3px}
.bc-name{font-size:.82rem;font-weight:600;color:var(--ink);line-height:1.3}
.bc-tag{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:99px;flex-shrink:0;white-space:nowrap}
.tag-24h{background:#dcfce7;color:#15803d}
.tag-near{background:#dcfce7;color:#15803d}
.bc-addr{font-size:.73rem;color:var(--ink-3);line-height:1.4;margin-bottom:5px}
.bc-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bc-meta-item{font-size:.67rem;color:var(--ink-3);display:flex;align-items:center;gap:2px}
.bc-dist{margin-left:auto;font-size:.67rem;font-weight:600;color:var(--ink-2);background:var(--surface-2);padding:1px 7px;border-radius:99px;border:.5px solid var(--border);flex-shrink:0}
.empty-state{padding:2.5rem 1.5rem;text-align:center;color:var(--ink-3);font-size:.82rem;line-height:1.6}

/* ─── MAP ─── */
#map{width:100%;height:100%}
.leaflet-popup-content-wrapper{border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important;font-family:var(--font)!important;border:.5px solid var(--border-2)!important}
.leaflet-popup-content{margin:14px 16px!important;min-width:200px}
.popup-name{font-size:.86rem;font-weight:700;color:var(--ink);margin-bottom:3px}
.popup-addr{font-size:.73rem;color:var(--ink-3);margin-bottom:6px}
.popup-hours{font-size:.7rem;color:var(--success);margin-bottom:10px;display:flex;align-items:center;gap:3px}
.popup-hours.regular{color:var(--ink-2)}
.popup-btns{display:flex;gap:6px;flex-wrap:wrap}
.popup-btn{font-size:.7rem;font-weight:600;padding:5px 10px;border-radius:99px;text-decoration:none;display:inline-flex;align-items:center;gap:3px;transition:opacity .14s;border:1px solid}
.popup-btn:hover{opacity:.82}
.pb-primary{background:var(--brand);border-color:var(--brand);color:#fff!important}
.pb-secondary{background:transparent;border-color:var(--border-2);color:var(--ink-2)}

/* ─── TOAST ─── */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(60px);background:var(--ink);color:#fff;font-size:.82rem;font-weight:500;padding:.65rem 1.25rem;border-radius:var(--radius);z-index:9999;transition:transform .3s cubic-bezier(.22,.61,.36,1),opacity .3s;opacity:0;pointer-events:none;max-width:88vw;text-align:center;box-shadow:var(--shadow-lg)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ─── RESPONSIVE ─── */
@media(max-width:768px){
  header{padding:0 1rem}
  .header-pill{display:none}

  .hero{padding:1.1rem 1rem 1rem}
  .hero-text{display:none}
  .search-wrap{min-width:unset;width:100%;max-width:100%}
  .search-box input{font-size:.92rem}

  .stats-bar{padding:0 1rem}
  .stat-item{padding-right:.7rem;margin-right:.7rem;font-size:.72rem}

  .mobile-tabs{display:flex}

  .main-layout{display:flex;flex-direction:column;flex:1;overflow:visible}

  /* list view */
  .main-layout[data-view="list"] .sidebar{flex:1;border-right:none;min-height:0;overflow:hidden}
  .main-layout[data-view="list"] #map{display:none}

  /* map view */
  .main-layout[data-view="map"] .sidebar{display:none}
  .main-layout[data-view="map"] #map{flex:1;min-height:60vh}

  /* bigger cards on touch */
  .branch-card{padding:1rem}
  .bc-name{font-size:.9rem}
  .bc-addr{font-size:.78rem}

  /* welcome */
  .welcome-overlay{padding:1rem;align-items:flex-start;padding-top:3rem}
  .welcome-card{padding:1.5rem 1.25rem;border-radius:16px}
  .welcome-title{font-size:1rem}
  .wb-icon{width:36px;height:36px}
  .wb-label{font-size:.85rem}
}

@media(min-width:769px){
  /* on desktop, show hero text if hidden */
  .hero-text{display:block!important}
}


/* ─── SEARCHING OVERLAY ─── */
.searching-overlay{position:fixed;inset:0;background:linear-gradient(160deg,#0558f6,#022b9a);z-index:1050;display:none;flex-direction:column;align-items:center;justify-content:center;gap:1.75rem;text-align:center;padding:2rem}
.so-pin{position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center}
.so-pulse{position:absolute;inset:0;border:2px solid rgba(255,255,255,.45);border-radius:50%;animation:soPulse 2s ease-out infinite}
.so-pulse:nth-child(2){animation-delay:.65s}
.so-pulse:nth-child(3){animation-delay:1.3s}
@keyframes soPulse{from{transform:scale(.5);opacity:1}to{transform:scale(2.6);opacity:0}}
.so-icon{position:relative;z-index:1;background:rgba(255,255,255,.18);width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.so-title{font-size:1.05rem;font-weight:600;color:#fff;line-height:1.5;max-width:280px}
.so-sub{font-size:.82rem;color:rgba(255,255,255,.65)}
.so-dots span{animation:soDot 1.4s infinite;opacity:0}
.so-dots span:nth-child(2){animation-delay:.2s}
.so-dots span:nth-child(3){animation-delay:.4s}
@keyframes soDot{0%,80%,100%{opacity:0}40%{opacity:1}}

/* ─── NEAR-ME MODE ─── */
.sidebar.near-me-mode .filter-row{display:none}
.near-me-actions{display:none;padding:.85rem 1rem 1rem;border-top:1px solid var(--border);background:var(--surface);gap:.5rem;flex-direction:column}
.near-me-actions.show{display:flex}
.nma-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:.1rem}
.nma-btn{display:flex;align-items:center;gap:.65rem;padding:.75rem .9rem;border-radius:var(--radius);border:1.5px solid var(--border-2);background:var(--white);font-family:var(--font);font-size:.82rem;font-weight:600;color:var(--ink-2);cursor:pointer;transition:all .14s;text-align:left;width:100%}
.nma-btn:hover{border-color:var(--brand);color:var(--brand)}
.nma-btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.nma-btn.primary:hover{background:var(--brand-dark)}

/* ─── BRANCH GO BUTTON (near-me mode) ─── */
.bc-go-btn{display:inline-flex;align-items:center;gap:4px;margin-top:7px;font-family:var(--font);font-size:.73rem;font-weight:600;color:var(--brand);text-decoration:none;padding:4px 10px;border-radius:99px;border:1.5px solid var(--brand);background:var(--brand-light);transition:all .14s}
.bc-go-btn:hover{background:var(--brand);color:#fff}
