/* Project panel */
.project-panel {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity var(--t-slow) var(--ease-out),
              transform var(--t-slow) var(--ease-out);
}

.project-panel.visible {
  opacity: 1;
  transform: translateY(0);
}

.panel-logo {
  width: clamp(48px, 8vw, 80px);
  height: auto;
  margin-bottom: var(--space-md);
  opacity: 0;
  transform: translateY(8px) scale(0.9);
  transition: opacity var(--t-normal) var(--ease-out),
              transform var(--t-normal) var(--ease-out);
  border-radius: 20%;
  box-shadow: 0 2px 16px rgba(126, 184, 212, 0.2);
  display: none;
}

.panel-logo.visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  display: block;
}

/* Per-scene panel theming */
.project-panel[data-scene="muscledaddies"] .panel-logo {
  box-shadow: 0 2px 20px rgba(217, 179, 77, 0.3);
}

.project-panel[data-scene="muscledaddies"] .project-oneliner {
  color: #a89060;
}

/* ATLAS panel theming */
.project-panel[data-scene="atlas"] .project-title {
  letter-spacing: 0.2em;
  text-shadow: 0 2px 12px rgba(0,0,0,0.8);
}

.project-panel[data-scene="atlas"] .project-oneliner {
  color: #f0f0f0;
  font-weight: 700;
  text-shadow: 0 1px 8px rgba(0,0,0,0.9);
}

/* MusicBoy LCD panel theming */
.project-panel[data-scene="musicboy"] .project-title {
  letter-spacing: 0.08em;
  font-size: clamp(1.5rem, 4vw, 3rem);
}

.project-panel[data-scene="musicboy"] .project-oneliner {
  color: #8a9a6a;
  font-family: 'PressStart2P', monospace;
  font-size: clamp(0.5rem, 0.8vw, 0.65rem);
  line-height: 2;
  letter-spacing: 0.04em;
}

.project-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-hero);
  line-height: 0.95;
  margin-bottom: var(--space-sm);
}

.project-title-logo {
  width: clamp(140px, 28vw, 300px);
  height: auto;
  display: block;
  margin-bottom: -4px;
}

.project-panel[data-scene="tonebar"] .project-title {
  margin-top: -12px;
}

/* Cone-ar panel theming */
.project-panel[data-scene="conear"] .project-title {
  margin-top: -8px;
  margin-bottom: var(--space-sm);
}

.project-title-logo--conear {
  width: clamp(180px, 32vw, 320px) !important;
  height: auto;
  display: block;
  filter: drop-shadow(0 6px 16px rgba(8, 35, 63, 0.22));
}

.project-panel[data-scene="conear"] .project-oneliner {
  font-family: 'Fredoka', system-ui, sans-serif;
  color: #08233F;
  font-weight: 600;
  text-shadow: 0 1px 0 rgba(255, 248, 232, 0.4);
}

/* SoundPower panel theming */
.project-panel[data-scene="soundpower"] .project-title {
  margin-top: -8px;
  margin-bottom: var(--space-sm);
}

.project-title-logo--soundpower {
  width: clamp(220px, 36vw, 380px) !important;
  height: auto;
  display: block;
  filter:
    drop-shadow(0 0 18px rgba(255, 20, 147, 0.45))
    drop-shadow(0 0 28px rgba(0, 229, 255, 0.30));
}

.project-panel[data-scene="soundpower"] .project-oneliner {
  font-family: 'Inter', 'Inter Tight', system-ui, sans-serif;
  color: #f4f5fb;
  font-weight: 600;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.7);
}

.project-oneliner {
  font-family: var(--font-mono);
  font-size: var(--text-body);
  color: var(--text-secondary);
  line-height: 1.5;
  max-width: 40ch;
}

/* Contact modal card */
.modal-card {
  background: var(--bg-secondary);
  border: 1px solid var(--bg-surface);
  border-radius: 12px;
  padding: var(--space-lg);
  width: min(420px, 90vw);
  position: relative;
}

.modal-close {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-md);
  font-size: 1.5rem;
  color: var(--text-secondary);
  transition: color var(--t-fast);
}

.modal-close:hover {
  color: var(--text-primary);
}

.modal-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.3rem;
  margin-bottom: var(--space-lg);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.contact-form input,
.contact-form textarea {
  font-family: var(--font-mono);
  font-size: var(--text-body);
  color: var(--text-primary);
  background: var(--bg-primary);
  border: 1px solid var(--bg-surface);
  border-radius: 6px;
  padding: var(--space-sm) var(--space-md);
  outline: none;
  transition: border-color var(--t-fast);
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--accent-teal);
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: var(--text-tertiary);
}

.form-submit {
  font-family: var(--font-mono);
  font-size: var(--text-body);
  color: var(--bg-primary);
  background: var(--accent-teal);
  border-radius: 6px;
  padding: var(--space-sm) var(--space-md);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: opacity var(--t-fast);
}

.form-submit:hover {
  opacity: 0.85;
}

@media (max-width: 1024px) {
  .project-panel.visible {
    transform: translateY(0);
  }

  .project-title {
    font-size: var(--text-project-title);
  }

  .project-oneliner {
    max-width: none;
  }
}
