@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700&family=Manrope:wght@600;700;800&display=swap');
:root{--ink:#17131f;--ink-soft:#2c2537;--muted:#706a7b;--line:#e5e0eb;--soft:#faf8fd;--surface:#fff;--purple:#6d28d9;--purple-dark:#4c1d95;--purple-light:#f2eaff;--violet:#a855f7;--yellow:#f5c451;--danger:#b42318;--success:#16715d;--shadow-sm:0 8px 22px rgba(44,37,55,.08);--shadow-md:0 18px 48px rgba(44,37,55,.13);--shadow-lg:0 30px 70px rgba(44,37,55,.18);--radius-sm:10px;--radius:16px;--radius-lg:24px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--surface);color:var(--ink);font-family:Inter,Arial,sans-serif;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}img{max-width:100%}.container{width:min(1220px,92vw);margin:auto}.muted{color:var(--muted)}.full{width:100%}.eyebrow,.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--purple-dark);font-size:12px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.eyebrow:before,.hero-eyebrow:before{content:"";width:26px;height:2px;background:var(--purple)}.icon{width:1.12em;height:1.12em;display:inline-block;vertical-align:-.18em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.icon-fill{fill:currentColor;stroke:none}.topbar{padding:9px 16px;background:linear-gradient(90deg,var(--ink),#30223d);color:#fff;text-align:center;font-size:13px;font-weight:600}.site-header{position:sticky;top:0;z-index:30;border-bottom:1px solid rgba(229,224,235,.86);background:rgba(255,255,255,.94);backdrop-filter:blur(18px);transition:box-shadow .25s ease}.site-header.scrolled{box-shadow:0 10px 30px rgba(44,37,55,.08)}.nav{display:flex;align-items:center;gap:18px;min-height:74px}.logo{display:flex;flex-shrink:0}.logo img{display:block;width:214px}.nav-category{font-size:14px;font-weight:700}.nav-category:hover,.nav-links a:hover{color:var(--purple)}.nav-search{display:flex;overflow:hidden;flex:1;border:1px solid #aaa4b1;border-radius:999px;background:#fff;transition:.2s}.nav-search:focus-within{border-color:var(--purple);box-shadow:0 0 0 4px rgba(109,40,217,.12)}.nav-search input{width:100%;border:0;outline:0;padding:12px 16px;background:transparent}.nav-search button{display:grid;place-items:center;border:0;background:transparent;padding:0 17px;color:var(--ink-soft)}.nav-links{display:flex;align-items:center;gap:16px;font-size:14px;font-weight:700}.nav-toggle{display:none;border:0;background:transparent;padding:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--ink);border-radius:9px;background:#fff;color:var(--ink);font-weight:800;padding:11px 17px;transition:transform .2s,background .2s,border-color .2s,box-shadow .2s}.btn:hover{transform:translateY(-2px);background:#f8f6fb;box-shadow:var(--shadow-sm)}.btn-primary{border-color:transparent;background:linear-gradient(135deg,var(--purple),var(--purple-dark));color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#7c35e6,#5420a1);box-shadow:0 10px 22px rgba(109,40,217,.26)}.btn-small{padding:7px 10px;border-radius:7px;font-size:13px}.btn-danger{border-color:var(--danger);background:var(--danger);color:#fff}.hero{position:relative;overflow:hidden;min-height:500px;background:linear-gradient(120deg,#faf9fc 0%,#f8f5ff 49%,#eadcff 100%)}.hero:before,.hero:after{content:"";position:absolute;border-radius:50%;opacity:.65}.hero:before{width:380px;height:380px;right:-85px;top:-125px;background:rgba(168,85,247,.18)}.hero:after{width:280px;height:280px;left:-85px;bottom:-155px;background:rgba(109,40,217,.12)}.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:42px;min-height:500px}.hero-copy{padding:52px 0}.hero h1,.section h2,.page-intro h1,.auth-card h1,.course-title-xl{font-family:Manrope,Inter,sans-serif;letter-spacing:-.045em}.hero h1{max-width:690px;margin:16px 0 18px;font-size:clamp(43px,5vw,70px);line-height:1.02}.hero p{max-width:650px;margin:0 0 27px;color:#453d51;font-size:19px;line-height:1.65}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.hero-art{position:relative;display:grid;place-items:center;min-height:390px;animation:floatArt 6s ease-in-out infinite}.hero-art:before{content:"";position:absolute;width:370px;height:370px;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.84),rgba(255,255,255,.18));box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}.hero-illustration{position:relative;width:min(470px,100%);filter:drop-shadow(0 24px 20px rgba(65,36,111,.16))}.hero-float-card{position:absolute;display:flex;align-items:center;gap:10px;padding:13px 15px;border:1px solid rgba(255,255,255,.82);border-radius:14px;background:rgba(255,255,255,.82);box-shadow:var(--shadow-sm);font-size:13px;font-weight:800;backdrop-filter:blur(12px)}.hero-float-card svg{color:var(--purple)}.card-one{top:52px;right:0;animation:floatMini 4.5s ease-in-out infinite}.card-two{bottom:42px;left:0;animation:floatMini 4.5s ease-in-out -1.5s infinite}.section{padding:76px 0}.section-soft{background:var(--soft)}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:26px}.section h2{margin:0 0 8px;font-size:clamp(29px,3vw,38px);line-height:1.12}.section-lead{margin:0;color:var(--muted);line-height:1.65}.text-link{display:inline-flex;align-items:center;gap:7px;color:var(--purple);font-size:14px;font-weight:800}.text-link:hover{text-decoration:underline}.grid{display:grid;gap:20px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.course-card{display:flex;overflow:hidden;flex-direction:column;border:1px solid var(--line);border-radius:var(--radius);background:#fff;transition:transform .25s,box-shadow .25s,border-color .25s}.course-card:hover{transform:translateY(-7px);border-color:#d5c2f6;box-shadow:var(--shadow-md)}.course-media{position:relative;display:grid;overflow:hidden;place-items:center;aspect-ratio:16/9;background:#f3f1f6}.course-media img{display:block;width:100%;height:100%;object-fit:contain;transition:transform .35s}.course-card:hover .course-media img{transform:scale(1.035)}.course-content{display:flex;flex:1;flex-direction:column;padding:14px}.course-title{font-family:Manrope,Inter,sans-serif;font-size:16px;font-weight:800;line-height:1.35}.course-instructor{margin-top:8px;color:var(--muted);font-size:13px}.rating{display:flex;align-items:center;gap:5px;margin-top:10px;color:#a35e00;font-size:13px;font-weight:800}.rating .icon{width:15px;height:15px;fill:#d07b00;stroke:#d07b00}.badge{align-self:flex-start;margin-top:9px;border-radius:999px;background:#fff0ba;color:#714800;padding:6px 10px;font-size:12px;font-weight:800}.price{display:flex;align-items:center;gap:8px;margin-top:auto;padding-top:20px}.price strong{font-size:19px}.price del{color:var(--muted);font-size:13px}.categories{grid-template-columns:repeat(6,minmax(0,1fr))}.category{display:flex;flex-direction:column;min-height:150px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:20px;font-weight:800;transition:.23s}.category small{display:block;margin-top:7px;color:var(--muted);font-size:12px;font-weight:500;line-height:1.5}.category-icon{display:grid;place-items:center;width:47px;height:47px;margin-bottom:17px;border-radius:13px;background:var(--purple-light);color:var(--purple);transition:.23s}.category-icon .icon{width:24px;height:24px}.category:hover{transform:translateY(-5px);border-color:#d5c2f6;box-shadow:var(--shadow-sm)}.category:hover .category-icon{transform:rotate(-6deg) scale(1.07);background:var(--purple);color:#fff}.promo{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:linear-gradient(120deg,var(--ink),#342043);color:#fff;padding:42px}.promo:after{content:"";position:absolute;width:260px;height:260px;right:-70px;top:-120px;border-radius:50%;background:rgba(168,85,247,.23)}.promo-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:24px}.promo p{margin-bottom:0;color:#ded8e8}.footer{padding:46px 0 19px;background:var(--ink);color:#fff}.footer-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:30px}.footer h3{margin-top:0;font-family:Manrope;font-size:15px}.footer p,.footer a{color:#cbc4d4;font-size:14px;line-height:1.7}.footer a{display:block;margin:7px 0}.footer a:hover{color:#fff}.footer-bottom{margin-top:29px;border-top:1px solid #443a4f;padding-top:17px;color:#aaa2b3;font-size:13px}.page-intro{margin-bottom:28px}.page-intro h1{margin:9px 0 8px;font-size:48px}.catalog-layout{display:grid;grid-template-columns:245px 1fr;gap:30px}.filters{height:max-content;border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:18px}.filters h3{margin:0 0 14px;font-family:Manrope}.filters label{display:flex;align-items:center;gap:9px;margin:11px 0;font-size:14px}.filters input{accent-color:var(--purple)}.catalog-toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:18px}.catalog-toolbar input,.catalog-toolbar select,.field input,.field select,.field textarea{width:100%;border:1px solid #aaa4b1;border-radius:8px;background:#fff;padding:12px;transition:.2s}.catalog-toolbar input:focus,.catalog-toolbar select:focus,.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--purple);box-shadow:0 0 0 4px rgba(109,40,217,.12)}.catalog-toolbar input{min-width:280px}.catalog-toolbar select{max-width:190px}.auth-shell{display:grid;min-height:calc(100vh - 112px);place-items:center;padding:48px 16px;background:linear-gradient(135deg,#fbfaff,#f2eaff)}.auth-card{width:min(510px,100%);border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;padding:30px;box-shadow:var(--shadow-md)}.auth-card h1{margin:11px 0 5px;font-size:34px}.auth-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:var(--purple-light);color:var(--purple)}.auth-icon .icon{width:25px;height:25px}.field{display:grid;gap:7px;margin-bottom:15px}.field label{font-size:14px;font-weight:800}.field textarea{min-height:110px;resize:vertical}.form-message{display:none;margin:14px 0;border-radius:8px;padding:10px 12px}.form-message.show{display:block}.form-message.error{background:#fce8e6;color:#8a1f11}.form-message.success{background:#dff4eb;color:#175548}.social-login{display:grid;gap:10px}.divider{display:flex;align-items:center;gap:10px;margin:18px 0;color:var(--muted);font-size:13px}.divider:before,.divider:after{content:"";height:1px;flex:1;background:var(--line)}.auth-note{margin-top:18px;color:var(--muted);font-size:12px;line-height:1.7}.auth-switch{margin-bottom:0;text-align:center;font-size:14px}.auth-switch a{color:var(--purple);font-weight:800}.course-hero{background:linear-gradient(125deg,#211a2a,#372145);color:#fff;padding:54px 0}.course-hero-grid{display:grid;grid-template-columns:1fr 390px;gap:42px}.course-title-xl{max-width:850px;margin:12px 0;font-size:clamp(34px,4vw,52px);line-height:1.08}.course-subtitle{max-width:800px;color:#eee5f7;font-size:17px;line-height:1.65}.course-meta{display:flex;flex-wrap:wrap;gap:14px;margin-top:18px;color:#efe8f8;font-size:14px}.purchase-card{overflow:hidden;border-radius:var(--radius);background:#fff;color:var(--ink);box-shadow:var(--shadow-lg)}.purchase-media{display:grid;overflow:hidden;place-items:center;aspect-ratio:16/9;background:#f4f1f7}.purchase-media img,.purchase-media video{width:100%;height:100%;object-fit:contain}.purchase-card-body{padding:16px}.purchase-card .price strong{font-size:27px}.purchase-card .btn{width:100%;margin-top:11px}.purchase-note{color:var(--muted);font-size:12px;line-height:1.5}.course-main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:34px;padding:44px 0}.course-main-content{min-width:0}.course-main h2{margin:0 0 18px;font-family:Manrope;font-size:30px;letter-spacing:-.035em}.learn-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;border:1px solid var(--line);border-radius:var(--radius);padding:22px;font-size:14px}.learn-item{display:flex;gap:10px;line-height:1.5}.learn-item .icon{flex:none;margin-top:2px;color:var(--success)}.course-section-block{margin-top:38px}.curriculum-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:13px}.curriculum-summary{color:var(--muted);font-size:14px}.curriculum-actions{border:0;background:transparent;color:var(--purple);font-weight:800}.accordion{border:1px solid #d9d5df;border-bottom:0}.accordion-item{border-bottom:1px solid #d9d5df}.accordion-head{display:flex;align-items:center;justify-content:space-between;width:100%;gap:14px;border:0;background:#f7f7f9;padding:18px 20px;text-align:left;font-weight:800}.accordion-head:hover{background:#f1eff5}.accordion-title{display:flex;align-items:center;gap:13px}.accordion-title .icon{transition:transform .2s}.accordion-item.open .accordion-title .icon{transform:rotate(180deg)}.accordion-body{display:none;background:#fff;padding:8px 20px}.accordion-item.open .accordion-body{display:block}.lesson{display:flex;justify-content:space-between;gap:12px;padding:10px 0;color:#4b4456;font-size:14px}.show-more{width:100%;margin-top:18px;border:1px solid var(--purple);border-radius:8px;background:#fff;color:var(--purple);padding:13px;font-weight:800}.related-list{display:grid;gap:14px}.related-card{display:grid;grid-template-columns:74px 1fr 135px;gap:15px;align-items:center;border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;transition:.2s}.related-card:hover{border-color:#d5c2f6;box-shadow:var(--shadow-sm)}.related-thumb{display:grid;overflow:hidden;place-items:center;width:74px;height:74px;border-radius:10px;background:#f3f1f6}.related-thumb img{width:100%;height:100%;object-fit:contain}.related-title{font-family:Manrope;font-weight:800;line-height:1.35}.related-meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px;color:#5d5568;font-size:12px}.meta-pill{border-radius:6px;background:#f0edf5;padding:5px 7px}.related-price{border-left:1px solid var(--line);padding-left:16px}.related-price strong{display:block}.related-price del{color:var(--muted);font-size:13px}.sidebar-note{height:max-content;border:1px solid var(--line);border-radius:var(--radius);background:#faf9fc;padding:18px}.sidebar-note h3{font-family:Manrope}.sidebar-note p{color:var(--muted);font-size:14px;line-height:1.6}.notice{border-left:4px solid var(--purple);border-radius:8px;background:#f8f3ff;padding:14px 16px;line-height:1.55}.loading-card,.empty{border:1px dashed var(--line);border-radius:10px;padding:25px;color:var(--muted);text-align:center}.chat-launch{position:fixed;right:24px;bottom:24px;z-index:50;display:grid;place-items:center;width:62px;height:62px;border:0;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--purple-dark));color:#fff;box-shadow:0 16px 32px rgba(109,40,217,.32);transition:.22s}.chat-launch:before{content:"";position:absolute;inset:-7px;border:1px solid rgba(109,40,217,.35);border-radius:50%;animation:pulseRing 2.5s ease-out infinite}.chat-launch:hover{transform:translateY(-5px) scale(1.04)}.chat-launch .icon{width:26px;height:26px}.chat-panel{display:none;position:fixed;right:24px;bottom:100px;z-index:55;overflow:hidden;width:min(390px,calc(100vw - 30px));height:min(550px,calc(100vh - 130px));border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-lg);grid-template-rows:auto 1fr auto}.chat-panel.open{display:grid;animation:chatOpen .25s ease both}.chat-head{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(120deg,var(--ink),#30223d);color:#fff;padding:15px}.chat-subtitle{margin-top:4px;color:#cec7d6;font-size:12px}.icon-button{display:grid;place-items:center;border:0;border-radius:6px;background:transparent;color:inherit;padding:5px}.chat-messages{display:flex;overflow:auto;flex-direction:column;gap:10px;background:#f8f6fb;padding:14px}.chat-msg{max-width:86%;border-radius:11px;padding:10px 12px;font-size:14px;line-height:1.45}.chat-msg.bot,.chat-msg.agent{align-self:flex-start;border:1px solid var(--line);background:#fff}.chat-msg.agent{border-color:#c9b2ef;background:#faf7ff}.chat-msg.visitor{align-self:flex-end;background:#e9d9ff}.chat-form{display:flex;border-top:1px solid var(--line)}.chat-form input{flex:1;border:0;outline:0;padding:13px}.chat-form button{border:0;background:var(--purple);color:#fff;padding:0 17px;font-weight:800}.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}.reveal.is-visible{opacity:1;transform:translateY(0)}@keyframes floatArt{50%{transform:translateY(-12px)}}@keyframes floatMini{50%{transform:translateY(-9px)}}@keyframes pulseRing{0%{opacity:.8;transform:scale(.92)}75%,100%{opacity:0;transform:scale(1.24)}}@keyframes chatOpen{from{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:scale(1)}}
@media(max-width:1050px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.categories{grid-template-columns:repeat(3,minmax(0,1fr))}.hero-inner{grid-template-columns:1fr 1fr}.course-hero-grid{grid-template-columns:1fr}.purchase-card{max-width:500px}.course-main{grid-template-columns:1fr}.sidebar-note{display:none}}
@media(max-width:820px){.nav{min-height:68px;gap:12px;flex-wrap:wrap;padding:10px 0}.logo img{width:188px}.nav-category{display:none}.nav-toggle{display:grid;place-items:center;margin-left:auto}.nav-search{order:3;flex-basis:100%}.nav-links{display:none;position:absolute;top:68px;right:4vw;left:4vw;z-index:40;align-items:stretch;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:12px;background:#fff;padding:8px;box-shadow:var(--shadow-md)}.nav-links.open{display:flex}.nav-links a{padding:11px 12px}.hero-inner{grid-template-columns:1fr;gap:0}.hero-copy{padding:65px 0 28px}.hero-art{min-height:310px;margin-bottom:25px}.catalog-layout{grid-template-columns:1fr}.filters{display:none}.footer-grid{grid-template-columns:1fr 1fr}.related-card{grid-template-columns:64px 1fr}.related-price{grid-column:2;border-left:0;padding-left:0}.course-main{padding-top:32px}}
@media(max-width:590px){.container{width:min(94vw,560px)}.logo img{width:164px}.hero h1{font-size:43px}.hero p{font-size:17px}.hero-art{min-height:250px}.hero-art:before{width:245px;height:245px}.hero-float-card{padding:10px 11px;font-size:11px}.card-one{top:25px}.card-two{bottom:25px}.section{padding:58px 0}.section-heading{align-items:start;flex-direction:column}.grid-4,.grid-3{grid-template-columns:1fr}.categories{grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.category{padding:17px 12px}.catalog-toolbar{display:grid}.catalog-toolbar input,.catalog-toolbar select{min-width:0;max-width:none}.footer-grid{grid-template-columns:1fr}.promo{padding:28px}.learn-list{grid-template-columns:1fr}.course-title-xl{font-size:35px}.course-hero{padding:36px 0}.curriculum-top{align-items:start;flex-direction:column}.accordion-head{align-items:start;padding:15px}.lesson{font-size:13px}.related-card{padding:11px}.chat-launch{right:16px;bottom:16px}.chat-panel{right:15px;bottom:88px}.auth-card{padding:22px}.page-intro h1{font-size:39px}}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}}

/* =========================================================
   Account profile circle, dropdown, and burger drawer
   ========================================================= */

.profile-menu-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.profile-trigger,
.account-burger,
.icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.profile-trigger {
  padding: 0;
  border-radius: 999px;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease;
}

.profile-trigger:hover {
  transform: translateY(-1px);
}

.profile-trigger:focus-visible,
.account-burger:focus-visible,
.icon-button:focus-visible {
  outline: 3px solid rgba(109, 40, 217, 0.25);
  outline-offset: 3px;
}

.profile-avatar {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      #6d28d9,
      #9333ea
    );
  color: #ffffff;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.04em;
  box-shadow:
    0 8px 20px
    rgba(109, 40, 217, 0.22);
}

.profile-avatar-large {
  width: 54px;
  height: 54px;
  font-size: 17px;
}

.profile-dropdown {
  position: absolute;
  top: calc(100% + 14px);
  right: 0;
  z-index: 1000;
  width: min(310px, calc(100vw - 28px));
  overflow: hidden;
  border: 1px solid #e7e2ef;
  border-radius: 18px;
  background: #ffffff;
  box-shadow:
    0 20px 50px
    rgba(35, 23, 62, 0.16);
  animation:
    accountMenuIn 170ms ease both;
}

.profile-dropdown-head {
  display: flex;
  gap: 13px;
  align-items: center;
  padding: 18px;
  background:
    linear-gradient(
      135deg,
      #faf7ff,
      #ffffff
    );
  border-bottom: 1px solid #ece8f2;
}

.profile-dropdown-user {
  min-width: 0;
}

.profile-dropdown-user strong,
.drawer-user strong {
  display: block;
  overflow: hidden;
  color: #171320;
  font-size: 15px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-dropdown-user small,
.drawer-user small {
  display: block;
  overflow: hidden;
  margin-top: 4px;
  color: #766d84;
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-dropdown-links {
  display: grid;
  padding: 8px;
}

.profile-dropdown-links a,
.profile-dropdown-links button,
.account-drawer-links a,
.account-drawer-links button {
  display: flex;
  width: 100%;
  gap: 11px;
  align-items: center;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: #272033;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  text-align: left;
  text-decoration: none;
  transition:
    background 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.profile-dropdown-links a,
.profile-dropdown-links button {
  padding: 12px;
}

.profile-dropdown-links a:hover,
.profile-dropdown-links button:hover,
.account-drawer-links a:hover,
.account-drawer-links button:hover {
  background: #f4efff;
  color: #6d28d9;
  transform: translateX(2px);
}

.profile-dropdown-links .icon,
.account-drawer-links .icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* =========================================================
   Left burger button
   ========================================================= */

.account-burger {
  width: 42px;
  height: 42px;
  flex-shrink: 0;
  border: 1px solid #e5dfed;
  border-radius: 12px;
  color: #30263d;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.account-burger:hover {
  border-color: #d8c9f7;
  background: #f6f1ff;
  color: #6d28d9;
  transform: translateY(-1px);
}

.account-burger .icon,
.icon-button .icon {
  width: 21px;
  height: 21px;
}

/* =========================================================
   Left account drawer
   ========================================================= */

.account-drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 1190;
  background:
    rgba(20, 14, 29, 0.42);
  backdrop-filter:
    blur(3px);
}

.account-drawer {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1200;
  width: min(350px, 88vw);
  height: 100vh;
  overflow-y: auto;
  border-right: 1px solid #ece6f4;
  background: #ffffff;
  box-shadow:
    20px 0 60px
    rgba(24, 15, 42, 0.18);
  transform: translateX(-105%);
  transition:
    transform 240ms ease;
}

.account-drawer.open {
  transform: translateX(0);
}

.account-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 19px 20px;
  border-bottom: 1px solid #eee8f4;
}

.account-drawer-head strong {
  color: #20172d;
  font-size: 17px;
}

.icon-button {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  color: #4c4357;
  transition:
    background 160ms ease,
    color 160ms ease;
}

.icon-button:hover {
  background: #f5f0ff;
  color: #6d28d9;
}

.drawer-user {
  display: flex;
  gap: 13px;
  align-items: center;
  margin: 18px;
  padding: 14px;
  border: 1px solid #ebe4f6;
  border-radius: 15px;
  background:
    linear-gradient(
      135deg,
      #f8f4ff,
      #ffffff
    );
}

.drawer-user > div:last-child {
  min-width: 0;
}

.account-drawer-links {
  display: grid;
  gap: 4px;
  padding: 0 14px 22px;
}

.account-drawer-links a,
.account-drawer-links button {
  padding: 14px;
}

body.drawer-open {
  overflow: hidden;
}

@keyframes accountMenuIn {
  from {
    opacity: 0;
    transform:
      translateY(-7px)
      scale(0.985);
  }

  to {
    opacity: 1;
    transform:
      translateY(0)
      scale(1);
  }
}

/* =========================================================
   Header account responsive behavior
   ========================================================= */

@media (max-width: 980px) {
  .account-burger {
    order: -1;
  }

  .profile-dropdown {
    right: -4px;
  }
}

@media (max-width: 680px) {
  .profile-avatar {
    width: 40px;
    height: 40px;
    font-size: 14px;
  }

  .profile-avatar-large {
    width: 52px;
    height: 52px;
    font-size: 17px;
  }

  .account-burger {
    width: 40px;
    height: 40px;
  }
}
/* =========================================================
   Udemy-inspired course details upgrade
   ========================================================= */

.course-hero-copy {
  max-width: 860px;
}

.course-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  color: #d8c7ef;
  font-size: 13px;
  font-weight: 800;
}

.course-breadcrumb a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.course-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.course-badge {
  display: inline-flex;
  align-items: center;
  background: #f5c451;
  color: #33250a;
  padding: 5px 8px;
  font-size: 12px;
  font-weight: 800;
}

.course-meta-primary {
  margin-top: 15px;
}

.course-rating {
  color: #f5c451;
  font-weight: 800;
}

.course-rating .icon {
  fill: currentColor;
  stroke: currentColor;
}

.course-details-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  grid-template-areas: "main purchase";
  gap: 42px;
  align-items: start;
  padding: 42px 0 76px;
}

.course-details-layout .course-main-content {
  grid-area: main;
}

.purchase-card-wrap {
  position: relative;
  z-index: 4;
  grid-area: purchase;
  margin-top: -300px;
}

.purchase-card-wrap .purchase-card {
  position: sticky;
  top: 92px;
  border: 1px solid var(--line);
  border-radius: 0;
}

.checkout-price-row {
  padding-top: 0;
}

.discount-label {
  margin-top: 7px;
  color: var(--success);
  font-size: 13px;
  font-weight: 800;
}

.purchase-card-body h3 {
  margin: 20px 0 12px;
  font-family: Manrope, Inter, sans-serif;
  font-size: 16px;
}

.course-includes {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
  color: #51495b;
  font-size: 13px;
  line-height: 1.45;
}

.course-includes li {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.course-includes .icon {
  flex: none;
  margin-top: 2px;
  color: var(--success);
}

.coupon-box {
  margin-top: 17px;
  border-top: 1px solid var(--line);
  padding-top: 15px;
}

.coupon-box label {
  display: block;
  margin-bottom: 7px;
  font-size: 13px;
  font-weight: 800;
}

.coupon-row {
  display: flex;
  gap: 7px;
}

.coupon-row input {
  min-width: 0;
  flex: 1;
  border: 1px solid #aaa4b1;
  border-radius: 7px;
  padding: 9px 10px;
}

.coupon-message {
  min-height: 18px;
  margin-top: 7px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.coupon-message.success {
  color: var(--success);
  font-weight: 800;
}

.coupon-message.error {
  color: var(--danger);
  font-weight: 800;
}

.course-outline-box {
  border: 1px solid var(--line);
  padding: 22px;
}

.course-outline-box h2 {
  margin-bottom: 17px;
}

.course-outline-box .learn-list {
  border: 0;
  padding: 0;
}

.course-topics {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.course-topic {
  border: 1px solid var(--purple);
  color: var(--purple-dark);
  padding: 7px 10px;
  font-size: 13px;
  font-weight: 800;
}

.course-topic:hover {
  background: var(--purple-light);
}

.course-list {
  margin: 0;
  padding-left: 20px;
  color: #51495b;
  line-height: 1.8;
}

.course-description {
  color: #51495b;
  line-height: 1.75;
}

.course-description p {
  margin: 0 0 14px;
}

.lesson-title {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.lesson-actions {
  display: inline-flex;
  gap: 13px;
  align-items: center;
  flex-shrink: 0;
}

.lesson-preview {
  border: 0;
  background: transparent;
  color: var(--purple);
  padding: 0;
  font-weight: 800;
  text-decoration: underline;
}

.instructor-card {
  display: flex;
  gap: 17px;
  border: 1px solid var(--line);
  padding: 18px;
}

.instructor-card h3,
.instructor-card p {
  margin: 0 0 8px;
}

.instructor-card p {
  color: #51495b;
  line-height: 1.65;
}

.instructor-avatar {
  display: grid;
  width: 78px;
  height: 78px;
  flex: none;
  overflow: hidden;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--purple), var(--violet));
  color: #ffffff;
  font-size: 22px;
  font-weight: 800;
}

.instructor-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.modal-open {
  overflow: hidden;
}

.course-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  place-items: center;
  background: rgba(23, 19, 31, 0.62);
  padding: 18px;
  backdrop-filter: blur(4px);
}

.course-modal {
  position: relative;
  overflow: auto;
  width: min(780px, 96vw);
  max-height: 92vh;
  border-radius: 14px;
  background: #ffffff;
  padding: 24px;
  box-shadow: var(--shadow-lg);
}

.course-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  display: grid;
  width: 36px;
  height: 36px;
  place-items: center;
  border: 0;
  border-radius: 50%;
  background: #f0edf5;
  color: var(--ink);
  font-size: 25px;
  line-height: 1;
}

.preview-video {
  display: block;
  width: 100%;
  max-height: 70vh;
  background: #000000;
}

.checkout-modal-head h2 {
  margin: 10px 42px 7px 0;
  font-family: Manrope, Inter, sans-serif;
}

.checkout-modal-head p {
  margin: 0;
  color: var(--muted);
}

.checkout-order-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 18px 0;
  border: 1px solid var(--line);
  background: #faf9fc;
  padding: 13px;
  font-weight: 800;
}

#embedded-sessions {
  min-height: 185px;
}

.payment-result-shell {
  display: grid;
  min-height: 65vh;
  place-items: center;
  padding: 54px 16px;
  background: #faf9fc;
}

.payment-result-card {
  width: min(610px, 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #ffffff;
  padding: 30px;
  text-align: center;
  box-shadow: var(--shadow-md);
}

.payment-result-icon {
  display: grid;
  width: 66px;
  height: 66px;
  margin: 0 auto 15px;
  place-items: center;
  border-radius: 50%;
  background: var(--purple-light);
  color: var(--purple);
  font-size: 31px;
  font-weight: 800;
}

.payment-result-card h1 {
  margin: 0 0 10px;
  font-family: Manrope, Inter, sans-serif;
}

.payment-result-card p {
  color: var(--muted);
  line-height: 1.65;
}

.payment-result-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 21px;
}

@media (max-width: 1050px) {
  .course-details-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "purchase"
      "main";
    gap: 30px;
  }

  .purchase-card-wrap {
    margin-top: 0;
  }

  .purchase-card-wrap .purchase-card {
    position: static;
    max-width: 580px;
  }
}

@media (max-width: 590px) {
  .course-outline-box {
    padding: 16px;
  }

  .lesson {
    align-items: flex-start;
    flex-direction: column;
  }

  .lesson-actions {
    padding-left: 25px;
  }

  .instructor-card {
    align-items: flex-start;
    flex-direction: column;
  }

  .course-modal {
    padding: 18px;
  }
}

/* =========================================================
   Coupon input row layout fix
   ========================================================= */

.purchase-card .coupon-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: stretch;
}

.purchase-card .coupon-row input {
  width: 100%;
  min-width: 0;
  height: 44px;
  border: 1px solid #aaa4b1;
  border-radius: 7px;
  background: #ffffff;
  padding: 9px 11px;
  outline: 0;
}

.purchase-card .coupon-row input:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 4px rgba(109, 40, 217, 0.12);
}

.purchase-card .coupon-row .btn {
  width: auto;
  min-width: 92px;
  margin-top: 0;
  padding: 9px 16px;
  white-space: nowrap;
}

@media (max-width: 410px) {
  .purchase-card .coupon-row {
    grid-template-columns: 1fr;
  }

  .purchase-card .coupon-row .btn {
    width: 100%;
  }
}



/* =========================================================
   Arabic-first language switcher, RTL layout, and cart
   ========================================================= */

html[dir="rtl"] body {
  font-family: Cairo, Inter, Arial, sans-serif;
}

html[dir="rtl"] .hero h1,
html[dir="rtl"] .section h2,
html[dir="rtl"] .page-intro h1,
html[dir="rtl"] .auth-card h1,
html[dir="rtl"] .course-title-xl,
html[dir="rtl"] .course-title,
html[dir="rtl"] .related-title,
html[dir="rtl"] .footer h3,
html[dir="rtl"] .filters h3,
html[dir="rtl"] .course-main h2,
html[dir="rtl"] .checkout-modal-head h2,
html[dir="rtl"] .payment-result-card h1 {
  font-family: Cairo, Manrope, Inter, sans-serif;
  letter-spacing: 0;
}

.nav-quick-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.language-switch,
.cart-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  color: var(--ink-soft);
  padding: 8px 11px;
  font-size: 13px;
  font-weight: 800;
  transition: .2s;
}

.language-switch:hover,
.cart-link:hover {
  border-color: #c7b2ea;
  background: var(--purple-light);
  color: var(--purple-dark);
}

.language-switch .icon,
.cart-link .icon {
  width: 19px;
  height: 19px;
}

.cart-link {
  width: 42px;
  padding: 8px;
}

.cart-count {
  position: absolute;
  top: -7px;
  right: -7px;
  display: grid;
  min-width: 20px;
  height: 20px;
  place-items: center;
  border: 2px solid #fff;
  border-radius: 999px;
  background: var(--purple);
  color: #fff;
  padding: 0 4px;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
}

html[dir="rtl"] .cart-count {
  right: auto;
  left: -7px;
}

html[dir="rtl"] .text-link .icon {
  transform: rotate(180deg);
}

html[dir="rtl"] .accordion-head {
  text-align: right;
}

html[dir="rtl"] .related-price {
  border-left: 0;
  border-right: 1px solid var(--line);
  padding-left: 0;
  padding-right: 16px;
}

html[dir="rtl"] .notice {
  border-left: 0;
  border-right: 4px solid var(--purple);
}

html[dir="rtl"] .chat-launch {
  right: auto;
  left: 24px;
}

html[dir="rtl"] .chat-panel {
  right: auto;
  left: 24px;
}

html[dir="rtl"] .chat-msg.bot,
html[dir="rtl"] .chat-msg.agent {
  align-self: flex-start;
}

html[dir="rtl"] .chat-msg.visitor {
  align-self: flex-end;
}

.cart-page {
  min-height: 62vh;
}

.cart-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.cart-toolbar p {
  margin: 0;
}

.cart-list {
  display: grid;
  gap: 14px;
}

.cart-item {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  padding: 14px;
  box-shadow: var(--shadow-sm);
}

.cart-item-image {
  display: grid;
  overflow: hidden;
  place-items: center;
  aspect-ratio: 16 / 9;
  border-radius: 10px;
  background: #f3f1f6;
}

.cart-item-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.cart-item-copy h2 {
  margin: 0 0 6px;
  font-size: 20px;
}

.cart-item-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.cart-item-copy .price {
  justify-content: flex-start;
  padding-top: 11px;
}

.cart-item-actions {
  display: grid;
  gap: 8px;
  min-width: 130px;
}

.cart-remove {
  border: 0;
  background: transparent;
  color: var(--danger);
  padding: 5px;
  font-weight: 800;
}

.cart-empty {
  padding: 45px 20px;
}

.cart-empty h2 {
  margin-top: 0;
}

@media (max-width: 1020px) {
  .nav {
    gap: 12px;
  }

  .language-switch span {
    display: none;
  }

  .language-switch {
    width: 42px;
    padding: 8px;
  }
}

@media (max-width: 820px) {
  .nav-toggle {
    margin-left: 0;
  }

  html[dir="ltr"] .nav-toggle {
    margin-left: auto;
  }

  html[dir="rtl"] .nav-toggle {
    margin-right: auto;
  }

  .nav-quick-actions {
    margin-inline-start: auto;
  }

  .nav-search {
    order: 4;
  }

  html[dir="rtl"] .nav-links {
    right: 4vw;
    left: 4vw;
  }

  html[dir="rtl"] .related-price {
    border-right: 0;
    padding-right: 0;
  }

  .cart-item {
    grid-template-columns: 130px minmax(0, 1fr);
  }

  .cart-item-actions {
    grid-column: 1 / -1;
    grid-template-columns: 1fr 1fr auto;
    align-items: center;
  }
}

@media (max-width: 590px) {
  html[dir="rtl"] .chat-launch {
    left: 16px;
  }

  html[dir="rtl"] .chat-panel {
    left: 15px;
  }

  .nav-quick-actions {
    gap: 5px;
  }

  .language-switch,
  .cart-link {
    width: 38px;
    min-height: 38px;
  }

  .cart-item {
    grid-template-columns: 1fr;
  }

  .cart-item-image {
    max-width: 260px;
  }

  .cart-item-actions {
    grid-column: auto;
    grid-template-columns: 1fr;
  }
}


/* =========================================================
   Western digits, RTL account dropdown fix, and cart toast
   ========================================================= */

.price strong,
.price del,
.checkout-price-row,
.cart-count,
.academy-toast-timer {
  direction: ltr;
  unicode-bidi: isolate;
}

html[dir="rtl"] .profile-dropdown {
  right: auto;
  left: 0;
}

html[dir="rtl"] .profile-dropdown-head,
html[dir="rtl"] .profile-dropdown-user,
html[dir="rtl"] .profile-dropdown-links a,
html[dir="rtl"] .profile-dropdown-links button {
  text-align: right;
}

html[dir="rtl"] .profile-dropdown-links a:hover,
html[dir="rtl"] .profile-dropdown-links button:hover,
html[dir="rtl"] .account-drawer-links a:hover,
html[dir="rtl"] .account-drawer-links button:hover {
  transform: translateX(-2px);
}

html[dir="rtl"] .account-drawer {
  right: 0;
  left: auto;
  border-right: 0;
  border-left: 1px solid #ece6f4;
  box-shadow: -20px 0 60px rgba(24, 15, 42, 0.18);
  transform: translateX(105%);
}

html[dir="rtl"] .account-drawer.open {
  transform: translateX(0);
}

.academy-toast-region {
  position: fixed;
  bottom: 24px;
  left: 24px;
  z-index: 2600;
  display: grid;
  width: min(390px, calc(100vw - 32px));
  gap: 10px;
  pointer-events: none;
}

html[dir="rtl"] .academy-toast-region {
  right: 24px;
  left: auto;
}

.academy-toast {
  overflow: hidden;
  border: 1px solid #e3d8f4;
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 20px 52px rgba(34, 19, 57, 0.2);
  pointer-events: auto;
  animation: academyToastInLtr 190ms ease both;
}

html[dir="rtl"] .academy-toast {
  animation-name: academyToastInRtl;
}

.academy-toast-leaving {
  animation: academyToastOut 180ms ease both;
}

.academy-toast-main {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 11px;
  align-items: start;
  padding: 14px 14px 12px;
}

.academy-toast-icon {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 50%;
  background: #e7f7f1;
  color: var(--success);
}

.academy-toast-icon .icon {
  width: 21px;
  height: 21px;
}

.academy-toast-copy {
  min-width: 0;
}

.academy-toast-copy strong {
  display: block;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
}

.academy-toast-copy p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.academy-toast-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 8px;
}

.academy-toast-actions a {
  color: var(--purple);
  font-size: 13px;
  font-weight: 800;
}

.academy-toast-actions a:hover {
  text-decoration: underline;
}

.academy-toast-timer {
  color: #857b91;
  font-size: 12px;
  font-weight: 800;
}

.academy-toast-close {
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: #786f84;
  transition: 160ms ease;
}

.academy-toast-close:hover {
  background: #f3eefb;
  color: var(--purple-dark);
}

.academy-toast-close .icon {
  width: 16px;
  height: 16px;
}

.academy-toast-progress {
  height: 4px;
  overflow: hidden;
  background: #efe9f6;
}

.academy-toast-progress span {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, var(--purple), var(--violet));
  transform: scaleX(1);
  transform-origin: left center;
}

html[dir="rtl"] .academy-toast-progress span {
  transform-origin: right center;
}

@keyframes academyToastInLtr {
  from { opacity: 0; transform: translateX(-18px) translateY(8px); }
  to { opacity: 1; transform: translateX(0) translateY(0); }
}

@keyframes academyToastInRtl {
  from { opacity: 0; transform: translateX(18px) translateY(8px); }
  to { opacity: 1; transform: translateX(0) translateY(0); }
}

@keyframes academyToastOut {
  from { opacity: 1; transform: translateY(0); }
  to { opacity: 0; transform: translateY(10px); }
}

@media (max-width: 980px) {
  html[dir="rtl"] .profile-dropdown {
    right: auto;
    left: -4px;
  }
}

@media (max-width: 520px) {
  .academy-toast-region,
  html[dir="rtl"] .academy-toast-region {
    right: 16px;
    bottom: 16px;
    left: 16px;
    width: auto;
  }
}

/* =========================================================
   Uploaded 1001 logo mark and compact Academy wordmark
   ========================================================= */

.logo {
  display: inline-flex;
  gap: 9px;
  align-items: center;
  flex-shrink: 0;
  min-width: max-content;
}

.logo img.logo-mark {
  width: auto;
  height: 48px;
  object-fit: contain;
}

.logo-word {
  color: var(--ink);
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 1;
  white-space: nowrap;
}

.footer-brand {
  display: inline-flex;
  gap: 11px;
  align-items: center;
  color: #ffffff;
}

.footer-brand img {
  width: auto;
  height: 58px;
  filter: brightness(0) invert(1);
}

.footer-brand span {
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 27px;
  font-weight: 800;
  letter-spacing: -0.045em;
}

@media (max-width: 820px) {
  .logo img.logo-mark {
    width: auto;
    height: 43px;
  }

  .logo-word {
    font-size: 20px;
  }
}

@media (max-width: 590px) {
  .logo img.logo-mark {
    width: auto;
    height: 39px;
  }

  .logo-word {
    font-size: 18px;
  }

  .footer-brand img {
    height: 52px;
  }
}

/* =========================================================
   Stable navbar layout in both languages
   Arabic changes the labels, but the navbar keeps the same
   left-to-right visual structure as the English version.
   ========================================================= */

.site-header .nav,
.site-header .nav-search,
.site-header .nav-quick-actions,
.site-header .nav-links {
  direction: ltr;
}

html[dir="rtl"] .site-header .nav-search input {
  direction: rtl;
  text-align: right;
}

html[dir="rtl"] .site-header .language-switch span,
html[dir="rtl"] .site-header .nav-links > a,
html[dir="rtl"] .site-header .profile-dropdown-user,
html[dir="rtl"] .site-header .profile-dropdown-links a,
html[dir="rtl"] .site-header .profile-dropdown-links button {
  direction: rtl;
  unicode-bidi: isolate;
}

/* Keep the cart badge on the same corner in Arabic and English. */
html[dir="rtl"] .site-header .cart-count {
  right: -7px;
  left: auto;
}

/* Keep the desktop account menu anchored exactly like English. */
html[dir="rtl"] .site-header .profile-dropdown {
  right: 0;
  left: auto;
}

@media (max-width: 980px) {
  html[dir="rtl"] .site-header .profile-dropdown {
    right: -4px;
    left: auto;
  }
}

@media (max-width: 820px) {
  html[dir="rtl"] .site-header .nav-toggle {
    margin-right: 0;
    margin-left: auto;
  }

  html[dir="rtl"] .site-header .nav-links {
    right: 4vw;
    left: 4vw;
  }
}

/* =========================================================
   Gemini AI support chat states
   ========================================================= */

.chat-form input:disabled,
.chat-form button:disabled {
  cursor: wait;
  opacity: 0.72;
}

.chat-msg-typing {
  display: inline-flex;
  gap: 5px;
  align-items: center;
  min-width: 54px;
  min-height: 36px;
}

.chat-msg-typing span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--purple);
  animation: chatTypingDot 1.1s infinite ease-in-out;
}

.chat-msg-typing span:nth-child(2) {
  animation-delay: 0.16s;
}

.chat-msg-typing span:nth-child(3) {
  animation-delay: 0.32s;
}

.chat-msg-error {
  border-color: #f3b7b2 !important;
  background: #fff2f1 !important;
  color: #8a1f11;
}

@keyframes chatTypingDot {
  0%, 60%, 100% {
    opacity: 0.35;
    transform: translateY(0);
  }

  30% {
    opacity: 1;
    transform: translateY(-4px);
  }
}


/* =========================================================
   PayPal Expanded Checkout
   ========================================================= */

.checkout-backdrop .course-modal {
  width: min(680px, calc(100vw - 28px));
  max-height: min(900px, calc(100vh - 28px));
  overflow-y: auto;
}

.paypal-payment-option {
  padding: 18px 0;
}

.paypal-payment-option h3 {
  margin: 0 0 12px;
  font-size: 17px;
}

.paypal-divider {
  position: relative;
  display: grid;
  place-items: center;
  margin: 2px 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.paypal-divider::before {
  position: absolute;
  right: 0;
  left: 0;
  height: 1px;
  background: var(--line);
  content: '';
}

.paypal-divider span {
  position: relative;
  padding: 0 12px;
  background: #ffffff;
}

.paypal-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.paypal-card-field {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

.paypal-card-field-wide {
  grid-column: 1 / -1;
}

.paypal-card-field > div {
  min-height: 46px;
  border: 1px solid #aaa4b1;
  border-radius: 7px;
  background: #ffffff;
  padding: 10px 11px;
}

.paypal-card-field > div:focus-within {
  border-color: var(--purple);
  box-shadow: 0 0 0 4px rgba(109, 40, 217, 0.12);
}

.paypal-card-submit {
  width: 100%;
  margin-top: 15px;
}

.paypal-checkout-message {
  min-height: 20px;
}

.paypal-checkout-message.error {
  color: #9d1c13;
}

@media (max-width: 520px) {
  .paypal-card-grid {
    grid-template-columns: 1fr;
  }

  .paypal-card-field-wide {
    grid-column: auto;
  }
}

/* =========================================================
   Enrolled learner course player
   Videos are streamed only after a server-side enrollment check.
   ========================================================= */

.learning-body {
  min-height: 100vh;
  background: #f6f3f9;
}

.learning-page {
  min-height: calc(100vh - 110px);
}

.learning-loading-shell {
  padding: 46px 0;
}

.learning-shell {
  display: grid;
  min-height: calc(100vh - 110px);
  grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
  background: #f6f3f9;
}

.learning-sidebar {
  position: sticky;
  top: 110px;
  z-index: 12;
  height: calc(100vh - 110px);
  overflow-y: auto;
  border-inline-end: 1px solid #e4deea;
  background: #ffffff;
  box-shadow: 12px 0 28px rgba(44, 37, 55, 0.04);
}

html[dir="rtl"] .learning-sidebar {
  box-shadow: -12px 0 28px rgba(44, 37, 55, 0.04);
}

.learning-sidebar-head {
  position: sticky;
  top: 0;
  z-index: 3;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  justify-content: space-between;
  border-bottom: 1px solid #ece7f0;
  background: rgba(255, 255, 255, 0.97);
  padding: 18px;
  backdrop-filter: blur(14px);
}

.learning-sidebar-head h2 {
  margin: 11px 0 0;
  color: #251b31;
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 20px;
  letter-spacing: -0.035em;
}

.learning-back {
  display: inline-flex;
  gap: 7px;
  align-items: center;
  color: var(--purple);
  font-size: 13px;
  font-weight: 800;
}

.learning-back .icon {
  width: 15px;
  height: 15px;
  transform: rotate(90deg);
}

html[dir="rtl"] .learning-back .icon {
  transform: rotate(-90deg);
}

.learning-sidebar-close {
  display: none;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 0;
  border-radius: 10px;
  background: #f5f1f8;
  color: #5e5369;
}

.learning-progress-card {
  margin: 16px;
  border: 1px solid #e6dcf2;
  border-radius: 14px;
  background: linear-gradient(135deg, #fbf8ff, #ffffff);
  padding: 14px;
}

.learning-progress-copy {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  color: #64596d;
  font-size: 12px;
  font-weight: 800;
}

.learning-progress-copy strong {
  color: var(--purple-dark);
  font-size: 20px;
}

.learning-progress-track {
  height: 7px;
  overflow: hidden;
  margin: 10px 0 8px;
  border-radius: 999px;
  background: #ece5f4;
}

.learning-progress-track span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--purple), var(--violet));
  transition: width 260ms ease;
}

.learning-progress-card small {
  color: #786f82;
  font-size: 11px;
  font-weight: 700;
}

.learning-curriculum {
  padding: 0 12px 22px;
}

.learning-section {
  overflow: hidden;
  margin-top: 10px;
  border: 1px solid #ece6f1;
  border-radius: 12px;
  background: #ffffff;
}

.learning-section-toggle {
  display: flex;
  width: 100%;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  border: 0;
  background: #fbf9fd;
  color: #281e33;
  padding: 13px;
  text-align: start;
}

.learning-section-toggle strong,
.learning-section-toggle small {
  display: block;
}

.learning-section-toggle strong {
  font-size: 14px;
  line-height: 1.35;
}

.learning-section-toggle small {
  margin-top: 4px;
  color: #7b7185;
  font-size: 11px;
}

.learning-section-toggle .icon {
  flex-shrink: 0;
  transition: transform 180ms ease;
}

.learning-section.open .learning-section-toggle .icon {
  transform: rotate(180deg);
}

.learning-section-lessons {
  display: none;
}

.learning-section.open .learning-section-lessons {
  display: block;
}

.learning-lesson {
  display: flex;
  width: 100%;
  gap: 10px;
  align-items: flex-start;
  border: 0;
  border-top: 1px solid #f0ebf3;
  background: #ffffff;
  color: #30273a;
  padding: 12px;
  text-align: start;
  transition: background 150ms ease, color 150ms ease;
}

.learning-lesson:hover {
  background: #faf7ff;
}

.learning-lesson.active {
  background: #f2eaff;
  color: var(--purple-dark);
}

.learning-lesson.completed .learning-lesson-icon {
  background: #eaf8ef;
  color: #168344;
}

.learning-lesson-icon {
  display: grid;
  width: 26px;
  height: 26px;
  place-items: center;
  flex-shrink: 0;
  border-radius: 50%;
  background: #f0ebf4;
  color: #776d82;
}

.learning-lesson-icon .icon {
  width: 14px;
  height: 14px;
}

.learning-lesson-copy {
  min-width: 0;
}

.learning-lesson-copy strong,
.learning-lesson-copy small {
  display: block;
}

.learning-lesson-copy strong {
  font-size: 13px;
  line-height: 1.45;
}

.learning-lesson-copy small {
  margin-top: 4px;
  color: #80768a;
  font-size: 11px;
}

.learning-sidebar-backdrop {
  display: none;
}

.learning-content {
  min-width: 0;
  padding: 28px clamp(18px, 3.8vw, 58px) 54px;
}

.learning-content-head {
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.learning-content-head p {
  margin: 0 0 5px;
  color: var(--purple);
  font-size: 13px;
  font-weight: 800;
}

.learning-content-head h1 {
  margin: 0;
  color: #211829;
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: clamp(24px, 3vw, 35px);
  letter-spacing: -0.045em;
  line-height: 1.2;
}

.learning-sidebar-open {
  display: none;
  flex-shrink: 0;
}

.learning-message {
  margin-bottom: 14px;
  border: 1px solid #d8c8f1;
  border-radius: 10px;
  background: #faf7ff;
  color: #5c349b;
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 700;
}

.learning-message.error {
  border-color: #f2b8ba;
  background: #fff1f1;
  color: #a52828;
}

.learning-player-wrap {
  display: grid;
  overflow: hidden;
  min-height: min(62vw, 690px);
  place-items: center;
  border-radius: 18px;
  background: #120f18;
  box-shadow: 0 24px 60px rgba(20, 15, 29, 0.2);
}

.learning-video {
  display: block;
  width: 100%;
  max-height: min(72vh, 760px);
  aspect-ratio: 16 / 9;
  background: #09070c;
  object-fit: contain;
}

.learning-empty-player {
  max-width: 560px;
  padding: 34px;
  color: #f2eef6;
  text-align: center;
}

.learning-empty-player h2 {
  margin: 13px 0 9px;
  color: #ffffff;
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 25px;
}

.learning-empty-player p {
  margin: 0;
  color: #c7bdcf;
  line-height: 1.7;
}

.learning-empty-icon {
  display: grid;
  width: 60px;
  height: 60px;
  place-items: center;
  margin: auto;
  border-radius: 18px;
  background: rgba(168, 85, 247, 0.2);
  color: #cfadff;
}

.learning-empty-icon .icon {
  width: 30px;
  height: 30px;
}

.learning-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 12px;
  margin-top: 18px;
}

.learning-toolbar .btn:first-child {
  justify-self: start;
}

.learning-toolbar .btn:last-child {
  justify-self: end;
}

.learning-toolbar .btn:first-child .icon {
  transform: rotate(90deg);
}

.learning-toolbar .btn:last-child .icon {
  transform: rotate(-90deg);
}

html[dir="rtl"] .learning-toolbar .btn:first-child .icon {
  transform: rotate(-90deg);
}

html[dir="rtl"] .learning-toolbar .btn:last-child .icon {
  transform: rotate(90deg);
}

.learning-toolbar .is-completed {
  border-color: #168344;
  background: #eaf8ef;
  color: #126d39;
}

.learning-course-note {
  display: flex;
  gap: 14px;
  margin-top: 24px;
  border: 1px solid #e6deec;
  border-radius: 16px;
  background: #ffffff;
  padding: 18px;
}

.learning-note-icon,
.learning-access-icon {
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  flex-shrink: 0;
  border-radius: 14px;
  background: #f0e7ff;
  color: var(--purple);
}

.learning-note-icon .icon,
.learning-access-icon .icon {
  width: 24px;
  height: 24px;
}

.learning-course-note h2 {
  margin: 0;
  color: #281f31;
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 19px;
}

.learning-course-note p {
  margin: 8px 0;
  color: #70667b;
  font-size: 14px;
  line-height: 1.65;
}

.learning-course-note small {
  color: #7e7487;
  font-size: 12px;
  font-weight: 700;
}

.learning-access-card {
  max-width: 650px;
  margin: 34px auto;
  border: 1px solid #e5ddeb;
  border-radius: 20px;
  background: #ffffff;
  padding: 34px;
  box-shadow: var(--shadow-md);
  text-align: center;
}

.learning-access-icon {
  margin: 0 auto 16px;
}

.learning-access-card h1 {
  margin: 0;
  color: #251b31;
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 30px;
  letter-spacing: -0.04em;
}

.learning-access-card p {
  margin: 13px auto 20px;
  color: #716679;
  line-height: 1.7;
}

.learning-access-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

@media (max-width: 980px) {
  .learning-page {
    min-height: calc(100vh - 148px);
  }

  .learning-shell {
    display: block;
    min-height: calc(100vh - 148px);
  }

  .learning-sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 2100;
    width: min(370px, 88vw);
    height: 100vh;
    border-inline-end: 1px solid #e4deea;
    box-shadow: 18px 0 46px rgba(30, 20, 42, 0.2);
    transform: translateX(-104%);
    transition: transform 220ms ease;
  }

  html[dir="rtl"] .learning-sidebar {
    right: 0;
    left: auto;
    box-shadow: -18px 0 46px rgba(30, 20, 42, 0.2);
    transform: translateX(104%);
  }

  .learning-sidebar.open,
  html[dir="rtl"] .learning-sidebar.open {
    transform: translateX(0);
  }

  .learning-sidebar-close,
  .learning-sidebar-open {
    display: inline-grid;
  }

  .learning-sidebar-backdrop {
    position: fixed;
    inset: 0;
    z-index: 2050;
    background: rgba(22, 16, 29, 0.48);
    backdrop-filter: blur(3px);
  }

  .learning-sidebar-backdrop.open {
    display: block;
  }

  body.learning-sidebar-visible {
    overflow: hidden;
  }

  .learning-content {
    padding: 22px 4vw 48px;
  }

  .learning-content-head {
    align-items: flex-start;
    justify-content: flex-start;
  }

  .learning-player-wrap {
    min-height: 0;
  }
}

@media (max-width: 620px) {
  .learning-content {
    padding: 16px 0 34px;
  }

  .learning-content-head,
  .learning-message,
  .learning-toolbar,
  .learning-course-note {
    margin-inline: 4vw;
  }

  .learning-content-head {
    gap: 11px;
    margin-bottom: 14px;
  }

  .learning-content-head h1 {
    font-size: 23px;
  }

  .learning-content-head p {
    font-size: 11px;
  }

  .learning-sidebar-open {
    padding: 8px 10px;
  }

  .learning-sidebar-open span {
    display: none;
  }

  .learning-player-wrap {
    border-radius: 0;
    box-shadow: none;
  }

  .learning-video {
    max-height: none;
    aspect-ratio: 16 / 9;
  }

  .learning-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
    margin-top: 14px;
  }

  .learning-toolbar .btn {
    width: 100%;
    min-height: 44px;
    padding: 9px 10px;
    font-size: 12px;
  }

  .learning-toolbar .btn:first-child,
  .learning-toolbar .btn:last-child {
    justify-self: stretch;
  }

  .learning-toolbar .btn-primary {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .learning-course-note {
    margin-top: 18px;
    padding: 14px;
  }

  .learning-note-icon {
    width: 42px;
    height: 42px;
  }

  .learning-course-note h2 {
    font-size: 16px;
  }

  .learning-course-note p {
    font-size: 13px;
  }

  .learning-empty-player {
    padding: 26px 20px;
  }

  .learning-empty-player h2 {
    font-size: 21px;
  }

  .learning-access-card {
    padding: 26px 18px;
  }

  .learning-access-card h1 {
    font-size: 25px;
  }
}


/* =========================================================
   Registration email verification OTP step
   ========================================================= */

.registration-otp-step {
  margin-top: 20px;
  border: 1px solid #e3d8f4;
  border-radius: 15px;
  background: #fcfaff;
  padding: 20px;
}

.registration-otp-step[hidden] {
  display: none;
}

.registration-otp-icon {
  display: grid;
  width: 46px;
  height: 46px;
  place-items: center;
  border-radius: 14px;
  background: var(--purple-light);
  color: var(--purple);
}

.registration-otp-icon .icon {
  width: 24px;
  height: 24px;
}

.registration-otp-step h2 {
  margin: 15px 0 7px;
  font-family: Manrope, Inter, Arial, sans-serif;
  font-size: 23px;
  letter-spacing: -.035em;
}

.registration-otp-lead,
.registration-resend-note {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.65;
}

.registration-otp-lead strong {
  display: inline-block;
  direction: ltr;
  unicode-bidi: isolate;
  color: var(--ink);
}

#registration-otp {
  direction: ltr;
  text-align: center;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 8px;
}

.registration-otp-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px;
  margin-top: 16px;
}

.auth-text-button {
  border: 0;
  background: transparent;
  color: var(--purple);
  padding: 3px 0;
  font-size: 13px;
  font-weight: 800;
}

.auth-text-button:hover {
  text-decoration: underline;
}

.auth-text-button:disabled {
  color: #9a92a5;
  cursor: not-allowed;
  text-decoration: none;
}

.registration-resend-note {
  min-height: 22px;
  margin: 10px 0 0;
  font-size: 12px;
}

@media (max-width: 590px) {
  .registration-otp-step {
    padding: 16px;
  }

  .registration-otp-step h2 {
    font-size: 21px;
  }
}
