/* ============ Manila Street · premium design system ============ */
:root{
  --bg:#08090d; --bg-soft:#0e1016; --surface:#14161e; --surface2:#1b1e28;
  --line:rgba(255,255,255,.07); --line2:rgba(255,255,255,.12);
  --text:#f4f5f8; --muted:#9aa3b4; --faint:#646d7e;
  --gold:#f3c577; --amber:#ff8a3d; --rose:#ff5a6e;
  --grad:linear-gradient(120deg,#f7c76b 0%,#ff7a3d 55%,#ff5470 110%);
  --grad-soft:linear-gradient(135deg,rgba(247,199,107,.18),rgba(255,84,112,.14));
  --ok:#43d6a0; --r:22px; --r-sm:15px;
  --sh:0 22px 50px -18px rgba(0,0,0,.7);
  --sh-glow:0 14px 36px -10px rgba(255,122,61,.5);
  --safe-t:env(safe-area-inset-top,0px); --safe-b:env(safe-area-inset-bottom,0px);
  --serif:'Cormorant Garamond',Georgia,serif; --sans:'Manrope',-apple-system,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;
  overscroll-behavior-y:none;-webkit-font-smoothing:antialiased;letter-spacing:.1px}
body::before{content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 40% at 15% 0%,rgba(255,122,61,.16),transparent 60%),
    radial-gradient(50% 35% at 100% 12%,rgba(255,84,112,.12),transparent 60%),
    radial-gradient(70% 50% at 50% 110%,rgba(247,199,107,.08),transparent 60%),var(--bg)}
.hidden{display:none!important}.muted{color:var(--muted);font-weight:500}.mt8{margin-top:10px}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.ic{width:22px;height:22px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* ============ SPLASH ============ */
#splash{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:40px;background:var(--bg);transition:opacity .6s ease,visibility .6s}
#splash.gone{opacity:0;visibility:hidden}
.mesh{position:absolute;inset:-20%;filter:blur(60px);opacity:.7;
  background:
    radial-gradient(30% 30% at 30% 35%,rgba(255,122,61,.55),transparent 60%),
    radial-gradient(28% 28% at 70% 45%,rgba(255,84,112,.45),transparent 60%),
    radial-gradient(34% 30% at 50% 70%,rgba(247,199,107,.4),transparent 60%);
  animation:mesh 7s ease-in-out infinite alternate}
@keyframes mesh{0%{transform:scale(1) translateY(0) rotate(0)}100%{transform:scale(1.25) translateY(-18px) rotate(8deg)}}
.splash-inner{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}
.logo-svg{width:118px;height:118px;filter:drop-shadow(0 8px 26px rgba(255,122,61,.45))}
.logo-svg .ring{stroke-dasharray:327;stroke-dashoffset:327;animation:draw 1.3s .15s cubic-bezier(.6,.1,.2,1) forwards}
.logo-svg .mono{font-family:var(--serif);font-weight:700;font-size:54px;fill:#fff;opacity:0;animation:popIn .6s .9s both}
.logo-svg .spark{opacity:0;animation:popIn .5s 1.15s both}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes popIn{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:none}}
.logo-svg .mono,.logo-svg .spark{transform-origin:60px 60px}
.word{font-family:var(--serif);font-weight:700;font-size:34px;letter-spacing:1px;display:flex;flex-wrap:wrap;justify-content:center;
  background:linear-gradient(120deg,#fff,#ffe6cf);-webkit-background-clip:text;background-clip:text;color:transparent}
.word span{opacity:0;transform:translateY(14px);display:inline-block;animation:up .5s forwards}
.word span:nth-child(1){animation-delay:1s}.word span:nth-child(2){animation-delay:1.05s}.word span:nth-child(3){animation-delay:1.1s}
.word span:nth-child(4){animation-delay:1.15s}.word span:nth-child(5){animation-delay:1.2s}.word span:nth-child(6){animation-delay:1.25s}
.word span:nth-child(7){animation-delay:1.34s}.word span:nth-child(8){animation-delay:1.39s}.word span:nth-child(9){animation-delay:1.44s}
.word span:nth-child(10){animation-delay:1.49s}.word span:nth-child(11){animation-delay:1.54s}.word span:nth-child(12){animation-delay:1.59s}.word span:nth-child(13){animation-delay:1.64s}
@keyframes up{to{opacity:1;transform:none}}
.word-tag{color:var(--muted);font-size:11.5px;letter-spacing:3px;text-transform:uppercase;opacity:0;animation:up .6s 1.7s forwards}
.loadline{position:relative;width:150px;height:3px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden;opacity:0;animation:up .5s 1.85s forwards}
.loadline i{position:absolute;left:-45%;width:45%;height:100%;border-radius:99px;background:var(--grad);animation:run 1.1s 1.85s ease-in-out infinite}
@keyframes run{0%{left:-45%}100%{left:100%}}

/* ============ SCREENS ============ */
.screen{display:none;padding:calc(14px + var(--safe-t)) 18px 120px}
.screen.active{display:block;animation:fadeUp .45s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.scr-title{font-family:var(--serif);font-size:34px;font-weight:700;margin:6px 2px 18px}

/* ============ MENU ============ */
.greet{margin:2px 2px 14px}
.greet-hi{color:var(--muted);font-size:13px;font-weight:600}
.greet-name{font-family:var(--serif);font-size:27px;font-weight:700;line-height:1.1;margin-top:1px}
.hero{position:relative;height:172px;border-radius:26px;overflow:hidden;margin-bottom:16px;box-shadow:var(--sh)}
.hero-bg{position:absolute;inset:0;background:var(--grad)}
.hero-bg::after{content:'';position:absolute;inset:0;background:
  radial-gradient(120% 90% at 80% -10%,rgba(255,255,255,.35),transparent 50%),
  linear-gradient(180deg,transparent 35%,rgba(0,0,0,.55))}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero img+.hero-shade{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.6))}
.hero-content{position:absolute;left:20px;bottom:18px;z-index:2}
.hero-word{font-family:var(--serif);font-size:30px;font-weight:700;text-shadow:0 3px 18px rgba(0,0,0,.4)}
.hero-sub{font-size:12.5px;letter-spacing:2px;text-transform:uppercase;opacity:.92;margin-top:2px}

.search{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:0 14px;margin-bottom:14px}
.search .ic{width:18px;height:18px;color:var(--faint);flex:0 0 auto}
.search input{flex:1;background:none;border:none;color:var(--text);padding:13px 0;font-size:15px;outline:none}

.catnav{display:flex;gap:9px;overflow-x:auto;padding:2px 0 14px;scrollbar-width:none;
  position:sticky;top:var(--safe-t);z-index:20;background:linear-gradient(180deg,var(--bg) 78%,transparent)}
.catnav::-webkit-scrollbar{display:none}
.catnav button{flex:0 0 auto;background:var(--surface);color:var(--muted);border:1px solid var(--line);
  padding:9px 17px;border-radius:99px;font-size:13.5px;font-weight:700;transition:.25s;white-space:nowrap}
.catnav button.active{background:var(--grad);border-color:transparent;color:#1a0e06;box-shadow:var(--sh-glow)}

.cat-h{font-family:var(--serif);font-size:23px;font-weight:700;margin:22px 2px 13px;display:flex;align-items:center;gap:9px}
.cat-banner{width:100%;height:128px;object-fit:cover;border-radius:var(--r);margin-bottom:8px}

.dish{position:relative;display:flex;gap:13px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:11px;margin-bottom:13px;align-items:center;transition:transform .15s,border-color .25s;overflow:hidden}
.dish:active{transform:scale(.985)}
.dish::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(255,138,61,.35),transparent 45%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;pointer-events:none}
.dish .ph{width:86px;height:86px;border-radius:16px;object-fit:cover;flex:0 0 auto;
  background:linear-gradient(135deg,var(--surface2),var(--bg-soft));display:flex;align-items:center;justify-content:center}
.dish .ph svg{width:30px;height:30px;color:var(--faint);opacity:.6;stroke-width:1.5}
.dish .info{flex:1;min-width:0}
.dish .nm{font-weight:700;font-size:15.5px;margin-bottom:3px;line-height:1.2}
.dish .ds{color:var(--muted);font-size:12.5px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dish .pr{margin-top:8px;font-weight:800;font-size:15px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.dish .ct{flex:0 0 auto;align-self:flex-end}
.add{width:42px;height:42px;border-radius:14px;background:var(--grad);color:#1a0e06;font-size:24px;font-weight:600;
  box-shadow:var(--sh-glow);display:flex;align-items:center;justify-content:center;transition:transform .12s}
.add:active{transform:scale(.88)}
.stepper{display:flex;align-items:center;background:var(--surface2);border-radius:14px;border:1px solid var(--line2)}
.stepper button{width:38px;height:42px;color:var(--gold);font-size:22px;font-weight:600}
.stepper .q{min-width:24px;text-align:center;font-weight:800;font-variant-numeric:tabular-nums}

/* skeletons */
.sk{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);height:108px;margin-bottom:13px;position:relative;overflow:hidden}
.sk::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);animation:shimmer 1.3s infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ============ CART ============ */
.crow{display:flex;gap:13px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:12px;margin-bottom:11px;animation:fadeUp .3s}
.crow .ph{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--surface2),var(--bg-soft));display:flex;align-items:center;justify-content:center}
.crow .ph svg{width:24px;height:24px;color:var(--faint);opacity:.6;stroke-width:1.5}
.crow .nm{font-weight:700}.crow .pr{color:var(--muted);font-size:13px;margin-top:3px}
.summary{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-top:8px}
.summary .row{display:flex;justify-content:space-between;padding:6px 0;color:var(--muted);font-weight:500}
.summary .row.total{color:var(--text);font-weight:800;font-size:20px;border-top:1px solid var(--line);margin-top:9px;padding-top:13px;font-family:var(--serif)}
.btn-primary{position:relative;width:100%;border-radius:18px;background:var(--grad);color:#1a0e06;font-weight:800;font-size:16px;padding:17px;margin-top:16px;box-shadow:var(--sh-glow);overflow:hidden;transition:transform .12s}
.btn-primary:active{transform:scale(.99)}
.btn-primary:disabled{opacity:.6}
.btn-ghost{width:100%;border:1px solid var(--line2);background:var(--surface);color:var(--text);border-radius:15px;padding:14px;font-weight:700;margin-top:11px}

/* ============ PROFILE ============ */
.prof-head{position:relative;display:flex;align-items:center;gap:15px;background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:18px;margin-bottom:14px;overflow:hidden}
.prof-head::before{content:'';position:absolute;right:-30px;top:-40px;width:160px;height:160px;border-radius:50%;background:var(--grad-soft);filter:blur(20px)}
.avatar{position:relative;width:66px;height:66px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:27px;font-weight:700;color:#1a0e06;flex:0 0 auto;box-shadow:var(--sh-glow)}
.prof-name{font-family:var(--serif);font-size:23px;font-weight:700;display:flex;align-items:center;gap:8px}
.prof-phone{color:var(--muted);font-size:13.5px;margin-top:3px}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:99px;font-size:12px;font-weight:800;letter-spacing:.3px}
.chip.vip{background:linear-gradient(120deg,rgba(243,197,119,.22),rgba(255,138,61,.18));color:var(--gold);border:1px solid rgba(243,197,119,.3)}
.chip.disc{background:rgba(67,214,160,.14);color:var(--ok)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:14px}
.card h4{font-size:13px;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);font-weight:700;margin-bottom:13px}
.langs{display:flex;gap:8px}
.langs button{flex:1;background:var(--surface2);border:1px solid var(--line);color:var(--text);padding:12px;border-radius:14px;font-weight:700;transition:.2s}
.langs button.active{background:var(--grad);border-color:transparent;color:#1a0e06}
.ohist{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--line)}
.ohist:last-child{border-bottom:none}.ohist .on{font-weight:700}.ohist .od{color:var(--faint);font-size:12px;margin-top:2px}
.ohist .ost{font-size:12.5px;color:var(--gold);font-weight:700;text-align:right}

/* ============ FIELDS / SEG ============ */
.field{margin-bottom:16px}.field label{display:block;margin:0 2px 9px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}
input,textarea{width:100%;background:var(--bg-soft);border:1px solid var(--line2);color:var(--text);border-radius:14px;padding:14px;font-size:15px;font-family:inherit;resize:none;outline:none;transition:border-color .2s}
input:focus,textarea:focus{border-color:var(--amber)}
.seg{display:flex;gap:8px}.seg-col{flex-direction:column}
.seg button{flex:1;background:var(--surface2);border:1px solid var(--line);color:var(--muted);padding:14px;border-radius:14px;font-size:13.5px;font-weight:700;transition:.22s}
.seg button.active{background:var(--grad);border-color:transparent;color:#1a0e06;box-shadow:var(--sh-glow)}

/* ============ SHEET ============ */
.sheet{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-end}
.sheet-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);animation:fadeUp .25s}
.sheet-card{position:relative;width:100%;max-height:92vh;overflow-y:auto;background:var(--bg-soft);border:1px solid var(--line);border-bottom:none;
  border-radius:30px 30px 0 0;padding:10px 18px calc(26px + var(--safe-b));box-shadow:0 -20px 60px rgba(0,0,0,.6);animation:slideUp .4s cubic-bezier(.2,.9,.2,1)}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
.sheet-handle{width:44px;height:5px;border-radius:99px;background:var(--line2);margin:8px auto 16px}
.sheet-title{font-family:var(--serif);font-size:26px;font-weight:700;margin-bottom:16px}

/* ============ CHAT ============ */
.screen.support{padding:0;display:none;flex-direction:column;height:100vh;height:100dvh}
.screen.support.active{display:flex;animation:none}
.sup-head{display:flex;align-items:center;gap:12px;padding:calc(12px + var(--safe-t)) 18px 12px;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.sup-av{width:44px;height:44px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#1a0e06}
.sup-av .ic{width:22px;height:22px}
.sup-name{font-weight:800}.sup-st{color:var(--ok);font-size:12px;margin-top:1px;display:flex;align-items:center;gap:5px}
.sup-st::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.chat{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:9px}
.bub{max-width:82%;padding:11px 15px;border-radius:18px;font-size:14.5px;line-height:1.4;word-wrap:break-word;animation:bub .25s ease}
@keyframes bub{from{opacity:0;transform:translateY(6px) scale(.97)}to{opacity:1;transform:none}}
.bub .tm{display:block;font-size:10px;color:var(--faint);margin-top:5px;letter-spacing:.3px}
.bub.me{align-self:flex-end;background:var(--grad);color:#1a0e06;border-bottom-right-radius:6px;box-shadow:var(--sh-glow)}
.bub.me .tm{color:rgba(26,14,6,.55)}
.bub.admin{align-self:flex-start;background:var(--surface);border:1px solid var(--line);border-bottom-left-radius:6px}
.chat-empty{margin:auto;text-align:center;color:var(--muted);padding:30px;font-size:14px;line-height:1.6;max-width:280px}
.chat-input{display:flex;gap:9px;padding:11px 14px calc(11px + var(--safe-b));background:var(--bg-soft);border-top:1px solid var(--line)}
.chat-input input{border-radius:99px;background:var(--surface)}
.chat-input button{width:46px;height:46px;flex:0 0 auto;border-radius:50%;background:var(--grad);color:#1a0e06;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-glow)}

/* ============ TABBAR ============ */
#tabbar{position:fixed;left:0;right:0;bottom:0;z-index:100;display:flex;
  background:rgba(10,11,14,.82);backdrop-filter:blur(20px) saturate(1.4);border-top:1px solid var(--line);padding-bottom:var(--safe-b)}
#tabbar button{flex:1;color:var(--faint);padding:10px 0 9px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;transition:color .25s}
#tabbar button .ic{transition:transform .25s}
#tabbar button i{font-size:10.5px;font-style:normal;font-weight:700;letter-spacing:.2px}
#tabbar button.active{color:var(--gold)}
#tabbar button.active .ic{transform:translateY(-2px) scale(1.06)}
#tabbar button.active::after{content:'';position:absolute;top:0;width:26px;height:3px;border-radius:0 0 4px 4px;background:var(--grad)}
.badge{position:absolute;top:5px;right:calc(50% - 24px);background:var(--rose);color:#fff;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:99px;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 8px rgba(255,90,110,.5)}

.toast{position:fixed;left:50%;bottom:92px;transform:translateX(-50%);z-index:150;background:rgba(20,22,30,.96);border:1px solid var(--line2);color:#fff;padding:12px 20px;border-radius:14px;font-size:14px;font-weight:600;backdrop-filter:blur(10px);animation:fadeUp .25s}
.empty{text-align:center;color:var(--muted);padding:70px 26px;font-size:15px;line-height:1.6}
.empty .big{font-size:40px;display:block;margin-bottom:14px;opacity:.5}
