/* ══════════════════════════════════════════════════════════════════
   Green Edge Technologies — Contact Page
   style.css — Full stylesheet (shared + page-specific)
   ══════════════════════════════════════════════════════════════════ */

/* ── Variables (Dark Mode Default) ─────────────────────────────── */
:root {
  --bg:           #0A0F1C;
  --bg-2:         #121826;
  --bg-3:         #0d1220;
  --surface:      #1A2235;
  --surface-2:    #202c42;
  --border:       rgba(255,255,255,0.07);
  --border-g:     rgba(0,200,83,0.22);
  --text:         #FFFFFF;
  --text-muted:   #B0B8C5;
  --text-faint:   #6F7A8A;
  --green:        #00C853;
  --green-dark:   #006837;
  --green-glow:   rgba(0,200,83,0.30);
  --green-subtle: rgba(0,200,83,0.08);
  --ai-blue:      #00A8FF;
  --tech-purple:  #6C63FF;
  --orange:       #FF6B00;
  --neon:         #39FF14;
  --grad-text:    linear-gradient(120deg,#00C853 0%,#00A8FF 50%,#6C63FF 100%);
  --grad-btn:     linear-gradient(135deg,#00C853,#006837);
  --font-d:       'Manrope', sans-serif;
  --font-b:       'Inter', sans-serif;
  --radius:       14px;
  --radius-lg:    22px;
  --ease:         cubic-bezier(0.16,1,0.3,1);
  --nav-h:        72px;
  --shadow:       0 4px 30px rgba(0,0,0,.5);
}

/* Light mode overrides */
body.light {
  --bg:           #F5F7FA;
  --bg-2:         #EBEEF3;
  --bg-3:         #E0E5EE;
  --surface:      #FFFFFF;
  --surface-2:    #F0F3F8;
  --border:       rgba(0,0,0,0.08);
  --border-g:     rgba(0,200,83,0.30);
  --text:         #0A0F1C;
  --text-muted:   #4A5568;
  --text-faint:   #9AA5B4;
  --green-subtle: rgba(0,200,83,0.10);
  --shadow:       0 4px 30px rgba(0,0,0,.12);
}

/* ── Reset ──────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x:hidden; }
body {
  background: var(--bg); color: var(--text);
  font-family: var(--font-b); font-size: 16px; line-height: 1.7;
   cursor:default;
  transition: background .4s, color .4s;
}
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { border: none; background: none; font-family: inherit; cursor:pointer; }
input, select, textarea { font-family: inherit; font-size: inherit; outline: none; }

/* ── Noise overlay ──────────────────────────────────────────────── */
/* ── Container ──────────────────────────────────────────────────── */
.container { max-max-width: 1240px; width: 100%; margin: 0 auto; padding: 0 28px; }

/* ── Buttons ────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 12px 26px; border-radius: 9px;
  font-family: var(--font-d); font-weight: 700; font-size: .9rem;
  letter-spacing: .01em; transition: all .3s var(--ease);
  position: relative; overflow: hidden; cursor:pointer;
}
.btn::after { content: ''; position: absolute; inset: 0; opacity: 0; background: rgba(255,255,255,.1); border-radius: inherit; transition: opacity .25s; }
.btn:hover::after { opacity: 1; }
.btn-primary { background: var(--grad-btn); color: #fff; box-shadow: 0 4px 22px var(--green-glow); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 40px var(--green-glow), 0 0 0 1px rgba(0,200,83,.35); }
.btn-ghost { border: 1.5px solid var(--green); color: var(--green); background: var(--green-subtle); backdrop-filter: blur(8px); }
.btn-ghost:hover { background: rgba(0,200,83,.16); transform: translateY(-2px); box-shadow: 0 6px 26px var(--green-glow); }
.btn-outline-blue { border: 1.5px solid rgba(0,168,255,.5); color: var(--ai-blue); background: rgba(0,168,255,.07); }
.btn-outline-blue:hover { background: rgba(0,168,255,.15); transform: translateY(-2px); box-shadow: 0 6px 26px rgba(0,168,255,.3); }
.btn-outline-purple { border: 1.5px solid rgba(108,99,255,.5); color: var(--tech-purple); background: rgba(108,99,255,.07); }
.btn-outline-purple:hover { background: rgba(108,99,255,.15); transform: translateY(-2px); box-shadow: 0 6px 26px rgba(108,99,255,.3); }
.btn-lg { padding: 15px 34px; font-size: 1rem; border-radius: 11px; }
.btn-xl { padding: 17px 42px; font-size: 1.05rem; border-radius: 12px; }
.btn-sm { padding: 9px 18px; font-size: .82rem; }
.btn-pulse { animation: btnPulse 3s ease-in-out infinite; }
.btn-pulse:hover { animation: none; }
@keyframes btnPulse { 0%,100% { box-shadow: 0 4px 22px var(--green-glow); } 50% { box-shadow: 0 4px 44px rgba(0,200,83,.6), 0 0 0 7px rgba(0,200,83,.07); } }

/* ── Section helpers ────────────────────────────────────────────── */
.section { padding: 110px 0; position: relative; }
.section-tag {
  display: inline-block; font-family: var(--font-d); font-size: .7rem;
  font-weight: 800; letter-spacing: .16em; text-transform: uppercase;
  color: var(--green); background: var(--green-subtle); border: 1px solid var(--border-g);
  padding: 4px 14px; border-radius: 100px; margin-bottom: 1.25rem;
}
.section-header { text-align: center; max-max-width: 700px; width: 100%; margin: 0 auto 5rem; }
.section-title { font-family: var(--font-d); font-size: clamp(1.875rem, 3.75vw, 3.0469rem); font-weight: 800; line-height: 1.12; letter-spacing: -.03em; margin-bottom: 1.1rem; }
.section-sub { font-size: 1.05rem; color: var(--text-muted); max-max-width: 560px; width: 100%; margin: 0 auto; line-height: 1.75; }
.gradient-text { background: var(--grad-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* ── Scroll reveal ──────────────────────────────────────────────── */
.reveal-up { opacity: 0; transform: translateY(40px); animation: revealUp .85s var(--ease) forwards; animation-delay: var(--d,0s); }
@keyframes revealUp { to { opacity: 1; transform: translateY(0); } }
.reveal-section, .reveal-card { opacity: 0; transform: translateY(36px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal-card { transition-delay: calc(var(--i,0) * .1s); }
.reveal-section.is-visible, .reveal-card.is-visible { opacity: 1; transform: translateY(0); }

/* ══════════════════════════════════════════════════════════════════
   SCROLL PROGRESS RING (Back to Top)
══════════════════════════════════════════════════════════════════ */
.progress-ring-wrap {
  position: fixed; bottom: 2rem; right: 2rem; z-index: 1200;
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--surface); border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; opacity: 0; visibility: hidden; transform: translateY(14px) scale(.9);
  transition: opacity .35s, visibility .35s, transform .35s var(--ease);
  box-shadow: 0 4px 24px rgba(0,0,0,.4);
}
.progress-ring-wrap.visible { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.progress-ring-wrap:hover { transform: translateY(-3px) scale(1.06); }
.progress-ring { position: absolute; inset: 0; transform: rotate(-90deg); }
.progress-ring__track { fill: none; stroke: rgba(255,255,255,.08); stroke-width: 2.5; }
.progress-ring__fill { fill: none; stroke: var(--green); stroke-width: 2.5; stroke-linecap: round; stroke-dasharray: 125.66; stroke-dashoffset: 125.66; transition: stroke-dashoffset .1s linear; }
.progress-ring__icon { position: relative; z-index: 1; color: var(--green); }

/* ══════════════════════════════════════════════════════════════════
   NAVIGATION
══════════════════════════════════════════════════════════════════ */

/* Theme toggle */
/* Mobile sidebar */
/* ══════════════════════════════════════════════════════════════════
   HERO CONTACT
══════════════════════════════════════════════════════════════════ */
.hero-contact {
  min-height: 100svh; display: flex; align-items: center;
  position: relative; overflow: hidden; padding-top: var(--nav-h);
  background: linear-gradient(160deg, var(--bg) 0%, var(--bg-2) 100%);
}
.hero-canvas { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; display: block; }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(110px); pointer-events: none; animation: glowFloat 9s ease-in-out infinite; }
.hero-glow-1 { max-width: 700px; width: 100%; height: 700px; background: radial-gradient(circle,rgba(0,200,83,.1) 0%,transparent 70%); top: -180px; right: -100px; }
.hero-glow-2 { max-width: 500px; width: 100%; height: 500px; background: radial-gradient(circle,rgba(108,99,255,.08) 0%,transparent 70%); bottom: -80px; left: -80px; animation-delay: -3.5s; }
.hero-glow-3 { max-width: 400px; width: 100%; height: 400px; background: radial-gradient(circle,rgba(0,168,255,.06) 0%,transparent 70%); top: 40%; left: 35%; animation-delay: -7s; }
@keyframes glowFloat { 0%,100% { transform: translate(0,0) scale(1); } 33% { transform: translate(28px,-20px) scale(1.05); } 66% { transform: translate(-18px,14px) scale(.97); } }
.hero-contact .container { position: relative; z-index: 1; padding-top: 4rem; padding-bottom: 5rem; }
.hero-contact-content { max-max-width: 760px; width: 100%; }
.hero-breadcrumb { display: inline-flex; align-items: center; gap: 8px; font-size: .78rem; font-weight: 600; color: var(--text-faint); margin-bottom: 1.25rem; }
.breadcrumb-sep { opacity: .4; }
.breadcrumb-active { color: var(--green); }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; font-size: .8rem; font-weight: 600; color: var(--green); background: var(--green-subtle); border: 1px solid var(--border-g); padding: 6px 16px; border-radius: 100px; margin-bottom: 1.5rem; }
.badge-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 10px var(--green); animation: badgePulse 2s ease-in-out infinite; }
@keyframes badgePulse { 0%,100% { box-shadow: 0 0 4px var(--green); } 50% { box-shadow: 0 0 18px var(--green), 0 0 32px var(--green-glow); } }
.hero-headline { font-family: var(--font-d); font-size: clamp(2.625rem, 6.0938vw, 4.6875rem); font-weight: 800; line-height: 1.07; letter-spacing: -.035em; margin-bottom: 1.5rem; }
.hero-sub { font-size: clamp(0.9375rem, 1.875vw, 1.125rem); color: var(--text-muted); max-max-width: 560px; width: 100%; line-height: 1.75; margin-bottom: 2.5rem; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 3rem; }
.hero-trust-bar { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.hero-trust-item { display: flex; align-items: center; gap: 8px; font-size: .82rem; font-weight: 600; color: var(--text-muted); font-family: var(--font-d); }
.hero-trust-item svg { color: var(--green); flex-shrink: 0; }
.hero-trust-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--text-faint); }
.hero-scroll-cue { position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--text-faint); }
.scroll-line { width: 1px; height: 44px; background: linear-gradient(to bottom,var(--green),transparent); animation: scrollPulse 1.7s ease-in-out infinite; }
@keyframes scrollPulse { 0% { transform: scaleY(1); transform-origin: top; } 50% { transform: scaleY(0); transform-origin: top; } 50.1% { transform-origin: bottom; } 100% { transform: scaleY(1); transform-origin: bottom; } }

/* ══════════════════════════════════════════════════════════════════
   CONTACT OPTIONS GRID
══════════════════════════════════════════════════════════════════ */
.contact-options-section { background: var(--bg-2); }
.contact-options-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.75rem; }
.contact-option-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 2.25rem 2rem; display: flex; flex-direction: column; gap: .9rem;
  position: relative; overflow: hidden; cursor:pointer;
  transition: border-color .3s, transform .4s var(--ease), box-shadow .4s;
}
.contact-option-card::before { content: ''; position: absolute; inset: 0; border-radius: inherit; opacity: 0; background: radial-gradient(circle at 50% 0%, var(--glow,rgba(0,200,83,.15)) 0%, transparent 70%); transition: opacity .4s; pointer-events: none; }
.contact-option-card:hover { transform: translateY(-8px); box-shadow: 0 28px 70px rgba(0,0,0,.4), 0 0 0 1px rgba(0,200,83,.2); border-color: var(--border-g); }
.contact-option-card:hover::before { opacity: 1; }
.option-card-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: .25rem; }
.option-icon-wrap { width: 58px; height: 58px; border-radius: 15px; display: flex; align-items: center; justify-content: center; border: 1px solid; flex-shrink: 0; transition: transform .3s, box-shadow .3s; }
.contact-option-card:hover .option-icon-wrap { transform: scale(1.08) rotate(4deg); }
.option-card-badge { font-family: var(--font-d); font-size: .68rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; padding: 4px 11px; border-radius: 100px; border: 1px solid; }
.contact-option-card h3 { font-family: var(--font-d); font-size: 1.3rem; font-weight: 800; letter-spacing: -.015em; }
.contact-option-card p { font-size: .9rem; color: var(--text-muted); line-height: 1.7; }
.option-features { display: flex; flex-direction: column; gap: 8px; margin: .25rem 0; }
.option-features li { display: flex; align-items: center; gap: 8px; font-size: .84rem; color: var(--text-muted); font-family: var(--font-d); font-weight: 500; }
.option-btn { margin-top: auto; align-self: flex-start; }

/* ══════════════════════════════════════════════════════════════════
   CONTACT FORM SECTION
══════════════════════════════════════════════════════════════════ */
.contact-form-section { background: var(--bg); position: relative; overflow: hidden; }
.form-bg-glow-1 { position: absolute; top: -100px; right: -100px; max-width: 600px; width: 100%; height: 600px; background: radial-gradient(circle,rgba(0,200,83,.06) 0%,transparent 70%); pointer-events: none; }
.form-bg-glow-2 { position: absolute; bottom: -100px; left: -100px; max-width: 500px; width: 100%; height: 500px; background: radial-gradient(circle,rgba(108,99,255,.05) 0%,transparent 70%); pointer-events: none; }
.contact-form-wrapper { display: grid; grid-template-columns: 1fr 1.5fr; gap: 5rem; align-items: start; }
.form-left {}
.form-left .section-title { text-align: left; font-size: clamp(1.6875rem, 3.2812vw, 2.625rem); }
.form-trust-items { display: flex; flex-direction: column; gap: 1.1rem; margin-top: 2.5rem; }
.form-trust-item { display: flex; align-items: flex-start; gap: 1rem; }
.form-trust-icon { font-size: 1.4rem; width: 42px; height: 42px; border-radius: 11px; background: var(--surface); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.form-trust-item > div { display: flex; flex-direction: column; gap: 2px; }
.form-trust-item strong { font-family: var(--font-d); font-size: .9rem; font-weight: 700; color: var(--text); }
.form-trust-item span { font-size: .82rem; color: var(--text-muted); }

/* Form */
.form-right { position: relative; }
.contact-form { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 2.75rem; display: flex; flex-direction: column; gap: 1.25rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group--full { grid-column: span 2; }
label { font-family: var(--font-d); font-size: .8rem; font-weight: 700; letter-spacing: .04em; color: var(--text-muted); text-transform: uppercase; }
.required { color: var(--green); }
.input-wrap { position: relative; }
.input-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--text-faint); pointer-events: none; transition: color .2s; }
.input-icon--textarea { top: 16px; transform: none; }
input, select, textarea {
  width: 100%; background: var(--bg-2); border: 1.5px solid var(--border);
  border-radius: 10px; padding: 12px 14px 12px 42px; color: var(--text); font-size: .9rem;
  transition: border-color .25s, box-shadow .25s, background .25s;
  -webkit-appearance: none; appearance: none;
}
input::placeholder, textarea::placeholder { color: var(--text-faint); }
input:focus, select:focus, textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(0,200,83,.12); background: var(--bg); }
.input-wrap--select select { padding-right: 38px; cursor: pointer; }
.select-arrow { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); color: var(--text-faint); pointer-events: none; }
.input-wrap--textarea textarea { padding: 12px 14px 12px 42px; resize: vertical; min-height: 130px; line-height: 1.7; }
.char-count { font-size: .74rem; color: var(--text-faint); text-align: right; margin-top: 4px; font-family: var(--font-d); }
.field-error { font-size: .76rem; color: #FF3D00; font-family: var(--font-d); font-weight: 600; display: none; }
.form-group.has-error input,
.form-group.has-error select,
.form-group.has-error textarea { border-color: #FF3D00; box-shadow: 0 0 0 3px rgba(255,61,0,.1); }
.form-group.has-error .field-error { display: block; }
.form-group.is-valid input,
.form-group.is-valid select,
.form-group.is-valid textarea { border-color: var(--green); }

/* Checkbox */
.form-checkbox { margin-top: .25rem; }
.checkbox-label { display: flex; align-items: center; gap: 12px; cursor: pointer; font-size: .85rem; color: var(--text-muted); }
.checkbox-label input[type="checkbox"] { display: none; }
.checkbox-custom { width: 18px; height: 18px; border-radius: 5px; border: 1.5px solid var(--border); background: var(--bg-2); flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: border-color .2s, background .2s; }
.checkbox-label input:checked + .checkbox-custom { background: var(--green); border-color: var(--green); }
.checkbox-label input:checked + .checkbox-custom::after { content: '✓'; font-size: .7rem; color: #000; font-weight: 900; }

/* Submit */
.form-submit { width: 100%; justify-content: center; margin-top: .5rem; padding: 15px; font-size: 1rem; border-radius: 11px; }
.submit-loader { display: none; align-items: center; gap: 8px; }
.form-submit.loading .submit-text { display: none; }
.form-submit.loading .submit-loader { display: flex; }
.form-submit.loading { pointer-events: none; opacity: .8; }
.spinner { animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Success */
.form-success { display: none; flex-direction: column; align-items: center; justify-content: center; gap: 1.25rem; background: var(--surface); border: 1px solid var(--border-g); border-radius: var(--radius-lg); padding: 3.5rem 2.5rem; text-align: center; }
.form-success.show { display: flex; animation: fadeScaleIn .5s var(--ease); }
@keyframes fadeScaleIn { from { opacity: 0; transform: scale(.94); } to { opacity: 1; transform: scale(1); } }
.success-icon { animation: successPop .5s var(--ease); }
@keyframes successPop { from { transform: scale(0) rotate(-20deg); } to { transform: scale(1) rotate(0deg); } }
.form-success h3 { font-family: var(--font-d); font-size: 1.6rem; font-weight: 800; color: var(--green); }
.form-success p { font-size: .95rem; color: var(--text-muted); max-max-width: 380px; width: 100%; line-height: 1.75; }
.success-ref { font-family: var(--font-d); font-size: .8rem; color: var(--text-faint); background: var(--bg-2); border: 1px solid var(--border); padding: 6px 16px; border-radius: 100px; }
.success-ref span { color: var(--green); font-weight: 700; }

/* ══════════════════════════════════════════════════════════════════
   CONTACT INFO SECTION
══════════════════════════════════════════════════════════════════ */
.contact-info-section { background: var(--bg-2); }
.contact-info-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.info-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.75rem; display: flex; align-items: flex-start; gap: 1.1rem;
  transition: border-color .3s, transform .4s var(--ease), box-shadow .4s; cursor:pointer;
}
.info-card:hover { border-color: var(--border-g); transform: translateY(-5px); box-shadow: 0 18px 50px rgba(0,0,0,.35), 0 0 24px var(--green-glow); }
.info-card--hours, .info-card--social { grid-column: span 1; flex-direction: column; }
.info-card-icon { width: 50px; height: 50px; border-radius: 13px; display: flex; align-items: center; justify-content: center; border: 1px solid; flex-shrink: 0; }
.info-card-body { display: flex; flex-direction: column; gap: 6px; }
.info-card h4 { font-family: var(--font-d); font-size: .95rem; font-weight: 800; margin-bottom: 2px; }
.info-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }
.info-card a { color: var(--text-muted); transition: color .2s; }
.info-card a:hover { color: var(--green); }
.hours-grid { display: flex; flex-direction: column; gap: 7px; margin-top: 4px; }
.hours-row { display: flex; justify-content: space-between; align-items: center; }
.hours-day { font-size: .82rem; color: var(--text-muted); font-family: var(--font-d); }
.hours-time { font-family: var(--font-d); font-size: .82rem; font-weight: 700; color: var(--text); }
.hours-time.active-now { color: var(--green); }
.hours-time.closed { color: var(--text-faint); }
.social-links-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.social-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 13px; border-radius: 100px; background: var(--bg-2); border: 1px solid var(--border); font-size: .78rem; font-family: var(--font-d); font-weight: 600; color: var(--text-muted); transition: all .2s; cursor:pointer; }
.social-chip:hover { background: var(--green-subtle); color: var(--green); border-color: var(--border-g); }

/* ══════════════════════════════════════════════════════════════════
   MAP SECTION
══════════════════════════════════════════════════════════════════ */
.map-section { background: var(--bg); }
.map-container { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border-g); height: 480px; box-shadow: 0 0 60px rgba(0,200,83,.06); }
.map-iframe { display: block; width: 100%; height: 100%; filter: grayscale(30%) invert(5%); border-radius: inherit; }
body.light .map-iframe { filter: none; }
.map-overlay-label {
  position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
  background: rgba(10,15,28,.9); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border-g); border-radius: var(--radius);
  padding: 1rem 1.5rem; display: flex; align-items: center; gap: 1.25rem;
  white-space: nowrap; z-index: 2; box-shadow: 0 8px 32px rgba(0,0,0,.4);
}
body.light .map-overlay-label { background: rgba(255,255,255,.92); }
.map-pin-pulse { position: relative; width: 24px; height: 24px; flex-shrink: 0; }
.map-pin-dot { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 10px; height: 10px; border-radius: 50%; background: var(--green); box-shadow: 0 0 10px var(--green); }
.map-pin-ring { position: absolute; inset: 0; border-radius: 50%; border: 2px solid var(--green); opacity: .5; animation: pinRing 2s ease-out infinite; }
@keyframes pinRing { 0% { transform: scale(0.5); opacity: .8; } 100% { transform: scale(1.4); opacity: 0; } }
.map-label-text { display: flex; flex-direction: column; gap: 2px; }
.map-label-text strong { font-family: var(--font-d); font-size: .88rem; font-weight: 800; color: var(--text); }
.map-label-text span { font-size: .78rem; color: var(--text-muted); }

/* ══════════════════════════════════════════════════════════════════
   FAQ
══════════════════════════════════════════════════════════════════ */
.faq-section { background: var(--bg-2); }
.faq-inner { display: grid; grid-template-columns: 1fr 1.6fr; gap: 6rem; align-items: start; }
.faq-stats { display: flex; gap: 2rem; margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.faq-stat { display: flex; flex-direction: column; gap: 3px; }
.faq-stat strong { font-family: var(--font-d); font-size: 1.8rem; font-weight: 800; background: var(--grad-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.faq-stat span { font-size: .78rem; color: var(--text-muted); letter-spacing: .03em; }
.faq-list { display: flex; flex-direction: column; gap: .75rem; }
.faq-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; transition: border-color .2s; }
.faq-item:hover, .faq-item[data-open="true"] { border-color: var(--border-g); }
.faq-question { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.2rem 1.4rem; text-align: left; cursor:pointer; font-family: var(--font-d); font-size: .94rem; font-weight: 700; color: var(--text); transition: color .2s; }
.faq-question:hover { color: var(--green); }
.faq-icon { width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0; background: var(--green-subtle); border: 1px solid var(--border-g); display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--green); transition: transform .35s var(--ease), background .2s; }
.faq-item[data-open="true"] .faq-icon { transform: rotate(45deg); background: var(--green); color: #000; border-color: var(--green); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height .45s var(--ease); }
.faq-item[data-open="true"] .faq-answer { max-height: 300px; }
.faq-answer-inner { padding: 0 1.4rem 1.4rem; }
.faq-answer-inner p { font-size: .9rem; color: var(--text-muted); line-height: 1.75; }

/* ══════════════════════════════════════════════════════════════════
   CTA STRIP
══════════════════════════════════════════════════════════════════ */
.cta-strip-section { background: var(--bg); padding: 100px 0; position: relative; overflow: hidden; }
.cta-strip-glow-1 { position: absolute; top: -80px; left: 50%; transform: translateX(-50%); max-width: 900px; width: 100%; height: 400px; background: radial-gradient(ellipse at top,rgba(0,200,83,.07) 0%,transparent 70%); pointer-events: none; }
.cta-strip-glow-2 { position: absolute; bottom: -80px; right: -100px; max-width: 500px; width: 100%; height: 500px; background: radial-gradient(circle,rgba(108,99,255,.06) 0%,transparent 70%); pointer-events: none; }
.cta-strip-inner { display: grid; grid-template-columns: 1fr auto; gap: 4rem; align-items: center; position: relative; z-index: 1; }
.cta-strip-right { display: flex; flex-direction: column; align-items: flex-end; gap: 1.25rem; }
.cta-strip-btn { white-space: nowrap; }
.cta-strip-micro { display: flex; flex-direction: column; align-items: flex-end; gap: 5px; }
.cta-strip-micro span { font-family: var(--font-d); font-size: .78rem; font-weight: 600; color: var(--green); display: flex; align-items: center; gap: 5px; }

/* ══════════════════════════════════════════════════════════════════
   FLOATING AI CHAT
══════════════════════════════════════════════════════════════════ */
.ai-chat-fab {
  position: fixed; bottom: 6rem; right: 2rem; z-index: 1100;
  display: flex; align-items: center; gap: 8px;
  background: var(--grad-btn); border-radius: 100px;
  padding: 11px 20px 11px 14px; cursor: pointer;
  box-shadow: 0 8px 32px var(--green-glow), 0 0 0 1px rgba(0,200,83,.3);
  transition: transform .3s var(--ease), box-shadow .3s;
  animation: fabFloat 4s ease-in-out infinite;
}
.ai-chat-fab:hover { transform: translateY(-4px) scale(1.04); box-shadow: 0 16px 48px var(--green-glow), 0 0 0 2px rgba(0,200,83,.4); }
@keyframes fabFloat { 0%,100% { box-shadow: 0 8px 32px var(--green-glow), 0 0 0 1px rgba(0,200,83,.3); } 50% { box-shadow: 0 8px 48px rgba(0,200,83,.5), 0 0 0 4px rgba(0,200,83,.1); } }
.chat-fab-ring { position: absolute; inset: -4px; border-radius: 100px; border: 1.5px solid rgba(0,200,83,.3); animation: chatRing 2.5s ease-in-out infinite; }
@keyframes chatRing { 0%,100% { opacity: .4; transform: scale(1); } 50% { opacity: .8; transform: scale(1.04); } }
.chat-fab-label { font-family: var(--font-d); font-size: .82rem; font-weight: 800; color: #fff; letter-spacing: .03em; }
.chat-fab-bubble {
  position: absolute; bottom: calc(100% + 16px); right: 0;
  max-width: 300px; width: 100%; background: var(--surface);
  border: 1px solid var(--border-g); border-radius: var(--radius-lg);
  padding: 1.25rem; box-shadow: 0 16px 50px rgba(0,0,0,.5);
  display: none; flex-direction: column; gap: .75rem;
  animation: bubblePop .3s var(--ease);
}
.chat-fab-bubble.open { display: flex; }
@keyframes bubblePop { from { opacity: 0; transform: translateY(10px) scale(.96); } to { opacity: 1; transform: translateY(0) scale(1); } }
.chat-bubble-header { display: flex; align-items: center; gap: 8px; padding-bottom: .75rem; border-bottom: 1px solid var(--border); }
.chat-bubble-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); animation: badgePulse 2s infinite; }
.chat-bubble-header strong { font-family: var(--font-d); font-size: .88rem; font-weight: 800; flex: 1; }
.chat-bubble-close { width: 22px; height: 22px; border-radius: 50%; background: var(--surface-2); display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--text-muted); cursor: pointer; transition: background .2s; }
.chat-bubble-close:hover { background: rgba(255,61,0,.2); color: #ff3d00; }
.chat-fab-bubble p { font-size: .88rem; color: var(--text-muted); line-height: 1.65; }
.chat-bubble-options { display: flex; flex-direction: column; gap: 6px; }
.chat-bubble-options button { background: var(--bg-2); border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; font-family: var(--font-d); font-size: .8rem; font-weight: 600; color: var(--text-muted); text-align: left; transition: all .2s; cursor: pointer; }
.chat-bubble-options button:hover { background: var(--green-subtle); color: var(--green); border-color: var(--border-g); }

/* ══════════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════════ */
.footer { background: var(--bg-3); border-top: 1px solid var(--border); }
.footer-top-bar { background: rgba(0,200,83,.05); border-bottom: 1px solid var(--border-g); padding: 13px 0; }
.footer-top-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: .8rem; color: var(--text-muted); font-family: var(--font-d); font-weight: 600; }
.footer-socials { display: flex; gap: 8px; }
.social-link { width: 34px; height: 34px; border-radius: 7px; background: var(--surface); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--text-muted); transition: all .2s; cursor:pointer; }
.social-link:hover { background: var(--green-subtle); color: var(--green); border-color: var(--border-g); box-shadow: 0 0 14px var(--green-glow); }
.footer-main { padding: 60px 0 44px; }
.footer-grid { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr 1fr; gap: 3rem; }
.footer-brand p { font-size: .875rem; color: var(--text-muted); line-height: 1.75; margin-bottom: 2rem; max-max-width: 280px; width: 100%; }
.newsletter-wrap { margin-top: 1.5rem; }
.newsletter-label { font-family: var(--font-d); font-size: .78rem; font-weight: 700; letter-spacing: .05em; color: var(--text-muted); margin-bottom: .65rem; }
.newsletter-form { display: flex; gap: 8px; }
.newsletter-form input { flex: 1; background: var(--surface); border: 1.5px solid var(--border); border-radius: 8px; padding: 10px 13px; color: var(--text); font-size: .85rem; transition: border-color .2s; }
.newsletter-form input:focus { border-color: var(--green); box-shadow: 0 0 0 2px var(--green-subtle); }
.footer-col h5 { font-family: var(--font-d); font-size: .73rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1.25rem; }
.footer-col ul { display: flex; flex-direction: column; gap: 9px; }
.footer-col a { font-size: .875rem; color: var(--text-muted); transition: color .2s; cursor:pointer; }
.footer-col a:hover { color: var(--green); }
.footer-bottom { border-top: 1px solid var(--border); padding: 22px 0; }
.footer-bottom-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; font-size: .79rem; color: var(--text-faint); }
.footer-legal { display: flex; gap: 1.5rem; }
.footer-legal a { color: var(--text-faint); transition: color .2s; cursor:pointer; }
.footer-legal a:hover { color: var(--green); }

/* ══════════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .footer-brand { grid-column: span 2; }
}
@media (max-width: 960px) {
  .contact-options-grid { grid-template-columns: 1fr; max-max-width: 520px; width: 100%; margin: 0 auto; }
  .contact-form-wrapper { grid-template-columns: 1fr; gap: 3rem; }
  .faq-inner { grid-template-columns: 1fr; gap: 3rem; }
  .cta-strip-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .cta-strip-right { align-items: flex-start; }
  .cta-strip-micro { align-items: flex-start; }
}
@media (max-width: 768px) {
  :root { --nav-h: 64px; }
  body { cursor:default; }
  .section { padding: 75px 0; }
  .hero-headline { font-size: clamp(2.25rem, 7.9688vw, 3.2812rem); }
  .hero-actions { flex-direction: column; align-items: flex-start; }
  .hero-trust-bar { gap: 1rem; }
  .contact-info-grid { grid-template-columns: 1fr 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .form-group--full { grid-column: span 1; }
  .contact-form { padding: 1.75rem; }
  .map-container { height: 380px; }
  .map-overlay-label { flex-direction: column; align-items: flex-start; gap: .75rem; white-space: normal; max-width: calc(100% - 3rem); bottom: 1rem; left: 1.5rem; transform: none; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-brand { grid-column: span 1; }
  .footer-bottom-inner { flex-direction: column; text-align: center; }
  .footer-legal { justify-content: center; flex-wrap: wrap; }
  .footer-top-inner { flex-direction: column; text-align: center; }
  .progress-ring-wrap { bottom: 6.5rem; }
}
@media (max-width: 540px) {
  .contact-options-grid { max-width: 100%; }
  .contact-info-grid { grid-template-columns: 1fr; }
  .faq-stats { gap: 1.5rem; }
  .ai-chat-fab { padding: 11px 14px; }
  .chat-fab-label { display: none; }
  .ai-chat-fab { border-radius: 50%; width: 52px; height: 52px; justify-content: center; bottom: 5.5rem; right: 1.25rem; }
  .chat-fab-bubble { right: -1rem; max-width: 280px; width: 100%; }
}

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

/* Logo Fix */

/* Logo sizing is controlled via Appearance → Customize → Logo & Branding.
   CSS custom properties are set by greenedge_logo_inline_css() in functions.php
   and consumed by components.css. Do not add hardcoded overrides here. */

/* ══════════════════════════════════════════════════════
   FORM TABS — Contact / Course Registration
   ══════════════════════════════════════════════════════ */

/* ── Tab bar ── */
.form-right .form-tabs {
  display: flex !important;
  gap: .4rem;
  margin-bottom: 1.75rem;
  background: rgba(255,255,255,.04);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: .35rem;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.form-right .form-tab {
  flex: 1;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 1rem;
  border-radius: 10px;
  border: none !important;
  background: transparent !important;
  color: var(--text-muted);
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer !important;
  transition: background .22s ease, color .22s ease, box-shadow .22s ease;
  white-space: nowrap;
  pointer-events: auto !important;
  position: relative;
  overflow: visible;
}

.form-right .form-tab::after { display: none !important; }

.form-right .form-tab svg {
  flex-shrink: 0;
  transition: stroke .22s;
}

.form-right .form-tab:hover {
  background: rgba(255,255,255,.06) !important;
  color: var(--text) !important;
  transform: none !important;
}

.form-right .form-tab.active {
  background: linear-gradient(135deg, rgba(0,200,83,.18), rgba(0,168,255,.10)) !important;
  color: var(--green, #00C853) !important;
  box-shadow: 0 0 0 1.5px rgba(0,200,83,.35) !important;
  transform: none !important;
}

.form-right .form-tab.active svg {
  stroke: var(--green, #00C853) !important;
}

/* ── Tab panels ── */
.form-tab-panel {
  display: none;
}

.form-tab-panel.active {
  display: block;
  animation: tabFadeIn .3s ease forwards;
}

@keyframes tabFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Registration: Mode of Lecture ── */
.reg-mode-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  margin-top: .4rem;
}

.reg-mode-option {
  display: block;
  cursor: pointer;
}

.reg-mode-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

.reg-mode-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  padding: 1.1rem .75rem;
  border-radius: 12px;
  border: 1.5px solid var(--border);
  background: rgba(255,255,255,.02);
  color: var(--text-muted);
  font-size: .84rem;
  text-align: center;
  transition: border-color .2s, background .2s, color .2s, box-shadow .2s;
  cursor: pointer;
}

.reg-mode-card svg { transition: stroke .2s; }

.reg-mode-card strong {
  display: block;
  font-size: .92rem;
  color: var(--text);
}

.reg-mode-option input[type="radio"]:checked ~ .reg-mode-card,
.reg-mode-option input[type="radio"]:checked + .reg-mode-card {
  border-color: var(--green, #00C853) !important;
  background: rgba(0,200,83,.07) !important;
  box-shadow: 0 0 0 1px rgba(0,200,83,.25);
}

.reg-mode-option input[type="radio"]:checked ~ .reg-mode-card svg,
.reg-mode-option input[type="radio"]:checked + .reg-mode-card svg {
  stroke: var(--green, #00C853) !important;
}

.reg-mode-option input[type="radio"]:checked ~ .reg-mode-card strong,
.reg-mode-option input[type="radio"]:checked + .reg-mode-card strong {
  color: var(--green, #00C853) !important;
}

.reg-mode-option:hover .reg-mode-card {
  border-color: rgba(0,200,83,.45);
}

.reg-mode-option input[type="radio"]:focus-visible ~ .reg-mode-card,
.reg-mode-option input[type="radio"]:focus-visible + .reg-mode-card {
  outline: 2px solid var(--green, #00C853);
  outline-offset: 2px;
}

/* ── Other course reveal ── */
.reg-other-wrap {
  margin-top: .65rem;
}

/* ── Responsive ── */
@media (max-width: 520px) {
  .form-right .form-tabs {
    flex-direction: column;
  }
  .form-right .form-tab {
    justify-content: center;
    width: 100%;
  }
  .reg-mode-group {
    grid-template-columns: 1fr;
  }
}


/* ══════════════════════════════════════════════════════════════════
   CONTACT FORM SECTION — Reference layout
   Tabs sit above the form card, visually separated.
   Full dark-mode support via body:not(.light).
   Keeps all existing AJAX handlers intact — visual override only.
══════════════════════════════════════════════════════════════════ */

/* ── Section wrapper ── */
#contact-form.contact-form-section {
  background: #f2f5f9 !important;
  padding-top: 56px !important;
  padding-bottom: 88px !important;
  overflow: visible !important;
}
#contact-form .form-bg-glow-1,
#contact-form .form-bg-glow-2 { display: none !important; }

/* ── Hide left column, stretch right to full width ── */
#contact-form .contact-form-wrapper {
  display: block !important;
  max-width: 900px !important;
  width: 100% !important;
  margin: 0 auto !important;
}
#contact-form .form-left  { display: none !important; }
#contact-form .form-right {
  width: 100% !important;
  max-width: none !important;
  opacity: 1 !important;
  transform: none !important;
}

/* ══════════════════════════════════════════════════
   TAB BAR — floats above the card, separated
══════════════════════════════════════════════════ */
#contact-form > .container > .form-tabs,
#contact-form .ge-form-tabs-modern {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0 !important;
  max-width: 900px !important;
  width: 100% !important;
  margin: 0 auto 0 auto !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
  border-radius: 18px 18px 0 0 !important;
}

#contact-form > .container > .form-tabs .form-tab,
#contact-form .ge-form-tabs-modern .form-tab {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  min-height: 96px !important;
  padding: 24px 28px !important;
  border: none !important;
  border-radius: 0 !important;
  background: #ffffff !important;
  color: #05af58 !important;
  font-family: var(--font-d, 'Manrope', sans-serif) !important;
  font-size: clamp(1.1719rem, 2.0625vw, 1.6406rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.025em !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transform: none !important;
  transition: background 0.25s ease, color 0.25s ease !important;
  position: relative !important;
  overflow: hidden !important;
  /* Right tab border separator */
}

/* Divider between the two tabs */
#contact-form > .container > .form-tabs .form-tab:first-child,
#contact-form .ge-form-tabs-modern .form-tab:first-child {
  border-right: 1.5px solid rgba(0,200,83,.25) !important;
}

#contact-form > .container > .form-tabs .form-tab svg,
#contact-form .ge-form-tabs-modern .form-tab svg {
  width: 28px !important;
  height: 28px !important;
  flex-shrink: 0 !important;
  stroke: currentColor !important;
}

/* Active tab */
#contact-form > .container > .form-tabs .form-tab.active,
#contact-form > .container > .form-tabs .form-tab[aria-selected="true"],
#contact-form .ge-form-tabs-modern .form-tab.active,
#contact-form .ge-form-tabs-modern .form-tab[aria-selected="true"] {
  background: #05af58 !important;
  color: #ffffff !important;
}

/* Hover on inactive */
#contact-form > .container > .form-tabs .form-tab:not(.active):hover,
#contact-form .ge-form-tabs-modern .form-tab:not(.active):hover {
  background: #f0faf5 !important;
  color: #039e4e !important;
  transform: none !important;
}

/* Active stays on hover */
#contact-form > .container > .form-tabs .form-tab.active:hover,
#contact-form .ge-form-tabs-modern .form-tab.active:hover {
  background: #05af58 !important;
  color: #ffffff !important;
  transform: none !important;
}

/* Tab panels — hide unless active */
#contact-form .form-tab-panel { display: none !important; }
#contact-form .form-tab-panel.active {
  display: block !important;
  animation: tabFadeIn .3s ease forwards !important;
}

/* ══════════════════════════════════════════════════
   FORM CARD — white rounded card below the tabs
══════════════════════════════════════════════════ */
#contact-form .contact-form.ge-reference-form,
#contact-form .form-success {
  background: #ffffff !important;
  border: 1px solid #e1e8f0 !important;
  border-radius: 0 0 24px 24px !important;
  box-shadow: 0 24px 80px rgba(15,23,42,.09) !important;
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 5vw, 4rem) !important;
  color: #111827 !important;
  gap: 1.75rem !important;
}

/* ── Form rows ── */
#contact-form .form-row {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  column-gap: clamp(1.2rem, 3vw, 2rem) !important;
  row-gap: 1.6rem !important;
}
#contact-form .form-group { gap: 9px !important; }
#contact-form .form-group--full { grid-column: 1 / -1 !important; }

/* ── Labels ── */
#contact-form label,
#contact-form .form-group > label {
  color: #596274 !important;
  font-family: var(--font-d, 'Manrope', sans-serif) !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
}
#contact-form .required { color: #00c853 !important; }

/* ── Input wrapper ── */
#contact-form .input-wrap {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}
#contact-form .input-wrap--textarea { align-items: stretch !important; }

/* ── Inputs, selects, textareas ── */
#contact-form input,
#contact-form select,
#contact-form textarea {
  width: 100% !important;
  background: linear-gradient(180deg, #f4f7fb 0%, #edf1f7 100%) !important;
  border: 1.5px solid #d9e2ec !important;
  border-radius: 12px !important;
  color: #1f2937 !important;
  font-family: var(--font-d, 'Manrope', sans-serif) !important;
  font-size: clamp(0.8906rem, 1.3125vw, 1.0781rem) !important;
  font-weight: 600 !important;
  min-height: 64px !important;
  padding: 0 44px 0 60px !important;
  box-shadow: inset 0 1px 3px rgba(15,23,42,.04) !important;
  transition: border-color .2s, box-shadow .2s, background .2s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
#contact-form input::placeholder,
#contact-form textarea::placeholder {
  color: #adb8c6 !important;
  font-weight: 500 !important;
  opacity: 1 !important;
}
#contact-form select:invalid,
#contact-form select option[disabled] { color: #7a8899 !important; }
#contact-form select option {
  background: #ffffff;
  color: #1f2937;
}
#contact-form input:focus,
#contact-form select:focus,
#contact-form textarea:focus {
  outline: none !important;
  background: #ffffff !important;
  border-color: #00c853 !important;
  box-shadow: 0 0 0 4px rgba(0,200,83,.13) !important;
}

/* ── Select arrow & icon ── */
#contact-form .input-icon {
  position: absolute !important;
  left: 20px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 20px !important;
  height: 20px !important;
  color: #b3bfcc !important;
  pointer-events: none !important;
  z-index: 2 !important;
}
#contact-form .input-wrap--textarea .input-icon {
  top: 22px !important;
  transform: none !important;
}
#contact-form .select-arrow {
  position: absolute !important;
  right: 18px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 16px !important;
  height: 16px !important;
  color: #a5b1bf !important;
  pointer-events: none !important;
  z-index: 2 !important;
}
#contact-form .input-wrap--select select { padding-right: 44px !important; }

/* ── Textarea ── */
#contact-form .input-wrap--textarea textarea {
  min-height: 200px !important;
  padding: 20px 24px 18px 60px !important;
  resize: vertical !important;
  line-height: 1.6 !important;
}

/* ── Char count ── */
#contact-form .char-count {
  color: #a5b1bf !important;
  font-family: var(--font-d, inherit) !important;
  font-size: .8rem !important;
  font-weight: 700 !important;
  text-align: right !important;
  margin-top: 6px !important;
}

/* ── Checkbox ── */
#contact-form .form-checkbox { margin-top: .1rem !important; }
#contact-form .checkbox-label {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  cursor: pointer !important;
  font-family: var(--font-d, inherit) !important;
  font-size: .78rem !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: #596274 !important;
}
#contact-form .checkbox-custom {
  flex-shrink: 0 !important;
  width: 26px !important;
  height: 26px !important;
  border-radius: 7px !important;
  border: 1.5px solid #d3dce6 !important;
  background: #f3f6fa !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: inset 0 1px 2px rgba(15,23,42,.04) !important;
  transition: background .2s, border-color .2s !important;
}
#contact-form .checkbox-label input:checked + .checkbox-custom {
  background: #00c853 !important;
  border-color: #00c853 !important;
}
#contact-form .checkbox-label input:checked + .checkbox-custom::after {
  content: '✓' !important;
  color: #ffffff !important;
  font-size: .85rem !important;
  font-weight: 900 !important;
}

/* ── Submit button ── */
#contact-form .form-submit {
  width: 100% !important;
  justify-content: center !important;
  min-height: 72px !important;
  border-radius: 14px !important;
  background: linear-gradient(90deg, #00d663 0%, #008b42 100%) !important;
  border: 0 !important;
  color: #ffffff !important;
  font-family: var(--font-d, inherit) !important;
  font-size: clamp(0.9375rem, 1.5vw, 1.2188rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
  box-shadow: 0 14px 32px rgba(0,200,83,.28) !important;
  margin-top: .25rem !important;
  transition: transform .2s ease, box-shadow .2s ease !important;
}
#contact-form .form-submit:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 20px 44px rgba(0,200,83,.36) !important;
}

/* ── Validation states ── */
#contact-form .field-error {
  color: #ef4444 !important;
  font-size: .76rem !important;
  font-weight: 700 !important;
}
#contact-form .form-group.has-error input,
#contact-form .form-group.has-error select,
#contact-form .form-group.has-error textarea {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.10) !important;
}
#contact-form .form-group.is-valid input,
#contact-form .form-group.is-valid select,
#contact-form .form-group.is-valid textarea {
  border-color: #00c853 !important;
}

/* ── Mode of lecture (registration tab) ── */
#contact-form .reg-mode-group {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: .9rem !important;
  margin-top: 0 !important;
}
#contact-form .reg-mode-card {
  min-height: 88px !important;
  border-radius: 12px !important;
  border: 1.5px solid #d9e2ec !important;
  background: linear-gradient(180deg, #f4f7fb 0%, #edf1f7 100%) !important;
  color: #667085 !important;
  box-shadow: inset 0 1px 3px rgba(15,23,42,.05) !important;
  transition: border-color .2s, background .2s, box-shadow .2s !important;
}
#contact-form .reg-mode-card strong { color: #1f2937 !important; font-size: .95rem !important; }
#contact-form .reg-mode-option input[type="radio"]:checked + .reg-mode-card,
#contact-form .reg-mode-option input[type="radio"]:checked ~ .reg-mode-card {
  background: #ffffff !important;
  border-color: #00c853 !important;
  box-shadow: 0 0 0 4px rgba(0,200,83,.12) !important;
}

/* ── Success state ── */
#contact-form .form-success h3,
#contact-form .success-ref span { color: #05af58 !important; }
#contact-form .form-success p,
#contact-form .success-ref { color: #596274 !important; }

/* ══════════════════════════════════════════════════
   DARK MODE — body:not(.light)
══════════════════════════════════════════════════ */
body:not(.light) #contact-form.contact-form-section {
  background: var(--bg, #0A0F1C) !important;
}

/* Tab bar */
body:not(.light) #contact-form > .container > .form-tabs .form-tab,
body:not(.light) #contact-form .ge-form-tabs-modern .form-tab {
  background: var(--surface, #1A2235) !important;
  color: #4ade80 !important;
  border-right-color: rgba(0,200,83,.15) !important;
}
body:not(.light) #contact-form > .container > .form-tabs .form-tab:first-child,
body:not(.light) #contact-form .ge-form-tabs-modern .form-tab:first-child {
  border-right-color: rgba(0,200,83,.18) !important;
}
body:not(.light) #contact-form > .container > .form-tabs .form-tab.active,
body:not(.light) #contact-form > .container > .form-tabs .form-tab[aria-selected="true"],
body:not(.light) #contact-form .ge-form-tabs-modern .form-tab.active,
body:not(.light) #contact-form .ge-form-tabs-modern .form-tab[aria-selected="true"] {
  background: #05af58 !important;
  color: #ffffff !important;
}
body:not(.light) #contact-form > .container > .form-tabs .form-tab:not(.active):hover,
body:not(.light) #contact-form .ge-form-tabs-modern .form-tab:not(.active):hover {
  background: rgba(0,200,83,.10) !important;
  color: #4ade80 !important;
}

/* Form card */
body:not(.light) #contact-form .contact-form.ge-reference-form,
body:not(.light) #contact-form .form-success {
  background: var(--surface, #1A2235) !important;
  border-color: var(--border, rgba(255,255,255,.08)) !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.45) !important;
  color: var(--text, #ffffff) !important;
}

/* Labels */
body:not(.light) #contact-form label,
body:not(.light) #contact-form .form-group > label {
  color: var(--text-muted, #B0B8C5) !important;
}

/* Inputs */
body:not(.light) #contact-form input,
body:not(.light) #contact-form select,
body:not(.light) #contact-form textarea {
  background: var(--bg-2, #121826) !important;
  border-color: var(--border, rgba(255,255,255,.10)) !important;
  color: var(--text, #ffffff) !important;
  box-shadow: none !important;
}
body:not(.light) #contact-form input::placeholder,
body:not(.light) #contact-form textarea::placeholder {
  color: var(--text-faint, #6F7A8A) !important;
  opacity: 1 !important;
}
body:not(.light) #contact-form select:invalid,
body:not(.light) #contact-form select option[disabled] { color: var(--text-faint, #6F7A8A) !important; }
body:not(.light) #contact-form select option {
  background: var(--surface, #1A2235);
  color: var(--text, #ffffff);
}
body:not(.light) #contact-form input:focus,
body:not(.light) #contact-form select:focus,
body:not(.light) #contact-form textarea:focus {
  background: var(--bg, #0A0F1C) !important;
  border-color: var(--green, #00C853) !important;
  box-shadow: 0 0 0 4px rgba(0,200,83,.14) !important;
}

/* Icons */
body:not(.light) #contact-form .input-icon  { color: var(--text-faint, #6F7A8A) !important; }
body:not(.light) #contact-form .select-arrow { color: var(--text-faint, #6F7A8A) !important; }
body:not(.light) #contact-form .char-count   { color: var(--text-faint, #6F7A8A) !important; }

/* Checkbox */
body:not(.light) #contact-form .checkbox-label { color: var(--text-muted, #B0B8C5) !important; }
body:not(.light) #contact-form .checkbox-custom {
  background: var(--bg-2, #121826) !important;
  border-color: var(--border, rgba(255,255,255,.15)) !important;
}
body:not(.light) #contact-form .checkbox-label input:checked + .checkbox-custom {
  background: var(--green, #00C853) !important;
  border-color: var(--green, #00C853) !important;
}
body:not(.light) #contact-form .checkbox-label input:checked + .checkbox-custom::after { color: #ffffff !important; }

/* Mode cards */
body:not(.light) #contact-form .reg-mode-card {
  border-color: var(--border, rgba(255,255,255,.10)) !important;
  background: var(--bg-2, #121826) !important;
  color: var(--text-muted, #B0B8C5) !important;
  box-shadow: none !important;
}
body:not(.light) #contact-form .reg-mode-card strong { color: var(--text, #ffffff) !important; }
body:not(.light) #contact-form .reg-mode-option input[type="radio"]:checked + .reg-mode-card,
body:not(.light) #contact-form .reg-mode-option input[type="radio"]:checked ~ .reg-mode-card {
  background: rgba(0,200,83,.10) !important;
  border-color: var(--green, #00C853) !important;
  box-shadow: 0 0 0 4px rgba(0,200,83,.12) !important;
}

/* Success */
body:not(.light) #contact-form .form-success h3,
body:not(.light) #contact-form .success-ref span { color: var(--green, #00C853) !important; }
body:not(.light) #contact-form .form-success p,
body:not(.light) #contact-form .success-ref { color: var(--text-muted, #B0B8C5) !important; }

/* Validation */
body:not(.light) #contact-form .form-group.has-error input,
body:not(.light) #contact-form .form-group.has-error select,
body:not(.light) #contact-form .form-group.has-error textarea {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.12) !important;
}
body:not(.light) #contact-form .form-group.is-valid input,
body:not(.light) #contact-form .form-group.is-valid select,
body:not(.light) #contact-form .form-group.is-valid textarea {
  border-color: var(--green, #00C853) !important;
}

/* ── Smooth transitions on all toggled elements ── */
#contact-form.contact-form-section,
#contact-form .ge-form-tabs-modern .form-tab,
#contact-form .contact-form.ge-reference-form,
#contact-form input,
#contact-form select,
#contact-form textarea,
#contact-form .checkbox-custom,
#contact-form .reg-mode-card {
  transition: background 0.4s ease, border-color 0.4s ease,
              color 0.4s ease, box-shadow 0.4s ease !important;
}

/* ══════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════ */
@media (max-width: 900px) {
  #contact-form.contact-form-section { padding-top: 36px !important; }
  #contact-form .form-row {
    grid-template-columns: 1fr !important;
    row-gap: 1.2rem !important;
  }
  #contact-form .form-group--full { grid-column: 1 !important; }
}
@media (max-width: 640px) {
  #contact-form > .container > .form-tabs,
  #contact-form .ge-form-tabs-modern {
    border-radius: 14px 14px 0 0 !important;
  }
  #contact-form > .container > .form-tabs .form-tab,
  #contact-form .ge-form-tabs-modern .form-tab {
    min-height: 70px !important;
    font-size: .95rem !important;
    padding: 14px 10px !important;
    white-space: normal !important;
    text-align: center !important;
    word-break: break-word !important;
    gap: 8px !important;
    line-height: 1.25 !important;
  }
  #contact-form > .container > .form-tabs .form-tab svg,
  #contact-form .ge-form-tabs-modern .form-tab svg {
    width: 20px !important;
    height: 20px !important;
    flex-shrink: 0 !important;
  }
  #contact-form .contact-form.ge-reference-form,
  #contact-form .form-success {
    border-radius: 0 0 18px 18px !important;
    padding: 1.5rem 1.25rem !important;
  }
  #contact-form input,
  #contact-form select,
  #contact-form textarea {
    min-height: 56px !important;
    padding: 0 40px 0 52px !important;
    font-size: .95rem !important;
  }
  #contact-form .reg-mode-group { grid-template-columns: 1fr !important; }
  #contact-form .form-submit { min-height: 60px !important; font-size: 1rem !important; }
}
@media (max-width: 420px) {
  #contact-form > .container > .form-tabs .form-tab,
  #contact-form .ge-form-tabs-modern .form-tab {
    min-height: 60px !important;
    font-size: .82rem !important;
    padding: 10px 8px !important;
    gap: 6px !important;
  }
  #contact-form > .container > .form-tabs .form-tab svg,
  #contact-form .ge-form-tabs-modern .form-tab svg {
    width: 17px !important;
    height: 17px !important;
  }
}
