/* =========================================================================
   KSG All-In-One — Premium Institutional Stylesheet
   Komunitas Saham Gorengan
   ========================================================================= */

/* ---------- Design Tokens ---------- */
:root{
  --ksg-blue-950:#06112b;
  --ksg-blue-900:#0a1840;
  --ksg-blue-800:#0f1f55;
  --ksg-blue-700:#15296f;
  --ksg-gold:#FFD24A;
  --ksg-gold-2:#F5A623;
  --ksg-gold-soft:rgba(255,210,74,.14);
  --ksg-red:#E63946;
  --ksg-red-2:#C1121F;
  --ksg-red-soft:rgba(230,57,70,.14);
  --ksg-green:#16C784;
  --ksg-green-soft:rgba(22,199,132,.14);
  --ksg-text:#E6EAF2;
  --ksg-text-dim:#9BA3B7;
  --ksg-text-mute:#6B7390;
  --ksg-border:rgba(255,255,255,.08);
  --ksg-border-strong:rgba(255,255,255,.16);
  --ksg-card:rgba(255,255,255,.04);
  --ksg-card-2:rgba(255,255,255,.06);
  --ksg-shadow:0 20px 60px -10px rgba(0,0,0,.55);
  --ksg-shadow-gold:0 16px 60px -10px rgba(245,166,35,.45);
  --ksg-shadow-red:0 16px 60px -10px rgba(230,57,70,.45);
  --ksg-radius:18px;
  --ksg-radius-sm:12px;
  --ksg-radius-lg:28px;
  --ksg-radius-pill:999px;
  --ksg-ease:cubic-bezier(.22,.61,.36,1);
  --ksg-font-body:"Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --ksg-font-display:"Space Grotesk", "Plus Jakarta Sans", system-ui, sans-serif;
  --ksg-font-mono:"JetBrains Mono", "SF Mono", ui-monospace, monospace;
  --ksg-container:1240px;
  --ksg-container-narrow:920px;
  --ksg-header-h:72px;
}

/* ---------- Resets / Base ---------- */
*,*::before,*::after{box-sizing:border-box}

html{scroll-behavior:smooth}

body.ksg-aio-active{
  margin:0;
  background:
    radial-gradient(1200px 800px at 80% -10%, rgba(245,166,35,.10), transparent 60%),
    radial-gradient(1000px 700px at -10% 20%, rgba(230,57,70,.10), transparent 55%),
    radial-gradient(900px 700px at 50% 110%, rgba(20,40,120,.55), transparent 60%),
    var(--ksg-blue-950);
  color:var(--ksg-text);
  font-family:var(--ksg-font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

body.ksg-aio-active::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  z-index:0;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
}

body.ksg-aio-active > *{position:relative; z-index:1}

a{color:var(--ksg-gold); text-decoration:none; transition:color .2s var(--ksg-ease)}
a:hover{color:var(--ksg-gold-2)}

img{max-width:100%; height:auto; display:block}

button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit}

input,textarea,select{font-family:inherit; color:inherit}

/* ---------- Containers / Layout ---------- */
.ksg-container{max-width:var(--ksg-container); margin:0 auto; padding:0 24px}
.ksg-narrow{max-width:var(--ksg-container-narrow); margin:0 auto}
.ksg-section{padding:96px 0; position:relative}
.ksg-section--tight{padding:64px 0}

@media (max-width:900px){
  .ksg-section{padding:64px 0}
  .ksg-section--tight{padding:48px 0}
}

/* ---------- Typography ---------- */
.ksg-h1{
  font-family:var(--ksg-font-display);
  font-size:clamp(2.2rem, 5vw, 4.2rem);
  line-height:1.05;
  font-weight:700;
  letter-spacing:-.02em;
  margin:0 0 24px;
}
.ksg-h2{
  font-family:var(--ksg-font-display);
  font-size:clamp(1.8rem, 3.6vw, 2.8rem);
  line-height:1.15;
  font-weight:700;
  letter-spacing:-.015em;
  margin:0 0 20px;
}
.ksg-h2--center{text-align:center; margin-left:auto; margin-right:auto; max-width:780px}
.ksg-h3{font-family:var(--ksg-font-display); font-size:1.4rem; font-weight:600; margin:0 0 12px}
.ksg-lead{
  font-size:clamp(1rem, 1.4vw, 1.18rem);
  color:var(--ksg-text-dim);
  line-height:1.7;
  margin:0 0 28px;
  max-width:680px;
}
.ksg-h2--center + .ksg-lead{margin-left:auto; margin-right:auto; text-align:center}

.ksg-text-gradient{
  background:linear-gradient(135deg, var(--ksg-gold) 0%, var(--ksg-gold-2) 50%, var(--ksg-red) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}

.ksg-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.18em;
  padding:8px 14px;
  border-radius:var(--ksg-radius-pill);
  border:1px solid var(--ksg-border-strong);
  background:var(--ksg-card);
  color:var(--ksg-text-dim);
  margin-bottom:20px;
}
.ksg-eyebrow--gold{color:var(--ksg-gold); border-color:rgba(255,210,74,.3); background:var(--ksg-gold-soft)}
.ksg-eyebrow--red{color:var(--ksg-red); border-color:rgba(230,57,70,.3); background:var(--ksg-red-soft)}
.ksg-eyebrow__dot{
  width:6px; height:6px; border-radius:50%;
  background:currentColor;
  box-shadow:0 0 12px currentColor;
  animation:ksg-pulse 1.6s var(--ksg-ease) infinite;
}
@keyframes ksg-pulse{
  0%,100%{opacity:.4; transform:scale(.85)}
  50%{opacity:1; transform:scale(1.2)}
}

/* ---------- Buttons ---------- */
.ksg-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 26px;
  border-radius:var(--ksg-radius-pill);
  font-weight:600;
  font-size:.96rem;
  letter-spacing:.01em;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .25s var(--ksg-ease), box-shadow .25s var(--ksg-ease), background .25s var(--ksg-ease);
  position:relative;
  overflow:hidden;
  white-space:nowrap;
}
.ksg-btn__arrow{transition:transform .25s var(--ksg-ease)}
.ksg-btn:hover .ksg-btn__arrow{transform:translateX(4px)}
.ksg-btn--sm{padding:10px 18px; font-size:.86rem}
.ksg-btn--lg{padding:16px 32px; font-size:1.02rem}
.ksg-btn--xl{padding:20px 38px; font-size:1.1rem}

.ksg-btn--gold{
  background:linear-gradient(135deg, var(--ksg-gold) 0%, var(--ksg-gold-2) 100%);
  color:#1a0f00;
  box-shadow:var(--ksg-shadow-gold);
}
.ksg-btn--gold:hover{transform:translateY(-2px); box-shadow:0 22px 70px -10px rgba(245,166,35,.6); color:#1a0f00}

.ksg-btn--red{
  background:linear-gradient(135deg, var(--ksg-red) 0%, var(--ksg-red-2) 100%);
  color:#fff;
  box-shadow:var(--ksg-shadow-red);
}
.ksg-btn--red:hover{transform:translateY(-2px); box-shadow:0 22px 70px -10px rgba(230,57,70,.6); color:#fff}

.ksg-btn--ghost{
  background:var(--ksg-card);
  color:var(--ksg-text);
  border-color:var(--ksg-border-strong);
  backdrop-filter:blur(8px);
}
.ksg-btn--ghost:hover{background:var(--ksg-card-2); border-color:rgba(255,255,255,.28); color:var(--ksg-text)}

/* ---------- Header ---------- */
.ksg-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(6,17,43,.7);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--ksg-border);
  transition:background .25s var(--ksg-ease), border-color .25s var(--ksg-ease);
}
.ksg-header.is-scrolled{background:rgba(6,17,43,.92); border-color:var(--ksg-border-strong)}
.ksg-header__inner{
  max-width:var(--ksg-container);
  margin:0 auto;
  padding:14px 24px;
  display:flex;
  align-items:center;
  gap:24px;
  min-height:var(--ksg-header-h);
}
.ksg-header__logo{display:flex; align-items:center; gap:12px; flex-shrink:0}
.ksg-header__logo-mark{
  width:42px; height:42px;
  border-radius:12px;
  background:linear-gradient(135deg, var(--ksg-gold) 0%, var(--ksg-red) 100%);
  display:grid; place-items:center;
  font-family:var(--ksg-font-display);
  font-weight:800;
  color:#1a0f00;
  font-size:1.1rem;
  box-shadow:0 6px 24px -6px rgba(255,210,74,.5);
}
.ksg-header__logo-text{display:flex; flex-direction:column; line-height:1.1}
.ksg-header__logo-name{font-family:var(--ksg-font-display); font-weight:700; font-size:1rem; color:#fff}
.ksg-header__logo-sub{font-size:.66rem; text-transform:uppercase; letter-spacing:.18em; color:var(--ksg-text-mute)}

.ksg-nav{flex:1}
.ksg-nav__menu{display:flex; align-items:center; gap:8px; list-style:none; padding:0; margin:0; justify-content:center}
.ksg-nav__item{position:relative}
.ksg-nav__item a{
  display:inline-block;
  padding:8px 14px;
  border-radius:var(--ksg-radius-pill);
  color:var(--ksg-text-dim);
  font-size:.92rem;
  font-weight:500;
  transition:color .2s var(--ksg-ease), background .2s var(--ksg-ease);
}
.ksg-nav__item a:hover{color:#fff; background:var(--ksg-card)}
.ksg-nav__item.is-current > a, .ksg-nav__item.current-menu-item > a{color:var(--ksg-gold); background:var(--ksg-gold-soft)}

.ksg-header__actions{display:flex; align-items:center; gap:10px; flex-shrink:0}

.ksg-burger{
  display:none;
  width:42px; height:42px;
  border-radius:12px;
  background:var(--ksg-card);
  border:1px solid var(--ksg-border-strong);
  align-items:center; justify-content:center;
  flex-direction:column; gap:4px;
}
.ksg-burger span{display:block; width:18px; height:2px; background:var(--ksg-text); border-radius:2px; transition:transform .25s var(--ksg-ease), opacity .25s var(--ksg-ease)}
.ksg-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.ksg-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.ksg-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

@media (max-width:1100px){
  .ksg-header__actions .ksg-btn--ghost{display:none}
}
@media (max-width:900px){
  .ksg-burger{display:inline-flex}
  .ksg-nav{
    position:absolute;
    top:100%; left:0; right:0;
    background:rgba(6,17,43,.97);
    backdrop-filter:blur(20px);
    border-bottom:1px solid var(--ksg-border-strong);
    padding:16px 24px 24px;
    transform:translateY(-8px);
    opacity:0;
    pointer-events:none;
    transition:transform .25s var(--ksg-ease), opacity .25s var(--ksg-ease);
  }
  body.ksg-menu-open .ksg-nav{transform:translateY(0); opacity:1; pointer-events:auto}
  .ksg-nav__menu{flex-direction:column; align-items:stretch; gap:4px}
  .ksg-nav__item a{display:block; padding:12px 16px; font-size:1rem}
}

/* ---------- Announcement Bar ---------- */
.ksg-announce{
  background:linear-gradient(90deg, var(--ksg-red) 0%, var(--ksg-gold-2) 100%);
  color:#fff;
  padding:8px 24px;
  text-align:center;
  font-size:.86rem;
  font-weight:500;
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.ksg-announce__dot{
  width:8px; height:8px; border-radius:50%; background:#fff;
  animation:ksg-pulse 1.4s var(--ksg-ease) infinite;
}
.ksg-announce__cta{color:#fff; text-decoration:underline; font-weight:700; margin-left:6px}
.ksg-announce__cta:hover{color:#fff}
@media (max-width:640px){
  .ksg-announce{font-size:.78rem; padding:8px 16px}
}

/* ---------- Hero ---------- */
.ksg-hero{
  position:relative;
  padding:80px 0 100px;
  overflow:hidden;
  min-height:calc(100vh - var(--ksg-header-h));
  display:flex; align-items:center;
}
.ksg-hero__bg{position:absolute; inset:0; pointer-events:none}
.ksg-hero__particles{position:absolute; inset:0; width:100%; height:100%; opacity:.65}
.ksg-hero__glow{
  position:absolute;
  width:600px; height:600px;
  border-radius:50%;
  filter:blur(80px);
  opacity:.4;
  animation:ksg-blob 18s var(--ksg-ease) infinite alternate;
}
.ksg-hero__glow:nth-child(2){top:-200px; left:-150px; background:radial-gradient(circle, rgba(245,166,35,.6), transparent 60%)}
.ksg-hero__glow:nth-child(3){bottom:-200px; right:-100px; background:radial-gradient(circle, rgba(230,57,70,.5), transparent 60%); animation-delay:-9s}
@keyframes ksg-blob{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(60px,-40px) scale(1.15)}
}

.ksg-hero__inner{
  position:relative;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:60px;
  align-items:center;
}
.ksg-hero__copy{max-width:620px}
.ksg-hero__title{margin-bottom:24px}
.ksg-hero__lead{font-size:clamp(1.05rem, 1.5vw, 1.22rem); margin-bottom:36px}
.ksg-hero__cta{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:48px}

.ksg-hero__proof{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  padding:24px;
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  backdrop-filter:blur(8px);
}
.ksg-stat__num{
  font-family:var(--ksg-font-display);
  font-size:clamp(1.6rem, 2.4vw, 2rem);
  font-weight:700;
  color:#fff;
  line-height:1;
  display:block;
  margin-bottom:6px;
  letter-spacing:-.02em;
}
.ksg-stat__label{font-size:.8rem; color:var(--ksg-text-dim); line-height:1.4}

/* Hero visual */
.ksg-hero__visual{position:relative; min-height:520px}
.ksg-hero__mascot-stage{
  position:relative;
  width:100%; height:100%;
  min-height:520px;
  display:grid; place-items:center;
}
.ksg-hero__mascot{
  position:relative;
  width:80%;
  max-width:480px;
  z-index:3;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.55));
  animation:ksg-floaty 6s var(--ksg-ease) infinite;
}
.ksg-floaty{animation:ksg-floaty 6s var(--ksg-ease) infinite}
@keyframes ksg-floaty{
  0%,100%{transform:translateY(0) rotate(-1deg)}
  50%{transform:translateY(-14px) rotate(1deg)}
}

.ksg-orbit{
  position:absolute;
  border-radius:50%;
  border:1px dashed rgba(255,210,74,.25);
  animation:ksg-orbit-spin 40s linear infinite;
}
.ksg-orbit--1{width:75%; height:75%; top:12%; left:12%}
.ksg-orbit--2{width:95%; height:95%; top:2%; left:2%; animation-duration:60s; animation-direction:reverse; border-color:rgba(230,57,70,.2)}
.ksg-orbit--3{width:55%; height:55%; top:22%; left:22%; animation-duration:30s; border-color:rgba(255,255,255,.1)}
@keyframes ksg-orbit-spin{
  to{transform:rotate(360deg)}
}

.ksg-ticker-card{
  position:absolute;
  background:rgba(10,24,64,.85);
  backdrop-filter:blur(16px);
  border:1px solid var(--ksg-border-strong);
  border-radius:14px;
  padding:12px 16px;
  font-family:var(--ksg-font-mono);
  font-size:.84rem;
  z-index:4;
  box-shadow:var(--ksg-shadow);
  animation:ksg-floaty 4s var(--ksg-ease) infinite;
}
.ksg-ticker-card__symbol{font-weight:700; color:#fff; margin-bottom:2px}
.ksg-ticker-card__change{color:var(--ksg-green); font-size:.78rem}
.ksg-ticker-card--1{top:8%; right:-4%; animation-delay:-2s}
.ksg-ticker-card--2{top:40%; left:-8%; animation-delay:-1s}
.ksg-ticker-card--2 .ksg-ticker-card__change{color:var(--ksg-red)}
.ksg-ticker-card--3{bottom:8%; right:4%}

@media (max-width:1100px){
  .ksg-hero__inner{grid-template-columns:1fr; gap:40px}
  .ksg-hero__visual{order:-1; min-height:380px}
  .ksg-hero__mascot-stage{min-height:380px}
  .ksg-hero__copy{max-width:none}
}
@media (max-width:640px){
  .ksg-hero{padding:48px 0 64px}
  .ksg-hero__proof{grid-template-columns:repeat(3,1fr); gap:12px; padding:16px}
  .ksg-stat__num{font-size:1.3rem}
  .ksg-stat__label{font-size:.7rem}
  .ksg-ticker-card{font-size:.74rem; padding:8px 12px}
}

/* ---------- Marquee ---------- */
.ksg-hero__marquee{margin-top:48px}
.ksg-marquee{
  overflow:hidden;
  position:relative;
  padding:16px 0;
  border-top:1px solid var(--ksg-border);
  border-bottom:1px solid var(--ksg-border);
  background:rgba(0,0,0,.18);
  mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.ksg-marquee__track{
  display:flex; gap:48px;
  animation:ksg-marquee 40s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.ksg-marquee__item{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--ksg-font-mono);
  font-size:.9rem;
  color:var(--ksg-text-dim);
}
.ksg-marquee__item strong{color:#fff; font-weight:600}
.ksg-marquee__dot{width:6px; height:6px; border-radius:50%; background:var(--ksg-text-mute)}
@keyframes ksg-marquee{
  to{transform:translateX(-50%)}
}

/* ---------- Cards ---------- */
.ksg-card{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:32px;
  backdrop-filter:blur(8px);
  transition:transform .35s var(--ksg-ease), border-color .35s var(--ksg-ease), background .35s var(--ksg-ease);
  position:relative;
  overflow:hidden;
}
.ksg-card:hover{transform:translateY(-4px); border-color:var(--ksg-border-strong); background:var(--ksg-card-2)}
.ksg-card__icon{
  width:56px; height:56px;
  border-radius:14px;
  display:grid; place-items:center;
  margin-bottom:20px;
  font-size:1.6rem;
  background:var(--ksg-card-2);
  border:1px solid var(--ksg-border-strong);
}
.ksg-card__icon--gold{background:var(--ksg-gold-soft); color:var(--ksg-gold); border-color:rgba(255,210,74,.3)}
.ksg-card__icon--red{background:var(--ksg-red-soft); color:var(--ksg-red); border-color:rgba(230,57,70,.3)}
.ksg-card__icon--blue{background:rgba(80,130,255,.14); color:#7aa2ff; border-color:rgba(80,130,255,.3)}
.ksg-card__title{font-family:var(--ksg-font-display); font-size:1.2rem; font-weight:600; margin:0 0 10px; color:#fff}
.ksg-card__body{color:var(--ksg-text-dim); font-size:.96rem; line-height:1.65}

/* Diff cards grid */
.ksg-diff{padding-top:48px}
.ksg-diff__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
@media (max-width:900px){.ksg-diff__grid{grid-template-columns:1fr}}

/* ---------- Method (4 Pillars) ---------- */
.ksg-method__grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
  margin-top:48px;
}
@media (max-width:1100px){.ksg-method__grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:560px){.ksg-method__grid{grid-template-columns:1fr}}

.ksg-pillar{
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:28px;
  position:relative;
  overflow:hidden;
  opacity:0;
  transform:translateY(20px);
  animation:ksg-fadeup .8s var(--ksg-ease) forwards;
  animation-delay:var(--ksg-pillar-delay, 0s);
  transition:border-color .3s var(--ksg-ease), transform .3s var(--ksg-ease);
}
.ksg-pillar:hover{border-color:rgba(255,210,74,.3); transform:translateY(-3px)}
.ksg-pillar::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:2px;
  background:linear-gradient(90deg, var(--ksg-gold), var(--ksg-red));
  opacity:.6;
}
.ksg-pillar__num{
  font-family:var(--ksg-font-mono);
  font-size:.8rem;
  color:var(--ksg-gold);
  margin-bottom:12px;
  letter-spacing:.15em;
}
.ksg-pillar__icon{font-size:2rem; margin-bottom:14px; line-height:1}
.ksg-pillar__title{font-family:var(--ksg-font-display); font-size:1.15rem; font-weight:600; color:#fff; margin:0 0 10px}
.ksg-pillar__body{color:var(--ksg-text-dim); font-size:.92rem; line-height:1.6}

@keyframes ksg-fadeup{
  to{opacity:1; transform:translateY(0)}
}

/* ---------- Simulator ---------- */
.ksg-sim{padding-top:24px}
.ksg-sim__wrap{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--ksg-border-strong);
  border-radius:var(--ksg-radius-lg);
  padding:40px;
  backdrop-filter:blur(12px);
  box-shadow:var(--ksg-shadow);
}
.ksg-sim__controls{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:32px;
  margin-bottom:32px;
}
@media (max-width:760px){.ksg-sim__controls{grid-template-columns:1fr; gap:24px}}
.ksg-sim__control label{
  display:block;
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--ksg-text-dim);
  margin-bottom:12px;
}
.ksg-sim__input-wrap{
  position:relative;
  display:flex; align-items:center;
  background:rgba(0,0,0,.3);
  border:1px solid var(--ksg-border-strong);
  border-radius:var(--ksg-radius-sm);
  padding:0 16px;
  margin-bottom:12px;
}
.ksg-sim__currency{color:var(--ksg-gold); font-weight:700; margin-right:8px; font-family:var(--ksg-font-mono)}
.ksg-sim__input{
  flex:1;
  background:transparent;
  border:none;
  outline:none;
  padding:14px 0;
  font-size:1.1rem;
  font-weight:600;
  color:#fff;
  font-family:var(--ksg-font-mono);
}
input[type="range"].ksg-sim__range{
  width:100%;
  height:6px;
  border-radius:6px;
  background:rgba(255,255,255,.1);
  -webkit-appearance:none;
  appearance:none;
  outline:none;
  cursor:pointer;
}
input[type="range"].ksg-sim__range::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:22px; height:22px; border-radius:50%;
  background:linear-gradient(135deg, var(--ksg-gold), var(--ksg-gold-2));
  border:3px solid var(--ksg-blue-950);
  box-shadow:0 4px 12px rgba(245,166,35,.5);
  cursor:pointer;
}
input[type="range"].ksg-sim__range::-moz-range-thumb{
  width:22px; height:22px; border-radius:50%;
  background:linear-gradient(135deg, var(--ksg-gold), var(--ksg-gold-2));
  border:3px solid var(--ksg-blue-950);
  cursor:pointer;
}
.ksg-sim__alloc-val{
  display:inline-block;
  margin-top:8px;
  font-family:var(--ksg-font-mono);
  color:var(--ksg-gold);
  font-weight:600;
}

.ksg-sim__tabs{display:flex; gap:8px; flex-wrap:wrap}
.ksg-sim__tab{
  padding:10px 18px;
  border-radius:var(--ksg-radius-pill);
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  color:var(--ksg-text-dim);
  font-size:.88rem;
  font-weight:600;
  cursor:pointer;
  transition:all .2s var(--ksg-ease);
}
.ksg-sim__tab:hover{color:#fff; border-color:var(--ksg-border-strong)}
.ksg-sim__tab.is-active{
  background:linear-gradient(135deg, var(--ksg-gold), var(--ksg-gold-2));
  color:#1a0f00;
  border-color:transparent;
}

.ksg-sim__results{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
  margin-bottom:32px;
}
@media (max-width:760px){.ksg-sim__results{grid-template-columns:1fr}}

.ksg-sim__result{
  background:rgba(0,0,0,.25);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:24px;
}
.ksg-sim__result-label{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--ksg-text-dim);
  margin-bottom:10px;
}
.ksg-sim__result-value{
  font-family:var(--ksg-font-display);
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  font-weight:700;
  color:var(--ksg-gold);
  font-variant-numeric:tabular-nums;
  letter-spacing:-.01em;
  line-height:1.1;
  margin-bottom:6px;
}
.ksg-sim__result-value--green{color:var(--ksg-green)}
.ksg-sim__result-sub{font-size:.84rem; color:var(--ksg-text-mute)}

.ksg-sim__chart{
  width:100%;
  height:240px;
  background:rgba(0,0,0,.2);
  border-radius:var(--ksg-radius);
  border:1px solid var(--ksg-border);
}
.ksg-sim__disclaimer{
  margin-top:20px;
  font-size:.8rem;
  color:var(--ksg-text-mute);
  line-height:1.6;
  padding:14px 18px;
  background:rgba(0,0,0,.2);
  border-left:3px solid var(--ksg-gold);
  border-radius:6px;
}

@media (max-width:640px){
  .ksg-sim__wrap{padding:24px}
}

/* ---------- Features Grid ---------- */
.ksg-features__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
  margin-top:48px;
}
@media (max-width:1100px){.ksg-features__grid{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:640px){.ksg-features__grid{grid-template-columns:1fr}}

.ksg-feature{
  padding:28px;
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  transition:transform .3s var(--ksg-ease), border-color .3s var(--ksg-ease);
}
.ksg-feature:hover{transform:translateY(-4px); border-color:var(--ksg-border-strong)}
.ksg-feature__icon{
  width:48px; height:48px;
  border-radius:12px;
  background:var(--ksg-gold-soft);
  display:grid; place-items:center;
  font-size:1.4rem;
  margin-bottom:18px;
}
.ksg-feature__title{font-family:var(--ksg-font-display); font-size:1.1rem; color:#fff; margin:0 0 10px}
.ksg-feature__body{color:var(--ksg-text-dim); font-size:.92rem; line-height:1.6}

/* ---------- Masterclass Promo ---------- */
.ksg-mc-promo{
  position:relative;
  margin:48px 0;
  overflow:hidden;
}
.ksg-mc-promo__inner{
  background:linear-gradient(135deg, rgba(230,57,70,.18) 0%, rgba(245,166,35,.14) 100%);
  border:1px solid rgba(230,57,70,.3);
  border-radius:var(--ksg-radius-lg);
  padding:56px;
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:48px;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.ksg-mc-promo__inner::before{
  content:"";
  position:absolute;
  top:-100px; right:-100px;
  width:400px; height:400px;
  background:radial-gradient(circle, rgba(230,57,70,.3), transparent 60%);
  filter:blur(40px);
  pointer-events:none;
}
.ksg-mc-promo__copy{position:relative; z-index:1}
.ksg-mc-promo__visual{position:relative; z-index:1; display:grid; place-items:center}
.ksg-mc-promo__visual img{max-width:280px; filter:drop-shadow(0 20px 40px rgba(0,0,0,.45))}

@media (max-width:900px){
  .ksg-mc-promo__inner{grid-template-columns:1fr; padding:36px; gap:24px}
}

/* ---------- Testimonials ---------- */
.ksg-testi__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:48px;
}
@media (max-width:900px){.ksg-testi__grid{grid-template-columns:1fr}}

.ksg-testi__card{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:32px;
  display:flex; flex-direction:column; gap:20px;
}
.ksg-testi__stars{color:var(--ksg-gold); font-size:1.1rem; letter-spacing:2px}
.ksg-testi__quote{color:var(--ksg-text); font-size:1rem; line-height:1.65; flex:1; font-style:italic}
.ksg-testi__author{display:flex; align-items:center; gap:12px; padding-top:16px; border-top:1px solid var(--ksg-border)}
.ksg-testi__avatar{
  width:44px; height:44px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--ksg-gold), var(--ksg-red));
  display:grid; place-items:center;
  font-weight:700;
  color:#1a0f00;
  font-family:var(--ksg-font-display);
}
.ksg-testi__name{font-weight:600; color:#fff; font-size:.96rem; display:block}
.ksg-testi__role{font-size:.82rem; color:var(--ksg-text-mute)}

/* ---------- Final CTA ---------- */
.ksg-final-cta{padding:64px 0 96px}
.ksg-final-cta__inner{
  background:linear-gradient(135deg, var(--ksg-blue-800) 0%, var(--ksg-blue-900) 100%);
  border:1px solid var(--ksg-border-strong);
  border-radius:var(--ksg-radius-lg);
  padding:64px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.ksg-final-cta__inner::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(245,166,35,.2), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(230,57,70,.2), transparent 50%);
  pointer-events:none;
}
.ksg-final-cta__mascot{
  position:relative; z-index:1;
  max-width:200px;
  margin:0 auto 20px;
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.4));
  animation:ksg-floaty 5s var(--ksg-ease) infinite;
}
.ksg-final-cta__inner > *{position:relative; z-index:1}
.ksg-final-cta__actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:32px}
@media (max-width:640px){
  .ksg-final-cta__inner{padding:36px 24px}
}

/* ---------- Page Hero ---------- */
.ksg-page-hero{
  position:relative;
  padding:80px 0 60px;
  overflow:hidden;
  border-bottom:1px solid var(--ksg-border);
}
.ksg-page-hero__bg{
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(800px 400px at 50% 0%, rgba(245,166,35,.12), transparent 60%);
}
.ksg-page-hero--red .ksg-page-hero__bg{background:radial-gradient(800px 400px at 50% 0%, rgba(230,57,70,.16), transparent 60%)}
.ksg-page-hero__inner{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:48px;
  align-items:center;
  position:relative;
}
.ksg-page-hero__mascot{max-width:300px; margin-left:auto; filter:drop-shadow(0 24px 50px rgba(0,0,0,.5)); animation:ksg-floaty 6s var(--ksg-ease) infinite}
.ksg-page-hero__cta{display:flex; gap:12px; flex-wrap:wrap; margin-top:28px}
@media (max-width:900px){
  .ksg-page-hero__inner{grid-template-columns:1fr; gap:24px}
  .ksg-page-hero__mascot{max-width:220px; margin:0 auto}
}

/* ---------- Benefits ---------- */
.ksg-benefit-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
  margin-top:40px;
}
@media (max-width:760px){.ksg-benefit-grid{grid-template-columns:1fr}}

.ksg-benefit{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:32px;
  display:flex; flex-direction:column; gap:14px;
  transition:transform .3s var(--ksg-ease), border-color .3s var(--ksg-ease);
}
.ksg-benefit:hover{transform:translateY(-3px); border-color:rgba(255,210,74,.3)}
.ksg-benefit__tag{
  display:inline-block;
  font-family:var(--ksg-font-mono);
  font-size:.74rem;
  color:var(--ksg-gold);
  letter-spacing:.15em;
  text-transform:uppercase;
}
.ksg-benefit__visual{width:80px; height:80px; margin-bottom:8px}
.ksg-benefit__title{font-family:var(--ksg-font-display); font-size:1.2rem; color:#fff; margin:0}
.ksg-benefit__body{color:var(--ksg-text-dim); font-size:.96rem; line-height:1.65; margin:0}

/* ---------- For Who / Not For Who ---------- */
.ksg-forwho__grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
  margin-top:40px;
}
@media (max-width:760px){.ksg-forwho__grid{grid-template-columns:1fr}}
.ksg-forwho__col{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:32px;
}
.ksg-forwho__col--for{border-top:3px solid var(--ksg-green)}
.ksg-forwho__col--not{border-top:3px solid var(--ksg-red)}
.ksg-forwho__col h3{font-family:var(--ksg-font-display); font-size:1.2rem; margin:0 0 18px; color:#fff}
.ksg-forwho__col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px}
.ksg-forwho__col li{
  display:flex; gap:10px; align-items:flex-start;
  color:var(--ksg-text-dim);
  font-size:.95rem;
  line-height:1.55;
}
.ksg-forwho__col li::before{
  content:""; flex-shrink:0;
  width:20px; height:20px; border-radius:50%;
  display:grid; place-items:center;
  margin-top:2px;
}
.ksg-forwho__col--for li::before{content:"✓"; background:var(--ksg-green-soft); color:var(--ksg-green); font-weight:700; font-size:.78rem}
.ksg-forwho__col--not li::before{content:"✕"; background:var(--ksg-red-soft); color:var(--ksg-red); font-weight:700; font-size:.78rem}

/* ---------- Steps ---------- */
.ksg-steps{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
  margin-top:40px;
  position:relative;
}
@media (max-width:1100px){.ksg-steps{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:560px){.ksg-steps{grid-template-columns:1fr}}
.ksg-step{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:28px;
  position:relative;
}
.ksg-step__num{
  display:inline-grid; place-items:center;
  width:44px; height:44px;
  border-radius:14px;
  background:linear-gradient(135deg, var(--ksg-gold), var(--ksg-gold-2));
  color:#1a0f00;
  font-family:var(--ksg-font-display);
  font-weight:700;
  font-size:1.2rem;
  margin-bottom:16px;
}
.ksg-step h3{font-family:var(--ksg-font-display); font-size:1.05rem; color:#fff; margin:0 0 10px}
.ksg-step p{color:var(--ksg-text-dim); font-size:.92rem; line-height:1.6; margin:0}

/* ---------- Pillar Row (Metode page) ---------- */
.ksg-pillar-row{
  padding:60px 0;
  border-bottom:1px solid var(--ksg-border);
}
.ksg-pillar-row:last-child{border-bottom:none}
.ksg-pillar-row__inner{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:48px;
  align-items:center;
}
.ksg-pillar-row--reverse .ksg-pillar-row__inner{direction:rtl}
.ksg-pillar-row--reverse .ksg-pillar-row__inner > *{direction:ltr}
.ksg-pillar-row__num{
  font-family:var(--ksg-font-mono);
  font-size:.86rem;
  color:var(--ksg-gold);
  letter-spacing:.2em;
  margin-bottom:14px;
}
.ksg-pillar-row__tagline{
  font-size:.92rem;
  color:var(--ksg-gold-2);
  font-weight:600;
  margin-bottom:18px;
}
.ksg-pillar-row__body{color:var(--ksg-text-dim); font-size:1rem; line-height:1.7; margin-bottom:20px}
.ksg-pillar-row__visual{
  position:relative;
  display:grid; place-items:center;
  min-height:280px;
}
.ksg-pillar-row__visual-inner{
  background:linear-gradient(135deg, rgba(255,210,74,.06), rgba(230,57,70,.06));
  border:1px solid var(--ksg-border-strong);
  border-radius:var(--ksg-radius-lg);
  padding:32px;
  display:grid; place-items:center;
  width:100%;
}
.ksg-pillar-row__visual-inner img{max-width:240px; filter:drop-shadow(0 14px 30px rgba(0,0,0,.4)); animation:ksg-floaty 5s var(--ksg-ease) infinite}
@media (max-width:900px){
  .ksg-pillar-row__inner{grid-template-columns:1fr; gap:24px}
  .ksg-pillar-row--reverse .ksg-pillar-row__inner{direction:ltr}
}

/* ---------- Checklist ---------- */
.ksg-checklist{
  list-style:none;
  padding:0;
  margin:0 0 24px;
  display:flex; flex-direction:column; gap:10px;
}
.ksg-checklist li{
  display:flex; gap:12px; align-items:flex-start;
  color:var(--ksg-text);
  font-size:.95rem;
  line-height:1.55;
}
.ksg-checklist li::before{
  content:"✓";
  flex-shrink:0;
  width:22px; height:22px; border-radius:50%;
  background:var(--ksg-gold-soft);
  color:var(--ksg-gold);
  font-weight:700;
  font-size:.84rem;
  display:grid; place-items:center;
  margin-top:1px;
}

/* ---------- Values (Tentang page) ---------- */
.ksg-values__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:40px;
}
@media (max-width:900px){.ksg-values__grid{grid-template-columns:1fr}}
.ksg-value{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:32px;
  text-align:center;
}
.ksg-value__icon{font-size:2.4rem; margin-bottom:14px; line-height:1}
.ksg-value h3{font-family:var(--ksg-font-display); font-size:1.15rem; color:#fff; margin:0 0 10px}
.ksg-value p{color:var(--ksg-text-dim); font-size:.94rem; line-height:1.6; margin:0}

/* ---------- Topics (Masterclass page) ---------- */
.ksg-topics{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
  margin-top:40px;
}
@media (max-width:900px){.ksg-topics{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:560px){.ksg-topics{grid-template-columns:1fr}}
.ksg-topic{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:24px;
  transition:transform .3s var(--ksg-ease), border-color .3s var(--ksg-ease);
}
.ksg-topic:hover{transform:translateY(-3px); border-color:rgba(230,57,70,.3)}
.ksg-topic__num{font-family:var(--ksg-font-mono); color:var(--ksg-red); font-size:.84rem; letter-spacing:.15em; margin-bottom:10px}
.ksg-topic h3{font-family:var(--ksg-font-display); font-size:1.02rem; color:#fff; margin:0 0 8px}
.ksg-topic p{color:var(--ksg-text-dim); font-size:.88rem; line-height:1.55; margin:0}

/* ---------- FAQ ---------- */
.ksg-faq-mini,.ksg-faq-group{padding-top:24px}
.ksg-faq-list{display:flex; flex-direction:column; gap:14px; margin-top:40px}
.ksg-faq-item{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius-sm);
  padding:0;
  overflow:hidden;
  transition:border-color .25s var(--ksg-ease);
}
.ksg-faq-item[open]{border-color:rgba(255,210,74,.3)}
.ksg-faq-item summary{
  padding:20px 24px;
  cursor:pointer;
  font-family:var(--ksg-font-display);
  font-weight:600;
  font-size:1.02rem;
  color:#fff;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
}
.ksg-faq-item summary::-webkit-details-marker{display:none}
.ksg-faq-item summary::after{
  content:"+";
  width:28px; height:28px;
  border-radius:50%;
  background:var(--ksg-gold-soft);
  color:var(--ksg-gold);
  display:grid; place-items:center;
  font-size:1.2rem; font-weight:700;
  flex-shrink:0;
  transition:transform .25s var(--ksg-ease);
}
.ksg-faq-item[open] summary::after{transform:rotate(45deg)}
.ksg-faq-answer{
  padding:0 24px 20px;
  color:var(--ksg-text-dim);
  font-size:.96rem;
  line-height:1.7;
}

/* ---------- Contact ---------- */
.ksg-contact-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
  margin-bottom:48px;
  margin-top:40px;
}
@media (max-width:900px){.ksg-contact-grid{grid-template-columns:1fr}}
.ksg-contact-card{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border);
  border-radius:var(--ksg-radius);
  padding:28px;
  transition:transform .3s var(--ksg-ease), border-color .3s var(--ksg-ease);
}
.ksg-contact-card:hover{transform:translateY(-3px); border-color:rgba(255,210,74,.3)}
.ksg-contact-card--primary{
  background:linear-gradient(135deg, rgba(245,166,35,.16), rgba(230,57,70,.10));
  border-color:rgba(245,166,35,.35);
}
.ksg-contact-card__icon{
  width:48px; height:48px;
  border-radius:14px;
  background:var(--ksg-gold-soft);
  color:var(--ksg-gold);
  display:grid; place-items:center;
  font-size:1.4rem;
  margin-bottom:16px;
}
.ksg-contact-card h3{font-family:var(--ksg-font-display); font-size:1.05rem; color:#fff; margin:0 0 8px}
.ksg-contact-card p{color:var(--ksg-text-dim); font-size:.92rem; line-height:1.55; margin:0 0 14px}

.ksg-contact-form-wrap{
  background:var(--ksg-card);
  border:1px solid var(--ksg-border-strong);
  border-radius:var(--ksg-radius-lg);
  padding:40px;
  max-width:680px;
  margin:0 auto;
}
.ksg-contact-form-wrap h3{font-family:var(--ksg-font-display); font-size:1.4rem; color:#fff; margin:0 0 24px; text-align:center}
.ksg-contact-form{display:flex; flex-direction:column; gap:16px}
.ksg-form-row{display:flex; flex-direction:column; gap:6px}
.ksg-form-row label{font-size:.84rem; color:var(--ksg-text-dim); font-weight:500}
.ksg-form-row input, .ksg-form-row textarea, .ksg-form-row select{
  background:rgba(0,0,0,.3);
  border:1px solid var(--ksg-border-strong);
  border-radius:var(--ksg-radius-sm);
  padding:12px 16px;
  font-size:.96rem;
  color:#fff;
  outline:none;
  transition:border-color .2s var(--ksg-ease);
  font-family:inherit;
}
.ksg-form-row input:focus, .ksg-form-row textarea:focus, .ksg-form-row select:focus{border-color:var(--ksg-gold)}
.ksg-form-row textarea{resize:vertical; min-height:120px}
.ksg-form-note{
  font-size:.82rem;
  color:var(--ksg-text-mute);
  text-align:center;
  margin-top:8px;
}
.ksg-form-success{
  padding:16px;
  background:var(--ksg-green-soft);
  border:1px solid rgba(22,199,132,.3);
  border-radius:var(--ksg-radius-sm);
  color:var(--ksg-green);
  text-align:center;
  font-weight:500;
}
@media (max-width:640px){
  .ksg-contact-form-wrap{padding:24px}
}

/* ---------- Footer ---------- */
.ksg-footer{
  position:relative;
  padding:80px 0 32px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.4));
  border-top:1px solid var(--ksg-border);
  margin-top:64px;
  overflow:hidden;
}
.ksg-footer__glow{
  position:absolute;
  top:-200px; left:50%;
  transform:translateX(-50%);
  width:800px; height:400px;
  background:radial-gradient(ellipse, rgba(245,166,35,.12), transparent 60%);
  filter:blur(60px);
  pointer-events:none;
}
.ksg-footer__grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:48px;
  position:relative;
}
@media (max-width:900px){.ksg-footer__grid{grid-template-columns:1fr 1fr; gap:32px}}
@media (max-width:560px){.ksg-footer__grid{grid-template-columns:1fr}}

.ksg-footer__brand .ksg-header__logo{margin-bottom:18px}
.ksg-footer__tagline{color:var(--ksg-text-dim); font-size:.94rem; line-height:1.65; margin-bottom:20px; max-width:340px}

.ksg-footer__col h4{
  font-family:var(--ksg-font-display);
  font-size:.96rem;
  color:#fff;
  margin:0 0 18px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.ksg-footer__col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
.ksg-footer__col a{color:var(--ksg-text-dim); font-size:.92rem; transition:color .2s var(--ksg-ease)}
.ksg-footer__col a:hover{color:var(--ksg-gold)}

.ksg-socials{display:flex; gap:10px; flex-wrap:wrap}
.ksg-socials a{
  width:38px; height:38px;
  border-radius:50%;
  background:var(--ksg-card);
  border:1px solid var(--ksg-border-strong);
  display:grid; place-items:center;
  color:var(--ksg-text-dim);
  transition:all .25s var(--ksg-ease);
}
.ksg-socials a:hover{background:var(--ksg-gold-soft); border-color:rgba(255,210,74,.4); color:var(--ksg-gold); transform:translateY(-2px)}
.ksg-socials svg{width:18px; height:18px}

.ksg-footer__bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:32px;
  border-top:1px solid var(--ksg-border);
  gap:24px;
  flex-wrap:wrap;
  position:relative;
}
.ksg-footer__copy{color:var(--ksg-text-mute); font-size:.86rem}
.ksg-footer__disclaimer{
  font-size:.78rem;
  color:var(--ksg-text-mute);
  line-height:1.6;
  max-width:680px;
  margin-top:24px;
  padding:16px 20px;
  background:rgba(0,0,0,.25);
  border-radius:var(--ksg-radius-sm);
  border-left:3px solid var(--ksg-red);
}

/* ---------- Sticky CTA (mobile) ---------- */
.ksg-sticky-cta{
  position:fixed;
  bottom:16px; right:16px;
  z-index:99;
  display:none;
  align-items:center; gap:8px;
  padding:12px 20px;
  border-radius:var(--ksg-radius-pill);
  background:linear-gradient(135deg, var(--ksg-gold), var(--ksg-gold-2));
  color:#1a0f00;
  font-weight:700;
  font-size:.9rem;
  box-shadow:0 10px 30px rgba(245,166,35,.5);
  animation:ksg-floaty 3s var(--ksg-ease) infinite;
}
@media (max-width:760px){.ksg-sticky-cta{display:inline-flex}}

/* ---------- Blog Posts ---------- */
.ksg-aio-page article{
  max-width:780px;
  margin:0 auto;
  padding:64px 24px;
  font-size:1.05rem;
  line-height:1.8;
  color:var(--ksg-text);
}
.ksg-aio-page article h1{
  font-family:var(--ksg-font-display);
  font-size:clamp(1.8rem, 3.5vw, 2.8rem);
  line-height:1.2;
  margin:0 0 24px;
  color:#fff;
  letter-spacing:-.015em;
}
.ksg-aio-page article h2{
  font-family:var(--ksg-font-display);
  font-size:1.5rem;
  margin:48px 0 16px;
  color:#fff;
}
.ksg-aio-page article h3{
  font-family:var(--ksg-font-display);
  font-size:1.2rem;
  margin:32px 0 12px;
  color:#fff;
}
.ksg-aio-page article p{margin:0 0 18px; color:var(--ksg-text)}
.ksg-aio-page article ul, .ksg-aio-page article ol{margin:0 0 20px; padding-left:24px; color:var(--ksg-text)}
.ksg-aio-page article li{margin-bottom:8px; line-height:1.7}
.ksg-aio-page article strong{color:#fff; font-weight:600}
.ksg-aio-page article blockquote{
  margin:24px 0;
  padding:16px 24px;
  border-left:3px solid var(--ksg-gold);
  background:var(--ksg-card);
  border-radius:0 var(--ksg-radius-sm) var(--ksg-radius-sm) 0;
  color:var(--ksg-text);
  font-style:italic;
}
.ksg-aio-page article a{border-bottom:1px solid rgba(255,210,74,.4)}
.ksg-aio-page article a:hover{border-bottom-color:var(--ksg-gold)}

/* ---------- Misc Utilities ---------- */
.ksg-link{color:var(--ksg-gold); font-weight:600}
.ksg-text-center{text-align:center}
.ksg-mb-0{margin-bottom:0}
.ksg-mb-sm{margin-bottom:16px}
.ksg-mb-lg{margin-bottom:40px}

/* ---------- Reveal Animations ---------- */
.ksg-reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s var(--ksg-ease), transform .8s var(--ksg-ease);
}
.ksg-reveal.is-visible{opacity:1; transform:translateY(0)}

/* ---------- Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .ksg-hero__particles{display:none}
}

/* ---------- WP-specific overrides ---------- */
body.ksg-aio-active .site-header,
body.ksg-aio-active .site-footer,
body.ksg-aio-active #wpadminbar + .site-header{display:none !important}
body.ksg-aio-active.admin-bar{padding-top:0 !important}
body.ksg-aio-active.admin-bar .ksg-header{top:32px}
@media (max-width:782px){
  body.ksg-aio-active.admin-bar .ksg-header{top:46px}
}
