/* ============================================================
   OC Labs — Configurator styles (clinical / precision-tech)
   Requires oc-tokens.css
   ============================================================ */
.oc-cfg { background: var(--oc-bg); border-radius: var(--oc-radius); padding: var(--oc-sp-5); }
.oc-cfg__error { color: var(--oc-error); text-align: center; padding: var(--oc-sp-6); }
.oc-cfg__error .oc-btn { margin-top: var(--oc-sp-4); }
.oc-cfg__loading { display: flex; align-items: center; justify-content: center; gap: var(--oc-sp-3);
  padding: var(--oc-sp-8); color: var(--oc-ink-soft); font-weight: 600; }
.oc-cfg__spinner { width: 22px; height: 22px; border: 3px solid var(--oc-sky-soft); border-top-color: var(--oc-blue);
  border-radius: 50%; animation: oc-spin .7s linear infinite; }
@keyframes oc-spin { to { transform: rotate(360deg); } }

/* progress steps */
.oc-cfg__steps { display: flex; flex-wrap: wrap; gap: var(--oc-sp-2); list-style: none; margin: 0 0 var(--oc-sp-5); padding: 0; }
.oc-cfg__steps li { display: flex; align-items: center; gap: 6px; font-size: .78rem; color: var(--oc-steel-text); }
.oc-cfg__steps li.is-active { color: var(--oc-navy); font-weight: 700; }
.oc-cfg__steps li.is-done { color: var(--oc-success); }
.oc-cfg__dot { width: 24px; height: 24px; border-radius: 50%; background: #fff; border: 2px solid var(--oc-line);
  display: inline-flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 700; }
.oc-cfg__steps li.is-active .oc-cfg__dot { background: var(--oc-blue); border-color: var(--oc-blue); color: #fff; }
.oc-cfg__steps li.is-done .oc-cfg__dot { background: var(--oc-success); border-color: var(--oc-success); color: #fff; }
.oc-cfg__steplbl { white-space: nowrap; }
@media (max-width: 760px) { .oc-cfg__steplbl { display: none; } }

/* layout */
.oc-cfg__body { display: grid; grid-template-columns: 1fr 280px; gap: var(--oc-sp-5); }
@media (max-width: 860px) { .oc-cfg__body { grid-template-columns: 1fr; } }
.oc-cfg__title { font: 700 var(--oc-h2)/1.1 var(--oc-font-head); color: var(--oc-navy); margin: 0 0 var(--oc-sp-4); }
.oc-cfg__panel { min-height: 240px; }
.oc-cfg__grp { font: 700 1rem var(--oc-font-head); color: var(--oc-navy-2); margin: var(--oc-sp-4) 0 var(--oc-sp-2); }

/* option grid */
.oc-cfg__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--oc-sp-3); }
.oc-cfg__opt { text-align: left; background: var(--oc-surface); border: 2px solid var(--oc-line);
  border-radius: var(--oc-radius-sm); padding: var(--oc-sp-4); cursor: pointer; transition: border-color .12s, box-shadow .12s;
  display: flex; flex-direction: column; gap: 4px; position: relative; }
.oc-cfg__opt:hover { border-color: var(--oc-sky); box-shadow: var(--oc-shadow); }
.oc-cfg__opt.is-active { border-color: var(--oc-blue); box-shadow: 0 0 0 3px var(--oc-sky-soft); }
.oc-cfg__opt-title { font-weight: 700; color: var(--oc-navy); }
.oc-cfg__opt-meta { font-size: .82rem; color: var(--oc-ink-soft); }
.oc-cfg__opt--toggle { padding-left: 44px; }
.oc-cfg__check { position: absolute; left: 14px; top: 14px; width: 20px; height: 20px; border-radius: 5px;
  border: 2px solid var(--oc-line); display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-size: .7rem; }
.oc-cfg__opt--toggle.is-active .oc-cfg__check { background: var(--oc-blue); border-color: var(--oc-blue); }

/* nav */
.oc-cfg__nav { display: flex; justify-content: space-between; margin-top: var(--oc-sp-5); gap: var(--oc-sp-3); }
.oc-btn[disabled] { opacity: .4; cursor: not-allowed; }

/* summary aside */
.oc-cfg__aside { background: var(--oc-navy); color: #fff; border-radius: var(--oc-radius); padding: var(--oc-sp-5); align-self: start; }
.oc-cfg__price { font: 800 2rem var(--oc-font-head); color: var(--oc-sky); }
.oc-cfg__pricelbl { font-size: .8rem; opacity: .7; margin-bottom: var(--oc-sp-4); }
.oc-cfg__asidelist { list-style: none; padding: 0; margin: 0; font-size: .85rem; }
.oc-cfg__asidelist li { padding: 6px 0 6px 20px; position: relative; border-top: 1px solid rgba(255,255,255,.12); }
.oc-cfg__asidelist li:before { content: "✓"; position: absolute; left: 0; color: var(--oc-sky); }

/* rx form */
.oc-cfg__note { color: var(--oc-ink-soft); }
.oc-cfg__rxtable { width: 100%; border-collapse: collapse; margin: var(--oc-sp-3) 0; }
.oc-cfg__rxtable th, .oc-cfg__rxtable td { padding: 6px; text-align: center; }
.oc-cfg__rxtable thead th { color: var(--oc-navy); font-size: .8rem; }
.oc-cfg__rxtable tbody th { text-align: left; color: var(--oc-navy-2); font-size: .85rem; }
.oc-cfg__rxtable input, .oc-cfg__pd input { width: 100%; padding: 8px; border: 1.5px solid var(--oc-line);
  border-radius: 6px; font: inherit; text-align: center; }
.oc-cfg__pd { display: block; margin-top: var(--oc-sp-3); font-size: .85rem; color: var(--oc-navy-2); }
.oc-cfg__pd input { max-width: 200px; text-align: left; margin-top: 4px; }

/* validation hint */
.oc-cfg__hint { color: var(--oc-ink-soft); font-size: .85rem; margin: var(--oc-sp-3) 0 0; text-align: right; }

/* rx tooltips */
.oc-cfg__rxtable abbr { text-decoration: underline dotted; cursor: help; }
.oc-cfg__rx .oc-cfg__note a { color: var(--oc-blue); font-weight: 600; }

/* sticky mobile bar */
.oc-cfg__mobilebar { display: none; }
@media (max-width: 860px) {
  .oc-cfg__mobilebar {
    display: flex; align-items: center; justify-content: space-between; gap: var(--oc-sp-3);
    position: sticky; bottom: 0; margin: var(--oc-sp-4) calc(-1 * var(--oc-sp-5)) calc(-1 * var(--oc-sp-5));
    padding: var(--oc-sp-3) var(--oc-sp-5); background: #fff; border-top: 1px solid var(--oc-line);
    box-shadow: 0 -4px 16px rgba(7,31,63,.10); z-index: 20;
  }
  .oc-cfg__mobilelbl { display: block; font-size: .7rem; color: var(--oc-ink-soft); }
  .oc-cfg__mobileprice { font: 800 1.25rem var(--oc-font-head); color: var(--oc-navy); }
  /* hide the desktop aside on mobile to avoid duplication */
  .oc-cfg__aside { display: none; }
  .oc-cfg__hint { text-align: left; }
}

/* review */
.oc-cfg__review { width: 100%; border-collapse: collapse; }
.oc-cfg__review th, .oc-cfg__review td { padding: 10px 8px; border-bottom: 1px solid var(--oc-line); text-align: left; }
.oc-cfg__review th { color: var(--oc-ink-soft); font-weight: 600; width: 35%; }
.oc-cfg__review td { color: var(--oc-navy); font-weight: 600; }
.oc-cfg__total th, .oc-cfg__total td { font-size: 1.15rem; color: var(--oc-navy); border-bottom: none; padding-top: var(--oc-sp-4); }
.oc-cfg__total td { color: var(--oc-blue); font-weight: 800; }
