/* ═══════════════════════════════════════════════════════════════════
   MAITREYA LEARN PLATFORM — DESIGN SYSTEM
   learn.maitreyabuddha.com
   ═══════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@200;300;400;500&display=swap');

:root {
  --void:       #0c0a14;
  --deep:       #100e1c;
  --indigo:     #16132b;
  --indigo-mid: #1e1a35;
  --white:      #ffffff;
  --off-white:  #faf9fc;
  --mist:       #f3f1f8;
  --gold:       #e8b355;
  --star-gold:  #f5c97a;
  --gold-dim:   #c9922a;
  --rule-dark:  rgba(245,201,122,.12);
  --text-bright:#f0ead6;
  --text-mid:   rgba(240,234,214,.62);
  --text-dim:   rgba(240,234,214,.35);
  --ink:        #16132b;
  --ink-mid:    rgba(22,19,43,.65);
  --ink-dim:    rgba(22,19,43,.38);
  --light-rule: rgba(22,19,43,.1);
  --success:    #4caf82;
  --sidebar-w:  280px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Jost',sans-serif; background:var(--off-white); color:var(--ink); overflow-x:hidden; }

/* ── TOP NAV ── */
.learn-nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:60px;
  background:rgba(12,10,20,.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--rule-dark);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 2rem;
}
.learn-nav-logo { display:flex; align-items:center; gap:.8rem; text-decoration:none; }
.learn-nav-logo-text { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:400; letter-spacing:.25em; text-transform:uppercase; color:var(--text-bright); }
.learn-nav-logo-text em { color:var(--star-gold); font-style:normal; }
.learn-nav-right { display:flex; align-items:center; gap:1.5rem; }
.learn-nav-right a { font-size:.72rem; font-weight:300; letter-spacing:.14em; text-transform:uppercase; color:var(--text-mid); text-decoration:none; transition:color .3s; }
.learn-nav-right a:hover { color:var(--star-gold); }
.learn-nav-avatar { width:34px; height:34px; border-radius:50%; background:var(--indigo); border:1px solid var(--rule-dark); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--star-gold); cursor:pointer; }

/* ── COURSE SIDEBAR ── */
.learn-layout { display:flex; padding-top:60px; min-height:100vh; }
.learn-sidebar {
  width:var(--sidebar-w); flex-shrink:0;
  background:var(--void);
  border-right:1px solid var(--rule-dark);
  position:fixed; top:60px; bottom:0; left:0;
  overflow-y:auto; z-index:100;
}
.sidebar-course-title {
  padding:1.5rem 1.5rem 1rem;
  border-bottom:1px solid var(--rule-dark);
}
.sidebar-course-title .eyebrow { font-size:.6rem; font-weight:400; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:.4rem; }
.sidebar-course-title h3 { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:400; color:var(--text-bright); line-height:1.3; }
.sidebar-progress-bar { height:3px; background:var(--rule-dark); margin:1rem 1.5rem 0; border-radius:2px; }
.sidebar-progress-fill { height:100%; background:var(--gold); border-radius:2px; transition:width .5s; }
.sidebar-progress-label { font-size:.62rem; font-weight:300; color:var(--text-dim); padding:0 1.5rem .8rem; margin-top:.4rem; display:block; }

.sidebar-week {
  border-bottom:1px solid var(--rule-dark);
}
.sidebar-week-header {
  padding:.9rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between;
  cursor:pointer;
  font-size:.7rem; font-weight:400; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-dim);
  transition:color .3s;
}
.sidebar-week-header:hover, .sidebar-week-header.active { color:var(--star-gold); }
.sidebar-week-header .week-num { font-family:'Cormorant Garamond',serif; font-size:1.1rem; color:var(--gold); margin-right:.6rem; font-weight:300; }
.sidebar-week-toggle { font-size:.8rem; transition:transform .3s; }
.sidebar-week-header.open .sidebar-week-toggle { transform:rotate(180deg); }

.sidebar-lessons { display:none; }
.sidebar-week-header.open + .sidebar-lessons { display:block; }
.sidebar-lesson {
  display:flex; align-items:center; gap:.8rem;
  padding:.7rem 1.5rem .7rem 2.5rem;
  text-decoration:none;
  font-size:.78rem; font-weight:300;
  color:var(--text-dim);
  transition:all .25s;
  border-left:2px solid transparent;
  cursor:pointer;
}
.sidebar-lesson:hover { color:var(--text-mid); background:rgba(245,201,122,.04); }
.sidebar-lesson.active { color:var(--star-gold); border-left-color:var(--gold); background:rgba(245,201,122,.06); }
.sidebar-lesson.completed { color:var(--text-mid); }
.lesson-check { width:16px; height:16px; border-radius:50%; border:1px solid var(--rule-dark); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:.6rem; }
.sidebar-lesson.completed .lesson-check { background:var(--gold); border-color:var(--gold); color:var(--void); }
.sidebar-lesson.active .lesson-check { border-color:var(--star-gold); }

/* ── MAIN CONTENT ── */
.learn-main {
  margin-left:var(--sidebar-w);
  flex:1;
  min-height:calc(100vh - 60px);
}

/* ── VIDEO PLAYER ── */
.lesson-video-wrap {
  background:var(--void);
  position:relative;
  padding-bottom:56.25%;
  height:0;
}
.lesson-video-wrap iframe {
  position:absolute; top:0; left:0; width:100%; height:100%;
  border:none;
}
.video-placeholder {
  position:absolute; top:0; left:0; width:100%; height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:var(--void);
}
.video-placeholder-icon { font-family:'Cormorant Garamond',serif; font-size:4rem; color:var(--gold); opacity:.4; margin-bottom:1rem; }
.video-placeholder-text { font-size:.8rem; font-weight:300; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim); }

/* ── LESSON CONTENT ── */
.lesson-content { padding:3rem 4rem; max-width:860px; }
.lesson-eyebrow { font-size:.68rem; font-weight:400; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:.8rem; }
.lesson-title { font-family:'Cormorant Garamond',serif; font-size:clamp(1.8rem,3vw,2.8rem); font-weight:300; color:var(--ink); margin-bottom:1.2rem; }
.lesson-meta { display:flex; gap:1.5rem; margin-bottom:2.5rem; flex-wrap:wrap; }
.lesson-meta span { font-size:.72rem; font-weight:300; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-dim); display:flex; align-items:center; gap:.4rem; }
.lesson-body { font-size:1rem; font-weight:300; line-height:1.9; color:var(--ink-mid); }
.lesson-body p { margin-bottom:1.4rem; }
.lesson-body h3 { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:400; color:var(--ink); margin:2rem 0 .8rem; }

/* ── PRACTICE BOX ── */
.practice-box {
  background:var(--mist);
  border-left:3px solid var(--gold);
  padding:2rem 2.5rem;
  margin:2.5rem 0;
}
.practice-box-label { font-size:.65rem; font-weight:400; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:.6rem; }
.practice-box h4 { font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:400; color:var(--ink); margin-bottom:.8rem; }
.practice-box p { font-size:.92rem; font-weight:300; line-height:1.8; color:var(--ink-mid); }

/* ── QUOTE BOX ── */
.lesson-quote {
  border-left:2px solid var(--gold);
  padding:1.2rem 0 1.2rem 2rem;
  margin:2rem 0;
}
.lesson-quote p { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:300; font-style:italic; color:var(--ink); line-height:1.6; }
.lesson-quote cite { font-size:.68rem; font-weight:400; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-style:normal; display:block; margin-top:.8rem; }

/* ── LESSON NAV ── */
.lesson-nav {
  display:flex; justify-content:space-between; align-items:center;
  padding:2rem 4rem;
  border-top:1px solid var(--light-rule);
  margin-top:3rem;
  gap:1rem;
  flex-wrap:wrap;
}
.lesson-nav-btn {
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.9rem 1.8rem;
  font-family:'Jost',sans-serif; font-size:.72rem; font-weight:400;
  letter-spacing:.16em; text-transform:uppercase;
  text-decoration:none; cursor:pointer;
  transition:all .3s; border:none;
}
.lesson-nav-btn.prev { background:var(--mist); color:var(--ink); }
.lesson-nav-btn.prev:hover { background:var(--light-rule); }
.lesson-nav-btn.next { background:var(--gold); color:var(--void); }
.lesson-nav-btn.next:hover { background:var(--star-gold); }
.lesson-nav-btn.complete { background:var(--indigo); color:var(--star-gold); }

/* ── COURSE DASHBOARD ── */
.dashboard { padding:60px 0 0; min-height:100vh; background:var(--off-white); }
.dashboard-hero { background:var(--void); padding:4rem 5rem 3rem; }
.dashboard-hero .eyebrow { font-size:.72rem; font-weight:400; letter-spacing:.3em; text-transform:uppercase; color:var(--star-gold); display:block; margin-bottom:1rem; }
.dashboard-hero h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(2rem,4vw,3.2rem); font-weight:300; color:var(--text-bright); margin-bottom:2rem; }
.dashboard-courses { padding:2rem 5rem 3rem; display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; max-width:1200px; background:var(--void); }
.course-card {
  background:var(--void);
  border:1px solid var(--rule-dark);
  border-top:3px solid var(--gold);
  padding:0;
  text-decoration:none; color:inherit;
  transition:all .35s; display:block;
  position:relative; overflow:hidden;
}
.course-card::before {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse 120% 80% at 50% 120%, rgba(232,179,85,.1), transparent);
  opacity:0; transition:opacity .35s;
}
.course-card:hover { box-shadow:0 12px 50px rgba(0,0,0,.35); transform:translateY(-3px); border-color:rgba(245,201,122,.4); }
.course-card:hover::before { opacity:1; }
.course-card-thumb {
  height:140px;
  background:radial-gradient(ellipse 130% 100% at 50% 0%, #1c1636 0%, var(--void) 80%);
  display:flex; align-items:center; justify-content:center;
  border-bottom:1px solid var(--rule-dark);
  position:relative; overflow:hidden;
}
.course-card-thumb-num {
  font-family:'Cormorant Garamond',serif;
  font-size:5rem; font-weight:300;
  color:rgba(245,201,122,.12); line-height:1;
  position:absolute;
}
.course-card-thumb-icon {
  font-family:'Cormorant Garamond',serif;
  font-size:2rem; color:var(--gold); position:relative; z-index:1;
}
.course-card-body { padding:2rem; }
.course-card-eyebrow { font-size:.6rem; font-weight:400; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:.7rem; }
.course-card h3 { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:400; color:var(--text-bright); margin-bottom:.7rem; line-height:1.3; }
.course-card p { font-size:.85rem; font-weight:300; line-height:1.7; color:var(--text-mid); margin-bottom:1.5rem; }
.course-card-progress { margin-bottom:1.2rem; }
.course-card-progress-bar { height:3px; background:rgba(245,201,122,.12); border-radius:2px; }
.course-card-progress-fill { height:100%; background:var(--gold); border-radius:2px; transition:width .5s; }
.course-card-progress-label { font-size:.62rem; font-weight:300; color:var(--text-dim); margin-top:.4rem; display:block; }
.course-card-cta {
  display:inline-block;
  font-size:.68rem; font-weight:400; letter-spacing:.18em; text-transform:uppercase;
  color:var(--void); background:var(--gold);
  padding:.6rem 1.4rem; transition:background .3s;
}
.course-card:hover .course-card-cta { background:var(--star-gold); }

/* ── LOGIN PAGE ── */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--void); }
.login-box { background:var(--deep); border:1px solid var(--rule-dark); border-top:2px solid var(--gold); padding:3.5rem; width:100%; max-width:440px; }
.login-logo { text-align:center; margin-bottom:2.5rem; }
.login-logo-text { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:400; letter-spacing:.3em; text-transform:uppercase; color:var(--text-bright); }
.login-logo-text em { color:var(--star-gold); font-style:normal; }
.login-title { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:300; color:var(--text-bright); text-align:center; margin-bottom:.5rem; }
.login-sub { font-size:.85rem; font-weight:300; color:var(--text-dim); text-align:center; margin-bottom:2rem; }
.login-field { margin-bottom:1.2rem; }
.login-field label { font-size:.65rem; font-weight:400; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim); display:block; margin-bottom:.4rem; }
.login-field input {
  width:100%; padding:.9rem 1rem;
  font-family:'Jost',sans-serif; font-size:.9rem; font-weight:300;
  background:rgba(255,255,255,.05); border:1px solid var(--rule-dark);
  color:var(--text-bright); outline:none;
  transition:border-color .3s;
}
.login-field input:focus { border-color:rgba(245,201,122,.4); }
.login-btn {
  width:100%; padding:1rem;
  background:var(--gold); color:var(--void);
  font-family:'Jost',sans-serif; font-size:.74rem; font-weight:400;
  letter-spacing:.18em; text-transform:uppercase;
  border:none; cursor:pointer; transition:background .3s;
  margin-top:.5rem;
}
.login-btn:hover { background:var(--star-gold); }
.login-divider { text-align:center; margin:1.5rem 0; font-size:.72rem; font-weight:300; color:var(--text-dim); }
.login-back { text-align:center; margin-top:1.5rem; }
.login-back a { font-size:.72rem; font-weight:300; color:var(--text-dim); text-decoration:none; letter-spacing:.1em; }
.login-back a:hover { color:var(--star-gold); }
.login-msg { font-size:.82rem; font-weight:300; color:var(--star-gold); text-align:center; margin-top:1rem; display:none; }
.login-msg.error { color:#ff8080; }

/* ── EVENT PAGES ── */
.events-dashboard { padding:60px 0 0; min-height:100vh; }
.events-hero { background:var(--void); padding:4rem 5rem 3rem; border-bottom:1px solid var(--rule-dark); }
.events-grid { padding:3rem 5rem; display:grid; grid-template-columns:repeat(2,1fr); gap:2rem; max-width:1100px; }
.event-card {
  background:var(--white); border-top:2px solid var(--gold); padding:2.5rem;
  display:flex; flex-direction:column; gap:1rem;
}
.event-card-type { font-size:.62rem; font-weight:400; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.event-card h3 { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:400; color:var(--ink); }
.event-card-meta { font-size:.8rem; font-weight:300; color:var(--ink-dim); display:flex; gap:1rem; flex-wrap:wrap; }
.event-card p { font-size:.9rem; font-weight:300; line-height:1.8; color:var(--ink-mid); }
.event-card-actions { display:flex; gap:.8rem; margin-top:auto; flex-wrap:wrap; }
.event-btn-primary { background:var(--gold); color:var(--void); padding:.8rem 1.6rem; font-family:'Jost',sans-serif; font-size:.7rem; font-weight:400; letter-spacing:.16em; text-transform:uppercase; text-decoration:none; border:none; cursor:pointer; transition:background .3s; display:inline-block; }
.event-btn-primary:hover { background:var(--star-gold); }
.event-btn-ghost { border:1px solid var(--light-rule); color:var(--ink-mid); padding:.8rem 1.6rem; font-family:'Jost',sans-serif; font-size:.7rem; font-weight:300; letter-spacing:.16em; text-transform:uppercase; text-decoration:none; transition:all .3s; display:inline-block; }
.event-btn-ghost:hover { border-color:var(--gold); color:var(--ink); }
.event-badge { display:inline-block; background:var(--indigo); color:var(--star-gold); font-size:.58rem; font-weight:400; letter-spacing:.16em; text-transform:uppercase; padding:.25rem .7rem; }
.event-badge.live { background:rgba(76,175,130,.15); color:#4caf82; }
.event-badge.upcoming { background:rgba(245,201,122,.1); color:var(--star-gold); }
.event-badge.recorded { background:rgba(22,19,43,.06); color:var(--ink-dim); }

/* ── RECORDING LIBRARY ── */
.recording-grid { padding:2rem 5rem; display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; max-width:1200px; }
.recording-card { background:var(--white); border-top:2px solid var(--gold); overflow:hidden; cursor:pointer; transition:box-shadow .3s; }
.recording-card:hover { box-shadow:0 4px 24px rgba(22,19,43,.08); }
.recording-thumb { background:var(--void); aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; position:relative; }
.recording-thumb-icon { font-size:2.5rem; opacity:.3; }
.recording-thumb-duration { position:absolute; bottom:.5rem; right:.5rem; background:rgba(0,0,0,.7); color:#fff; font-size:.65rem; padding:.2rem .4rem; }
.recording-card-body { padding:1.5rem; }
.recording-card-type { font-size:.6rem; font-weight:400; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:.4rem; }
.recording-card-title { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:400; color:var(--ink); margin-bottom:.4rem; }
.recording-card-meta { font-size:.75rem; font-weight:300; color:var(--ink-dim); }

/* ── MOBILE ── */
.sidebar-toggle { display:none; background:var(--void); border:none; color:var(--star-gold); font-size:1.2rem; cursor:pointer; padding:.5rem; }

@media(max-width:960px) {
  .learn-sidebar { transform:translateX(-100%); transition:transform .3s; }
  .learn-sidebar.open { transform:translateX(0); }
  .learn-main { margin-left:0; }
  .sidebar-toggle { display:block; }
  .lesson-content { padding:2rem 1.5rem; }
  .lesson-nav { padding:1.5rem; }
  .dashboard-hero { padding:2.5rem 1.5rem 2rem; }
  .dashboard-courses { padding:2rem 1.5rem; grid-template-columns:1fr; }
  .events-hero { padding:2.5rem 1.5rem; }
  .events-grid { padding:2rem 1.5rem; grid-template-columns:1fr; }
  .recording-grid { padding:1.5rem; grid-template-columns:1fr 1fr; }
}
@media(max-width:640px) {
  .recording-grid { grid-template-columns:1fr; }
  .login-box { padding:2rem 1.5rem; margin:1rem; }
}

/* ── DASHBOARD MOBILE ── */
@media(max-width:768px) {
  .dashboard-hero { padding:2.5rem 1.5rem 2rem !important; }
  .dashboard-courses { padding:1.5rem !important; grid-template-columns:1fr !important; }
  .learn-nav-right a { display:none; }
  .learn-nav-right a:last-of-type { display:none; }
}
@media(max-width:640px) {
  [style*="grid-template-columns:repeat(3"] {
    grid-template-columns:1fr !important;
  }
  [style*="grid-template-columns:1fr 420px"] {
    grid-template-columns:1fr !important;
  }
  [style*="padding:4rem 8rem"] {
    padding:2rem 1.5rem !important;
  }
  [style*="padding:4rem 5rem"] {
    padding:2rem 1.5rem !important;
  }
  [style*="padding:3rem 5rem"] {
    padding:1.5rem !important;
  }
}

/* ── HAMBURGER + MOBILE NAV ── */
.learn-hamburger {
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  cursor:pointer;
  background:none;
  border:none;
  padding:.4rem;
  z-index:10000;
  flex-shrink:0;
}
.learn-hamburger span {
  display:block;
  width:22px;
  height:1.5px;
  background:var(--text-mid);
  border-radius:2px;
  transition:all .3s ease;
}
.learn-hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.learn-hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.learn-hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

.learn-mobile-nav {
  display:none;
  position:fixed;
  top:60px;
  left:0;
  right:0;
  bottom:0;
  background:rgba(10,8,18,.99);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  z-index:9999;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:0;
  padding:2rem 0 4rem;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.learn-mobile-nav.open {
  display:flex !important;
}
.learn-mobile-nav a {
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem;
  font-weight:300;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-mid);
  text-decoration:none;
  padding:.85rem 2rem;
  width:100%;
  text-align:center;
  border-bottom:1px solid rgba(245,201,122,.06);
  transition:color .25s;
}
.learn-mobile-nav a:hover,
.learn-mobile-nav a.active { color:var(--star-gold); }
.learn-mobile-nav a:first-child { border-top:1px solid rgba(245,201,122,.06); }
.learn-mobile-nav .mob-cta {
  color:var(--void) !important;
  background:var(--gold);
  margin-top:1.5rem;
  border:none !important;
  font-size:1rem !important;
  padding:1rem 3rem !important;
  letter-spacing:.2em !important;
  transition:background .3s !important;
}
.learn-mobile-nav .mob-cta:hover { background:var(--star-gold) !important; }
.learn-mobile-nav .mob-gold {
  color:var(--star-gold) !important;
  border:1px solid rgba(245,201,122,.25) !important;
  margin-top:.5rem;
}

@media(max-width:768px) {
  .learn-hamburger { display:flex; }
  .learn-nav-right a { display:none !important; }
  .learn-nav { padding:0 1.2rem; }
}
