:root{
  --black:#050507;
  --panel:#111116;
  --panel2:#17131f;
  --line:rgba(255,255,255,.14);
  --text:#f6f1ff;
  --muted:#b9aec8;
  --purple:#7a18ff;
  --purple2:#b868ff;
  --purple3:#d9a8ff;
  --deep:#220064;
  --max:1180px;
  --radius:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --shadow-lg:0 30px 90px rgba(122,24,255,.20);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
::selection{background:rgba(184,104,255,.45);color:#fff}

body{
  margin:0;
  font-family:'Inter','Noto Sans JP',system-ui,sans-serif;
  background:#030304;
  color:var(--text);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  letter-spacing:-.005em;
}
body:before{
  content:"";position:fixed;inset:0;z-index:-3;
  background:
    radial-gradient(circle at 8% 28%,rgba(111,0,255,.22),transparent 30%),
    radial-gradient(circle at 94% 72%,rgba(122,24,255,.25),transparent 34%),
    radial-gradient(circle at 50% 110%,rgba(184,104,255,.10),transparent 45%),
    linear-gradient(#050506,#000);
  animation:bgFloat 24s ease-in-out infinite alternate;
}
@keyframes bgFloat{
  0%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(-2%,1%,0)}
  100%{transform:translate3d(2%,-1%,0)}
}
body.lang-ja{font-family:'Noto Sans JP','Inter',system-ui,sans-serif}

a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}

.container{width:min(var(--max),calc(100% - 34px));margin-inline:auto}
.section{padding:120px 0;position:relative}

.label{
  font-size:12px;font-weight:800;letter-spacing:.18em;
  text-transform:uppercase;color:var(--purple2);
}

h1,h2,h3,p{margin:0}
h1{
  font-size:clamp(42px,7vw,82px);
  line-height:1.02;font-weight:900;
  letter-spacing:-.055em;text-wrap:balance;
  background:linear-gradient(180deg,#fff 0%,#e6d8ff 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
}
h2{
  font-size:clamp(30px,4.4vw,50px);
  line-height:1.1;font-weight:850;
  letter-spacing:-.04em;text-align:center;
  text-wrap:balance;
}
h2 .accent,.accent{color:var(--purple2)}
h3{font-size:clamp(18px,2.2vw,24px);line-height:1.3;letter-spacing:-.01em}
.muted{color:var(--muted)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;min-height:48px;padding:13px 26px;
  border-radius:10px;border:1px solid transparent;
  font-weight:800;letter-spacing:.01em;
  cursor:pointer;position:relative;overflow:hidden;
  transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),border-color .3s var(--ease-out),background .3s var(--ease-out);
}
.btn:before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.18) 50%,transparent 100%);
  transform:translateX(-120%);transition:transform .7s var(--ease-out);
  pointer-events:none;
}
.btn:hover:before{transform:translateX(120%)}
.btn-primary{
  background:linear-gradient(135deg,var(--purple),#5d00e8);
  color:#fff;
  box-shadow:0 12px 36px rgba(122,24,255,.32),inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 50px rgba(122,24,255,.45),inset 0 1px 0 rgba(255,255,255,.22);
}
.btn-outline,.btn-ghost{
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.04);
  color:#fff;
  backdrop-filter:blur(8px);
}
.btn-outline:hover,.btn-ghost:hover{
  transform:translateY(-3px);
  border-color:rgba(184,104,255,.55);
  background:rgba(184,104,255,.08);
}

/* Navbar */
.navbar{
  position:sticky;top:0;z-index:1000;
  background:rgba(6,6,8,.62);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.navbar.scrolled{
  background:rgba(4,4,7,.82);
  border-bottom-color:rgba(255,255,255,.10);
  box-shadow:0 8px 32px rgba(0,0,0,.32);
}
.nav-inner{height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo img{
  width:255px;height:auto;
  filter:drop-shadow(0 0 18px rgba(126,41,255,.22));
  transition:filter .3s var(--ease),transform .3s var(--ease);
}
.logo:hover img{filter:drop-shadow(0 0 26px rgba(184,104,255,.4));transform:scale(1.02)}
.nav-links{display:flex;align-items:center;gap:28px;font-weight:700;font-size:13px;color:#d8d1e6}
.nav-links>a,.nav-links .dropdown>a{position:relative;padding:6px 2px}
.nav-links>a:after,.nav-links .dropdown>a:after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,var(--purple),var(--purple2));
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease-out);
  border-radius:2px;
}
.nav-links>a:hover:after,.nav-links .dropdown:hover>a:after{transform:scaleX(1)}
.nav-links a:hover{color:#fff}

.nav-actions{display:flex;align-items:center;gap:10px}
.lang-toggle{
  display:flex;align-items:center;
  border:1px solid rgba(255,255,255,.12);border-radius:999px;
  padding:4px;background:rgba(255,255,255,.04);min-height:44px;
}
.lang-toggle button{
  border:0;background:transparent;color:#fff;
  padding:8px 14px;border-radius:999px;cursor:pointer;font-weight:800;
  transition:background .25s var(--ease),color .25s var(--ease);
}
.lang-toggle button.active{
  background:linear-gradient(135deg,var(--purple),#4b00be);
  box-shadow:0 4px 14px rgba(122,24,255,.32);
}

.hamb{
  display:none;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);color:#fff;
  border-radius:10px;min-width:48px;height:48px;font-size:26px;
  transition:background .25s var(--ease),transform .25s var(--ease);
}
.hamb:hover{background:rgba(184,104,255,.16);transform:scale(1.05)}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;background:#050507;color:#fff;
  z-index:2000;padding:24px;
  transform:translateX(100%);opacity:0;
  transition:transform .35s var(--ease-out),opacity .25s var(--ease);
  display:flex;flex-direction:column;
}
.mobile-menu.open{transform:translateX(0);opacity:1}
.mobile-head{display:flex;justify-content:space-between;align-items:center}
.mobile-head img,.footer img[alt="FOX Academy"]{background:transparent!important;padding:0!important;border-radius:0!important}
.close{
  background:transparent;color:#fff;border:1px solid rgba(255,255,255,.22);
  font-size:28px;border-radius:10px;width:48px;height:48px;
  transition:background .25s var(--ease),transform .25s var(--ease);
}
.close:hover{background:rgba(255,255,255,.08);transform:rotate(90deg)}
.mobile-links{display:grid;gap:8px;margin-top:40px}
.mobile-links a{
  font-size:28px;font-weight:800;
  padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);
  transition:padding .25s var(--ease),color .25s var(--ease);
}
.mobile-links a:hover{padding-left:8px;color:var(--purple2)}

/* Hero */
.hero{
  min-height:calc(100vh - 78px);
  display:grid;align-items:center;text-align:center;
  position:relative;overflow:hidden;
  background:#070709;color:#fff;
}
.hero:before{
  content:"";position:absolute;left:50%;top:6%;
  width:min(1120px,145vw);height:min(560px,72vw);
  transform:translateX(-50%);
  border-radius:560px 560px 0 0;
  background:radial-gradient(ellipse at center bottom,
    rgba(122,24,255,.96) 0 18%,
    rgba(122,24,255,.78) 33%,
    rgba(177,101,255,.55) 48%,
    rgba(255,255,255,.78) 56%,
    transparent 59%);
  filter:blur(9px);opacity:.92;
  animation:heroPulse 9s ease-in-out infinite;
}
@keyframes heroPulse{
  0%,100%{opacity:.92;transform:translateX(-50%) scale(1)}
  50%{opacity:1;transform:translateX(-50%) scale(1.04)}
}
.hero:after{
  content:"";position:absolute;left:0;right:0;top:44%;height:24%;
  background:linear-gradient(to bottom,rgba(5,5,7,.05),#050507 85%);
}
.hero-content{position:relative;z-index:1;max-width:920px;padding:120px 0 80px}
.hero-content>*{animation:heroFadeUp .9s var(--ease-out) both}
.hero-content>*:nth-child(1){animation-delay:.05s}
.hero-content>*:nth-child(2){animation-delay:.18s}
.hero-content>*:nth-child(3){animation-delay:.32s}
.hero-content>*:nth-child(4){animation-delay:.46s}
.hero-content>*:nth-child(5){animation-delay:.60s}
@keyframes heroFadeUp{
  0%{opacity:0;transform:translateY(28px)}
  100%{opacity:1;transform:translateY(0)}
}

.hero .label{
  display:inline-flex;border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.35);padding:9px 16px;
  border-radius:999px;margin-bottom:24px;
  backdrop-filter:blur(8px);
}
.hero p{
  font-size:clamp(16px,2vw,20px);
  max-width:720px;margin:24px auto 0;
  color:rgba(255,255,255,.85);
}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:36px}

.stat-badges{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  margin:90px auto 0;max-width:880px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(13,13,18,.62);
  border-radius:18px;backdrop-filter:blur(18px);padding:20px;
  box-shadow:0 24px 80px rgba(0,0,0,.36);
}
.badge{padding:12px 22px;border-right:1px solid rgba(255,255,255,.16)}
.badge:last-child{border-right:0}
.badge strong{display:block;font-size:30px;line-height:1;font-weight:900;letter-spacing:-.02em}
.badge span{font-size:13px;color:rgba(255,255,255,.72)}

/* Grid + cards */
.grid{display:grid;gap:22px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  border:1px solid rgba(255,255,255,.12);border-radius:18px;
  background:linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  padding:30px;
  transition:transform .4s var(--ease-out),border-color .35s var(--ease),box-shadow .4s var(--ease-out),background .35s var(--ease);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  position:relative;overflow:hidden;
}
.card:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),rgba(184,104,255,.10),transparent 50%);
  opacity:0;transition:opacity .4s var(--ease);pointer-events:none;
}
.card:hover{
  transform:translateY(-6px);
  border-color:rgba(184,104,255,.5);
  box-shadow:0 26px 80px rgba(89,0,255,.22);
}
.card:hover:before{opacity:1}

.icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(122,24,255,.22),rgba(184,104,255,.12));
  display:grid;place-items:center;color:var(--purple2);
  font-size:24px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 8px 20px rgba(122,24,255,.18);
}

.strip{background:linear-gradient(180deg,#050507,#090711)}

/* Dark + counters */
.dark{
  background:linear-gradient(135deg,#160039,#4300a8 52%,#21005d);
  color:#fff;position:relative;overflow:hidden;
}
.dark:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.12),transparent 35%),
             radial-gradient(circle at 80% 100%,rgba(255,255,255,.10),transparent 40%);
  pointer-events:none;
}
.dark .muted{color:rgba(255,255,255,.78)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;position:relative}
.counter{font-size:54px;font-weight:900;letter-spacing:-.04em;color:#fff;font-variant-numeric:tabular-nums}

/* Two-col */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}

/* Abstract visual */
.visual{
  min-height:440px;border-radius:28px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 28% 28%,rgba(184,104,255,.85),transparent 42%),
    radial-gradient(circle at 78% 70%,rgba(99,0,238,.85),transparent 46%),
    radial-gradient(circle at 50% 100%,rgba(217,168,255,.42),transparent 55%),
    linear-gradient(135deg,#1a0046,#3c0090 55%,#190036);
  box-shadow:0 32px 100px rgba(122,24,255,.28),inset 0 1px 0 rgba(255,255,255,.10);
  position:relative;overflow:hidden;
}
.visual:before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(110deg,transparent 0 28px,rgba(255,255,255,.04) 28px 29px),
    repeating-linear-gradient(20deg,transparent 0 28px,rgba(255,255,255,.03) 28px 29px);
  mix-blend-mode:overlay;opacity:.7;
}
.visual:after{
  content:"";position:absolute;left:50%;top:50%;
  width:62%;aspect-ratio:1;transform:translate(-50%,-50%);
  border-radius:50%;
  background:conic-gradient(from 0deg,rgba(255,255,255,.04),rgba(184,104,255,.18),rgba(122,24,255,.10),rgba(255,255,255,.04));
  filter:blur(28px);
  animation:visualSpin 22s linear infinite;
}
@keyframes visualSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.course-card{padding:0;overflow:hidden}
.thumb{
  aspect-ratio:16/9;
  background:radial-gradient(circle at 55% 35%,rgba(184,104,255,.9),transparent 24%),
             linear-gradient(135deg,#0b0b12,#6b00ff 55%,#23004d);
  position:relative;overflow:hidden;
  transition:transform .6s var(--ease-out);
}
.course-card:hover .thumb{transform:scale(1.04)}
.thumb:before{
  content:"AI";position:absolute;inset:28px;
  border:1px solid rgba(255,255,255,.22);border-radius:16px;
  display:grid;place-items:center;font-size:42px;font-weight:900;
  color:rgba(255,255,255,.18);
}
.course-body{padding:26px}
.price{
  display:inline-flex;background:rgba(122,24,255,.16);
  border:1px solid rgba(122,24,255,.4);
  border-radius:999px;padding:7px 14px;
  font-weight:800;margin:16px 0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.was{text-decoration:line-through;color:var(--muted);font-size:13px;margin-left:8px}

.orange-bg{background:linear-gradient(135deg,#050507,#140030 52%,#050507);position:relative;overflow:hidden}

.founder-photo{
  width:min(420px,100%);aspect-ratio:4/5;border-radius:28px;
  background:
    radial-gradient(circle at 30% 30%,rgba(217,168,255,.7),transparent 42%),
    radial-gradient(circle at 70% 80%,rgba(122,24,255,.85),transparent 50%),
    linear-gradient(135deg,#1a0046,#3c0090 55%,#0e0023);
  box-shadow:0 32px 100px rgba(122,24,255,.32);
  border:1px solid rgba(255,255,255,.16);margin:auto;
  color:transparent;font-size:0;position:relative;overflow:hidden;
}
.pill{
  display:inline-flex;border:1px solid rgba(184,104,255,.4);
  background:rgba(122,24,255,.14);border-radius:999px;
  padding:8px 14px;color:#fff;font-weight:800;font-size:12px;
  letter-spacing:.08em;text-transform:uppercase;
}

/* Testimonials */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonials .card{position:relative}
.testimonials .card:before{
  content:"\201C";position:absolute;top:16px;right:24px;
  font-size:72px;line-height:1;color:rgba(184,104,255,.18);
  font-family:Georgia,serif;font-weight:700;
}

.page-hero{
  padding:124px 0;
  background:
    radial-gradient(circle at 50% -20%,rgba(122,24,255,.65),transparent 44%),
    radial-gradient(circle at 80% 120%,rgba(184,104,255,.25),transparent 45%),
    #050507;
  color:#fff;position:relative;overflow:hidden;
}
.page-hero .muted{color:rgba(255,255,255,.78)}
.page-hero h1{animation:heroFadeUp .8s var(--ease-out) both}
.page-hero p{animation:heroFadeUp .8s var(--ease-out) .15s both}

/* Trainer cards */
.trainer-card{display:flex;gap:18px;align-items:center}
.avatar{
  flex:0 0 58px;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--purple),#2a005d);
  color:#fff;display:grid;place-items:center;font-weight:900;
  box-shadow:0 10px 30px rgba(122,24,255,.30),inset 0 1px 0 rgba(255,255,255,.18);
}
.badge-small{
  display:inline-flex;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  padding:5px 10px;border-radius:999px;
  font-size:12px;color:var(--muted);margin-top:8px;
}

/* Sidebar */
.layout-sidebar{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:36px;align-items:start}
.sidebar{position:sticky;top:104px}
.benefit-list{display:grid;gap:14px;padding:0;margin:0}
.benefit-list li{list-style:none;padding-left:30px;position:relative}
.benefit-list li:before{
  content:"";position:absolute;left:0;top:.55em;
  width:16px;height:16px;border-radius:50%;
  background:linear-gradient(135deg,var(--purple),var(--purple2));
  box-shadow:0 4px 10px rgba(122,24,255,.4);
}
.benefit-list li:after{
  content:"";position:absolute;left:5px;top:.85em;
  width:6px;height:3px;border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg);
}

.orange-band{
  background:linear-gradient(135deg,#230064,#7a18ff);
  color:#fff;padding:54px;border-radius:24px;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 30px 90px rgba(122,24,255,.30);
  position:relative;overflow:hidden;
}
.orange-band:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.18),transparent 50%);
}

/* Forms */
.contact-list{display:grid;gap:18px}
.form{display:grid;gap:16px}
.field{display:grid;gap:6px}
.field label{font-weight:800;letter-spacing:.01em}
.field input,.field textarea{
  width:100%;border:1px solid rgba(255,255,255,.14);
  border-radius:12px;padding:14px 16px;
  background:rgba(255,255,255,.04);color:#fff;
  transition:border-color .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease);
}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--purple2);
  background:rgba(184,104,255,.06);
  box-shadow:0 0 0 4px rgba(122,24,255,.18);
}

/* Footer */
.footer{
  background:#030304;color:#fff;
  padding:80px 0 28px;
  border-top:1px solid rgba(255,255,255,.10);
  position:relative;
}
.footer:before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(184,104,255,.45),transparent);
}
.footer-grid{display:grid;grid-template-columns:1.4fr .8fr .8fr 1.4fr;gap:36px}
.footer a,.footer .muted{color:rgba(255,255,255,.68);transition:color .25s var(--ease)}
.footer a:hover{color:#fff}
.footer-col{display:grid;gap:10px;align-content:start}
.footer-col strong{letter-spacing:.05em}
.bottom{
  margin-top:52px;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  color:rgba(255,255,255,.58);font-size:14px;
}

/* Reveal */
.reveal{opacity:0;transform:translateY(28px) scale(.985);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.visible{opacity:1;transform:none}
.grid .card.reveal.visible:nth-child(1){transition-delay:0s}
.grid .card.reveal.visible:nth-child(2){transition-delay:.08s}
.grid .card.reveal.visible:nth-child(3){transition-delay:.16s}
.grid .card.reveal.visible:nth-child(4){transition-delay:.24s}

.mobile-cta{display:none}

/* Dropdown */
.dropdown{position:relative}
.dropdown-menu{
  display:none;position:absolute;top:calc(100% + 6px);left:0;
  background:rgba(9,9,13,.95);
  border:1px solid rgba(255,255,255,.14);border-radius:16px;
  padding:14px;min-width:340px;
  box-shadow:0 22px 70px rgba(0,0,0,.42);
  backdrop-filter:blur(20px);
  opacity:0;transform:translateY(-6px);
  transition:opacity .25s var(--ease),transform .25s var(--ease-out);
}
.dropdown:hover .dropdown-menu{display:grid;gap:4px;opacity:1;transform:translateY(0)}
.dropdown-menu a{padding:10px;border-radius:10px;transition:background .25s var(--ease)}
.dropdown-menu a:hover{background:rgba(184,104,255,.12)}

@media (max-width:1023px){
  .nav-links,.nav-actions .hide-tablet{display:none}
  .hamb{display:block}
  .grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}
  .two-col,.layout-sidebar{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stat-badges,.stats{grid-template-columns:repeat(2,1fr)}
  .badge{border-right:0;border-bottom:1px solid rgba(255,255,255,.14)}
  .badge:nth-last-child(-n+2){border-bottom:0}
}

@media (max-width:767px){
  .section{padding:74px 0}
  .logo img{width:210px}
  .nav-inner{height:70px}
  .hero{min-height:calc(100vh - 70px)}
  .hero-content{padding:86px 0 84px}
  .hero-actions{display:grid}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .card{padding:24px}
  .course-card{padding:0}
  .testimonials{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:12px;gap:14px}
  .testimonials .card{min-width:86%;scroll-snap-align:start}
  .footer-grid{grid-template-columns:1fr}
  .bottom{display:grid}
  .mobile-cta{
    position:fixed;bottom:0;left:0;right:0;z-index:999;
    background:rgba(3,3,4,.85);backdrop-filter:blur(14px);
    border-top:1px solid rgba(255,255,255,.10);
    padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:8px;
  }
  .mobile-cta .btn{padding:10px 8px;font-size:13px;min-height:42px}
  .page-hero{padding:84px 0}
  .visual{min-height:300px}
  .container{width:min(var(--max),calc(100% - 24px))}
  h1{text-align:center}
  .hero p{text-align:center}
}

@media (prefers-reduced-motion:reduce){
  *,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}

/* Light panels */
.community-stats,.light-stats{
  background:#f8f4fb;color:#050507;border-radius:24px;padding:36px;
  border:1px solid rgba(122,24,255,.16);
  box-shadow:0 24px 70px rgba(0,0,0,.10);
}
.community-stats .counter,.community-stats p,.light-stats .counter,.light-stats p{color:#050507!important}

.instructor-photo{
  width:96px;height:96px;border-radius:24px;
  background:
    radial-gradient(circle at 30% 25%,rgba(217,168,255,.6),transparent 50%),
    linear-gradient(135deg,#3a0080,#7a18ff);
  flex:0 0 96px;
  box-shadow:0 16px 38px rgba(122,24,255,.30);
  border:1px solid rgba(255,255,255,.18);
  position:relative;overflow:hidden;
}
.instructor-photo:before{
  content:"FA";position:absolute;inset:0;
  display:grid;place-items:center;font-weight:900;font-size:30px;
  color:rgba(255,255,255,.88);letter-spacing:.04em;
}
.trainer-card{align-items:center}
.trainer-card .avatar{box-shadow:0 10px 30px rgba(122,24,255,.28),inset 0 1px 0 rgba(255,255,255,.18)}

.thumb.genai{background:url('thumb-genai.jpg') center/cover no-repeat}
.thumb.agri{background:url('thumb-agri.jpg') center/cover no-repeat}
.thumb.nlp{background:url('thumb-nlp.jpg') center/cover no-repeat}
.thumb.semi{background:url('thumb-semi.jpg') center/cover no-repeat}
.thumb.genai:before,.thumb.agri:before,.thumb.nlp:before,.thumb.semi:before{display:none}

/* Auth */
.auth-page{
  min-height:calc(100vh - 78px);display:grid;place-items:center;
  padding:80px 0;
  background:
    radial-gradient(circle at 50% 0%,rgba(122,24,255,.55),transparent 45%),
    radial-gradient(circle at 80% 90%,rgba(184,104,255,.22),transparent 45%),
    #050507;
}
.auth-card{
  width:min(520px,calc(100% - 28px));padding:40px;border-radius:28px;
  background:rgba(16,14,24,.84);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 30px 100px rgba(0,0,0,.46);
  backdrop-filter:blur(22px);
  animation:heroFadeUp .8s var(--ease-out) both;
}
.auth-card h1{font-size:42px;text-align:left;margin-bottom:8px}
.auth-card .field{margin-top:16px}
.auth-card .btn{width:100%;margin-top:20px}
.auth-links{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-top:18px;color:#d8c8ff;font-weight:700;
}

.payment-summary{display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:start}
.payment-box{position:sticky;top:108px}
.secure-note{font-size:13px;color:rgba(255,255,255,.72);margin-top:12px}
.course-card .btn-primary{white-space:nowrap}

@media(max-width:767px){
  .payment-summary{grid-template-columns:1fr}
  .auth-card{padding:28px}
  .auth-card h1{font-size:34px}
  .trainer-card{align-items:flex-start}
  .instructor-photo{width:78px;height:78px;flex-basis:78px}
  .instructor-photo:before{font-size:24px}
}

/* Course detail */
.course-detail-hero{
  padding:100px 0 60px;
  background:radial-gradient(circle at 50% -10%,rgba(122,24,255,.62),transparent 46%),#050507;
}
.course-detail-wrap{display:grid;grid-template-columns:minmax(0,1.15fr) .85fr;gap:36px;align-items:center}
.course-preview-img{
  border-radius:26px;overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 28px 90px rgba(122,24,255,.24);
  background:#111;
}
.course-preview-img img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .6s var(--ease-out)}
.course-preview-img:hover img{transform:scale(1.03)}

.course-meta{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0}
.course-meta span{
  display:inline-flex;padding:8px 12px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  font-size:13px;font-weight:800;color:#eee;
}

.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:32px;align-items:start}
.detail-list{display:grid;gap:12px;margin:18px 0 0;padding:0}
.detail-list li{
  list-style:none;padding:16px 18px;border-radius:14px;
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.10);
  transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease-out);
}
.detail-list li:hover{
  background:rgba(184,104,255,.08);border-color:rgba(184,104,255,.3);
  transform:translateX(4px);
}

.curriculum{display:grid;gap:14px}
.module{
  padding:18px;border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.045);
  transition:background .3s var(--ease),border-color .3s var(--ease);
}
.module:hover{background:rgba(184,104,255,.08);border-color:rgba(184,104,255,.3)}
.module strong{display:block;margin-bottom:4px}

.sticky-enroll{position:sticky;top:104px}
.instructor-mini{display:flex;gap:14px;align-items:center;margin-top:20px}
.instructor-mini img{
  width:72px;height:72px;border-radius:18px;object-fit:cover;
  border:1px solid rgba(255,255,255,.14);
}

@media(max-width:1023px){
  .course-detail-wrap,.detail-grid{grid-template-columns:1fr}
  .sticky-enroll{position:static}
}

/* LW course preview */
.course-lw-hero{padding:90px 0}
.course-lw-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:74px;align-items:center}
.eyebrow{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--purple2)}
.course-lw-hero h1{font-size:clamp(38px,5vw,64px);line-height:1.06;margin:14px 0 24px;letter-spacing:-.04em}
.course-lw-hero p{max-width:600px;font-size:17px;line-height:1.75}
.lw-price-btn{margin-top:30px;display:flex;align-items:center;justify-content:center;gap:12px;max-width:520px}
.old-price{display:none!important}

.course-shot{
  width:100%;border-radius:22px;
  box-shadow:0 28px 90px rgba(122,24,255,.24);
  object-fit:cover;aspect-ratio:1.05/1;
  border:1px solid rgba(255,255,255,.14);
}

.instructor-section{padding:96px 0}
.instructor-grid{display:grid;grid-template-columns:1fr .95fr;gap:80px;align-items:center}
.instructor-grid h2{font-size:clamp(36px,4vw,58px);line-height:1.08;text-align:left;margin:10px 0 28px}
.instructor-grid p,.expert-list{font-size:16px;line-height:1.72}
.instructor-img{
  width:100%;box-shadow:0 28px 70px rgba(122,24,255,.24);
  object-fit:cover;aspect-ratio:1/1;
  border-radius:22px;border:1px solid rgba(255,255,255,.14);
}
.expert-list{margin-top:20px;padding-left:0;list-style:none}
.expert-list li{margin:9px 0}
.expert-list li:before{content:'▶';font-size:11px;margin-right:10px;color:var(--purple2)}
.linkedin-box{
  display:inline-grid;place-items:center;width:38px;height:38px;
  background:var(--purple);color:#fff;border-radius:6px;margin-top:20px;
  font-weight:800;transition:transform .25s var(--ease),background .25s var(--ease);
}
.linkedin-box:hover{transform:translateY(-3px);background:var(--purple2)}

.course-dropdown-preview{min-width:360px;padding:12px}
.course-dropdown-preview a{
  display:grid!important;grid-template-columns:60px 1fr;gap:12px;
  align-items:center;padding:10px!important;border-radius:14px;
}
.course-dropdown-preview img{
  width:60px;height:50px;object-fit:cover;border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.28);
}
.course-dropdown-preview small{display:block;color:var(--muted);margin-top:3px}

@media(max-width:900px){
  .course-lw-grid,.instructor-grid{grid-template-columns:1fr;gap:36px}
  .course-lw-hero{padding:56px 0}
  .instructor-section{padding:60px 0}
  .course-dropdown-preview{min-width:0}
  .course-dropdown-preview img{display:none}
  .course-dropdown-preview a{display:block!important}
}

.course-lw-hero{
  background:radial-gradient(circle at 50% -18%,rgba(122,24,255,.62),transparent 45%),#050507!important;
  color:#fff!important;
}
.course-lw-hero .eyebrow{color:var(--purple2)!important}
.course-lw-hero h1{color:#fff!important}
.course-lw-hero .muted{color:rgba(255,255,255,.80)!important}
.lw-price-btn{color:#fff!important}
.instructor-section{
  background:linear-gradient(180deg,#090711,#050507)!important;
  color:#fff!important;
}
.instructor-grid p,.instructor-grid .expert-list{color:rgba(255,255,255,.80)!important}
.instructor-grid h2,.instructor-grid h3{color:#fff!important}

.course-dropdown-preview{
  background:rgba(9,9,13,.95)!important;
  border:1px solid rgba(255,255,255,.14)!important;
}
.course-dropdown-preview a{color:#fff!important}
.course-dropdown-preview small{color:var(--muted)!important}
.course-dropdown-preview a:hover{background:rgba(122,24,255,.18)!important}

/* Course catalogue alignment */
.layout-sidebar .grid-2{align-items:stretch}
.course-card{height:100%;display:flex;flex-direction:column}
.course-card .thumb{flex:0 0 auto}
.course-card .course-body{display:flex;flex-direction:column;flex:1}
.course-card h3{min-height:72px;margin-bottom:10px}
.course-card .muted{min-height:86px}
.course-card .course-body p:has(.avatar){min-height:48px;margin-top:auto}
.course-card .price{align-self:flex-start;margin:14px 0 18px;color:#fff}
.course-card .course-body>div:last-child{margin-top:0}

@media(max-width:767px){
  .course-card h3,.course-card .muted,.course-card .course-body p:has(.avatar){min-height:0}
}

/* Scroll progress */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--purple),var(--purple2));
  z-index:9999;transition:width .12s linear;
  box-shadow:0 0 12px rgba(184,104,255,.6);
}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:#0a0a10}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--purple),#3a0080);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--purple2),var(--purple))}
