:root{--bg:11 14 17;--card:24 28 34;--text:234 236 239;--muted:132 142 156;--border:40 46 54;--primary:255 199 0;--primaryText:17 17 17;--danger:239 68 68;--shadow:0 10px 30px rgba(0,0,0,.35);color-scheme:dark}
*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;-webkit-text-size-adjust:100%}body{background:rgb(var(--bg));color:rgb(var(--text));overflow-x:hidden}
#app{min-height:100vh}

/* iOS-ish motion shell */
.shell{min-height:100vh;max-width:430px;margin:0 auto;padding:16px 16px calc(140px + env(safe-area-inset-bottom));position:relative}
.header{position:sticky;top:0;z-index:30;margin:-16px -16px 12px;padding:calc(10px + env(safe-area-inset-top)) 16px 12px;background:rgba(var(--bg),.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(var(--border),.25)}
.headerRow{display:flex;align-items:center;gap:10px}
.backBtn{display:none}
.header.hasBack .backBtn{display:inline-flex}
.backBtn{border:1px solid rgba(var(--border),.35);background:rgba(var(--card),.9);color:rgb(var(--text));padding:8px 12px;border-radius:14px;font-weight:800}
.title{font-size:18px;font-weight:900;letter-spacing:.2px}

.card{background:rgb(var(--card));border:1px solid rgba(var(--border),.35);border-radius:22px;padding:14px;box-shadow:var(--shadow);overflow:hidden}
.row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.muted{color:rgb(var(--muted))}
.btn{border:0;border-radius:18px;padding:14px 14px;font-weight:900;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;min-height:52px;font-size:14px;line-height:1.1}
.btn{display:flex;align-items:center;justify-content:center}
.btnPrimary{background:rgb(var(--primary));color:#111827}
.btnGhost{background:rgba(var(--bg),.25);color:rgb(var(--text));border:1px solid rgba(255,255,255,.10)}
.btnDanger{background:rgb(var(--danger));color:#fff}
.btnSmall{padding:10px 12px;border-radius:14px;font-size:13px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid2 .btn{width:100%}
@media (max-width: 380px){
  .grid2{grid-template-columns:1fr}
}
.list{display:flex;flex-direction:column;gap:10px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:rgba(var(--bg),.55);border:1px solid rgba(var(--border),.35);font-size:12px;font-weight:800}

/* Tabs + iPhone bottom bar */
.tabsViewport{position:relative;overflow:hidden}
.tabsTrack{display:flex;gap:0;width:400%;transition:transform 420ms cubic-bezier(.22,1,.36,1);will-change:transform}
.tabPage{width:100%;flex:0 0 100%;opacity:.18;transition:opacity 260ms ease;pointer-events:none}
.tabPage.active{opacity:1;pointer-events:auto}

.bottomWrap{position:fixed;left:0;right:0;bottom:0;z-index:40;padding:0 16px calc(10px + env(safe-area-inset-bottom));pointer-events:none}
.bottomBar{pointer-events:auto;max-width:430px;margin:0 auto;background:rgba(var(--card),.82);backdrop-filter:blur(14px);border:1px solid rgba(var(--border),.35);border-radius:30px;padding:8px;box-shadow:var(--shadow)}
.nav{display:flex;gap:0;position:relative}
.indicator{position:absolute;top:6px;bottom:6px;width:25%;border-radius:22px;background:rgba(var(--bg),.7);border:1px solid rgba(var(--border),.25);transform:translate3d(0,0,0);transition:transform 420ms cubic-bezier(.22,1,.36,1)}
.nav.drag .indicator{transition:none}
.tabBtn{flex:1;border:0;background:transparent;color:rgb(var(--muted));padding:8px 4px;border-radius:22px;font-weight:900;font-size:11px;display:flex;flex-direction:column;align-items:center;gap:2px;position:relative}
.tabBtn .ico{font-size:16px;line-height:1}
.tabBtn.active{color:rgb(var(--text))}

/* Forms */
.input{width:100%;padding:14px 14px;border-radius:18px;border:1px solid rgba(var(--border),.35);background:rgba(var(--bg),.55);color:rgb(var(--text));font-weight:700;outline:none}
textarea.input{min-height:110px;resize:vertical}

.toast{position:fixed;left:0;right:0;top:12px;z-index:60;display:flex;justify-content:center;pointer-events:none}
.toastInner{pointer-events:auto;max-width:430px;margin:0 16px;background:rgba(var(--card),.92);border:1px solid rgba(var(--border),.35);border-radius:22px;padding:12px 14px;font-weight:800;box-shadow:var(--shadow)}

.skel{height:72px;border-radius:22px;background:rgba(var(--card),.6);animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}

.small{font-size:12px}
.h1{font-size:22px;font-weight:950}
.h2{font-size:14px;font-weight:950}
.sep{height:1px;background:rgba(var(--border),.25);margin:10px 0}

.badge{font-size:11px;font-weight:900;padding:6px 10px;border-radius:999px;background:rgba(var(--bg),.6);border:1px solid rgba(var(--border),.35)}
