
    .page-hero {
      background: #1a2e2d;
      padding: 80px 80px 60px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }

    .page-hero::before {
      content: 'CONTACT';
      position: absolute;
      font-family: 'Cormorant Garamond', serif;
      font-size: 170px;
      font-weight: 300;
      color: rgba(58, 189, 181, .04);
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      white-space: nowrap;
      letter-spacing: 18px;
      pointer-events: none;
    }

    .page-hero-label {
      font-size: 10px;
      letter-spacing: 5px;
      color: #3abdb5;
      text-transform: uppercase;
      margin-bottom: 16px;
    }

    .page-hero-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: clamp(36px, 5vw, 64px);
      font-weight: 300;
      color: #fff;
      line-height: 1.1;
    }

    .page-hero-title em {
      font-style: italic;
      color: #3abdb5;
    }

    .page-hero-sub {
      font-size: 14px;
      font-weight: 300;
      color: rgba(255, 255, 255, .45);
      margin-top: 16px;
      letter-spacing: 1px;
    }

    /* ── Contact main ── */
    .contact-page {
      padding: 90px 80px;
      background: #f7fafa;
    }

    .contact-wrap {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 70px;
      max-width: 1300px;
      margin: 0 auto;
    }

    /* Info side */
    .ci-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 36px;
      font-weight: 300;
      color: #1a2e2d;
      line-height: 1.2;
      margin-bottom: 14px;
    }

    .ci-title em {
      font-style: italic;
      color: #3abdb5;
    }

    .ci-desc {
      font-size: 14px;
      font-weight: 300;
      line-height: 1.9;
      color: #6b9996;
      margin-bottom: 40px;
      max-width: 400px;
    }

    .ci-list {
      display: flex;
      flex-direction: column;
      gap: 24px;
    }

    .ci-row {
      display: flex;
      gap: 16px;
      align-items: flex-start;
    }

    .ci-ic {
      width: 46px;
      height: 46px;
      border: 1.5px solid #3abdb5;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #3abdb5;
      flex-shrink: 0;
      transition: all .3s;
    }

    .ci-row:hover .ci-ic {
      background: #3abdb5;
      color: #fff;
    }

    .ci-tx strong {
      display: block;
      font-size: 10px;
      letter-spacing: 2px;
      color: #3abdb5;
      text-transform: uppercase;
      margin-bottom: 4px;
    }

    .ci-tx span {
      font-size: 15px;
      color: #1a2e2d;
      font-weight: 300;
      line-height: 1.5;
    }

    .ci-tx a {
      color: #1a2e2d;
      text-decoration: none;
      transition: color .3s;
    }

    .ci-tx a:hover {
      color: #3abdb5;
    }

    /* Hours card */
    .hours-card {
      margin-top: 36px;
      padding: 24px;
      background: #fff;
      border-left: 3px solid #3abdb5;
    }

    .hours-title {
      font-size: 10px;
      letter-spacing: 2px;
      color: #3abdb5;
      text-transform: uppercase;
      margin-bottom: 14px;
    }

    .hours-row {
      display: flex;
      justify-content: space-between;
      font-size: 13px;
      color: #6b9996;
      padding: 6px 0;
      border-bottom: 1px solid #eef5f4;
    }

    .hours-row:last-child {
      border-bottom: none;
    }

    .hours-row strong {
      color: #1a2e2d;
      font-weight: 500;
    }

    /* Form side */
    .form-card {
      background: #fff;
      padding: 48px;
      border: 1px solid #e8f4f3;
    }

    .form-card-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 26px;
      font-weight: 300;
      color: #1a2e2d;
      margin-bottom: 6px;
    }

    .form-card-sub {
      font-size: 13px;
      color: #8aadaa;
      margin-bottom: 32px;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }

    .cform .fg {
      display: flex;
      flex-direction: column;
      gap: 6px;
      margin-bottom: 18px;
    }

    .cform .fg label {
      font-size: 10px;
      letter-spacing: 2px;
      color: #8aadaa;
      text-transform: uppercase;
    }

    .cform .fg input,
    .cform .fg textarea,
    .cform .fg select {
      background: #f7fafa;
      border: 1.5px solid #d8eeed;
      padding: 13px 16px;
      font-family: 'Inter', sans-serif;
      font-size: 14px;
      color: #1a2e2d;
      outline: none;
      transition: border-color .3s;
      resize: none;
      width: 100%;
    }

    .cform .fg input:focus,
    .cform .fg textarea:focus,
    .cform .fg select:focus {
      border-color: #3abdb5;
    }

    .cform .fg textarea {
      height: 130px;
    }

    .cform .sbtn {
      padding: 15px 40px;
      background: #3abdb5;
      color: #fff;
      font-family: 'Inter', sans-serif;
      font-size: 11px;
      letter-spacing: 3px;
      text-transform: uppercase;
      border: none;
      cursor: pointer;
      transition: all .3s;
      width: 100%;
    }

    .cform .sbtn:hover {
      background: #1a2e2d;
    }

    /* ── Map ── */
    .map-section {
      padding: 0;
      background: #1a2e2d;
    }

    .map-wrap {
      position: relative;
      width: 100%;
      height: 480px;
      overflow: hidden;
    }

    .map-wrap iframe {
      width: 100%;
      height: 100%;
      border: none;
      filter: grayscale(.3) contrast(1.05);
    }

    .map-badge {
      position: absolute;
      top: 30px;
      left: 80px;
      background: rgba(26, 46, 45, .95);
      backdrop-filter: blur(10px);
      padding: 24px 30px;
      border: 1px solid rgba(58, 189, 181, .2);
      z-index: 10;
      max-width: 300px;
    }

    .map-badge-label {
      font-size: 10px;
      letter-spacing: 3px;
      color: #3abdb5;
      text-transform: uppercase;
      margin-bottom: 8px;
    }

    .map-badge-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 22px;
      color: #fff;
      margin-bottom: 8px;
    }

    .map-badge-addr {
      font-size: 13px;
      color: rgba(255, 255, 255, .5);
      line-height: 1.6;
    }

    @media(max-width:1024px) {

      .page-hero,
      .contact-page {
        padding: 60px 32px;
      }

      .contact-wrap {
        grid-template-columns: 1fr;
        gap: 50px;
      }

      .map-badge {
        left: 32px;
        right: 32px;
        max-width: none;
      }
    }

    @media(max-width:600px) {

      .page-hero,
      .contact-page {
        padding: 50px 20px;
      }

      .form-card {
        padding: 30px 24px;
      }

      .form-row {
        grid-template-columns: 1fr;
        gap: 0;
      }

      .map-badge {
        left: 20px;
        right: 20px;
        top: 20px;
        padding: 18px 20px;
      }

      .map-wrap {
        height: 360px;
      }

      .ci-title {
        font-size: 28px;
      }
    }
