/* DKL Tour — mobile-first Tagesrouten-UI */

.dkl-tour {
    max-width: 720px;
    margin: 0 auto;
    padding: 16px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: #1f1b18;
}
.dkl-tour__header {
    position: sticky;
    top: 0;
    z-index: 10;
    background: #fffcf9;
    padding: 12px 16px;
    margin: -16px -16px 16px;
    border-bottom: 1px solid #e6ddd2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
}
.dkl-tour__title { margin: 0; font-size: 20px; }
.dkl-tour__progress { display: flex; align-items: center; gap: 8px; }
.dkl-tour__progress-text { font-size: 13px; font-weight: 600; color: #555; }
.dkl-tour__progress-bar { width: 120px; height: 8px; background: #e6ddd2; border-radius: 4px; overflow: hidden; }
.dkl-tour__progress-bar span { display: block; height: 100%; background: #1f4e79; transition: width 250ms ease; }

.dkl-tour__hint { color: #6b6356; font-size: 14px; }
.dkl-tour__hint--small { font-size: 12px; margin-top: 8px; }
.dkl-tour__planner-form { display: grid; gap: 16px; margin-top: 16px; }
.dkl-tour__field { display: flex; flex-direction: column; gap: 4px; }
.dkl-tour__field label { font-weight: 600; font-size: 14px; }
.dkl-tour__field input[type="range"] { width: 100%; }
.dkl-tour__field input[type="number"] { padding: 10px; font-size: 16px; border: 1px solid #ccc; border-radius: 6px; min-height: 44px; }

.dkl-tour__map { height: 320px; width: 100%; border: 1px solid #ddd; border-radius: 8px; }

/* Adress-Autocomplete (Empty-State Start-Pin-Picker) */
.dkl-tour__address-field { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.dkl-tour__address-label { font-weight: 600; font-size: 14px; }
.dkl-tour__autocomplete { position: relative; }
.dkl-tour__autocomplete input {
    width: 100%;
    padding: 12px 38px 12px 14px;
    font-size: 16px;
    border: 1px solid #ccc;
    border-radius: 8px;
    min-height: 44px;
    background: #fff;
    box-sizing: border-box;
}
.dkl-tour__autocomplete input:focus {
    outline: 2px solid #1f4e79;
    outline-offset: 1px;
    border-color: #1f4e79;
}
.dkl-tour__autocomplete[data-state="loading"] input {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24'><circle cx='12' cy='12' r='9' stroke='%231f4e79' stroke-width='3' fill='none' stroke-dasharray='40 60' stroke-linecap='round'><animateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='0.9s' repeatCount='indefinite'/></circle></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 18px;
}
.dkl-tour__address-clear {
    position: absolute;
    right: 8px; top: 50%;
    transform: translateY(-50%);
    width: 28px; height: 28px;
    border: 0; background: #eee; color: #555;
    border-radius: 50%; cursor: pointer;
    font-size: 18px; line-height: 1;
    display: flex; align-items: center; justify-content: center;
}
.dkl-tour__address-clear:hover { background: #ddd; }

.dkl-tour__suggestions {
    list-style: none; padding: 0;
    margin: 4px 0 0;
    position: absolute;
    left: 0; right: 0; top: 100%;
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 8px;
    box-shadow: 0 6px 18px rgba(0,0,0,0.12);
    z-index: 500;
    max-height: 280px; overflow-y: auto;
}
.dkl-tour__suggestion {
    padding: 12px 14px;
    cursor: pointer;
    border-bottom: 1px solid #f0eae3;
    display: flex; flex-direction: column; gap: 2px;
    min-height: 44px;
}
.dkl-tour__suggestion:last-child { border-bottom: 0; }
.dkl-tour__suggestion:hover,
.dkl-tour__suggestion.is-focused { background: #f0f4f9; }
.dkl-tour__suggestion strong { font-size: 14px; font-weight: 600; color: #1f1b18; }
.dkl-tour__suggestion-sub { font-size: 12px; color: #6b6356; }

/* Branche-Filter-Chips */
.dkl-tour__filter-hint { font-weight: 400; color: #888; font-size: 12px; }
.dkl-tour__chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.dkl-tour__chip-toggle { cursor: pointer; user-select: none; }
.dkl-tour__chip-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.dkl-tour__chip-toggle span {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px 12px; border-radius: 16px;
    background: #f5f5f5; color: #555;
    border: 1px solid #ddd;
    font-size: 13px; font-weight: 500;
    transition: background 120ms;
}
.dkl-tour__chip-toggle:hover span { background: #ebebeb; }
.dkl-tour__chip-toggle input:checked + span {
    background: #1f4e79; color: #fff; border-color: #1f4e79;
}
.dkl-tour__chip-toggle small { opacity: 0.7; font-size: 11px; font-weight: 600; }

/* Buttons */
.dkl-tour-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: 44px;
    padding: 10px 18px;
    border-radius: 8px;
    border: 1px solid #1f4e79;
    background: #fff;
    color: #1f4e79;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background 150ms;
}
.dkl-tour-btn:hover, .dkl-tour-btn:focus-visible { background: #f0f4f9; }
.dkl-tour-btn:disabled { opacity: 0.5; cursor: not-allowed; }
/* hidden-Attribut muss display:inline-flex schlagen, sonst greift recordBtn.hidden=true nicht
   (Pitfall css_display_property_overrides_hidden_attribute) */
.dkl-tour-btn[hidden] { display: none !important; }
.dkl-tour-btn--primary { background: #1f4e79; color: #fff; }
.dkl-tour-btn--primary:hover, .dkl-tour-btn--primary:focus-visible { background: #174266; }
.dkl-tour-btn--ghost { background: transparent; border-color: #ccc; color: #555; }
/* Stop & senden: waehrend der Aufnahme DIE Hauptaktion → prominent (gefuellt rot). */
.dkl-tour-btn--stop { background: #b91c1c; color: #fff; border-color: #b91c1c; }
.dkl-tour-btn--stop:hover, .dkl-tour-btn--stop:focus-visible { background: #991b1b; border-color: #991b1b; }
.dkl-tour-btn--mic { background: #d97706; color: #fff; border-color: #d97706; }
.dkl-tour-btn--mic:hover { background: #b8650a; }
.dkl-tour-btn--nav { background: #0b8043; color: #fff; border-color: #0b8043; text-decoration: none; }
.dkl-tour-btn--nav:hover, .dkl-tour-btn--nav:focus-visible { background: #086a37; color: #fff; }
.dkl-tour-btn--snooze { border-color: #c97e2a; color: #c97e2a; }
.dkl-tour-btn--snooze:hover, .dkl-tour-btn--snooze:focus-visible { background: #c97e2a; color: #fff; }
.dkl-tour-btn--close { border-color: #d9756c; color: #d9756c; }
.dkl-tour-btn--close:hover, .dkl-tour-btn--close:focus-visible { background: #d9756c; color: #fff; }
.dkl-tour-btn--demo { border-color: #2563eb; color: #2563eb; }
.dkl-tour-btn--demo:hover, .dkl-tour-btn--demo:focus-visible { background: #2563eb; color: #fff; }
.dkl-tour-btn--regen { border-color: #7c3aed; color: #7c3aed; }
.dkl-tour-btn--regen:hover, .dkl-tour-btn--regen:focus-visible { background: #7c3aed; color: #fff; }
.dkl-tour-btn--fav { border-color: #e0a800; color: #b8860b; }
.dkl-tour-btn--fav:hover, .dkl-tour-btn--fav:focus-visible { background: #fef3c7; color: #92400e; }
.dkl-tour-btn--fav.is-fav { background: #f5b50a; color: #3a2e00; border-color: #e0a800; }
.dkl-tour-btn--fav.is-fav:hover, .dkl-tour-btn--fav.is-fav:focus-visible { background: #e0a800; color: #3a2e00; }
.dkl-tour-mic-confirm { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.dkl-tour-mic-confirm[hidden] { display: none !important; }

/* Active-Route */
.dkl-tour__list { list-style: none; margin: 0; padding: 0; }
.dkl-tour__item {
    background: #fff;
    border: 1px solid #e6ddd2;
    border-radius: 10px;
    margin-bottom: 12px;
    padding: 14px;
    transition: background 200ms;
}
.dkl-tour__item.is-done { background: #f0f4ec; opacity: 0.65; }
.dkl-tour__item.is-done .dkl-tour__item-name::before { content: "✓ "; color: #2d7a4f; }
.dkl-tour__item.is-snoozed { background: #fdf3e3; }
.dkl-tour__item.is-snoozed .dkl-tour__item-name::before { content: "⏰ "; color: #c97e2a; }
.dkl-tour__item.is-closed { background: #fbe9e7; }
.dkl-tour__item.is-closed .dkl-tour__item-name::before { content: "❌ "; color: #d9756c; }
.dkl-tour__item-head { display: flex; gap: 12px; align-items: flex-start; }
.dkl-tour__item-num {
    flex-shrink: 0;
    width: 32px; height: 32px;
    background: #1f4e79; color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 14px;
}
.dkl-tour__item-info { flex: 1; display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.dkl-tour__item-name { font-size: 16px; }
.dkl-tour__chip {
    display: inline-block;
    align-self: flex-start;
    padding: 2px 8px;
    background: #fef3c7;
    color: #7a5800;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
}
.dkl-tour__item-inhaber, .dkl-tour__item-address { font-size: 13px; color: #555; }
.dkl-tour__item-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}
.dkl-tour__item-actions .dkl-tour-btn { flex: 1 1 auto; min-width: 130px; }

.dkl-tour__footer { margin-top: 24px; text-align: center; }

/* Gate */
.dkl-tour-gate { max-width: 480px; margin: 60px auto; text-align: center; }

/* Mic-Overlay
   WICHTIG: `display: flex` überschreibt den nativen HTML `hidden`-Default (display: none).
   Daher explizit `[hidden]`-Regel — sonst zeigt das Overlay bei Page-Load. */
.dkl-tour-mic-overlay[hidden] { display: none !important; }
.dkl-tour-mic-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.6);
    z-index: 1000;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
@media (min-width: 720px) {
    .dkl-tour-mic-overlay { align-items: center; }
}
.dkl-tour-mic-sheet {
    background: #fff;
    border-radius: 16px 16px 0 0;
    width: 100%;
    max-width: 540px;
    max-height: 90vh;
    overflow-y: auto;
    padding: 20px 18px 24px;
    position: relative;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.2);
}
@media (min-width: 720px) {
    .dkl-tour-mic-sheet { border-radius: 16px; }
}
.dkl-tour-mic-close {
    position: absolute; right: 12px; top: 8px;
    background: transparent; border: none;
    width: 36px; height: 36px;
    font-size: 24px; line-height: 1;
    cursor: pointer; color: #888;
}
.dkl-tour-mic-sheet h3 { margin: 0 0 4px; font-size: 18px; }
.dkl-tour-mic-lead-name { margin: 0 0 16px; color: #6b6356; font-size: 14px; }
.dkl-tour-mic-status { padding: 12px; background: #f6f7f7; border-radius: 8px; font-size: 14px; color: #444; text-align: center; margin-bottom: 14px; }
.dkl-tour-mic-status.is-recording { background: #fee2e2; color: #991b1b; font-weight: 600; }
.dkl-tour-mic-controls { display: flex; gap: 8px; margin-bottom: 18px; }
.dkl-tour-mic-controls .dkl-tour-btn { flex: 1; }

/* Demo-Mode Methoden-Auswahl ("Website anpassen" → 3 Varianten).
   [hidden]-Override Pflicht: .dkl-tour-mic-controls ist display:flex, würde sonst trotz hidden zeigen. */
.dkl-tour-mic-controls[hidden],
.dkl-tour-mic-state[hidden],
.dkl-tour-mic-methods[hidden] { display: none !important; }
/* Aktueller-Stand-Panel (Demo-Mode) */
.dkl-tour-mic-state {
    background: #f6f3ed; border: 1px solid #e4ddd0; border-radius: 10px;
    padding: 10px 12px; margin: 0 0 14px; font-size: 13px; color: #3a352c;
}
.dkl-tour-mic-state__head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.dkl-tour-mic-state__badge { background: #fbe6c8; color: #8a5a00; border-radius: 999px; padding: 1px 8px; font-size: 11px; font-weight: 600; cursor: default; }
.dkl-tour-mic-state__badge--ok { background: #e6efe6; color: #2e6b3b; }
.dkl-tour-mic-state__v { color: #6b6356; font-size: 11px; }
.dkl-tour-mic-state__hint { font-style: normal; color: #1f4e79; }
.dkl-tour-mic-state__hint em { color: #9a917f; }
.dkl-tour-mic-state__hist { margin-top: 6px; }
.dkl-tour-mic-state__hist summary { cursor: pointer; color: #6b6356; font-size: 12px; }
.dkl-tour-mic-state__hist ul { margin: 6px 0 0; padding-left: 14px; }
.dkl-tour-mic-state__hist li { margin-bottom: 4px; line-height: 1.35; }
.dkl-tour-mic-state__hist time { color: #9a917f; font-size: 11px; margin-right: 4px; }
.dkl-tour-mic-state__cap { margin-top: 6px; color: #9a917f; font-size: 11px; }
.dkl-tour-mic-state__loading { color: #9a917f; }
.dkl-tour-mic-methods { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.dkl-tour-mic-methods__intro { margin: 0 0 2px; font-size: 14px; font-weight: 600; color: #1f4e79; }
.dkl-tour-mic-method {
    display: flex; gap: 12px; align-items: flex-start;
    text-align: left; width: 100%;
    padding: 12px 14px;
    background: #fff; border: 1px solid #d9dee5; border-radius: 10px;
    cursor: pointer; transition: border-color 120ms, background 120ms;
}
.dkl-tour-mic-method:hover:not(:disabled) { border-color: #1f4e79; background: #f5f8fc; }
.dkl-tour-mic-method:disabled { opacity: 0.55; cursor: not-allowed; }
.dkl-tour-mic-method__icon { font-size: 22px; line-height: 1.2; flex: 0 0 auto; }
.dkl-tour-mic-method__body { display: flex; flex-direction: column; gap: 2px; }
.dkl-tour-mic-method__body strong { font-size: 14px; color: #222; }
.dkl-tour-mic-method__body em { font-style: normal; color: #94794a; font-weight: 600; }
.dkl-tour-mic-method__body small { font-size: 12px; color: #6b6356; line-height: 1.4; }

/* Mikrofon-Test (Diagnose, kein Upload). */
/* Live-Pegel-Meter waehrend der Aufnahme — visuelles "Ton kommt an"-Signal. */
.dkl-tour-mic-meter[hidden] { display: none !important; }
.dkl-tour-mic-meter { height: 8px; background: #eef0f2; border-radius: 6px; overflow: hidden; margin: -6px 0 14px; }
.dkl-tour-mic-meter__bar { display: block; height: 100%; width: 0%; background: linear-gradient(90deg,#22c55e,#eab308,#ef4444); transition: width 80ms linear; }

/* Mikrofon-Test: dezenter Text-Link (sekundaer, konkurriert NICHT mit "Aufnahme starten"). */
.dkl-tour-mic-test[hidden] { display: none !important; }
.dkl-tour-mic-test { margin: -4px 0 14px; text-align: center; }
.dkl-tour-mic-test-btn {
    background: transparent; border: none; padding: 4px 6px;
    color: #6b7689; font-size: 12px; text-decoration: underline; text-underline-offset: 2px;
    cursor: pointer;
}
.dkl-tour-mic-test-btn:hover { color: #1f4e79; }
.dkl-tour-mic-test-out[hidden] { display: none !important; }
.dkl-tour-mic-test-out { margin-top: 8px; }
.dkl-tour-mic-test-info { margin: 0 0 6px; font-size: 12px; color: #444; line-height: 1.4; }
.dkl-tour-mic-test-audio { width: 100%; height: 36px; }

.dkl-tour-mic-questions {
    background: #fffae6;
    border: 1px solid #f0d97d;
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 14px;
}
.dkl-tour-mic-questions__intro { margin: 0; font-size: 13px; font-weight: 600; color: #7a5800; cursor: pointer; user-select: none; }
.dkl-tour-mic-questions[open] .dkl-tour-mic-questions__intro { margin-bottom: 8px; }
.dkl-tour-mic-questions__list { margin: 0; padding-left: 22px; color: #444; font-size: 13px; line-height: 1.5; }
.dkl-tour-mic-questions__list li { margin-bottom: 4px; }

.dkl-tour-mic-result {
    padding: 14px;
    background: #f0f4f9;
    border-left: 3px solid #1f4e79;
    border-radius: 8px;
    font-size: 13px;
    white-space: pre-wrap;
    line-height: 1.5;
}

/* Multi-Stage-Demo-Pipeline: v1/v2-Badge im Demo-Link.
   v1 = generisch (Stitch-only), v2 = mit Lead-Daten gepatcht. */
.dkl-tour__demo-badge {
    display: inline-block;
    margin-left: 6px;
    padding: 1px 7px;
    border-radius: 9px;
    font-size: 10px;
    font-weight: 600;
    line-height: 1.6;
    vertical-align: middle;
    letter-spacing: 0.02em;
}
.dkl-tour__demo-badge--v1 {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}
.dkl-tour__demo-badge--v2 {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}

/* Stage 3: v3-Badge (Visual-QA passed/refined) */
.dkl-tour__demo-badge--v3 {
    background: #dbeafe;
    color: #1e3a8a;
    border: 1px solid #93c5fd;
}

/* Disabled-Variante: zeigt "Demo wird vorbereitet" statt aktivem Link. */
.dkl-tour-btn--disabled {
    pointer-events: none;
    opacity: 0.6;
    cursor: not-allowed;
    background: #f4f6fa;
    color: #6b7280;
    border-color: #d1d5db;
    font-style: italic;
}
