/* ================================================================
   CONTACT PAGE -- contact.css
   ================================================================ */

/* -- NAV ACTIVE STATE ------------------------------------------- */
.active-page { color: var(--neon) !important; }

/* -- HERO ------------------------------------------------------- */
.ct-hero {
  position: relative;
  padding: 100px 0 70px;
  overflow: hidden;
  text-align: center;
}
.ct-hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 0%,  rgba(0,255,136,.09) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 80% 80%, rgba(0,212,255,.07) 0%, transparent 50%);
}
.ct-hero-inner {
  position: relative; z-index: 1;
  max-width: 680px; margin: 0 auto;
}
.ct-hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(0,255,136,.07);
  border: 1px solid rgba(0,255,136,.2);
  border-radius: 30px; padding: .35rem 1rem;
  font-size: .75rem; font-weight: 700;
  color: var(--neon); letter-spacing: .5px;
  text-transform: uppercase; margin-bottom: 1.4rem;
}
.ct-live-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--neon); box-shadow: 0 0 6px var(--neon);
  animation: ct-pulse 2s ease-in-out infinite;
}
@keyframes ct-pulse { 0%,100%{ opacity:1; } 50%{ opacity:.4; } }

.ct-hero-title {
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 900; color: #fff;
  letter-spacing: -.5px; line-height: 1.1;
  margin-bottom: 1.1rem;
}
.ct-hero-sub {
  font-size: .95rem; color: rgba(180,192,220,.7);
  line-height: 1.75; max-width: 520px; margin: 0 auto 2rem;
}
.ct-response-strip {
  display: inline-flex; align-items: center; gap: 0;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px; padding: .75rem 1.5rem;
  flex-wrap: wrap; justify-content: center;
}
.ct-resp-item {
  display: flex; align-items: center; gap: .5rem;
  font-size: .82rem; color: rgba(180,192,220,.6);
  padding: .2rem .9rem;
}
.ct-resp-item i { color: var(--neon); font-size: .85rem; }
.ct-resp-item strong { color: #fff; font-weight: 700; }
.ct-resp-sep { width: 1px; height: 20px; background: rgba(255,255,255,.08); }

/* -- MAIN GRID -------------------------------------------------- */
.ct-main { padding: 0 0 100px; }
.ct-grid {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 2rem;
  align-items: start;
}
@media (max-width: 960px) {
  .ct-grid { grid-template-columns: 1fr; }
}

/* -- INFO PANEL ------------------------------------------------- */
.ct-info-cards {
  display: flex; flex-direction: column; gap: .85rem;
  margin-bottom: 1.25rem;
}
.ct-info-card {
  display: flex; align-items: flex-start; gap: 1rem;
  background: rgba(14,22,44,.8);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; padding: 1.1rem 1.25rem;
  transition: border-color .2s, transform .2s;
}
.ct-info-card:hover {
  border-color: rgba(255,255,255,.14);
  transform: translateX(4px);
}
.ct-info-ico {
  width: 42px; height: 42px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
}
.ct-info-ico.neon   { background: rgba(0,255,136,.1);   border: 1px solid rgba(0,255,136,.2);   color: var(--neon); }
.ct-info-ico.blue   { background: rgba(0,212,255,.1);   border: 1px solid rgba(0,212,255,.2);   color: #00d4ff; }
.ct-info-ico.gold   { background: rgba(255,209,102,.1); border: 1px solid rgba(255,209,102,.2); color: #ffd166; }
.ct-info-ico.purple { background: rgba(191,95,255,.1);  border: 1px solid rgba(191,95,255,.2);  color: #bf5fff; }
.ct-info-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: rgba(120,128,165,.6); margin-bottom: .25rem; }
.ct-info-val {
  display: block; font-size: .9rem; font-weight: 700; color: #fff;
  text-decoration: none; transition: color .18s;
}
a.ct-info-val:hover { color: var(--neon); }
.ct-info-hint { font-size: .75rem; color: rgba(120,128,165,.55); margin-top: .2rem; }

/* -- SOCIAL ----------------------------------------------------- */
.ct-social-block {
  background: rgba(14,22,44,.8);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; padding: 1.1rem 1.25rem;
  margin-bottom: 1.25rem;
}
.ct-social-title {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .5px; color: rgba(120,128,165,.6); margin-bottom: .85rem;
}
.ct-social-row { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; }
.ct-social-btn {
  display: flex; align-items: center; gap: .6rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px; padding: .6rem .9rem;
  color: rgba(180,192,220,.65); font-size: .82rem; font-weight: 600;
  text-decoration: none; transition: all .18s;
}
.ct-social-btn:hover {
  background: rgba(0,255,136,.06);
  border-color: rgba(0,255,136,.25);
  color: #fff; transform: translateY(-2px);
}
.ct-social-btn i { font-size: 1rem; }

/* -- MAP CARD --------------------------------------------------- */
.ct-map-card {
  border-radius: 16px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.07);
}
.ct-map-visual {
  position: relative; height: 160px;
  background: linear-gradient(160deg, rgba(10,15,32,.95), rgba(6,10,22,.98));
  overflow: hidden;
}
.ct-map-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(0,255,136,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,136,.06) 1px, transparent 1px);
  background-size: 28px 28px;
}
.ct-map-pin {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
.ct-map-pin-dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--neon); box-shadow: 0 0 12px var(--neon);
  position: relative; z-index: 2; margin: 0 auto;
}
.ct-map-pin-ring {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid rgba(0,255,136,.35);
  animation: ct-ring 2s ease-out infinite;
}
@keyframes ct-ring {
  0%   { width: 12px; height: 12px; opacity: .8; }
  100% { width: 55px; height: 55px; opacity: 0; }
}
.ct-map-pin-label {
  position: absolute; top: -26px; left: 50%;
  transform: translateX(-50%);
  background: rgba(0,255,136,.12);
  border: 1px solid rgba(0,255,136,.3);
  border-radius: 6px; padding: 2px 10px;
  font-size: .7rem; font-weight: 700; color: var(--neon);
  white-space: nowrap;
}
.ct-map-coords {
  position: absolute; bottom: .75rem; right: .9rem;
  font-size: .68rem; color: rgba(120,128,165,.5);
  font-variant-numeric: tabular-nums; letter-spacing: .03em;
}

/* -- FORM CARD -------------------------------------------------- */
.ct-form-card {
  background: rgba(14,22,44,.8);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px; padding: 2rem 2.25rem;
  backdrop-filter: blur(16px);
  box-shadow: 0 24px 80px rgba(0,0,0,.35);
  margin-bottom: 1.25rem;
  position: relative; overflow: hidden;
}
.ct-form-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--neon), #00d4ff, #bf5fff, var(--neon));
  background-size: 200% 100%;
  animation: ct-bar 4s linear infinite;
}
@keyframes ct-bar { to { background-position: -200% 0; } }

.ct-form-head { margin-bottom: 1.75rem; }
.ct-form-head h2 { font-size: 1.35rem; font-weight: 800; color: #fff; margin-bottom: .35rem; }
.ct-form-head p  { font-size: .84rem; color: rgba(180,192,220,.55); }

/* -- FIELDS ----------------------------------------------------- */
.ct-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 540px) { .ct-form-row { grid-template-columns: 1fr; } }

.ct-field { margin-bottom: 1.1rem; }
.ct-field label {
  display: block; font-size: .8rem; font-weight: 700;
  color: rgba(180,192,220,.75); margin-bottom: .45rem;
  letter-spacing: .1px;
}
.req  { color: #ff4d6d; margin-left: 2px; }
.opt  { color: rgba(120,128,165,.5); font-weight: 500; font-size: .74rem; }

.ct-input-wrap {
  position: relative;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
  transition: border-color .2s, box-shadow .2s;
}
.ct-input-wrap.focused {
  border-color: rgba(0,255,136,.4);
  box-shadow: 0 0 0 3px rgba(0,255,136,.08);
}
.ct-input-wrap.error {
  border-color: rgba(255,77,109,.45);
  box-shadow: 0 0 0 3px rgba(255,77,109,.08);
}
.ct-input-ico {
  position: absolute; left: .9rem; top: 50%;
  transform: translateY(-50%);
  color: rgba(120,128,165,.4); font-size: .85rem;
  pointer-events: none; transition: color .2s;
}
.ct-input-wrap.focused .ct-input-ico { color: var(--neon); }
.ct-textarea-ico { top: .85rem; transform: none; }

.ct-input-wrap input,
.ct-input-wrap select,
.ct-input-wrap textarea {
  width: 100%; background: none; border: none; outline: none;
  padding: .7rem .9rem .7rem 2.4rem;
  color: #fff; font-family: 'DM Sans', sans-serif;
  font-size: .88rem; line-height: 1.5;
}
.ct-input-wrap select { cursor: pointer; -webkit-appearance: none; appearance: none; }
.ct-input-wrap textarea { padding-top: .75rem; resize: vertical; min-height: 110px; }
.ct-input-wrap input::placeholder,
.ct-input-wrap textarea::placeholder { color: rgba(120,128,165,.4); }
.ct-input-wrap select option { background: #0e1628; }

.ct-select-wrap .ct-select-arrow {
  position: absolute; right: .9rem; top: 50%;
  transform: translateY(-50%);
  color: rgba(120,128,165,.4); font-size: .75rem;
  pointer-events: none;
}
.ct-textarea-wrap .ct-input-ico { top: .85rem; transform: none; }

.ct-field-err {
  display: none; font-size: .75rem; color: #ff4d6d;
  margin-top: .35rem; padding-left: .2rem;
}
.ct-char-count {
  text-align: right; font-size: .73rem;
  color: rgba(120,128,165,.45); margin-top: .3rem;
}

/* -- SUBMIT BUTTON ---------------------------------------------- */
.ct-submit-btn {
  width: 100%; padding: .85rem 1.5rem;
  background: linear-gradient(135deg, rgba(0,255,136,.2) 0%, rgba(0,212,255,.14) 100%);
  border: 1px solid rgba(0,255,136,.4);
  border-radius: 14px; color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: .95rem; font-weight: 700;
  cursor: pointer; transition: all .22s;
  display: flex; align-items: center; justify-content: center; gap: .55rem;
  box-shadow: 0 4px 22px rgba(0,255,136,.15), inset 0 1px 0 rgba(255,255,255,.1);
  margin-top: .5rem;
}
.ct-submit-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, rgba(0,255,136,.3) 0%, rgba(0,212,255,.22) 100%);
  border-color: rgba(0,255,136,.6);
  box-shadow: 0 6px 32px rgba(0,255,136,.28);
  transform: translateY(-2px);
}
.ct-submit-btn:disabled { opacity: .7; cursor: not-allowed; }
.ct-btn-default,
.ct-btn-loading { display: flex; align-items: center; gap: .55rem; }

.ct-spinner {
  width: 18px; height: 18px;
  border: 2px solid rgba(255,255,255,.2);
  border-top-color: #fff;
  border-radius: 50%;
  animation: ct-spin .7s linear infinite;
}
@keyframes ct-spin { to { transform: rotate(360deg); } }

/* -- SUCCESS STATE ---------------------------------------------- */
.ct-success {
  flex-direction: column; align-items: center;
  text-align: center; padding: 2rem 1rem;
  gap: .75rem;
}
.ct-success h3 { font-size: 1.4rem; font-weight: 800; color: #fff; margin: 0; }
.ct-success p  { font-size: .88rem; color: rgba(180,192,220,.65); line-height: 1.65; max-width: 340px; margin: 0; }
.ct-success p strong { color: #fff; }

/* Animated checkmark */
.ct-success-ico { margin-bottom: .5rem; }
.ct-checkmark {
  width: 72px; height: 72px;
}
.ct-checkmark-circle {
  stroke: var(--neon); stroke-width: 2;
  stroke-dasharray: 166; stroke-dashoffset: 166;
  animation: ct-stroke 0.6s cubic-bezier(0.65,0,.45,1) forwards;
}
.ct-checkmark-check {
  stroke: var(--neon); stroke-width: 3;
  stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 48; stroke-dashoffset: 48;
  animation: ct-stroke 0.4s cubic-bezier(0.65,0,.45,1) 0.55s forwards;
}
@keyframes ct-stroke { to { stroke-dashoffset: 0; } }

.ct-success-meta {
  display: flex; align-items: center; gap: 1.25rem;
  background: rgba(0,255,136,.05);
  border: 1px solid rgba(0,255,136,.15);
  border-radius: 10px; padding: .55rem 1.25rem;
  font-size: .78rem; color: rgba(180,192,220,.55);
}
.ct-success-meta span { display: flex; align-items: center; gap: .4rem; }
.ct-success-meta i { color: var(--neon); }

.ct-send-another {
  display: flex; align-items: center; gap: .45rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; padding: .55rem 1.25rem;
  color: rgba(180,192,220,.65); font-family: 'DM Sans', sans-serif;
  font-size: .84rem; font-weight: 600; cursor: pointer;
  transition: all .18s; margin-top: .5rem;
}
.ct-send-another:hover {
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.22); color: #fff;
}

/* -- MINI FAQ --------------------------------------------------- */
.ct-faq-mini {
  background: rgba(14,22,44,.8);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; padding: 1.4rem 1.5rem;
}
.ct-faq-title {
  font-size: .8rem; font-weight: 700; color: rgba(180,192,220,.55);
  text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: 1rem; display: flex; align-items: center; gap: .45rem;
}
.ct-faq-title i { color: var(--neon); }
.ct-faq-list { display: flex; flex-direction: column; gap: .5rem; }

.ct-faq-item {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px; overflow: hidden;
  transition: border-color .18s;
}
.ct-faq-item[open] { border-color: rgba(0,255,136,.18); }
.ct-faq-item summary {
  padding: .75rem 1rem;
  font-size: .85rem; font-weight: 600; color: rgba(200,210,235,.85);
  cursor: pointer; list-style: none;
  display: flex; align-items: center; justify-content: space-between;
  gap: .5rem; user-select: none;
}
.ct-faq-item summary::-webkit-details-marker { display: none; }
.ct-faq-item summary::after {
  content: '\F282'; font-family: 'bootstrap-icons';
  font-size: .75rem; color: rgba(120,128,165,.5);
  transition: transform .25s;
  flex-shrink: 0;
}
.ct-faq-item[open] summary::after { transform: rotate(180deg); color: var(--neon); }
.ct-faq-item[open] summary { color: #fff; }
.ct-faq-item p {
  margin: 0; padding: 0 1rem .9rem;
  font-size: .82rem; color: rgba(150,160,190,.65);
  line-height: 1.65;
  border-top: 1px solid rgba(255,255,255,.05);
  padding-top: .7rem;
}
