    :root{
      --bg:#EAE9E4;
      --panel:#ffffff;
      --panel2:#ffffff;
      --line:rgba(62,61,86,.22);
      --text:#262638;
      --muted:#7A7888;
      --good:#9BC39A;
      --warn:#DDC9C4;
      --bad:#D96B6B;
      --accent:#2A2737;
      --accent2:#3F3C57;
      --chip:#ECE9E2;
      --shadow: 0 10px 22px rgba(27,27,46,.10);
      --radius:18px;
      --radiusSm:14px;
      --radiusXs:12px;
      --font:'Manrope', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    }
    *{box-sizing:border-box}
    body{
      margin:0;
      font-family: var(--font);
      background: var(--bg);
      color: var(--text);
      position:relative;
      isolation:isolate;
    }
    .wrap{max-width:1840px;margin:0 auto;padding:16px}
    body > .wrap{position:relative;z-index:1}
    .topbar{
      position: sticky; top:0; z-index:30;
      background: var(--accent2);
      border-bottom: 1px solid rgba(255,255,255,.08);
      color:#fff;
    }
    .topbar .btn{
      background: rgba(255,255,255,.14);
      border-color: rgba(255,255,255,.18);
      color:#fff;
    }

    .input{
      width:100%;
      height:40px;
      border-radius: 12px;
      border: 1px solid rgba(44,43,59,.35);
      background: rgba(255,255,255,.55);
      padding: 0 12px;
      outline: none;
      font-family: inherit;
      font-size: 14px;
      color: rgba(20,20,30,.9);
    }
    .input:focus{
      border-color: rgba(44,43,59,.7);
      box-shadow: 0 0 0 3px rgba(44,43,59,.12);
    }
    .modalCard.modalWide{ width: min(980px, calc(100vw - 32px)); }
    .modalCard.modalSmall{ width: min(460px, calc(100vw - 32px)); }
    .modalTitle{ font-weight:800; letter-spacing:.5px; text-transform:uppercase; }
    .iconBtn{
      width:36px; height:36px;
      border-radius: 12px;
      border: 1px solid rgba(255,255,255,.22);
      background: rgba(255,255,255,.10);
      color:#fff;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      cursor:pointer;
      font-size: 20px;
      line-height: 1;
    }
    .btnRow{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

    .detailsBtn{
      background: var(--accent2);
      border:1px solid rgba(255,255,255,.0);
      color:#fff;
      border-radius: 999px;
      padding: 7px 12px;
      font-weight:700;
      font-size:12px;
      line-height:1;
      box-shadow: 0 10px 18px rgba(27,27,46,.14);
    }
    .detailsBtn:hover{filter:brightness(1.05)}

    .topbar .btn:hover{filter: brightness(1.06)}
    .topbar .search::placeholder{color: rgba(255,255,255,.65)}
    .topbar .pill{
      background: rgba(255,255,255,.14);
      border-color: rgba(255,255,255,.18);
      color: rgba(255,255,255,.9);
    }
    .topbar .muted{color: rgba(255,255,255,.72)}

    .topbar .wrap{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
    .brand{
      display:flex;align-items:center;gap:12px;
      min-width:220px;
    }
    .brand .titles{display:flex;flex-direction:column;gap:2px}
    .brand .t{font-weight:900;letter-spacing:.3px;font-size:16px;line-height:1.1;color:#fff}
    .logo{
      width:32px;
      height:32px;
      display:block;
      background-image:url('https://drive.google.com/thumbnail?id=1L3FmdWi0s_zZjzYJmFBd9IBy6NC0nFJ_&sz=w200');
      background-size:contain;
      background-position:center;
      background-repeat:no-repeat;
      border:0;
      box-shadow:none;
      background-color:transparent;
      flex: 0 0 auto;
    }
    .brand{
      display:flex;align-items:center;gap:12px;
      min-width: 56px;
    }
    .brand .t{display:none}

    .spacer{flex:1}
    .pill{
      display:inline-flex;align-items:center;gap:8px;
      border:1px solid var(--line);
      background: var(--chip);
      padding:8px 10px;border-radius:999px;
      color:var(--muted); font-size:12px;
      font-weight:600;
    }
    .search{
      flex: 1;
      min-width: 260px;
      height: 36px;
      border:1px solid rgba(255,255,255,.18);
      background: var(--accent2);
      color: #fff;
      padding: 8px 12px 8px 36px;
      border-radius: 10px;
      outline: none;
      font-weight: 500;
      letter-spacing: .1px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: 12px 50%;
      background-size: 14px 14px;
    }
    .grid{
      display:grid;
      grid-template-columns: 1fr;
      gap: 14px;
      margin-top: 14px;
    }
    .kpis{
      display:grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 12px;
    }
    .card{
      background: var(--panel);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 14px;
    }
    .kpi{
      display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
    }
    .kpi .n{font-size:22px;font-weight:900;line-height:1}
    .kpi .l{color:var(--muted);font-size:12px;margin-top:6px}
    .badge{
      font-size:12px;
      font-weight:600;
      border-radius:999px;
      padding:6px 12px;
      border:0;
      background:#D1D3E0;
      color:#262638;
      white-space:nowrap;
    }
    .badge.good{background:#9BC39A;color:#ffffff;font-weight:700}
    .badge.warn{background:#DDC9C4;color:#262638;font-weight:700}
    .badge.bad{background:#D96B6B;color:#ffffff;font-weight:700}
    .badge.info{background:#A9CFDE;color:#262638;font-weight:700}

    .badge.contacts{background:#D1D3E0;color:#262638;font-weight:700}
    .badge.media{background:#DDC9C4;color:#262638;font-weight:700}
    .badge.contracts{background:#A9CFDE;color:#262638;font-weight:700}
    .badge.spo{background:#9BC39A;color:#ffffff;font-weight:800}

    .chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:12px}
    .chip{display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius:999px; border:1px solid rgba(62,61,86,.55); background: transparent; color: var(--text); font-size:12px}
    .chip .x{opacity:.7; font-weight:900; cursor:pointer}
    .chip .x:hover{opacity:1}
    .yearPill{
      display:inline-flex;
      align-items:center;
      gap:6px;
      padding:5px 10px;
      border-radius:999px;
      border:0;
      background:#ffffff;
      color:#262638;
      font-size:12px;
      font-weight:700;
      box-shadow: 0 8px 18px rgba(27,27,46,.10);
    }
    .yearPill:hover{background: rgba(46,46,64,.14)}
    .yearPill.on{border-color: rgba(168,207,224,.55); background: rgba(168,207,224,.10)}
    .kv{display:flex; flex-direction:column; gap:6px; margin-top:8px}
    .kvRow{display:flex; gap:10px; flex-wrap:wrap}
    .kvKey{color: var(--muted); min-width:140px}
    .incentItem{padding:10px 0; border-top:1px solid rgba(46,46,64,.14)}
    .incentTop{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
    .incentTitle{font-weight:800}

    .badgeRow{display:flex; flex-wrap:wrap; gap:6px;}
    .twocol{
      display:grid;grid-template-columns: 1fr; gap: 14px;
    }
.chartsGrid{
      display:grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
      align-items:stretch;
    }
    .chartsGrid > .card{display:flex; flex-direction:column; height:100%;}
    .chartsToggle{display:block; margin-top:14px;}
    .chartsToggle .title{margin:0;}
    .chartsToggleHint{color: var(--muted); font-size:13px; display:flex; align-items:center; gap:6px; font-weight:700;}
    .chartsToggleHint .chev{display:inline-block; transition: transform .18s ease;}
    #chartsToggle[aria-expanded="true"] .chartsToggleHint .chev{transform: rotate(180deg);}
    .chartsGrid.isCollapsed{display:none;}

#chartsToggle, #chartsToggle *{
  cursor: pointer !important;
  -webkit-user-select: none;
  user-select: none;
}


    @media (max-width: 1200px){
      .chartsGrid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }
    @media (max-width: 760px){
      .chartsGrid{ grid-template-columns: 1fr; }
    }
    .chartBox.scrollY{
      max-height: 520px;
      overflow: auto;
      padding: 6px 6px 6px 0;
      display:block;
    }
    .chartBox.tall{height: 260px;}
    .title{
      font-size:13px; color: var(--muted);
      font-weight:800; letter-spacing:.08em;
      text-transform: uppercase;
      margin: 0 0 10px 0;
    }
    .hint{
      font-size:12px;
      color: var(--muted);
      opacity:.9;
      margin: -4px 0 10px 0;
      display:flex;
      align-items:center;
      gap:8px;
      user-select:none;
    }
    .hint:before{
      content:'ⓘ';
      color: var(--accent);
      font-weight:800;
    }

    .chartBox{height:260px; display:flex; align-items:center; justify-content:center; flex:1 1 auto; min-width:0;}
    .chartBox > canvas{display:block;}
    #pie{max-width:220px!important; max-height:220px!important; width:220px!important; height:220px!important}
    #bar, #spo, #market, #transfer{width:100%!important; height:100%!important}

    .listBars{width:100%; display:flex; flex-direction:column; gap:8px; padding:6px 0 2px;}
    .listRow{
      display:flex; align-items:center; gap:10px;
      padding:6px 8px;
      border-radius:12px;
      border:1px solid rgba(46,46,64,.14);
      background: rgba(255,255,255,.55);
      cursor:pointer;
      user-select:none;
    }
    .listRow:hover{background: rgba(255,255,255,.055);}
    .listRow.active{
      border-color: rgba(168,207,224,.55);
      background: rgba(168,207,224,.085);
      box-shadow: 0 0 0 1px rgba(168,207,224,.18) inset;
    }
    .listLabel{
      flex: 0 0 170px;
      max-width: 170px;
      font-size: 12px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .listBarTrack{
      flex: 1;
      height: 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.07);
      overflow: hidden;
    }
    .listBarFill{height:100%; border-radius:999px; background: rgba(62,61,86,.92);}
    .listValue{width:38px; text-align:right; font-size:12px; color: var(--muted);}
    .tableWrap{overflow:auto;border-radius: var(--radius); border:1px solid var(--line)}
    table{width:100%; border-collapse:collapse; min-width:1320px; background: var(--panel)}
    th,td{padding:10px 12px; border-bottom:1px solid var(--line); font-size:13px; text-align:left; vertical-align:top; color: var(--text)}
    th{position:sticky; top:0; background: var(--accent); z-index:2; color: rgba(255,255,255,.86); font-size:12px; letter-spacing:.08em; text-transform:uppercase}
    th:last-child, td:last-child{width:130px; min-width:130px; text-align:right; white-space:nowrap}
    td:last-child{position:sticky; right:0; background: var(--panel)}
    tr:hover td:last-child{background: #f7f5ef}
    tr:hover td{background: #f7f5ef}
    tr.closed td{opacity:.55}
    tr.closed td:nth-child(2) b{text-decoration: line-through}
    .dot{display:inline-block;width:8px;height:8px;border-radius:99px;margin-right:8px;vertical-align:middle}

    .loadingOverlay{
      position:fixed; inset:0; z-index:50;
      display:none;
      align-items:center; justify-content:center;
      background: rgba(19,22,34,.62);
      backdrop-filter: blur(7px) saturate(1.05);
    }
    .loadingOverlay.show{display:flex;}
    .waveLoaderHost{--loader-size:84px;width:var(--loader-size);height:var(--loader-size);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;position:relative;border-radius:999px;background:transparent;overflow:visible;}
    .loadingOverlay .waveLoaderHost::before{display:none;}
    .waveLoaderHost.sm{--loader-size:22px;}
    .waveLoaderHost.md{--loader-size:44px;}
    .waveLoaderHost.lg{--loader-size:96px;}
    .waveLoaderFrame{width:100%;height:100%;border:0;display:block;background:transparent;border-radius:inherit;pointer-events:none;filter:none;color-scheme:light;background-color:transparent;}
    .loadingOverlay .waveLoaderFrame{filter:none;}
    .loadingShell{min-width:188px;min-height:188px;padding:20px;border-radius:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;box-shadow:none;backdrop-filter:none;}
    .sideLoading .waveLoaderHost{--loader-size:64px;}
    .inlineLoading{display:flex;align-items:center;gap:10px;margin-top:6px;}
    .inlineLoading .muted{font-size:12px;}
    .dot.good{background: var(--good)}
    .dot.warn{background: var(--warn)}
    .dot.bad{background: var(--bad)}
    .btn{
      border:1px solid var(--line);
      background: var(--chip);
      color: var(--text);
      padding: 9px 12px;
      border-radius: 999px;
      cursor:pointer;
      font-size: 13px;
      font-weight: 600;
    }
    .btn:hover{filter: brightness(.98)}
    .btn.primary{background: var(--accent); border-color: rgba(0,0,0,0); color:#fff}
    .btn.primary:hover{filter: brightness(1.03)}
    .btn.ghost{background: transparent}
    .btn.ghost:hover{background: rgba(61,61,88,.08)}
    .btn:active{transform: translateY(1px)}
    
    .backdrop{
      position:fixed;
      inset:0;
      background: rgba(0,0,0,.45);
      backdrop-filter: blur(2px);
      opacity:0;
      pointer-events:none;
      transition: opacity .18s ease;
      z-index:49;
    }
    .backdrop.show{opacity:1; pointer-events:auto;}
.side{
      position: fixed;
      top: 12px; right: 12px;
      width: min(760px, calc(100% - 24px));
      height: calc(100% - 24px);
      background: #f1efe9;
      border: 1px solid rgba(62,61,86,.22);
      border-radius: 30px;
      box-shadow: 0 28px 80px rgba(0,0,0,.28);
      transform: translateX(110%);
      transition: transform .18s ease;
      z-index: 50;
      display:flex; flex-direction:column;
      overflow:hidden;
    }
    .side.open{transform: translateX(0)}
    .sideHeader{
      padding: 22px 22px 18px;
      background: var(--accent2);
      color: #fff;
      border-bottom: 0;
      display:flex; align-items:flex-start; gap:12px;
    }
    .sideHeader .h{
      flex:1;
    }
    .sideHeader .h .name{font-weight:600; letter-spacing:.14em; text-transform:uppercase; font-size:22px}
    .sideHeader .h .sub{font-size:12px;color:rgba(255,255,255,.78);margin-top:6px}
    .close{
      width:38px;height:38px;border-radius:16px;
      display:grid;place-items:center;
      border:1px solid rgba(255,255,255,.22);
      background: rgba(255,255,255,.10);
      color:#fff;
      cursor:pointer;
    }
    .close:hover{background: rgba(255,255,255,.16)}
    .sideBody{padding:0; overflow:auto; background: var(--bg); overscroll-behavior: contain; -webkit-overflow-scrolling: touch;}
    body.detailsOpen{ overflow:hidden !important; }
    #sideBody .tabs{position:sticky; top:0; z-index:6; margin:0; padding:14px 22px 10px; background: var(--bg); border-bottom:1px solid rgba(28,29,37,.12);} 
    #sideBody .tabPanes{padding:0;} 
    #sideBody .pane{padding:18px 22px 22px;}

    .tabs{
      position: sticky; top: 0; z-index: 5;
      display:flex; gap:14px; flex-wrap:wrap;
      padding: 16px 22px 14px;
      margin: -18px -22px 18px;
      background: #ffffff;
      border-bottom: 0;
    }
    .tabBtn{
      appearance:none;
      border:1px solid var(--accent2);
      background: #ffffff;
      color: var(--accent2);
      padding: 10px 22px;
      border-radius: 999px;
      font-size: 14px;
      font-weight:600;
      cursor:pointer;
      user-select:none;
    }
    .tabBtn:hover{background: rgba(62,61,86,.06);}
    .tabBtn:active{transform: translateY(1px)}
    .tabBtn.active{
      background: var(--accent2);
      color:#ffffff;
      border-color: var(--accent2);
    }
    .pane{display:none}
    .pane.active{display:block}

    .section{
      border:1px solid rgba(62,61,86,.45);
      border-radius: 22px;
      padding: 18px 18px 16px;
      background: #f3f1ea;
      margin-bottom: 16px;
      box-shadow: none;
    }
    .sectionHeader{
      display:flex; align-items:center; justify-content:space-between; gap:10px;
      padding-bottom: 10px;
      border-bottom: 1px solid rgba(46,46,64,.14);
      margin-bottom: 10px;
    }
    .sectionTitle{
      margin:0;
      font-size: 12px;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--muted);
      font-weight: 800;
    }
    .chipRow{display:flex; flex-wrap:wrap; gap:8px}
    .chip{
      display:inline-flex; align-items:center; gap:8px;
      padding: 7px 10px;
      border-radius: 999px;
      border:1px solid rgba(62,61,86,.55);
      background: transparent;
      color: var(--text);
      font-size: 12px;
      line-height: 16px;
    }
    .chip b{color: var(--muted); font-weight: 800; font-size: 11px; letter-spacing:.04em; text-transform:uppercase}

    .itemCard{
      border: 1px solid rgba(255,255,255,.08);
      background: rgba(255,255,255,.55);
      border-radius: 16px;
      padding: 10px;
      margin-top: 10px;
    }
    .itemTop{display:flex; align-items:flex-start; justify-content:space-between; gap:10px}
    .itemTitle{font-weight: 900}
    .itemMeta{font-size: 12px; color: var(--muted); margin-top: 4px}

    .badgeRow{display:flex; gap:8px; flex-wrap:wrap}
    .badge{
      display:inline-flex; align-items:center; gap:6px;
      font-size: 11px;
      letter-spacing: .04em;
      padding: 4px 8px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.05);
      color: var(--text);
      white-space: nowrap;
    }
    .badge.good{color: rgba(156,193,143,1); border-color: rgba(156,193,143,.45); background: rgba(156,193,143,.10)}
    .badge.bad{color: rgba(217,107,107,1); border-color: rgba(217,107,107,.45); background: rgba(217,107,107,.12)}
    .badge.info{color: rgba(168,207,224,1); border-color: rgba(168,207,224,.55); background: rgba(168,207,224,.12)}
    .badge.warn{color: rgba(233,178,107,1); border-color: rgba(233,178,107,.45); background: rgba(233,178,107,.12)}

    .kv{display:flex; flex-direction:column; gap:8px; margin-top: 10px}
    .kvRow{display:grid; grid-template-columns: 140px 1fr; gap:10px; align-items:flex-start}
    .kvKey{font-size: 11px; letter-spacing:.04em; text-transform:uppercase; color: var(--muted); font-weight:800}
    .kvVal{font-weight:700; line-height:1.42; color: var(--text); min-width:0; white-space:normal; overflow-wrap:anywhere; word-break:break-word;}

    @media (min-width: 960px){
      .kv.kvResort .kvRow{grid-template-columns: minmax(150px, 210px) minmax(0,1fr); align-items:flex-start; gap:12px}
      .kv.kvResort .kvVal{padding-left: 10px; border-left: 1px dashed rgba(62,61,86,.18)}
    }

    .contactRow{display:flex; gap:10px; align-items:flex-start}
    .avatar{
      width: 34px; height: 34px; border-radius: 12px;
      display:grid; place-items:center;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.05);
      font-weight: 900;
      color: var(--text);
      flex: 0 0 auto;
    }

    .acc{border:1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.55); border-radius: 16px; overflow:hidden; margin-top: 10px}
    .accHead{display:flex; align-items:center; justify-content:space-between; gap:10px; padding: 10px 12px; cursor:pointer; user-select:none}
    .accHead:hover{background: rgba(255,255,255,.04)}
    .accBody{display:none; padding: 0 12px 12px}
    .acc.open .accBody{display:block}
    .caret{width:10px;height:10px; border-right:2px solid rgba(255,255,255,.55); border-bottom:2px solid rgba(255,255,255,.55); transform: rotate(-45deg); transition: transform .12s ease}
    .acc.open .caret{transform: rotate(45deg)}

    .block{border:1px solid var(--line); border-radius: var(--radiusSm); padding: 12px; background: var(--panel); margin-bottom: 12px}
    .block h3{margin:0 0 10px 0; font-size:12px; letter-spacing:.08em; text-transform:uppercase; color: var(--muted)}
    .mono{white-space: pre-wrap; font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace; font-size: 12px}
    .link{color:#9fd0ff; text-decoration:none}
    .row{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
    .muted{color:var(--muted)}
    @media (min-width: 960px){
      .grid{grid-template-columns: 1fr}
      .kpis{grid-template-columns: repeat(4, 1fr)}
      .twocol{grid-template-columns: 1fr 1fr}
      .chartBox{height:300px}
    }
  
    .yearPill{
      display:inline-flex;
      align-items:center;
      gap:6px;
      padding:2px 8px;
      border-radius:999px;
      background: rgba(46,46,64,.14);
      border:1px solid rgba(255,255,255,.08);
      margin-right:6px;
      margin-bottom:4px;
      font-size:12px;
      line-height:18px;
      white-space:nowrap;
    }
    .yIcon{
      width:8px;height:8px;border-radius:999px;display:inline-block;
      background: #D1D3E0;
    }
    .yIcon.active{ background: #9AC399; }
    .yIcon.pending{ background: #F3BC6C; }

    .sideLoading{
      position:absolute; inset:0; z-index:60;
      display:none;
      align-items:center; justify-content:center;
      background: rgba(11,16,32,.55);
      backdrop-filter: blur(6px);
    }
    .sideLoading.show{ display:flex; }
    .sideLoadingInner{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;}
    .sideLoadingText{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.78);text-align:center;}
    .sideLoadingText:empty{display:none;}


    .legendRow{display:flex;flex-wrap:wrap;gap:8px;margin:-2px 0 8px 0;min-height:52px;align-content:flex-start}
    .legendBtn{
      font-weight:600;

      display:inline-flex;align-items:center;gap:8px;
      padding:6px 10px;
      border-radius:999px;
      border:1px solid var(--line);
      background: var(--chip);
      color: var(--text);
      font-size:12px;
      cursor:pointer;
      user-select:none;
      transition: transform .06s ease, background .12s ease, border-color .12s ease, color .12s ease, opacity .12s ease;
    }
    .legendBtn:hover{background: rgba(46,46,64,.14); border-color: rgba(60,60,75,.30); color: var(--text)}
    .legendBtn:active{transform: translateY(1px)}
    .legendBtn.off{opacity:.45}
    .legendBtn.solid{
      border:0;
      color:#fff;
    }
    .legendBtn.solid .legendSwatch{display:none}

    .legendSwatch{width:10px;height:10px;border-radius:999px;display:inline-block;box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset}


:root{
  --page-bg:#EAE9E3;
  --card:#FFFFFF;
  --hdr:#272630;
  --hdr-ctl:#2D2A42;
  --hdr-btn:#494662;
  --ink:#2C2B36;
  --muted:#8C8A98;
  --bar:#3F3B56;
  --spo:#9AC398;
  --inc:#BAE0E6;
  --opening:#5A86C5;
  --closure:#FFB54C;
  --contracts:#A8CFDF;
  --contacts:#CFD3DF;
  --media:#DFB8A8;
}

body{ background:var(--page-bg) !important; }


.topbar, header, .header, .appHeader{
  background:var(--hdr) !important;
}


.searchWrap, .searchBox, .searchContainer{
  width:180px !important;
  max-width:180px !important;
}
@media (max-width: 900px){
  .searchWrap, .searchBox, .searchContainer{ width:100% !important; max-width:100% !important; }
}
.searchWrap input,
.searchBox input,
.searchContainer input,
#searchInput{
  height:40px !important;
  border-radius:10px !important;
  padding:0 14px 0 42px !important;
  background:var(--hdr-ctl) !important;
  border:1px solid rgba(255,255,255,.10) !important;
  color:#fff !important;
  font-size:16px !important;
  box-shadow:none !important;
}
.searchWrap input::placeholder,
.searchBox input::placeholder,
.searchContainer input::placeholder,
#searchInput::placeholder{ color: rgba(255,255,255,.45) !important; }


.btnRefresh, #refreshBtn, .refreshBtn, button.refresh{
  background:var(--hdr-btn) !important;
  border:0 !important;
  border-radius:10px !important;
  color:#fff !important;
  height:40px !important;
  padding:0 18px !important;
}


.card, .panel, .tile{
  background:var(--card) !important;
  border:0 !important;
  border-radius:16px !important;
  box-shadow: 0 18px 30px rgba(0,0,0,.08) !important;
}


.cardTitle, .panelTitle, .sectionTitle{
  color:var(--bar) !important;
  letter-spacing:2px !important;
}


.detailsBtn, .btnDetails, button.details, a.details, .details-button{
  background:var(--bar) !important;
  color:#fff !important;
  border:0 !important;
  border-radius:8px !important;
  padding:8px 14px !important;
  font-weight:600 !important;
  font-size:14px !important;
}


.spoBadge, .incBadge, .miniBadge, .thBadge, .colBadge{
  border:0 !important;
  border-radius:8px !important;
  height:32px !important;
  padding:0 12px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:15px !important;
  font-weight:600 !important;
  line-height:1 !important;
}
.spoBadge{ background:var(--spo) !important; color:#fff !important; }
.incBadge{ background:var(--inc) !important; color:var(--bar) !important; }
.spoBadge.p,
.incBadge.p{
  background:#F3BC6C !important;
  color:#fff !important;
}


.spoBadge.e,
.incBadge.e{
  background:#FF6769 !important;
  color:#fff !important;
}

.yearPill, .contractYear, .yearBadge{
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  padding:0 !important;
  box-shadow:none !important;
  color:var(--muted) !important;
  font-weight:500 !important;
}

.legendBtn.opening, .badgeOpening{ background:var(--opening) !important; color:#fff !important; border:0 !important; border-radius:10px !important; }
.legendBtn.closure, .badgeClosure{ background:var(--closure) !important; color:#fff !important; border:0 !important; border-radius:10px !important; }

.badge-contacts{ background:var(--contacts) !important; color:var(--bar) !important; border:0 !important; }
.badge-media{ background:var(--media) !important; color:var(--bar) !important; border:0 !important; }
.badge-contracts{ background:var(--contracts) !important; color:var(--bar) !important; border:0 !important; }
.badge-spo{ background:var(--spo) !important; color:#fff !important; border:0 !important; }
.badge-inc{ background:var(--inc) !important; color:var(--bar) !important; border:0 !important; }

.badge.metaTag.opening{ background:var(--opening) !important; color:#fff !important; border:0 !important; border-radius:10px !important; padding:8px 14px !important; }
.badge.metaTag.closure{ background:var(--closure) !important; color:#fff !important; border:0 !important; border-radius:10px !important; padding:8px 14px !important; }

.badge.contacts{ background:var(--contacts) !important; color:var(--bar) !important; border:0 !important; }
.badge.media{ background:var(--media) !important; color:var(--bar) !important; border:0 !important; }
.badge.contracts{ background:var(--contracts) !important; color:var(--bar) !important; border:0 !important; }
.badge.spo{ background:var(--spo) !important; color:#fff !important; border:0 !important; }
.badge.inc{ background:var(--inc) !important; color:var(--bar) !important; border:0 !important; }

.badge.contacts,.badge.media,.badge.contracts,.badge.spo,.badge.inc{
  border-radius:10px !important;
  padding:8px 14px !important;
  font-size:16px !important;
  font-weight:500 !important;
}


.logo{ width:54px !important; height:54px !important; }

.topbar .search{
  flex: 0 0 200px !important;
  width: 200px !important;
  min-width: 200px !important;
  max-width: 200px !important;
}
@media (max-width: 900px){
  .topbar .search{ flex:1 1 auto !important; width:100% !important; max-width:100% !important; }
}

.tableWrap .spo,
.tableWrap .inc,
.tableWrap .badge.inc{
  border-radius: 8px !important;
  padding: 5px 9px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
}


    #pane-contracts .accBody .itemCard{
      background: rgba(255,255,255,.70);
      border-color: rgba(63,59,86,.18);
      box-shadow: 0 4px 14px rgba(39,38,48,.08);
    }

    #pane-spo .itemCard .itemCard,
    #pane-inc .itemCard .itemCard,
    #pane-inc .incentItem{
      background: rgba(255,255,255,.70);
      border: 1px solid rgba(63,59,86,.16);
      box-shadow: 0 4px 14px rgba(39,38,48,.08);
      border-radius: 14px;
    }

    #pane-inc .incentItem{
      padding: 14px 16px;
      border-top: 0;
    }

    #pane-spo > .section > .itemCard,
    #pane-inc > .section > .itemCard{
      box-shadow: none;
    }

.modalOverlay{
  position: fixed;
  inset: 0;
  background: rgba(12, 13, 20, .55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.modalCard{
  width: min(520px, calc(100vw - 32px));
  background: var(--card, #ffffff);
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
}
.modalHead{
  background: var(--dark, #3A3952);
  color: #fff;
  padding: 18px 22px;
  font-size: 18px;
  letter-spacing: .08em;
  text-transform: uppercase;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.modalBody{
  padding: 20px 22px 22px;
  background: var(--bg, #EAE7E2);
}
.field{ margin: 10px 0 12px; }
.field label{
  display:block;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(0,0,0,.55);
  margin: 0 0 6px;
}
.field input{
  width: 100%;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(58,57,82,.25);
  background: rgba(255,255,255,.75);
  padding: 0 14px;
  outline: none;
  font-size: 16px;
}
.field input:focus{
  border-color: rgba(58,57,82,.55);
  box-shadow: 0 0 0 3px rgba(58,57,82,.12);
}
.modalActions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top: 14px;
}
.modalActions .btn{ height: 40px; border-radius: 12px; }
.authError{
  margin-top: 10px;
  padding: 10px 12px;
  background: rgba(217,107,107,.12);
  border: 1px solid rgba(217,107,107,.35);
  border-radius: 12px;
  color: #b24b4b;
  font-size: 14px;
  display:none;
}


@media (max-width: 980px) {
  .container, .bm-container { padding-left: 16px !important; padding-right: 16px !important; }
  header, .topbar, .bm-topbar { flex-wrap: wrap !important; gap: 10px !important; }
  .topbar .search, .bm-search, #searchBox, input[type="search"] { max-width: 100% !important; width: 100% !important; }
  .topbar .right, .bm-topbar-right { width: 100% !important; justify-content: flex-end !important; }
  .kpi-grid, .stats-grid, .bm-kpis { grid-template-columns: 1fr 1fr !important; }
  .charts-grid, .bm-grid { grid-template-columns: 1fr !important; }
  .chart-card, .bm-card { min-height: 260px; }
  .bm-modal { width: min(720px, calc(100vw - 24px)) !important; }
}
@media (max-width: 620px) {
  .kpi-grid, .stats-grid, .bm-kpis { grid-template-columns: 1fr !important; }
  .kpi-card, .stat-card, .bm-kpi { padding: 14px 14px !important; }
  .chart-card, .bm-card { padding: 14px 14px !important; }

  table { display: block; overflow-x: auto; white-space: nowrap; }
  th, td { white-space: nowrap; }
  .bm-tabs { flex-wrap: wrap; }
  .bm-tab { flex: 1 1 auto; }

  button, .bm-btn { min-height: 42px; }
  input, select { min-height: 42px; }


  .legendRow { gap: 10px; }
  .legendBtn {
    max-width: 100%;
    flex: 1 1 auto;
    white-space: normal;
    align-items: center;
    justify-content: flex-start;
  }
  .legendBtn span { white-space: normal; }
  .legendBtn .lbl, .legendBtn .label { white-space: normal; }
  .badgeOpening, .badgeClosure {
    max-width: 100%;
    box-sizing: border-box;
    white-space: normal;
    word-break: break-word;
  }

}


    .hotelCards{display:none}
    .hotelCard{
      background:#ffffff;
      border:1px solid rgba(62,61,86,.10);
      border-radius: 18px;
      padding: 12px;
      margin-bottom: 12px;
      box-shadow: 0 12px 26px rgba(0,0,0,.06);
    }
    .hotelCard.closed{opacity:.92}
    .hotelCardTop{display:flex; gap:12px; align-items:flex-start; justify-content:space-between}
    .hotelCardLeft{min-width:0; flex:1}
    .hotelCardNameRow{display:flex; gap:10px; align-items:center}
    .hotelCardName{font-weight:900; letter-spacing:.02em; line-height:1.2; word-break:break-word}
    .hotelCardGrid{display:grid; grid-template-columns: 1fr; gap:10px; margin-top: 10px}
    .hotelField{background: rgba(255,255,255,.55); border:1px solid rgba(62,61,86,.10); border-radius: 14px; padding: 10px}
    .hotelFieldLabel{font-size:11px; letter-spacing:.08em; text-transform:uppercase; color: var(--muted); font-weight:900; margin-bottom:6px}
    .hotelFieldValue{font-size:13px; color: var(--text)}
    .hotelFieldValue .pill{margin-right:6px; margin-bottom:6px}
    .hotelFieldValue .calcCell{max-width:100%}
    .hotelFieldValue .calcLine{white-space:normal}

    .hotelCardActions{display:flex; gap:10px; align-items:center; justify-content:flex-end}
    .hotelMoreBtn{
      height:36px;
      padding:0 12px;
      border-radius: 12px;
      border:1px solid rgba(62,61,86,.18);
      background: rgba(255,255,255,.35);
      cursor:pointer;
      font-weight:800;
      color: var(--text);
      white-space:nowrap;
    }
    .hotelMoreWrap{display:none; margin-top:10px}
    .hotelCard.isOpen .hotelMoreWrap{display:block}

    @media (max-width: 760px){
      .tableWrap table{display:none}
      .hotelCards{display:block}

      .top{padding: 12px 14px}
      .search{max-width: 260px}
      .wrap{padding: 14px}

      .topbar .wrap{
        display:grid;
        grid-template-columns: auto minmax(0,1fr) auto auto;
        grid-template-areas: "logo search search search" "logout logout anim anim";
        gap: 10px 12px;
        align-items:center;
        overflow-x:hidden;
      }
      .topbar .spacer, #updatedPill, #refreshBtn, #settingsBtn{display:none !important;}
      .topbar .brand{grid-area:logo; justify-self:start;}
      #q{grid-area:search; width:100%; max-width: 100%; min-width:0;}
      #logoutBtn{grid-area:logout; justify-self:start; border-radius:12px !important; -webkit-appearance:none; appearance:none;
        display:flex; align-items:center; justify-content:center; line-height:1; padding:0 16px; height:40px; min-width:110px;
      }
      #headerAnimationToggle{grid-area:anim; justify-self:end; min-width:0; padding:0 14px; max-width:none;}
      #headerAnimationToggleText{display:inline !important;}
      .topbar .btn, .topbar .pill, .headerAnimBtn{height:40px; font-size:14px;}

      .chartsToggle{display:block !important; margin-top:14px;}
      .chartsToggleRow{display:flex; align-items:center; justify-content:space-between;}
      .chartsToggleHint{color: var(--muted); font-size:13px; display:flex; align-items:center; gap:6px;}

      body{overflow-x:hidden;}
      .wrap{overflow-x:hidden;}

      .hotelCardNameRow{flex-direction:column; align-items:flex-start; gap:6px;}
      .hotelStatusRow{display:flex; align-items:center; gap:10px;}
      .hotelStatusRow .muted{font-size:12px;}
      .hotelCards{overflow-x:hidden;}


      .kpis{grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px}
      .kpi{padding: 14px 14px}

      .chartsGrid{grid-template-columns: 1fr !important; gap: 12px}
      .chartBox{min-height: 220px}
      .chartBox.tall{min-height: 220px}
      .legendRow{min-height:0}

      .side{
        top:0; right:0;
        width: 100%;
        height: 100%;
        border-radius: 0;
        border-left: 0;
        border-right: 0;
      }
      .sideHeader{padding: 16px 16px 14px}
      .sideHeader .h .name{font-size: 18px; letter-spacing:.12em}
      .sideBody{padding: 14px 16px 18px}

      .tabs{
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 10px;
        padding: 12px 16px 12px;
        margin: -14px -16px 14px;
        -webkit-overflow-scrolling: touch;
      }
      .tabBtn{padding: 10px 16px; font-size: 13px; white-space: nowrap}
      .section{border-radius: 18px; padding: 14px 14px 12px}
      .kvRow{grid-template-columns: 1fr; gap:6px}
      .chipRow{gap:8px}
      .chip{width:100%; justify-content:space-between}

      .mono{white-space:pre-wrap; word-break:break-word; overflow-wrap:anywhere}

      .hotelCard{padding:12px}
      .hotelCardGrid{grid-template-columns: 1fr 1fr; gap:10px}
      .hotelField.full{grid-column: 1 / -1}
      .hotelCardName{font-size:15px}
      .hotelBadges .pill{font-size:11px}
      .btn.detailsBtn{padding:0 14px; height:36px; border-radius:12px}

      .itemCard{border-radius: 16px}
      .btn{min-height: 40px}
      .close{width:42px;height:42px;border-radius:16px}
    }

html.bm-force-mobile body{overflow-x:hidden;}
html.bm-force-mobile .wrap{overflow-x:hidden;}
html.bm-force-mobile .tableWrap{display:block !important; border:none;}
html.bm-force-mobile .hotelCards{display:block !important;}
html.bm-force-mobile .tableWrap table{display:none !important;}
html.bm-force-mobile .chartsToggle{display:block !important; margin-top:14px;}
html.bm-force-mobile .hotelCardNameRow{flex-direction:column; align-items:flex-start; gap:6px;}
html.bm-force-mobile .hotelStatusRow{display:flex; align-items:center; gap:10px;}
html.bm-force-mobile .hotelStatusRow .muted{font-size:12px;}

@media (max-width: 760px){
  html.bm-force-mobile .topbar .wrap{
    display:grid;
    grid-template-columns: auto minmax(0,1fr) auto auto;
    grid-template-areas: "logo search search search" "logout logout anim anim";
    gap: 10px 12px;
    align-items:center;
    overflow-x:hidden;
  }
  html.bm-force-mobile .topbar .spacer, html.bm-force-mobile #updatedPill, html.bm-force-mobile #refreshBtn, html.bm-force-mobile #settingsBtn{display:none !important;}
  html.bm-force-mobile .topbar .brand{grid-area:logo; justify-self:start;}
  html.bm-force-mobile #q{grid-area:search; width:100%; max-width: 100%; min-width:0;}
  html.bm-force-mobile #logoutBtn{grid-area:logout; justify-self:start; border-radius:12px !important; -webkit-appearance:none; appearance:none;
    display:flex; align-items:center; justify-content:center; line-height:1; padding:0 16px; height:40px; min-width:110px;
  }
  html.bm-force-mobile #headerAnimationToggle{grid-area:anim; justify-self:end; min-width:0; padding:0 14px; max-width:none;}
  html.bm-force-mobile #headerAnimationToggleText{display:inline !important;}
  html.bm-force-mobile .topbar .btn, html.bm-force-mobile .topbar .pill, html.bm-force-mobile .headerAnimBtn{height:40px; font-size:14px;}

  html.bm-force-mobile .chartsGrid{grid-template-columns: 1fr;}
  html.bm-force-mobile .chartBox.tall{min-height:220px;}
  html.bm-force-mobile .legendRow{min-height:0}
}

@media (min-width: 761px){
  html.bm-force-mobile .topbar .wrap{
    display:flex;
    flex-wrap:nowrap;
    gap:12px;
    align-items:center;
  }
  html.bm-force-mobile .topbar .spacer{flex:1 1 auto !important; display:block !important;}
  html.bm-force-mobile .topbar .brand{order:1;}
  html.bm-force-mobile #q{order:2; flex: 1 1 420px; max-width: 520px; width:auto;}
  html.bm-force-mobile #updatedPill{order:3;}
  html.bm-force-mobile #refreshBtn{order:4;}
  html.bm-force-mobile #settingsBtn{order:5;}
  html.bm-force-mobile #logoutBtn{order:6;}
  html.bm-force-mobile .topbar .btn{height:40px; padding:0 14px; font-size:14px;}
  html.bm-force-mobile .topbar .pill{height:40px;}

  html.bm-force-mobile .chartsGrid{grid-template-columns: repeat(2, minmax(0, 1fr));}

  html.bm-force-mobile .hotelCards{
    max-width: 1200px;
    margin: 0 auto;
  }
  html.bm-force-mobile .hotelCards .hotelCard{
    border-radius: 18px;
  }
  html.bm-force-mobile .hotelCards{
    display:grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    align-items:start;
  }
  html.bm-force-mobile .hotelCardGrid{grid-template-columns: 1fr 1fr;}
  html.bm-force-mobile .hotelField.full{grid-column: 1 / -1;}
}


    body.modalOpen{ overflow:hidden !important; }

    #settingsModal .modalCard{
      max-height: calc(100vh - 24px);
      display:flex;
      flex-direction:column;
    }
    #settingsModal .modalBody{
      display:flex;
      flex-direction:column;
      overflow:hidden;
      min-height:0;
      flex:1;
    }
    #settingsModal #usageKpis{
      grid-template-columns: repeat(3, 1fr);
      gap: 10px;
    }
    #settingsModal #usageKpis .kpi{
      background:#ffffff;
      border:1px solid rgba(62,61,86,.22);
      border-radius: 16px;
      padding: 10px 12px;
      display:flex;
      flex-direction:column;
      align-items:center;
      justify-content:center;
      text-align:center;
      min-height: 56px;
    }
    #settingsModal #usageKpis .kpiValue{
      font-size: 18px;
      font-weight: 800;
      line-height: 1.1;
      color: var(--ink);
    }
    #settingsModal #usageKpis .kpiLabel{
      margin-top: 4px;
      font-size: 12px;
      color: var(--muted);
    }

    #settingsModal #settingsUsers,
    #settingsModal #settingsUsage{
      display:flex;
      flex-direction:column;
      flex: 1;
      min-height: 0;
    }
    #settingsModal #settingsUsers .btnRow,
    #settingsModal #settingsUsage #usageKpis{
      flex: 0 0 auto;
    }

    #settingsModal .tableWrap{
      flex: 1;
      min-height: 0;
      overflow: auto;
      overscroll-behavior: contain;
    }

    #settingsModal .tabs{ flex:0 0 auto; }
    #settingsModal .tabBtn{
      appearance:none;
      border:1px solid rgba(62,61,86,.35);
      background:#ffffff;
      color: var(--ink);
      padding: 8px 14px;
      border-radius: 999px;
      font-weight: 700;
      font-size: 13px;
      line-height: 1;
      cursor: pointer;
    }
    #settingsModal .tabBtn.active{
      background: var(--accent2);
      border-color: var(--accent2);
      color: #ffffff;
    }
    #settingsModal .tabBtn:not(.active):hover{
      border-color: rgba(62,61,86,.6);
    }


#settingsModal .usageSubhead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin: 10px 0 6px;
  font-weight: 800;
  color: var(--ink);
  flex: 0 0 auto;
}

#settingsModal .usageFailedWrap{
  flex: 0 1 220px !important;
  max-height: 260px;
}

#settingsModal #failedLoginTable td:nth-child(4){
  max-width: 420px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

body.modalOpen{ overflow:hidden !important; }

#settingsModal .modalCard{
  max-height: calc(100vh - 28px);
  display:flex;
  flex-direction:column;
}
#settingsModal .modalHead{
  flex:0 0 auto;
}
#settingsModal .modalBody{
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
  gap: 12px;
  overflow:hidden;
}

#settingsModal .settingsTabs{
  position: static !important;
  top:auto !important;
  z-index: 1;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  display:flex;
  gap: 10px;
  flex-wrap: nowrap;
}
#settingsModal .modalCard{
  width:min(1080px, calc(100vw - 48px));
}
#settingsModal table{
  width:100%;
  table-layout:fixed;
}
#settingsModal th,
#settingsModal td{
  white-space:nowrap;
}
#settingsModal th:last-child,
#settingsModal td:last-child{
  width:220px;
}
#settingsModal td:last-child .btn{
  padding:8px 10px;
}
.hotelHeaderBar{align-items:center;gap:10px;}
.hotelHeaderLeft{gap:6px;min-width:min(420px,100%);}
.hotelHeaderTitleRow{gap:8px;}
.hotelHeaderSearch{width:min(420px,100%);height:34px;padding-top:0;padding-bottom:0;}
.riSearchStatus{min-height:0;display:none;}
#settingsModal .settingsTabs .tabBtn{
  padding: 8px 16px;
  font-size: 13px;
}

#settingsModal #settingsUsers,
#settingsModal #settingsUsage{
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
}
#settingsModal .tableWrap{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  background: #ffffff;
}

#settingsModal #usageKpis{
  margin: 0;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
#settingsModal #usageKpis .kpi{
  background:#ffffff;
  border:1px solid rgba(62,61,86,.22);
  border-radius: 16px;
  padding: 10px 12px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  min-height: 56px;
}
#settingsModal #usageKpis .kpiValue{
  font-size: 18px;
  font-weight: 800;
  line-height: 1.1;
  color: var(--ink);
}
#settingsModal #usageKpis .kpiLabel{
  margin-top: 4px;
  font-size: 12px;
  color: var(--muted);
}


html.bm-force-mobile #settingsBtn { display:none !important; }
@media (max-width: 760px){ #settingsBtn{ display:none !important; } }

#settingsModal .modalCard{
  height: min(860px, calc(100vh - 28px));
  max-height: calc(100vh - 28px);
}
@media (max-width: 900px){
  #settingsModal .modalCard{
    height: calc(100vh - 24px);
    max-height: calc(100vh - 24px);
  }
}
#settingsModal .modalBody{
  min-height: 0 !important;
  overflow: hidden !important;
}

#settingsModal .settingsContent{
  min-height: 0 !important;
  overflow: hidden !important;
}
#settingsModal #settingsUsers,
#settingsModal #settingsUsage{
  min-height: 0 !important;
  height: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

#settingsModal #settingsUsers .tableWrap,
#settingsModal #settingsUsage .tableWrap{
  flex: 1 1 auto;
  min-height: 0 !important;
  overflow: auto !important;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

#settingsModal table{ min-width: 980px; }
@media (max-width: 760px){ #settingsModal table{ min-width: 1100px; } }

#settingsModal .kpiGrid{ flex: 0 0 auto; }

@media (max-width: 760px) {
  .topbar .wrap{
    column-gap: 10px;
  }
  #q{
    margin-left: -6px;
    max-width: 66vw;
  }

  #pane-overview .sectionHeader{
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: 10px !important;
  }
  #pane-overview .sectionHeader .badgeRow{
    width: 100% !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    justify-content: flex-start !important;
  }
  #pane-overview .sectionHeader .badgeRow .badge{
    flex: 1 1 calc(50% - 10px) !important;
    justify-content: center !important;
    text-align: center !important;
  }

  #pane-contacts a{
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    max-width: 100% !important;
  }
}
html.bm-force-mobile{
}
html.bm-force-mobile .topbar .wrap{
  column-gap: 10px;
}
html.bm-force-mobile #q{
  margin-left: -6px;
  max-width: 66vw;
}
html.bm-force-mobile #pane-overview .sectionHeader{
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  gap: 10px !important;
}
html.bm-force-mobile #pane-overview .sectionHeader .badgeRow{
  width: 100% !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  justify-content: flex-start !important;
}
html.bm-force-mobile #pane-overview .sectionHeader .badgeRow .badge{
  flex: 1 1 calc(50% - 10px) !important;
  justify-content: center !important;
  text-align: center !important;
}
html.bm-force-mobile #pane-contacts a{
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  max-width: 100% !important;
}

html.bm-force-mobile #logoutBtn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
  padding:0 14px !important;
}



@media (hover: none) and (pointer: coarse) {
  #sidePanel { background: var(--bg) !important; }
  #sideBody { background: var(--bg) !important; padding: 0 !important; }
  #sideBody .tabs{
    position: sticky;
    top: 0;
    z-index: 25;
    margin: 0 !important;
    padding: 12px 16px !important;
    background: var(--bg) !important;
    border-bottom: 1px solid rgba(62,61,86,.14);
  }
  #sideBody .pane{ padding: 16px !important; }
  #sideBody{ overscroll-behavior: contain; }
}

      .chartCard{position:relative;}
      .chartHeader{display:flex; align-items:center; justify-content:space-between; gap:10px; cursor:pointer;}
      .chartHeader .title{margin:0;}
      .chartToggleHint{color: var(--muted); font-size:13px; display:flex; align-items:center; gap:6px;}
      .chartToggleHint .chev{display:inline-block; transform: rotate(-90deg); transition: transform .15s ease;}
      .chartCard.expanded .chartToggleHint .chev{transform: rotate(0deg);}
      .chartBody{margin-top:10px;}
      .chartCard:not(.expanded) .chartBody{display:none;}

      .inlineResortInf{margin-top:10px; padding:12px 12px; border:1px solid var(--line); border-radius:16px; background: #ffffff; text-align:left; overflow:hidden;}
      .inlineResortInf .riTitle{font-size:14px; font-weight:700; margin-bottom:6px; color: var(--ink);}
      .inlineResortInf .riGrid{display:grid; gap:10px; grid-template-columns: 1fr; min-width:0;}
      @media (min-width: 980px){
        .inlineResortInf .riGrid{grid-template-columns: repeat(2, minmax(0,1fr));}
      }
      .inlineResortInf .riItem{padding:9px 10px; border:1px solid var(--line); border-radius:14px; background: #fbfbfd; min-width:0; max-width:100%; overflow:hidden;}
      .inlineResortInf .riItemHead{display:flex; align-items:center; justify-content:space-between; gap:10px; user-select:none; min-width:0;}
      .inlineResortInf .riItemTitle{font-size:12px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; margin:0; color: var(--ink); min-width:0;}
      .inlineResortInf .riBody{margin-top:4px; min-width:0; max-width:100%;}
      .inlineResortInf .riKV{display:grid; grid-template-columns: minmax(110px, 180px) minmax(0,1fr); gap:8px 8px; padding:3px 0; align-items:start; min-width:0; max-width:100%;}
      .inlineResortInf .riKV > .k, .inlineResortInf .riKV > .v{min-width:0; max-width:100%; white-space:normal; overflow-wrap:anywhere; word-break:break-word;}
      .inlineResortInf .riKV .k{font-size:12.5px; color: var(--muted); font-weight:650;}
      .inlineResortInf .riKV .v{font-size:13px; color: var(--ink); line-height:1.35;}
      .inlineResortInf .riLine{font-size:13px; color: var(--ink); line-height:1.35; min-width:0; max-width:100%; white-space:normal; overflow-wrap:anywhere; word-break:break-word;}
      .inlineResortInf .riLine b{color: var(--muted); font-weight:650;}
      .riSearchWrap{margin:12px 0 14px;}
      .riSearchInput{width:100%;height:42px;padding:0 14px;border-radius:14px;border:1px solid rgba(62,61,86,.14);background:rgba(255,255,255,.88);color:var(--text);outline:none;font-size:13px;box-shadow: inset 0 1px 0 rgba(255,255,255,.55);}
      .riSearchInput:focus{border-color:rgba(62,61,86,.28);box-shadow:0 0 0 4px rgba(169,207,222,.18);}
      .riSearchMeta{margin-top:8px;font-size:12px;color:var(--muted);}
      .riSearchEmpty{margin-top:10px;padding:14px 16px;border-radius:14px;border:1px dashed rgba(62,61,86,.18);color:var(--muted);background:rgba(255,255,255,.55);}

      .hotelHeaderBar{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;}
      .hotelHeaderLeft{display:flex;flex-direction:column;gap:10px;min-width:min(440px,100%);flex:1 1 420px;}
      .hotelHeaderTitleRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
      .hotelHeaderSearch{width:min(312px,100%);max-width:100%;min-width:0;height:36px;padding-top:8px;padding-bottom:8px;border-radius:10px;}
      .riSearchStatus{display:flex;align-items:center;gap:8px;min-height:18px;font-size:12px;color:var(--muted);}
      .riSearchStatus.busy{color:var(--ink);}
      .riSearchStatus .waveLoaderHost{flex:0 0 auto;}
      .riSearchStatus mark, .inlineResortInf mark, .section mark{background:rgba(255,181,76,.34);color:inherit;padding:0 .14em;border-radius:4px;}
      @media (max-width: 760px){
        .hotelHeaderLeft{min-width:100%;}
        .hotelHeaderSearch{width:100%;}
      }

      @media (max-width: 520px){
        .inlineResortInf .riKV{grid-template-columns: 1fr; gap:4px;}
      }
      .hotelNameLink{appearance:none; border:0; background:transparent; padding:0; text-align:left; cursor:pointer; font:inherit; color: inherit;}
      .hotelNameLink:hover{opacity:.9; text-decoration:underline;}

      .calcShort{cursor:pointer;}
      .yearPill{cursor:pointer;}

      #bmTooltip{position:fixed; z-index:9999; max-width:360px; background: rgba(15,18,32,.96); color:#fff; padding:10px 12px; border-radius:12px;
        font-size:13px; line-height:1.35; box-shadow: 0 10px 30px rgba(0,0,0,.18); display:none;}
      #bmTooltip .ttTitle{font-weight:700; margin-bottom:4px;}
      #bmTooltip .ttLine{opacity:.95;}


.logoWrap{position:relative;display:inline-block;width:54px;height:54px;flex:0 0 auto}
.logoWrap .logo{width:100%;height:100%;background-image:url('../icon.ico')}
body.bm-style-spring .logoWrap .logo{background-image:url('../spring.ico')}
body.bm-style-winter .logoWrap .logo{background-image:url('../winter.ico')}
#seasonFxLayer{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.seasonFxItem{position:absolute;top:-16vh;left:0;will-change:transform,opacity;user-select:none;pointer-events:none;animation-name:bmSeasonFall;animation-timing-function:linear;animation-iteration-count:infinite;animation-fill-mode:both;backface-visibility:hidden;transform:translateZ(0)}
.seasonFxItem img{display:block;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 3px 6px rgba(0,0,0,.10))}
body.bm-style-spring .seasonFxItem img{opacity:.78}
body.bm-style-winter .seasonFxItem img{opacity:.92;filter:drop-shadow(0 2px 8px rgba(123,164,255,.28))}
@keyframes bmSeasonFall{
  0%{transform:translate3d(var(--sx,0),-18vh,0) rotate(0deg);opacity:0}
  6%{opacity:var(--op,.8)}
  94%{opacity:var(--op,.8)}
  100%{transform:translate3d(calc(var(--sx,0) + var(--dx, 24px)),118vh,0) rotate(var(--rot,240deg));opacity:0}
}
#settingsStyle{display:none;flex-direction:column;gap:14px}
.styleGrid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:14px}
.styleCard{border:1px solid var(--line);background:#fff;border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 24px rgba(42,52,84,.06)}
.styleCard.active{border-color:rgba(62,61,86,.48);box-shadow:0 16px 28px rgba(42,52,84,.1)}
.styleCardHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.styleTitle{font-size:15px;font-weight:800;color:var(--text)}
.styleDesc{font-size:12px;line-height:1.45;color:var(--muted)}
.stylePreview{height:90px;border-radius:16px;background:linear-gradient(180deg,#f8f7f4,#efede8);border:1px solid rgba(62,61,86,.08);position:relative;overflow:hidden}
.stylePreview img{position:absolute;object-fit:contain;opacity:.9}
.stylePreview.flowers img:nth-child(1){width:36px;left:18px;top:16px;transform:rotate(-12deg)}
.stylePreview.flowers img:nth-child(2){width:28px;right:24px;top:20px;transform:rotate(10deg)}
.stylePreview.flowers img:nth-child(3){width:24px;left:46%;bottom:10px;transform:translateX(-50%) rotate(18deg)}
.stylePreview.snow img:nth-child(1){width:26px;left:20px;top:14px}
.stylePreview.snow img:nth-child(2){width:18px;right:26px;top:24px}
.stylePreview.snow img:nth-child(3){width:22px;left:48%;bottom:12px;transform:translateX(-50%)}
.toggleRow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--line);background:#fff;border-radius:16px}
.switch{position:relative;display:inline-block;width:52px;height:30px;flex:0 0 auto}
.switch input{opacity:0;width:0;height:0}
.switchSlider{position:absolute;inset:0;border-radius:999px;background:#d8d5cf;transition:.2s ease;box-shadow:inset 0 0 0 1px rgba(62,61,86,.12)}
.switchSlider:before{content:"";position:absolute;width:24px;height:24px;left:3px;top:3px;border-radius:50%;background:#fff;transition:.2s ease;box-shadow:0 4px 12px rgba(15,18,32,.16)}
.switch input:checked + .switchSlider{background:#3F3B56}
.switch input:checked + .switchSlider:before{transform:translateX(22px)}
.styleActions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.headerAnimBtn{display:none;align-items:center;gap:8px;height:38px;padding:0 12px;border-radius:12px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.82);color:var(--text);font-weight:700;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.headerAnimBtn{justify-content:center;white-space:nowrap;min-width:42px}
.headerAnimBtn .dot{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.72;flex:0 0 auto}
.headerAnimBtn[data-enabled="0"]{opacity:.72;color:var(--muted)}
.styleCard input[type="radio"]{width:18px;height:18px;accent-color:#3F3B56;cursor:pointer;flex:0 0 auto}
@media (max-width:760px){.styleGrid{grid-template-columns:1fr}.headerAnimBtn{padding:0 12px;font-size:13px;max-width:100%;min-width:0} #headerAnimationToggleText{display:inline}.seasonFxItem img{transform:scale(.82);transform-origin:center center;} .logoWrap{width:48px;height:48px;} .logo{width:48px !important;height:48px !important;}}


@media (max-width: 760px){
  .actions{width:100%; justify-content:space-between; gap:8px; align-items:center; flex-wrap:wrap;}
  .actions > *{flex:0 0 auto;}
  .actions .animToggleBtn{margin-left:auto;}
}


/* SPO in progress chat */
.spoDesktopOnly{display:inline-flex}
.spoMobileOnly{display:none !important}
@media (max-width:760px){
  .spoDesktopOnly{display:none !important}
  .spoMobileOnly{display:inline-flex !important}
  .spoBtnWrap{position:relative;display:inline-flex;align-items:center;justify-content:center}
  .spoBtn{
    width:40px;height:40px;padding:0;min-width:40px;border-radius:12px;
  }
  .spoBtn .spoBtnLabel{display:none !important}
  .spoBtn .spoBtnIcon{display:inline-flex !important}
}
.spoBtn .spoBtnIcon{display:inline-flex;align-items:center;justify-content:center;width:20px;min-width:20px;height:20px;flex:0 0 20px;font-size:18px;line-height:1}
.spoBtnWrap{position:relative;display:none;align-items:center;justify-content:center;overflow:visible;isolation:isolate;flex:0 0 auto}
.spoBtn{position:relative;display:inline-flex;align-items:center;gap:10px;height:40px;min-width:40px;padding:0 14px;border-radius:13px;border:1px solid rgba(62,61,86,.12);background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(244,241,255,.92));color:var(--text);font-weight:800;letter-spacing:.01em;box-shadow:0 10px 24px rgba(42,52,84,.08), inset 0 1px 0 rgba(255,255,255,.65);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:box-shadow .18s ease, border-color .18s ease, background .18s ease;overflow:visible;flex:0 0 auto;white-space:nowrap}
.spoBtn:hover{box-shadow:0 16px 28px rgba(42,52,84,.12), inset 0 1px 0 rgba(255,255,255,.7);border-color:rgba(62,61,86,.22)}
.spoBtnDot{width:10px;height:10px;flex:0 0 10px;border-radius:50%;background:linear-gradient(180deg,#8c7bff,#5d53b4);box-shadow:0 0 0 5px rgba(130,110,255,.12)}
.spoUnreadBadge{position:absolute;top:-10px;right:-8px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#ff5b7d;color:#fff;font-size:11px;line-height:1;font-weight:900;display:none;align-items:center;justify-content:center;box-shadow:0 8px 16px rgba(255,91,125,.32);z-index:6;pointer-events:none}
.spoUnreadBadge.show{display:flex;animation:spoPulse 1.6s ease infinite}
@keyframes spoPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
html.bm-spo-lock,body.bm-spo-lock{overflow:hidden !important}
.spoOverlay{position:fixed;inset:0;z-index:1200;display:none;pointer-events:none;overscroll-behavior:contain}
.spoOverlay.open{display:block;pointer-events:auto}
.spoBackdrop{position:absolute;inset:0;background:rgba(14,18,35,.28);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .22s ease}
.spoOverlay.open .spoBackdrop{opacity:1}
.spoPanel{position:absolute;top:70px;right:20px;width:min(500px,calc(100vw - 28px));height:min(82vh,840px);border-radius:26px;border:1px solid rgba(62,61,86,.12);background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,245,255,.96));box-shadow:0 30px 80px rgba(19,24,40,.24);overflow:hidden;display:flex;flex-direction:column;transform:translateY(-8px) scale(.98);opacity:0;transition:transform .24s ease, opacity .24s ease;overscroll-behavior:contain}
.spoOverlay.open .spoPanel{transform:translateY(0) scale(1);opacity:1}
.spoHead{padding:16px 16px 12px;border-bottom:1px solid rgba(62,61,86,.08);background:linear-gradient(180deg,rgba(245,242,255,.95),rgba(255,255,255,.82));display:flex;flex-direction:column;gap:12px}
.spoHeadTop{display:flex;align-items:center;justify-content:space-between;gap:12px}.spoHeadBottom{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}
.spoTitleBlock{display:flex;align-items:center;gap:0;min-width:0;flex:0 0 auto}
.spoOrb{width:44px;height:44px;border-radius:16px;background:radial-gradient(circle at 30% 30%,#9f92ff,#5d53b4 72%);box-shadow:0 14px 28px rgba(93,83,180,.28);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.spoTitleBlock > div:not(.spoOrb){display:none}
.spoPanelTitle{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.spoPanelSub{display:none}
.spoHeadActions{display:flex;align-items:center;gap:10px;flex:0 0 auto;flex-wrap:nowrap;justify-content:flex-end;min-width:0}.spoSearchRow{display:none}.spoSearchRow.open{display:block}.spoSearchField{display:flex;align-items:center;gap:8px;height:38px;padding:0 10px;border-radius:14px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.88);box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}.spoSearchLens{font-size:14px;opacity:.72}.spoSearchInput{flex:1 1 auto;min-width:0;border:0;outline:none;background:transparent;color:var(--text);font:inherit;font-size:13px}.spoSearchClear{width:24px;height:24px;border:0;border-radius:8px;background:rgba(93,83,180,.08);color:var(--muted);display:none;align-items:center;justify-content:center;font-size:13px;font-weight:900}.spoSearchClear.show{display:inline-flex}
.spoTinyBtn,.spoIconBtn{height:34px;border-radius:12px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.86);color:var(--text);font-size:12px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease}
.spoTinyBtn:hover,.spoIconBtn:hover{transform:translateY(-1px);border-color:rgba(62,61,86,.22);box-shadow:0 10px 20px rgba(42,52,84,.08)}
.spoIconBtn{width:34px;padding:0;font-size:16px}
.spoTabs{display:flex;flex-wrap:wrap;gap:8px;overflow:visible;padding:2px 0 0;min-width:0;flex:1 1 auto;scrollbar-width:none;-ms-overflow-style:none}.spoTabs::-webkit-scrollbar{display:none}
.spoTab{border:1px solid rgba(62,61,86,.10);background:rgba(255,255,255,.8);color:var(--muted);height:34px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:12px;font-weight:800;white-space:nowrap;flex:0 0 auto}
.spoTab.active{background:linear-gradient(180deg,#5d53b4,#4b448c);color:#fff;border-color:transparent;box-shadow:0 14px 24px rgba(93,83,180,.24)}
.spoTabCount{min-width:18px;height:18px;border-radius:999px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;background:rgba(62,61,86,.08);color:inherit;font-size:10px;font-weight:900}
.spoTab.active .spoTabCount{background:rgba(255,255,255,.18)}
.spoList{flex:1 1 auto;overflow:auto;padding:16px;background:linear-gradient(180deg,rgba(248,247,252,.88),rgba(244,241,250,.94));scrollbar-width:thin;scrollbar-color:rgba(93,83,180,.28) transparent;overscroll-behavior:contain}.spoList::-webkit-scrollbar{width:10px}.spoList::-webkit-scrollbar-track{background:transparent}.spoList::-webkit-scrollbar-thumb{background:rgba(93,83,180,.22);border-radius:999px;border:3px solid transparent;background-clip:padding-box}
.spoEmpty{height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:18px;color:var(--muted);font-size:13px;border:1px dashed rgba(62,61,86,.12);border-radius:22px;background:rgba(255,255,255,.55)}
.spoMessage{position:relative;display:flex;gap:10px;margin-bottom:14px;opacity:1;transform:none}
.spoMessage.isNew{opacity:0;transform:translateY(8px);animation:spoMsgIn .22s ease forwards}
@keyframes spoMsgIn{to{opacity:1;transform:translateY(0)}}
.spoAvatar{width:38px;height:38px;min-width:38px;min-height:38px;flex:0 0 38px;border-radius:14px;background:linear-gradient(180deg,#ece8ff,#dcd5ff);color:#4d478b;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.spoBubble{flex:1 1 auto;min-width:0;background:rgba(255,255,255,.88);border:1px solid rgba(62,61,86,.08);border-radius:20px;padding:12px 14px 11px;box-shadow:0 14px 28px rgba(42,52,84,.06)}
.spoMeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.spoAuthor{font-size:13px;font-weight:900;color:var(--text)}
.spoTime{font-size:11px;color:var(--muted)}
.spoStatusPill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;background:rgba(93,83,180,.08);color:#4d478b;font-size:11px;font-weight:800}.spoStatusPill.hasHint{position:relative;cursor:help}
.spoReplyPreview{display:none;margin:0 0 9px;padding:8px 10px;border-radius:14px;background:rgba(93,83,180,.06);border-left:3px solid rgba(93,83,180,.42)}
.spoReplyPreview.show{display:block}
.spoReplyAuthor{font-size:11px;font-weight:900;color:#4d478b;margin-bottom:2px}
.spoReplyText{font-size:12px;line-height:1.35;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spoText{font-size:13px;line-height:1.45;color:var(--text);white-space:pre-wrap;word-break:break-word}
.spoMsgActions{position:relative;flex:0 0 auto;padding-top:4px;display:flex;align-items:flex-start;gap:6px}
.spoStatusBtn,.spoContextBtn{width:34px;height:34px;border-radius:12px;border:1px solid rgba(62,61,86,.1);background:rgba(255,255,255,.82);color:var(--muted);font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 18px rgba(42,52,84,.06);transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease}
.spoContextBtn{font-size:16px;font-weight:900}
.spoStatusBtn:hover,.spoContextBtn:hover{transform:translateY(-1px);border-color:rgba(62,61,86,.18);box-shadow:0 12px 22px rgba(42,52,84,.09)}
.spoStatusMenu,.spoContextMenu{position:absolute;top:40px;width:210px;padding:8px;border-radius:16px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.98);box-shadow:0 24px 44px rgba(19,24,40,.18);display:none;z-index:4;max-height:min(280px,46vh);overflow:auto}.spoStatusMenu.isUp,.spoContextMenu.isUp{top:auto;bottom:40px}
.spoStatusMenu{right:42px}
.spoContextMenu{right:0;width:170px}
.spoStatusMenu.open,.spoContextMenu.open{display:block;animation:spoMenu .18s ease}
@keyframes spoMenu{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.spoStatusOption,.spoContextOption{width:100%;border:0;background:transparent;border-radius:12px;padding:9px 10px;display:flex;align-items:center;gap:10px;text-align:left;color:var(--text);font-size:13px;font-weight:700}
.spoStatusOption:hover,.spoContextOption:hover{background:rgba(93,83,180,.08)}
.spoContextOption.isDanger{color:#b24c63}
.spoComposer{padding:14px 16px 16px;border-top:1px solid rgba(62,61,86,.08);background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(243,240,250,.96));display:flex;flex-direction:column;gap:10px}
.spoComposerAssist{display:none}
.spoComposerAssist.show{display:block}
.spoComposerBanner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:16px;background:rgba(93,83,180,.08);border:1px solid rgba(93,83,180,.12)}
.spoComposerBannerTitle{font-size:11px;font-weight:900;color:#4d478b;margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}
.spoComposerBannerText{font-size:12px;line-height:1.35;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.spoComposerBannerClose{flex:0 0 auto;width:28px;height:28px;border-radius:10px;border:0;background:rgba(255,255,255,.72);color:var(--muted);font-size:15px;font-weight:900;display:flex;align-items:center;justify-content:center}
.spoInputWrap{display:grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:end;gap:10px}
.spoTextarea{width:100%;min-height:52px;height:52px;max-height:130px;resize:none;border-radius:18px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.95);padding:14px 16px;color:var(--text);font:inherit;line-height:1.4;display:block;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.spoTextarea:focus{outline:none;border-color:rgba(93,83,180,.34);box-shadow:0 0 0 4px rgba(93,83,180,.10)}
.spoSendBtn{height:52px;min-width:96px;padding:0 18px;border-radius:16px;border:0;background:linear-gradient(180deg,#5d53b4,#4b448c);color:#fff;font-size:13px;font-weight:900;align-self:end;box-shadow:0 16px 28px rgba(93,83,180,.26)}
.spoSendBtn[disabled]{opacity:.6;box-shadow:none}
.spoTools{display:flex;align-items:center;gap:10px;justify-content:flex-end;min-height:18px}
.spoEmojiWrap{position:relative}
.spoEmojiBtn{height:38px;width:38px;padding:0;border-radius:12px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.88);font-size:18px;display:flex;align-items:center;justify-content:center}
.spoEmojiPanel{position:absolute;left:0;bottom:42px;width:280px;max-height:220px;overflow:auto;padding:10px;border-radius:18px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.98);box-shadow:0 24px 44px rgba(19,24,40,.18);display:none;grid-template-columns:repeat(8,minmax(0,1fr));gap:8px;scrollbar-width:thin;scrollbar-color:rgba(93,83,180,.28) transparent}.spoEmojiPanel::-webkit-scrollbar{width:10px}.spoEmojiPanel::-webkit-scrollbar-track{background:transparent}.spoEmojiPanel::-webkit-scrollbar-thumb{background:rgba(93,83,180,.22);border-radius:999px;border:3px solid transparent;background-clip:padding-box}
.spoEmojiPanel.open{display:grid}
.spoEmojiItem{height:30px;border-radius:10px;border:0;background:rgba(93,83,180,.06);font-size:18px}
.spoComposerMeta{font-size:12px;color:var(--muted)}.spoScrollDown{position:absolute;right:18px;bottom:106px;width:40px;height:40px;border-radius:14px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.96);color:#4d478b;font-size:20px;font-weight:900;display:none;align-items:center;justify-content:center;box-shadow:0 18px 34px rgba(19,24,40,.16);z-index:5;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.spoScrollDown.show{display:flex}.spoScrollDown:hover{transform:translateY(-1px)}
.spoUnreadDot{width:8px;height:8px;border-radius:50%;background:#ff5b7d;display:inline-block;margin-left:2px;box-shadow:0 0 0 4px rgba(255,91,125,.12)}
.spoMark{display:inline;padding:0 .18em;border-radius:.42em;background:rgba(255,214,80,.58);color:#3d3207;font-weight:800;box-shadow:inset 0 0 0 1px rgba(255,196,0,.16)}
.spoDiagCard{display:none !important;padding:12px 12px 10px;border-radius:18px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.9);box-shadow:0 16px 34px rgba(19,24,40,.08)}
.spoDiagCard.open{display:block;animation:spoMenu .18s ease}
.spoDiagTop{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.spoDiagTitle{font-size:12px;font-weight:900;color:var(--text)}.spoDiagHint{font-size:11px;color:var(--muted)}
.spoDiagGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.spoDiagItem{padding:9px 10px;border-radius:14px;background:rgba(93,83,180,.04);border:1px solid rgba(93,83,180,.08)}
.spoDiagLabel{font-size:10px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:#7f78a8;margin-bottom:4px}
.spoDiagValue{font-size:12px;line-height:1.35;font-weight:800;color:var(--text);word-break:break-word}
.spoDiagValue.isOk{color:#1b8f52}.spoDiagValue.isWarn{color:#b26f18}.spoDiagValue.isError{color:#b24c63}
.spoDiagActions{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:10px}.spoDiagBtnMini{height:30px;padding:0 10px;border-radius:10px;border:1px solid rgba(62,61,86,.12);background:rgba(255,255,255,.92);color:var(--text);font-size:12px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.spoDiagLogs{margin-top:10px;max-height:126px;overflow:auto;padding-right:2px;scrollbar-width:thin;scrollbar-color:rgba(93,83,180,.28) transparent}.spoDiagLogs::-webkit-scrollbar{width:10px}.spoDiagLogs::-webkit-scrollbar-track{background:transparent}.spoDiagLogs::-webkit-scrollbar-thumb{background:rgba(93,83,180,.22);border-radius:999px;border:3px solid transparent;background-clip:padding-box}
.spoDiagLog{display:flex;gap:8px;padding:8px 10px;border-radius:12px;background:rgba(248,247,252,.92);border:1px solid rgba(62,61,86,.06);font-size:11px;line-height:1.35;color:var(--text);margin-bottom:6px}.spoDiagLog:last-child{margin-bottom:0}.spoDiagLogTs{flex:0 0 auto;color:var(--muted);font-weight:800}.spoDiagLogMsg{flex:1 1 auto;min-width:0;word-break:break-word}.spoDiagLog.isWarn .spoDiagLogMsg{color:#9d6618}.spoDiagLog.isError .spoDiagLogMsg{color:#b24c63}

@media (max-width:1080px){
  .spoPanel{right:16px;width:min(440px,calc(100vw - 24px));height:min(76vh,760px)}
  .spoHeadTop{align-items:flex-start}
  .spoHeadActions{gap:6px}
  .spoTinyBtn{padding:0 10px}
}

