/* property-report primitives. Target <8 KB. Tokens in ./tokens.css.
   All colors/type reference --g-* tokens. No hardcoded palette. */
@import url("./tokens.css");

.pr-report {
  font-family: var(--g-font-sans); font-size: var(--g-text-base); line-height: 1.5;
  color: var(--g-text-primary); background: var(--g-bg-base);
  padding: var(--g-space-6); max-width: 1120px; margin: 0 auto;
}
.pr-report__header { margin-bottom: var(--g-space-6); }
.pr-report__eyebrow {
  font: var(--g-weight-semibold) var(--g-text-sm)/1.2 var(--g-font-mono);
  letter-spacing: .08em; text-transform: uppercase; color: var(--g-text-secondary);
  margin: 0 0 var(--g-space-2);
}
.pr-report__heading { font: var(--g-weight-bold) var(--g-text-xl)/1.2 var(--g-font-sans); margin: 0 0 var(--g-space-2); }
.pr-report__meta { font-family: var(--g-font-mono); font-size: var(--g-mono-base); color: var(--g-text-secondary); margin: 0; }

.pr-section { padding: var(--g-space-5) 0; border-top: 1px solid var(--g-border); }
.pr-section__header { display: flex; justify-content: space-between; align-items: baseline; gap: var(--g-space-4); margin-bottom: var(--g-space-4); }
.pr-section__title { font: var(--g-weight-semibold) var(--g-text-lg)/1.3 var(--g-font-sans); margin: 0; letter-spacing: .01em; text-transform: uppercase; }
.pr-section__source { font-family: var(--g-font-mono); font-size: var(--g-mono-sm); color: var(--g-text-secondary); }
.pr-section__note { font-size: var(--g-text-sm); color: var(--g-text-secondary); margin: var(--g-space-3) 0 0; }

.pr-kv { display: grid; grid-template-columns: 220px 1fr; gap: var(--g-space-4); padding: var(--g-space-1) 0; align-items: baseline; }
.pr-kv--muted .pr-kv__value { color: var(--g-text-secondary); }
.pr-kv__label { color: var(--g-text-secondary); font-size: var(--g-text-sm); }
.pr-kv__value { font-family: var(--g-font-mono); font-size: var(--g-mono-base); }
.pr-kv__sub { display: inline-block; margin-left: var(--g-space-4); color: var(--g-text-secondary); font-size: var(--g-text-xs); }
.pr-kv__note { margin-left: var(--g-space-2); color: var(--g-text-tertiary); font-size: var(--g-text-xs); }

.pr-chip {
  display: inline-flex; align-items: center; gap: var(--g-space-1);
  padding: var(--g-space-1) var(--g-space-3); border-radius: var(--g-radius-full);
  font: var(--g-weight-medium) var(--g-text-sm)/1.2 var(--g-font-sans);
  background: var(--g-bg-elevated); color: var(--g-text-primary);
  border: 1px solid var(--g-border); margin: var(--g-space-1);
}
.pr-chip__glyph { font-family: var(--g-font-mono); font-weight: var(--g-weight-bold); }
.pr-chip--danger  { background: color-mix(in srgb, var(--g-danger)  18%, transparent); color: var(--g-danger);  border-color: color-mix(in srgb, var(--g-danger)  40%, transparent); }
.pr-chip--warning { background: color-mix(in srgb, var(--g-warning) 22%, transparent); color: var(--g-warning); border-color: color-mix(in srgb, var(--g-warning) 45%, transparent); }
.pr-chip--success { background: color-mix(in srgb, var(--g-success) 18%, transparent); color: var(--g-success); border-color: color-mix(in srgb, var(--g-success) 40%, transparent); }
.pr-chip--info    { background: color-mix(in srgb, var(--g-info)    18%, transparent); color: var(--g-info);    border-color: color-mix(in srgb, var(--g-info)    40%, transparent); }
.pr-chip--muted   { background: var(--g-bg-elevated); color: var(--g-text-secondary); }
.pr-chips { display: flex; flex-wrap: wrap; gap: var(--g-space-1); margin: 0 0 var(--g-space-4); }
.pr-chips__detail { display: grid; gap: var(--g-space-1); }
.pr-chips__row { display: grid; grid-template-columns: 220px 1fr auto; gap: var(--g-space-4); align-items: baseline; padding: var(--g-space-1) 0; font-family: var(--g-font-mono); font-size: var(--g-mono-base); }
.pr-chips__label { color: var(--g-text-secondary); font-size: var(--g-text-sm); font-family: var(--g-font-sans); }
.pr-chips__source { color: var(--g-text-tertiary); font-size: var(--g-text-xs); }

.pr-bignum { display: inline-flex; flex-direction: column; padding: var(--g-space-2) var(--g-space-3); }
.pr-bignum__label { font-size: var(--g-text-xs); color: var(--g-text-secondary); letter-spacing: .04em; text-transform: uppercase; }
.pr-bignum__value { font: var(--g-weight-semibold) var(--g-text-xl)/1.1 var(--g-font-mono); color: var(--g-data); }
.pr-bignum__unit { font-family: var(--g-font-mono); font-size: var(--g-text-sm); color: var(--g-text-secondary); margin-left: var(--g-space-1); }

.pr-badge { display: inline-flex; align-items: center; gap: var(--g-space-1); padding: 2px var(--g-space-2); border-radius: var(--g-radius-sm); font: var(--g-weight-semibold) var(--g-text-xs)/1.2 var(--g-font-sans); text-transform: uppercase; letter-spacing: .04em; }
.pr-badge--danger  { background: color-mix(in srgb, var(--g-danger)  18%, transparent); color: var(--g-danger); }
.pr-badge--warning { background: color-mix(in srgb, var(--g-warning) 22%, transparent); color: var(--g-warning); }
.pr-badge--success { background: color-mix(in srgb, var(--g-success) 18%, transparent); color: var(--g-success); }
.pr-badge--info    { background: color-mix(in srgb, var(--g-info)    18%, transparent); color: var(--g-info); }
.pr-badge--muted   { background: var(--g-bg-elevated); color: var(--g-text-secondary); }

.pr-pdflink { display: inline-flex; align-items: center; gap: 2px; color: var(--g-accent); text-decoration: none; font-size: var(--g-text-sm); }
.pr-pdflink:hover { text-decoration: underline; }
.pr-pdflink__title { white-space: nowrap; }
.pr-pdflink__glyph { font-weight: var(--g-weight-bold); }

.pr-subbox { border: 1px solid var(--g-border); border-radius: var(--g-radius-md); padding: var(--g-space-4); margin: var(--g-space-3) 0; background: var(--g-bg-surface); }
.pr-subbox--dashed, .pr-subbox--manual { border-style: dashed; background: var(--g-bg-elevated); }
.pr-subbox--danger { border-color: color-mix(in srgb, var(--g-danger) 50%, var(--g-border)); }
.pr-subbox__title { display: flex; align-items: center; gap: var(--g-space-2); font: var(--g-weight-semibold) var(--g-text-md)/1.2 var(--g-font-sans); margin: 0 0 var(--g-space-3); }
.pr-subbox__body > :first-child { margin-top: 0; }

.pr-slot__blurb { color: var(--g-text-secondary); font-size: var(--g-text-sm); margin: 0 0 var(--g-space-3); }
.pr-slot__steps { padding-left: var(--g-space-5); margin: 0 0 var(--g-space-3); font-size: var(--g-text-sm); }
.pr-slot__step { padding: var(--g-space-1) 0; }
.pr-slot__upload { display: inline-block; margin-left: var(--g-space-2); padding: 2px var(--g-space-3); border-radius: var(--g-radius-sm); border: 1px dashed var(--g-border-hover); background: transparent; color: var(--g-accent); font: var(--g-weight-semibold) var(--g-text-xs)/1.2 var(--g-font-sans); letter-spacing: .08em; cursor: pointer; }
.pr-slot__outcome { color: var(--g-text-secondary); font-size: var(--g-text-sm); margin: 0; }

.pr-viewer { display: flex; flex-direction: column; gap: var(--g-space-2); margin: 0; }
.pr-viewer__stage { aspect-ratio: 4/3; border-radius: var(--g-radius-md); background: var(--g-bg-elevated); border: 1px solid var(--g-border); display: flex; align-items: center; justify-content: center; font-size: 3rem; color: var(--g-text-tertiary); }
.pr-viewer__caption { font-family: var(--g-font-mono); font-size: var(--g-mono-sm); color: var(--g-text-secondary); text-align: center; }

.pr-prov { font-family: var(--g-font-mono); font-size: var(--g-mono-base); }
.pr-prov__fetched { margin: 0 0 var(--g-space-4); color: var(--g-text-secondary); }
.pr-prov__row { margin-bottom: var(--g-space-3); }
.pr-prov__track { display: inline-block; min-width: 180px; color: var(--g-text-secondary); font-weight: var(--g-weight-semibold); }
.pr-prov__sources { color: var(--g-text-primary); }
.pr-prov__list { margin: 0 0 0 180px; padding: 0; list-style: none; }
.pr-prov__list li { color: var(--g-text-primary); padding: 2px 0; }
.pr-prov__footer { margin: var(--g-space-4) 0 0; color: var(--g-text-secondary); font-size: var(--g-text-sm); font-family: var(--g-font-sans); }

.pr-unprovided { color: var(--g-text-tertiary); font-style: italic; }
.pr-unprovided--not-fetched { color: var(--g-text-secondary); }

.pr-deprecated { margin-left: var(--g-space-2); color: var(--g-text-tertiary); font-size: var(--g-text-xs); font-family: var(--g-font-sans); }
.pr-deprecated__tag { text-transform: uppercase; letter-spacing: .06em; font-weight: var(--g-weight-semibold); }
.pr-deprecated__arrow { margin: 0 var(--g-space-1); color: var(--g-text-tertiary); }
.pr-deprecated__successor code { font-family: var(--g-font-mono); font-size: var(--g-text-xs); color: var(--g-text-secondary); padding: 0 var(--g-space-1); }

.pr-card { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--g-space-3); padding: var(--g-space-4); border: 1px solid var(--g-border); border-radius: var(--g-radius-lg); background: var(--g-bg-surface); margin: 0 0 var(--g-space-5); }
.pr-card__header { grid-column: 1/-1; display: flex; justify-content: space-between; align-items: baseline; gap: var(--g-space-3); flex-wrap: wrap; padding-bottom: var(--g-space-3); border-bottom: 1px solid var(--g-border); }
.pr-card__bignums { grid-column: 1/-1; display: flex; gap: var(--g-space-4); flex-wrap: wrap; }
.pr-card__chips   { grid-column: 1/-1; padding-top: var(--g-space-3); border-top: 1px solid var(--g-border); }
.pr-card__legend  { grid-column: 1/-1; font-family: var(--g-font-mono); font-size: var(--g-mono-sm); color: var(--g-text-secondary); }

.pr-building__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--g-space-2) var(--g-space-4); }
.pr-building__action { margin-top: var(--g-space-3); padding: var(--g-space-3); border-left: 3px solid var(--g-danger); background: color-mix(in srgb, var(--g-danger) 6%, transparent); font-size: var(--g-text-sm); }

@media (max-width: 720px) {
  .pr-card { grid-template-columns: 1fr 1fr; }
  .pr-building__grid, .pr-kv, .pr-chips__row { grid-template-columns: 1fr; }
  .pr-prov__track { min-width: unset; display: block; }
  .pr-prov__list { margin-left: var(--g-space-4); }
}

/* Phase 3 — geometry viewer iframe.
 * Light-theme chrome for the ginnung-viewer embed. Reuses --g-* tokens.
 * The iframe itself carries its own theme; the chrome around it (frame,
 * spinner, caption) stays on the report's surface. */
.pr-viewer--iframe { margin: 0 0 var(--g-space-3); }
.pr-viewer__frame {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--g-radius-md);
  border: 1px solid var(--g-border);
  background: var(--g-bg-elevated);
  overflow: hidden;
}
.pr-viewer__iframe {
  width: 100%; height: 100%;
  border: 0; display: block; background: transparent;
}
.pr-viewer__spinner {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font: var(--g-weight-medium) var(--g-text-sm)/1.2 var(--g-font-sans);
  color: var(--g-text-secondary);
  background: var(--g-bg-elevated);
  pointer-events: none;
  transition: opacity .2s ease-out;
}
.pr-viewer--ready .pr-viewer__spinner,
.pr-viewer__spinner[hidden] { opacity: 0; }
.pr-viewer__spinner-label::before {
  content: ""; display: inline-block;
  width: 10px; height: 10px; margin-right: var(--g-space-2);
  border-radius: 50%;
  background: var(--g-accent);
  animation: pr-viewer-pulse 1.2s ease-in-out infinite;
  vertical-align: middle;
}
@keyframes pr-viewer-pulse {
  0%, 100% { opacity: .3; transform: scale(.85); }
  50%      { opacity: 1;  transform: scale(1); }
}

/* Three-map primitive — satellite / street / 3D side-by-side.
 *
 * On screen: three equal-width cells in a row, collapsing to a single
 * column under 720 px. The cells reuse `.pr-viewer__frame` for the
 * iframe chrome so spinner + ready-state transitions stay consistent
 * with the single-viewer primitive.
 *
 * In print (HTML → PDF): each iframe is pinned to a fixed px width/height
 * so the browser's layout engine doesn't collapse the iframes when it
 * drops to print media (where `aspect-ratio` sometimes behaves poorly).
 * The whole block uses `break-inside: avoid` so a printed report keeps
 * the three maps on one page. `preserveDrawingBuffer: true` in the
 * report-viewer's Three.js renderer is the companion piece — without it
 * the WebGL canvas comes out blank in the PDF. */
.pr-threemaps { margin: var(--g-space-4) 0; }
.pr-threemaps__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--g-space-3);
}
.pr-threemaps__cell { margin: 0; }
.pr-threemaps__caption {
  margin-top: var(--g-space-2);
  font-family: var(--g-font-mono);
  font-size: var(--g-mono-sm);
  color: var(--g-text-secondary);
  text-align: center;
}
@media (max-width: 720px) {
  .pr-threemaps__grid { grid-template-columns: 1fr; }
}
@media print {
  .pr-threemaps { break-inside: avoid; page-break-inside: avoid; }
  .pr-threemaps__grid { grid-template-columns: repeat(3, 1fr); gap: 6mm; }
  .pr-threemaps__cell .pr-viewer__frame {
    /* Fixed mm sizing for print so aspect-ratio collapses don't happen. */
    aspect-ratio: auto;
    width: 60mm;
    height: 45mm;
  }
  .pr-threemaps__cell .pr-viewer__iframe {
    width: 60mm;
    height: 45mm;
  }
  .pr-viewer__spinner { display: none; }
}
