/**
 * Jocelyne Pages - Custom Page Templates Styling
 * Unified CSS for all Jocelyne Saab archive page templates
 * Uses Inter + Libre Baskerville fonts, existing slate colors
 * Author: Mohamed Serag
 * Date: 2025-01-27
 * Version: 1.0.0
 */

/* ========================================
   Font Loading
   ======================================== */
/* Inter and Libre Baskerville loaded via functions.php when needed */

/* ========================================
   CSS Variables (inherits from main.css)
   ======================================== */
.jocelyne-page {
  /* Typography */
  --jocelyne-font-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --jocelyne-font-body: 'Libre Baskerville', Georgia, serif;
  
  /* Colors (using existing theme palette) */
  --jocelyne-slate: #708090;
  --jocelyne-slate-light: #9FB3C8;
  --jocelyne-slate-dark: #5A6B7D;
  --jocelyne-cream: #FEFEFE;
  --jocelyne-white: #FFFFFF;
  --jocelyne-gray-light: #F9FAFB;
  
  /* Spacing */
  --jocelyne-section-padding: 60px 15%;
  --jocelyne-section-padding-mobile: 40px 5%;
  
  /* Transitions */
  --jocelyne-transition: 0.3s ease-out;
}

/* ========================================
   Base Styles
   ======================================== */
.jocelyne-page {
  font-family: var(--jocelyne-font-body);
  line-height: 1.7;
  color: #333;
}

.jocelyne-page h1,
.jocelyne-page h2,
.jocelyne-page h3,
.jocelyne-page h4,
.jocelyne-page h5,
.jocelyne-page h6 {
  font-family: var(--jocelyne-font-heading);
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 1.5rem;
  line-height: 1.3;
}

.jocelyne-page h1 {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
}

.jocelyne-page h2 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  margin-bottom: 1.5rem;
  margin-top: 2.5rem;
  position: relative;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(112, 128, 144, 0.2);
}

.jocelyne-page h2::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 60px;
  height: 2px;
  background: var(--jocelyne-slate);
}

.jocelyne-page h3 {
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  margin-top: 2rem;
  margin-bottom: 1rem;
  color: var(--jocelyne-slate-dark);
  font-weight: 600;
}

.jocelyne-page p {
  font-family: var(--jocelyne-font-body);
  font-size: 1.125rem;
  line-height: 1.8;
  margin-bottom: 1.5rem;
  color: #555;
}

/* First paragraph after heading - slightly larger and more prominent */
.jocelyne-page h2 + p,
.jocelyne-page h3 + p {
  font-size: 1.25rem;
  line-height: 1.85;
  color: #444;
  margin-top: 1rem;
}

/* Varied paragraph spacing for visual rhythm */
.jocelyne-page p + p {
  margin-top: 1.25rem;
}

.jocelyne-page a {
  color: var(--jocelyne-slate);
  text-decoration: none;
  transition: color 0.2s ease;
  border-bottom: 1px solid transparent;
}

.jocelyne-page a:hover {
  color: var(--jocelyne-slate-dark);
  border-bottom-color: var(--jocelyne-slate-dark);
}

.jocelyne-page strong {
  font-weight: 600;
  color: #1a1a1a;
}

/* ========================================
   Section Styling (Auto-detected)
   ======================================== */
.jocelyne-page section {
  padding: var(--jocelyne-section-padding);
  width: 100%;
}

.jocelyne-page section:first-child {
  padding-top: 100px;
}

/* Override section:first-child padding for hero sections */
.jocelyne-page section.jocelyne-hero:first-child {
  padding-top: 100px !important;
}

.jocelyne-page section:last-child {
  padding-bottom: 120px;
}

/* Alternating backgrounds with subtle variation */
.jocelyne-page section:nth-child(even) {
  background-color: var(--jocelyne-white);
  background-image: linear-gradient(to bottom, transparent 0%, rgba(159, 179, 200, 0.02) 100%);
}

.jocelyne-page section:nth-child(odd) {
  background-color: var(--jocelyne-gray-light);
  background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.5) 0%, transparent 100%);
}

/* Subtle visual separators */
.jocelyne-page section:not(:first-child) {
  border-top: 1px solid rgba(112, 128, 144, 0.08);
  margin-top: 1px;
}

/* ========================================
   Hero/Title Section
   ======================================== */
.jocelyne-hero {
  padding: 100px 15% 4rem 15%;
  background-color: var(--jocelyne-white);
  text-align: center;
}

.jocelyne-hero h1 {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  margin-bottom: 0;
  font-weight: 700;
  color: var(--jocelyne-slate-dark);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* ========================================
   Fade-up Animation
   ======================================== */
.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity var(--jocelyne-transition), transform var(--jocelyne-transition);
}

.fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ========================================
   Container & Content Wrapper
   ======================================== */
.jocelyne-page .container {
  max-width: 1000px;
  margin: 0 auto;
}

.jocelyne-page .content-wrapper {
  max-width: 100%;
}

/* Varied content widths for editorial style */
.jocelyne-page section .content-wrapper {
  max-width: 65%;
  margin: 0 auto;
}

/* Team sections - wider for 2-column grid */
.jocelyne-page section:has(.jocelyne-team-grid) .content-wrapper,
.jocelyne-page section:has(p:has(strong:first-child)) .content-wrapper {
  max-width: 80%;
}

/* Film cards - full width */
.jocelyne-page section:has(.jocelyne-film-card) .content-wrapper {
  max-width: 100%;
}

/* Technical sections - medium width */
.jocelyne-page section:has(.jocelyne-info-badge) .content-wrapper {
  max-width: 75%;
}

/* Fallback for browsers without :has() support - use class-based approach */
.jocelyne-page section.with-team .content-wrapper,
.jocelyne-page section.with-badges .content-wrapper {
  max-width: 75%;
}

.jocelyne-page section.with-film-cards .content-wrapper {
  max-width: 100%;
}

/* Our History page - wider content for better readability */
.jocelyne-page.page-our-history section .content-wrapper {
  max-width: 85%;
}

/* Archive Circulation page - wider content for better readability */
.jocelyne-page.page-archive-circulation section .content-wrapper {
  max-width: 80%;
}

/* WordPress block paragraph styling */
.jocelyne-page .wp-block-paragraph {
  margin-bottom: 1.5rem;
}

/* WordPress block heading styling */
.jocelyne-page .wp-block-heading h2 {
  margin-top: 2.5rem;
}

.jocelyne-page .wp-block-heading h3 {
  margin-top: 2rem;
}

/* ========================================
   Badges & Info Cards
   ======================================== */
.jocelyne-info-badge {
  display: inline-block;
  padding: 0.35rem 0.85rem;
  background-color: rgba(159, 179, 200, 0.15);
  color: var(--jocelyne-slate-dark);
  border-radius: 3px;
  font-family: var(--jocelyne-font-heading);
  font-size: 0.875rem;
  font-weight: 500;
  margin-right: 0.6rem;
  margin-bottom: 0.6rem;
  border: 1px solid rgba(159, 179, 200, 0.3);
  letter-spacing: 0.02em;
  line-height: 1.4;
  white-space: normal;
}

/* Hide <br /> tags within badges */
.jocelyne-info-badge br {
  display: none;
}

.jocelyne-info-line {
  margin-bottom: 0.75rem;
  font-family: var(--jocelyne-font-heading);
  font-weight: 600;
  color: var(--jocelyne-slate-dark);
}

.jocelyne-info-line span {
  color: var(--jocelyne-slate);
  font-weight: 400;
}

/* Highlighted info patterns */
.jocelyne-page p:has-attr(data-location),
.jocelyne-page p:has-attr(data-duration),
.jocelyne-page p:has-attr(data-speaker) {
  padding: 1rem;
  background-color: var(--jocelyne-cream);
  border-left: 3px solid var(--jocelyne-slate);
  margin-bottom: 1.5rem;
}

/* ========================================
   Lists
   ======================================== */
.jocelyne-page ul,
.jocelyne-page ol,
.jocelyne-page .wp-block-list {
  margin-bottom: 2rem;
  padding-left: 2rem;
}

.jocelyne-page li,
.jocelyne-page .wp-block-list-item {
  font-family: var(--jocelyne-font-body);
  font-size: 1.125rem;
  line-height: 1.85;
  margin-bottom: 0.85rem;
  color: #555;
  padding-left: 0.5rem;
}

.jocelyne-page ul li::marker {
  color: var(--jocelyne-slate);
}

/* WordPress list blocks */
.jocelyne-page .wp-block-list {
  margin-left: 0;
  padding-left: 2rem;
}

.jocelyne-page ol {
  counter-reset: step-counter;
}

.jocelyne-page ol li {
  counter-increment: step-counter;
  position: relative;
  padding-left: 2.5rem;
}

.jocelyne-page ol li::before {
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--jocelyne-font-heading);
  font-weight: 700;
  color: var(--jocelyne-slate);
  font-size: 1.25rem;
}

/* Step-based list styling */
.jocelyne-step-list {
  list-style: none;
  padding-left: 0;
}

.jocelyne-step-list li {
  margin-bottom: 2rem;
  padding: 1.5rem;
  background-color: var(--jocelyne-white);
  border-radius: 8px;
  border: 1px solid #e0e0e0;
}

.jocelyne-step-list li::before {
  content: none;
  padding-left: 0;
}

/* ========================================
   Film Cards (for Supported Films page)
   ======================================== */
.jocelyne-film-card {
  padding: 2rem;
  margin-bottom: 3rem;
  background-color: var(--jocelyne-white);
  border-radius: 8px;
  transition: box-shadow 0.3s ease;
}

.jocelyne-film-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.jocelyne-film-card h2 {
  margin-bottom: 1.5rem;
  color: var(--jocelyne-slate-dark);
}

.jocelyne-film-meta {
  font-family: var(--jocelyne-font-heading);
  font-size: 0.9rem;
  color: var(--jocelyne-slate);
  margin-bottom: 1.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.jocelyne-film-meta span {
  padding: 0.25rem 0.75rem;
  background-color: var(--jocelyne-gray-light);
  border-radius: 4px;
}

/* ========================================
   Video Embeds (YouTube & Vimeo)
   ======================================== */
.jocelyne-page .wp-block-embed,
.jocelyne-page .wp-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 aspect ratio */
  height: 0;
  overflow: hidden;
  max-width: 100%;
  margin: 2.5rem auto;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  background: #000;
}

.jocelyne-page iframe,
.jocelyne-page .wp-block-embed iframe,
.jocelyne-page .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 8px;
}

/* WordPress auto-embedded videos */
.jocelyne-page .wp-embedded-content {
  max-width: 100%;
}

/* Additional WordPress embed styling for better integration */
.jocelyne-page .wp-block-embed.is-type-video {
  margin: 2.5rem auto;
}

.jocelyne-page .wp-block-embed.is-provider-youtube .wp-block-embed__wrapper,
.jocelyne-page .wp-block-embed.is-provider-vimeo .wp-block-embed__wrapper {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* YouTube embeds in film cards - styled with theme slate colors */
.jocelyne-film-card .wp-block-embed__wrapper,
.jocelyne-film-card .jocelyne-youtube-embed {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
  margin: 2.5rem auto;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(112, 128, 144, 0.15);
  background: #000;
  border: 1px solid var(--jocelyne-slate-light);
}

.jocelyne-film-card .wp-block-embed__wrapper iframe,
.jocelyne-film-card .jocelyne-youtube-embed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 8px;
  border: none;
}

/* Hide empty paragraphs that might appear before embeds */
.jocelyne-page p:empty,
.jocelyne-page p:has(:only-child) {
  display: none;
}

/* ========================================
   Partner Cards (for Archive Circulation page)
   ======================================== */
.jocelyne-partner-card {
  background-color: var(--jocelyne-white);
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 2rem;
  margin-bottom: 2rem;
  transition: all 0.3s ease;
}

.jocelyne-partner-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
  border-color: var(--jocelyne-slate-light);
}

.jocelyne-partner-card h3 {
  margin-bottom: 1rem;
  color: var(--jocelyne-slate-dark);
}

/* ========================================
   Team Grid (for About page)
   ======================================== */
/* Team Grid - 2 columns as specified */
.jocelyne-team-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem 2rem;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(112, 128, 144, 0.15);
}

/* Auto-detect Role: Name pattern in paragraphs and style as grid */
.jocelyne-page p:has(strong:first-child) {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem 2rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(112, 128, 144, 0.1);
}

.jocelyne-page p:has(strong:first-child) strong {
  font-family: var(--jocelyne-font-heading);
  font-weight: 600;
  color: var(--jocelyne-slate-dark);
  margin-right: 1rem;
}

/* Additional styling for role:name paragraphs */
.jocelyne-page p:has(strong:first-child)::before {
  /* Visual separator could be added here if needed */
}

.jocelyne-team-role {
  font-family: var(--jocelyne-font-heading);
  font-weight: 600;
  color: var(--jocelyne-slate-dark);
  font-size: 1rem;
  line-height: 1.5;
}

.jocelyne-team-name {
  font-family: var(--jocelyne-font-body);
  font-weight: 400;
  color: #555;
  font-size: 1rem;
  line-height: 1.6;
}

/* ========================================
   Contact Grid
   ======================================== */
.jocelyne-contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 3rem;
  margin-top: 1.5rem;
}

.jocelyne-contact-item h3 {
  margin-bottom: 1rem;
  color: #1a1a1a;
}

.jocelyne-contact-item p {
  color: #555;
  margin-bottom: 0;
  line-height: 1.8;
}

/* ========================================
   Section Dividers
   ======================================== */
.jocelyne-page hr,
.jocelyne-section-divider {
  border: none;
  border-top: 1px solid #e0e0e0;
  margin: 3rem 0;
}

/* ========================================
   Blockquotes & Quotes
   ======================================== */
.jocelyne-page blockquote,
.jocelyne-page .wp-block-quote {
  border-left: 3px solid var(--jocelyne-slate);
  padding: 1.5rem 0 1.5rem 2rem;
  margin: 2.5rem 0;
  font-style: italic;
  color: var(--jocelyne-slate-dark);
  background: rgba(159, 179, 200, 0.05);
  border-radius: 0 4px 4px 0;
  font-size: 1.125rem;
  line-height: 1.75;
}

.jocelyne-page blockquote p,
.jocelyne-page .wp-block-quote p {
  margin-bottom: 1rem;
}

.jocelyne-page blockquote cite,
.jocelyne-page .wp-block-quote cite {
  display: block;
  margin-top: 1rem;
  font-size: 0.9rem;
  font-style: normal;
  color: var(--jocelyne-slate);
  font-family: var(--jocelyne-font-heading);
}

/* ========================================
   Images - Right Floating
   ======================================== */
/* WordPress image blocks float right in margins */
.jocelyne-page .wp-block-image,
.jocelyne-page figure.wp-block-image {
  float: right;
  width: 40%;
  max-width: 400px;
  margin: 1rem 0 1.5rem 2.5rem;
  clear: right;
}

.jocelyne-page img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
}

.jocelyne-page figure {
  margin: 0;
}

.jocelyne-page figcaption {
  font-family: var(--jocelyne-font-body);
  font-size: 0.85rem;
  color: var(--jocelyne-slate);
  text-align: left;
  margin-top: 0.75rem;
  font-style: italic;
  line-height: 1.5;
  padding-left: 0.5rem;
  border-left: 2px solid var(--jocelyne-slate-light);
}

/* Clear floats */
.jocelyne-page section::after {
  content: "";
  display: table;
  clear: both;
}

/* ========================================
   Responsive Design
   ======================================== */
@media (max-width: 1024px) {
  .jocelyne-page section {
    padding: 50px 10%;
  }
}

@media (max-width: 768px) {
  .jocelyne-page {
    --jocelyne-section-padding: 40px 5%;
  }
  
  .jocelyne-page section {
    padding: var(--jocelyne-section-padding);
  }
  
  .jocelyne-page section:first-child {
    padding-top: 80px;
  }
  
  .jocelyne-page section:last-child {
    padding-bottom: 80px;
  }
  
  .jocelyne-hero {
    padding: 100px 5% 3rem 5%;
  }
  
  /* Override section:first-child padding for hero sections on tablet */
  .jocelyne-page section.jocelyne-hero:first-child {
    padding-top: 100px !important;
  }
  
  /* Reset content widths on mobile */
  .jocelyne-page section .content-wrapper {
    max-width: 100%;
  }
  
  /* Images float below on mobile */
  .jocelyne-page .wp-block-image,
  .jocelyne-page figure.wp-block-image {
    float: none;
    width: 100%;
    max-width: 100%;
    margin: 1.5rem 0;
    clear: both;
  }
  
  .jocelyne-hero h1 {
    white-space: normal;
    font-size: 1.5rem;
  }
  
  .jocelyne-page h1 {
    font-size: 2rem;
  }
  
  .jocelyne-page h2 {
    font-size: 1.5rem;
  }
  
  .jocelyne-page h3 {
    font-size: 1.25rem;
  }
  
  .jocelyne-page p {
    font-size: 1rem;
  }
  
  .jocelyne-page h2 + p,
  .jocelyne-page h3 + p {
    font-size: 1.1rem;
  }
  
  .jocelyne-page li {
    font-size: 1rem;
  }
  
  .jocelyne-team-grid,
  .jocelyne-page p:has(strong:first-child) {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  
  .jocelyne-team-role {
    font-weight: 700;
    margin-bottom: 0.25rem;
  }
  
  .jocelyne-team-name {
    margin-bottom: 1.5rem;
  }
  
  .jocelyne-contact-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  
  .jocelyne-step-list li {
    padding: 1rem;
  }
  
  .jocelyne-film-card {
    padding: 1.5rem;
  }
  
  .jocelyne-partner-card {
    padding: 1.5rem;
  }
}

@media (max-width: 480px) {
  .jocelyne-page {
    --jocelyne-section-padding: 30px 5%;
  }
  
  .jocelyne-page section {
    padding: var(--jocelyne-section-padding);
  }
  
  .jocelyne-page section:first-child {
    padding-top: 60px;
  }
  
  .jocelyne-page section:last-child {
    padding-bottom: 60px;
  }
  
  .jocelyne-hero {
    padding: 80px 5% 2rem 5%;
  }
  
  /* Override section:first-child padding for hero sections on mobile */
  .jocelyne-page section.jocelyne-hero:first-child {
    padding-top: 80px !important;
  }
  
  .jocelyne-hero h1 {
    white-space: normal;
    font-size: 1.5rem;
  }
  
  .jocelyne-page h1 {
    font-size: 1.75rem;
  }
  
  .jocelyne-page h2 {
    font-size: 1.35rem;
  }
  
  .jocelyne-page h3 {
    font-size: 1.15rem;
  }
  
  .jocelyne-page p {
    font-size: 0.95rem;
  }
  
  .jocelyne-info-badge {
    font-size: 0.85rem;
    padding: 0.4rem 0.8rem;
  }
  
  .jocelyne-film-meta {
    font-size: 0.85rem;
    flex-direction: column;
    gap: 0.5rem;
  }
}

/* ========================================
   Hamburger Menu Positioning Override
   ======================================== */
/* Ensure hamburger menu respects positioning on Jocelyne pages */
.jocelyne-page ~ .hamburger-menu-content,
body.jocelyne-page .hamburger-menu-content,
.jocelyne-page .hamburger-menu-content {
  top: 25px !important;
}

@media (max-width: 768px) {
  body.jocelyne-page .hamburger-menu-content,
  .jocelyne-page .hamburger-menu-content {
    top: 15px !important;
  }
}

@media (max-width: 480px) {
  body.jocelyne-page .hamburger-menu-content,
  .jocelyne-page .hamburger-menu-content {
    top: 10px !important;
  }
}

/* ========================================
   Print Styles
   ======================================== */
@media print {
  .jocelyne-page section {
    padding: 20px 0;
    page-break-inside: avoid;
  }
  
  .jocelyne-page a[href]:after {
    content: " (" attr(href) ")";
  }
  
  .jocelyne-page iframe,
  .jocelyne-page .wp-block-embed__wrapper {
    display: none;
  }
}

