/* Ordia Project Type Selectors candidate source
   This file contains Product Type selector-owned implementation CSS only.
   It must not redefine shared foundation tokens in :root.
   It consumes Fieldsets, Questions, Controls, Section Headers, Helper Notes, and the icon library.
*/

/* ==========================================================================
   Project Type selector grid
   ========================================================================== */

.pt-selector-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  width: 100%;
}

.pt-selector-grid--secondary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* ==========================================================================
   Project Type whole-tile radio option
   ========================================================================== */

.pt-radio-tile {
  position: relative;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 118px;
  padding: 16px;
  border-radius: 14px;
  border: 1px solid var(--border-01, rgba(255,255,255,0.08));
  background: var(--surface-01, rgba(255,255,255,0.024));
  color: var(--text-muted, rgba(255,255,255,0.68));
  cursor: pointer;
  transition:
    background-color 120ms ease,
    border-color 120ms ease,
    box-shadow 120ms ease,
    color 120ms ease,
    transform 120ms ease;
}

.pt-radio-tile:hover,
.pt-radio-tile.is-hover {
  background: rgba(255,255,255,0.036);
  border-color: rgba(255,255,255,0.15);
  transform: translateY(-1px);
}

.pt-radio-tile:focus-within,
.pt-radio-tile.is-focus {
  outline: none;
  box-shadow: 0 0 0 3px var(--focus-halo, rgba(136,167,183,0.08));
}

.pt-radio-tile.is-selected {
  background: var(--supportive-selected-fill, rgba(0,163,136,0.06));
  border-color: var(--supportive-selected-stroke, rgba(0,163,136,0.35));
  box-shadow: inset 0 0 0 1px rgba(0,163,136,0.16);
  color: var(--text-primary, #f2eee8);
}

.pt-radio-tile.is-disabled,
.pt-radio-tile.is-secondary-disabled {
  cursor: default;
  transform: none;
  background: rgba(255,255,255,0.014);
  border-color: var(--border-01, rgba(255,255,255,0.08));
  box-shadow: none;
}

.pt-radio-tile.is-disabled:hover,
.pt-radio-tile.is-disabled.is-hover,
.pt-radio-tile.is-secondary-disabled:hover,
.pt-radio-tile.is-secondary-disabled.is-hover {
  background: rgba(255,255,255,0.014);
  border-color: var(--border-01, rgba(255,255,255,0.08));
  transform: none;
}

.pt-radio-tile__input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.pt-radio-tile__icon {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.pt-radio-tile__icon svg {
  width: 64px;
  height: 64px;
  display: block;
}

.pt-radio-tile__copy {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.pt-radio-tile__meta {
  margin: 0;
  color: var(--text-faint, rgba(255,255,255,0.42));
  font: 600 10px/1.25 "DM Sans", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pt-radio-tile__title {
  margin: 0;
  color: var(--text-primary, #f2eee8);
  font: 600 15px/1.28 "DM Sans", sans-serif;
}

.pt-radio-tile__text {
  margin: 0;
  color: var(--text-muted, rgba(255,255,255,0.68));
  font: 400 13px/1.5 "DM Sans", sans-serif;
}

.pt-radio-tile.is-disabled .pt-radio-tile__meta,
.pt-radio-tile.is-disabled .pt-radio-tile__title,
.pt-radio-tile.is-disabled .pt-radio-tile__text,
.pt-radio-tile.is-secondary-disabled .pt-radio-tile__meta,
.pt-radio-tile.is-secondary-disabled .pt-radio-tile__title,
.pt-radio-tile.is-secondary-disabled .pt-radio-tile__text {
  color: var(--text-disabled, rgba(152,165,173,0.34));
}

.pt-radio-tile__selected-mark {
  position: absolute;
  right: 14px;
  top: 14px;
  display: none;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: var(--radius-pill, 999px);
  border: 1px solid var(--supportive-selected-stroke, rgba(0,163,136,0.35));
  background: rgba(0,163,136,0.09);
  color: var(--success-note-accent, #00A388);
  font: 700 10px/1 "DM Sans", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pt-radio-tile__selected-mark svg {
  width: 14px;
  height: 14px;
  display: block;
}

.pt-radio-tile.is-selected .pt-radio-tile__selected-mark {
  display: inline-flex;
}

.pt-radio-tile.is-disabled .pt-radio-tile__selected-mark,
.pt-radio-tile.is-secondary-disabled .pt-radio-tile__selected-mark {
  display: none;
}

/* ==========================================================================
   Project Type locked summary
   ========================================================================== */

.pt-lock-strip {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--supportive-selected-stroke, rgba(0,163,136,0.35));
  background: var(--supportive-selected-fill, rgba(0,163,136,0.06));
}

.pt-lock-strip__row {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}

.pt-lock-strip__icon {
  width: 64px;
  height: 64px;
  display: grid;
  place-items: center;
}

.pt-lock-strip__icon svg {
  width: 64px;
  height: 64px;
  display: block;
}

.pt-lock-strip__copy {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.pt-lock-strip__label {
  color: var(--success-note-accent, #00A388);
  font: 600 10px/1.25 "DM Sans", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pt-lock-strip__title {
  margin: 0;
  color: var(--text-primary, #f2eee8);
  font: 600 16px/1.32 "DM Sans", sans-serif;
}

.pt-lock-strip__text {
  margin: 0;
  color: var(--text-muted, rgba(255,255,255,0.68));
  font: 400 13px/1.5 "DM Sans", sans-serif;
}

.pt-lock-strip__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 6px 10px;
  border-radius: var(--radius-pill, 999px);
  border: 1px solid var(--supportive-selected-stroke, rgba(0,163,136,0.35));
  background: rgba(0,163,136,0.09);
  color: var(--success-note-accent, #00A388);
  font: 700 10px/1 "DM Sans", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.pt-lock-strip__badge svg {
  width: 14px;
  height: 14px;
  display: block;
}

/* ==========================================================================
   Responsive behaviour
   ========================================================================== */

@media (max-width: 860px) {
  .pt-selector-grid,
  .pt-selector-grid--secondary {
    grid-template-columns: 1fr;
  }

  .pt-radio-tile {
    grid-template-columns: 64px minmax(0, 1fr);
    min-height: 112px;
  }

  .pt-lock-strip__row {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .pt-lock-strip__badge {
    grid-column: 2;
    justify-self: start;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pt-radio-tile {
    transition: none;
  }
}
