  /* ── PAGE HERO ── */
    .page-hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; background: var(--navy); overflow: hidden; }
    .page-hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 35%; opacity: .35; }
    .page-hero::before { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(160deg, oklch(11% 0.08 282 / .95) 0%, oklch(11% 0.08 282 / .6) 60%, oklch(11% 0.08 282 / .25) 100%); }
    .page-hero::after { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none; background-image: linear-gradient(oklch(99% 0.005 88 / .018) 1px, transparent 1px), linear-gradient(90deg, oklch(99% 0.005 88 / .018) 1px, transparent 1px); background-size: 80px 80px; }
    .page-hero-inner { position: relative; z-index: 2; padding: clamp(110px, 13vw, 168px) 0 clamp(72px, 9vw, 110px); display: flex; flex-direction: column; gap: 20px; }
    .page-hero-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--orange); display: flex; align-items: center; gap: 12px; }
    .page-hero-eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--orange); flex-shrink: 0; }
    .page-hero-h { font-family: var(--ff-d); font-weight: 900; font-size: clamp(42px, 7vw, 96px); letter-spacing: -0.04em; line-height: 0.92; color: var(--ink); }
    .page-hero-h em { font-style: normal; color: var(--orange); }
    .page-hero-sub { font-size: clamp(14px, 1.5vw, 17px); color: oklch(99% 0.005 88 / .55); line-height: 1.65; max-width: 54ch; }
    .page-hero-breadcrumb { position: absolute; bottom: 32px; right: clamp(20px, 4vw, 40px); z-index: 2; display: flex; align-items: center; gap: 10px; font-size: 11px; color: oklch(99% 0.005 88 / .35); letter-spacing: .04em; }
    .page-hero-breadcrumb a { color: oklch(99% 0.005 88 / .45); transition: color .2s; }
    .page-hero-breadcrumb a:hover { color: var(--orange); }
    .page-hero-breadcrumb > span { color: var(--orange); font-weight: 600; }

    /* ── CONTACT SPLIT LAYOUT ── */
    .contact-sec { background: var(--bg); }
    .contact-inner {
      display: grid;
      grid-template-columns: 380px 1fr;
      gap: 0;
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 24px 80px oklch(22% 0.093 282 / .12);
    }

    /* LEFT PANEL */
    .contact-panel {
      background: var(--navy);
      position: relative;
      padding: clamp(40px, 5vw, 64px);
      display: flex; flex-direction: column; gap: 40px;
      overflow: hidden;
    }
    .contact-panel::before {
      content: '';
      position: absolute; inset: 0; z-index: 0;
      background-image: linear-gradient(oklch(99% 0.005 88 / .025) 1px, transparent 1px), linear-gradient(90deg, oklch(99% 0.005 88 / .025) 1px, transparent 1px);
      background-size: 48px 48px;
    }
    .contact-panel > * { position: relative; z-index: 1; }

    .cp-top { display: flex; flex-direction: column; gap: 16px; }
    .cp-top .lbl { color: var(--orange); }
    .cp-top h2 { font-family: var(--ff-d); font-weight: 900; font-size: clamp(22px, 2.5vw, 32px); letter-spacing: -0.03em; color: var(--ink); line-height: 1.1; }
    .cp-top h2 em { font-style: normal; color: var(--orange); }
    .cp-top p { font-size: 13px; color: oklch(99% 0.005 88 / .48); line-height: 1.75; }

    .cp-info { display: flex; flex-direction: column; gap: 22px; }
    .cp-info-item { display: flex; align-items: flex-start; gap: 14px; }
    .cp-info-ico {
      width: 38px; height: 38px; border-radius: 6px; flex-shrink: 0;
      background: oklch(99% 0.005 88 / .07); border: 1px solid oklch(99% 0.005 88 / .12);
      display: flex; align-items: center; justify-content: center; color: var(--orange);
    }
    .cp-info-ico svg { display: block; }
    .cp-info-lbl { font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: oklch(99% 0.005 88 / .3); margin-bottom: 4px; }
    .cp-info-val { font-size: 13px; color: oklch(99% 0.005 88 / .72); line-height: 1.55; }
    .cp-info-val a { color: oklch(99% 0.005 88 / .72); transition: color .2s; }
    .cp-info-val a:hover { color: var(--orange); }

    .cp-hours { padding: 18px 20px; background: oklch(99% 0.005 88 / .05); border: 1px solid oklch(99% 0.005 88 / .1); border-radius: 6px; }
    .cp-hours-row { display: flex; justify-content: space-between; align-items: center; font-size: 12px; }
    .cp-hours-row + .cp-hours-row { margin-top: 10px; padding-top: 10px; border-top: 1px solid oklch(99% 0.005 88 / .07); }
    .cp-hours-day { color: oklch(99% 0.005 88 / .45); font-weight: 500; }
    .cp-hours-time { color: var(--ink); font-weight: 600; }
    .cp-hours-time.closed { color: oklch(99% 0.005 88 / .3); }

    .cp-soc { display: flex; gap: 8px; }
    .cp-soc-a { width: 34px; height: 34px; border-radius: 4px; background: oklch(99% 0.005 88 / .06); border: 1px solid oklch(99% 0.005 88 / .12); display: flex; align-items: center; justify-content: center; color: oklch(99% 0.005 88 / .42); transition: all .2s; }
    .cp-soc-a svg { display: block; }
    .cp-soc-a:hover { background: var(--orange); border-color: var(--orange); color: var(--ink); }

    /* RIGHT PANEL */
    .contact-form-wrap {
      background: var(--ink);
      padding: clamp(40px, 5vw, 64px);
      display: flex; flex-direction: column; gap: 36px;
    }

    .cf-top h3 { font-family: var(--ff-d); font-weight: 900; font-size: clamp(22px, 2.5vw, 34px); letter-spacing: -0.03em; color: var(--forest); line-height: 1.15; margin-bottom: 10px; }
    .cf-top h3 em { font-style: normal; color: var(--orange); }
    .cf-top p { font-size: 14px; color: var(--muted); line-height: 1.7; }

    /* Inquiry type cards */
    .inq-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
    .inq-card {
      padding: 22px 12px 18px; border-radius: 10px;
      border: 1.5px solid oklch(22% 0.093 282 / .10);
      background: transparent; cursor: pointer;
      display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center;
      transition: all .2s; font-family: var(--ff-b);
    }
    .inq-card:hover { border-color: var(--orange); background: oklch(74.9% 0.166 61 / .04); transform: translateY(-2px); box-shadow: 0 8px 24px oklch(22% 0.093 282 / .07); }
    .inq-card.selected { border-color: var(--orange); background: oklch(74.9% 0.166 61 / .07); box-shadow: 0 4px 16px oklch(74.9% 0.166 61 / .15); }
    .inq-card-ico {
      width: 52px; height: 52px; border-radius: 50%;
      background: oklch(22% 0.093 282 / .06); border: 1px solid oklch(22% 0.093 282 / .08);
      display: flex; align-items: center; justify-content: center;
      color: var(--navy); transition: background .2s, color .2s, border-color .2s;
    }
    .inq-card.selected .inq-card-ico,
    .inq-card:hover .inq-card-ico { background: var(--orange); border-color: var(--orange); color: var(--ink); }
    .inq-card-lbl { font-size: 11px; font-weight: 700; color: var(--forest); line-height: 1.35; letter-spacing: .01em; }

    /* Form */
    .cf-form { display: flex; flex-direction: column; gap: 18px; }
    .cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
    .cf-field { display: flex; flex-direction: column; gap: 7px; }
    .cf-field label { font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: oklch(22% 0.093 282 / .45); }
    .cf-field input,
    .cf-field select,
    .cf-field textarea {
      font-family: var(--ff-b); font-size: 14px; font-weight: 400;
      color: var(--forest); background: var(--bg);
      border: 1.5px solid oklch(22% 0.093 282 / .15);
      border-radius: 6px; padding: 12px 16px;
      transition: border-color .2s, background .2s;
      outline: none; width: 100%;
    }
    .cf-field input:focus,
    .cf-field select:focus,
    .cf-field textarea:focus { border-color: var(--orange); background: var(--ink); }
    .cf-field input::placeholder,
    .cf-field textarea::placeholder { color: oklch(22% 0.093 282 / .28); }
    .cf-field select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; cursor: pointer; }
    .cf-field textarea { resize: vertical; min-height: 110px; }

    .cf-submit { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
    .cf-submit p { font-size: 11px; color: oklch(22% 0.093 282 / .38); max-width: 34ch; line-height: 1.6; }
    .cf-btn { padding: 14px 32px; background: var(--orange); color: var(--ink); border: none; border-radius: 6px; font-family: var(--ff-b); font-size: 14px; font-weight: 700; cursor: pointer; transition: opacity .2s, transform .2s; white-space: nowrap; display: inline-flex; align-items: center; gap: 8px; }
    .cf-btn:hover { opacity: .88; transform: translateY(-1px); }

    /* success state */
    .cf-success { display: none; text-align: center; padding: 48px 24px; }
    .cf-success-ico { width: 64px; height: 64px; border-radius: 50%; background: oklch(81.3% 0.173 121 / .15); border: 2px solid oklch(81.3% 0.173 121 / .3); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; color: var(--lime); }
    .cf-success h4 { font-family: var(--ff-d); font-weight: 700; font-size: 20px; letter-spacing: -0.02em; color: var(--forest); margin-bottom: 8px; }
    .cf-success p { font-size: 14px; color: var(--muted); line-height: 1.65; }