/* =======================================================
   Rex Connect — Public CSS
   Contact form, Booking card, Calendar, Newsletter forms
   All variables inherited from Rex Luxa theme.
======================================================= */

/* ── Shared form elements ──────────────────────────────── */
.rc-form-card {
  background: var(--f, #F8F5F0);
  padding: 44px 40px;
}
.rc-form-ttl,
.rc-book-eyebrow {
  font-size: 9px; font-weight: 700; letter-spacing: 4px;
  text-transform: uppercase; color: var(--g, #B8973A); margin-bottom: 28px;
}
.rc-fg { margin-bottom: 20px; }
.rc-fl, .rc-dfl {
  display: block; font-size: 9px; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; margin-bottom: 8px;
}
.rc-fl  { color: var(--n, #0D1B2A); }
.rc-dfl { color: rgba(255,255,255,.38); }

.rc-fi, .rc-fs, .rc-ft {
  width: 100%; padding: 13px 16px; border: 1px solid var(--bdr, #E8E2D8);
  border-radius: 1px; font-family: inherit; font-size: 13px; font-weight: 300;
  color: var(--tx, #1a1918); background: #fff; outline: none;
  transition: border-color .2s;
}
.rc-fi:focus, .rc-fs:focus, .rc-ft:focus { border-color: var(--g, #B8973A); }
.rc-ft  { resize: vertical; min-height: 110px; }

/* Dark form inputs (booking panel) */
.rc-dfi, .rc-dfs {
  width: 100%; padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.1); border-radius: 1px;
  background: rgba(255,255,255,.05); color: #fff;
  font-family: inherit; font-size: 13px; font-weight: 300;
  outline: none; transition: border-color .2s; margin-bottom: 14px;
}
.rc-dfi::placeholder { color: rgba(255,255,255,.25); }
.rc-dfi:focus, .rc-dfs:focus { border-color: var(--g, #B8973A); }
.rc-dfs { color: rgba(255,255,255,.5); }
.rc-dfs option { background: #1e3451; color: #fff; }

/* Feedback banners */
.rc-ok {
  display: none; padding: 13px 18px; margin-top: 14px; border-radius: 1px;
  text-align: center; font-size: 12px; font-weight: 500;
  background: rgba(184,151,58,.08); border: 1px solid var(--g, #B8973A);
  color: var(--n, #0D1B2A);
}
.rc-err {
  display: none; padding: 13px 18px; margin-top: 14px; border-radius: 1px;
  text-align: center; font-size: 12px; font-weight: 500;
  background: rgba(200,40,40,.07); border: 1px solid #cc3333; color: #aa2222;
}
/* Dark variant (inside booking card) */
.rc-book-card .rc-ok  { color: var(--g2, #D4AF5A); background: rgba(184,151,58,.12); }
.rc-book-card .rc-err { color: #f87171; background: rgba(200,40,40,.09); }

/* ── Booking card ──────────────────────────────────────── */
.rc-book-card {
  background: var(--n, #0D1B2A);
  overflow: hidden;
}
.rc-book-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 26px; font-weight: 300; color: #fff; margin-bottom: 8px;
}
.rc-book-sub {
  font-size: 12px; font-weight: 300; color: rgba(255,255,255,.38);
  line-height: 1.7; margin-bottom: 28px; padding: 0 40px;
}
.rc-book-eyebrow { padding: 40px 40px 0; }
.rc-book-title   { padding: 0 40px; }
.rc-book-sub     { padding: 0 40px 0; }

.rc-book-tabs {
  display: flex; border-bottom: 1px solid rgba(255,255,255,.09);
  margin: 0 0 0; padding: 0 40px;
}
.rc-btab {
  flex: 1; padding: 11px 8px; text-align: center; font-size: 9px;
  font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  cursor: pointer; color: rgba(255,255,255,.32); background: none; border: none;
  border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all .2s;
}
.rc-btab.is-active, .rc-btab:hover { color: var(--g2, #D4AF5A); border-bottom-color: var(--g, #B8973A); }

.rc-tab-panel { display: none; }
.rc-tab-panel.is-active { display: block; }

.rc-manual-wrap { padding: 28px 40px 40px; }

/* Calendly placeholder */
.rc-cal-ph {
  padding: 52px 40px; text-align: center;
}
.rc-cal-ph-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px; font-weight: 300; color: #fff; margin-bottom: 10px;
}
.rc-cal-ph-sub {
  font-size: 12px; font-weight: 300; color: rgba(255,255,255,.38);
  line-height: 1.7; max-width: 280px; margin: 0 auto 22px;
}

/* ── Interactive Calendar ──────────────────────────────── */
.rc-cal-nav {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px;
}
.rc-cal-lbl {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 18px; font-weight: 300; color: var(--g2, #D4AF5A); letter-spacing: 1px;
}
.rc-cal-nb {
  background: none; border: 1px solid rgba(255,255,255,.12); color: var(--g, #B8973A);
  width: 28px; height: 28px; border-radius: 1px; font-size: 14px; display: flex;
  align-items: center; justify-content: center; cursor: pointer; transition: background .2s;
}
.rc-cal-nb:hover { background: rgba(184,151,58,.15); }
.rc-cal-grid {
  display: grid; grid-template-columns: repeat(7,1fr); gap: 3px; margin-bottom: 6px;
}
.rc-cal-dow {
  font-size: 8px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: rgba(255,255,255,.22); text-align: center; padding: 4px 0 6px;
}
.rc-cal-day {
  font-size: 11px; font-weight: 500; color: rgba(255,255,255,.42); padding: 7px 4px;
  text-align: center; border-radius: 1px; cursor: pointer; border: 1px solid transparent;
  line-height: 1; transition: all .15s;
}
.rc-cal-day:hover:not(.rc-cal-empty):not(.rc-cal-past) {
  background: rgba(184,151,58,.1); border-color: rgba(184,151,58,.3); color: var(--g2, #D4AF5A);
}
.rc-cal-empty, .rc-cal-past { cursor: default; opacity: .2; }
.rc-cal-today { border-color: rgba(184,151,58,.4); color: var(--g2, #D4AF5A); }
.rc-cal-selected {
  background: var(--g, #B8973A) !important; color: #0D1B2A !important;
  font-weight: 700; border-color: var(--g, #B8973A) !important;
}
.rc-cal-sel {
  font-size: 11px; font-weight: 500; color: var(--g2, #D4AF5A);
  text-align: center; margin: 8px 0 16px; min-height: 14px;
}

/* ── Time Slots ────────────────────────────────────────── */
.rc-slots { display: flex; flex-direction: column; gap: 8px; margin-bottom: 22px; }
.rc-slot {
  padding: 11px 16px; border: 1px solid rgba(255,255,255,.09); border-radius: 1px;
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  transition: all .2s;
}
.rc-slot:hover, .rc-slot.is-active {
  background: rgba(184,151,58,.08); border-color: var(--g, #B8973A);
}
.rc-slot-lbl  { font-size: 9.5px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--g2, #D4AF5A); }
.rc-slot-time { font-size: 11px; font-weight: 300; color: rgba(255,255,255,.35); }

/* ── Newsletter inline ─────────────────────────────────── */
.rc-nl-inline .nl-inline-form { display: flex; flex: 1; max-width: 460px; }
.rc-nl-ok {
  font-size: 11px; font-weight: 500; color: var(--g2, #D4AF5A);
  margin-top: 8px; letter-spacing: .5px;
}

/* ── Newsletter full form fields (dark) ────────────────── */
.rc-nl-full-fields { display: flex; flex-direction: column; gap: 12px; }
.rc-nl-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.rc-nfi, .rc-nfs {
  width: 100%; padding: 12px 14px; border: 1px solid rgba(255,255,255,.1); border-radius: 1px;
  background: rgba(255,255,255,.05); color: #fff; font-family: inherit;
  font-size: 12px; font-weight: 300; outline: none; transition: border-color .2s;
}
.rc-nfi::placeholder { color: rgba(255,255,255,.25); }
.rc-nfi:focus, .rc-nfs:focus { border-color: var(--g, #B8973A); }
.rc-nfs { color: rgba(255,255,255,.45); }
.rc-nfs option { background: #1e3451; color: #fff; }

/* ── Inline subscriber info blocks (connect page) ──────── */
.ci {
  background: var(--f, #F8F5F0); padding: 28px 24px; text-align: center;
  border-top: 3px solid var(--g, #B8973A);
}
.ci-ico { font-size: 28px; margin-bottom: 12px; }
.ci-lbl { font-size: 8.5px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--g, #B8973A); margin-bottom: 6px; }
.ci-val { font-size: 12px; font-weight: 300; color: var(--n, #0D1B2A); }

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 900px) {
  .rc-form-card, .rc-manual-wrap { padding: 28px 24px; }
  .rc-book-eyebrow, .rc-book-title, .rc-book-sub, .rc-book-tabs { padding-left: 24px; padding-right: 24px; }
  .rc-cal-ph { padding: 36px 24px; }
}
@media (max-width: 600px) {
  .rc-nl-row { grid-template-columns: 1fr; }
}

/* ── Inline field validation ───────────────────────────────
   No alert() dialogs — errors appear directly under fields.
─────────────────────────────────────────────────────────── */
.rc-invalid {
  border-color: #cc3333 !important;
  background-color: rgba(200,40,40,.04) !important;
}
.rc-field-err {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: #cc3333;
  margin-top: 5px;
  letter-spacing: .2px;
  line-height: 1.4;
}
/* Dark-panel variant (booking form) */
.rc-book-card .rc-invalid { border-color: #f87171 !important; }
.rc-book-card .rc-field-err { color: #f87171; }

/* Date selector invalid state */
.rc-cal-sel.rc-invalid {
  color: #f87171;
  font-weight: 600;
}

/* Input focus resets invalid state */
.rc-fi:focus.rc-invalid,
.rc-dfi:focus.rc-invalid,
.rc-nfi:focus.rc-invalid {
  border-color: var(--g, #B8973A) !important;
  background: rgba(255,255,255,.05) !important;
}
