/* ============================================================
   Bonlive — shared design system
   Used across the customer app, concierge app, and admin.
   ============================================================ */
:root{
  --ink:#0b0f14;
  --ink-2:#11161d;
  --ink-3:#1a212b;
  --line:rgba(255,255,255,0.08);
  --line-strong:rgba(255,255,255,0.16);
  --line-light: rgba(0,0,0,0.06);
  --line-light-strong: rgba(0,0,0,0.12);
  --paper:#f6f1e7;
  --paper-2:#ece5d4;
  --cream:#fbf7ef;
  --gold:#c8a96a;
  --gold-2:#d8b97b;
  --gold-soft:#e8d3a3;
  --gold-bg:#fbf3df;
  --rouge:#b23a3a;
  --green:#2f7a55;
  --green-soft:#dff0e6;
  --blue:#3a6ea5;
  --amber:#c98e2e;
  --text:#1a1f27;
  --text-mute:#5a6573;
  --text-on-dark:#e9e3d4;
  --text-on-dark-mute:#9aa3ad;
  --shadow-lg: 0 30px 60px -20px rgba(0,0,0,.45), 0 18px 30px -18px rgba(0,0,0,.35);
  --shadow-md: 0 18px 30px -24px rgba(0,0,0,.18);
  --shadow-sm: 0 6px 16px -8px rgba(0,0,0,.18);
  --radius: 18px;
  --radius-sm: 10px;
  --radius-xs: 8px;
  --max: 1240px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  line-height:1.5;
  min-height:100vh;
}
a{color:inherit; text-decoration:none}
button{font:inherit; cursor:pointer; border:0; background:none; color:inherit}
input,select,textarea{font:inherit; color:inherit}
img{max-width:100%; display:block}
h1,h2,h3,h4{font-family:"Fraunces", Georgia, serif; font-weight:500; letter-spacing:-0.01em; margin:0; color:var(--ink)}
h1{font-size:clamp(28px, 3.5vw, 40px); letter-spacing:-0.02em; line-height:1.1}
h2{font-size:clamp(22px, 2.4vw, 28px); line-height:1.15}
h3{font-size:18px; line-height:1.2}
h4{font-size:15px; line-height:1.3}
p{margin:0}

/* ====== Layout primitives ====== */
.wrap{max-width:var(--max); margin:0 auto; padding:0 24px}
.eyebrow{
  font-family:"Inter", sans-serif;
  text-transform:uppercase;
  letter-spacing:0.18em;
  font-size:11px;
  font-weight:600;
  color:var(--gold);
}
.muted{color:var(--text-mute)}
.tiny{font-size:12px}
.small{font-size:13px}
.center{text-align:center}
.row{display:flex; gap:12px; align-items:center}
.col{display:flex; flex-direction:column; gap:12px}
.spacer{flex:1}
.divider{height:1px; background:var(--line-light); margin:14px 0}

/* ====== Buttons ====== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 18px; border-radius:999px;
  font-weight:600; font-size:14px;
  transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
  border:1px solid transparent;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink); color:var(--cream); border-color:var(--ink)}
.btn-primary:hover{background:#000}
.btn-gold{background:var(--gold); color:var(--ink); border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-2)}
.btn-ghost{background:transparent; color:var(--ink); border-color:rgba(0,0,0,.18)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-danger{background:rgba(178,58,58,.1); color:var(--rouge); border-color:rgba(178,58,58,.2)}
.btn-danger:hover{background:rgba(178,58,58,.16)}
.btn-sm{padding:7px 12px; font-size:13px}
.btn-lg{padding:14px 22px; font-size:15px}
.btn-block{width:100%}
.btn-icon{padding:8px; border-radius:10px; width:36px; height:36px}

/* ====== Inputs ====== */
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-size:13px; font-weight:600; color:var(--ink)}
.input, select.input, textarea.input{
  width:100%;
  padding:11px 14px;
  border:1px solid rgba(0,0,0,.12);
  border-radius:12px;
  background:#fff;
  font-size:15px;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.input:focus, select.input:focus, textarea.input:focus{
  outline:0;
  border-color:var(--gold);
  box-shadow: 0 0 0 4px rgba(200,169,106,.15);
}
.input.lg{padding:14px 16px; font-size:16px}
textarea.input{min-height:80px; resize:vertical; font-family:inherit}

/* ====== Cards ====== */
.card{
  background:#fff;
  border:1px solid var(--line-light);
  border-radius:var(--radius);
  box-shadow: var(--shadow-md);
}
.card-pad{padding:22px}
.card-pad-sm{padding:16px}
.card-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 22px;
  border-bottom:1px solid var(--line-light);
}
.card-head h3{font-family:"Fraunces", serif; font-size:20px; font-weight:500}
.card-body{padding:22px}

/* ====== Tags / pills ====== */
.tag{
  display:inline-flex; gap:6px; align-items:center;
  padding:4px 10px; border-radius:999px;
  font-size:12px; font-weight:600; letter-spacing:.02em;
}
.tag-amber{background:rgba(201,142,46,.14); color:var(--amber)}
.tag-green{background:var(--green-soft); color:var(--green)}
.tag-blue{background:rgba(58,110,165,.14); color:var(--blue)}
.tag-rouge{background:rgba(178,58,58,.12); color:var(--rouge)}
.tag-ink{background:rgba(0,0,0,.06); color:var(--ink)}
.tag-gold{background:var(--gold-bg); color:#7a5a2c}

/* ====== App shell ====== */
.app-shell{min-height:100vh; display:flex; flex-direction:column}
.app-bar{
  position:sticky; top:0; z-index:40;
  background:rgba(251,247,239,.86);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.app-bar.dark{
  background:rgba(11,15,20,.85);
  color:var(--text-on-dark);
  border-bottom:1px solid var(--line);
}
.app-bar.dark a{color:var(--text-on-dark-mute)}
.app-bar.dark a.on, .app-bar.dark a:hover{color:var(--cream)}
.app-bar-inner{display:flex; align-items:center; justify-content:space-between; gap:16px; height:64px; padding: 0 24px; max-width:1400px; margin:0 auto}
.app-bar nav{display:flex; gap:6px}
.app-bar nav a{
  padding:8px 14px; border-radius:999px; font-size:14px; font-weight:500; color:var(--text-mute);
}
.app-bar nav a:hover{background:rgba(0,0,0,.04); color:var(--ink)}
.app-bar nav a.on{background:var(--ink); color:var(--cream)}
.app-bar.dark nav a.on{background:var(--gold); color:var(--ink)}
.app-bar.dark nav a:hover{background:rgba(255,255,255,.06)}
.app-bar.dark nav a.on:hover{background:var(--gold)}

.brand{display:flex; align-items:center; gap:10px; font-family:"Fraunces", serif; font-size:20px; font-weight:500; letter-spacing:-.01em}
.brand .mark{
  width:30px; height:30px; border-radius:8px;
  background:linear-gradient(135deg, var(--ink), #2a323e);
  display:grid; place-items:center; color:var(--gold);
  font-family:"Fraunces", serif; font-weight:600; font-size:16px;
}
.brand.on-dark{color:var(--cream)}

.user-pill{
  display:flex; gap:10px; align-items:center;
  padding:5px 14px 5px 5px; border-radius:999px;
  background:rgba(0,0,0,.04);
  font-size:13px;
}
.user-pill .av{
  width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg, #caa56a, #7d5a2f);
}
.app-bar.dark .user-pill{background:rgba(255,255,255,.06)}

.app-main{flex:1; padding: 28px 24px 80px}
.app-main .wrap{max-width:1400px; padding:0}

/* ====== Page header ====== */
.page-head{
  display:flex; justify-content:space-between; align-items:flex-end; gap:16px; flex-wrap:wrap;
  margin-bottom:24px;
}
.page-head h1{font-family:"Fraunces", serif}
.page-head .sub{color:var(--text-mute); font-size:15px; margin-top:4px}

/* ====== Grid utilities ====== */
.grid{display:grid; gap:18px}
.grid-2{grid-template-columns:repeat(2, 1fr)}
.grid-3{grid-template-columns:repeat(3, 1fr)}
.grid-4{grid-template-columns:repeat(4, 1fr)}
.grid-12{grid-template-columns:repeat(12, 1fr)}
@media(max-width:980px){
  .grid-3, .grid-4{grid-template-columns:repeat(2, 1fr)}
}
@media(max-width:680px){
  .grid-2, .grid-3, .grid-4{grid-template-columns:1fr}
}

/* ====== KPIs ====== */
.kpi{
  background:#fff; border-radius:var(--radius); padding:18px 20px;
  border:1px solid var(--line-light);
}
.kpi .label{font-size:12px; text-transform:uppercase; letter-spacing:.12em; color:var(--text-mute); font-weight:600}
.kpi .value{font-family:"Fraunces", serif; font-size:34px; font-weight:500; line-height:1; margin-top:8px; letter-spacing:-.02em}
.kpi .delta{font-size:13px; color:var(--green); margin-top:6px}
.kpi .delta.down{color:var(--rouge)}

/* ====== Tables ====== */
.tbl{width:100%; border-collapse:separate; border-spacing:0; font-size:14px}
.tbl th{
  text-align:left; font-weight:600; color:var(--text-mute); font-size:12px;
  text-transform:uppercase; letter-spacing:.1em; padding:14px 16px;
  border-bottom:1px solid var(--line-light); background:rgba(0,0,0,.015);
}
.tbl td{
  padding:14px 16px; border-bottom:1px solid var(--line-light);
  vertical-align:middle;
}
.tbl tbody tr:hover{background:rgba(0,0,0,.015)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .num{font-family:"JetBrains Mono", ui-monospace, SFMono-Regular, monospace; font-size:13px}

/* ====== Map / live styles (reused) ====== */
.map-stage{
  position:relative; background:var(--ink); border-radius:18px; overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
}
.map-stage .map-bg{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 500px at 30% 30%, rgba(200,169,106,.12), transparent 60%),
    linear-gradient(160deg, #0f1620 0%, #131c27 50%, #0c1118 100%);
}
.map-stage .grid-streets{
  position:absolute; inset:0;
  background-image:
    linear-gradient(0deg, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 36px 36px;
}
.map-stage .lake{
  position:absolute; left:-10%; bottom:-15%; width:120%; height:55%;
  background: radial-gradient(60% 100% at 50% 0%, rgba(70,120,160,.32), rgba(70,120,160,0) 70%);
}
.map-stage .pin{
  position:absolute; transform:translate(-50%, -100%);
  display:flex; flex-direction:column; align-items:center; gap:4px; z-index:2;
}
.map-stage .pin .dot{
  width:14px; height:14px; border-radius:50%;
  background:var(--gold); box-shadow:0 0 0 4px rgba(200,169,106,.25), 0 0 0 10px rgba(200,169,106,.12);
}
.map-stage .pin .dot.start{background:#fff; box-shadow:0 0 0 3px rgba(255,255,255,.25)}
.map-stage .pin .dot.end{background:var(--rouge); box-shadow:0 0 0 4px rgba(178,58,58,.28)}
.map-stage .pin .label{
  font-size:10px; color:#e9e3d4; background:rgba(0,0,0,.55);
  padding:3px 7px; border-radius:99px; border:1px solid rgba(255,255,255,.08);
  white-space:nowrap; font-weight:600;
}
.courier-dot{
  position:absolute; transform:translate(-50%,-50%);
  width:30px; height:30px; border-radius:50%;
  background:linear-gradient(180deg, var(--gold), #b59056);
  display:grid; place-items:center; z-index:3;
  box-shadow:0 0 0 4px rgba(200,169,106,.22), 0 0 0 10px rgba(200,169,106,.10), 0 8px 14px rgba(0,0,0,.35);
  color:#0b0f14;
}
.courier-dot::after{
  content:""; position:absolute; inset:-5px; border-radius:50%;
  border:1px solid rgba(200,169,106,.45);
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse{
  0%{transform:scale(1); opacity:.9}
  100%{transform:scale(1.9); opacity:0}
}
.live-tag{
  display:inline-flex; gap:6px; align-items:center;
  font-size:11px; font-weight:700; letter-spacing:.1em;
  background:rgba(178,58,58,.88); color:#fff; padding:5px 10px; border-radius:99px;
}
.live-tag i{width:6px; height:6px; border-radius:50%; background:#fff; animation:blink 1.2s infinite}
@keyframes blink{50%{opacity:.25}}

/* ====== POV mock card ====== */
.pov-card{
  background:#000; color:#e9e3d4; border-radius:18px; overflow:hidden; position:relative;
  border:1px solid rgba(255,255,255,.08); aspect-ratio:16/10;
}
.pov-card .feed{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 50% 60%, rgba(255,220,170,.08), transparent 60%),
    linear-gradient(180deg, #1a2030 0%, #0c1018 60%, #060a10 100%);
}
.pov-card .shelves{
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0 2px, transparent 2px 50px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 30px);
  mask-image: linear-gradient(180deg, black 25%, transparent 100%);
}
.pov-card .product{
  position:absolute; left:50%; top:55%; transform:translate(-50%,-50%);
  width:120px; height:96px; border-radius:8px;
  background:linear-gradient(135deg,#c9a572,#7a5a2c);
  box-shadow:0 12px 24px rgba(0,0,0,.5), inset 0 0 0 1px rgba(255,255,255,.08);
}
.pov-card .reticle{
  position:absolute; left:50%; top:55%; transform:translate(-50%,-50%);
  width:150px; height:120px; border:1px solid rgba(200,169,106,.65); border-radius:6px;
}
.pov-card .reticle::before, .pov-card .reticle::after{content:""; position:absolute; background:rgba(200,169,106,.65)}
.pov-card .reticle::before{left:-14px; right:-14px; top:50%; height:1px}
.pov-card .reticle::after{top:-14px; bottom:-14px; left:50%; width:1px}
.pov-card .scan-line{
  position:absolute; left:0; right:0; height:30%; top:-30%;
  background:linear-gradient(180deg, transparent, rgba(200,169,106,.12), transparent);
  animation: scan 5s linear infinite;
}
@keyframes scan{0%{top:-30%}100%{top:130%}}
.pov-card .ui{
  position:absolute; inset:0; padding:14px 16px;
  display:flex; flex-direction:column; justify-content:space-between;
  font-size:11px; letter-spacing:.04em;
}
.pov-card .ui .top, .pov-card .ui .bottom{display:flex; justify-content:space-between; align-items:center}
.pov-card .glasses-svg{width:18px; height:14px}
.pov-card.off .feed{background:#0a0a0a}
.pov-card.off .product, .pov-card.off .reticle, .pov-card.off .shelves, .pov-card.off .scan-line{display:none}
.pov-card.off .center-msg{
  position:absolute; inset:0; display:grid; place-items:center;
  color:#9aa3ad; font-size:13px; letter-spacing:.04em;
}

/* ====== Avatar / shopper ====== */
.av{width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,#caa56a,#7d5a2f); flex-shrink:0; position:relative}
.av.online::after{content:""; position:absolute; right:-1px; bottom:-1px; width:10px; height:10px; border-radius:50%; background:#3ad07a; border:2px solid #fff}
.av.lg{width:48px; height:48px}
.av.sm{width:28px; height:28px}
.av.xl{width:64px; height:64px}

/* ====== Toast ====== */
.toast-wrap{position:fixed; right:20px; bottom:20px; display:flex; flex-direction:column; gap:8px; z-index:80}
.toast{
  background:var(--ink); color:var(--cream); padding:12px 16px; border-radius:12px;
  font-size:14px; box-shadow: var(--shadow-lg);
  display:flex; gap:10px; align-items:center;
  animation: toastIn .3s ease;
}
.toast .ico{width:18px; height:18px; color:var(--gold)}
.toast.ok .ico{color:#3ad07a}
@keyframes toastIn{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:translateY(0)}}

/* ====== Empty states ====== */
.empty{
  text-align:center; padding:60px 20px; color:var(--text-mute);
  border:1px dashed rgba(0,0,0,.12); border-radius:16px;
}
.empty .ico{
  width:56px; height:56px; border-radius:18px; background:var(--gold-bg);
  display:grid; place-items:center; color:var(--gold); margin: 0 auto 14px;
}
.empty h3{color:var(--ink); margin-bottom:6px; font-family:"Fraunces", serif}

/* ====== Modal ====== */
.modal-back{
  position:fixed; inset:0; background:rgba(11,15,20,.55); backdrop-filter:blur(4px);
  display:grid; place-items:center; z-index:90; padding:20px;
}
.modal{
  width:100%; max-width:560px; background:#fff; border-radius:20px; overflow:hidden;
  box-shadow: var(--shadow-lg);
}
.modal .head{padding:20px 24px; border-bottom:1px solid var(--line-light); display:flex; justify-content:space-between; align-items:center}
.modal .body{padding:24px}
.modal .foot{padding:16px 24px; background:var(--cream); display:flex; justify-content:flex-end; gap:8px}

/* ====== SVG icon helper ====== */
.ico-svg{width:18px; height:18px; stroke-width:1.8; stroke:currentColor; fill:none; stroke-linecap:round; stroke-linejoin:round}
.ico-svg.lg{width:22px; height:22px}
.ico-svg.sm{width:14px; height:14px}

/* Swiss cross detail */
.swiss-cross{width:14px; height:14px; background:var(--rouge); position:relative; border-radius:2px; flex-shrink:0; display:inline-block; vertical-align:middle}
.swiss-cross::before, .swiss-cross::after{content:""; position:absolute; background:#fff}
.swiss-cross::before{left:50%; top:18%; bottom:18%; width:2px; transform:translateX(-50%)}
.swiss-cross::after{top:50%; left:18%; right:18%; height:2px; transform:translateY(-50%)}

/* Status badges for orders */
.status-badge{font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:4px 9px; border-radius:99px}
.status-badge.queued{background:rgba(0,0,0,.06); color:var(--text-mute)}
.status-badge.accepted{background:var(--gold-bg); color:#7a5a2c}
.status-badge.shopping{background:rgba(58,110,165,.12); color:var(--blue)}
.status-badge.enroute{background:rgba(201,142,46,.14); color:var(--amber)}
.status-badge.delivered{background:var(--green-soft); color:var(--green)}
.status-badge.cancelled{background:rgba(178,58,58,.12); color:var(--rouge)}

/* Item rows in lists */
.li-item{
  display:flex; gap:12px; align-items:flex-start; padding:14px 16px;
  border:1px solid var(--line-light); border-radius:12px; background:#fff;
  transition: border-color .15s ease, background .15s ease;
}
.li-item.done{background:#fafafa; border-color:rgba(0,0,0,.04)}
.li-item.done .name{text-decoration:line-through; color:var(--text-mute)}
.li-item .check{
  width:22px; height:22px; border-radius:6px; border:2px solid rgba(0,0,0,.2); flex-shrink:0;
  display:grid; place-items:center; cursor:pointer; transition: all .15s ease;
}
.li-item .check:hover{border-color:var(--gold)}
.li-item.done .check{background:var(--green); border-color:var(--green); color:#fff}
.li-item .qty{font-family:"JetBrains Mono", monospace; font-size:13px; padding:2px 8px; background:var(--cream); border-radius:6px; color:var(--text-mute)}
.li-item .body{flex:1; min-width:0}
.li-item .name{font-weight:600; font-size:15px}
.li-item .note{color:var(--text-mute); font-size:13px; margin-top:2px}
.li-item .shop{font-size:12px; color:var(--gold); font-weight:600; text-transform:uppercase; letter-spacing:.06em; margin-top:4px}
