:root {
  --brand: #188b97;
  --brand-2: #22c1c8;
  --brand-3: #14b8a6;
  --accent: #84cc16;
  --bg-1: #eef6f7;
  --bg-2: #e2f1f3;
  --bg-3: #fff8e8;
  --surface: rgba(255,255,255,0.68);
  --surface-solid: #fff;
  --surface-2: rgba(255,255,255,0.46);
  --border: rgba(15,28,36,0.09);
  --border-strong: rgba(15,28,36,0.15);
  --text-1: #0c1f25;
  --text-2: #4d6068;
  --text-3: #8696a0;
  --green: #16a34a;
  --green-soft: rgba(22,163,74,0.12);
  --red: #e11d48;
  --red-soft: rgba(225,29,72,0.12);
  --amber: #fbbf24;
  --amber-soft: rgba(251,191,36,0.18);
  --blue: #3b82f6;
  --blue-soft: rgba(59,130,246,0.14);
  --shadow-sm: 0 2px 6px rgba(8,42,52,0.06);
  --shadow-md: 0 14px 32px rgba(8,42,52,0.10);
  --shadow-lg: 0 30px 60px rgba(8,42,52,0.18);
  --shadow-glow: 0 0 0 1px rgba(255,255,255,0.4) inset;
  --radius: 18px;
  --radius-sm: 12px;
}

[data-theme="dark"] {
  --bg-1: #050c12;
  --bg-2: #0a141c;
  --bg-3: #0a1925;
  --surface: rgba(20,32,42,0.58);
  --surface-solid: #131e29;
  --surface-2: rgba(20,32,42,0.36);
  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.16);
  --text-1: #eaf2f6;
  --text-2: #a3b1bc;
  --text-3: #6c7c88;
  --shadow-md: 0 14px 32px rgba(0,0,0,0.58);
  --shadow-lg: 0 30px 60px rgba(0,0,0,0.70);
  --shadow-glow: 0 0 0 1px rgba(255,255,255,0.06) inset;
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
[hidden] { display: none !important; }
body {
  min-height: 100vh;
  font-family: Inter, -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--text-1);
  background: var(--bg-1);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(900px 600px at 8% 8%, rgba(34,193,200,0.30), transparent 60%),
    radial-gradient(700px 500px at 92% 12%, rgba(132,204,22,0.18), transparent 60%),
    radial-gradient(800px 600px at 50% 100%, rgba(24,139,151,0.25), transparent 65%);
}
[data-theme="dark"] body::before {
  background:
    radial-gradient(900px 600px at 8% 8%, rgba(34,193,200,0.18), transparent 60%),
    radial-gradient(700px 500px at 92% 12%, rgba(132,204,22,0.10), transparent 60%),
    radial-gradient(800px 600px at 50% 100%, rgba(24,139,151,0.18), transparent 65%);
}
a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }
.hidden { display: none !important; }

.glass {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md), var(--shadow-glow);
  backdrop-filter: blur(22px) saturate(160%);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
}

.auth-shell {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(380px, 440px);
  align-items: center;
  gap: 42px;
  width: min(1160px, calc(100vw - 40px));
  margin: 0 auto;
  padding: 42px 0;
}
.auth-brand { display: grid; gap: 34px; }
.logo-xl { width: min(310px, 74vw); height: auto; display: block; }
.auth-copy { max-width: 720px; }
.eyebrow, .pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  padding: 6px 11px;
  border: 1px solid rgba(24,139,151,0.18);
  border-radius: 999px;
  background: rgba(24,139,151,0.10);
  color: var(--brand);
  font-size: 12px;
  font-weight: 700;
}
.auth-copy h1 {
  max-width: 760px;
  margin: 18px 0 14px;
  font-size: clamp(36px, 5.4vw, 68px);
  line-height: 0.98;
  letter-spacing: 0;
}
.auth-copy p {
  max-width: 620px;
  margin: 0;
  color: var(--text-2);
  font-size: 17px;
}
.auth-preview { width: min(520px, 100%); padding: 20px; }
.preview-row { display: flex; justify-content: space-between; align-items: center; gap: 18px; font-size: 13px; color: var(--text-2); }
.preview-row strong { font-size: 22px; color: var(--text-1); }
.preview-row.muted { border-top: 1px dashed var(--border); padding-top: 14px; }
.preview-bars { height: 126px; display: flex; align-items: end; gap: 12px; padding: 18px 2px; }
.preview-bars i {
  flex: 1;
  border-radius: 12px 12px 4px 4px;
  background: linear-gradient(180deg, var(--brand-2), var(--accent));
  box-shadow: 0 12px 24px rgba(24,139,151,0.24);
}

.auth-panel { padding: 24px; }
.theme-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 22px; }
.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  padding: 4px;
  border-radius: 14px;
  background: rgba(255,255,255,0.42);
  border: 1px solid var(--border);
  margin-bottom: 18px;
}
[data-theme="dark"] .auth-tabs { background: rgba(255,255,255,0.04); }
.auth-tab {
  border: 0;
  background: transparent;
  color: var(--text-2);
  border-radius: 11px;
  padding: 10px;
  cursor: pointer;
  font-weight: 700;
}
.auth-tab.active { background: var(--surface-solid); color: var(--brand); box-shadow: var(--shadow-sm); }
.auth-form { display: none; }
.auth-form.active, .stack-form { display: grid; gap: 14px; }
.form-separated {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.section-focus {
  animation: sectionPulse 0.9s ease;
}
@keyframes sectionPulse {
  0% { box-shadow: 0 0 0 0 rgba(24,139,151,0); }
  35% { box-shadow: 0 0 0 4px rgba(24,139,151,0.18), var(--shadow-md); }
  100% { box-shadow: 0 0 0 0 rgba(24,139,151,0); }
}
label { display: grid; gap: 7px; }
label span { color: var(--text-2); font-size: 12px; font-weight: 700; }
input, select {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  background-color: rgba(255,255,255,0.55);
  color: var(--text-1);
  min-height: 56px;
  padding: 14px 16px;
  line-height: 1.35;
  outline: 0;
}
select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 44px;
  background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7L9 3L13 7' stroke='%2364758B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M5 11L9 15L13 11' stroke='%2364758B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px 18px;
}
[data-theme="dark"] input, [data-theme="dark"] select { background-color: rgba(255,255,255,0.04); }
[data-theme="dark"] select {
  background-image: url("data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 7L9 3L13 7' stroke='%23E5EDF4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M5 11L9 15L13 11' stroke='%23E5EDF4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
input:focus, select:focus { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(24,139,151,0.16); }
input[type="color"] { min-height: 45px; padding: 6px; cursor: pointer; }

.layout { position: relative; z-index: 1; display: flex; min-height: 100vh; }
.sidebar { width: 256px; flex-shrink: 0; padding: 22px 14px; position: sticky; top: 0; height: 100vh; }
.sidebar-inner { height: 100%; padding: 20px 14px; display: flex; flex-direction: column; }
.brand { display: flex; align-items: center; padding: 4px 8px 18px; border-bottom: 1px solid var(--border); margin-bottom: 14px; }
.brand-logo { width: 174px; max-width: 100%; height: auto; display: block; }
.nav { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.nav-section {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 14px 10px 6px;
}
.nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  color: var(--text-2);
  font-weight: 600;
}
.nav-link i { width: 18px; text-align: center; }
.nav-link:hover { background: var(--surface-2); color: var(--text-1); }
.nav-link.active {
  color: var(--brand);
  background: linear-gradient(135deg, rgba(24,139,151,0.18), rgba(34,193,200,0.10));
  box-shadow: 0 0 0 1px rgba(24,139,151,0.18) inset;
}
.admin-nav { display: none; }
.is-platform-admin .admin-nav { display: flex; }
.sidebar-footer { border-top: 1px solid var(--border); padding-top: 12px; }
.user { display: flex; gap: 12px; align-items: center; padding: 4px 6px; min-width: 0; }
.user-avatar, .profile-avatar {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 800;
  background: linear-gradient(135deg, var(--accent), var(--brand));
}
.user-info { min-width: 0; }
.user-name { font-weight: 700; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-role { font-size: 12px; color: var(--text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.main {
  flex: 1;
  width: 100%;
  max-width: min(calc(100vw - 256px), 1480px);
  min-height: 100vh;
  margin-right: auto;
  padding: 22px 28px 28px 8px;
  display: flex;
  flex-direction: column;
}
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 18px;
  margin-bottom: 22px;
}
[data-page="locationDetail"] .topbar {
  padding-left: 0;
  padding-right: 0;
}
.page-title { margin: 0; font-size: 22px; line-height: 1.2; }
.page-sub { margin: 2px 0 0; color: var(--text-2); font-size: 13px; }
.topbar-right { display: flex; align-items: center; gap: 10px; }
.search {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 320px;
  padding: 8px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,0.55);
  border: 1px solid var(--border);
}
[data-theme="dark"] .search { background: rgba(255,255,255,0.04); }
.search input { border: 0; padding: 0; background: transparent; box-shadow: none; min-height: 0; }

.icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.55);
  color: var(--text-2);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: transform 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
[data-theme="dark"] .icon-btn { background: rgba(255,255,255,0.04); }
.icon-btn:hover { color: var(--brand); border-color: var(--brand); transform: translateY(-1px); }

.kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-bottom: 22px; }
.analysis-head { margin: 0 0 12px; }
.analysis-head h2 { margin: 0; font-size: 18px; }
.analysis-head p { margin: 4px 0 0; color: var(--text-2); font-size: 13px; }
.kpi { padding: 22px; position: relative; overflow: hidden; }
.kpi-clickable {
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.kpi-clickable:hover,
.kpi-clickable:focus-visible {
  border-color: rgba(24,139,151,0.42);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  outline: 0;
}
.kpi-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 12px; }
.kpi-label { color: var(--text-2); font-weight: 600; }
.kpi-icon {
  width: 42px;
  height: 42px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 18px;
}
.icon-teal { background: linear-gradient(135deg, #188b97, #22c1c8); }
.icon-amber { background: linear-gradient(135deg, #fbbf24, #facc15); }
.icon-blue { background: linear-gradient(135deg, #3b82f6, #60a5fa); }
.icon-violet { background: linear-gradient(135deg, #8b5cf6, #a78bfa); }
.kpi-value {
  margin-bottom: 8px;
  font-size: 30px;
  font-weight: 800;
  letter-spacing: 0;
  background: linear-gradient(135deg, var(--text-1), var(--text-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.kpi-foot { display: flex; align-items: center; gap: 8px; color: var(--text-3); font-size: 12px; }
.badge-trend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 12px;
  font-weight: 700;
}
.badge-trend.up { color: var(--green); background: var(--green-soft); }
.badge-trend.neutral { color: var(--text-2); background: var(--surface-2); border: 1px solid var(--border); }

.card { padding: 22px; margin-bottom: 22px; }
.card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.card-title { font-size: 16px; margin: 0; line-height: 1.3; }
.card-sub { color: var(--text-3); margin: 3px 0 0; font-size: 12px; }
.grid-2 { display: grid; grid-template-columns: 1.5fr 1fr; gap: 18px; margin-bottom: 22px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 22px; }
.span-2 { grid-column: span 2; }
.span-3 { grid-column: 1 / -1; }
.contract-detail-stack { display: grid; gap: 18px; margin-bottom: 22px; }
.chart-wrap { height: 290px; position: relative; }
.chart-donut { height: 214px; }
.legend { display: grid; gap: 8px; margin-top: 14px; }
.legend > div { display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--text-2); font-size: 13px; }
.legend span { display: inline-flex; align-items: center; gap: 8px; }
.legend i { width: 10px; height: 10px; border-radius: 4px; display: inline-block; }

.location-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.location-grid-wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.location-overview-grid { grid-template-columns: repeat(auto-fit, minmax(360px, 1fr)); }
.location-card, .container-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  background: rgba(255,255,255,0.36);
}
.location-overview-card { min-height: 178px; padding: 22px; display: flex; flex-direction: column; justify-content: space-between; }
.location-overview-card h3 { font-size: 18px; }
[data-theme="dark"] .location-card, [data-theme="dark"] .container-card { background: rgba(255,255,255,0.03); }
.location-card-clickable { cursor: pointer; transition: border-color 0.2s ease, transform 0.2s ease; }
.location-card-clickable:hover { border-color: rgba(24,139,151,0.42); transform: translateY(-1px); }
.container-card-clickable {
  cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.container-card-clickable:hover,
.container-card-clickable:focus {
  border-color: var(--brand);
  box-shadow: 0 14px 34px rgba(24,139,151,0.18);
  transform: translateY(-1px);
  outline: none;
}
.location-card h3, .container-card h3 { margin: 0 0 4px; font-size: 15px; }
.location-card p, .container-card p { margin: 0; color: var(--text-2); font-size: 13px; }
.location-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.location-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr);
  gap: 14px;
  align-items: end;
  margin-bottom: 18px;
}
.meta-line { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.meta-line span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--text-2);
  font-size: 12px;
}
.container-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.container-management-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.container-management-card { display: grid; gap: 10px; }
.container-card-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.container-card-tools {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-left: auto;
}
.container-edit-icon {
  width: 34px;
  height: 34px;
  border-radius: 11px;
}
.container-type-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin: 10px 0 4px; }
.container-type-grid[data-collapsible="true"] { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.container-type-grid-wide { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.container-rectangle-card {
  position: relative;
  overflow: hidden;
  border-left: 5px solid var(--container-accent, var(--brand));
  display: grid;
  gap: 10px;
}
.container-rectangle-card .container-visual { background: var(--container-accent, var(--brand)); }
#locationDetailContainers {
  gap: 10px;
}
#locationDetailContainers .container-card {
  padding: 12px;
  border-radius: 12px;
}
.container-card-compact {
  gap: 7px;
  align-content: start;
}
.container-card-compact .container-card-top {
  align-items: center;
  gap: 8px;
}
.container-card-compact .container-card-tools { gap: 6px; }
.container-card-compact .container-edit-icon {
  width: 30px;
  height: 30px;
  border-radius: 9px;
}
.container-card-compact .container-visual {
  width: 42px;
  height: 36px;
  border-radius: 10px;
  box-shadow: 0 6px 14px rgba(24,139,151,0.16);
}
.container-card-compact .container-visual i { font-size: 18px; }
.container-card-compact .container-visual-svg {
  width: 42px;
  height: 36px;
  padding: 4px;
}
.container-card-compact .container-visual-svg img {
  width: 28px;
  height: 22px;
}
.container-card-compact h3 {
  font-size: 14px;
  margin-bottom: 2px;
}
.container-card-compact p {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.35;
}
.container-card-compact .fill-track {
  height: 5px;
  margin: 6px 0 2px;
}
.container-card-compact .meta-line {
  gap: 5px;
  margin-top: 4px;
}
.container-card-compact .meta-line span {
  gap: 4px;
  padding: 3px 6px;
  font-size: 11px;
}
.container-card-compact .status {
  padding: 3px 8px;
  font-size: 11px;
}
.container-card-compact .status::before {
  width: 5px;
  height: 5px;
}
.container-color-chip {
  max-width: 180px;
  border-color: color-mix(in srgb, var(--container-accent), var(--border) 45%) !important;
  background: color-mix(in srgb, var(--container-accent), transparent 88%);
}
.container-color-chip b {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--container-accent);
  flex: 0 0 auto;
}
.container-color-chip i {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-style: normal;
}
.container-image-preview {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface-2);
}
.container-image-preview img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.container-note {
  margin: 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.container-card-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: auto;
}
.container-type-card {
  min-height: 112px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,0.34);
  color: var(--text-1);
  display: grid;
  justify-items: start;
  gap: 7px;
  padding: 12px;
  cursor: pointer;
  text-align: left;
}
[data-theme="dark"] .container-type-card { background: rgba(255,255,255,0.03); }
.container-type-card.active {
  border-color: rgba(24,139,151,0.62);
  box-shadow: 0 0 0 4px rgba(24,139,151,0.12);
}
.container-type-card strong { font-size: 13px; }
.container-type-card small { color: var(--text-3); font-size: 11px; line-height: 1.35; }
.container-type-card.is-collapsed-extra { display: none; }
.container-visual {
  width: 52px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-3));
  box-shadow: 0 8px 18px rgba(24,139,151,0.22);
}
.container-visual i { font-size: 22px; }
.container-visual-svg {
  width: 52px;
  height: 42px;
  padding: 5px;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-3));
}
.container-visual-svg img {
  width: 34px;
  height: 26px;
  display: block;
  object-fit: contain;
}
.container-visual-fass { border-radius: 18px / 11px; background: linear-gradient(135deg, #188b97, #22c1c8); }
.container-visual-absetzcontainer { width: 58px; clip-path: polygon(12% 18%, 88% 18%, 100% 82%, 0 82%); background: linear-gradient(135deg, #188b97, #84cc16); }
.container-visual-abrollcontainer { width: 62px; border-radius: 8px; background: linear-gradient(135deg, #0f766e, #22c1c8); }
.container-visual-mgb { width: 42px; height: 50px; border-radius: 8px 8px 14px 14px; }
.container-visual-asp { background: linear-gradient(135deg, #7c3aed, #22c1c8); }
.container-visual-ibc { border-radius: 8px; background: linear-gradient(135deg, #2563eb, #188b97); }
.container-visual-asf { border-radius: 14px; background: linear-gradient(135deg, #fbbf24, #e11d48); }
.fill-track { height: 8px; border-radius: 999px; background: var(--surface-2); overflow: hidden; margin: 14px 0 10px; }
.fill-track i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--brand), var(--accent)); }

.request-list { list-style: none; padding: 0; margin: 16px 0 0; display: grid; gap: 10px; }
.request-list li { display: flex; justify-content: space-between; gap: 10px; padding: 10px 0; border-top: 1px dashed var(--border); color: var(--text-2); font-size: 13px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-section-title {
  margin-top: 6px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  color: var(--text-1);
  font-size: 13px;
  font-weight: 800;
}
.field-label {
  display: block;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 7px;
}
.inline-check {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 56px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--surface-solid);
  color: var(--text-1);
  cursor: pointer;
}
.inline-check input {
  width: 20px;
  height: 20px;
  accent-color: var(--brand);
  flex: 0 0 auto;
}
.inline-check span {
  display: grid;
  gap: 2px;
}
.inline-check strong {
  font-size: 14px;
  line-height: 1.25;
}
.inline-check small {
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.contact-internal-toggle:has(input:checked) {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(24,139,151,0.12);
}
.segmented-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 5px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.34);
}
[data-theme="dark"] .segmented-options { background: rgba(255,255,255,0.04); }
.segmented-options button {
  min-height: 38px;
  border: 0;
  border-radius: 9px;
  background: transparent;
  color: var(--text-2);
  cursor: pointer;
  font-weight: 800;
}
.segmented-options button.active {
  color: var(--brand);
  background: var(--surface-solid);
  box-shadow: var(--shadow-sm);
}
.conditional-panel {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.26);
}
[data-theme="dark"] .conditional-panel { background: rgba(255,255,255,0.03); }
.btn-primary, .btn-secondary, .btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 12px;
  padding: 10px 16px;
  border: 0;
  cursor: pointer;
  font-weight: 700;
}
.btn-primary { color: #fff; background: linear-gradient(135deg, var(--brand), var(--brand-3)); box-shadow: 0 8px 22px rgba(24,139,151,0.36); }
.btn-secondary { color: var(--text-1); background: rgba(255,255,255,0.50); border: 1px solid var(--border); }
[data-theme="dark"] .btn-secondary { background: rgba(255,255,255,0.04); }
.btn-danger { color: #fff; background: linear-gradient(135deg, var(--red), #f97316); box-shadow: 0 8px 22px rgba(239,68,68,0.22); }
.btn-small { min-height: 34px; padding: 7px 10px; border-radius: 10px; font-size: 12px; box-shadow: none; }
.full { width: 100%; }
.form-message { min-height: 20px; color: var(--text-2); font-size: 13px; }
.form-message.error { color: var(--red); }
.form-message.success { color: var(--green); }
.form-message.warn { color: var(--amber); }
.sr-only-file {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.view-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 6px;
  margin-bottom: 22px;
}
.view-tab {
  border: 0;
  border-radius: 13px;
  background: transparent;
  color: var(--text-2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 46px;
  padding: 10px 14px;
  font-weight: 800;
}
.view-tab.active {
  color: var(--brand);
  background: var(--surface-solid);
  box-shadow: var(--shadow-sm);
}
.admin-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  padding: 6px;
  margin-bottom: 22px;
}
.admin-panel { display: none; }
.admin-panel.active { display: block; }
.document-create-layout {
  display: grid;
  grid-template-columns: minmax(620px, 1fr) minmax(340px, 420px);
  gap: 18px;
  align-items: start;
}
.document-preview-card {
  position: sticky;
  top: 18px;
  padding: 18px;
}
.document-detail-card {
  position: sticky;
  top: 18px;
  max-height: calc(100vh - 36px);
  overflow: auto;
  padding: 18px;
}
.document-detail-card .card-head {
  margin-bottom: 12px;
}
.document-detail-card .card-title {
  font-size: 18px;
}
.document-detail-card .card-sub {
  font-size: 12px;
}
.document-ai-panel {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(24,139,151,0.09);
}
[data-theme="dark"] .document-ai-panel {
  background: rgba(24,139,151,0.12);
}
.document-ai-panel > div:first-child {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.document-ai-panel strong {
  color: var(--text-1);
  font-size: 13px;
}
.document-ai-panel span {
  color: var(--text-2);
  font-size: 12px;
}
.document-analysis-preview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.document-analysis-preview div {
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(255,255,255,0.26);
}
[data-theme="dark"] .document-analysis-preview div {
  background: rgba(255,255,255,0.04);
}
.document-analysis-preview span,
.document-analysis-preview strong {
  display: block;
}
.document-ai-diagnostic {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid rgba(239,68,68,0.35);
  border-radius: 12px;
  background: rgba(239,68,68,0.08);
}
.diagnostic-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.diagnostic-head > div {
  display: grid;
  gap: 4px;
}
.diagnostic-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.diagnostic-grid div {
  min-width: 0;
  padding: 8px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: rgba(255,255,255,0.04);
}
.diagnostic-grid span,
.diagnostic-grid strong {
  display: block;
}
.diagnostic-grid strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.document-ai-diagnostic ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.document-ai-diagnostic li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
  font-size: 12px;
}
.document-ai-diagnostic code {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.diagnostic-status {
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(148,163,184,0.16);
  color: var(--text-2);
}
.diagnostic-status.ok {
  background: rgba(34,197,94,0.14);
  color: #22c55e;
}
.diagnostic-status.error {
  background: rgba(239,68,68,0.14);
  color: #ef4444;
}
.document-ai-diagnostic pre {
  max-height: 220px;
  overflow: auto;
  margin: 0;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text-2);
  background: rgba(0,0,0,0.18);
  font-size: 11px;
  line-height: 1.5;
  white-space: pre-wrap;
}
.document-detail-form {
  gap: 12px;
}
.document-detail-form .form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.document-detail-form label span,
.document-detail-form .form-section-title {
  font-size: 12px;
}
.document-detail-form input,
.document-detail-form select,
.document-detail-form textarea,
.document-detail-form .currency-input {
  min-height: 42px;
  font-size: 14px;
  border-radius: 12px;
}
.document-detail-form .btn-primary.full,
.document-detail-form .btn-secondary.full {
  min-height: 42px;
  border-radius: 12px;
}
.document-preview-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.document-preview-toolbar span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
  min-width: 48px;
  text-align: center;
}
.document-preview-frame {
  height: calc(100vh - 245px);
  min-height: 640px;
  overflow: auto;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.32);
}
[data-theme="dark"] .document-preview-frame { background: rgba(255,255,255,0.03); }
.document-preview-frame canvas,
.document-preview-frame img {
  max-width: none;
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.document-preview-frame:has(canvas),
.document-preview-frame:has(img) {
  align-content: start;
}
.document-position-list {
  display: grid;
  gap: 10px;
}
.document-position-block {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.26);
}
[data-theme="dark"] .document-position-block { background: rgba(255,255,255,0.03); }
.document-position-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.document-position-head strong { font-size: 13px; }
.document-training-layout {
  display: grid;
  grid-template-columns: minmax(560px, 1fr) minmax(380px, 520px);
  gap: 18px;
  align-items: start;
}
.document-training-preview,
.document-training-editor {
  padding: 18px;
}
.training-preview-frame {
  min-height: 520px;
  max-height: 68vh;
  overflow: auto;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px dashed var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.32);
}
[data-theme="dark"] .training-preview-frame { background: rgba(255,255,255,0.03); }
.training-preview-frame iframe,
.training-preview-frame img {
  width: 100%;
  min-height: 500px;
  border: 0;
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.training-preview-frame img {
  width: auto;
  max-width: 100%;
  min-height: 0;
}
.training-text-preview {
  display: grid;
  gap: 7px;
  margin-top: 12px;
}
.training-text-preview span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
}
.training-text-preview textarea {
  min-height: 132px;
  resize: vertical;
}
.training-position-source {
  grid-column: 1 / -1;
}
.training-example-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.location-view { display: none; }
.location-view.active { display: block; }
.toolbar-inline {
  display: flex;
  align-items: end;
  justify-content: flex-start;
  margin-bottom: 16px;
}
.toolbar-inline label { width: min(360px, 100%); }
.waste-point-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.waste-point-grid.location-detail-preview-grid,
.contact-grid.location-detail-preview-grid,
.container-grid.location-detail-preview-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 360px));
  justify-content: start;
}
.waste-point-card {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  background: rgba(255,255,255,0.36);
}
[data-theme="dark"] .waste-point-card { background: rgba(255,255,255,0.03); }
.waste-point-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 8px 20px rgba(24,139,151,0.24);
}
.waste-point-card h3 { margin: 0 0 4px; font-size: 15px; }
.waste-point-card p, .empty-state { margin: 0; color: var(--text-2); font-size: 13px; }
.waste-point-card-body { min-width: 0; display: grid; gap: 12px; }
.waste-point-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.waste-point-card-head > div { min-width: 0; }
.waste-point-card-head .btn-small { flex: 0 0 auto; }
.waste-point-card-clickable { cursor: pointer; transition: border-color 0.2s ease, transform 0.2s ease; }
.waste-point-card-clickable:hover { border-color: rgba(24,139,151,0.42); transform: translateY(-1px); }
.modal-section { margin: 18px 0; display: grid; gap: 10px; }
.modal-section h3 { margin: 0; font-size: 15px; }
.section-note { margin: 0; color: var(--text-2); font-size: 12px; }
.waste-type-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 360px));
  gap: 12px;
  justify-content: start;
}
.waste-guide-card {
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 148px;
  border: 1px solid color-mix(in srgb, var(--waste-guide-color), var(--border) 55%);
  border-top: 5px solid var(--waste-guide-color);
  border-radius: 8px;
  padding: 14px;
  background: color-mix(in srgb, var(--waste-guide-color) 10%, var(--surface) 90%);
}
.waste-guide-card-clickable {
  cursor: pointer;
  transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.waste-guide-card-clickable:hover,
.waste-guide-card-clickable:focus-visible {
  border-color: color-mix(in srgb, var(--waste-guide-color), #fff 20%);
  background: color-mix(in srgb, var(--waste-guide-color) 15%, var(--surface) 85%);
  transform: translateY(-1px);
}
.waste-guide-card-clickable:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--waste-guide-color), transparent 48%);
  outline-offset: 3px;
}
.waste-guide-top {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}
.waste-guide-swatch {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: var(--waste-guide-color);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.28), 0 8px 18px color-mix(in srgb, var(--waste-guide-color) 28%, transparent);
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 17px;
}
.waste-guide-card strong {
  display: block;
  color: var(--text-1);
  font-size: 14px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.waste-guide-card span { color: var(--text-2); font-size: 12px; }
.waste-guide-card .meta-line { margin-top: 0; }
.waste-guide-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: auto;
}
.waste-guide-card .status {
  justify-self: start;
  width: fit-content;
}
.avv-code sup {
  font-size: 0.68em;
  line-height: 0;
  position: relative;
  top: -0.18em;
  margin-left: 1px;
}
.waste-type-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,0.34);
}
[data-theme="dark"] .waste-type-item { background: rgba(255,255,255,0.03); }
.waste-type-item strong { display: block; }
.waste-type-item span { color: var(--text-2); font-size: 12px; }
.contact-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.contact-person-card {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  background: rgba(255,255,255,0.36);
}
[data-theme="dark"] .contact-person-card { background: rgba(255,255,255,0.03); }
.contact-person-card h3 { margin: 0 0 4px; font-size: 15px; }
.contact-person-card p { margin: 0; color: var(--text-2); font-size: 13px; }
.contact-avatar-small {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-3));
  box-shadow: 0 8px 20px rgba(24,139,151,0.24);
}
.contact-search-card { padding: 14px; margin-bottom: 18px; }
.contact-search { width: 100%; margin-bottom: 0; }
.contact-search input { font-size: 14px; }
.contract-search-panel { margin-bottom: 18px; }
.contact-card {
  position: relative;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px;
  background: rgba(255,255,255,0.36);
  min-width: 0;
}
[data-theme="dark"] .contact-card { background: rgba(255,255,255,0.03); }
.contact-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-3));
  box-shadow: 0 8px 20px rgba(24,139,151,0.24);
}
.contact-body { min-width: 0; display: grid; gap: 9px; }
.contact-head { display: grid; gap: 10px; }
.contact-head > div:first-child { min-width: 0; padding-right: 42px; }
.contact-head-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; padding-right: 34px; }
.contact-edit-icon {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  box-shadow: none;
}
.contact-edit-icon i { font-size: 15px; }
.contact-card h3 { margin: 0 0 4px; font-size: 15px; overflow-wrap: anywhere; }
.contact-card p { margin: 0; color: var(--text-2); font-size: 13px; }
.contact-card .meta-line { margin-top: 0; gap: 6px; }
.contact-card .meta-line span,
.contact-inline-action {
  font-size: 11px;
  padding: 4px 7px;
}
.contract-service-rows {
  display: grid;
  gap: 10px;
}
.contract-service-row {
  display: grid;
  grid-template-columns: minmax(260px, 0.85fr) minmax(0, 1.65fr);
  gap: 18px;
  align-items: start;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  background: rgba(255,255,255,0.36);
}
[data-theme="dark"] .contract-service-row { background: rgba(255,255,255,0.03); }
.contract-service-row-head {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  min-width: 0;
}
.contract-service-row-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--brand-3));
  box-shadow: 0 8px 20px rgba(24,139,151,0.24);
}
.contract-service-row h3 {
  margin: 0 0 4px;
  color: var(--text-1);
  font-size: 15px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.contract-service-row p {
  margin: 0;
  color: var(--text-2);
  font-size: 13px;
}
.contract-service-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(130px, 1fr));
  gap: 10px 18px;
  margin: 0;
}
.contract-service-facts div {
  display: grid;
  gap: 3px;
  align-items: baseline;
}
.contract-service-facts dt {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 800;
}
.contract-service-facts dd {
  margin: 0;
  color: var(--text-1);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.contract-service-facts a {
  color: var(--brand);
  font-weight: 800;
  text-decoration: none;
}
.contract-service-facts a:hover { text-decoration: underline; }
.contact-inline-action {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: transparent;
  color: var(--text-2);
  cursor: pointer;
  font: inherit;
  line-height: 1.2;
  transition: color var(--transition), border-color var(--transition), background var(--transition);
}
.contact-inline-action:hover,
.contact-inline-action:focus-visible {
  color: var(--brand);
  border-color: var(--brand);
  background: rgba(24,139,151,0.10);
  outline: none;
}
.contact-note { padding-top: 2px; }
.contact-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.contact-preview-actions {
  display: flex;
  justify-content: center;
  padding-top: 16px;
}
.contact-preview-actions:empty { display: none; }
.contact-preview-toggle { min-width: 220px; justify-content: center; }
.contact-directory-filter {
  width: min(420px, 100%);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.clickable-card {
  cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.clickable-card:hover {
  border-color: var(--brand);
  box-shadow: 0 14px 34px rgba(24,139,151,0.22);
  transform: translateY(-1px);
}
.clickable-card:focus-within { border-color: var(--brand); }
.contact-person-focused {
  border-color: var(--brand);
  box-shadow: 0 14px 34px rgba(24,139,151,0.22);
}
.form-block-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 4px;
}
.form-block-head strong { font-size: 13px; }
.service-editor { display: grid; gap: 12px; }
.contract-service-editor { gap: 16px; }
.service-row {
  display: grid;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  background: rgba(255,255,255,0.28);
}
[data-theme="dark"] .service-row { background: rgba(255,255,255,0.03); }
.service-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.contract-capture-card textarea {
  width: 100%;
  resize: vertical;
  min-height: 72px;
}
.form-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.form-grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.contract-container-picker {
  display: grid;
  gap: 8px;
}
.contract-container-picker > span {
  color: var(--text-2);
  font-size: 13px;
  font-weight: 800;
}
.contract-container-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: 8px;
  max-height: 260px;
  overflow: auto;
  padding: 4px;
}
.contract-container-option {
  align-items: flex-start;
}
.contract-container-option span {
  display: grid;
  gap: 3px;
}
.contract-container-option small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.35;
}
.contract-alias-line {
  margin-top: 10px;
}
.currency-input {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.48);
  padding-right: 14px;
}
[data-theme="dark"] .currency-input { background: rgba(255,255,255,0.04); }
.currency-input input {
  border: 0;
  background: transparent;
  padding-right: 0;
  min-height: 0;
}
.currency-input input:focus { outline: none; box-shadow: none; }
.currency-input:focus-within {
  border-color: rgba(24,139,151,0.55);
  box-shadow: 0 0 0 4px rgba(24,139,151,0.12);
}
.currency-input b {
  color: var(--text-2);
  font-size: 14px;
}
.detail-list { display: grid; gap: 10px; }
.detail-list > div {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 10px;
}
.detail-list span { color: var(--text-3); font-size: 12px; font-weight: 700; }
.detail-list strong { color: var(--text-1); font-size: 13px; text-align: right; overflow-wrap: anywhere; }
.entity-dialog-wide {
  width: min(920px, 100%);
}
.container-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-right: 42px;
}
.container-detail-summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
  margin: 18px 0;
  background: rgba(255,255,255,0.28);
}
[data-theme="dark"] .container-detail-summary { background: rgba(255,255,255,0.03); }
.container-detail-summary h3 {
  margin: 0 0 4px;
  color: var(--text-1);
  font-size: 18px;
}
.container-detail-summary p {
  margin: 0;
  color: var(--text-2);
}
.container-detail-visual .container-visual {
  background: var(--container-accent, var(--brand));
}
.container-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.container-detail-page-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.85fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.container-detail-wide {
  grid-column: 1 / -1;
}
.container-image-card {
  align-self: stretch;
}
.container-detail-image-frame {
  display: grid;
  place-items: center;
  min-height: 280px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255,255,255,0.22);
}
[data-theme="dark"] .container-detail-image-frame {
  background: rgba(255,255,255,0.03);
}
.container-detail-image-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.container-detail-image-empty {
  display: grid;
  place-items: center;
  gap: 10px;
  color: var(--text-3);
  text-align: center;
  padding: 24px;
}
.container-detail-image-empty i {
  display: grid;
  place-items: center;
  width: 62px;
  height: 62px;
  border-radius: 18px;
  color: #fff;
  background: var(--brand);
  font-size: 28px;
}
.container-detail-image-empty span {
  color: var(--text-2);
  font-weight: 800;
}
.container-image-upload {
  margin-top: 14px;
}
.detail-panel {
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
  background: rgba(255,255,255,0.24);
}
[data-theme="dark"] .detail-panel { background: rgba(255,255,255,0.025); }
.detail-list a {
  color: var(--brand);
  font-weight: 800;
}
.meta-line a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--brand);
  font-size: 12px;
  font-weight: 700;
}
.empty-state {
  border: 1px dashed var(--border-strong);
  border-radius: 14px;
  padding: 18px;
  background: rgba(255,255,255,0.24);
}
.location-empty-state {
  margin: 0;
  color: var(--text-2);
  font-size: 28px;
  font-weight: 800;
  line-height: 1.35;
  text-align: center;
}
.location-empty-state-small {
  font-size: 16px;
  font-weight: 700;
  text-align: left;
}
.location-overview-empty {
  min-height: 360px;
  display: grid;
  place-items: center;
}
#locationAdminGrid .empty-state {
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
  min-height: 0;
  font-size: 0;
  color: transparent;
}
#locationAdminGrid .empty-state::after {
  content: "Noch keine Standorte vorhanden. Füge den ersten Standort hinzu.";
  color: var(--text-2);
  font-size: 14px;
  line-height: 1.5;
}
.small-kpi { font-size: 18px; line-height: 1.2; -webkit-text-fill-color: currentColor; color: var(--text-1); background: none; }
.check-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.check-row {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 12px;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 700;
  background: rgba(255,255,255,0.36);
}
.check-row input { width: auto; }
.no-end-toggle { margin-top: -4px; }
.admin-list { display: grid; gap: 10px; }
.admin-list-item {
  display: grid;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  background: rgba(255,255,255,0.36);
}
[data-theme="dark"] .admin-list-item, [data-theme="dark"] .check-row { background: rgba(255,255,255,0.03); }
.admin-list-item span { color: var(--text-2); font-size: 12px; }
.admin-list-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.compact-select { width: min(300px, 100%); }
.admin-inspect-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.inspect-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  display: grid;
  gap: 8px;
  background: rgba(255,255,255,0.36);
}
[data-theme="dark"] .inspect-card { background: rgba(255,255,255,0.03); }
.inspect-card i { color: var(--brand); font-size: 20px; }
.inspect-card span { color: var(--text-2); font-size: 12px; font-weight: 700; }
.inspect-card strong { font-size: 18px; }
.inspect-actions { align-content: start; }

.site-header {
  position: sticky;
  top: 16px;
  z-index: 20;
  width: min(1180px, calc(100vw - 32px));
  margin: 16px auto 0;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.site-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.site-logo img { width: 126px; height: auto; display: block; }
.site-logo span {
  color: var(--brand);
  font-size: 12px;
  font-weight: 800;
  border: 1px solid rgba(24,139,151,0.20);
  background: rgba(24,139,151,0.10);
  border-radius: 999px;
  padding: 4px 8px;
}
.site-nav { display: flex; align-items: center; gap: 22px; color: var(--text-2); font-weight: 700; }
.site-nav a:hover { color: var(--brand); }
.site-actions { display: flex; align-items: center; gap: 10px; }

.landing {
  position: relative;
  z-index: 1;
  width: min(1180px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 0 0 44px;
}
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(390px, 0.72fr);
  align-items: center;
  gap: 42px;
  padding: clamp(76px, 9vh, 120px) 0 clamp(58px, 8vh, 96px);
}
.hero-copy h1 {
  max-width: 640px;
  margin: 18px 0 18px;
  font-size: clamp(38px, 4.35vw, 62px);
  line-height: 1.08;
  letter-spacing: 0;
}
.hero-copy p {
  max-width: 720px;
  margin: 0;
  color: var(--text-2);
  font-size: clamp(18px, 2vw, 23px);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.hero-product { padding: 24px; overflow: hidden; }
.product-top, .product-list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.product-top strong { color: var(--text-2); font-size: 13px; }
.product-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 24px 0 4px;
}
.product-kpis div {
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.36);
  border-radius: 14px;
  padding: 14px;
}
[data-theme="dark"] .product-kpis div { background: rgba(255,255,255,0.03); }
.product-kpis span { display: block; color: var(--text-3); font-size: 12px; font-weight: 700; }
.product-kpis strong { display: block; margin-top: 4px; font-size: 18px; }
.product-list {
  border-top: 1px dashed var(--border);
  padding-top: 16px;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.product-list span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--text-2);
  font-weight: 700;
  font-size: 13px;
}
.product-list i { color: var(--green); }

.section {
  padding: 58px 0;
  scroll-margin-top: 112px;
}
.section-head {
  max-width: 720px;
  margin-bottom: 24px;
}
.section h2 {
  margin: 14px 0 0;
  font-size: clamp(32px, 4.2vw, 54px);
  line-height: 1.02;
  letter-spacing: 0;
}
.section p {
  color: var(--text-2);
  font-size: 17px;
  margin: 16px 0 0;
}
.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.feature-card {
  padding: 24px;
  min-height: 210px;
}
.feature-card > i {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 20px;
  background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: 0 10px 22px rgba(24,139,151,0.26);
}
.feature-card h3 { margin: 18px 0 8px; font-size: 18px; }
.feature-card p { margin: 0; font-size: 14px; }
.split {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(380px, 0.75fr);
  gap: 42px;
  align-items: center;
}
.process-list { padding: 18px; display: grid; gap: 10px; }
.process-list div {
  display: grid;
  grid-template-columns: 46px 1fr;
  align-items: center;
  gap: 14px;
  padding: 15px;
  border-radius: 14px;
  background: rgba(255,255,255,0.36);
  border: 1px solid var(--border);
}
[data-theme="dark"] .process-list div { background: rgba(255,255,255,0.03); }
.process-list strong { color: var(--brand); font-size: 15px; }
.process-list span { color: var(--text-2); font-weight: 700; }
.cta {
  padding: 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.cta h2 { max-width: 720px; }
.cta p { max-width: 680px; }

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.auth-modal.open { display: flex; }
.auth-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5,12,18,0.42);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.auth-dialog {
  position: relative;
  width: min(440px, 100%);
  padding: 24px;
}
.entity-dialog { width: min(680px, 100%); max-height: min(86vh, 820px); overflow-y: auto; }
.auth-dialog h2 { margin: 0; font-size: 24px; }
.auth-dialog > p { margin: 4px 0 18px; color: var(--text-2); }
.auth-close { position: absolute; top: 16px; right: 16px; }
.address-autocomplete { position: relative; }
.address-suggestions {
  position: absolute;
  z-index: 4;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  display: grid;
  gap: 6px;
  max-height: 260px;
  overflow-y: auto;
}
.address-suggestions:empty { display: none; }
.address-suggestions button {
  text-align: left;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 12px;
  background: var(--surface-solid);
  color: var(--text-1);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}
.address-suggestions button:disabled { cursor: default; color: var(--text-3); }
.address-suggestions strong,
.address-suggestions span,
.address-suggestions small { display: block; }
.address-suggestions span { margin-top: 3px; color: var(--text-2); font-size: 12px; line-height: 1.35; }
.address-suggestions small { margin-top: 2px; color: var(--text-3); font-size: 11px; line-height: 1.35; }

.table-wrap { overflow-x: auto; border-radius: var(--radius-sm); }
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-table th {
  text-align: left;
  padding: 12px 16px;
  color: var(--text-2);
  background: rgba(255,255,255,0.40);
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  text-transform: uppercase;
}
[data-theme="dark"] .data-table th { background: rgba(255,255,255,0.04); }
.data-table td { padding: 14px 16px; border-bottom: 1px solid var(--border); white-space: nowrap; }
.data-table-clickable-row {
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}
.data-table-clickable-row:hover,
.data-table-clickable-row:focus-visible {
  background: rgba(24,139,151,0.12);
  color: var(--text-1);
  outline: none;
}
.status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
}
.status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; }
.status.ok { color: var(--green); background: var(--green-soft); }
.status.ok::before { background: var(--green); }
.status.pending { color: var(--blue); background: var(--blue-soft); }
.status.pending::before { background: var(--blue); }
.status.warn { color: var(--amber); background: var(--amber-soft); }
.status.warn::before { background: var(--amber); }

.profile-hero { display: flex; align-items: center; gap: 18px; padding: 24px; margin-bottom: 22px; }
.profile-hero-actions { align-items: flex-start; }
.profile-hero-actions > div:nth-child(2) { flex: 1; min-width: 0; }
.profile-hero-tools { margin-left: auto; display: flex; align-items: center; justify-content: flex-end; gap: 10px; flex-wrap: wrap; }
.profile-avatar { width: 72px; height: 72px; border-radius: 22px; font-size: 24px; }
.profile-hero h2 { margin: 0; font-size: 24px; }
.profile-hero p { margin: 4px 0 0; color: var(--text-2); }
.waste-type-create-card { max-width: 100%; }
.footer { display: flex; justify-content: space-between; margin-top: auto; padding: 16px 0; color: var(--text-3); font-size: 12px; }

@media (max-width: 1120px) {
  .kpis { grid-template-columns: repeat(2, 1fr); }
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
  .span-2, .span-3 { grid-column: auto; }
  .container-grid { grid-template-columns: repeat(2, 1fr); }
  .profile-hero-actions { flex-wrap: wrap; }
  .profile-hero-tools { width: 100%; margin-left: 0; justify-content: flex-start; }
  .admin-inspect-grid { grid-template-columns: repeat(3, 1fr); }
  .waste-point-grid, .location-grid-wide { grid-template-columns: 1fr; }
  .hero, .split { grid-template-columns: 1fr; }
  .hero { padding-top: 54px; }
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .waste-type-list { grid-template-columns: repeat(2, minmax(220px, 360px)); }
}
@media (min-width: 821px) and (max-width: 1180px) {
  .sidebar {
    width: 218px;
    padding: 16px 10px;
  }
  .sidebar-inner {
    padding: 16px 10px;
  }
  .brand-logo {
    width: 148px;
    margin: 0 auto 18px;
  }
  .nav-section {
    padding: 10px 8px 5px;
    font-size: 10px;
  }
  .nav-link {
    min-height: 46px;
    padding: 10px 11px;
    gap: 10px;
    font-size: 13px;
  }
  .sidebar-user {
    gap: 10px;
    padding-top: 12px;
  }
  .avatar {
    width: 38px;
    height: 38px;
    border-radius: 12px;
  }
  .main {
    max-width: min(calc(100vw - 218px), 1180px);
    padding: 18px 20px 24px 6px;
  }
  .topbar {
    padding: 12px 14px;
    gap: 12px;
    margin-bottom: 18px;
  }
  .topbar h1,
  .page-title {
    font-size: 22px;
  }
  .topbar p,
  .page-subtitle {
    font-size: 13px;
  }
  .topbar-right {
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .card,
  .kpi {
    padding: 18px;
  }
  .kpi {
    min-height: 150px;
  }
  .kpi-value {
    font-size: 28px;
  }
  .location-toolbar,
  .admin-inspect-grid,
  .contact-detail-layout,
  .document-create-layout,
  .document-training-layout,
  .container-detail-grid,
  .container-detail-page-layout,
  .contract-service-row,
  .container-management-grid {
    grid-template-columns: 1fr;
  }
  .contract-service-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .document-preview-card,
  .document-detail-card {
    position: static;
    max-height: none;
  }
  .document-preview-frame {
    height: min(62vh, 560px);
    min-height: 420px;
  }
  .location-grid,
  .contact-grid,
  .contact-company-grid,
  .container-type-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .entity-card,
  .location-card,
  .container-card {
    min-width: 0;
  }
  .form-grid {
    gap: 10px;
  }
  .document-detail-form .form-grid {
    grid-template-columns: 1fr;
  }
  .entity-dialog {
    width: min(720px, calc(100vw - 48px));
  }
}
@media (max-width: 820px) {
  .auth-shell { grid-template-columns: 1fr; width: min(100% - 32px, 560px); gap: 24px; }
  .auth-copy h1 { font-size: 38px; }
  .site-header { position: relative; top: 0; flex-wrap: wrap; }
  .site-nav { order: 3; width: 100%; justify-content: center; gap: 16px; }
  .site-actions { margin-left: auto; }
  .landing { padding-top: 0; }
  .hero { padding-top: 40px; }
  .hero-copy h1 { font-size: 48px; }
  .product-kpis, .feature-grid { grid-template-columns: 1fr; }
  .cta { flex-direction: column; align-items: flex-start; }
  .sidebar { display: none; }
  .main { max-width: 100vw; padding: 18px; }
  .topbar { align-items: flex-start; flex-direction: column; }
  .topbar-right, .search { width: 100%; }
  .search { flex: 1; }
  .location-toolbar { grid-template-columns: 1fr; }
  .contract-service-row,
  .contract-service-facts {
    grid-template-columns: 1fr;
  }
  .container-detail-grid,
  .container-detail-page-layout,
  .container-detail-summary {
    grid-template-columns: 1fr;
  }
  .container-detail-head {
    padding-right: 34px;
  }
  .kpis, .location-grid, .container-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .waste-type-list { grid-template-columns: minmax(0, 1fr); }
  .admin-inspect-grid, .check-grid { grid-template-columns: 1fr; }
  .view-switch { grid-template-columns: 1fr; }
}
@media (min-width: 700px) and (max-width: 820px) {
  .main {
    padding: 20px 22px 26px;
  }
  .topbar {
    align-items: flex-start;
    flex-direction: row;
  }
  .topbar-right {
    width: auto;
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .search {
    width: min(100%, 520px);
  }
  .kpis,
  .location-grid,
  .container-grid,
  .container-type-grid,
  .waste-type-list,
  .contact-company-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .location-toolbar {
    grid-template-columns: 1fr 1fr;
    align-items: end;
  }
  .view-switch {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .card,
  .kpi {
    padding: 20px;
  }
  .entity-dialog,
  .auth-dialog {
    width: min(720px, calc(100vw - 44px));
  }
}
@media (pointer: coarse) and (min-width: 700px) {
  .btn-primary,
  .btn-secondary,
  .btn-ghost,
  .nav-link,
  input,
  select,
  textarea {
    min-height: 44px;
  }
  .icon-btn {
    min-width: 44px;
    min-height: 44px;
  }
}
@media (max-width: 520px) {
  .auth-panel, .card, .kpi { padding: 18px; }
  .site-logo img { width: 108px; }
  .site-actions { width: 100%; display: grid; grid-template-columns: 1fr 1fr 40px; }
  .site-actions .btn-primary, .site-actions .btn-secondary { padding-left: 10px; padding-right: 10px; }
  .hero-copy h1 { font-size: 40px; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn-primary, .hero-actions .btn-secondary, .cta .btn-primary { width: 100%; }
  .section { padding: 48px 0; }
  .form-grid { grid-template-columns: 1fr; }
  .footer { flex-direction: column; gap: 6px; }
}
