/* DMC Quote — multi-step form styling. Brand accent #4caad4. Self-contained. */
#dmc-quote-root {
  --dmc-accent: #4caad4;
  --dmc-accent-dark: #3a99c3;
  --dmc-grey-700: #3f4d52;
  --dmc-grey-500: #5b6b70;
  --dmc-grey-300: #c8d2d5;
  --dmc-grey-100: #eef2f3;
  --dmc-radius: 16px;
  max-width: 820px;
  margin: 0 auto;
  padding: 0 1rem 4rem;
  font-family: inherit;
}
#dmc-quote-root * { box-sizing: border-box; }
/* Neutralise the quark2 theme's decorative heading ::before accent bar
   (it renders as a stray dash on our centred step headings). */
#dmc-quote-root h1::before, #dmc-quote-root h2::before,
#dmc-quote-root h3::before, #dmc-quote-root h4::before { content: none !important; display: none !important; }
#dmc-quote-root h1, #dmc-quote-root h2, #dmc-quote-root h3, #dmc-quote-root h4 { line-height: 1.2; }

.dmc-hero {
  background: var(--dmc-accent);
  color: #fff;
  border-radius: var(--dmc-radius);
  padding: 1.75rem 1.5rem;
  text-align: center;
  margin-bottom: 1rem;
}
.dmc-hero h1 { margin: 0 0 .75rem; font-size: clamp(1.4rem, 3vw, 2.1rem); color: #fff; }
.dmc-trust { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; }
.dmc-trust span {
  background: rgba(255,255,255,.18); border-radius: 999px;
  padding: .35rem .8rem; font-size: .8rem; font-weight: 600;
}

/* Progress bar */
.dmc-progress { display: flex; align-items: center; justify-content: space-between;
  background: #fff; border: 1px solid var(--dmc-grey-300); border-radius: 12px;
  padding: .75rem 1rem; margin-bottom: 1rem; position: relative; }
.dmc-progress .step { display: flex; align-items: center; gap: .4rem; position: relative; z-index: 1; }
.dmc-progress .dot {
  width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center;
  font-size: .8rem; font-weight: 700; border: 2px solid var(--dmc-grey-300);
  background: #fff; color: var(--dmc-grey-500); transition: all .25s;
}
.dmc-progress .step.active .dot, .dmc-progress .step.done .dot {
  background: var(--dmc-accent); border-color: var(--dmc-accent); color: #fff;
}
.dmc-progress .label { font-size: .78rem; font-weight: 600; color: var(--dmc-grey-500); }
.dmc-progress .step.active .label, .dmc-progress .step.done .label { color: var(--dmc-accent-dark); }
@media (max-width: 640px) { .dmc-progress .label { display: none; } }

/* Card */
.dmc-card { background: #fff; border: 1px solid var(--dmc-grey-300);
  border-radius: var(--dmc-radius); box-shadow: 0 10px 30px rgba(0,0,0,.06);
  padding: 1.5rem; }
@media (min-width: 720px) { .dmc-card { padding: 2.25rem; } }
.dmc-step-head { text-align: center; margin-bottom: 1.5rem; }
.dmc-step-head .icon { width: 48px; height: 48px; border-radius: 12px; background: var(--dmc-accent);
  display: grid; place-items: center; margin: 0 auto .75rem; font-size: 1.4rem; }
.dmc-step-head h2 { margin: 0 0 .25rem; font-size: clamp(1.2rem, 2.5vw, 1.7rem); }
.dmc-step-head p { margin: 0; color: var(--dmc-grey-500); font-size: .95rem; }

label.dmc-field-label { display: block; font-weight: 600; font-size: .9rem;
  margin: 0 0 .4rem; color: var(--dmc-grey-700); }
.dmc-input { width: 100%; padding: .75rem .9rem; border: 2px solid var(--dmc-grey-300);
  border-radius: 12px; font-size: .95rem; outline: none; background: #fff; color: inherit; }
.dmc-input:focus { border-color: var(--dmc-accent); box-shadow: 0 0 0 3px rgba(76,170,212,.2); }
.dmc-grid2 { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .dmc-grid2 { grid-template-columns: 1fr 1fr; } }
.dmc-mb { margin-bottom: 1.25rem; }

/* Option button grids */
.dmc-options { display: grid; gap: .6rem; }
.dmc-options.cols2 { grid-template-columns: repeat(2, 1fr); }
.dmc-options.cols3 { grid-template-columns: repeat(3, 1fr); }
.dmc-options.cols4 { grid-template-columns: repeat(2, 1fr); }
@media (min-width: 640px) { .dmc-options.cols4 { grid-template-columns: repeat(4, 1fr); } }
.dmc-opt { padding: .85rem .75rem; border: 2px solid var(--dmc-grey-300); border-radius: 12px;
  background: #fff; color: var(--dmc-grey-700); font-weight: 600; font-size: .9rem;
  cursor: pointer; text-align: center; transition: all .15s; }
.dmc-opt:hover { border-color: var(--dmc-accent); }
.dmc-opt.sel { background: var(--dmc-accent); border-color: var(--dmc-accent); color: #fff; }

/* Service card with Yes/No toggle */
.dmc-service { border: 2px solid var(--dmc-grey-300); border-radius: var(--dmc-radius);
  padding: 1.1rem; margin-bottom: 1rem; transition: all .2s; }
.dmc-service.on { border-color: var(--dmc-accent); background: rgba(76,170,212,.05); }
.dmc-service-head { display: flex; align-items: center; justify-content: space-between; }
.dmc-service-head .name { font-weight: 700; font-size: 1.02rem; }
.dmc-toggle { display: inline-flex; border-radius: 999px; overflow: hidden; }
.dmc-toggle button { border: 0; padding: .4rem .9rem; font-weight: 700; font-size: .8rem;
  cursor: pointer; background: var(--dmc-grey-100); color: var(--dmc-grey-500); }
.dmc-toggle button.yes.sel { background: var(--dmc-accent); color: #fff; }
.dmc-toggle button.no.sel { background: var(--dmc-grey-500); color: #fff; }
.dmc-service-body { margin-top: .9rem; padding-top: .9rem; border-top: 1px solid var(--dmc-grey-100); }
.dmc-sub-label { font-size: .82rem; font-weight: 600; color: var(--dmc-grey-700); margin: 0 0 .4rem; }

/* Live price box */
.dmc-pricebox { position: sticky; bottom: .5rem; margin-top: 1.25rem;
  background: var(--dmc-grey-100); border: 1px solid var(--dmc-grey-300);
  border-radius: 12px; padding: 1rem 1.1rem; }
.dmc-pricebox h4 { margin: 0 0 .5rem; font-size: .85rem; color: var(--dmc-grey-500);
  text-transform: uppercase; letter-spacing: .04em; }
.dmc-priceline { display: flex; justify-content: space-between; font-size: .88rem; padding: .15rem 0; }
.dmc-priceline.total { font-weight: 800; font-size: 1.05rem; border-top: 2px solid var(--dmc-grey-300);
  margin-top: .4rem; padding-top: .5rem; color: var(--dmc-accent-dark); }
.dmc-price-note { font-size: .78rem; color: var(--dmc-grey-500); margin: .4rem 0 0; }

/* Nav buttons */
.dmc-nav { display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  margin-top: 1.75rem; padding-top: 1.25rem; border-top: 1px solid var(--dmc-grey-100); }
.dmc-btn { padding: .8rem 1.6rem; border-radius: 12px; font-weight: 700; font-size: .95rem;
  cursor: pointer; border: 0; transition: all .15s; }
.dmc-btn-primary { background: var(--dmc-accent); color: #fff; }
.dmc-btn-primary:hover { background: var(--dmc-accent-dark); }
.dmc-btn-primary:disabled { opacity: .5; cursor: not-allowed; }
.dmc-btn-ghost { background: transparent; color: var(--dmc-grey-500); }
.dmc-btn-ghost:hover { background: var(--dmc-grey-100); }

/* Address suggestions */
.dmc-suggest { position: relative; }
.dmc-suggest-list { position: absolute; z-index: 40; width: 100%; margin-top: .25rem;
  background: #fff; border: 1px solid var(--dmc-grey-300); border-radius: 12px;
  max-height: 16rem; overflow-y: auto; box-shadow: 0 10px 30px rgba(0,0,0,.12); }
.dmc-suggest-list button { display: block; width: 100%; text-align: left; padding: .7rem .9rem;
  border: 0; background: #fff; border-bottom: 1px solid var(--dmc-grey-100); cursor: pointer; font-size: .88rem; }
.dmc-suggest-list button:hover { background: rgba(76,170,212,.08); }
.dmc-link { background: none; border: 0; color: var(--dmc-accent-dark); font-weight: 600;
  text-decoration: underline; cursor: pointer; font-size: .85rem; padding: 0; }

/* Review */
.dmc-review-section { border: 1px solid var(--dmc-grey-300); border-radius: 12px;
  padding: 1rem 1.1rem; margin-bottom: 1rem; }
.dmc-review-section h3 { margin: 0 0 .6rem; font-size: 1rem; color: var(--dmc-accent-dark); }
.dmc-review-row { display: flex; justify-content: space-between; font-size: .88rem; padding: .2rem 0; gap: 1rem; }
.dmc-review-row span:first-child { color: var(--dmc-grey-500); }
.dmc-checkbox { display: flex; align-items: flex-start; gap: .6rem; font-size: .88rem; color: var(--dmc-grey-500); }
.dmc-checkbox input { margin-top: .25rem; }

/* Success */
.dmc-success { text-align: center; padding: 2rem 1rem; }
.dmc-success .tick { width: 84px; height: 84px; border-radius: 22px; background: var(--dmc-accent);
  display: grid; place-items: center; margin: 0 auto 1.25rem; font-size: 2.4rem; color: #fff; }
.dmc-next { background: var(--dmc-grey-100); border-radius: 12px; padding: 1.25rem; text-align: left;
  max-width: 460px; margin: 1.5rem auto; }
.dmc-next .nx { display: flex; gap: .7rem; align-items: flex-start; margin-bottom: .6rem; }
.dmc-next .nx b { background: var(--dmc-accent); color: #fff; width: 26px; height: 26px; border-radius: 7px;
  display: grid; place-items: center; flex: 0 0 auto; font-size: .8rem; }

.dmc-spinner { display: inline-block; width: 1em; height: 1em; border: 2px solid currentColor;
  border-right-color: transparent; border-radius: 50%; animation: dmc-spin .7s linear infinite; vertical-align: -2px; }
@keyframes dmc-spin { to { transform: rotate(360deg); } }
.dmc-err { color: #c0392b; font-size: .85rem; margin-top: .5rem; }
.dmc-hidden { display: none !important; }
.dmc-velux-qty { width: 90px; }
.dmc-hint { font-size: .8rem; color: var(--dmc-grey-500); margin: .4rem 0 0; }
