/*
 * Genesis AI Platform™ — Registration & Checkout
 * Design: Precision dark · Gold authority · Converts
 * v1.0.0
 */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&family=DM+Mono&display=swap');

.gr-wrap {
  --c-bg:       #07080f;
  --c-surface:  #0d1117;
  --c-s2:       #161b22;
  --c-s3:       #1c2230;
  --c-border:   rgba(255,255,255,.07);
  --c-border-2: rgba(255,255,255,.13);
  --c-gold:     #c9a84c;
  --c-gold-h:   #e2a72c;
  --c-gold-dim: rgba(201,168,76,.12);
  --c-gold-glow:rgba(201,168,76,.18);
  --c-text:     #e8e0d0;
  --c-text-2:   #9e9a8e;
  --c-text-3:   #5a5650;
  --c-green:    #10b981;
  --c-red:      #ef4444;
  --r:          12px;
  --r-sm:       8px;
  font-family: 'DM Sans', system-ui, sans-serif;
  color: var(--c-text);
  background: var(--c-bg);
  box-sizing: border-box;
}
.gr-wrap *, .gr-wrap *::before, .gr-wrap *::after { box-sizing: border-box; margin:0; padding:0; }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.gr-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 26px; border-radius:var(--r-sm);
  font:700 14px/1 'DM Sans',sans-serif; cursor:pointer;
  text-decoration:none; border:none; white-space:nowrap;
  transition:background .15s,transform .1s,border-color .15s;
}
.gr-btn:active { transform:scale(.97); }
.gr-btn--full  { width:100%; }
.gr-btn--gold  { background:var(--c-gold); color:#000; }
.gr-btn--gold:hover { background:var(--c-gold-h); color:#000; }
.gr-btn--outline {
  background:transparent; color:var(--c-text);
  border:1.5px solid var(--c-border-2);
}
.gr-btn--outline:hover { border-color:var(--c-gold); color:var(--c-gold); }
.gr-btn--ghost {
  background:var(--c-s2); color:var(--c-text-2);
  border:1px solid var(--c-border);
}
.gr-btn--ghost:hover { background:var(--c-s3); color:var(--c-text); }
.gr-btn--annual {
  background:transparent; border:1px dashed rgba(201,168,76,.35);
  color:var(--c-gold); font-weight:600; font-size:13px; margin-top:6px;
}
.gr-btn--annual:hover { background:var(--c-gold-dim); }
.gr-btn--current {
  pointer-events:none; opacity:.5; cursor:default;
}
.gr-btn__spinner { display:inline-flex; }
.gr-spin { width:18px;height:18px;animation:gr-spin .8s linear infinite; }
@keyframes gr-spin { to{transform:rotate(360deg);} }

/* ── Hero ────────────────────────────────────────────────────────────────── */
.gr-hero {
  text-align:center; padding:72px 24px 48px; max-width:760px; margin:0 auto;
}
.gr-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font:600 11px/1 'DM Sans'; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(201,168,76,.6); margin-bottom:28px;
}
.gr-dot {
  width:7px;height:7px;border-radius:50%;
  background:var(--c-gold);box-shadow:0 0 8px var(--c-gold);
}
.gr-hero__title {
  font:800 clamp(40px,6vw,68px)/1.06 'DM Sans'; letter-spacing:-.02em;
  color:var(--c-text); margin-bottom:20px;
}
.gr-hero__gold { color:var(--c-gold); }
.gr-hero__sub {
  font-size:17px; color:var(--c-text-2); line-height:1.7;
  max-width:560px; margin:0 auto 40px;
}

/* Stats strip */
.gr-stats {
  display:flex; align-items:center; justify-content:center; flex-wrap:wrap;
  gap:0; border:1px solid var(--c-border); border-radius:var(--r);
  overflow:hidden; max-width:640px; margin:0 auto;
}
.gr-stat {
  flex:1; min-width:100px; padding:16px 12px; text-align:center;
  background:var(--c-surface);
}
.gr-stat:not(:last-child) { border-right:1px solid var(--c-border); }
.gr-stat__num   { display:block; font:700 24px/1 'DM Sans'; color:var(--c-gold); margin-bottom:4px; }
.gr-stat__label { display:block; font-size:11px; color:var(--c-text-3); text-transform:uppercase; letter-spacing:.06em; }
.gr-stats__div  { display:none; }

/* ── Plans grid ──────────────────────────────────────────────────────────── */
.gr-plans {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px; max-width:860px; margin:0 auto 40px; padding:0 20px;
}

.gr-plan {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-radius:var(--r); padding:28px; position:relative;
  display:flex; flex-direction:column; gap:0;
  transition:border-color .2s;
}
.gr-plan:hover { border-color:var(--c-border-2); }
.gr-plan--featured {
  border-color:var(--c-gold);
  box-shadow:0 0 40px rgba(201,168,76,.1);
}
.gr-plan--selected { border-color:var(--c-gold); }

.gr-plan__badge {
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  background:var(--c-gold); color:#000;
  font:700 10px/1 'DM Sans'; letter-spacing:.06em; text-transform:uppercase;
  padding:5px 16px; border-radius:0 0 var(--r-sm) var(--r-sm);
}

.gr-plan__header {
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:6px; margin-top:8px;
}
.gr-plan__name  { font:700 13px/1 'DM Sans'; color:var(--c-text-2); text-transform:uppercase; letter-spacing:.05em; margin-bottom:4px; }
.gr-plan__tier  { font:700 22px/1 'DM Sans'; color:var(--c-text); }
.gr-plan--featured .gr-plan__tier { color:var(--c-gold); }

.gr-plan__pricing { text-align:right; }
.gr-plan__price   { font:800 38px/1 'DM Sans'; color:var(--c-text); }
.gr-plan--featured .gr-plan__price { color:var(--c-gold); }
.gr-plan__period  { font-size:15px; color:var(--c-text-2); }

.gr-plan__note   { font-size:11px; color:var(--c-text-3); margin:8px 0 14px; line-height:1.5; }
.gr-plan__tagline{ font-size:14px; color:var(--c-text-2); line-height:1.55; margin-bottom:16px; }

.gr-plan__discount {
  background:var(--c-gold-dim); border:1px solid rgba(201,168,76,.2);
  border-radius:var(--r-sm); padding:10px 14px; margin-bottom:18px;
  display:flex; align-items:baseline; gap:6px;
}
.gr-plan__discount-num   { font:700 20px/1 'DM Sans'; color:var(--c-gold); }
.gr-plan__discount-label { font-size:12px; color:var(--c-text-2); }

.gr-plan__features {
  list-style:none; margin-bottom:24px; display:flex; flex-direction:column; gap:6px; flex:1;
}
.gr-plan__features li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:13px; color:var(--c-text-2); line-height:1.45;
}
.gr-feat--off { opacity:.4; }
.gr-feat__icon {
  font-size:13px; flex-shrink:0; margin-top:1px; width:14px; text-align:center;
}
.gr-feat--on .gr-feat__icon { color:var(--c-gold); }

/* ── Registration form ───────────────────────────────────────────────────── */
.gr-form-wrap {
  max-width:440px; margin:0 auto 48px; padding:0 20px;
  animation:gr-fadein .25s ease;
}
@keyframes gr-fadein { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:none} }

.gr-form {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-top:2px solid var(--c-gold); border-radius:var(--r); padding:32px;
}
.gr-form__title { font:700 22px/1 'DM Sans'; color:var(--c-text); margin-bottom:6px; }
.gr-form__sub   { font-size:13px; color:var(--c-text-2); margin-bottom:24px; }

.gr-form__error {
  background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.25);
  border-radius:var(--r-sm); padding:10px 14px;
  font-size:13px; color:#fca5a5; margin-bottom:16px; line-height:1.4;
}

.gr-field { margin-bottom:16px; }
.gr-field label {
  display:block; font:600 11px/1 'DM Sans'; text-transform:uppercase;
  letter-spacing:.06em; color:var(--c-text-3); margin-bottom:7px;
}
.gr-field input[type=text],
.gr-field input[type=email],
.gr-field input[type=password] {
  width:100%; background:var(--c-s2); border:1px solid var(--c-border);
  border-radius:var(--r-sm); padding:12px 14px;
  font:400 14px/1 'DM Sans'; color:var(--c-text);
  outline:none; transition:border-color .15s, box-shadow .15s;
}
.gr-field input:focus {
  border-color:var(--c-gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.12);
}
.gr-field--pwd { position:relative; }
.gr-field--pwd input { padding-right:44px; }
.gr-pwd-toggle {
  position:absolute; right:12px; bottom:12px;
  background:none; border:none; cursor:pointer;
  color:var(--c-text-3); transition:color .15s; line-height:1;
}
.gr-pwd-toggle:hover { color:var(--c-text-2); }
.gr-pwd-toggle svg { width:18px; height:18px; display:block; }

.gr-form__terms { font-size:12px; color:var(--c-text-3); margin:12px 0 16px; line-height:1.5; }
.gr-form__terms a { color:var(--c-text-2); }
.gr-form__login { text-align:center; font-size:13px; color:var(--c-text-3); margin-top:16px; }
.gr-form__login a { color:var(--c-gold); text-decoration:none; }

/* ── Social proof strip ──────────────────────────────────────────────────── */
.gr-proof {
  display:flex; align-items:center; justify-content:center;
  gap:32px; flex-wrap:wrap; padding:24px 20px 56px;
  border-top:1px solid var(--c-border); max-width:860px; margin:0 auto;
}
.gr-proof__item {
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--c-text-3);
}
.gr-proof__icon { font-size:16px; }

/* ── State pages (success / canceled) ───────────────────────────────────── */
.gr-state {
  min-height:60vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:80px 24px;
}
.gr-state__glyph {
  font-size:56px; margin-bottom:24px; opacity:.8;
  animation:gr-pulse 3s ease-in-out infinite;
}
@keyframes gr-pulse { 0%,100%{opacity:.5} 50%{opacity:.9} }
.gr-state__title { font:700 clamp(32px,5vw,52px)/1.1 'DM Sans'; color:var(--c-text); margin-bottom:16px; }
.gr-state__sub   { font-size:17px; color:var(--c-text-2); line-height:1.65; max-width:500px; margin:0 auto 32px; }
.gr-state__actions { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.gr-state__badges  { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin:0 0 32px; }

.gr-badge {
  padding:5px 14px; border-radius:20px; font:700 11px/1 'DM Sans';
  letter-spacing:.05em; text-transform:uppercase;
}
.gr-badge--platinum { background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.3); color:var(--c-gold); }
.gr-badge--info     { background:var(--c-s2); border:1px solid var(--c-border); color:var(--c-text-2); }

/* ── Pricing header (standalone pricing table) ───────────────────────────── */
.gr-pricing-wrap { padding-top:48px; }
.gr-pricing-header { text-align:center; padding:0 24px 40px; }
.gr-pricing-header__title { font:700 36px/1.1 'DM Sans'; color:var(--c-text); margin-bottom:10px; }
.gr-pricing-header__sub   { font-size:16px; color:var(--c-text-2); }

/* ── Loading overlay ─────────────────────────────────────────────────────── */
.gr-loading-overlay {
  position:fixed; inset:0; z-index:9999;
  background:rgba(7,8,15,.85); backdrop-filter:blur(6px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:16px;
}
.gr-loading-overlay__spinner { width:40px; height:40px; }
.gr-loading-overlay__spinner circle {
  stroke:var(--c-gold); stroke-width:3;
  stroke-dasharray:100; stroke-dashoffset:25;
  animation:gr-spin .9s linear infinite;
}
.gr-loading-overlay__text { font:600 14px/1 'DM Sans'; color:var(--c-text-2); }

/* ── Toast ───────────────────────────────────────────────────────────────── */
.gr-toast {
  position:fixed; bottom:20px; right:20px; z-index:9998;
  padding:13px 18px; border-radius:var(--r-sm); font:600 13px/1.4 'DM Sans';
  animation:gr-fadein .2s ease; max-width:340px;
}
.gr-toast--error   { background:rgba(239,68,68,.12); border:1px solid rgba(239,68,68,.3); color:#fca5a5; }
.gr-toast--success { background:rgba(16,185,129,.12); border:1px solid rgba(16,185,129,.3); color:#6ee7b7; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width:600px) {
  .gr-plans { padding:0 14px; }
  .gr-plan  { padding:22px 18px; }
  .gr-hero  { padding:48px 16px 32px; }
  .gr-hero__title { font-size:36px; }
  .gr-form  { padding:24px 18px; }
  .gr-state__actions { flex-direction:column; width:100%; max-width:300px; }
  .gr-stats { gap:0; }
  .gr-stat  { padding:12px 8px; min-width:80px; }
  .gr-stat__num { font-size:20px; }
}
