/*!
 * gi-calculator.css  —  Go Ignite Profit Calculator
 * Version  : 2.0.0
 * Scope    : [data-gi-calc]  →  ZERO global side-effects
 * Drop-in  : <link rel="stylesheet" href="gi-calculator.css">
 * ─────────────────────────────────────────────────────────────────
 * Every single rule is scoped inside [data-gi-calc].
 * Nothing bleeds into the rest of your page.
 * ─────────────────────────────────────────────────────────────────
 */

/* ══════════════════════════════════════════════════════════════════
   1. DESIGN TOKENS  (custom props scoped to the component)
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] {
  /* Brand colours */
  --gic-green       : #00E69D;
  --gic-green-dark  : #00C284;
  --gic-green-glow  : rgba(0,230,157,0.35);
  --gic-green-dim   : rgba(0,230,157,0.08);
  --gic-purple      : #9D00FF;
  --gic-purple-dim  : rgba(157,0,255,0.10);
  --gic-pink        : #FF14A9;
  /* Backgrounds */
  --gic-bg          : #0a0a0f;
  --gic-card        : #12121a;
  --gic-card-2      : #0d0d16;
  /* Text */
  --gic-text        : #ffffff;
  --gic-muted       : #99a2b2;
  --gic-subtle      : #4b5563;
  /* Borders */
  --gic-border      : rgba(255,255,255,0.08);
  --gic-border-hover: rgba(255,255,255,0.22);
  --gic-border-card : rgba(255,255,255,0.06);
  /* Typography */
  --gic-font        : 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  /* Radii */
  --gic-r-sm        : 0.5rem;
  --gic-r-md        : 0.75rem;
  --gic-r-lg        : 1rem;
  --gic-r-xl        : 1.25rem;
  /* Easing */
  --gic-ease        : cubic-bezier(0.4, 0, 0.2, 1);

  /* Base reset — scoped, never leaks */
  font-family       : var(--gic-font);
  color             : var(--gic-text);
  color-scheme      : dark;
  -webkit-font-smoothing : antialiased;
  -moz-osx-font-smoothing: grayscale;
  box-sizing        : border-box;
  position          : relative;
}
[data-gi-calc] *, [data-gi-calc] *::before, [data-gi-calc] *::after {
  box-sizing: inherit;
  margin: 0;
  padding: 0;
}

/* ══════════════════════════════════════════════════════════════════
   2. STEPPER
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-stepper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 560px;
  margin: 0 auto 2rem;
  position: relative;
}
[data-gi-calc] .gic-stepper-track {
  position: absolute;
  left: 0; top: 50%; width: 100%; height: 1px;
  background: rgba(255,255,255,0.10);
  transform: translateY(-50%);
  z-index: 0;
  pointer-events: none;
}
[data-gi-calc] .gic-stepper-fill {
  position: absolute;
  left: 0; top: 50%; height: 1px;
  background: var(--gic-green);
  transform: translateY(-50%);
  z-index: 0;
  pointer-events: none;
  transition: width 0.55s var(--gic-ease);
}
[data-gi-calc] .gic-step-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  z-index: 1;
  user-select: none;
  /* Key: background matches page so track line is "cut" behind labels */
  background: var(--gic-bg);
}
[data-gi-calc] .gic-step-item:first-child { padding-right: 0.75rem; }
[data-gi-calc] .gic-step-item:last-child  { padding-left:  0.75rem; }
[data-gi-calc] .gic-step-item:not(:first-child):not(:last-child) { padding: 0 0.75rem; }

[data-gi-calc] .gic-step-dot {
  width: 1.5rem; height: 1.5rem;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.7rem; font-weight: 700; line-height: 1;
  background: var(--gic-card);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--gic-muted);
  flex-shrink: 0;
  transition: background 0.25s, border-color 0.25s, color 0.25s, box-shadow 0.25s;
}
[data-gi-calc] .gic-step-dot svg {
  width: 0.7rem; height: 0.7rem;
}
[data-gi-calc] .gic-step-label {
  font-size: 0.8125rem; font-weight: 500;
  color: var(--gic-muted);
  white-space: nowrap;
  transition: color 0.25s;
}
/* Active step */
[data-gi-calc] .gic-step-item.is-active .gic-step-dot {
  background: var(--gic-green);
  border-color: var(--gic-green);
  color: #05080F;
  box-shadow: 0 0 12px var(--gic-green-glow);
}
[data-gi-calc] .gic-step-item.is-active .gic-step-label { color: var(--gic-green); }
/* Done step */
[data-gi-calc] .gic-step-item.is-done .gic-step-dot {
  background: var(--gic-green);
  border-color: var(--gic-green);
  color: #05080F;
}
[data-gi-calc] .gic-step-item.is-done .gic-step-label { color: var(--gic-green); }

/* ══════════════════════════════════════════════════════════════════
   3. PANEL SHELL
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-panel {
  background: var(--gic-bg);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--gic-r-xl);
  padding: 1.75rem 1.5rem;
  box-shadow: 0 25px 60px rgba(0,0,0,0.50);
}
@media (min-width: 640px)  { [data-gi-calc] .gic-panel { padding: 2.5rem; } }
@media (min-width: 1024px) { [data-gi-calc] .gic-panel { padding: 2.5rem 3rem; } }

[data-gi-calc] .gic-panel-title {
  font-size: 1.375rem; font-weight: 700; line-height: 1.25;
  color: var(--gic-green);
  margin-bottom: 1.75rem;
}
[data-gi-calc] .gic-panel-subtitle {
  font-size: 0.875rem;
  color: var(--gic-muted);
  margin-top: -1.25rem;
  margin-bottom: 1.75rem;
  line-height: 1.5;
}

/* ══════════════════════════════════════════════════════════════════
   4. STEP PANELS — show / hide with animation
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-step-panel { display: none; }
[data-gi-calc] .gic-step-panel.is-visible {
  display: block;
  animation: gicFadeUp 0.38s var(--gic-ease) both;
}
@keyframes gicFadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════════════════════════════════════
   5. QUESTION BLOCK
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-q         { margin-bottom: 1.5rem; }
[data-gi-calc] .gic-q-label   { display: block; font-size: 0.8125rem; font-weight: 600; color: var(--gic-green); margin-bottom: 0.5rem; }
[data-gi-calc] .gic-q-sub     { display: block; font-size: 0.75rem; color: var(--gic-muted); margin-bottom: 0.625rem; }

/* ══════════════════════════════════════════════════════════════════
   6. OPTION GRID
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-opts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.45rem;
}
@media (min-width: 560px) {
  [data-gi-calc] .gic-opts.cols-3 { grid-template-columns: repeat(3, 1fr); }
  [data-gi-calc] .gic-opts.cols-2 { grid-template-columns: repeat(2, 1fr); }
}

/* ══════════════════════════════════════════════════════════════════
   7. OPTION BUTTON  (single-select)
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-opt {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  border-radius: var(--gic-r-sm);
  border: 1px solid var(--gic-border);
  background: var(--gic-card);
  color: var(--gic-muted);
  font-family: var(--gic-font);
  font-size: 0.8125rem; font-weight: 500;
  text-align: left;
  cursor: pointer;
  outline: none;
  -webkit-tap-highlight-color: transparent;
  transition: border-color 0.18s var(--gic-ease),
              color        0.18s var(--gic-ease),
              background   0.18s var(--gic-ease),
              box-shadow   0.18s var(--gic-ease),
              transform    0.18s var(--gic-ease);
}
[data-gi-calc] .gic-opt:hover {
  border-color: var(--gic-border-hover);
  color: #e2e8f0;
  transform: translateY(-1px);
}
[data-gi-calc] .gic-opt:active { transform: translateY(0); }
[data-gi-calc] .gic-opt.is-selected {
  border-color: var(--gic-green);
  background: var(--gic-green-dim);
  color: var(--gic-green);
  box-shadow: 0 0 14px rgba(0,230,157,0.12);
  transform: translateY(0);
}

/* ══════════════════════════════════════════════════════════════════
   8. PAIN POINT BUTTON  (multi-select)
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-pain-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.875rem 1rem;
  border-radius: var(--gic-r-sm);
  border: 1px solid rgba(255,255,255,0.05);
  background: var(--gic-card);
  cursor: pointer;
  outline: none;
  font-family: var(--gic-font);
  -webkit-tap-highlight-color: transparent;
  transition: border-color 0.18s var(--gic-ease),
              background   0.18s var(--gic-ease);
}
[data-gi-calc] .gic-pain-btn:hover { border-color: rgba(255,255,255,0.12); }
[data-gi-calc] .gic-pain-btn.is-selected {
  border-color: rgba(0,230,157,0.35);
  background: rgba(0,230,157,0.04);
}
[data-gi-calc] .gic-pain-inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
[data-gi-calc] .gic-pain-icon {
  color: var(--gic-subtle);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: color 0.18s;
}
[data-gi-calc] .gic-pain-icon svg {
  width: 1rem; height: 1rem;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
[data-gi-calc] .gic-pain-btn.is-selected .gic-pain-icon { color: var(--gic-green); }
[data-gi-calc] .gic-pain-label {
  font-size: 0.875rem; font-weight: 400;
  color: var(--gic-muted);
  transition: color 0.18s;
}
[data-gi-calc] .gic-pain-btn.is-selected .gic-pain-label { color: #ffffff; }

/* Checkbox */
[data-gi-calc] .gic-check {
  flex-shrink: 0;
  width: 1rem; height: 1rem;
  border-radius: 0.25rem;
  border: 1px solid var(--gic-subtle);
  background: transparent;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.18s, border-color 0.18s;
}
[data-gi-calc] .gic-check svg {
  width: 0.6rem; height: 0.6rem;
  stroke: #05080F; fill: none;
  stroke-width: 3; stroke-linecap: round; stroke-linejoin: round;
  display: none;
}
[data-gi-calc] .gic-pain-btn.is-selected .gic-check {
  background: var(--gic-green);
  border-color: var(--gic-green);
}
[data-gi-calc] .gic-pain-btn.is-selected .gic-check svg { display: block; }

/* ══════════════════════════════════════════════════════════════════
   9. VALIDATION HINT
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-hint {
  font-size: 0.7rem; color: #f87171;
  margin-top: 0.375rem; display: none;
  animation: gicShake 0.35s ease both;
}
[data-gi-calc] .gic-hint.is-visible { display: block; }
@keyframes gicShake {
  0%,100% { transform: translateX(0); }
  25%     { transform: translateX(-4px); }
  75%     { transform: translateX(4px); }
}

/* ══════════════════════════════════════════════════════════════════
   10. ACTION BUTTONS (Continue / Back)
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 2rem;
  flex-wrap: wrap;
}
[data-gi-calc] .gic-btn-continue {
  flex: 1;
  min-width: 180px;
  display: inline-flex; align-items: center; justify-content: center; gap: 0.375rem;
  padding: 0.875rem 1.5rem;
  border-radius: var(--gic-r-sm);
  border: 1px solid rgba(255,255,255,0.05);
  background: var(--gic-card);
  color: var(--gic-subtle);
  font-family: var(--gic-font);
  font-size: 0.875rem; font-weight: 600;
  cursor: not-allowed;
  outline: none;
  transition: all 0.25s var(--gic-ease);
}
[data-gi-calc] .gic-btn-continue svg {
  width: 1rem; height: 1rem;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
[data-gi-calc] .gic-btn-continue.is-ready {
  background: var(--gic-green);
  border-color: var(--gic-green);
  color: #05080F;
  cursor: pointer;
  box-shadow: 0 0 24px var(--gic-green-glow);
}
[data-gi-calc] .gic-btn-continue.is-ready:hover {
  background: var(--gic-green-dark);
  box-shadow: 0 0 36px rgba(0,230,157,0.50);
  transform: translateY(-2px);
}
[data-gi-calc] .gic-btn-continue.is-ready:active { transform: translateY(0); }

[data-gi-calc] .gic-btn-back {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.875rem 1.25rem;
  border-radius: var(--gic-r-sm);
  border: 1px solid rgba(255,255,255,0.10);
  background: transparent;
  color: var(--gic-muted);
  font-family: var(--gic-font);
  font-size: 0.875rem; font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  outline: none;
  transition: border-color 0.18s, color 0.18s;
}
[data-gi-calc] .gic-btn-back svg {
  width: 1rem; height: 1rem;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
[data-gi-calc] .gic-btn-back:hover { border-color: rgba(255,255,255,0.25); color: #e2e8f0; }

/* ══════════════════════════════════════════════════════════════════
   11. STEP 2 — SLIDERS
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-slider-grid {
  display: grid;
  grid-template-columns: 1fr;            /* mobile: stack */
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
@media (min-width: 560px) {
  [data-gi-calc] .gic-slider-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));  /* tablet+: 2 × 2 */
    column-gap: 2rem;
    row-gap: 1.75rem;
  }
}
[data-gi-calc] .gic-slider-row { min-width: 0; }       /* prevent grid overflow */
[data-gi-calc] .gic-slider-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.5rem;
  gap: 0.5rem;
}
[data-gi-calc] .gic-slider-label {
  font-size: 0.9375rem; font-weight: 500;
  color: #ffffff;
  line-height: 1.3;
}
[data-gi-calc] .gic-slider-val {
  font-size: 1.25rem; font-weight: 700;
  color: var(--gic-green);
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 5rem;
  text-align: right;
}
[data-gi-calc] .gic-slider {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  border-radius: 9999px;
  background: rgba(255,255,255,0.12);
  outline: none;
  cursor: pointer;
}
[data-gi-calc] .gic-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--gic-green);
  cursor: pointer;
  box-shadow: 0 0 8px var(--gic-green-glow);
  transition: box-shadow 0.18s;
}
[data-gi-calc] .gic-slider::-moz-range-thumb {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--gic-green);
  cursor: pointer;
  border: none;
  box-shadow: 0 0 8px var(--gic-green-glow);
}
[data-gi-calc] .gic-slider::-webkit-slider-thumb:hover { box-shadow: 0 0 14px rgba(0,230,157,0.60); }
[data-gi-calc] .gic-slider-range {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--gic-muted);
  margin-top: 0.25rem;
}

/* ══════════════════════════════════════════════════════════════════
   12. STEP 2 — MINI RESULT CARDS (live calculation display)
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-mini-box {
  border: 1px solid var(--gic-border-card);
  border-radius: var(--gic-r-md);
  padding: 1.25rem 1.5rem;
  background: rgba(255,255,255,0.02);
  margin-bottom: 1.5rem;
}
[data-gi-calc] .gic-mini-box-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gic-muted);
  margin-bottom: 1rem;
}
[data-gi-calc] .gic-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  text-align: center;
}
@media (min-width: 560px) {
  [data-gi-calc] .gic-mini-grid { grid-template-columns: repeat(4, 1fr); }
}
[data-gi-calc] .gic-mini-val {
  font-size: 1.375rem; font-weight: 900;
  color: var(--gic-purple);
  line-height: 1;
  margin-bottom: 0.3rem;
  transition: color 0.2s;
}
[data-gi-calc] .gic-mini-lbl {
  font-size: 0.72rem;
  color: var(--gic-muted);
  line-height: 1.3;
}

/* ══════════════════════════════════════════════════════════════════
   13. STEP 3 — RESULTS
   ══════════════════════════════════════════════════════════════════ */
/* Top leak box */
[data-gi-calc] .gic-leak-box {
  border: 1px solid rgba(255,255,255,0.08);
  border-left: 4px solid var(--gic-green);
  border-radius: var(--gic-r-md);
  padding: 1.5rem;
  background: var(--gic-bg);
  margin-bottom: 1rem;
}
[data-gi-calc] .gic-leak-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
  flex-wrap: wrap;
}
[data-gi-calc] .gic-leak-header-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gic-muted);
}
[data-gi-calc] .gic-info-btn {
  font-size: 0.75rem;
  color: var(--gic-green);
  background: transparent;
  border: 1px solid rgba(0,230,157,0.30);
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  cursor: pointer;
  white-space: nowrap;
  font-family: var(--gic-font);
  outline: none;
  transition: background 0.18s;
}
[data-gi-calc] .gic-info-btn:hover { background: rgba(0,230,157,0.08); }
[data-gi-calc] .gic-total-amount {
  font-size: clamp(2.5rem, 8vw, 3.5rem);
  font-weight: 900;
  color: var(--gic-purple);
  line-height: 1;
  letter-spacing: -0.04em;
  text-shadow: 0 0 40px rgba(157,0,255,0.40);
  margin: 0.5rem 0;
  min-height: 1em;
}
[data-gi-calc] .gic-monthly-text {
  font-size: 0.9375rem;
  color: var(--gic-muted);
  line-height: 1.5;
}
[data-gi-calc] .gic-monthly-amount {
  color: var(--gic-purple);
  font-weight: 700;
}

/* Result cards grid */
[data-gi-calc] .gic-result-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin-bottom: 1rem;
}
@media (min-width: 560px) {
  [data-gi-calc] .gic-result-grid { grid-template-columns: repeat(4, 1fr); }
}
[data-gi-calc] .gic-result-card {
  background: var(--gic-bg);
  border: 1px solid var(--gic-border-card);
  border-radius: var(--gic-r-md);
  padding: 1.25rem 0.75rem;
  text-align: center;
}
[data-gi-calc] .gic-result-icon { font-size: 1.25rem; margin-bottom: 0.5rem; opacity: 0.65; }
[data-gi-calc] .gic-result-val {
  font-size: 1.375rem; font-weight: 900;
  color: var(--gic-purple);
  line-height: 1;
  margin-bottom: 0.3rem;
  min-height: 1em;
}
[data-gi-calc] .gic-result-lbl {
  font-size: 0.72rem;
  color: var(--gic-muted);
  line-height: 1.3;
}

/* Plan recommendation box */
[data-gi-calc] .gic-plan-box {
  border: 1px solid rgba(255,255,255,0.08);
  border-left: 4px solid var(--gic-green);
  border-radius: var(--gic-r-md);
  padding: 1.5rem;
  background: var(--gic-bg);
  margin-bottom: 1rem;
}
[data-gi-calc] .gic-plan-box-label {
  font-size: 0.7rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--gic-muted);
  margin-bottom: 0.5rem;
}
[data-gi-calc] .gic-plan-name {
  font-size: 2rem; font-weight: 900;
  color: var(--gic-green);
  margin-bottom: 0.5rem;
  line-height: 1.1;
}
[data-gi-calc] .gic-plan-desc {
  color: var(--gic-muted);
  font-size: 0.875rem;
  line-height: 1.55;
  margin-bottom: 1.5rem;
}
[data-gi-calc] .gic-plan-ctas {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
[data-gi-calc] .gic-cta-primary {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.75rem 1.25rem;
  border-radius: var(--gic-r-sm);
  background: var(--gic-green);
  color: #05080F;
  font-family: var(--gic-font);
  font-size: 0.875rem; font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: opacity 0.18s, transform 0.18s;
  outline: none;
}
[data-gi-calc] .gic-cta-primary:hover { opacity: 0.9; transform: translateY(-1px); }
[data-gi-calc] .gic-cta-secondary {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.75rem 1.25rem;
  border-radius: var(--gic-r-sm);
  border: 1px solid var(--gic-green);
  background: transparent;
  color: var(--gic-green);
  font-family: var(--gic-font);
  font-size: 0.875rem; font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.18s, transform 0.18s;
  outline: none;
}
[data-gi-calc] .gic-cta-secondary:hover { background: rgba(0,230,157,0.08); transform: translateY(-1px); }
[data-gi-calc] .gic-plan-note {
  font-size: 0.875rem;
  color: var(--gic-muted);
}
[data-gi-calc] .gic-plan-note a {
  color: var(--gic-green);
  text-decoration: underline;
  cursor: pointer;
}

/* Email capture box */
[data-gi-calc] .gic-email-box {
  border: 1px solid var(--gic-border-card);
  border-radius: var(--gic-r-md);
  padding: 1.5rem;
  background: var(--gic-bg);
  text-align: center;
  margin-bottom: 1rem;
  display: none;
}
[data-gi-calc] .gic-email-title {
  font-size: 1rem; font-weight: 700;
  color: #ffffff;
  margin-bottom: 0.4rem;
}
[data-gi-calc] .gic-email-sub {
  font-size: 0.875rem;
  color: var(--gic-muted);
  margin-bottom: 1rem;
  line-height: 1.5;
}
[data-gi-calc] .gic-email-form {
  display: flex;
  gap: 0.5rem;
  max-width: 500px;
  margin: 0 auto;
  flex-wrap: wrap;
}
[data-gi-calc] .gic-email-input {
  flex: 1;
  min-width: 200px;
  padding: 0.75rem 1rem;
  background: var(--gic-card);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--gic-r-sm);
  color: #ffffff;
  font-family: var(--gic-font);
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.18s;
}
[data-gi-calc] .gic-email-input::placeholder { color: var(--gic-muted); }
[data-gi-calc] .gic-email-input:focus { border-color: var(--gic-green); }
[data-gi-calc] .gic-email-submit {
  padding: 0.75rem 1.5rem;
  border-radius: var(--gic-r-sm);
  background: var(--gic-green);
  color: #05080F;
  font-family: var(--gic-font);
  font-size: 0.875rem; font-weight: 700;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  outline: none;
  transition: opacity 0.18s;
}
[data-gi-calc] .gic-email-submit:hover { opacity: 0.9; }
[data-gi-calc] .gic-email-submit:disabled { opacity: 0.6; cursor: default; }

/* Restart link */
[data-gi-calc] .gic-restart-btn {
  background: transparent;
  border: none;
  color: var(--gic-muted);
  text-decoration: underline;
  cursor: pointer;
  font-family: var(--gic-font);
  font-size: 0.875rem;
  outline: none;
  transition: color 0.18s;
}
[data-gi-calc] .gic-restart-btn:hover { color: #ffffff; }

/* ══════════════════════════════════════════════════════════════════
   14. MOBILE OVERRIDES
   ══════════════════════════════════════════════════════════════════ */
@media (max-width: 479px) {
  [data-gi-calc] .gic-panel          { padding: 1.25rem 1rem; }
  [data-gi-calc] .gic-panel-title    { font-size: 1.125rem; }
  [data-gi-calc] .gic-stepper        { max-width: 100%; }
  [data-gi-calc] .gic-step-label     { font-size: 0.68rem; }
  [data-gi-calc] .gic-total-amount   { font-size: 2rem; }
  [data-gi-calc] .gic-result-grid    { grid-template-columns: repeat(2, 1fr); }
  [data-gi-calc] .gic-plan-ctas      { flex-direction: column; }
  [data-gi-calc] .gic-cta-primary,
  [data-gi-calc] .gic-cta-secondary  { width: 100%; text-align: center; }
  [data-gi-calc] .gic-slider-label   { font-size: 0.8125rem; }
  [data-gi-calc] .gic-slider-val     { font-size: 1rem; }
}

/* ══════════════════════════════════════════════════════════════════
   15. REDUCED MOTION
   ══════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  [data-gi-calc] *,
  [data-gi-calc] *::before,
  [data-gi-calc] *::after {
    animation-duration:        0.001ms !important;
    animation-iteration-count: 1       !important;
    transition-duration:       0.001ms !important;
  }
}

/* ══════════════════════════════════════════════════════════════════
   16. "OTHER" INDUSTRY TEXT INPUT
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc] .gic-other-wrap {
  margin-top: -0.75rem;
  margin-bottom: 0.5rem;
  animation: gicFadeUp 0.28s cubic-bezier(0.4,0,0.2,1) both;
}
[data-gi-calc] .gic-other-label {
  display: block;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--gic-muted);
  margin-bottom: 0.45rem;
}
[data-gi-calc] .gic-other-input {
  width: 100%;
  padding: 0.7rem 1rem;
  background: var(--gic-card);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--gic-r-sm);
  color: var(--gic-text);
  font-family: var(--gic-font);
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.18s;
}
[data-gi-calc] .gic-other-input::placeholder { color: var(--gic-muted); }
[data-gi-calc] .gic-other-input:focus        { border-color: var(--gic-green); }

/* ══════════════════════════════════════════════════════════════════
   17. CALCULATION FORMULA MODAL  [data-gi-calc-modal]
       Separate scope from [data-gi-calc] so it can overlay the page
   ══════════════════════════════════════════════════════════════════ */
[data-gi-calc-modal] {
  --gicm-green   : #00E69D;
  --gicm-bg      : #0d0d16;
  --gicm-border  : rgba(255,255,255,0.08);
  --gicm-text    : #ffffff;
  --gicm-muted   : #99a2b2;
  --gicm-font    : 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  position       : fixed;
  inset          : 0;
  z-index        : 999999;
  pointer-events : all;
  font-family    : var(--gicm-font);
  -webkit-font-smoothing: antialiased;
}
/* Fade-in / fade-out */
[data-gi-calc-modal] .gicm-overlay {
  position   : absolute;
  inset      : 0;
  background : rgba(0,0,0,0.72);
  backdrop-filter: blur(4px);
  display    : flex;
  align-items: center;
  justify-content: center;
  padding    : 1rem;
  animation  : gicmOverlayIn 0.22s ease both;
  overflow-y : auto;
}
[data-gi-calc-modal].is-closing .gicm-overlay {
  animation: gicmOverlayOut 0.24s ease both;
}
@keyframes gicmOverlayIn  { from{opacity:0;} to{opacity:1;} }
@keyframes gicmOverlayOut { from{opacity:1;} to{opacity:0;} }

/* Modal card */
[data-gi-calc-modal] .gicm-box {
  background   : var(--gicm-bg);
  border       : 1px solid var(--gicm-border);
  border-radius: 1rem;
  width        : 100%;
  max-width    : 560px;
  max-height   : calc(100vh - 2rem);
  overflow-y   : auto;
  box-shadow   : 0 30px 80px rgba(0,0,0,0.70);
  animation    : gicmBoxIn 0.28s cubic-bezier(0.22,1,0.36,1) both;
  position     : relative;
}
[data-gi-calc-modal].is-closing .gicm-box {
  animation: gicmBoxOut 0.22s ease both;
}
@keyframes gicmBoxIn  { from{opacity:0;transform:translateY(16px) scale(0.97);} to{opacity:1;transform:none;} }
@keyframes gicmBoxOut { from{opacity:1;transform:none;} to{opacity:0;transform:translateY(8px) scale(0.97);} }

/* Header */
[data-gi-calc-modal] .gicm-header {
  display        : flex;
  align-items    : center;
  justify-content: space-between;
  padding        : 1.5rem 1.5rem 0;
  gap            : 1rem;
}
[data-gi-calc-modal] .gicm-title {
  font-size  : 1.375rem;
  font-weight: 800;
  color      : var(--gicm-green);
  line-height: 1.2;
  margin     : 0;
}
[data-gi-calc-modal] .gicm-close {
  display        : flex;
  align-items    : center;
  justify-content: center;
  flex-shrink    : 0;
  width          : 2rem;
  height         : 2rem;
  border-radius  : 0.375rem;
  background     : rgba(255,255,255,0.06);
  border         : 1px solid rgba(255,255,255,0.10);
  color          : var(--gicm-muted);
  cursor         : pointer;
  outline        : none;
  transition     : background 0.18s, color 0.18s;
}
[data-gi-calc-modal] .gicm-close svg {
  width: 0.875rem; height: 0.875rem;
}
[data-gi-calc-modal] .gicm-close:hover {
  background: rgba(255,255,255,0.12);
  color     : #fff;
}

/* Body */
[data-gi-calc-modal] .gicm-body {
  padding: 1.25rem 1.5rem 1.75rem;
}
[data-gi-calc-modal] .gicm-intro {
  font-size  : 0.9rem;
  color      : var(--gicm-muted);
  line-height: 1.65;
  margin-bottom: 1.25rem;
}
[data-gi-calc-modal] .gicm-ai {
  color      : var(--gicm-green);
  font-weight: 600;
}

/* Bullet list */
[data-gi-calc-modal] .gicm-list {
  list-style : none;
  padding    : 0;
  margin     : 0 0 1.25rem;
  display    : flex;
  flex-direction: column;
  gap        : 1rem;
}
[data-gi-calc-modal] .gicm-list li {
  font-size  : 0.875rem;
  color      : var(--gicm-muted);
  line-height: 1.65;
  padding-left: 1.25rem;
  position   : relative;
}
[data-gi-calc-modal] .gicm-list li::before {
  content      : '•';
  position     : absolute;
  left         : 0;
  color        : var(--gicm-green);
  font-weight  : 700;
}
[data-gi-calc-modal] .gicm-term {
  color      : var(--gicm-green);
  font-weight: 700;
}

/* Disclaimer box */
[data-gi-calc-modal] .gicm-disclaimer {
  background   : rgba(255,255,255,0.03);
  border       : 1px solid rgba(255,255,255,0.07);
  border-radius: 0.625rem;
  padding      : 1rem 1.25rem;
}
[data-gi-calc-modal] .gicm-disclaimer p {
  font-size  : 0.875rem;
  color      : var(--gicm-muted);
  line-height: 1.6;
  margin     : 0;
}
[data-gi-calc-modal] .gicm-disclaimer em {
  font-style: italic;
  font-weight: 600;
}

/* Mobile */
@media (max-width: 479px) {
  [data-gi-calc-modal] .gicm-header { padding: 1.25rem 1.25rem 0; }
  [data-gi-calc-modal] .gicm-body   { padding: 1rem 1.25rem 1.5rem; }
  [data-gi-calc-modal] .gicm-title  { font-size: 1.1rem; }
}
/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  [data-gi-calc-modal] * { animation-duration: 0.001ms !important; }
}
