/*
Theme Name: Tel Shaddud
Theme URI: https://telshaddud.com
Author: Tel Shaddud Archaeological Project
Description: Official theme for the Tel Shaddud Archaeological Research Project.
Version: 4.0
Text Domain: tel-shaddud
*/

/* ── FONTS & TOKENS ───────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Cinzel:wght@400;500;600&display=swap');

:root {
  --bg: #F7F3EC; --bg2: #FDFAF5; --surface: #EDE8DF;
  --umber: #3D2B1F; --sepia: #7A5C42; --olive: #6B7C4A;
  --text: #1A1208; --muted: #8A7A6A; --rule: #C8B89A;
  --clay: #c05030; --deep-earth: #3a1508;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--bg); color: var(--text); font-family: 'Libre Baskerville', serif; font-size: 16px; line-height: 1.8; overflow-x: hidden; }

/* ── NAV (header template part) ──────────────────────────── */
.site-header {
  position: fixed !important; top: 0; left: 0; right: 0; z-index: 200;
  background: rgba(253,250,245,0.97) !important;
  backdrop-filter: blur(8px);
  display: flex !important; align-items: center; justify-content: space-between;
  padding: 0 2.5rem !important; height: 62px;
  border-bottom: 1px solid var(--rule);
}
.nav-logo, .nav-logo a {
  font-family: 'Playfair Display', serif !important; color: #000 !important;
  font-size: 0.65rem !important; font-weight: 400 !important; font-style: italic;
  letter-spacing: 0.02em; text-decoration: none; line-height: 1.4; flex-shrink: 0;
}
/* Native navigation block */
.site-header .wp-block-navigation__container {
  display: flex; gap: 1.6rem; list-style: none; align-items: center;
  font-family: 'Cinzel', serif; font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase;
}
.site-header .wp-block-navigation-item__content {
  color: #000 !important; font-family: 'Cinzel', serif; font-size: 0.68rem;
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 500;
  text-decoration: none; padding: 0;
}
.site-header .wp-block-navigation-item__content:hover { color: var(--sepia) !important; }
/* Dropdown submenu styling */
.site-header .wp-block-navigation__submenu-container {
  background: rgba(253,250,245,0.98) !important; border: 1px solid var(--rule) !important;
  border-top: 2px solid var(--clay) !important; padding: 0.5rem 0;
  box-shadow: 0 8px 24px rgba(26,18,8,0.12);
}
.site-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  padding: 0.6rem 1.2rem !important; font-size: 0.62rem !important;
  color: rgba(61,43,31,0.8) !important; white-space: nowrap;
}
.site-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
  color: var(--sepia) !important; background: rgba(122,92,66,0.08);
}
/* Register CTA button in nav */
.nav-cta-btn .wp-block-button__link {
  background: var(--clay) !important; color: #fff !important;
  padding: 0.45rem 1.2rem !important; border-radius: 2px !important;
  font-family: 'Cinzel', serif !important; font-size: 0.68rem !important;
  font-weight: 500 !important; letter-spacing: 0.12em !important;
  text-transform: uppercase !important; border: none !important;
}
.nav-cta-btn .wp-block-button__link:hover { background: #b84a2a !important; }

/* ── BANNER ───────────────────────────────────────────────── */
.site-banner {
  background: var(--umber) !important; color: var(--bg2) !important;
  padding: 0.9rem 4rem !important; margin-top: 62px;
  display: flex !important; justify-content: space-between; align-items: center;
}
.site-banner p { font-family: 'Cinzel', serif; font-size: 0.68rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--bg2) !important; margin: 0; }
.site-banner strong { color: #C8B89A; }
.site-banner .wp-block-button__link {
  font-family: 'Cinzel', serif; font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bg2) !important; background: transparent !important;
  border: 1px solid rgba(255,255,255,0.35) !important; padding: 0.38rem 1.1rem !important;
  border-radius: 0 !important;
}

/* ── HERO (original layout: video bg + sidebar) ───────────── */
.hero { position: relative; min-height: 100vh; display: flex; align-items: stretch; border-bottom: 2px solid var(--rule); margin-top: -62px; }
/* The wp:html block wrapping the video must NOT take any flex space,
   but its absolutely-positioned children still fill .hero */
.hero > .wp-block-html { flex: 0 0 0 !important; width: 0 !important; overflow: visible !important; padding: 0 !important; margin: 0 !important; }
/* WordPress group wrapper — kill any max-width/padding it adds to hero */
.hero.wp-block-group { max-width: none !important; padding: 0 !important; margin: 0 !important; }
.hero > .wp-block-group.hero-main { flex: 1; }
.hero > .wp-block-group.hero-sidebar { width: 230px; flex-shrink: 0; }
.hero-video-wrap { position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important; z-index: 0 !important; pointer-events: none; overflow: hidden; }
.hero-video-wrap iframe { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%) scale(1.35); width: 100%; height: 1080px; min-height: 1080px; min-width: 177.78vh; filter: brightness(0.62) saturate(1.15); }
.hero-video-overlay { position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important; z-index: 1 !important; background: linear-gradient(to right, rgba(26,18,8,0.75) 0%, rgba(26,18,8,0.48) 60%, rgba(26,18,8,0.1) 100%); }
.hero-main { position: relative !important; z-index: 2 !important; padding: 7rem 3rem 5rem !important; flex: 1 !important; display: flex !important; flex-direction: column !important; justify-content: flex-start !important; gap: 1.5rem !important; max-width: none !important; }
.hero-sidebar { position: relative !important; z-index: 2 !important; width: 230px !important; flex-shrink: 0 !important; display: flex !important; flex-direction: column !important; border-left: 1px solid var(--rule) !important; background: rgba(237,232,223,0.85) !important; backdrop-filter: blur(4px); max-width: none !important; padding: 0 !important; }
h1 { font-family: 'Playfair Display', serif; font-size: clamp(2.2rem,4.5vw,4rem); font-weight: 700; line-height: 1.04; letter-spacing: -0.02em; color: #fff; max-width: 16ch; }
.hero-subtitle { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-style: italic; color: #ecdcbc; }
.hero-rule { width: 56px; height: 2px; background: #c05030; margin: 0.8rem 0; }
.hero-meta { display: flex; gap: 0; border: 1px solid rgba(200,184,154,0.4); width: fit-content; background: rgba(26,18,8,0.55); }
.meta-cell { padding: 0.7rem 1.4rem; border-right: 1px solid rgba(200,184,154,0.3); }
.meta-cell:last-child { border-right: none; }
.meta-label { font-family: 'Cinzel', serif; font-size: 0.5rem; letter-spacing: 0.3em; color: #c8b88a; text-transform: uppercase; display: block; margin-bottom: 0.15rem; }
.meta-val { font-family: 'Playfair Display', serif; font-size: 0.85rem; color: #fff; font-weight: 600; }
.hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; }
.btn { display: inline-block; padding: 0.75rem 2rem; font-family: 'Libre Baskerville', serif; font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; text-decoration: none; cursor: pointer; border: none; transition: all 0.22s; }
.btn-primary { background: #c05030; color: #fff; }
.btn-primary:hover { background: #b84a2a; }
.btn-outline { background: transparent; color: #fff; border: 1px solid #fff; }
.btn-outline:hover { background: rgba(255,255,255,0.1); }
/* Sidebar */
.sb2-header { padding: 1rem 1.25rem; border-top: 3px solid #c05030; border-bottom: 3px solid #c05030; margin-top: 150px; text-align: center; }
.sb2-header p { margin: 0; font-family: 'Cinzel', serif; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--umber); }
.sb2-body { padding: 0.35rem 1.25rem; position: relative; }
.sb2-track { position: absolute; left: calc(1.25rem + 5px); top: 0.35rem; bottom: 0.35rem; width: 1px; background: var(--rule); }
.sb2-item { display: flex; gap: 6px; align-items: flex-start; padding: 0.48rem 0; }
.sb2-dot { width: 9px; height: 9px; border-radius: 50%; background: #c05030; border: 2px solid var(--surface); flex-shrink: 0; margin-top: 3px; position: relative; z-index: 1; }
.sb2-text { display: flex; flex-direction: column; flex: 1; }
.sb2-era { font-family: 'Playfair Display', serif; font-size: 0.85rem; font-weight: 600; color: var(--umber); line-height: 1.2; }
.sb2-dates { font-size: 0.72rem; color: var(--muted); }

/* ── SECTION LABELS ───────────────────────────────────────── */
.section-label {
  font-family: 'Cinzel', serif !important; font-size: 0.58rem !important;
  letter-spacing: 0.42em !important; color: var(--clay) !important;
  text-transform: uppercase !important; margin-bottom: 0.7rem !important;
  display: block !important;
}
h2.wp-block-heading { font-family: 'Playfair Display', serif !important; font-size: clamp(1.7rem,3vw,2.4rem) !important; font-weight: 700 !important; color: var(--umber) !important; line-height: 1.2 !important; }
.wp-block-paragraph { color: var(--sepia); line-height: 1.9; }

/* ── ABOUT SECTION ────────────────────────────────────────── */
.about-section { background: var(--bg) !important; padding: 4rem !important; }
.about-section .wp-block-column:first-child { display: flex; flex-direction: column; }
.about-section .wp-block-paragraph { font-size: 0.95rem; line-height: 1.85; color: #6a3018 !important; margin-bottom: 1.2rem; }
.about-cta .wp-block-button__link {
  background: var(--clay) !important; color: #fff !important; padding: 0.75rem 2rem !important;
  font-size: 0.78rem !important; font-weight: 700 !important; letter-spacing: 0.12em !important;
  text-transform: uppercase !important; border-radius: 2px !important; border: 2px solid var(--clay) !important;
}
.about-cta .wp-block-button__link:hover { background: #b84a2a !important; }

/* ── CARDS ────────────────────────────────────────────────── */
.cards-section { background: var(--bg) !important; padding: 0 4rem 5rem !important; text-align: center; }
.cards-section .wp-block-columns { margin-top: 2rem !important; gap: 1.5rem !important; }
.cards-section .wp-block-column {
  background: #fff; border: 1px solid rgba(158,144,128,0.2); border-radius: 3px;
  overflow: hidden; transition: transform 0.25s, box-shadow 0.25s; padding: 0 !important;
}
.cards-section .wp-block-column:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(59,42,26,0.1); }
.cards-section .wp-block-image img { width: 100%; aspect-ratio: 3/2; object-fit: cover; display: block; }
.cards-section .card-body { padding: 1.5rem; text-align: left; }
.cards-section h3.wp-block-heading { font-family: 'Playfair Display', serif !important; font-size: 1.3rem !important; color: var(--deep-earth) !important; margin-bottom: 0.6rem !important; }
.cards-section .wp-block-paragraph { font-size: 0.85rem; color: #a07060; line-height: 1.6; }
.cards-section .wp-block-button__link { color: var(--clay) !important; background: transparent !important; font-size: 0.78rem !important; letter-spacing: 0.1em !important; text-transform: uppercase !important; padding: 0 !important; border-bottom: 1px solid rgba(192,80,48,0.4) !important; border-radius: 0 !important; }

/* ── SEASON ───────────────────────────────────────────────── */
.season-section { background: var(--bg) !important; padding: 0 4rem 5rem !important; }
.season-section .wp-block-paragraph { font-size: 0.92rem; color: var(--sepia); line-height: 1.85; }
.season-dates-box {
  background: var(--bg); border-top: 3px solid var(--clay); border-left: 1px solid var(--rule);
  padding: 2.5rem;
}
.season-dates-box .dates-heading { font-family: 'Cinzel', serif; font-size: 0.6rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--muted); margin-bottom: 1.2rem; display: block; }
.season-dates-box .dates-big { font-family: 'Playfair Display', serif; font-size: 1.8rem; font-weight: 700; color: var(--umber); line-height: 1.2; }
.season-dates-box .dates-sub { font-size: 0.83rem; color: var(--sepia); font-style: italic; margin-top: 0.3rem; }
.dates-list { list-style: none; margin-top: 1.5rem; }
.dates-list li { font-size: 0.83rem; color: var(--sepia); padding: 0.48rem 0; border-bottom: 1px solid var(--rule); display: flex; justify-content: space-between; }
.dates-list li:last-child { border-bottom: none; }
.dates-list strong { color: var(--umber); font-weight: 600; }
.season-section .wp-block-button__link {
  background: var(--clay) !important; color: #fff !important; width: 100%;
  padding: 0.75rem 2rem !important; font-size: 0.65rem !important;
  letter-spacing: 0.15em !important; text-transform: uppercase !important;
  border-radius: 0 !important; text-align: center; display: block;
}
.season-photo-wrap { overflow: hidden; border-bottom: 3px solid var(--clay); height: 220px; }
.season-photo-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ── PARTNERS ─────────────────────────────────────────────── */
.partners-section { background: var(--bg); text-align: center; padding: 4rem !important; border-top: 1px solid var(--rule); }
.partners-section h2.wp-block-heading { font-weight: 400 !important; font-size: clamp(1.4rem,2.5vw,2rem) !important; margin-bottom: 2.5rem !important; }
.partners-section .wp-block-image img { height: 70px; width: auto; object-fit: contain; filter: opacity(0.75); transition: filter 0.3s; }
.partners-section .wp-block-image img:hover { filter: opacity(1); }
.partners-row { display: flex !important; flex-wrap: wrap; justify-content: center; align-items: center; gap: 2.5rem 4rem !important; }

/* ── CONTACT ──────────────────────────────────────────────── */
.contact-section { background: var(--bg) !important; padding: 5rem 4rem !important; border-top: 1px solid var(--rule); }
.contact-section .wp-block-paragraph { font-size: 0.92rem; color: var(--sepia); font-style: italic; }
.c-row { display: flex; gap: 1rem; margin-bottom: 1.1rem; align-items: flex-start; font-size: 0.88rem; color: var(--umber); }
.c-ico { font-size: 1rem; flex-shrink: 0; }
.c-lbl { font-family: 'Cinzel', serif; font-size: 0.53rem; letter-spacing: 0.28em; color: var(--muted); text-transform: uppercase; display: block; }
.contact-section .fg { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1rem; }
.contact-section .fg label { font-family: 'Cinzel', serif; font-size: 0.55rem; letter-spacing: 0.28em; color: var(--clay); text-transform: uppercase; }
.contact-section .fg input, .contact-section .fg textarea, .contact-section .fg select {
  background: var(--bg2); border: 1px solid var(--rule); color: var(--text);
  padding: 0.78rem 1rem; font-family: 'Libre Baskerville', serif; font-size: 0.9rem;
  outline: none; transition: border-color 0.2s; resize: none; width: 100%;
}
.contact-section .fg input:focus, .contact-section .fg textarea:focus { border-color: var(--clay); }
.contact-section .submit-btn .wp-block-button__link {
  background: var(--clay) !important; color: #fff !important; width: 100%; display: block;
  padding: 0.9rem 2rem !important; font-size: 0.65rem !important;
  letter-spacing: 0.15em !important; text-transform: uppercase !important; border-radius: 0 !important;
}

/* ── FOOTER ───────────────────────────────────────────────── */
.site-footer { background: #1e0c04 !important; color: #EDE8DF !important; padding: 4rem 2rem 2rem !important; }
.site-footer .wp-block-heading { font-size: 0.68rem !important; letter-spacing: 0.2em !important; text-transform: uppercase !important; color: rgba(237,232,223,0.5) !important; margin-bottom: 1rem !important; font-family: 'Cinzel', serif !important; font-weight: 400 !important; }
.site-footer .wp-block-paragraph { font-size: 0.82rem; line-height: 1.7; color: #EDE8DF !important; }
.footer-email a, .site-footer a { color: #EDE8DF !important; text-decoration: none; font-size: 0.82rem; transition: opacity 0.2s; }
.site-footer a:hover { opacity: 0.7; }
.site-footer .wp-block-list { list-style: none !important; padding: 0 !important; }
.site-footer .wp-block-list li { margin-bottom: 0.55rem; }
.footer-bottom { border-top: 1px solid rgba(237,232,223,0.15) !important; padding-top: 1.5rem !important; }
.footer-bottom .wp-block-paragraph { font-size: 0.75rem; color: rgba(237,232,223,0.5) !important; }

/* Utility */
.wp-site-blocks { padding: 0 !important; }
.is-root-container > * { margin-block: 0 !important; }

@media (max-width: 768px) {
  .site-header { padding: 0 1.5rem !important; }
  .site-header .wp-block-navigation { display: none !important; }
  .site-banner { padding: 0.9rem 1.5rem !important; flex-direction: column; gap: 0.5rem; text-align: center; }
  .about-section, .cards-section, .season-section, .contact-section, .partners-section { padding: 3rem 1.5rem !important; }
}

/* ── HERO WORDPRESS OVERRIDE PATCH ──────────────────────────────────────────
   WordPress adds margin/padding to block groups via its own stylesheet.
   These rules forcefully reset anything that would break the hero layout.  */
.wp-site-blocks > .alignfull.hero,
.wp-site-blocks > .wp-block-group.hero { margin-top: -62px !important; margin-bottom: 0 !important; }
.hero.wp-block-group > .wp-block-html { flex: 0 0 0 !important; width: 0 !important; min-width: 0 !important; overflow: visible !important; padding: 0 !important; margin: 0 !important; position: static !important; }
.hero .hero-video-wrap,
.hero .hero-video-overlay { position: absolute !important; }
.hero.wp-block-group { display: flex !important; align-items: stretch !important; min-height: 100vh !important; }
/* Prevent WP constrained layout from capping hero children width */
.hero > .wp-block-group { max-width: none !important; width: auto !important; }

/* ── FULL WIDTH PAGE TEMPLATE ────────────────────────────────────────────────
   When using the "Full Width" page template, Custom HTML blocks and their
   content fill the entire viewport with no margin or max-width constraints.  */

/* The post content itself — no padding, no max-width */
.wp-block-post-content {
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
}
.wp-block-post-content > * {
  max-width: none !important;
}

/* Custom HTML blocks inside pages — full width, no gutters */
.wp-block-post-content .wp-block-html {
  display: block;
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Make sure sections/divs inside custom HTML blocks also go full width */
.wp-block-post-content .wp-block-html > * {
  max-width: none !important;
}

/* Page content top padding to clear the fixed nav (62px) + banner (~45px) */
.wp-block-post-content > .wp-block-html:first-child {
  margin-top: 107px !important;
}
