/* ── Floor plan ──────────────────────────────────────────────── */
.area-section{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--card-bg);margin-bottom:14px;box-shadow:var(--shadow-sm)}
.area-header{padding:12px 18px;display:flex;align-items:center;gap:12px;border-left:4px solid var(--c3);background:linear-gradient(90deg,var(--accent-lt) 0%,transparent 100%)}
.area-header h4{font-weight:700;font-size:.84rem;color:var(--c2)}
.area-header p{font-size:.7rem;color:var(--text-muted)}
.tables-grid{padding:16px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}
.table-card{border-radius:var(--r);border:1.5px solid;padding:12px 10px;cursor:pointer;transition:all .18s;position:relative;text-align:center;user-select:none}
.table-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.table-card.available {background:#EFF9F0;border-color:rgba(22,163,74,.3)}
.table-card.reserved  {background:#FFFBEB;border-color:rgba(217,119,6,.35)}
.table-card.seated    {background:#EFF8FC;border-color:rgba(8,145,178,.35)}
.table-card.occupied  {background:#EFF8FC;border-color:rgba(8,145,178,.35)}
.table-card.unavailable,.table-card.inactive{background:var(--c5);border-color:var(--border);opacity:.55}
.table-num,.table-number{font-weight:800;font-size:.95rem;line-height:1;margin-bottom:2px;color:var(--c2)}
.table-cap{font-size:.62rem;color:var(--text-muted)}
.table-guest,.table-res-info{font-size:.62rem;font-weight:600;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--teal)}
.table-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%}
.available .table-dot{background:var(--green)}
.reserved  .table-dot{background:var(--amber)}
.seated    .table-dot,.occupied .table-dot{background:var(--teal)}
.unavailable .table-dot,.inactive .table-dot{background:var(--text-light)}
.table-status{font-size:.58rem;font-weight:700;padding:2px 7px;border-radius:10px;display:inline-block;margin-top:3px}
.available  .table-status{background:var(--green);color:#fff}
.occupied   .table-status,.seated .table-status{background:var(--teal);color:#fff}
.reserved   .table-status{background:var(--amber);color:#fff}
.inactive   .table-status,.unavailable .table-status{background:var(--text-light);color:#fff}

/* Floor legend */
.floor-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:16px;align-items:center}
.legend-item{display:flex;align-items:center;gap:6px;font-size:.70rem;font-weight:600;color:var(--text-mid)}
.legend-dot{width:11px;height:11px;border-radius:3px;flex-shrink:0}

/* ── Calendar ────────────────────────────────────────────────── */
.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}
.cal-title{font-size:1.05rem;font-weight:700;color:var(--c2);flex:1;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--card-bg);box-shadow:var(--shadow-sm)}
.cal-dow,.cal-head{background:linear-gradient(135deg,var(--c2),var(--c1));padding:10px;text-align:center;font-size:.62rem;font-weight:700;color:rgba(255,255,255,.8);text-transform:uppercase;letter-spacing:.09em}
.cal-day,.cal-cell{min-height:82px;padding:7px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.cal-day:hover,.cal-cell:hover{background:var(--accent-lt)}
.cal-day:nth-child(7n),.cal-cell:nth-child(7n){border-right:none}
.cal-day.empty,.cal-cell.other-month{background:var(--c5);cursor:default;opacity:.45}
.cal-day.empty:hover{background:var(--c5)}
.cal-day.today .cal-dn,.cal-cell.today .cal-dn,.cal-cell.today .cal-day-num{background:var(--c3);color:#fff}
.cal-dn,.cal-day-num{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.74rem;font-weight:700;margin-bottom:3px;color:var(--text-dark)}
.cal-res{font-size:.58rem;background:var(--accent-lt2);color:var(--accent-dk);border-radius:3px;padding:1px 4px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.cal-more,.cal-count{font-size:.57rem;color:var(--text-muted);margin-top:2px}
.cal-dots{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px}
.cal-dot{width:6px;height:6px;border-radius:50%;background:var(--c3)}
.cal-dot.full{background:var(--rose)}

/* ── Employee cards ──────────────────────────────────────────── */
.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.emp-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;transition:all .2s;box-shadow:var(--shadow-sm)}
.emp-card:hover{border-color:var(--c3);box-shadow:var(--shadow);transform:translateY(-2px)}
.emp-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;color:#fff;margin:0 auto 10px;box-shadow:var(--shadow)}
.emp-name{font-size:.84rem;font-weight:700;color:var(--c2);margin-bottom:3px}
.emp-role{font-size:.68rem;color:var(--text-muted);margin-bottom:10px}
.emp-stats{display:flex;justify-content:space-around;border-top:1px solid var(--border);padding-top:10px;margin-top:8px}
.emp-stat-val{font-size:.88rem;font-weight:800;color:var(--c3)}
.emp-stat-lbl{font-size:.60rem;color:var(--text-muted)}
.emp-actions{display:flex;gap:6px;margin-top:10px}

/* ── Charts ──────────────────────────────────────────────────── */
.chart-wrap{display:flex;align-items:flex-end;gap:5px;height:110px;padding-top:8px}
.chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}
.chart-bar{width:100%;border-radius:3px 3px 0 0;background:var(--c3);transition:height .5s ease;min-height:2px}
.chart-bar:hover{background:var(--c1)}
.chart-bar.alt{background:var(--c1)}
.chart-bar.alt:hover{background:var(--c3)}
.chart-label{font-size:.57rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:center}
/* Horizontal bars */
.chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:22px}
.chart-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.chart-bar-label{font-size:.7rem;color:var(--text-muted);min-width:80px;text-align:right;flex-shrink:0}
.chart-bar-wrap2{flex:1;height:10px;background:var(--border);border-radius:99px;overflow:hidden}
.chart-bar-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--c3),var(--accent-dk));transition:width .6s ease}
.chart-bar-val{font-size:.7rem;color:var(--text-mid);font-weight:700;min-width:28px;text-align:right}

/* ── Stars ───────────────────────────────────────────────────── */
.star-btn{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border);background:var(--c5);cursor:pointer;font-size:.95rem;transition:all .15s;display:flex;align-items:center;justify-content:center;color:var(--text-light)}
.star-btn.active{background:var(--amber-lt);border-color:rgba(217,119,6,.35);color:var(--amber)}
.stars-row{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:16px}
.star-field{flex:1;min-width:170px}
.star-field-label{font-size:.64rem;font-weight:700;color:var(--text-mid);text-transform:uppercase;letter-spacing:.09em;margin-bottom:7px}
.star-group{display:flex;gap:5px}
.star{font-size:1.5rem;cursor:pointer;color:#CDD8E6;transition:color .12s,transform .1s;-webkit-tap-highlight-color:transparent;line-height:1}
.star:hover,.star.on{color:#F59E0B}
.star:hover{transform:scale(1.18)}
.star-avg{font-size:1.1rem;font-weight:800;color:var(--c3)}
.star-count{font-size:.65rem;color:var(--text-muted)}

/* ── Hostess ─────────────────────────────────────────────────── */
.hostess-header{background:linear-gradient(135deg,var(--c2) 0%,#001A50 100%);color:#fff;padding:24px 32px;margin:-28px -32px 24px;position:relative;overflow:hidden}
.hostess-header::before{content:'';position:absolute;top:-40%;right:-10%;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(0,156,222,.2) 0%,transparent 70%);pointer-events:none}
.hostess-title{font-size:1.2rem;font-weight:800;margin-bottom:4px}
.hostess-sub{font-size:.75rem;color:rgba(255,255,255,.65)}
.hostess-stats{display:flex;gap:20px;margin-top:16px;flex-wrap:wrap}
.h-stat{text-align:center}
.h-stat-val{font-size:1.6rem;font-weight:800;color:var(--c3);line-height:1}
.h-stat-lbl{font-size:.62rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.07em;margin-top:2px}
.hostess-pin-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:24px;text-align:center}
.pin-icon{font-size:3rem;margin-bottom:16px}
.pin-title{font-size:.95rem;font-weight:700;color:var(--c2);margin-bottom:6px}
.pin-label{font-size:.80rem;color:var(--text-muted);margin-bottom:22px}
.pin-dots{display:flex;gap:10px;justify-content:center;margin-bottom:20px}
.pin-dot{width:14px;height:14px;border-radius:50%;background:var(--border);transition:background .15s}
.pin-dot.filled{background:var(--c3)}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:240px;width:100%;margin:0 auto}
.pin-key{aspect-ratio:1;border-radius:var(--r-lg);background:var(--card-bg);border:1.5px solid var(--border);font-size:1.1rem;font-weight:700;color:var(--c2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .14s;box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.pin-key:hover{background:var(--accent-lt);border-color:var(--c3)}
.pin-key:active{transform:scale(.92);background:var(--c3);color:#fff}
.pin-key.del{font-size:.8rem;color:var(--text-muted)}
.pin-error{color:var(--rose);font-size:.75rem;font-weight:600;min-height:1.2em;margin-top:8px}
.res-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s;border-left:3px solid var(--border)}
.res-card:hover{border-color:var(--c3);box-shadow:var(--shadow)}
.res-card.res-seated{border-left-color:var(--teal)}
.res-card.res-waiting{border-left-color:var(--amber)}
.res-card.res-done{opacity:.6}
.res-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.res-card-name{font-size:.86rem;font-weight:700;color:var(--c2)}
.res-card-time{font-size:.73rem;font-weight:700;color:var(--c3);white-space:nowrap}
.res-card-info{font-size:.72rem;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:8px}
.res-card-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.res-card-actions .btn{flex:1;justify-content:center;min-width:76px}

/* ── Reports ─────────────────────────────────────────────────── */
.report-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin-bottom:20px}
.report-controls .form-group{margin-bottom:0}
.summary-kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:12px;margin-bottom:20px}
.kpi-box{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 12px;text-align:center;box-shadow:var(--shadow-sm)}
.kpi-val{font-size:1.45rem;font-weight:800;color:var(--c2);line-height:1}
.kpi-lbl{font-size:.60rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-top:5px;font-weight:700}
.kpi-sub{font-size:.66rem;color:var(--text-muted);margin-top:3px}

/* ── Settings ────────────────────────────────────────────────── */
.settings-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:20px;box-shadow:var(--shadow-sm);overflow:hidden}
.settings-section-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;background:linear-gradient(90deg,var(--navy-lt) 0%,transparent 100%)}
.settings-section-head h3{font-size:.82rem;font-weight:700;color:var(--c2)}
.settings-section-body{padding:18px}
.op-hours-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.op-hour-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r);background:var(--input-bg);flex-wrap:wrap}
.op-hour-day{font-size:.72rem;font-weight:700;color:var(--c2);min-width:72px}
.op-hour-time{font-size:.72rem;color:var(--text-muted);flex:1;min-width:80px}

/* ── Dashboard ───────────────────────────────────────────────── */
.dashboard-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}
.today-res-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.today-res-item:last-child{border-bottom:none}
.today-res-time{font-size:.72rem;font-weight:700;color:var(--c3);min-width:42px}
.today-res-name{font-size:.80rem;font-weight:600;color:var(--c2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.today-res-party{font-size:.70rem;color:var(--text-muted);white-space:nowrap}

/* ── Customers ───────────────────────────────────────────────── */
.customer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.customer-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px;box-shadow:var(--shadow-sm);transition:all .2s}
.customer-card:hover{border-color:var(--c3);box-shadow:var(--shadow);transform:translateY(-1px)}
.customer-name{font-size:.83rem;font-weight:700;color:var(--c2);margin-bottom:3px}
.customer-meta{font-size:.70rem;color:var(--text-muted);margin-bottom:8px}
.customer-stats{display:flex;gap:14px;border-top:1px solid var(--border);padding-top:8px;margin-top:6px}
.customer-stat-val{font-size:.86rem;font-weight:800;color:var(--c3)}
.customer-stat-lbl{font-size:.59rem;color:var(--text-muted)}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — solo en pantallas pequeñas
═══════════════════════════════════════════════════════ */
@media(max-width:960px){.dashboard-grid{grid-template-columns:1fr}}
@media(max-width:700px){.chart-grid{grid-template-columns:1fr}}
@media(max-width:580px){
  .summary-kpis{grid-template-columns:repeat(2,1fr)}
  .report-controls{flex-direction:column}
  .settings-section-body{padding:14px}
  .op-hours-grid{grid-template-columns:1fr}
}
@media(max-width:500px){
  .emp-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .emp-card{padding:14px 10px}
  .emp-avatar{width:46px;height:46px}
}
@media(max-width:480px){
  .customer-grid{grid-template-columns:1fr}
  .cal-day,.cal-cell{min-height:56px;padding:5px 4px}
  .cal-dow,.cal-head{padding:8px 2px;font-size:.56rem}
  .cal-dn,.cal-day-num{font-size:.7rem;width:20px;height:20px}
  .hostess-header{margin:-16px -18px 16px;padding:18px}
}
@media(max-width:380px){
  .cal-day,.cal-cell{min-height:42px}
  .cal-res,.cal-more,.cal-count{display:none}
  .tables-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:320px){.emp-grid{grid-template-columns:1fr}}
/* Hostess responsive padding */
@media(max-width:768px){.hostess-header{margin:-16px -18px 20px;padding:20px 18px}}
@media(max-width:540px){.hostess-header{margin:-14px -14px 16px;padding:16px 14px}}
