/**
 * Akademische Jobs — Custom Styles
 * Design System: "The Academic Curator"
 *
 * Keine 1px Borders. Tiefe durch Hintergrundfarb-Abstufungen.
 * Newsreader (Serif) für Headlines, Inter (Sans) für Body.
 */

/* ═══════════════════════════════════════════════════════
   CSS Custom Properties (ergänzend zu theme.json)
   ═══════════════════════════════════════════════════════ */

:root {
  --akjobs-shadow-sm: 0 1px 3px rgba(26, 28, 30, 0.04);
  --akjobs-shadow-md: 0 4px 12px rgba(26, 28, 30, 0.06);
  --akjobs-shadow-lg: 0 20px 40px rgba(26, 28, 30, 0.06);
  --akjobs-transition: 200ms ease-in-out;
  --akjobs-radius-sm: 0.25rem;
  --akjobs-radius-md: 0.375rem;
  --akjobs-radius-lg: 0.5rem;
  --akjobs-radius-xl: 0.75rem;
}


/* ═══════════════════════════════════════════════════════
   Glassmorphism Header
   ═══════════════════════════════════════════════════════ */

.glass-header {
  background: rgba(255, 255, 255, 0.85) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--akjobs-shadow-sm);
  z-index: 100;
}

/* Kein Abstand zwischen Header und erstem Content-Block (Hero) */
.wp-site-blocks > .wp-block-group > main > .wp-block-cover:first-child,
.wp-site-blocks > main > .wp-block-cover:first-child,
main.wp-block-group > .wp-block-cover:first-child {
  margin-top: 0 !important;
}

/* Allgemein: Kein oberer Abstand nach sticky Header */
.wp-site-blocks > *:first-child,
.wp-site-blocks > .wp-block-template-part + * {
  margin-top: 0 !important;
}


/* ═══════════════════════════════════════════════════════
   Navigation: Aktiver Menüpunkt (Gold Underline)
   ═══════════════════════════════════════════════════════ */

/* Aktiver Link: Gold-Unterstrich + Primary-Farbe */
.wp-block-navigation .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation-item.current_page_item > .wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation-item > .wp-block-navigation-item__content[aria-current="page"],
.wp-block-navigation .wp-block-navigation-item.is-active > .wp-block-navigation-item__content,
.wp-block-navigation-item > a.wp-block-navigation-item__content[aria-current="page"] {
  color: var(--wp--preset--color--primary) !important;
  border-bottom: 2px solid var(--wp--preset--color--tertiary-fixed);
  padding-bottom: 0.25rem;
}

/* Hover auf Nav-Links */
.wp-block-navigation .wp-block-navigation-item > .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--primary) !important;
  transition: color var(--akjobs-transition);
}

/* Fallback: JS-basierte aktive Markierung (für wp_navigation ohne current-menu-item) */
.wp-block-navigation-item--active > .wp-block-navigation-item__content {
  color: var(--wp--preset--color--primary) !important;
  border-bottom: 2px solid var(--wp--preset--color--tertiary-fixed) !important;
  padding-bottom: 0.25rem;
}


/* ═══════════════════════════════════════════════════════
   Klassisches WP-Menü (Shortcode [akjobs_nav])
   ═══════════════════════════════════════════════════════ */

.akjobs-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 2rem;
  align-items: center;
}

.akjobs-nav-list li a {
  font-family: var(--wp--preset--font-family--newsreader);
  font-style: italic;
  font-size: 1.125rem;
  color: var(--wp--preset--color--on-surface-variant);
  text-decoration: none;
  transition: color var(--akjobs-transition);
}

.akjobs-nav-list li a:hover {
  color: var(--wp--preset--color--primary);
}

/* Aktiver Menüpunkt: Gold-Unterstrich */
.akjobs-nav-list li.current-menu-item a,
.akjobs-nav-list li.current_page_item a,
.akjobs-nav-list li.current-menu-ancestor a {
  color: var(--wp--preset--color--primary);
  border-bottom: 2px solid var(--wp--preset--color--tertiary-fixed);
  padding-bottom: 0.25rem;
}

/* Mobile: Hamburger ausblenden, vertikal */
@media (max-width: 768px) {
  .akjobs-nav-list {
    flex-direction: column;
    gap: 1rem;
  }
}


/* ═══════════════════════════════════════════════════════
   Hero Section
   ═══════════════════════════════════════════════════════ */

.hero-section .wp-block-cover__inner-container {
  max-width: 1400px;
  margin: 0 auto;
}

.hero-search-bar {
  box-shadow: var(--akjobs-shadow-lg);
  max-width: 900px;
}

.hero-search-bar .job_filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  width: 100%;
}

.hero-search-bar .search_jobs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0;
  width: 100%;
}

.hero-search-bar input[type="text"],
.hero-search-bar select {
  border: none;
  background: transparent;
  padding: 1rem 1.5rem;
  font-size: 1rem;
  flex: 1;
  min-width: 150px;
}

.hero-search-bar input[type="text"]:focus,
.hero-search-bar select:focus {
  outline: none;
  background: var(--wp--preset--color--surface);
}


/* ═══════════════════════════════════════════════════════
   Editorial Underline (Gold Accent)
   ═══════════════════════════════════════════════════════ */

.editorial-underline {
  position: relative;
  text-decoration: none;
}

.editorial-underline::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--wp--preset--color--tertiary-fixed);
}


/* ═══════════════════════════════════════════════════════
   Job Cards (WP Job Manager Override)
   ═══════════════════════════════════════════════════════ */

.job_listings {
  list-style: none;
  padding: 0;
  margin: 0;
}

.job_listings .job_listing {
  background: var(--wp--preset--color--surface-container-lowest);
  border-radius: var(--akjobs-radius-xl);
  padding: 1.5rem 2rem;
  margin-bottom: 1rem;
  transition: box-shadow var(--akjobs-transition);
  border: none;
  box-shadow: var(--akjobs-shadow-sm);
}

.job_listings .job_listing:hover {
  box-shadow: var(--akjobs-shadow-md);
}

.job_listings .job_listing a {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
}

.job_listings .job_listing .position h3 {
  font-family: var(--wp--preset--font-family--newsreader);
  font-style: italic;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--wp--preset--color--primary);
  margin: 0 0 0.25rem 0;
}

.job_listings .job_listing .company strong {
  font-weight: 600;
  color: var(--wp--preset--color--on-surface);
}

.job_listings .job_listing .location,
.job_listings .job_listing .job-type {
  font-size: 0.875rem;
  color: var(--wp--preset--color--on-surface-variant);
}

.job_listings .job_listing .meta {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--outline);
}

/* Date Badge */
.job_listings .job_listing .date time {
  font-size: 0.75rem;
  color: var(--wp--preset--color--outline);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Category Badge */
.job_listings .job_listing .job_listing-badges .job-type {
  background: var(--wp--preset--color--tertiary-fixed);
  color: var(--wp--preset--color--tertiary);
  padding: 0.25rem 0.75rem;
  border-radius: var(--akjobs-radius-sm);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}


/* ═══════════════════════════════════════════════════════
   Single Job Detail
   ═══════════════════════════════════════════════════════ */

.single-job_listing .job-detail-sidebar {
  background: var(--wp--preset--color--surface-container-low);
  border-radius: var(--akjobs-radius-xl);
  padding: 2rem;
  position: sticky;
  top: 6rem;
}

/* Eckdaten Definition List */
.akjobs-details {
  margin: 0;
}

.akjobs-details dt {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--on-surface-variant);
  margin-bottom: 0.25rem;
  margin-top: 1.25rem;
}

.akjobs-details dt:first-child {
  margin-top: 0;
}

.akjobs-details dd {
  font-size: 1rem;
  font-weight: 700;
  color: var(--wp--preset--color--primary);
  margin-bottom: 0;
  margin-left: 0;
}

.akjobs-details dd a {
  color: var(--wp--preset--color--primary);
  text-decoration: none;
}

.akjobs-details dd a:hover {
  text-decoration: underline;
}

/* Bewerbungs-Button in der Sidebar */
.job-detail-sidebar .application-button {
  display: block;
  width: 100%;
  margin-top: 1.5rem;
  padding: 1rem 1.5rem;
  box-sizing: border-box;
  text-align: center;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* Sicherstellen dass die Sidebar den Button enthält */
.job-detail-sidebar {
  overflow: visible;
}

/* WP Job Manager Standard-Meta ausblenden (Fallback) */
.single_job_listing .job_listing_meta,
.single_job_listing .job-manager-company,
.job_listing-company,
.job-overview,
ul.job-listing-meta,
.job-manager-application-wrapper,
.single-job_listing .wp-post-image {
  display: none !important;
}

.single-job_listing .job-description {
  line-height: 1.8;
}

.single-job_listing .job-description h3 {
  font-family: var(--wp--preset--font-family--newsreader);
  font-style: italic;
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--wp--preset--color--primary);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
}

.single-job_listing .job-description ul {
  padding-left: 1.5rem;
  margin-bottom: 1.5rem;
}

.single-job_listing .job-description li {
  margin-bottom: 0.5rem;
  color: var(--wp--preset--color--on-surface-variant);
}

.single-job_listing .job-description strong {
  color: var(--wp--preset--color--on-surface);
}

/* Apply Button */
.single-job_listing .application-button {
  display: block;
  width: 100%;
  background: linear-gradient(135deg, var(--wp--preset--color--primary), var(--wp--preset--color--primary-container));
  color: var(--wp--preset--color--on-primary);
  text-align: center;
  padding: 1.25rem 2rem;
  border-radius: var(--akjobs-radius-md);
  font-weight: 700;
  font-size: 1.125rem;
  text-decoration: none;
  box-shadow: var(--akjobs-shadow-md);
  transition: box-shadow var(--akjobs-transition), transform var(--akjobs-transition);
}

.single-job_listing .application-button:hover {
  box-shadow: var(--akjobs-shadow-lg);
  transform: translateY(-1px);
}


/* ═══════════════════════════════════════════════════════
   Hochschul-Cards
   ═══════════════════════════════════════════════════════ */

.institution-card {
  background: var(--wp--preset--color--surface-container-lowest);
  border-radius: var(--akjobs-radius-xl);
  padding: 2rem;
  box-shadow: var(--akjobs-shadow-sm);
  transition: box-shadow var(--akjobs-transition);
}

.institution-card:hover {
  box-shadow: var(--akjobs-shadow-md);
}

.institution-card .institution-name {
  font-family: var(--wp--preset--font-family--newsreader);
  font-style: italic;
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--wp--preset--color--primary);
  margin-bottom: 0.5rem;
}

.institution-card .institution-meta {
  font-size: 0.875rem;
  color: var(--wp--preset--color--on-surface-variant);
}

.institution-card .job-count {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--wp--preset--color--tertiary);
  margin-top: 1rem;
}


/* ═══════════════════════════════════════════════════════
   Newsletter Placeholder
   ═══════════════════════════════════════════════════════ */

.newsletter-placeholder {
  background: linear-gradient(135deg, var(--wp--preset--color--primary), var(--wp--preset--color--primary-container));
  border-radius: var(--akjobs-radius-xl);
  padding: 3rem;
  text-align: center;
  color: var(--wp--preset--color--on-primary);
  margin: 2rem 0;
}

.newsletter-placeholder h3 {
  font-family: var(--wp--preset--font-family--newsreader);
  font-style: italic;
  color: var(--wp--preset--color--on-primary);
}


/* ═══════════════════════════════════════════════════════
   Pagination
   ═══════════════════════════════════════════════════════ */

.job-manager-pagination {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  padding: 2rem 0;
}

.job-manager-pagination a,
.job-manager-pagination span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--akjobs-radius-md);
  font-weight: 600;
  text-decoration: none;
  transition: all var(--akjobs-transition);
}

.job-manager-pagination a {
  background: var(--wp--preset--color--surface-container-lowest);
  color: var(--wp--preset--color--on-surface);
}

.job-manager-pagination a:hover {
  background: var(--wp--preset--color--surface-container-high);
}

.job-manager-pagination span.current {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--on-primary);
}


/* ═══════════════════════════════════════════════════════
   Filter Sidebar (WP Job Manager)
   ═══════════════════════════════════════════════════════ */

.job_filters .search_jobs div {
  margin-bottom: 1rem;
}

.job_filters label {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  color: var(--wp--preset--color--on-surface-variant);
  display: block;
  margin-bottom: 0.375rem;
}

.job_filters input[type="text"],
.job_filters select {
  width: 100%;
  padding: 0.75rem 1rem;
  background: var(--wp--preset--color--surface-container-high);
  border: none;
  border-bottom: 2px solid var(--wp--preset--color--primary);
  border-radius: var(--akjobs-radius-sm) var(--akjobs-radius-sm) 0 0;
  font-size: 1rem;
  color: var(--wp--preset--color--on-surface);
  transition: all var(--akjobs-transition);
}

.job_filters input[type="text"]:focus,
.job_filters select:focus {
  background: var(--wp--preset--color--surface-container-lowest);
  border-bottom-color: var(--wp--preset--color--tertiary-fixed);
  outline: none;
}

.job_filters input[type="submit"] {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--on-primary);
  border: none;
  padding: 1rem 2rem;
  border-radius: var(--akjobs-radius-md);
  font-weight: 700;
  cursor: pointer;
  width: 100%;
  transition: background var(--akjobs-transition);
}

.job_filters input[type="submit"]:hover {
  background: var(--wp--preset--color--primary-container);
}


/* ═══════════════════════════════════════════════════════
   Responsive
   ═══════════════════════════════════════════════════════ */

@media (max-width: 768px) {
  .hero-section .wp-block-cover {
    min-height: 500px !important;
  }

  .hero-section h1 {
    font-size: 2.25rem !important;
  }

  .hero-search-bar {
    border-left-width: 4px !important;
  }

  .single-job_listing .job-detail-sidebar {
    position: static;
  }
}

@media (max-width: 480px) {
  .hero-section h1 {
    font-size: 1.75rem !important;
  }

  .job_listings .job_listing {
    padding: 1rem 1.25rem;
  }
}
