:root{
  --ink:#0E1420; --ink-2:#161E2E; --ink-3:#1E2839; --line:#28344A;
  --paper:#E8EDF4; --muted:#8A97AD; --faint:#5C6980;
  --beacon:#FF9E5A; --beacon-ink:#0E1420; --route:#4FD1C5;
  --good:#56C271; --warn:#E8B45A; --crit:#E86A6A;
  --sans:"SF Pro Display",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  --mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,monospace;
  --shadow:0 24px 60px -30px rgba(0,0,0,.8);
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{font-family:var(--sans);background:var(--ink);color:var(--paper);overflow:hidden;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--beacon);outline-offset:2px}
.muted{color:var(--muted)}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--route)}

#map{position:fixed;inset:0}
.maplibregl-ctrl-attrib{font-size:9px;opacity:.5}
.maplibregl-ctrl-bottom-right{display:none}

/* pins */
.pin{width:30px;height:30px;transform:translate(-50%,-100%);cursor:pointer;filter:drop-shadow(0 3px 5px rgba(0,0,0,.5))}
.pin svg{width:100%;height:100%}
.pin .glow{transition:.2s}
.pin:hover .glow,.pin.active .glow{filter:drop-shadow(0 0 8px var(--beacon))}

/* buttons */
.btn-primary{background:var(--beacon);color:var(--beacon-ink);border:0;font-weight:600;font-size:14px;padding:10px 16px;border-radius:11px}
.btn-primary:hover{filter:brightness(1.06)}
.btn-primary.wide{width:100%;padding:13px;font-size:15px;margin-top:6px}
.btn-ghost{background:var(--ink-2);color:var(--paper);border:1px solid var(--line);font-weight:600;font-size:14px;padding:9px 16px;border-radius:11px}
.btn-ghost:hover{border-color:var(--faint)}
.iconbtn{position:relative;background:var(--ink-2);border:1px solid var(--line);border-radius:11px;width:40px;height:40px;font-size:18px}
.badge{position:absolute;top:-5px;right:-5px;background:var(--beacon);color:var(--ink);font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px}

/* top bar */
.topbar{position:fixed;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;gap:12px;
  padding:12px 16px;background:linear-gradient(180deg,rgba(14,20,32,.94),rgba(14,20,32,.55));backdrop-filter:blur(10px)}
.brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:17px;letter-spacing:-.02em}
.brand svg{flex:none}
.search{display:flex;gap:6px;background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:5px}
.search input{background:transparent;border:0;color:var(--paper);font-size:14px;padding:6px 10px;width:120px;outline:none}
.search input::placeholder{color:var(--faint)}
.search select{background:transparent;border:0;color:var(--muted);font-size:13px;outline:none}
.search select option{background:var(--ink-2)}
.roleswitch{display:inline-flex;gap:4px;background:var(--ink-2);border:1px solid var(--line);border-radius:999px;padding:4px}
.roleswitch button{background:transparent;border:0;color:var(--muted);font-weight:600;font-size:13px;padding:7px 15px;border-radius:999px;transition:.15s}
.roleswitch button.on{background:var(--beacon);color:var(--ink)}
.topbar>.btn-ghost,.topbar>.iconbtn{margin-left:auto}
.topbar>.iconbtn{margin-left:0}

/* bottom sheet */
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:15;max-height:46vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(22,30,46,.82),rgba(14,20,32,.97));backdrop-filter:blur(14px);
  border-top:1px solid var(--line);border-radius:20px 20px 0 0;box-shadow:0 -20px 50px -30px #000}
.sheet-grip{width:40px;height:4px;border-radius:2px;background:var(--line);margin:9px auto 4px}
.sheet-head{display:flex;align-items:flex-start;justify-content:space-between;padding:6px 20px 12px}
.sheet-head h2{margin:0;font-size:18px;letter-spacing:-.02em}
.sheet-head .muted{font-size:13px;margin:2px 0 0}
.count{font-family:var(--mono);font-size:13px;color:var(--beacon);background:rgba(255,158,90,.1);padding:4px 10px;border-radius:999px}
.giglist{overflow-y:auto;padding:0 14px 18px;display:flex;flex-direction:column;gap:10px}

/* gig card in list */
.gigcard{display:flex;gap:13px;align-items:center;padding:13px;border:1px solid var(--line);border-radius:14px;background:var(--ink-2);cursor:pointer;transition:.15s}
.gigcard:hover{border-color:var(--faint);transform:translateY(-1px)}
.gigcard .av{width:46px;height:46px;border-radius:12px;flex:none;display:grid;place-items:center;font-weight:700;color:var(--ink);font-size:16px}
.gigcard .info{min-width:0;flex:1}
.gigcard .t{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gigcard .s{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gigcard .meta{text-align:right;flex:none}
.gigcard .price{font-family:var(--mono);font-weight:600;color:var(--paper);font-size:14px}
.gigcard .dist{font-size:12px;color:var(--beacon)}
.gigcard .rate{font-size:12px;color:var(--warn)}
.empty{padding:26px 10px;text-align:center;color:var(--muted);font-size:14px}

/* dashboard */
.dash{position:fixed;inset:0;z-index:16;background:var(--ink);overflow-y:auto;padding:74px 0 40px}
.dash-inner{max-width:760px;margin:0 auto;padding:0 20px}
.dash-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px}
.dash-head h2{margin:4px 0 0;font-size:26px;letter-spacing:-.02em}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:26px}
.stat{border:1px solid var(--line);border-radius:14px;background:var(--ink-2);padding:16px}
.stat .v{font-family:var(--mono);font-size:24px;font-weight:600}
.stat .l{font-size:12px;color:var(--muted);margin-top:2px}
.dash-sec{font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:22px 0 12px}
.minigigs,.orders{display:flex;flex-direction:column;gap:10px}
.minigig,.order{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:13px;background:var(--ink-2);padding:14px}
.minigig .t,.order .t{font-weight:600;font-size:15px}
.minigig .s,.order .s{font-size:13px;color:var(--muted)}
.minigig .grow,.order .grow{flex:1;min-width:0}
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:999px;white-space:nowrap}
.tag.live{color:var(--good);background:rgba(86,194,113,.12)}
.tag.requested{color:var(--warn);background:rgba(232,180,90,.12)}
.tag.accepted{color:var(--route);background:rgba(79,209,197,.12)}
.tag.delivered,.tag.closed{color:var(--good);background:rgba(86,194,113,.12)}
.tag.cancelled{color:var(--crit);background:rgba(232,106,106,.12)}
.linkbtn{background:transparent;border:1px solid var(--line);color:var(--paper);font-size:12.5px;font-weight:600;padding:7px 12px;border-radius:9px}
.linkbtn.warn{border-color:var(--beacon);color:var(--beacon)}
.linkbtn.danger{border-color:rgba(232,106,106,.4);color:var(--crit)}

/* slide-in panel (gig detail) */
.panel{position:fixed;top:0;right:0;bottom:0;z-index:30;width:min(440px,100%);background:var(--ink-2);
  border-left:1px solid var(--line);box-shadow:var(--shadow);overflow-y:auto;animation:slide .22s ease}
@keyframes slide{from{transform:translateX(30px);opacity:0}to{transform:none;opacity:1}}
.panel .phead{position:sticky;top:0;background:var(--ink-2);display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line);z-index:2}
.panel .x,.modal .x{background:transparent;border:0;color:var(--muted);font-size:24px;line-height:1;width:32px;height:32px}
.pbody{padding:20px}
.pbody h2{margin:0 0 4px;font-size:21px;letter-spacing:-.02em}
.owner{display:flex;align-items:center;gap:11px;margin:14px 0 18px;padding:13px;border:1px solid var(--line);border-radius:13px}
.owner .av{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-weight:700;color:var(--ink)}
.owner .nm{font-weight:600}
.owner .r{font-size:12.5px;color:var(--muted)}
.phone-row{margin-left:auto;text-align:right;font-family:var(--mono);font-size:12.5px}
.phone-row .locked{color:var(--warn)}
.phone-row .num{color:var(--good)}
.pdesc{font-size:14.5px;color:#C6D0DE;line-height:1.55;margin:0 0 20px}
.tier{border:1px solid var(--line);border-radius:14px;background:var(--ink);padding:16px;margin-bottom:12px}
.tier.mid{border-color:var(--beacon)}
.tier .th{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.tier .tn{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.tier.mid .tn{color:var(--beacon)}
.tier .tp{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums}
.tier .tp small{font-size:12px;color:var(--muted);font-weight:500}
.tier ul{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:6px;font-size:13.5px;color:#C1CBD9}
.tier li{display:flex;gap:8px}.tier li::before{content:"→";color:var(--route);font-family:var(--mono)}
.tier .hire{width:100%;padding:10px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--paper);font-weight:600;font-size:14px}
.tier.mid .hire{background:var(--beacon);color:var(--ink);border-color:var(--beacon)}
.contactbar{display:flex;gap:10px;margin:4px 0 20px}
.contactbar button{flex:1}
.reviews{margin-top:22px}
.reviews h3{font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:0 0 10px}
.rev{border-top:1px solid var(--ink-3);padding:11px 0}
.rev .st{color:var(--warn);font-size:13px}
.rev .tx{font-size:13.5px;color:#C6D0DE;margin:3px 0 2px}
.rev .au{font-size:12px;color:var(--faint)}

/* chat */
.chat{position:fixed;top:0;right:0;bottom:0;z-index:31;width:min(400px,100%);background:var(--ink-2);
  border-left:1px solid var(--line);box-shadow:var(--shadow);display:flex;flex-direction:column;animation:slide .22s ease}
.chat-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.chat-head .back{background:transparent;border:0;color:var(--paper);font-size:26px;line-height:1;width:30px}
.chat-head #chat-title{font-weight:600}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.unlock-banner{font-family:var(--mono);font-size:12px;padding:9px 12px;border-radius:10px;text-align:center;margin-bottom:6px}
.unlock-banner.locked{color:var(--warn);background:rgba(232,180,90,.09);border:1px solid rgba(232,180,90,.25)}
.unlock-banner.open{color:var(--good);background:rgba(86,194,113,.09);border:1px solid rgba(86,194,113,.28)}
.bubble{max-width:78%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.4}
.bubble.them{align-self:flex-start;background:var(--ink-3);border-bottom-left-radius:4px}
.bubble.me{align-self:flex-end;background:var(--beacon);color:var(--ink);border-bottom-right-radius:4px}
.bubble.sys{align-self:center;background:transparent;color:var(--muted);font-size:12.5px;font-family:var(--mono);max-width:90%;text-align:center}
.chat-list{display:flex;flex-direction:column;gap:8px;padding:6px}
.thread{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:13px;background:var(--ink);cursor:pointer}
.thread:hover{border-color:var(--faint)}
.thread .av{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;font-weight:700;color:var(--ink)}
.thread .grow{min-width:0;flex:1}
.thread .nm{font-weight:600;font-size:14.5px}
.thread .lm{font-size:12.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-send{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.chat-send input{flex:1;background:var(--ink);border:1px solid var(--line);border-radius:11px;color:var(--paper);padding:11px 13px;font-size:14px;outline:none}

/* modal */
.overlay{position:fixed;inset:0;z-index:40;background:rgba(6,10,18,.66);backdrop-filter:blur(3px)}
.modal{position:fixed;z-index:41;top:50%;left:50%;transform:translate(-50%,-50%);width:min(400px,92vw);
  background:var(--ink-2);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);animation:pop .2s ease}
.modal.wide-modal{width:min(520px,94vw);max-height:88vh;overflow-y:auto}
@keyframes pop{from{transform:translate(-50%,-46%);opacity:0}to{transform:translate(-50%,-50%);opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0;font-size:17px}
.tabs{display:flex;gap:4px;background:var(--ink);border:1px solid var(--line);border-radius:999px;padding:3px}
.tabs button{background:transparent;border:0;color:var(--muted);font-weight:600;font-size:13px;padding:6px 14px;border-radius:999px}
.tabs button.on{background:var(--beacon);color:var(--ink)}
.modal-body{padding:18px;display:flex;flex-direction:column;gap:13px}
.fld{display:flex;flex-direction:column;gap:6px}
.fld>span{font-size:12.5px;color:var(--muted)}
.fld input,.fld textarea{background:var(--ink);border:1px solid var(--line);border-radius:11px;color:var(--paper);padding:11px 13px;font-size:14.5px;font-family:inherit;outline:none}
.fld input:focus,.fld textarea:focus{border-color:var(--beacon)}
.fld textarea{min-height:64px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hint{font-size:12.5px;color:var(--faint);margin:0}
.tiers-edit{display:flex;flex-direction:column;gap:12px}
.tedit{border:1px solid var(--line);border-radius:12px;padding:13px;background:var(--ink)}
.tedit .tt{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--beacon);margin-bottom:9px}
.tedit .g3{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.tedit input{width:100%;background:var(--ink-2);border:1px solid var(--line);border-radius:9px;color:var(--paper);padding:9px 11px;font-size:13.5px;outline:none;margin-top:0}
.tedit input:focus{border-color:var(--beacon)}
.tedit .full{grid-column:1 / -1}

/* toaster */
.toaster{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--ink-3);border:1px solid var(--line);color:var(--paper);font-size:14px;padding:11px 18px;border-radius:12px;box-shadow:var(--shadow);animation:pop .2s ease;max-width:90vw}
.toast.err{border-color:rgba(232,106,106,.5)}
.toast.ok{border-color:rgba(86,194,113,.5)}

[hidden]{display:none !important}
@media (max-width:560px){
  .search input{width:88px}
  .roleswitch{position:fixed;bottom:calc(46vh + 12px);left:50%;transform:translateX(-50%);z-index:18}
  .brand span{display:none}
  .stats{grid-template-columns:1fr}
  .row2,.tedit .g3{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important}}
