/* ============================================================================
   Onlineglish / Bastak — REDESIGN component system (bold, modern)
   Styles the new markup emitted by the parsa-child templates + coded home.
   RTL-first, logical properties, brand emerald + gold. Tokens from og-ux.css.
   Loaded site-wide by the mu-plugin so child markup + Elementor pages share it.
   ========================================================================== */

/* ---- Layout primitives -------------------------------------------------- */
.og-container{ width:min(100% - 32px, var(--og-container)); margin-inline:auto; }
.og-section{ padding-block:clamp(40px,6vw,84px); position:relative; }
.og-section--tight{ padding-block:clamp(28px,4vw,52px); }
.og-section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:clamp(22px,3vw,40px); flex-wrap:wrap; }

.og-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:var(--t-sm); font-weight:800; color:var(--og-emerald-600);
  letter-spacing:.02em; margin-bottom:10px;
}
.og-eyebrow::before{ content:""; width:26px; height:3px; border-radius:3px; background:linear-gradient(90deg,var(--og-emerald),var(--og-gold-deep)); }
.og-title{ font-size:var(--t-2xl); font-weight:800; line-height:1.5; color:var(--og-ink); letter-spacing:-.01em; margin:0; }
.og-title em{ font-style:normal; color:var(--og-emerald); }
.og-subtitle{ font-size:var(--t-base); color:var(--og-muted); line-height:2; margin-top:10px; max-width:60ch; }

/* ---- Buttons ------------------------------------------------------------ */
.og-btn{
  --_bg:var(--c-primary); --_fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:13px 24px; border-radius:var(--r-pill); border:none; cursor:pointer;
  font-family:inherit; font-size:var(--t-sm); font-weight:800; line-height:1;
  background:var(--_bg); color:var(--_fg); text-decoration:none;
  position:relative; overflow:hidden; isolation:isolate;
  box-shadow:0 10px 22px -10px rgba(0,86,63,.55);
  transition:transform .25s var(--og-ease), box-shadow .3s var(--og-ease), filter .25s var(--og-ease);
}
.og-btn::after{
  content:""; position:absolute; inset:0; z-index:-1; transform:translateX(-130%) skewX(-18deg);
  background:linear-gradient(100deg,transparent,rgba(240,227,178,.5),transparent);
}
.og-btn:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -12px rgba(0,86,63,.6); filter:saturate(1.06); color:var(--_fg); }
.og-btn:hover::after{ transform:translateX(130%) skewX(-18deg); transition:transform .7s var(--og-ease-out); }
.og-btn:active{ transform:translateY(0) scale(.985); }
.og-btn--primary{ --_bg:linear-gradient(180deg,var(--og-emerald-600),var(--og-emerald)); }
.og-btn--accent{ --_bg:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); --_fg:var(--og-emerald-700); box-shadow:0 10px 22px -10px rgba(217,192,116,.8); }
.og-btn--ghost{ --_bg:transparent; --_fg:var(--og-emerald); border:1.5px solid var(--og-line); box-shadow:none; }
.og-btn--ghost:hover{ border-color:var(--og-emerald); }
.og-btn--on-dark{ --_bg:rgba(255,255,255,.08); --_fg:#fff; border:1.5px solid rgba(255,255,255,.28); box-shadow:none; backdrop-filter:blur(4px); }
.og-btn--on-dark:hover{ --_bg:var(--og-gold); --_fg:var(--og-emerald-700); border-color:transparent; }
.og-btn--lg{ padding:16px 30px; font-size:var(--t-base); }
.og-btn--block{ display:flex; width:100%; }

/* ---- Surfaces / cards --------------------------------------------------- */
.og-card{ background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); }

/* ---- Chips / pills ------------------------------------------------------ */
.og-chip{
  display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:var(--r-pill);
  font-size:var(--t-xs); font-weight:700; line-height:1.6;
  background:var(--og-surface-2); color:var(--og-ink-soft);
}
.og-chip--emerald{ background:rgba(0,86,63,.10); color:var(--og-emerald); }
.og-chip--gold{ background:linear-gradient(180deg,var(--og-gold-soft),var(--og-gold)); color:var(--og-emerald-700); }
.og-chip--outline{ background:transparent; border:1px solid var(--og-line); color:var(--og-muted); }

/* ---- Icon circle -------------------------------------------------------- */
.og-icon-circle{
  display:grid; place-items:center; width:54px; height:54px; border-radius:50%;
  background:rgba(0,86,63,.08); color:var(--og-emerald); font-size:22px; flex:0 0 auto;
}

/* ---- Responsive grid + horizontal rail --------------------------------- */
.og-grid{ display:grid; gap:clamp(16px,2vw,26px); }
.og-grid--3{ grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); }
.og-grid--4{ grid-template-columns:repeat(auto-fill, minmax(230px, 1fr)); }
.og-rail{ display:grid; grid-auto-flow:column; grid-auto-columns:minmax(280px, 1fr); gap:clamp(16px,2vw,24px); overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:10px; scrollbar-width:thin; }
.og-rail__item{ scroll-snap-align:start; }

/* ---- Stat / counter ----------------------------------------------------- */
.og-stat{ text-align:center; }
.og-stat__num{ font-size:var(--t-2xl); font-weight:800; color:var(--og-emerald); line-height:1.1; }
.og-stat__label{ font-size:var(--t-sm); color:var(--og-muted); margin-top:4px; }

/* ---- CTA band ----------------------------------------------------------- */
.og-cta-band{
  position:relative; overflow:hidden; border-radius:var(--r-2xl); color:#fff;
  padding:clamp(30px,5vw,60px);
  background:
    radial-gradient(120% 160% at 88% -30%, rgba(240,227,178,.20), transparent 55%),
    linear-gradient(100deg,var(--og-emerald-700),var(--og-emerald) 55%,var(--og-emerald-500));
  box-shadow:var(--og-shadow-3);
}
.og-cta-band .og-title{ color:#fff; }

/* ---- Section divider accents ------------------------------------------- */
.og-accent-line{ height:4px; width:64px; border-radius:4px; background:linear-gradient(90deg,var(--og-emerald),var(--og-gold-deep)); }

/* ---- Number rendering: keep Latin price/numerals tidy ------------------ */
.num-latin{ font-feature-settings:"tnum" 1; direction:ltr; unicode-bidi:isolate; }

/* ============================ 404 ============================ */
.og-404{ background:radial-gradient(90% 70% at 82% -10%, rgba(0,86,63,.05), transparent 60%), var(--og-bg); }
.og-404__inner{ max-width:760px; margin-inline:auto; text-align:center; padding-block:clamp(40px,8vw,100px); }
.og-404__num{
  font-size:clamp(110px,22vw,236px); font-weight:900; line-height:.9; letter-spacing:-.04em;
  background:linear-gradient(160deg,var(--og-emerald),var(--og-emerald-500) 55%,var(--og-gold-deep));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  filter:drop-shadow(0 18px 36px rgba(0,86,63,.18)); margin-bottom:6px;
}
.og-404 .og-eyebrow{ justify-content:center; }
.og-404 .og-subtitle{ margin-inline:auto; }
.og-404__search{ display:flex; gap:10px; max-width:520px; margin:26px auto 18px; }
.og-404__search input{ flex:1; }
.og-404__links{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ======================= Archive / blog ======================= */
.og-archive{ background:var(--og-bg); padding-block:clamp(28px,4vw,56px); }
.og-archive__head{ margin-bottom:clamp(22px,3vw,38px); }
.og-archive__title{ font-size:var(--t-2xl); font-weight:800; color:var(--og-ink); margin:0; line-height:1.5; }
.og-archive__layout{ display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:clamp(20px,3vw,40px); align-items:start; }
.og-archive__side{ position:sticky; top:96px; }
@media (max-width:991px){ .og-archive__layout{ grid-template-columns:1fr; } .og-archive__side{ position:static; } }
.og-pagination{ display:flex; justify-content:center; margin-top:34px; }
.og-pagination .page-numbers{
  display:inline-grid; place-items:center; min-width:42px; height:42px; padding:0 12px; margin:0 4px;
  border-radius:12px; background:#fff; border:1px solid var(--og-line); color:var(--og-ink-soft);
  font-weight:700; text-decoration:none; transition:all .25s var(--og-ease);
}
.og-pagination .page-numbers.current, .og-pagination a.page-numbers:hover{ background:var(--og-emerald); color:#fff; border-color:var(--og-emerald); }
.og-empty{ padding:30px; text-align:center; color:var(--og-muted); }

/* ===================== Article card ===================== */
.og-post-card{ display:flex; flex-direction:column; overflow:hidden; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); transition:transform .4s var(--og-ease-out), box-shadow .4s var(--og-ease-out); }
.og-post-card:hover{ transform:translateY(-7px); box-shadow:var(--og-shadow-3); }
.og-post-card__media{ display:block; position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--og-surface-2); }
.og-post-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--og-ease-out); }
.og-post-card:hover .og-post-card__media img{ transform:scale(1.06); }
.og-post-card__ph{ position:absolute; inset:0; background:linear-gradient(135deg,var(--og-surface-2),#e3ebe6); }
.og-post-card__cat{ position:absolute; inset-block-start:12px; inset-inline-end:12px; }
.og-post-card__body{ padding:18px 18px 16px; display:flex; flex-direction:column; gap:10px; flex:1; }
.og-post-card__title{ font-size:var(--t-lg); font-weight:800; line-height:1.7; margin:0; }
.og-post-card__title a{ color:var(--og-ink); text-decoration:none; }
.og-post-card__title a:hover{ color:var(--og-emerald); }
.og-post-card__excerpt{ font-size:var(--t-sm); color:var(--og-muted); line-height:2; margin:0; flex:1; }
.og-post-card__meta{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:12px; border-top:1px solid var(--og-line-soft); font-size:var(--t-xs); color:var(--og-muted); }
.og-post-card__more{ display:inline-flex; align-items:center; gap:6px; color:var(--og-emerald); font-weight:800; text-decoration:none; transition:gap .25s var(--og-ease); }
.og-post-card__more:hover{ gap:11px; }

/* ====================== Single-post reader ====================== */
.og-reader{ background:var(--og-bg); padding-bottom:clamp(30px,5vw,60px); }
.og-reader__hero{ background:linear-gradient(160deg,var(--og-emerald-700),var(--og-emerald)); color:#fff; padding-block:clamp(34px,5vw,60px); margin-bottom:clamp(20px,3vw,34px); position:relative; overflow:hidden; }
.og-reader__hero::after{ content:""; position:absolute; inset-block-start:-40%; inset-inline-start:-8%; width:340px; height:340px; border-radius:50%; background:radial-gradient(circle,rgba(240,227,178,.14),transparent 70%); }
.og-reader__hero-inner{ position:relative; max-width:860px; }
.og-reader__title{ font-size:var(--t-3xl); font-weight:800; line-height:1.55; margin:14px 0 16px; letter-spacing:-.01em; }
.og-reader__meta{ display:flex; flex-wrap:wrap; gap:8px 20px; color:rgba(255,255,255,.82); font-size:var(--t-sm); }
.og-reader__meta i{ color:var(--og-gold); margin-inline-end:4px; }
.og-reader__readtime{ color:var(--og-gold-soft); }
.og-reader__cover{ margin:0 auto clamp(20px,3vw,32px); border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--og-shadow-3); max-width:980px; }
.og-reader__cover img{ width:100%; height:auto; display:block; }
.og-reader__layout{ display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:clamp(22px,3vw,46px); align-items:start; max-width:1120px; margin-inline:auto; }
@media (max-width:991px){ .og-reader__layout{ grid-template-columns:1fr; } }
.og-reader__main{ background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-xl); padding:clamp(22px,3vw,42px); box-shadow:var(--og-shadow-1); }
.og-reader__content{ font-size:1.06rem; line-height:2.2; color:var(--og-ink-soft); }
.og-reader__side{ position:sticky; top:96px; }
/* Parent get_sidebar() wraps widgets in a floated .single-sidebar — neutralize it so it fills our grid column (same fix as .og-course__buy) */
.og-reader__side .single-sidebar, .og-archive__side .single-sidebar{ float:none !important; width:auto !important; }
.og-reader__side .sidebar-widget, .og-archive__side .sidebar-widget{ width:auto; box-sizing:border-box; }
.og-reader__share{ display:flex; flex-wrap:wrap; align-items:center; gap:12px; margin-top:28px; padding-top:20px; border-top:1px dashed var(--og-line); clear:both; width:100%; }
.og-reader__share-label{ font-weight:700; color:var(--og-muted); font-size:var(--t-sm); }
.og-reader__share a{ display:grid; place-items:center; flex:0 0 40px; width:40px; height:40px; border-radius:50%; background:rgba(0,86,63,.08); color:var(--og-emerald); transition:all .25s var(--og-ease); text-decoration:none; }
.og-reader__share a:hover{ background:var(--og-emerald); color:#fff; transform:translateY(-3px); }
.og-author{ display:flex; gap:16px; align-items:center; margin-top:24px; padding:20px; }
.og-author__avatar{ border-radius:50%; flex:0 0 auto; }
.og-author__name{ font-weight:800; color:var(--og-ink); margin-bottom:4px; }
.og-author__name a{ color:inherit; text-decoration:none; }
.og-author__desc{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.9; }
.og-related{ background:var(--og-bg); }

/* ===================== Coded blog / reader sidebar ===================== */
.og-sidebar{ display:flex; flex-direction:column; gap:clamp(16px,2vw,22px); }
.og-sidebar .og-widget{ background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-xl); padding:clamp(18px,2vw,24px); box-shadow:var(--og-shadow-1); }
.og-widget__title{ display:flex; align-items:center; gap:9px; margin:0 0 16px; font-size:1.04rem; font-weight:800; color:var(--og-ink); padding-bottom:13px; border-bottom:1px solid var(--og-line-soft); }
.og-widget__title i{ color:var(--og-emerald); font-size:.9em; }
/* search */
.og-search{ display:flex; flex-direction:column; gap:10px; }
.og-search__input{ width:100%; box-sizing:border-box; padding:12px 15px; border:1.5px solid var(--og-line); border-radius:var(--r-md); background:var(--og-surface-2); color:var(--og-ink); font:inherit; font-size:var(--t-sm); transition:border-color .2s var(--og-ease), box-shadow .2s var(--og-ease), background .2s var(--og-ease); }
.og-search__input::placeholder{ color:var(--og-muted); }
.og-search__input:focus{ outline:none; border-color:var(--og-emerald); box-shadow:0 0 0 3px rgba(0,86,63,.12); background:var(--og-surface); }
.og-search__btn{ width:100%; justify-content:center; }
/* latest posts */
.og-wposts{ list-style:none; margin:0; padding:0; }
.og-wpost{ display:flex; gap:12px; align-items:center; padding:13px 0; border-bottom:1px solid var(--og-line-soft); }
.og-wpost:first-child{ padding-top:0; }
.og-wpost:last-child{ padding-bottom:0; border-bottom:0; }
.og-wpost__thumb{ flex:0 0 62px; width:62px; height:62px; border-radius:var(--r-md); overflow:hidden; background:var(--og-surface-2); display:block; }
.og-wpost__thumb img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--og-ease-out); }
.og-wpost:hover .og-wpost__thumb img{ transform:scale(1.08); }
.og-wpost__ph{ display:grid; place-items:center; width:100%; height:100%; color:var(--og-emerald); background:linear-gradient(135deg,var(--og-surface-2),#e3ebe6); }
.og-wpost__body{ min-width:0; flex:1; display:flex; flex-direction:column; gap:5px; }
.og-wpost__title{ color:var(--og-ink); font-weight:700; font-size:.92rem; line-height:1.65; text-decoration:none; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; transition:color .2s var(--og-ease); }
.og-wpost__title:hover{ color:var(--og-emerald); }
.og-wpost__date{ font-size:var(--t-xs); color:var(--og-muted); }
.og-wpost__date i{ margin-inline-end:4px; color:var(--og-gold-deep); }
/* categories */
.og-wcats{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:4px; }
.og-wcats li a{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 13px; border-radius:var(--r-md); color:var(--og-ink-soft); text-decoration:none; font-size:var(--t-sm); font-weight:600; transition:background .2s var(--og-ease), color .2s var(--og-ease); }
.og-wcats li a:hover{ background:var(--og-surface-2); color:var(--og-emerald); }
.og-wcats li.is-active a{ background:rgba(0,86,63,.08); color:var(--og-emerald); }
.og-wcats__count{ flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center; min-width:26px; line-height:1; padding:5px 9px; border-radius:var(--r-pill); background:var(--og-surface-2); color:var(--og-muted); font-size:var(--t-xs); font-weight:700; transition:background .2s var(--og-ease), color .2s var(--og-ease); }
.og-wcats li a:hover .og-wcats__count, .og-wcats li.is-active .og-wcats__count{ background:var(--og-emerald); color:#fff; }
/* courses CTA */
.og-widget--cta{ background:linear-gradient(160deg,var(--og-emerald-700),var(--og-emerald)); border:0 !important; color:#fff; text-align:center; position:relative; overflow:hidden; }
.og-widget--cta::after{ content:""; position:absolute; inset-block-start:-50%; inset-inline-end:-22%; width:180px; height:180px; border-radius:50%; background:radial-gradient(circle,rgba(240,227,178,.16),transparent 70%); }
.og-widget__cta-eyebrow{ position:relative; display:inline-block; font-size:var(--t-xs); font-weight:700; color:var(--og-gold-soft); letter-spacing:.04em; margin-bottom:8px; }
.og-widget__cta-title{ position:relative; margin:0 0 8px; font-size:1.05rem; font-weight:800; line-height:1.6; color:#fff; }
.og-widget__cta-text{ position:relative; margin:0 0 16px; font-size:var(--t-sm); line-height:1.9; color:rgba(255,255,255,.86); }
.og-widget--cta .og-btn{ position:relative; width:100%; justify-content:center; }

/* ========================= Shop / archive ========================= */
.og-shop{ background:var(--og-bg); padding-block:clamp(24px,4vw,52px); }
.og-shop__head{ margin-bottom:clamp(20px,3vw,32px); }
.og-shop__title{ font-size:var(--t-2xl); font-weight:800; color:var(--og-ink); margin:0 0 10px; line-height:1.4; }
.og-shop__layout{ display:grid; grid-template-columns:300px minmax(0,1fr); grid-template-areas:"side main"; gap:clamp(20px,3vw,38px); align-items:start; }
.og-shop__side{ grid-area:side; position:sticky; top:96px; }
.og-shop__main{ grid-area:main; min-width:0; }
@media (max-width:991px){
  .og-shop__layout{ grid-template-columns:1fr; grid-template-areas:"main" "side"; }
  .og-shop__side{ position:static; }
}
.og-shop__bar{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-bottom:22px; padding:12px 18px; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-md); box-shadow:var(--og-shadow-1); }
.og-shop__bar .woocommerce-result-count{ margin:0 !important; color:var(--og-muted); font-size:var(--t-sm); }
.og-shop__bar .woocommerce-ordering{ margin:0 !important; }
.og-shop__bar .woocommerce-ordering select{ margin:0; border-radius:10px; border:1.5px solid var(--og-line); padding:8px 12px; }

/* ===================== Course card (shop + related) ===================== */
.og-course-card{ display:flex; flex-direction:column; overflow:hidden; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); transition:transform .4s var(--og-ease-out), box-shadow .4s var(--og-ease-out); }
.og-course-card:hover{ transform:translateY(-8px); box-shadow:var(--og-shadow-3); }
.og-course-card__media{ position:relative; display:block; aspect-ratio:5/3.3; overflow:hidden; background:var(--og-surface-2); }
.og-course-card__media img, .og-course-card__img{ position:absolute; inset:0; z-index:1; width:100%; height:100%; object-fit:cover; transition:transform .6s var(--og-ease-out); }
.og-course-card:hover .og-course-card__media img{ transform:scale(1.07); }
.og-course-card__badge, .og-course-card__play{ z-index:2; }
.og-course-card__ph{ position:absolute; inset:0; background:linear-gradient(135deg,var(--og-surface-2),#e3ebe6); }
.og-course-card__badge{ position:absolute; inset-block-start:12px; inset-inline-start:12px; background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); color:var(--og-emerald-700); font-weight:800; font-size:var(--t-xs); padding:5px 11px; border-radius:var(--r-pill); box-shadow:0 6px 14px -5px rgba(217,192,116,.8); }
.og-course-card__play{ position:absolute; inset-block-end:12px; inset-inline-end:12px; width:42px; height:42px; display:grid; place-items:center; border-radius:50%; background:rgba(255,255,255,.94); color:var(--og-emerald); box-shadow:var(--og-shadow-2); }
.og-course-card__body{ display:flex; flex-direction:column; gap:9px; padding:16px; flex:1; }
.og-course-card__teacher{ font-size:var(--t-xs); color:var(--og-muted); font-weight:600; }
.og-course-card__teacher i{ color:var(--og-emerald); margin-inline-end:4px; }
.og-course-card__title{ font-size:var(--t-lg); font-weight:800; line-height:1.7; margin:0; }
.og-course-card__title a{ color:var(--og-ink); text-decoration:none; }
.og-course-card__title a:hover{ color:var(--og-emerald); }
.og-course-card__excerpt{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.95; margin:0; flex:1; }
.og-course-card__meta{ display:flex; gap:16px; font-size:var(--t-xs); color:var(--og-muted); }
.og-course-card__rating i{ color:var(--og-gold-deep); margin-inline-end:3px; }
.og-course-card__sales i{ color:var(--og-emerald-300); margin-inline-end:3px; }
.og-course-card__foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top:14px; margin-top:auto; border-top:1px solid var(--og-line-soft); }
.og-course-card__price{ font-weight:800; color:var(--og-emerald); font-size:var(--t-base); }
.og-course-card__price del{ color:var(--og-muted); font-weight:500; font-size:.82em; }
.og-course-card__price ins{ text-decoration:none; }
.og-course-card__cta{ padding:9px 15px; font-size:var(--t-xs); white-space:nowrap; }

/* ===================== Single course page ===================== */
.og-course{ background:var(--og-bg); padding-bottom:clamp(30px,5vw,60px); }
.og-course__hero{ background:linear-gradient(160deg,var(--og-emerald-700),var(--og-emerald)); color:#fff; padding-block:clamp(28px,4vw,56px) clamp(56px,7vw,90px); position:relative; overflow:hidden; }
.og-course__hero::after{ content:""; position:absolute; inset-block-start:-50%; inset-inline-start:-6%; width:360px; height:360px; border-radius:50%; background:radial-gradient(circle,rgba(240,227,178,.13),transparent 70%); }
.og-course__hero-inner{ position:relative; }
.og-course__crumb{ font-size:var(--t-xs); opacity:.85; margin-bottom:12px; }
.og-course__crumb a{ color:var(--og-gold-soft); text-decoration:none; }
.og-course__crumb a:hover{ color:#fff; }
.og-course__title{ font-size:var(--t-3xl); font-weight:800; line-height:1.5; margin:0 0 14px; max-width:880px; }
.og-course__hero-meta{ display:flex; flex-wrap:wrap; gap:10px 22px; font-size:var(--t-sm); color:rgba(255,255,255,.85); }
.og-course__hero-meta i{ color:var(--og-gold); margin-inline-end:5px; }
.og-course__layout{ display:grid; grid-template-columns:360px minmax(0,1fr); grid-template-areas:"buy main"; gap:clamp(20px,3vw,40px); align-items:start; margin-top:clamp(-60px,-5vw,-44px); position:relative; z-index:2; }
.og-course__buy{ grid-area:buy; position:sticky; top:90px; }
.og-course__main{ grid-area:main; min-width:0; }
@media (max-width:991px){
  .og-course__layout{ grid-template-columns:1fr; grid-template-areas:"main" "buy"; margin-top:18px; }
  .og-course__buy{ position:static; }
}
.og-course__media{ border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--og-shadow-2); margin-bottom:24px; background:#fff; }
.og-course__media figure{ margin:0; }
.og-course__media img, .og-course__media video, .og-course__media .wp-video{ width:100% !important; height:auto; display:block; }
.og-course__content{ background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-xl); padding:clamp(20px,2.5vw,34px); box-shadow:var(--og-shadow-1); margin-bottom:24px; }
.og-course__content .product-content{ line-height:2.1; }
.og-course__exam{ padding:24px; margin-top:24px; }
.og-course__exam-title{ font-weight:800; color:var(--og-emerald); margin:0 0 16px; }

/* purchase box (reused parent product-sidebar.php) → premium sticky card */
.og-course__buy .product-sidebar, .og-course__buy .single-sidebar{ float:none !important; width:auto !important; margin:0 !important; }
.og-course__buy .product-sidebar-widget{
  background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-xl);
  padding:22px; box-shadow:var(--og-shadow-2); margin-bottom:18px; position:relative; overflow:hidden;
}
.og-course__buy .product-sidebar-widget::before{ content:""; position:absolute; inset-block-start:0; inset-inline:0; height:5px; background:linear-gradient(90deg,var(--og-emerald),var(--og-gold-deep)); }
.og-course__buy .product-prices{ margin:6px 0 4px; }
.og-course__buy .product-prices .price{ color:var(--og-emerald) !important; font-weight:800 !important; font-size:var(--t-xl) !important; }
.og-course__buy .product-prices .price del{ color:var(--og-muted) !important; font-size:.6em; }
.og-course__buy .pay-button, .og-course__buy .installment-button{
  display:flex; align-items:center; justify-content:center; gap:8px; width:100%;
  padding:14px 18px; border-radius:14px; font-weight:800; margin-top:12px; text-decoration:none;
  transition:transform .25s var(--og-ease), box-shadow .3s var(--og-ease);
}
.og-course__buy .pay-button{ background:linear-gradient(180deg,var(--og-emerald-600),var(--og-emerald)) !important; color:#fff !important; box-shadow:0 12px 24px -10px rgba(0,86,63,.6); }
.og-course__buy .pay-button:hover{ transform:translateY(-2px); }
.og-course__buy .installment-button{ background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)) !important; color:var(--og-emerald-700) !important; }
.og-course__buy .product-capacity{ background:rgba(0,86,63,.06); color:var(--og-emerald-700); border-radius:10px; padding:9px 12px; font-size:var(--t-sm); margin-top:12px; text-align:center; }
.og-course__buy .product-author-box{ display:flex; align-items:center; gap:12px; margin-top:16px; padding-top:16px; border-top:1px solid var(--og-line-soft); }
.og-course__buy .product-author-box img{ width:52px; height:52px; border-radius:50%; object-fit:cover; flex:0 0 auto; }
.og-course__buy .author-name{ font-weight:700; color:var(--og-ink); }
.og-course__buy .author-job{ font-size:var(--t-xs); color:var(--og-muted); }
.og-course__buy .product-information{ display:flex; justify-content:space-between; gap:10px; padding:9px 0; border-bottom:1px solid var(--og-line-soft); font-size:var(--t-sm); color:var(--og-muted); }
.og-course__buy .product-information span{ color:var(--og-ink-soft); font-weight:600; }
.og-course__buy .view-statistics{ display:flex; gap:18px; color:var(--og-muted); font-size:var(--t-sm); }
.og-course__buy .view-statistics i{ color:var(--og-emerald); margin-inline-end:4px; }
.og-course__buy .sale-count{ display:flex; justify-content:space-between; gap:12px; margin-top:14px; }
.og-course__buy .number-sale{ font-weight:800; color:var(--og-emerald); }
.og-course__buy .social-share-box a{ display:inline-grid; place-items:center; width:36px; height:36px; border-radius:50%; background:rgba(0,86,63,.08); color:var(--og-emerald); margin-inline-start:6px; transition:all .2s var(--og-ease); }
.og-course__buy .social-share-box a:hover{ background:var(--og-emerald); color:#fff; }
.og-course__related{ margin-top:10px; }

/* ============================== Coded HOME ============================== */
.og-home{ background:var(--og-bg); overflow:hidden; }
.og-eyebrow--light{ color:var(--og-gold-soft); }
.og-eyebrow--light::before{ background:var(--og-gold); }

.og-hero{ background:
    radial-gradient(55% 75% at 10% 112%, rgba(0,70,50,.6), transparent 60%),
    linear-gradient(155deg,var(--og-emerald-700) 0%,var(--og-emerald) 55%,var(--og-emerald-500) 100%);
  color:#fff; position:relative; overflow:hidden; padding-block:clamp(44px,6vw,96px); }
.og-hero::before{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none; background-image:radial-gradient(rgba(255,255,255,.05) 1.1px, transparent 1.1px); background-size:24px 24px; -webkit-mask:linear-gradient(180deg,#000,transparent 85%); mask:linear-gradient(180deg,#000,transparent 85%); }
.og-hero::after{ content:""; position:absolute; inset-block-start:-30%; inset-inline-end:-8%; width:560px; height:560px; border-radius:50%; background:radial-gradient(circle,rgba(240,227,178,.14),transparent 65%); pointer-events:none; }
.og-hero__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,60px); align-items:center; position:relative; z-index:2; }
@media (max-width:900px){ .og-hero__grid{ grid-template-columns:1fr; } .og-hero__visual{ order:-1; } }
.og-hero__title{ font-size:var(--t-3xl); font-weight:900; line-height:1.4; margin:14px 0 16px; letter-spacing:-.01em; }
.og-hero__title em{ font-style:normal; color:var(--og-gold); text-shadow:0 2px 24px rgba(240,227,178,.32); }
.og-hero__sub{ font-size:var(--t-lg); line-height:2; color:rgba(255,255,255,.86); max-width:52ch; margin:0 0 24px; }
.og-hero__cta{ display:flex; gap:12px; flex-wrap:wrap; }
.og-hero__trust{ list-style:none; padding:0; margin:28px 0 0; display:flex; flex-wrap:wrap; gap:10px; font-size:var(--t-sm); }
.og-hero__trust li{ display:inline-flex; align-items:center; gap:7px; color:#fff; background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.17); padding:8px 15px; border-radius:var(--r-pill); backdrop-filter:blur(4px); transition:background .25s var(--og-ease), border-color .25s var(--og-ease); }
.og-hero__trust li:hover{ background:rgba(240,227,178,.16); border-color:rgba(240,227,178,.4); }
.og-hero__trust i{ color:var(--og-gold); }
.og-hero__visual{ position:relative; display:grid; place-items:center; min-height:340px; }
.og-hero__visual::before{ content:""; position:absolute; width:74%; aspect-ratio:1; border-radius:50%; background:radial-gradient(circle, rgba(240,227,178,.22), transparent 68%); filter:blur(18px); pointer-events:none; }
.og-hero__rings{ position:absolute; inset:0; margin:auto; width:min(440px,94%); aspect-ratio:1; border-radius:50%;
  background:repeating-radial-gradient(circle at center, transparent 0 25px, rgba(240,227,178,.18) 25px 28px);
  -webkit-mask:radial-gradient(circle at center,#000 56%,transparent 74%); mask:radial-gradient(circle at center,#000 56%,transparent 74%);
  animation:og-hero-breathe 7s var(--og-ease) infinite; }
@keyframes og-hero-breathe{ 0%,100%{ transform:scale(1); opacity:.82; } 50%{ transform:scale(1.045); opacity:1; } }
@media (prefers-reduced-motion:reduce){ .og-hero__rings{ animation:none; } }
.og-hero__card{ position:relative; z-index:2; display:block; width:min(330px,88%); background:#fff; color:var(--og-ink); border-radius:var(--r-xl); overflow:hidden; box-shadow:0 36px 80px -28px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.4) inset; text-decoration:none; transform:rotate(-2.2deg); transition:transform .45s var(--og-ease-out), box-shadow .45s var(--og-ease-out); }
.og-hero__card:hover{ transform:rotate(0) translateY(-6px); box-shadow:0 44px 92px -28px rgba(0,0,0,.6); }
.og-hero__card-media{ position:relative; aspect-ratio:16/10; overflow:hidden; background:linear-gradient(135deg,var(--og-surface-2),#dfe9e3); }
.og-hero__card-media img{ width:100%; height:100%; object-fit:cover; }
.og-hero__card-media::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(180deg,transparent 58%,rgba(0,40,28,.16)); pointer-events:none; }
.og-hero__card-tag{ position:absolute; z-index:2; inset-block-start:10px; inset-inline-start:10px; background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); color:var(--og-emerald-700); font-size:var(--t-xs); font-weight:800; padding:5px 12px; border-radius:var(--r-pill); box-shadow:0 6px 16px -6px rgba(217,192,116,.85); }
.og-hero__card-cap{ position:absolute; z-index:2; inset-inline:0; inset-block-end:0; padding:32px 14px 12px; background:linear-gradient(180deg,transparent,rgba(0,38,27,.9)); }
.og-hero__card-title{ display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; color:#fff; font-size:var(--t-base); font-weight:800; line-height:1.55; }
.og-hero__card-body{ padding:13px 16px; display:flex; align-items:center; justify-content:space-between; gap:10px 12px; flex-wrap:wrap; }
.og-hero__card-price{ color:var(--og-emerald); font-weight:800; font-size:var(--t-lg); white-space:nowrap; }
.og-hero__card-cta{ display:inline-flex; align-items:center; gap:6px; color:var(--og-emerald); font-weight:700; font-size:var(--t-sm); white-space:nowrap; }
.og-hero__card-cta i{ transition:transform .25s var(--og-ease-out); }
.og-hero__card:hover .og-hero__card-cta i{ transform:translateX(-4px); }

.og-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; padding:clamp(20px,3vw,30px); }
@media (max-width:600px){ .og-stats{ grid-template-columns:repeat(2,1fr); } }
.og-stats .og-stat{ border-inline-end:1px solid var(--og-line-soft); }
.og-stats .og-stat:last-child{ border-inline-end:none; }
@media (max-width:600px){ .og-stats .og-stat{ border-inline-end:none; } }

.og-cats-sec, .og-articles-sec{ background:var(--og-bg); }
.og-cat-card{ display:flex; flex-direction:column; align-items:flex-start; gap:8px; padding:22px; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); text-decoration:none; transition:transform .35s var(--og-ease-out), box-shadow .35s var(--og-ease-out); }
.og-cat-card:hover{ transform:translateY(-6px); box-shadow:var(--og-shadow-2); }
.og-cat-card:hover .og-icon-circle{ background:var(--og-emerald); color:#fff; }
.og-cat-card__name{ font-weight:800; color:var(--og-ink); font-size:var(--t-lg); }
.og-cat-card__count{ font-size:var(--t-sm); color:var(--og-muted); }
.og-icon-circle{ transition:background-color .3s var(--og-ease), color .3s var(--og-ease); }

.og-feature{ padding:24px; display:flex; flex-direction:column; gap:10px; }
.og-feature__title{ font-weight:800; color:var(--og-ink); font-size:var(--t-lg); margin:0; }
.og-feature__desc{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.95; margin:0; }

.og-cta-band{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.og-cta-band__text p{ margin:8px 0 0; color:rgba(255,255,255,.85); line-height:1.9; }

/* ========================= Coded footer (.og-foot) ========================= */
.og-coded-footer{ position:relative; margin-top:auto; }
.og-foot{ background:radial-gradient(60% 80% at 88% -10%, rgba(240,227,178,.08), transparent 60%), linear-gradient(180deg,var(--og-emerald-700),var(--og-emerald) 72%); color:#fff; position:relative; overflow:hidden; }
.og-foot::before{ content:""; position:absolute; inset:0; pointer-events:none; background-image:radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px); background-size:24px 24px; -webkit-mask:linear-gradient(180deg,#000,transparent 70%); mask:linear-gradient(180deg,#000,transparent 70%); }
.og-foot__wrap{ width:min(100% - 40px, 1240px); margin-inline:auto; position:relative; z-index:1; }
.og-foot__main{ padding-block:clamp(40px,5vw,64px) clamp(28px,3vw,40px); }
.og-foot__main .og-foot__wrap{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.4fr; gap:clamp(24px,3vw,48px); }
@media (max-width:980px){ .og-foot__main .og-foot__wrap{ grid-template-columns:1fr 1fr; gap:34px 28px; } }
@media (max-width:560px){ .og-foot__main .og-foot__wrap{ grid-template-columns:1fr; } }
.og-foot__logo img{ height:50px; width:auto; display:block; filter:brightness(0) invert(1); margin-bottom:16px; }
.og-foot__tagline{ color:rgba(255,255,255,.78); line-height:2.1; font-size:var(--t-sm); margin:0 0 18px; max-width:36ch; }
.og-foot__socials{ display:flex; gap:9px; flex-wrap:wrap; }
.og-foot__socials a{ display:inline-grid; place-items:center; width:38px; height:38px; border-radius:11px; background:rgba(255,255,255,.1); color:#fff; font-size:16px; transition:background .25s var(--og-ease), color .25s var(--og-ease), transform .25s var(--og-ease); }
.og-foot__socials a:hover{ background:var(--og-gold); color:var(--og-emerald-700); transform:translateY(-3px); }
.og-foot__title{ font-size:1.05rem; font-weight:800; color:#fff; margin:0 0 18px; position:relative; padding-bottom:12px; }
.og-foot__title::after{ content:""; position:absolute; inset-block-end:0; inset-inline-start:0; width:38px; height:3px; border-radius:3px; background:linear-gradient(90deg,var(--og-gold),var(--og-gold-deep)); }
.og-foot__links{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.og-foot__links a{ color:rgba(255,255,255,.8); text-decoration:none; font-size:var(--t-sm); font-weight:500; display:inline-flex; align-items:center; gap:8px; transition:color .22s var(--og-ease), padding-inline-start .22s var(--og-ease); }
.og-foot__links a::before{ content:"\f104"; font-family:"Font Awesome 6 Free","Font Awesome 5 Free"; font-weight:900; font-size:.7em; color:var(--og-gold); opacity:0; transform:translateX(6px); transition:opacity .22s var(--og-ease), transform .22s var(--og-ease); }
.og-foot__links a:hover{ color:var(--og-gold); padding-inline-start:4px; }
.og-foot__links a:hover::before{ opacity:1; transform:translateX(0); }
.og-foot__info{ list-style:none; margin:0 0 20px; padding:0; display:flex; flex-direction:column; gap:13px; }
.og-foot__info li, .og-foot__info a{ display:flex; align-items:flex-start; gap:10px; color:rgba(255,255,255,.82); text-decoration:none; font-size:var(--t-sm); line-height:1.8; }
.og-foot__info li span, .og-foot__info a span{ min-width:0; overflow-wrap:anywhere; }
.og-foot__info a:hover{ color:var(--og-gold); }
.og-foot__info i{ color:var(--og-gold); margin-top:5px; flex:0 0 auto; width:16px; text-align:center; }
.og-foot__cta{ display:flex; gap:10px; flex-wrap:wrap; }
.og-foot__cta .og-btn{ flex:1 1 auto; justify-content:center; min-width:120px; }
.og-foot__ticket{ background:rgba(255,255,255,.12) !important; color:#fff !important; border:1px solid rgba(255,255,255,.22); }
.og-foot__ticket:hover{ background:rgba(255,255,255,.2) !important; }
.og-foot__bottom{ border-top:1px solid rgba(255,255,255,.12); background:rgba(0,0,0,.12); }
.og-foot__bottom-wrap{ display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; padding-block:18px; }
.og-foot__copy{ margin:0; color:rgba(255,255,255,.72); font-size:var(--t-sm); line-height:1.9; }
.og-foot__copy strong{ color:var(--og-gold-soft); font-weight:700; }
.og-foot__badges{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.og-foot__badge{ display:inline-grid; place-items:center; height:60px; min-width:56px; padding:6px 10px; background:#fff; border-radius:12px; transition:transform .25s var(--og-ease); }
.og-foot__badge:hover{ transform:translateY(-3px); }
.og-foot__badge img{ max-height:46px; max-width:120px; width:auto; display:block; object-fit:contain; }
.og-totop{ position:fixed; bottom:24px; right:24px; z-index:120; width:46px; height:46px; border:0; border-radius:50%; background:linear-gradient(180deg,var(--og-emerald-600),var(--og-emerald)); color:#fff; font-size:17px; cursor:pointer; box-shadow:0 12px 28px -10px rgba(0,86,63,.7); opacity:0; visibility:hidden; transform:translateY(12px); transition:opacity .3s var(--og-ease), transform .3s var(--og-ease), visibility .3s; }
.og-totop.is-on{ opacity:1; visibility:visible; transform:translateY(0); }
.og-totop:hover{ filter:brightness(1.08); }
@media (max-width:992px){ .og-totop{ bottom:78px; } }

/* ---- footer polish ---- */
.og-coded-footer::before{ content:""; position:absolute; inset-block-start:0; inset-inline:0; height:3px; z-index:3; background:linear-gradient(90deg,var(--og-gold-deep),var(--og-gold) 28%,var(--og-emerald-500) 50%,var(--og-gold) 72%,var(--og-gold-deep)); }
.og-foot{ background:radial-gradient(50% 70% at 92% -12%, rgba(240,227,178,.1), transparent 60%), radial-gradient(46% 64% at 4% 110%, rgba(0,86,63,.55), transparent 60%), linear-gradient(180deg,var(--og-emerald-700),var(--og-emerald) 74%); }
.og-foot__main .og-foot__wrap{ grid-template-columns:1.6fr 1fr 1fr 1.5fr; align-items:stretch; }
@media (max-width:980px){ .og-foot__main .og-foot__wrap{ grid-template-columns:1fr 1fr; } .og-foot__brand{ grid-column:1 / -1; } }
@media (max-width:560px){ .og-foot__main .og-foot__wrap{ grid-template-columns:1fr; } }
.og-foot__contact{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-xl); padding:26px 24px; display:flex; flex-direction:column; box-shadow:0 24px 60px -36px rgba(0,0,0,.6); }
.og-foot__contact .og-foot__cta{ margin-top:auto; padding-top:10px; }
.og-foot__socials a{ width:40px; height:40px; font-size:17px; }
.og-foot__badge{ height:62px; }
.og-foot__badges-label{ color:rgba(255,255,255,.55); font-size:var(--t-xs); font-weight:600; align-self:center; margin-inline-end:4px; }
@media (max-width:560px){ .og-foot__contact{ padding:22px 18px; } .og-foot__bottom-wrap{ flex-direction:column; align-items:flex-start; gap:16px; } }

/* ===================== Homepage: hero slider ===================== */
.og-hsl{ position:relative; color:#fff; overflow:hidden; background:
    radial-gradient(55% 75% at 10% 112%, rgba(0,70,50,.6), transparent 60%),
    linear-gradient(155deg,var(--og-emerald-700) 0%,var(--og-emerald) 55%,var(--og-emerald-500) 100%); }
.og-hsl::before{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none; background-image:radial-gradient(rgba(255,255,255,.05) 1.1px,transparent 1.1px); background-size:24px 24px; -webkit-mask:linear-gradient(180deg,#000,transparent 85%); mask:linear-gradient(180deg,#000,transparent 85%); }
.og-hsl__track{ display:grid; }
/* Only the active slide is ever visible (others instantly hidden — no text-over-text crossfade). */
.og-hsl__slide{ grid-area:1/1; opacity:0; visibility:hidden; }
.og-hsl__slide.is-active{ opacity:1; visibility:visible; animation:ogHeroIn .6s var(--og-ease-out) both; }
@keyframes ogHeroIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .og-hsl__slide.is-active{ animation:none; } }
.og-hsl__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,60px); align-items:center; padding-block:clamp(46px,6vw,92px); position:relative; z-index:2; }
@media (max-width:900px){ .og-hsl__grid{ grid-template-columns:1fr; } .og-hsl__visual{ display:none; } }
.og-hsl__title{ font-size:var(--t-3xl); font-weight:900; line-height:1.4; margin:12px 0 14px; letter-spacing:-.01em; color:#fff; }
.og-hsl__sub{ font-size:var(--t-lg); line-height:2; color:rgba(255,255,255,.86); max-width:52ch; margin:0 0 18px; }
.og-hsl__points{ list-style:none; padding:0; margin:0 0 24px; display:flex; flex-wrap:wrap; gap:10px; }
.og-hsl__points li{ display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.16); padding:8px 14px; border-radius:var(--r-pill); font-size:var(--t-sm); backdrop-filter:blur(4px); }
.og-hsl__points i{ color:var(--og-gold); }
.og-hsl__cta{ display:flex; gap:12px; flex-wrap:wrap; }
.og-hsl__visual{ position:relative; display:grid; place-items:center; min-height:300px; }
.og-hsl__rings{ position:absolute; inset:0; margin:auto; width:min(420px,90%); aspect-ratio:1; border-radius:50%; background:repeating-radial-gradient(circle at center, transparent 0 25px, rgba(240,227,178,.18) 25px 28px); -webkit-mask:radial-gradient(circle at center,#000 56%,transparent 74%); mask:radial-gradient(circle at center,#000 56%,transparent 74%); }
.og-hsl__badge{ position:relative; z-index:2; width:clamp(140px,18vw,196px); aspect-ratio:1; border-radius:50%; display:grid; place-items:center; font-size:clamp(40px,6vw,64px); font-weight:900; letter-spacing:.02em; color:var(--og-emerald-700); background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); box-shadow:0 30px 70px -24px rgba(0,0,0,.5); }
.og-hsl__dots{ position:absolute; inset-block-end:18px; inset-inline:0; z-index:5; display:flex; justify-content:center; gap:9px; }
.og-hsl__dot{ width:9px; height:9px; padding:0; border:0; border-radius:50%; background:rgba(255,255,255,.35); cursor:pointer; transition:all .3s var(--og-ease); }
.og-hsl__dot.is-active{ background:var(--og-gold); width:26px; border-radius:5px; }
.og-hsl__nav{ position:absolute; inset-block-start:50%; transform:translateY(-50%); z-index:5; width:46px; height:46px; border:0; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; cursor:pointer; display:grid; place-items:center; font-size:16px; transition:background .25s var(--og-ease); }
.og-hsl__nav:hover{ background:rgba(255,255,255,.22); }
/* RTL: prev (chevron-right →) sits on the RIGHT, next (chevron-left ←) on the LEFT — arrows point outward. */
.og-hsl__nav--prev{ inset-inline-start:14px; } .og-hsl__nav--next{ inset-inline-end:14px; }
@media (max-width:680px){ .og-hsl__nav{ display:none; } }

/* ===================== Homepage: welcome ===================== */
.og-welcome__grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(28px,4vw,56px); align-items:center; }
@media (max-width:880px){ .og-welcome__grid{ grid-template-columns:1fr; } }
.og-welcome__text p{ color:var(--og-ink-soft); line-height:2.15; margin:0 0 14px; }
.og-welcome__text strong{ color:var(--og-emerald); font-weight:700; }
.og-welcome__text .og-btn{ margin-top:8px; }
.og-welcome__stats{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.og-welcome__stat{ background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); padding:24px 18px; text-align:center; box-shadow:var(--og-shadow-1); }
.og-welcome__stat strong{ display:block; font-size:var(--t-xl); font-weight:900; color:var(--og-emerald); margin-bottom:6px; }
.og-welcome__stat span{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.7; }

/* ===================== Homepage: departments ===================== */
.og-depts-sec{ background:var(--og-bg); }
.og-dept{ display:flex; flex-direction:column; align-items:flex-start; gap:11px; padding:24px; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); text-decoration:none; transition:transform .35s var(--og-ease-out), box-shadow .35s var(--og-ease-out); }
.og-dept:hover{ transform:translateY(-6px); box-shadow:var(--og-shadow-2); }
.og-dept:hover .og-icon-circle{ background:var(--og-emerald); color:#fff; }
.og-dept__name{ font-weight:800; color:var(--og-ink); font-size:var(--t-lg); }
.og-dept__desc{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.95; flex:1; }
.og-dept__more{ display:inline-flex; align-items:center; gap:6px; color:var(--og-emerald); font-weight:700; font-size:var(--t-sm); transition:gap .25s var(--og-ease); }
.og-dept:hover .og-dept__more{ gap:11px; }

/* ===================== Homepage: testimonials band ===================== */
.og-testi__inner{ background:linear-gradient(160deg,var(--og-emerald-700),var(--og-emerald) 55%,var(--og-gold-deep)); color:#fff; border-radius:var(--r-2xl); padding:clamp(34px,5vw,64px); text-align:center; position:relative; overflow:hidden; }
.og-testi__inner::after{ content:""; position:absolute; inset-block-start:-30%; inset-inline-end:-8%; width:380px; height:380px; border-radius:50%; background:radial-gradient(circle,rgba(240,227,178,.16),transparent 65%); pointer-events:none; }
.og-testi__inner > *{ position:relative; z-index:1; }
.og-testi__inner .og-title{ color:#fff; }
.og-testi__inner .og-title em{ color:var(--og-gold); } /* gold accent — emerald em would vanish on the band */
.og-testi__inner p{ max-width:60ch; margin:14px auto 24px; line-height:2; color:rgba(255,255,255,.88); }
.og-testi__cta{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
/* tighten the stacked section padding between the band and the articles below */
.og-testi{ padding-block-end:clamp(28px,4vw,48px); }
/* Footer wrapper: the theme's .footer-elementor default is slate #34495E with
   51px top padding — that strip showed above the emerald .og-foot. Match emerald
   and drop the top padding so the footer reads as one solid block. */
footer.footer-elementor.og-coded-footer{ background:var(--og-emerald-700) !important; padding-top:0 !important; }

/* ===================== Course landing pages ===================== */
.og-lhero{ position:relative; color:#fff; overflow:hidden; background:
    radial-gradient(55% 75% at 10% 112%, rgba(0,70,50,.6), transparent 60%),
    linear-gradient(155deg,var(--og-emerald-700) 0%,var(--og-emerald) 55%,var(--og-emerald-500) 100%); }
.og-lhero::before{ content:""; position:absolute; inset:0; pointer-events:none; background-image:radial-gradient(rgba(255,255,255,.05) 1.1px,transparent 1.1px); background-size:24px 24px; -webkit-mask:linear-gradient(180deg,#000,transparent 85%); mask:linear-gradient(180deg,#000,transparent 85%); }
.og-lhero__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,60px); align-items:center; padding-block:clamp(44px,6vw,88px); }
@media (max-width:900px){ .og-lhero__grid{ grid-template-columns:1fr; } .og-lhero__visual{ display:none; } }
.og-lhero__title{ font-size:var(--t-3xl); font-weight:900; line-height:1.45; margin:12px 0 14px; letter-spacing:-.01em; color:#fff; }
.og-lhero__lead{ font-size:var(--t-lg); line-height:2; color:rgba(255,255,255,.88); max-width:54ch; margin:0 0 18px; }
.og-lhero__facts{ list-style:none; padding:0; margin:0 0 24px; display:flex; flex-wrap:wrap; gap:10px; }
.og-lhero__facts li{ display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.16); padding:8px 14px; border-radius:var(--r-pill); font-size:var(--t-sm); }
.og-lhero__facts i{ color:var(--og-gold); }
.og-lhero__cta{ display:flex; gap:12px; flex-wrap:wrap; }
.og-lhero__visual{ position:relative; display:grid; place-items:center; min-height:280px; }
.og-lhero__rings{ position:absolute; inset:0; margin:auto; width:min(400px,90%); aspect-ratio:1; border-radius:50%; background:repeating-radial-gradient(circle at center, transparent 0 25px, rgba(240,227,178,.18) 25px 28px); -webkit-mask:radial-gradient(circle at center,#000 56%,transparent 74%); mask:radial-gradient(circle at center,#000 56%,transparent 74%); }
.og-lhero__badge{ position:relative; z-index:2; width:clamp(130px,16vw,180px); aspect-ratio:1; border-radius:50%; display:grid; place-items:center; font-size:clamp(38px,5vw,60px); font-weight:900; letter-spacing:.02em; color:var(--og-emerald-700); background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); box-shadow:0 30px 70px -24px rgba(0,0,0,.5); }

.og-land__grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(26px,3.5vw,50px); align-items:start; }
@media (max-width:920px){ .og-land__grid{ grid-template-columns:1fr; } }
.og-land__intro p{ color:var(--og-ink-soft); line-height:2.15; margin:0 0 14px; }
.og-syllabus{ padding:clamp(22px,3vw,30px); position:sticky; top:90px; }
@media (max-width:920px){ .og-syllabus{ position:static; } }
.og-syllabus__title{ display:flex; align-items:center; gap:9px; font-size:var(--t-lg); font-weight:800; color:var(--og-emerald); margin:0 0 16px; padding-bottom:14px; border-bottom:1px solid var(--og-line-soft); }
.og-syllabus__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.og-syllabus__list li{ display:flex; gap:10px; align-items:flex-start; font-size:var(--t-sm); line-height:1.85; color:var(--og-ink-soft); }
.og-syllabus__list i{ color:var(--og-gold-deep); margin-top:5px; flex-shrink:0; }

.og-levels-sec{ background:var(--og-bg); }
.og-level{ display:flex; flex-direction:column; align-items:flex-start; gap:11px; padding:24px; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); position:relative; overflow:hidden; transition:transform .35s var(--og-ease-out), box-shadow .35s var(--og-ease-out); }
.og-level::before{ content:""; position:absolute; inset-block-start:0; inset-inline-end:0; width:66px; height:66px; background:radial-gradient(circle at top left, rgba(240,227,178,.45), transparent 70%); }
.og-level:hover{ transform:translateY(-5px); box-shadow:var(--og-shadow-2); }
.og-level__badge{ display:inline-flex; align-items:center; background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); color:var(--og-emerald-700); font-weight:800; font-size:var(--t-sm); padding:6px 14px; border-radius:var(--r-pill); position:relative; z-index:1; }
.og-level__book{ font-size:var(--t-lg); font-weight:800; color:var(--og-ink); }
.og-level__terms{ display:inline-flex; align-items:center; gap:7px; font-size:var(--t-sm); color:var(--og-muted); font-weight:600; }
.og-level__terms i{ color:var(--og-emerald); }
.og-levels__note{ margin:22px 0 0; display:flex; align-items:center; gap:10px; background:rgba(0,86,63,.06); border:1px solid rgba(0,86,63,.14); border-radius:var(--r-md); padding:16px 20px; color:var(--og-emerald); font-weight:600; line-height:1.8; }
.og-levels__note i{ color:var(--og-emerald); flex-shrink:0; }

.og-land-cta{ display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; background:linear-gradient(160deg,var(--og-emerald-700),var(--og-emerald) 60%,var(--og-gold-deep)); color:#fff; border-radius:var(--r-2xl); padding:clamp(28px,4vw,48px); position:relative; overflow:hidden; }
.og-land-cta::after{ content:""; position:absolute; inset-block-start:-40%; inset-inline-end:-5%; width:340px; height:340px; border-radius:50%; background:radial-gradient(circle,rgba(240,227,178,.16),transparent 65%); pointer-events:none; }
.og-land-cta > *{ position:relative; z-index:1; }
.og-land-cta .og-title{ color:#fff; margin:0 0 6px; }
.og-land-cta__text p{ color:rgba(255,255,255,.88); margin:0; line-height:1.9; max-width:52ch; }
.og-land-cta__btns{ display:flex; gap:12px; flex-wrap:wrap; }

/* ===================== Service pages ===================== */
.og-lhero__badge--icon{ font-size:clamp(46px,6vw,72px); }
.og-svc__intro{ max-width:840px; }
.og-svc__intro p{ color:var(--og-ink-soft); line-height:2.15; margin:0 0 14px; }
.og-svc-block{ padding:clamp(24px,3vw,34px); }
.og-svc-block__title{ display:flex; align-items:center; gap:10px; font-size:var(--t-xl); font-weight:800; color:var(--og-emerald); margin:0 0 14px; }
.og-svc-block p{ color:var(--og-ink-soft); line-height:2.1; margin:0; }
.og-svc-lang{ display:flex; flex-direction:column; align-items:flex-start; gap:11px; padding:24px; text-decoration:none; transition:transform .35s var(--og-ease-out), box-shadow .35s var(--og-ease-out); }
.og-svc-lang:hover{ transform:translateY(-5px); box-shadow:var(--og-shadow-2); }
.og-svc-lang__flag{ display:inline-grid; place-items:center; width:46px; height:46px; border-radius:50%; background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); color:var(--og-emerald-700); font-weight:900; font-size:var(--t-sm); }
.og-svc-lang__name{ font-size:var(--t-lg); font-weight:800; color:var(--og-ink); }
.og-svc-lang__desc{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.95; flex:1; }
.og-schedule{ background:linear-gradient(135deg,rgba(0,86,63,.06),rgba(240,227,178,.16)); border:1px solid var(--og-line-soft); border-radius:var(--r-xl); padding:clamp(24px,3vw,34px); text-align:center; }
.og-schedule__head{ display:inline-flex; align-items:center; gap:9px; font-weight:800; color:var(--og-emerald); font-size:var(--t-lg); margin-bottom:16px; }
.og-schedule__days{ display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:14px; }
.og-schedule__day{ background:var(--og-surface); border:2px solid var(--og-emerald); color:var(--og-emerald); font-weight:800; font-size:var(--t-lg); padding:11px 30px; border-radius:var(--r-pill); box-shadow:var(--og-shadow-1); }
.og-schedule__note{ max-width:60ch; margin:0 auto; color:var(--og-muted); line-height:1.9; font-size:var(--t-sm); }
.og-checklist{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr 1fr; gap:14px 28px; }
@media (max-width:760px){ .og-checklist{ grid-template-columns:1fr; } }
.og-checklist li{ display:flex; gap:11px; align-items:flex-start; font-size:var(--t-base); line-height:1.9; color:var(--og-ink-soft); }
.og-checklist i{ color:var(--og-emerald); margin-top:5px; flex-shrink:0; }

/* ===================== Department pages ===================== */
.og-prose{ max-width:880px; }
.og-prose__title{ display:flex; align-items:center; gap:10px; font-size:var(--t-xl); font-weight:800; color:var(--og-ink); margin:0 0 16px; }
.og-prose__title i{ color:var(--og-emerald); }
.og-prose p{ color:var(--og-ink-soft); line-height:2.15; margin:0 0 14px; }
.og-pills__intro{ color:var(--og-ink-soft); line-height:2; margin:0 0 16px; max-width:72ch; }
.og-pills{ display:flex; flex-wrap:wrap; gap:11px; }
.og-pill{ background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-pill); padding:9px 18px; font-weight:700; color:var(--og-emerald); font-size:var(--t-sm); box-shadow:var(--og-shadow-1); }
.og-dtable{ width:100%; max-width:520px; border-collapse:collapse; border:1px solid var(--og-line-soft); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--og-shadow-1); }
.og-dtable td{ padding:14px 22px; border-bottom:1px solid var(--og-line-soft); font-size:var(--t-base); }
.og-dtable tr:last-child td{ border-bottom:0; }
.og-dtable td:first-child{ font-weight:700; color:var(--og-ink); }
.og-dtable td:last-child{ color:var(--og-emerald); font-weight:800; text-align:left; }
.og-dtable tr:nth-child(even){ background:var(--og-bg); }

/* ===================== Home: social row ===================== */
.og-social-row{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.og-social-chip{ display:flex; flex-direction:column; align-items:center; gap:9px; width:96px; padding:16px 8px; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); text-decoration:none; transition:transform .3s var(--og-ease-out), box-shadow .3s var(--og-ease-out), border-color .3s; }
.og-social-chip:hover{ transform:translateY(-5px); box-shadow:var(--og-shadow-2); border-color:var(--og-gold); }
.og-social-chip__icon{ display:grid; place-items:center; width:46px; height:46px; border-radius:50%; background:linear-gradient(180deg,var(--og-emerald),var(--og-emerald-700)); color:#fff; font-size:20px; }
.og-social-chip__abbr{ font-size:13px; font-weight:800; }
.og-social-chip__name{ font-size:var(--t-xs); color:var(--og-muted); font-weight:600; }
/* real platform icons (own coloured badge) — drop the emerald circle */
.og-social-chip--img .og-social-chip__icon{ width:52px; height:52px; background:none; border-radius:0; }
.og-social-chip--img .og-social-chip__icon img{ width:100%; height:100%; object-fit:contain; display:block; filter:drop-shadow(0 4px 8px rgba(0,86,63,.18)); }

/* ===================== Home: English levels rail ===================== */
.og-levels-rail{ display:grid; grid-template-columns:repeat(6,1fr); gap:clamp(12px,1.6vw,20px); }
.og-level-card{ display:flex; flex-direction:column; align-items:center; gap:9px; text-decoration:none; transition:transform .35s var(--og-ease-out); }
.og-level-card:hover{ transform:translateY(-6px); }
.og-level-card img{ width:100%; height:auto; display:block; filter:drop-shadow(0 14px 22px rgba(0,86,63,.16)); transition:filter .35s var(--og-ease-out); }
.og-level-card:hover img{ filter:drop-shadow(0 22px 32px rgba(0,86,63,.28)); }
.og-level-card__name{ font-weight:800; color:var(--og-emerald); font-size:var(--t-sm); }
@media (max-width:980px){ .og-levels-rail{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:560px){ .og-levels-rail{ grid-template-columns:repeat(2,1fr); } }

/* ===================== Home: annual calendar ===================== */
.og-calendar .og-cal-card{ display:flex; flex-direction:column; align-items:flex-start; gap:10px; padding:24px; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-lg); box-shadow:var(--og-shadow-1); position:relative; overflow:hidden; }
.og-calendar .og-cal-card::before{ content:""; position:absolute; inset-block-start:0; inset-inline:0; height:4px; background:linear-gradient(90deg,var(--og-gold),var(--og-emerald)); }
.og-cal-card__icon{ display:grid; place-items:center; width:48px; height:48px; border-radius:14px; background:rgba(0,86,63,.08); color:var(--og-emerald); font-size:21px; }
.og-cal-card__name{ font-weight:800; font-size:var(--t-lg); color:var(--og-ink); }
.og-cal-card__desc{ font-size:var(--t-sm); color:var(--og-muted); line-height:1.7; }
.og-calendar__note{ margin:22px 0 0; display:flex; align-items:center; gap:9px; font-size:var(--t-sm); color:var(--og-muted); }
.og-calendar__note i{ color:var(--og-emerald); flex-shrink:0; }

/* ===================== Home: welcome mascot ===================== */
.og-welcome__side{ display:flex; flex-direction:column; gap:20px; align-items:center; }
.og-welcome__mascot{ width:min(230px,72%); height:auto; filter:drop-shadow(0 24px 40px rgba(0,86,63,.18)); }
@media (max-width:880px){ .og-welcome__mascot{ width:170px; } }

/* ===================== Floating consultation button ===================== */
.og-consult-fab{ position:fixed; bottom:22px; left:50%; transform:translateX(-50%); z-index:997; display:inline-flex; align-items:center; gap:9px; background:linear-gradient(180deg,var(--og-gold),var(--og-gold-deep)); color:var(--og-emerald-700); font-weight:800; font-size:var(--t-sm); padding:12px 24px; border-radius:var(--r-pill); box-shadow:0 16px 38px -10px rgba(0,0,0,.45); text-decoration:none; transition:transform .25s var(--og-ease-out), box-shadow .25s; }
.og-consult-fab:hover{ transform:translateX(-50%) translateY(-3px); box-shadow:0 22px 48px -10px rgba(0,0,0,.55); color:var(--og-emerald-700); }
.og-consult-fab i{ font-size:16px; }
@media (max-width:992px){ .og-consult-fab{ bottom:78px; padding:11px 20px; } }
@media (max-width:380px){ .og-consult-fab span{ display:none; } .og-consult-fab{ padding:14px; } .og-consult-fab i{ font-size:18px; } }

/* ===================== Form pages ===================== */
.og-form-wrap{ max-width:820px; margin-inline:auto; background:var(--og-surface); border:1px solid var(--og-line-soft); border-radius:var(--r-xl); box-shadow:var(--og-shadow-2); padding:clamp(24px,4vw,44px); }
.og-form__hp{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; padding:0; margin:-1px; }
.og-form__grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px 22px; }
@media (max-width:640px){ .og-form__grid{ grid-template-columns:1fr; } }
.og-field{ display:flex; flex-direction:column; gap:8px; }
.og-field--wide{ grid-column:1 / -1; }
.og-field__label{ font-size:var(--t-sm); font-weight:700; color:var(--og-ink); }
.og-field__req{ color:#c0392b; }
.og-field__input{ width:100%; padding:12px 15px; border:1.5px solid var(--og-line-soft); border-radius:var(--r-md); background:var(--og-bg); color:var(--og-ink); font:inherit; font-size:var(--t-base); transition:border-color .2s, box-shadow .2s, background .2s; }
.og-field__input:focus{ outline:none; border-color:var(--og-emerald); box-shadow:0 0 0 3px rgba(0,86,63,.12); background:var(--og-surface); }
textarea.og-field__input{ resize:vertical; min-height:110px; line-height:1.8; }
.og-field__file{ padding:9px 12px; cursor:pointer; }
.og-form__foot{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:24px; }
.og-form__hint{ font-size:var(--t-xs); color:var(--og-muted); }
.og-form-alert{ display:flex; align-items:flex-start; gap:12px; padding:16px 20px; border-radius:var(--r-md); margin-bottom:24px; line-height:1.7; }
.og-form-alert i{ font-size:22px; margin-top:2px; flex-shrink:0; }
.og-form-alert > div{ display:flex; flex-direction:column; gap:3px; }
.og-form-alert strong{ font-weight:800; }
.og-form-alert--ok{ background:rgba(0,86,63,.08); border:1px solid rgba(0,86,63,.2); color:var(--og-emerald); }
.og-form-alert--err{ background:rgba(192,57,43,.07); border:1px solid rgba(192,57,43,.22); color:#a93226; }

/* ===================== Hero mascots + promo banner ===================== */
.og-hsl__visual--img .og-hsl__rings{ opacity:.45; }
.og-hsl__mascot{ position:relative; z-index:2; width:min(440px,94%); height:auto; filter:drop-shadow(0 30px 50px rgba(0,0,0,.34)); }
.og-lhero__visual--img .og-lhero__rings{ opacity:.45; }
.og-lhero__mascot{ position:relative; z-index:2; width:min(380px,90%); height:auto; filter:drop-shadow(0 26px 44px rgba(0,0,0,.3)); }
.og-promo-banner{ display:block; border-radius:var(--r-2xl); overflow:hidden; box-shadow:var(--og-shadow-2); line-height:0; }
.og-promo-banner img{ width:100%; height:auto; display:block; transition:transform .6s var(--og-ease-out); }
.og-promo-banner:hover img{ transform:scale(1.03); }

/* ===================== Single-course fixes ===================== */
/* Hide the theme's «لینک کوتاه» short-link field (renders as an empty box in the buy sidebar). */
.og-course__buy .product-shortlink,
.single-product .product-shortlink{ display:none !important; }
/* Off-brand pure-blue instructor name → brand emerald. */
.author-name-2{ color:var(--og-emerald) !important; }

/* =====================================================================
   .og-vox — Customer-satisfaction carousel (Avatar Navigator / Scrubber)
   iOS-navigator feel: one emerald "quote stage" + a tactile avatar
   filmstrip navigator at the bottom + progress scrubber. Token-only,
   scoped, RTL-correct. Server-renders N testimonials; one slide painted.
   ===================================================================== */
.og-vox{
  --vox-dur:.55s;
  padding-block:clamp(48px,6vw,84px);
  background:var(--og-bg);
  overflow:clip;
}
.og-vox *{ box-sizing:border-box; }
.og-vox__container{ max-inline-size:var(--og-container); margin-inline:auto; padding-inline:clamp(16px,4vw,28px); }

/* head — reuses site .og-eyebrow/.og-title, just centered */
.og-vox__head{ text-align:center; margin-block-end:clamp(28px,4vw,44px); }
.og-vox__head .og-eyebrow{ justify-content:center; }
.og-vox__head .og-title{ margin:6px 0 .4em; }
.og-vox__head p{ font-size:var(--t-base); color:var(--og-muted); margin:0 auto; max-inline-size:54ch; line-height:1.9; }

/* quote stage — emerald, only the active slide painted */
.og-vox__stage{
  position:relative;
  background:linear-gradient(155deg,var(--og-emerald) 0%,var(--og-emerald-700) 100%);
  border-radius:var(--r-2xl);
  box-shadow:var(--og-shadow-3);
  padding:clamp(30px,5vw,58px);
  padding-block-start:clamp(48px,6vw,76px);
  color:var(--og-gold-soft);
  overflow:hidden;
  isolation:isolate;
  touch-action:pan-y;            /* allow vertical page scroll; JS handles horizontal swipe */
}
.og-vox__stage::before{
  content:""; position:absolute; inset-block-start:-40%; inset-inline-end:-12%;
  inline-size:60%; block-size:120%;
  background:radial-gradient(closest-side,rgba(240,227,178,.16),transparent 70%);
  z-index:-1; pointer-events:none;
}
.og-vox__qmark{
  position:absolute; inset-block-start:clamp(16px,3vw,28px);
  /* RTL: inset-inline-start = the RIGHT edge → quote mark hugs the reading start */
  inset-inline-start:clamp(22px,4vw,46px);
  font-size:clamp(30px,4vw,46px); line-height:1;
  color:var(--og-gold); opacity:.5;
}
.og-vox__track{ position:relative; min-block-size:clamp(196px,24vw,236px); }
.og-vox__slide{
  position:absolute; inset:0;
  display:flex; flex-direction:column; gap:clamp(14px,2vw,20px);
  opacity:0; transform:translateX(24px);
  transition:opacity var(--vox-dur) var(--og-ease-out), transform var(--vox-dur) var(--og-ease-out);
  pointer-events:none; will-change:opacity,transform;
}
.og-vox__slide.is-active{ position:relative; opacity:1; transform:none; pointer-events:auto; }
.og-vox__slide[data-enter="next"]{ transform:translateX(24px); }
.og-vox__slide[data-enter="prev"]{ transform:translateX(-24px); }

.og-vox__stars{ font-size:clamp(17px,2.2vw,21px); color:var(--og-gold-deep); letter-spacing:.1em; line-height:1; }
.og-vox__star--off{ color:rgba(247,239,206,.26); }
.og-vox__quote{ margin:0; font-size:var(--t-xl); line-height:1.85; font-weight:600; color:var(--og-gold-soft); text-wrap:pretty; }
.og-vox__who{ display:flex; align-items:center; gap:14px; margin-block-start:auto; }
.og-vox__pic{ flex:0 0 auto; position:relative; inline-size:64px; block-size:64px; border-radius:var(--r-pill); background:var(--c,var(--og-gold)); box-shadow:0 0 0 3px rgba(240,227,178,.35), var(--og-shadow-2); overflow:hidden; }
.og-vox__pic img{ inline-size:100%; block-size:100%; object-fit:cover; display:block; }
.og-vox__pinit{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:26px; font-weight:800; color:var(--og-emerald-700); }
.og-vox__wmeta{ display:flex; flex-direction:column; gap:3px; min-inline-size:0; }
.og-vox__name{ font-size:var(--t-lg); font-weight:800; color:#fff; }
.og-vox__role{ font-size:var(--t-sm); color:var(--og-gold); opacity:.85; }
.og-vox__count{ display:block; text-align:center; margin:12px auto 0; font-size:var(--t-xs); font-weight:700; color:var(--og-muted); letter-spacing:.08em; }
.og-vox__src{
  position:absolute; inset-block-end:clamp(20px,3vw,32px);
  /* RTL: inset-inline-end = the LEFT edge → source badge sits opposite the name */
  inset-inline-end:clamp(24px,4vw,46px);
  display:inline-flex; align-items:center; gap:6px;
  font-size:var(--t-xs); font-weight:700; color:var(--og-emerald-700);
  background:var(--og-gold); padding:.35em 1em; border-radius:var(--r-pill);
}

/* avatar filmstrip navigator */
.og-vox__nav{ display:flex; align-items:center; gap:clamp(8px,1.5vw,14px); margin-block-start:clamp(22px,3vw,34px); }
.og-vox__arrow{
  flex:0 0 auto; inline-size:46px; block-size:46px;
  display:grid; place-items:center; border-radius:var(--r-pill);
  border:1px solid var(--og-line); background:var(--og-surface); color:var(--og-emerald);
  box-shadow:var(--og-shadow-1); cursor:pointer; font-size:18px;
  transition:transform .18s var(--og-ease), background .18s, color .18s, box-shadow .18s;
}
.og-vox__arrow:hover{ background:var(--og-emerald); color:var(--og-gold-soft); box-shadow:var(--og-shadow-2); }
.og-vox__arrow:active{ transform:scale(.92); }
.og-vox__arrow:focus-visible{ outline:3px solid var(--og-emerald-300); outline-offset:2px; }

.og-vox__strip{
  flex:1 1 auto; display:flex; align-items:center; gap:clamp(12px,1.8vw,18px);
  padding:12px clamp(8px,2vw,18px);
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.og-vox__strip::-webkit-scrollbar{ display:none; }
.og-vox__strip:focus-visible{ outline:3px solid var(--og-emerald-300); outline-offset:3px; border-radius:var(--r-lg); }

.og-vox__face{
  flex:0 0 auto; position:relative; inline-size:56px; block-size:56px;
  padding:0; border:0; cursor:pointer; border-radius:var(--r-pill);
  background:var(--c,var(--og-emerald-500));
  transition:transform .42s var(--og-ease), box-shadow .42s var(--og-ease), opacity .3s;
  opacity:.55; will-change:transform; outline-offset:4px;
}
.og-vox__face::after{
  content:""; position:absolute; inset:-5px; border-radius:var(--r-pill);
  border:2.5px solid var(--og-gold-deep); opacity:0; transform:scale(.82);
  transition:opacity .42s var(--og-ease), transform .42s var(--og-ease); pointer-events:none;
}
.og-vox__face:hover{ opacity:.85; }
.og-vox__face:focus-visible{ outline:3px solid var(--og-emerald-600); }
.og-vox__face.is-active{ opacity:1; transform:scale(1.34); box-shadow:var(--og-shadow-2); z-index:2; }
.og-vox__face.is-active::after{ opacity:1; transform:scale(1); }
.og-vox__img{ inline-size:100%; block-size:100%; object-fit:cover; border-radius:inherit; display:block; }
.og-vox__initial{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:800; color:var(--og-emerald-700); border-radius:inherit; }

/* progress scrubber (iOS page-control analogue) */
.og-vox__scrubber{ block-size:4px; inline-size:min(280px,60%); margin:clamp(18px,2.4vw,26px) auto 0; background:var(--og-line); border-radius:var(--r-pill); overflow:hidden; }
.og-vox__scrubfill{ display:block; block-size:100%; background:linear-gradient(90deg,var(--og-emerald-500),var(--og-emerald)); border-radius:var(--r-pill); transform:translateX(0); transition:transform var(--vox-dur) var(--og-ease-out); will-change:transform; }

.og-vox__live{ position:absolute; inline-size:1px; block-size:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; }

@media (prefers-reduced-motion: reduce){
  .og-vox__slide, .og-vox__face, .og-vox__face::after, .og-vox__scrubfill, .og-vox__arrow{ transition:none !important; }
  .og-vox__strip{ scroll-behavior:auto; }
}

/* no-JS fallback: stage becomes a horizontal snap list, all slides visible */
.og-vox:not(.og-vox--ready) .og-vox__track{ display:flex; gap:18px; overflow-x:auto; min-block-size:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; }
.og-vox:not(.og-vox--ready) .og-vox__slide{ position:relative; opacity:1; transform:none; pointer-events:auto; flex:0 0 100%; scroll-snap-align:center; }
.og-vox:not(.og-vox--ready) .og-vox__slide[hidden]{ display:flex; }
.og-vox:not(.og-vox--ready) .og-vox__scrubber{ display:none; }

@media (max-width:560px){
  .og-vox__face{ inline-size:48px; block-size:48px; }
  .og-vox__face.is-active{ transform:scale(1.28); }
  .og-vox__arrow{ inline-size:40px; block-size:40px; font-size:16px; }
  .og-vox__pic{ inline-size:52px; block-size:52px; }
  .og-vox__pinit{ font-size:21px; }
  .og-vox__src{ position:static; align-self:flex-start; margin-block-start:10px; }
}
