/* ============================================================
   Masonic Lodge Websites - marketing site
   Direction matched to pglcornwall.org.uk:
   light, deep navy (#13325E) + warm brick red (#C44C3A) accent,
   Raleway sans for body/nav, an elegant serif for big headlines.
   No gold, no thin accent bars, minimal lines.
   ============================================================ */

:root {
  --navy:    #13325e;   /* primary                        */
  --navy-2:  #0e2647;   /* deepest navy                   */
  --navy-3:  #1c3f72;   /* lifted navy                    */
  --red:     #c44c3a;   /* warm brick-red accent          */
  --red-2:   #a83d2e;   /* red hover                       */
  --red-soft:#f3e2de;   /* faint red wash                  */

  --bg:      #ffffff;   /* page                            */
  --bg-2:    #f5f5f2;   /* soft panel                      */
  --bg-3:    #ebebe7;   /* deeper panel                    */
  --text:    #22272e;   /* near-black slate                */
  --text-soft:#525860;
  --text-dim:#7a7f85;
  --on-navy: #ffffff;
  --on-navy-soft: rgba(255,255,255,0.82);
  --on-navy-eyebrow: #e3a394;  /* light terracotta on navy */
  --line:    #e4e4e0;
  --line-soft: rgba(20,30,55,0.08);

  /* aliases for inline styles in views (gold -> red, etc.) */
  --paper: var(--bg); --paper-2: var(--bg-2);
  --ink: var(--text); --ink-soft: var(--text-soft); --navy-deep: var(--navy-2);
  --gold: var(--red); --gold-deep: var(--red-2); --gold-2: var(--red-2);
  --gold-bright: var(--on-navy-eyebrow); --gold-soft: var(--red-soft);
  --line-ink: var(--line);

  --display: "EB Garamond", Georgia, "Times New Roman", serif;
  --body: "Raleway", Helvetica, Arial, sans-serif;

  --maxw: 1180px;
  --measure: 66ch;
}

* , *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--text);
  font-family: var(--body); font-size: 18px; font-weight: 400; line-height: 1.7;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
::selection { background: var(--navy); color: #fff; }

h1, h2, h3 { font-family: var(--display); font-weight: 500; line-height: 1.1; color: var(--navy); margin: 0; }
p { margin: 0; max-width: var(--measure); }
a { color: var(--red-2); text-decoration: none; }

.shell { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

/* Eyebrow label - uppercase Raleway, brick red */
.label { display: inline-block; font-family: var(--body); font-weight: 700; font-size: 13px;
  letter-spacing: .16em; text-transform: uppercase; color: var(--red); margin-bottom: 10px; }

/* Buttons - solid, confident, lightly rounded (matches reference) */
.btn {
  display: inline-flex; align-items: center; gap: 9px; font-family: var(--body); font-weight: 600; font-size: 16px;
  padding: 13px 26px; border-radius: 4px; cursor: pointer; color: var(--navy);
  background: transparent; border: 1.5px solid var(--navy); transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.btn:hover { background: var(--navy); color: #fff; }
.btn--gold { background: var(--red); border-color: var(--red); color: #fff; }
.btn--gold:hover { background: var(--red-2); border-color: var(--red-2); color: #fff; }
.btn--ghost-light { color: #fff; border-color: rgba(255,255,255,0.55); }
.btn--ghost-light:hover { background: #fff; color: var(--navy); border-color: #fff; }

.diamond { width: 9px; height: 9px; background: var(--red); transform: rotate(45deg); display: inline-block; }
.rule-pair, .chequer { height: 1px; background: var(--line); }

/* ── Header (navy, with crest, like the reference) ──────────── */
.mhead { position: sticky; top: 0; z-index: 40; background: var(--navy); border-bottom: 3px solid var(--red); }
.mhead .shell { display: flex; align-items: center; gap: 18px; min-height: 78px; }
.mbrand { display: inline-flex; align-items: center; gap: 13px; color: #fff; font-family: var(--display); font-weight: 600; font-size: 23px; line-height: 1.05; }
.mbrand .crest { width: 40px; height: auto; display: block; }
.mhead-nav { margin-left: auto; display: flex; align-items: center; gap: 2px; }
.mhead-nav a { display: inline-flex; align-items: center; color: rgba(255,255,255,0.85); font-size: 15px; font-weight: 600; padding: 10px 14px; border-radius: 4px; line-height: 1; }
.mhead-nav a:hover { color: #fff; }
.mhead-nav a.is-current { color: var(--on-navy-eyebrow); }
.mhead-nav .signin { color: #fff; }
.mhead-nav .signup { color: #fff; background: var(--red); padding: 11px 20px; border-radius: 4px; margin-left: 8px; }
.mhead-nav .signup:hover { background: var(--red-2); color: #fff; }
.mnav-toggle { display: none; margin-left: auto; flex-direction: column; gap: 4px; width: 46px; height: 42px; border: 1.5px solid rgba(255,255,255,0.5); background: transparent; border-radius: 4px; cursor: pointer; align-items: center; justify-content: center; }
.mnav-toggle span { width: 20px; height: 2px; background: #fff; display: block; transition: transform .2s, opacity .2s; }
.mnav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.mnav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.mnav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
@media (max-width: 900px) {
  .mnav-toggle { display: flex; }
  .mhead-nav { display: none; position: absolute; left: 0; right: 0; top: 100%; flex-direction: column; align-items: stretch; gap: 0;
    background: var(--navy); border-bottom: 3px solid var(--red); padding: 8px 28px 18px; box-shadow: 0 20px 40px -28px rgba(8,16,30,.6); }
  .mhead-nav.open { display: flex; }
  .mhead-nav a { padding: 15px 8px; font-size: 17px; border-top: 1px solid rgba(255,255,255,0.12); }
  .mhead-nav .signup, .mhead-nav .signin { text-align: center; justify-content: center; margin: 10px 0 0; }
  .mhead-nav .signup { border-top: 0; }
}

/* ── Hero ───────────────────────────────────────────────────── */
.hero { position: relative; text-align: center; padding: clamp(72px, 12vh, 128px) 0 clamp(52px, 8vh, 92px); background: var(--bg-2); }
.hero::before, .hero::after { content: none; }
.hero .shell { position: relative; z-index: 2; max-width: 900px; }
.hero .crest { width: 64px; height: 64px; margin: 0 auto 24px; border-radius: 50%; border: 2px solid var(--red);
  display: grid; place-items: center; }
.hero .crest .diamond { width: 15px; height: 15px; }
.hero h1 { font-size: clamp(42px, 6.4vw, 76px); font-weight: 500; line-height: 1.04; margin: 14px 0 0; }
.hero .sub { font-size: clamp(18px, 2vw, 22px); color: var(--text-soft); margin: 22px auto 0; max-width: 46ch; line-height: 1.55; }
.hero .ctas { display: flex; gap: 13px; justify-content: center; flex-wrap: wrap; margin-top: 34px; }
.hero .fine { margin: 26px auto 0; font-size: 13px; letter-spacing: .1em; color: var(--text-dim); text-transform: uppercase; }
.hero .seal { margin: 36px auto 0; display: flex; align-items: center; justify-content: center; gap: 16px; }
.hero .seal span { height: 1px; width: 54px; background: var(--red); opacity: .5; }

/* Navy hero band (home) - white serif headline over deep navy, like the reference banner */
.hero--navy { background: var(--navy); color: var(--on-navy-soft); }
.hero--navy .label { color: var(--on-navy-eyebrow); }
.hero--navy h1 { color: #fff; }
.hero--navy .sub { color: var(--on-navy-soft); }
.hero--navy .fine { color: rgba(255,255,255,0.6); }
.hero--navy .crest { border-color: var(--red); }
.hero--navy .seal span { background: rgba(255,255,255,0.4); }
.hero--navy .btn { color: #fff; border-color: rgba(255,255,255,0.55); }
.hero--navy .btn:hover { background: #fff; color: var(--navy); border-color: #fff; }
.hero--navy .btn--gold { background: var(--red); border-color: var(--red); color: #fff; }
.hero--navy .btn--gold:hover { background: var(--red-2); border-color: var(--red-2); }

/* Photographic hero (home): full-bleed image, navy scrim, white serif over it */
.hero--photo {
  background:
    linear-gradient(180deg, rgba(13,30,55,0.62), rgba(10,22,42,0.84)),
    url("img/hero.jpg") center / cover no-repeat;
  color: var(--on-navy-soft);
  padding: clamp(94px, 15vh, 172px) 0 clamp(70px, 11vh, 132px);
}
.hero--photo .label { color: var(--on-navy-eyebrow); }
.hero--photo h1 { color: #fff; }
.hero--photo .sub { color: rgba(255,255,255,0.9); }
.hero--photo .fine { color: rgba(255,255,255,0.7); }
.hero--photo .crest { border-color: var(--red); }
.hero--photo .seal span { background: rgba(255,255,255,0.45); }
.hero--photo .btn { color: #fff; border-color: rgba(255,255,255,0.55); }
.hero--photo .btn:hover { background: #fff; color: var(--navy); border-color: #fff; }
.hero--photo .btn--gold { background: var(--red); border-color: var(--red); color: #fff; }
.hero--photo .btn--gold:hover { background: var(--red-2); border-color: var(--red-2); }
.hero--image { background: var(--navy-2) center / cover no-repeat; color: var(--on-navy-soft); }
.hero--image h1 { color: #fff; }

/* Image-and-text feature band (like the reference's photo sections) */
.feature { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 6vw, 72px); align-items: center; }
.feature-media img { width: 100%; height: clamp(280px, 42vh, 460px); object-fit: cover; border-radius: 8px; display: block; box-shadow: 0 30px 60px -44px rgba(19,50,94,0.5); }
.feature.rev .feature-media { order: 2; }
.feature-text h2 { font-size: clamp(30px, 4vw, 46px); margin: 6px 0 0; }
.feature-text p.body { margin-top: 16px; color: var(--text-soft); font-size: 18px; }
.feature-text .btn { margin-top: 26px; }
.sec--ink .feature-text p.body { color: var(--on-navy-soft); }
@media (max-width: 820px) { .feature { grid-template-columns: 1fr; gap: 28px; } .feature.rev .feature-media { order: 0; } }

/* ── Sections ───────────────────────────────────────────────── */
.sec { padding: clamp(60px, 9vh, 112px) 0; }
.sec--paper2 { background: var(--bg-2); }
.sec--ink { background: var(--navy); color: var(--on-navy-soft); }
.sec--ink h1, .sec--ink h2, .sec--ink h3 { color: #fff; }
.sec--ink p, .sec--ink blockquote { color: var(--on-navy-soft); }
.sec--ink .label { color: var(--on-navy-eyebrow); }
.sec--ink .btn { color: #fff; border-color: rgba(255,255,255,0.5); }
.sec--ink .btn:hover { background: #fff; color: var(--navy); border-color: #fff; }
.sec--ink .btn--gold { background: var(--red); border-color: var(--red); color: #fff; }
.sec--ink .btn--gold:hover { background: var(--red-2); border-color: var(--red-2); }

/* Editorial two-column: heading rail + content */
.split { display: grid; grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr); gap: clamp(32px, 6vw, 80px); align-items: start; }
@media (max-width: 820px) { .split { grid-template-columns: 1fr; gap: 36px; } .rail--sticky { position: static; top: auto; } }
.rail h2 { font-size: clamp(32px, 4.2vw, 50px); margin: 6px 0 0; }
.rail .label { margin-bottom: 6px; }
.rail p { margin-top: 16px; color: var(--text-soft); font-size: 18px; }
.rail--sticky { position: sticky; top: 100px; }
.sec--ink .rail p { color: var(--on-navy-soft); }

/* Index list - numbered rows with a red numeral, light separators */
.index { list-style: none; margin: 0; padding: 0; }
.index li { display: grid; grid-template-columns: auto 1fr; gap: 20px; align-items: start; padding: 20px 0; border-top: 1px solid var(--line); }
.index li:last-child { border-bottom: 1px solid var(--line); }
.index .n { font-family: var(--display); font-weight: 600; font-size: 22px; color: var(--red); line-height: 1.2; }
.index h3 { font-family: var(--body); font-weight: 700; font-size: 18px; color: var(--navy); margin: 0 0 4px; }
.index p { font-size: 16.5px; color: var(--text-soft); margin: 0; max-width: 56ch; }
.sec--ink .index li { border-color: rgba(255,255,255,0.16); }
.sec--ink .index h3 { color: #fff; }
.sec--ink .index p { color: var(--on-navy-soft); }
.sec--ink .index .n { color: var(--on-navy-eyebrow); }

/* Steps - large serif numerals */
.steps { display: grid; gap: 0; margin-top: 8px; }
.stepr { display: grid; grid-template-columns: clamp(70px, 10vw, 116px) 1fr; gap: clamp(24px, 4vw, 52px); align-items: start; padding: 36px 0; border-top: 1px solid rgba(255,255,255,0.16); }
.stepr:last-child { border-bottom: 1px solid rgba(255,255,255,0.16); }
.stepr .big { font-family: var(--display); font-weight: 600; font-size: clamp(52px, 8vw, 92px); line-height: .9; color: var(--on-navy-eyebrow); }
.stepr h3 { font-size: clamp(25px, 3vw, 34px); margin: 0 0 10px; color: #fff; }
.stepr p { color: var(--on-navy-soft); font-size: 17.5px; }

/* ── Pricing card ───────────────────────────────────────────── */
.pricewrap { display: grid; place-items: center; }
.cert {
  width: min(520px, 100%); background: #fff; position: relative; border: 1px solid var(--line); border-radius: 8px;
  padding: clamp(34px, 5vw, 50px) clamp(28px, 5vw, 52px); text-align: center;
  box-shadow: 0 30px 60px -44px rgba(19,50,94,0.5);
}
.cert .label { display: block; }
.cert .amount { font-family: var(--display); font-weight: 600; font-size: clamp(60px, 11vw, 86px); line-height: 1; margin: 8px 0 4px; color: var(--navy); }
.cert .per { color: var(--text-soft); font-size: 15px; letter-spacing: .12em; text-transform: uppercase; }
.cert .setup { margin: 18px auto 0; font-size: 16px; color: var(--text-soft); max-width: 42ch; }
.cert .setup b { color: var(--text); }
.cert hr { border: 0; border-top: 1px solid var(--line); margin: 28px 0; }
.cert .incl { list-style: none; margin: 0 0 28px; padding: 0; text-align: left; display: grid; gap: 13px; }
.cert .incl li { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; font-size: 16.5px; color: var(--text); }
.cert .incl .tick { color: var(--red); font-size: 13px; line-height: 1.5; }
.cert .btn { width: 100%; justify-content: center; }
.cert .seal-d { width: 12px; height: 12px; background: var(--red); transform: rotate(45deg); margin: 0 auto 14px; }

/* ── FAQ ────────────────────────────────────────────────────── */
.faq { max-width: 800px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--line); }
.faq summary { cursor: pointer; list-style: none; padding: 22px 4px; display: flex; justify-content: space-between; gap: 20px;
  font-family: var(--display); font-weight: 600; font-size: 22px; color: var(--navy); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pm { color: var(--red); font-size: 26px; line-height: 1; transition: transform .2s; font-family: var(--body); }
.faq details[open] summary .pm { transform: rotate(45deg); }
.faq .ans { padding: 0 4px 24px; color: var(--text-soft); font-size: 17px; max-width: 72ch; }

/* ── Comparison table ───────────────────────────────────────── */
.compare { width: 100%; border-collapse: collapse; font-size: 16px; margin-top: 8px; }
.compare caption { text-align: left; color: var(--text-soft); margin-bottom: 16px; }
.compare th, .compare td { text-align: left; padding: 16px 18px; border-bottom: 1px solid var(--line); vertical-align: top; }
.compare thead th { font-family: var(--body); font-weight: 700; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; color: var(--text-soft); border-bottom: 2px solid var(--navy); }
.compare thead th.us { color: var(--red); }
.compare tbody th { font-weight: 600; color: var(--navy); }
.compare td { color: var(--text-soft); }
.compare td.us { background: var(--red-soft); color: var(--text); }
.compare .yes { color: var(--red-2); font-weight: 700; }

/* ── Pull quote (on navy) ───────────────────────────────────── */
.quote { text-align: center; }
.quote .shell { max-width: 920px; }
.quote blockquote { margin: 0; font-family: var(--display); font-weight: 500; font-style: italic; font-size: clamp(26px, 3.6vw, 42px); line-height: 1.25; color: #fff; }
.quote .mk { font-family: var(--display); font-weight: 600; font-size: 70px; color: var(--on-navy-eyebrow); line-height: 0; display: block; height: 34px; }
.quote cite { display: block; margin-top: 22px; font-style: normal; font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: var(--on-navy-eyebrow); font-family: var(--body); }

/* ── Long-form prose (guides, about, legal) ─────────────────── */
.prose { max-width: 70ch; margin: 0 auto; font-size: 18.5px; line-height: 1.78; color: var(--text); }
.prose > * + * { margin-top: 20px; }
.prose h2 { font-size: clamp(28px, 3.4vw, 40px); margin-top: 50px; color: var(--navy); }
.prose h3 { font-family: var(--body); font-weight: 700; font-size: 20px; margin-top: 36px; color: var(--navy); }
.prose p, .prose li { color: var(--text-soft); }
.prose strong { color: var(--text); font-weight: 700; }
.prose ul, .prose ol { padding-left: 1.3em; }
.prose li { margin-top: 9px; }
.prose .keytake { background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px; padding: 24px 28px; }
.prose .keytake h3 { margin: 0 0 8px; color: var(--red-2); }
.prose .keytake p { margin: 0; color: var(--text); }
.prose a { color: var(--red-2); font-weight: 600; }
.lead { font-family: var(--display); font-size: clamp(21px, 2.5vw, 27px); line-height: 1.45; color: var(--navy); font-weight: 500; }

/* ── Contact ────────────────────────────────────────────────── */
.contactgrid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: clamp(32px, 6vw, 72px); align-items: start; }
@media (max-width: 800px) { .contactgrid { grid-template-columns: 1fr; gap: 36px; } }
.cform { display: grid; gap: 16px; }
.cform .field { display: grid; gap: 7px; }
.cform label { font-weight: 600; font-size: 15.5px; color: var(--navy); }
.cform input, .cform textarea { font: 17px var(--body); color: var(--text); padding: 13px 15px; border: 1px solid var(--line); border-radius: 4px; background: #fff; width: 100%; box-sizing: border-box; }
.cform textarea { min-height: 156px; resize: vertical; }
.cform input::placeholder, .cform textarea::placeholder { color: var(--text-dim); }
.cform input:focus, .cform textarea:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3px var(--red-soft); }
.note { padding: 15px 18px; border: 1px solid; border-radius: 4px; font-weight: 600; margin-bottom: 8px; }
.note--ok { background: #e7f4e7; color: #2f7d33; border-color: #b6dcb7; }
.note--err { background: var(--red-soft); color: var(--red-2); border-color: #e3b3aa; }
.contact-aside dt { font-family: var(--display); font-weight: 600; font-size: 20px; color: var(--navy); margin-top: 24px; }
.contact-aside dt:first-child { margin-top: 0; }
.contact-aside dd { margin: 6px 0 0; color: var(--text-soft); font-size: 16.5px; }

/* ── CTA band ───────────────────────────────────────────────── */
.cta { text-align: center; background: var(--navy); color: var(--on-navy-soft); }
.cta .chequer { height: 3px; background: var(--red); }
.cta .shell { padding: clamp(58px, 9vh, 100px) 28px; }
.cta .label { color: var(--on-navy-eyebrow); }
.cta h2 { color: #fff; font-size: clamp(32px, 4.6vw, 54px); }
.cta p { margin: 16px auto 30px; max-width: 50ch; font-size: 19px; color: var(--on-navy-soft); }

/* ── Footer ─────────────────────────────────────────────────── */
.mfoot { background: var(--navy-2); color: var(--on-navy-soft); }
.mfoot .shell { padding: clamp(52px, 8vh, 84px) 28px 28px; }
.mfoot a { color: var(--on-navy-soft); }
.mfoot a:hover { color: #fff; }
.mfoot-top { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.7fr); gap: clamp(32px, 6vw, 80px); padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.14); }
.mfoot-brand .brand { font-family: var(--display); font-weight: 600; color: #fff; font-size: 22px; display: inline-flex; align-items: center; gap: 11px; }
.mfoot-brand p { margin: 16px 0 24px; font-size: 16px; max-width: 42ch; line-height: 1.65; }
.mfoot-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.mfoot-cols h4 { font-family: var(--body); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; font-size: 12px; color: var(--on-navy-eyebrow); margin: 0 0 14px; }
.mfoot-cols a { display: block; padding: 7px 0; font-size: 15.5px; }
.mfoot-base { display: flex; flex-wrap: wrap; gap: 12px 24px; justify-content: space-between; align-items: center; padding-top: 24px; font-size: 14px; color: rgba(255,255,255,0.55); }
.mfoot-legal { display: flex; gap: 22px; }
@media (max-width: 720px) { .mfoot-top { grid-template-columns: 1fr; gap: 36px; } }
@media (max-width: 460px) { .mfoot-cols { grid-template-columns: 1fr 1fr; } }

/* Page-load reveal (respects reduced motion) */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(14px); animation: rise .7s cubic-bezier(.16,1,.3,1) forwards; }
  .reveal.d1 { animation-delay: .07s; } .reveal.d2 { animation-delay: .15s; } .reveal.d3 { animation-delay: .23s; }
  @keyframes rise { to { opacity: 1; transform: none; } }
}

/* ============================================================
   Auth pages (sign up / sign in)
   ============================================================ */
.auth-body { background: var(--bg-2); min-height: 100vh; }
.auth-main { display: flex; flex-direction: column; align-items: center; padding: clamp(28px, 6vh, 64px) 24px 64px; }
.auth-card {
  width: 100%; max-width: 480px; background: #fff; position: relative; border: 1px solid var(--line);
  border-radius: 8px; padding: clamp(30px, 5vw, 48px) clamp(30px, 5vw, 48px) clamp(40px, 6vw, 56px);
  box-shadow: 0 30px 60px -44px rgba(19,50,94,0.45);
}
.auth-card form > p { margin: 18px 0 0; }
.auth-main:has(.wiz) .auth-card { max-width: 560px; }

/* ── Sign-up wizard ─────────────────────────────────────────── */
.wiz-steps { display: grid; grid-template-columns: repeat(3, 1fr); margin: 4px 0 30px; }
.wiz-step { text-align: center; position: relative; }
.wiz-step::before { content: ""; position: absolute; top: 16px; left: -50%; width: 100%; height: 2px; background: var(--line); z-index: 0; }
.wiz-step:first-child::before { display: none; }
.wiz-step.done::before, .wiz-step.active::before { background: var(--red); }
.wiz-step .dot { position: relative; z-index: 1; width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
  margin: 0 auto 8px; font-weight: 700; font-size: 15px; background: #fff; border: 2px solid var(--line); color: var(--text-dim); transition: all .2s; }
.wiz-step .lbl { font-size: 12.5px; font-weight: 600; color: var(--text-dim); }
.wiz-step.active .dot { border-color: var(--red); color: var(--red); }
.wiz-step.done .dot { background: var(--red); border-color: var(--red); color: #fff; }
.wiz-step.active .lbl, .wiz-step.done .lbl { color: var(--navy); }

.wiz-panel { display: block; }            /* no-JS fallback: all steps visible as one form */
.wiz-js .wiz-panel { display: none; }
.wiz-js .wiz-panel.active { display: block; }
.wiz:not(.wiz-js) .wiz-steps { display: none; }
@media (prefers-reduced-motion: no-preference) { .wiz-js .wiz-panel.active { animation: wizfade .25s ease; } @keyframes wizfade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } } }
.wiz-panel h2 { font-family: var(--display); font-weight: 600; font-size: 23px; color: var(--navy); margin: 0 0 4px; }
.wiz-panel .panel-intro { color: var(--text-soft); font-size: 15.5px; margin: 0 0 20px; }

.wiz-nav { display: flex; gap: 12px; margin-top: 22px; }
.wiz-nav .btn { flex: 1; justify-content: center; }
.wiz-back { background: transparent; }

.wiz-review { background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px; padding: 18px 20px; margin-bottom: 18px; }
.wiz-review dl { display: grid; grid-template-columns: auto 1fr; gap: 10px 16px; margin: 0; font-size: 15.5px; }
.wiz-review dt { color: var(--text-soft); }
.wiz-review dd { margin: 0; color: var(--navy); font-weight: 600; text-align: right; word-break: break-word; }
.wiz-price { border: 1px solid var(--line); border-radius: 8px; padding: 18px 20px; margin-bottom: 16px; }
.wiz-price .row { display: flex; justify-content: space-between; align-items: baseline; font-size: 16px; padding: 4px 0; }
.wiz-price .row.total { border-top: 1px solid var(--line); margin-top: 10px; padding-top: 12px; }
.wiz-price .row.total .amt { font-family: var(--display); font-weight: 600; font-size: 26px; color: var(--navy); }
.wiz-price .muted { color: var(--text-soft); }
.pay-note { display: flex; align-items: center; justify-content: center; gap: 7px; font-size: 13.5px; color: var(--text-soft); margin-top: 14px; }
.pay-note svg { width: 14px; height: 14px; flex: none; }
.auth-seal { width: 46px; height: 46px; margin: 0 auto 18px; border: 2px solid var(--red); border-radius: 50%; display: grid; place-items: center; }
.auth-seal .diamond { width: 13px; height: 13px; }
.auth-card h1 { font-family: var(--display); font-weight: 600; font-size: clamp(28px, 5vw, 38px); text-align: center; margin: 0 0 8px; color: var(--navy); }
.auth-card .lede { text-align: center; color: var(--text-soft); font-size: 17px; margin: 0 auto 26px; max-width: 46ch; }
.auth-card .field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
.auth-card .field label { font-family: var(--body); font-weight: 600; font-size: 15px; color: var(--navy); }
.auth-card .field .hint { font-size: 14px; color: var(--text-soft); }
.auth-card .field input {
  font: 17px var(--body); color: var(--text); padding: 14px 15px; min-height: 52px; border: 1px solid var(--line);
  border-radius: 4px; background: #fff; width: 100%; box-sizing: border-box; transition: border-color .15s, box-shadow .15s;
}
.auth-card .field input::placeholder { color: var(--text-dim); }
.auth-card .field input:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3px var(--red-soft); }
.auth-card .btn { width: 100%; justify-content: center; }
.auth-card form > p { text-align: center; }
.auth-card a { color: var(--red-2); font-weight: 600; }
.auth-card .tickrow { display: flex; gap: 13px; align-items: flex-start; margin: 20px 0 4px; padding: 15px 16px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-2); }
.auth-card .tickrow input[type="checkbox"] { width: 22px; height: 22px; accent-color: var(--red); flex: none; margin-top: 2px; cursor: pointer; }
.auth-card .tickrow label { font-size: 15.5px; color: var(--text); cursor: pointer; }
.auth-card .flash { padding: 14px 18px; margin-bottom: 18px; font-weight: 600; font-size: 16px; border: 1px solid; border-radius: 4px; }
.auth-card .flash--ok { background: #e7f4e7; color: #2f7d33; border-color: #b6dcb7; }
.auth-card .flash--error { background: var(--red-soft); color: var(--red-2); border-color: #e3b3aa; }
.auth-foot { margin-top: 26px; color: var(--text-dim); font-size: 15px; text-align: center; }
