:root {
  --pink: #E91E63;
  --pink-dark: #C2185B;
  --pink-light: #FF6B9D;
  --yellow: #FFD93D;
  --blue: #5DADE2;
  --navy: #0D1B3D;
  --bg: #FFFFFF;
  --text: #1F2937;
  --muted: #6B7280;
  --border: #E5E7EB;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Inter, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}

main { max-width: 480px; margin: 0 auto; padding: 24px 20px 48px; }

header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  max-width: 480px;
  margin: 0 auto;
}

.logo { height: 40px; width: auto; }

.logout {
  color: var(--muted);
  text-decoration: none;
  font-size: 14px;
}
.logout:hover { color: var(--pink); }

h1 { font-size: 28px; margin: 8px 0 24px; color: var(--navy); }
h2 { font-size: 18px; margin: 32px 0 12px; color: var(--navy); }

/* Hero card on the model page */
.hero-card {
  background: linear-gradient(135deg, var(--pink) 0%, var(--yellow) 100%);
  color: white;
  border-radius: 24px;
  padding: 28px 24px;
  text-align: center;
  box-shadow: 0 12px 32px rgba(233, 30, 99, 0.25);
}
.hero-card .label {
  font-size: 14px;
  opacity: 0.95;
  margin: 0;
  text-transform: capitalize;
}
.hero-card .big-number {
  font-size: 56px;
  font-weight: 800;
  margin: 8px 0;
  letter-spacing: -1px;
  line-height: 1.1;
}
.hero-card .forecast { font-size: 15px; opacity: 0.95; margin: 0; }

.past-months { margin-top: 24px; }
.past-months ul { list-style: none; padding: 0; margin: 0; }
.past-months li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  border-radius: 12px;
  background: #F9FAFB;
  margin-bottom: 8px;
}
.past-months li strong { color: var(--pink); font-size: 18px; }
.past-months .empty { color: var(--muted); }

footer { margin-top: 32px; text-align: center; color: var(--muted); }

/* Forms */
form { display: flex; flex-direction: column; gap: 12px; max-width: 320px; }

input[type="password"],
input[type="number"] {
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: 16px;
  outline: none;
  width: 100%;
}
input:focus { border-color: var(--pink); }

button {
  background: var(--pink);
  color: white;
  border: 0;
  padding: 14px;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: background 120ms ease;
}
button:hover { background: var(--pink-dark); }
button:active { transform: translateY(1px); }

.error { color: #DC2626; font-size: 14px; }
.success { color: #059669; font-size: 14px; }

/* Login + home pages */
.login-page main, .home-page main {
  text-align: center;
  padding-top: 64px;
}
.login-page form, .home-page form { margin: 24px auto 0; }

/* Admin */
.admin-page header {
  border-bottom: 1px solid var(--border);
  padding-bottom: 12px;
}
.admin-page table {
  width: 100%;
  border-collapse: collapse;
  max-width: 360px;
  margin-bottom: 16px;
}
.admin-page td {
  padding: 10px 0;
  vertical-align: middle;
}
.admin-page td:first-child {
  font-weight: 600;
}
.admin-page td:last-child {
  text-align: right;
  white-space: nowrap;
}
.admin-page input[type="number"] {
  width: 80px;
  text-align: right;
  display: inline-block;
}

.snapshot-info {
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}
.snapshot-info form { margin-top: 8px; }
.snapshot-info button {
  background: var(--blue);
  font-size: 14px;
  padding: 10px 16px;
}
.snapshot-info button:hover { background: #4A90C2; }

/* Mobile tweaks */
@media (max-width: 380px) {
  .hero-card .big-number { font-size: 44px; }
  h1 { font-size: 24px; }
  main { padding: 16px 16px 36px; }
}
/* style.css — BubbleTeam дашборд модели (additions to existing style.css).
   Полная палитра + все блоки страницы /m/:slug.
   Шрифты подключаются в HTML head: Inter + Space Grotesk. */

:root {
  /* Бренд (текущая палитра) */
  --bt-pink:        #E91E63;
  --bt-pink-dark:   #C2185B;
  --bt-pink-light:  #FF6B9D;
  --bt-pink-soft:   #FFD3E2;
  --bt-yellow:      #FFD93D;
  --bt-yellow-soft: #FFF4C2;
  --bt-blue:        #5DADE2;
  --bt-blue-soft:   #CFE6F5;
  --bt-navy:        #0D1B3D;

  --bt-bg:        #FFFFFF;
  --bt-surface:   #FFF9FB;
  --bt-text:      #0D1B3D;
  --bt-muted:     #6B7280;
  --bt-border:    rgba(13,27,61,.08);

  --bt-radius-l:  22px;
  --bt-radius-m:  18px;
  --bt-radius-s:  14px;

  --font-display: 'Space Grotesk','Inter',system-ui,-apple-system,sans-serif;
  --font-text:    'Inter',system-ui,-apple-system,sans-serif;
}

.model-page { background: var(--bt-bg); color: var(--bt-text); font-family: var(--font-text); }
.model-page main { display: flex; flex-direction: column; gap: 22px; max-width: 480px; margin: 0 auto; padding: 4px 16px 36px; }

/* Header */
.m-header { display:flex; align-items:center; justify-content:space-between; padding:12px 16px 14px; max-width:480px; margin:0 auto; }
.brand { display:flex; align-items:center; gap:10px; }
.brand .logo { width:36px; height:36px; object-fit:contain; }
.brand-txt { display:flex; flex-direction:column; line-height:1.1; }
.brand-name { font-size:11px; color:var(--bt-muted); font-weight:500; }
.hello { font-size:15px; font-weight:600; color:var(--bt-text); }
.iconbtn { width:36px; height:36px; border-radius:12px; display:grid; place-items:center; background:var(--bt-surface); border:1px solid var(--bt-border); color:var(--bt-muted); text-decoration:none; }

/* Hero */
.hero { position:relative; border-radius:26px; padding:26px 22px; color:#fff; overflow:hidden;
  background: linear-gradient(135deg, var(--bt-pink) 0%, var(--bt-pink-light) 55%, var(--bt-yellow) 100%);
  box-shadow: 0 18px 40px rgba(233,30,99,.2), 0 2px 0 rgba(255,255,255,.4) inset; }
.hero-bubbles::before, .hero-bubbles::after { content:""; position:absolute; border-radius:50%; pointer-events:none; }
.hero-bubbles::before { top:-30px; right:-20px; width:110px; height:110px; background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.45), transparent 60%); }
.hero-bubbles::after  { bottom:-40px; left:-30px; width:140px; height:140px; background: radial-gradient(circle at 35% 30%, rgba(255,255,255,.18), transparent 65%); }
.hero-label { margin:0; font-size:13px; font-weight:500; opacity:.92; }
.hero-big { font-family:var(--font-display); font-size:56px; font-weight:600; letter-spacing:-2px; margin:4px 0 0; line-height:1; font-variant-numeric: tabular-nums; }
.hero-big .cents { font-size:26px; opacity:.78; font-weight:500; margin-left:4px; }
.hero-empty { font-family:var(--font-display); font-size:34px; font-weight:600; margin:6px 0 4px; line-height:1.05; }
.hero-forecast { margin:14px 0 0; font-size:14px; font-weight:500; opacity:.95; }
.hero-delta { display:inline-flex; align-items:center; gap:6px; margin-top:12px; padding:6px 12px; border-radius:999px; background:rgba(255,255,255,.22); backdrop-filter:blur(8px); font-size:12.5px; font-weight:600; }

/* Sections */
.sec-title { margin: 0 0 4px; font-size:13px; font-weight:600; letter-spacing:.4px; text-transform:uppercase; color:var(--bt-muted); }
.sec-sub { margin:0 0 10px; font-size:12px; color:var(--bt-muted); }
.card { background:var(--bt-surface); border:1px solid var(--bt-border); border-radius:var(--bt-radius-m); padding:18px; box-shadow:0 1px 2px rgba(13,27,61,.04); }

/* Donut */
.donut { width:100%; display:block; }
.donut-cap { font-size:11px; fill:var(--bt-muted); font-weight:500; }
.donut-total { font-family:var(--font-display); font-size:22px; fill:var(--bt-text); font-weight:600; }
.legend { list-style:none; padding:0; margin:12px 0 0; display:grid; grid-template-columns:1fr 1fr; gap:10px 14px; }
.legend li { display:flex; align-items:center; gap:8px; }
.lg-dot { width:10px; height:10px; border-radius:3px; flex:none; }
.lg-body { display:flex; flex-direction:column; min-width:0; }
.lg-label { font-size:12.5px; font-weight:500; color:var(--bt-text); }
.lg-val   { font-size:11.5px; color:var(--bt-muted); font-variant-numeric:tabular-nums; }

/* Platforms */
.platforms { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.plat { border-radius:var(--bt-radius-s); padding:14px; }
.plat-of     { background:var(--bt-pink-soft); }
.plat-fansly { background:var(--bt-blue-soft); }
.plat-dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:7px; vertical-align:middle; }
.plat-of .plat-dot     { background:var(--bt-pink); }
.plat-fansly .plat-dot { background:var(--bt-blue); }
.plat-name { font-size:12px; font-weight:600; letter-spacing:.3px; }
.plat-val { font-family:var(--font-display); font-size:22px; font-weight:600; margin-top:8px; letter-spacing:-.5px; font-variant-numeric:tabular-nums; }

/* Months list */
.months { display:flex; flex-direction:column; }
.m-row { display:grid; grid-template-columns:64px 1fr auto; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--bt-border); }
.m-row.is-last { border-bottom:none; }
.m-name { font-size:13px; font-weight:500; color:var(--bt-text); }
.m-name.is-current { color:var(--bt-pink); font-weight:600; }
.m-bar { height:6px; border-radius:999px; background:var(--bt-border); overflow:hidden; position:relative; }
.m-fill { position:absolute; inset:0; border-radius:999px; background: linear-gradient(90deg, var(--bt-pink-light), var(--bt-pink)); }
.m-fill.is-record { background: var(--bt-yellow); }
.m-fill.is-current { background: repeating-linear-gradient(90deg, var(--bt-pink) 0 6px, var(--bt-pink-light) 6px 12px); }
.m-val { font-family:var(--font-display); font-size:14px; font-weight:600; font-variant-numeric:tabular-nums; min-width:56px; text-align:right; }

/* Bubble chart (legacy — оставлено на случай возврата к bubble-варианту) */
.bubble-chart { width:100%; display:block; overflow:visible; }
.bub-month { font-size:9.5px; fill:var(--bt-muted); font-weight:500; }
.bub-month.is-current { fill:var(--bt-pink); font-weight:600; }
.bub-hint { margin:6px 0 0; font-size:11px; color:var(--bt-muted); text-align:center; }

/* ARPPU */
.arppu { display:flex; gap:14px; align-items:flex-start; }
.arppu-icon { width:44px; height:44px; border-radius:14px; flex:none; background:var(--bt-yellow-soft); display:grid; place-items:center; font-size:22px; }
.arppu-num { font-family:var(--font-display); font-size:28px; font-weight:600; letter-spacing:-.5px; font-variant-numeric:tabular-nums; line-height:1; display:flex; align-items:baseline; gap:8px; flex-wrap:wrap; }
.pill { font-family:var(--font-text); font-size:11px; font-weight:600; color:var(--bt-pink); padding:2px 7px; border-radius:999px; background:var(--bt-pink-soft); }
.arppu-cap { margin:6px 0 0; font-size:12.5px; font-style:italic; color:var(--bt-muted); line-height:1.4; }

/* All-time 2x2 */
.alltime { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.at-card { background:var(--bt-surface); border:1px solid var(--bt-border); border-radius:var(--bt-radius-s); padding:14px; position:relative; overflow:hidden; }
.at-card::after { content:""; position:absolute; top:-10px; right:-10px; width:60px; height:60px; border-radius:50%; background:var(--bt-pink); opacity:.08; }
.at-card:nth-child(2)::after { background:var(--bt-yellow); }
.at-card:nth-child(3)::after { background:var(--bt-blue); }
.at-card:nth-child(4)::after { background:var(--bt-pink-light); }
.at-emoji { font-size:18px; margin-bottom:4px; }
.at-num { font-family:var(--font-display); font-size:22px; font-weight:600; letter-spacing:-.5px; font-variant-numeric:tabular-nums; line-height:1.05; }
.at-lbl { font-size:11.5px; color:var(--bt-muted); margin-top:3px; }

/* Badges */
.badges { display:flex; flex-direction:column; gap:8px; }
.badge { background:var(--bt-surface); border:1px solid var(--bt-border); border-radius:var(--bt-radius-s); padding:12px 14px; }
.badge[open] { background:var(--bt-pink-soft); border-color:transparent; }
.badge summary { display:flex; align-items:center; gap:12px; list-style:none; cursor:pointer; }
.badge summary::-webkit-details-marker { display:none; }
.b-emoji { width:36px; height:36px; border-radius:12px; flex:none; background:var(--bt-pink-soft); display:grid; place-items:center; font-size:18px; }
.badge[open] .b-emoji { background:#fff; }
.b-label { flex:1; font-size:13.5px; font-weight:600; color:var(--bt-text); }
.b-chev { color:var(--bt-muted); font-size:12px; transition:transform .2s; }
.badge[open] .b-chev { transform:rotate(180deg); }
.b-desc { margin:10px 0 2px; font-size:12.5px; line-height:1.5; color:var(--bt-muted); }

/* Footer */
.m-footer { margin-top:8px; padding:12px 14px; border-radius:14px; text-align:center; font-size:12px; color:var(--bt-muted); }
.m-footer.stale { background:var(--bt-yellow-soft); color:#8B6F00; }

@media (max-width: 380px) {
  .hero-big { font-size:46px; }
  .hero-big .cents { font-size:22px; }
  .at-num, .plat-val { font-size:20px; }
}

/* Forecast card (run-rate) ───────────────────────────────── */
.forecast {
  background: #FFFFFF;
  border: 1px solid var(--bt-border);
  border-radius: var(--bt-radius-m);
  padding: 16px 18px;
  box-shadow: 0 6px 18px rgba(13,27,61,.06);
}
.forecast-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.forecast-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--bt-muted);
  letter-spacing: .2px;
}
.forecast-num {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -.5px;
  color: var(--bt-pink-dark);
  font-variant-numeric: tabular-nums;
}
.forecast-bar {
  height: 8px;
  border-radius: 999px;
  background: var(--bt-pink-soft);
  overflow: hidden;
  position: relative;
}
.forecast-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--bt-pink-light) 0%, var(--bt-pink) 60%, var(--bt-yellow) 100%);
  transition: width 600ms cubic-bezier(.2,.7,.2,1);
}
.forecast-meta {
  margin-top: 8px;
  display: flex;
  justify-content: space-between;
  font-size: 11.5px;
  color: var(--bt-muted);
  font-variant-numeric: tabular-nums;
}
@media (max-width: 380px) {
  .forecast-num { font-size: 22px; }
}
