/* ============================================================
   URANUS — Telegram Android style (mobile-first, responsive)
   ============================================================ */
@import url('https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/Vazirmatn-font-face.css');

:root{
  --blue:#3d8fd1; --blue-d:#2f7ab8; --blue-l:#eaf3fb;
  --ink:#1c2b33; --sub:#8a98a5; --line:#eef1f3; --line2:#e6ebee;
  --sent:#effdde; --recv:#ffffff; --check:#4aa3d8;
  --badge:#46a0e0; --badge-mut:#c2cdd6;
  --chat-green:#d4e6cb; --danger:#e0414f;
  --bg:#ffffff; --press:#f2f5f7;
  --shadow:0 2px 10px rgba(20,50,70,.12); --shadow-lg:0 8px 30px rgba(20,50,70,.22);
  --topbar-h:56px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:Vazirmatn,'Segoe UI',Tahoma,system-ui,sans-serif;direction:rtl;color:var(--ink);
  background:var(--bg);overflow:hidden;-webkit-font-smoothing:antialiased}
input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit}
.hidden{display:none !important}
.muted{color:var(--sub)}
.ic{display:block;flex:none}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-thumb{background:rgba(140,160,175,.4);border-radius:6px}

/* icon buttons */
.ico-btn{width:42px;height:42px;border:none;background:transparent;color:#fff;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex:none;transition:background .15s}
.ico-btn:hover{background:rgba(255,255,255,.16)}

/* avatars */
.avatar{width:54px;height:54px;border-radius:50%;flex:none;display:inline-flex;align-items:center;
  justify-content:center;color:#fff;font-weight:600;font-size:21px;overflow:hidden;background:#65aadd}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.avatar.sm{width:40px;height:40px;font-size:16px}
.avatar.lg{width:64px;height:64px;font-size:26px}
.avatar.xl{width:112px;height:112px;font-size:46px}

/* ===================== STARFIELD (auth) ===================== */
.stars{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.star{position:absolute;width:2px;height:2px;border-radius:50%;background:#cfe6ff;opacity:.5;animation:tw 3s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:.15}50%{opacity:.85}}

/* planet */
.planet{width:90px;height:90px;border-radius:50%;margin:0 auto;position:relative;
  background:radial-gradient(circle at 32% 30%,#bdf3ec,#5fc7d6 45%,#2f7d99 100%);
  box-shadow:inset -9px -9px 22px rgba(0,0,0,.3),0 0 44px rgba(79,209,197,.4)}
.planet::after{content:"";position:absolute;left:50%;top:50%;width:158%;height:32%;
  transform:translate(-50%,-50%) rotate(-22deg);border-radius:50%;
  border:5px solid rgba(173,224,255,.55);border-left-color:transparent;border-right-color:transparent}
.sm-planet{width:64px;height:64px}

/* ===================== AUTH ===================== */
#auth{position:fixed;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:18px;
  background:radial-gradient(1100px 650px at 70% -10%,#15314a,transparent),#0a1119}
.auth-card{position:relative;z-index:2;width:100%;max-width:370px;background:rgba(255,255,255,.96);
  border-radius:22px;padding:30px 26px;box-shadow:var(--shadow-lg)}
.brand{text-align:center;font-size:30px;font-weight:800;letter-spacing:4px;margin-top:14px;color:var(--blue)}
.brand-sub{text-align:center;color:var(--sub);font-size:13px;margin-bottom:18px}
.auth-card h3{font-size:18px;margin-bottom:16px}
.field{position:relative;margin-bottom:16px}
.field input,.field select{width:100%;padding:14px 12px 7px;border:1px solid var(--line2);border-radius:11px;
  background:#fff;outline:none;font-size:15px;transition:border-color .15s}
.field select{padding:13px 12px}
.field input:focus,.field select:focus{border-color:var(--blue)}
.field label{position:absolute;right:13px;top:13px;color:var(--sub);font-size:14px;pointer-events:none;
  transition:.15s;background:#fff;padding:0 3px}
.field input:focus+label,.field input:not(:placeholder-shown)+label{top:-8px;font-size:11px;color:var(--blue)}
.full-btn{width:100%;padding:13px;border:none;border-radius:11px;background:var(--blue);color:#fff;
  font-weight:700;font-size:15px;cursor:pointer;transition:background .15s}
.full-btn:hover{background:var(--blue-d)}
.full-btn.ghost{background:transparent;color:var(--blue);border:1px solid var(--line2)}
.auth-links{display:flex;justify-content:center;gap:16px;margin-top:14px}
.link{color:var(--blue);cursor:pointer;font-size:13px}
.err{color:var(--danger);font-size:13px;min-height:16px;margin:-6px 0 8px}

/* ===================== APP SHELL ===================== */
#app{position:fixed;inset:0;z-index:1;background:var(--bg)}
.panes{display:flex;height:100%}
.pane-list{display:flex;flex-direction:column;width:100%;height:100%;position:relative;background:#fff}
.pane-detail{display:none;flex-direction:column;flex:1;height:100%;background:var(--chat-green)}

/* mobile: detail slides over list */
@media(max-width:899px){
  .pane-detail{position:fixed;inset:0;z-index:20;transform:translateX(100%);transition:transform .26s ease;display:flex}
  body.detail-open .pane-detail{transform:none}
  #detailEmpty{display:none !important}
}
/* desktop: two panes */
@media(min-width:900px){
  .pane-list{width:400px;flex:none;border-left:1px solid var(--line2)}
  .pane-detail{display:flex}
  body.detail-open #detailEmpty{display:none}
  #detail:empty{display:none}
}

/* ===================== TOPBAR ===================== */
.topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--blue);color:#fff;display:flex;
  align-items:center;gap:6px;padding:0 6px;box-shadow:0 1px 4px rgba(0,0,0,.12);z-index:3}
.top-title{font-size:18px;font-weight:600;flex:1;padding:0 6px}
.list-top{padding:0 8px}
.list-search{flex:1;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.18);border-radius:20px;
  padding:0 14px;height:40px;margin:0 4px}
.list-search .search-ic{color:rgba(255,255,255,.85)}
.list-search input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:15px}
.list-search input::placeholder{color:rgba(255,255,255,.8)}

/* ===================== TABS ===================== */
.tabs{display:flex;background:var(--blue);box-shadow:0 2px 5px rgba(0,0,0,.1);z-index:2}
.tab{flex:1;text-align:center;padding:11px 0;color:rgba(255,255,255,.7);font-size:14px;font-weight:600;
  cursor:pointer;position:relative}
.tab.on{color:#fff}
.tab.on::after{content:"";position:absolute;bottom:0;left:18%;right:18%;height:3px;background:#fff;border-radius:3px 3px 0 0}

/* ===================== CHAT LIST ===================== */
.chat-list{flex:1;overflow-y:auto;background:#fff}
.empty-note{text-align:center;color:var(--sub);font-size:14px;padding:30px 16px}
.chat-row{display:flex;align-items:center;gap:13px;padding:9px 14px;cursor:pointer;transition:background .12s}
.chat-row:hover,.chat-row.active{background:var(--press)}
.chat-row .row-body{flex:1;min-width:0;border-bottom:1px solid var(--line);padding-bottom:9px;margin-top:9px;margin-bottom:-9px}
.chat-row:last-child .row-body{border-bottom:none}
.row-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.row-name{font-weight:600;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:5px}
.row-time{font-size:12px;color:var(--sub);flex:none}
.row-bottom{display:flex;align-items:center;gap:6px;margin-top:3px}
.row-last{flex:1;font-size:14px;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-mute{color:var(--badge-mut);display:flex}
.unread{background:var(--badge);color:#fff;font-size:12px;font-weight:700;min-width:22px;height:22px;border-radius:11px;
  display:inline-flex;align-items:center;justify-content:center;padding:0 6px;flex:none}
.unread.mut{background:var(--badge-mut)}
.sys-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);display:inline-block}

/* ===================== FAB ===================== */
.fab{position:absolute;bottom:20px;right:18px;width:56px;height:56px;border:none;border-radius:50%;
  background:var(--blue);color:#fff;box-shadow:var(--shadow-lg);cursor:pointer;display:flex;align-items:center;
  justify-content:center;z-index:6;transition:transform .2s,background .15s}
.fab:hover{background:var(--blue-d)}
.fab.open{transform:rotate(45deg)}
.fab-menu{position:absolute;bottom:86px;right:18px;background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);
  z-index:6;overflow:hidden;opacity:0;transform:translateY(12px) scale(.96);pointer-events:none;transition:.18s;min-width:190px}
.fab-menu.open{opacity:1;transform:none;pointer-events:auto}
.fab-item{display:flex;align-items:center;gap:13px;padding:13px 16px;font-size:14.5px;cursor:pointer;color:var(--ink)}
.fab-item:hover{background:var(--press)}
.fab-item .ic{color:var(--blue)}

/* ===================== SCREENS ===================== */
.detail{height:100%}
.detail.slide-fwd .screen{animation:slidefwd .26s ease}
.detail.slide-back .screen{animation:slideback .26s ease}
@keyframes slidefwd{from{transform:translateX(100%)}to{transform:none}}
@keyframes slideback{from{transform:translateX(-30%);opacity:.6}to{transform:none;opacity:1}}
.screen{height:100%;display:flex;flex-direction:column;background:#fff}
.detail-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#5a7a55}
.detail-empty p{background:rgba(255,255,255,.6);padding:7px 16px;border-radius:16px;font-size:14px}

/* ===================== CHAT SCREEN ===================== */
.chat-top .chat-id{flex:1;display:flex;align-items:center;gap:10px;cursor:pointer;min-width:0;padding:0 2px}
.chat-id-text{min-width:0}
.chat-title{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}
.chat-status{font-size:12.5px;color:rgba(255,255,255,.82)}
.msg-search{flex:1;background:rgba(255,255,255,.18);border:none;outline:none;color:#fff;height:38px;border-radius:19px;padding:0 16px;font-size:15px;margin:0 4px}
.msg-search::placeholder{color:rgba(255,255,255,.8)}

.chat-bg{flex:1;overflow-y:auto;padding:12px 0 6px;background-color:var(--chat-green);
  background-image:
    radial-gradient(circle at 12% 18%,rgba(255,255,255,.55) 0 1.5px,transparent 2.2px),
    radial-gradient(circle at 68% 34%,rgba(255,255,255,.4) 0 1.5px,transparent 2.2px),
    radial-gradient(circle at 38% 72%,rgba(255,255,255,.4) 0 1.5px,transparent 2.2px),
    radial-gradient(circle at 86% 82%,rgba(255,255,255,.5) 0 1.5px,transparent 2.2px),
    radial-gradient(circle at 50% 50%,rgba(110,160,100,.18) 0 2px,transparent 3px),
    radial-gradient(1000px 560px at 82% -5%,rgba(150,195,230,.3),transparent);
  background-size:170px 170px,210px 210px,150px 150px,190px 190px,150px 230px,100% 100%}
.messages{display:flex;flex-direction:column;gap:3px;padding:0 10px;min-height:100%;justify-content:flex-end}
.date-sep{align-self:center;margin:12px 0;background:rgba(58,90,64,.55);color:#fff;font-size:12px;
  padding:3px 13px;border-radius:13px;backdrop-filter:blur(2px)}

/* bubbles */
.msg{position:relative;max-width:76%;padding:6px 10px 4px;border-radius:12px;font-size:15px;line-height:1.5;
  box-shadow:0 1px 1px rgba(0,0,0,.08);animation:pop .14s ease;word-wrap:break-word}
@keyframes pop{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.msg.in{align-self:flex-start;background:var(--recv);border-top-right-radius:4px}
.msg.out{align-self:flex-end;background:var(--sent);border-top-left-radius:4px}
/* tails */
.msg.in::before{content:"";position:absolute;top:0;right:-7px;width:11px;height:14px;background:var(--recv);
  clip-path:path('M0,0 C3,6 6,11 11,14 L0,14 Z')}
.msg.out::before{content:"";position:absolute;top:0;left:-7px;width:11px;height:14px;background:var(--sent);
  clip-path:path('M11,0 C8,6 5,11 0,14 L11,14 Z')}
.msg-sender{font-size:13px;font-weight:700;margin-bottom:2px;cursor:pointer}
.msg-text{white-space:pre-wrap}
.msg-photo{max-width:100%;border-radius:9px;display:block;cursor:pointer;margin:-1px 0 2px}
.msg audio{max-width:220px;height:38px;margin:2px 0}
.msg-file{display:flex;align-items:center;gap:9px;color:inherit;text-decoration:none;padding:3px 0}
.msg-file .ic{color:var(--blue);flex:none}
.msg-file span{display:flex;flex-direction:column;min-width:0}
.msg-file b{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}
.msg-file i{font-size:12px;color:var(--sub);font-style:normal}
.msg-meta{display:flex;align-items:center;gap:3px;justify-content:flex-start;font-size:11px;color:#7a9183;margin-top:2px}
.msg.out .msg-meta{color:#6aa06a}
.checks{display:flex}.checks .ic{color:var(--check)}
.msg-del{position:absolute;top:3px;left:4px;border:none;background:transparent;color:#9bb09e;cursor:pointer;
  opacity:0;transition:opacity .12s;padding:2px;border-radius:5px}
.msg:hover .msg-del{opacity:.7}
.msg-del:hover{opacity:1;background:rgba(0,0,0,.06)}
.typing-line{min-height:16px;padding:1px 22px;font-size:12.5px;color:#3f7a3f}

/* composer */
.composer{display:flex;align-items:center;gap:4px;padding:7px 8px;background:#fff;border-top:1px solid var(--line2)}
.composer .ico-btn{color:var(--sub)}
.composer .ico-btn:hover{background:var(--press)}
.comp-input{flex:1;border:none;outline:none;background:transparent;font-size:16px;padding:10px 8px}
.send-btn{width:46px;height:46px;border:none;border-radius:50%;background:var(--blue);color:#fff;display:none;
  align-items:center;justify-content:center;cursor:pointer;flex:none;transition:background .15s}
.send-btn:hover{background:var(--blue-d)}
.composer.has-text #voiceBtn{display:none}
.composer.has-text .send-btn{display:inline-flex}
.comp-mic.rec{color:var(--danger)!important;animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.composer-locked{padding:16px;text-align:center;color:var(--sub);background:#fff;border-top:1px solid var(--line2);font-size:14px}

/* ===================== PROFILE / SETTINGS ===================== */
.profile-screen .topbar,.edit-screen .topbar{gap:4px}
.profile-scroll,.edit-scroll{flex:1;overflow-y:auto;background:#f1f4f6}
.profile-head{background:#fff;padding:24px 16px 20px;text-align:center;border-bottom:1px solid var(--line2)}
.profile-head .avatar{margin:0 auto 12px}
.profile-name{font-size:21px;font-weight:700}
.profile-status{font-size:14px;color:var(--blue);margin-top:3px}
.info-block{background:#fff;margin-top:10px;border-top:1px solid var(--line2);border-bottom:1px solid var(--line2)}
.info-row{padding:13px 18px;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:none}
.info-row.col{display:block}
.info-k{font-size:12.5px;color:var(--blue);margin-bottom:3px}
.info-v{font-size:15.5px;word-break:break-word}
.bio-edit{width:100%;border:1px solid var(--line2);border-radius:10px;padding:10px;font-size:15px;outline:none;resize:vertical;margin-top:4px}
.bio-edit:focus{border-color:var(--blue)}
.text-btn{background:transparent;border:none;color:var(--blue);font-weight:700;font-size:14px;cursor:pointer;padding:8px 0 2px}
.invite-box input{width:100%;border:1px solid var(--line2);border-radius:9px;padding:9px;font-size:13px;background:#f7f9fa;outline:none;direction:ltr;text-align:left}

/* media tabs + grid */
.media-tabs{display:flex;background:#fff;margin-top:10px;border-bottom:1px solid var(--line2);position:sticky;top:0;z-index:1}
.mtab{flex:1;text-align:center;padding:13px 0;font-size:14px;font-weight:600;color:var(--sub);cursor:pointer;position:relative}
.mtab.on{color:var(--blue)}
.mtab.on::after{content:"";position:absolute;bottom:0;left:15%;right:15%;height:3px;background:var(--blue);border-radius:3px 3px 0 0}
.media-area{background:#fff;min-height:120px}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding:2px}
.media-cell{aspect-ratio:1;background-size:cover;background-position:center;cursor:pointer;background-color:#dde4e8}
.media-list-row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line)}
.media-list-row .ic{color:var(--blue);flex:none}
.media-list-row audio{height:34px}
.media-list-row a{color:var(--blue);word-break:break-all;font-size:14px}
.section-label{padding:14px 18px 6px;color:var(--blue);font-size:13px;font-weight:600;background:#f1f4f6}
.members{background:#fff;border-top:1px solid var(--line2)}
.member-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 16px;border-bottom:1px solid var(--line)}
.member-row:last-child{border-bottom:none}
.mr-id{display:flex;align-items:center;gap:10px;cursor:pointer;min-width:0}
.mr-id>span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.role{font-size:10px;font-weight:700;padding:1px 6px;border-radius:6px;margin-right:4px}
.role.owner{background:#eaf3fb;color:var(--blue)}
.role.admin{background:#e8f6ed;color:#3a9d57}
.mini{border:1px solid var(--line2);background:#fff;border-radius:8px;padding:5px 9px;font-size:12px;cursor:pointer;color:var(--blue);margin-right:5px}
.mini.danger{color:var(--danger);border-color:#f3c7cc}

/* ===================== EDIT / NEW screens ===================== */
.edit-scroll{padding:22px 18px}
.big-photo{width:120px;height:120px;border-radius:50%;margin:0 auto 22px;position:relative;cursor:pointer;
  background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;color:#fff}
.bp-initials{font-size:46px;font-weight:600}
.bp-cam{position:absolute;right:2px;bottom:2px;width:38px;height:38px;border-radius:50%;background:var(--blue);
  display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.25)}
.float-field{position:relative;margin-bottom:20px}
.float-field input{width:100%;border:none;border-bottom:2px solid var(--line2);padding:9px 2px;font-size:16px;outline:none;background:transparent}
.float-field input:focus{border-color:var(--blue)}
.float-field label{position:absolute;right:2px;top:9px;color:var(--sub);pointer-events:none;transition:.15s}
.float-field input:focus+label,.float-field input:not(:placeholder-shown)+label{top:-12px;font-size:12px;color:var(--blue)}
.hint{font-size:12.5px;color:var(--sub);text-align:center;margin-top:6px}
.nc-results{flex:1;overflow-y:auto;background:#fff}

/* ===================== DRAWER ===================== */
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .2s;z-index:39}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;bottom:0;left:0;width:288px;max-width:84vw;background:#fff;z-index:40;
  transform:translateX(-100%);transition:transform .26s ease;box-shadow:var(--shadow-lg);overflow-y:auto}
.drawer.open{transform:none}
.drawer-head{background:linear-gradient(135deg,#3d8fd1,#2f6f8f);color:#fff;padding:22px 18px 16px}
.drawer-head .avatar{margin-bottom:10px}
.dh-name{font-size:17px;font-weight:700}
.dh-user{font-size:13px;opacity:.85}
.drawer-list{padding:8px}
.drawer-item{display:flex;align-items:center;gap:16px;padding:13px 14px;border-radius:10px;cursor:pointer;font-size:15px}
.drawer-item:hover{background:var(--press)}
.drawer-item .di-ic,.drawer-item .avatar{color:var(--sub)}
.drawer-item .di-ic{display:flex}
.drawer-item.danger{color:var(--danger)}
.drawer-item.danger .di-ic{color:var(--danger)}

/* ===================== BOTTOM SHEET ===================== */
#sheetRoot .scrim{z-index:49}
.bottom-sheet{position:fixed;left:0;right:0;bottom:0;z-index:50;background:#fff;border-radius:18px 18px 0 0;
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -4px 24px rgba(0,0,0,.2);
  transform:translateY(100%);animation:sheetup .26s ease forwards;max-width:520px;margin:0 auto}
@keyframes sheetup{to{transform:none}}
.sheet-title{padding:12px 16px 8px;color:var(--sub);font-size:13px}
.sheet-item{display:flex;align-items:center;gap:14px;padding:14px 16px;font-size:15.5px;cursor:pointer;border-radius:10px}
.sheet-item:hover{background:var(--press)}
.sheet-item .ic{color:var(--blue);flex:none}
.sheet-item.danger{color:var(--danger)}
.sheet-item.danger .ic{color:var(--danger)}
.sheet-item.cancel{justify-content:center;color:var(--sub)}
.sheet-grid{display:flex;gap:10px;padding:16px}
.sheet-item-wrap{flex:1}
.sheet-grid .sheet-item{flex-direction:column;flex:1;gap:8px;font-size:13px}
.si-ic{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}
.si-ic.green{background:#5fb85f}.si-ic.blue{background:var(--blue)}
.invite-box{padding:6px 16px}

/* ===================== POPUP (3-dot) ===================== */
#modalRoot .scrim{z-index:54;background:rgba(0,0,0,.2)}
.popup-menu{position:fixed;top:50px;left:8px;z-index:55;background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);
  overflow:hidden;min-width:200px;opacity:0;transform:scale(.95);transform-origin:top left;animation:popin .15s ease forwards}
@keyframes popin{to{opacity:1;transform:none}}
.pop-item{display:flex;align-items:center;gap:14px;padding:13px 16px;font-size:14.5px;cursor:pointer}
.pop-item:hover{background:var(--press)}
.pop-item .ic{color:var(--sub)}
.pop-item.danger{color:var(--danger)}
.pop-item.danger .ic{color:var(--danger)}

/* ===================== CENTER MODAL (admin) ===================== */
.center-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:55;background:#fff;border-radius:16px;
  width:calc(100% - 36px);max-width:440px;max-height:84vh;overflow-y:auto;padding:22px;box-shadow:var(--shadow-lg)}
.modal-x{position:absolute;top:12px;left:14px;background:transparent;border:none;font-size:24px;color:var(--sub);cursor:pointer}
.modal-head{font-size:18px;font-weight:700;margin-bottom:14px}
.stat-row{display:flex;justify-content:space-between;padding:9px 2px;border-bottom:1px solid var(--line);font-size:15px}
.center-modal .full-btn{margin-top:8px}

/* ===================== TOAST ===================== */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:80;background:rgba(30,45,55,.95);
  color:#fff;padding:11px 20px;border-radius:22px;font-size:14px;opacity:0;pointer-events:none;transition:.22s;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%)}

/* desktop niceties */
@media(min-width:900px){
  .fab{right:18px}
  .bottom-sheet{right:auto;left:50%;transform:translateX(-50%) translateY(100%);animation:sheetup-d .26s ease forwards}
  @keyframes sheetup-d{to{transform:translateX(-50%)}}
  .popup-menu{left:auto;right:8px;transform-origin:top right}
}
