/* ========== BASE ========== */
* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --bg:        #080c10;
  --bg2:       #0d1117;
  --bg3:       #161b22;
  --bg4:       #1c2430;
  --border:    #21293a;
  --border2:   #30363d;
  --green:     #3fb950;
  --green-glow:rgba(63,185,80,0.25);
  --green-hi:  #56d364;
  --cyan:      #39d0d8;
  --cyan-glow: rgba(57,208,216,0.2);
  --text:      #e6edf3;
  --muted:     #8b949e;
  --muted2:    #6e7681;
  --red:       #f85149;
  --vanga:     #39d0d8;
  --amber:     #f59e0b;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
}

/* Animated grid background */
body::before {
  content:'';
  position:fixed; inset:0;
  background-image:
    linear-gradient(rgba(63,185,80,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(63,185,80,0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events:none;
  z-index:0;
}

/* ========== PRELOADER ========== */
.preloader {
  position:fixed; inset:0;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
  z-index:9999;
}
.preloader.hidden { display:none; }
.preloader-content { text-align:center; position:relative; z-index:10; }
.preloader-icon { font-size:56px; display:block; margin-bottom:24px;
  filter:drop-shadow(0 0 20px rgba(63,185,80,0.6));
  animation:breathe 2s ease-in-out infinite; }
@keyframes breathe {
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.08);opacity:0.85}
}
.preloader-logo {
  font-family:'Press Start 2P',monospace;
  color:var(--green); font-size:15px; letter-spacing:3px;
  margin-bottom:8px; text-shadow:0 0 20px var(--green-glow);
}
.preloader-sub { color:var(--cyan); font-size:10px; font-family:'Press Start 2P',monospace;
  letter-spacing:2px; margin-bottom:28px; }
.preloader-bar {
  width:260px; height:4px; background:var(--border);
  border-radius:2px; margin:0 auto 16px; overflow:hidden;
  box-shadow:0 0 8px rgba(63,185,80,0.15);
}
.preloader-progress {
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--green),var(--cyan));
  transition:width 0.4s ease;
  box-shadow:0 0 8px var(--green);
}
.preloader-text { color:var(--muted); font-size:12px; letter-spacing:0.5px; }
.preloader-joke { color:var(--muted2); font-size:13px; max-width:340px;
  margin:12px auto 0; line-height:1.5; min-height:40px; }

/* ========== SHARED SCREEN WRAPPER ========== */
.screen {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  padding:24px; position:relative; z-index:1;
}
#vanga-result-screen {
  align-items:flex-start; padding:20px 16px;
}

/* ========== LOGIN ========== */
.login-card {
  background:var(--bg3); border-radius:16px;
  border:1px solid var(--border2);
  box-shadow:0 0 0 1px rgba(63,185,80,0.1), 0 24px 48px rgba(0,0,0,0.5);
  padding:52px 48px; text-align:center; width:100%; max-width:440px;
  position:relative; overflow:hidden;
}
.login-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--cyan),var(--green));
  background-size:200%;
  animation:shimmer 3s linear infinite;
}
@keyframes shimmer { 0%{background-position:0%}100%{background-position:200%} }

.brand-icon { font-size:52px; display:block; margin-bottom:20px;
  filter:drop-shadow(0 0 16px rgba(63,185,80,0.5)); }
.brand-title {
  font-family:'Press Start 2P',monospace;
  font-size:13px; letter-spacing:3px; margin-bottom:4px;
  background:linear-gradient(135deg,var(--green),var(--cyan));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.brand-sub { color:var(--cyan); font-size:10px;
  font-family:'Press Start 2P',monospace; letter-spacing:2px;
  margin-bottom:28px; opacity:0.8; }
.login-desc { color:var(--muted); font-size:14px; line-height:1.6; margin-bottom:24px; }
.login-desc a { color:var(--green); text-decoration:none; }
.login-desc a:hover { text-decoration:underline; }

.code-input {
  width:100%; padding:16px 20px; border-radius:10px;
  border:1px solid var(--border2); background:var(--bg2);
  color:var(--text); font-size:24px; text-align:center;
  letter-spacing:8px; font-weight:700; outline:none;
  transition:all 0.2s; margin-bottom:16px; font-family:monospace;
}
.code-input:focus {
  border-color:var(--green);
  box-shadow:0 0 0 3px var(--green-glow), 0 0 20px rgba(63,185,80,0.1);
}
.code-input::placeholder { letter-spacing:4px; font-size:18px; opacity:0.3; }

.btn-primary {
  width:100%; padding:16px; border-radius:10px; border:none;
  background:linear-gradient(135deg,var(--green),var(--green-hi));
  color:#080c10; font-weight:800; font-size:14px; cursor:pointer;
  letter-spacing:1px; text-transform:uppercase;
  box-shadow:0 4px 16px rgba(63,185,80,0.35);
  transition:all 0.2s;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(63,185,80,0.5); }
.btn-primary:active { transform:translateY(0); }
.btn-primary:disabled { opacity:0.4; cursor:not-allowed; transform:none; box-shadow:none; }

.login-error { color:var(--red); font-size:13px; margin-top:12px;
  display:none; font-weight:500; }

/* ========== PROJECT SELECTOR ========== */
.project-card-wrap {
  width:100%; max-width:700px;
  background:var(--bg3); border-radius:16px;
  border:1px solid var(--border2);
  box-shadow:0 0 0 1px rgba(63,185,80,0.08), 0 24px 48px rgba(0,0,0,0.5);
  padding:48px 40px; text-align:center; position:relative; overflow:hidden;
}
.project-card-wrap::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--cyan),var(--green));
  background-size:200%; animation:shimmer 3s linear infinite;
}

.screen-icon { font-size:48px; display:block; margin-bottom:20px;
  filter:drop-shadow(0 0 14px rgba(63,185,80,0.45)); }
.screen-title {
  font-family:'Press Start 2P',monospace; font-size:13px;
  letter-spacing:3px; margin-bottom:6px;
  background:linear-gradient(135deg,var(--green),var(--cyan));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.screen-sub { color:var(--muted); font-size:15px; margin-bottom:32px; }

.proj-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:28px; }
.proj-btn {
  padding:32px 20px; background:var(--bg4);
  border:2px solid var(--border); border-radius:14px;
  cursor:pointer; transition:all 0.25s; text-align:center; position:relative;
  overflow:hidden;
}
.proj-btn::after {
  content:''; position:absolute; inset:0; border-radius:12px;
  background:linear-gradient(135deg,transparent 40%,rgba(63,185,80,0.04));
  opacity:0; transition:opacity 0.25s;
}
.proj-btn:hover { border-color:var(--green); transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(63,185,80,0.15); }
.proj-btn:hover::after { opacity:1; }
.proj-btn.selected { border-color:var(--green);
  background:rgba(63,185,80,0.08);
  box-shadow:0 0 0 4px rgba(63,185,80,0.15), 0 8px 24px rgba(63,185,80,0.1); }
.proj-btn.selected::after { opacity:1; }

.proj-btn.vanga-btn:hover { border-color:var(--cyan);
  box-shadow:0 8px 24px var(--cyan-glow); }
.proj-btn.vanga-btn.selected { border-color:var(--cyan);
  background:rgba(57,208,216,0.07);
  box-shadow:0 0 0 4px rgba(57,208,216,0.12), 0 8px 24px var(--cyan-glow); }

.proj-icon { font-size:40px; margin-bottom:12px; display:block; }
.proj-label { font-family:'Press Start 2P',monospace; font-size:11px;
  letter-spacing:2px; color:var(--green); margin-bottom:10px; }
.vanga-btn .proj-label { color:var(--cyan); }
.proj-desc { font-size:13px; color:var(--muted); line-height:1.5; }
.proj-badge {
  display:inline-block; font-size:9px; font-weight:700; letter-spacing:1px;
  padding:3px 8px; border-radius:4px; margin-bottom:8px; text-transform:uppercase;
}
.proj-badge.live { background:rgba(63,185,80,0.15); color:var(--green);
  border:1px solid rgba(63,185,80,0.3); }
.proj-badge.beta { background:rgba(57,208,216,0.12); color:var(--cyan);
  border:1px solid rgba(57,208,216,0.3); }

/* ========== SELECTION SCREENS (region / purpose) ========== */
.sel-card {
  width:100%; max-width:600px;
  background:var(--bg3); border-radius:16px;
  border:1px solid var(--border2);
  box-shadow:0 0 0 1px rgba(63,185,80,0.08), 0 24px 48px rgba(0,0,0,0.5);
  padding:48px 40px; text-align:center; position:relative; overflow:hidden;
}
.sel-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--green),var(--cyan),var(--green));
  background-size:200%; animation:shimmer 3s linear infinite;
}
.sel-title {
  font-family:'Press Start 2P',monospace; font-size:13px; letter-spacing:3px;
  background:linear-gradient(135deg,var(--green),var(--cyan));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; margin-bottom:8px;
}
.sel-sub { color:var(--muted); font-size:14px; margin-bottom:30px; text-transform:uppercase;
  letter-spacing:1px; }

.choice-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:24px; }
.choice-btn {
  padding:28px 18px; background:var(--bg4); border:2px solid var(--border);
  border-radius:12px; cursor:pointer; transition:all 0.2s; text-align:center; color:var(--text);
}
.choice-btn:hover { border-color:var(--green); transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(63,185,80,0.12); }
.choice-btn.selected { border-color:var(--green); background:rgba(63,185,80,0.08);
  box-shadow:0 0 0 3px rgba(63,185,80,0.15); }
.choice-btn .flag { font-size:40px; margin-bottom:10px; }
.choice-btn .label { font-size:16px; font-weight:700; color:var(--green); margin-bottom:6px; }
.choice-btn .desc { font-size:13px; color:var(--muted); line-height:1.4; }

.btn-continue {
  width:100%; padding:16px; border-radius:10px; border:none;
  background:linear-gradient(135deg,var(--green),var(--green-hi));
  color:#080c10; font-weight:800; font-size:14px; cursor:pointer;
  letter-spacing:1px; text-transform:uppercase;
  box-shadow:0 4px 16px rgba(63,185,80,0.35); transition:all 0.2s; margin-bottom:12px;
}
.btn-continue:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(63,185,80,0.5); }
.btn-continue:disabled { opacity:0.35; cursor:not-allowed; transform:none; box-shadow:none; }
.btn-back {
  background:transparent; border:1px solid var(--border2); color:var(--muted);
  padding:11px 24px; border-radius:10px; cursor:pointer; font-size:14px;
  transition:all 0.2s; width:100%;
}
.btn-back:hover { border-color:var(--green); color:var(--green); }

/* ========== ВАНГА SCREENS ========== */
.vanga-card {
  width:100%; max-width:860px;
  background:var(--bg3); border-radius:16px;
  border:1px solid rgba(57,208,216,0.25);
  box-shadow:0 0 0 1px rgba(57,208,216,0.08), 0 24px 48px rgba(0,0,0,0.6);
  padding:48px 52px; text-align:center; position:relative; overflow:hidden;
}
/* Result card gets more vertical room */
#vanga-result-screen .vanga-card {
  padding:32px 40px;
  max-height:90vh; overflow-y:auto;
}
#vanga-result-screen .vanga-card::-webkit-scrollbar { width:4px; }
#vanga-result-screen .vanga-card::-webkit-scrollbar-track { background:var(--bg2); }
#vanga-result-screen .vanga-card::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }
.report-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.report-date { font-size:11px; color:var(--muted2); letter-spacing:1px; }
.vanga-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--cyan),var(--green),var(--cyan));
  background-size:200%; animation:shimmer 3s linear infinite;
}
.vanga-title {
  font-family:'Press Start 2P',monospace; font-size:12px; letter-spacing:3px;
  color:var(--cyan); margin-bottom:6px; text-shadow:0 0 16px var(--cyan-glow);
}
.vanga-sub { color:var(--muted); font-size:14px; margin-bottom:28px; }

/* Artist input */
.artist-input-wrap { position:relative; margin-bottom:20px; }
.artist-input {
  width:100%; padding:18px 20px; border-radius:10px;
  border:1px solid var(--border2); background:var(--bg2);
  color:var(--text); font-size:18px; font-weight:600;
  outline:none; transition:all 0.25s; text-align:center;
}
.artist-input:focus {
  border-color:var(--cyan);
  box-shadow:0 0 0 3px var(--cyan-glow), 0 0 24px rgba(57,208,216,0.08);
}
.artist-input::placeholder { color:var(--muted2); font-weight:400; font-size:15px; }

.btn-vanga {
  width:100%; padding:16px; border-radius:10px; border:none;
  background:linear-gradient(135deg,#1a3a3a,#1a4a3a);
  border:1px solid var(--cyan); color:var(--cyan);
  font-weight:700; font-size:14px; cursor:pointer;
  letter-spacing:1px; text-transform:uppercase;
  box-shadow:0 4px 16px rgba(57,208,216,0.15); transition:all 0.2s; margin-bottom:12px;
}
.btn-vanga:hover { transform:translateY(-2px); box-shadow:0 8px 24px var(--cyan-glow);
  background:linear-gradient(135deg,#1e4040,#1e5040); }
.btn-vanga:disabled { opacity:0.35; cursor:not-allowed; transform:none; }

/* Analysis steps */
.scan-steps { text-align:left; margin:24px 0; }
.scan-step {
  display:flex; align-items:center; gap:14px; padding:12px 16px;
  border-radius:8px; margin-bottom:8px; font-size:14px;
  border:1px solid transparent; transition:all 0.3s;
}
.scan-step.waiting { color:var(--muted2); }
.scan-step.running { color:var(--cyan); border-color:rgba(57,208,216,0.2);
  background:rgba(57,208,216,0.05); }
.scan-step.running .scan-step-icon { animation:spin-slow 1s linear infinite; display:inline-block; }
.scan-step.done { color:var(--green); border-color:rgba(63,185,80,0.15);
  background:rgba(63,185,80,0.04); }
.scan-step.error { color:var(--red); }
.scan-step-icon { font-size:16px; width:20px; flex-shrink:0; }
.scan-step-text { flex:1; }
.scan-step-val { font-weight:700; font-size:13px; }
@keyframes spin-slow { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
.scan-bar {
  height:3px; background:var(--border); border-radius:2px; overflow:hidden;
  margin-top:20px;
}
.scan-bar-fill {
  height:100%; width:0%;
  background:linear-gradient(90deg,var(--cyan),var(--green));
  transition:width 0.5s ease;
  box-shadow:0 0 6px var(--cyan);
}
/* Retry single signal button */
.btn-retry-signal {
  font-size:10px; color:var(--cyan); background:rgba(57,208,216,0.08);
  border:1px solid rgba(57,208,216,0.3); border-radius:4px;
  padding:1px 6px; margin-left:6px; cursor:pointer; transition:all .15s;
}
.btn-retry-signal:hover { background:rgba(57,208,216,0.2); }
.btn-retry-signal:disabled { opacity:0.5; cursor:not-allowed; }

/* Model disclaimer — collapsible at top of result */
.model-disclaimer {
  background: rgba(255,255,255,0.025); border:1px solid var(--border);
  border-radius:10px; margin: 12px 0 16px; text-align:left;
}
.model-disclaimer summary {
  cursor:pointer; padding:10px 14px; font-size:12px; color:var(--muted);
  user-select:none; list-style:none;
}
.model-disclaimer summary::-webkit-details-marker { display:none; }
.model-disclaimer[open] summary {
  border-bottom:1px solid var(--border); color:var(--cyan);
}
.model-disclaimer .disclaimer-body {
  padding:12px 16px 14px; font-size:12px; color:var(--text);
  line-height:1.55;
}
.model-disclaimer .disclaimer-body p { margin: 0; }
.model-disclaimer .disclaimer-body strong { color:var(--cyan); font-weight:600; }
.model-disclaimer .disclaimer-body ul,
.model-disclaimer .disclaimer-body ol { padding-left:18px; }
.model-disclaimer .disclaimer-body li { margin: 2px 0; }

/* Confidence warning banner */
.confidence-banner {
  border-radius:10px; padding:12px 16px; margin-bottom:16px;
  display:flex; align-items:flex-start; gap:12px; text-align:left;
}
.confidence-banner.danger {
  background:rgba(248,81,73,0.08); border:1px solid rgba(248,81,73,0.35);
}
.confidence-banner.warn {
  background:rgba(245,158,11,0.08); border:1px solid rgba(245,158,11,0.35);
}
.conf-banner-icon { font-size:18px; flex-shrink:0; margin-top:1px; }
.conf-banner-text { flex:1; }
.conf-banner-title { font-weight:700; font-size:13px; margin-bottom:3px; }
.conf-banner.danger .conf-banner-title { color:var(--red); }
.confidence-banner.warn .conf-banner-title { color:var(--amber); }
.conf-banner-sub { font-size:11px; color:var(--muted); line-height:1.5; }
.conf-banner-action {
  font-size:11px; color:var(--cyan); background:none; border:1px solid rgba(57,208,216,0.3);
  border-radius:5px; padding:3px 9px; cursor:pointer; margin-top:6px; white-space:nowrap;
}
.conf-banner-action:hover { background:rgba(57,208,216,0.08); }

/* Copy/share button */
.btn-copy {
  background:none; border:1px solid var(--border2); border-radius:7px;
  color:var(--muted); font-size:11px; padding:5px 10px; cursor:pointer;
  transition:all 0.15s; white-space:nowrap;
}
.btn-copy:hover { border-color:var(--cyan); color:var(--cyan); }

.scan-artist-name {
  font-family:'Press Start 2P',monospace; font-size:11px; color:var(--cyan);
  letter-spacing:2px; margin-bottom:20px; text-shadow:0 0 10px var(--cyan-glow);
}

/* Signals review */
.signals-grid { display:grid; grid-template-columns:1fr; gap:10px;
  margin:20px 0; text-align:left; }
.signal-row {
  background:var(--bg4); border:1px solid var(--border); border-radius:10px;
  padding:14px 16px; transition:border-color 0.2s;
}
.signal-row:hover { border-color:var(--cyan); }
.signal-row-empty { border-color:rgba(245,158,11,0.4); background:rgba(245,158,11,0.04); }
.signal-row-top {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:6px; margin-bottom:6px;
}
.signal-label { color:var(--muted); font-size:11px; text-transform:uppercase;
  letter-spacing:0.5px; font-weight:600; line-height:1.4; }
.signal-weight { color:var(--cyan); font-size:10px; font-weight:500;
  background:rgba(57,208,216,0.1); border:1px solid rgba(57,208,216,0.25);
  border-radius:4px; padding:1px 5px; white-space:nowrap; letter-spacing:0; text-transform:none; }
.signal-verify-link {
  font-size:10px; color:var(--cyan); text-decoration:none; white-space:nowrap;
  opacity:0.7; transition:opacity 0.15s; flex-shrink:0;
}
.signal-verify-link:hover { opacity:1; text-decoration:underline; }

/* Wordstat picker */
.ws-picker { display:flex; flex-direction:column; gap:5px; margin-bottom:8px; }
.ws-opt {
  display:flex; align-items:center; gap:8px;
  background:var(--bg3); border:1px solid var(--border2); border-radius:7px;
  padding:7px 10px; cursor:pointer; text-align:left; transition:all 0.15s;
  width:100%;
}
.ws-opt:hover { border-color:var(--cyan); background:rgba(57,208,216,0.05); }
.ws-opt-active {
  border-color:var(--cyan); background:rgba(57,208,216,0.1);
  box-shadow:0 0 0 1px rgba(57,208,216,0.3);
}
.ws-opt-val { font-size:14px; font-weight:700; color:var(--text); min-width:52px; }
.ws-opt-label { font-size:10px; color:var(--muted); flex:1; line-height:1.3; }
.ws-opt-link {
  font-size:11px; color:var(--cyan); text-decoration:none; opacity:0.6;
  margin-left:auto; transition:opacity 0.15s;
}
.ws-opt-link:hover { opacity:1; }

/* Signal candidates picker (VK multiple communities etc.) */
.sig-picker { display:flex; flex-direction:column; gap:5px; margin-bottom:8px; }
.sig-pick-item {
  display:flex; align-items:center; gap:8px;
  background:var(--bg3); border:1px solid var(--border2); border-radius:7px;
  padding:7px 10px; cursor:pointer; text-align:left; transition:all 0.15s; width:100%;
}
.sig-pick-item:hover { border-color:var(--cyan); background:rgba(57,208,216,0.05); }
.sig-pick-item-active {
  border-color:var(--cyan); background:rgba(57,208,216,0.1);
  box-shadow:0 0 0 1px rgba(57,208,216,0.3);
}
.sig-pick-val { font-size:14px; font-weight:700; color:var(--text); min-width:60px; }
.sig-pick-label { font-size:10px; color:var(--muted); flex:1; line-height:1.3; }
.sig-pick-link { font-size:11px; color:var(--cyan); text-decoration:none; opacity:0.6; transition:opacity .15s; }
.sig-pick-link:hover { opacity:1; }

/* Standalone URL line shown below a chip */
.sig-url-line {
  display:block; font-size:11px; color:var(--cyan); text-decoration:none;
  padding:3px 4px 3px 2px; opacity:0.75; overflow:hidden; text-overflow:ellipsis;
  white-space:nowrap; transition:opacity .15s;
}
.sig-url-line:hover { opacity:1; text-decoration:underline; }

.signal-input {
  width:100%; background:var(--bg2); border:1px solid var(--border2);
  color:var(--text); font-size:16px; font-weight:700; border-radius:6px;
  padding:8px 12px; outline:none; transition:all 0.2s;
}
.signal-input:focus { border-color:var(--cyan); box-shadow:0 0 0 2px var(--cyan-glow); }
.signal-source { font-size:10px; color:var(--muted2); margin-top:4px; display:flex; align-items:center; gap:4px; }

.sig-tip-icon {
  display:inline-flex; align-items:center; justify-content:center;
  font-size:11px; color:var(--cyan); cursor:pointer;
  position:relative; flex-shrink:0; outline:none; font-style:normal;
}
.sig-tip-icon:hover .sig-tip-box,
.sig-tip-icon:focus .sig-tip-box { opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }

.sig-tip-box {
  position:absolute; bottom:calc(100% + 6px); left:50%;
  transform:translateX(-50%) translateY(4px);
  background:#1a1a2e; border:1px solid var(--cyan);
  color:var(--text); font-size:11px; line-height:1.5;
  padding:8px 10px; border-radius:6px; width:220px;
  opacity:0; pointer-events:none;
  transition:opacity .15s, transform .15s;
  z-index:100; text-align:left; font-family:inherit;
  box-shadow:0 4px 16px rgba(0,0,0,.5);
}

/* Result */
.result-box {
  background:var(--bg4); border:1px solid rgba(57,208,216,0.3); border-radius:14px;
  padding:28px 24px; margin:20px 0; position:relative; overflow:hidden;
}
.result-box::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--cyan),var(--green));
}
.result-artist { font-family:'Press Start 2P',monospace; font-size:11px;
  color:var(--text); letter-spacing:2px; margin-bottom:16px; }
.tier-badge {
  display:inline-block; font-family:'Press Start 2P',monospace; font-size:20px;
  padding:12px 24px; border-radius:10px; margin-bottom:16px;
  letter-spacing:4px;
}
.tier-A { background:rgba(63,185,80,0.15); color:var(--green);
  border:2px solid rgba(63,185,80,0.4); box-shadow:0 0 20px rgba(63,185,80,0.2); }
.tier-B { background:rgba(57,208,216,0.12); color:var(--cyan);
  border:2px solid rgba(57,208,216,0.4); box-shadow:0 0 20px var(--cyan-glow); }
.tier-C { background:rgba(255,165,0,0.1); color:#FFA500;
  border:2px solid rgba(255,165,0,0.35); }
.tier-D { background:rgba(248,81,73,0.1); color:var(--red);
  border:2px solid rgba(248,81,73,0.3); }

.capacity-line { font-size:22px; font-weight:800; color:var(--text); margin-bottom:6px; }

/* Calculation breakdown */
.calc-details { margin-top:10px; text-align:left; }
.calc-details summary {
  font-size:11px; color:var(--cyan); cursor:pointer; list-style:none;
  padding:4px 0; user-select:none;
}
.calc-details summary::-webkit-details-marker { display:none; }
.calc-details[open] summary { margin-bottom:8px; }
.calc-body { background:var(--bg4); border:1px solid var(--border); border-radius:8px; padding:10px 12px; }
.calc-table { width:100%; border-collapse:collapse; font-size:11px; }
.calc-table th { color:var(--muted); font-weight:600; text-align:left; padding:2px 6px 6px; border-bottom:1px solid var(--border); }
.calc-table td { padding:4px 6px; color:var(--text); }
.calc-table tbody tr:hover { background:rgba(255,255,255,.03); }
.calc-result { font-size:11px; color:var(--muted); margin-top:8px; padding-top:6px; border-top:1px solid var(--border); }
.capacity-unit { font-size:13px; color:var(--muted); }
.result-meta { display:flex; gap:12px; justify-content:center;
  flex-wrap:wrap; margin-top:16px; }
.result-meta-item {
  background:var(--bg3); border:1px solid var(--border2); border-radius:8px;
  padding:8px 16px; font-size:13px; color:var(--muted); text-align:center;
}
.result-meta-item strong { display:block; color:var(--text); font-size:15px; }

/* Revenue block */
.revenue-label { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:6px; }
.revenue-amount { font-size:22px; font-weight:800; color:var(--vanga); letter-spacing:1px; margin-bottom:4px; }
.revenue-sub { font-size:11px; color:var(--muted2); }

/* Concert history */
.history-title { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.history-item { background:var(--bg3); border:1px solid var(--border2); border-radius:8px; padding:10px 12px; margin-bottom:6px; }
.history-snippet { font-size:12px; color:var(--muted); margin-bottom:4px; line-height:1.5; }
.history-link { font-size:11px; color:var(--vanga); text-decoration:none; word-break:break-all; }
.history-link:hover { text-decoration:underline; }
.history-loading { font-size:12px; color:var(--muted); padding:8px 0; }
.history-empty { font-size:12px; color:var(--muted2); padding:8px 0; }

/* Feedback */
.feedback-row { display:flex; gap:12px; margin-top:20px; }
.btn-feedback {
  flex:1; padding:14px; border-radius:10px; font-size:14px;
  font-weight:700; cursor:pointer; transition:all 0.2s; border:2px solid;
  letter-spacing:0.5px;
}
.btn-good { background:rgba(63,185,80,0.1); border-color:rgba(63,185,80,0.4);
  color:var(--green); }
.btn-good:hover { background:rgba(63,185,80,0.2); box-shadow:0 4px 12px rgba(63,185,80,0.2); }
.btn-bad { background:rgba(248,81,73,0.08); border-color:rgba(248,81,73,0.35);
  color:var(--red); }
.btn-bad:hover { background:rgba(248,81,73,0.15); box-shadow:0 4px 12px rgba(248,81,73,0.15); }

.feedback-reason { margin-top:16px; display:none; }
.feedback-textarea {
  width:100%; padding:14px; border-radius:10px; border:1px solid var(--border2);
  background:var(--bg2); color:var(--text); font-size:14px; resize:vertical;
  min-height:80px; outline:none; transition:border-color 0.2s; font-family:inherit;
}
.feedback-textarea:focus { border-color:var(--cyan); box-shadow:0 0 0 2px var(--cyan-glow); }

.feedback-sent { color:var(--green); font-size:14px; font-weight:600; margin-top:12px;
  display:none; }

/* ========== ВАНГА REPORT SECTIONS ========== */
/* Verdict */
.verdict-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border-radius:30px; font-size:14px; font-weight:700;
  letter-spacing:0.5px; margin:12px 0 8px;
}
.verdict-go   { background:rgba(63,185,80,0.12); color:var(--green); border:1.5px solid rgba(63,185,80,0.35); }
.verdict-risk { background:rgba(245,158,11,0.1); color:var(--amber); border:1.5px solid rgba(245,158,11,0.35); }
.verdict-nogo { background:rgba(248,81,73,0.1);  color:var(--red);   border:1.5px solid rgba(248,81,73,0.3); }

/* Report section shell */
.report-section {
  margin:14px 0; background:var(--bg4);
  border:1px solid var(--border); border-radius:12px;
  overflow:hidden; text-align:left;
}
.report-section-header {
  font-size:11px; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:1.5px;
  padding:10px 14px 10px;
  border-bottom:1px solid var(--border);
  background:rgba(0,0,0,0.2);
}
.report-section-body { padding:12px 14px; }

/* Signals table */
.signals-table-wrap { overflow-x:auto; }
.signals-table { width:100%; border-collapse:collapse; font-size:13px; }
.signals-table th {
  font-size:10px; text-transform:uppercase; letter-spacing:1px;
  color:var(--muted2); padding:8px 10px; text-align:left;
  border-bottom:1px solid var(--border); font-weight:600;
}
.signals-table td { padding:9px 10px; border-bottom:1px solid rgba(255,255,255,0.04); }
.signals-table tr:last-child td { border-bottom:none; }
.signals-table tr.sig-missing td { opacity:0.45; }
.dot-rating { display:flex; gap:3px; align-items:center; }
.dot { width:8px; height:8px; border-radius:50%; }
.dot-on-5  { background:var(--green); }
.dot-on-4  { background:var(--green); opacity:0.85; }
.dot-on-3  { background:var(--cyan); }
.dot-on-2  { background:var(--amber); }
.dot-on-1  { background:var(--red); }
.dot-off   { background:var(--border2); }
.muted-txt { color:var(--muted2); }

/* Venues */
.venue-row {
  display:flex; align-items:center; gap:10px;
  padding:9px 0; border-bottom:1px solid rgba(255,255,255,0.04);
  font-size:13px;
}
.venue-row:last-child { border-bottom:none; }
.venue-fit { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.venue-fit-ok   { background:var(--green); }
.venue-fit-big  { background:var(--amber); }
.venue-fit-small{ background:rgba(255,255,255,0.2); }
.venue-name { flex:1; color:var(--text); font-weight:500; }
.venue-cap  { color:var(--muted); font-size:12px; white-space:nowrap; }
.venue-type { font-size:10px; color:var(--muted2); background:var(--bg3);
  padding:2px 6px; border-radius:4px; white-space:nowrap; }
.venue-verified { font-size:10px; color:var(--green); }

/* Revenue + ad budget */
.finance-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.finance-item { background:var(--bg3); border-radius:8px; padding:10px 12px; }
.finance-label { font-size:10px; color:var(--muted2); text-transform:uppercase; letter-spacing:0.8px; margin-bottom:4px; }
.finance-value { font-size:17px; font-weight:700; color:var(--text); }
.finance-sub { font-size:11px; color:var(--muted2); margin-top:2px; }
.finance-note { font-size:11px; color:var(--muted2); margin-top:10px; padding-top:8px; border-top:1px solid var(--border); line-height:1.5; }

/* Channel list */
.channel-list { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.channel-chip {
  font-size:11px; padding:4px 10px; border-radius:12px;
  background:var(--bg3); border:1px solid var(--border2);
  color:var(--text);
}
.channel-chip.ch-high { border-color:rgba(63,185,80,0.4); color:var(--green); background:rgba(63,185,80,0.07); }
.channel-chip.ch-med  { border-color:rgba(57,208,216,0.3); color:var(--cyan);  background:rgba(57,208,216,0.06); }

/* History in report section */
.report-history-item {
  padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.04);
}
.report-history-item:last-child { border-bottom:none; }
.report-history-title { font-size:13px; color:var(--text); margin-bottom:3px; font-weight:500; }
.report-history-snippet { font-size:12px; color:var(--muted); line-height:1.5; margin-bottom:4px; }
.report-history-link { font-size:11px; color:var(--cyan); text-decoration:none; }
.report-history-link:hover { text-decoration:underline; }

/* ========== DASHBOARD ========== */
.dashboard { display:none; padding:24px; background:var(--bg); min-height:100vh; }
.dashboard.active { display:block; }

.header {
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:16px; margin-bottom:24px; padding:20px 24px;
  background:var(--bg3); border:1px solid var(--border2); border-radius:14px;
  box-shadow:0 4px 16px rgba(0,0,0,0.3); position:relative; overflow:hidden;
}
.header::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--green),var(--cyan));
}
h1 { color:var(--green); margin-bottom:6px; font-size:22px;
  font-weight:800; letter-spacing:-0.5px; }
.subtitle { color:var(--muted2); font-size:13px; }
.badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:6px; font-size:13px; font-weight:700;
  margin-left:8px;
}
.badge-region { background:var(--bg4); color:var(--green); border:1px solid rgba(63,185,80,0.3); }
.badge-sales { background:rgba(63,185,80,0.12); color:var(--green);
  border:1px solid rgba(63,185,80,0.25); }
.badge-marketing { background:rgba(255,123,0,0.12); color:#FF7B00;
  border:1px solid rgba(255,123,0,0.25); }

.status { padding:16px 20px; border-radius:10px; margin:20px 0;
  border:1px solid; font-size:14px; font-weight:500; }
.loading { background:rgba(63,185,80,0.06); color:var(--green);
  border-color:rgba(63,185,80,0.25); }
.success { background:rgba(63,185,80,0.06); border-color:rgba(63,185,80,0.2);
  color:var(--text); }
.error { background:rgba(248,81,73,0.06); border-color:rgba(248,81,73,0.25);
  color:var(--red); }

/* Filters */
.filters { background:var(--bg3); border:1px solid var(--border2); border-radius:14px;
  padding:24px; margin-bottom:24px; }
.filters-title { color:var(--green); font-size:14px; font-weight:700; margin-bottom:20px;
  text-transform:uppercase; cursor:pointer; display:flex;
  justify-content:space-between; align-items:center; letter-spacing:0.5px; }
.filters-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; }
.filter-group label { display:block; color:var(--muted); font-size:12px; margin-bottom:6px;
  text-transform:uppercase; font-weight:600; letter-spacing:0.3px; }
.filter-group input, .filter-group select {
  width:100%; padding:10px 14px; border-radius:8px; border:1px solid var(--border2);
  background:var(--bg2); color:var(--text); font-size:14px; outline:none; transition:all 0.2s;
}
.filter-group input:focus, .filter-group select:focus {
  border-color:var(--green); box-shadow:0 0 0 3px var(--green-glow);
}

/* Stats */
.stats { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:16px; margin:20px 0; }
.stat-card { background:var(--bg3); border:1px solid var(--border2); border-radius:12px;
  padding:20px; transition:all 0.2s; }
.stat-card:hover { border-color:var(--green); transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(63,185,80,0.08); }
.stat-label { color:var(--muted); font-size:12px; text-transform:uppercase;
  font-weight:600; letter-spacing:0.3px; }
.stat-value { color:var(--green); font-size:28px; font-weight:800; margin-top:6px; }

/* Buttons */
.btn-group { margin:20px 0; display:flex; gap:10px; flex-wrap:wrap; }
.btn { background:var(--green); color:#080c10; border:none; padding:10px 20px;
  border-radius:8px; font-weight:700; font-size:13px; cursor:pointer;
  box-shadow:0 3px 10px rgba(63,185,80,0.25); text-transform:uppercase; letter-spacing:0.5px;
  transition:all 0.2s; }
.btn:hover { background:var(--green-hi); transform:translateY(-1px);
  box-shadow:0 5px 14px rgba(63,185,80,0.35); }
.btn-secondary { background:var(--bg3); color:var(--text); box-shadow:none;
  border:1px solid var(--border2); }
.btn-secondary:hover { background:var(--bg4); box-shadow:none; }
.btn-logout { background:transparent; border:1px solid rgba(248,81,73,0.4);
  color:var(--red); box-shadow:none; }
.btn-logout:hover { background:rgba(248,81,73,0.08); }
.btn-change { background:transparent; border:1px solid rgba(63,185,80,0.4);
  color:var(--green); box-shadow:none; }
.btn-change:hover { background:rgba(63,185,80,0.08); }

/* Table */
table { width:100%; border-collapse:collapse; margin-top:20px; }
th { text-align:left; padding:14px 16px; color:var(--green); border-bottom:2px solid rgba(63,185,80,0.2);
  font-size:13px; text-transform:uppercase; position:sticky; top:0;
  background:var(--bg2); font-weight:700; letter-spacing:0.3px; }
td { padding:14px 16px; border-bottom:1px solid var(--border); color:var(--muted);
  font-size:14px; }
td:first-child { color:var(--text); font-weight:500; }
.price-cell { color:var(--green); text-align:right; font-weight:700; font-size:15px; }
.date-cell { color:var(--muted); font-size:13px; }
a { color:#58a6ff; text-decoration:none; }
a:hover { text-decoration:underline; color:#79c0ff; }
tr:hover { background:rgba(63,185,80,0.03); }
.table-container { max-height:680px; overflow-y:auto; border:1px solid var(--border2);
  border-radius:12px; background:var(--bg2); }
.results-info { color:var(--muted2); text-align:center; padding:12px; font-size:13px; }

/* Comments */
.comment-cell { max-width:220px; }
.comment-text {
  cursor:pointer; padding:7px 12px; border-radius:6px;
  background:var(--bg4); border:1px solid var(--border2);
  min-height:32px; display:inline-block; min-width:100px;
  font-size:13px; transition:all 0.2s; color:var(--text);
}
.comment-text:hover { border-color:var(--green); }
.comment-text.empty { color:var(--muted2); font-style:italic; }

/* New events */
.new-events-section { background:var(--bg3); border:1px solid var(--border2);
  border-radius:12px; padding:20px; margin-bottom:20px; }
.new-events-title { color:var(--green); font-size:16px; font-weight:700;
  margin-bottom:16px; display:flex; align-items:center; gap:10px; }
.new-events-title .count { background:var(--green); color:#080c10;
  padding:3px 10px; border-radius:5px; font-size:13px; font-weight:700; }
.new-events-list { display:grid; gap:10px; }
.new-event-card { background:var(--bg4); border:1px solid var(--border);
  border-radius:8px; padding:14px 18px; display:flex; justify-content:space-between;
  align-items:center; gap:16px; transition:border-color 0.2s; }
.new-event-card:hover { border-color:var(--green); }
.new-event-info { flex:1; }
.new-event-title { color:var(--green); font-weight:600; font-size:14px; }
.new-event-title a { color:var(--green); text-decoration:none; }
.new-event-title a:hover { text-decoration:underline; }
.new-event-meta { color:var(--muted); font-size:13px; margin-top:4px; }
.new-event-date { color:var(--muted); font-size:13px; white-space:nowrap; text-align:right; }

/* Modal */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.7);
  z-index:1000; align-items:center; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal { background:var(--bg3); border:1px solid var(--border2); border-radius:14px;
  padding:32px; width:90%; max-width:500px; box-shadow:0 24px 48px rgba(0,0,0,0.6); }
.modal h3 { color:var(--green); font-size:18px; margin-bottom:8px; }
.modal-event-title { color:var(--muted); font-size:14px; margin-bottom:16px; }
textarea { width:100%; padding:14px; border-radius:8px; border:1px solid var(--border2);
  background:var(--bg2); color:var(--text); font-size:14px; resize:vertical;
  min-height:100px; outline:none; font-family:inherit; }
textarea:focus { border-color:var(--green); box-shadow:0 0 0 3px var(--green-glow); }
.modal-buttons { display:flex; gap:12px; margin-top:16px; justify-content:flex-end; }
.btn-cancel { background:transparent; border:1px solid var(--border2); color:var(--muted);
  padding:10px 20px; border-radius:8px; cursor:pointer; font-size:14px; transition:all 0.2s; }
.btn-cancel:hover { border-color:var(--green); color:var(--green); }
.btn-save { background:var(--green); color:#080c10; border:none; padding:10px 24px;
  border-radius:8px; font-weight:700; font-size:14px; cursor:pointer; transition:all 0.2s; }
.btn-save:hover { background:var(--green-hi); }

/* Genre dropdown */
.custom-dropdown-wrapper { position:relative; }
.custom-dropdown-header { width:100%; padding:10px 14px; border-radius:8px;
  border:1px solid var(--border2); background:var(--bg2); color:var(--text);
  font-size:14px; cursor:pointer; display:flex; justify-content:space-between;
  align-items:center; user-select:none; transition:all 0.2s; }
.custom-dropdown-header:hover { border-color:var(--green); }
.custom-dropdown-content { position:absolute; z-index:100; width:100%; top:calc(100%+6px);
  background:var(--bg3); border:1px solid var(--border2); border-radius:10px;
  box-shadow:0 16px 32px rgba(0,0,0,0.4); max-height:280px; overflow:hidden;
  display:flex; flex-direction:column; }
.dropdown-search { padding:10px 14px; border:none; border-bottom:1px solid var(--border);
  background:var(--bg4); color:var(--text); font-size:13px; outline:none; }
.dropdown-options { overflow-y:auto; max-height:220px; }
.dropdown-option { padding:10px 14px; cursor:pointer; display:flex; align-items:center;
  gap:10px; font-size:14px; transition:background 0.15s; }
.dropdown-option:hover { background:var(--bg4); }
.dropdown-option.selected-opt { color:var(--green); background:rgba(63,185,80,0.06); }
.dropdown-option-checkbox { width:14px; height:14px; border:2px solid var(--border2);
  border-radius:3px; flex-shrink:0; }
.selected-opt .dropdown-option-checkbox { background:var(--green); border-color:var(--green); }
.dropdown-arrow { color:var(--muted2); font-size:11px; }
.selected-items { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.genre-tag { background:rgba(63,185,80,0.12); border:1px solid rgba(63,185,80,0.3);
  color:var(--green); border-radius:5px; padding:4px 10px; font-size:12px;
  display:flex; align-items:center; gap:6px; }
.genre-tag-remove { cursor:pointer; color:var(--muted); }
.genre-tag-remove:hover { color:var(--red); }

/* ========== MOBILE ========== */
@media(max-width:768px){
  .proj-grid,.choice-grid{grid-template-columns:1fr;gap:12px}
  .signals-grid{grid-template-columns:1fr}
  .login-card,.sel-card,.vanga-card,.project-card-wrap{padding:32px 24px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .btn-group{flex-direction:column}
  .btn{width:100%}
  .header{padding:16px}
  h1{font-size:18px}
  .new-event-card{flex-direction:column;align-items:flex-start;gap:10px}
  table{min-width:700px}
  .table-container{overflow-x:auto}
  .feedback-row{flex-direction:column}
}
@media(max-width:480px){
  .brand-title,.preloader-logo{font-size:11px}
  .login-card,.sel-card,.vanga-card,.project-card-wrap{padding:24px 16px}
  .stat-value{font-size:22px}
  .stats{grid-template-columns:1fr}
  .proj-icon{font-size:32px}
}
