/* ============ Page-specific styles: contact.html ============ */

/* ── Contact Page Styles ── */
    .contact-hero {
      background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);
      padding: 100px 0 72px;
      text-align: center;
      position: relative;
      overflow: hidden;
    }
    .contact-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(255,106,0,0.1) 0%, transparent 70%);
      pointer-events: none;
    }
    .contact-hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(255,106,0,0.12);
      border: 1px solid rgba(255,106,0,0.25);
      border-radius: 999px;
      padding: 6px 16px;
      font-size: 0.75rem;
      font-weight: 600;
      color: var(--accent);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-bottom: 20px;
    }
    .contact-hero h1 {
      font-family: var(--font-heading);
      font-size: clamp(2rem, 5vw, 3.25rem);
      font-weight: 700;
      color: #fff;
      line-height: 1.15;
      margin-bottom: 16px;
    }
    .contact-hero h1 span { color: var(--accent); }
    .contact-hero p {
      color: rgba(255,255,255,0.55);
      font-size: 1rem;
      max-width: 480px;
      margin: 0 auto;
      line-height: 1.7;
    }

    /* ── Contact Body ── */
    .contact-body {
      background: var(--bg-secondary);
      padding: 80px 0;
    }
    .contact-grid {
      display: grid;
      grid-template-columns: 1fr 1.5fr;
      gap: 40px;
      align-items: start;
    }

    /* ── Info Cards ── */
    .contact-info-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 16px;
      padding: 32px;
    }
    .contact-info-card h2 {
      font-family: var(--font-heading);
      font-size: 1.4rem;
      font-weight: 700;
      color: var(--heading);
      margin-bottom: 8px;
    }
    .contact-info-card > p {
      color: var(--body);
      font-size: 0.9rem;
      line-height: 1.65;
      margin-bottom: 28px;
    }
    .contact-info-item {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      padding: 18px 0;
      border-top: 1px solid var(--border);
    }
    .contact-info-item:last-child { border-bottom: 1px solid var(--border); }
    .contact-icon-wrap {
      width: 40px;
      height: 40px;
      background: rgba(255,106,0,0.08);
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      color: var(--accent);
    }
    .contact-info-text strong {
      display: block;
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--heading);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      margin-bottom: 3px;
    }
    .contact-info-text a,
    .contact-info-text span {
      font-size: 0.9rem;
      color: var(--body);
      text-decoration: none;
      line-height: 1.55;
    }
    .contact-info-text a:hover { color: var(--accent); }

    .contact-hours {
      background: linear-gradient(135deg, #0f0f0f 0%, #1c1c1c 100%);
      border-radius: 12px;
      padding: 20px;
      margin-top: 24px;
    }
    .contact-hours-title {
      font-family: var(--font-heading);
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--accent);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      margin-bottom: 12px;
    }
    .contact-hours-row {
      display: flex;
      justify-content: space-between;
      font-size: 0.85rem;
      color: rgba(255,255,255,0.55);
      padding: 5px 0;
    }
    .contact-hours-row span:last-child { color: rgba(255,255,255,0.8); }

    /* ── Form Card ── */
    .contact-form-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 16px;
      padding: 40px;
    }
    .contact-form-card h2 {
      font-family: var(--font-heading);
      font-size: 1.5rem;
      font-weight: 700;
      color: var(--heading);
      margin-bottom: 6px;
    }
    .contact-form-card > p {
      color: var(--body);
      font-size: 0.9rem;
      margin-bottom: 28px;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .form-group {
      margin-bottom: 20px;
    }
    .form-group label {
      display: block;
      font-size: 0.8rem;
      font-weight: 600;
      color: var(--heading);
      margin-bottom: 7px;
      letter-spacing: 0.02em;
    }
    .form-group label span { color: var(--accent); }
    .form-control {
      width: 100%;
      padding: 12px 16px;
      border: 1.5px solid var(--border);
      border-radius: 10px;
      font-family: var(--font-body);
      font-size: 0.9rem;
      color: var(--heading);
      background: var(--white);
      transition: border-color 0.2s, box-shadow 0.2s;
      box-sizing: border-box;
      outline: none;
    }
    .form-control:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 3px rgba(255,106,0,0.1);
    }
    .form-control::placeholder { color: #bbb; }
    textarea.form-control {
      resize: vertical;
      min-height: 130px;
    }
    select.form-control {
      appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23999' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 14px center;
      padding-right: 40px;
      cursor: pointer;
    }
    .submit-btn {
      width: 100%;
      padding: 14px 24px;
      background: var(--accent);
      color: #fff;
      border: none;
      border-radius: 10px;
      font-family: var(--font-heading);
      font-size: 0.95rem;
      font-weight: 600;
      cursor: pointer;
      transition: background 0.2s, transform 0.15s;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
    }
    .submit-btn:hover { background: var(--accent-hover); transform: translateY(-1px); }
    .submit-btn:active { transform: translateY(0); }

    .form-note {
      font-size: 0.78rem;
      color: var(--body);
      text-align: center;
      margin-top: 12px;
      line-height: 1.5;
    }

    /* Success state */
    .form-success {
      display: none;
      text-align: center;
      padding: 40px 20px;
    }
    .form-success-icon {
      width: 64px;
      height: 64px;
      background: rgba(255,106,0,0.1);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 20px;
      color: var(--accent);
    }
    .form-success h3 {
      font-family: var(--font-heading);
      font-size: 1.3rem;
      color: var(--heading);
      margin-bottom: 8px;
    }
    .form-success p { color: var(--body); font-size: 0.9rem; }

    /* ── FAQ Section ── */
    .contact-faq { background: var(--white); padding: 80px 0; }
    .faq-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-top: 48px;
    }
    .faq-item {
      background: var(--bg-secondary);
      border: 1px solid var(--border);
      border-radius: 12px;
      padding: 24px;
      cursor: pointer;
      transition: border-color 0.2s, box-shadow 0.2s;
    }
    .faq-item:hover { border-color: var(--accent); box-shadow: 0 4px 16px rgba(255,106,0,0.08); }
    .faq-question {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
    }
    .faq-question span {
      font-family: var(--font-heading);
      font-size: 0.95rem;
      font-weight: 600;
      color: var(--heading);
      line-height: 1.4;
    }
    .faq-toggle {
      width: 24px;
      height: 24px;
      background: rgba(255,106,0,0.1);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      color: var(--accent);
      font-size: 1.1rem;
      font-weight: 300;
      transition: transform 0.2s;
    }
    .faq-answer {
      display: none;
      font-size: 0.875rem;
      color: var(--body);
      line-height: 1.65;
      margin-top: 12px;
      padding-top: 12px;
      border-top: 1px solid var(--border);
    }
    .faq-item.open .faq-answer { display: block; }
    .faq-item.open .faq-toggle { transform: rotate(45deg); }

    /* ── Map Section ── */
    .contact-map { background: var(--bg-secondary); padding: 80px 0; }
    .map-wrap {
      border-radius: 16px;
      overflow: hidden;
      border: 1px solid var(--border);
      height: 360px;
      background: #e8e8e8;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 40px;
      position: relative;
    }
    .map-placeholder {
      text-align: center;
      color: var(--body);
    }
    .map-placeholder svg { color: var(--accent); margin-bottom: 12px; }
    .map-placeholder strong {
      display: block;
      font-family: var(--font-heading);
      font-size: 1rem;
      color: var(--heading);
      margin-bottom: 4px;
    }
    .map-placeholder p { font-size: 0.85rem; line-height: 1.55; }
    .map-link {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: var(--accent);
      color: #fff;
      border-radius: 8px;
      padding: 10px 20px;
      font-size: 0.85rem;
      font-weight: 600;
      text-decoration: none;
      margin-top: 14px;
      transition: background 0.2s;
    }
    .map-link:hover { background: var(--accent-hover); }

    /* Responsive */
    @media (max-width: 900px) {
      .contact-grid { grid-template-columns: 1fr; }
      .faq-grid { grid-template-columns: 1fr; }
      .form-row { grid-template-columns: 1fr; }
      .contact-form-card { padding: 28px 20px; }
    }
