/* ============================================================
   Planer-Leadportal · Haupt-Stylesheet
   Designrichtung: seriös, Bau / Ingenieurwesen
   ============================================================ */

/* ---- Custom Properties ------------------------------------ */
:root {
    /* Primärfarbe: tiefes Stahlblau – Vertrauen, Kompetenz */
    --color-primary:       #1c3a5c;
    --color-primary-dark:  #122540;
    --color-primary-mid:   #264d78;
    --color-primary-light: #e8eff6;
    --color-primary-pale:  #f2f6fa;

    /* CTA – kräftiges, seriöses Blau; gut sichtbar auf weiß */
    --color-cta:           #1258a8;
    --color-cta-dark:      #0d4382;
    --color-cta-light:     #dbeafe;

    /* Akzent für sekundäre Elemente */
    --color-accent:        #c96b00;   /* Ingenieur-Orange für Highlights */
    --color-accent-bg:     #fff7ed;

    /* Neutrals */
    --color-text:          #1a2535;
    --color-text-mid:      #3d4f63;
    --color-text-light:    #64748b;
    --color-text-muted:    #94a3b8;

    --color-bg:            #f5f7fa;
    --color-bg-alt:        #eef1f6;
    --color-white:         #ffffff;
    --color-border:        #d8e0ea;
    --color-border-light:  #ecf0f5;

    /* Status */
    --color-success:       #15803d;
    --color-success-bg:    #f0fdf4;
    --color-success-border:#bbf7d0;
    --color-error:         #b91c1c;
    --color-error-bg:      #fef2f2;
    --color-error-border:  #fecaca;
    --color-warning:       #92400e;
    --color-warning-bg:    #fffbeb;
    --color-warning-border:#fde68a;
    --color-info:          #1e40af;
    --color-info-bg:       #eff6ff;
    --color-info-border:   #bfdbfe;

    /* Typografie */
    --font-sans: 'Segoe UI', system-ui, -apple-system, 'Helvetica Neue', Arial, sans-serif;
    --font-mono: 'Consolas', 'Courier New', monospace;

    /* Geometrie */
    --radius-xs: 3px;
    --radius-sm: 5px;
    --radius:    8px;
    --radius-lg: 12px;
    --radius-xl: 16px;

    /* Schatten */
    --shadow-xs: 0 1px 2px 0 rgba(28,58,92,.06);
    --shadow-sm: 0 1px 3px 0 rgba(28,58,92,.08), 0 1px 2px -1px rgba(28,58,92,.05);
    --shadow:    0 4px 6px -1px rgba(28,58,92,.09), 0 2px 4px -2px rgba(28,58,92,.06);
    --shadow-md: 0 8px 16px -4px rgba(28,58,92,.12), 0 2px 6px -2px rgba(28,58,92,.07);
    --shadow-lg: 0 20px 32px -8px rgba(28,58,92,.14), 0 6px 12px -4px rgba(28,58,92,.08);

    /* Abstände */
    --max-width:       1200px;
    --max-width-form:  780px;
    --section-padding: 5rem;
}

/* ---- Reset & Basis ---------------------------------------- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    scroll-padding-top: 11rem; /* Kompensiert die sticky Nav mit großem Logo */
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-bg);
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img, video, svg {
    display: block;
    max-width: 100%;
}

a {
    color: var(--color-cta);
    text-decoration: none;
    transition: color .15s;
}
a:hover { color: var(--color-cta-dark); text-decoration: underline; }

ul, ol { padding-left: 1.375rem; }
li + li { margin-top: .25rem; }

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: 2rem 0;
}

code {
    font-family: var(--font-mono);
    font-size: .875em;
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xs);
    padding: .1em .45em;
    color: var(--color-text-mid);
}

/* ---- Typografie ------------------------------------------- */
h1 { font-size: clamp(1.75rem, 4vw, 2.375rem); font-weight: 700; line-height: 1.2; letter-spacing: -.02em; }
h2 { font-size: clamp(1.375rem, 3vw, 1.875rem); font-weight: 700; line-height: 1.25; letter-spacing: -.015em; }
h3 { font-size: 1.1875rem; font-weight: 600; line-height: 1.35; }
h4 { font-size: 1rem;      font-weight: 600; line-height: 1.4; }

h1, h2, h3, h4 { color: var(--color-text); }

/* ============================================================
   LAYOUT
   ============================================================ */

.container {
    width: 100%;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: 1.5rem;
}

.container--narrow { max-width: var(--max-width-form); }

.grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
}

@media (max-width: 640px) { .grid-2 { grid-template-columns: 1fr; } }

/* ============================================================
   NAVIGATION
   ============================================================ */

.nav {
    background: var(--color-white);
    border-bottom: 2px solid var(--color-primary-light);
    position: sticky;
    top: 0;
    z-index: 200;
    box-shadow: var(--shadow-sm);
}

.nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    max-width: var(--max-width);
    margin-inline: auto;
    padding: .875rem 1.5rem;
}

.nav__logo {
    display: flex;
    align-items: center;
    gap: .625rem;
    color: var(--color-primary);
    font-weight: 700;
    font-size: 1.0625rem;
    letter-spacing: -.01em;
    text-decoration: none;
    flex-shrink: 0;
}
.nav__logo:hover { color: var(--color-primary-dark); text-decoration: none; }

.nav__logo-icon {
    width: 2.125rem;
    height: 2.125rem;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 800;
    letter-spacing: .01em;
    flex-shrink: 0;
}

.nav__logo-img {
    height: 9em;
    width: auto;
    display: block;
    flex-shrink: 0;
}

.nav__links {
    display: flex;
    align-items: center;
    gap: 2rem;
    list-style: none;
    padding: 0;
}

.nav__links a {
    color: var(--color-text-mid);
    font-size: .9375rem;
    font-weight: 500;
    transition: color .15s;
    text-decoration: none;
}
.nav__links a:hover { color: var(--color-primary); }
.nav__links a.btn--primary,
.nav__links a.btn--primary:hover { color: var(--color-white); }

@media (max-width: 600px) {
    .nav__links { gap: 1rem; }
    .nav__links li:not(:last-child) { display: none; }
}

/* ============================================================
   BUTTONS
   ============================================================ */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .625rem 1.375rem;
    border: 1.5px solid transparent;
    border-radius: var(--radius);
    font-family: var(--font-sans);
    font-size: .9375rem;
    font-weight: 600;
    line-height: 1.4;
    cursor: pointer;
    text-decoration: none;
    transition: background-color .15s, border-color .15s, color .15s, box-shadow .15s, transform .1s;
    white-space: nowrap;
    user-select: none;
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn:focus-visible {
    outline: 3px solid var(--color-cta);
    outline-offset: 2px;
}
.btn:disabled,
.btn[aria-disabled="true"] {
    opacity: .5;
    cursor: not-allowed;
    pointer-events: none;
}

/* Primär-CTA – klar, seriös, sichtbar */
.btn--primary {
    background: var(--color-cta);
    color: var(--color-white);
    border-color: var(--color-cta);
    box-shadow: 0 2px 6px rgba(18,88,168,.25);
}
.btn--primary:hover {
    background: var(--color-cta-dark);
    border-color: var(--color-cta-dark);
    box-shadow: 0 4px 10px rgba(18,88,168,.32);
    color: var(--color-white);
}

/* Sekundär */
.btn--secondary {
    background: var(--color-white);
    color: var(--color-text-mid);
    border-color: var(--color-border);
    box-shadow: var(--shadow-xs);
}
.btn--secondary:hover {
    background: var(--color-primary-pale);
    border-color: var(--color-primary-light);
    color: var(--color-primary);
}

/* Danger */
.btn--danger {
    background: var(--color-error);
    color: var(--color-white);
    border-color: var(--color-error);
}
.btn--danger:hover { background: #991b1b; border-color: #991b1b; }

/* Größen */
.btn--sm  { padding: .375rem .875rem; font-size: .875rem; }
.btn--lg  { padding: .875rem 2rem;    font-size: 1.0625rem; }
.btn--block { width: 100%; }

/* ============================================================
   FORMULARE
   ============================================================ */

.form-section {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.75rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-sm);
}

.form-section__title {
    display: flex;
    align-items: center;
    gap: .625rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 1.375rem;
    padding-bottom: .875rem;
    border-bottom: 1px solid var(--color-border-light);
    letter-spacing: -.01em;
}

.form-section__num {
    width: 1.75rem;
    height: 1.75rem;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .8125rem;
    font-weight: 700;
    flex-shrink: 0;
}

.form-group { margin-bottom: 1.125rem; }
.form-group:last-child { margin-bottom: 0; }

.form-label {
    display: block;
    font-size: .9rem;
    font-weight: 600;
    color: var(--color-text-mid);
    margin-bottom: .375rem;
    letter-spacing: .005em;
}

.required { color: var(--color-error); margin-left: .125rem; }

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: .5625rem .875rem;
    background: var(--color-white);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius);
    font-family: var(--font-sans);
    font-size: .9375rem;
    color: var(--color-text);
    line-height: 1.5;
    transition: border-color .15s, box-shadow .15s, background-color .15s;
    appearance: none;
}

.form-input::placeholder,
.form-textarea::placeholder { color: var(--color-text-muted); }

.form-input:hover,
.form-select:hover,
.form-textarea:hover { border-color: #a0b4cc; }

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--color-cta);
    box-shadow: 0 0 0 3px rgba(18,88,168,.12);
    background: var(--color-white);
}

.form-input.is-invalid,
.form-select.is-invalid,
.form-textarea.is-invalid {
    border-color: var(--color-error);
    background: #fff8f8;
}
.form-input.is-invalid:focus,
.form-select.is-invalid:focus,
.form-textarea.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(185,28,28,.12);
}

.form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right .75rem center;
    background-repeat: no-repeat;
    background-size: 1.125rem;
    padding-right: 2.5rem;
    cursor: pointer;
}

.form-textarea {
    resize: vertical;
    min-height: 130px;
    line-height: 1.65;
}

.form-hint {
    font-size: .8125rem;
    color: var(--color-text-light);
    margin-top: .3rem;
    line-height: 1.5;
}

.form-error {
    font-size: .8125rem;
    color: var(--color-error);
    margin-top: .3rem;
    font-weight: 500;
}

/* Radio-Gruppe */
.radio-group { display: flex; flex-wrap: wrap; gap: 1rem; }

.radio-option {
    display: flex;
    align-items: center;
    gap: .4rem;
    cursor: pointer;
    font-size: .9375rem;
    font-weight: 500;
    color: var(--color-text-mid);
}
.radio-option input[type="radio"] {
    accent-color: var(--color-cta);
    width: 1rem;
    height: 1rem;
    cursor: pointer;
    flex-shrink: 0;
}

/* Checkbox */
.checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: .625rem;
}
.checkbox-group input[type="checkbox"] {
    accent-color: var(--color-cta);
    width: 1.125rem;
    height: 1.125rem;
    cursor: pointer;
    flex-shrink: 0;
    margin-top: .2rem;
}
.checkbox-group label {
    font-size: .9375rem;
    color: var(--color-text-mid);
    cursor: pointer;
    line-height: 1.55;
}

/* Datei-Upload */
.upload-zone {
    position: relative;
    border: 2px dashed var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2.25rem 1.5rem;
    text-align: center;
    cursor: pointer;
    background: var(--color-bg);
    transition: border-color .15s, background .15s;
}
.upload-zone:hover,
.upload-zone:focus-within {
    border-color: var(--color-cta);
    background: var(--color-cta-light);
}
.upload-zone input[type="file"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
}
.upload-zone__icon {
    font-size: 2.25rem;
    margin-bottom: .5rem;
    color: var(--color-text-light);
    line-height: 1;
}
.upload-zone__text {
    font-weight: 600;
    color: var(--color-text-mid);
    font-size: .9375rem;
    margin-bottom: .25rem;
}
.upload-zone__hint {
    font-size: .8125rem;
    color: var(--color-text-light);
}

/* DSGVO-Box */
.dsgvo-box {
    background: var(--color-info-bg);
    border: 1px solid var(--color-info-border);
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
}
.dsgvo-box .form-error { margin-top: .5rem; }

/* ============================================================
   ALERTS
   ============================================================ */

.alert {
    padding: .875rem 1.125rem;
    border-radius: var(--radius);
    border: 1px solid transparent;
    font-size: .9375rem;
    margin-bottom: 1.25rem;
    line-height: 1.55;
}
.alert__title {
    font-weight: 700;
    margin-bottom: .25rem;
    font-size: .9375rem;
}
.alert ul { margin-top: .375rem; padding-left: 1.25rem; }
.alert li + li { margin-top: .125rem; }

.alert--error   { background: var(--color-error-bg);   border-color: var(--color-error-border);   color: #7f1d1d; }
.alert--success { background: var(--color-success-bg); border-color: var(--color-success-border); color: #14532d; }
.alert--warning { background: var(--color-warning-bg); border-color: var(--color-warning-border); color: var(--color-warning); }
.alert--info    { background: var(--color-info-bg);    border-color: var(--color-info-border);    color: var(--color-info); }

.alert--error   .alert__title { color: #991b1b; }
.alert--success .alert__title { color: #166534; }

/* ============================================================
   CARDS
   ============================================================ */

.card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.card__header {
    padding: .875rem 1.25rem;
    background: var(--color-primary-pale);
    border-bottom: 1px solid var(--color-border-light);
    font-size: .9375rem;
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: -.01em;
}

.card__body { padding: 1.25rem; }

.card__footer {
    padding: .875rem 1.25rem;
    border-top: 1px solid var(--color-border-light);
    background: var(--color-bg);
}

/* ============================================================
   BADGES / STATUS
   ============================================================ */

.badge {
    display: inline-flex;
    align-items: center;
    padding: .2rem .65rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .02em;
    text-transform: uppercase;
    white-space: nowrap;
    border: 1px solid transparent;
}

/* Lead-Status */
.badge--neu            { background: #dbeafe; color: #1e3a8a; border-color: #bfdbfe; }
.badge--in_bearbeitung { background: #fef9c3; color: #713f12; border-color: #fde047; }
.badge--kontaktiert    { background: #ffedd5; color: #7c2d12; border-color: #fed7aa; }
.badge--distributed    { background: #f3e8ff; color: #581c87; border-color: #e9d5ff; }
.badge--abgeschlossen  { background: #dcfce7; color: #14532d; border-color: #bbf7d0; }
.badge--abgelehnt      { background: #fee2e2; color: #7f1d1d; border-color: #fecaca; }

/* ============================================================
   TABELLEN
   ============================================================ */

.table-wrap {
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    overflow-x: auto;
    box-shadow: var(--shadow-sm);
    background: var(--color-white);
}

.table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9375rem;
}

.table th {
    background: var(--color-primary-pale);
    color: var(--color-text-mid);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .75rem 1rem;
    text-align: left;
    border-bottom: 1.5px solid var(--color-border);
    white-space: nowrap;
}

.table td {
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--color-border-light);
    vertical-align: middle;
    color: var(--color-text);
}

.table tbody tr:last-child td { border-bottom: none; }

.table tbody tr {
    transition: background .1s;
}
.table tbody tr:hover { background: var(--color-primary-pale); }

/* ============================================================
   DETAIL-TABELLE (Lead-Detailansicht)
   ============================================================ */

.detail-table {
    width: 100%;
    border-collapse: collapse;
}
.detail-table th {
    width: 38%;
    text-align: left;
    padding: .625rem .875rem;
    font-size: .8125rem;
    font-weight: 600;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: .05em;
    background: var(--color-primary-pale);
    border-bottom: 1px solid var(--color-border-light);
    vertical-align: top;
}
.detail-table td {
    padding: .625rem .875rem;
    font-size: .9375rem;
    border-bottom: 1px solid var(--color-border-light);
    color: var(--color-text);
    vertical-align: top;
    line-height: 1.55;
}
.detail-table tr:last-child th,
.detail-table tr:last-child td { border-bottom: none; }

/* ============================================================
   PAGINATION
   ============================================================ */

.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .375rem;
    flex-wrap: wrap;
    padding: 1.5rem 0 .5rem;
}

.pagination__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.25rem;
    height: 2.25rem;
    padding: 0 .625rem;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius);
    font-size: .9rem;
    font-weight: 600;
    color: var(--color-text-mid);
    background: var(--color-white);
    text-decoration: none;
    transition: background .15s, border-color .15s, color .15s;
}
.pagination__item:hover {
    background: var(--color-primary-light);
    border-color: var(--color-primary-light);
    color: var(--color-primary);
    text-decoration: none;
}
.pagination__item.is-active {
    background: var(--color-cta);
    border-color: var(--color-cta);
    color: var(--color-white);
    box-shadow: 0 2px 5px rgba(18,88,168,.25);
}
.pagination__item.is-disabled {
    opacity: .4;
    pointer-events: none;
}

/* ============================================================
   STATS-KARTEN
   ============================================================ */

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 1.75rem;
}

@media (max-width: 900px) { .stats-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .stats-grid { grid-template-columns: 1fr; } }

.stat-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.375rem 1.25rem;
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
}
.stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--color-primary);
}
.stat-card__value {
    font-size: 2rem;
    font-weight: 800;
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: .375rem;
    letter-spacing: -.03em;
}
.stat-card__label {
    font-size: .8125rem;
    color: var(--color-text-light);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .05em;
}

/* ============================================================
   FILTER-TABS
   ============================================================ */

.filter-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.25rem;
}

.filter-tab {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .4rem 1rem;
    border: 1.5px solid var(--color-border);
    border-radius: 999px;
    font-size: .875rem;
    font-weight: 600;
    color: var(--color-text-mid);
    background: var(--color-white);
    text-decoration: none;
    transition: background .15s, border-color .15s, color .15s;
    white-space: nowrap;
}
.filter-tab:hover {
    background: var(--color-primary-pale);
    border-color: var(--color-primary-light);
    color: var(--color-primary);
    text-decoration: none;
}
.filter-tab.is-active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-white);
}
.filter-tab__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.375rem;
    height: 1.375rem;
    padding: 0 .3rem;
    background: rgba(0,0,0,.12);
    border-radius: 999px;
    font-size: .6875rem;
    font-weight: 800;
}

/* ============================================================
   SUCHLEISTE
   ============================================================ */

.search-bar {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
    box-shadow: var(--shadow-sm);
}
.search-bar form {
    display: flex;
    flex-wrap: wrap;
    gap: .875rem;
    align-items: flex-end;
}
.search-bar .form-group { margin-bottom: 0; }

.search-input-wrap {
    position: relative;
    flex: 1;
    min-width: 180px;
}
.search-input-wrap .form-input { padding-left: 2.25rem; }
.search-icon {
    position: absolute;
    left: .75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    pointer-events: none;
    font-size: .9rem;
    line-height: 1;
}

/* ============================================================
   DATEI-LISTE
   ============================================================ */

.file-list { list-style: none; padding: 0; }

.file-item {
    display: flex;
    align-items: center;
    gap: .875rem;
    padding: .75rem;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
    background: var(--color-bg);
    margin-bottom: .5rem;
    transition: background .15s;
}
.file-item:hover { background: var(--color-primary-pale); }

.file-item__thumb {
    width: 3rem;
    height: 3rem;
    object-fit: cover;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    flex-shrink: 0;
}
.file-item__icon {
    width: 3rem;
    height: 3rem;
    background: #fee2e2;
    color: #991b1b;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .6875rem;
    font-weight: 800;
    letter-spacing: .03em;
    flex-shrink: 0;
}
.file-item__info { flex: 1; min-width: 0; }
.file-item__name {
    font-size: .9375rem;
    font-weight: 600;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.file-item__meta {
    font-size: .8125rem;
    color: var(--color-text-light);
    margin-top: .125rem;
}

/* ============================================================
   ADMIN-LAYOUT
   ============================================================ */

.admin-layout {
    display: flex;
    min-height: 100vh;
    background: var(--color-bg);
}

/* Sidebar */
.admin-sidebar {
    width: 250px;
    flex-shrink: 0;
    background: var(--color-primary);
    color: rgba(255,255,255,.8);
    display: flex;
    flex-direction: column;
}

.admin-sidebar__logo {
    display: block;
    padding: 1.25rem 1.375rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-white);
    letter-spacing: -.01em;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,.1);
    transition: background .15s;
}
.admin-sidebar__logo:hover {
    background: rgba(255,255,255,.05);
    text-decoration: none;
    color: var(--color-white);
}

.admin-nav {
    display: flex;
    flex-direction: column;
    padding: .75rem 0;
    flex: 1;
}

.admin-nav__item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .6875rem 1.375rem;
    color: rgba(255,255,255,.72);
    text-decoration: none;
    font-size: .9375rem;
    font-weight: 500;
    transition: background .15s, color .15s;
    border-right: 3px solid transparent;
}
.admin-nav__item:hover {
    background: rgba(255,255,255,.07);
    color: var(--color-white);
    text-decoration: none;
}
.admin-nav__item.is-active {
    background: rgba(255,255,255,.1);
    color: var(--color-white);
    border-right-color: #7ec8f5;
    font-weight: 600;
}

/* Logout-Eintrag: durch Abstand optisch abgetrennt */
.admin-nav__item--logout {
    margin-top: auto;
    border-top: 1px solid rgba(255,255,255,.1);
    color: rgba(255,255,255,.5);
}
.admin-nav__item--logout:hover { color: rgba(255,255,255,.85); }

.admin-sidebar__footer {
    padding: 1rem 1.375rem;
    border-top: 1px solid rgba(255,255,255,.1);
    font-size: .8125rem;
    color: rgba(255,255,255,.5);
    line-height: 1.55;
}
.admin-sidebar__footer a {
    color: rgba(255,255,255,.5);
    transition: color .15s;
}
.admin-sidebar__footer a:hover { color: rgba(255,255,255,.85); }

/* Main */
.admin-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    overflow: hidden;
}

.admin-header {
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border);
    padding: .875rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    box-shadow: var(--shadow-xs);
    position: sticky;
    top: 0;
    z-index: 100;
    flex-wrap: wrap;
}

.admin-header__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0;
    letter-spacing: -.015em;
}

.admin-content {
    padding: 1.5rem;
    flex: 1;
    overflow-y: auto;
}

/* Detail-Grid: links breit, rechts schmal */
.detail-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.5rem;
    align-items: start;
}

@media (max-width: 900px) {
    .admin-layout { flex-direction: column; }
    .admin-sidebar { width: 100%; }
    .admin-nav { display: flex; flex-wrap: wrap; padding: .5rem; }
    .admin-nav__item {
        border-right: none;
        border-bottom: 2px solid transparent;
        padding: .5rem .875rem;
        font-size: .875rem;
    }
    .admin-nav__item.is-active { border-bottom-color: #7ec8f5; }
    .admin-sidebar__footer { display: none; }
    .admin-header { position: static; }
    .detail-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   LOGIN-SEITE
   ============================================================ */

.login-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary-pale);
    padding: 2rem 1.5rem;
}

.login-card {
    width: 100%;
    max-width: 420px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2.5rem 2rem;
    box-shadow: var(--shadow-lg);
}

.login-card__logo {
    text-align: center;
    margin-bottom: 2rem;
}

.login-card__logo-img {
    height: 7rem;
    width: auto;
    display: block;
    margin: 0 auto 1.5rem;
}

.login-card h1 {
    font-size: 1.375rem;
    text-align: center;
    margin-bottom: .25rem;
}

.login-card__subtitle {
    text-align: center;
    color: var(--color-text-light);
    font-size: .9375rem;
    margin-top: .25rem;
}

/* ============================================================
   DANKE-SEITE
   ============================================================ */

.danke-wrap {
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4rem 1.5rem;
}

.danke-card {
    width: 100%;
    max-width: 560px;
    text-align: center;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 3rem 2.25rem;
    box-shadow: var(--shadow-lg);
}

.danke-icon {
    width: 5rem;
    height: 5rem;
    background: var(--color-success-bg);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.25rem;
    margin: 0 auto 1.75rem;
    border: 2px solid var(--color-success-border);
}

/* ============================================================
   LANDINGPAGE – HERO
   ============================================================ */

.hero {
    background: linear-gradient(150deg, var(--color-primary-dark) 0%, var(--color-primary) 55%, var(--color-primary-mid) 100%);
    color: var(--color-white);
    padding: 5.5rem 1.5rem 4.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}

/* Subtiler Hintergrund-Struktur-Effekt */
.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        repeating-linear-gradient(
            90deg,
            rgba(255,255,255,.018) 0,
            rgba(255,255,255,.018) 1px,
            transparent 1px,
            transparent 60px
        ),
        repeating-linear-gradient(
            0deg,
            rgba(255,255,255,.018) 0,
            rgba(255,255,255,.018) 1px,
            transparent 1px,
            transparent 60px
        );
    pointer-events: none;
}

.hero > * { position: relative; }

.hero__badge {
    display: inline-block;
    background: rgba(255,255,255,.13);
    color: rgba(255,255,255,.92);
    font-size: .8125rem;
    font-weight: 700;
    padding: .3rem 1rem;
    border-radius: 999px;
    margin-bottom: 1.375rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    border: 1px solid rgba(255,255,255,.18);
}

.hero__title {
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 800;
    line-height: 1.15;
    margin-bottom: 1.25rem;
    color: var(--color-white);
    letter-spacing: -.03em;
}

.hero__subtitle {
    font-size: clamp(.9375rem, 2.5vw, 1.125rem);
    color: rgba(255,255,255,.85);
    max-width: 600px;
    margin: 0 auto 2.25rem;
    line-height: 1.7;
}

.hero__cta {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* ============================================================
   LANDINGPAGE – SERVICE-KARTEN
   ============================================================ */

.service-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
}
@media (max-width: 640px) { .service-grid { grid-template-columns: 1fr; } }

.service-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.75rem 1.5rem;
    display: flex;
    gap: 1.125rem;
    align-items: flex-start;
    box-shadow: var(--shadow-sm);
    transition: box-shadow .2s, transform .2s, border-color .2s;
}
.service-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
    border-color: var(--color-primary-light);
}
.service-card__icon {
    width: 3rem;
    height: 3rem;
    background: var(--color-primary-light);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.375rem;
    flex-shrink: 0;
    border: 1px solid rgba(28,58,92,.08);
}
.service-card__body h3 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: .375rem;
    color: var(--color-text);
}
.service-card__body p {
    font-size: .9rem;
    color: var(--color-text-light);
    margin: 0;
    line-height: 1.6;
}

/* ============================================================
   LANDINGPAGE – TRUST-BOX
   ============================================================ */

.trust-box {
    background: linear-gradient(135deg, #eef4fb 0%, #e4edf7 100%);
    border: 1px solid #c8d9ea;
    border-left: 4px solid var(--color-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem 1.75rem;
    display: flex;
    align-items: flex-start;
    gap: 1.25rem;
}
.trust-box__icon {
    font-size: 2.25rem;
    flex-shrink: 0;
    line-height: 1;
    margin-top: .125rem;
}
.trust-box__text strong {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-primary-dark);
    margin-bottom: .375rem;
}
.trust-box__text p {
    margin: 0;
    color: var(--color-text-mid);
    font-size: .9375rem;
    line-height: 1.6;
}
@media (max-width: 480px) {
    .trust-box { flex-direction: column; }
}

/* ============================================================
   LANDINGPAGE – PROZESS-SCHRITTE
   ============================================================ */

.step-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    position: relative;
}
@media (max-width: 768px) { .step-list { grid-template-columns: 1fr; } }

/* Verbindungslinie zwischen Steps (Desktop) */
@media (min-width: 769px) {
    .step-list::before {
        content: '';
        position: absolute;
        top: 1.5rem;
        left: calc(100% / 6);
        width: calc(100% - 100% / 3);
        height: 2px;
        background: var(--color-primary-light);
        z-index: 0;
    }
}

.step-card {
    text-align: center;
    padding: 1.75rem 1.25rem;
    position: relative;
    z-index: 1;
}
.step-card__num {
    width: 3rem;
    height: 3rem;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 1.125rem;
    margin: 0 auto 1.125rem;
    box-shadow: 0 0 0 6px var(--color-primary-light);
    position: relative;
    z-index: 1;
}
.step-card h3 {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: .5rem;
    color: var(--color-text);
}
.step-card p {
    font-size: .9rem;
    color: var(--color-text-light);
    margin: 0;
    line-height: 1.6;
}

/* ============================================================
   LANDINGPAGE – ABSCHNITTS-TYPOGRAFIE
   ============================================================ */

.section-label {
    font-size: .75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--color-cta);
    margin-bottom: .625rem;
}

.section-heading {
    font-size: clamp(1.5rem, 3.5vw, 2rem);
    font-weight: 800;
    margin-bottom: .625rem;
    letter-spacing: -.02em;
}

.section-sub {
    color: var(--color-text-light);
    font-size: 1.0625rem;
    line-height: 1.7;
    max-width: 580px;
}

.section-header { margin-bottom: 2.5rem; }
.section-header--center { text-align: center; }
.section-header--center .section-sub { margin-inline: auto; }

/* ============================================================
   LANDINGPAGE – CTA-BEREICH
   ============================================================ */

.cta-section {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: var(--color-white);
    padding: 5rem 1.5rem;
    text-align: center;
}
.cta-section h2 {
    color: var(--color-white);
    margin-bottom: 1rem;
}
.cta-section p {
    color: rgba(255,255,255,.8);
    font-size: 1.0625rem;
    margin-bottom: 2rem;
}

/* ============================================================
   FOOTER
   ============================================================ */

.footer {
    background: var(--color-text);
    color: rgba(255,255,255,.55);
    padding: 1.75rem 1.5rem;
    font-size: .875rem;
}

.footer__inner {
    max-width: var(--max-width);
    margin-inline: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
}

.footer__links {
    list-style: none;
    padding: 0;
    display: flex;
    gap: 1.5rem;
}
.footer__links a {
    color: rgba(255,255,255,.55);
    font-size: .875rem;
    transition: color .15s;
}
.footer__links a:hover { color: rgba(255,255,255,.9); }

/* ============================================================
   UTILITY-KLASSEN
   ============================================================ */

.text-muted    { color: var(--color-text-light); }
.text-sm       { font-size: .875rem; }
.text-xs       { font-size: .8125rem; }
.text-right    { text-align: right; }
.text-center   { text-align: center; }
.font-bold     { font-weight: 700; }
.font-semibold { font-weight: 600; }

.d-flex          { display: flex; }
.align-center    { align-items: center; }
.justify-between { justify-content: space-between; }
.flex-wrap       { flex-wrap: wrap; }
.gap-2  { gap: .5rem; }
.gap-3  { gap: .75rem; }
.gap-4  { gap: 1rem; }

.mt-1 { margin-top: .25rem; }
.mt-2 { margin-top: .5rem; }
.mt-3 { margin-top: .75rem; }
.mt-4 { margin-top: 1rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-6 { margin-bottom: 1.5rem; }

/* ============================================================
   PLANER-STATUS-BADGES
   ============================================================ */

.badge--pending { background: #fef9c3; color: #713f12; border-color: #fde047; }
.badge--active  { background: #dcfce7; color: #14532d; border-color: #86efac; }
.badge--blocked { background: #fee2e2; color: #7f1d1d; border-color: #fca5a5; }

/* ============================================================
   PLANER-LAYOUT
   ============================================================ */

.planer-layout {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background: var(--color-bg);
}

/* Header */
.planer-header {
    background: var(--color-white);
    border-bottom: 2px solid var(--color-primary-light);
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 0;
    z-index: 200;
}

.planer-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    max-width: var(--max-width);
    margin-inline: auto;
    padding: .75rem 1.5rem;
    flex-wrap: wrap;
}

.planer-header__logo {
    display: flex;
    align-items: center;
    gap: .625rem;
    color: var(--color-primary);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: -.01em;
    text-decoration: none;
    flex-shrink: 0;
}
.planer-header__logo:hover { color: var(--color-primary-dark); text-decoration: none; }

.planer-header__logo-img {
    height: 9em;
    width: auto;
    display: block;
    flex-shrink: 0;
}

.planer-header__logo-icon {
    width: 2rem;
    height: 2rem;
    background: var(--color-primary);
    color: var(--color-white);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    font-weight: 800;
    flex-shrink: 0;
}

.planer-nav {
    display: flex;
    align-items: center;
    gap: .25rem;
}

.planer-nav__item {
    padding: .4375rem .875rem;
    border-radius: var(--radius);
    color: var(--color-text-mid);
    font-size: .9375rem;
    font-weight: 500;
    text-decoration: none;
    transition: background .15s, color .15s;
}
.planer-nav__item:hover {
    background: var(--color-primary-light);
    color: var(--color-primary);
    text-decoration: none;
}
.planer-nav__item.is-active {
    background: var(--color-primary-light);
    color: var(--color-primary);
    font-weight: 600;
}

.planer-header__user {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-shrink: 0;
}

/* Main */
.planer-main {
    flex: 1;
    padding: 2rem 0 3rem;
}

.page-heading {
    margin-bottom: 1.75rem;
}
.page-heading h1 { margin-bottom: .25rem; }

/* ============================================================
   LEAD-CARDS (Planer-Dashboard)
   ============================================================ */

.lead-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.125rem;
    margin-bottom: 1.5rem;
}

.lead-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    transition: box-shadow .18s, border-color .18s;
}
.lead-card:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary-light);
}

.lead-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: .75rem;
    padding: 1rem 1.125rem .625rem;
}

.lead-card__code {
    display: block;
    font-family: var(--font-mono);
    font-size: .8125rem;
    color: var(--color-text-light);
    margin-bottom: .25rem;
}

.lead-card__category {
    display: inline-block;
    font-size: .9375rem;
    font-weight: 600;
    color: var(--color-text);
}

.lead-card__body {
    padding: 0 1.125rem .75rem;
    flex: 1;
}

.lead-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: .375rem .875rem;
    font-size: .8125rem;
    color: var(--color-text-light);
    margin-bottom: .625rem;
}

.lead-card__price {
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--color-primary);
}

.lead-card__footer {
    padding: .75rem 1.125rem 1rem;
    border-top: 1px solid var(--color-border-light);
}

/* ============================================================
   CTA-CARD (lead_view freischalten)
   ============================================================ */

.card--cta {
    border: 2px dashed var(--color-border);
    background: var(--color-primary-pale);
}

/* ============================================================
   DATA-LIST (Detailansicht)
   ============================================================ */

.data-list { display: grid; gap: 0; }

.data-list__row {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: .5rem;
    padding: .625rem 0;
    border-bottom: 1px solid var(--color-border-light);
    align-items: start;
}
.data-list__row:last-child { border-bottom: none; }

.data-list__row dt {
    font-size: .875rem;
    font-weight: 600;
    color: var(--color-text-light);
    padding-top: .0625rem;
}
.data-list__row dd {
    font-size: .9375rem;
    color: var(--color-text);
    word-break: break-word;
}

/* ============================================================
   FORM-SECTION-TITLE / CHECKBOX / REQUIRED
   ============================================================ */

.form-section-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 1rem;
    padding-bottom: .5rem;
    border-bottom: 1px solid var(--color-border-light);
}

.form-checkbox {
    display: flex;
    align-items: flex-start;
    gap: .625rem;
    cursor: pointer;
    font-size: .9375rem;
    line-height: 1.5;
}
.form-checkbox input[type="checkbox"] {
    margin-top: .1875rem;
    flex-shrink: 0;
    width: 1rem;
    height: 1rem;
    accent-color: var(--color-primary);
    cursor: pointer;
}

.checkbox-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: .5rem .75rem;
    margin-bottom: .375rem;
}

.required { color: var(--color-error); }

/* ============================================================
   PAGINATION
   ============================================================ */

.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 1.25rem 0 .5rem;
}

.pagination__btn {
    padding: .5rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-white);
    color: var(--color-primary);
    font-size: .9375rem;
    font-weight: 500;
    text-decoration: none;
    transition: background .15s, border-color .15s;
}
.pagination__btn:hover {
    background: var(--color-primary-light);
    border-color: var(--color-primary);
    text-decoration: none;
}

.pagination__info {
    font-size: .875rem;
    color: var(--color-text-muted);
}

/* ============================================================
   DASHBOARD — Tabellen-Hilfsstile
   ============================================================ */

/* Inline-Code für Lead-Codes */
.lead-code {
    font-family: var(--font-mono, ui-monospace, 'Courier New', monospace);
    font-size: .8rem;
    background: var(--color-primary-light);
    color: var(--color-primary-dark);
    padding: .15em .45em;
    border-radius: var(--radius-sm);
    white-space: nowrap;
}

/* Beschreibungsspalte: bricht normal um, aber nicht zu breit */
.lead-desc {
    max-width: 26rem;
    color: var(--color-text-mid);
    line-height: 1.4;
}

/* Verhindert Umbrüche in Zellen mit Zahlen / Codes */
.text-nowrap { white-space: nowrap; }

/* Dashboard: Zeile mit PLZ-Region-Übereinstimmung dezent hervorheben */
tr.row--plz-match { background: var(--color-primary-pale); }
tr.row--plz-match:hover { background: var(--color-primary-light); }

/* Kleiner Punkt-Marker für PLZ-Region-Match */
.match-dot {
    color: var(--color-primary-mid);
    font-size: .55rem;
    vertical-align: middle;
    margin-left: .25rem;
}

/* ============================================================
   LEAD-VIEW — CTA-Block (Kontakt freischalten)
   ============================================================ */

/* Schloss-Icon im CTA */
.cta-lock-icon {
    font-size: 2.5rem;
    line-height: 1;
}

/* Preis + Slots nebeneinander, zentriert */
.cta-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.cta-price {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1.2;
}

.cta-slots {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .9375rem;
    color: var(--color-text-mid);
}

/* Größere lead-code Variante für Detailansicht-Titel */
.lead-code--lg {
    font-size: 1.125rem;
    padding: .2em .55em;
}

/* ============================================================
   ADMIN PLANNERS — Fachgebiete-Tags in Tabellenzeilen
   ============================================================ */

/* Wrapper: Tags umbrechen bei Platzmangel */
.specialty-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
}

/* Einzelnes Tag: dezente Pill-Form */
.specialty-tag {
    display: inline-block;
    padding: .15em .55em;
    font-size: .72rem;
    line-height: 1.5;
    background: var(--color-primary-light);
    color: var(--color-primary-dark);
    border-radius: 999px;
    white-space: nowrap;
}

/* Unformatierter Link (Firmenname in Tabelle) */
.link-plain {
    color: inherit;
    text-decoration: none;
}
.link-plain:hover { text-decoration: underline; }

/* ============================================================
   PRINT
   ============================================================ */

/* ============================================================
   Address Autocomplete Dropdown
   ============================================================ */

.addr-ac-dropdown {
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #cbd5e1;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .12);
    list-style: none;
    margin: 0;
    padding: 4px 0;
    z-index: 9999;
    max-height: 300px;
    overflow-y: auto;
}

.addr-ac-item {
    display: flex;
    flex-direction: column;
    padding: 9px 14px;
    cursor: pointer;
    border-bottom: 1px solid #f1f5f9;
    transition: background .12s;
}

.addr-ac-item:last-child { border-bottom: none; }

.addr-ac-item:hover,
.addr-ac-item--active {
    background: #eff6ff;
}

.addr-ac-street {
    font-size: .875rem;
    font-weight: 600;
    color: #1e293b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.addr-ac-location {
    font-size: .78rem;
    color: #64748b;
    margin-top: 1px;
}

/* ============================================================
   Print
   ============================================================ */

@media print {
    .nav,
    .admin-sidebar,
    .admin-header,
    .planer-header,
    .filter-tabs,
    .search-bar,
    .pagination,
    .btn { display: none !important; }

    .admin-layout { display: block; }
    .admin-main   { width: 100%; }
    .detail-grid  { display: block; }

    body { background: white; color: black; font-size: 12pt; }
    .card { box-shadow: none; border: 1px solid #ccc; }
    a { color: black; text-decoration: underline; }
}
