:root {
  --bg: #0a0a0a;
  --bg2: #141414;
  --bg3: #1c1c1c;
  --bg4: #242424;
  --border: rgba(255,255,255,0.08);
  --border2: rgba(255,255,255,0.14);
  --text: #ffffff;
  --text2: rgba(255,255,255,0.6);
  --text3: rgba(255,255,255,0.4);
  --green: #00e676;
  --green-dim: rgba(0,230,118,0.12);
  --green-dark: #00a152;
  --accent: #ff5252;
  --accent-dim: rgba(255,82,82,0.12);
  --accent-dark: #d32f2f;
  --blue: #448aff;
  --blue-dim: rgba(68,138,255,0.12);
  --amber: #ffab40;
  --amber-dim: rgba(255,171,64,0.12);
  --red: #ff5252;
  --red-dim: rgba(255,82,82,0.1);
  --gold: #ffd54f;
  --silver: #b0bec5;
  --bronze: #ff8a65;
  --radius: 14px;
  --radius-sm: 8px;
  --font: 'DM Sans', sans-serif;
  --font-display: 'Plus Jakarta Sans', 'DM Sans', sans-serif;
  --mono: 'DM Mono', monospace;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-top: env(safe-area-inset-top, 0px);
  --card-glow: 0 0 18px 2px rgba(255,60,60,0.22), 0 0 40px 6px rgba(255,60,60,0.08);
  --card-glow-active: 0 0 26px 4px rgba(255,60,60,0.40), 0 0 56px 10px rgba(255,60,60,0.18), 0 0 80px 14px rgba(255,60,60,0.06);
}
.theme-light body::after { background: none; }
.theme-light .card, .theme-light .admin-card { background: #f0f1f3; border-color: rgba(0,0,0,0.05); box-shadow: var(--card-glow); }
.theme-light .stat-box { background: #e4eaf3; }
.theme-light .success-wrap { background: radial-gradient(ellipse at 50% 45%, rgba(74,144,217,0.08) 0%, transparent 65%); }
.theme-light .post-btn { background: linear-gradient(135deg, #4A90D9, #5DA0E8); box-shadow: 0 10px 30px rgba(74,144,217,0.25); }
.theme-light .login-wrap { background: linear-gradient(165deg, #fff 0%, #f0f1f3 50%, #fff 100%); }
.theme-light .fpill.active { background: var(--accent); border-color: var(--accent); }
.theme-light .confirm-sheet { background: #fff; }
.theme-light .sheet { background: #fff; }
.theme-light .media-preview { background: var(--bg3); }
.theme-light .studio-pill { background: #f0f1f3; border-color: rgba(0,0,0,0.08); }
.theme-light .topbar { background: var(--bg); }
.theme-light .bottom-nav { background: var(--bg); box-shadow: 0 -2px 10px rgba(0,0,0,0.06); }
.theme-light .announce { border-left-color: var(--accent); }
#cp-watermark { display:none; position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); width:280px; height:280px; opacity:0.07; pointer-events:none; z-index:0; background:url('/v1/public/club-pilates-logo.png') center/contain no-repeat; }
#cp-watermark.visible { display:block; }
#rumble-watermark { display:none; position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); width:340px; height:340px; opacity:0.07; pointer-events:none; z-index:0; background:url('/v1/public/rumble-logo.png') center/contain no-repeat; }
#rumble-watermark.visible { display:block; }
* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
html, body { height: 100%; background: var(--bg); color: var(--text); font-family: var(--font); overflow: hidden; }
body::after { content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none; background: radial-gradient(ellipse at 50% 40%, rgba(255,255,255,0.04) 0%, transparent 70%); }
#app { height: 100vh; height: 100dvh; display: flex; flex-direction: column; max-width: 480px; margin: 0 auto; position: relative; z-index: 1; }
.screen { display: none; flex-direction: column; height: 100%; animation: fadeUp 0.22s ease; }
.screen.active { display: flex; }
@keyframes fadeUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
@keyframes slideLeft { from { opacity:0; transform:translateX(40px); } to { opacity:1; transform:translateX(0); } }
@keyframes slideRight { from { opacity:0; transform:translateX(-40px); } to { opacity:1; transform:translateX(0); } }
.scroll-content { flex: 1; overflow-y: auto; overflow-x: hidden; padding: 16px 20px; padding-bottom: calc(80px + var(--safe-bottom)); -webkit-overflow-scrolling: touch; }
.scroll-content::-webkit-scrollbar { display: none; }
#screen-post1 .scroll-content, #screen-post2 .scroll-content, #screen-post3 .scroll-content, #screen-post4 .scroll-content { background: linear-gradient(180deg, var(--bg) 0%, var(--bg2) 40%, var(--bg) 100%); }
.topbar { padding: 16px 20px 14px; padding-top: calc(16px + var(--safe-top)); display: flex; align-items: center; gap: 12px; border-bottom: 0.5px solid var(--border); flex-shrink: 0; background: var(--bg); }
.topbar-title { font-size: 13px; font-weight: 400; flex: 1; color: var(--text2); }
.back-btn { background: none; border: none; color: var(--text); font-size: 22px; font-weight: 700; cursor: pointer; padding: 8px; margin: -8px; line-height: 1; min-width: 44px; min-height: 44px; display: flex; align-items: center; justify-content: center; }
.topbar-badge { font-size: 11px; font-weight: 500; padding: 3px 10px; border-radius: 99px; background: var(--red-dim); color: var(--red); animation: badgePulse 2.5s ease-in-out infinite; }
@keyframes badgePulse { 0%,100% { box-shadow: 0 0 0 0 rgba(255,82,82,0); } 50% { box-shadow: 0 0 10px 2px rgba(255,82,82,0.15); } }
.bottom-nav { display: flex; border-top: 1px solid var(--border2); background: rgba(10,10,10,0.85); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); padding: 12px 0; padding-bottom: calc(12px + var(--safe-bottom)); flex-shrink: 0; box-shadow: 0 -4px 16px rgba(0,0,0,0.3); }
.nav-item { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 4px; background: none; border: none; cursor: pointer; padding: 6px 0; color: var(--text3); transition: color 0.25s ease, opacity 0.25s ease, transform 0.12s ease; min-height: 44px; justify-content: center; opacity: 0.55; position: relative; }
.nav-item:active { transform: scale(0.9); }
.nav-item.active { color: var(--accent); opacity: 1; }
.nav-item.active::before { content: ''; position: absolute; top: -1px; left: 50%; transform: translateX(-50%); width: 28px; height: 3px; border-radius: 99px; background: var(--accent); box-shadow: 0 0 10px var(--accent-dim); transition: width 0.25s ease; }
.nav-item svg { width: 22px; height: 22px; transition: transform 0.2s ease; }
.nav-item.active svg { transform: scale(1.1); }
.nav-label { font-size: 10px; font-weight: 600; font-family: var(--font-display); letter-spacing: 0.02em; }
.login-wrap { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 28px; padding-top: calc(40px + var(--safe-top)); position: relative; overflow-y: auto; overflow-x: hidden; background: linear-gradient(165deg, #0a0a0a 0%, #111 50%, #0d0d0d 100%); }
.login-pattern-bg { display: none; }
.login-watermark { display: none; }
.login-card { background: var(--bg2); border: 1px solid var(--border2); border-radius: 20px; padding: 36px 32px; max-width: 380px; width: 100%; box-shadow: 0 12px 40px rgba(0,0,0,0.5); z-index: 1; position: relative; }
.login-wordmark { font-size: 34px; font-weight: 800; letter-spacing: -1.2px; color: var(--text); margin-bottom: 4px; font-family: var(--font-display); }
.login-wordmark span { color: var(--red); }
.login-tagline { font-size: 13px; color: var(--text3); margin-bottom: 48px; letter-spacing: 0.02em; }
.login-step { animation: fadeUp 0.2s ease; }
#screen-login .page-title { color: var(--text); font-weight: 700; }
#screen-login .page-sub { color: var(--text2); }
#screen-login .form-label { color: var(--text2); }
#screen-login .form-input { background: var(--bg); border: 1px solid var(--border2); color: var(--text); }
#screen-login .form-input:focus { border-color: var(--red); box-shadow: 0 0 0 3px rgba(255,82,82,0.1); }
#screen-login .form-input::placeholder { color: var(--text3); }
#screen-login .btn-dim { background: var(--bg3); color: var(--text); border: 1px solid var(--border2); }
#screen-login .btn-green { background: var(--red); color: #fff; font-weight: 700; }
.form-group { margin-bottom: 16px; }
.form-label { font-size: 12px; font-weight: 500; color: var(--text2); text-transform: uppercase; letter-spacing: 0.06em; display: block; margin-bottom: 8px; }
.form-input { width: 100%; padding: 13px 16px; border-radius: var(--radius-sm); border: 0.5px solid var(--border); background: var(--bg3); color: var(--text); font-size: 15px; font-family: var(--font); outline: none; transition: border-color 0.15s; -webkit-appearance: none; }
.form-input:focus { border-color: var(--accent); }
.form-input.input-error { border-color: var(--red); box-shadow: 0 0 0 3px rgba(255,82,82,0.12); }
.field-error { font-size: 11px; color: var(--red); margin-top: 4px; display: none; line-height: 1.4; }
.field-error.visible { display: block; }
.bulk-bar { display:none; position:sticky; top:0; z-index:10; background:var(--bg2); border:1px solid var(--accent-dim); border-radius:12px; padding:10px 14px; margin-bottom:12px; gap:8px; align-items:center; }
.bulk-bar.visible { display:flex; }
.bulk-bar-count { font-size:13px; font-weight:600; color:var(--text); flex:1; }
.bulk-bar button { padding:8px 14px; border-radius:8px; font-size:12px; font-weight:600; font-family:var(--font); border:none; cursor:pointer; }
.bulk-bar .bulk-approve { background:var(--green); color:#000; }
.bulk-bar .bulk-reject { background:var(--red-dim); color:var(--red); }
.bulk-bar .bulk-cancel { background:var(--bg3); color:var(--text3); }
.bulk-check { position:absolute; top:10px; left:10px; z-index:5; width:24px; height:24px; border-radius:6px; border:2px solid var(--border2); background:rgba(0,0,0,0.5); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background 0.15s, border-color 0.15s; }
.bulk-check.checked { background:var(--accent); border-color:var(--accent); }
.bulk-check.checked::after { content:'\2713'; color:#fff; font-size:14px; font-weight:700; }
.form-input::placeholder { color: var(--text3); }
select.form-input { cursor: pointer; }
textarea.form-input { resize: none; min-height: 100px; line-height: 1.6; }
.btn { width: 100%; padding: 15px; border-radius: var(--radius); border: none; font-size: 15px; font-weight: 500; font-family: var(--font); cursor: pointer; transition: opacity 0.15s, transform 0.1s; letter-spacing: 0.01em; }
.btn:active { transform: scale(0.98); opacity: 0.85; }
.btn-green { background: var(--accent); color: #000; }
.btn-dim { background: var(--bg3); color: var(--text); border: 0.5px solid var(--border); }
.btn + .btn { margin-top: 10px; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }
.btn-sm { width: auto; padding: 10px 14px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500; font-family: var(--font); cursor: pointer; border: none; transition: opacity 0.15s, transform 0.12s ease; min-height: 36px; }
.btn-sm:active { transform: scale(0.97); }
.card { background: var(--bg2); border: 1px solid var(--border); border-radius: 18px; padding: 22px; margin-bottom: 16px; box-shadow: var(--card-glow); transition: transform 0.15s ease, box-shadow 0.25s ease; }
.card:active { transform: scale(0.98); box-shadow: var(--card-glow-active); transition: box-shadow 0.1s ease; }
.card:hover { box-shadow: var(--card-glow-active); }
.card-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text3); margin-bottom: 12px; font-family: var(--font-display); }
.announce { background: var(--bg2); border-radius: 12px; padding: 12px 14px; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; border-left: 3px solid var(--accent); }
.announce-dot { display: none; }
.announce-text { font-size: 12px; font-weight: 400; color: var(--text2); line-height: 1.5; opacity: 0.8; }
.dash-hero-card { position:relative; border-radius:16px; overflow:hidden; height:160px; margin-bottom:16px; border: 1px solid var(--border); box-shadow: var(--card-glow); transition: box-shadow 0.25s ease, transform 0.15s ease; cursor:pointer; }
.dash-hero-card:active { box-shadow: var(--card-glow-active); transform: scale(0.98); }
.dash-hero-card img { width:100%; height:100%; object-fit:cover; display:block; }
.dash-hero-card .hero-overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.15) 100%); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:16px; text-align:center; }
.dash-hero-card .hero-tagline { font-size:24px; font-weight:900; color:#fff; text-shadow:0 2px 8px rgba(0,0,0,0.4); letter-spacing:0.01em; }
.dash-hero-card .hero-studio { font-size:13px; font-weight:500; color:rgba(255,255,255,0.8); margin-top:6px; }
.leader-item { display: flex; align-items: center; gap: 10px; padding: 9px 0; opacity: 0; transform: translateX(16px); animation: leaderSlideIn 0.3s ease forwards; }
.leader-item + .leader-item { border-top: 0.5px solid var(--border); }
@keyframes leaderSlideIn { from { opacity: 0; transform: translateX(16px); } to { opacity: 1; transform: translateX(0); } }
.leader-item.leader-1st { animation: leader1stIn 0.35s cubic-bezier(0.34,1.56,0.64,1) forwards; }
@keyframes leader1stIn { from { opacity: 0; transform: scale(0.95) translateX(12px); } to { opacity: 1; transform: scale(1) translateX(0); } }
@keyframes leaderGlow { 0%,100% { box-shadow: 0 0 20px rgba(255,82,82,0.15), 0 0 40px rgba(255,82,82,0.05); } 50% { box-shadow: 0 0 24px rgba(255,82,82,0.22), 0 0 48px rgba(255,82,82,0.08); } }
.leader-item.leader-1st { animation: leader1stIn 0.35s cubic-bezier(0.34,1.56,0.64,1) forwards, leaderGlow 3s ease-in-out 0.5s infinite; }
.rank-num { width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600; flex-shrink: 0; }
.rank-medal { width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; line-height: 1; }
.rank-other { background: var(--bg3); color: var(--text3); }
.leader-info { flex: 1; min-width: 0; }
.leader-name { font-size: 13px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-family: var(--font-display); }
.leader-studio { font-size: 11px; color: var(--text3); margin-top: 1px; opacity: 0.7; }
.leader-count { font-size: 12px; font-weight: 700; color: var(--text3); opacity: 0.7; font-family: var(--font-display); }
.leader-count-pop { animation: countPop 0.3s cubic-bezier(0.34,1.56,0.64,1) forwards; }
/* ── Streak Badge: Molten Ember ── */
.streak-badge {
  position: relative; display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px 3px 6px; border-radius: 99px;
  font-size: 12px; font-weight: 800; font-family: var(--font-display);
  color: #fff; white-space: nowrap; line-height: 1;
  background: linear-gradient(135deg, rgba(255,60,20,0.25), rgba(255,140,0,0.15));
  border: 1px solid rgba(255,120,30,0.4);
  overflow: hidden; flex-shrink: 0;
  animation: ember-pulse 2.5s ease-in-out infinite;
  text-shadow: 0 1px 4px rgba(0,0,0,0.5);
  letter-spacing: -0.3px;
}
/* shimmer sweep */
.streak-badge::before {
  content: ''; position: absolute; top: -50%; left: -75%; width: 50%; height: 200%;
  background: linear-gradient(105deg, transparent 30%, rgba(255,200,100,0.25) 45%, rgba(255,255,255,0.18) 50%, rgba(255,200,100,0.25) 55%, transparent 70%);
  transform: skewX(-20deg);
  animation: badge-shimmer 3s ease-in-out infinite;
  pointer-events: none;
}
/* hot inner glow */
.streak-badge::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(ellipse at 30% 0%, rgba(255,180,50,0.2) 0%, transparent 60%);
  pointer-events: none;
}
.streak-badge .streak-flame {
  font-size: 14px; line-height: 1; position: relative; z-index: 1;
  filter: drop-shadow(0 0 3px rgba(255,100,0,0.6));
  animation: flame-dance 0.8s ease-in-out infinite alternate;
}
.streak-badge .streak-num {
  position: relative; z-index: 1;
  font-variant-numeric: tabular-nums;
}
/* ── Tier escalation ── */
.streak-badge.streak-hot {
  border-color: rgba(255,80,20,0.55);
  background: linear-gradient(135deg, rgba(255,40,10,0.35), rgba(255,100,0,0.2));
}
.streak-badge.streak-hot .streak-flame { font-size: 15px; }
.streak-badge.streak-inferno {
  border-color: rgba(255,200,50,0.5);
  background: linear-gradient(135deg, rgba(255,50,10,0.4), rgba(255,180,30,0.25));
  text-shadow: 0 0 8px rgba(255,200,50,0.4), 0 1px 4px rgba(0,0,0,0.5);
}
.streak-badge.streak-inferno .streak-flame { font-size: 16px; }
.streak-badge.streak-inferno::before {
  animation-duration: 2s;
  background: linear-gradient(105deg, transparent 25%, rgba(255,220,100,0.35) 42%, rgba(255,255,255,0.25) 50%, rgba(255,220,100,0.35) 58%, transparent 75%);
}
/* ── Animations ── */
@keyframes ember-pulse {
  0%, 100% { box-shadow: 0 0 6px rgba(255,100,0,0.3), 0 0 16px rgba(255,50,20,0.12); }
  50% { box-shadow: 0 0 10px rgba(255,100,0,0.5), 0 0 24px rgba(255,50,20,0.2), 0 0 40px rgba(255,80,0,0.08); }
}
@keyframes flame-dance {
  0% { transform: scale(1) translateY(0) rotate(-2deg); }
  100% { transform: scale(1.12) translateY(-1px) rotate(2deg); }
}
@keyframes badge-shimmer {
  0%, 100% { left: -75%; opacity: 0; }
  10% { opacity: 1; }
  60% { left: 150%; opacity: 1; }
  70%, 100% { left: 150%; opacity: 0; }
}
/* light theme adjustments */
.theme-light .streak-badge {
  background: linear-gradient(135deg, rgba(255,70,20,0.18), rgba(255,150,30,0.12));
  border-color: rgba(255,100,20,0.35);
  color: #d93a00; text-shadow: none;
}
.theme-light .streak-badge.streak-inferno { color: #c42e00; }
.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.stat-box { background: var(--bg3); border-radius: 12px; padding: 18px 14px; text-align: center; }
.stat-val { font-size: 28px; font-weight: 800; color: var(--text); line-height: 1; margin-bottom: 5px; font-family: var(--font-display); }
.stat-val.green { color: var(--accent); }
.stat-lbl { font-size: 11px; color: var(--text3); font-weight: 400; opacity: 0.7; }
.progress-row { display: flex; justify-content: space-between; font-size: 11px; color: var(--text3); margin-bottom: 6px; }
.progress-track { background: var(--bg3); border-radius: 99px; height: 4px; overflow: hidden; }
.progress-fill { height: 100%; background: var(--accent); border-radius: 99px; transition: width 0.6s cubic-bezier(0.4,0,0.2,1); }
.nudge { font-size: 13px; color: var(--red); margin-top: 14px; font-weight: 600; padding: 10px 14px; background: rgba(255,82,82,0.06); border-radius: 10px; border: 1px solid rgba(255,82,82,0.1); text-align: center; letter-spacing: -0.2px; }
.nudge-cta { display: block; width: 100%; margin-top: 10px; padding: 10px; background: var(--red); color: #fff; font-size: 13px; font-weight: 700; font-family: var(--font); border: none; border-radius: var(--radius-sm); cursor: pointer; transition: transform 0.1s, opacity 0.15s; }
.nudge-cta:active { transform: scale(0.97); opacity: 0.85; }
.tier-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: 99px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 14px; font-family: var(--font-display); }
.tier-badge .tier-dot { width: 6px; height: 6px; border-radius: 50%; }
.streak-row { display: flex; align-items: center; justify-content: center; gap: 7px; padding: 10px 0; font-size: 13px; font-weight: 600; color: var(--text2); }
.streak-row .streak-fire { font-size: 15px; line-height: 1; }
.streak-row .streak-count { color: var(--text); font-weight: 800; }
.streak-row .streak-label { color: var(--text3); font-weight: 500; font-size: 12px; }
.post-btn { width: 100%; padding: 18px; background: linear-gradient(135deg, #ff2d2d, #ff4d4d); color: #fff; border-radius: var(--radius); border: none; font-size: 16px; font-weight: 700; font-family: var(--font); cursor: pointer; margin-bottom: 12px; display: flex; align-items: center; justify-content: center; gap: 8px; transition: transform 0.15s ease, box-shadow 0.15s ease; box-shadow: 0 10px 30px rgba(255,50,50,0.25); animation: fabPulse 3s ease-in-out infinite; }
.post-btn:active { transform: scale(0.98); box-shadow: 0 6px 20px rgba(255,50,50,0.2); animation: none; }
@keyframes fabPulse { 0%, 100% { box-shadow: 0 10px 30px rgba(255,50,50,0.25); } 50% { box-shadow: 0 12px 36px rgba(255,50,50,0.35), 0 0 60px rgba(255,50,50,0.1); } }
.step-bar { display: flex; align-items: center; gap: 6px; margin-bottom: 24px; }
.step-pip { width: 6px; height: 6px; border-radius: 50%; background: var(--bg4); transition: all 0.2s; }
.step-pip.done { background: var(--accent-dark); }
.step-pip.active { background: var(--accent); width: 20px; border-radius: 3px; }
.step-line { flex: 1; height: 0.5px; background: var(--border); }
.upload-zone { border: 2px dashed rgba(255,82,82,0.25); border-radius: 20px; padding: 56px 24px; text-align: center; cursor: pointer; background: linear-gradient(135deg, rgba(255,82,82,0.04), rgba(255,82,82,0.01)); transition: border-color 0.25s ease, background 0.25s ease, transform 0.15s ease, box-shadow 0.25s ease; margin-bottom: 16px; }
.upload-zone:hover, .upload-zone.has-file { border-color: var(--accent); background: rgba(255,82,82,0.08); box-shadow: 0 0 30px rgba(255,82,82,0.12); }
.upload-zone:active { transform: scale(0.98); }
.upload-icon { font-size: 48px; margin-bottom: 16px; animation: uploadBounce 2.5s ease-in-out infinite; }
@keyframes uploadBounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-5px); } }
.upload-title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 5px; }
.upload-sub { font-size: 13px; color: var(--text2); }
.upload-preview { background: var(--accent-dim); border: 0.5px solid var(--accent-dark); border-radius: var(--radius-sm); padding: 12px 14px; margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.upload-preview-name { font-size: 13px; color: var(--accent); font-weight: 500; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.enhance-btn { width: 100%; padding: 15px; background: var(--blue); color: #fff; border: none; border-radius: var(--radius); font-size: 15px; font-weight: 600; font-family: var(--font); cursor: pointer; margin-bottom: 14px; display: flex; align-items: center; justify-content: center; gap: 10px; transition: opacity 0.15s; }
.enhance-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.enhance-btn .spinner { width: 16px; height: 16px; border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff; border-radius: 50%; animation: spin 0.7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.enhanced-wrap { background: var(--bg3); border-left: 2px solid var(--accent); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; padding: 0; margin-bottom: 14px; overflow: hidden; }
.enhanced-label { font-size: 11px; font-weight: 500; color: var(--accent); text-transform: uppercase; letter-spacing: 0.08em; padding: 10px 14px 0; }
textarea.enhanced-text { width: 100%; background: transparent; border: none; color: var(--text); font-size: 13px; line-height: 1.7; padding: 8px 14px 14px; font-family: var(--font); outline: none; resize: none; min-height: 160px; }
.success-wrap { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 32px 28px; padding-top: calc(32px + var(--safe-top)); text-align: center; background: radial-gradient(ellipse at 50% 45%, rgba(255,82,82,0.04) 0%, transparent 65%); position: relative; overflow: hidden; }
.success-title { font-size: 26px; font-weight: 800; color: var(--text); margin-bottom: 4px; letter-spacing: -0.8px; opacity: 0; animation: successFadeIn 0.25s ease 0.05s forwards; font-family: var(--font-display); }
.success-sub { font-size: 13px; color: var(--text3); line-height: 1.6; margin-bottom: 28px; opacity: 0; animation: successFadeIn 0.25s ease 0.15s forwards; }
.success-count { font-size: 72px; font-weight: 800; color: var(--accent); line-height: 1; margin-bottom: 4px; opacity: 0; font-family: var(--font-display); }
.success-count-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; margin-bottom: 32px; opacity: 0; animation: successFadeIn 0.2s ease 0.35s forwards; }
.success-quote { font-size: 14px; color: var(--text2); font-weight: 500; font-style: italic; max-width: 260px; line-height: 1.5; opacity: 0; transition: opacity 0.4s ease; }
.success-quote.visible { opacity: 0.8; }
@keyframes successFadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes countPop { 0% { transform: scale(0.7); opacity: 0; } 50% { transform: scale(1.08); opacity: 1; } 100% { transform: scale(1); opacity: 1; } }
.success-count.pop { animation: countPop 0.35s cubic-bezier(0.34,1.56,0.64,1) forwards; }
.success-tier-badge { display: none; padding: 8px 20px; border-radius: 99px; font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 28px; opacity: 0; }
@keyframes tierPop { 0% { transform: scale(0.5); opacity: 0; } 50% { transform: scale(1.12); opacity: 1; } 100% { transform: scale(1); opacity: 1; } }
.success-tier-badge.pop { display: inline-block; animation: tierPop 0.4s cubic-bezier(0.34,1.56,0.64,1) forwards; }
/* Confetti */
.confetti-container { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.confetti-piece { position: absolute; width: 8px; height: 8px; top: 45%; left: 50%; border-radius: 2px; opacity: 0; animation: confettiBurst 1s cubic-bezier(0.2,0.8,0.3,1) forwards; }
@keyframes confettiBurst {
  0% { transform: translate(0,0) rotate(0deg) scale(0); opacity: 1; }
  15% { transform: translate(calc(var(--tx) * 0.3), calc(var(--ty) * 0.3)) rotate(calc(var(--rot) * 0.3)) scale(1); opacity: 1; }
  100% { transform: translate(var(--tx), var(--ty)) rotate(var(--rot)) scale(0.4); opacity: 0; }
}
/* Radial pulse behind count */
.success-pulse { position: absolute; width: 180px; height: 180px; border-radius: 50%; top: 50%; left: 50%; transform: translate(-50%,-55%); opacity: 0; z-index: 0; }
@keyframes successPulse {
  0% { transform: translate(-50%,-55%) scale(0.3); opacity: 0.5; }
  100% { transform: translate(-50%,-55%) scale(2.5); opacity: 0; }
}
.success-pulse.active { animation: successPulse 1s ease-out forwards; }
.admin-card { background: #111; border: 1px solid rgba(255,255,255,0.05); border-radius: 22px; overflow: hidden; margin-bottom: 20px; box-shadow: var(--card-glow); transition: transform 0.15s ease, box-shadow 0.25s ease; }
.admin-card:active { transform: scale(0.98); box-shadow: var(--card-glow-active); transition: box-shadow 0.1s ease; }
.admin-card.fade-out { opacity: 0; transform: scale(0.96); transition: opacity 0.2s ease, transform 0.2s ease; }
.admin-card:hover { box-shadow: var(--card-glow-active); }
.media-preview { width: 100%; height: 180px; background: var(--bg3); display: flex; align-items: center; justify-content: center; font-size: 48px; position: relative; overflow: hidden; }
.media-preview img, .media-preview video { width: 100%; height: 100%; object-fit: cover; }
.media-gallery { width: 100%; position: relative; overflow: hidden; background: var(--bg3); }
.media-gallery-track { display: flex; transition: transform 0.3s ease; }
.media-gallery-slide { width: 100%; min-width: 100%; height: 220px; display: flex; align-items: center; justify-content: center; background: var(--bg3); }
.media-gallery-slide img, .media-gallery-slide video { width: 100%; height: 100%; object-fit: cover; }
.media-gallery-dots { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; z-index: 2; }
.media-gallery-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,0.35); border: none; padding: 0; cursor: pointer; transition: background 0.2s; }
.media-gallery-dot.active { background: #fff; }
.media-gallery-counter { position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,0.7); color: #fff; font-size: 11px; padding: 2px 8px; border-radius: 99px; z-index: 2; }
.admin-card-body { padding: 18px; }
.admin-card-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; margin-bottom: 10px; }
.admin-card-name { font-size: 14px; font-weight: 700; color: var(--text); font-family: var(--font-display); }
.admin-card-meta { font-size: 12px; color: var(--text3); margin-top: 1px; line-height: 1.6; opacity: 0.7; }
.status-pill { font-size: 9px; font-weight: 500; padding: 2px 7px; border-radius: 99px; white-space: nowrap; flex-shrink: 0; text-transform: uppercase; letter-spacing: 0.04em; opacity: 0.7; }
.s-pending { background: rgba(255,171,64,0.08); color: #c89030; }
.s-approved { background: rgba(255,82,82,0.06); color: #2a9d5c; }
.s-rejected { background: rgba(255,82,82,0.06); color: #c45050; }
.s-archived { background: var(--bg3); color: var(--text3); }
.caption-box { background: none; border-radius: 0; padding: 0; font-size: 13px; color: var(--text2); line-height: 1.65; margin-bottom: 14px; max-height: none; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
.caption-box.expanded { -webkit-line-clamp: unset; }
.caption-toggle { background: none; border: none; color: var(--accent); font-size: 12px; font-weight: 500; font-family: var(--font); cursor: pointer; padding: 0; margin-bottom: 14px; display: none; }
.admin-actions-primary { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.admin-actions-row-pair { display: flex; gap: 8px; }
.admin-actions-secondary { display: none; gap: 8px; flex-wrap: wrap; padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.05); margin-top: 4px; }
.admin-actions-secondary.open { display: flex; }
.more-toggle { background: none; border: none; color: var(--text3); font-size: 18px; cursor: pointer; padding: 4px 8px; margin-left: auto; display: block; opacity: 0.5; transition: opacity 0.15s; }
.more-toggle:active { opacity: 1; }
.workflow-actions { display: flex; gap: 8px; margin-bottom: 10px; }
.workflow-actions button, .workflow-actions a { flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px; min-height: 44px; padding: 10px 12px; background: var(--bg3); color: var(--text1); font-weight: 600; font-size: 13px; font-family: var(--font); border: 1px solid var(--border); border-radius: var(--radius-sm); cursor: pointer; transition: background 0.15s, transform 0.1s; text-decoration: none; }
.workflow-actions button:active, .workflow-actions a:active { transform: scale(0.97); background: var(--accent-dim); }
.workflow-actions .wf-icon { font-size: 16px; flex-shrink: 0; }
.filter-pills { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; margin-bottom: 16px; }
.filter-pills::-webkit-scrollbar { display: none; }
.fpill { padding: 8px 16px; border-radius: 99px; border: 0.5px solid var(--border); background: var(--bg2); color: var(--text3); font-size: 13px; font-weight: 500; cursor: pointer; white-space: nowrap; font-family: var(--font); transition: all 0.2s ease; flex-shrink: 0; min-height: 36px; opacity: 0.65; }
.fpill:active { transform: scale(0.97); }
.fpill.active { background: var(--red); color: #fff; border-color: var(--red); opacity: 1; font-weight: 600; }
.sfpill { padding: 6px 12px; border-radius: 99px; border: 0.5px solid var(--border); background: transparent; color: var(--text3); font-size: 11px; font-weight: 500; cursor: pointer; white-space: nowrap; font-family: var(--font); transition: all 0.2s ease; flex-shrink: 0; min-height: 32px; opacity: 0.6; }
.sfpill:active { transform: scale(0.97); }
.sfpill.active { background: rgba(255,82,82,0.1); color: var(--red); border-color: rgba(255,82,82,0.3); opacity: 1; font-weight: 600; }
.toast { position: fixed; bottom: calc(90px + var(--safe-bottom)); left: 50%; transform: translateX(-50%) translateY(20px); background: var(--bg4); color: var(--text); font-size: 13px; font-weight: 500; padding: 10px 20px; border-radius: 99px; border: 0.5px solid var(--border2); opacity: 0; transition: all 0.25s; pointer-events: none; white-space: nowrap; z-index: 999; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.toast-success { font-size: 15px; font-weight: 700; padding: 14px 28px; background: rgba(0,230,118,0.15); color: #00e676; border: 1px solid rgba(0,230,118,0.3); box-shadow: 0 0 20px rgba(0,230,118,0.25), 0 0 40px rgba(0,230,118,0.1); }
.toast.toast-error { background: rgba(255,82,82,0.15); color: #ff5252; border: 1px solid rgba(255,82,82,0.3); }
.loading-screen { flex: 1; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 16px; padding-top: var(--safe-top); }
.loading-logo { font-size: 24px; font-weight: 700; color: var(--text); letter-spacing: -0.5px; font-family: var(--font-display); }
.loading-logo span { color: var(--accent); }
.loading-bar { width: 60px; height: 3px; background: var(--bg3); border-radius: 99px; overflow: hidden; }
.loading-bar-fill { height: 100%; background: var(--accent); border-radius: 99px; animation: loadbar 1.2s ease infinite; }
@keyframes loadbar { 0%{width:0%;margin-left:0} 50%{width:80%;margin-left:0} 100%{width:0%;margin-left:100%} }
.page-title { font-size: 22px; font-weight: 700; letter-spacing: -0.5px; color: var(--text); margin-bottom: 6px; font-family: var(--font-display); }
.page-sub { font-size: 14px; color: var(--text2); margin-bottom: 28px; opacity: 0.75; }
.confirm-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: flex; align-items: flex-end; justify-content: center; z-index: 998; padding-bottom: var(--safe-bottom); }
.confirm-sheet { background: var(--bg2); border-radius: var(--radius) var(--radius) 0 0; padding: 24px 24px calc(24px + var(--safe-bottom)); width: 100%; max-width: 480px; border-top: 0.5px solid var(--border); }
.confirm-title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 8px; }
.confirm-sub { font-size: 14px; color: var(--text2); margin-bottom: 24px; line-height: 1.5; }
.confirm-actions { display: flex; gap: 10px; }
.confirm-actions button { flex: 1; }
.login-logos { display: flex; align-items: center; justify-content: center; gap: 16px; margin-bottom: 28px; }
.login-logos img { height: 48px; width: auto; }
.login-logo-divider { width: 1px; height: 32px; background: var(--border2); }
#screen-login.active { background: #0a0a0a; }
.topbar-logo { display: none; }
.studio-pill { display: inline-flex; align-items: center; gap: 7px; padding: 9px 14px; border-radius: 99px; background: var(--bg3); border: 1px solid var(--border2); font-size: 13px; font-weight: 600; color: var(--text); cursor: pointer; white-space: nowrap; min-height: 44px; transition: background 0.15s ease, box-shadow 0.25s ease; box-shadow: var(--card-glow); }
.studio-pill:active { background: var(--bg4); box-shadow: var(--card-glow-active); }
.studio-pill svg { width: 10px; height: 10px; }
.sheet-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 100; }
.sheet-overlay.open { display: flex; align-items: flex-end; justify-content: center; }
.sheet { max-width: 480px; width: 100%; background: var(--bg2); border-radius: 16px 16px 0 0; padding: 20px; padding-bottom: calc(20px + var(--safe-bottom)); animation: sheetUp 0.2s ease; }
@keyframes sheetUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
.sheet-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 16px; font-family: var(--font-display); }
.sheet-option { display: flex; align-items: center; gap: 12px; padding: 14px 12px; border-radius: var(--radius-sm); cursor: pointer; border: none; background: none; width: 100%; text-align: left; font-family: var(--font); font-size: 14px; color: var(--text); transition: background 0.15s; }
.sheet-option:hover { background: var(--bg3); }
.sheet-option.active { background: var(--accent-dim); color: var(--accent); }
.sheet-option-logo { height: 24px; width: 24px; object-fit: contain; }
.sheet-option-check { margin-left: auto; color: var(--accent); font-size: 16px; }
.admin-studio-logo { width: 20px; height: 20px; vertical-align: middle; margin-right: 4px; border-radius: 3px; }

/* April Challenge Modal */
.challenge-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 20px; animation: fadeUp 0.25s ease; }
.challenge-card { background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--radius); max-width: 360px; width: 100%; max-height: 85vh; overflow-y: auto; padding: 28px 24px 20px; position: relative; text-align: center; }
.challenge-card::-webkit-scrollbar { display: none; }
.challenge-close { position: absolute; top: 8px; right: 8px; background: none; border: none; color: var(--text3); font-size: 22px; cursor: pointer; line-height: 1; padding: 10px; }
.challenge-trophy { font-size: 48px; margin-bottom: 12px; }
.challenge-title { font-size: 22px; font-weight: 700; color: var(--text); margin-bottom: 4px; font-family: var(--font-display); }
.challenge-subtitle { font-size: 14px; color: var(--accent); font-weight: 500; margin-bottom: 18px; }
.challenge-date-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 4px; }
.challenge-date { font-size: 16px; font-weight: 500; color: var(--text); margin-bottom: 20px; }
.challenge-toggle { background: none; border: 1px solid var(--border2); color: var(--text2); font-size: 13px; font-family: var(--font); padding: 8px 18px; border-radius: 99px; cursor: pointer; margin-bottom: 14px; transition: border-color 0.15s, color 0.15s; }
.challenge-toggle:hover { border-color: var(--accent); color: var(--accent); }
.challenge-rules { display: none; text-align: left; margin-bottom: 16px; padding: 16px; background: var(--bg3); border-radius: var(--radius-sm); font-size: 13px; line-height: 1.65; color: var(--text2); }
.challenge-rules.show { display: block; }
.challenge-rules h4 { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--accent); margin: 14px 0 6px; }
.challenge-rules h4:first-child { margin-top: 0; }
.challenge-rules ul { padding-left: 18px; margin: 4px 0; }
.challenge-rules ol { padding-left: 18px; margin: 4px 0; }
.challenge-rules li { margin-bottom: 3px; }
.challenge-rules p { margin: 6px 0; }
.challenge-go-btn { width: 100%; padding: 14px; border: none; border-radius: var(--radius-sm); background: var(--accent); color: #000; font-size: 16px; font-weight: 600; font-family: var(--font); cursor: pointer; margin-bottom: 10px; }
.challenge-remind { background: none; border: none; color: var(--text3); font-size: 12px; font-family: var(--font); cursor: pointer; }
.challenge-remind:hover { color: var(--text2); }
/* Dashboard tabs */
.dash-tabs { display: flex; gap: 4px; padding: 8px 20px; background: var(--bg); flex-shrink: 0; }
.dash-tab { flex: 1; padding: 8px; font-size: 13px; font-weight: 600; font-family: var(--font); border: none; border-radius: 8px; cursor: pointer; transition: background 0.15s, color 0.15s; background: transparent; color: var(--text3); }
.dash-tab.active { background: var(--bg3); color: var(--text); }
.dash-tab:active { transform: scale(0.97); }
/* Pulse cards */
.pulse-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 16px; margin-bottom: 12px; }
.pulse-card-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text3); margin-bottom: 12px; font-family: var(--font-display); }
.pulse-stat-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; }
.pulse-stat-row + .pulse-stat-row { border-top: 0.5px solid var(--border); }
.pulse-stat-label { font-size: 13px; color: var(--text2); }
.pulse-stat-val { font-size: 14px; font-weight: 700; color: var(--text); }
.pulse-stat-val.good { color: #00e676; }
.pulse-stat-val.warn { color: #ffab40; }
.pulse-stat-val.bad { color: #ff5252; }
.pulse-coach-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 14px; padding: 16px; margin-bottom: 10px; }
.pulse-coach-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.pulse-coach-avatar { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,82,82,0.15); color: #ff5252; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; }
.pulse-coach-name { font-size: 14px; font-weight: 600; color: var(--text); }
.pulse-coach-sub { font-size: 11px; color: var(--text3); }
.pulse-coach-score { font-size: 22px; font-weight: 800; color: var(--accent); margin-left: auto; }
.pulse-metric-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.pulse-metric { background: var(--bg3); border-radius: 8px; padding: 10px; text-align: center; }
.pulse-metric-val { font-size: 18px; font-weight: 700; color: var(--text); }
.pulse-metric-label { font-size: 10px; color: var(--text3); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.04em; }
.pulse-trend-up { color: #00e676; }
.pulse-trend-down { color: #ff5252; }
.pulse-fresh { font-size: 11px; color: var(--text3); text-align: center; padding: 8px 0; margin-top: 8px; }
.pulse-explain { position: fixed; bottom: 0; left: 0; right: 0; z-index: 999; animation: sheetUp 0.2s ease; }
.pulse-explain-bg { position: fixed; inset: 0; background: rgba(0,0,0,0.5); }
.pulse-explain-sheet { position: relative; max-width: 480px; margin: 0 auto; background: var(--bg2); border-radius: 20px 20px 0 0; padding: 24px 24px calc(24px + var(--safe-bottom)); }
.pulse-explain-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.pulse-explain-body { font-size: 13px; color: var(--text2); line-height: 1.65; }
/* Gallery / showcase */
.gallery-grid { display: block; columns: 2; column-gap: 10px; }
.gallery-item { position: relative; overflow: hidden; border-radius: 12px; cursor: pointer; background: var(--bg3); transition: transform 0.15s ease, box-shadow 0.2s ease, opacity 0.15s ease; break-inside: avoid; margin-bottom: 10px; }
.gallery-item:active { transform: scale(0.96); opacity: 0.9; }
.gallery-item img, .gallery-item video { width: 100%; height: auto; object-fit: cover; display: block; }
.gallery-item .gallery-video-badge { position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,0.6); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); color: #fff; font-size: 11px; padding: 3px 8px; border-radius: 6px; font-weight: 600; }
.gallery-item .gallery-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 8px 10px; background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 100%); display: flex; align-items: flex-end; justify-content: space-between; pointer-events: none; }
.gallery-item .gallery-overlay-name { font-size: 11px; font-weight: 600; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,0.5); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 70%; }
.gallery-item .gallery-reaction-pill { font-size: 11px; background: rgba(255,255,255,0.15); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); padding: 2px 7px; border-radius: 99px; color: #fff; font-weight: 600; display: flex; align-items: center; gap: 3px; flex-shrink: 0; }
.gallery-detail-overlay { position: fixed; inset: 0; z-index: 998; background: rgba(0,0,0,0.92); display: flex; flex-direction: column; animation: fadeUp 0.2s ease; }
.gallery-detail-topbar { display: flex; align-items: center; padding: 16px 20px; padding-top: calc(16px + var(--safe-top)); flex-shrink: 0; }
.gallery-detail-media { flex: 1; display: flex; align-items: center; justify-content: center; overflow: hidden; min-height: 0; }
.gallery-detail-media img, .gallery-detail-media video { max-width: 100%; max-height: 100%; object-fit: contain; }
.gallery-detail-body { padding: 16px 20px; padding-bottom: calc(16px + var(--safe-bottom)); flex-shrink: 0; max-height: 40vh; overflow-y: auto; }
.gallery-detail-caption { font-size: 14px; color: rgba(255,255,255,0.9); line-height: 1.6; margin-bottom: 12px; }
.gallery-detail-meta { font-size: 12px; color: rgba(255,255,255,0.55); margin-bottom: 14px; }
.gallery-detail-actions { display: flex; gap: 8px; }
.gallery-detail-actions button { flex: 1; min-height: 44px; padding: 10px; font-size: 13px; font-weight: 600; font-family: var(--font); border-radius: var(--radius-sm); cursor: pointer; border: none; display: flex; align-items: center; justify-content: center; gap: 6px; transition: transform 0.1s; }
.gallery-detail-actions button:active { transform: scale(0.97); }
.gallery-ig-btn { background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888) !important; color: #fff !important; }
/* Reaction bar */
.reaction-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px; }
.reaction-btn { border: 1px solid var(--border2); border-radius: 99px; padding: 6px 10px; font-size: 14px; cursor: pointer; display: flex; align-items: center; gap: 4px; min-width: 44px; min-height: 36px; justify-content: center; color: var(--text); font-family: var(--font); background: var(--bg3); transition: transform 0.15s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease; }
.reaction-btn:active { transform: scale(0.9); }
.reaction-btn.mine { background: var(--accent-dim); border-color: var(--accent); box-shadow: 0 0 10px var(--accent-dim); }
.reaction-btn .reaction-emoji { display: inline-block; transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1); }
.reaction-btn.mine .reaction-emoji { transform: scale(1.15); }
.reaction-btn .reaction-count { font-size: 12px; font-weight: 600; min-width: 8px; text-align: center; }
@keyframes reactionPop { 0% { transform: scale(1); } 40% { transform: scale(1.35); } 100% { transform: scale(1.15); } }
.reaction-btn.just-selected .reaction-emoji { animation: reactionPop 0.3s cubic-bezier(0.34,1.56,0.64,1) forwards; }
/* Activity feed */
.activity-item { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; margin-bottom: 8px; }
.activity-icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.activity-icon.submitted { background: var(--amber-dim); }
.activity-icon.approved { background: rgba(0,230,118,0.1); }
.activity-icon.rejected { background: var(--red-dim); }
.activity-icon.reaction { background: rgba(68,138,255,0.1); }
.activity-text { flex: 1; font-size: 13px; color: var(--text2); line-height: 1.45; }
.activity-text strong { color: var(--text); font-weight: 600; }
.activity-time { font-size: 11px; color: var(--text3); white-space: nowrap; flex-shrink: 0; }
.activity-thumb { width: 36px; height: 36px; border-radius: 6px; object-fit: cover; flex-shrink: 0; }
/* Upload progress */
.upload-progress { display: none; margin-bottom: 14px; }
.upload-progress.active { display: block; }
.upload-progress-label { font-size: 12px; color: var(--text2); margin-bottom: 6px; text-align: center; }
.upload-progress-track { background: var(--bg3); border-radius: 99px; height: 6px; overflow: hidden; }
.upload-progress-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--red), var(--accent)); border-radius: 99px; transition: width 0.2s ease; }
/* Anytime toggle */
.anytime-toggle { width: 100%; padding: 14px 16px; border-radius: var(--radius-sm); border: 1px solid var(--border2); background: var(--bg3); color: var(--text2); font-size: 14px; font-weight: 500; font-family: var(--font); cursor: pointer; margin-bottom: 16px; transition: background 0.15s, border-color 0.15s, color 0.15s; text-align: left; }
.anytime-toggle.active { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); }
.anytime-toggle.active::before { content: '✓ '; font-weight: 700; }
/* Pull-to-refresh */
.ptr-indicator { display:flex; align-items:center; justify-content:center; height:0; overflow:hidden; transition: height 0.25s ease, opacity 0.25s ease; opacity:0; pointer-events:none; }
.ptr-indicator.pulling { transition:none; }
.ptr-indicator .ptr-spinner { width:22px; height:22px; border:2px solid var(--border2); border-top-color:var(--red); border-radius:50%; opacity:0.7; }
.ptr-indicator.refreshing .ptr-spinner { animation: ptrSpin 0.6s linear infinite; }
@keyframes ptrSpin { to { transform:rotate(360deg); } }

/* ═══ THE VAULT ═══ */
.vault-header { text-align:center; padding:24px 0 8px; }
.vault-logo { font-size:28px; font-weight:800; letter-spacing:-1px; color:var(--text); }
.vault-logo span { background:linear-gradient(135deg, #ffd54f, #ffab40); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.vault-sub { font-size:12px; color:var(--text3); margin-top:4px; letter-spacing:0.04em; text-transform:uppercase; }
.vault-updated { font-size:11px; color:var(--text3); opacity:0.5; margin-top:6px; }
.vault-section { margin-top:28px; }
.vault-section-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--amber); margin-bottom:14px; display:flex; align-items:center; gap:8px; }
.vault-section-title::after { content:''; flex:1; height:1px; background:linear-gradient(90deg, rgba(255,171,64,0.3), transparent); }
.vault-kpi-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.vault-kpi { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:14px 16px; position:relative; overflow:hidden; }
.vault-kpi::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg, var(--amber), transparent); opacity:0.4; }
.vault-kpi-label { font-size:10px; color:var(--text3); text-transform:uppercase; letter-spacing:0.06em; font-weight:500; }
.vault-kpi-value { font-size:22px; font-weight:800; color:var(--text); margin-top:4px; font-family:var(--mono); letter-spacing:-0.5px; }
.vault-kpi-delta { font-size:11px; font-weight:600; margin-top:3px; }
.vault-kpi-delta.up { color:#00e676; }
.vault-kpi-delta.down { color:var(--red); }
.vault-kpi-delta.flat { color:var(--text3); }
.vault-kpi.wide { grid-column: 1 / -1; }
.vault-chart-wrap { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:16px; margin-top:10px; }
.vault-chart-wrap canvas { width:100% !important; max-height:220px; }
.vault-chart-title { font-size:12px; font-weight:600; color:var(--text2); margin-bottom:12px; }
.vault-table { width:100%; border-collapse:collapse; font-size:12px; }
.vault-table th { text-align:left; color:var(--text3); font-size:10px; text-transform:uppercase; letter-spacing:0.06em; font-weight:600; padding:8px 8px 8px 0; border-bottom:1px solid var(--border); }
.vault-table td { padding:8px 8px 8px 0; color:var(--text2); border-bottom:1px solid rgba(255,255,255,0.03); }
.vault-table tr:last-child td { border-bottom:none; }
.vault-table td:first-child { color:var(--text); font-weight:500; }
.vault-insight { background:linear-gradient(135deg, rgba(255,171,64,0.06), rgba(255,213,79,0.03)); border:1px solid rgba(255,171,64,0.15); border-radius:12px; padding:16px 18px; margin-top:14px; }
.vault-insight-title { font-size:11px; font-weight:700; color:var(--amber); text-transform:uppercase; letter-spacing:0.06em; margin-bottom:8px; display:flex; align-items:center; gap:6px; }
.vault-insight p { font-size:13px; color:var(--text2); line-height:1.65; margin:0; }
.vault-insight p + p { margin-top:10px; }
.vault-insight strong { color:var(--text); font-weight:600; }
.vault-heatmap { overflow-x:auto; -webkit-overflow-scrolling:touch; margin-top:10px; }
.vault-heatmap table { border-collapse:collapse; font-size:10px; min-width:600px; }
.vault-heatmap th, .vault-heatmap td { padding:4px 6px; text-align:center; white-space:nowrap; }
.vault-heatmap th { color:var(--text3); font-weight:600; font-size:9px; }
.vault-heatmap td.cohort-label { text-align:left; color:var(--text2); font-weight:500; font-size:10px; min-width:70px; }
.vault-heatmap td.heat { border-radius:3px; font-weight:600; font-size:10px; min-width:32px; color:var(--text); }
.vault-funnel { display:flex; flex-direction:column; gap:6px; margin-top:10px; }
.vault-funnel-step { display:flex; align-items:center; gap:10px; }
.vault-funnel-bar { height:28px; border-radius:6px; background:linear-gradient(90deg, var(--amber), rgba(255,171,64,0.4)); display:flex; align-items:center; padding:0 10px; font-size:11px; font-weight:700; color:var(--bg); min-width:40px; }
.vault-funnel-label { font-size:11px; color:var(--text2); white-space:nowrap; }
.vault-tabs { display:flex; gap:6px; margin-bottom:16px; flex-wrap:wrap; }
.vault-tab { padding:7px 14px; border-radius:99px; border:1px solid var(--border); background:transparent; color:var(--text3); font-size:12px; font-weight:500; cursor:pointer; font-family:var(--font); transition:all 0.2s; }
.vault-tab.active { background:var(--amber); color:var(--bg); border-color:var(--amber); font-weight:700; }
.vault-atrisk-card { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:12px 14px; margin-bottom:8px; }
.vault-atrisk-name { font-size:13px; font-weight:600; color:var(--text); }
.vault-atrisk-meta { font-size:11px; color:var(--text3); margin-top:3px; }
.vault-atrisk-meta span { color:var(--red); font-weight:600; }
.vault-divider { height:1px; background:linear-gradient(90deg, transparent, var(--border2), transparent); margin:32px 0; }
.vault-rank-block { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:16px; margin-bottom:12px; }
.vault-rank-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.vault-rank-period { font-size:12px; font-weight:600; color:var(--text); }
.vault-rank-overall { font-size:11px; color:var(--amber); font-weight:700; background:rgba(255,171,64,0.1); padding:4px 10px; border-radius:99px; }
.vault-rank-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.vault-rank-item { display:flex; align-items:center; gap:8px; padding:8px 10px; background:var(--bg3); border-radius:8px; }
.vault-rank-pos { font-size:16px; font-weight:800; color:var(--amber); font-family:var(--mono); min-width:28px; }
.vault-rank-info { flex:1; }
.vault-rank-metric { font-size:11px; color:var(--text3); font-weight:500; }
.vault-rank-val { font-size:12px; color:var(--text2); font-weight:600; margin-top:1px; }
.vault-goal { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:12px 14px; margin-bottom:8px; }
.vault-goal-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.vault-goal-metric { font-size:12px; font-weight:600; color:var(--text); }
.vault-goal-nums { font-size:11px; color:var(--text3); }
.vault-goal-bar { height:8px; background:var(--bg3); border-radius:99px; overflow:hidden; }
.vault-goal-fill { height:100%; border-radius:99px; transition:width 0.6s ease; }
.vault-goal-pct { font-size:11px; font-weight:700; margin-top:4px; text-align:right; }
/* Install prompt */
/* Instructor cards */
.vault-instructor { background:var(--bg2); border:1px solid var(--border); border-radius:12px; padding:14px; margin-bottom:10px; }
.vault-instructor-header { display:flex; align-items:center; gap:12px; }
.vault-instructor-avatar { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; flex-shrink:0; }
.vault-instructor-avatar.top { background:rgba(0,230,118,0.15); color:#00e676; }
.vault-instructor-avatar.poor { background:rgba(255,82,82,0.15); color:#ff5252; }
.vault-instructor-name { font-size:14px; font-weight:600; color:var(--text); }
.vault-instructor-sub { font-size:11px; color:var(--text3); margin-top:2px; }
.vault-instructor-pct { font-size:22px; font-weight:800; margin-left:auto; }
.vault-instructor-pct.top { color:#00e676; }
.vault-instructor-pct.poor { color:#ff5252; }
.vault-instructor-detail { margin-top:10px; padding-top:10px; border-top:1px solid var(--border); font-size:12px; color:var(--text3); }
.vault-instructor-detail strong { color:var(--text2); }
/* Utilization bar */
.vault-util-bar { background:var(--bg3); border-radius:6px; height:10px; overflow:hidden; margin-top:6px; }
.vault-util-fill { height:100%; border-radius:6px; }
.install-prompt-overlay { position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:9999;display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity 0.3s;pointer-events:none; }
.install-prompt-overlay.show { opacity:1;pointer-events:auto; }
.install-prompt { background:var(--bg2);border-radius:20px 20px 0 0;padding:24px 20px calc(24px + var(--safe-bottom));width:100%;max-width:420px;transform:translateY(100%);transition:transform 0.35s cubic-bezier(0.32,0.72,0,1); }
.install-prompt-overlay.show .install-prompt { transform:translateY(0); }
.install-prompt-handle { width:36px;height:4px;background:var(--border2);border-radius:99px;margin:0 auto 20px; }
.install-prompt-icon { width:56px;height:56px;border-radius:14px;background:var(--bg3);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 2px 12px rgba(0,0,0,0.3); }
.install-prompt-icon img { width:40px;height:40px;border-radius:8px; }
.install-prompt h3 { font-size:18px;font-weight:700;color:var(--text);text-align:center;margin:0 0 6px; }
.install-prompt p { font-size:13px;color:var(--text3);text-align:center;margin:0 0 20px;line-height:1.5; }
.install-steps { background:var(--bg3);border-radius:12px;padding:16px;margin-bottom:20px; }
.install-step { display:flex;align-items:flex-start;gap:10px;padding:8px 0; }
.install-step + .install-step { border-top:1px solid var(--border); }
.install-step-num { width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--bg);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px; }
.install-step-text { font-size:13px;color:var(--text2);line-height:1.45; }
.install-step-text strong { color:var(--text);font-weight:600; }
.install-btn-row { display:flex;gap:10px; }
.install-btn-row button { flex:1;padding:14px;border-radius:12px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;border:none; }
.install-btn-dismiss { background:var(--bg3);color:var(--text3); }
.install-btn-native { background:var(--accent);color:#fff; }
.april-goals { margin-bottom:20px; }
.april-goals .ag-header { display:flex;align-items:center;gap:10px;margin-bottom:14px; }
.april-goals .ag-badge { background:var(--red);color:#fff;font-size:11px;font-weight:700;letter-spacing:0.5px;padding:4px 10px;border-radius:20px;text-transform:uppercase; }
.april-goals .ag-title { font-size:18px;font-weight:700;color:var(--text); }
.april-goals .ag-target-card { background:linear-gradient(135deg, rgba(255,82,82,0.12), rgba(255,82,82,0.04));border:1px solid rgba(255,82,82,0.25);border-radius:var(--radius);padding:20px;margin-bottom:12px;text-align:center; }
.april-goals .ag-target-num { font-size:42px;font-weight:800;color:var(--red);line-height:1; }
.april-goals .ag-target-label { font-size:13px;color:var(--text2);margin-top:4px;font-weight:500; }
.april-goals .ag-funnel { display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px; }
.april-goals .ag-funnel-item { background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 8px;text-align:center; }
.april-goals .ag-funnel-num { font-size:22px;font-weight:700;color:var(--text); }
.april-goals .ag-funnel-label { font-size:10px;color:var(--text3);margin-top:2px;line-height:1.3; }
.april-goals .ag-funnel-note { font-size:9px;color:var(--text3);margin-top:4px;opacity:0.7; }
.april-goals .ag-focus { background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px; }
.april-goals .ag-focus-title { font-size:13px;font-weight:700;color:var(--red);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.5px; }
.april-goals .ag-focus-item { font-size:13px;color:var(--text2);padding:4px 0;display:flex;align-items:flex-start;gap:8px; }
.april-goals .ag-focus-item::before { content:'';display:inline-block;width:6px;height:6px;background:var(--red);border-radius:50%;margin-top:5px;flex-shrink:0; }
.april-goals .ag-section-label { font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px; }
.scorecard { margin-bottom:28px; }
.sc-header { display:flex;align-items:center;gap:14px;margin-bottom:22px; }
.sc-badge { background:var(--red);color:#fff;font-size:15px;font-weight:700;letter-spacing:0.5px;padding:8px 16px;border-radius:20px;text-transform:uppercase; }
.sc-studio { font-size:20px;font-weight:700;color:var(--text); }
.sc-section { background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:16px;overflow-x:auto; }
.sc-section-title { font-size:16px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border); }
.sc-row { display:flex;align-items:center;padding:12px 8px;border-bottom:1px solid var(--border);min-width:0;border-radius:4px;transition:background 0.15s; }
.sc-row:last-child { border-bottom:none; }
.sc-row:nth-child(even) { background:rgba(255,255,255,0.02); }
.sc-row:hover { background:rgba(255,255,255,0.04); }
.sc-row-header { border-bottom:1px solid var(--border2); }
.sc-row-header .sc-val { font-weight:700;color:var(--text3); }
.sc-label { flex:1.4;font-size:16px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0; }
.sc-val { flex:1;text-align:center;font-size:18px;font-weight:700;color:var(--text);min-width:0; }
.sc-bold { font-weight:800; font-size:22px; }
.sc-month-label { font-size:14px;text-transform:uppercase;letter-spacing:0.3px; }
.sc-bench { font-size:12px;color:var(--text3);font-weight:500; }
.sc-sub .sc-label { padding-left:14px;font-size:14px;color:var(--text3); }
.sc-sub .sc-val { font-size:15px;font-weight:600;color:var(--text2); }
.sc-good { color:#00e676 !important; }
.sc-warn { color:#ffab40 !important; }
.sc-bad { color:#ff5252 !important; }
.sc-trend-up { color:#00e676;font-size:18px; }
.sc-trend-down { color:#ff5252;font-size:18px; }
.sc-trend-flat { color:var(--text3);font-size:18px; }

/* Skeleton loading states */
.skeleton { background: var(--bg3); border-radius: 8px; position: relative; overflow: hidden; }
.skeleton::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0%, var(--skeleton-shimmer, rgba(255,255,255,0.04)) 50%, transparent 100%); animation: skeletonShimmer 1.5s ease infinite; }
@keyframes skeletonShimmer { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }
.skeleton-text { height: 12px; margin-bottom: 8px; }
.skeleton-text.w60 { width: 60%; }
.skeleton-text.w80 { width: 80%; }
.skeleton-text.w40 { width: 40%; }
.skeleton-text.w100 { width: 100%; }
.skeleton-circle { border-radius: 50%; }
.skeleton-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 18px; padding: 18px; margin-bottom: 14px; }
.skeleton-leader-row { display: flex; align-items: center; gap: 10px; padding: 12px 0; }
.skeleton-leader-row + .skeleton-leader-row { border-top: 0.5px solid var(--border); }
.skeleton-stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.skeleton-stat-box { background: var(--bg3); border-radius: 12px; padding: 18px 14px; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.skeleton-activity-item { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; margin-bottom: 8px; }
.skeleton-gallery-item { aspect-ratio: 1; border-radius: 12px; }
.skeleton-admin-card { background: #111; border: 1px solid rgba(255,255,255,0.05); border-radius: 22px; overflow: hidden; margin-bottom: 20px; }
.skeleton-media { width: 100%; height: 180px; }

/* Nav badge */
.nav-badge { position: absolute; top: 2px; right: 50%; transform: translateX(14px); min-width: 16px; height: 16px; border-radius: 99px; background: var(--red); color: #fff; font-size: 9px; font-weight: 700; font-family: var(--font-display); display: flex; align-items: center; justify-content: center; padding: 0 4px; border: 2px solid var(--bg); line-height: 1; }

/* Onboarding tour */
.tour-overlay { position: fixed; inset: 0; z-index: 9998; background: rgba(0,0,0,0.75); display: flex; align-items: flex-end; justify-content: center; padding: 20px; animation: fadeUp 0.2s ease; }
.tour-card { background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--radius); max-width: 360px; width: 100%; padding: 24px 20px 20px; text-align: center; animation: sheetUp 0.25s ease; }
.tour-step-dots { display: flex; gap: 6px; justify-content: center; margin-bottom: 16px; }
.tour-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--bg4); }
.tour-dot.active { background: var(--accent); width: 16px; border-radius: 3px; }
.tour-emoji { font-size: 36px; margin-bottom: 12px; }
.tour-title { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 6px; font-family: var(--font-display); }
.tour-desc { font-size: 13px; color: var(--text2); line-height: 1.6; margin-bottom: 20px; }
.tour-next { width: 100%; padding: 14px; background: var(--accent); color: #000; font-size: 15px; font-weight: 700; font-family: var(--font-display); border: none; border-radius: var(--radius-sm); cursor: pointer; }
.tour-skip { background: none; border: none; color: var(--text3); font-size: 12px; font-family: var(--font); cursor: pointer; margin-top: 10px; }

/* Content calendar */
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; margin-bottom: 16px; }
.cal-header { font-size: 10px; font-weight: 700; color: var(--text3); text-align: center; padding: 8px 0; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; }
.cal-day { min-height: 56px; background: var(--bg2); border-radius: 6px; padding: 4px; position: relative; cursor: default; }
.cal-day.empty { background: transparent; }
.cal-day.today { border: 1px solid var(--accent); }
.cal-day-num { font-size: 10px; font-weight: 600; color: var(--text3); margin-bottom: 2px; }
.cal-day.has-posts .cal-day-num { color: var(--text); }
.cal-dots { display: flex; flex-wrap: wrap; gap: 2px; }
.cal-dot { width: 6px; height: 6px; border-radius: 50%; }
.cal-dot.pending { background: var(--amber); }
.cal-dot.approved { background: var(--green); }
.cal-dot.rejected { background: var(--red); }
.cal-month-title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 14px; font-family: var(--font-display); text-align: center; }
.cal-legend { display: flex; gap: 14px; justify-content: center; margin-bottom: 16px; font-size: 11px; color: var(--text3); }
.cal-legend-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; margin-right: 4px; vertical-align: middle; }

/* Social card preview (Instagram-style) */
.social-preview { background: #000; border-radius: 16px; overflow: hidden; margin-bottom: 20px; border: 1px solid var(--border2); }
.social-preview-header { display: flex; align-items: center; gap: 10px; padding: 12px 14px; }
.social-preview-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--accent-dim); color: var(--accent); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; flex-shrink: 0; }
.social-preview-name { font-size: 13px; font-weight: 700; color: #fff; font-family: var(--font-display); }
.social-preview-studio { font-size: 11px; color: rgba(255,255,255,0.5); }
.social-preview-media { width: 100%; aspect-ratio: 1; background: var(--bg3); overflow: hidden; }
.social-preview-media img, .social-preview-media video { width: 100%; height: 100%; object-fit: cover; display: block; }
.social-preview-actions { display: flex; gap: 14px; padding: 12px 14px 8px; }
.social-preview-actions svg { width: 22px; height: 22px; stroke: #fff; fill: none; stroke-width: 1.8; }
.social-preview-caption { padding: 0 14px 14px; font-size: 13px; color: rgba(255,255,255,0.85); line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.social-preview-caption strong { color: #fff; }
.social-preview-label { font-size: 10px; color: var(--text3); text-align: center; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; font-family: var(--font-display); }

/* Animated stat entrance */
@keyframes statSlideUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.stat-box-animated { opacity: 0; animation: statSlideUp 0.35s cubic-bezier(0.34,1.56,0.64,1) forwards; }

/* ══════════════════════════════════════════
   MANAGER NOTES ON REVIEW QUEUE
   ══════════════════════════════════════════ */
.notes-divider { height: 1px; background: var(--border); margin: 4px 0 14px; opacity: 0.6; }
.notes-section { margin-top: 2px; margin-bottom: 14px; }
.notes-label { display: flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: 0.06em; font-family: var(--font-display); margin-bottom: 10px; padding-left: 2px; }
.notes-label svg { width: 14px; height: 14px; opacity: 0.5; }
.notes-count { font-size: 10px; padding: 1px 6px; border-radius: 99px; background: rgba(255,171,64,0.12); color: #ffab40; font-weight: 700; }
.note-bubble { background: rgba(255,171,64,0.06); border: 1px solid rgba(255,171,64,0.12); border-radius: 14px; padding: 14px 16px; margin-bottom: 8px; animation: fadeUp 0.2s ease; position: relative; }
.note-bubble::before { content: ''; position: absolute; top: -6px; left: 20px; width: 12px; height: 12px; background: rgba(255,171,64,0.06); border-left: 1px solid rgba(255,171,64,0.12); border-top: 1px solid rgba(255,171,64,0.12); transform: rotate(45deg); }
.note-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.note-author { display: flex; align-items: center; gap: 8px; }
.note-avatar { width: 22px; height: 22px; border-radius: 50%; background: rgba(255,171,64,0.12); color: #ffab40; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; }
.note-author-name { font-size: 12px; font-weight: 600; color: #ffab40; font-family: var(--font-display); }
.note-author-role { font-size: 10px; font-weight: 500; color: var(--text3); text-transform: uppercase; letter-spacing: 0.04em; padding: 1px 6px; border-radius: 99px; background: rgba(255,171,64,0.08); }
.note-time { font-size: 11px; color: var(--text3); opacity: 0.6; }
.note-text { font-size: 13px; color: var(--text2); line-height: 1.6; }
.note-tag { display: inline-block; padding: 1px 8px; border-radius: 6px; background: rgba(68,138,255,0.1); color: #448aff; font-size: 11px; font-weight: 600; margin-left: 4px; vertical-align: middle; }
.note-input-wrap { margin-top: 6px; }
.note-input-area { background: var(--bg3); border: 1px solid var(--border); border-radius: 14px; padding: 12px 14px; transition: border-color 0.2s, box-shadow 0.2s; }
.note-input-area:focus-within { border-color: #ffab40; box-shadow: 0 0 0 3px rgba(255,171,64,0.08); }
.note-textarea { width: 100%; border: none; background: none; color: var(--text); font-size: 13px; font-family: var(--font); line-height: 1.6; resize: none; outline: none; min-height: 36px; max-height: 120px; }
.note-textarea::placeholder { color: var(--text3); }
.note-input-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 8px; padding-top: 8px; border-top: 0.5px solid var(--border); }
.note-char-count { font-size: 11px; color: var(--text3); opacity: 0.5; }
.note-send-btn { display: flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: 99px; background: #ffab40; color: #000; font-size: 12px; font-weight: 600; font-family: var(--font); border: none; cursor: pointer; transition: all 0.15s; }
.note-send-btn:active { transform: scale(0.95); }
.note-send-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.note-send-btn svg { width: 14px; height: 14px; }
.note-delete-btn { background: none; border: none; color: var(--text3); font-size: 14px; cursor: pointer; opacity: 0.4; padding: 2px 6px; transition: opacity 0.15s; }
.note-delete-btn:hover { opacity: 0.8; color: var(--red); }

/* Light theme overrides for notes */
.theme-light .note-bubble { background: rgba(74,144,217,0.06); border-color: rgba(74,144,217,0.12); }
.theme-light .note-bubble::before { background: rgba(74,144,217,0.06); border-color: rgba(74,144,217,0.12); }
.theme-light .note-avatar { background: rgba(74,144,217,0.12); color: #4A90D9; }
.theme-light .note-author-name { color: #4A90D9; }
.theme-light .note-author-role { background: rgba(74,144,217,0.08); }
.theme-light .notes-count { background: rgba(74,144,217,0.12); color: #4A90D9; }
.theme-light .note-input-area:focus-within { border-color: #4A90D9; box-shadow: 0 0 0 3px rgba(74,144,217,0.08); }
.theme-light .note-send-btn { background: #4A90D9; color: #fff; }

/* ══════════════════════════════════════════
   DOCUMENT LIBRARY
   ══════════════════════════════════════════ */
.doc-count-badge { font-size: 12px; font-weight: 700; color: var(--text3); padding: 2px 10px; border-radius: 99px; background: var(--bg3); border: 0.5px solid var(--border); }
.doc-search-bar { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 12px; background: var(--bg3); border: 0.5px solid var(--border); margin-bottom: 16px; transition: border-color 0.2s; }
.doc-search-bar:focus-within { border-color: var(--accent); }
.doc-search-bar svg { width: 16px; height: 16px; color: var(--text3); flex-shrink: 0; }
.doc-search-bar input { flex: 1; border: none; background: none; color: var(--text); font-size: 14px; font-family: var(--font); outline: none; }
.doc-search-bar input::placeholder { color: var(--text3); }
.category-tabs { display: flex; gap: 6px; overflow-x: auto; padding-bottom: 4px; margin-bottom: 18px; }
.category-tabs::-webkit-scrollbar { display: none; }
.cat-tab { display: flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 12px; background: var(--bg3); border: 0.5px solid var(--border); color: var(--text3); font-size: 12px; font-weight: 500; font-family: var(--font); cursor: pointer; transition: all 0.2s; flex-shrink: 0; white-space: nowrap; }
.cat-tab:active { transform: scale(0.97); }
.cat-tab.active { background: var(--red-dim); color: var(--red); border-color: rgba(255,82,82,0.2); font-weight: 600; }
.theme-light .cat-tab.active { background: rgba(74,144,217,0.1); color: var(--accent); border-color: rgba(74,144,217,0.2); }
.category-count { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 99px; background: rgba(255,255,255,0.06); color: var(--text3); min-width: 18px; text-align: center; }
.cat-tab.active .category-count { background: rgba(255,82,82,0.15); color: var(--red); }
.theme-light .cat-tab.active .category-count { background: rgba(74,144,217,0.15); color: var(--accent); }
.upload-zone { border: 2px dashed rgba(255,255,255,0.1); border-radius: 18px; padding: 32px 20px; display: flex; flex-direction: column; align-items: center; gap: 12px; margin-bottom: 20px; cursor: pointer; transition: all 0.25s; background: rgba(255,255,255,0.02); }
.upload-zone:hover { border-color: rgba(255,82,82,0.3); background: rgba(255,82,82,0.03); }
.theme-light .upload-zone { border-color: rgba(0,0,0,0.1); background: rgba(74,144,217,0.03); }
.theme-light .upload-zone:hover { border-color: rgba(74,144,217,0.3); background: rgba(74,144,217,0.06); }
.upload-zone-icon { width: 56px; height: 56px; border-radius: 50%; background: var(--accent-dim); color: var(--accent); display: flex; align-items: center; justify-content: center; font-size: 24px; transition: transform 0.2s; }
.upload-zone:hover .upload-zone-icon { transform: scale(1.05); }
.upload-zone-text { font-size: 14px; font-weight: 600; color: var(--text2); font-family: var(--font-display); text-align: center; }
.upload-zone-sub { font-size: 12px; color: var(--text3); text-align: center; }
.doc-card { background: #111; border: 1px solid rgba(255,255,255,0.05); border-radius: 16px; padding: 16px; margin-bottom: 12px; display: flex; gap: 14px; align-items: flex-start; box-shadow: var(--card-glow); transition: transform 0.15s, box-shadow 0.25s; cursor: pointer; animation: fadeUp 0.3s ease backwards; }
.doc-card:hover { box-shadow: var(--card-glow-active); }
.doc-card:active { transform: scale(0.98); }
.theme-light .doc-card { background: #fff; border-color: rgba(0,0,0,0.05); }
.doc-type-icon { width: 44px; height: 44px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; flex-shrink: 0; font-family: var(--font-display); letter-spacing: -0.3px; text-transform: uppercase; }
.doc-type-icon.pdf { background: rgba(255,82,82,0.12); color: #ff5252; }
.doc-type-icon.doc { background: rgba(68,138,255,0.12); color: #448aff; }
.doc-type-icon.img { background: rgba(0,230,118,0.12); color: #00e676; }
.doc-type-icon.vid { background: rgba(187,134,252,0.12); color: #bb86fc; }
.doc-type-icon.gen { background: rgba(255,171,64,0.12); color: #ffab40; }
.theme-light .doc-type-icon.pdf { background: rgba(220,60,60,0.08); color: #c44; }
.theme-light .doc-type-icon.doc { background: rgba(40,100,200,0.08); color: #2864c8; }
.theme-light .doc-type-icon.img { background: rgba(80,180,80,0.08); color: #4a4; }
.theme-light .doc-type-icon.vid { background: rgba(160,60,200,0.08); color: #a03cc8; }
.doc-info { flex: 1; min-width: 0; }
.doc-name { font-size: 14px; font-weight: 600; color: var(--text); font-family: var(--font-display); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 3px; }
.doc-meta { font-size: 11px; color: var(--text3); line-height: 1.6; display: flex; flex-wrap: wrap; gap: 0 8px; }
.doc-meta span { white-space: nowrap; }
.doc-meta .dot { opacity: 0.4; }
.doc-category-tag { display: inline-block; padding: 1px 8px; border-radius: 6px; font-size: 10px; font-weight: 600; }
.doc-category-tag.sops { background: rgba(255,82,82,0.08); color: var(--red); }
.doc-category-tag.training { background: rgba(0,230,118,0.08); color: var(--green); }
.doc-category-tag.policies { background: rgba(68,138,255,0.08); color: var(--blue); }
.doc-category-tag.general { background: rgba(255,171,64,0.08); color: var(--amber); }
.doc-actions { display: flex; flex-direction: column; gap: 4px; flex-shrink: 0; align-self: center; }
.doc-action-btn { width: 32px; height: 32px; border-radius: 8px; background: var(--bg3); border: 0.5px solid var(--border); color: var(--text3); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.15s; font-size: 14px; }
.doc-action-btn:hover { background: var(--bg4); color: var(--text2); }
.doc-action-btn:active { transform: scale(0.92); }
.doc-action-btn.delete:hover { background: var(--red-dim); color: var(--red); }
.doc-card:nth-child(1) { animation-delay: 0ms; }
.doc-card:nth-child(2) { animation-delay: 40ms; }
.doc-card:nth-child(3) { animation-delay: 80ms; }
.doc-card:nth-child(4) { animation-delay: 120ms; }
.doc-card:nth-child(5) { animation-delay: 160ms; }
.doc-card:nth-child(6) { animation-delay: 200ms; }

/* ═══════════════════════════════════════════════════
   UI ENHANCEMENTS — Apr 5
   ═══════════════════════════════════════════════════ */

/* 1. April Target — Bullseye icon */
.ag-badge {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
}
.ag-badge::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Ccircle cx='12' cy='12' r='10' stroke='%23fff' stroke-width='1.8'/%3E%3Ccircle cx='12' cy='12' r='6' stroke='%23fff' stroke-width='1.5'/%3E%3Ccircle cx='12' cy='12' r='2.2' fill='%23fff'/%3E%3Cline x1='20' y1='4' x2='13.5' y2='10.5' stroke='%23fff' stroke-width='1.5' stroke-linecap='round'/%3E%3Cline x1='17' y1='4' x2='20' y2='4' stroke='%23fff' stroke-width='1.5' stroke-linecap='round'/%3E%3Cline x1='20' y1='4' x2='20' y2='7' stroke='%23fff' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;
  flex-shrink: 0;
  filter: drop-shadow(0 0 3px rgba(255,255,255,0.4));
}
@keyframes bullseyePulse {
  0%, 100% { transform: scale(1); filter: drop-shadow(0 0 3px rgba(255,255,255,0.4)); }
  50% { transform: scale(1.15); filter: drop-shadow(0 0 8px rgba(255,82,82,0.7)); }
}
.ag-badge::before {
  animation: bullseyePulse 2.5s ease-in-out infinite;
}

/* 2. Leaderboard Medals — Metallic shine */
.rank-medal {
  position: relative;
  overflow: hidden;
}
.rank-medal::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -80%;
  width: 40%;
  height: 200%;
  background: linear-gradient(
    105deg,
    transparent 30%,
    rgba(255,255,255,0.5) 45%,
    rgba(255,255,255,0.8) 50%,
    rgba(255,255,255,0.5) 55%,
    transparent 70%
  );
  animation: medalShine 3s ease-in-out infinite;
  pointer-events: none;
}
@keyframes medalShine {
  0% { left: -80%; }
  30% { left: 120%; }
  100% { left: 120%; }
}
/* Stagger the shine per medal */
.leader-item:nth-child(1) .rank-medal::after { animation-delay: 0s; }
.leader-item:nth-child(2) .rank-medal::after { animation-delay: 0.8s; }
.leader-item:nth-child(3) .rank-medal::after { animation-delay: 1.6s; }

/* Gold medal glow */
.leader-item:nth-child(1) .rank-medal {
  filter: drop-shadow(0 0 6px rgba(255,215,0,0.5));
}
/* Silver medal glow */
.leader-item:nth-child(2) .rank-medal {
  filter: drop-shadow(0 0 5px rgba(192,192,192,0.4));
}
/* Bronze medal glow */
.leader-item:nth-child(3) .rank-medal {
  filter: drop-shadow(0 0 5px rgba(205,127,50,0.4));
}

/* 3. Feed/Pulse Tab Toggle — Pill slider */
.dash-tabs {
  display: flex !important;
  gap: 0 !important;
  padding: 6px 20px !important;
  background: var(--bg) !important;
  position: relative;
}
.dash-tabs-inner {
  display: flex;
  position: relative;
  background: var(--bg3);
  border-radius: 12px;
  padding: 3px;
  width: 100%;
  border: 1px solid var(--border);
}
.dash-tab {
  flex: 1;
  padding: 10px 0 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border: none !important;
  border-radius: 10px !important;
  cursor: pointer;
  transition: color 0.25s ease, text-shadow 0.25s ease !important;
  background: transparent !important;
  color: var(--text3) !important;
  position: relative;
  z-index: 2;
}
.dash-tab.active {
  color: #fff !important;
  background: transparent !important;
  text-shadow: 0 1px 8px rgba(255,255,255,0.2);
}
.dash-tab-slider {
  position: absolute;
  top: 3px;
  bottom: 3px;
  left: 0;
  width: 0;
  background: var(--accent);
  border-radius: 10px;
  transition: left 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), width 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  box-shadow: 0 0 14px rgba(var(--accent-rgb, 255,82,82), 0.4), 0 0 30px rgba(var(--accent-rgb, 255,82,82), 0.15);
  z-index: 1;
}

/* 4. Hero Tagline Breathing Animation */
@keyframes heroBreath {
  0%   { transform: scale(0.92); opacity: 0.7; }
  25%  { transform: scale(1.08); opacity: 1; }
  50%  { transform: scale(0.95); opacity: 0.85; }
  75%  { transform: scale(1.06); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}
.hero-tagline.breathing {
  animation: heroBreath 5s cubic-bezier(0.37, 0, 0.63, 1) forwards;
  will-change: transform, opacity;
}

/* 5. 1st Place Name in Flames */
@keyframes flameFlicker {
  0%   { background-position: 0% 50%; }
  25%  { background-position: 50% 0%; }
  50%  { background-position: 100% 50%; }
  75%  { background-position: 50% 100%; }
  100% { background-position: 0% 50%; }
}
@keyframes flameGlow {
  0%, 100% { text-shadow: 0 0 8px rgba(255,100,0,0.5), 0 0 20px rgba(255,60,0,0.3), 0 -4px 12px rgba(255,200,0,0.2); }
  50%      { text-shadow: 0 0 12px rgba(255,100,0,0.7), 0 0 30px rgba(255,60,0,0.45), 0 -6px 18px rgba(255,200,0,0.35); }
}
.leader-name-flames {
  background: linear-gradient(
    -45deg,
    #ff4500 0%,
    #ff8c00 15%,
    #ffd700 30%,
    #ff6347 45%,
    #ff4500 55%,
    #ffcc00 70%,
    #ff8c00 85%,
    #ff4500 100%
  ) !important;
  background-size: 300% 300% !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  animation: flameFlicker 2s ease-in-out infinite, flameGlow 1.5s ease-in-out infinite !important;
  filter: brightness(1.1);
}

/* Prevent zoom/select on UI — feel native */
html { touch-action: manipulation; }
button, a, .nav-item, .fpill, .sfpill, .sheet-option, .studio-pill, .dash-tab, .cat-tab { touch-action: manipulation; -webkit-user-select: none; user-select: none; }

/* ─── Activity Dashboard ─── */
.act-stat-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 12px; text-align: center; }
.act-stat-val { font-size: 24px; font-weight: 800; color: var(--text); font-variant-numeric: tabular-nums; letter-spacing: -0.02em; }
.act-stat-label { font-size: 11px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.05em; margin-top: 4px; }
.act-stat-card.frust-low .act-stat-val { color: var(--green); }
.act-stat-card.frust-mid .act-stat-val { color: var(--amber); }
.act-stat-card.frust-high .act-stat-val { color: var(--red); }

.act-session-row { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-bottom: 1px solid var(--border); cursor: pointer; transition: background 0.15s; }
.act-session-row:hover { background: var(--bg3); }
.act-session-row:last-child { border-bottom: none; }
.act-session-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--bg4); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: var(--text2); flex-shrink: 0; }
.act-session-info { flex: 1; min-width: 0; }
.act-session-name { font-size: 14px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.act-session-meta { font-size: 11px; color: var(--text3); margin-top: 2px; }
.act-badge { display: inline-block; padding: 2px 8px; border-radius: 99px; font-size: 11px; font-weight: 600; }
.act-badge-green { background: rgba(0,230,118,0.12); color: var(--green); }
.act-badge-amber { background: rgba(255,171,64,0.12); color: var(--amber); }
.act-badge-red { background: rgba(255,82,82,0.12); color: var(--red); }

.act-issue-row { padding: 14px 16px; border-bottom: 1px solid var(--border); }
.act-issue-row:last-child { border-bottom: none; }
.act-issue-type { font-size: 13px; font-weight: 600; color: var(--text); }
.act-issue-page { font-size: 11px; color: var(--text3); }
.act-issue-count { font-size: 13px; font-weight: 700; color: var(--red); float: right; }

.act-bar { display: flex; align-items: center; gap: 10px; padding: 6px 0; }
.act-bar-label { font-size: 12px; color: var(--text2); width: 80px; flex-shrink: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.act-bar-fill { height: 8px; border-radius: 99px; background: var(--accent); transition: width 0.3s ease; }
.act-bar-count { font-size: 11px; color: var(--text3); min-width: 28px; text-align: right; }

.act-drawer { flex: 1; overflow: hidden; display: flex; flex-direction: column; }
.act-drawer-inner { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.act-event-item { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 12px; }
.act-event-item:last-child { border-bottom: none; }
.act-event-icon { font-size: 14px; flex-shrink: 0; width: 20px; text-align: center; }
.act-event-detail { flex: 1; color: var(--text2); line-height: 1.4; }
.act-event-time { font-size: 10px; color: var(--text3); flex-shrink: 0; font-family: var(--mono); }

/* ---------- Goal Forecast Widget ---------- */
.gf-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  margin-top: 16px;
}
.gf-loading, .gf-error {
  color: var(--text3);
  font-size: 13px;
  text-align: center;
  padding: 12px 0;
}
.gf-header-title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--text1);
  margin-bottom: 8px;
}
.gf-progress-bar {
  height: 6px;
  background: var(--bg3);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 6px;
}
.gf-progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 99px;
  transition: width 0.4s ease;
}
.gf-header-meta {
  font-size: 12px;
  color: var(--text2);
  margin-bottom: 12px;
}
.gf-celebrate {
  background: rgba(46, 204, 113, 0.12);
  color: #2ecc71;
  padding: 10px 12px;
  border-radius: 10px;
  text-align: center;
  font-weight: 700;
  margin: 8px 0 14px;
}
.gf-likelihood-section {
  text-align: center;
  padding: 14px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: 8px 0;
}
.gf-likelihood-label {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--text3);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.gf-chip {
  display: inline-block;
  font-size: 38px;
  font-weight: 800;
  padding: 6px 18px;
  border-radius: 99px;
}
.gf-chip-green { background: rgba(46, 204, 113, 0.15); color: #2ecc71; }
.gf-chip-amber { background: rgba(241, 196, 15, 0.15); color: #f1c40f; }
.gf-chip-red { background: rgba(231, 76, 60, 0.15); color: #e74c3c; }
.gf-likelihood-meta {
  font-size: 11px;
  color: var(--text2);
  margin-top: 10px;
  line-height: 1.5;
  padding: 0 8px;
}
.gf-rates-period {
  font-size: 10px;
  color: var(--text3);
  margin-top: 4px;
}
.gf-empty, .gf-empty-small {
  color: var(--text3);
  font-size: 12px;
  text-align: center;
  padding: 12px 0;
}
.gf-upcoming-section, .gf-actions-section {
  margin-top: 14px;
}
.gf-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--text3);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.gf-refresh-btn {
  background: var(--bg3);
  border: 1px solid var(--border);
  color: var(--text2);
  padding: 4px 10px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
}
.gf-intro-row {
  display: grid;
  grid-template-columns: 92px 80px 1fr 46px;
  gap: 8px;
  align-items: center;
  font-size: 12px;
  padding: 6px 0;
  border-bottom: 1px dashed var(--border);
}
.gf-intro-row:last-of-type { border-bottom: none; }
.gf-intro-when { color: var(--text1); font-weight: 600; }
.gf-intro-coach { color: var(--text2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gf-intro-bar {
  height: 6px;
  background: var(--bg3);
  border-radius: 99px;
  overflow: hidden;
}
.gf-intro-bar-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 99px;
}
.gf-intro-count { text-align: right; color: var(--text2); font-variant-numeric: tabular-nums; }
.gf-intro-total {
  text-align: right;
  margin-top: 8px;
  font-size: 12px;
  color: var(--text2);
  font-weight: 600;
}
.gf-actions-title {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--text3);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.gf-actions-line {
  font-size: 13px;
  color: var(--text1);
  padding: 3px 0;
}
.gf-focus-title {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--text3);
  text-transform: uppercase;
  margin-top: 14px;
  margin-bottom: 6px;
}
.gf-focus-item {
  font-size: 12px;
  color: var(--text2);
  padding: 2px 0;
}
.gf-warning {
  margin-top: 12px;
  padding: 8px 10px;
  background: rgba(241, 196, 15, 0.1);
  color: #f1c40f;
  border-radius: 8px;
  font-size: 11px;
  text-align: center;
}
.gf-footer {
  margin-top: 12px;
  font-size: 10px;
  color: var(--text3);
  text-align: right;
}
@media (max-width: 420px) {
  .gf-intro-row {
    grid-template-columns: 82px 64px 1fr 42px;
    gap: 6px;
    font-size: 11px;
  }
  .gf-chip { font-size: 32px; }
}

/* Goal Forecast — coaching mode (<30% likelihood) */
.gf-pep {
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  margin: 4px 0 12px;
  letter-spacing: 0.2px;
}
.gf-coaching-headline {
  font-size: 12px;
  color: var(--text2);
  margin-bottom: 14px;
}
.gf-coaching-headline strong { color: var(--text1); font-weight: 700; }
.gf-coaching-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: left;
  margin: 0 auto 14px;
  max-width: 320px;
}
.gf-coaching-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 8px 14px;
  background: var(--bg3);
  border-radius: 10px;
}
.gf-coaching-num {
  font-size: 28px;
  font-weight: 800;
  color: var(--accent);
  min-width: 56px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.gf-coaching-label {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.3;
}
.gf-coaching-gap {
  font-size: 12px;
  color: var(--text2);
  padding: 8px 12px;
  margin: 0 auto 6px;
  max-width: 320px;
  background: rgba(255,255,255,0.03);
  border-radius: 8px;
  text-align: center;
}
.gf-coaching-gap strong { color: var(--accent); font-size: 14px; }
.gf-coach-notes {
  text-align: left;
  margin: 14px auto 2px;
  max-width: 320px;
}
.gf-coach-notes-title {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--text3);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.gf-coach-note {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.5;
  padding: 4px 0;
}
.gf-coach-note strong { color: var(--text1); }
