/* ═══════════════════════════════════════════════════════════════════════════
   Cafe Chiya Munch v4 — Design System
   Fonts: Sora (display) · Plus Jakarta Sans (body)
   ═══════════════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ── Tokens ─────────────────────────────────────────────────────────────── */
:root {
  --teal-50:#f0fdfa;--teal-100:#ccfbf1;--teal-200:#99f6e4;
  --teal-500:#14b8a6;--teal-600:#0d9488;--teal-700:#0f766e;
  --teal-800:#115e59;--teal-900:#134e4a;
  --amber-400:#fbbf24;--amber-500:#f59e0b;
  --bg:#f0f4f8;--surface:#ffffff;--surface-2:#f8fafc;--surface-3:#f1f5f9;
  --text:#0f172a;--text-2:#334155;--muted:#64748b;
  --border:#e2e8f0;--border-2:#cbd5e1;
  --primary:var(--teal-700);--primary-2:var(--teal-500);--accent:var(--amber-500);
  --danger:#dc2626;--success:#16a34a;--warning:#d97706;--info:#0284c7;
  --shadow-xs:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 2px 8px rgba(15,23,42,.08),0 1px 3px rgba(15,23,42,.04);
  --shadow-md:0 8px 24px rgba(15,23,42,.10),0 2px 8px rgba(15,23,42,.05);
  --shadow-lg:0 16px 48px rgba(15,23,42,.12),0 4px 16px rgba(15,23,42,.06);
  --radius-sm:10px;--radius:16px;--radius-lg:20px;--radius-xl:28px;
  --ease:cubic-bezier(.4,0,.2,1);--dur:220ms;
}
[data-theme="dark"] {
  --bg:#0b1120;--surface:#131c2e;--surface-2:#1a2540;--surface-3:#212d48;
  --text:#e2e8f0;--text-2:#94a3b8;--muted:#64748b;
  --border:#1e2e47;--border-2:#2a3a58;
  --shadow-xs:0 1px 3px rgba(0,0,0,.3);--shadow-sm:0 2px 8px rgba(0,0,0,.35);
  --shadow-md:0 8px 24px rgba(0,0,0,.4);--shadow-lg:0 16px 48px rgba(0,0,0,.5);
}

/* ── Base ───────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-size:.9375rem;line-height:1.6;
  color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(ellipse 60% 40% at 85% 0%,rgba(20,184,166,.08) 0%,transparent 60%),
    radial-gradient(ellipse 50% 35% at 10% 100%,rgba(245,158,11,.06) 0%,transparent 55%);
  background-attachment:fixed;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
a{text-decoration:none;color:var(--primary)}a:hover{color:var(--primary-2)}
h1,h2,h3,h4,h5,h6{font-family:'Sora',system-ui,sans-serif;font-weight:700;line-height:1.25;color:var(--text)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ── Layout ─────────────────────────────────────────────────────────────── */
.page-shell{max-width:1440px;margin:0 auto}
main.container-fluid{padding-top:1.5rem;padding-bottom:1.5rem}

/* ── Navbar ─────────────────────────────────────────────────────────────── */
.navbar{background:rgba(10,15,28,.92)!important;backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid rgba(255,255,255,.06);
  padding:.55rem 0;transition:all var(--dur) var(--ease)}
[data-theme="dark"] .navbar{background:rgba(7,10,20,.95)!important}
.navbar .nav-link{color:rgba(255,255,255,.68)!important;font-weight:600;font-size:.82rem;
  letter-spacing:.01em;padding:.38rem .7rem!important;border-radius:8px;
  transition:all var(--dur) var(--ease)}
.navbar .nav-link:hover,.navbar .nav-link.active{color:#fff!important;background:rgba(255,255,255,.1)}
.navbar .nav-link.active{color:var(--teal-200)!important}
.navbar .dropdown-menu{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:.5rem}
.navbar .dropdown-item{border-radius:8px;font-size:.84rem;color:var(--text-2);padding:.45rem .8rem;transition:all var(--dur) var(--ease)}
.navbar .dropdown-item:hover,.navbar .dropdown-item.active{background:var(--teal-50);color:var(--teal-800)}
[data-theme="dark"] .navbar .dropdown-item:hover{background:rgba(20,184,166,.12);color:var(--teal-200)}
.brand-badge{width:34px;height:34px;border-radius:11px;display:inline-flex;align-items:center;
  justify-content:center;background:linear-gradient(135deg,var(--teal-700),var(--teal-500));
  color:#fff;font-weight:800;font-size:.85rem;box-shadow:0 4px 12px rgba(20,184,166,.4);flex-shrink:0}
.navbar-brand{font-family:'Sora',sans-serif;font-weight:700;font-size:.92rem;
  color:#fff!important;display:flex;align-items:center;gap:.5rem}
#darkToggle{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.75);width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.85rem;
  transition:all var(--dur) var(--ease)}
#darkToggle:hover{background:rgba(255,255,255,.16);color:#fff}
.user-chip{display:flex;align-items:center;gap:.45rem;padding:.22rem .5rem;
  border-radius:20px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.09);cursor:pointer}
.user-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2)}
.user-avatar-placeholder{width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal-600),var(--teal-500));
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:.65rem;font-weight:800}

/* ── Cards ──────────────────────────────────────────────────────────────── */
.card-soft{background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);
  transition:box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.card-soft:hover{box-shadow:var(--shadow-md);border-color:var(--border-2)}

/* ── Metric tiles ───────────────────────────────────────────────────────── */
.metric-tile{padding:1.1rem 1.15rem;border-radius:var(--radius);border:1px solid var(--border);
  background:var(--surface);box-shadow:var(--shadow-xs);position:relative;overflow:hidden;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.metric-tile::before{content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(20,184,166,.03),transparent);pointer-events:none}
.metric-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.metric-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.metric-value{font-family:'Sora',sans-serif;font-size:1.75rem;font-weight:800;line-height:1;
  margin:.35rem 0 .2rem}
.metric-icon{position:absolute;top:.9rem;right:.9rem;width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:.95rem}
.metric-delta{font-size:.72rem;font-weight:600;color:var(--muted)}
.metric-delta.up{color:var(--success)}.metric-delta.down{color:var(--danger)}

/* ── Quick tiles ────────────────────────────────────────────────────────── */
.quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem}
.quick-tile{display:flex;flex-direction:column;align-items:flex-start;padding:.9rem;
  border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border);
  color:var(--text);font-weight:600;font-size:.85rem;cursor:pointer;
  transition:all var(--dur) var(--ease);position:relative;overflow:hidden;min-height:90px}
.quick-tile::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2.5px;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}
.quick-tile:hover{background:var(--surface);border-color:var(--primary-2);
  color:var(--text);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.quick-tile:hover::after{transform:scaleX(1)}
.quick-tile .q-icon{width:38px;height:38px;border-radius:11px;background:var(--teal-50);
  color:var(--teal-700);display:flex;align-items:center;justify-content:center;
  font-size:1rem;margin-bottom:.55rem;transition:background var(--dur) var(--ease)}
[data-theme="dark"] .quick-tile .q-icon{background:rgba(20,184,166,.14);color:var(--teal-200)}
.quick-tile:hover .q-icon{background:var(--teal-100)}
[data-theme="dark"] .quick-tile:hover .q-icon{background:rgba(20,184,166,.24)}
.quick-tile .q-desc{font-size:.68rem;color:var(--muted);font-weight:400;margin-top:.15rem}

/* ── App header banner ──────────────────────────────────────────────────── */
.app-header{padding:1.35rem 1.5rem;border-radius:var(--radius-xl);
  background:linear-gradient(135deg,var(--teal-900) 0%,#0f172a 55%,#1c1438 100%);
  position:relative;overflow:hidden;box-shadow:var(--shadow-lg);margin-bottom:1.5rem}
.app-header::before,.app-header::after{content:'';position:absolute;border-radius:50%;pointer-events:none}
.app-header::before{width:480px;height:480px;top:-50%;right:-8%;
  background:radial-gradient(circle,rgba(20,184,166,.16) 0%,transparent 70%)}
.app-header::after{width:300px;height:300px;bottom:-40%;left:3%;
  background:radial-gradient(circle,rgba(245,158,11,.11) 0%,transparent 70%)}
.app-header-inner{position:relative;z-index:1}
.app-header h1{font-size:clamp(1.15rem,2.5vw,1.55rem);font-weight:800;color:#fff;margin-bottom:.2rem}
.app-header .greeting{color:var(--teal-200);font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:.35rem}
.app-header .sub{color:rgba(255,255,255,.6);font-size:.8rem}
.live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;
  animation:live-pulse 2s ease-in-out infinite}
@keyframes live-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}
.pwa-chip{display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.13);
  color:rgba(255,255,255,.82);padding:.3rem .8rem;border-radius:999px;
  font-size:.76rem;font-weight:600;backdrop-filter:blur(8px)}

/* ── Login page ─────────────────────────────────────────────────────────── */
.login-wrap{min-height:100vh;
  background:radial-gradient(ellipse 70% 60% at 20% 20%,rgba(20,184,166,.2) 0%,transparent 55%),
    radial-gradient(ellipse 50% 45% at 80% 80%,rgba(245,158,11,.15) 0%,transparent 50%),
    linear-gradient(135deg,#0b1120 0%,#0f2a26 45%,#0f172a 100%);
  display:flex;align-items:center;justify-content:center;padding:2rem 1rem}
.login-card{width:100%;max-width:450px}
.login-card .card{background:rgba(255,255,255,.04)!important;backdrop-filter:blur(28px);
  border:1px solid rgba(255,255,255,.10)!important;border-radius:var(--radius-xl)!important;
  box-shadow:0 32px 80px rgba(0,0,0,.55)}
.login-card .card-body{padding:2.25rem!important}
.login-card .form-control,.login-card .form-select{color:#e2e8f0!important;
  background:rgba(255,255,255,.07)!important;border-color:rgba(255,255,255,.12)!important}
.login-card .form-control::placeholder{color:rgba(255,255,255,.28)!important}
.login-card .form-control:focus{border-color:var(--teal-500)!important;
  box-shadow:0 0 0 3px rgba(20,184,166,.22)!important}
.login-card .form-label{color:rgba(255,255,255,.72)!important}
.login-card .input-group-text{background:rgba(255,255,255,.06)!important;
  border-color:rgba(255,255,255,.12)!important;color:rgba(255,255,255,.5)!important}
.login-brand{font-family:'Sora',sans-serif;font-size:1.45rem;font-weight:800;color:#fff}
.login-brand-sub{color:rgba(255,255,255,.48);font-size:.8rem}

/* ── Tables ─────────────────────────────────────────────────────────────── */
.table{color:var(--text)}
.table>thead>tr>th{font-size:.72rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--border);
  padding:.6rem .9rem;background:var(--surface-2);white-space:nowrap}
.table>tbody>tr>td{padding:.65rem .9rem;border-bottom:1px solid var(--border);
  vertical-align:middle;color:var(--text-2);font-size:.875rem;
  transition:background var(--dur) var(--ease)}
.table>tbody>tr:last-child>td{border-bottom:none}
.table>tbody>tr:hover>td{background:var(--surface-2)}

/* ── Forms ──────────────────────────────────────────────────────────────── */
.form-label{font-size:.78rem;font-weight:700;color:var(--text-2);letter-spacing:.01em;margin-bottom:.3rem}
.form-control,.form-select,.input-group-text{border-radius:var(--radius-sm)!important;
  border-color:var(--border);background-color:var(--surface);color:var(--text);
  font-size:.875rem;min-height:42px;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),background var(--dur) var(--ease)}
.form-control:focus,.form-select:focus{border-color:var(--primary-2)!important;
  box-shadow:0 0 0 3px rgba(20,184,166,.15)!important;background-color:var(--surface);color:var(--text)}
[data-theme="dark"] .form-control,[data-theme="dark"] .form-select{background-color:var(--surface-2);color:var(--text);border-color:var(--border)}
[data-theme="dark"] .form-control:focus,[data-theme="dark"] .form-select:focus{background-color:var(--surface-3)}
.input-group-text{background:var(--surface-2);color:var(--muted);border-color:var(--border)}
textarea.form-control{min-height:100px;resize:vertical}
.form-control-sm,.form-select-sm{min-height:34px;font-size:.8rem}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.btn-primary-app{background:linear-gradient(135deg,var(--teal-700),var(--teal-500));
  border:none;color:#fff;font-weight:700;box-shadow:0 4px 14px rgba(20,184,166,.28);
  transition:all var(--dur) var(--ease)}
.btn-primary-app:hover{color:#fff;transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(20,184,166,.38);filter:brightness(1.06)}
.btn-primary-app:active{transform:translateY(0)}
.btn-xs{font-size:.72rem!important;padding:.18rem .55rem!important;border-radius:6px!important}

/* ── Badges ─────────────────────────────────────────────────────────────── */
.badge-soft{background:var(--teal-50);color:var(--teal-800);
  border:1px solid var(--teal-100);font-weight:600;font-size:.72rem}
[data-theme="dark"] .badge-soft{background:rgba(20,184,166,.12);color:var(--teal-200);border-color:rgba(20,184,166,.2)}

/* ── Mini KPI ───────────────────────────────────────────────────────────── */
.mini-kpi{border-radius:var(--radius);border:1px solid var(--border);
  background:linear-gradient(135deg,var(--surface-2),var(--surface-3));padding:1rem 1.15rem}
.mini-kpi .kpi-value{font-family:'Sora',sans-serif;font-size:1.85rem;font-weight:800;line-height:1;margin:.25rem 0}

/* ── Section title ──────────────────────────────────────────────────────── */
.section-title{font-family:'Sora',sans-serif;font-size:.95rem;font-weight:800;letter-spacing:-.01em;color:var(--text)}
.section-subtitle{font-size:.8rem;color:var(--muted);margin-top:.15rem}

/* ── Alerts ─────────────────────────────────────────────────────────────── */
.alert{border-radius:var(--radius)!important;border-left-width:4px;font-weight:500;font-size:.875rem}
.alert-success{background:#f0fdf4;border-color:#86efac;color:#166534}
.alert-danger{background:#fef2f2;border-color:#fca5a5;color:#991b1b}
.alert-warning{background:#fffbeb;border-color:#fcd34d;color:#92400e}
.alert-info{background:#f0f9ff;border-color:#7dd3fc;color:#0c4a6e}
[data-theme="dark"] .alert-success{background:rgba(22,163,74,.1);border-color:rgba(134,239,172,.3);color:#86efac}
[data-theme="dark"] .alert-danger{background:rgba(220,38,38,.1);border-color:rgba(252,165,165,.3);color:#fca5a5}
[data-theme="dark"] .alert-warning{background:rgba(217,119,6,.1);border-color:rgba(252,211,77,.3);color:#fcd34d}
[data-theme="dark"] .alert-info{background:rgba(2,132,199,.1);border-color:rgba(125,211,252,.3);color:#7dd3fc}

/* ── Bottom mobile nav ──────────────────────────────────────────────────── */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:1040;background:var(--surface);
  backdrop-filter:blur(16px);border-top:1px solid var(--border);display:none;
  box-shadow:0 -4px 20px rgba(0,0,0,.08);padding-bottom:env(safe-area-inset-bottom)}
.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;
  padding:.52rem .25rem .58rem;color:var(--muted);font-size:.65rem;font-weight:700;
  letter-spacing:.01em;transition:color var(--dur) var(--ease);gap:.12rem;text-decoration:none}
.bottom-nav a .bi{font-size:1.1rem}
.bottom-nav a.active,.bottom-nav a:hover{color:var(--primary)}
.mobile-pad{padding-bottom:5.5rem}

/* ── Status badges ──────────────────────────────────────────────────────── */
.kitchen-status{border-radius:999px;padding:.18rem .65rem;font-size:.7rem;font-weight:700}

/* ── Step indicator ─────────────────────────────────────────────────────── */
.step-indicator{display:flex;align-items:center;margin-bottom:1.75rem}
.step-item{display:flex;flex-direction:column;align-items:center;flex:1}
.step-dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.82rem;border:2px solid var(--border);background:var(--surface);color:var(--muted);
  transition:all var(--dur) var(--ease)}
.step-item.done .step-dot{background:var(--success);border-color:var(--success);color:#fff}
.step-item.active .step-dot{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px rgba(20,184,166,.2)}
.step-label{font-size:.7rem;font-weight:700;color:var(--muted);margin-top:.3rem;text-align:center}
.step-item.active .step-label,.step-item.done .step-label{color:var(--text)}
.step-line{flex:1;height:2px;background:var(--border);margin-top:-17px}
.step-line.done{background:var(--success)}

/* ── GPS indicator ──────────────────────────────────────────────────────── */
.gps-indicator{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600}
.gps-dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}
.gps-dot.acquiring{background:var(--warning);animation:live-pulse 1s infinite}
.gps-dot.ok{background:var(--success)}
.gps-dot.error{background:var(--danger)}

/* ── Progress ───────────────────────────────────────────────────────────── */
.progress{background:var(--surface-2);border-radius:999px}
.progress-bar{border-radius:999px;transition:width .6s var(--ease)}

/* ── Animations ─────────────────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .35s var(--ease) both}
.fade-up-1{animation-delay:.05s}.fade-up-2{animation-delay:.1s}
.fade-up-3{animation-delay:.15s}.fade-up-4{animation-delay:.2s}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}

/* ── Utility ────────────────────────────────────────────────────────────── */
.text-muted-2{color:var(--muted)!important}
.fw-display{font-family:'Sora',sans-serif}
.card-scroll{max-height:380px;overflow-y:auto}
.list-tight li{margin-bottom:.45rem}
.border-soft{border-color:var(--border)!important}
.bg-surface{background:var(--surface)!important}
.bg-surface-2{background:var(--surface-2)!important}
.rounded-app{border-radius:var(--radius)!important}
.rounded-app-lg{border-radius:var(--radius-lg)!important}
.divider-text{position:relative;text-align:center;color:var(--muted);font-size:.78rem;font-weight:600}
.divider-text::before,.divider-text::after{content:'';position:absolute;top:50%;width:calc(50% - 40px);height:1px;background:var(--border)}
.divider-text::before{left:0}.divider-text::after{right:0}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media(max-width:991.98px){
  .desktop-only{display:none!important}
  .bottom-nav{display:flex}
  .container-fluid{padding-left:.9rem;padding-right:.9rem}
  .app-header{border-radius:var(--radius-lg);padding:1.1rem 1.15rem}
  .quick-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.65rem}
}
@media(min-width:992px){.mobile-only{display:none!important}}

/* ── Print ──────────────────────────────────────────────────────────────── */
@media print{
  .navbar,.bottom-nav,.no-print{display:none!important}
  body{background:#fff!important;color:#000!important}
  .card-soft{box-shadow:none!important;border:1px solid #e2e8f0!important}
}
