/* ==========================================================
   PHOTOGRAPHY SECTION — Token Compliant Glass Redesign
   ========================================================== */

/* ── Guidelines Grid ── */
.photo-guidelines {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 48px;
}

.photo-guideline {
  border-radius: var(--r-lg);
  padding: 28px 24px;
  border: 1px solid;
  position: relative;
}

.photo-guideline--approved {
  background: color-mix(in srgb, var(--c-green-cta) 5%, transparent);
  border-color: color-mix(in srgb, var(--c-green-cta) 20%, transparent);
}

.photo-guideline--rejected {
  background: color-mix(in srgb, var(--c-red) 5%, transparent);
  border-color: color-mix(in srgb, var(--c-red) 16%, transparent);
}

/* ── Badge ── */
.photo-guideline__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-mono);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  padding: 4px 10px;
  border-radius: 100px;
  margin-bottom: 18px;
  border: 1px solid;
}

.photo-guideline__badge i {
  width: 12px;
  height: 12px;
}

.photo-guideline__badge--approved {
  background: color-mix(in srgb, var(--c-green-cta) 12%, transparent);
  border-color: color-mix(in srgb, var(--c-green-cta) 30%, transparent);
  color: var(--c-green-cta);
}

.photo-guideline__badge--rejected {
  background: color-mix(in srgb, var(--c-red) 12%, transparent);
  border-color: color-mix(in srgb, var(--c-red) 28%, transparent);
  color: var(--c-red);
}

.photo-guideline ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.photo-guideline ul li {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--text-2);
  padding-left: 20px;
  position: relative;
}

.photo-guideline--approved ul li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--c-green-cta);
  font-size: 11px;
  font-weight: 700;
  top: 1px;
}

.photo-guideline--rejected ul li::before {
  content: '✗';
  position: absolute;
  left: 0;
  color: var(--c-red);
  font-size: 11px;
  font-weight: 700;
  top: 1px;
}

/* ── Treatments Grid ── */
.photo-treatments {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.photo-treatment {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--g-border);
  box-shadow: var(--g-shadow-card);
  transition: transform 380ms cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 380ms ease;
  position: relative;
}

/* Specular top edge */
.photo-treatment::before {
  content: '';
  position: absolute;
  top: 0;
  left: 4%;
  right: 4%;
  height: 1px;
  background: var(--g-specular);
  z-index: 3;
  pointer-events: none;
}

.photo-treatment:hover {
  transform: translateY(-3px);
  box-shadow: var(--g-shadow-hover);
}

.photo-treatment__swatch {
  height: 100px;
  position: relative;
}

/* Swatch color variants */
.photo-treatment__swatch--dark {
  background: linear-gradient(
    150deg,
    var(--c-black) 0%,
    color-mix(in srgb, var(--c-blue) 12%, var(--c-black)) 60%,
    color-mix(in srgb, var(--c-purple) 16%, var(--c-black)) 100%
  );
}

.photo-treatment__swatch--blue {
  background: linear-gradient(
    135deg,
    var(--c-black) 0%,
    color-mix(in srgb, var(--c-blue) 55%, var(--c-black)) 65%,
    var(--c-blue) 100%
  );
}

.photo-treatment__swatch--purple {
  background: linear-gradient(
    135deg,
    var(--c-black) 0%,
    color-mix(in srgb, var(--c-purple) 55%, var(--c-black)) 65%,
    var(--c-purple) 100%
  );
}

.photo-treatment__swatch--green {
  background: linear-gradient(
    135deg,
    var(--c-black) 0%,
    color-mix(in srgb, var(--c-green-cta) 50%, var(--c-black)) 65%,
    var(--c-green-cta) 100%
  );
}

.photo-treatment__swatch--gold {
  background: linear-gradient(
    135deg,
    var(--c-black) 0%,
    color-mix(in srgb, var(--c-yellow) 50%, var(--c-black)) 65%,
    var(--c-yellow) 100%
  );
}

.photo-treatment__info {
  padding: 14px 16px;
  background: var(--surface);
  border-top: 1px solid var(--border);
  transition: background var(--t-slow);
}

.photo-treatment:hover .photo-treatment__info {
  background: var(--surface-2);
}

.photo-treatment__name {
  font-family: var(--f-mono);
  font-size: 11.5px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.04em;
  margin-bottom: 3px;
}

.photo-treatment__desc {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.4;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .photo-guidelines  { grid-template-columns: 1fr; }
  .photo-treatments  { grid-template-columns: repeat(2, 1fr); }
}
