/* ============================================================
   TREDEDO — shared app shell (dashboard / bots / profile / etc)
   ============================================================ */
.app{display:grid;grid-template-columns:264px 1fr;min-height:100vh;position:relative;z-index:2}

/* sidebar — first column in RTL = visual right */
.side{grid-column:1;position:sticky;top:0;height:100vh;border-left:1px solid var(--line);
  background:rgba(7,14,29,.6);backdrop-filter:blur(16px);padding:26px 20px;display:flex;flex-direction:column;gap:6px}
.side .brand{margin-bottom:16px;height:auto;justify-content:flex-start;padding:0}
.side .brand-logo{height:34px;max-width:160px;width:auto;object-fit:contain}
@media (max-width:1400px){.side .brand-logo{height:30px;max-width:140px}}
@media (max-width:1280px){.side .brand-logo{height:28px;max-width:130px}.side .brand{margin-bottom:14px}}
@media (max-width:1180px){.side .brand-logo{height:26px;max-width:120px}}
.nav-item{display:flex;align-items:center;gap:14px;padding:13px 16px;border-radius:12px;
  font-size:15px;font-weight:600;color:var(--ink-mute);transition:.2s;cursor:pointer}
.nav-item .ni{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-size:17px}
.nav-item .ni svg{width:100%;height:100%;display:block;stroke:currentColor;stroke-width:1.8;fill:none}
.nav-item.active .ni svg,.nav-item:hover .ni svg{filter:drop-shadow(0 0 6px rgba(245,196,81,.35))}
.nav-item:hover{color:var(--ink);background:rgba(120,180,255,.05)}
.nav-item.active{color:var(--cyan);background:rgba(92,240,255,.08);box-shadow:inset 0 0 0 1px rgba(92,240,255,.2)}
.side-foot{margin-top:auto;padding-top:20px;border-top:1px solid var(--line)}
.user{display:flex;align-items:center;gap:12px;transition:.2s}
.user:hover{opacity:.85}
.avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--cyan),var(--blue));
  display:grid;place-items:center;color:#04121f;font-weight:800;font-size:16px}
.nav-logout{display:none}

/* main + topbar */
.main{grid-column:2;padding:26px 30px;min-width:0;min-height:100vh}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.topbar h1{font-size:26px}
.topbar .sub{color:var(--ink-mute);font-size:14px;margin-top:2px}
.tb-actions{display:flex;gap:12px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:999px;font-size:13.5px;
  font-weight:700;background:rgba(52,224,161,.1);border:1px solid rgba(52,224,161,.25);color:var(--up)}

/* section title divider */
.sec-title{display:flex;align-items:center;gap:14px;margin:30px 0 16px}
.sec-title h2{font-size:19px}
.sec-title .ln{flex:1;height:1px;background:var(--line)}
.sec-title .kicker{margin:0}

/* panels */
.panel{padding:24px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.panel-head h3{font-size:18px}

/* modal */
.modal-bg{position:fixed;inset:0;z-index:100;background:rgba(3,7,16,.7);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.show{display:flex}
.modal{width:100%;max-width:440px;padding:30px;position:relative}
.modal h3{font-size:22px;margin-bottom:6px}
.modal .ms{color:var(--ink-mute);font-size:14px;margin-bottom:22px}
.amt-row{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:18px}
.amt-chip{padding:9px 16px;border-radius:10px;border:1px solid var(--line);background:rgba(255,255,255,.02);
  font-family:var(--mono);font-weight:700;font-size:14px;cursor:pointer;transition:.2s;color:var(--ink-soft)}
.amt-chip:hover,.amt-chip.active{border-color:var(--cyan);color:var(--cyan);background:rgba(92,240,255,.08)}
.modal label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:8px}
.modal .ipw{position:relative;margin-bottom:20px}
.modal .ipw .cur{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--ink-mute);font-family:var(--mono);font-weight:700}
.modal input{width:100%;padding:15px 38px 15px 16px;border-radius:12px;background:rgba(255,255,255,.03);
  border:1px solid var(--line);color:var(--ink);font-size:18px;font-family:var(--mono);font-weight:700;outline:none}
.modal input:focus{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(92,240,255,.08)}
.modal .x{position:absolute;top:20px;left:24px;cursor:pointer;color:var(--ink-mute);font-size:20px}
.modal-foot{font-size:12px;color:var(--ink-faint);margin-top:16px;text-align:center}

/* toast */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);z-index:120;
  background:rgba(10,20,40,.92);border:1px solid rgba(92,240,255,.3);backdrop-filter:blur(14px);
  padding:14px 22px;border-radius:14px;font-size:14px;font-weight:600;color:var(--ink);
  box-shadow:0 20px 50px -10px rgba(0,0,0,.6);opacity:0;pointer-events:none;transition:.35s;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast b{color:var(--cyan)}
.toast.success{border-color:rgba(52,224,161,.45);background:rgba(8,30,22,.95)}
.toast.success b,.toast.success{color:var(--up)}
.toast.error{border-color:rgba(255,92,122,.5);background:rgba(38,8,16,.95)}
.toast.error b,.toast.error{color:var(--down)}

/* ============================================================
   MOBILE / TABLET (≤1100px) — collapse layout to single column
   ============================================================ */
@media (max-width:1100px){
  .app{grid-template-columns:1fr;z-index:auto}
  .side,.main{grid-column:auto}
  .main{padding:20px 16px 110px}
}

/* ============================================================
   MOBILE (≤560px) — compact app shell + per-page grids
   ============================================================ */
@media (max-width:560px){
  html,body{overflow-x:hidden;max-width:100vw}
  .app,.main{max-width:100vw;overflow-x:hidden}
  .main{padding:16px 12px 110px}

  .topbar{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:16px}
  .topbar>div:first-child{width:100%}
  .topbar h1{font-size:20px}
  .topbar .sub{font-size:12.5px}
  .tb-actions{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:6px}
  .tb-actions .btn,.tb-actions .pill,.tb-actions .icon-toggle{
    font-size:11.5px !important;padding:7px 10px !important;white-space:nowrap}
  .tb-actions .icon-toggle{width:34px;height:34px;padding:0 !important}
  .pill{font-size:11.5px !important}

  .sec-title{margin:22px 0 12px;gap:10px}
  .sec-title h2{font-size:16px}
  .panel{padding:16px;border-radius:18px}
  .panel-head h3{font-size:16px}
  .panel,.glass{max-width:100%;overflow:hidden}
  img,canvas,svg,video{max-width:100%;height:auto}

  /* dashboard */
  .kpis{grid-template-columns:1fr 1fr !important;gap:10px !important}
  .kpi{padding:14px !important}
  .kpi .v{font-size:22px !important}
  .kpi .ks{height:26px !important}
  .grid-2,.grid-3{grid-template-columns:1fr !important;gap:12px !important}
  .bots{grid-template-columns:1fr !important}
  .equity-chart{height:220px !important}
  .donut-row{flex-direction:column;gap:14px;align-items:stretch}
  .donut-c{width:110px;height:110px;margin:0 auto}
  .gauge-c{height:80px}
  .tabs{flex-wrap:wrap}
  .tab{padding:6px 10px;font-size:12px}
  .sym-cell{gap:8px;font-size:12.5px}
  .sym-badge{width:28px;height:28px;font-size:11px}

  /* bots */
  .split{grid-template-columns:1fr !important;gap:12px !important}
  .ec-stats{grid-template-columns:1fr 1fr 1fr !important;gap:6px !important}
  .pp-cards{grid-template-columns:1fr 1fr !important;gap:10px !important}
  .combined-grid{grid-template-columns:1fr !important}

  /* reports */
  .sum-grid{grid-template-columns:1fr 1fr !important;gap:10px !important}
  .tbl{font-size:12px}
  .tbl th,.tbl td{padding:8px 6px !important}
  .tbl th:nth-child(4),.tbl td:nth-child(4),
  .tbl th:nth-child(5),.tbl td:nth-child(5){display:none}

  /* profile */
  .id-grid,.fin-grid{grid-template-columns:1fr !important;gap:12px !important}
  .lp-tiers{overflow-x:auto;gap:12px;-webkit-overflow-scrolling:touch}
  .srow{flex-wrap:wrap;gap:10px !important}
  .v,.bv,.n,.roi-v{font-size:clamp(20px,6vw,28px) !important}
  table,.tbl-wrap{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* modals → bottom sheet on mobile */
  .modal-bg{align-items:flex-end;padding:0}
  .modal{padding:22px 18px 24px;border-radius:22px 22px 0 0;max-width:100vw;width:100%;
    max-height:92vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .modal h3{font-size:19px}
  .modal input{font-size:16px;padding:13px 34px 13px 14px}
  .modal .x{top:14px;left:16px;font-size:22px;padding:6px 10px}
  .amt-row{gap:7px;margin-bottom:14px}
  .amt-chip{padding:8px 12px;font-size:13px}
  .toast{font-size:13px;padding:11px 16px;bottom:90px;left:12px;right:12px;
    transform:translateY(20px);max-width:none;width:auto}
  .toast.show{transform:translateY(0)}
}

@media (max-width:380px){
  .topbar h1{font-size:18px}
  .tb-actions .btn,.tb-actions .pill{font-size:10.5px !important;padding:6px 8px !important}
}

/* ============================================================
   MOBILE — Floating pill bottom navigation (SINGLE SOURCE OF TRUTH)
   All `.side` / `.nav-item` mobile styling lives in this block only.
   Do not redefine these selectors elsewhere (page-level <style>, etc.)
   ============================================================ */
@media (max-width:1100px){
  .side{
    position:fixed !important;
    left:12px !important;right:12px !important;
    bottom:calc(14px + env(safe-area-inset-bottom)) !important;
    top:auto !important;
    width:auto !important;max-width:560px !important;margin:0 auto !important;
    height:auto !important;
    display:flex !important;flex-direction:row !important;
    justify-content:space-around !important;align-items:center !important;
    gap:0 !important;padding:10px 8px !important;
    border:1px solid rgba(255,255,255,.08) !important;
    border-radius:999px !important;
    background:rgba(10,16,30,.78) !important;
    backdrop-filter:blur(18px) saturate(140%) !important;
    -webkit-backdrop-filter:blur(18px) saturate(140%) !important;
    box-shadow:0 18px 50px -12px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.03) !important;
    overflow:visible !important;
    z-index:9999 !important;
    pointer-events:auto !important;
    order:initial !important;
    box-sizing:border-box;
  }
  .side .brand,.side-foot{display:none !important}
  .nav-item{
    flex:1 !important;display:flex !important;
    flex-direction:column !important;justify-content:center !important;align-items:center !important;
    gap:4px !important;padding:6px 4px !important;
    border-radius:14px !important;background:transparent !important;box-shadow:none !important;
    color:rgba(220,228,245,.55) !important;
    font-size:10.5px !important;font-weight:700 !important;
    letter-spacing:0 !important;line-height:1.25 !important;
    text-transform:none !important;white-space:normal !important;text-align:center !important;
    min-width:0 !important;
    cursor:pointer;pointer-events:auto;
    -webkit-tap-highlight-color:rgba(245,196,81,.2);
    transition:.2s;
  }
  .nav-item .ni{
    width:24px;height:24px;line-height:1;
    display:inline-flex;align-items:center;justify-content:center;color:inherit;transition:.2s;
  }
  .nav-item .ni svg{width:24px;height:24px;stroke-width:1.9}
  .nav-item:hover{color:rgba(245,196,81,.85) !important}
  .nav-item.active{color:#f5c451 !important;background:transparent !important;box-shadow:none !important}
  .nav-item.active .ni{color:#f5c451}
  .nav-item.active .ni svg{filter:drop-shadow(0 0 8px rgba(245,196,81,.55));stroke-width:2.1}
  .nav-logout{color:rgba(255,120,140,.7) !important;display:flex !important}
}

/* fine-tune sizing on small phones — keep pill shape, only adjust spacing */
@media (max-width:560px){
  .side{left:10px !important;right:10px !important;padding:9px 6px 8px !important}
  .nav-item{font-size:9.5px !important;padding:5px 2px !important;gap:3px !important}
  .nav-item .ni,.nav-item .ni svg{width:22px;height:22px}
}
@media (max-width:380px){
  .nav-item{font-size:8.8px !important;line-height:1.2 !important}
  .nav-item .ni,.nav-item .ni svg{width:20px;height:20px}
}

/* button loading spinner */
.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.22);border-top-color:rgba(255,255,255,.95);border-radius:50%;animation:btn-spin .7s linear infinite;vertical-align:middle}
@keyframes btn-spin{to{transform:rotate(360deg)}}
.btn-loading{display:inline-flex;align-items:center;gap:8px}
