@import url('fonts.css');

/* ═══════════════════════════════════════════════════════
   TOKENS
═══════════════════════════════════════════════════════ */
:root {
  --purple:       #6b53a3;
  --purple-l:     #8b6fc7;
  --purple-d:     #4a3878;
  --purple-glow:  rgba(107,83,163,.22);
  --black:        #000;
  --dark:         #0a0a0a;
  --d2:           #111;
  --d3:           #1a1a1a;
  --white:        #fff;
  --soft:         #c8c8c8;
  --muted:        #777;
  --red:          #ff3532;
  --green:        #14a800;
  --display:      'Syne', sans-serif;
  --body:         'DM Sans', sans-serif;
  --ease:         cubic-bezier(.16,1,.3,1);
  --nav-h:        72px;
}

/* ═══════════════════════════════════════════════════════
   RESET
═══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);font-size:16px;line-height:1.65;color:var(--soft);background:var(--black);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}

/* ═══════════════════════════════════════════════════════
   TYPE
═══════════════════════════════════════════════════════ */
h1,h2,h3,h4,h5,h6{font-family:var(--display);font-weight:700;line-height:1.1;color:var(--white);letter-spacing:-.025em}
.xl  {font-size:clamp(52px,8vw,108px);font-weight:800;letter-spacing:-.04em;line-height:.95}
.lg  {font-size:clamp(38px,5.5vw,72px);font-weight:800;letter-spacing:-.03em;line-height:1.0}
.md  {font-size:clamp(28px,3.8vw,52px);font-weight:700;letter-spacing:-.025em;line-height:1.08}
.sm  {font-size:clamp(22px,2.8vw,36px);font-weight:700;letter-spacing:-.02em}
.eye {
  font-family:var(--body);font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--purple-l);
  display:inline-flex;align-items:center;gap:8px;
}
.eye::before{content:'';width:20px;height:1px;background:var(--purple-l)}
.bl{font-size:18px;line-height:1.75;color:var(--soft)}
.bm{font-size:15px;line-height:1.8;color:var(--soft)}
.bs{font-size:13px;line-height:1.7;color:var(--muted)}

/* ═══════════════════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════════════════ */
.wrap{width:100%;max-width:1380px;margin:0 auto;padding:0 60px}
.sec {padding:120px 0;position:relative}
.sec--d2{background:var(--d2)}
.sec--d3{background:var(--d3)}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.gs{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.row--c{justify-content:center}
.mb8{margin-bottom:8px}
.mb12{margin-bottom:12px}
.mb16{margin-bottom:16px}
.mb20{margin-bottom:20px}
.mb24{margin-bottom:24px}
.mb32{margin-bottom:32px}
.mb40{margin-bottom:40px}
.mb56{margin-bottom:56px}
.mb64{margin-bottom:64px}
.tc{text-align:center}
.mxc{margin:0 auto}

/* ═══════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--body);font-weight:600;font-size:15px;
  padding:15px 30px;border-radius:8px;border:1.5px solid transparent;
  transition:all .25s var(--ease);white-space:nowrap;cursor:pointer;
  position:relative;overflow:hidden;
}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.09);opacity:0;transition:opacity .2s}
.btn:hover::after{opacity:1}
.btn:active{transform:scale(.98)}

.btn-p{background:var(--purple);color:var(--white);border-color:var(--purple)}
.btn-p:hover{background:var(--purple-l);border-color:var(--purple-l);transform:translateY(-2px);box-shadow:0 8px 32px var(--purple-glow)}

.btn-u{background:var(--green);color:var(--white);border-color:var(--green)}
.btn-u:hover{background:#10940a;border-color:#10940a;transform:translateY(-2px);box-shadow:0 8px 28px rgba(20,168,0,.3)}

.btn-o{background:transparent;color:var(--white);border-color:rgba(139,111,199,.4)}
.btn-o:hover{border-color:var(--purple-l);background:rgba(107,83,163,.1)}

.btn-r{background:var(--red);color:var(--white);border-color:var(--red)}
.btn-r:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,53,50,.35)}

.btn-sm{padding:10px 22px;font-size:13px;border-radius:7px}
.btn-lg{padding:18px 38px;font-size:17px}

/* ═══════════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:rgba(0,0,0,.82);
  backdrop-filter:blur(20px) saturate(1.5);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:all .35s var(--ease);
}
.nav.sc{background:rgba(0,0,0,.96);border-bottom-color:rgba(107,83,163,.2)}
.nav__in{
  display:flex;align-items:center;gap:32px;
  height:100%;max-width:1380px;margin:0 auto;padding:0 60px;
}
.nav__logo{
  display:flex;align-items:center;gap:10px;flex-shrink:0;
  font-family:var(--display);font-weight:800;font-size:20px;
  color:var(--white);letter-spacing:-.04em;
}
.nav__mark{
  width:38px;height:38px;background:var(--purple);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:17px;font-weight:800;color:var(--white);flex-shrink:0;
}
.nav__logo em{color:var(--purple-l);font-style:normal;font-weight:400}
.nav__links{display:flex;align-items:center;gap:2px;flex:1}
.nav__links a{
  font-size:14px;color:var(--soft);padding:8px 13px;
  border-radius:6px;transition:all .2s;
}
.nav__links a:hover,.nav__links a.act{color:var(--white);background:rgba(255,255,255,.06)}
.nav__acad{
  background:var(--red)!important;color:var(--white)!important;
  border-radius:20px!important;padding:5px 12px!important;
  font-size:12px!important;font-weight:600!important;
  animation:pulse-r 2.5s ease-in-out infinite;
}
@keyframes pulse-r{0%,100%{box-shadow:0 0 0 0 rgba(255,53,50,.4)}50%{box-shadow:0 0 0 6px rgba(255,53,50,0)}}
.nav__act{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}
.nav__hbg{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__hbg span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}
.nav__mob{
  display:none;flex-direction:column;
  position:fixed;top:var(--nav-h);left:0;right:0;z-index:999;
  background:rgba(0,0,0,.97);backdrop-filter:blur(20px);
  padding:24px 60px 32px;gap:4px;
  border-bottom:1px solid rgba(107,83,163,.18);
}
.nav__mob.open{display:flex}
.nav__mob a{font-size:17px;color:var(--soft);padding:13px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.nav__mob a:hover{color:var(--white)}
.nav__mob-btns{display:flex;flex-direction:column;gap:10px;margin-top:16px}

/* ═══════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding-top:var(--nav-h);position:relative;overflow:hidden;
}
.hero__grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(107,83,163,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(107,83,163,.04) 1px,transparent 1px);
  background-size:80px 80px;
}
.hero__g1{
  position:absolute;right:-80px;top:-80px;
  width:700px;height:700px;pointer-events:none;
  background:radial-gradient(circle,rgba(107,83,163,.17) 0%,transparent 70%);
}
.hero__g2{
  position:absolute;right:180px;bottom:0;
  width:400px;height:400px;pointer-events:none;
  background:radial-gradient(circle,rgba(255,53,50,.055) 0%,transparent 70%);
}
.hero__in{
  position:relative;z-index:1;width:100%;
  max-width:1380px;margin:0 auto;padding:0 60px;
  display:grid;grid-template-columns:1fr 400px;gap:60px;align-items:center;
}
.hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(107,83,163,.12);border:1px solid rgba(107,83,163,.28);
  border-radius:100px;padding:6px 14px 6px 8px;margin-bottom:36px;
}
.hero__dot{width:8px;height:8px;border-radius:50%;background:var(--purple-l);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.hero__badge span{font-size:12px;color:var(--purple-l);font-weight:500}
.hero__hl{margin-bottom:28px}
.hero__hl .ln{display:block;overflow:hidden}
.hero__hl .ln s{display:block;text-decoration:none;animation:su .8s var(--ease) both}
.hero__hl .ln:nth-child(1) s{animation-delay:.1s}
.hero__hl .ln:nth-child(2) s{animation-delay:.2s;color:var(--purple-l)}
.hero__hl .ln:nth-child(3) s{animation-delay:.3s;color:rgba(255,255,255,.3)}
@keyframes su{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.hero__sub{font-size:17px;line-height:1.75;color:var(--soft);max-width:540px;margin-bottom:40px;animation:fi 1s var(--ease) .5s both}
.hero__cta{animation:fi 1s var(--ease) .65s both}
@keyframes fi{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.hero__reel{
  margin-top:32px;display:inline-flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:12px;padding:13px 20px;cursor:pointer;transition:all .3s;
  animation:fi 1s var(--ease) .8s both;max-width:fit-content;
}
.hero__reel:hover{background:rgba(107,83,163,.1);border-color:rgba(107,83,163,.3)}
.hero__play{
  width:44px;height:44px;background:var(--purple);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s;
}
.hero__reel:hover .hero__play{transform:scale(1.1)}
.hero__play svg{width:13px;height:13px;fill:var(--white);margin-left:2px}
.hero__rl-t{font-size:14px;font-weight:600;color:var(--white)}
.hero__rl-s{font-size:12px;color:var(--muted);margin-top:2px}

/* stat cards right */
.hero__stats{display:flex;flex-direction:column;gap:14px}
.sc-card{
  background:var(--d3);border:1px solid rgba(107,83,163,.14);
  border-radius:16px;padding:22px 26px;
  display:flex;align-items:center;gap:20px;
  transition:all .3s;animation:fi .8s var(--ease) both;
}
.sc-card:nth-child(1){animation-delay:.4s}
.sc-card:nth-child(2){animation-delay:.5s}
.sc-card:nth-child(3){animation-delay:.6s}
.sc-card:nth-child(4){animation-delay:.7s}
.sc-card:hover{border-color:rgba(107,83,163,.38);background:rgba(107,83,163,.07)}
.sc-val{font-family:var(--display);font-size:36px;font-weight:800;color:var(--purple-l);letter-spacing:-.03em;line-height:1}
.sc-lbl{font-size:12px;color:var(--muted);margin-top:4px}

/* ═══════════════════════════════════════════════════════
   CARDS
═══════════════════════════════════════════════════════ */
.card{
  background:var(--d3);border:1px solid rgba(255,255,255,.05);
  border-radius:20px;padding:28px;transition:all .35s var(--ease);
  position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(107,83,163,.5),transparent);
  opacity:0;transition:opacity .3s;
}
.card:hover{border-color:rgba(107,83,163,.24);transform:translateY(-4px)}
.card:hover::before{opacity:1}
.card:hover{box-shadow:0 20px 60px rgba(0,0,0,.38),0 0 0 1px rgba(107,83,163,.09)}

/* service */
.sv-icon{
  width:50px;height:50px;border-radius:12px;margin-bottom:16px;
  background:rgba(107,83,163,.14);border:1px solid rgba(107,83,163,.22);
  display:flex;align-items:center;justify-content:center;font-size:22px;
  transition:all .3s;
}
.card:hover .sv-icon{background:rgba(107,83,163,.24);transform:scale(1.05) rotate(-3deg)}
.sv-name{font-family:var(--display);font-size:17px;font-weight:700;color:var(--white);margin-bottom:8px}
.sv-desc{font-size:14px;color:var(--muted);line-height:1.65;flex:1}
.sv-link{font-size:13px;color:var(--purple-l);font-weight:500;margin-top:16px;display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
.card:hover .sv-link{gap:8px}

/* portfolio */
.pc{
  border-radius:16px;overflow:hidden;
  border:1px solid rgba(255,255,255,.05);
  transition:all .35s var(--ease);cursor:pointer;
}
.pc:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(0,0,0,.5);border-color:rgba(107,83,163,.28)}
.pc-thumb{
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;font-size:64px;
}
.pc-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%)}
.pc:hover .pc-thumb img,.pc:hover .pc-thumb span{transform:scale(1.05)}
.pc-body{padding:18px 20px;background:var(--d3)}
.pc-cat{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--purple-l);margin-bottom:5px}
.pc-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--white)}

/* testimonial */
.tc-card{
  background:var(--d3);border:1px solid rgba(255,255,255,.05);
  border-radius:20px;padding:30px;
}
.tc-stars{display:flex;gap:3px;margin-bottom:18px;font-size:15px}
.tc-q{font-size:15px;color:var(--soft);line-height:1.75;font-style:italic;margin-bottom:22px}
.tc-div{height:1px;background:rgba(255,255,255,.06);margin-bottom:18px}
.tc-auth{display:flex;align-items:center;gap:12px}
.tc-av{
  width:42px;height:42px;border-radius:50%;background:var(--purple);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:13px;font-weight:700;color:var(--white);flex-shrink:0;
}
.tc-name{font-size:14px;font-weight:600;color:var(--white)}
.tc-role{font-size:12px;color:var(--muted)}

/* pricing */
.pr-card{
  padding:36px 30px;background:var(--d3);
  border:1px solid rgba(255,255,255,.06);border-radius:24px;
  position:relative;transition:all .35s var(--ease);
}
.pr-card:hover{transform:translateY(-4px)}
.pr-feat{background:rgba(107,83,163,.09);border-color:var(--purple);border-width:2px}
.pr-badge{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--purple);color:var(--white);
  font-size:12px;font-weight:600;padding:4px 16px;border-radius:100px;white-space:nowrap;
}
.pr-name{font-family:var(--display);font-size:20px;font-weight:700;color:var(--white);margin-bottom:7px}
.pr-desc{font-size:13px;color:var(--muted);margin-bottom:22px}
.pr-price{font-family:var(--display);font-size:52px;font-weight:800;color:var(--white);letter-spacing:-.03em;line-height:1;margin-bottom:5px}
.pr-note{font-size:12px;color:var(--muted);margin-bottom:22px}
.pr-div{height:1px;background:rgba(255,255,255,.06);margin-bottom:22px}
.pr-feats{display:flex;flex-direction:column;gap:9px;margin-bottom:28px}
.pr-feat-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--soft)}
.pr-feat-row::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--purple);opacity:.5;flex-shrink:0}

/* team */
.tm-card{
  padding:26px;background:var(--d3);
  border:1px solid rgba(255,255,255,.05);border-radius:20px;text-align:center;transition:all .3s;
}
.tm-card:hover{border-color:rgba(107,83,163,.28);transform:translateY(-4px)}
.tm-av{
  width:76px;height:76px;border-radius:50%;background:var(--purple);
  margin:0 auto 16px;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:22px;font-weight:800;color:var(--white);
  position:relative;
}
.tm-av::after{content:'';position:absolute;inset:-3px;border-radius:50%;border:1.5px solid rgba(107,83,163,.28)}
.tm-name{font-family:var(--display);font-size:16px;font-weight:700;color:var(--white);margin-bottom:4px}
.tm-role{font-size:13px;color:var(--purple-l);margin-bottom:11px}
.tm-bio{font-size:13px;color:var(--muted);line-height:1.6}

/* value */
.val-card{
  padding:26px;background:var(--d3);
  border:1px solid rgba(255,255,255,.05);border-radius:14px;
  border-left:3px solid var(--purple);transition:all .3s;
}
.val-card:hover{background:rgba(107,83,163,.06);border-left-color:var(--purple-l)}
.val-icon{font-size:26px;margin-bottom:12px}
.val-name{font-family:var(--display);font-size:17px;font-weight:700;color:var(--white);margin-bottom:7px}
.val-desc{font-size:14px;color:var(--muted);line-height:1.65}

/* case study */
.cs-card{
  background:var(--d3);border:1px solid rgba(255,255,255,.06);
  border-radius:24px;overflow:hidden;
  display:grid;grid-template-columns:240px 1fr;position:relative;
}
.cs-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--purple)}
.cs-metrics{
  background:rgba(107,83,163,.06);border-right:1px solid rgba(107,83,163,.1);
  padding:36px 26px;display:flex;flex-direction:column;
}
.cs-m{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.cs-m:last-child{border-bottom:none}
.cs-mval{font-family:var(--display);font-size:30px;font-weight:800;color:var(--purple-l);letter-spacing:-.02em;line-height:1}
.cs-mlbl{font-size:12px;color:var(--muted);margin-top:4px}
.cs-body{padding:38px 38px;display:flex;flex-direction:column}
.cs-num{font-size:10px;font-weight:600;letter-spacing:.15em;color:var(--red);margin-bottom:14px;text-transform:uppercase}
.cs-title{font-family:var(--display);font-size:26px;font-weight:800;color:var(--white);letter-spacing:-.02em;line-height:1.15;margin-bottom:14px}
.cs-desc{font-size:14px;color:var(--soft);line-height:1.75;margin-bottom:22px;flex:1}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.tag{
  font-size:12px;color:var(--purple-l);
  background:rgba(107,83,163,.12);border:1px solid rgba(107,83,163,.25);
  padding:4px 12px;border-radius:100px;
}

/* addon */
.add-card{
  padding:22px;background:var(--d3);border:1px solid rgba(255,255,255,.05);
  border-radius:13px;display:flex;align-items:center;justify-content:space-between;gap:14px;
  transition:border-color .3s;
}
.add-card:hover{border-color:rgba(107,83,163,.2)}
.add-name{font-size:15px;font-weight:600;color:var(--white);margin-bottom:3px}
.add-desc{font-size:12px;color:var(--muted)}
.add-price{font-family:var(--display);font-size:20px;font-weight:700;color:var(--purple-l);white-space:nowrap}

/* course */
.co-card{border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.05);transition:all .35s var(--ease)}
.co-card:hover{transform:translateY(-6px);border-color:rgba(107,83,163,.28);box-shadow:0 24px 64px rgba(0,0,0,.5)}
.co-thumb{height:148px;display:flex;align-items:center;justify-content:center;font-size:52px;position:relative;overflow:hidden}
.co-body{padding:20px;background:var(--d3)}
.co-cat{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:7px}
.co-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--white);margin-bottom:12px;line-height:1.35}
.co-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid rgba(255,255,255,.06)}
.co-price{font-family:var(--display);font-size:17px;font-weight:800;color:var(--purple-l)}
.co-batch{font-size:11px;color:var(--muted)}

/* hof */
.hof-card{
  display:flex;align-items:center;gap:14px;
  background:var(--d3);border:1px solid rgba(255,255,255,.05);
  border-radius:14px;padding:18px 22px;transition:border-color .3s;
}
.hof-card:hover{border-color:rgba(107,83,163,.24)}
.hof-av{
  width:48px;height:48px;border-radius:50%;background:var(--purple);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:14px;font-weight:800;color:var(--white);flex-shrink:0;
}
.hof-name{font-size:14px;font-weight:600;color:var(--white)}
.hof-det{font-size:12px;color:var(--muted);margin-top:2px}
.hof-prize{margin-left:auto;font-size:14px;color:var(--purple-l);font-weight:600;white-space:nowrap}

/* info card */
.info-card{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--d3);border:1px solid rgba(107,83,163,.1);
  border-radius:14px;padding:18px 20px;transition:border-color .3s;
}
.info-card:hover{border-color:rgba(107,83,163,.28)}
.info-icon{
  width:40px;height:40px;border-radius:10px;background:rgba(107,83,163,.14);
  display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;
}
.info-lbl{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.info-val{font-size:14px;color:var(--soft);line-height:1.5}

/* ═══════════════════════════════════════════════════════
   STATS STRIP
═══════════════════════════════════════════════════════ */
.strip{
  display:flex;border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.strip-i{
  flex:1;padding:38px 20px;text-align:center;
  border-right:1px solid rgba(255,255,255,.05);transition:background .3s;
}
.strip-i:last-child{border-right:none}
.strip-i:hover{background:rgba(107,83,163,.05)}
.strip-v{font-family:var(--display);font-size:40px;font-weight:800;color:var(--purple-l);letter-spacing:-.03em;line-height:1}
.strip-l{font-size:13px;color:var(--muted);margin-top:5px;font-weight:500}

/* ═══════════════════════════════════════════════════════
   CLOSING CTA
═══════════════════════════════════════════════════════ */
.cta-sec{
  padding:140px 0;text-align:center;position:relative;
  background:var(--black);overflow:hidden;
}
.cta-glow{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:800px;height:500px;pointer-events:none;
  background:radial-gradient(ellipse,rgba(107,83,163,.11) 0%,transparent 70%);
}
.cta-sec p{color:var(--muted);max-width:520px;margin:0 auto 38px;font-size:16px}

/* ═══════════════════════════════════════════════════════
   LEADERBOARD
═══════════════════════════════════════════════════════ */
.lb{width:100%;border-collapse:collapse;background:var(--d3);border:1px solid rgba(107,83,163,.14);border-radius:16px;overflow:hidden}
.lb th{background:rgba(107,83,163,.11);padding:13px 20px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.lb td{padding:13px 20px;font-size:14px;color:var(--soft);border-top:1px solid rgba(255,255,255,.04)}
.lb tr:nth-child(1) td{background:rgba(255,215,0,.04)}
.lb tr:nth-child(2) td{background:rgba(192,192,192,.03)}
.lb tr:nth-child(3) td{background:rgba(205,127,50,.03)}
.lb-rank{font-family:var(--display);font-weight:800;font-size:15px}
.lb-tot{font-family:var(--display);font-weight:700;color:var(--purple-l)!important}

/* ═══════════════════════════════════════════════════════
   FORM
═══════════════════════════════════════════════════════ */
.fg{margin-bottom:18px}
.fl{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;letter-spacing:.06em;text-transform:uppercase}
.fi,.fta,.fsel{
  width:100%;background:rgba(255,255,255,.04);
  border:1px solid rgba(107,83,163,.2);border-radius:8px;
  color:var(--white);font-size:15px;padding:13px 16px;transition:all .2s;appearance:none;
}
.fi:focus,.fta:focus,.fsel:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(107,83,163,.14);background:rgba(107,83,163,.04)}
.fi::placeholder,.fta::placeholder{color:rgba(119,119,119,.55)}
.fta{min-height:120px;resize:vertical}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ═══════════════════════════════════════════════════════
   FILTERS
═══════════════════════════════════════════════════════ */
.ftabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:38px}
.ftab{
  padding:8px 18px;border-radius:100px;font-size:13px;font-weight:500;
  cursor:pointer;border:1px solid rgba(107,83,163,.24);color:var(--soft);
  background:transparent;transition:all .2s;font-family:var(--body);
}
.ftab:hover,.ftab.act{background:var(--purple);border-color:var(--purple);color:var(--white)}

/* ═══════════════════════════════════════════════════════
   FAQ
═══════════════════════════════════════════════════════ */
.faq-i{border-bottom:1px solid rgba(255,255,255,.06);overflow:hidden}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;cursor:pointer;font-size:15px;font-weight:600;
  color:var(--white);text-align:left;gap:14px;transition:color .2s;
}
.faq-q:hover{color:var(--purple-l)}
.faq-ic{
  width:27px;height:27px;border-radius:50%;border:1.5px solid rgba(107,83,163,.3);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:16px;color:var(--purple-l);transition:all .3s;
}
.faq-i.open .faq-ic{background:var(--purple);border-color:var(--purple);transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;font-size:14px;color:var(--muted);
  line-height:1.75;transition:max-height .4s var(--ease),padding .3s;
}
.faq-i.open .faq-a{max-height:300px;padding-bottom:20px}

/* ═══════════════════════════════════════════════════════
   REVEAL
═══════════════════════════════════════════════════════ */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.vis{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}
.rv.d4{transition-delay:.4s}.rv.d5{transition-delay:.5s}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}.hero__hl .ln s{animation:none}}

/* ═══════════════════════════════════════════════════════
   PAGE HERO (inner)
═══════════════════════════════════════════════════════ */
.ph{
  padding:calc(var(--nav-h) + 80px) 0 80px;
  background:var(--d2);position:relative;overflow:hidden;
}
.ph__g{
  position:absolute;right:-80px;top:-80px;width:480px;height:480px;pointer-events:none;
  background:radial-gradient(circle,rgba(107,83,163,.11) 0%,transparent 70%);
}

/* trust bar */
.trust{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(20,168,0,.08);border:1px solid rgba(20,168,0,.2);
  border-radius:100px;padding:7px 18px;font-size:13px;font-weight:500;color:var(--soft);
}
.trust-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}

/* banner */
.banner{
  background:var(--d3);border:1px solid rgba(107,83,163,.18);
  border-radius:14px;padding:22px 28px;
  display:flex;align-items:center;gap:14px;
}
.banner-icon{font-size:22px;flex-shrink:0}
.banner-title{font-size:14px;font-weight:600;color:var(--white);margin-bottom:3px}
.banner-text{font-size:13px;color:var(--muted);line-height:1.5}

/* ssl */
.ssl-bar{
  background:var(--d3);border:1px solid rgba(107,83,163,.14);
  border-radius:11px;padding:14px 22px;margin-top:18px;
  display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);
}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.footer{background:var(--black);border-top:1px solid rgba(107,83,163,.11);padding:76px 0 0}
.footer__g{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;padding-bottom:56px}
.footer__logo{font-family:var(--display);font-size:22px;font-weight:800;color:var(--white);margin-bottom:13px;letter-spacing:-.03em}
.footer__desc{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:14px}
.footer__loc{font-size:13px;color:var(--muted)}
.footer__ct{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:18px}
.footer__col a{display:block;font-size:14px;color:var(--muted);margin-bottom:11px;transition:color .2s}
.footer__col a:hover{color:var(--white)}
.footer__bot{border-top:1px solid rgba(255,255,255,.04);padding:22px 0;display:flex;align-items:center;justify-content:space-between}
.footer__copy{font-size:13px;color:var(--muted)}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .wrap{padding:0 40px}
  .nav__in{padding:0 40px}
  .hero__in{grid-template-columns:1fr 360px;gap:40px}
  .footer__g{grid-template-columns:1fr 1fr;gap:36px}
  .cs-card{grid-template-columns:200px 1fr}
}
@media(max-width:900px){
  .wrap{padding:0 24px}
  .nav__in{padding:0 24px}
  .nav__links,.nav__act{display:none}
  .nav__hbg{display:flex}
  .sec{padding:80px 0}
  .hero__in{grid-template-columns:1fr}
  .hero__stats{flex-direction:row;flex-wrap:wrap}
  .sc-card{flex:1;min-width:150px}
  .g3{grid-template-columns:repeat(2,1fr)}
  .gs{grid-template-columns:1fr;gap:44px}
  .cs-card{grid-template-columns:1fr}
  .cs-metrics{border-right:none;border-bottom:1px solid rgba(107,83,163,.1);display:grid;grid-template-columns:repeat(2,1fr)}
  .f2{grid-template-columns:1fr}
  .footer__g{grid-template-columns:1fr 1fr}
  .nav__mob{padding:20px 24px 28px}
}
@media(max-width:600px){
  .sec{padding:60px 0}
  .g3{grid-template-columns:1fr}
  .g2{grid-template-columns:1fr}
  .g4{grid-template-columns:repeat(2,1fr)}
  .strip{flex-direction:column}
  .strip-i{border-right:none;border-bottom:1px solid rgba(255,255,255,.05)}
  .row{flex-direction:column;align-items:stretch}
  .row .btn{text-align:center;justify-content:center}
  .footer__g{grid-template-columns:1fr;gap:28px}
  .footer__bot{flex-direction:column;gap:6px;text-align:center}
  .hero__in{padding:0 24px}
}

/* ═══════════════════════════════════════════════════════
   BUGFIXES — Added after audit
═══════════════════════════════════════════════════════ */

/* 1. Page Hero must be position:relative for glow to clip */
.ph { position:relative; }

/* 2. Missing .mb48 utility class */
.mb48 { margin-bottom:48px; }

/* 3. CTA section needs position:relative for glow to work */
.cta-sec { position:relative; }

/* 4. Nav mobile menu — z-index must sit above page content */
.nav__mob { z-index:1001; }

/* 5. Academy teaser — responsive grid fix */
@media(max-width:900px){
  .ph { padding-top: calc(var(--nav-h) + 56px); padding-bottom:56px; }
}
@media(max-width:700px){
  [style*="grid-template-columns:1fr auto"]{
    grid-template-columns:1fr !important;
  }
}

/* 6. Portfolio grid — fix featured 2fr/1fr layout on mobile */
@media(max-width:700px){
  [style*="grid-template-columns:2fr 1fr"]{
    grid-template-columns:1fr !important;
  }
}

/* 7. Leaderboard table — responsive font size */
@media(max-width:600px){
  .lb th, .lb td { padding:10px 12px; font-size:13px; }
  .lb-rank { font-size:13px; }
}

/* 8. Contact grid — already handled by .contact-grid media query in page <style> */

/* 9. Form grid on contact page */
@media(max-width:600px){
  .form-card [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr !important;
  }
}

/* 10. Strip — ensure full width with no overflow */
.strip { width:100%; overflow:hidden; }

/* 11. Footer column titles should not inherit anchor styles */
.footer__ct { display:block; }

/* 12. Case study card responsive — better mobile layout */
@media(max-width:600px){
  .cs-card { display:flex; flex-direction:column; }
  .cs-metrics { display:grid; grid-template-columns:repeat(2,1fr); border-right:none; border-bottom:1px solid rgba(107,83,163,.1); }
  .cs-body { padding:28px 24px; }
}

/* 13. Services page svc-img responsive (already in page style, reinforced here) */
@media(max-width:600px){
  .g4 { grid-template-columns:1fr 1fr; }
}

/* 14. Smooth scrolling — anchor links with empty hash (#) should not fire */
/* Handled in JS; no CSS needed */

/* 15. Nav logo font-family fix — display font needs font-family applied */
.nav__logo { font-family: var(--display); }

/* 16. Button color override for hover states — ::after was overlapping text */
.btn { color: inherit; }
.btn-p, .btn-p:hover { color: var(--white); }
.btn-u, .btn-u:hover { color: var(--white); }
.btn-r, .btn-r:hover { color: var(--white); }

/* ═══════════════════════════════════════════════════════
   THEME TOGGLE BUTTON
═══════════════════════════════════════════════════════ */
.theme-toggle{
  width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .25s var(--ease);flex-shrink:0;
  color:var(--soft);padding:0;
}
.theme-toggle:hover{background:rgba(107,83,163,.18);border-color:rgba(107,83,163,.4);color:var(--white)}
.theme-toggle svg{width:17px;height:17px;fill:currentColor}
/* show sun in dark mode (click → light), show moon in light mode (click → dark) */
[data-theme="dark"]  .ti-sun  { display:block }
[data-theme="dark"]  .ti-moon { display:none  }
[data-theme="light"] .ti-sun  { display:none  }
[data-theme="light"] .ti-moon { display:block }

/* ═══════════════════════════════════════════════════════
   LIGHT THEME — variable overrides
═══════════════════════════════════════════════════════ */
[data-theme="light"]{
  --black:      #ffffff;
  --dark:       #f7f7f7;
  --d2:         #f0f0f0;
  --d3:         #ffffff;
  --white:      #111111;
  --soft:       #3d3d3d;
  --muted:      #888888;
  --purple-glow:rgba(107,83,163,.18);
}

/* nav */
[data-theme="light"] .nav{background:rgba(255,255,255,.88);border-bottom-color:rgba(0,0,0,.08)}
[data-theme="light"] .nav.sc{background:rgba(255,255,255,.98);border-bottom-color:rgba(0,0,0,.12)}
[data-theme="light"] .nav__mob{background:rgba(255,255,255,.99);border-bottom-color:rgba(0,0,0,.1)}
[data-theme="light"] .nav__links a{color:#555}
[data-theme="light"] .nav__links a:hover,[data-theme="light"] .nav__links a.act{color:#111;background:rgba(0,0,0,.06)}
[data-theme="light"] .nav__mob a{color:#555;border-bottom-color:rgba(0,0,0,.05)}
[data-theme="light"] .nav__mob a:hover{color:#111}
[data-theme="light"] .nav__hbg span{background:#333}
[data-theme="light"] .theme-toggle{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.12);color:#555}
[data-theme="light"] .theme-toggle:hover{background:rgba(107,83,163,.1);border-color:var(--purple)}

/* cards + borders */
[data-theme="light"] .card{border-color:rgba(0,0,0,.09);box-shadow:0 2px 12px rgba(0,0,0,.05)}
[data-theme="light"] .card:hover{border-color:rgba(107,83,163,.35);box-shadow:0 20px 50px rgba(0,0,0,.1)}
[data-theme="light"] .sc-card{border-color:rgba(0,0,0,.09);background:var(--d3)}
[data-theme="light"] .sc-card:hover{border-color:rgba(107,83,163,.35);background:rgba(107,83,163,.04)}
[data-theme="light"] .tc-card{border-color:rgba(0,0,0,.09);box-shadow:0 2px 12px rgba(0,0,0,.05)}
[data-theme="light"] .tc-div{background:rgba(0,0,0,.09)}
[data-theme="light"] .pr-card{border-color:rgba(0,0,0,.09);box-shadow:0 2px 12px rgba(0,0,0,.05)}
[data-theme="light"] .pr-feat{border-color:var(--purple);border-width:2px;background:rgba(107,83,163,.06)}
[data-theme="light"] .pr-div{background:rgba(0,0,0,.09)}
[data-theme="light"] .pc{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .pc-body{background:var(--d3)}
[data-theme="light"] .cs-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .cs-metrics{border-right-color:rgba(0,0,0,.09);background:rgba(107,83,163,.04)}
[data-theme="light"] .cs-m{border-bottom-color:rgba(0,0,0,.06)}
[data-theme="light"] .val-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .val-card:hover{background:rgba(107,83,163,.04)}
[data-theme="light"] .add-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .info-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .hof-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .co-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .co-foot{border-top-color:rgba(0,0,0,.07)}
[data-theme="light"] .co-body{background:var(--d3)}
[data-theme="light"] .tm-card{border-color:rgba(0,0,0,.09)}
[data-theme="light"] .tm-card:hover{border-color:rgba(107,83,163,.3)}
[data-theme="light"] .banner{background:var(--d3);border-color:rgba(107,83,163,.2)}
[data-theme="light"] .ssl-bar{background:var(--d3);border-color:rgba(0,0,0,.09)}
[data-theme="light"] .lb{background:var(--d3);border-color:rgba(107,83,163,.2)}
[data-theme="light"] .lb th{background:rgba(107,83,163,.08)}
[data-theme="light"] .lb td{border-top-color:rgba(0,0,0,.06)}

/* strips + dividers */
[data-theme="light"] .strip{border-top-color:rgba(0,0,0,.08);border-bottom-color:rgba(0,0,0,.08);background:var(--dark)}
[data-theme="light"] .strip-i{border-right-color:rgba(0,0,0,.08)}
[data-theme="light"] .strip-i:hover{background:rgba(107,83,163,.06)}

/* form */
[data-theme="light"] .fi,[data-theme="light"] .fta,[data-theme="light"] .fsel{
  background:rgba(0,0,0,.04);color:#111;border-color:rgba(0,0,0,.15)
}
[data-theme="light"] .fi:focus,[data-theme="light"] .fta:focus,[data-theme="light"] .fsel:focus{
  background:rgba(107,83,163,.04);border-color:var(--purple)
}
[data-theme="light"] .fi::placeholder,[data-theme="light"] .fta::placeholder{color:rgba(0,0,0,.28)}
[data-theme="light"] .fl{color:#888}
[data-theme="light"] .ftab{color:#555;border-color:rgba(0,0,0,.15)}

/* FAQ */
[data-theme="light"] .faq-i{border-bottom-color:rgba(0,0,0,.08)}
[data-theme="light"] .faq-q{color:#111}

/* footer */
[data-theme="light"] .footer{background:var(--black);border-top-color:rgba(107,83,163,.2)}
[data-theme="light"] .footer__bot{border-top-color:rgba(0,0,0,.08)}
[data-theme="light"] .footer__col a{color:#888}
[data-theme="light"] .footer__col a:hover{color:#111}

/* hero */
[data-theme="light"] .hero__grid{
  background-image:
    linear-gradient(rgba(107,83,163,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(107,83,163,.07) 1px,transparent 1px)
}

/* page hero inner */
[data-theme="light"] .ph{background:var(--dark)}

/* services page inline border */
[data-theme="light"] .svc-row{border-bottom-color:rgba(0,0,0,.07)}

/* btn-o */
[data-theme="light"] .btn-o{color:#111;border-color:rgba(107,83,163,.4)}
[data-theme="light"] .btn-o:hover{color:#111;background:rgba(107,83,163,.1)}
