/* ============================================================
   GDA — Game Development Academy
   Design system prototype · dark-mode-first · "engineered/premium"
   Fonts: Noto Sans Armenian (display/body) + JetBrains Mono (technical)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg:#06070A;
  --bg-1:#090B10;
  --surface:#0C0F16;
  --surface-2:#11151F;
  --surface-3:#161B27;

  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.12);
  --line-3:rgba(255,255,255,.20);

  --ink:#EEF1F8;
  --ink-2:#C5CBD8;
  --muted:#878D9C;
  --faint:#565C6B;

  --accent:#00FEB2;
  --accent-2:#5CFFD2;
  --accent-ink:#bff5e6;
  --accent-soft:rgba(0,254,178,.12);
  --accent-line:rgba(0,254,178,.35);
  --accent-glow:rgba(0,254,178,.42);
  --on-accent:#03130D;

  --ok:#37D39B;
  --warn:#FFB54D;

  --radius:14px;
  --radius-lg:22px;
  --radius-sm:9px;
  --maxw:1220px;
  --gutter:24px;

  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --font-sans:"Noto Sans Armenian","Noto Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}

/* Per-engine accent themes */
.theme-unreal{ --accent:#00FEB2; --accent-2:#37FFD9; --accent-soft:rgba(0,254,178,.12); --accent-line:rgba(0,254,178,.35); --accent-glow:rgba(0,254,178,.42); }
.theme-unity { --accent:#C9D2E3; --accent-2:#8FA0Bd; --accent-soft:rgba(201,210,227,.10); --accent-line:rgba(201,210,227,.30); --accent-glow:rgba(201,210,227,.30); }
.theme-blender{ --accent:#FF8A3D; --accent-2:#FFB44D; --accent-soft:rgba(255,138,61,.12); --accent-line:rgba(255,138,61,.35); --accent-glow:rgba(255,138,61,.45); }
.theme-motion{ --accent:#FF5C8A; --accent-2:#B16CFF; --accent-soft:rgba(255,92,138,.12); --accent-line:rgba(255,92,138,.35); --accent-glow:rgba(255,92,138,.45); }

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:96px; }
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  font-size:16px;
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
  min-height:100vh;
}
html{ overflow-x:clip; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
img,svg{ display:block; max-width:100%; }
ul{ list-style:none; }
::selection{ background:var(--accent); color:var(--on-accent); }

/* ---------- Atmosphere ---------- */
.bg-atmos{ position:fixed; inset:0; z-index:-2; pointer-events:none; background:var(--bg); }
.bg-atmos::before{ /* technical grid */
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 25%, transparent 80%);
          mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 25%, transparent 80%);
}
.bg-atmos::after{ /* aurora */
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(50% 40% at 18% 0%, rgba(0,254,178,.16), transparent 70%),
    radial-gradient(45% 35% at 85% 8%, rgba(0,224,178,.10), transparent 70%),
    radial-gradient(60% 50% at 50% 100%, rgba(0,254,178,.06), transparent 70%);
}
.grain{ position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.04; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
section{ position:relative; }
.section{ padding-block:clamp(64px,9vw,128px); }
.section-tight{ padding-block:clamp(48px,6vw,80px); }
.divider{ height:1px; background:linear-gradient(90deg,transparent,var(--line-2),transparent); }

/* ---------- Typography helpers ---------- */
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:12px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent);
}
.kicker .idx{ color:var(--faint); }
.kicker::before{ content:""; width:26px; height:1px; background:var(--accent-line); }

.h-display{ font-weight:800; line-height:1.04; letter-spacing:-.035em; overflow-wrap:break-word; }
.h1{ font-size:clamp(2.6rem,6.4vw,4rem); }
.h2{ font-size:clamp(2rem,4.2vw,3rem); font-weight:800; line-height:1.08; letter-spacing:-.03em; }
.h3{ font-size:clamp(1.3rem,2.2vw,1.7rem); font-weight:700; letter-spacing:-.02em; line-height:1.2; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.2rem); color:var(--ink-2); line-height:1.65; max-width:60ch; }
.muted{ color:var(--muted); }
.section-head{ max-width:62ch; }
.section-head .h2{ margin-top:18px; }
.section-head p{ margin-top:18px; color:var(--muted); font-size:1.05rem; }
.text-grad{ color:var(--accent); -webkit-text-fill-color:currentColor; background:none; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:600; font-size:.95rem; letter-spacing:-.01em;
  padding:13px 22px; border-radius:var(--radius-sm);
  border:1px solid transparent; position:relative; isolation:isolate;
  transition:transform .25s var(--ease), box-shadow .35s var(--ease), background .25s, border-color .25s, color .25s;
  white-space:nowrap;
}
.btn .arr{ transition:transform .3s var(--ease-out); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-spinner{ display:none; width:16px; height:16px; border:2px solid currentColor; border-right-color:transparent; border-radius:50%; animation:btnspin .6s linear infinite; }
.btn.is-loading{ pointer-events:none; opacity:.92; }
.btn.is-loading .btn-spinner{ display:inline-block; }
.btn.is-loading .arr{ display:none; }
@keyframes btnspin{ to{ transform:rotate(360deg); } }
.btn-primary{ background:var(--accent); color:var(--on-accent); box-shadow:0 1px 0 rgba(255,255,255,.35) inset, 0 10px 30px -10px var(--accent-glow); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 1px 0 rgba(255,255,255,.4) inset, 0 18px 44px -12px var(--accent-glow); }
.btn-ghost{ background:rgba(255,255,255,.02); color:var(--ink); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--line-3); background:rgba(255,255,255,.05); transform:translateY(-2px); }
.btn-lg{ padding:16px 28px; font-size:1rem; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{ position:fixed; top:0; left:0; right:0; z-index:60; transition:transform .4s var(--ease); }
.header-inner{
  display:flex; align-items:center; gap:20px; height:74px;
  margin-top:14px; padding:0 18px 0 22px;
  border:1px solid var(--line); border-radius:16px;
  background:rgba(10,12,17,.55); backdrop-filter:blur(14px) saturate(140%);
  transition:background .3s, border-color .3s, height .3s, margin .3s;
}
.scrolled .header-inner{ height:62px; margin-top:8px; background:rgba(8,9,13,.82); border-color:var(--line-2); }
.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand svg, .brand img{ height:22px; width:auto; }
.brand .brand-mark path{ fill:var(--ink); }
.brand-tag{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.22em; color:var(--muted); border:1px solid var(--line-2); padding:3px 7px; border-radius:5px; text-transform:uppercase; }
.nav{ display:flex; align-items:center; gap:6px; margin-inline:auto; }
.nav a{
  font-size:.92rem; color:var(--ink-2); padding:9px 14px; border-radius:8px;
  position:relative; transition:color .2s, background .2s;
}
.nav a:hover{ color:var(--ink); background:rgba(255,255,255,.04); }
.header-actions{ display:flex; align-items:center; gap:12px; flex-shrink:0; }

/* language switcher */
.lang{ position:relative; }
.lang-btn{
  display:flex; align-items:center; gap:7px; font-family:var(--font-mono);
  font-size:.78rem; letter-spacing:.08em; color:var(--ink-2);
  border:1px solid var(--line-2); padding:8px 11px; border-radius:8px; transition:.2s;
}
.lang-btn:hover{ border-color:var(--line-3); color:var(--ink); }
.lang-btn .chev{ transition:transform .25s; }
.lang[data-open=true] .chev{ transform:rotate(180deg); }
.lang-menu{
  position:absolute; top:calc(100% + 8px); right:0; min-width:64px;
  background:var(--surface-2); border:1px solid var(--line-2); border-radius:11px;
  padding:6px; box-shadow:0 24px 60px -20px rgba(0,0,0,.8);
  opacity:0; transform:translateY(-6px) scale(.98); pointer-events:none; transition:.22s var(--ease-out);
}
.lang[data-open=true] .lang-menu{ opacity:1; transform:none; pointer-events:auto; }
.lang-menu a{ display:flex; justify-content:space-between; gap:14px; font-family:var(--font-mono); font-size:.78rem; padding:9px 11px; border-radius:7px; color:var(--ink-2); transition:.18s; }
.lang-menu a:hover{ background:rgba(255,255,255,.05); color:var(--ink); }
.lang-menu a.active{ color:var(--accent); }
.lang-menu a span{ color:var(--faint); }

.burger{ display:none; width:42px; height:42px; border:1px solid var(--line-2); border-radius:9px; align-items:center; justify-content:center; }
.burger span{ display:block; width:18px; height:1.6px; background:var(--ink); position:relative; transition:.3s; }
.burger span::before,.burger span::after{ content:""; position:absolute; left:0; width:18px; height:1.6px; background:var(--ink); transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }

/* mobile drawer */
.m-nav{ position:fixed; inset:0; z-index:55; background:rgba(6,7,10,.97); backdrop-filter:blur(8px); padding:110px 28px 40px; display:flex; flex-direction:column; gap:6px; opacity:0; pointer-events:none; transition:.3s; }
.m-nav[data-open=true]{ opacity:1; pointer-events:auto; }
.m-nav a{ font-size:1.6rem; font-weight:700; letter-spacing:-.02em; padding:14px 0; border-bottom:1px solid var(--line); }
.m-nav .m-langs{ display:flex; gap:10px; margin-top:24px; }
.m-nav .m-langs a{ font-family:var(--font-mono); font-size:.9rem; border:1px solid var(--line-2); border-bottom:1px solid var(--line-2); border-radius:8px; padding:10px 16px; }

/* ---------- Hero (home) ---------- */
.hero{ padding-top:170px; padding-bottom:clamp(60px,8vw,110px); position:relative; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:56px; align-items:center; }
.badge-row{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:26px; }
.pill{
  display:inline-flex; align-items:center; gap:9px; font-size:.8rem; color:var(--ink-2);
  background:rgba(255,255,255,.03); border:1px solid var(--line-2); padding:7px 13px; border-radius:100px;
}
.pill .dot{ width:6px; height:6px; border-radius:50%; background:var(--accent); box-shadow:0 0 10px var(--accent-glow); }
.pill .mono{ font-family:var(--font-mono); letter-spacing:.04em; color:var(--muted); }
.hero h1{ margin-bottom:24px; }
.hero .lead{ margin-bottom:36px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero-stats{ display:flex; gap:34px; margin-top:46px; padding-top:30px; border-top:1px solid var(--line); }
.stat .num{ font-family:var(--font-mono); font-size:1.9rem; font-weight:600; letter-spacing:-.02em; color:var(--ink); }
.stat .num b{ color:var(--accent); font-weight:600; }
.stat .lbl{ font-size:.82rem; color:var(--muted); margin-top:4px; }

/* hero visual panel */
.hero-panel{
  position:relative; border:1px solid var(--line-2); border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--surface-2),var(--surface)); padding:22px; overflow:hidden;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.9);
}
.hero-panel::before{ content:""; position:absolute; inset:0; background:radial-gradient(70% 50% at 70% 0%,var(--accent-soft),transparent 70%); pointer-events:none; }
.hp-top{ display:flex; align-items:center; justify-content:space-between; font-family:var(--font-mono); font-size:.72rem; color:var(--muted); letter-spacing:.1em; margin-bottom:18px; }
.hp-dots{ display:flex; gap:6px; } .hp-dots i{ width:9px;height:9px;border-radius:50%;background:var(--line-3); display:block;}
.hp-list{ display:flex; flex-direction:column; gap:10px; }
.hp-item{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:15px 16px; border:1px solid var(--line); border-radius:11px; background:rgba(255,255,255,.015); transition:.3s var(--ease); }
.hp-item:hover{ border-color:var(--accent-line); background:var(--accent-soft); transform:translateX(4px); }
.hp-item .l{ display:flex; align-items:center; gap:13px; }
.hp-ico{ width:38px; height:38px; border-radius:9px; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--accent); background:rgba(255,255,255,.02); flex-shrink:0; }
.hp-item .nm{ font-weight:600; font-size:.96rem; }
.hp-item .sub{ font-size:.78rem; color:var(--muted); }
.hp-item .px{ font-family:var(--font-mono); font-size:.82rem; color:var(--ink-2); }

/* ---------- Marquee trust ---------- */
.trust{ border-block:1px solid var(--line); padding-block:26px; }
.trust-inner{ display:flex; align-items:center; gap:28px; }
.trust-lbl{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); white-space:nowrap; }
.trust-logos{ display:flex; align-items:center; gap:40px; flex-wrap:wrap; }
.trust-logos img{ height:26px; opacity:.55; filter:brightness(0) invert(1); transition:opacity .3s; }
.trust-logos img:hover{ opacity:.9; }

/* ---------- Courses grid (home) ---------- */
.courses-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:54px; }
.course-card{
  position:relative; display:flex; flex-direction:column; min-height:300px;
  border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden;
  background:linear-gradient(180deg,var(--surface-2),var(--surface));
  padding:28px; transition:transform .4s var(--ease-out), border-color .35s, box-shadow .4s;
}
.course-card::after{ content:""; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(80% 60% at 20% 0%,var(--accent-soft),transparent 65%); opacity:0; transition:opacity .4s; pointer-events:none; }
.course-card:hover{ transform:translateY(-5px); border-color:var(--accent-line); box-shadow:0 30px 70px -30px rgba(0,0,0,.85); }
.course-card:hover::after{ opacity:1; }
.cc-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:auto; }
.cc-ico{ width:54px; height:54px; border-radius:13px; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--accent); background:rgba(255,255,255,.02); }
.cc-idx{ font-family:var(--font-mono); font-size:.8rem; color:var(--faint); }
.cc-body{ margin-top:30px; }
.cc-title{ font-size:1.5rem; font-weight:800; letter-spacing:-.02em; }
.cc-desc{ color:var(--muted); font-size:.94rem; margin-top:9px; max-width:42ch; }
.cc-foot{ display:flex; align-items:center; justify-content:space-between; gap:14px; margin-top:24px; padding-top:20px; border-top:1px solid var(--line); }
.cc-tiers{ display:flex; gap:7px; flex-wrap:wrap; }
.chip{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.03em; color:var(--ink-2); border:1px solid var(--line-2); padding:5px 9px; border-radius:6px; }
.chip.muted{ color:var(--faint); }
.cc-go{ width:42px; height:42px; border-radius:10px; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--ink); transition:.3s; flex-shrink:0; }
.cc-go svg{ transition:transform .3s; }
.course-card:hover .cc-go{ background:var(--accent); border-color:var(--accent); color:var(--on-accent); transform:rotate(-45deg); }
/* keep the arrow pointing right while only the box spins */
.course-card:hover .cc-go svg{ transform:rotate(45deg); }
.cc-price{ font-family:var(--font-mono); font-size:.82rem; color:var(--muted); }
.cc-price b{ color:var(--ink); font-weight:500; }

/* ---------- Feature / why grid ---------- */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:50px; }
.feature{ border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); padding:26px; transition:.35s; }
.feature:hover{ border-color:var(--line-2); transform:translateY(-3px); }
.feature .f-ico{ width:44px; height:44px; border-radius:11px; background:var(--accent-soft); border:1px solid var(--accent-line); display:grid; place-items:center; color:var(--accent); margin-bottom:18px; }
.feature h4{ font-size:1.08rem; font-weight:700; letter-spacing:-.01em; }
.feature p{ color:var(--muted); font-size:.92rem; margin-top:8px; }

/* ============================================================
   COURSE PAGE
   ============================================================ */
.course-hero{ padding-top:160px; padding-bottom:60px; }
.ch-top{ display:flex; align-items:center; gap:14px; margin-bottom:30px; }
.ch-badge{ display:inline-flex; align-items:center; gap:10px; border:1px solid var(--accent-line); background:var(--accent-soft); color:var(--accent); border-radius:100px; padding:8px 15px; font-size:.82rem; font-weight:600; }
.course-hero h1{ font-size:clamp(2.7rem,6.5vw,5.4rem); font-weight:800; letter-spacing:-.04em; line-height:1; margin-bottom:26px; }
.course-hero h1 em{ font-style:normal; color:var(--accent); }
.ch-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:50px; align-items:end; }
.ch-meta{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.ch-meta div{ background:var(--surface); padding:18px 20px; }
.ch-meta .k{ font-family:var(--font-mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); }
.ch-meta .v{ font-size:1.05rem; font-weight:600; margin-top:6px; }
.ch-meta .v b{ font-family:var(--font-mono); color:var(--accent); font-weight:600; }

/* sub-nav (anchor) */
.subnav{ position:sticky; top:90px; z-index:40; }
.subnav-inner{ display:flex; align-items:center; gap:4px; padding:7px; border:1px solid var(--line); border-radius:13px; background:rgba(10,12,17,.7); backdrop-filter:blur(12px); overflow-x:auto; }
.subnav a{ font-size:.86rem; color:var(--muted); padding:9px 15px; border-radius:8px; white-space:nowrap; transition:.2s; }
.subnav a:hover{ color:var(--ink); background:rgba(255,255,255,.04); }
.subnav a.active{ color:var(--ink); background:var(--accent-soft); border:1px solid var(--accent-line); }
.subnav .sn-cta{ margin-left:auto; }

/* description split */
.desc-split{ display:grid; grid-template-columns:.8fr 1.2fr; gap:50px; }
.desc-split .lead{ font-size:1.12rem; color:var(--ink-2); }

/* ---------- Tier cards ---------- */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); column-gap:18px; row-gap:0; margin-top:50px; align-items:stretch;
  /* spacing between the aligned sections — admin-configurable per page (desktop) */
  --sp-head:16px; --sp-main:20px; --sp-out:22px; }
.tier-head{ padding-bottom:var(--sp-head); }
.tier-main{ padding-bottom:var(--sp-main); }
.tier{
  position:relative; display:flex; flex-direction:column;
  border:1px solid var(--line); border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--surface-2),var(--surface)); padding:28px; transition:.4s var(--ease-out);
}
.tier:hover{ transform:translateY(-5px); border-color:var(--line-2); box-shadow:0 30px 70px -34px rgba(0,0,0,.85); }
.tier.featured{ border-color:var(--accent-line); box-shadow:0 0 0 1px var(--accent-line), 0 30px 80px -34px var(--accent-glow); }
.tier.featured::before{ content:""; position:absolute; inset:0; border-radius:inherit; background:radial-gradient(80% 50% at 50% 0,var(--accent-soft),transparent 60%); pointer-events:none; }
.tier-flag{ position:absolute; top:18px; right:18px; font-family:var(--font-mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); border:1px solid var(--accent-line); background:var(--accent-soft); padding:5px 9px; border-radius:6px; }
.tier-name{ font-size:1.35rem; font-weight:800; letter-spacing:-.02em; }
.tier-sub{ color:var(--muted); font-size:.86rem; margin-top:6px; min-height:38px; }
.tier-price{ margin:0 0 4px; }
.tier-price-now{ display:flex; align-items:baseline; gap:7px; }
.tier-price-old{ display:flex; align-items:center; gap:10px; margin-bottom:7px; }
.tier-save{ font-family:var(--font-mono); font-size:.72rem; font-weight:500; letter-spacing:.02em; line-height:1; color:var(--accent); border:1px solid var(--accent-line); background:var(--accent-soft); padding:4px 8px; border-radius:6px; }
.tier-price .amt{ font-family:var(--font-mono); font-size:2.3rem; font-weight:600; letter-spacing:-.03em; color:var(--ink); }
.tier-price .cur{ font-family:var(--font-mono); font-size:1.1rem; color:var(--accent); }
.tier-price .per{ font-size:.85rem; color:var(--muted); }
.tier-disc{ font-size:.8rem; color:var(--muted); padding:9px 12px; border:1px dashed var(--line-2); border-radius:8px; margin-bottom:20px; }
.tier-disc b{ color:var(--ink-2); font-weight:600; }
.tier-feats{ display:flex; flex-direction:column; gap:13px; margin-bottom:0; margin-top: 16px; }
.tier-feats li{ display:flex; gap:11px; font-size:.9rem; color:var(--ink-2); line-height:1.45; }
.tier-feats .ck{ flex-shrink:0; margin-top:2px; color:var(--accent); }
.tier-foot{ margin-top:auto; display:flex; flex-direction:column; gap:10px; }
.tier-link{ display:inline-flex; align-items:center; gap:8px; justify-content:center; font-size:.84rem; color:var(--muted); padding:11px; border-radius:8px; border:1px solid var(--line); transition:.25s; margin-top: 12px; }
.tier-link:hover{ color:var(--ink); border-color:var(--line-2); background:rgba(255,255,255,.03); }

/* Adaptive layout for courses with 1–2 tiers */
/* Two tiers → same card style as the 3-tier grid, just wider (full width) */
.tiers.cols-2{ grid-template-columns:repeat(2,1fr); }

/* Side-by-side cards: the four sections (head / price+bullets / outcomes / buttons)
   share row heights across cards, so each section starts at the same line —
   sized by the tallest card. Stacked (mobile) layouts fall back to natural flow. */
@supports (grid-template-rows: subgrid) {
  .tiers:not(.cols-1) > .tier{
    display:grid;
    grid-template-rows:subgrid;
    grid-row:span 4;
    align-content:start;
  }
}
.tier-outcomes.is-empty{ border:none; margin:0; padding:0; }

.tiers.cols-1{ grid-template-columns:minmax(300px,400px) 1fr; }
.tier-aside{
  display:flex; flex-direction:column;
  border:1px solid var(--line); border-radius:var(--radius-lg);
  background:radial-gradient(130% 90% at 100% 0,var(--accent-soft),transparent 55%), linear-gradient(180deg,var(--surface-2),var(--surface));
  padding:36px 40px;
}
.tier-aside h4{ font-size:1.2rem; font-weight:800; letter-spacing:-.02em; margin-bottom:24px; }
.ta-outcomes{ display:grid; grid-template-columns:1fr 1fr; gap:17px 32px; }
.ta-outcomes li{ display:flex; gap:11px; font-size:.96rem; color:var(--ink-2); line-height:1.5; }
.ta-outcomes .ck{ flex-shrink:0; margin-top:2px; color:var(--accent); }
.ta-highlights{ margin-top:auto; padding-top:26px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; gap:12px 30px; }
.ta-highlights > span{ display:inline-flex; align-items:center; gap:9px; font-size:.88rem; color:var(--muted); }
.ta-highlights .ck{ flex-shrink:0; color:var(--accent); }
@media (max-width:900px){
  .tiers.cols-1,.tiers.cols-2{ grid-template-columns:1fr; }
  .ta-outcomes{ grid-template-columns:1fr; }
}

/* ---------- Curriculum grid ---------- */
.curriculum{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; margin-top:46px; }
.cur-cell{ background:var(--surface); padding:24px 22px; min-height:140px; display:flex; flex-direction:column; justify-content:space-between; transition:.3s; position:relative; }
.cur-cell:hover{ background:var(--surface-2); }
.cur-cell .num{ font-family:var(--font-mono); font-size:.78rem; color:var(--faint); }
.cur-cell:hover .num{ color:var(--accent); }
.cur-cell .nm{ font-weight:600; font-size:1rem; letter-spacing:-.01em; line-height:1.25; }
.cur-cell .cur-ico{ color:var(--muted); margin-bottom:auto; }

/* ---------- Outcomes ---------- */
.outcomes{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px 40px; margin-top:42px; }
.outcome{ display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line); }
.outcome .oi{ width:28px; height:28px; border-radius:8px; background:var(--accent-soft); border:1px solid var(--accent-line); color:var(--accent); display:grid; place-items:center; flex-shrink:0; font-family:var(--font-mono); font-size:.72rem; }
.outcome p{ font-size:.96rem; color:var(--ink-2); }

/* ---------- Audience ---------- */
.audience{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:42px; }
.aud{ display:flex; gap:16px; align-items:center; padding:24px; border:1px solid var(--line); border-radius:var(--radius); background:var(--surface); transition:.3s; }
.aud:hover{ border-color:var(--accent-line); }
.aud .ai{ width:40px; height:40px; border-radius:10px; border:1px solid var(--line-2); display:grid; place-items:center; color:var(--accent); flex-shrink:0; }
.aud p{ font-size:.98rem; color:var(--ink-2); }

/* ---------- Instructor ---------- */
.instructor{ display:grid; grid-template-columns:.85fr 1.15fr; gap:46px; align-items:center; border:1px solid var(--line); border-radius:var(--radius-lg); background:linear-gradient(120deg,var(--surface-2),var(--surface)); padding:40px; margin-top:46px; position:relative; overflow:hidden; }
.instructor::before{ content:""; position:absolute; top:0; right:0; width:50%; height:100%; background:radial-gradient(60% 80% at 100% 0,var(--accent-soft),transparent 70%); pointer-events:none; }
.ins-photo{ aspect-ratio:4/5; border-radius:var(--radius); border:1px solid var(--line-2); background:linear-gradient(160deg,var(--surface-3),var(--surface)); display:grid; place-items:center; position:relative; overflow:hidden; }
.ins-photo .ph-ico{ color:var(--faint); }
.ins-photo .ph-tag{ position:absolute; bottom:14px; left:14px; right:14px; display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:.7rem; color:var(--muted); }
.ins-body .ins-name{ font-size:1.9rem; font-weight:800; letter-spacing:-.02em; }
.ins-role{ color:var(--accent); font-size:.92rem; margin-top:6px; font-weight:600; }
.ins-body p{ color:var(--ink-2); margin-top:18px; font-size:.98rem; line-height:1.7; }
.ins-creds{ display:flex; gap:10px; flex-wrap:wrap; margin-top:24px; }
.cred{ display:flex; align-items:center; gap:9px; font-size:.82rem; color:var(--ink-2); border:1px solid var(--line-2); padding:9px 13px; border-radius:9px; background:rgba(255,255,255,.02); }
.cred svg{ color:var(--accent); }
.ins-bio{ margin-top:18px; }

/* ---------- Rich text (shared: instructor bio, prose block) ---------- */
.rich{ color:var(--ink-2); line-height:1.7; font-size:1rem; }
.rich > :first-child{ margin-top:0; }
.rich p{ margin-top:16px; }
.rich h2,.rich h3,.rich h4{ color:var(--ink); font-weight:800; letter-spacing:-.02em; line-height:1.28; margin-top:34px; }
.rich h2{ font-size:1.55rem; } .rich h3{ font-size:1.25rem; } .rich h4{ font-size:1.08rem; }
.rich a{ color:var(--accent); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; transition:opacity .2s; }
.rich a:hover{ opacity:.75; }
.rich strong{ color:var(--ink); font-weight:700; }
.rich em{ font-style:italic; }
.rich ul,.rich ol{ margin-top:16px; padding-left:0; display:flex; flex-direction:column; gap:11px; }
.rich li{ list-style:none; position:relative; }
.rich ul li{ padding-left:24px; }
.rich ul li::before{ content:""; position:absolute; left:3px; top:.62em; width:7px; height:7px; border-radius:2px; background:var(--accent); transform:rotate(45deg); }
.rich ol{ counter-reset:ri; }
.rich ol li{ padding-left:32px; counter-increment:ri; }
.rich ol li::before{ content:counter(ri,decimal-leading-zero); position:absolute; left:0; top:.05em; font-family:var(--font-mono); font-size:.8rem; color:var(--accent); }
.rich blockquote{ margin-top:20px; padding:4px 0 4px 20px; border-left:2px solid var(--accent-line); color:var(--muted); font-style:italic; }
.rich hr{ border:none; border-top:1px solid var(--line); margin:32px 0; }

/* full-width left-aligned prose block */
.prose-block{ max-width:none; }
.prose-block.rich h2{ margin-top:0; }

/* ---------- Showcase ---------- */
.showcase{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:42px; }
.show{ aspect-ratio:1; border-radius:var(--radius); border:1px solid var(--line); background:linear-gradient(160deg,var(--surface-2),var(--surface)); position:relative; overflow:hidden; display:grid; place-items:center; transition:.4s var(--ease-out); }
.show:hover{ transform:scale(1.03); border-color:var(--accent-line); z-index:2; }
.show .s-ico{ color:var(--faint); transition:.3s; } .show:hover .s-ico{ color:var(--accent); }
.show .s-cap{ position:absolute; bottom:0; left:0; right:0; padding:14px; font-size:.8rem; color:var(--ink-2); background:linear-gradient(transparent,rgba(0,0,0,.6)); opacity:0; transform:translateY(8px); transition:.3s; }
.show:hover .s-cap{ opacity:1; transform:none; }

/* ---------- Lead form ---------- */
.form-section{ position:relative; }
.form-card{ display:grid; grid-template-columns:.9fr 1.1fr; border:1px solid var(--line-2); border-radius:var(--radius-lg); overflow:hidden; background:var(--surface); }
.form-aside{ padding:46px 40px; background:linear-gradient(180deg,var(--surface-2),var(--surface)); border-right:1px solid var(--line); position:relative; overflow:hidden; }
.form-aside::before{ content:""; position:absolute; inset:0; background:radial-gradient(70% 50% at 0 100%,var(--accent-soft),transparent 70%); pointer-events:none; }
.form-aside h3{ font-size:1.7rem; font-weight:800; letter-spacing:-.02em; line-height:1.15; }
.form-aside p{ color:var(--muted); margin-top:14px; font-size:.96rem; }
.form-aside .fa-list{ margin-top:28px; display:flex; flex-direction:column; gap:14px; }
.fa-list li{ display:flex; gap:12px; align-items:center; font-size:.92rem; color:var(--ink-2); }
.fa-list .fc{ width:26px;height:26px;border-radius:7px;background:var(--accent-soft);border:1px solid var(--accent-line);color:var(--accent);display:grid;place-items:center;flex-shrink:0; }
.form-body{ padding:42px 40px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:.8rem; color:var(--muted); margin-bottom:8px; font-weight:500; }
.field label .req{ color:var(--accent); }
.input, .select{
  width:100%; background:var(--bg-1); border:1px solid var(--line-2); color:var(--ink);
  padding:14px 15px; border-radius:10px; font-size:.96rem; font-family:inherit; transition:.22s;
}
.input::placeholder{ color:var(--faint); }
.input:focus,.select:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-soft); background:var(--surface); }
.select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23878D9C' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; cursor:pointer; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.consent{ display:flex; gap:11px; align-items:flex-start; margin:6px 0 22px; }
.consent input{ margin-top:3px; accent-color:var(--accent); width:16px; height:16px; flex-shrink:0; }
.consent label{ font-size:.82rem; color:var(--muted); line-height:1.5; }
.consent a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.form-note{ font-family:var(--font-mono); font-size:.72rem; color:var(--faint); margin-top:16px; text-align:center; display:flex; align-items:center; justify-content:center; gap:8px; }

/* ---------- Ecosystem ---------- */
.eco-wall{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; margin-top:46px; }
.eco{ background:var(--surface); padding:38px 32px; display:flex; align-items:center; justify-content:center; min-height:150px; transition:.35s; position:relative; }
.eco:hover{ background:var(--surface-2); }
.eco img{ height:42px; max-width:170px; object-fit:contain; filter:brightness(0) invert(1); opacity:.5; transition:.35s; }
.eco:hover img{ filter:none; opacity:1; }

/* ---------- FAQ ---------- */
.faq{ max-width:840px; margin:46px auto 0; border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; text-align:left; padding:26px 4px; font-size:1.12rem; font-weight:600; letter-spacing:-.01em; transition:color .2s; }
.faq-q:hover{ color:var(--accent); }
.faq-ico{ width:30px; height:30px; border-radius:8px; border:1px solid var(--line-2); display:grid; place-items:center; flex-shrink:0; position:relative; transition:.3s; }
.faq-ico::before,.faq-ico::after{ content:""; position:absolute; background:var(--ink); transition:.3s; }
.faq-ico::before{ width:12px; height:1.6px; } .faq-ico::after{ width:1.6px; height:12px; }
.faq-item[data-open=true] .faq-ico{ background:var(--accent); border-color:var(--accent); }
.faq-item[data-open=true] .faq-ico::before,.faq-item[data-open=true] .faq-ico::after{ background:var(--on-accent); }
.faq-item[data-open=true] .faq-ico::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .4s var(--ease); }
.faq-a-inner{ padding:0 4px 26px; color:var(--muted); font-size:1rem; line-height:1.7; max-width:68ch; }

/* ---------- CTA banner ---------- */
.cta{ position:relative; border:1px solid var(--line-2); border-radius:var(--radius-lg); overflow:hidden; padding:clamp(40px,6vw,72px); text-align:center; background:linear-gradient(180deg,var(--surface-2),var(--surface)); }
.cta::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 120% at 50% 0,var(--accent-soft),transparent 60%); pointer-events:none; }
.cta h2{ font-size:clamp(2rem,4.5vw,3.4rem); font-weight:800; letter-spacing:-.03em; line-height:1.05; max-width:18ch; margin-inline:auto; }
.cta p{ color:var(--muted); margin-top:18px; max-width:52ch; margin-inline:auto; }
.cta .cta-btns{ display:flex; gap:14px; justify-content:center; margin-top:34px; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.footer{ border-top:1px solid var(--line); margin-top:30px; padding-block:64px 36px; }
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; }
/* homepages show the map in the Contacts section instead */
.footer-grid.no-map{ grid-template-columns:1.6fr 1fr 1fr; }
.foot-brand .brand-mark{ height:30px; } .foot-brand .brand-mark path{ fill:var(--ink); }
.foot-brand p{ color:var(--muted); font-size:.92rem; margin-top:18px; max-width:34ch; }
.foot-soc{ display:flex; gap:10px; margin-top:22px; }
.foot-soc a{ width:40px; height:40px; border:1px solid var(--line-2); border-radius:9px; display:grid; place-items:center; color:var(--ink-2); transition:.25s; }
.foot-soc a:hover{ border-color:var(--accent-line); color:var(--accent); background:var(--accent-soft); transform:translateY(-2px); }
.foot-col h5{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:18px; }
.foot-col a{ display:block; color:var(--ink-2); font-size:.92rem; padding:7px 0; transition:.2s; }
.foot-col a:hover{ color:var(--accent); }
.foot-bottom{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-top:50px; padding-top:26px; border-top:1px solid var(--line); flex-wrap:wrap; }
.foot-bottom p{ font-size:.84rem; color:var(--faint); }
.foot-bottom .mono{ font-family:var(--font-mono); font-size:.78rem; color:var(--muted); }

/* ---------- Modal (curriculum) ---------- */
.modal{ position:fixed; inset:0; z-index:90; display:grid; place-items:center; padding:24px; opacity:0; pointer-events:none; transition:opacity .3s; }
.modal[data-open="true"]{ opacity:1; pointer-events:auto; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(4,5,8,.82); backdrop-filter:blur(8px); }
.modal-panel{ position:relative; width:100%; max-width:920px; max-height:86vh; overflow:auto; border:1px solid var(--line-2); border-radius:var(--radius-lg); background:var(--surface); box-shadow:0 50px 120px -40px rgba(0,0,0,.9); transform:translateY(20px) scale(.98); transition:transform .35s var(--ease-out); }
.modal[data-open="true"] .modal-panel{ transform:none; }
.modal-head{ position:sticky; top:0; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:24px 28px; background:linear-gradient(180deg,var(--surface-2),var(--surface)); border-bottom:1px solid var(--line); z-index:2; }
.modal-head h3{ font-size:1.3rem; font-weight:800; letter-spacing:-.02em; }
.modal-head .mono{ font-family:var(--font-mono); font-size:.74rem; color:var(--muted); }
.modal-close{ width:40px; height:40px; border:1px solid var(--line-2); border-radius:10px; display:grid; place-items:center; color:var(--ink-2); transition:.25s; flex-shrink:0; }
.modal-close:hover{ border-color:var(--line-3); color:var(--ink); background:rgba(255,255,255,.04); transform:rotate(90deg); }
.modal-body{ padding:28px; }
.modal-group + .modal-group{ margin-top:28px; }
.modal-group h4{ font-family:var(--font-mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; display:flex; align-items:center; gap:10px; }
.modal-group h4::after{ content:""; flex:1; height:1px; background:var(--line); }
.mod-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.mod-cell{ display:flex; gap:13px; align-items:center; padding:14px 16px; border:1px solid var(--line); border-radius:10px; background:rgba(255,255,255,.015); transition:.25s; }
.mod-cell:hover{ border-color:var(--accent-line); background:var(--accent-soft); }
.mod-cell .n{ font-family:var(--font-mono); font-size:.74rem; color:var(--faint); flex-shrink:0; }
.mod-cell:hover .n{ color:var(--accent); }
.mod-cell .t{ font-size:.92rem; font-weight:500; }
@media (max-width:640px){ .mod-grid{ grid-template-columns:1fr; } }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }

@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } *{ scroll-behavior:auto; } }

/* ---------- Contacts section ---------- */
.contact-wrap{ display:grid; grid-template-columns:1.02fr .98fr; gap:18px; margin-top:46px; align-items:stretch; }
.contact-panel{
  display:flex; flex-direction:column;
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px 34px;
  background:radial-gradient(120% 80% at 100% 0,var(--accent-soft),transparent 55%), linear-gradient(180deg,var(--surface-2),var(--surface));
}
.contact-row{ display:flex; align-items:center; gap:16px; padding:17px 0; border-bottom:1px solid var(--line); transition:.2s; }
.contact-row:first-child{ padding-top:4px; }
.contact-row .cc-ico{ flex-shrink:0; width:44px; height:44px; display:grid; place-items:center; border-radius:11px; border:1px solid var(--line-2); color:var(--accent); background:var(--accent-soft); transition:.25s; }
.contact-row .cc-lbl{ font-family:var(--font-mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:3px; }
.contact-row .cc-v{ font-size:.98rem; font-weight:600; color:var(--ink-2); line-height:1.35; word-break:break-word; transition:.2s; }
.contact-row:hover .cc-v{ color:var(--accent); }
.contact-row:hover .cc-ico{ border-color:var(--accent-line); }
.contact-socials{ margin-top:auto; padding-top:26px; }
.contact-map{ position:relative; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; min-height:380px; background:var(--surface); }
.contact-map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter:invert(.92) hue-rotate(180deg) contrast(.95) saturate(.85); }
.contact-map::after{ content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit; box-shadow:inset 0 0 0 1px rgba(255,255,255,.04), inset 0 30px 60px -30px rgba(0,0,0,.55); }

/* unified social / messenger icon buttons (footer + contacts) */
.soc-row{ display:flex; flex-wrap:wrap; gap:10px; }
.soc-btn{ width:42px; height:42px; flex-shrink:0; border:1px solid var(--line-2); border-radius:10px; display:grid; place-items:center; color:var(--ink-2); transition:.25s var(--ease-out); }
.soc-btn:hover{ border-color:var(--accent-line); color:var(--accent); background:var(--accent-soft); transform:translateY(-2px); }
.soc-btn svg{ width:19px; height:19px; }
.soc-btn.soc-img img{ width:20px; height:20px; object-fit:contain; }
.foot-brand .soc-row{ margin-top:22px; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero-grid,.ch-grid,.desc-split,.instructor,.form-card,.footer-grid,.contact-wrap{ grid-template-columns:1fr; }
  .hero-panel{ display:none; }
  .tiers,.feature-grid,.eco-wall{ grid-template-columns:1fr 1fr; }
  .curriculum{ grid-template-columns:repeat(3,1fr); }
  .showcase{ grid-template-columns:repeat(3,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .instructor{ padding:30px; } .ins-photo{ max-width:320px; }
  /* tablets: collapse the centered nav into the burger so the CTA never crams/clips */
  .nav{ display:none; }
  .burger{ display:flex; }
  .header-inner{ gap:12px; }
  .header-actions{ margin-left:auto; }
}
@media (max-width:760px){
  :root{ --gutter:18px; }
  /* phones: keep the CTA visible — just tighten the pill + make the button compact */
  .header-inner{ padding:0 10px 0 14px; gap:10px; }
  .header-actions{ gap:8px; }
  .header-actions .btn-primary{ padding:10px 14px; font-size:.84rem; }
  .header-actions .btn-primary .arr{ display:none; }
  .lang-btn{ padding:7px 8px; }
  .hero{ padding-top:130px; }
  .hero-stats{ flex-wrap:wrap; gap:22px; }
  .courses-grid,.tiers,.feature-grid,.outcomes,.audience,.eco-wall,.curriculum,.showcase,.field-row{ grid-template-columns:1fr; }
  .contact-map{ min-height:260px; }
  /* phones: course hero title must fit long words (e.g. Профессиональное) */
  .course-hero h1{ font-size:clamp(1.9rem,8.4vw,2.7rem); overflow-wrap:break-word; }
  .ch-meta{ grid-template-columns:1fr 1fr; }
  .form-aside{ border-right:none; border-bottom:1px solid var(--line); }
  .subnav{ display:none; }
  .footer-grid{ grid-template-columns:1fr; }
  .trust-inner{ flex-direction:column; align-items:flex-start; gap:16px; }
}
/* small phones: drop the language pill to give the CTA room (it lives in the menu) */
@media (max-width:480px){
  .header-actions .lang{ display:none; }
  /* shrink the hero headline so long Armenian words (e.g. մասնագիտական) fit */
  .h1{ font-size:clamp(1.9rem,7.6vw,2.4rem); }
}
/* very narrow: only now hide the CTA (still reachable via the burger menu) */
@media (max-width:340px){
  .header-actions > .btn-primary{ display:none; }
}

/* ============================================================
   HOME UPDATES — flags · hero groups · course groups · carousel · about
   ============================================================ */

/* Language flags */
.flag{ width:22px; height:15px; border-radius:3px; object-fit:cover; box-shadow:0 0 0 1px rgba(255,255,255,.14); flex-shrink:0; display:block; }
.lang-btn{ padding:8px 10px; }
.lang-menu a{ align-items:center; }
.m-langs a{ display:inline-flex; align-items:center; justify-content:center; }
.m-langs .flag{ width:30px; height:20px; }

/* Hero panel: group labels, course logos, arrow */
.hp-group{ font-family:var(--font-mono); font-size:.85rem; letter-spacing:.16em; text-transform:uppercase; color:var(--faint); padding:14px 18px 7px; }
.hp-list > .hp-group:first-child{ padding-top:16px; }
.hp-ico{ overflow:hidden; }
.hp-ico img{ width:24px; height:24px; object-fit:contain; }
.hp-go{ color:var(--faint); transition:color .25s var(--ease), transform .25s var(--ease); flex-shrink:0; }
.hp-item:hover .hp-go{ color:var(--accent); transform:translateX(3px); }

/* Course groups (Programming / Design) */
.course-group{ margin-top:46px; }
.course-group + .course-group{ margin-top:40px; }
.course-group-head{ display:flex; align-items:center; gap:14px; padding-bottom:16px; border-bottom:1px solid var(--line); }
.cg-num{ font-family:var(--font-mono); font-size:.82rem; color:var(--accent); }
.cg-title{ font-size:1.4rem; font-weight:800; letter-spacing:-.02em; }
.cg-en{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-left:auto; }
.course-group .courses-grid{ margin-top:20px; }
.cc-ico{ overflow:hidden; }
.cc-ico img{ width:32px; height:32px; object-fit:contain; }

/* About — UATC badge left, heading + text right */
.about-badge{ display:flex; align-items:center; justify-content:center; padding:8px; }
.about-badge img{ width:100%; max-width:230px; height:auto; filter:drop-shadow(0 20px 44px rgba(0,0,0,.55)); }

/* Ecosystem — partner carousel */
.partner-carousel{ margin-top:46px; border:1px solid var(--line); border-radius:var(--radius-lg);
  overflow-x:auto; overflow-y:hidden; cursor:grab; user-select:none; touch-action:pan-y;
  scrollbar-width:none; -ms-overflow-style:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
.partner-carousel::-webkit-scrollbar{ display:none; }
.partner-carousel.dragging{ cursor:grabbing; }
.partner-track{ display:flex; width:max-content; }
.partner{ flex:0 0 auto; width:clamp(170px,20vw,230px); height:128px; display:grid; place-items:center; padding:24px 28px; border-right:1px solid var(--line); text-decoration:none; color:inherit; }
a.partner{ cursor:pointer; }
.partner img{ height:60px; max-width:150px; object-fit:contain; filter:brightness(0) invert(1); opacity:.42; transition:filter .35s, opacity .35s; pointer-events:none; -webkit-user-drag:none; user-select:none; }
.partner:hover img{ filter:none; opacity:1; }

@media (max-width:760px){
  .course-group-head .cg-en{ display:none; }
  .partner{ width:clamp(150px,54vw,200px); height:112px; }
}

/* ============================================================
   UNREAL ENGINE PAGE UPDATES
   ============================================================ */

/* Hero certification logo (replaces the meta grid) */
.ch-cert{ display:flex; align-items:center; justify-content:center; }
.ch-cert img{ width:100%; max-width:300px; height:auto; filter:drop-shadow(0 24px 50px rgba(0,0,0,.55)); }

/* Tier format tags */
.tier-tags{ display:flex; gap:7px; margin-top:14px; }
/* tags live on the title row, pinned to the card's right edge */
.tier-head-top{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.tier-head-top .tier-tags{ margin-top:5px; flex-shrink:0; flex-wrap:wrap; justify-content:flex-end; }
.tier-tag{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.06em; text-transform:uppercase; color:var(--accent); border:1px solid var(--accent-line); background:var(--accent-soft); padding:4px 9px; border-radius:5px; }

/* Next cohort, directly under price */
.tier-next{ font-family:var(--font-mono); font-size:.78rem; color:var(--accent); margin:2px 0 18px; }

/* "Ավարտին կկարողանաս" outcomes */
.tier-outcomes{ margin:0; padding-top:18px; padding-bottom:var(--sp-out); border-top:1px solid var(--line); }
.tier-outcomes h5{ font-family:var(--font-mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:13px; }
.tier-outcomes ul{ display:flex; flex-direction:column; gap:10px; }
.tier-outcomes li{ position:relative; padding-left:20px; font-size:.88rem; color:var(--ink-2); line-height:1.4; }
.tier-outcomes li::before{ content:"\2192"; position:absolute; left:0; top:0; color:var(--accent); font-family:var(--font-mono); }

/* Tier cursor-follow glow (#00FEB2) */
.tier{ overflow:hidden; }
.tier > *{ position:relative; z-index:1; }
/* featured card keeps only its edge ring (no inner glow) so the glow stays edges-only everywhere */
.tier.featured::before{ display:none; }
.tier::after{ content:""; position:absolute; inset:0; border-radius:inherit; padding:1.5px;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%), var(--accent), transparent 45%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite:xor;
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); mask-composite:exclude;
  opacity:0; transition:opacity .35s; pointer-events:none; z-index:3; }
.tier:hover::after{ opacity:1; }

/* Instructor photo image */
.ins-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; }
.ins-photo .ph-tag{ left:0; right:0; bottom:0; padding:26px 16px 14px; background:linear-gradient(transparent, rgba(0,0,0,.72)); z-index:2; }

/* Per-tier components modal (fixes Beginner/Advanced showing Complete) */
.modal[data-show="beginner"] .modal-group[data-grp="advanced"]{ display:none; }
.modal[data-show="advanced"] .modal-group[data-grp="beginner"]{ display:none; }

/* Registration steps — distinct green bullets */
.fa-steps-label{ margin-top:22px; color:var(--ink); font-weight:600; font-size:.95rem; }
.fa-steps{ margin-top:14px; display:flex; flex-direction:column; gap:14px; }
.fa-steps li{ position:relative; padding-left:24px; color:var(--ink-2); font-size:.92rem; line-height:1.55; }
.fa-steps .fa-dot{ position:absolute; left:0; top:8px; width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px var(--accent-soft), 0 0 12px var(--accent-glow); }

/* Tier promo price — original struck through, discount highlighted */
.tier-price .was{ position:relative; font-family:var(--font-mono); font-size:1.02rem; color:var(--faint); }
.tier-price .was::after{
  content:""; position:absolute; left:-4%; right:-4%; top:50%; height:1.5px; border-radius:2px;
  background:var(--muted); opacity:.85; transform:translateY(-50%) rotate(-10deg); pointer-events:none;
}
.tier-price.has-promo .amt{ color:var(--accent); }

/* Footer: contacts left + map right */
.foot-contact{ display:flex; flex-direction:column; }
.foot-map{ margin-top:0; }
.foot-map iframe{ width:100%; height:100%; min-height:180px; border:1px solid var(--line-2); border-radius:12px; display:block; filter:invert(.92) hue-rotate(180deg) contrast(.95) saturate(.85); }
