/* ═══════════════════════════════════════
   PEACE UNIVERSITY — GLOBAL STYLESHEET
   ═══════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --ink:        #0d0d0d;
  --cream:      #f5f1eb;
  --gold:       #b89a5a;
  --gold-light: #d4b87a;
  --mist:       #e8e2d9;
  --stone:      #8a8279;
  --deep:       #1a1612;
  --white:      #faf8f5;
  --nav-h:      80px;
}

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

/* ── CURSOR ── */
.cursor {
  position:fixed; width:8px; height:8px;
  background:var(--gold); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .15s ease;
}
.cursor-ring {
  position:fixed; width:36px; height:36px;
  border:1px solid rgba(184,154,90,.5); border-radius:50%;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,opacity .3s;
}

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:28px 60px;
  transition:background .4s,padding .4s,border-color .4s;
}
nav.scrolled {
  background:rgba(245,241,235,.97);
  backdrop-filter:blur(14px);
  padding:16px 60px;
  border-bottom:1px solid rgba(184,154,90,.2);
}
.nav-logo {
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem; font-weight:600;
  color:var(--white); letter-spacing:.02em;
  text-decoration:none; transition:color .3s;
}
nav.scrolled .nav-logo { color:var(--ink); }
nav.light .nav-logo  { color:var(--ink); }

.nav-links { display:flex; gap:36px; list-style:none; }
.nav-links a {
  font-size:.75rem; font-weight:400;
  letter-spacing:.12em; text-transform:uppercase;
  color:rgba(255,255,255,.75); text-decoration:none;
  transition:color .3s; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-3px; left:0; right:0;
  height:1px; background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s ease;
}
.nav-links a:hover::after { transform:scaleX(1); }
nav.scrolled .nav-links a,
nav.light .nav-links a { color:var(--stone); }
nav.scrolled .nav-links a:hover,
nav.light .nav-links a:hover { color:var(--ink); }

.nav-cta {
  font-size:.72rem; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold);
  padding:10px 24px; text-decoration:none;
  transition:all .3s ease;
}
.nav-cta:hover { background:var(--gold); color:var(--deep); }

/* Mobile hamburger */
.nav-burger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.nav-burger span {
  display:block; width:24px; height:1px;
  background:var(--white); transition:all .3s;
}
nav.scrolled .nav-burger span,
nav.light .nav-burger span { background:var(--ink); }
.nav-burger.open span:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.nav-burger.open span:nth-child(2) { opacity:0; }
.nav-burger.open span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

.mobile-menu {
  display:none; position:fixed; inset:0; z-index:190;
  background:var(--deep); flex-direction:column;
  align-items:center; justify-content:center; gap:36px;
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
  font-family:'Cormorant Garamond',serif;
  font-size:2.5rem; font-weight:300;
  color:var(--white); text-decoration:none;
  transition:color .3s;
}
.mobile-menu a:hover { color:var(--gold); }

/* ── HERO (inner pages) ── */
.page-hero {
  padding: calc(var(--nav-h) + 80px) 60px 100px;
  background:var(--deep);
  position:relative; overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 60% at 70% 50%,rgba(184,154,90,.1) 0%,transparent 70%),
             linear-gradient(140deg,#0d0a06 0%,#1a1612 50%,#0d0d0d 100%);
}
.page-hero-grain {
  position:absolute; inset:0; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}
.page-hero-content { position:relative; z-index:2; max-width:800px; }
.page-breadcrumb {
  font-size:.65rem; letter-spacing:.25em; text-transform:uppercase;
  color:rgba(255,255,255,.35); margin-bottom:20px;
  display:flex; align-items:center; gap:10px;
}
.page-breadcrumb a { color:rgba(255,255,255,.35); text-decoration:none; transition:color .3s; }
.page-breadcrumb a:hover { color:var(--gold); }
.page-breadcrumb span { color:var(--gold); }
.page-eyebrow {
  font-size:.68rem; letter-spacing:.25em; text-transform:uppercase;
  color:var(--gold); display:flex; align-items:center; gap:14px;
  margin-bottom:20px;
}
.page-eyebrow::before { content:''; display:block; width:32px; height:1px; background:var(--gold); }
.page-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,6vw,5.5rem); font-weight:300;
  line-height:1; color:var(--white); margin-bottom:24px;
}
.page-title em { font-style:italic; color:var(--gold-light); }
.page-subtitle {
  font-size:1rem; font-weight:300;
  color:rgba(255,255,255,.5); line-height:1.8; max-width:520px;
}

/* ── MARQUEE ── */
.marquee-strip {
  background:var(--gold); padding:13px 0; overflow:hidden; white-space:nowrap;
}
.marquee-inner { display:inline-flex; animation:marqueeSlide 25s linear infinite; }
@keyframes marqueeSlide { to { transform:translateX(-50%); } }
.marquee-item {
  display:inline-flex; align-items:center; gap:28px;
  font-size:.68rem; font-weight:500; letter-spacing:.2em;
  text-transform:uppercase; color:var(--deep); padding:0 36px;
}
.marquee-dot { width:4px; height:4px; background:var(--deep); border-radius:50%; opacity:.5; }

/* ── SECTION LABELS ── */
.section-label {
  font-size:.65rem; font-weight:500; letter-spacing:.3em;
  text-transform:uppercase; color:var(--gold);
  display:flex; align-items:center; gap:14px; margin-bottom:20px;
}
.section-label::before { content:''; display:block; width:32px; height:1px; background:var(--gold); }

/* ── BUTTONS ── */
.btn-primary {
  font-size:.75rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--deep); background:var(--gold);
  padding:16px 40px; text-decoration:none;
  transition:all .3s; display:inline-block; position:relative; overflow:hidden;
}
.btn-primary::after {
  content:''; position:absolute; inset:0;
  background:var(--gold-light); transform:translateX(-101%);
  transition:transform .3s ease;
}
.btn-primary:hover::after { transform:translateX(0); }
.btn-primary span { position:relative; z-index:1; }

.btn-outline {
  font-size:.75rem; font-weight:500; letter-spacing:.14em;
  text-transform:uppercase; color:var(--gold);
  border:1px solid var(--gold); padding:14px 36px;
  text-decoration:none; transition:all .3s; display:inline-block;
}
.btn-outline:hover { background:var(--gold); color:var(--deep); }

.btn-ghost {
  font-size:.75rem; font-weight:400; letter-spacing:.14em;
  text-transform:uppercase; color:var(--stone);
  text-decoration:none; display:inline-flex; align-items:center; gap:10px;
  transition:color .3s;
}
.btn-ghost:hover { color:var(--gold); }
.btn-ghost-arrow {
  width:32px; height:1px; background:currentColor;
  position:relative; transition:width .3s;
}
.btn-ghost:hover .btn-ghost-arrow { width:50px; }
.btn-ghost-arrow::after {
  content:''; position:absolute; right:0; top:-3px;
  width:6px; height:6px;
  border-right:1px solid currentColor;
  border-top:1px solid currentColor;
  transform:rotate(45deg);
}

/* ── CARDS ── */
.card-grid { display:grid; gap:2px; }
.card-grid-2 { grid-template-columns:1fr 1fr; }
.card-grid-3 { grid-template-columns:repeat(3,1fr); }
.card-grid-4 { grid-template-columns:repeat(4,1fr); }

.card {
  background:var(--white); padding:50px 40px;
  position:relative; overflow:hidden;
  transition:transform .4s ease;
}
.card:hover { transform:translateY(-5px); }
.card::before {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:3px; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .4s;
}
.card:hover::before { transform:scaleX(1); }
.card-dark { background:var(--deep); }
.card-num {
  font-family:'Cormorant Garamond',serif;
  font-size:.9rem; color:var(--gold); margin-bottom:16px; display:block;
}
.card-title {
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem; font-weight:400; color:var(--ink);
  margin-bottom:14px; line-height:1.2;
}
.card-dark .card-title { color:var(--white); }
.card-body {
  font-size:.83rem; font-weight:300; color:var(--stone); line-height:1.75;
}
.card-dark .card-body { color:rgba(255,255,255,.45); }

/* ── CONTENT SECTIONS ── */
.section { padding:120px 60px; }
.section-sm { padding:80px 60px; }
.section-cream { background:var(--cream); }
.section-dark  { background:var(--deep); }
.section-white { background:var(--white); }

.section-header {
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:70px;
}
.section-heading {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem,4vw,3.5rem); font-weight:300; line-height:1.1;
}
.section-heading em { font-style:italic; color:var(--gold); }
.section-dark .section-heading { color:var(--white); }

/* ── TABLE LIST ROWS ── */
.list-rows { display:flex; flex-direction:column; gap:2px; }
.list-row {
  display:grid; align-items:center; gap:40px;
  padding:32px 40px; background:var(--cream);
  transition:background .3s; cursor:pointer; position:relative; overflow:hidden;
}
.list-row::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--gold);
  transform:scaleY(0); transition:transform .3s;
}
.list-row:hover::before { transform:scaleY(1); }
.list-row:hover { background:var(--mist); }

/* ── CTA BAND ── */
.cta-band {
  padding:120px 60px; background:var(--gold);
  text-align:center; position:relative; overflow:hidden;
}
.cta-band-bg {
  position:absolute; inset:0;
  background:repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(0,0,0,.04) 80px,rgba(0,0,0,.04) 81px);
}
.cta-band-content { position:relative; z-index:2; }
.cta-band-eyebrow {
  font-size:.65rem; letter-spacing:.3em; text-transform:uppercase;
  color:rgba(26,22,18,.55); display:block; margin-bottom:22px;
}
.cta-band-heading {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5vw,5rem); font-weight:300;
  color:var(--deep); line-height:1.05; margin-bottom:48px;
}
.cta-actions { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }
.cta-btn-dark {
  font-size:.73rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; background:var(--deep); color:var(--gold);
  padding:16px 44px; text-decoration:none; transition:background .3s;
}
.cta-btn-dark:hover { background:var(--ink); }
.cta-btn-outline-dark {
  font-size:.73rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; color:var(--deep);
  border:1px solid rgba(26,22,18,.35); padding:14px 38px;
  text-decoration:none; transition:background .3s;
}
.cta-btn-outline-dark:hover { background:rgba(26,22,18,.08); }

/* ── FOOTER ── */
footer {
  background:var(--ink); padding:80px 60px 48px;
}
.footer-top {
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:60px; padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:40px;
}
.footer-brand {
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem; font-weight:300;
  color:var(--white); display:block; margin-bottom:14px;
}
.footer-tagline {
  font-size:.78rem; font-weight:300;
  color:rgba(255,255,255,.32); line-height:1.75; margin-bottom:30px;
}
.footer-socials { display:flex; gap:10px; }
.footer-social {
  width:36px; height:36px;
  border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.4); text-decoration:none;
  font-size:.75rem; transition:all .3s;
}
.footer-social:hover { border-color:var(--gold); color:var(--gold); }
.footer-col-title {
  font-size:.62rem; letter-spacing:.25em;
  text-transform:uppercase; color:var(--gold);
  margin-bottom:24px; display:block;
}
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a {
  font-size:.82rem; font-weight:300;
  color:rgba(255,255,255,.42); text-decoration:none; transition:color .3s;
}
.footer-links a:hover { color:var(--gold-light); }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
}
.footer-copy, .footer-contact { font-size:.72rem; color:rgba(255,255,255,.2); }
.footer-contact a { color:var(--gold); text-decoration:none; }

/* ── REVEAL ANIMATIONS ── */
.reveal {
  opacity:0; transform:translateY(36px);
  transition:opacity .8s ease,transform .8s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }

/* ── FORMS ── */
.form-group { margin-bottom:28px; }
.form-label {
  display:block; font-size:.68rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--stone); margin-bottom:10px;
}
.form-input, .form-select, .form-textarea {
  width:100%; padding:14px 18px;
  background:transparent; border:1px solid var(--mist);
  font-family:'DM Sans',sans-serif; font-size:.9rem;
  color:var(--ink); transition:border-color .3s;
  outline:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color:var(--gold);
}
.form-textarea { height:140px; resize:vertical; }
.form-input::placeholder { color:rgba(138,130,121,.5); }

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  nav { padding:20px 32px; }
  nav.scrolled { padding:14px 32px; }
  .section, .cta-band { padding:90px 32px; }
  .section-sm { padding:60px 32px; }
  .page-hero { padding:calc(var(--nav-h)+60px) 32px 80px; }
  .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
}
@media(max-width:768px){
  nav { padding:18px 24px; }
  nav.scrolled { padding:14px 24px; }
  .nav-links, .nav-cta { display:none; }
  .nav-burger { display:flex; }
  .section { padding:70px 24px; }
  .section-sm { padding:50px 24px; }
  .page-hero { padding:calc(var(--nav-h)+40px) 24px 60px; }
  .card-grid-2, .card-grid-3, .card-grid-4 { grid-template-columns:1fr; }
  .section-header { flex-direction:column; align-items:flex-start; gap:20px; }
  .footer-top { grid-template-columns:1fr; gap:36px; }
  .footer-bottom { flex-direction:column; gap:10px; text-align:center; }
  .cta-band { padding:80px 24px; }
}

/* ═══════════════════════════════════════════════════
   NEW ADDITIONS v2 — Language, Search, Hero, Chat,
   Courses, Dashboard, Payment, RTL
   ═══════════════════════════════════════════════════ */

/* ── LANG SWITCHER ── */
.lang-wrap{position:relative;display:inline-flex;align-items:center}
.lang-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(255,255,255,.25);background:transparent;color:rgba(255,255,255,.8);font-size:.72rem;font-weight:500;letter-spacing:.1em;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
nav.scrolled .lang-btn,nav.light .lang-btn{border-color:var(--mist);color:var(--stone)}
.lang-btn:hover{border-color:var(--gold);color:var(--gold)}
.lang-globe{font-size:1rem;line-height:1}
.lang-code{font-size:.7rem;letter-spacing:.1em}
.lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--white);border:1px solid var(--mist);min-width:160px;display:none;z-index:300;box-shadow:0 8px 32px rgba(0,0,0,.12)}
.lang-dropdown.open{display:block}
.lang-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:.82rem;color:var(--stone);cursor:pointer;transition:background .2s;text-decoration:none;white-space:nowrap}
.lang-item:hover{background:var(--cream);color:var(--ink)}
.lang-item.active{color:var(--gold);font-weight:500}
.lang-item .lang-flag{font-size:1rem}

/* ── GLOBAL SEARCH ── */
.search-wrap{position:relative;flex:1;max-width:320px}
.search-wrap input{width:100%;padding:9px 14px 9px 38px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);font-family:'DM Sans',sans-serif;font-size:.82rem;color:var(--white);outline:none;transition:all .25s;backdrop-filter:blur(6px)}
nav.scrolled .search-wrap input,nav.light .search-wrap input{background:var(--cream);border-color:var(--mist);color:var(--ink)}
.search-wrap input:focus{border-color:var(--gold);background:rgba(255,255,255,.14)}
nav.scrolled .search-wrap input:focus,nav.light .search-wrap input:focus{background:var(--white)}
.search-wrap input::placeholder{color:rgba(255,255,255,.4)}
nav.scrolled .search-wrap input::placeholder{color:var(--stone)}
.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.4);font-size:.9rem;pointer-events:none}
nav.scrolled .search-icon,nav.light .search-icon{color:var(--stone)}
#searchResults{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--white);border:1px solid var(--mist);z-index:400;display:none;max-height:340px;overflow-y:auto}
#searchResults.open{display:block}
.sr-item{display:flex;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;transition:background .2s;border-bottom:1px solid var(--mist)}
.sr-item:last-child{border-bottom:none}
.sr-item:hover{background:var(--cream)}
.sr-badge{padding:2px 8px;font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;flex-shrink:0}
.sr-blue{background:#e6f1fb;color:#185fa5}.sr-purple{background:#eeedfe;color:#534ab7}
.sr-green{background:#eaf3de;color:#3b6d11}.sr-amber{background:#faeeda;color:#854f0b}
.sr-teal{background:#e1f5ee;color:#0f6e56}
.sr-name{flex:1;font-size:.83rem;color:var(--ink)}
.sr-price{font-size:.78rem;color:var(--stone);font-family:'Cormorant Garamond',serif;font-size:.9rem}
.sr-free{font-size:.65rem;color:#3b6d11;background:#eaf3de;padding:2px 8px;letter-spacing:.08em}
.sr-empty{padding:16px;font-size:.83rem;color:var(--stone);text-align:center}

/* ── NAV update for new elements ── */
.nav-right{display:flex;align-items:center;gap:14px}
@media(max-width:900px){.search-wrap{display:none}}

/* ── HERO SLIDESHOW ── */
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;background-size:cover;background-position:center}
.hero-slide.active{opacity:1}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(10,8,5,.85) 0%,rgba(10,8,5,.5) 60%,rgba(10,8,5,.2) 100%)}
.hero-dots{display:flex;gap:8px;position:absolute;bottom:40px;left:60px;z-index:3}
.hero-dot{width:28px;height:2px;background:rgba(255,255,255,.3);cursor:pointer;transition:all .3s}
.hero-dot.active{background:var(--gold);width:44px}
@media(max-width:768px){.hero-dots{left:24px;bottom:30px}}

/* ── PARTNER LOGOS SECTION ── */
.partners-strip{padding:36px 60px;background:var(--white);border-bottom:1px solid var(--mist)}
.partners-label-text{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--stone);text-align:center;margin-bottom:24px}
.partners-logos{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap}
.partner-logo{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.65;transition:opacity .3s;cursor:default}
.partner-logo:hover{opacity:1}
.partner-badge{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--white)}
.partner-name-text{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);font-family:'DM Sans',sans-serif}
.partner-courses{font-size:.65rem;color:var(--gold);font-family:'DM Sans',sans-serif}
@media(max-width:768px){.partners-strip{padding:28px 24px}.partners-logos{gap:28px}}

/* ── HOMEPAGE SEARCH SECTION ── */
.search-section{padding:60px 60px;background:var(--cream)}
.search-section-heading{font-family:'Cormorant Garamond',serif;font-size:2.2rem;font-weight:300;color:var(--ink);margin-bottom:24px;text-align:center}
.search-section-heading em{font-style:italic;color:var(--gold)}
.search-bar-big{display:flex;gap:0;max-width:700px;margin:0 auto 24px;border:1px solid var(--mist)}
.search-bar-big input{flex:1;padding:16px 20px;border:none;background:var(--white);font-family:'DM Sans',sans-serif;font-size:.95rem;color:var(--ink);outline:none}
.search-bar-big button{padding:16px 32px;background:var(--gold);border:none;font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--deep);cursor:pointer;transition:background .2s;white-space:nowrap}
.search-bar-big button:hover{background:var(--gold-light)}
.search-filters{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.sf-pill{padding:6px 20px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:1px solid var(--mist);background:var(--white);color:var(--stone);transition:all .2s}
.sf-pill:hover{background:var(--mist)}
.sf-pill.active{background:var(--gold);color:var(--deep);border-color:var(--gold)}
@media(max-width:768px){.search-section{padding:40px 24px}.search-bar-big{flex-direction:column}.search-bar-big button{width:100%}}

/* ── COURSE CARDS ── */
.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2px}
.course-card{background:var(--white);position:relative;overflow:hidden;transition:transform .35s ease;text-decoration:none;display:block}
.course-card:hover{transform:translateY(-5px)}
.course-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.course-card:hover::after{transform:scaleX(1)}
.course-card-img{height:180px;background:var(--mist);overflow:hidden;position:relative}
.course-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.course-card:hover .course-card-img img{transform:scale(1.06)}
.course-card-badge{position:absolute;top:14px;left:14px;padding:3px 10px;font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.course-card-partner{position:absolute;top:14px;right:14px;font-size:.6rem;letter-spacing:.06em;background:rgba(0,0,0,.6);color:var(--gold);padding:3px 8px}
.course-card-free{position:absolute;bottom:14px;right:14px;background:var(--gold);color:var(--deep);font-size:.6rem;font-weight:600;letter-spacing:.1em;padding:3px 10px}
.course-card-body{padding:24px 28px}
.course-card-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--ink);margin-bottom:8px;line-height:1.25}
.course-card-desc{font-size:.78rem;font-weight:300;color:var(--stone);line-height:1.65;margin-bottom:16px}
.course-card-meta{display:flex;gap:14px;align-items:center;justify-content:space-between}
.course-card-price{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--gold)}
.course-card-info{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--stone)}

/* ── FLOATING CHATBOT ── */
.chat-float{position:fixed;bottom:28px;right:28px;z-index:500}
.chat-toggle{width:54px;height:54px;border-radius:50%;background:var(--gold);border:none;cursor:pointer;font-size:1.3rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(184,154,90,.4);transition:all .25s;color:var(--deep)}
.chat-toggle:hover{background:var(--gold-light);transform:scale(1.08)}
.chat-panel{position:absolute;bottom:68px;right:0;width:320px;height:440px;background:var(--white);border:1px solid var(--mist);display:none;flex-direction:column;box-shadow:0 8px 40px rgba(0,0,0,.15)}
.chat-panel.open{display:flex}
.chat-header{background:var(--deep);padding:16px 20px;display:flex;align-items:center;gap:12px}
.chat-header-dot{width:36px;height:36px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.chat-header-title{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--white)}
.chat-header-sub{font-size:.65rem;color:rgba(255,255,255,.4);margin-top:1px}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chat-msg{display:flex}
.chat-bot{justify-content:flex-start}
.chat-user{justify-content:flex-end}
.chat-bubble{max-width:85%;padding:10px 14px;font-size:.82rem;line-height:1.55;font-family:'DM Sans',sans-serif}
.chat-bot .chat-bubble{background:var(--cream);color:var(--ink);border-radius:0 12px 12px 12px}
.chat-user .chat-bubble{background:var(--gold);color:var(--deep);border-radius:12px 0 12px 12px}
.chat-typing .chat-bubble{display:flex;gap:4px;align-items:center;padding:12px 16px}
.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--stone);animation:typingDot 1.2s ease infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}
.chat-input-row{display:flex;border-top:1px solid var(--mist)}
.chat-input-row input{flex:1;padding:12px 14px;border:none;font-family:'DM Sans',sans-serif;font-size:.83rem;color:var(--ink);outline:none;background:var(--white)}
.chat-input-row button{padding:12px 18px;background:var(--gold);border:none;cursor:pointer;font-size:.72rem;font-weight:500;letter-spacing:.1em;color:var(--deep);transition:background .2s}
.chat-input-row button:hover{background:var(--gold-light)}
@media(max-width:500px){.chat-panel{width:calc(100vw - 40px);right:-10px}}

/* ── STUDENT DASHBOARD ── */
.dash-wrap{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.dash-sidebar{background:var(--deep);padding:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.dash-main{background:#f0ece4;min-height:100vh}
.dash-topbar{background:var(--white);padding:20px 36px;border-bottom:1px solid var(--mist);display:flex;align-items:center;justify-content:space-between}
.dash-content{padding:32px 36px}
.dash-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}
.dash-stat{background:var(--white);padding:24px 28px;position:relative;overflow:hidden}
.dash-stat::after{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--gold)}
.dash-stat-label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);display:block;margin-bottom:8px}
.dash-stat-val{font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--ink);font-weight:300;line-height:1;display:block}
.dash-section-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;color:var(--ink);margin-bottom:20px}
.dash-section-title em{font-style:italic;color:var(--gold)}
.enrolled-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-bottom:32px}
.enrolled-card{background:var(--white);padding:0;overflow:hidden}
.enrolled-card-img{height:120px;background:var(--mist);overflow:hidden;position:relative}
.enrolled-card-img img{width:100%;height:100%;object-fit:cover}
.enrolled-card-body{padding:16px 20px}
.enrolled-card-title{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--ink);margin-bottom:10px}
.progress-bar{height:4px;background:var(--mist);margin-bottom:6px;overflow:hidden}
.progress-fill{height:100%;background:var(--gold);transition:width .6s ease}
.progress-text{font-size:.68rem;color:var(--stone);letter-spacing:.06em}
.purchase-table{width:100%;border-collapse:collapse;background:var(--white)}
.purchase-table th{background:var(--deep);color:rgba(255,255,255,.6);padding:11px 16px;text-align:left;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;font-weight:400}
.purchase-table td{padding:12px 16px;border-bottom:1px solid var(--mist);font-size:.83rem;color:var(--ink)}
.purchase-table tr:last-child td{border-bottom:none}
.offer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.offer-card{background:var(--deep);padding:24px;position:relative;overflow:hidden}
.offer-pct{font-family:'Cormorant Garamond',serif;font-size:3rem;color:var(--gold);display:block;line-height:1}
.offer-label{font-size:.78rem;font-weight:300;color:rgba(255,255,255,.55);margin-top:6px;display:block}
.offer-code{font-family:monospace;font-size:.75rem;color:var(--gold);border:1px solid rgba(184,154,90,.3);padding:4px 10px;margin-top:10px;display:inline-block;cursor:pointer}
@media(max-width:900px){.dash-wrap{grid-template-columns:1fr}.dash-sidebar{display:none}.dash-stat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.dash-stat-grid{grid-template-columns:1fr}.enrolled-grid{grid-template-columns:1fr}}

/* ── PAYMENT ── */
.pay-wrap{display:grid;grid-template-columns:1fr 1.2fr;min-height:calc(100vh - 80px)}
.pay-summary{background:var(--deep);padding:80px 60px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.pay-form-wrap{background:var(--white);padding:80px 60px;display:flex;flex-direction:column;justify-content:center}
.pay-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.pay-item-name{font-size:.88rem;font-weight:300;color:rgba(255,255,255,.7)}
.pay-item-price{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--gold)}
.pay-total-row{display:flex;justify-content:space-between;align-items:center;margin-top:20px}
.pay-total-label{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.pay-total-amount{font-family:'Cormorant Garamond',serif;font-size:2.5rem;color:var(--gold)}
.card-brand-icons{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}
.card-icon{padding:5px 12px;border:1px solid var(--mist);font-size:.7rem;font-weight:600;letter-spacing:.06em;color:var(--stone);background:var(--cream)}
.card-input-wrap{position:relative}
.card-input-wrap input{padding-right:48px}
.card-input-wrap .card-type{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.75rem;color:var(--stone)}
.pay-secure-badge{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--stone);margin-top:16px}
.pay-btn{width:100%;padding:17px;background:var(--gold);border:none;font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--deep);cursor:pointer;transition:background .2s;position:relative;overflow:hidden}
.pay-btn:hover{background:var(--gold-light)}
.phase2-note{background:var(--cream);padding:16px 20px;border-left:3px solid var(--gold);font-size:.78rem;color:var(--stone);margin-top:24px;line-height:1.6}
@media(max-width:900px){.pay-wrap{grid-template-columns:1fr}.pay-summary,.pay-form-wrap{padding:56px 32px}}
@media(max-width:600px){.pay-summary,.pay-form-wrap{padding:44px 20px}}

/* ── COURSE VIEWER ── */
.viewer-layout{display:grid;grid-template-columns:300px 1fr;min-height:calc(100vh - 80px)}
.viewer-sidebar{background:var(--deep);padding:0;overflow-y:auto}
.viewer-sidebar-title{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.08);font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--white)}
.module-list{list-style:none}
.module-item{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:background .2s}
.module-item:hover{background:rgba(255,255,255,.04)}
.module-item.active{background:rgba(184,154,90,.12);border-left:3px solid var(--gold)}
.module-item.locked{opacity:.45;cursor:not-allowed}
.module-icon{font-size:.9rem;width:18px;flex-shrink:0}
.module-title{font-size:.8rem;font-weight:300;color:rgba(255,255,255,.7);flex:1;line-height:1.3}
.module-meta{font-size:.65rem;color:rgba(255,255,255,.3)}
.viewer-main{background:var(--white);padding:0;display:flex;flex-direction:column}
.viewer-topbar{padding:16px 28px;border-bottom:1px solid var(--mist);display:flex;align-items:center;justify-content:space-between}
.viewer-content{flex:1;padding:32px 40px;overflow-y:auto}
.video-placeholder{background:var(--deep);width:100%;aspect-ratio:16/9;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:24px;max-width:760px;position:relative;overflow:hidden}
.video-thumb{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;opacity:.35}
.play-btn{width:64px;height:64px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:1.4rem;position:relative;z-index:1;cursor:pointer;transition:transform .2s}
.play-btn:hover{transform:scale(1.1)}
.pdf-frame{width:100%;height:560px;border:1px solid var(--mist);margin-bottom:24px}
.audio-player{width:100%;margin-bottom:24px;background:var(--cream);padding:20px;display:flex;align-items:center;gap:16px}
.locked-overlay{background:var(--cream);border:1px solid var(--mist);padding:48px;text-align:center;max-width:500px;margin:40px auto}
@media(max-width:768px){.viewer-layout{grid-template-columns:1fr}.viewer-sidebar{height:auto;max-height:300px}}

/* ── RTL SUPPORT ── */
body.rtl{font-family:'Tajawal','DM Sans',sans-serif}
body.rtl .nav-links{flex-direction:row-reverse}
body.rtl .nav-right{flex-direction:row-reverse}
body.rtl .section-label::before{display:none}
body.rtl .section-label::after{content:'';display:block;width:32px;height:1px;background:var(--gold);order:-1}
body.rtl .page-hero-content{direction:rtl;text-align:right}
body.rtl .hero-content{text-align:right}
body.rtl .hero-eyebrow{flex-direction:row-reverse}
body.rtl .hero-eyebrow::before{display:none}
body.rtl .about-text{text-align:right}
body.rtl .footer-top{direction:rtl}
body.rtl .course-card-body{text-align:right}
body.rtl .chat-panel{right:auto;left:0}
body.rtl .chat-bot{justify-content:flex-end}
body.rtl .chat-user{justify-content:flex-start}
body.rtl .chat-bot .chat-bubble{border-radius:12px 0 12px 12px}
body.rtl .chat-user .chat-bubble{border-radius:0 12px 12px 12px}
body.rtl .lang-dropdown{right:auto;left:0}
body.rtl .dash-sidebar{order:2}
body.rtl .pay-wrap{direction:rtl}
body.rtl input,body.rtl select,body.rtl textarea{direction:rtl;text-align:right}
body.rtl .form-label{text-align:right}
body.rtl .search-icon{left:auto;right:12px}
body.rtl .search-wrap input{padding:9px 38px 9px 14px}

/* ── COURSE CATALOG PAGE ── */
.catalog-layout{display:grid;grid-template-columns:240px 1fr;gap:0;padding-top:80px}
.catalog-filters{background:var(--cream);padding:32px 24px;border-right:1px solid var(--mist);position:sticky;top:80px;height:calc(100vh - 80px);overflow-y:auto}
.catalog-main{padding:32px 36px;background:var(--white)}
.filter-group{margin-bottom:28px}
.filter-group-title{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);margin-bottom:12px;display:block}
.filter-check{display:flex;align-items:center;gap:8px;margin-bottom:8px;cursor:pointer;font-size:.83rem;color:var(--stone)}
.filter-check input{accent-color:var(--gold);width:14px;height:14px}
.filter-check:hover{color:var(--ink)}
.catalog-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.catalog-count{font-size:.78rem;color:var(--stone)}
.sort-select{padding:8px 14px;border:1px solid var(--mist);background:var(--cream);font-family:'DM Sans',sans-serif;font-size:.8rem;color:var(--ink);outline:none}
.no-results{text-align:center;padding:60px 20px;color:var(--stone);font-size:.95rem}
@media(max-width:768px){.catalog-layout{grid-template-columns:1fr;padding-top:70px}.catalog-filters{position:static;height:auto}.catalog-main{padding:24px 20px}}
