/* ═══════════════════════════════════════════════════════════
   VARIABLES & RESET
═══════════════════════════════════════════════════════════ */
:root{
  --teal:#0d9488;--teal-d:#0f766e;--teal-l:#ccfbf1;--teal-xl:#f0fdf9;
  --amber:#f59e0b;--red:#ef4444;--purple:#7c3aed;--green:#22c55e;
  --slate:#1e293b;--slate2:#334155;--slate3:#64748b;--slate4:#94a3b8;
  --border:#e2e8f0;--bg:#f0fdf9;--white:#ffffff;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
  --shadow:0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:0 20px 60px rgba(0,0,0,.20);
  --r:12px;--r-sm:8px;--r-lg:16px;--r-xl:20px;
  /* Touch target minimum */
  --touch:44px;
  /* Safe area for notched phones */
  --safe-t:env(safe-area-inset-top,0px);
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-l:env(safe-area-inset-left,0px);
  --safe-r:env(safe-area-inset-right,0px);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;}
body{
  font-family:'DM Sans',system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--slate);min-height:100vh;
  overscroll-behavior:none;
}
img,svg,canvas{max-width:100%;height:auto;display:block;}
input:not([type=checkbox]):not([type=radio]),select,textarea,button{font-family:inherit;-webkit-appearance:none;appearance:none;}
/* Restaurar apariencia nativa para checkboxes y radios — necesarios para clickear */
input[type=checkbox],input[type=radio]{-webkit-appearance:auto;appearance:auto;cursor:pointer;}
/* Prevent iOS zoom on input focus - keep 16px minimum */
input,select,textarea{font-size:16px;}

/* ═══════════════════════════════════════════════════════════
   UTILITY
═══════════════════════════════════════════════════════════ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}
.flex{display:flex;}.flex-col{flex-direction:column;}
.items-center{align-items:center;}.items-start{align-items:flex-start;}
.justify-between{justify-content:space-between;}.justify-center{justify-content:center;}
.flex-wrap{flex-wrap:wrap;}.gap-xs{gap:.25rem;}.gap-sm{gap:.5rem;}.gap{gap:.75rem;}.gap-lg{gap:1rem;}
.w-full{width:100%;}.min-w-0{min-width:0;}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hidden{display:none!important;}

/* ═══════════════════════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════════════════════ */
.serif{font-family:'Playfair Display',Georgia,serif;}
.text-xs{font-size:.75rem;}.text-sm{font-size:.82rem;}.text-base{font-size:.9rem;}.text-lg{font-size:1.1rem;}
.font-600{font-weight:600;}.font-700{font-weight:700;}.font-800{font-weight:800;}
.text-slate{color:var(--slate3);}.text-teal{color:var(--teal);}.text-red{color:var(--red);}

/* ═══════════════════════════════════════════════════════════
   BADGES
═══════════════════════════════════════════════════════════ */
.bdg{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;font-weight:700;padding:.18rem .55rem;border-radius:20px;line-height:1.4;white-space:nowrap;}
.bdg-teal{background:var(--teal-l);color:var(--teal-d);}
.bdg-slate{background:#f1f5f9;color:var(--slate2);border:1px solid var(--border);}
.bdg-red{background:#fee2e2;color:#b91c1c;}
.bdg-amber{background:#fef3c7;color:#92400e;}
.bdg-green{background:#dcfce7;color:#166534;}
.bdg-purple{background:#ede9fe;color:#5b21b6;}

/* ═══════════════════════════════════════════════════════════
   BUTTONS  — minimum 44×44 touch target
═══════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:inherit;font-weight:600;font-size:.875rem;
  border:none;border-radius:var(--r-sm);padding:.55rem 1rem;
  cursor:pointer;transition:all .15s;
  min-height:var(--touch);touch-action:manipulation;
  user-select:none;-webkit-user-select:none;
  white-space:nowrap;
}
.btn:active{transform:scale(.96);}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;}
.btn-teal{background:var(--teal);color:#fff;}.btn-teal:hover{background:var(--teal-d);}
.btn-amber{background:var(--amber);color:#fff;}.btn-amber:hover{background:#d97706;}
.btn-red{background:var(--red);color:#fff;}.btn-red:hover{background:#dc2626;}
.btn-purple{background:var(--purple);color:#fff;}.btn-purple:hover{background:#6d28d9;}
.btn-ghost{background:transparent;color:var(--slate3);border:1.5px solid var(--border);}.btn-ghost:hover{background:var(--bg);}
.btn-oteal{background:transparent;color:var(--teal);border:1.5px solid var(--teal);}.btn-oteal:hover{background:var(--teal-l);}
.btn-white{background:#fff;color:var(--slate);border:1.5px solid var(--border);}
.btn-sm{padding:.3rem .65rem;font-size:.78rem;min-height:36px;}
.btn-lg{padding:.7rem 1.6rem;font-size:1rem;}
.btn-icon{padding:.3rem;min-height:var(--touch);min-width:var(--touch);border-radius:var(--r-sm);}
/* Buttons that are white on dark bg */
.btn-hdr{background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.3);}
.btn-hdr:hover{background:rgba(255,255,255,.3);}

/* ═══════════════════════════════════════════════════════════
   FORM ELEMENTS
═══════════════════════════════════════════════════════════ */
.form-label{display:block;font-weight:600;font-size:.8rem;color:var(--slate3);margin-bottom:.3rem;}
.form-control,.form-select{
  width:100%;padding:.55rem .9rem;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  background:#fff;color:var(--slate);
  font-size:16px;/* prevents iOS zoom */
  transition:border-color .15s,box-shadow .15s;
  min-height:var(--touch);
}
.form-control:focus,.form-select:focus{
  outline:none;border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(13,148,136,.15);
}
textarea.form-control{min-height:80px;resize:vertical;}
.form-select{padding-right:2.2rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;}

/* Checkbox custom */
.chk-wrap{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.4rem 0;min-height:var(--touch);}
.chk-wrap input[type=checkbox]{
  width:20px;height:20px;border-radius:5px;border:2px solid var(--border);
  background:#fff;cursor:pointer;flex-shrink:0;
  accent-color:var(--teal);
}

/* Grid helpers */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;}
.span2{grid-column:span 2;}
.span3{grid-column:span 3;}

/* ═══════════════════════════════════════════════════════════
   CARDS
═══════════════════════════════════════════════════════════ */
.card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r);box-shadow:var(--shadow-sm);
  margin-bottom:.85rem;overflow:hidden;
}
.card-head{
  padding:.8rem 1rem;border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:.5rem;flex-wrap:wrap;
}
.card-body{padding:.85rem 1rem;}
.card-foot{padding:.75rem 1rem;border-top:1px solid var(--border);background:#fafafa;}

/* ═══════════════════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════════════════ */
.app-header{
  background:linear-gradient(135deg,#0f766e,#0d9488,#0891b2);
  padding:calc(.75rem + var(--safe-t)) 1rem .75rem;
  position:sticky;top:0;z-index:100;
  box-shadow:0 4px 20px rgba(13,148,136,.35);
}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:nowrap;}
.hdr-left{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1;}
.hdr-title{min-width:0;}
.hdr-title h1{font-family:'Playfair Display',serif;color:#fff;font-size:1.15rem;margin:0;white-space:nowrap;}
.hdr-title .hdr-sub{color:rgba(255,255,255,.7);font-size:.7rem;white-space:nowrap;}
.hdr-right{display:flex;gap:.35rem;align-items:center;flex-shrink:0;}
.hdr-user{color:rgba(255,255,255,.85);font-size:.78rem;font-weight:600;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis;}

/* ═══════════════════════════════════════════════════════════
   TABS  — scrollable, no scrollbar visible
═══════════════════════════════════════════════════════════ */
.tab-bar{
  background:#fff;border-bottom:2px solid var(--border);
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;display:flex;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.tab-bar::-webkit-scrollbar{display:none;}
.tab-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  padding:.65rem .85rem;border:none;background:none;
  color:var(--slate3);font-family:inherit;font-size:.72rem;font-weight:700;
  border-bottom:3px solid transparent;cursor:pointer;
  transition:all .2s;white-space:nowrap;flex-shrink:0;
  min-width:60px;touch-action:manipulation;
}
.tab-btn i{font-size:1.1rem;}
.tab-btn:hover{color:var(--teal);background:var(--teal-l);}
.tab-btn.active{color:var(--teal);border-bottom-color:var(--teal);}
.tab-label{font-size:.65rem;display:block;}

/* ═══════════════════════════════════════════════════════════
   CONTENT AREA
═══════════════════════════════════════════════════════════ */
.content{
  padding:1rem;max-width:1140px;margin:0 auto;
  padding-bottom:calc(1rem + var(--safe-b));
}
.tab-pane{display:none;animation:fadeIn .2s ease;}
.tab-pane.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}

.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem;}
.page-title{font-family:'Playfair Display',serif;font-size:1.1rem;display:flex;align-items:center;gap:.4rem;}

/* Group selector bar */
.gsel-bar{
  background:#fff;border:2px solid var(--teal);border-radius:var(--r);
  padding:.85rem 1rem;margin-bottom:1rem;
  display:flex;gap:.6rem;align-items:flex-end;flex-wrap:wrap;
}
.gsel-bar>div{flex:1;min-width:160px;}

/* ═══════════════════════════════════════════════════════════
   TURISTA CARD
═══════════════════════════════════════════════════════════ */
.t-card{
  border:1px solid var(--border);border-radius:var(--r);
  padding:.85rem;margin-bottom:.55rem;background:#fff;
  display:flex;align-items:flex-start;gap:.75rem;
}
.avatar{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.85rem;flex-shrink:0;
}
.t-info{flex:1;min-width:0;}
.t-name{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;}
.t-meta{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.75rem;color:var(--slate3);margin-top:.3rem;}
.t-actions{display:flex;gap:.3rem;flex-shrink:0;}

/* ═══════════════════════════════════════════════════════════
   GASTOS
═══════════════════════════════════════════════════════════ */
.total-banner{
  background:linear-gradient(135deg,var(--teal-d),var(--teal));
  border-radius:var(--r);padding:1rem 1.25rem;color:#fff;
  margin-bottom:1rem;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:.75rem;
}
.total-amt{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:800;}
.gasto-row{
  background:#fff;border:1px solid var(--border);border-radius:var(--r);
  padding:.75rem 1rem;margin-bottom:.5rem;
  display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;
}
.gasto-info{flex:1;min-width:0;}
.gasto-amt{font-weight:800;color:var(--red);font-size:1rem;white-space:nowrap;}
.gasto-actions{display:flex;gap:.3rem;flex-shrink:0;}

/* ═══════════════════════════════════════════════════════════
   EMPTY STATE
═══════════════════════════════════════════════════════════ */
.empty{text-align:center;padding:3rem 1rem;color:var(--slate3);}
.empty-icon{font-size:2.5rem;opacity:.2;display:block;margin-bottom:.75rem;}

/* ═══════════════════════════════════════════════════════════
   TABLES  — horizontal scroll on small screens
═══════════════════════════════════════════════════════════ */
.twrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-sm);}
table{width:100%;border-collapse:collapse;min-width:460px;}
th{
  font-size:.71rem;text-transform:uppercase;color:var(--slate3);
  font-weight:700;padding:.55rem .75rem;background:var(--bg);
  border-bottom:2px solid var(--border);white-space:nowrap;text-align:left;
}
td{padding:.6rem .75rem;border-bottom:1px solid var(--border);font-size:.84rem;vertical-align:middle;}
tr:last-child td{border-bottom:none;}
td input[type=checkbox]{width:20px;height:20px;accent-color:var(--teal);cursor:pointer;}
td input[type=text]{font-size:14px;min-width:100px;padding:.3rem .5rem;}

/* ═══════════════════════════════════════════════════════════
   MENU TAGS (preórdenes)
═══════════════════════════════════════════════════════════ */
.mtag{display:inline-flex;align-items:center;gap:4px;border-radius:20px;padding:3px 10px;font-size:.76rem;font-weight:600;margin:2px;}
.mtag-principal{background:#dcfce7;color:#166534;}
.mtag-bebida{background:#cffafe;color:#155e75;}
.mtag-postre{background:#fef9c3;color:#854d0e;}
.mtag-extra{background:#f1f5f9;color:#334155;}
.mtag .x{cursor:pointer;background:none;border:none;padding:0;line-height:1;opacity:.65;font-size:.85rem;}
.mtag .x:hover{opacity:1;}

/* ═══════════════════════════════════════════════════════════
   RIFA
═══════════════════════════════════════════════════════════ */
.rifa-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
#rifaCanvas{display:block;margin:0 auto;touch-action:none;}
.win-badge{border-radius:var(--r);padding:.9rem 1.25rem;text-align:center;margin-bottom:.6rem;color:#fff;}
.win-gold{background:linear-gradient(135deg,#f59e0b,#d97706);}
.win-silver{background:linear-gradient(135deg,#94a3b8,#475569);}
.win-bronze{background:linear-gradient(135deg,#b45309,#78350f);}

/* ═══════════════════════════════════════════════════════════
   ADMIN LAYOUT
═══════════════════════════════════════════════════════════ */
.admin-wrap{display:flex;min-height:calc(100vh - 58px);}
.admin-sidebar{
  width:220px;flex-shrink:0;background:var(--slate);
  padding:1rem 0;overflow-y:auto;
  transition:transform .25s,width .25s;
}
.sidebar-section{padding:.4rem 1.25rem .6rem;color:rgba(255,255,255,.3);font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-top:.5rem;}
.adm-link{
  display:flex;align-items:center;gap:.65rem;
  padding:.7rem 1.25rem;color:rgba(255,255,255,.6);
  font-size:.85rem;font-weight:600;cursor:pointer;
  border:none;background:none;width:100%;text-align:left;
  transition:all .18s;min-height:var(--touch);
}
.adm-link:hover{color:#fff;background:rgba(255,255,255,.07);}
.adm-link.active{color:#fff;background:rgba(13,148,136,.38);border-right:3px solid var(--teal);}
.admin-main{flex:1;padding:1.25rem;overflow-y:auto;min-width:0;}
.adm-pane{display:none;}.adm-pane.active{display:block;animation:fadeIn .2s ease;}

/* Hamburger button */
.menu-toggle{display:none;}

/* Stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-bottom:1.25rem;}
.stat-card{background:#fff;border-radius:var(--r);padding:1.1rem 1rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);}
.stat-num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;line-height:1;}
.stat-lbl{font-size:.75rem;color:var(--slate3);font-weight:600;margin-top:.3rem;}

/* User rows */
.user-row{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.user-row:last-child{border-bottom:none;}
.user-info{flex:1;min-width:150px;}
.user-actions{display:flex;gap:.3rem;flex-wrap:wrap;flex-shrink:0;}

/* ═══════════════════════════════════════════════════════════
   MODALS / DIALOGS
═══════════════════════════════════════════════════════════ */
.dlg{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(15,23,42,.72);
  overflow-y:auto;padding:1rem .75rem;
  align-items:flex-start;justify-content:center;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.dlg.open{display:flex;}
.dlg-box{
  background:#fff;border-radius:var(--r-lg);width:100%;
  box-shadow:var(--shadow-lg);flex-shrink:0;
  /* Animate in */
  animation:dlgIn .2s cubic-bezier(.34,1.56,.64,1);
}
@keyframes dlgIn{from{opacity:0;transform:translateY(20px) scale(.97);}to{opacity:1;transform:none;}}
.dlg-box.sm{max-width:480px;}.dlg-box.md{max-width:700px;}.dlg-box.lg{max-width:960px;}
.dlg-head{
  padding:.95rem 1.1rem;border-radius:var(--r-lg) var(--r-lg) 0 0;
  display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;
}
.dlg-head.purple{background:linear-gradient(135deg,#5b21b6,#7c3aed);}
.dlg-head h5{margin:0;font-size:.95rem;font-weight:700;flex:1;min-width:0;}
.dlg-close{
  background:rgba(255,255,255,.2);border:none;color:#fff;
  width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  touch-action:manipulation;transition:background .15s;
}
.dlg-close:hover{background:rgba(255,255,255,.35);}
.dlg-body{background:#fff;padding:1.1rem;}
.dlg-foot{
  background:#f8fafc;padding:.9rem 1.1rem;border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:.5rem;flex-wrap:wrap;
  border-radius:0 0 var(--r-lg) var(--r-lg);
}
.dlg-foot-split{justify-content:space-between;}

/* ═══════════════════════════════════════════════════════════
   TOAST  — centered bottom, above safe area
═══════════════════════════════════════════════════════════ */
#toast{
  position:fixed;bottom:calc(1.2rem + var(--safe-b));
  left:50%;transform:translateX(-50%) translateY(80px);
  z-index:99999;padding:.7rem 1.4rem;border-radius:20px;
  color:#fff;font-weight:700;font-size:.875rem;opacity:0;
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,.25);
  max-width:90vw;text-align:center;white-space:nowrap;
}
#toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
#toast.ok{background:var(--teal);}
#toast.err{background:var(--red);}
#toast.warn{background:var(--amber);}

/* ═══════════════════════════════════════════════════════════
   SPINNER
═══════════════════════════════════════════════════════════ */
.spin-wrap{position:fixed;inset:0;background:rgba(255,255,255,.72);z-index:9998;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px);}
.spin-wrap.on{display:flex;}
.spinner{width:46px;height:46px;border:4px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .75s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ═══════════════════════════════════════════════════════════
   LOGIN PAGE
═══════════════════════════════════════════════════════════ */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(150deg,#0f766e,#0d9488 50%,#0891b2);padding:1rem;}
.login-card{background:#fff;border-radius:var(--r-xl);padding:2rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);}
.login-logo{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--teal-d);text-align:center;margin-bottom:.2rem;}
.login-sub{text-align:center;color:var(--slate3);font-size:.84rem;margin-bottom:1.75rem;}
.login-err{background:#fee2e2;color:#b91c1c;padding:.75rem 1rem;border-radius:var(--r-sm);font-size:.85rem;margin-bottom:1rem;font-weight:600;}

/* ═══════════════════════════════════════════════════════════
   BIRTHDAY ICON
═══════════════════════════════════════════════════════════ */
.bday{font-size:.9rem;cursor:default;}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE  ←  THE KEY PART
═══════════════════════════════════════════════════════════ */

/* ── TABLET (≤900px) ─── */
@media(max-width:900px){
  /* Admin sidebar slides in as drawer */
  .admin-wrap{position:relative;}
  .admin-sidebar{
    position:fixed;left:0;top:0;bottom:0;z-index:200;
    transform:translateX(-100%);width:260px;
    padding-top:calc(60px + var(--safe-t));
    box-shadow:var(--shadow-lg);
  }
  .admin-sidebar.open{transform:translateX(0);}
  .sidebar-overlay{display:none;position:fixed;inset:0;z-index:199;background:rgba(0,0,0,.45);}
  .sidebar-overlay.open{display:block;}
  .menu-toggle{display:flex;}
  .admin-main{padding:1rem;}

  /* Rifa stacks */
  .rifa-layout{grid-template-columns:1fr;}
  #rifaCanvas{max-width:280px;}

  /* Dialogs full-ish width */
  .dlg-box.lg{max-width:100%;}

  /* Tabs slightly smaller */
  .tab-btn{padding:.6rem .75rem;}
}

/* ── MÓVIL  (≤600px) ─── */
@media(max-width:600px){
  /* Header */
  .app-header{padding:calc(.6rem + var(--safe-t)) calc(.85rem + var(--safe-l)) .6rem calc(.85rem + var(--safe-r));}
  .hdr-title h1{font-size:1rem;}
  .hdr-user{display:none;}/* hide username on small phones */

  /* Tabs — icon + tiny label */
  .tab-btn{padding:.55rem .6rem;min-width:52px;}
  .tab-btn i{font-size:1rem;}
  .tab-label{font-size:.6rem;}

  /* Content */
  .content{padding:.75rem;padding-bottom:calc(.75rem + var(--safe-b));}
  .page-head{gap:.35rem;}
  .page-title{font-size:1rem;}

  /* Grids collapse */
  .g2,.g3,.g4{grid-template-columns:1fr;}
  .span2,.span3{grid-column:span 1;}

  /* Group selector */
  .gsel-bar{flex-direction:column;padding:.75rem;}
  .gsel-bar>div{min-width:100%;}
  .gsel-bar .btn{width:100%;}

  /* Cards */
  .card-head{padding:.7rem .85rem;}
  .card-body{padding:.75rem .85rem;}

  /* Turista card compact */
  .t-card{padding:.7rem .85rem;gap:.6rem;}
  .avatar{width:36px;height:36px;font-size:.78rem;}
  .t-actions .btn-sm{padding:.28rem .5rem;font-size:.74rem;min-height:36px;}

  /* Dialogs — full screen with rounded top corners */
  .dlg{padding:.5rem .5rem 0;align-items:flex-end;}
  .dlg-box,.dlg-box.sm,.dlg-box.md,.dlg-box.lg{
    max-width:100%;border-radius:var(--r-xl) var(--r-xl) 0 0;
    max-height:92vh;display:flex;flex-direction:column;
  }
  .dlg-body{overflow-y:auto;flex:1;}
  .dlg-head{border-radius:var(--r-xl) var(--r-xl) 0 0;}
  .dlg-foot{border-radius:0;}

  /* Gastos */
  .gasto-amt{font-size:.9rem;}
  .total-amt{font-size:1.5rem;}
  .total-banner{padding:.85rem 1rem;}

  /* Rifa */
  .rifa-layout{grid-template-columns:1fr;}
  #rifaCanvas{max-width:240px;}
  .win-badge{padding:.75rem 1rem;}

  /* Tables still scroll, but smaller text */
  th{font-size:.67rem;padding:.45rem .55rem;}
  td{font-size:.8rem;padding:.5rem .55rem;}
  td input[type=text]{font-size:13px;min-width:80px;}

  /* Admin stats */
  .stat-grid{grid-template-columns:1fr 1fr;}
  .stat-num{font-size:1.6rem;}

  /* User rows */
  .user-row{flex-direction:column;gap:.5rem;}
  .user-actions{width:100%;justify-content:flex-end;}

  /* Buttons in dlg-foot stack on tiny screens */
  .dlg-foot{gap:.4rem;}
}

/* ── VERY SMALL (≤380px, small Android) ─── */
@media(max-width:380px){
  .tab-btn{padding:.5rem .5rem;min-width:44px;}
  .tab-label{display:none;}/* icons only on tiny screens */
  #rifaCanvas{max-width:200px;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .btn{font-size:.8rem;}
}

/* ── LARGE / DESKTOP (≥1024px) ─── */
@media(min-width:1024px){
  .tab-btn{padding:.75rem 1.1rem;font-size:.8rem;}
  .tab-btn i{font-size:1.05rem;}
  .tab-label{font-size:.72rem;}
  .content{padding:1.5rem;}
  .card-head{padding:.9rem 1.25rem;}
  .card-body{padding:1rem 1.25rem;}
  .gsel-bar{padding:1rem 1.25rem;}
  .total-amt{font-size:2rem;}
}
/* ── PROVEEDORES & TRANSPORTE ─── */
.prov-row{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:.75rem 1rem;margin-bottom:.5rem;display:flex;align-items:flex-start;gap:.65rem;flex-wrap:wrap;}
.prov-info{flex:1;min-width:0;}
.prov-actions{display:flex;gap:.3rem;flex-shrink:0;}
.tipo-badge-transporte{background:#dbeafe;color:#1e40af;}
.tipo-badge-tour{background:#d1fae5;color:#065f46;}
.tipo-badge-restaurante{background:#fef3c7;color:#92400e;}
.geo-row{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap;margin-bottom:.6rem;}
.geo-row>div{flex:1;min-width:120px;}
.geo-add-row{display:flex;gap:.4rem;align-items:center;margin-top:.3rem;}
.geo-add-row input{flex:1;}
.trans-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:.75rem;}
.trans-head{padding:.75rem 1rem;background:linear-gradient(90deg,#0f766e,#0d9488);color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;}
.trans-body{padding:.85rem 1rem;}
.trans-stat{display:inline-flex;align-items:center;gap:.3rem;background:rgba(255,255,255,.2);border-radius:20px;padding:.2rem .65rem;font-size:.75rem;font-weight:700;}

/* ═══════════════════════════════════════════════════════════
   v6.1 — Dashboard responsivo
═══════════════════════════════════════════════════════════ */
.stat-click{
  background:#fff;border:1px solid var(--border);border-radius:var(--r);
  padding:1rem;cursor:pointer;transition:all .15s;text-align:left;
  font-family:inherit;width:100%;display:block;
}
.stat-click:hover{
  border-color:var(--teal);box-shadow:var(--shadow);
  transform:translateY(-1px);
}
.stat-click:active{transform:scale(.98);}

#dash-chart{background:linear-gradient(180deg,#fff,var(--bg));border-radius:var(--r-sm);}
#dash-chart circle{transition:r .15s;}
#dash-chart circle:hover{r:5;}


/* ══ PWA install prompt ════════════════════════════════════════ */
.pwa-install {
  position: fixed;
  bottom: 1rem;
  left: 1rem;
  right: 1rem;
  max-width: 420px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: 0 6px 24px rgba(0,0,0,.18);
  padding: 1rem;
  z-index: 9999;
  animation: pwaSlideUp .3s ease-out;
}
@keyframes pwaSlideUp {
  from { transform: translateY(120%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.pwa-install.hidden { display: none; }
.pwa-install-head {
  display: flex;
  gap: .75rem;
  align-items: center;
  margin-bottom: .6rem;
}
.pwa-install-icon {
  width: 44px;
  height: 44px;
  background: var(--teal);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  color: #fff;
  flex-shrink: 0;
}
.pwa-install-title {
  font-weight: 700;
  font-size: .95rem;
  line-height: 1.2;
}
.pwa-install-sub {
  font-size: .8rem;
  color: var(--slate);
  margin-top: .15rem;
}
.pwa-install-body {
  font-size: .85rem;
  color: var(--text);
  margin: .3rem 0 .75rem 0;
  line-height: 1.45;
}
.pwa-install-steps {
  background: var(--bg);
  border-radius: var(--r-sm);
  padding: .55rem .75rem;
  font-size: .82rem;
  margin-top: .4rem;
}
.pwa-install-steps ol {
  margin: 0;
  padding-left: 1.2rem;
}
.pwa-install-steps li {
  margin: .2rem 0;
}
.pwa-install-actions {
  display: flex;
  gap: .5rem;
  justify-content: flex-end;
}
.pwa-install-close {
  background: transparent;
  border: none;
  font-size: 1.3rem;
  cursor: pointer;
  color: var(--slate);
  padding: 0 .4rem;
  margin-left: auto;
  line-height: 1;
}
@media (min-width: 640px) {
  .pwa-install { bottom: 1.5rem; right: 1.5rem; left: auto; }
}
