/*
Theme Name: Midlyr Webinar
Theme URI: https://midlyr.com
Author: Custom
Description: Single Webinar landing page template. All content is pulled from ACF fields on the "Webinar" custom post type. Fonts: Crimson Pro (headings) + IBM Plex Mono (eyebrow/body).
Version: 1.3.5
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: midlyr-webinar
*/

/* =========================================================
   Design tokens
   ========================================================= */
:root{
  /* Section backgrounds — sampled directly from the design mockup */
  --cream-1:   #f5eee4;   /* hero + page base */
  --cream-2:   #f7f7ef;   /* built-for / why sections */
  --beige:     #f5f1e6;   /* speakers section bg (soft warm cream) */
  --learn-bg:  #fefcf5;   /* "what you will learn" (near white) */
  --paper:     #fbf8f0;   /* card surface */
  --ink:       #1b1b18;   /* near-black text */
  --dark:      #27231f;   /* dark cards + footer (sampled) */
  --muted:     #84827a;   /* secondary text */
  --line:      #e3ddce;   /* hairline borders */
  --green:     #5f7a6a;   /* CTA buttons + links (midlyr.com brand) */
  --green-dk:  #4d6457;
  --on-dark:   #f3efe6;   /* text on dark cards */
  --on-dark-mut:#a7a59b;

  --maxw: 1180px;
  --radius: 4px;

  --font-head: "Crimson Pro", Georgia, "Times New Roman", serif;
  --font-sans: "IBM Plex Sans", -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

/* =========================================================
   Base
   ========================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body.webinar-template{
  margin:0;
  font-family:var(--font-mono);
  font-weight:400;
  font-size:18px;
  line-height:1.7;
  color:var(--ink);
  background:var(--cream-1);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--green); text-decoration:none; }
a:hover{ color:var(--green-dk); }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }

.eyebrow{
  font-family:var(--font-mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 18px;
}
h1,h2,h3{ font-family:var(--font-head); font-weight:600; color:var(--ink); margin:0; line-height:1.12; }

/* =========================================================
   Header / nav
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  background:transparent;
  transition:background .25s ease, box-shadow .25s ease;
}
.site-header.is-stuck{
  background:rgba(245,238,228,.85);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  box-shadow:0 1px 0 rgba(30,27,27,.06);
}
.header-inner{ max-width:var(--maxw); margin:0 auto; padding:14px 24px; display:flex; align-items:center; gap:34px; }
.brand{ position:relative; z-index:60; display:inline-flex; align-items:center; color:var(--ink); }
.brand svg{ width:80px; height:30px; display:block; }

/* Burger toggle (mobile only) */
.nav-toggle{ position:relative; z-index:60; display:none; margin-left:auto; background:none; border:0; padding:4px; cursor:pointer; color:var(--ink); }
.nav-toggle svg{ width:28px; height:28px; display:block; }
.nav-toggle .icon-close{ display:none; }
.site-header.menu-open .nav-toggle .icon-burger{ display:none; }
.site-header.menu-open .nav-toggle .icon-close{ display:block; }
.btn.mobile-cta{ display:none; }
.nav-backdrop{ display:none; }

.nav{ display:flex; align-items:center; gap:28px; }
.nav-item{ position:relative; }
.nav-link{
  font-family:var(--font-sans); font-size:14px; font-weight:500; color:var(--ink); line-height:1;
  background:none; border:0; padding:6px 0; cursor:pointer; display:inline-flex; align-items:center; gap:5px;
}
.nav-link:hover{ color:var(--green); }
.nav-link .caret{ width:9px; height:9px; opacity:.7; }

.dropdown{
  position:absolute; top:calc(100% + 8px); left:0;
  min-width:300px; background:#fffdf5; border:1px solid rgba(194,200,194,.5); border-radius:0;
  padding:12px 0; box-shadow:0 12px 32px rgba(31,27,27,.1);
  opacity:0; visibility:hidden; transform:translateY(6px);
  transition:opacity .16s ease, transform .16s ease; z-index:60;
}
.dropdown::before{ content:""; position:absolute; left:0; right:0; top:-8px; height:8px; } /* hover bridge over the gap */
.nav-item:hover .dropdown, .nav-item:focus-within .dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a{ display:block; padding:11px 18px; border-radius:0; white-space:nowrap; }
.dropdown a:hover{ background:rgba(95,122,106,.08); }
.dropdown .item-label{ display:block; font-family:var(--font-head); font-size:16px; font-weight:500; color:var(--ink); line-height:1.25; }
.dropdown .item-desc{ display:block; font-family:var(--font-mono); font-size:11px; color:#6b6660; margin-top:3px; }

.btn{
  margin-left:auto;
  display:inline-block; font-family:var(--font-sans); font-size:14px; font-weight:600;
  padding:8px 20px; border-radius:4px; white-space:nowrap;
  background:var(--green); color:#fffdf5; border:0;
  transition:background .15s ease;
}
.btn:hover{ background:var(--green-dk); color:#fffdf5; }
.btn-block{ display:block; width:100%; text-align:center; padding:13px; font-size:14px; cursor:pointer; margin-left:0; }

/* =========================================================
   Hero
   ========================================================= */
.hero{ position:relative; overflow:hidden; padding:40px 0 90px; }
.hero::before{
  content:""; position:absolute; inset:0;
  background:var(--cream-1) center top / cover no-repeat;
  background-image:var(--hero-bg, none);
  opacity:.9; z-index:0;
}
.hero::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(245,238,228,.2) 0%, rgba(245,238,228,.65) 70%, var(--cream-1) 100%);
  z-index:0;
}
.hero .wrap{ position:relative; z-index:1; display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:start; padding-top:50px; }
.hero-copy h1{ font-size:clamp(34px, 4.2vw, 58px); line-height:1.08; max-width:14em; }
.hero-date{ font-family:var(--font-mono); font-size:15px; color:var(--ink); margin-top:26px; }

/* Form card */
.form-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:6px;
  padding:26px 24px;
  box-shadow:0 18px 40px -28px rgba(40,35,20,.45);
}
.form-card h3{ font-family:var(--font-mono); font-weight:600; font-size:16px; margin:0 0 8px; }
.form-card p{ font-size:12.5px; color:var(--muted); line-height:1.55; margin:0 0 18px; }
.form-card .attio-embed :is(input,select,textarea){
  width:100%; font-family:var(--font-mono); font-size:13px;
  padding:11px 12px; margin-bottom:12px;
  border:1px solid var(--line); border-radius:var(--radius);
  background:#fff; color:var(--ink);
}
.form-card label{ display:block; font-family:var(--font-mono); font-size:12px; color:var(--muted); margin-bottom:5px; }

/* =========================================================
   Generic section
   ========================================================= */
.section{ padding:84px 0; }
.section-title{ text-align:center; font-size:clamp(30px, 4vw, 56px); margin-bottom:54px; }

/* Built for */
.builtfor{ background:var(--cream-2); }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.feature{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:40px 28px; text-align:center; min-height:210px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px;
}
.feature p{ margin:0; font-family:var(--font-sans); font-size:18px; color:#46443d; line-height:1.6; text-align:center; }
.feature .icon{ width:100px; height:100px; color:var(--ink); display:flex; align-items:center; justify-content:center; }
.feature .icon svg, .feature .icon img{ width:100px; height:100px; }
.feature.is-dark{ background:var(--dark); border-color:var(--dark); }
.feature.is-dark p{ color:var(--on-dark); }
.feature.is-dark .icon{ color:var(--on-dark); }

/* =========================================================
   Speakers
   ========================================================= */
.speakers{ background:var(--beige); }
.speaker-grid{ display:flex; gap:28px; justify-content:center; flex-wrap:wrap; }
.speaker{
  background:var(--paper); border:1px solid var(--line); border-radius:4px;
  width:350px; overflow:hidden; text-align:center; padding-bottom:28px;
}
.speaker .photo{ width:100%; height:445px; object-fit:cover; }
.speaker h3{ font-family:var(--font-sans); font-weight:700; font-size:24px; letter-spacing:-.01em; margin:26px 0 8px; }
.speaker .role{ font-family:var(--font-mono); font-size:12.5px; color:var(--muted); margin:0 0 16px; }
.speaker .bio{ font-family:var(--font-sans); font-size:18px; color:#5b594f; line-height:1.55; padding:0 26px; margin:0 0 18px; }
.speaker .linkedin{ font-family:var(--font-mono); font-size:13px; color:var(--green); display:inline-flex; gap:8px; align-items:center; }

/* =========================================================
   Why this matters
   ========================================================= */
.why .grid-3{ gap:22px; }
.stat{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:34px 28px; min-height:200px; font-family:var(--font-sans); font-size:18px; line-height:1.6; color:#46443d; text-align:center;
}
.stat.is-dark{ background:var(--dark); border-color:var(--dark); color:var(--on-dark); }

/* =========================================================
   What you will learn
   ========================================================= */
.learn{
  background:var(--learn-bg);
  background-image:radial-gradient(var(--line) 1px, transparent 1px);
  background-size:22px 22px;
}
.learn-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.learn-card{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 20px; font-family:var(--font-sans); font-size:18px; line-height:1.55; color:#46443d; min-height:188px; text-align:center;
}
.learn-card.is-dark{ background:var(--dark); border-color:var(--dark); color:var(--on-dark); }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:var(--dark); color:var(--on-dark); padding:64px 0 32px; font-family:var(--font-sans); }
.footer-inner{ max-width:var(--maxw); margin:0 auto; padding:0 24px; display:grid; grid-template-columns:1.3fr 3fr; gap:56px; }
.footer-brand .brand{ color:var(--on-dark); font-family:var(--font-head); font-size:40px; font-weight:600; line-height:1; }
.footer-tagline{ font-size:14px; line-height:1.6; color:var(--on-dark-mut); max-width:30ch; margin:20px 0 22px; }
.footer-badge{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.12em;
  color:var(--on-dark-mut); border:1px solid rgba(255,253,245,.18); border-radius:999px; padding:6px 13px;
}
.footer-badge svg{ width:13px; height:13px; }
.footer-cols{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.footer-col h4{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--on-dark-mut); margin:0 0 14px; font-weight:600; }
.footer-col a{ display:block; font-family:var(--font-sans); font-size:14px; color:var(--on-dark); opacity:.85; padding:5px 0; }
.footer-col a:hover{ opacity:1; color:#fff; }
.footer-bottom{
  max-width:var(--maxw); margin:44px auto 0; padding:22px 24px 0;
  border-top:1px solid rgba(255,253,245,.12);
  display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap;
}
.footer-bottom .copy{ font-family:var(--font-mono); font-size:12.5px; color:var(--on-dark-mut); }
.footer-bottom a{ font-family:var(--font-sans); font-size:13px; color:var(--on-dark); display:inline-flex; align-items:center; gap:7px; }
.footer-bottom a:hover{ color:#fff; }
.footer-bottom svg{ width:16px; height:16px; }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:920px){
  .hero .wrap{ grid-template-columns:1fr; gap:36px; padding-top:20px; }
  .grid-3{ grid-template-columns:1fr; }
  .learn-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-inner{ grid-template-columns:1fr; gap:40px; }
  .footer-cols{ grid-template-columns:repeat(2,1fr); }

  /* --- Mobile burger menu --- */
  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .header-inner > .btn{ display:none; }   /* hide top-bar CTA; shown inside overlay */

  /* Right-side drawer (not full screen) */
  .nav{
    position:fixed; top:0; right:0; bottom:0; left:auto;
    width:min(90vw, 300px); height:100%; z-index:46;
    background:var(--cream-1);
    box-shadow:-12px 0 40px rgba(27,23,20,.18);
    flex-direction:column; align-items:stretch; gap:0;
    padding:88px 24px 32px; margin:0;
    transform:translateX(100%); transition:transform .28s ease;
    overflow-y:auto;
  }
  .site-header.menu-open .nav{ transform:translateX(0); }

  /* Dimmed backdrop over the rest of the page */
  .nav-backdrop{
    display:block; position:fixed; inset:0; z-index:44; border:0; padding:0; cursor:pointer;
    background:rgba(27,23,20,.45);
    opacity:0; visibility:hidden; transition:opacity .28s ease, visibility .28s ease;
  }
  .site-header.menu-open .nav-backdrop{ opacity:1; visibility:visible; }

  /* When the drawer is open, the header must NOT have backdrop-filter:
     it would become the containing block for the fixed drawer/backdrop
     and clip them to the header height once the page is scrolled. */
  .site-header.menu-open{ background:transparent; -webkit-backdrop-filter:none; backdrop-filter:none; box-shadow:none; }

  /* Cards stack on mobile — let them size to their content */
  .feature, .stat, .learn-card{ min-height:0; }

  .nav-item{ border-bottom:1px solid var(--line); }
  .nav-link{ width:100%; justify-content:space-between; font-size:18px; padding:18px 2px; }
  .nav > a.nav-link{ border-bottom:1px solid var(--line); }
  .nav-link .caret{ width:13px; height:13px; transition:transform .2s ease; }
  .nav-item.open .nav-link .caret{ transform:rotate(180deg); }

  .dropdown,
  .nav-item:hover .dropdown,
  .nav-item:focus-within .dropdown{
    position:static; left:auto; transform:none; opacity:1; visibility:visible;
    min-width:0; background:none; border:0; box-shadow:none;
    padding:0 0 10px; display:none;
  }
  .nav-item.open .dropdown{ display:block; }
  .dropdown a{ font-size:16px; padding:10px 2px; }

  .btn.mobile-cta{ display:block; width:100%; margin-top:28px; margin-left:0; text-align:center; padding:15px; font-size:16px; }
}
@media (max-width:560px){
  .learn-grid{ grid-template-columns:1fr; }
  .speaker{ width:100%; max-width:350px; }
  .speaker .photo{ height:340px; }
  .footer-cols{ grid-template-columns:1fr 1fr; }
}
