/* MSX — Terminal Noir Theme */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&display=swap');

/* ─── Custom Fonts ─── */
/* PP Mondwest — page titles, headings (add .woff2 files to /fonts/) */
@font-face {
  font-family: 'PP Mondwest';
  src: url('../fonts/PPMondwest-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* PP Neue Bit — labels, badges, small caps */
@font-face {
  font-family: 'PP Neue Bit';
  src: url('../fonts/PPNeueBit-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg-deep: #0a0a0f;
  --bg-panel: #0d0d14;
  --bg-card: #111119;
  --bg-hover: #16161f;
  --bg-input: #0e0e16;
  --green-dim: #1a3a2a;
  --green-core: #00ff88;
  --green-bright: #33ffaa;
  --green-muted: #4a9e6e;
  --green-ghost: rgba(0, 255, 136, 0.06);
  --cyan-core: #00e5ff;
  --cyan-dim: #0088aa;
  --cyan-ghost: rgba(0, 229, 255, 0.08);
  --status-shipping: #ff6b35;
  --status-building: #ffcc00;
  --status-idle: #555566;
  --status-deployed: #00ff88;
  --status-forking: #b388ff;
  --text-primary: #e0e0e8;
  --text-secondary: #8888a0;
  --text-dim: #555566;
  --text-accent: var(--green-core);
  --border-subtle: #1a1a28;
  --border-panel: #222233;
  --border-glow: rgba(0, 255, 136, 0.15);
  --glow-green: 0 0 10px rgba(0, 255, 136, 0.3), 0 0 30px rgba(0, 255, 136, 0.1);
  --glow-cyan: 0 0 10px rgba(0, 229, 255, 0.3), 0 0 30px rgba(0, 229, 255, 0.1);
  --glow-ship: 0 0 12px rgba(255, 107, 53, 0.4), 0 0 30px rgba(255, 107, 53, 0.15);
  --font-mono: "Space Grotesk", sans-serif;
  --font-heading: "Space Grotesk", sans-serif;
  --font-label: "Space Grotesk", sans-serif;
  --font-body: "Space Grotesk", sans-serif;
  --font-display: "Space Grotesk", sans-serif;
  --font-logo: 'PP Mondwest', Georgia, serif;
  --gap-xs: 4px; --gap-sm: 8px; --gap-md: 12px; --gap-lg: 16px; --gap-xl: 24px;
  --radius-sm: 3px; --radius-md: 6px;
  --scanline-opacity: 0.035;
}

* { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }

html, body {
  background: var(--bg-deep) !important;
  color: var(--text-primary) !important;
  font-family: var(--font-mono) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  overflow: hidden !important;
  height: 100vh !important;
  width: 100vw !important;
}

::-webkit-scrollbar { width: 4px !important; }
::-webkit-scrollbar-track { background: transparent !important; }
::-webkit-scrollbar-thumb { background: var(--border-panel) !important; border-radius: 2px !important; }
::-webkit-scrollbar-thumb:hover { background: var(--green-dim) !important; }
::selection { background: var(--green-core) !important; color: var(--bg-deep) !important; }

/* ─── CRT Effects ─── */
.crt-overlay {
  pointer-events: none; position: fixed; inset: 0; z-index: 9999;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,255,136,0.015) 2px, rgba(0,255,136,0.015) 4px) !important;
}
.crt-overlay::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(transparent 50%, rgba(0,0,0,0.03) 50%);
  background-size: 100% 4px; animation: scanmove 8s linear infinite;
}
@keyframes scanmove { 0% { transform: translateY(-100%); } 100% { transform: translateY(100%); } }
.crt-flicker { animation: flicker 4s infinite; }
@keyframes flicker { 0%,100%{opacity:1} 41%{opacity:0.98} 43%{opacity:1} 72%{opacity:0.97} 74%{opacity:1} }

/* ─── Animations ─── */
@keyframes feedIn { from{opacity:0;transform:translateX(-16px)} to{opacity:1;transform:translateX(0)} }
.feed-entry { animation: feedIn 400ms ease-out; }

@keyframes cardSpawn { 0%{opacity:0;transform:translateY(12px) scale(0.95)} 70%{transform:translateY(-2px) scale(1.01)} 100%{opacity:1;transform:translateY(0) scale(1)} }
.card-spawn { animation: cardSpawn 500ms ease-out; }

@keyframes shipGlow { 0%,100%{box-shadow:0 0 8px rgba(255,107,53,0.2)} 50%{box-shadow:0 0 20px rgba(255,107,53,0.5),0 0 40px rgba(255,107,53,0.2)} }
.ship-glow { animation: shipGlow 1.5s ease-in-out 3; }

@keyframes dotPulse { 0%,100%{box-shadow:0 0 0 0 rgba(0,255,136,0.6)} 50%{box-shadow:0 0 0 6px rgba(0,255,136,0)} }
.dot-pulse { animation: dotPulse 600ms ease-out 3; }

@keyframes cursorBlink { 0%,49%{opacity:1} 50%,100%{opacity:0} }
.cursor-blink { animation: cursorBlink 800ms step-end infinite; }

@keyframes cmdFlash { 0%{background:rgba(0,255,136,0.08)} 100%{background:transparent} }
.cmd-flash { animation: cmdFlash 300ms ease-out; }

@keyframes counterTick { 0%,100%{transform:scale(1)} 50%{transform:scale(1.12);color:var(--green-bright)} }
.counter-tick { animation: counterTick 250ms ease-out; }

.progress-fill { transition: width 400ms ease !important; }

@keyframes borderPulse { 0%,100%{border-color:var(--border-panel)} 50%{border-color:var(--border-glow)} }
.panel-pulse { animation: borderPulse 4s ease-in-out infinite; }

@keyframes agentLeave { to{opacity:0;transform:translateX(10px);filter:blur(2px)} }
.agent-leave { animation: agentLeave 300ms ease-out forwards; }

@keyframes agentJoin { from{opacity:0;transform:translateX(16px)} to{opacity:1;transform:translateX(0)} }
.agent-join { animation: agentJoin 350ms ease-out; }

@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)} }
.error-shake { animation: shake 300ms ease-out; }

@keyframes starPop { 0%,100%{transform:scale(1)} 50%{transform:scale(1.3);color:#ffcc00} }
.star-pop { animation: starPop 250ms ease-out; }

@keyframes milestone { 0%{text-shadow:none;transform:scale(1)} 50%{text-shadow:0 0 15px var(--green-core);transform:scale(1.2)} 100%{text-shadow:none;transform:scale(1)} }
.milestone-burst { animation: milestone 800ms ease-out; }

@keyframes bootReveal { 0%{clip-path:inset(50% 0 50% 0);opacity:0} 60%{clip-path:inset(5% 0 5% 0);opacity:0.7} 100%{clip-path:inset(0);opacity:1} }
.boot-in { animation: bootReveal 1200ms ease-out; }

/* ─── Components ─── */
.product-card { transition: box-shadow 200ms ease, border-color 200ms ease, transform 150ms ease !important; }
.product-card:hover { box-shadow:0 0 12px rgba(0,255,136,0.1)!important; border-color:rgba(0,255,136,0.2)!important; transform:translateY(-1px)!important; }

.tag { font-family:var(--font-label)!important; font-size:10px!important; padding:1px 6px!important; border-radius:3px!important; font-weight:700!important; letter-spacing:0.5px!important; text-transform:uppercase!important; }

.status-dot { width:6px!important; height:6px!important; border-radius:50%!important; display:inline-block!important; flex-shrink:0!important; }

/* ─── Detail Panel ─── */
@keyframes panelSlideIn { from{transform:translateX(100%)} to{transform:translateX(0)} }
@keyframes panelSlideOut { from{transform:translateX(0)} to{transform:translateX(100%)} }

.detail-panel {
  position: fixed !important; top: 0 !important; right: 0 !important; bottom: 0 !important;
  width: 55vw !important; min-width: 400px !important; max-width: 800px !important;
  background: var(--bg-panel) !important; border-left: 1px solid var(--border-panel) !important;
  z-index: 1000 !important; display: flex !important; flex-direction: column !important;
  animation: panelSlideIn 300ms ease-out !important;
  box-shadow: -4px 0 20px rgba(0,0,0,0.5) !important;
}
.detail-panel.closing { animation: panelSlideOut 250ms ease-in forwards !important; }
.detail-panel-overlay {
  position: fixed !important; inset: 0 !important; background: rgba(0,0,0,0.5) !important;
  z-index: 999 !important; animation: fadeIn 200ms ease-out !important;
}
@keyframes fadeIn { from{opacity:0} to{opacity:1} }

.detail-panel iframe {
  width: 100% !important; height: 100% !important; border: none !important;
  background: var(--bg-deep) !important; border-radius: var(--radius-sm) !important;
}

/* ─── Badges ─── */
.badge-real {
  font-family:var(--font-label)!important;
  font-size:8px!important; padding:1px 5px!important; border-radius:2px!important;
  background:var(--green-core)!important; color:var(--bg-deep)!important; font-weight:700!important;
  letter-spacing:0.5px!important; text-transform:uppercase!important;
}
.badge-sim {
  font-family:var(--font-label)!important;
  font-size:8px!important; padding:1px 5px!important; border-radius:2px!important;
  background:var(--status-idle)!important; color:var(--text-dim)!important; font-weight:500!important;
  letter-spacing:0.5px!important; text-transform:uppercase!important;
}
.badge-db {
  font-family:var(--font-label)!important;
  font-size:8px!important; padding:1px 5px!important; border-radius:2px!important;
  background:#007AFF!important; color:#fff!important; font-weight:700!important;
  letter-spacing:0.5px!important; text-transform:uppercase!important;
}

/* ─── Signal Tabs ─── */
.signal-tab { transition: color 200ms, border-color 200ms !important; }
.signal-tab:hover { color: var(--green-core) !important; }
.signal-tab-active { color: var(--green-core) !important; border-bottom-color: var(--green-core) !important; }

/* ─── Signal & Idea Entries ─── */
@keyframes signalIn { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.signal-entry { animation: signalIn 350ms ease-out; transition: background 150ms !important; }
.signal-entry:hover { background: rgba(255,255,255,0.04) !important; }

@keyframes ideaIn { from{opacity:0;transform:scale(0.96)} to{opacity:1;transform:scale(1)} }
@keyframes revenueIn { from{opacity:0;transform:translateX(-10px)} to{opacity:1;transform:translateX(0)} }
.idea-entry { animation: ideaIn 300ms ease-out; transition: background 150ms !important; }
.idea-entry:hover { background: rgba(255,255,255,0.04) !important; }

/* ─── Score Badges ─── */
.score-high { color: var(--green-core) !important; }
.score-mid { color: var(--status-building) !important; }
.score-low { color: var(--status-shipping) !important; }

/* ─── Platform Colors ─── */
.platform-tiktok { color: #ff0050 !important; }
.platform-reddit { color: #ff4500 !important; }
.platform-youtube { color: #ff0000 !important; }
.platform-hackernews { color: #ff6600 !important; }
.platform-producthunt { color: #da552f !important; }

/* ─── Claim Button ─── */
.btn-claim {
  font-size: 10px !important; padding: 4px 10px !important; border-radius: 3px !important;
  background: var(--cyan-core) !important; color: var(--bg-deep) !important;
  font-weight: 700 !important; border: none !important; cursor: pointer !important;
  transition: all 150ms !important; text-transform: uppercase !important; letter-spacing: 0.5px !important;
}
.btn-claim:hover { background: var(--green-core) !important; transform: translateY(-1px) !important; }

/* ─── Skill Tags ─── */
.skill-tag {
  font-family: var(--font-label) !important;
  font-size: 8px !important; padding: 1px 4px !important; border-radius: 2px !important;
  font-weight: 700 !important; letter-spacing: 0.3px !important; text-transform: uppercase !important;
  white-space: nowrap !important; display: inline-block !important;
}

/* ─── Goal Entry ─── */
@keyframes goalIn { from{opacity:0;transform:translateX(-8px)} to{opacity:1;transform:translateX(0)} }
#goals-list > div { animation: goalIn 300ms ease-out; }

/* ─── Live Feed (same as feed-entry) ─── */
#live-feed .feed-entry { animation: feedIn 400ms ease-out; }

/* ─── Responsive ─── */
@media (max-width: 900px) {
  .detail-panel { width: 100vw !important; min-width: unset !important; }
}

/* ─── Mobile Orientation Lock ─── */
body.orientation-lock-active {
  overflow: hidden !important;
}

.orientation-lock-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 30000 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 24px !important;
  background:
    radial-gradient(circle at top, rgba(0, 229, 255, 0.12), transparent 35%),
    rgba(10, 10, 15, 0.96) !important;
  backdrop-filter: blur(14px) !important;
}

body.orientation-lock-active .orientation-lock-overlay {
  display: flex !important;
}

.orientation-lock-card {
  width: min(100%, 420px) !important;
  padding: 28px 24px !important;
  border: 1px solid rgba(0, 255, 136, 0.22) !important;
  border-radius: 18px !important;
  background: linear-gradient(180deg, rgba(13, 13, 20, 0.98), rgba(17, 17, 25, 0.98)) !important;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45), 0 0 40px rgba(0, 255, 136, 0.08) !important;
  text-align: center !important;
}

.orientation-lock-eyebrow {
  display: inline-block !important;
  margin-bottom: 14px !important;
  padding: 4px 10px !important;
  border: 1px solid rgba(0, 229, 255, 0.25) !important;
  border-radius: 999px !important;
  color: var(--cyan-core) !important;
  font-family: var(--font-label) !important;
  font-size: 10px !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
}

.orientation-lock-icon {
  position: relative !important;
  width: 92px !important;
  height: 92px !important;
  margin: 0 auto 18px !important;
}

.orientation-lock-device,
.orientation-lock-device-landscape {
  position: absolute !important;
  border: 1px solid rgba(0, 255, 136, 0.35) !important;
  border-radius: 14px !important;
  background: rgba(0, 255, 136, 0.05) !important;
}

.orientation-lock-device {
  width: 34px !important;
  height: 56px !important;
  top: 14px !important;
  left: 14px !important;
}

.orientation-lock-device-landscape {
  width: 56px !important;
  height: 34px !important;
  right: 8px !important;
  bottom: 12px !important;
}

.orientation-lock-arrow {
  position: absolute !important;
  top: 12px !important;
  right: 18px !important;
  color: var(--green-core) !important;
  font-size: 26px !important;
  text-shadow: 0 0 18px rgba(0, 255, 136, 0.3) !important;
}

.orientation-lock-title {
  margin-bottom: 10px !important;
  color: var(--text-primary) !important;
  font-family: var(--font-display) !important;
  font-size: 28px !important;
  line-height: 1 !important;
}

.orientation-lock-text {
  color: var(--text-secondary) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

.orientation-lock-text strong {
  color: var(--green-core) !important;
  font-weight: 700 !important;
}
