/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PREMIUM KUNDLI GENERATOR — PERFECT DESIGN v2.0
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@600;700;800&family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --kg-bg:      #0e0305;
  --kg-bg2:     #1e0709;
  --kg-red:     #8b0000;
  --kg-red2:    #c0111b;
  --kg-red3:    #e63030;
  --kg-gold:    #c9a227;
  --kg-gold2:   #ffe8a3;
  --kg-gold3:   #fff3d0;
  --kg-cream:   #fff8eb;
  --kg-text:    #2b160d;
  --kg-muted:   #6d5441;
  --kg-border:  #e8d5b0;
  --kg-shadow:  0 32px 100px rgba(0,0,0,.28);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

.kg-page {
  font-family: 'Poppins', sans-serif;
  width: 100%;
  background:
    radial-gradient(ellipse 80% 50% at 10% 0%,   rgba(212,175,55,.22), transparent),
    radial-gradient(ellipse 60% 40% at 90% 100%,  rgba(189,17,27,.22),  transparent),
    linear-gradient(160deg, var(--kg-bg), var(--kg-bg2) 60%, #2a0510);
  padding: 30px 16px 120px;
  overflow: hidden;
  position: relative;
}

/* subtle star-like noise overlay */
.kg-page::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 20% 35%,  rgba(255,232,163,.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 15%,  rgba(255,232,163,.25) 0%, transparent 100%),
    radial-gradient(1px 1px at 50% 65%,  rgba(255,232,163,.20) 0%, transparent 100%),
    radial-gradient(1px 1px at 85% 80%,  rgba(255,232,163,.18) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}

.kg-container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HERO
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-hero {
  position: relative;
  min-height: 580px;
  border-radius: 40px;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,.45);
  box-shadow: var(--kg-shadow), inset 0 1px 0 rgba(255,232,163,.12);
  margin-bottom: 24px;
  background:
    linear-gradient(100deg, rgba(10,2,4,.96) 38%, rgba(18,6,10,.82) 62%, rgba(12,3,6,.96)),
    url('https://images.unsplash.com/photo-1532968961962-8a0cb3a2d4f5?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
}

/* animated golden accent line on top */
.kg-hero::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--kg-gold2) 40%, #fff5c0 55%, var(--kg-gold2) 70%, transparent 100%);
  animation: kgLine 4s ease-in-out infinite;
}

@keyframes kgLine {
  0%, 100% { opacity: .6; }
  50%       { opacity: 1; }
}

.kg-slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: 1fr .75fr;
  gap: 28px;
  align-items: center;
  padding: 60px 56px 80px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .75s ease, transform .75s ease;
  transform: translateX(18px);
}

.kg-slide.active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

.kg-hero-copy { position: relative; z-index: 3; }

.kg-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, rgba(212,175,55,.18), rgba(212,175,55,.08));
  color: var(--kg-gold2);
  border: 1px solid rgba(212,175,55,.50);
  padding: 9px 18px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 800;
  letter-spacing: .4px;
  margin-bottom: 20px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 20px rgba(212,175,55,.12);
}

.kg-badge i { font-size: 15px; color: #ffe066; }

.kg-hero h1 {
  font-family: 'Cinzel', serif;
  color: #fff8e7;
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.10;
  letter-spacing: .3px;
  margin-bottom: 18px;
  text-shadow: 0 2px 30px rgba(0,0,0,.5);
}

.kg-hero h1 span {
  background: linear-gradient(135deg, var(--kg-gold2), #fff08a, var(--kg-gold2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.kg-hero p {
  color: #f0d9a8;
  font-size: 15.5px;
  line-height: 1.85;
  max-width: 600px;
  margin-bottom: 28px;
  font-weight: 400;
}

.kg-feature-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  max-width: 620px;
}

.kg-feature {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 12px 16px;
  border-radius: 16px;
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.12);
  color: #fef2d5;
  font-size: 13px;
  font-weight: 600;
  backdrop-filter: blur(12px);
  transition: background .25s;
}

.kg-feature:hover { background: rgba(255,255,255,.12); }
.kg-feature i { color: var(--kg-gold2); font-size: 19px; flex: 0 0 auto; }

/* Hero visual */
.kg-hero-visual {
  position: relative;
  z-index: 2;
  min-height: 460px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.kg-hero-glow {
  position: absolute;
  width: 360px;
  height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,232,163,.42) 0%, rgba(189,17,27,.16) 50%, transparent 72%);
  filter: blur(8px);
  bottom: 40px;
  animation: kgPulse 3.5s ease-in-out infinite;
}

@keyframes kgPulse {
  0%, 100% { transform: scale(1);   opacity: .8; }
  50%       { transform: scale(1.08); opacity: 1; }
}

.kg-hero-img {
  position: relative;
  z-index: 2;
  width: auto;
  max-width: 100%;
  max-height: 460px;
  object-fit: contain;
  filter: drop-shadow(0 30px 50px rgba(0,0,0,.55));
  animation: kgFloat 6s ease-in-out infinite;
}

@keyframes kgFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-12px); }
}

.kg-float-card {
  position: absolute;
  z-index: 4;
  right: 0;
  bottom: 36px;
  width: 240px;
  background: linear-gradient(145deg, #fff9ed, #fff5e0);
  color: var(--kg-text);
  border: 1px solid rgba(212,175,55,.65);
  border-radius: 22px;
  padding: 16px 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.28), 0 0 0 1px rgba(212,175,55,.15) inset;
}

.kg-float-card b { display: block; color: var(--kg-red); font-size: 14.5px; margin-bottom: 5px; }
.kg-float-card span { display: block; color: #72604c; font-size: 12px; line-height: 1.6; }

.kg-slider-dots {
  position: absolute;
  z-index: 8;
  left: 56px;
  bottom: 34px;
  display: flex;
  gap: 8px;
  align-items: center;
}

.kg-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.38);
  cursor: pointer;
  transition: .3s;
  border: 1px solid rgba(255,255,255,.18);
}

.kg-dot.active { width: 32px; background: var(--kg-gold2); border-color: var(--kg-gold2); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   OFFER STRIP
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-offer-strip {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  margin-bottom: 24px;
}

.kg-offer-card {
  background: linear-gradient(145deg, #fff9ed, #fffdf8);
  border: 1px solid rgba(212,175,55,.42);
  border-radius: 28px;
  padding: 28px 30px;
  box-shadow: 0 18px 60px rgba(0,0,0,.12);
  position: relative;
  overflow: hidden;
}

.kg-offer-card::before {
  content: '';
  position: absolute;
  right: -70px; top: -70px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(212,175,55,.22), transparent 70%);
}

.kg-offer-card::after {
  content: '★';
  position: absolute;
  bottom: 16px; right: 22px;
  font-size: 90px;
  color: rgba(212,175,55,.08);
  line-height: 1;
  pointer-events: none;
}

.kg-offer-card h2 {
  font-family: 'Cinzel', serif;
  color: var(--kg-red);
  font-size: 26px;
  line-height: 1.25;
  margin-bottom: 10px;
  position: relative;
}

.kg-offer-card p {
  color: #675040;
  line-height: 1.75;
  font-size: 14px;
  position: relative;
  max-width: 500px;
}

.kg-offer-mini { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }

.kg-mini-benefit {
  background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(212,175,55,.35);
  border-radius: 24px;
  padding: 20px;
  color: #fff8d7;
  position: relative;
  overflow: hidden;
  transition: border-color .25s;
}

.kg-mini-benefit::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(212,175,55,.06), transparent);
  pointer-events: none;
}

.kg-mini-benefit i { font-size: 30px; color: var(--kg-gold2); display: block; margin-bottom: 10px; }
.kg-mini-benefit b { display: block; margin-bottom: 5px; font-size: 14.5px; color: #fff8d7; }
.kg-mini-benefit span { color: #e5c98a; font-size: 12.5px; line-height: 1.6; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FORM CARD
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-form-card {
  background: #fff;
  border-radius: 40px;
  overflow: hidden;
  border: 1px solid rgba(212,175,55,.38);
  box-shadow: var(--kg-shadow);
}

.kg-form-head {
  padding: 44px 36px;
  text-align: center;
  background:
    radial-gradient(ellipse 80% 80% at 100% 0%,  rgba(212,175,55,.25), transparent 50%),
    radial-gradient(ellipse 60% 60% at 0%   100%, rgba(139,0,0,.08),    transparent 50%),
    linear-gradient(180deg, #fffcf2, #fff);
  border-bottom: 1px solid #f0e0c0;
  position: relative;
  overflow: hidden;
}

.kg-form-head::after {
  content: 'ॐ';
  position: absolute;
  right: 32px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 90px;
  color: rgba(139,0,0,.045);
  pointer-events: none;
}

.kg-form-icon {
  width: 78px;
  height: 78px;
  margin: 0 auto 18px;
  border-radius: 26px;
  background: linear-gradient(145deg, #9a0000, #c8141e);
  color: var(--kg-gold2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 34px;
  box-shadow: 0 18px 50px rgba(125,0,0,.35), 0 0 0 5px rgba(139,0,0,.10);
  position: relative;
}

.kg-form-icon::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 29px;
  border: 1.5px solid rgba(212,175,55,.40);
}

.kg-form-head h2 {
  font-family: 'Cinzel', serif;
  color: var(--kg-red);
  font-size: clamp(28px, 4.5vw, 46px);
  line-height: 1.15;
  margin-bottom: 12px;
}

.kg-form-head p {
  max-width: 860px;
  margin: 0 auto;
  color: #6b5540;
  font-size: 15px;
  line-height: 1.8;
}

.kg-form-body { padding: 36px; }

/* Fields */
.kg-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }

.kg-field label {
  display: block;
  margin-bottom: 8px;
  font-size: 12.5px;
  font-weight: 800;
  color: #3a2114;
  letter-spacing: .5px;
  text-transform: uppercase;
}

.kg-input-wrap { position: relative; }

.kg-input-wrap .kg-ico {
  position: absolute;
  left: 17px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--kg-gold);
  font-size: 17px;
  z-index: 2;
  pointer-events: none;
}

.kg-input-wrap input,
.kg-input-wrap select {
  width: 100%;
  height: 58px;
  border: 1.5px solid var(--kg-border);
  border-radius: 18px;
  padding: 0 18px 0 48px;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--kg-text);
  background: #fffdf8;
  outline: none;
  transition: border-color .2s, box-shadow .2s, background .2s;
  -webkit-appearance: none;
  appearance: none;
}

.kg-input-wrap input:focus,
.kg-input-wrap select:focus {
  border-color: var(--kg-gold);
  box-shadow: 0 0 0 4px rgba(201,162,39,.16);
  background: #fff;
}

.kg-input-wrap input::placeholder { color: #c0a882; font-weight: 400; }

/* info bar */
.kg-help {
  margin-top: 22px;
  padding: 20px 22px;
  border-radius: 22px;
  background: linear-gradient(135deg, #fff9e8, #fffcf2);
  border: 1px solid #efdbb5;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.kg-help-item { display: flex; align-items: flex-start; gap: 11px; font-size: 13px; line-height: 1.6; color: #6a5642; }
.kg-help-item i { color: var(--kg-red); font-size: 20px; margin-top: 1px; flex: 0 0 auto; }

/* submit */
.kg-sticky-submit {
  position: sticky;
  bottom: 0;
  z-index: 20;
  margin-top: 26px;
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding: 14px;
  border: 1px solid #efdbb5;
  border-radius: 26px;
  box-shadow: 0 -12px 40px rgba(0,0,0,.10);
}

.kg-submit-btn {
  width: 100%;
  height: 62px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  font-family: 'Poppins', sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, #740000 0%, #b50d17 45%, #e02a2a 100%);
  box-shadow: 0 18px 40px rgba(125,0,0,.35), 0 4px 10px rgba(125,0,0,.20);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  position: relative;
  overflow: hidden;
  letter-spacing: .4px;
  transition: transform .2s, box-shadow .2s;
}

.kg-submit-btn:hover { transform: translateY(-2px); box-shadow: 0 24px 50px rgba(125,0,0,.42); }
.kg-submit-btn:active { transform: translateY(0); }

.kg-submit-btn::before {
  content: '';
  position: absolute;
  top: 0; left: -130px;
  width: 90px; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.70), transparent);
  transform: skewX(-22deg);
  animation: kgShine 3s infinite;
}

@keyframes kgShine {
  0%   { left: -130px; }
  40%  { left: 110%; }
  100% { left: 110%; }
}

.kg-submit-btn i, .kg-submit-btn span { position: relative; z-index: 2; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LOADER
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-loader {
  display: none;
  margin-top: 28px;
  padding: 36px;
  border-radius: 30px;
  background: linear-gradient(145deg, #fff9e8, #fff);
  border: 1px solid #efdbb5;
  text-align: center;
}

.kg-loader.active { display: block; animation: kgFadeIn .4s ease; }

@keyframes kgFadeIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

.kg-loader-ring {
  width: 80px; height: 80px;
  margin: 0 auto 18px;
  position: relative;
}

.kg-loader-ring::before,
.kg-loader-ring::after {
  content: '';
  position: absolute;
  border-radius: 50%;
}

.kg-loader-ring::before {
  inset: 0;
  border: 5px solid #f4e4c2;
  border-top-color: var(--kg-red);
  animation: kgSpin 1s linear infinite;
}

.kg-loader-ring::after {
  inset: 10px;
  border: 3px solid #f4e4c2;
  border-top-color: var(--kg-gold);
  animation: kgSpin .7s linear infinite reverse;
}

@keyframes kgSpin { to { transform: rotate(360deg); } }

.kg-loader h3 { font-family: 'Cinzel', serif; color: var(--kg-red); font-size: 24px; margin-bottom: 8px; }
.kg-loader p  { color: #6d5843; font-size: 14px; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   REPORT
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-report {
  display: none;
  margin-top: 32px;
  background: #fff;
  border-radius: 34px;
  border: 1px solid rgba(212,175,55,.35);
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.12);
  position: relative;
}

.kg-report.active { display: block; animation: kgFadeIn .5s ease; }

.kg-report-top {
  position: relative;
  z-index: 1;
  padding: 34px 36px;
  background:
    radial-gradient(ellipse 80% 100% at 100% 0%, rgba(212,175,55,.30), transparent 55%),
    linear-gradient(135deg, #720000, #240408);
  color: #fff;
}

.kg-report-top::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(212,175,55,.6), transparent);
}

.kg-report-top h2 { font-family: 'Cinzel', serif; color: #ffe8a3; font-size: 32px; margin-bottom: 8px; }
.kg-report-top p  { color: #f5dcaa; line-height: 1.65; font-size: 15px; }

.kg-report-body { padding: 32px; }

.kg-report-id {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #fff9e8, #fff);
  color: var(--kg-red);
  border: 1px solid #efdcb7;
  padding: 9px 16px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  margin-bottom: 22px;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
}

/* user info row */
.kg-user-info {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 28px;
}

.kg-info {
  padding: 16px;
  border-radius: 18px;
  background: linear-gradient(145deg, #fff9e8, #fffcf0);
  border: 1px solid #efdcb7;
  box-shadow: 0 4px 16px rgba(125,0,0,.05);
  transition: transform .2s;
}

.kg-info:hover { transform: translateY(-2px); }
.kg-info small { display: block; color: #7d6b57; font-weight: 800; margin-bottom: 5px; font-size: 11.5px; text-transform: uppercase; letter-spacing: .4px; }
.kg-info b     { color: var(--kg-red); font-size: 13.5px; word-break: break-word; line-height: 1.4; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SECTIONS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-section {
  margin-top: 24px;
  background: #fff;
  border: 1px solid #e8d8b5;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 12px 36px rgba(125,0,0,.06);
  transition: box-shadow .25s;
}

.kg-section:hover { box-shadow: 0 18px 50px rgba(125,0,0,.10); }

.kg-section-head {
  padding: 16px 22px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  position: relative;
  overflow: hidden;
}

.kg-section-head::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 60%, rgba(255,255,255,.06));
  pointer-events: none;
}

.kg-section-head h3 {
  margin: 0;
  font-family: 'Cinzel', serif;
  font-size: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative;
  z-index: 1;
}

.kg-section-head h3 i { font-size: 20px; }

.kg-section-badge {
  font-size: 11.5px;
  font-weight: 800;
  background: rgba(255,255,255,.20);
  border: 1px solid rgba(255,255,255,.25);
  padding: 5px 12px;
  border-radius: 999px;
  position: relative;
  z-index: 1;
  white-space: nowrap;
  letter-spacing: .3px;
}

.kg-section-content { padding: 24px; background: #fefcf7; }

/* Section color themes */
.s-red    { background: linear-gradient(135deg, #720000, #b50d17); }
.s-gold   { background: linear-gradient(135deg, #7a4e0c, #c9880a); }
.s-purple { background: linear-gradient(135deg, #45115a, #8328ad); }
.s-blue   { background: linear-gradient(135deg, #0f3460, #1a7ab5); }
.s-green  { background: linear-gradient(135deg, #10502f, #1d9d68); }
.s-orange { background: linear-gradient(135deg, #8c3000, #e87d22); }
.s-pink   { background: linear-gradient(135deg, #7e0f40, #ce3278); }
.s-brown  { background: linear-gradient(135deg, #502610, #9e5f24); }
.s-teal   { background: linear-gradient(135deg, #005252, #1a9d9d); }
.s-dark   { background: linear-gradient(135deg, #181818, #484848); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SUMMARY STRIP
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-summary-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

.kg-summary-card {
  background: linear-gradient(145deg, #fff9e8, #fffdf6);
  border: 1px solid #e8d8b5;
  border-radius: 22px;
  padding: 20px 16px;
  text-align: center;
  box-shadow: 0 6px 22px rgba(0,0,0,.05);
  transition: transform .2s, box-shadow .2s;
}

.kg-summary-card:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(0,0,0,.09); }
.kg-summary-card i     { color: var(--kg-gold); font-size: 28px; display: block; margin-bottom: 10px; }
.kg-summary-card small { display: block; color: #735f4a; font-weight: 800; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; margin-bottom: 6px; }
.kg-summary-card b     { color: var(--kg-red); font-size: 14.5px; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   KUNDLI CHART AREA
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-chart-area { display: grid; grid-template-columns: .95fr 1.05fr; gap: 20px; }

.kg-chart-box,
.kg-table-box {
  border-radius: 24px;
  background: linear-gradient(145deg, #fffdf8, #fffcf0);
  border: 1px solid #e8d8b5;
  padding: 24px;
  box-shadow: 0 6px 22px rgba(0,0,0,.04);
}

.kg-chart-title {
  font-family: 'Cinzel', serif;
  color: var(--kg-red);
  font-size: 19px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #f0e0c0;
}

/* SVG Kundli Chart */
.kg-kundli-svg-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0;
}

.kg-kundli-svg {
  width: 100%;
  max-width: 300px;
  filter: drop-shadow(0 12px 28px rgba(125,0,0,.12));
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PLANETARY TABLE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-planet-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 8px;
}

.kg-planet-table tr { transition: transform .2s; }

.kg-planet-table th {
  padding: 12px 14px;
  font-size: 12px;
  font-weight: 900;
  color: #7d0000;
  background: #ffecc2;
  text-transform: uppercase;
  letter-spacing: .4px;
  border-top: 1px solid #efdcb7;
  border-bottom: 1px solid #efdcb7;
}

.kg-planet-table td {
  padding: 12px 14px;
  font-size: 13px;
  color: var(--kg-text);
  background: #fff9e8;
  border-top: 1px solid #efdcb7;
  border-bottom: 1px solid #efdcb7;
  vertical-align: middle;
}

.kg-planet-table th:first-child, .kg-planet-table td:first-child {
  border-left: 1px solid #efdcb7;
  border-radius: 14px 0 0 14px;
}

.kg-planet-table th:last-child, .kg-planet-table td:last-child {
  border-right: 1px solid #efdcb7;
  border-radius: 0 14px 14px 0;
}

.kg-planet-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 700;
  color: var(--kg-red);
}

.kg-planet-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--kg-gold);
  flex: 0 0 auto;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CARD GRID
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.kg-two-col   { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }

.kg-detail-card {
  padding: 20px;
  border-radius: 22px;
  background: linear-gradient(145deg, #fffdf8, #fffcf0);
  border: 1px solid #e8d8b5;
  box-shadow: 0 6px 20px rgba(0,0,0,.05);
  transition: transform .2s, box-shadow .2s;
}

.kg-detail-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,.09); }

.kg-detail-card .kg-dc-icon {
  width: 50px; height: 50px;
  border-radius: 16px;
  background: linear-gradient(145deg, #fff3d0, #fff9e8);
  border: 1px solid #efdcb7;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}

.kg-detail-card .kg-dc-icon i { color: var(--kg-gold); font-size: 24px; }
.kg-detail-card h4 { color: var(--kg-red); font-size: 15px; margin-bottom: 8px; font-weight: 700; }
.kg-detail-card p  { color: #5a4732; font-size: 13px; line-height: 1.75; margin: 0; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LIST
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-list { list-style: none; display: grid; gap: 10px; }

.kg-list li {
  padding: 14px 16px;
  border-radius: 16px;
  background: linear-gradient(145deg, #fff9e8, #fffcf0);
  border: 1px solid #efdcb7;
  color: #5a4732;
  font-size: 13.5px;
  line-height: 1.65;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  box-shadow: 0 3px 12px rgba(0,0,0,.04);
  transition: transform .2s;
}

.kg-list li:hover { transform: translateX(4px); }
.kg-list li i { color: var(--kg-red); font-size: 17px; margin-top: 1px; flex: 0 0 auto; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DISCLAIMER & ACTIONS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.kg-disclaimer {
  margin-top: 24px;
  padding: 18px 20px;
  border-radius: 18px;
  background: linear-gradient(135deg, #fff9e8, #fffcf0);
  border-left: 4px solid var(--kg-gold);
  color: #5a4732;
  font-size: 13px;
  line-height: 1.75;
  box-shadow: 0 4px 16px rgba(0,0,0,.04);
}

.kg-download-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }

.kg-small-btn {
  border: 0;
  border-radius: 999px;
  padding: 15px 24px;
  cursor: pointer;
  font-family: 'Poppins', sans-serif;
  font-weight: 800;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: transform .2s, box-shadow .2s;
  letter-spacing: .2px;
}

.kg-small-btn:hover { transform: translateY(-2px); }

.kg-print {
  background: linear-gradient(135deg, #e8c85a, #c9a227, #e8c85a);
  color: #3a2000;
  box-shadow: 0 10px 28px rgba(201,162,39,.35);
}

.kg-new {
  background: #fff;
  border: 1.5px solid rgba(125,0,0,.28);
  color: var(--kg-red);
  box-shadow: 0 6px 20px rgba(0,0,0,.07);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 1024px) {
  .kg-slide            { grid-template-columns: 1fr; padding: 44px 38px 80px; }
  .kg-hero             { min-height: 880px; }
  .kg-hero-visual      { min-height: 380px; }
  .kg-float-card       { right: 50%; transform: translateX(50%); bottom: 0; }
  .kg-offer-strip      { grid-template-columns: 1fr; }
  .kg-user-info        { grid-template-columns: repeat(3, 1fr); }
  .kg-chart-area       { grid-template-columns: 1fr; }
  .kg-card-grid        { grid-template-columns: repeat(2, 1fr); }
  .kg-summary-strip    { grid-template-columns: repeat(2, 1fr); }
  .kg-help             { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .kg-page             { padding: 10px 10px 110px; }
  .kg-hero             { min-height: auto; border-radius: 26px; margin-bottom: 16px; }
  .kg-slide            { position: relative; padding: 28px 20px 80px; align-content: start; gap: 20px; }
  .kg-hero h1          { font-size: 30px; }
  .kg-hero p           { font-size: 14px; }
  .kg-feature-grid     { grid-template-columns: 1fr; gap: 10px; }
  .kg-hero-visual      { min-height: 280px; }
  .kg-hero-img         { max-height: 260px; }
  .kg-float-card       { left: 10px; right: 10px; width: auto; transform: none; bottom: -2px; border-radius: 18px; padding: 12px 16px; }
  .kg-slider-dots      { left: 22px; bottom: 130px; }
  .kg-form-head        { padding: 28px 20px; }
  .kg-form-head h2     { font-size: 28px; }
  .kg-form-body        { padding: 20px; }
  .kg-grid             { grid-template-columns: 1fr; }
  .kg-user-info        { grid-template-columns: repeat(2, 1fr); }
  .kg-card-grid,
  .kg-summary-strip,
  .kg-two-col          { grid-template-columns: 1fr; }
  .kg-sticky-submit    { position: fixed; left: 8px; right: 8px; bottom: 8px; border-radius: 20px; padding: 10px; }
  .kg-submit-btn       { height: 58px; font-size: 15px; }
  .kg-report-top       { padding: 24px 20px; }
  .kg-report-top h2    { font-size: 24px; }
  .kg-report-body      { padding: 20px; }
  .kg-section-head     { flex-direction: column; align-items: flex-start; padding: 16px 18px; gap: 8px; }
  .kg-section-head h3  { font-size: 17px; }
  .kg-section-content  { padding: 18px; }
  .kg-chart-box,
  .kg-table-box        { padding: 18px; }
  .kg-download-row     { flex-direction: column; }
  .kg-small-btn        { width: 100%; }
  .kg-offer-mini       { grid-template-columns: 1fr; }
}

@media print {
  body *              { visibility: hidden; }
  .kg-report,
  .kg-report *        { visibility: visible; }
  .kg-report          { display: block !important; position: absolute; left: 0; top: 0; width: 100%; box-shadow: none; border: none; }
  .kg-download-row,
  .kg-sticky-submit,
  .kg-loader,
  .kg-hero,
  .kg-form-head,
  .kg-grid,
  .kg-help,
  .kg-offer-strip     { display: none !important; }
}
