/* ═══════════════════════════════════════
   CONTACT PAGE — contact.css
═══════════════════════════════════════ */

/* ── Hero ───────────────────────────── */
.ct-hero {
  position: relative;
  /* min-height: 360px; */
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  /* background: #07090d; */
  background: linear-gradient(135deg, #031a30, #0b1d3a, #031a30);
}

.ct-hero__bg {
  position: absolute;
  inset: 0;
  background: url('../assets/img/contact-hero.jpg') center/cover no-repeat;
  filter: brightness(.38) saturate(1.1);
}

.ct-hero__inner {
  position: relative;
  padding: 80px 0 56px;
}

.ct-hero__kicker {
  color: #c9a84c;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 12px;
  margin-bottom: 10px;
  display: block;
}

.ct-hero h1 {
  font-size: clamp(24px, 4vw, 46px);
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  margin: 0 0 12px;
}

.ct-hero p {
  color: rgba(255,255,255,.70);
  font-size: 15px;
  max-width: 52ch;
  margin: 0;
}

.breadcrumb-item,
.breadcrumb-item a { color: rgba(255,255,255,.55); font-size: 13px; }
.breadcrumb-item.active { color: #c9a84c; }
.breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.30); }

/* ── Main Section ───────────────────── */
.ct-section {
  padding: 70px 0;
  /* background: linear-gradient(135deg,
    rgba(3,26,48,.98),
    rgba(11,29,58,.95),
    rgba(3,26,48,.98)); */


    background: linear-gradient(135deg,
    rgba(234, 238, 241, 0.98),
    rgba(231, 234, 238, 0.95),
    rgba(230, 232, 238, 0.98));
  position: relative;
  overflow: hidden;
}

/* Dot pattern */
.ct-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(0, 0, 0, 0) 1px, transparent 1px);
  background-size: 26px 26px;
  pointer-events: none;
}

.ct-kicker {
  display: block;
  color: #c9a84c;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 11px;
  margin-bottom: 6px;
}

/* ── Alert Banners ──────────────────── */
.ct-alert {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 22px;
  border-radius: 14px;
  margin-bottom: 28px;
  border: 1px solid transparent;
}

.ct-alert--success {
  background: rgba(34,197,94,.10);
  border-color: rgba(34,197,94,.30);
  color: #fff;
}

.ct-alert--error {
  background: rgba(239,68,68,.10);
  border-color: rgba(239,68,68,.30);
  color: #fff;
}

.ct-alert__icon { font-size: 22px; margin-top: 2px; flex-shrink: 0; }
.ct-alert--success .ct-alert__icon { color: #22c55e; }
.ct-alert--error .ct-alert__icon { color: #ef4444; }
.ct-alert strong { display: block; font-size: 15px; margin-bottom: 3px; }
.ct-alert p { margin: 0; font-size: 13px; opacity: .80; }

/* ── Info Card ──────────────────────── */
.ct-info-card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  height: 100%;
  display: flex;
  flex-direction: column;
}

.ct-info-card__header {
  padding: 28px 28px 0;
}

.ct-info-card__title {
  font-size: 20px;
  font-weight: 700;
  color: #0b1d3a;
  margin: 4px 0 0;
}

/* Info list */
.ct-info-list {
  padding: 20px 28px;
  display: grid;
  gap: 0;
}

.ct-info-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid #f0f0f0;
}

.ct-info-item:last-child { border-bottom: none; }

.ct-info-item__icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(201,168,76,.12);
  color: #c9a84c;
  display: grid;
  place-items: center;
  font-size: 15px;
  flex-shrink: 0;
}

.ct-info-item__body strong {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: #0b1d3a;
  margin-bottom: 2px;
}

.ct-info-item__body span {
  font-size: 13px;
  color: #666;
  line-height: 1.5;
}

.ct-info-item__body a {
  color: #c9a84c;
  text-decoration: none;
  font-weight: 600;
}

.ct-info-item__body a:hover { text-decoration: underline; }

/* Registration box */
.ct-reg-box {
  margin: 0 28px;
  background: #f8f9fb;
  border: 1px solid rgba(11,29,58,.08);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 20px;
}

.ct-reg-box__title {
  font-size: 12px;
  font-weight: 700;
  color: #0b1d3a;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.ct-reg-box__title i { color: #c9a84c; }

.ct-reg-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.ct-reg-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ct-reg-item__label {
  font-size: 10px;
  font-weight: 700;
  color: #999;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.ct-reg-item__val {
  font-size: 12px;
  font-weight: 600;
  color: #333;
}

/* Map */
.ct-map-wrap {
  margin-top: auto;
  overflow: hidden;
  border-top: 1px solid #f0f0f0;
}

.ct-map-wrap iframe {
  display: block;
  border-radius: 0 0 20px 20px;
}

/* ── Form Card ──────────────────────── */
.ct-form-card {
  background: #fff;
  border-radius: 20px;
  padding: 36px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  height: 100%;
}

.ct-form-card__header {
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid #f0f0f0;
}

.ct-form-card__title {
  font-size: 20px;
  font-weight: 700;
  color: #0b1d3a;
  margin: 4px 0 8px;
}

.ct-form-card__sub {
  font-size: 14px;
  color: #777;
  margin: 0;
}

/* ── Form Fields ────────────────────── */
.ct-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #333;
  margin-bottom: 7px;
}

.ct-req { color: #c9a84c; }

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

.ct-input-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #c9a84c;
  font-size: 14px;
  pointer-events: none;
}

.ct-textarea-wrap .ct-textarea-icon {
  top: 16px;
  transform: none;
}

.ct-input {
  width: 100%;
  padding: 12px 14px 12px 40px;
  border: 1.5px solid rgba(11,29,58,.14);
  border-radius: 12px;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  color: #333;
  background: #fff;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
  appearance: none;
}

.ct-input:focus {
  border-color: #c9a84c;
  box-shadow: 0 0 0 3px rgba(201,168,76,.15);
}

.ct-input::placeholder { color: #bbb; }

.ct-select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%23c9a84c' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

.ct-textarea {
  resize: vertical;
  min-height: 130px;
  padding-top: 14px;
  line-height: 1.6;
}

/* Submit button */
.ct-submit-btn {
  width: 100%;
  padding: 14px;
  background: #c9a84c;
  color: #111;
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  font-weight: 700;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.ct-submit-btn:hover {
  background: #e8c97a;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(201,168,76,.35);
}

.ct-submit-btn:active { transform: none; }

/* Note */
.ct-note {
  font-size: 12px;
  color: #aaa;
  margin: 12px 0 0;
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: center;
}

.ct-note i { color: #c9a84c; font-size: 11px; }

/* ── Quick Contact Strip ────────────── */
.ct-quick-strip {
  background: #0b1d3a;
  padding: 36px 0;
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.ct-quick-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  text-decoration: none;
  color: #fff;
  transition: .2s ease;
  justify-content: flex-start;
  text-align: left;
}

.ct-quick-item:hover {
  background: rgba(201,168,76,.10);
  border-color: rgba(201,168,76,.30);
  color: #fff;
  transform: translateY(-3px);
}

.ct-quick-item__icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: rgba(201,168,76,.14);
  color: #c9a84c;
  display: grid;
  place-items: center;
  font-size: 18px;
  flex-shrink: 0;
}

.ct-quick-item__icon--wa {
  background: rgba(37,211,102,.14);
  color: #25d366;
}

.ct-quick-item strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}

.ct-quick-item span {
  display: block;
  font-size: 12px;
  color: rgba(255,255,255,.60);
  margin-top: 2px;
}

/* ── Responsive ─────────────────────── */
@media (max-width: 991px) {
  .ct-form-card { padding: 28px; }
  .ct-section { padding: 56px 0; }
}

@media (max-width: 767px) {
  /* .ct-hero { min-height: 280px; } */
  .ct-hero__inner { padding: 68px 0 38px; }
  .ct-form-card { padding: 24px; }
  .ct-info-card__header { padding: 22px 22px 0; }
  .ct-info-list { padding: 14px 22px; }
  .ct-reg-box { margin: 0 22px 16px; }
  .ct-quick-strip { padding: 28px 0; }
  .ct-quick-item { justify-content: flex-start; }
}

@media (max-width: 576px) {
  .ct-section { padding: 44px 0; }
  .ct-form-card { padding: 20px; }
  .ct-form-card__title { font-size: 17px; }
  .ct-info-card__title { font-size: 17px; }
  .ct-reg-grid { grid-template-columns: 1fr; }
  .ct-submit-btn { font-size: 14px; padding: 13px; }
  .ct-quick-item { padding: 13px 16px; }
}