/* ═══════════════════════════════════════
       NAVHAR FOODS – CONTACT PAGE STYLES
       Class naming convention:
         contact-hero, contact-info, contact-form,
         contact-channels, contact-map, contact-faq,
         contact-cta
    ═══════════════════════════════════════ */

    :root {
      --green:        #1c8366;
      --green-dark:   #0f4f3d;
      --green-mid:    #2a9e7c;
      --green-light:  #e8f4f0;
      --green-pale:   #f0faf6;
      --amber:        #f7a942;
      --amber-light:  #fff8ed;
      --amber-dark:   #d4892e;
      --cream:        #fef9f0;
      --dark:         #1a1a1a;
      --mid:          #555;
      --light:        #888;
      --border:       #e6e6dc;
      --white:        #ffffff;
      --shadow-sm:    0 2px 10px rgba(0,0,0,0.06);
      --shadow-md:    0 8px 32px rgba(0,0,0,0.10);
      --shadow-lg:    0 20px 60px rgba(0,0,0,0.14);
      --radius-sm:    8px;
      --radius-md:    16px;
      --radius-lg:    24px;
      --ease:         cubic-bezier(0.4,0,0.2,1);
      --font-display: 'Playfair Display', serif;
      --font-body:    'DM Sans', sans-serif;
    }

    *, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior: smooth; }
    body {
      font-family: var(--font-body);
      background: var(--cream);
      color: var(--dark);
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }
    a { text-decoration: none; color: inherit; }
    img { display:block; max-width:100%; }
    button { font-family: inherit; cursor: pointer; border: none; outline: none; }

    /* ── GRAIN TEXTURE ── */
    body::before {
      content: '';
      position: fixed; inset: 0; pointer-events: none; z-index: 0;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
    }

    /* ═══════════════════════════════
       HEADER
    ═══════════════════════════════ */
    .site-header {
      position: sticky; top: 0; z-index: 100;
      background: rgba(254,249,240,0.92);
      backdrop-filter: blur(16px);
      border-bottom: 1px solid var(--border);
      transition: box-shadow 0.3s;
    }
    .site-header.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,0.08); }

    .site-header__inner {
      max-width: 1400px; margin: 0 auto;
      padding: 0 32px;
      display: flex; align-items: center; justify-content: space-between;
      height: 68px; gap: 24px;
    }

    .site-header__logo {
      display: flex; align-items: center; gap: 10px;
      font-family: var(--font-display);
      font-size: 22px; font-weight: 700;
      color: var(--green-dark);
    }
    .site-header__logo-icon { font-size: 28px; }

    .site-header__nav { display: flex; gap: 28px; }
    .site-header__nav a {
      font-size: 13px; font-weight: 500;
      color: var(--mid); letter-spacing: 0.5px; text-transform: uppercase;
      position: relative; transition: color 0.25s;
    }
    .site-header__nav a::after {
      content: ''; position: absolute; left: 0; bottom: -3px;
      width: 0; height: 2px; background: var(--green);
      transition: width 0.25s;
    }
    .site-header__nav a:hover, .site-header__nav a.active { color: var(--green); }
    .site-header__nav a:hover::after, .site-header__nav a.active::after { width: 100%; }

    .site-header__cta {
      background: var(--green); color: white;
      padding: 10px 22px; border-radius: 99px;
      font-size: 13px; font-weight: 600;
      transition: all 0.25s;
    }
    .site-header__cta:hover {
      background: var(--green-dark);
      transform: translateY(-2px);
      box-shadow: 0 4px 16px rgba(28,131,102,.3);
    }

    /* ═══════════════════════════════
       CONTACT HERO
    ═══════════════════════════════ */
    .contact-hero {
      position: relative;
      background: linear-gradient(150deg, #0f4f3d 0%, #1c8366 60%, #f7a942 150%);
      padding: 90px 32px 110px;
      overflow: hidden;
      text-align: center;
    }

    /* Wavy dot grid */
    .contact-hero::before {
      content: '';
      position: absolute; inset: 0;
      background-image: radial-gradient(circle, rgba(255,255,255,0.07) 1px, transparent 1px);
      background-size: 32px 32px;
    }

    /* Bottom curve */
    .contact-hero::after {
      content: '';
      position: absolute; bottom: -2px; left: 0; right: 0; height: 80px;
      background: var(--cream);
      clip-path: ellipse(55% 100% at 50% 100%);
    }

    .contact-hero__deco {
      position: absolute; font-size: 140px; opacity: 0.06; pointer-events: none;
    }
    .contact-hero__deco--1 { top: -20px; left: -20px; transform: rotate(-20deg); }
    .contact-hero__deco--2 { bottom: 40px; right: -10px; transform: rotate(15deg); font-size: 100px; }

    .contact-hero__inner {
      position: relative; z-index: 1;
      max-width: 680px; margin: 0 auto;
    }

    .contact-hero__breadcrumb {
      display: flex; align-items: center; justify-content: center; gap: 8px;
      font-size: 12px; color: rgba(255,255,255,0.6);
      margin-bottom: 20px;
    }
    .contact-hero__breadcrumb a { color: rgba(255,255,255,0.7); }
    .contact-hero__breadcrumb a:hover { color: var(--amber); }

    .contact-hero__tag {
      display: inline-flex; align-items: center; gap: 8px;
      background: rgba(247,169,66,0.2); border: 1px solid rgba(247,169,66,0.4);
      color: var(--amber); padding: 6px 18px; border-radius: 99px;
      font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px;
      margin-bottom: 24px;
    }

    .contact-hero__title {
      font-family: var(--font-display);
      font-size: clamp(38px, 6vw, 68px);
      color: white; line-height: 1.05; margin-bottom: 18px;
    }
    .contact-hero__title em { color: var(--amber); font-style: italic; }

    .contact-hero__subtitle {
      font-size: 16px; color: rgba(255,255,255,0.75);
      font-weight: 300; line-height: 1.8; margin-bottom: 40px;
    }

    /* Quick contact pills */
    .contact-hero__quick {
      display: flex; flex-wrap: wrap; gap: 12px; justify-content: center;
    }
    .contact-hero__quick-link {
      display: inline-flex; align-items: center; gap: 8px;
      background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.22);
      color: white; padding: 10px 20px; border-radius: 99px;
      font-size: 13px; font-weight: 500;
      transition: all 0.25s;
    }
    .contact-hero__quick-link:hover {
      background: rgba(255,255,255,0.22); transform: translateY(-2px);
    }
    .contact-hero__quick-link--wa {
      background: #25d366; border-color: #25d366;
    }
    .contact-hero__quick-link--wa:hover { background: #1ab954; border-color: #1ab954; }

    /* ═══════════════════════════════
       CONTACT LAYOUT (Form + Info)
    ═══════════════════════════════ */
    .contact-layout {
      max-width: 1400px; margin: 0 auto;
      padding: 80px 32px;
      display: grid; grid-template-columns: 1fr 420px;
      gap: 48px; align-items: start;
      position: relative; z-index: 1;
    }

    /* ═══════════════════════════════
       CONTACT FORM
    ═══════════════════════════════ */
    .contact-form {
      background: white; border: 1.5px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 48px;
      box-shadow: var(--shadow-md);
    }

    .contact-form__header { margin-bottom: 36px; }

    .contact-form__tag {
      display: inline-block;
      background: var(--green-light); color: var(--green);
      padding: 5px 14px; border-radius: 99px;
      font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px;
      margin-bottom: 14px;
    }

    .contact-form__title {
      font-family: var(--font-display); font-size: 28px;
      color: var(--dark); line-height: 1.2;
    }

    .contact-form__subtitle {
      font-size: 14px; color: var(--mid); margin-top: 8px; line-height: 1.6;
    }

    /* Subject tabs */
    .contact-form__tabs {
      display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 28px;
    }
    .contact-form__tab {
      background: var(--cream); border: 1.5px solid var(--border);
      padding: 7px 16px; border-radius: 99px;
      font-size: 12px; font-weight: 600; color: var(--mid);
      transition: all 0.2s;
    }
    .contact-form__tab.active, .contact-form__tab:hover {
      background: var(--green); border-color: var(--green); color: white;
    }

    /* Form rows */
    .contact-form__row {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 16px; margin-bottom: 16px;
    }
    .contact-form__row--full { grid-template-columns: 1fr; }

    .contact-form__group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }

    .contact-form__label {
      font-size: 12px; font-weight: 600; text-transform: uppercase;
      letter-spacing: 0.8px; color: var(--mid);
    }
    .contact-form__label span { color: var(--amber); }

    .contact-form__input,
    .contact-form__select,
    .contact-form__textarea {
      background: var(--cream); border: 1.5px solid var(--border);
      border-radius: var(--radius-sm); padding: 12px 16px;
      font-family: var(--font-body); font-size: 14px; color: var(--dark);
      transition: border-color 0.25s, box-shadow 0.25s; outline: none;
      width: 100%;
    }
    .contact-form__input::placeholder,
    .contact-form__textarea::placeholder { color: var(--light); }
    .contact-form__input:focus,
    .contact-form__select:focus,
    .contact-form__textarea:focus {
      border-color: var(--green);
      box-shadow: 0 0 0 4px rgba(28,131,102,0.08);
      background: white;
    }
    .contact-form__select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
    .contact-form__textarea { resize: vertical; min-height: 130px; line-height: 1.6; }

    /* Checkbox */
    .contact-form__check {
      display: flex; align-items: flex-start; gap: 10px; margin-bottom: 24px;
    }
    .contact-form__check input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--green); margin-top: 2px; flex-shrink: 0; }
    .contact-form__check label { font-size: 13px; color: var(--mid); line-height: 1.5; }
    .contact-form__check label a { color: var(--green); }

    .contact-form__submit {
      width: 100%; background: var(--green); color: white;
      padding: 16px; border-radius: var(--radius-sm);
      font-size: 15px; font-weight: 700;
      display: flex; align-items: center; justify-content: center; gap: 10px;
      transition: all 0.25s;
    }
    .contact-form__submit:hover {
      background: var(--green-dark);
      transform: translateY(-2px);
      box-shadow: 0 8px 24px rgba(28,131,102,.3);
    }
    .contact-form__submit:active { transform: translateY(0); }

    .contact-form__wa-alt {
      width: 100%; background: #25d366; color: white;
      padding: 14px; border-radius: var(--radius-sm);
      font-size: 13px; font-weight: 600; margin-top: 12px;
      display: flex; align-items: center; justify-content: center; gap: 8px;
      transition: all 0.25s;
    }
    .contact-form__wa-alt:hover { background: #1ab954; transform: translateY(-2px); }

    /* Success state */
    .contact-form__success {
      display: none; text-align: center; padding: 40px 24px;
    }
    .contact-form__success-icon { font-size: 56px; margin-bottom: 16px; }
    .contact-form__success h3 {
      font-family: var(--font-display); font-size: 24px; margin-bottom: 10px; color: var(--green);
    }
    .contact-form__success p { font-size: 14px; color: var(--mid); line-height: 1.7; }

    /* ═══════════════════════════════
       CONTACT INFO SIDEBAR
    ═══════════════════════════════ */
    .contact-info { display: flex; flex-direction: column; gap: 20px; }

    .contact-info__card {
      background: white; border: 1.5px solid var(--border);
      border-radius: var(--radius-md); padding: 28px;
      box-shadow: var(--shadow-sm);
      transition: all 0.3s;
    }
    .contact-info__card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: var(--green); }

    .contact-info__card-icon {
      width: 52px; height: 52px; border-radius: var(--radius-sm);
      background: var(--green-light);
      display: flex; align-items: center; justify-content: center;
      font-size: 24px; margin-bottom: 16px;
    }
    .contact-info__card--amber .contact-info__card-icon { background: var(--amber-light); }

    .contact-info__card-title {
      font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px;
      color: var(--light); font-weight: 600; margin-bottom: 8px;
    }

    .contact-info__card-main {
      font-size: 18px; font-weight: 700; color: var(--dark); margin-bottom: 4px;
    }
    .contact-info__card-main a { color: var(--green); }
    .contact-info__card-main a:hover { text-decoration: underline; }

    .contact-info__card-sub {
      font-size: 13px; color: var(--mid); line-height: 1.5;
    }

    /* Hours table */
    .contact-info__hours {
      width: 100%; font-size: 13px; margin-top: 12px; border-collapse: collapse;
    }
    .contact-info__hours tr { border-bottom: 1px solid var(--border); }
    .contact-info__hours tr:last-child { border-bottom: none; }
    .contact-info__hours td { padding: 7px 0; color: var(--mid); }
    .contact-info__hours td:last-child { text-align: right; font-weight: 600; color: var(--dark); }
    .contact-info__hours .open { color: var(--green); }
    .contact-info__hours .closed { color: #ff4757; }

    /* Social row */
    .contact-info__social {
      display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap;
    }
    .contact-info__social-link {
      display: flex; align-items: center; gap: 8px;
      background: var(--cream); border: 1.5px solid var(--border);
      padding: 8px 14px; border-radius: 99px;
      font-size: 12px; font-weight: 600; color: var(--mid);
      transition: all 0.25s;
    }
    .contact-info__social-link:hover { background: var(--green); border-color: var(--green); color: white; }

    /* ═══════════════════════════════
       CONTACT CHANNELS
    ═══════════════════════════════ */
    .contact-channels {
      background: var(--green-pale);
      border-top: 1px solid var(--green-light);
      padding: 80px 32px;
      position: relative; z-index: 1;
    }

    .contact-channels__inner { max-width: 1400px; margin: 0 auto; }

    .contact-channels__header {
      text-align: center; margin-bottom: 48px;
    }

    .contact-channels__tag {
      display: inline-block;
      background: var(--green-light); color: var(--green);
      padding: 6px 16px; border-radius: 99px;
      font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px;
      margin-bottom: 14px;
    }

    .contact-channels__title {
      font-family: var(--font-display); font-size: clamp(26px, 3vw, 40px);
      color: var(--dark);
    }

    .contact-channels__grid {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
    }

    .contact-channels__card {
      background: white; border: 1.5px solid var(--border);
      border-radius: var(--radius-md); padding: 32px 24px;
      text-align: center; transition: all 0.3s;
      cursor: pointer;
    }
    .contact-channels__card:hover {
      transform: translateY(-6px); box-shadow: var(--shadow-lg);
      border-color: var(--green);
    }

    .contact-channels__card-icon { font-size: 40px; margin-bottom: 14px; }

    .contact-channels__card-title {
      font-family: var(--font-display); font-size: 18px;
      color: var(--dark); margin-bottom: 8px;
    }

    .contact-channels__card-desc {
      font-size: 13px; color: var(--mid); line-height: 1.6; margin-bottom: 18px;
    }

    .contact-channels__card-action {
      display: inline-flex; align-items: center; gap: 6px;
      padding: 9px 20px; border-radius: 99px;
      font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
      transition: all 0.25s;
    }
    .contact-channels__card-action--green {
      background: var(--green-light); color: var(--green);
    }
    .contact-channels__card-action--green:hover { background: var(--green); color: white; }
    .contact-channels__card-action--wa {
      background: #dcf8e5; color: #1a8a3c;
    }
    .contact-channels__card-action--wa:hover { background: #25d366; color: white; }
    .contact-channels__card-action--amber {
      background: var(--amber-light); color: var(--amber-dark);
    }
    .contact-channels__card-action--amber:hover { background: var(--amber); color: white; }

    /* ═══════════════════════════════
       CONTACT MAP
    ═══════════════════════════════ */
    .contact-map {
      padding: 80px 32px;
      max-width: 1400px; margin: 0 auto;
      position: relative; z-index: 1;
    }

    .contact-map__header {
      display: flex; align-items: flex-end; justify-content: space-between;
      margin-bottom: 32px; flex-wrap: wrap; gap: 16px;
    }

    .contact-map__header-tag {
      display: inline-block;
      background: var(--amber-light); color: var(--amber-dark);
      padding: 5px 14px; border-radius: 99px;
      font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px;
      margin-bottom: 10px;
    }

    .contact-map__header-title {
      font-family: var(--font-display); font-size: clamp(24px, 2.5vw, 36px);
      color: var(--dark);
    }

    .contact-map__directions-btn {
      display: inline-flex; align-items: center; gap: 8px;
      background: var(--green); color: white;
      padding: 12px 24px; border-radius: 99px;
      font-size: 13px; font-weight: 700; transition: all 0.25s;
    }
    .contact-map__directions-btn:hover {
      background: var(--green-dark); transform: translateY(-2px);
      box-shadow: 0 6px 16px rgba(28,131,102,.3);
    }

    .contact-map__embed {
      width: 100%; height: 380px;
      border-radius: var(--radius-md); overflow: hidden;
      border: 1.5px solid var(--border);
      box-shadow: var(--shadow-md);
      background: var(--green-light);
      display: flex; align-items: center; justify-content: center;
      position: relative;
    }
    /* placeholder when real iframe not loaded */
    .contact-map__placeholder {
      text-align: center;
    }
    .contact-map__placeholder-icon { font-size: 64px; margin-bottom: 16px; }
    .contact-map__placeholder-address {
      font-family: var(--font-display); font-size: 20px; color: var(--green-dark); margin-bottom: 8px;
    }
    .contact-map__placeholder-sub { font-size: 14px; color: var(--mid); }

    /* ═══════════════════════════════
       CONTACT FAQ
    ═══════════════════════════════ */
    .contact-faq {
      background: white;
      padding: 80px 32px;
      border-top: 1px solid var(--border);
    }

    .contact-faq__inner { max-width: 900px; margin: 0 auto; }

    .contact-faq__header {
      text-align: center; margin-bottom: 48px;
    }

    .contact-faq__tag {
      display: inline-block;
      background: var(--green-light); color: var(--green);
      padding: 5px 14px; border-radius: 99px;
      font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px;
      margin-bottom: 14px;
    }

    .contact-faq__title {
      font-family: var(--font-display); font-size: clamp(26px, 3vw, 40px);
      color: var(--dark);
    }

    .contact-faq__list { display: flex; flex-direction: column; gap: 12px; }

    .contact-faq__item {
      border: 1.5px solid var(--border); border-radius: var(--radius-sm);
      overflow: hidden; transition: border-color 0.25s;
    }
    .contact-faq__item.open { border-color: var(--green); }

    .contact-faq__question {
      width: 100%; background: none;
      display: flex; align-items: center; justify-content: space-between;
      padding: 20px 24px; text-align: left;
      font-size: 15px; font-weight: 600; color: var(--dark);
      transition: color 0.25s;
    }
    .contact-faq__item.open .contact-faq__question { color: var(--green); }

    .contact-faq__chevron {
      width: 28px; height: 28px; border-radius: 50%;
      background: var(--cream); border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center;
      font-size: 12px; flex-shrink: 0;
      transition: transform 0.3s, background 0.25s;
    }
    .contact-faq__item.open .contact-faq__chevron {
      transform: rotate(180deg); background: var(--green); color: white; border-color: var(--green);
    }

    .contact-faq__answer {
      max-height: 0; overflow: hidden;
      transition: max-height 0.4s var(--ease), padding 0.3s;
    }
    .contact-faq__item.open .contact-faq__answer { max-height: 400px; }

    .contact-faq__answer-inner {
      padding: 0 24px 20px;
      font-size: 14px; color: var(--mid); line-height: 1.75;
      border-top: 1px solid var(--border);
      padding-top: 16px;
    }

    /* ═══════════════════════════════
       CONTACT CTA
    ═══════════════════════════════ */
    .contact-cta {
      background: linear-gradient(135deg, var(--green-dark), var(--green-mid));
      padding: 80px 32px; text-align: center;
      position: relative; overflow: hidden;
    }
    .contact-cta::before {
      content: '';
      position: absolute; inset: 0;
      background-image: radial-gradient(circle, rgba(255,255,255,0.05) 1px, transparent 1px);
      background-size: 28px 28px;
    }
    .contact-cta__inner { position: relative; z-index: 1; max-width: 560px; margin: 0 auto; }
    .contact-cta__icon { font-size: 48px; margin-bottom: 16px; }
    .contact-cta__title {
      font-family: var(--font-display); font-size: clamp(28px, 3.5vw, 44px);
      color: white; margin-bottom: 12px;
    }
    .contact-cta__title em { color: var(--amber); font-style: italic; }
    .contact-cta__sub { font-size: 15px; color: rgba(255,255,255,.7); margin-bottom: 32px; line-height: 1.7; }
    .contact-cta__btn {
      display: inline-flex; align-items: center; gap: 8px;
      background: var(--amber); color: white;
      padding: 14px 32px; border-radius: 99px;
      font-size: 15px; font-weight: 700; transition: all 0.25s;
    }
    .contact-cta__btn:hover { background: var(--amber-dark); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(247,169,66,.4); }

    /* ─── FOOTER ─── */
    .site-footer {
      background: var(--dark); color: white;
      text-align: center; padding: 28px 32px;
      font-size: 13px; color: rgba(255,255,255,0.5);
    }
    .site-footer a { color: var(--amber); }

    /* ─── REVEAL ─── */
    .reveal {
      opacity: 0; transform: translateY(28px);
      transition: opacity 0.65s ease, transform 0.65s ease;
    }
    .reveal.visible { opacity: 1; transform: translateY(0); }
    .reveal-left {
      opacity: 0; transform: translateX(-36px);
      transition: opacity 0.65s ease, transform 0.65s ease;
    }
    .reveal-left.visible { opacity: 1; transform: translateX(0); }
    .reveal-right {
      opacity: 0; transform: translateX(36px);
      transition: opacity 0.65s ease, transform 0.65s ease;
    }
    .reveal-right.visible { opacity: 1; transform: translateX(0); }

    /* ─── RESPONSIVE ─── */
    @media (max-width: 1024px) {
      .contact-layout { grid-template-columns: 1fr; }
      .contact-channels__grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 768px) {
      .contact-form { padding: 28px 20px; }
      .contact-form__row { grid-template-columns: 1fr; }
      .contact-channels__grid { grid-template-columns: repeat(2, 1fr); }
      .site-header__nav { display: none; }
      .contact-hero, .contact-layout, .contact-channels, .contact-map, .contact-faq, .contact-cta { padding-left: 20px; padding-right: 20px; }
    }
    @media (max-width: 480px) {
      .contact-channels__grid { grid-template-columns: 1fr; }
      .contact-hero__quick { flex-direction: column; align-items: center; }
    }