/* =========================================================

   CONTACT.CSS — FINAL CLEAN LOCKED VERSION

   Uses design-system.css as master visual reference.

   Page CSS controls Contact-specific layout only.

=========================================================

01. Page Base

02. Hero Banner

03. Support Section

04. Form Card

05. Help Card

06. Locations Section

07. Location Editorial Rows

08. Location Buttons

09. Map System

10. Contact Footer

11. Final Strip

12. iPad / Tablet Layout

13. Mobile Layout

14. Final Contact Locks

========================================================= */

/* =========================================================

   01. PAGE BASE

========================================================= */

body.contact-page {

  margin: 0;

  padding: 0;

  overflow-x: hidden;

  background: var(--brand-cream);

  color: var(--brand-charcoal);

  font-family: var(--font-heading);

}

.contact-page *,

.contact-page *::before,

.contact-page *::after {

  box-sizing: border-box;

}

.contact-page img {

  max-width: 100%;

  display: block;

}

.contact-page a {

  text-decoration: none;

}

/* =========================================================

   02. HERO BANNER

========================================================= */

.contact-hero {

  position: relative;

  width: 100%;

  height: 240px;

  overflow: hidden;

  background-image:

    linear-gradient(rgba(7,22,38,0.18), rgba(7,22,38,0.24)),

    url('contact-hero-panorama.png');

  background-size: cover;

  background-repeat: no-repeat;

  background-position: center 42%;

}

.contact-hero-overlay {

  position: absolute;

  inset: 0;

  display: flex;

  align-items: center;

  justify-content: center;

  text-align: center;

  padding-top: 8px;

}

.contact-hero-overlay h1 {

  position: relative;

  margin: 0;

  color: var(--hero-title-color-light);

  font-family: var(--hero-title-font-family);

  font-size: 52px;

  line-height: 1;

  font-weight: var(--hero-title-font-weight);

  letter-spacing: 0.26em;

  text-transform: uppercase;

  text-shadow: var(--hero-title-text-shadow-light);

}

.contact-hero-overlay h1::after {

  content: "";

  display: block;

  width: var(--underline-width-desktop);

  height: var(--underline-height-desktop);

  margin: var(--underline-gap-top) auto 0;

  background: var(--underline-color);

}

/* =========================================================

   03. SUPPORT SECTION

========================================================= */

.contact-support-section {

  width: 100%;

  background: var(--brand-steel-blue);

  padding: 68px 5.5% 60px;

  display: grid;

  grid-template-columns: 1.04fr 0.96fr;

  gap: 26px;

}

.contact-form-card,

.contact-help-card {

  min-height: 100%;

  padding: 40px;

  border: 1px solid rgba(255,255,255,0.16);

}

/* =========================================================

   04. FORM CARD

========================================================= */

.contact-form-card {

  background: rgba(245,238,227,0.98);

  color: var(--brand-charcoal);

}

.contact-form-card h2,

.contact-help-card h2 {

  margin: 0;

  font-family: var(--section-title-font-family);

  font-size: var(--section-title-size-desktop);

  line-height: var(--section-title-line-height);

  font-weight: var(--section-title-font-weight);

  letter-spacing: var(--section-title-letter-spacing);

}

.contact-form-card h2 {

  color: var(--section-title-color-navy);

}

.contact-help-card h2 {

  color: var(--section-title-color-light);

}

.small-line {

  display: block;

  width: var(--underline-width-desktop);

  height: var(--underline-height-desktop);

  margin: 18px 0 28px;

  background: var(--underline-color);

}

.form-row {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 16px;

}

.contact-form-card input,

.contact-form-card textarea {

  width: 100%;

  padding: 16px;

  border: 1px solid rgba(45,42,38,0.14);

  background: rgba(255,255,255,0.78);

  color: var(--brand-charcoal);

  font-family: var(--body-copy-font-family);

  font-size: var(--body-copy-font-size-mobile);

  line-height: 1.5;

  font-weight: var(--body-copy-font-weight);

  margin-bottom: 16px;

  outline: none;

}

.contact-form-card textarea {

  min-height: 150px;

  resize: vertical;

}

.contact-form-card button {

  width: 100%;

  height: 52px;

  border: 1px solid var(--brand-gold);

  background: var(--brand-gold);

  color: var(--brand-white);

  display: flex;

  align-items: center;

  justify-content: center;

  gap: 10px;

  font-family: var(--button-font-family);

  font-size: var(--button-font-size);

  line-height: 1;

  font-weight: var(--button-font-weight);

  letter-spacing: var(--button-letter-spacing);

  text-transform: uppercase;

  cursor: pointer;

}

.contact-form-card button::after {

  content: "›";

  font-size: 18px;

  line-height: 1;

  margin-left: 4px;

  transform: translateY(-1px);

}

.privacy-note {

  margin: 18px 0 0;

  color: rgba(45,42,38,0.72);

  font-family: var(--body-copy-font-family);

  font-size: 13px;

  line-height: 1.6;

  font-weight: var(--body-copy-font-weight);

}

.privacy-note i {

  color: var(--brand-gold);

  margin-right: 7px;

}

/* =========================================================

   05. HELP CARD

========================================================= */

.contact-help-card {

  background: rgba(83,101,116,0.92);

  color: var(--brand-white);

}

.help-intro {

  margin: 0 0 28px;

  padding-bottom: 22px;

  border-bottom: 1px solid rgba(185,150,87,0.44);

  color: rgba(255,255,255,0.88);

  font-family: var(--body-copy-font-family);

  font-size: var(--body-copy-font-size-mobile);

  line-height: 1.82;

  font-weight: var(--body-copy-font-weight);

}

.help-item {

  display: flex;

  gap: 18px;

  margin-bottom: 24px;

}

.help-item i {

  width: 34px;

  color: var(--brand-gold-soft);

  font-size: 26px;

  margin-top: 2px;

}

.help-item strong {

  display: block;

  margin-bottom: 6px;

  color: var(--brand-white);

  font-family: var(--body-copy-font-family);

  font-size: 15px;

  line-height: 1.4;

  font-weight: 400;

}

.help-item span,

.help-item a {

  color: rgba(255,255,255,0.82);

  font-family: var(--body-copy-font-family);

  font-size: 13px;

  line-height: 1.6;

  font-weight: var(--body-copy-font-weight);

}

/* =========================================================

   06. LOCATIONS SECTION

========================================================= */

.contact-locations-section {

  background: var(--brand-cream);

  padding: 46px 7% 58px;

}

.contact-section-heading {

  margin: 0 0 38px;

}

.contact-section-heading span:first-child {

  display: block;

  color: var(--section-title-color-dark);

  font-family: var(--section-title-font-family);

  font-size: var(--section-title-size-desktop);

  line-height: var(--section-title-line-height);

  font-weight: var(--section-title-font-weight);

  letter-spacing: 0.14em;

  text-transform: uppercase;

}

.contact-section-line {

  display: block;

  width: var(--underline-width-desktop);

  height: var(--underline-height-desktop);

  margin: var(--underline-gap-top) 0 0;

  background: var(--underline-color);

}

/* =========================================================

   07. LOCATION EDITORIAL ROWS

========================================================= */

.location-grid {

  display: grid;

  grid-template-columns: 1fr;

  gap: 0;

  max-width: 1220px;

  margin: 0 auto;

}

.location-card {

  display: grid;

  grid-template-columns: 31% 29% 40%;

  column-gap: 26px;

  align-items: start;

  border-bottom: 1px solid rgba(185,150,87,0.28);

  padding: 0 0 34px;

  margin: 0 0 34px;

}

.location-card:last-child {

  margin-bottom: 0;

}

.location-info,

.location-image-area {

  display: contents;

}

.location-info h2 {

  grid-column: 1;

  grid-row: 1;

  margin: 0 0 24px;

  color: var(--section-title-color-dark);

  font-family: var(--section-title-font-family);

  font-size: var(--card-title-size-desktop);

  line-height: 1.12;

  font-weight: var(--card-title-font-weight);

  letter-spacing: var(--card-title-letter-spacing);

}

.location-image {

  grid-column: 1;

  grid-row: 2;

  width: 100%;

  height: 176px;

  overflow: hidden;

}

.location-image img {

  width: 100%;

  height: 100%;

  object-fit: cover;

  filter: saturate(0.88) brightness(0.92);

}

.location-card:first-child .location-image {

  transform: translateY(-32px);

}

.location-card:last-child .location-image {

  transform: translateY(-50px);

}

.location-card:first-child .location-image img {

  object-position: center 18%;

}

.location-card:last-child .location-image img {

  object-position: center 52%;

}

.location-details {

  grid-column: 2;

  grid-row: 1;

  padding: 8px 24px 0 14px;

  border-left: 1px solid rgba(185,150,87,0.28);

  border-right: 1px solid rgba(185,150,87,0.28);

}

.location-details p {

  margin: 0 0 18px;

  display: grid;

  grid-template-columns: 22px 1fr;

  column-gap: 10px;

  align-items: start;

  color: rgba(45,42,38,0.82);

  font-family: var(--body-copy-font-family);

  font-size: var(--body-copy-font-size-mobile);

  line-height: 1.55;

  font-weight: var(--body-copy-font-weight);

}

.location-details i {

  color: var(--brand-gold);

  margin-top: 4px;

}

.location-details a {

  color: rgba(45,42,38,0.82);

}

/* =========================================================

   08. LOCATION BUTTONS

========================================================= */

.location-buttons {

  grid-column: 2;

  grid-row: 2;

  padding: 0 28px;

  display: flex;

  flex-direction: column;

  gap: 10px;

}

.location-card:first-child .location-buttons {

  transform: translateY(48px);

}

.location-card:last-child .location-buttons {

  transform: translateY(24px);

}

.location-btn {

  width: 100%;

  height: 40px;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  gap: 10px;

  font-family: var(--button-font-family);

  font-size: 10px;

  line-height: 1;

  font-weight: var(--button-font-weight);

  letter-spacing: var(--button-letter-spacing);

  text-transform: uppercase;

}

.location-btn::after {

  content: "›";

  font-size: 18px;

  line-height: 1;

  margin-left: 4px;

  transform: translateY(-1px);

}

.location-btn.dark {

  background: var(--brand-gold);

  border: 1px solid var(--brand-gold);

  color: var(--brand-white);

}

.location-btn.light {

  background: transparent;

  border: 1px solid var(--brand-gold);

  color: var(--brand-gold);

}

/* =========================================================

   09. MAP SYSTEM

========================================================= */

.location-map {

  grid-column: 3;

  grid-row: 1 / span 2;

  width: 100%;

}

.location-map iframe {

  width: 100%;

  height: 300px;

  border: none;

  display: block;

  filter: saturate(0.82) brightness(0.96);

}

/* =========================================================

   10. CONTACT FOOTER

========================================================= */

.contact-footer {

  background: var(--footer-variant-bg);

  color: var(--footer-text-light);

  padding: 42px 5.5% 36px;

}

.contact-footer-inner {

  max-width: 1280px;

  margin: 0 auto;

  display: grid;

  grid-template-columns: 1fr 1fr 1fr;

  gap: 44px;

}

.contact-footer-column {

  position: relative;

}

.contact-footer-column:not(:last-child)::after {

  content: "";

  position: absolute;

  top: 8px;

  right: -22px;

  width: 1px;

  height: 100%;

  background: var(--footer-border-gold-dark);

}

.contact-footer h3 {

  margin: 0 0 22px;

  color: var(--footer-text-light);

  font-family: var(--font-heading);

  font-size: 13px;

  line-height: 1;

  font-weight: 400;

  letter-spacing: 0.14em;

  text-transform: uppercase;

}

.contact-footer p,

.contact-footer a {

  color: var(--footer-text-light-soft);

  font-family: var(--body-copy-font-family);

  font-size: 13px;

  line-height: 1.7;

  font-weight: var(--body-copy-font-weight);

}

.contact-footer-contact p {

  display: grid;

  grid-template-columns: 22px 1fr;

  column-gap: 10px;

  margin: 0 0 12px;

}

.contact-footer-contact i {

  color: var(--brand-gold);

  margin-top: 4px;

}

.contact-footer-links {

  display: flex;

  flex-direction: column;

  align-items: flex-start;

}

.contact-footer-links a {

  margin-bottom: 8px;

}

.contact-footer-brand img {

  width: 210px;

  height: auto;

  margin-bottom: 18px;

}

.contact-footer-cta {

  margin-top: 18px;

  width: 210px;

  height: var(--button-height);

  background: var(--brand-gold);

  border: 1px solid var(--brand-gold);

  color: var(--brand-white) !important;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  gap: 10px;

  text-transform: uppercase;

  letter-spacing: var(--button-letter-spacing);

  font-family: var(--button-font-family);

  font-size: var(--button-font-size) !important;

  line-height: 1;

  font-weight: var(--button-font-weight);

}

.contact-footer-cta::after {

  content: "›";

  font-size: 18px;

  line-height: 1;

  margin-left: 4px;

  transform: translateY(-1px);

}

.contact-footer-socials {

  display: flex;

  gap: 14px;

  margin-top: 22px;

}

.contact-footer-socials .icon {

  width: 42px;

  height: 42px;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  font-size: 18px;

  border-radius: 50% !important;

  color: var(--brand-white) !important;

}

.contact-footer-socials .icon i {

  color: var(--brand-white) !important;

}

.contact-footer-socials .instagram {

  background:

    radial-gradient(

      circle at 30% 107%,

      #fdf497 0%,

      #fdf497 5%,

      #fd5949 45%,

      #d6249f 60%,

      #285AEB 90%

    );

}

.contact-footer-socials .facebook {

  background: #1877f2;

}

.contact-footer-socials .twitter {

  background: #000000;

}

.contact-footer-socials .youtube {

  background: #ff0000;

}

/* =========================================================

   11. FINAL STRIP

========================================================= */

.contact-final-strip {

  width: 100%;

  padding: 14px 5.5%;

  background: #b99f82;

  color: rgba(255,255,255,0.92);

  font-family: var(--body-copy-font-family);

  font-size: 11px;

  line-height: 1.5;

  font-weight: var(--body-copy-font-weight);

  letter-spacing: 0.04em;

  display: flex;

  justify-content: space-between;

  gap: 20px;

}

/* =========================================================

   12. iPAD / TABLET LAYOUT

========================================================= */

@media (min-width: 701px) and (max-width: 1400px) {

  .contact-hero {

    height: 190px;

  }

  .contact-hero-overlay h1 {

    font-size: var(--hero-title-size-tablet);

    letter-spacing: 0.24em;

  }

  .contact-hero-overlay h1::after,

  .small-line,

  .contact-section-line {

    width: var(--underline-width-tablet);

    height: var(--underline-height-tablet);

  }

  .contact-support-section {

    padding: 56px 5%;

    gap: 22px;

  }

  .contact-form-card,

  .contact-help-card {

    padding: 34px;

  }

  .contact-form-card h2,

  .contact-help-card h2,

  .contact-section-heading span:first-child {

    font-size: var(--section-title-size-tablet);

  }

  .location-card {

    grid-template-columns: 31% 29% 40%;

    column-gap: 22px;

  }

  .location-map iframe {

    height: 300px;

  }

}

/* =========================================================

   13. MOBILE LAYOUT

========================================================= */

@media (max-width: 700px) {

  .contact-hero {

    height: 150px;

    background-position: center 44%;

  }

  .contact-hero-overlay h1 {

    font-size: 28px;

    letter-spacing: 0.18em;

  }

  .contact-hero-overlay h1::after {

    width: var(--underline-width-mobile);

    height: var(--underline-height-mobile);

    margin-top: 16px;

  }

  .contact-support-section {

    grid-template-columns: 1fr;

    gap: 18px;

    padding: 42px 5%;

  }

  .contact-form-card,

  .contact-help-card {

    padding: 28px 22px;

  }

  .contact-form-card h2,

  .contact-help-card h2,

  .contact-section-heading span:first-child {

    font-size: var(--section-title-size-mobile);

  }

  .small-line,

  .contact-section-line {

    width: var(--underline-width-mobile);

    height: var(--underline-height-mobile);

  }

  .form-row {

    grid-template-columns: 1fr;

    gap: 0;

  }

  .contact-locations-section {

    padding: 48px 5% 54px;

  }

  .location-card {

    display: block;

    padding-bottom: 28px;

    margin-bottom: 28px;

  }

  .location-info h2 {

    font-size: var(--card-title-size-mobile);

  }

  .location-image {

    height: 155px;

    margin: 16px 0;

    transform: none !important;

  }

  .location-details {

    padding: 0;

    border: none;

  }

  .location-buttons {

    padding: 0;

    margin: 16px 0 22px;

    transform: none !important;

  }

  .location-map iframe {

    height: 220px;

  }

  .contact-footer-inner {

    grid-template-columns: 1fr;

    gap: 30px;

  }

  .contact-footer-column::after {

    display: none;

  }

  .contact-footer-brand img {

    width: 190px;

    max-width: none;

    margin: 0 auto 22px auto;

  }

  .contact-footer-brand {

    max-width: 280px;

    margin: 0 auto;

    text-align: center;

  }

  .contact-footer-cta {

    width: 76%;

    max-width: 540px;

    margin-left: auto;

    margin-right: auto;

  }

  .contact-final-strip {

    flex-direction: column;

    text-align: center;

    font-size: 9px;

  }

}

/* =========================================================

   14. FINAL CONTACT LOCKS

========================================================= */

.floating-contact,

.float-whatsapp,

.float-call,

.contact-footer-socials .icon {

  border-radius: 50% !important;

  overflow: hidden !important;

}



