/* Examples page: concept styling */

/* Hero */
.examples-hero {
  position: relative;
  padding: 9rem 1.25rem 4rem;
  color: #fff;
  overflow: hidden;
}
.examples-hero .examples-hero-background { position: absolute; inset: 0; z-index: -1; }
.examples-hero .examples-gradient { position: absolute; inset: 0; background: var(--primary-gradient); opacity: .95; }
.examples-hero .examples-hero-content { max-width: 1100px; margin: 0 auto; }
.examples-title { font-family: var(--font-display); font-size: 3.25rem; line-height: 1.1; }
.examples-title .title-accent { color: var(--title-accent-color); }

/* Catalog */
.examples-catalog { padding: 3rem 1.25rem; }
.catalog-grid {
  display: grid; gap: 1rem; grid-template-columns: repeat(12, 1fr);
  max-width: 1100px; margin: 0 auto;
}
.catalog-card {
  grid-column: span 12;
  display: block;
  background: #fff; border: 1px solid var(--neutral-200); border-radius: var(--radius-xl);
  padding: 1.1rem; box-shadow: var(--shadow-sm); color: inherit; text-decoration: none;
  transition: transform .2s var(--ease-out-cubic), box-shadow .2s var(--ease-out-cubic);
}
.catalog-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.card-icon { width: 36px; height: 36px; color: var(--color-primary); }
.card-icon svg { width: 100%; height: 100%; }
.card-title { margin-top: .5rem; font-size: 1.2rem; font-weight: 800; }
.card-desc { margin-top: .25rem; color: var(--neutral-600); }
.card-cta { margin-top: .6rem; display: inline-block; color: var(--color-primary); font-weight: 700; }

@media (min-width: 800px) { .catalog-card { grid-column: span 4; } }

/* Example sections */
.example-section { padding: 2.5rem 1.25rem; background: linear-gradient(180deg, #ffffff 0, #fbfbfb 100%); scroll-margin-top: 80px; }
.example-header {
  margin: 0 auto 1.25rem;
  max-width: 1100px;
  text-align: left;
}

.example-body {
  display: grid;
  gap: 1rem;
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
}
.example-body > * { min-width: 0; }
.example-info { color: var(--neutral-700); }
.example-info code {
  white-space: normal;
  word-break: break-word;
}

.example-subheading {
  margin-top: 1.5rem;
}

.timeline-frame {
  border: 1px solid var(--neutral-200);
  overflow: hidden;
  background: #fff;
  box-shadow: var(--shadow-sm);
  min-width: 0;
}
.example-timeline-container {
  width: 100%;
  height: 500px;
  background: #f8fafc;
  min-width: 0;
}

/* Specific example height tweaks */
#events-timeline-container.example-timeline-container { height: 450px; }
#time-bands-timeline-container.example-timeline-container { height: 300px; }

/* Output panes */
.output-tabs { display: inline-flex; gap: .5rem; flex-wrap: wrap; margin-top: .5rem; }
.output-tab {
  border: 1px solid var(--neutral-200); background: #fff; color: var(--neutral-700);
  border-radius: .5rem; padding: .4rem .75rem; font-weight: 600; cursor: pointer;
}
.output-tab[aria-pressed="true"] { background: var(--neutral-900); color: #fff; border-color: var(--neutral-900); }

.output-panes { margin-top: .6rem; display: grid; gap: .6rem; }
.output-pane { margin: 0; padding: .8rem; border-radius: .75rem; background: #0b1220; color: #e5e7eb; overflow: auto; box-shadow: var(--shadow-inner); }
.output-pane code { font-family: var(--font-mono); font-size: .9rem; }

/* Events */
.events-grid { display: grid; gap: 1rem; grid-template-columns: 1fr; max-width: 1100px; margin: 1rem auto; }
@media (min-width: 900px) { .events-grid { grid-template-columns: 1fr 1fr; } }
.event-panel { background: #fff; border: 1px solid var(--neutral-200); border-radius: var(--radius-xl); padding: 1rem; box-shadow: var(--shadow-sm); }
.output-box { margin: .5rem 0 0; padding: .7rem .8rem; background: #0b1220; color: #e5e7eb; border-radius: .6rem; overflow: auto; font-family: var(--font-mono); font-size: .92rem; min-height: 48px; }
.muted { color: var(--neutral-600); }
.code-inline { font-family: var(--font-mono); font-size: .95rem; color: var(--neutral-800); word-break: break-word; }
.note {
  background: #f9f9f9;
  border: 1px solid var(--neutral-200);
  padding: .6rem .75rem;
  border-radius: .6rem;
  white-space: normal;
  word-break: break-word;
  margin: var(--space-4) 0;
}

/* Events meta labels */
.events-meta {
  display: grid;
  gap: .2rem;
  margin-top: .2rem;
}
.events-meta .meta-line { color: var(--neutral-600); font-size: .95rem; }
.events-meta .meta-label { color: var(--neutral-800); font-weight: 800; margin-right: .4ch; }

/* Controls */
.example-controls {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .75rem;
  align-items: end;
  max-width: 1100px;
  margin: 0 auto .8rem;
  width: 100%;
}
.example-controls.compact { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.control { min-width: 0; }
.control label { display: inline-block; font-size: .86rem; font-weight: 600; color: var(--neutral-700); margin-bottom: .25rem; }
.control input[type="number"], .control select { width: 100%; padding: .5rem .6rem; border: 1px solid var(--neutral-300); border-radius: .5rem; background: #fff; }
.control.checkbox label { display: inline-flex; align-items: center; gap: .5rem; font-weight: 600; }
.control.stretch { display: none; }
@media (min-width: 900px) { .control.stretch { display: block; } }

/* Simple toggle switch styling for radio pair */
.toggle-switch {
  display: inline-grid;
  grid-auto-flow: column;
  gap: .4rem;
  background: #fff;
  border: 1px solid var(--neutral-300);
  border-radius: .75rem;
  padding: .25rem;
}
.toggle-switch input[type="radio"] { display: none; }
.toggle-switch label {
  margin: 0;
  padding: .35rem .7rem;
  border-radius: .5rem;
  font-weight: 700;
  color: var(--neutral-700);
  cursor: pointer;
}
.toggle-switch input[type="radio"]:checked + label {
  background: var(--neutral-900);
  color: #fff;
}

/* Utilities */
[hidden] { display: none !important; }
