:root {
  --ink: #172018;
  --ink-soft: rgba(23, 32, 24, .72);
  --ink-muted: rgba(23, 32, 24, .58);
  --forest: #19382b;
  --forest-2: #0e261d;
  --moss: #6f8f59;
  --lichen: #dbe8bf;
  --sand: #f4ecd9;
  --paper: #fffaf0;
  --paper-strong: rgba(255, 250, 240, .96);
  --paper-soft: rgba(255, 250, 240, .78);
  --clay: #c98252;
  --rust: #9e543b;
  --line: rgba(25, 56, 43, .15);
  --line-strong: rgba(25, 56, 43, .25);
  --grid: rgba(25, 56, 43, .052);

  --space-1: .35rem;
  --space-2: .6rem;
  --space-3: .9rem;
  --space-4: 1.25rem;
  --space-5: 1.75rem;
  --space-6: 2.5rem;
  --space-7: 4rem;

  --radius-sm: .75rem;
  --radius-md: 1rem;
  --radius-lg: 1.35rem;
  --radius-xl: 2rem;
  --radius-pill: 999px;

  --shadow-card: 0 16px 36px rgba(21, 31, 24, .1);
  --shadow-float: 0 22px 60px rgba(21, 31, 24, .14);
  --shadow-soft: 0 10px 26px rgba(21, 31, 24, .08);

  --page-max: 1220px;
  color-scheme: light;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  color: var(--ink);
  background-color: var(--sand);
  background-image:
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    linear-gradient(0deg, var(--grid) 1px, transparent 1px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1600' height='1200' viewBox='0 0 1600 1200'%3E%3Cg fill='none' stroke='%2319382b' stroke-opacity='.12' stroke-width='1.45' stroke-linecap='round'%3E%3Cpath d='M-120 210 C110 65 330 98 522 230 S910 418 1238 190 1650 94 1760 268'/%3E%3Cpath d='M-130 375 C115 226 344 232 548 370 S918 590 1244 385 1654 318 1760 498'/%3E%3Cpath d='M-120 575 C120 430 352 448 575 582 S942 782 1260 610 1660 548 1760 725'/%3E%3Cpath d='M-140 835 C128 672 382 698 612 838 S1012 1042 1325 842 1668 780 1770 958'/%3E%3Cpath d='M250 -90 C360 80 365 265 260 430 S112 742 292 1290'/%3E%3Cpath d='M820 -120 C695 106 735 302 905 462 S1085 780 872 1320'/%3E%3Cpath d='M1325 -90 C1190 125 1205 330 1360 505 S1515 812 1345 1300'/%3E%3C/g%3E%3Cg fill='none' stroke='%23c98252' stroke-opacity='.085' stroke-width='1.35' stroke-linecap='round'%3E%3Cpath d='M1160 -80 C1300 130 1260 330 1120 510 S950 822 1128 1300'/%3E%3Cpath d='M-180 1020 C135 835 390 882 650 1030 S1135 1240 1780 982'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, #f8f0de 0%, var(--sand) 54%, #ede3cd 100%);
  background-repeat: repeat, repeat, no-repeat, no-repeat;
  background-size: 64px 64px, 64px 64px, 1850px auto, auto;
  background-position: 0 0, 0 0, center -90px, 0 0;
  background-attachment: fixed, fixed, fixed, scroll;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; }
:focus-visible { outline: 3px solid rgba(111, 143, 89, .55); outline-offset: 3px; }

main { width: min(var(--page-max), calc(100% - 2rem)); margin: 0 auto; }

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  padding: .82rem clamp(1rem, 4vw, 4rem);
  background: rgba(244, 236, 217, .9);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 8px 30px rgba(21, 31, 24, .045);
  backdrop-filter: blur(18px);
}
.site-header.compact { position: relative; }
.brand {
  display: inline-flex;
  align-items: center;
  gap: .82rem;
  min-width: 0;
}
.brand-mark {
  position: relative;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 3.1rem;
  height: 3.1rem;
  border: 1px solid rgba(25, 56, 43, .3);
  border-radius: var(--radius-pill);
  background: var(--forest);
  color: var(--lichen);
}
.brand-mark::after {
  content: "";
  position: absolute;
  inset: -.28rem;
  border: 1px solid rgba(25, 56, 43, .12);
  border-radius: inherit;
}
.brand-mark svg { width: 2.15rem; height: 2.15rem; }
.brand-mark path { fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.brand strong { display: block; font-size: 1.08rem; line-height: 1; letter-spacing: .01em; }
.brand small {
  display: block;
  margin-top: .08rem;
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .18em;
  line-height: 1;
  text-transform: uppercase;
}
.top-nav {
  display: flex;
  gap: .18rem;
  padding: .28rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-pill);
  background: var(--paper-strong);
  box-shadow: var(--shadow-soft);
  color: var(--ink-soft);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .03em;
}
.top-nav a {
  min-height: 2.25rem;
  display: inline-flex;
  align-items: center;
  padding: .48rem .72rem;
  border-radius: var(--radius-pill);
  transition: background .16s ease, color .16s ease;
}
.top-nav a:hover { background: var(--forest); color: var(--paper); }

/* Type */
.eyebrow {
  margin: 0 0 var(--space-2);
  color: var(--rust);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .18em;
  line-height: 1.25;
  text-transform: uppercase;
}
h1, h2, h3, h4, h5, h6 {
  margin: 0;
  color: var(--ink);
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", serif;
  text-wrap: balance;
}
h1 {
  max-width: 10ch;
  font-size: clamp(3.1rem, 7.7vw, 7.25rem);
  font-weight: 900;
  line-height: .98;
  letter-spacing: -.055em;
}
h2 {
  font-size: clamp(1.8rem, 3.4vw, 3.25rem);
  font-weight: 850;
  line-height: 1;
  letter-spacing: -.045em;
}
h3 {
  font-size: clamp(1.45rem, 2.25vw, 2.05rem);
  font-weight: 820;
  line-height: 1.06;
  letter-spacing: -.035em;
}
h4 {
  font-size: clamp(1.18rem, 1.55vw, 1.42rem);
  font-weight: 800;
  line-height: 1.16;
  letter-spacing: -.02em;
}
h5 {
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.22;
  letter-spacing: .02em;
}
h6 {
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .78rem;
  font-weight: 900;
  line-height: 1.25;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.lead {
  max-width: 49rem;
  margin: var(--space-4) 0 0;
  color: var(--ink-soft);
  font-size: clamp(1.08rem, 1.45vw, 1.3rem);
  line-height: 1.55;
}

/* Buttons */
.button,
.reset-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  border-radius: var(--radius-pill);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-weight: 850;
  line-height: 1;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease, border-color .16s ease;
}
.button { padding: .82rem 1.08rem; border: 1px solid rgba(25, 56, 43, .24); }
.button.primary { background: var(--forest); color: var(--paper); border-color: var(--forest); box-shadow: 0 12px 30px rgba(14, 38, 29, .14); }
.button.ghost { background: var(--paper-soft); color: var(--forest-2); }
.button:hover,
.reset-button:hover { transform: translateY(-1px); box-shadow: var(--shadow-soft); }
.button.primary:hover { background: var(--forest-2); }
.button.ghost:hover { background: var(--paper-strong); border-color: var(--line-strong); }

/* Hero */
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
  gap: clamp(1.5rem, 4vw, 4.25rem);
  align-items: center;
  min-height: 68vh;
  padding: clamp(3rem, 8vw, 6.5rem) 0 var(--space-6);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-5); }
.hero-panel { align-self: stretch; display: grid; align-items: center; }
.map-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-height: 22.5rem;
  padding: var(--space-4);
  overflow: hidden;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-xl);
  background: var(--paper-strong);
  box-shadow: var(--shadow-float);
  backdrop-filter: blur(4px);
}
.map-label {
  align-self: flex-start;
  display: inline-flex;
  padding: .47rem .74rem;
  border-radius: var(--radius-pill);
  background: var(--forest);
  color: var(--lichen);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .75rem;
  font-weight: 900;
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
  width: 100%;
  margin: auto 0 0;
}
.hero-stats div {
  padding: .85rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--paper-strong);
}
.hero-stats dt,
.facts-strip span,
.datasheet dt,
.price-card span,
.price-card small {
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .72rem;
}
.hero-stats dd { margin: .16rem 0 0; font-size: 1.35rem; font-weight: 950; letter-spacing: -.04em; }
.map-note { margin: 0; color: var(--ink-soft); line-height: 1.45; }

/* Catalog */
.catalog-layout {
  display: grid;
  grid-template-columns: 18rem minmax(0, 1fr);
  gap: var(--space-4);
  align-items: start;
  padding: 0 0 var(--space-7);
}
.sidebar,
.offer-card,
.price-card,
.contact-card,
.context-panel,
.datasheet,
.text-card,
.facts-strip div,
.empty-state {
  border: 1px solid var(--line);
  background: var(--paper-strong);
  box-shadow: var(--shadow-card);
}
.sidebar {
  position: sticky;
  top: 5.6rem;
  padding: var(--space-4);
  border-radius: var(--radius-lg);
}
.sidebar-head h2 { margin-bottom: var(--space-4); font-size: clamp(1.55rem, 2vw, 2rem); }
.filter-block { display: grid; gap: .48rem; margin-bottom: var(--space-4); }
.filter-block label,
.filter-label {
  color: rgba(23, 32, 24, .68);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .77rem;
  font-weight: 850;
  letter-spacing: .05em;
}
.field {
  width: 100%;
  min-height: 2.9rem;
  border: 1px solid rgba(25, 56, 43, .24);
  border-radius: var(--radius-md);
  padding: .82rem .95rem;
  background: rgba(255, 250, 240, .98);
}
.field:hover { border-color: var(--line-strong); }
.chip-row { display: flex; flex-wrap: wrap; gap: .4rem; }
.chip {
  min-height: 2.15rem;
  border: 1px solid rgba(25, 56, 43, .2);
  border-radius: var(--radius-pill);
  padding: .42rem .66rem;
  background: rgba(244, 236, 217, .62);
  color: rgba(23, 32, 24, .74);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .74rem;
  font-weight: 800;
}
.chip:hover { border-color: var(--forest); color: var(--forest); }
.chip.active { background: var(--forest); border-color: var(--forest); color: var(--paper); }
.reset-button {
  width: 100%;
  padding: .78rem 1rem;
  border: 1px dashed rgba(25, 56, 43, .32);
  background: transparent;
  color: var(--forest);
}
.filter-actions { display: grid; gap: var(--space-2); }
.filter-submit { width: 100%; }
.sidebar-note { margin: var(--space-4) 0 0; color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .86rem; line-height: 1.45; }
.catalog { min-width: 0; }
.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-5);
  margin: .15rem 0 var(--space-4);
}
.section-head p:last-child { max-width: 31rem; color: var(--ink-soft); line-height: 1.5; }
.active-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  margin: 0 0 var(--space-4);
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .78rem;
  font-weight: 850;
}
.active-filter-row b,
.active-filter-row a {
  display: inline-flex;
  min-height: 2rem;
  align-items: center;
  padding: .35rem .62rem;
  border-radius: var(--radius-pill);
  background: rgba(25, 56, 43, .08);
  color: var(--forest);
}
.active-filter-row a { background: transparent; border: 1px dashed rgba(25, 56, 43, .28); }
.cards-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-4); }

/* Cards */
.offer-card {
  display: flex;
  min-width: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  flex-direction: column;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.offer-card:hover,
.offer-card:focus-within { transform: translateY(-3px); border-color: var(--line-strong); box-shadow: var(--shadow-float); }
.card-image { position: relative; display: block; aspect-ratio: 4 / 3; background: var(--forest); overflow: hidden; }
.card-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 58%, rgba(14, 38, 29, .33));
  pointer-events: none;
}
.card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .24s ease; }
.offer-card:hover .card-image img { transform: scale(1.02); }
.type-pill {
  position: absolute;
  left: .8rem;
  bottom: .8rem;
  z-index: 2;
  padding: .44rem .66rem;
  border-radius: var(--radius-pill);
  background: rgba(14, 38, 29, .88);
  color: var(--paper);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .72rem;
  font-weight: 850;
}
.card-body { display: flex; flex: 1; flex-direction: column; padding: var(--space-4); }
.card-title {
  display: -webkit-box;
  min-height: 2.85rem;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  font-size: 1.15rem;
  font-weight: 900;
  line-height: 1.12;
  letter-spacing: -.025em;
}
.card-location {
  min-height: 2.25rem;
  margin: .55rem 0 .75rem;
  color: var(--ink-muted);
  font-size: .95rem;
  line-height: 1.35;
}
.card-price { display: flex; flex-wrap: wrap; gap: .55rem; align-items: baseline; margin-bottom: .85rem; }
.card-price strong { display: inline-flex; padding: .2rem .45rem; background: var(--lichen); color: var(--forest-2); font-size: 1.35rem; font-weight: 950; letter-spacing: -.04em; }
.card-price span { color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .82rem; }
.mini-facts { display: grid; grid-template-columns: repeat(3, 1fr); gap: .45rem; margin: 0 0 .85rem; }
.mini-facts div { min-width: 0; padding: .55rem; border: 1px solid rgba(25, 56, 43, .12); border-radius: var(--radius-sm); background: rgba(244, 236, 217, .5); }
.mini-facts dt { color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .66rem; }
.mini-facts dd { margin: .12rem 0 0; overflow: hidden; font-size: .9rem; font-weight: 850; text-overflow: ellipsis; white-space: nowrap; }
.signals-row { display: flex; flex-wrap: wrap; gap: .38rem; margin-top: auto; }
.signal-chip {
  max-width: 100%;
  overflow: hidden;
  padding: .42rem .55rem;
  border-radius: var(--radius-pill);
  background: rgba(25, 56, 43, .08);
  color: rgba(23, 32, 24, .72);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .7rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.signal-chip b { margin-right: .25rem; color: var(--forest); }
.empty-state { grid-column: 1 / -1; padding: var(--space-5); border-style: dashed; border-radius: var(--radius-md); }

/* Detail */
.detail-layout { padding: var(--space-4) 0 var(--space-7); }
.gallery-block { display: grid; gap: var(--space-3); }
.gallery-main { position: relative; overflow: hidden; border-radius: var(--radius-xl); aspect-ratio: 16 / 8; background: var(--forest); box-shadow: var(--shadow-float); }
.gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.gallery-count {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  padding: .48rem .68rem;
  border-radius: var(--radius-pill);
  background: rgba(14, 38, 29, .88);
  color: var(--paper);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-weight: 850;
}
.thumb-row { display: flex; gap: .55rem; overflow-x: auto; padding-bottom: .25rem; }
.thumb { flex: 0 0 6rem; height: 4.4rem; padding: 0; border: 2px solid transparent; border-radius: var(--radius-sm); overflow: hidden; background: transparent; opacity: .72; }
.thumb.active { border-color: var(--forest); opacity: 1; }
.thumb img { width: 100%; height: 100%; object-fit: cover; }
.object-sheet { display: grid; grid-template-columns: minmax(0, 1fr) 22.5rem; gap: var(--space-4); align-items: start; margin: var(--space-5) 0 var(--space-4); }
.object-head { padding: var(--space-3) 0; }
.back-link { display: inline-flex; margin-bottom: var(--space-3); color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; }
.back-link:hover,
.source-link:hover { color: var(--forest); }
.object-head h1 { max-width: 28ch; font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1.05; }
.detail-address { margin: var(--space-3) 0 0; color: var(--ink-soft); font-size: 1.08rem; }
.object-tools { display: grid; gap: var(--space-3); }
.price-card,
.contact-card,
.context-panel,
.datasheet,
.text-card { border-radius: var(--radius-lg); }
.price-card,
.contact-card,
.compact-panel,
.datasheet,
.text-card { padding: var(--space-4); }
.price-card strong { display: inline-flex; margin: .35rem 0; padding: .15rem .45rem; background: var(--lichen); font-size: 2rem; letter-spacing: -.05em; }
.contact-card { display: grid; gap: var(--space-2); }
.contact-card h2 { font-size: clamp(1.35rem, 2vw, 1.8rem); }
.contact-card .button { width: 100%; min-height: 2.75rem; }
.contact-card .source-link { margin-top: 0; }
.facts-strip { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: .65rem; margin: var(--space-4) 0 var(--space-5); }
.facts-strip div { padding: .85rem; border-radius: var(--radius-md); }
.facts-strip strong { display: block; margin-top: .25rem; overflow: hidden; font-size: 1.03rem; text-overflow: ellipsis; white-space: nowrap; }
.signal-panel { display: grid; gap: .55rem; }
.signal-card { padding: .72rem; border-radius: var(--radius-md); background: rgba(25, 56, 43, .07); }
.signal-card div { display: flex; justify-content: space-between; gap: .7rem; align-items: baseline; }
.signal-card span { color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .72rem; }
.signal-card strong { text-align: right; font-size: .82rem; }
.signal-card i { display: block; height: .42rem; margin-top: .45rem; border-radius: var(--radius-pill); background: rgba(25, 56, 43, .12); overflow: hidden; }
.signal-card b { display: block; height: 100%; border-radius: inherit; background: var(--moss); }
.muted { margin: .75rem 0 0; color: var(--ink-muted); line-height: 1.45; }
.content-grid { display: grid; grid-template-columns: 20rem minmax(0, 1fr); gap: var(--space-4); align-items: start; min-width: 0; }
.datasheet,
.text-stack,
.text-card { min-width: 0; }
.datasheet { position: sticky; top: 5.6rem; }
.datasheet dl { display: grid; gap: .55rem; margin: 0; }
.datasheet dl div { padding: .65rem 0; border-bottom: 1px solid rgba(25, 56, 43, .12); }
.datasheet dd { margin: .16rem 0 0; font-weight: 850; }
.source-link { display: inline-flex; margin-top: var(--space-4); color: var(--forest); font-family: ui-sans-serif, system-ui, sans-serif; font-weight: 850; }
.text-stack { display: grid; gap: var(--space-4); }
.text-card h2 { margin-bottom: var(--space-3); font-size: clamp(1.7rem, 2.5vw, 2.2rem); }
.text-card p { margin: 0 0 1rem; color: rgba(23, 32, 24, .82); line-height: 1.65; overflow-wrap: anywhere; }
.detail-list { margin: 0; padding-left: 1.2rem; color: rgba(23, 32, 24, .82); line-height: 1.65; overflow-wrap: anywhere; }
.detail-rows { display: grid; gap: .55rem; margin: 0; }
.detail-rows div { display: grid; grid-template-columns: 12rem minmax(0, 1fr); gap: var(--space-3); padding: .7rem 0; border-bottom: 1px solid rgba(25, 56, 43, .12); }
.detail-rows dt { color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .76rem; }
.detail-rows dd { margin: 0; font-weight: 850; overflow-wrap: anywhere; }
button:disabled { cursor: not-allowed; opacity: .58; }

/* Auth, Admin, Forms */
.auth-layout,
.admin-shell,
.form-shell {
  padding: clamp(2.5rem, 6vw, 5rem) 0 var(--space-7);
}
.auth-layout {
  display: grid;
  min-height: 68vh;
  place-items: center;
}
.auth-card,
.form-card,
.table-card,
.dashboard-card,
.action-card,
.account-object-card,
.form-section,
.upload-placeholder,
.preview-banner,
.form-message {
  border: 1px solid var(--line);
  background: var(--paper-strong);
  box-shadow: var(--shadow-card);
}
.auth-card {
  width: min(100%, 34rem);
  padding: var(--space-5);
  border-radius: var(--radius-xl);
}
.auth-card h1,
.admin-hero h1,
.form-hero h1 { max-width: 12ch; font-size: clamp(2.35rem, 5vw, 4.6rem); }
.stack-form {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-5);
}
.stack-form label,
.form-grid label {
  display: grid;
  gap: .45rem;
}
.stack-form label span,
.form-grid label span {
  color: rgba(23, 32, 24, .68);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .77rem;
  font-weight: 850;
  letter-spacing: .05em;
}
.auth-note,
.form-helper {
  margin: var(--space-4) 0 0;
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .86rem;
  line-height: 1.5;
}
.preview-banner,
.form-message {
  display: flex;
  gap: var(--space-2);
  align-items: baseline;
  padding: .85rem 1rem;
  border-radius: var(--radius-lg);
  background: rgba(219, 232, 191, .55);
}
.preview-banner strong,
.form-message strong {
  color: var(--forest);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .78rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.preview-banner span,
.form-message span { color: var(--ink-soft); line-height: 1.45; }
.compact-preview { max-width: 28rem; }
.wide-message { margin-bottom: var(--space-4); }
.form-message { background: rgba(201, 130, 82, .14); border-color: rgba(201, 130, 82, .24); }
.admin-hero,
.form-hero {
  display: flex;
  gap: var(--space-5);
  align-items: end;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}
.compact-admin-hero { align-items: center; }
.admin-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin: 0 0 var(--space-4);
  padding: .32rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-pill);
  background: var(--paper-strong);
  box-shadow: var(--shadow-soft);
  width: fit-content;
}
.admin-subnav a {
  min-height: 2.35rem;
  display: inline-flex;
  align-items: center;
  padding: .52rem .78rem;
  border-radius: var(--radius-pill);
  color: var(--ink-soft);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .78rem;
  font-weight: 850;
}
.admin-subnav a:hover,
.admin-subnav a.active { background: var(--forest); color: var(--paper); }
.status-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
  margin: 0 0 var(--space-4);
}
.status-summary article {
  padding: var(--space-3);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-strong);
  box-shadow: var(--shadow-soft);
}
.status-summary span {
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.status-summary strong { display: block; margin-top: .15rem; font-size: 1.75rem; line-height: 1; }
.admin-status-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.status-filter-nav,
.form-jump-nav {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin: 0 0 var(--space-4);
  padding: .3rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-pill);
  background: var(--paper-strong);
  box-shadow: var(--shadow-soft);
  width: fit-content;
}
.status-filter-nav a,
.form-jump-nav a {
  min-height: 2.25rem;
  display: inline-flex;
  align-items: center;
  padding: .48rem .72rem;
  border-radius: var(--radius-pill);
  color: var(--ink-soft);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .77rem;
  font-weight: 850;
}
.status-filter-nav a:hover,
.status-filter-nav a.active,
.form-jump-nav a:hover { background: var(--forest); color: var(--paper); }
.dashboard-grid,
.action-grid,
.admin-grid-two {
  display: grid;
  gap: var(--space-4);
}
.dashboard-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-bottom: var(--space-4); }
.action-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.admin-grid-two { grid-template-columns: minmax(0, 1.2fr) minmax(20rem, .8fr); align-items: start; }
.dashboard-card,
.action-card,
.account-object-card {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
}
.dashboard-card span,
.action-card span {
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.dashboard-card strong { font-size: 2.15rem; line-height: 1; letter-spacing: -.05em; }
.dashboard-card p,
.action-card p,
.account-object-card p { margin: 0; color: var(--ink-muted); line-height: 1.45; }
.action-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-float); border-color: var(--line-strong); }
.panel-head { margin-bottom: var(--space-4); }
.panel-head h2 { font-size: clamp(1.55rem, 2vw, 2.1rem); }
.form-card,
.table-card,
.form-section {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
}
.table-scroll { overflow-x: auto; }
.data-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 42rem;
}
.data-table th,
.data-table td {
  padding: .85rem .75rem;
  border-bottom: 1px solid rgba(25, 56, 43, .12);
  text-align: left;
  vertical-align: top;
}
.data-table th {
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.data-table td { line-height: 1.35; }
.data-table td:first-child { font-weight: 850; }
.object-table td:first-child { max-width: 24rem; }
.status-badge,
.role-pill {
  display: inline-flex;
  align-items: center;
  min-height: 1.85rem;
  padding: .34rem .58rem;
  border-radius: var(--radius-pill);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .04em;
  white-space: nowrap;
}
.status-badge.aktiv { background: var(--forest); color: var(--paper); }
.status-badge.entwurf { background: var(--lichen); color: var(--forest-2); }
.status-badge.archiviert,
.status-badge.deaktiviert { background: rgba(23, 32, 24, .12); color: var(--ink-muted); }
.role-pill { background: rgba(25, 56, 43, .08); color: var(--forest); text-transform: uppercase; }
.link-button,
.table-actions button,
.table-actions a {
  border: 0;
  background: none;
  color: var(--forest);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .78rem;
  font-weight: 850;
  padding: 0;
}
.table-actions { display: flex; flex-wrap: wrap; gap: .65rem; }
.table-actions form { margin: 0; }
.mobile-object-list { display: none; }
.mobile-admin-card {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-strong);
  box-shadow: var(--shadow-soft);
}
.mobile-admin-card img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: var(--radius-sm); background: var(--forest); }
.mobile-admin-card h3 { margin: .45rem 0 .25rem; font-size: 1.28rem; }
.mobile-admin-card p { margin: 0 0 .3rem; color: var(--ink-muted); }
.mobile-admin-card strong { font-size: 1.05rem; }
.mobile-actions a,
.mobile-actions button { min-height: 2.1rem; }
.account-cards { align-items: stretch; }
.account-object-card h2 { margin: .55rem 0 .25rem; font-size: clamp(1.35rem, 2vw, 1.8rem); }
.account-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: auto; }
.account-actions .button { width: auto; min-height: 2.65rem; }
.account-object-card.status-archiviert { opacity: .78; }
.account-object-card.status-entwurf { border-color: rgba(111, 143, 89, .28); }
.form-shell { max-width: 68rem; }
.object-form { display: grid; gap: var(--space-4); }
.form-section-head { display: grid; gap: var(--space-1); margin-bottom: var(--space-4); }
.form-section-head h2 { font-size: clamp(1.55rem, 2.4vw, 2.4rem); }
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}
.wide-field { grid-column: 1 / -1; }
textarea.field { min-height: 8rem; resize: vertical; line-height: 1.5; }
.checkbox-card {
  align-self: end;
  min-height: 2.9rem;
  padding: .82rem .95rem;
  border: 1px solid rgba(25, 56, 43, .24);
  border-radius: var(--radius-md);
  background: rgba(255, 250, 240, .98);
  display: flex !important;
  grid-template-columns: auto 1fr;
  gap: .65rem !important;
  align-items: center;
}
.checkbox-card input { width: 1.05rem; height: 1.05rem; }
.upload-placeholder {
  display: grid;
  place-items: center;
  min-height: 13rem;
  padding: var(--space-5);
  border-style: dashed;
  border-radius: var(--radius-lg);
  text-align: center;
}
.upload-placeholder strong { font-size: 1.35rem; }
.upload-placeholder p { max-width: 34rem; margin: .45rem 0 0; color: var(--ink-muted); line-height: 1.5; }
.upload-field { gap: var(--space-3); }
.upload-field label { width: min(100%, 34rem); }
.image-selection,
.upload-status { min-height: 1.25rem; margin: .35rem 0 0; color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .84rem; line-height: 1.35; }
.image-selection { max-width: 34rem; }
.inline-upload { display: grid; gap: var(--space-2); margin-top: var(--space-2); padding-top: var(--space-2); border-top: 1px solid rgba(25, 56, 43, .12); }
.inline-upload label { display: grid; gap: .35rem; color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .76rem; font-weight: 850; }
.inline-upload .button { width: fit-content; min-height: 2.4rem; padding: .64rem .9rem; }
.account-thumb { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: var(--radius-sm); background: var(--forest); }
.admin-object-title { display: flex; gap: .65rem; align-items: center; }
.admin-object-title img { width: 4.5rem; height: 3.2rem; object-fit: cover; border-radius: .45rem; background: var(--forest); }
.table-upload { flex: 1 1 100%; max-width: 22rem; }
.table-upload .field { min-height: 2.25rem; padding: .42rem; font-size: .78rem; }
.detail-preview-banner { width: min(var(--page-max), calc(100% - 2rem)); margin: var(--space-4) auto 0; }
.detail-preview-banner a { margin-left: auto; color: var(--forest); font-family: ui-sans-serif, system-ui, sans-serif; font-weight: 850; }
.preview-action-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  width: min(var(--page-max), calc(100% - 2rem));
  margin: var(--space-2) auto 0;
  padding: var(--space-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-strong);
  box-shadow: var(--shadow-soft);
}
.preview-action-bar form { margin: 0; }
.preview-action-bar .button { min-height: 2.45rem; }
.image-manager-section { margin-bottom: var(--space-3); }
.image-manager { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-3); }
.image-manager-card { display: grid; grid-template-columns: 8rem minmax(0, 1fr); gap: var(--space-2); align-items: center; padding: var(--space-2); border: 1px solid rgba(25, 56, 43, .14); border-radius: var(--radius-sm); background: rgba(255, 250, 240, .72); }
.image-manager-card img { width: 8rem; height: 5.5rem; object-fit: cover; border-radius: .45rem; background: var(--forest); }
.image-manager-card strong,
.image-manager-card span { display: block; font-family: ui-sans-serif, system-ui, sans-serif; }
.image-manager-card strong { color: var(--forest); font-size: .82rem; }
.image-manager-card span { overflow: hidden; color: var(--ink-muted); font-size: .76rem; text-overflow: ellipsis; white-space: nowrap; }
.image-actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: .6rem; }
.image-actions form { margin: 0; }
.image-actions button { border: 0; background: none; color: var(--forest); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .78rem; font-weight: 850; padding: 0; }
.form-submit-bar {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
  padding: var(--space-3);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  background: rgba(255, 250, 240, .9);
  box-shadow: var(--shadow-float);
  backdrop-filter: blur(14px);
}
.footer { display: flex; justify-content: space-between; gap: var(--space-4); align-items: center; padding: var(--space-5) clamp(1rem, 4vw, 4rem); border-top: 1px solid var(--line); background: rgba(25, 56, 43, .06); }
.footer p { margin: .25rem 0 0; color: var(--ink-muted); }
.footer-links { display: flex; flex-wrap: wrap; gap: .45rem; justify-content: flex-end; }
.footer-links a {
  min-height: 2.55rem;
  display: inline-flex;
  align-items: center;
  padding: .68rem .9rem;
  border: 1px solid rgba(25, 56, 43, .2);
  border-radius: var(--radius-pill);
  background: var(--paper-soft);
  color: var(--forest-2);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .82rem;
  font-weight: 850;
}
.footer-links a:hover { background: var(--forest); color: var(--paper); }

/* Legal pages */
.legal-shell { max-width: 860px; padding: clamp(2.5rem, 6vw, 5rem) 0 var(--space-7); }
.legal-hero { margin-bottom: var(--space-4); }
.legal-hero h1 { max-width: none; font-size: clamp(2.7rem, 7vw, 5.4rem); }
.legal-card {
  margin-bottom: var(--space-4);
  padding: var(--space-5);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-strong);
  box-shadow: var(--shadow-card);
}
.legal-card h2 { margin-bottom: var(--space-3); font-size: clamp(1.55rem, 2.5vw, 2.25rem); }
.legal-card p { margin: 0 0 var(--space-3); color: rgba(23, 32, 24, .82); line-height: 1.65; }
.legal-card p:last-child { margin-bottom: 0; }
.legal-card code { padding: .12rem .3rem; border-radius: .35rem; background: rgba(25, 56, 43, .08); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .92em; }
.legal-rows { display: grid; gap: .75rem; margin: 0; }
.legal-rows div { display: grid; grid-template-columns: 11rem minmax(0, 1fr); gap: var(--space-3); padding-bottom: .75rem; border-bottom: 1px solid rgba(25, 56, 43, .12); }
.legal-rows div:last-child { border-bottom: 0; padding-bottom: 0; }
.legal-rows dt { color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; font-size: .78rem; font-weight: 850; }
.legal-rows dd { margin: 0; font-weight: 850; line-height: 1.45; }
.muted-card { background: rgba(219, 232, 191, .35); }

/* Functional backend masks */
body[data-page^="admin"],
body[data-page="meine-objekte"],
body[data-page="objekt-neu"] {
  font-family: ui-sans-serif, system-ui, sans-serif;
  background-color: #f3eedf;
  background-image:
    linear-gradient(90deg, rgba(25, 56, 43, .035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(25, 56, 43, .035) 1px, transparent 1px),
    linear-gradient(180deg, #f7f1e3 0%, #eee5d2 100%);
  background-size: 56px 56px, 56px 56px, auto;
  background-attachment: fixed, fixed, scroll;
}
body[data-page^="admin"] main,
body[data-page="meine-objekte"] main,
body[data-page="objekt-neu"] main { width: min(1320px, calc(100% - 2rem)); }
body[data-page^="admin"] h1,
body[data-page^="admin"] h2,
body[data-page^="admin"] h3,
body[data-page="meine-objekte"] h1,
body[data-page="meine-objekte"] h2,
body[data-page="meine-objekte"] h3,
body[data-page="objekt-neu"] h1,
body[data-page="objekt-neu"] h2,
body[data-page="objekt-neu"] h3 {
  max-width: none;
  font-family: ui-sans-serif, system-ui, sans-serif;
  letter-spacing: -.025em;
}
body[data-page^="admin"] .site-header,
body[data-page="meine-objekte"] .site-header,
body[data-page="objekt-neu"] .site-header {
  background: rgba(247, 241, 227, .94);
  box-shadow: none;
}
body[data-page^="admin"] .top-nav,
body[data-page="meine-objekte"] .top-nav,
body[data-page="objekt-neu"] .top-nav {
  gap: .35rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
body[data-page^="admin"] .top-nav a,
body[data-page="meine-objekte"] .top-nav a,
body[data-page="objekt-neu"] .top-nav a {
  min-height: 2.15rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(255, 250, 240, .72);
}
body[data-page^="admin"] .admin-shell,
body[data-page="meine-objekte"] .admin-shell,
body[data-page="objekt-neu"] .form-shell {
  padding: var(--space-4) 0 var(--space-6);
}
body[data-page="objekt-neu"] .form-shell { max-width: 1180px; }
body[data-page^="admin"] .admin-hero,
body[data-page="meine-objekte"] .admin-hero,
body[data-page="objekt-neu"] .form-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-4);
  align-items: center;
  margin-bottom: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 250, 240, .82);
  box-shadow: none;
}
body[data-page^="admin"] .admin-hero h1,
body[data-page="meine-objekte"] .admin-hero h1,
body[data-page="objekt-neu"] .form-hero h1 {
  font-size: clamp(1.75rem, 2.3vw, 2.45rem);
  line-height: 1.08;
}
body[data-page^="admin"] .lead,
body[data-page="meine-objekte"] .lead,
body[data-page="objekt-neu"] .lead {
  max-width: 58rem;
  margin-top: .45rem;
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .95rem;
  line-height: 1.45;
}
body[data-page^="admin"] .eyebrow,
body[data-page="meine-objekte"] .eyebrow,
body[data-page="objekt-neu"] .eyebrow {
  margin-bottom: .35rem;
  font-size: .68rem;
  letter-spacing: .12em;
}
body[data-page^="admin"] .preview-banner,
body[data-page="meine-objekte"] .preview-banner,
body[data-page="objekt-neu"] .preview-banner,
body[data-page="objekt-neu"] .form-message {
  padding: .62rem .78rem;
  border-radius: var(--radius-sm);
  background: rgba(219, 232, 191, .36);
  box-shadow: none;
}
body[data-page^="admin"] .preview-banner span,
body[data-page="meine-objekte"] .preview-banner span,
body[data-page="objekt-neu"] .preview-banner span,
body[data-page="objekt-neu"] .form-message span { font-size: .86rem; }
body[data-page^="admin"] .admin-subnav {
  width: 100%;
  gap: .35rem;
  margin-bottom: var(--space-3);
  padding: 0 0 var(--space-2);
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
body[data-page^="admin"] .admin-subnav a {
  min-height: 2.1rem;
  padding: .48rem .72rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(255, 250, 240, .72);
  color: var(--ink-soft);
  font-size: .78rem;
}
body[data-page^="admin"] .admin-subnav a:hover,
body[data-page^="admin"] .admin-subnav a.active { background: var(--forest); color: var(--paper); }
body[data-page^="admin"] .dashboard-grid { gap: var(--space-2); margin-bottom: var(--space-3); }
body[data-page^="admin"] .action-grid,
body[data-page^="admin"] .admin-grid-two { gap: var(--space-3); }
body[data-page^="admin"] .dashboard-card,
body[data-page^="admin"] .action-card,
body[data-page^="admin"] .table-card,
body[data-page^="admin"] .form-card,
body[data-page="meine-objekte"] .account-object-card,
body[data-page="objekt-neu"] .form-section,
body[data-page="objekt-neu"] .upload-placeholder {
  border-radius: var(--radius-md);
  box-shadow: none;
}
body[data-page^="admin"] .dashboard-card,
body[data-page^="admin"] .action-card,
body[data-page="meine-objekte"] .account-object-card { padding: var(--space-3); }
body[data-page^="admin"] .dashboard-card strong { font-size: 1.7rem; }
body[data-page^="admin"] .dashboard-card p,
body[data-page^="admin"] .action-card p,
body[data-page="meine-objekte"] .account-object-card p { font-size: .86rem; }
body[data-page^="admin"] .action-card:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--line-strong);
  background: var(--paper-strong);
}
body[data-page^="admin"] .panel-head { margin-bottom: var(--space-3); }
body[data-page^="admin"] .panel-head h2,
body[data-page="objekt-neu"] .form-section-head h2 { font-size: 1.18rem; line-height: 1.18; }
body[data-page^="admin"] .form-card,
body[data-page^="admin"] .table-card,
body[data-page="objekt-neu"] .form-section { padding: var(--space-3); }
body[data-page^="admin"] .data-table {
  min-width: 40rem;
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .9rem;
}
body[data-page^="admin"] .data-table th,
body[data-page^="admin"] .data-table td { padding: .62rem .68rem; }
body[data-page^="admin"] .data-table th { font-size: .66rem; }
body[data-page^="admin"] .data-table tbody tr:hover { background: rgba(25, 56, 43, .035); }
body[data-page="admin-objekte"] .data-table { min-width: 58rem; }
body[data-page^="admin"] .status-badge,
body[data-page^="admin"] .role-pill,
body[data-page="meine-objekte"] .status-badge {
  min-height: 1.55rem;
  padding: .26rem .48rem;
  font-size: .64rem;
}
body[data-page^="admin"] .field,
body[data-page="objekt-neu"] .field {
  min-height: 2.55rem;
  padding: .62rem .75rem;
  border-radius: var(--radius-sm);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-size: .92rem;
}
body[data-page^="admin"] .stack-form,
body[data-page="objekt-neu"] .stack-form { gap: var(--space-2); margin-top: var(--space-3); }
body[data-page="objekt-neu"] .object-form { gap: var(--space-3); }
body[data-page="objekt-neu"] .form-section-head {
  display: grid;
  grid-template-columns: 10rem minmax(0, 1fr);
  gap: var(--space-3);
  align-items: start;
  margin-bottom: var(--space-3);
}
body[data-page="objekt-neu"] .form-grid { gap: var(--space-2); }
body[data-page="objekt-neu"] textarea.field { min-height: 6rem; }
body[data-page="objekt-neu"] .upload-placeholder { min-height: 8rem; padding: var(--space-4); }
body[data-page="objekt-neu"] .form-submit-bar {
  padding: var(--space-2);
  border-radius: var(--radius-md);
  box-shadow: none;
}

/* Styleguide */
.styleguide-shell { padding-bottom: var(--space-7); }
.styleguide-hero {
  max-width: 56rem;
  padding: clamp(3rem, 8vw, 6.5rem) 0 var(--space-6);
}
.styleguide-hero h1 { max-width: 11ch; }
.styleguide-section {
  margin: 0 0 var(--space-7);
  padding: var(--space-5);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: rgba(255, 250, 240, .66);
  box-shadow: var(--shadow-card);
}
.styleguide-section-head {
  display: grid;
  gap: var(--space-2);
  max-width: 52rem;
  margin-bottom: var(--space-5);
}
.styleguide-section-head p:last-child { margin: 0; color: var(--ink-soft); line-height: 1.55; }
.token-grid,
.styleguide-panel-grid,
.state-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}
.token-card,
.styleguide-note-card {
  padding: var(--space-4);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-strong);
  box-shadow: var(--shadow-card);
}
.token-card span {
  display: block;
  width: 100%;
  height: 4.5rem;
  margin-bottom: var(--space-3);
  border: 1px solid rgba(25, 56, 43, .12);
  border-radius: var(--radius-md);
}
.token-card strong,
.token-card small { display: block; }
.token-card small { margin-top: .2rem; color: var(--ink-muted); font-family: ui-sans-serif, system-ui, sans-serif; }
.type-specimen {
  display: grid;
  gap: var(--space-3);
  max-width: 56rem;
}
.type-specimen h1 { max-width: 10ch; font-size: clamp(2.8rem, 7vw, 6.5rem); }
.type-specimen h2 { margin-top: var(--space-3); }
.type-specimen p:not(.eyebrow) { margin: 0; max-width: 44rem; line-height: 1.6; }
.type-scale {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-5);
}
.type-row {
  display: grid;
  grid-template-columns: 16rem minmax(0, 1fr);
  gap: var(--space-4);
  align-items: baseline;
  padding: var(--space-4);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--paper-strong);
  box-shadow: var(--shadow-card);
}
.type-row span,
.type-row code {
  display: block;
  font-family: ui-sans-serif, system-ui, sans-serif;
}
.type-row span {
  color: var(--forest);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.type-row code {
  margin-top: .25rem;
  color: var(--ink-muted);
  font-size: .78rem;
}
.type-row h1,
.type-row h2,
.type-row h3,
.type-row h4,
.type-row h5,
.type-row h6 { max-width: none; }
.component-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}
.component-row .reset-button { width: auto; }
.styleguide-demo-layout { padding-bottom: 0; }
.styleguide-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 56rem; }
.image-placeholder {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background:
    linear-gradient(135deg, rgba(25, 56, 43, .12), rgba(201, 130, 82, .08)),
    var(--sand);
  color: var(--ink-muted);
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-weight: 850;
}
.styleguide-facts-demo { margin-bottom: 0; }
.styleguide-gallery-main { max-height: 26rem; }
.styleguide-content-demo { margin-top: var(--space-4); }
.error-state { border-color: rgba(158, 84, 59, .34); }
.loading-state { opacity: .78; }
.empty-state strong { display: block; margin-bottom: .25rem; }
.empty-state p { margin: 0; color: var(--ink-muted); }

/* Tablet */
@media (max-width: 1079px) {
  main { width: min(100% - 1.5rem, var(--page-max)); }
  .hero { grid-template-columns: 1fr; min-height: auto; padding-top: var(--space-6); }
  .map-card { min-height: auto; }
  .hero-stats { margin-top: var(--space-4); }
  .catalog-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .cards-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .object-sheet,
  .content-grid,
  .dashboard-grid,
  .action-grid,
  .admin-grid-two,
  .image-manager { grid-template-columns: 1fr; }
  .datasheet { position: static; }
}

/* Mobile */
@media (max-width: 719px) {
  body { background-attachment: scroll; background-size: 64px 64px, 64px 64px, 1200px auto, auto; }
  main { width: min(100% - 1rem, var(--page-max)); }
  .site-header { align-items: center; flex-wrap: wrap; gap: .65rem; padding: .78rem 1rem; }
  .brand-mark { width: 2.75rem; height: 2.75rem; }
  .brand-mark svg { width: 1.9rem; height: 1.9rem; }
  .top-nav {
    order: 2;
    flex: 1 1 100%;
    width: 100%;
    overflow-x: auto;
    border-radius: var(--radius-lg);
    box-shadow: none;
    scrollbar-width: none;
  }
  .top-nav::-webkit-scrollbar { display: none; }
  .top-nav a { flex: 0 0 auto; min-height: 2.45rem; }
  h1 { font-size: clamp(2.65rem, 16vw, 4.2rem); }
  h2 { font-size: clamp(1.8rem, 9vw, 2.5rem); }
  .hero { gap: var(--space-5); padding: var(--space-5) 0 var(--space-6); }
  .lead { font-size: 1.04rem; }
  .hero-actions { align-items: stretch; flex-direction: column; }
  .button { width: 100%; }
  .hero-stats,
  .mini-facts,
  .facts-strip { grid-template-columns: 1fr; }
  .section-head { display: block; }
  .section-head p:last-child { margin-top: var(--space-3); }
  .cards-grid,
  .styleguide-card-grid,
  .styleguide-panel-grid,
  .state-grid,
  .type-row { grid-template-columns: 1fr; }
  .token-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .styleguide-section { padding: var(--space-4); }
  .styleguide-hero { padding-top: var(--space-5); }
  .card-title { min-height: auto; }
  .gallery-main { aspect-ratio: 4 / 3; border-radius: var(--radius-lg); }
  .object-head h1 { font-size: clamp(1.65rem, 8vw, 2.3rem); }
  .price-card strong { font-size: 1.75rem; }
  .admin-hero,
  .form-hero,
  .preview-banner,
  .form-message { display: block; }
  .preview-banner span,
  .form-message span { display: block; margin-top: .25rem; }
  .admin-subnav,
  .status-filter-nav,
  .form-jump-nav { width: 100%; border-radius: var(--radius-lg); overflow-x: auto; }
  .admin-subnav a,
  .status-filter-nav a,
  .form-jump-nav a { flex: 1 1 auto; justify-content: center; }
  body[data-page^="admin"] main,
  body[data-page="meine-objekte"] main,
  body[data-page="objekt-neu"] main { width: min(100% - 1rem, var(--page-max)); }
  body[data-page^="admin"] .admin-hero,
  body[data-page="meine-objekte"] .admin-hero,
  body[data-page="objekt-neu"] .form-hero,
  body[data-page="objekt-neu"] .form-section-head { grid-template-columns: 1fr; }
  body[data-page^="admin"] .admin-subnav { border-bottom: 0; }
  body[data-page^="admin"] .dashboard-grid,
  .status-summary,
  .admin-status-summary { grid-template-columns: 1fr 1fr; }
  .admin-object-table { display: none; }
  .mobile-object-list { display: grid; gap: var(--space-3); }
  .mobile-actions { gap: var(--space-2); }
  .mobile-actions a,
  .mobile-actions button { display: inline-flex; align-items: center; padding: .45rem .6rem; border-radius: var(--radius-pill); background: rgba(25, 56, 43, .08); }
  .form-grid { grid-template-columns: 1fr; }
  .form-submit-bar { position: static; border-radius: var(--radius-lg); flex-direction: column; }
  .form-submit-bar .button,
  .account-actions .button { width: 100%; }
  .footer { display: block; }
  .footer-links { justify-content: flex-start; margin-top: var(--space-4); }
  .footer-links a { flex: 1 1 auto; justify-content: center; }
  .legal-card { padding: var(--space-4); }
  .legal-rows div { grid-template-columns: 1fr; gap: .25rem; }
}

@media (max-width: 420px) {
  .map-card,
  .sidebar,
  .card-body,
  .price-card,
  .contact-card,
  .compact-panel,
  .datasheet,
  .text-card { padding: var(--space-3); }
  .thumb { flex-basis: 5.2rem; height: 3.85rem; }
  .signal-card div { display: block; }
  .signal-card strong { margin-top: .15rem; text-align: left; }
}
