/* ==========================================================================
   Meet Ava — Components
   ========================================================================== */

/* ── Sticky Header ─────────────────────────────────────────────────────────── */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-5);
  transition: background var(--transition-base), box-shadow var(--transition-base);
  pointer-events: none;
}

.site-header > * {
  pointer-events: auto;
}

.site-header.scrolled {
  background: rgba(245, 240, 235, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 8px rgba(26, 26, 46, 0.06);
}

.site-header.on-dark {
  background: rgba(26, 26, 46, 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.site-header__logo {
  height: 28px;
  width: auto;
  opacity: 0;
  transition: opacity var(--transition-base);
}

.site-header.scrolled .site-header__logo {
  opacity: 1;
}

.site-header__right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.site-header__act {
  font-family: var(--font-headline);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  opacity: 0;
  transition: opacity var(--transition-base), color var(--transition-base);
}

.site-header.scrolled .site-header__act {
  opacity: 1;
}

.site-header.on-dark .site-header__act {
  color: rgba(245, 240, 235, 0.5);
}

.lang-switch {
  display: flex;
  gap: 2px;
  background: rgba(13, 115, 119, 0.08);
  border-radius: var(--radius-sm);
  padding: 2px;
}

.lang-switch__btn {
  font-family: var(--font-headline);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-1) var(--space-2);
  border: none;
  border-radius: 4px;
  cursor: pointer;
  background: transparent;
  color: var(--text-muted);
  transition: all var(--transition-fast);
  text-decoration: none;
}

.lang-switch__btn.active,
.lang-switch__btn:hover {
  background: var(--color-primary);
  color: #FFFFFF;
}

.site-header.on-dark .lang-switch {
  background: rgba(255, 255, 255, 0.1);
}

.site-header.on-dark .lang-switch__btn {
  color: rgba(245, 240, 235, 0.5);
}

.site-header.on-dark .lang-switch__btn.active,
.site-header.on-dark .lang-switch__btn:hover {
  background: var(--color-primary);
  color: #FFFFFF;
}

@media (max-width: 768px) {
  .site-header__act { display: none; }
  .site-header__logo { height: 22px; }
}

/* ── Progress Bar (Navigation) ─────────────────────────────────────────────── */
.progress-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: transparent;
  z-index: calc(var(--z-sticky) + 1);
}

.progress-bar__fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transition: width 100ms linear;
}

/* ── Section Navigation ────────────────────────────────────────────────────── */
.section-nav {
  position: fixed;
  right: var(--space-5);
  top: 50%;
  transform: translateY(-50%);
  z-index: var(--z-sticky);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.section-nav__dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  background: rgba(13, 115, 119, 0.2);
  border: none;
  cursor: pointer;
  transition: all var(--transition-base);
  padding: 0;
}

.section-nav__dot:hover {
  background: rgba(13, 115, 119, 0.5);
  transform: scale(1.3);
}

.section-nav__dot.active {
  background: var(--color-primary);
  transform: scale(1.4);
  box-shadow: var(--shadow-glow);
}

.section--dark ~ .section-nav .section-nav__dot,
.section-nav--light .section-nav__dot {
  background: rgba(245, 240, 235, 0.3);
}

@media (max-width: 768px) {
  .section-nav { display: none; }
}

/* ── Glasmorphism Card ─────────────────────────────────────────────────────── */
.card {
  background: var(--glass-bg);
  border: var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-md);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.card--solid {
  background: #FFFFFF;
  backdrop-filter: none;
}

.card--dark {
  background: rgba(26, 26, 46, 0.6);
  border-color: rgba(255, 255, 255, 0.1);
  color: var(--text-on-dark);
}

.card--teal {
  background: rgba(13, 115, 119, 0.08);
  border-color: rgba(13, 115, 119, 0.15);
}

.card__icon {
  width: 48px;
  height: 48px;
  margin-bottom: var(--space-3);
}

.card__title {
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.card__text {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: 1.6;
}

.card--dark .card__text {
  color: rgba(245, 240, 235, 0.7);
}

/* Card Grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-5);
  width: 100%;
}

.card-grid--2 {
  grid-template-columns: repeat(2, 1fr);
}

.card-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 768px) {
  .card-grid--2,
  .card-grid--3 {
    grid-template-columns: 1fr;
  }
}

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-base);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition-base);
  text-decoration: none;
  line-height: 1.4;
}

.btn--primary {
  background: var(--color-primary);
  color: var(--text-on-primary);
  border-color: var(--color-primary);
}

.btn--primary:hover {
  background: var(--teal-700);
  border-color: var(--teal-700);
  box-shadow: var(--shadow-glow);
  transform: translateY(-1px);
}

.btn--secondary {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn--secondary:hover {
  background: var(--teal-50);
  transform: translateY(-1px);
}

.btn--cta {
  background: var(--color-accent);
  color: var(--text-on-primary);
  border-color: var(--color-accent);
  font-size: var(--text-lg);
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-md);
}

.btn--cta:hover {
  background: var(--coral-dark);
  border-color: var(--coral-dark);
  box-shadow: 0 0 24px rgba(255, 107, 90, 0.3);
  transform: translateY(-2px);
}

.btn--ghost {
  background: transparent;
  color: var(--text-on-dark);
  border-color: rgba(245, 240, 235, 0.3);
}

.btn--ghost:hover {
  background: rgba(245, 240, 235, 0.1);
  border-color: rgba(245, 240, 235, 0.6);
}

.btn--lg {
  font-size: var(--text-lg);
  padding: var(--space-4) var(--space-7);
}

/* ── Pill Badges ───────────────────────────────────────────────────────────── */
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-1) var(--space-3);
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pill--teal {
  background: var(--teal-50);
  color: var(--teal-700);
}

.pill--coral {
  background: rgba(255, 107, 90, 0.12);
  color: var(--coral-dark);
}

.pill--amber {
  background: rgba(245, 158, 11, 0.12);
  color: #92600A;
}

.pill--mint {
  background: rgba(52, 211, 153, 0.12);
  color: #065F46;
}

.pill--dark {
  background: rgba(26, 26, 46, 0.08);
  color: var(--text-primary);
}

/* ── Speech Bubbles ────────────────────────────────────────────────────────── */
.bubble {
  position: relative;
  background: #FFFFFF;
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-sm);
  max-width: 480px;
}

.bubble::after {
  content: '';
  position: absolute;
  bottom: -8px;
  width: 16px;
  height: 16px;
  background: #FFFFFF;
  transform: rotate(45deg);
  box-shadow: 2px 2px 4px rgba(26, 26, 46, 0.06);
}

.bubble--ava {
  border-left: 3px solid var(--color-primary);
  margin-left: var(--space-5);
}

.bubble--ava::after {
  left: var(--space-5);
}

.bubble--user {
  border-right: 3px solid var(--color-dark);
  margin-right: var(--space-5);
  margin-left: auto;
}

.bubble--user::after {
  right: var(--space-5);
  left: auto;
}

.bubble__sender {
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-primary);
  margin-bottom: var(--space-1);
}

.bubble--user .bubble__sender {
  color: var(--color-dark);
  text-align: right;
}

.bubble__text {
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--text-primary);
}

/* ── Chat Dialog ───────────────────────────────────────────────────────────── */
.chat-dialog {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  width: 100%;
  max-width: 560px;
}

/* ── Counter (animierte Zahlen) ────────────────────────────────────────────── */
.counter {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--text-6xl);
  color: var(--color-primary);
  line-height: 1;
}

.counter--coral { color: var(--color-accent); }
.counter--dark  { color: var(--text-on-dark); }

.counter-unit {
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--text-secondary);
}

.stat-block {
  text-align: center;
}

.stat-block__label {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: var(--space-2);
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-6);
  width: 100%;
}

/* ── Mockup-Rahmen ─────────────────────────────────────────────────────────── */
.browser-frame {
  background: #FFFFFF;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  width: 100%;
  max-width: 800px;
}

.browser-frame__bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: #F0F0F3;
  border-bottom: 1px solid #E0E0E5;
}

.browser-frame__dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
}

.browser-frame__dot--red    { background: #FF5F57; }
.browser-frame__dot--yellow { background: #FEBC2E; }
.browser-frame__dot--green  { background: #28C840; }

.browser-frame__url {
  flex: 1;
  background: #FFFFFF;
  border-radius: var(--radius-sm);
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-left: var(--space-3);
}

.browser-frame__content {
  padding: var(--space-5);
  min-height: 300px;
}

/* ── Office / Kanban Rooms ─────────────────────────────────────────────────── */
.office-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
  width: 100%;
}

.office-room {
  background: var(--glass-bg);
  border: var(--glass-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  transition: all var(--transition-base);
}

.office-room:hover {
  box-shadow: var(--shadow-glow);
}

.office-room__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.office-room__title {
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-base);
}

.office-room__status {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
}

.office-room__status--active   { background: var(--color-success); box-shadow: 0 0 6px rgba(52, 211, 153, 0.5); }
.office-room__status--question { background: var(--color-warning); box-shadow: 0 0 6px rgba(245, 158, 11, 0.5); }
.office-room__status--waiting  { background: var(--text-muted); }
.office-room__status--done     { background: var(--color-primary); }

.office-room__avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-2);
}

.office-room__badges {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* ── Transparenz-Layer ─────────────────────────────────────────────────────── */
.layer-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  width: 100%;
  max-width: 600px;
}

.layer {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border-left: 4px solid;
}

.layer--blocker {
  background: rgba(255, 107, 90, 0.08);
  border-color: var(--color-accent);
}

.layer--assumption {
  background: rgba(245, 158, 11, 0.08);
  border-color: var(--color-warning);
}

.layer--guess {
  background: rgba(91, 181, 184, 0.08);
  border-color: var(--color-info);
}

.layer__label {
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-sm);
  min-width: 120px;
}

.layer__text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

/* ── Trust Badges ──────────────────────────────────────────────────────────── */
.trust-grid {
  display: flex;
  justify-content: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.trust-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  text-align: center;
}

.trust-badge__icon {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-2xl);
  transition: box-shadow var(--transition-base);
}

.trust-badge:hover .trust-badge__icon {
  box-shadow: var(--shadow-glow);
}

.trust-badge__label {
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-sm);
}

/* ── Section Dividers ──────────────────────────────────────────────────────── */
.section-divider {
  width: 100%;
  height: 80px;
  position: relative;
}

.section-divider svg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ── Parallax Background Layer ─────────────────────────────────────────────── */
.parallax-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: var(--z-background);
  overflow: hidden;
  pointer-events: none;
}

.parallax-bg__shape {
  position: absolute;
  opacity: 0.06;
}

/* ── Notification Mockup ───────────────────────────────────────────────────── */
.notification {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  background: #FFFFFF;
  border-radius: var(--radius-md);
  padding: var(--space-4);
  box-shadow: var(--shadow-md);
  max-width: 400px;
  border-left: 3px solid var(--color-primary);
}

.notification__icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.notification__title {
  font-family: var(--font-headline);
  font-weight: 600;
  font-size: var(--text-sm);
  margin-bottom: var(--space-1);
}

.notification__text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.notification__time {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-1);
}

/* ── Split Layout ──────────────────────────────────────────────────────────── */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
  align-items: center;
  width: 100%;
}

.split--reverse {
  direction: rtl;
}

.split--reverse > * {
  direction: ltr;
}

@media (max-width: 768px) {
  .split,
  .split--reverse {
    grid-template-columns: 1fr;
    direction: ltr;
    gap: var(--space-5);
  }
}

/* ── Early Bird Counter ────────────────────────────────────────────────────── */
.slots {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
}

.slot {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-headline);
  font-weight: 700;
  font-size: var(--text-lg);
  transition: all var(--transition-base);
}

.slot--available {
  background: var(--teal-50);
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
}

.slot--available:hover {
  box-shadow: var(--shadow-glow);
  transform: scale(1.05);
}

.slot--taken {
  background: var(--text-muted);
  color: #FFFFFF;
  border: 2px solid transparent;
  opacity: 0.4;
}

/* ── Avatar Wrapper ────────────────────────────────────────────────────────── */
.avatar-wrapper {
  position: relative;
  display: inline-block;
}

.avatar-img {
  width: 100%;
  max-width: 320px;
  height: auto;
}

.avatar-img--sm  { max-width: 80px; }
.avatar-img--md  { max-width: 160px; }
.avatar-img--lg  { max-width: 320px; }
.avatar-img--xl  { max-width: 480px; }
