/* =====================================================
   Amigo Book-a-Call Page — amigo-book-call.css
   Extracted from book-a-call-soft.html
   NAV + FOOTER rules intentionally omitted (theme-owned)
   Font URLs changed to absolute (uploads/2026/04/)
   ===================================================== */

@font-face {
  font-family: "Arial Rounded Bold";
  src: url("https://amigopersonalcare.com.au/wp-content/uploads/2026/04/Arial-Rounded-Bold-1.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Montserrat";
  src: url("https://amigopersonalcare.com.au/wp-content/uploads/2026/04/Montserrat-VariableFont_wght.ttf") format("truetype-variations");
  font-weight: 100 900; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Montserrat";
  src: url("https://amigopersonalcare.com.au/wp-content/uploads/2026/04/Montserrat-Bold.ttf") format("truetype");
  font-weight: 700; font-style: normal; font-display: swap;
}

:root {
  --teal: #447E98;
  --teal-dark: #147a98;
  --teal-deep: #0D6060;
  --teal-mid: #1A9898;
  --teal-pale: #E2F7F7;
  --teal-ice: #F2FAFB;
  --accent: #36DCFB;
  --accent-deep: #1ABFBF;
  --accent-pale: #DDF0F6;
  --ink-700: #447E98;
  --ink-500: #2C3E50;
  --gray-700: #7A7A7A;
  --gray-500: #7A7A7A;
  --gray-300: #B8D0D8;
  --gray-100: #E8EEF1;
  --bg: #FDFCFA;
  --bg-soft: #F6F9FB;
  --hairline: rgba(20, 122, 152, 0.12);
  --shadow-amb: 0 1px 2px rgba(15,31,44,0.04),
                0 8px 24px rgba(15,31,44,0.04),
                0 40px 80px -20px rgba(13,96,96,0.10);
  --shadow-lift: 0 2px 4px rgba(15,31,44,0.05),
                 0 20px 48px rgba(15,31,44,0.08),
                 0 60px 120px -30px rgba(13,96,96,0.16);
  --shadow-teal: 0 20px 48px -12px rgba(26,152,152,0.38);

  --ease-spring: cubic-bezier(0.32, 0.72, 0, 1);
  --ease-fluid:  cubic-bezier(0.22, 1, 0.36, 1);
  --d-fast: 220ms;
  --d-med:  420ms;
  --d-slow: 720ms;
}

/* ---- base reset (scoped so we don't bleed to theme) ---- */
.amigo-book-call-page * { box-sizing: border-box; }
.amigo-book-call-page {
  font-family: "Montserrat", system-ui, -apple-system, sans-serif;
  font-weight: 300;
  font-size: 20px;
  line-height: 1.6;
  color: #7A7A7A;
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
.amigo-book-call-page img { max-width: 100%; display: block; }
.amigo-book-call-page button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
.amigo-book-call-page a { color: inherit; text-decoration: none; }

.amigo-book-call-page h1,
.amigo-book-call-page h2 {
  font-family: "Arial Rounded Bold", "Arial Rounded MT Bold", sans-serif;
  font-style: italic;
  font-weight: 700;
  color: #447E98;
  line-height: 1.08;
  letter-spacing: -0.01em;
}
.amigo-book-call-page h3 {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  color: #7A7A7A;
  font-size: 22px;
  line-height: 1.3;
}
.amigo-book-call-page p { max-width: 62ch; }

.amigo-book-call-page .eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 16px; border-radius: 999px;
  background: var(--teal-pale); color: var(--teal-deep);
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.18em;
}
.amigo-book-call-page .eyebrow::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-deep);
  box-shadow: 0 0 0 3px rgba(26,191,191,0.22);
}

/* ============ PROGRESS PILL ============ */
.progress-pill-bar {
  position: relative;
  padding: 20px 32px 0;
  z-index: 2;
  margin-top: 110px;
}
.progress-pill {
  max-width: 1240px; margin: 0 auto;
  display: inline-flex; align-items: center; gap: 14px;
  padding: 8px 18px 8px 8px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--hairline);
  box-shadow: var(--shadow-amb);
  font-size: 13px; color: var(--gray-700);
}
.progress-dot {
  width: 26px; height: 26px; border-radius: 999px;
  background: linear-gradient(135deg, #36DCFB, #1A9898); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.progress-pill strong { color: var(--teal-deep); font-weight: 700; }

/* ============ HERO-FILTER ============ */
.hero-filter {
  position: relative;
  padding: 24px 32px 100px;
  overflow: hidden;
  background:
    radial-gradient(1100px 600px at 10% 0%, rgba(54,220,251,0.12), transparent 60%),
    radial-gradient(900px 600px at 95% 20%, rgba(26,191,191,0.10), transparent 60%),
    linear-gradient(180deg, #FDFCFA 0%, #F6F9FB 100%);
}
.hero-inner {
  position: relative; z-index: 1;
  max-width: 1240px; margin: 0 auto;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 56px;
  align-items: start;
  padding-top: 32px;
}
.hero-eyebrow { margin-bottom: 22px; }
.hero-filter h1 {
  font-size: clamp(40px, 5.4vw, 68px);
  margin-bottom: 20px;
  color: #447E98;
  letter-spacing: -0.015em;
}
.hero-filter h1 .soft {
  display: block;
  color: var(--teal-deep);
}
.hero-lede {
  font-size: 19px; color: #7A7A7A; font-weight: 300;
  max-width: 50ch; margin-bottom: 28px;
}

.hero-reassure {
  list-style: none;
  padding: 0; margin: 0 0 32px;
  display: flex; flex-direction: column; gap: 10px;
}
.hero-reassure li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 15px; color: var(--gray-700);
}
.hero-reassure strong { color: var(--teal-deep); font-weight: 700; }
.hero-reassure .check {
  width: 22px; height: 22px; flex: 0 0 22px;
  border-radius: 999px;
  background: linear-gradient(135deg, #36DCFB, #1A9898);
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: 2px;
}

/* ============ FORM (primary focus) ============ */
.hero-form { position: relative; }
.form-wrap {
  padding: 8px;
  border-radius: 32px;
  background: linear-gradient(160deg, rgba(255,255,255,0.92), rgba(242,250,251,0.6));
  border: 1px solid rgba(255,255,255,0.9);
  box-shadow: var(--shadow-lift);
  position: sticky;
  top: 110px;
}
.form-core {
  border-radius: 26px;
  background: linear-gradient(180deg, #ffffff 0%, #FBFDFD 100%);
  padding: 36px;
  min-height: 560px;
  box-shadow: inset 0 1px 1px rgba(255,255,255,0.95);
}
.form-core-head {
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px dashed var(--hairline);
}
.form-core-head .step-label {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 4px 12px; border-radius: 999px;
  background: var(--accent-pale); color: var(--teal-deep);
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.14em;
  margin-bottom: 10px;
}
.form-core-head h3 {
  font-family: "Arial Rounded Bold", sans-serif;
  font-style: italic; color: #447E98;
  font-size: 24px; font-weight: 700; margin-bottom: 4px;
}
.form-core-head p { font-size: 14px; color: var(--gray-700); }

@media (max-width: 960px) {
  .progress-pill-bar { margin-top: 100px; padding: 16px 20px 0; }
  .hero-filter { padding: 20px 20px 70px; }
  .hero-inner { grid-template-columns: 1fr; gap: 36px; padding-top: 20px; }
  .form-wrap { position: static; }
  .form-core { padding: 24px; min-height: 460px; }
}

/* ============ TRUST BAND ============ */
.band {
  padding: 24px 32px;
  background: #fff;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.band-inner {
  max-width: 1240px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 18px;
}
.band-item {
  display: flex; align-items: center; gap: 12px;
  font-size: 13px; color: var(--gray-700);
}
.band-item strong {
  font-family: "Arial Rounded Bold", sans-serif;
  font-style: italic; color: var(--teal-deep);
  font-size: 15px; font-weight: 700;
}
.band-divider { width: 1px; height: 28px; background: var(--hairline); }
.band-ico {
  width: 34px; height: 34px; border-radius: 999px;
  background: var(--teal-pale); color: var(--teal-deep);
  display: inline-flex; align-items: center; justify-content: center;
}
@media (max-width: 840px) {
  .band-divider { display: none; }
  .band-inner { justify-content: flex-start; }
  .band-item { flex-basis: calc(50% - 12px); }
}

/* ============ MINI FAQ ============ */
.faq {
  padding: 100px 32px;
  background: linear-gradient(180deg, #FDFCFA 0%, #F2FAFB 100%);
}
.faq-inner { max-width: 820px; margin: 0 auto; }
.faq-head { text-align: center; margin-bottom: 40px; }
.faq-head .eyebrow { margin-bottom: 16px; }
.faq-head h2 { font-size: clamp(28px, 3.6vw, 42px); }
.faq-head p { margin: 10px auto 0; font-size: 16px; max-width: 540px; color: var(--gray-700); }
.faq-list { display: flex; flex-direction: column; gap: 14px; }
.faq-item {
  padding: 4px;
  border-radius: 22px;
  background: linear-gradient(160deg, rgba(255,255,255,0.9), rgba(242,250,251,0.5));
  border: 1px solid rgba(255,255,255,0.9);
  box-shadow: var(--shadow-amb);
  transition: box-shadow var(--d-med);
}
.faq-item[open] { box-shadow: var(--shadow-lift); }
.faq-item summary {
  list-style: none;
  padding: 20px 24px;
  border-radius: 18px;
  cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  gap: 20px;
  font-family: "Arial Rounded Bold", sans-serif;
  font-style: italic; color: #447E98;
  font-size: 18px; font-weight: 700;
  background: #fff;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-plus {
  width: 30px; height: 30px; flex: 0 0 30px;
  border-radius: 999px; background: var(--teal-pale); color: var(--teal-deep);
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform var(--d-fast) var(--ease-spring);
}
.faq-item[open] .faq-plus { transform: rotate(45deg); background: var(--teal-deep); color: #fff; }
.faq-body { padding: 4px 24px 22px; font-size: 15px; color: var(--gray-700); }
@media (max-width: 700px) {
  .faq { padding: 70px 20px; }
  .faq-item summary { padding: 18px 20px; font-size: 16px; }
  .faq-body { padding: 4px 20px 18px; }
}

/* ============ #amigo-router EMBEDDED in .form-core ============
   The inline <style> in the template has:
     #amigo-router * { margin:0; padding:0 }   (specificity 1-0-1)
   We beat it with ID+class selectors + !important (specificity 1-1-0)
   ============================================================= */

/* Layout: block, transparent, full-width */
#amigo-router {
  display: block !important;
  min-height: unset !important;
  height: auto !important;
  background: transparent !important;
  border-radius: 0 !important;
  overflow: visible !important;
}
#amigo-router .ar-left  { display: none !important; }   /* removed from HTML too — belt+braces */
#amigo-router .ar-right { display: block !important; padding: 0 !important; background: transparent !important; }
#amigo-router .ar-form  { max-width: 100% !important; width: 100% !important; }

/* Spacing — restore margins wiped by #amigo-router *{margin:0;padding:0} */
#amigo-router .dots       { display: flex !important; gap: 8px !important; margin-bottom: 20px !important; }
#amigo-router .tag        { display: inline-flex !important; margin-bottom: 16px !important; }
#amigo-router .step-title { color: #447E98 !important; margin-bottom: 6px !important; font-size: 22px !important; font-weight: 800 !important; line-height: 1.22 !important; }
#amigo-router .step-sub   { color: #7a9aa5 !important; margin-bottom: 20px !important; font-size: 14px !important; line-height: 1.5 !important; }
#amigo-router .q-label    { display: block !important; margin-bottom: 8px !important; font-size: 13px !important; font-weight: 700 !important; color: #447E98 !important; text-transform: uppercase !important; letter-spacing: .3px !important; }
#amigo-router .q-input,
#amigo-router .q-textarea { display: block !important; width: 100% !important; padding: 14px 16px !important; border: 2px solid #d8edf2 !important; border-radius: 12px !important; font-size: 15px !important; color: #1a3a4a !important; background: #fff !important; }
#amigo-router .q-input:focus,
#amigo-router .q-textarea:focus { border-color: #36DCFB !important; box-shadow: 0 0 0 4px rgba(54,220,251,.15) !important; }
#amigo-router .next-btn   { margin-top: 14px !important; }
#amigo-router .back-lnk   { margin-top: 12px !important; }

/* ============ REVEAL ============ */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  filter: blur(4px);
  transition: opacity var(--d-slow) var(--ease-fluid),
              transform var(--d-slow) var(--ease-fluid),
              filter var(--d-slow) var(--ease-fluid);
}
.reveal.in { opacity: 1; transform: translateY(0); filter: blur(0); }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; filter: none; transition: none; }
  .amigo-book-call-page * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}
