/* ===== DESIGN TOKENS ===== */
:root {
  --bg: #0a0a14;
  --bg2: #12122a;
  --bg3: #0e0e20;
  --card: #16163a;
  --border: #1e1e4a;
  --border2: #2a2a5a;
  --border-hover: #3030aa;
  --text: #f0f0f5;
  --text2: #9999bb;
  --text3: #8888cc;
  --accent: #7c83ff;
  --accent2: #6366f1;
  --green: #34d399;
  --blue: #60a5fa;
  --purple: #a78bfa;
  --orange: #fb923c;
  --red: #f87171;
  --yellow: #fbbf24;
  --cyan: #22d3ee;
  --radius: 16px;
  --radius-sm: 12px;
  --radius-xs: 8px;
  --shadow: 0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.55);
  --glass: rgba(22,22,58,0.55);
  --glass-border: rgba(120,120,255,0.08);
  --transition: 0.2s cubic-bezier(0.4,0,0.2,1);
}

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;line-height:1.55;
  min-height:100vh;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--blue)}
img{max-width:100%;display:block}
ul,ol{list-style:none}

/* ===== TELEGRAM THEME INTEGRATION ===== */
body.tg-theme{
  --bg:var(--tg-theme-bg-color,#0a0a14);
  --text:var(--tg-theme-text-color,#f0f0f5);
  --accent:var(--tg-theme-button-color,#7c83ff);
  --card:var(--tg-theme-secondary-bg-color,#16163a);
  --text3:var(--tg-theme-hint-color,#5555aa);
}

/* ===== LIGHT THEME ===== */
body.tg-theme.light,body.light{
  --bg:#f0f0f4;--bg2:#e4e4ec;--bg3:#d8d8e2;
  --card:#ffffff;
  --border:#c0c0d0;--border2:#b0b0c4;--border-hover:#6366f1;
  --text:#111128;--text2:#444466;--text3:#777799;
  --accent:#4f56e0;--accent2:#4349d0;
  --green:#1a9a6e;--blue:#3b82f6;--purple:#7c5fcf;--orange:#d97706;--red:#dc2626;--yellow:#ca8a04;--cyan:#0891b2;
  --glass:rgba(255,255,255,0.8);--glass-border:rgba(0,0,50,0.10);
  --shadow:0 2px 12px rgba(0,0,0,0.08);--shadow-lg:0 4px 24px rgba(0,0,0,0.12);
}
body.light .header,body.tg-theme.light .header{
  background:linear-gradient(135deg,#e8e8f4 0%,#ddddf0 50%,#e8e8f4 100%);
}
body.light .btn,body.tg-theme.light .btn{background:#dcdce8;color:#111128;border-color:#b8b8cc}
body.light .btn:hover,body.tg-theme.light .btn:hover{background:#ccccdc;border-color:var(--border-hover)}
body.light .project-card,body.tg-theme.light .project-card{
  background:#fff;border:1px solid #d0d0e0;box-shadow:0 2px 8px rgba(0,0,0,0.06);
}
body.light .project-card:hover,body.tg-theme.light .project-card:hover{
  border-color:var(--accent);box-shadow:0 4px 16px rgba(91,99,239,0.12);
}
body.light .today-strip,body.tg-theme.light .today-strip{
  background:rgba(91,99,239,0.08);border-color:#c4c4d8;
}
body.light .modal,body.light .stats-modal,body.tg-theme.light .modal,body.tg-theme.light .stats-modal{
  background:#fff;border:1px solid #d0d0e0;
}
body.light .tip,body.tg-theme.light .tip{background:rgba(255,255,255,0.95);color:var(--text);border-color:var(--border)}
body.light .live,body.tg-theme.light .live{background:rgba(255,255,255,0.9)}
body.light .card,body.tg-theme.light .card{
  background:#fff;border:1px solid #d0d0e0;
}
body.light .global-card,body.light .global-stat,body.tg-theme.light .global-card,body.tg-theme.light .global-stat{
  background:#fff;border:1px solid #d8d8e4;
}
body.light input,body.light textarea,body.light select,body.tg-theme.light input,body.tg-theme.light textarea,body.tg-theme.light select{
  background:var(--bg2);color:var(--text);border-color:var(--border);
}
body.light .toast,body.tg-theme.light .toast{
  background:#fff;color:var(--text);border:1px solid var(--border);
}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}

/* ===== CONTAINER ===== */
.container{max-width:1200px;margin:0 auto;padding:8px 16px 0;overflow-x:hidden}

/* ===== HEADER ===== */
.header{
  background:linear-gradient(135deg,#10102e 0%,#181850 50%,#10102e 100%);
  border-bottom:1px solid var(--border);padding:14px 16px;
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}
.header-logo{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.3px}
.header-logo span{color:var(--accent)}
.user-pill{
  display:flex;align-items:center;gap:6px;
  background:transparent;border:none;
  padding:0;font-size:13px;color:var(--text2);
  flex-shrink:0;
}
.user-pill img{width:28px;height:28px;border-radius:50%}

/* ===== SECTION TITLES ===== */
.section-title{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.6px;
  color:var(--text3);margin:28px 0 14px;padding-left:2px;
  display:flex;align-items:center;gap:10px;
}
.section-title::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 20px;border-radius:var(--radius-sm);border:1px solid var(--border);
  background:var(--card);color:var(--text);font-size:14px;font-weight:500;
  cursor:pointer;transition:all var(--transition);white-space:nowrap;
  user-select:none;-webkit-user-select:none;
}
.btn:hover{border-color:var(--border-hover);background:#1c1c48}
.btn:active{transform:scale(0.97)}

.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent2);border-color:var(--accent2)}

.btn-danger{background:rgba(248,113,113,0.12);color:var(--red);border-color:rgba(248,113,113,0.25)}
.btn-danger:hover{background:rgba(248,113,113,0.22);border-color:var(--red)}

.btn-green{background:rgba(52,211,153,0.12);color:var(--green);border-color:rgba(52,211,153,0.25)}
.btn-green:hover{background:rgba(52,211,153,0.22);border-color:var(--green)}

.btn-purple{background:rgba(167,139,250,0.12);color:var(--purple);border-color:rgba(167,139,250,0.25)}
.btn-purple:hover{background:rgba(167,139,250,0.22);border-color:var(--purple)}

.btn-orange{background:rgba(251,146,60,0.12);color:var(--orange);border-color:rgba(251,146,60,0.25)}
.btn-orange:hover{background:rgba(251,146,60,0.22);border-color:var(--orange)}

.btn-ai{
  background:linear-gradient(135deg,var(--accent),var(--purple));
  color:#fff;border:none;font-weight:600;
  box-shadow:0 2px 16px rgba(124,131,255,0.3);
}
.btn-ai:hover{box-shadow:0 4px 24px rgba(124,131,255,0.45);filter:brightness(1.1)}

.btn-analytics{
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  color:#fff;border:none;font-weight:600;
  text-shadow:0 1px 2px rgba(0,0,0,0.3);
}
.btn-analytics:hover{filter:brightness(1.12)}

.btn-sm{padding:7px 14px;font-size:13px;border-radius:var(--radius-xs)}
.btn-xs{padding:4px 10px;font-size:12px;border-radius:6px}

/* ===== CARDS ===== */
.project-card{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--radius);padding:20px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:all var(--transition);position:relative;overflow:hidden;
}
.project-card::before{
  content:'';position:absolute;inset:0;border-radius:var(--radius);
  background:radial-gradient(ellipse at 30% 0%,rgba(124,131,255,0.06),transparent 60%);
  pointer-events:none;
}
.project-card:hover{
  border-color:var(--border-hover);
  box-shadow:0 0 0 1px var(--border-hover),var(--shadow);
  transform:translateY(-2px);
}

.stat-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:16px;text-align:center;
}
.stat-card .stat-number{font-size:26px;font-weight:700;color:var(--text);line-height:1.2}
.stat-card .stat-label{font-size:12px;color:var(--text2);margin-top:4px}

/* ===== SUMMARY GRID ===== */
.summary-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0;
}
.summary-card{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--radius-sm);padding:14px 12px;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;flex-direction:column;gap:4px;
}
.summary-card .summary-icon{font-size:18px;line-height:1}
.summary-card .summary-value{font-size:20px;font-weight:700;color:var(--text)}
.summary-card .summary-label{font-size:11px;color:var(--text2);line-height:1.3}
.summary-card .summary-delta{font-size:11px;font-weight:600}
.summary-card .summary-delta.up{color:var(--green)}
.summary-card .summary-delta.down{color:var(--red)}

/* ===== CHART CARDS ===== */
.chart-card{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--radius);overflow:hidden;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  margin-bottom:16px;
}
.chart-card .chart-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 12px;border-bottom:1px solid var(--border);
}
.chart-card .chart-title{font-size:15px;font-weight:600;color:var(--text)}
.chart-card .chart-body{padding:14px;position:relative;min-height:180px}
.chart-card canvas{width:100%!important;max-height:300px}

/* ===== HEATMAP ===== */
.heatmap-wrapper{overflow-x:auto;padding:4px 0}
.heatmap-grid{
  display:grid;grid-template-columns:repeat(24,1fr);gap:3px;min-width:500px;
}
.heatmap-cell{
  aspect-ratio:1;border-radius:4px;transition:all var(--transition);
  cursor:pointer;position:relative;
}
.heatmap-cell:hover{transform:scale(1.25);z-index:2;box-shadow:var(--shadow)}
.heatmap-cell[data-level="0"]{background:var(--bg3)}
.heatmap-cell[data-level="1"]{background:rgba(124,131,255,0.2)}
.heatmap-cell[data-level="2"]{background:rgba(124,131,255,0.4)}
.heatmap-cell[data-level="3"]{background:rgba(124,131,255,0.6)}
.heatmap-cell[data-level="4"]{background:var(--accent)}
.heatmap-legend{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:11px;color:var(--text3)}
.heatmap-legend .legend-cell{width:14px;height:14px;border-radius:3px}

/* ===== TAB BAR ===== */
.tab-bar{
  display:flex;gap:4px;padding:4px;
  background:var(--bg3);border-radius:var(--radius-sm);
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}
.tab-bar::-webkit-scrollbar{display:none}
.tab-item{
  padding:9px 18px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;
  color:var(--text2);cursor:pointer;transition:all var(--transition);
  white-space:nowrap;border:none;background:none;
}
.tab-item:hover{color:var(--text)}
.tab-item.active{background:var(--accent);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(124,131,255,0.3)}

/* ===== MODALS ===== */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:flex-end;justify-content:center;
  animation:fadeIn 0.2s ease;
}
.modal{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius) var(--radius) 0 0;
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  padding:24px 20px calc(24px + env(safe-area-inset-bottom));
  animation:slideUp 0.3s cubic-bezier(0.32,0.72,0,1);
}
.stats-modal{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius) var(--radius) 0 0;
  width:100%;max-width:580px;max-height:90vh;overflow-y:auto;
  padding:24px 20px calc(24px + env(safe-area-inset-bottom));
  animation:slideUp 0.3s cubic-bezier(0.32,0.72,0,1);
}
/* AI response styling */
.ai-response{word-wrap:break-word;overflow-wrap:break-word}
.ai-response b{color:var(--accent);font-weight:700}
.ai-response a{color:var(--blue);text-decoration:underline;word-break:break-all}
.ai-response a:hover{color:var(--cyan)}
.ai-response p{margin:6px 0}

/* Hide number input spinners */
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}

/* SVG inline icons */
svg{vertical-align:middle;display:inline-block;flex-shrink:0}
span > svg{margin:-2px 2px 0 0}
.mi-icon svg,.menu-icon svg{width:18px;height:18px}
.btn svg{width:16px;height:16px;margin:-1px 4px 0 0}
.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 18px}
.modal-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:16px}
.modal-close{
  width:32px;height:32px;
  border-radius:50%;background:var(--bg3);border:1px solid var(--border);
  color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all var(--transition);flex-shrink:0;font-size:16px;
}
.modal-close:hover{background:var(--card);color:var(--text)}

/* ===== STATS MODAL ===== */
.stats-modal .stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.stats-modal .stat-grid .stat-card{background:var(--bg3);border:1px solid var(--border)}
.stats-modal .top-posts-list{display:flex;flex-direction:column;gap:10px}

/* ===== MENU ITEMS ===== */
.menu-item{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  border-radius:var(--radius-sm);cursor:pointer;
  transition:all var(--transition);color:var(--text);
  background:var(--card);border:1px solid var(--border);
  width:100%;text-align:left;font-family:inherit;font-size:inherit;
  box-sizing:border-box;margin-bottom:6px;
}
.menu-item:hover,.menu-item:focus{background:rgba(124,131,255,0.12);border-color:var(--border-hover);outline:none}
.menu-item:active{transform:scale(0.98)}
.menu-item .menu-icon,.menu-item .mi-icon{width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);border:1px solid var(--border);font-size:16px;flex-shrink:0}
.menu-item .menu-text,.menu-item .mi-text{flex:1;font-size:14px;font-weight:500;color:var(--text)}
.menu-item .menu-text .menu-label{font-size:14px;font-weight:500}
.menu-item .menu-text .menu-desc{font-size:12px;color:var(--text2)}
.menu-item .menu-arrow,.menu-item .mi-arrow{color:var(--text3);font-size:16px;flex-shrink:0}
/* icon color variants */
.mi-purple{background:rgba(167,139,250,0.15)!important;border-color:rgba(167,139,250,0.25)!important;color:#a78bfa}
.mi-blue{background:rgba(96,165,250,0.15)!important;border-color:rgba(96,165,250,0.25)!important;color:#60a5fa}
.mi-cyan{background:rgba(34,211,238,0.15)!important;border-color:rgba(34,211,238,0.25)!important;color:#22d3ee}
.mi-green{background:rgba(52,211,153,0.15)!important;border-color:rgba(52,211,153,0.25)!important;color:#34d399}
.mi-orange{background:rgba(251,146,60,0.15)!important;border-color:rgba(251,146,60,0.25)!important;color:#fb923c}
.mi-pink{background:rgba(244,114,182,0.15)!important;border-color:rgba(244,114,182,0.25)!important;color:#f472b6}
.mi-red{background:rgba(248,113,113,0.15)!important;border-color:rgba(248,113,113,0.25)!important;color:#f87171}
.mi-yellow{background:rgba(251,191,36,0.15)!important;border-color:rgba(251,191,36,0.25)!important;color:#fbbf24}
.mi-indigo{background:rgba(99,102,241,0.15)!important;border-color:rgba(99,102,241,0.25)!important;color:#6366f1}

/* ===== PLAN BADGES ===== */
.plan-badge{
  display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;
  font-size:11px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase;
}
.plan-free{background:rgba(85,85,170,0.15);color:var(--text3);border:1px solid rgba(85,85,170,0.25)}
.plan-starter{background:rgba(96,165,250,0.15);color:var(--blue);border:1px solid rgba(96,165,250,0.25)}
.plan-pro{background:rgba(124,131,255,0.15);color:var(--accent);border:1px solid rgba(124,131,255,0.3)}
.plan-unlimited{
  background:linear-gradient(135deg,rgba(124,131,255,0.2),rgba(167,139,250,0.2));
  color:var(--purple);border:1px solid rgba(167,139,250,0.3);
}

/* ===== STATUS BADGES ===== */
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:500}
.status-ok{background:rgba(52,211,153,0.12);color:var(--green)}
.status-ok::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
.status-warn{background:rgba(251,191,36,0.12);color:var(--yellow)}
.status-warn::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--yellow)}
.status-off{background:rgba(248,113,113,0.12);color:var(--red)}
.status-off::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--red)}

/* ===== TOAST NOTIFICATIONS ===== */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);
  z-index:3000;padding:12px 24px;border-radius:var(--radius-sm);
  background:var(--card);border:1px solid var(--border);
  color:var(--text);font-size:13px;font-weight:500;
  box-shadow:var(--shadow-lg);transition:transform 0.35s ease,opacity 0.35s ease;
  opacity:0;pointer-events:none;white-space:nowrap;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}

/* ===== REAL-TIME BANNER ===== */
.rt-banner{
  padding:10px 16px;font-size:13px;font-weight:500;text-align:center;
  display:flex;align-items:center;justify-content:center;gap:8px;
  animation:fadeIn 0.3s ease;
}
.rt-banner.success{background:rgba(52,211,153,0.1);color:var(--green);border-bottom:1px solid rgba(52,211,153,0.2)}
.rt-banner.info{background:rgba(96,165,250,0.1);color:var(--blue);border-bottom:1px solid rgba(96,165,250,0.2)}
.rt-banner.warning{background:rgba(251,191,36,0.1);color:var(--yellow);border-bottom:1px solid rgba(251,191,36,0.2)}
.rt-banner.error{background:rgba(248,113,113,0.1);color:var(--red);border-bottom:1px solid rgba(248,113,113,0.2)}

/* ===== LOADING & SKELETON ===== */
.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text3)}
.spinner{width:24px;height:24px;border:2.5px solid var(--border);
  border-top-color:var(--accent);border-radius:50%;animation:spin 0.7s linear infinite}

.skeleton{
  background:linear-gradient(90deg,var(--bg3) 25%,var(--card) 50%,var(--bg3) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-xs);
}
.skeleton-card{height:120px;border-radius:var(--radius)}
.skeleton-line{height:14px;margin-bottom:10px}
.skeleton-line.short{width:60%}
.skeleton-chart{height:200px;border-radius:var(--radius)}

/* ===== FORMS ===== */
input[type="text"],input[type="number"],input[type="search"],
input[type="url"],input[type="email"],input[type="password"],
select,textarea{
  width:100%;padding:11px 14px;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-xs);
  color:var(--text);font-size:14px;font-family:inherit;
  transition:all var(--transition);outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,131,255,0.15);
}
input::placeholder,textarea::placeholder{color:var(--text3)}
select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%235555aa'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}

/* ===== ADMIN ROWS ===== */
.admin-card{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  margin-bottom:8px;
}
.admin-card .admin-name{flex:1;font-size:14px;font-weight:500;color:var(--text)}
.admin-card .admin-role{font-size:12px;color:var(--text2)}
.perm-pill{
  padding:4px 10px;border-radius:100px;font-size:11px;font-weight:600;cursor:pointer;
  border:1px solid var(--border);background:var(--bg3);color:var(--text2);
  transition:all var(--transition);
}
.perm-pill.active{background:rgba(124,131,255,0.15);color:var(--accent);border-color:rgba(124,131,255,0.3)}

/* ===== TOP POSTS ===== */
.top-post{
  display:flex;align-items:flex-start;gap:12px;padding:12px 14px;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);
}
.top-post .rank-badge{
  width:28px;height:28px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--text);
  background:var(--card);border:1px solid var(--border);
}
.top-post .rank-badge.gold{background:linear-gradient(135deg,#b8860b,#daa520);color:#fff;border:none}
.top-post .rank-badge.silver{background:linear-gradient(135deg,#6b7280,#9ca3af);color:#fff;border:none}
.top-post .rank-badge.bronze{background:linear-gradient(135deg,#92400e,#b45309);color:#fff;border:none}
.top-post .post-body{flex:1;min-width:0}
.top-post .post-text{font-size:13px;color:var(--text);line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.top-post .post-meta{font-size:11px;color:var(--text2);margin-top:4px;display:flex;gap:10px}
.top-post .post-link{flex-shrink:0}

/* ===== TODAY STRIP ===== */
.today-strip{
  display:flex;gap:0;padding:0;overflow:hidden;
  background:rgba(124,131,255,0.10);
  border:1px solid var(--border2);border-radius:var(--radius-xs);margin:8px 0;
  font-size:12px;color:var(--text2);flex-wrap:wrap;
}
.today-strip .today-label{
  width:100%;padding:5px 10px 2px;font-size:11px;color:var(--text2);font-weight:500;
}
.today-strip .today-nums{
  display:flex;width:100%;padding:2px 10px 6px;gap:0;justify-content:space-between;
}
.today-strip .today-nums span{flex:1;text-align:center;white-space:nowrap;font-size:13px}
.today-strip .today-nums b{color:var(--text);font-weight:700}
.today-strip::-webkit-scrollbar{display:none}
.today-strip .today-metric{white-space:nowrap;text-align:center;min-width:70px}
.today-strip .today-metric .today-val{font-size:18px;font-weight:700;color:var(--text)}
.today-strip .today-metric .today-lbl{font-size:11px;color:var(--text2)}

/* ===== GLOBAL STATS BAR ===== */
.global-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:16px 0;
}
.global-stat{text-align:center;padding:16px 8px;
  background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.global-stat .gs-number{font-size:28px;font-weight:700;color:var(--text);line-height:1.1}
.global-stat .gs-label{font-size:11px;color:var(--text2);margin-top:4px}

/* ===== FOOTER ===== */
.footer{
  text-align:center;padding:28px 16px calc(28px + env(safe-area-inset-bottom));
  font-size:12px;color:var(--text3);
}

/* ===== UTILITY ===== */
.hidden{display:none!important}

/* ===== INDEX: HEADER LAYOUT ===== */
.header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.header-brand{display:flex;align-items:center;gap:10px}
.header-brand h1{font-size:17px;font-weight:700;color:var(--text);margin:0;line-height:1.2}
.header-brand p{font-size:11px;color:var(--text2);margin:0}
.user-pill .name{font-size:13px;color:var(--text)}
.role-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 12px;border-radius:100px;font-size:11px;font-weight:600;
  background:rgba(124,131,255,0.12);color:var(--accent);
  border:1px solid rgba(124,131,255,0.2);
  white-space:nowrap;
}
.role-bot_owner{
  background:linear-gradient(135deg,rgba(167,139,250,0.15),rgba(124,131,255,0.15));
  color:var(--purple);border-color:rgba(167,139,250,0.3);
}
.role-project_owner{background:rgba(96,165,250,0.12);color:var(--blue);border-color:rgba(96,165,250,0.25)}
.role-admin{background:rgba(52,211,153,0.12);color:var(--green);border-color:rgba(52,211,153,0.25)}
.role-none{background:rgba(85,85,170,0.15);color:var(--text3)}
.sse-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.sse-dot.live{background:var(--green);animation:pulse 2s infinite}

/* ===== INDEX: GLOBAL BAR (bot_owner stats) ===== */
.global-bar{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px;
}
.global-card{
  text-align:center;padding:12px 6px;
  background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);
  overflow:hidden;
}
.global-card .val{font-size:22px;font-weight:700;line-height:1.2;white-space:nowrap}
.global-card .lbl{font-size:10px;color:var(--text2);margin-top:3px;text-transform:uppercase;letter-spacing:0.3px;white-space:nowrap}

/* ===== INDEX: OWNER PANEL ===== */
.owner-panel{
  display:flex;flex-direction:column;gap:6px;margin-bottom:16px;
}
.owner-row{display:flex;gap:6px}
.owner-row .btn{flex:1;justify-content:center}

/* ===== INDEX: CREATE ROW ===== */
.create-row{display:flex;gap:8px;align-items:center;margin-bottom:16px}
.create-row .btn-primary{flex:1}
.create-row .btn-sm{flex-shrink:0}

/* ===== INDEX: PROJECTS GRID ===== */
.projects-grid{display:flex;flex-direction:column;gap:14px}

/* ===== INDEX: PROJECT CARD INNER ===== */
.project-card .pc-top{
  display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;
}
.project-card .pc-name{font-size:16px;font-weight:700;color:var(--text)}
.project-card .pc-channel{font-size:13px;color:var(--text2);margin-bottom:8px}
.project-card .pc-channel .status{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:100px;font-size:11px;font-weight:500;margin-left:6px;
}
.project-card .pc-channel .status-ok{background:rgba(52,211,153,0.12);color:var(--green)}
.project-card .pc-channel .status-ok::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green)}
.project-card .pc-channel .status-warn{background:rgba(251,191,36,0.12);color:var(--yellow)}
.project-card .pc-channel .status-warn::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--yellow)}
.project-card .pc-stats{
  display:flex;gap:14px;font-size:13px;color:var(--text2);flex-wrap:wrap;
}
.project-card .pc-stats .num{font-weight:600;color:var(--text)}
.today-row{
  display:flex;align-items:center;gap:8px;margin-top:4px;
}
.today-row span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.refresh-btn{
  flex-shrink:0;width:32px;height:32px;border:1px solid var(--border2);
  border-radius:var(--radius-xs);background:var(--bg2);color:var(--text);
  font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:var(--transition);
}
.refresh-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.refresh-btn:disabled{opacity:0.5;cursor:not-allowed}
.project-card .pc-actions{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:12px;
}
.project-card .pc-actions .btn{
  min-width:0;overflow:hidden;text-overflow:ellipsis;
  justify-content:center;width:100%;padding:9px 8px;font-size:13px;
}
.project-card .pc-actions .btn-full{grid-column:1/-1}
.project-card .pc-actions .extra-btn{animation:fadeIn 0.15s ease}
.pc-quick-actions{width:100%;margin-top:6px;grid-column:1/-1}
@media(min-width:480px){
  .project-card .pc-actions{grid-template-columns:1fr 1fr 1fr;gap:8px}
}

/* Prevent overflow on mobile */
.project-card{overflow:hidden;word-break:break-word}
.project-card .pc-channel{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== INDEX: EMPTY STATE ===== */
.empty{
  text-align:center;padding:40px 20px;color:var(--text2);
}
.empty h2{font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}
.empty p{font-size:14px;color:var(--text2);margin-bottom:12px;line-height:1.6}

/* ===== MODALS: header & actions ===== */
.modal-header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:18px;position:relative;
}
.modal-header h2{font-size:18px;font-weight:700;color:var(--text)}
.modal-header .modal-close{position:static;flex-shrink:0}
.modal-actions{
  display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:18px;
}

/* ===== MODALS: stat sections ===== */
.stat-section{
  font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;
  color:var(--text3);margin:18px 0 10px;padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}
.stat-card .val{font-size:22px;font-weight:700;line-height:1.2}
.stat-card .lbl{font-size:11px;color:var(--text2);margin-top:2px;text-transform:uppercase;letter-spacing:0.3px}
.subtitle{font-size:13px;color:var(--text2);margin-bottom:16px}

/* ===== INDEX: MY STATS MODAL ===== */
.my-chart-wrap{margin-bottom:16px;background:var(--bg3);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border)}
.my-chart-wrap canvas{width:100%!important}
.top-post-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);
  margin-bottom:6px;
}
.top-post-item .rank{
  font-weight:700;color:var(--accent);min-width:28px;flex-shrink:0;
}
.top-post-item .top-post-text{flex:1;font-size:13px;color:var(--text);line-height:1.4}
.top-post-item .top-post-meta{font-size:11px;color:var(--text2);margin-top:3px}
.top-post-item .top-post-link{
  padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;
  background:rgba(124,131,255,0.15);color:var(--accent);border:1px solid rgba(124,131,255,0.25);
  cursor:pointer;white-space:nowrap;flex-shrink:0;
}
.perm-list{font-size:13px;line-height:2;color:var(--text);padding:8px 0}

/* ===== DASHBOARD: GENERIC CARD ===== */
.card{
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--radius);padding:18px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  margin-bottom:12px;overflow:hidden;
}
.card h3{font-size:15px;font-weight:600;color:var(--text);margin-bottom:14px}
.card canvas{width:100%!important;max-height:300px}
.card.fw{grid-column:1/-1}

/* ===== DASHBOARD: CHARTS GRID ===== */
.charts{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
  padding:0 16px 16px;
}
@media(max-width:600px){
  .charts{grid-template-columns:1fr}
}

/* ===== DASHBOARD: HEADER (back, info, channel) ===== */
.header .back{
  color:var(--text2);font-size:20px;text-decoration:none;margin-right:12px;
  display:inline-flex;align-items:center;
}
.header .back:hover{color:var(--text)}
.header .info{flex:1}
.header .info h1{font-size:17px;font-weight:700;color:var(--text);margin:0}
.header .info .channel{font-size:12px;color:var(--accent)}

/* ===== DASHBOARD: TABS ===== */
.tabs{
  display:flex;gap:4px;padding:12px 16px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}
.tabs::-webkit-scrollbar{display:none}
.tabs button{
  padding:7px 16px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;
  color:var(--text2);cursor:pointer;transition:all var(--transition);
  white-space:nowrap;border:1px solid var(--border);background:var(--card);
  font-family:inherit;
}
.tabs button:hover{color:var(--text);border-color:var(--border-hover)}
.tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}

/* ===== DASHBOARD: HEATMAP ===== */
.heatmap-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}
.heatmap{
  display:grid;grid-template-columns:auto repeat(24,1fr);gap:3px;
  min-width:560px;align-items:center;
}
.heatmap .hl{font-size:10px;color:var(--text3);text-align:center;padding:2px 0}
.heatmap .dl{font-size:10px;color:var(--text2);text-align:right;padding-right:6px;white-space:nowrap}
.heatmap .c{
  aspect-ratio:1;border-radius:3px;cursor:pointer;
  transition:transform 0.15s,box-shadow 0.15s;min-width:14px;min-height:14px;
}
.heatmap .c:hover{transform:scale(1.3);z-index:2;box-shadow:0 0 8px rgba(250,204,21,0.4)}

/* ===== DASHBOARD: TOOLTIP ===== */
.tip{
  display:none;position:fixed;z-index:500;
  padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;
  background:rgba(15,15,30,0.95);color:#fff;border:1px solid var(--border);
  box-shadow:var(--shadow);pointer-events:none;white-space:nowrap;
  max-width:calc(100vw - 20px);
}

/* ===== DASHBOARD: LIVE INDICATOR ===== */
.live{
  position:fixed;bottom:16px;right:16px;z-index:200;
  display:flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:100px;font-size:11px;font-weight:600;
  background:rgba(15,15,30,0.9);border:1px solid var(--glass-border);
  color:var(--text2);letter-spacing:0.5px;
}
.live-dot{
  width:7px;height:7px;border-radius:50%;background:var(--green);
  animation:pulse 2s infinite;
}

/* ===== DASHBOARD: ER BADGES ===== */
.er-badge{
  display:inline-flex;padding:2px 8px;border-radius:100px;
  font-size:11px;font-weight:700;
}
.er-h{background:rgba(52,211,153,0.15);color:var(--green)}
.er-m{background:rgba(251,191,36,0.15);color:var(--yellow)}
.er-l{background:rgba(248,113,113,0.15);color:var(--red)}

/* ===== DASHBOARD: POST LINK ===== */
.post-link-btn{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;
  background:rgba(124,131,255,0.12);color:var(--accent);
  border:1px solid rgba(124,131,255,0.2);cursor:pointer;
  text-decoration:none;transition:all var(--transition);white-space:nowrap;
}
.post-link-btn:hover{background:rgba(124,131,255,0.25);color:var(--accent)}

/* ===== PAYMENT ===== */
.pay-method{
  padding:14px;border-radius:12px;border:1px solid var(--border);
  background:var(--card);cursor:pointer;text-align:center;
  transition:all var(--transition);
}
.pay-method:hover{border-color:var(--border-hover)}
.pay-method.selected{border-color:var(--accent);background:rgba(124,131,255,0.1);box-shadow:0 0 0 2px rgba(124,131,255,0.2)}
.pay-copy{
  color:var(--accent);cursor:pointer;font-size:12px;font-weight:500;
  text-decoration:underline;text-underline-offset:2px;
}
.pay-copy:hover{color:var(--blue)}

/* ===== ADMIN MANAGE ===== */
.admin-row{
  padding:14px;background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-sm);margin-bottom:8px;
}
.admin-row-header{
  display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;
}
.admin-row .admin-name{font-size:14px;font-weight:600;color:var(--text)}
.admin-row .admin-username{font-size:13px;color:var(--accent)}
.perm-toggle{
  padding:4px 10px;border-radius:100px;font-size:11px;font-weight:500;cursor:pointer;
  border:1px solid var(--border);background:var(--bg3);color:var(--text2);
  transition:all var(--transition);margin:2px;
}
.perm-toggle.active{background:rgba(52,211,153,0.15);color:var(--green);border-color:rgba(52,211,153,0.25)}
.perm-toggle.inactive{background:var(--bg3);color:var(--text3);border-color:var(--border)}

/* ===== TAB BTN (cleaner) ===== */
.tab-btn{
  flex:1;padding:8px 16px;border-radius:var(--radius-xs);font-size:13px;font-weight:500;
  color:var(--text2);cursor:pointer;transition:all var(--transition);
  white-space:nowrap;border:1px solid var(--border);background:var(--card);
  font-family:inherit;text-align:center;
}
.tab-btn:hover{color:var(--text);border-color:var(--border-hover)}
.tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}

/* ===== RT-BANNER SHOW ===== */
.rt-banner{display:none}
.rt-banner.show{display:flex}

/* ===== CHART.JS OVERRIDES ===== */
.chart-card canvas{height:auto!important}

/* ===== ANIMATIONS ===== */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
svg.spin{animation:spin 1s linear infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeOut{to{opacity:0;visibility:hidden}}

/* ===== RESPONSIVE ===== */
@media(max-width:380px){
  .global-bar{grid-template-columns:repeat(2,1fr)}
  .global-card .val{font-size:20px}
  .stat-grid{grid-template-columns:1fr 1fr;gap:6px}
  .project-card .pc-actions{gap:4px}
  .project-card .pc-actions .btn{padding:6px 10px;font-size:12px}
}

@media(min-width:400px){
  .summary-grid{gap:12px}
  .summary-card .summary-value{font-size:22px}
}

@media(min-width:480px){
  .summary-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .container{padding:0 20px}
  .modal{padding:28px 24px}
}

@media(min-width:768px){
  .modal-overlay{align-items:center}
  .modal,.stats-modal{border-radius:var(--radius);max-height:92vh}
  .modal-handle{display:none}
  .summary-grid{grid-template-columns:repeat(6,1fr)}
  .stats-modal .stat-grid{grid-template-columns:repeat(4,1fr)}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
  .global-stats{gap:14px}
  .global-stat .gs-number{font-size:34px}
  .global-bar{gap:12px}
  .global-card .val{font-size:28px}
  body{font-size:15px}
}

@media(min-width:1200px){
  .container{padding:0 32px}
  .chart-card .chart-body{padding:20px}
  .project-card{padding:24px}
}

/* Wide screens (1.5K+, 2K, 2.5K) — модалки розтягуються щоб не виглядали вузькою колонкою */
@media(min-width:1400px){
  .modal{max-width:760px !important}
  .stats-modal{max-width:880px !important}
}
@media(min-width:1800px){
  .modal{max-width:880px !important}
  .stats-modal{max-width:1040px !important}
}
