.taller-page {
  padding-top: var(--sp-header-height);
}

.taller-background {
  position: fixed;
  inset: 0;
  z-index: var(--sp-z-behind);
  background: linear-gradient(180deg, var(--sp-color-bg) 0%, var(--sp-color-surface) 100%);
}

.taller-background::before {
  content: '';
  position: fixed;
  top: -150px;
  right: -150px;
  width: 600px;
  height: 600px;
  border-radius: var(--sp-radius-full);
  background: radial-gradient(circle,
    oklch(0.75 0.16 52 / 0.35) 0%,
    oklch(0.75 0.16 52 / 0.06) 70%,
    transparent 100%);
  pointer-events: none;
}

.taller-container {
  max-width: var(--sp-container-max);
  margin: 0 auto;
  padding: 0 var(--sp-space-6);
}

.taller-section-title {
  text-align: center;
  font-family: var(--sp-font-brand);
  font-size: var(--sp-text-3xl);
  font-weight: 700;
  letter-spacing: var(--sp-tracking-tight);
  margin-bottom: var(--sp-space-6);
  color: var(--sp-color-text);
}

.taller-section-subtitle {
  text-align: center;
  color: var(--sp-color-text-secondary);
  font-size: var(--sp-text-lg);
  margin-top: 0;
  margin-bottom: var(--sp-space-16);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
  line-height: var(--sp-leading-normal);
}

@media (max-width: 768px) {
  .taller-section-title {
    font-size: var(--sp-text-2xl);
  }

  .taller-section-subtitle {
    margin-bottom: var(--sp-space-10);
  }
}

@media (max-width: 480px) {
  .taller-container {
    padding: 0 var(--sp-space-4);
  }
}

.taller-wd-page { padding-top: var(--sp-header-height); }

.taller-wd-breadcrumbs { padding: var(--sp-space-4) 0; font-size: var(--sp-text-sm); color: var(--sp-color-text-secondary); }
.taller-wd-breadcrumbs a { color: var(--sp-color-text-secondary); text-decoration: none; }
.taller-wd-breadcrumbs a:hover { color: var(--sp-color-primary); }
.taller-wd-breadcrumbs .separator { margin: 0 var(--sp-space-2); }

.taller-wd-progress { padding: var(--sp-space-4) 0; }
.taller-wd-progress-bar { height: 4px; background: var(--sp-color-border); border-radius: var(--sp-radius-full); overflow: hidden; }
.taller-wd-progress-fill { height: 100%; background: var(--sp-color-primary); border-radius: var(--sp-radius-full); transition: width 0.6s ease; }
.taller-wd-progress-label { font-size: var(--sp-text-xs); color: var(--sp-color-text-secondary); margin-top: var(--sp-space-2); text-align: right; }

.taller-wd-hero { padding: var(--sp-space-12) 0 var(--sp-space-8); border-bottom: 1px solid var(--sp-color-border); margin-bottom: var(--sp-space-12); }
.taller-wd-hero-badge { display: inline-flex; align-items: center; gap: var(--sp-space-2); background: var(--sp-color-primary); color: var(--sp-color-text-on-primary); font-family: var(--sp-font-brand); font-size: var(--sp-text-lg); font-weight: 700; width: 48px; height: 48px; border-radius: 50%; justify-content: center; margin-bottom: var(--sp-space-4); }
.taller-wd-hero-title { font-family: var(--sp-font-brand); font-size: var(--sp-text-3xl); font-weight: 700; letter-spacing: var(--sp-tracking-tight); color: var(--sp-color-text); margin-bottom: var(--sp-space-4); }
.taller-wd-hero-objective { font-size: var(--sp-text-lg); color: var(--sp-color-text-secondary); line-height: var(--sp-leading-relaxed); max-width: 700px; }

.taller-wd-meta { display: flex; flex-wrap: wrap; gap: var(--sp-space-4); margin-top: var(--sp-space-6); }
.taller-wd-meta-item { display: flex; align-items: center; gap: var(--sp-space-2); font-size: var(--sp-text-sm); color: var(--sp-color-text-secondary); }
.taller-wd-meta-icon { width: 16px; height: 16px; color: var(--sp-color-primary); }
.taller-wd-meta-icon svg { width: 100%; height: 100%; }

.taller-wd-intro { padding: var(--sp-space-8) 0; font-size: var(--sp-text-lg); color: var(--sp-color-text-secondary); line-height: var(--sp-leading-relaxed); max-width: 800px; border-bottom: 1px solid var(--sp-color-border); margin-bottom: var(--sp-space-12); }

.taller-wd-learn { padding: var(--sp-space-8) 0; }
.taller-wd-learn-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-space-8); }
.taller-wd-learn-column { }
.taller-wd-learn-title { font-family: var(--sp-font-brand); font-size: var(--sp-text-xl); font-weight: 700; margin-bottom: var(--sp-space-6); color: var(--sp-color-text); }
.taller-wd-learn-list { list-style: none; padding: 0; margin: 0; }
.taller-wd-learn-item { display: flex; gap: var(--sp-space-3); padding: var(--sp-space-3) 0; font-size: var(--sp-text-base); color: var(--sp-color-text-secondary); line-height: var(--sp-leading-relaxed); }
.taller-wd-learn-check { color: var(--sp-color-primary); flex-shrink: 0; margin-top: 2px; width: 18px; height: 18px; }
.taller-wd-learn-check svg { width: 100%; height: 100%; }

.taller-wd-concepts { padding: var(--sp-space-8) 0; }
.taller-wd-concepts-list { display: flex; flex-wrap: wrap; gap: var(--sp-space-3); }
.taller-wd-concept-tag { display: inline-block; padding: var(--sp-space-2) var(--sp-space-4); background: color-mix(in oklch, var(--sp-color-primary) 10%, transparent); border: 1px solid color-mix(in oklch, var(--sp-color-primary) 25%, transparent); border-radius: var(--sp-radius-full); font-size: var(--sp-text-sm); color: var(--sp-color-primary); }

.taller-wd-frictions { padding: var(--sp-space-4) 0; }
.taller-wd-friction-list { display: flex; flex-wrap: wrap; gap: var(--sp-space-2); }
.taller-wd-friction-tag { display: inline-block; padding: var(--sp-space-1) var(--sp-space-3); background: var(--sp-color-surface); border: 1px solid var(--sp-color-border); border-radius: var(--sp-radius-sm); font-size: var(--sp-text-xs); color: var(--sp-color-text-secondary); }

.taller-wd-prereqs { padding: var(--sp-space-8) 0; }
.taller-wd-prereqs-box { background: var(--sp-color-surface); border: 1px solid var(--sp-color-border); border-left: 3px solid var(--sp-color-primary); border-radius: var(--sp-corners-sm); padding: var(--sp-space-6); }
.taller-wd-prereqs-title { font-family: var(--sp-font-brand); font-size: var(--sp-text-lg); font-weight: 700; margin-bottom: var(--sp-space-4); color: var(--sp-color-text); }
.taller-wd-prereqs-list { list-style: none; padding: 0; margin: 0; }
.taller-wd-prereqs-list li { padding: var(--sp-space-2) 0; font-size: var(--sp-text-base); color: var(--sp-color-text-secondary); padding-left: var(--sp-space-5); position: relative; }
.taller-wd-prereqs-list li::before { content: "\2192"; position: absolute; left: 0; color: var(--sp-color-primary); }

.taller-wd-outcomes { padding: var(--sp-space-12) 0; }
.taller-wd-outcomes-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-space-8); }
.taller-wd-outcomes-col { background: var(--sp-color-surface); border: 1px solid var(--sp-color-border); border-radius: var(--sp-corners-md); padding: var(--sp-space-6); }
.taller-wd-outcomes-heading { font-family: var(--sp-font-brand); font-size: var(--sp-text-lg); font-weight: 700; margin-bottom: var(--sp-space-4); color: var(--sp-color-text); }
.taller-wd-outcomes-list { list-style: none; padding: 0; margin: 0; }
.taller-wd-outcomes-list li { display: flex; gap: var(--sp-space-3); padding: var(--sp-space-3) 0; font-size: var(--sp-text-base); color: var(--sp-color-text-secondary); line-height: var(--sp-leading-relaxed); border-bottom: 1px solid var(--sp-color-border); }
.taller-wd-outcomes-list li:last-child { border-bottom: none; }
.taller-wd-outcomes-check { color: var(--sp-color-primary); flex-shrink: 0; margin-top: 2px; width: 16px; height: 16px; }
.taller-wd-outcomes-check svg { width: 100%; height: 100%; }

.taller-wd-next-preview { padding: var(--sp-space-8) 0; }
.taller-wd-next-card { background: linear-gradient(135deg, color-mix(in oklch, var(--sp-color-primary) 8%, transparent), transparent 60%); border: 1px solid var(--sp-color-border); border-radius: var(--sp-corners-md); padding: var(--sp-space-6); }
.taller-wd-next-label { font-size: var(--sp-text-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--sp-color-primary); font-weight: 600; margin-bottom: var(--sp-space-2); }
.taller-wd-next-text { font-size: var(--sp-text-base); color: var(--sp-color-text-secondary); line-height: var(--sp-leading-relaxed); }

.taller-wd-cta { padding: var(--sp-space-12) 0; text-align: center; }
.taller-wd-cta-title { font-family: var(--sp-font-brand); font-size: var(--sp-text-2xl); font-weight: 700; margin-bottom: var(--sp-space-4); color: var(--sp-color-text); }

@media (max-width: 768px) {
  .taller-wd-learn-grid, .taller-wd-outcomes-grid { grid-template-columns: 1fr; }
  .taller-wd-hero-title { font-size: var(--sp-text-2xl); }
  .taller-wd-meta { flex-direction: column; gap: var(--sp-space-2); }
}
@media (max-width: 480px) {
  .taller-wd-hero { padding: var(--sp-space-8) 0 var(--sp-space-6); }
}

.taller-wd-materials { padding: var(--sp-space-12) 0; }
.taller-wd-materials-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--sp-space-6); }
.taller-wd-material-card { border: 1px solid var(--sp-color-border); border-radius: var(--sp-corners-md); padding: var(--sp-space-6); background: var(--sp-color-surface); transition: border-color var(--sp-duration-fast) var(--sp-ease-default), box-shadow var(--sp-duration-fast) var(--sp-ease-default); }
.taller-wd-material-card:hover { border-color: var(--sp-color-primary); box-shadow: var(--sp-shadow-md); }
.taller-wd-material-icon { width: 40px; height: 40px; border-radius: var(--sp-radius-md); background: color-mix(in oklch, var(--sp-color-primary) 12%, transparent); display: flex; align-items: center; justify-content: center; color: var(--sp-color-primary); margin-bottom: var(--sp-space-4); }
.taller-wd-material-icon svg { width: 20px; height: 20px; }
.taller-wd-material-title { font-size: var(--sp-text-base); font-weight: var(--sp-font-semibold); color: var(--sp-color-text); margin-bottom: var(--sp-space-2); }
.taller-wd-material-desc { font-size: var(--sp-text-sm); color: var(--sp-color-text-secondary); line-height: var(--sp-leading-relaxed); margin: 0; }
a.taller-wd-material-card { text-decoration: none; display: block; }
a.taller-wd-material-card:hover { text-decoration: none; }

@media (max-width: 480px) {
  .taller-wd-materials-grid { grid-template-columns: 1fr; }
}

.taller-wd-nav { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-space-4); padding: var(--sp-space-12) 0; border-top: 1px solid var(--sp-color-border); }
.taller-wd-nav-link { display: flex; flex-direction: column; padding: var(--sp-space-5); border: 1px solid var(--sp-color-border); border-radius: var(--sp-corners-md); text-decoration: none; transition: border-color var(--sp-duration-fast) var(--sp-ease-default), box-shadow var(--sp-duration-fast) var(--sp-ease-default); }
.taller-wd-nav-link:hover { border-color: var(--sp-color-primary); box-shadow: var(--sp-shadow-sm); text-decoration: none; }
.taller-wd-nav-link--next { text-align: right; grid-column: 2; }
.taller-wd-nav-label { font-size: var(--sp-text-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--sp-color-text-secondary); margin-bottom: var(--sp-space-1); }
.taller-wd-nav-title { font-size: var(--sp-text-base); font-weight: var(--sp-font-semibold); color: var(--sp-color-text); }

@media (max-width: 768px) {
  .taller-wd-nav { grid-template-columns: 1fr; }
  .taller-wd-nav-link--next { grid-column: 1; text-align: left; }
}
