/* ==============================================================================
   MINDFRAME STUDIO — COMPONENTS v4
   Dark Cosmic Premium — Glassmorphism buttons, cards, nav, modals, forms.
   ============================================================================== */

/* ══════════════════════════════════════════════════════════════════
   NAVIGATION — Floating pill bar (Diagram-style)
   ══════════════════════════════════════════════════════════════════ */

.header-nav {
  position: fixed;
  top: var(--space-4);
  left: 50%;
  transform: translateX(-50%);
  z-index: var(--z-header);
  transition: transform var(--duration-slow) var(--ease-out),
    opacity var(--duration-slow) var(--ease-out);
}

.header-nav--hidden {
  transform: translateX(-50%) translateY(-120%);
  opacity: 0;
  pointer-events: none;
}

.header-container {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: rgba(17, 17, 25, 0.75);
  backdrop-filter: var(--backdrop-blur);
  -webkit-backdrop-filter: var(--backdrop-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
}

.logo {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: var(--fw-bold);
  color: var(--color-text);
  text-decoration: none;
  padding: var(--space-2) var(--space-4);
  white-space: nowrap;
  letter-spacing: -0.01em;
  transition: color var(--duration-normal) var(--ease-out);
}

.logo span {
  color: var(--color-primary);
}

.logo:hover {
  color: var(--color-primary);
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.nav-link {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full);
  transition: all var(--duration-normal) var(--ease-out);
  white-space: nowrap;
}

.nav-link:hover {
  color: var(--color-text);
  background: var(--color-glass-hover);
}

.nav-link.is-active {
  color: var(--color-text);
  background: rgba(255, 255, 255, 0.08);
}

/* Mobile hamburger */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--space-2);
  background: none;
  border: none;
  cursor: pointer;
  z-index: 1001;
  position: relative;
}

.nav-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--color-text);
  border-radius: 2px;
  transition: transform var(--duration-normal) var(--ease-out),
              opacity var(--duration-normal) var(--ease-out);
  transform-origin: center;
}

.nav-toggle.is-active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav-toggle.is-active span:nth-child(2) {
  opacity: 0;
}

.nav-toggle.is-active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ══════════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  padding: var(--space-3) var(--space-6);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--duration-normal) var(--ease-out);
  white-space: nowrap;
}

.btn-primary {
  background: var(--gradient-btn-primary);
  color: var(--color-text-on-primary);
  box-shadow: 0 2px 16px rgba(245, 166, 35, 0.25);
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 24px rgba(245, 166, 35, 0.35);
  color: var(--color-text-on-primary);
}

.btn-primary:active {
  transform: translateY(0);
}

.btn-secondary {
  background: var(--color-glass);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  backdrop-filter: var(--backdrop-blur);
  -webkit-backdrop-filter: var(--backdrop-blur);
}

.btn-secondary:hover {
  background: var(--color-glass-hover);
  border-color: var(--color-border-hover);
  color: var(--color-text);
  transform: translateY(-2px);
}

/* ══════════════════════════════════════════════════════════════════
   GLASSMORPHISM CARDS
   ══════════════════════════════════════════════════════════════════ */

.glass-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  backdrop-filter: var(--backdrop-blur);
  -webkit-backdrop-filter: var(--backdrop-blur);
  transition: all var(--duration-slow) var(--ease-out);
  overflow: hidden;
}

.glass-card:hover {
  background: var(--color-card-hover);
  border-color: var(--color-border-hover);
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

/* ══════════════════════════════════════════════════════════════════
   FORM INPUTS — Dark Glass
   ══════════════════════════════════════════════════════════════════ */

.input-field,
.textarea-field {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--color-text);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  transition: all var(--duration-normal) var(--ease-out);
  outline: none;
}

.input-field::placeholder,
.textarea-field::placeholder {
  color: var(--color-text-dim);
}

.input-field:focus,
.textarea-field:focus {
  border-color: var(--color-primary);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: 0 0 0 3px var(--color-primary-subtle);
}

.textarea-field {
  resize: vertical;
  min-height: 120px;
}

select.input-field {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.4)' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

select.input-field option {
  background: var(--color-surface);
  color: var(--color-text);
}

.form-group {
  margin-bottom: var(--space-5);
}

.form-label {
  display: block;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-soft);
  margin-bottom: var(--space-2);
  letter-spacing: var(--ls-wide);
}

.form-inline {
  display: flex;
  gap: var(--space-3);
  max-width: 460px;
  margin: 0 auto;
}

.form-inline .input-field {
  flex: 1;
}

/* ══════════════════════════════════════════════════════════════════
   FORM SUCCESS STATE
   ══════════════════════════════════════════════════════════════════ */

.form-success {
  display: none;
  text-align: center;
  padding: var(--space-6);
  animation: fadeIn 0.5s var(--ease-out);
}

.form-success.is-visible {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.form-success svg {
  width: 40px;
  height: 40px;
  color: var(--color-success);
}

.form-success p {
  font-size: var(--fs-body);
  color: var(--color-text-soft);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ══════════════════════════════════════════════════════════════════
   MODAL — Dark Glass Panel
   ══════════════════════════════════════════════════════════════════ */

.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-overlay);
  backdrop-filter: var(--backdrop-blur);
  -webkit-backdrop-filter: var(--backdrop-blur);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-slow) var(--ease-out);
  padding: var(--space-4);
}

.modal-overlay.is-active {
  opacity: 1;
  pointer-events: auto;
}

.modal {
  position: relative;
  width: 100%;
  max-width: 520px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-xl);
  transform: translateY(20px) scale(0.97);
  transition: transform var(--duration-slow) var(--ease-spring);
}

.modal-overlay.is-active .modal {
  transform: translateY(0) scale(1);
}

.modal h3 {
  font-size: var(--fs-h3);
  margin-bottom: var(--space-2);
}

.modal>p {
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
  font-size: var(--fs-small);
}

.modal-close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text-muted);
  font-size: 1.2rem;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
}

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

/* ══════════════════════════════════════════════════════════════════
   BADGES / TAGS
   ══════════════════════════════════════════════════════════════════ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  letter-spacing: var(--ls-wide);
}

.badge--primary {
  background: var(--color-primary-subtle);
  color: var(--color-primary);
  border: 1px solid var(--color-primary-light);
}

.badge--bonus {
  background: var(--color-glass);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
}

.tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-glass);
  transition: all var(--duration-normal) var(--ease-out);
}

.tag:hover {
  border-color: var(--color-border-hover);
  color: var(--color-text-soft);
}

.tag svg {
  color: var(--color-primary);
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  justify-content: center;
  margin-bottom: var(--space-8);
}

/* ══════════════════════════════════════════════════════════════════
   SCROLL INDICATOR
   ══════════════════════════════════════════════════════════════════ */

.scroll-indicator {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-dim);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  animation: float 3s ease-in-out infinite;
  transition: opacity var(--duration-normal) var(--ease-out);
  z-index: var(--z-content);
}

.scroll-indicator svg {
  opacity: 0.5;
}

/* ══════════════════════════════════════════════════════════════════
   SPLINE PLACEHOLDER CONTAINER
   Universal container for 3D placeholders / future Spline scenes
   ══════════════════════════════════════════════════════════════════ */

.spline-placeholder {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 500px;
  margin: 0 auto;
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

.spline-placeholder canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE — MOBILE
   ══════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  .header-nav {
    top: 0;
    left: 0;
    right: 0;
    transform: none;
    padding: var(--space-2);
  }

  .header-nav--hidden {
    transform: translateY(-120%);
  }

  .header-container {
    border-radius: var(--radius-xl);
    justify-content: space-between;
  }

  body.nav-open .header-container {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
  }

  body.nav-open .logo {
    position: relative;
    z-index: 1001;
  }

  .nav-toggle {
    display: flex;
    position: relative;
    z-index: 1001;
  }

  .modal-overlay {
    align-items: flex-start;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .nav-menu {
    position: fixed;
    inset: 0;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: var(--space-6);
    background: rgba(8, 8, 15, 0.97);
    backdrop-filter: var(--backdrop-blur-heavy);
    -webkit-backdrop-filter: var(--backdrop-blur-heavy);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--duration-slow) var(--ease-out);
    z-index: 999;
    overflow-y: auto;
    max-height: 100vh;
    padding: var(--space-16) var(--space-6) var(--space-8);
  }

  .nav-menu.is-active {
    opacity: 1;
    pointer-events: auto;
  }

  .nav-link {
    font-size: var(--fs-h4);
    padding: var(--space-3) var(--space-6);
  }

  .form-inline {
    flex-direction: column;
  }

  .btn {
    width: 100%;
    justify-content: center;
  }

  .modal {
    padding: var(--space-6);
    margin: var(--space-4) auto !important;
  }
}