/* ============================================
   ALPENPOST - Inner Pages Styles
   ============================================ */

/* --- Page Inner (non-hero pages) --- */
.page-inner {
  padding-top: 64px;
}

.page-inner .nav {
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(0,0,0,0.06);
}

/* Inner pages: nav always dark text regardless of .scrolled class */
.page-inner .nav .nav-link {
  color: var(--color-neutral-600);
}
.page-inner .nav .nav-link:hover {
  color: var(--color-neutral-950);
}
.page-inner .nav .nav-link.nav-link--cta {
  color: var(--color-white) !important;
  background: var(--color-primary-600);
}
.page-inner .nav .nav-link.nav-link--cta:hover {
  color: var(--color-white) !important;
  background: var(--color-primary-700);
}
.page-inner .nav .nav-account {
  color: var(--color-neutral-500);
}
.page-inner .nav .nav-account:hover {
  color: var(--color-neutral-950);
  background: var(--color-neutral-100);
}

/* --- Page Header --- */
.page-header {
  padding: var(--space-16) 0 var(--space-12);
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-100);
  text-align: center;
}

.page-title {
  font-family: var(--font-display);
  font-size: var(--fluid-4xl);
  font-weight: 700;
  color: var(--color-neutral-950);
  letter-spacing: -0.03em;
  line-height: 1.1;
  text-wrap: balance;
}

.page-subtitle {
  font-size: var(--fluid-lg);
  color: var(--color-neutral-500);
  margin-top: var(--space-3);
  max-width: min(560px, 100%);
  margin-left: auto;
  margin-right: auto;
}

/* --- Active nav link --- */
.nav-link--active {
  font-weight: 600;
}

.nav.scrolled .nav-link--active {
  color: var(--color-primary-600);
}

/* ============================================
   Filter Bar
   ============================================ */
.filter-bar {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-neutral-100);
  padding: var(--space-4) 0;
  position: sticky;
  top: 64px;
  z-index: 50;
}

.filter-bar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}

.filter-bar-left {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.filter-bar-right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.filter-group {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.filter-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-neutral-500);
}

.filter-select {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--color-neutral-800);
  background: var(--color-neutral-50);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  padding: 8px 32px 8px 12px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%235c6370' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  transition: all var(--transition-fast);
}

.filter-select:hover {
  border-color: var(--color-neutral-300);
}

.filter-select:focus {
  outline: none;
  border-color: var(--color-primary-600);
  box-shadow: 0 0 0 3px var(--color-primary-100);
}

.filter-count {
  font-size: 13px;
  color: var(--color-neutral-400);
}

/* Search Bar */
.search-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: var(--color-neutral-50);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  padding: 0 var(--space-3);
  height: 40px;
  transition: all var(--transition-fast);
  min-width: 300px;
}

.search-bar:focus-within {
  border-color: var(--color-primary-600);
  box-shadow: 0 0 0 3px var(--color-primary-100);
  background: var(--color-white);
}

.search-bar-icon {
  color: var(--color-neutral-400);
  flex-shrink: 0;
}

.search-bar-input {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--color-neutral-800);
  border: none;
  background: transparent;
  flex: 1;
  outline: none;
  height: 100%;
}

.search-bar-input::placeholder {
  color: var(--color-neutral-400);
}

.search-bar-badge {
  flex-shrink: 0;
  font-size: 9px;
  padding: 3px 6px;
}

/* ============================================
   Library Grid
   ============================================ */
.library-section {
  padding-top: var(--space-12);
}

.library-featured {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-10);
  align-items: start;
  padding: var(--space-10);
  background: var(--color-primary-50);
  border-radius: var(--radius-xl);
  margin-bottom: var(--space-12);
  border: 1px solid var(--color-primary-100);
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}

.library-featured-title {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-top: var(--space-4);
}

.library-featured-date {
  font-size: 0.95rem;
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

.library-featured-teaser {
  font-size: 1rem;
  color: var(--color-neutral-600);
  line-height: 1.6;
  margin-top: var(--space-4);
}

.library-featured-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}

.library-year-label {
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-neutral-800);
  margin-bottom: var(--space-6);
  margin-top: var(--space-10);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-neutral-200);
}

.library-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8) var(--space-5);
  margin-bottom: var(--space-8);
}

/* ============================================
   Archive / Chronik Section
   ============================================ */
.archive {
  display: grid;
  grid-template-columns: 4fr 6fr;
  margin-top: var(--space-16);
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* Left: curated image grid */
.archive-imagery {
  position: relative;
  background: #18140e;
  display: grid;
  grid-template-columns: 3fr 2fr;
  grid-template-rows: 1fr 1fr;
  gap: 3px;
  padding: 3px;
}

.archive-hero-img {
  grid-row: 1 / 3;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  border-right: 2px solid var(--color-accent-600);
}

.archive-accent-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.archive-accent-img--2 {
  filter: brightness(0.9);
}

.archive-year-tag {
  position: absolute;
  bottom: 8px;
  left: 10px;
  font-family: var(--font-display);
  font-size: 5rem;
  font-weight: 700;
  color: rgba(255,255,255,0.06);
  line-height: 1;
  letter-spacing: -0.03em;
}

/* Right: content on warm gold bg */
.archive-body {
  background: var(--color-accent-50);
  padding: var(--space-12) var(--space-10);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.archive-body .badge {
  align-self: flex-start;
}

.archive-title {
  font-family: var(--font-display);
  font-size: var(--fluid-3xl);
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-top: var(--space-5);
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.archive-text {
  font-size: 0.95rem;
  color: var(--color-neutral-600);
  margin-top: var(--space-4);
  line-height: 1.65;
  max-width: 400px;
}

.archive-features {
  display: flex;
  gap: var(--space-6);
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-accent-200);
}

.archive-feature {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-accent-700);
}

.archive-feature svg {
  flex-shrink: 0;
  color: var(--color-accent-600);
}

.archive-body .btn {
  margin-top: var(--space-8);
  align-self: flex-start;
}

/* ============================================
   Edition Detail Page
   ============================================ */
.detail-back {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 14px;
  font-weight: 500;
  color: var(--color-neutral-500);
  padding: var(--space-4) 0;
  transition: color var(--transition-fast);
}

.detail-back:hover {
  color: var(--color-primary-600);
}

.detail-layout {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: var(--space-16);
  align-items: start;
  padding-top: var(--space-8);
}

.detail-cover {
  position: sticky;
  top: calc(72px + var(--space-8));
}

.detail-cover .edition-card {
  cursor: default;
}

.detail-cover .edition-card:hover {
  transform: none;
  box-shadow: var(--shadow-md);
}

.detail-content {
  padding-top: var(--space-2);
}

.detail-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.detail-title {
  font-family: var(--font-display);
  font-size: var(--fluid-3xl);
  font-weight: 700;
  color: var(--color-neutral-950);
  line-height: 1.15;
}

.detail-date {
  font-size: 1rem;
  color: var(--color-neutral-500);
  margin-top: var(--space-2);
}

/* Purchase/CTA Block */
.detail-cta-block {
  background: var(--color-neutral-50);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  margin-top: var(--space-10);
}

.detail-cta-title {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-6);
}

/* Abo Options (prominent) */
.detail-abo-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.detail-abo-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--color-white);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
  transition: all var(--transition-fast);
}

.detail-abo-card:hover {
  border-color: var(--color-primary-400);
  background: var(--color-primary-50);
}

.detail-abo-card--recommended {
  border-color: var(--color-primary-600);
  background: var(--color-primary-50);
}

.detail-abo-card--recommended:hover {
  background: var(--color-primary-100);
}

.detail-abo-card-top {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
}

.detail-abo-card-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-neutral-950);
}

.detail-abo-card-price {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-primary-600);
}

.detail-abo-card-desc {
  font-size: 0.8rem;
  color: var(--color-neutral-500);
}

.detail-all-plans {
  display: block;
  text-align: center;
  margin-top: var(--space-4);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-primary-600);
}

.detail-all-plans:hover {
  color: var(--color-primary-700);
}

/* Einzelkauf (compact) */
.detail-single-purchase {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-neutral-200);
}

.detail-single-options {
  display: flex;
  gap: var(--space-3);
}

.detail-single-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  padding: var(--space-3) var(--space-4);
  background: var(--color-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-neutral-700);
  transition: all var(--transition-fast);
}

.detail-single-option:hover {
  border-color: var(--color-neutral-300);
  background: var(--color-neutral-50);
}

.detail-single-price {
  font-weight: 600;
  color: var(--color-neutral-950);
}

.detail-single-note {
  font-size: 0.75rem;
  color: var(--color-neutral-400);
  margin-top: var(--space-2);
}

/* Table of Contents */
.detail-toc {
  margin-top: var(--space-12);
}

.detail-toc-title {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-5);
}

/* Related Editions */
.related-editions {
  margin-top: var(--space-16);
  padding-top: var(--space-12);
  border-top: 1px solid var(--color-neutral-100);
}

.related-editions-title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-neutral-800);
  margin-bottom: var(--space-8);
}

.related-editions-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.related-editions-cta {
  margin-top: var(--space-8);
  text-align: center;
}

/* ============================================
   Pricing Page
   ============================================ */
.pricing-hero {
  text-align: center;
  padding: var(--space-16) 0 var(--space-12);
  background: var(--color-neutral-50);
  border-bottom: 1px solid var(--color-neutral-100);
}

.pricing-hero .page-title {
  margin-bottom: var(--space-3);
}

.pricing-hero .page-subtitle {
  margin: 0 auto;
  text-align: center;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  max-width: 1100px;
  margin: 0 auto;
}

.pricing-card {
  position: relative;
  background: var(--color-white);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  transition: all var(--transition-base);
}

.pricing-card .btn {
  margin-top: auto;
}

.pricing-card-price-note {
  font-size: 0.8rem;
  color: var(--color-neutral-400);
  margin-top: 2px;
  margin-bottom: var(--space-4);
}

.pricing-card:hover {
  border-color: var(--color-neutral-300);
  box-shadow: var(--shadow-md);
}

.pricing-card--recommended {
  border-color: var(--color-primary-600);
  box-shadow: 0 0 0 1px var(--color-primary-600);
  transform: scale(1.02);
  z-index: 1;
}

.pricing-card--recommended:hover {
  border-color: var(--color-primary-600);
  box-shadow: 0 0 0 1px var(--color-primary-600), var(--shadow-lg);
}

.pricing-card-badge {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
}

.pricing-card-name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-bottom: var(--space-1);
}

.pricing-card-desc {
  font-size: 0.85rem;
  color: var(--color-neutral-500);
  margin-bottom: var(--space-6);
  line-height: 1.4;
}

.pricing-card-price {
  margin-bottom: var(--space-8);
}

.pricing-card-amount {
  font-size: var(--fluid-3xl);
  font-weight: 700;
  color: var(--color-neutral-950);
  font-variant-numeric: tabular-nums;
}

.pricing-card-period {
  font-size: 0.9rem;
  color: var(--color-neutral-500);
}

.pricing-card-features {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
  flex: 1;
}

.pricing-card-feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: 0.85rem;
  color: var(--color-neutral-700);
  line-height: 1.4;
}

.pricing-card-feature svg {
  flex-shrink: 0;
  margin-top: 1px;
}

.pricing-card-feature--disabled {
  color: var(--color-neutral-400);
}

.pricing-card-feature--disabled svg {
  color: var(--color-neutral-300);
}

/* Single Purchase Banner */
.single-purchase-banner {
  background: var(--color-neutral-50);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-10);
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-12);
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
}

.single-purchase-content h3 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-neutral-800);
}

.single-purchase-content p {
  font-size: 0.9rem;
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

/* FAQ */
.faq-section {
  max-width: 760px;
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid var(--color-neutral-200);
}

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-6) 0;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-neutral-800);
  text-align: left;
}

.faq-question:hover {
  color: var(--color-primary-600);
}

.faq-question svg {
  flex-shrink: 0;
  color: var(--color-neutral-400);
  transition: transform var(--transition-fast);
}

.faq-item.open .faq-question svg {
  transform: rotate(180deg);
}

.faq-answer {
  font-size: 0.95rem;
  color: var(--color-neutral-600);
  line-height: 1.7;
  padding-bottom: var(--space-6);
  display: none;
}

.faq-item.open .faq-answer {
  display: block;
}

/* ============================================
   Dashboard
   ============================================ */
.dashboard-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--space-10);
  min-height: calc(100vh - 72px - 200px);
}

.dashboard-sidebar {
  padding-top: var(--space-8);
  border-right: 1px solid var(--color-neutral-100);
}

.dashboard-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding-right: var(--space-6);
}

.dashboard-nav-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-neutral-600);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.dashboard-nav-link:hover {
  color: var(--color-neutral-800);
  background: var(--color-neutral-50);
}

.dashboard-nav-link--active {
  color: var(--color-primary-600);
  background: var(--color-primary-50);
  font-weight: 600;
}

.dashboard-main {
  padding: var(--space-10) 0 var(--space-16);
}

.dashboard-welcome {
  margin-bottom: var(--space-10);
}

.dashboard-welcome h2 {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-neutral-950);
}

.dashboard-welcome p {
  font-size: 1rem;
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

/* Subscription Status Card */
.sub-status-card {
  background: var(--color-primary-50);
  border: 1.5px solid var(--color-primary-100);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  margin-bottom: var(--space-8);
}

.sub-status-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.sub-status-plan {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-neutral-950);
}

.sub-status-active {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-primary-600);
}

.sub-status-active::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--color-primary-600);
  border-radius: 50%;
}

.sub-status-details {
  display: flex;
  gap: var(--space-10);
  margin-bottom: var(--space-6);
}

.sub-status-detail {
  display: flex;
  flex-direction: column;
}

.sub-status-label {
  font-size: 0.8rem;
  color: var(--color-neutral-500);
  margin-bottom: 2px;
}

.sub-status-value {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-neutral-800);
}

/* Quick Actions */
.quick-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-10);
}

.quick-action {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-6);
  background: var(--color-white);
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--color-neutral-700);
  transition: all var(--transition-fast);
  text-align: center;
  min-width: 0;
}

.quick-action:hover {
  border-color: var(--color-primary-400);
  color: var(--color-primary-600);
  background: var(--color-primary-50);
}

.quick-action-icon {
  width: 36px;
  height: 36px;
  background: var(--color-neutral-100);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-neutral-500);
  flex-shrink: 0;
}

.quick-action:hover .quick-action-icon {
  background: var(--color-primary-100);
  color: var(--color-primary-600);
}

/* Recent Purchases */
.dashboard-section-title {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-5);
}

.purchase-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.purchase-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  background: var(--color-white);
  border: 1px solid var(--color-neutral-100);
  border-radius: var(--radius-lg);
  transition: all var(--transition-fast);
}

.purchase-item:hover {
  border-color: var(--color-neutral-200);
  box-shadow: var(--shadow-sm);
}

.purchase-item-left {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

/* Upgrade Banner */
.upgrade-banner {
  background: var(--color-accent-50);
  border: 1.5px solid var(--color-accent-200);
  border-radius: var(--radius-md);
  padding: var(--space-8);
  margin-top: var(--space-10);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.upgrade-banner-title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-top: var(--space-2);
}

.upgrade-banner-text {
  font-size: 0.9rem;
  color: var(--color-neutral-600);
  margin-top: var(--space-1);
}

.purchase-item-thumb {
  width: 44px;
  height: 58px;
  background: var(--color-neutral-100);
  border-radius: 2px;
  object-fit: cover;
  flex-shrink: 0;
  color: var(--color-primary-600);
}

.purchase-item-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-neutral-800);
}

.purchase-item-date {
  font-size: 0.8rem;
  color: var(--color-neutral-500);
  margin-top: 1px;
}

.purchase-item-right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.purchase-item-format {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-neutral-500);
  background: var(--color-neutral-100);
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

/* ============================================
   Mediadaten Page
   ============================================ */
.media-hero {
  text-align: center;
  padding: var(--space-20) 0 var(--space-16);
  background: linear-gradient(160deg, #0f1f18 0%, #1a3a2a 100%);
  color: var(--color-white);
}

.media-hero .overline {
  color: var(--color-primary-400);
}

.media-hero .page-title {
  color: var(--color-white);
}

.media-hero .page-subtitle {
  color: rgba(255,255,255,0.6);
  margin: var(--space-3) auto 0;
  text-align: center;
}

/* Impact Stats */
.impact-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  max-width: 900px;
  margin: calc(-1 * var(--space-12)) auto var(--space-16);
  position: relative;
  z-index: 2;
}

.impact-stat {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-neutral-100);
}

.impact-stat-number {
  font-family: var(--font-display);
  font-size: var(--fluid-4xl);
  font-weight: 700;
  color: var(--color-primary-600);
  line-height: 1;
}

.impact-stat-label {
  font-size: 0.9rem;
  color: var(--color-neutral-600);
  margin-top: var(--space-2);
}

.impact-stat-desc {
  font-size: 0.8rem;
  color: var(--color-neutral-400);
  margin-top: var(--space-1);
}

/* Readership Grid */
.readership-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  max-width: 1000px;
  margin: 0 auto;
}

.readership-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  text-align: center;
  border: 1px solid var(--color-neutral-200);
}

.readership-number {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-primary-600);
}

.readership-label {
  font-size: 0.85rem;
  color: var(--color-neutral-600);
  margin-top: var(--space-2);
}

/* Rate Card */
.rate-card {
  background: var(--color-neutral-50);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
  margin-top: var(--space-8);
}

.rate-card + .rate-card {
  margin-top: var(--space-6);
}

.rate-card-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-bottom: var(--space-8);
}

.rate-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.rate-table th {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-neutral-500);
  text-align: left;
  padding: var(--space-3) var(--space-4);
  border-bottom: 2px solid var(--color-neutral-200);
}

.rate-table td {
  font-size: 0.9rem;
  color: var(--color-neutral-700);
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-neutral-100);
}

.rate-table td:last-child {
  font-weight: 600;
  color: var(--color-neutral-800);
  text-align: right;
}

.rate-table th:last-child {
  text-align: right;
}

.rate-table tbody tr:hover {
  background: var(--color-white);
}

/* Publication Calendar */
.pub-calendar {
  margin-top: var(--space-12);
}

.pub-calendar-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-bottom: var(--space-8);
}

.pub-calendar-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-3);
}

.pub-calendar-month {
  background: var(--color-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  text-align: center;
  transition: all var(--transition-fast);
}

.pub-calendar-month:hover {
  border-color: var(--color-primary-400);
  box-shadow: var(--shadow-sm);
}

.pub-calendar-month-name {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-neutral-800);
  margin-bottom: var(--space-2);
}

.pub-calendar-month-dates {
  font-size: 0.75rem;
  color: var(--color-neutral-500);
  line-height: 1.6;
}

.pub-calendar-month-dates span {
  display: block;
  background: var(--color-primary-50);
  border-radius: var(--radius-sm);
  padding: 2px 4px;
  margin-top: 2px;
  color: var(--color-primary-700);
  font-weight: 500;
}

/* Media CTA */
.media-cta {
  text-align: center;
  background: var(--color-primary-50);
  border-radius: var(--radius-xl);
  padding: var(--space-16);
  margin-top: var(--space-16);
  border: 1px solid var(--color-primary-100);
}

.media-cta h3 {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-neutral-950);
  margin-bottom: var(--space-3);
}

.media-cta p {
  font-size: 1rem;
  color: var(--color-neutral-600);
  margin-bottom: var(--space-8);
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.media-cta-contact {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  margin-top: var(--space-6);
  font-size: 0.9rem;
  color: var(--color-neutral-600);
}

.media-cta-contact a {
  color: var(--color-primary-600);
  font-weight: 600;
}

/* Sub Status Actions */
.sub-status-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

/* Section Tight (reduced top padding) */
.section--tight {
  padding-top: var(--space-6);
}

/* Region CTA */
.region-cta {
  margin-top: var(--space-6);
}

/* Pricing Card Feature Highlight */
.pricing-card-feature--highlight {
  font-weight: 600;
  color: var(--color-neutral-900);
}

/* ============================================
   Auth / Utility Sections
   ============================================ */
.auth-message-section {
  min-height: 60vh;
  display: flex;
  align-items: center;
}

.auth-message-content {
  text-align: center;
}

.auth-message-icon {
  margin-bottom: var(--space-6);
  color: var(--color-neutral-400);
}

.auth-message-text {
  color: var(--color-neutral-600);
  margin-top: var(--space-4);
  line-height: 1.6;
}

.auth-message-actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-8);
  flex-wrap: wrap;
}

.auth-form-container {
  max-width: 480px;
}

.auth-form-footer {
  text-align: center;
  margin-top: var(--space-6);
  font-size: 0.9rem;
  color: var(--color-neutral-500);
}

.auth-form-link {
  color: var(--color-primary-600);
  font-weight: 600;
}

/* Dashboard login prompt */
.dashboard-login-prompt {
  text-align: center;
  max-width: 480px;
  margin: 0 auto;
}

.dashboard-login-register {
  margin-top: var(--space-4);
  font-size: 0.9rem;
  color: var(--color-neutral-500);
}

.dashboard-login-register-link {
  color: var(--color-primary-600);
  font-weight: 600;
}

/* ============================================
   Responsive - Inner Pages
   ============================================ */
/* ============================================
   Responsive — fluid overrides for inner pages
   ============================================ */

/* Library grid auto-fits based on available space */
.library-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(14rem, 100%), 1fr));
}

/* Library featured: keep grid, stack on mobile */
@media (max-width: 52rem) {
  .library-featured {
    grid-template-columns: 1fr;
    max-width: 100%;
    text-align: center;
  }
  .library-featured .edition-card {
    max-width: 12rem;
    margin: 0 auto;
  }
  .library-featured-actions {
    justify-content: center;
  }
}

/* Detail layout wraps */
.detail-layout {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10);
}

.detail-cover {
  flex: 0 0 clamp(14rem, 30vw, 24rem);
}

.detail-content {
  flex: 1 1 20rem;
  min-width: 0;
}

/* Pricing grid auto-fits */
.pricing-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(15rem, 100%), 1fr));
}

/* Impact stats auto-fit */
.impact-stats {
  grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr));
}

/* Readership auto-fit */
.readership-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(10rem, 100%), 1fr));
}

/* Calendar auto-fit */
.pub-calendar-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(9rem, 100%), 1fr));
}

/* Related editions auto-fit */
.related-editions-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(10rem, 100%), 1fr));
}

/* Dashboard layout wraps */
.dashboard-layout {
  display: flex;
  flex-wrap: wrap;
}

.dashboard-sidebar {
  flex: 0 0 clamp(10rem, 20vw, 15rem);
}

.dashboard-main {
  flex: 1 1 20rem;
  min-width: 0;
}

/* Quick actions auto-fit */
.quick-actions {
  grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr));
}

/* Single purchase banner wraps */
.single-purchase-banner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}

/* Archive section wraps on small */
.archive {
  display: flex;
  flex-wrap: wrap;
}

.archive-imagery {
  flex: 1 1 16rem;
  min-height: 16rem;
}

.archive-body {
  flex: 1 1 20rem;
}

/* ============================================
   52rem breakpoint — inner page layout shifts
   ============================================ */
@media (max-width: 52rem) {
  /* Page header padding */
  .page-header {
    padding: var(--space-10) 0 var(--space-8);
  }

  /* Filter bar stacks: search below filters */
  .filter-bar-inner {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .filter-bar-left {
    flex-wrap: wrap;
  }

  .search-bar {
    min-width: 0;
    width: 100%;
  }

  /* Library featured handled by 52rem breakpoint above */

  /* Detail page: cover above content, centered */
  .detail-cover {
    flex: 0 0 auto;
    width: min(70%, 20rem);
    margin: 0 auto;
    position: static;
  }

  .detail-content {
    flex: 1 1 100%;
  }

  .detail-title {
    font-size: var(--fluid-3xl);
  }

  /* Detail single purchase options stack */
  .detail-single-options {
    flex-direction: column;
  }

  /* Pricing hero padding */
  .pricing-hero {
    padding: var(--space-10) 0 var(--space-8);
  }

  /* Pricing card recommended: no scale on mobile */
  .pricing-card--recommended {
    transform: none;
  }

  .pricing-card--recommended:hover {
    transform: none;
  }

  /* Single purchase banner stacks */
  .single-purchase-banner {
    flex-direction: column;
    text-align: center;
    padding: var(--space-6);
  }

  /* Dashboard sidebar becomes horizontal tabs */
  .dashboard-layout {
    flex-direction: column;
  }

  .dashboard-sidebar {
    flex: 0 0 auto;
    border-right: none;
    border-bottom: 1px solid var(--color-neutral-100);
    padding-top: 0;
    padding-bottom: var(--space-4);
  }

  .dashboard-nav {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--space-2);
    padding-right: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .dashboard-nav-link {
    white-space: nowrap;
    padding: var(--space-2) var(--space-4);
    font-size: 0.85rem;
  }

  .dashboard-main {
    padding-top: var(--space-6);
  }

  /* Purchase items: full width */
  .purchase-item {
    flex-wrap: wrap;
    gap: var(--space-3);
  }

  .purchase-item-right {
    width: 100%;
    justify-content: flex-end;
  }

  /* Media hero padding */
  .media-hero {
    padding: var(--space-12) 0 var(--space-10);
  }

  .media-hero .page-title {
    font-size: var(--fluid-4xl);
  }

  /* Rate tables: horizontal scroll */
  .rate-card {
    padding: var(--space-6);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .rate-table {
    min-width: 28rem;
  }

  /* Archive features wrap */
  .archive-features {
    flex-wrap: wrap;
  }

  .archive-body {
    padding: var(--space-8) var(--space-6);
  }

  .archive-title {
    font-size: var(--fluid-3xl);
  }

  /* Upgrade banner stacks */
  .upgrade-banner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-4);
  }

  /* Media CTA padding */
  .media-cta {
    padding: var(--space-8);
  }

  .media-cta-contact {
    flex-direction: column;
    gap: var(--space-2);
  }

  /* Sub status details wrap */
  .sub-status-details {
    flex-wrap: wrap;
    gap: var(--space-4);
  }

  .sub-status-header {
    flex-wrap: wrap;
    gap: var(--space-3);
  }
}

/* ============================================
   30rem breakpoint — small phone adjustments
   ============================================ */
@media (max-width: 30rem) {
  /* Quick actions single column */
  .quick-actions {
    grid-template-columns: 1fr;
  }

  /* Impact stats single column */
  .impact-stats {
    grid-template-columns: 1fr;
  }

  /* Library grid 2 columns minimum */
  .library-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4) var(--space-3);
  }

  /* Related editions 2 columns */
  .related-editions-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }

  /* FAQ full width */
  .faq-section {
    max-width: 100%;
  }

  .faq-question {
    font-size: 0.9rem;
    padding: var(--space-4) 0;
  }

  /* Detail abo cards stack */
  .detail-abo-card {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
  }

  .detail-abo-card-top {
    flex-direction: column;
    gap: var(--space-1);
  }
}

/* ============================================
   About / Über uns Page
   ============================================ */
.page-header--about {
  background: var(--color-neutral-50);
}

/* Story section: text + image side by side */
.about-story {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-12);
  align-items: start;
}

.about-story-content {
  flex: 1 1 22rem;
  min-width: 0;
}

.about-story-content .section-title {
  margin-bottom: var(--space-6);
}

.about-text {
  color: var(--color-neutral-600);
  line-height: 1.7;
  margin-top: var(--space-4);
}

.about-story-image {
  flex: 0 0 clamp(14rem, 25vw, 20rem);
}

.about-img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}

.about-img-caption {
  font-size: var(--fluid-xs);
  color: var(--color-neutral-500);
  margin-top: var(--space-2);
  text-align: center;
}

/* Stats strip */
.about-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-10);
  text-align: center;
}

.about-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.about-stat-number {
  font-family: var(--font-display);
  font-size: var(--fluid-4xl);
  font-weight: 700;
  color: var(--color-white);
  line-height: 1;
}

.about-stat-label {
  font-size: var(--fluid-sm);
  color: rgba(255,255,255,0.7);
  margin-top: var(--space-2);
}

/* Team grid */
.about-team {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr));
  gap: var(--space-6);
  margin-bottom: var(--space-12);
}

.about-team-member {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  background: var(--color-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  transition: border-color 0.2s ease;
}

.about-team-member:hover {
  border-color: var(--color-primary-300);
}

.about-team-avatar {
  width: 3.5rem;
  height: 3.5rem;
  margin: 0 auto var(--space-4);
  background: var(--color-primary-50);
  color: var(--color-primary-600);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
}

.about-team-name {
  font-family: var(--font-display);
  font-size: var(--fluid-lg);
  font-weight: 600;
  color: var(--color-neutral-950);
}

.about-team-role {
  font-size: var(--fluid-sm);
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

/* Contributors */
.about-contributors {
  margin-bottom: var(--space-6);
}

.about-contributors-title {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-2);
}

.about-contributors-list {
  font-size: var(--fluid-base);
  color: var(--color-neutral-600);
  line-height: 1.6;
}

/* History grid */
.about-history-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr));
  gap: var(--space-6);
}

.about-history-item {
  overflow: hidden;
  border-radius: var(--radius-md);
}

.about-history-img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.about-history-caption {
  font-size: var(--fluid-xs);
  color: var(--color-neutral-500);
  margin-top: var(--space-2);
}

/* CTA */
.about-cta {
  text-align: center;
  max-width: 36rem;
  margin: 0 auto;
}

.about-cta-text {
  font-size: var(--fluid-lg);
  color: var(--color-neutral-600);
  margin-top: var(--space-4);
  margin-left: auto;
  margin-right: auto;
}

.about-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-8);
}

/* About: Geschichte Kapitel */
.about-chapter {
  padding-left: var(--space-8);
  border-left: 2px solid var(--color-neutral-200);
  margin-top: var(--space-8);
  position: relative;
}

.about-chapter::before {
  content: '';
  position: absolute;
  left: -5px;
  top: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary-600);
}

.about-chapter-year {
  font-family: var(--font-display);
  font-size: var(--fluid-sm);
  font-weight: 700;
  color: var(--color-primary-600);
  letter-spacing: 0.05em;
}

.about-chapter-title {
  font-family: var(--font-display);
  font-size: var(--fluid-xl);
  font-weight: 600;
  color: var(--color-neutral-950);
  margin-top: var(--space-1);
  margin-bottom: var(--space-3);
}

/* Override SureCart's fullscreen cover blocks inside our auth templates */
.auth-form-wrapper .wp-block-cover,
.auth-form-wrapper .wp-block-cover.alignfull {
  all: unset !important;
  display: block !important;
}

.auth-form-wrapper .wp-block-cover__background {
  display: none !important;
}

.auth-form-wrapper .wp-block-cover__inner-container {
  all: unset !important;
  display: block !important;
}

.auth-form-wrapper .wp-block-group {
  all: unset !important;
  display: block !important;
  background: var(--color-white) !important;
  border: 1px solid var(--color-neutral-200) !important;
  border-radius: var(--radius-md) !important;
  padding: var(--space-8) !important;
  min-height: 200px;
}

/* Style SureCart form inputs inside our auth wrapper */
.auth-form-wrapper input[type="text"],
.auth-form-wrapper input[type="email"],
.auth-form-wrapper input[type="password"],
.auth-form-wrapper input[type="username"],
.auth-form-wrapper select {
  display: block;
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--fluid-base);
  padding: 0.7em 0.9em;
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-neutral-800);
  transition: border-color 0.15s ease;
  margin-top: 0.3em;
  margin-bottom: 0.8em;
}

.auth-form-wrapper input:focus {
  outline: none;
  border-color: var(--color-primary-600);
  box-shadow: 0 0 0 3px var(--color-primary-100);
}

.auth-form-wrapper label {
  font-size: var(--fluid-sm);
  font-weight: 500;
  color: var(--color-neutral-700);
  display: block;
}

.auth-form-wrapper button,
.auth-form-wrapper input[type="submit"],
.auth-form-wrapper .wp-block-button__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fluid-base);
  padding: 0.7em 1.5em;
  border: none;
  border-radius: var(--radius-sm);
  background: var(--color-primary-600);
  color: var(--color-white);
  cursor: pointer;
  width: 100%;
  margin-top: var(--space-4);
  transition: background 0.15s ease;
}

.auth-form-wrapper button:hover,
.auth-form-wrapper input[type="submit"]:hover {
  background: var(--color-primary-700);
}

.auth-form-wrapper .wp-block-group {
  min-height: auto !important;
}

/* WordPress login form styling */
.auth-login-box {
  background: var(--color-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  padding: var(--space-8);
}

.auth-login-box label {
  display: block;
  font-size: var(--fluid-sm);
  font-weight: 500;
  color: var(--color-neutral-700);
  margin-bottom: var(--space-1);
}

.auth-login-box input[type="text"],
.auth-login-box input[type="password"] {
  display: block;
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--fluid-base);
  padding: 0.7em 0.9em;
  border: 1.5px solid var(--color-neutral-200);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-neutral-800);
  margin-bottom: var(--space-4);
  transition: border-color 0.15s ease;
}

.auth-login-box input[type="text"]:focus,
.auth-login-box input[type="password"]:focus {
  outline: none;
  border-color: var(--color-primary-600);
  box-shadow: 0 0 0 3px var(--color-primary-100);
}

.auth-login-box .login-remember {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  font-size: var(--fluid-sm);
  color: var(--color-neutral-600);
}

.auth-login-box input[type="submit"] {
  display: block;
  width: 100%;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--fluid-base);
  padding: 0.75em 1.5em;
  border: 2px solid var(--color-primary-600);
  border-radius: 4px;
  background: var(--color-primary-600);
  color: var(--color-white);
  cursor: pointer;
  transition: background 0.15s ease;
  outline: 1.5px solid rgba(255,255,255,0.55);
  outline-offset: -5px;
}

.auth-login-box input[type="submit"]:hover {
  background: var(--color-primary-700);
  border-color: var(--color-primary-700);
}

.auth-login-lost {
  text-align: center;
  margin-top: var(--space-4);
  font-size: var(--fluid-sm);
}

.auth-login-lost a {
  color: var(--color-primary-600);
  font-weight: 500;
}

.auth-login-lost a:hover {
  color: var(--color-primary-700);
}
