/* === Move To Shop Storefront (Phase D.1) ============================== */
/* Theme-friendly: nutzt currentColor + neutrale Greys, ueberschreibt nichts. */

:root {
    /* MTS-Brand: warmer Gradient von Gelb (#FFB300) zu Orange (#FF8C00),
       passend zur CTA-Reihe (Add-to-Cart) und zum Plugin-Icon (#FF9800).
       Wir benutzen Orange (#FF8C00) als Primary, das Helle (#FFB300) fuer
       Light-Backgrounds und Akzentlinien, das Dunkle (#F57C00) fuer Hover. */
    --mts-c-primary:        #FF8C00;
    --mts-c-primary-dark:   #F57C00;
    --mts-c-primary-soft:   #FFB300;
    --mts-c-primary-tint:   rgba(255, 140, 0, 0.10);
    --mts-c-primary-ring:   rgba(255, 140, 0, 0.22);
    --mts-c-primary-onbg:   #1a1a1a;
    --mts-c-warning: #d97706;
    --mts-c-danger:  #dc2626;
    --mts-c-success: #16a34a;
    --mts-c-text:    #1f2937;
    --mts-c-muted:   #6b7280;
    --mts-c-border:  #e5e7eb;
    --mts-c-bg-soft: #f9fafb;
    --mts-radius:    0.55rem;
    --mts-shadow-sm: 0 1px 2px rgba(15,23,42,0.06);
    --mts-shadow-md: 0 6px 18px rgba(15,23,42,0.10);
}

/* --- Header-Pill (BranchPickerHeader) --------------------------------- */
.mts-branch-pill {
    display: inline-flex; align-items: center; gap: 0.4rem;
    padding: 0.35rem 0.7rem;
    border: 1px solid var(--mts-c-border);
    border-radius: 9999px;
    background: #fff;
    color: var(--mts-c-text);
    text-decoration: none !important;
    font-size: 0.85rem; line-height: 1;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.mts-branch-pill:hover { border-color: var(--mts-c-primary); box-shadow: 0 0 0 3px var(--mts-c-primary-ring); color: var(--mts-c-primary-dark); }
.mts-branch-pill svg { flex-shrink: 0; }
.mts-branch-pill-label { font-weight: 600; max-width: 28ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
@media (max-width: 768px) { .mts-branch-pill-label { max-width: 16ch; } }
.mts-branch-pill-caret { opacity: 0.6; }

/* --- PDP-Stockbox ------------------------------------------------------ */
.mts-pdp-stockbox {
    margin: 1rem 0;
    padding: 1rem 1.1rem;
    background: var(--mts-c-bg-soft);
    border: 1px solid var(--mts-c-border);
    border-radius: var(--mts-radius);
    color: var(--mts-c-text);
    font-size: 0.9rem;
}
.mts-pdp-stockbox-head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.6rem; }
.mts-pdp-stockbox-title { font-weight: 600; }
.mts-pdp-stockbox-aggregate { margin-left: auto; font-size: 0.78rem; color: var(--mts-c-muted); }
.mts-pdp-stockbox-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.3rem; }
.mts-pdp-stockbox-row {
    display: grid;
    grid-template-columns: 12px 1fr auto auto;
    align-items: center; gap: 0.5rem;
    padding: 0.35rem 0.5rem;
    border-radius: 0.35rem;
    background: #fff;
    border: 1px solid transparent;
}
.mts-pdp-stockbox-row.is-current { border-color: var(--mts-c-primary); background: var(--mts-c-primary-tint); }
.mts-pdp-stockbox-dot { width: 10px; height: 10px; border-radius: 50%; background: #ddd; }
.mts-state-in  .mts-pdp-stockbox-dot { background: var(--mts-c-success); }
.mts-state-low .mts-pdp-stockbox-dot { background: var(--mts-c-warning); }
.mts-state-out .mts-pdp-stockbox-dot { background: var(--mts-c-danger); }
.mts-pdp-stockbox-name { color: var(--mts-c-text); text-decoration: none; font-weight: 500; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mts-pdp-stockbox-name:hover { text-decoration: underline; }
.mts-pdp-stockbox-status { font-size: 0.78rem; color: var(--mts-c-muted); }
.mts-state-in  .mts-pdp-stockbox-status { color: var(--mts-c-success); }
.mts-state-low .mts-pdp-stockbox-status { color: var(--mts-c-warning); }
.mts-state-out .mts-pdp-stockbox-status { color: var(--mts-c-danger); }
.mts-pdp-stockbox-qty { font-size: 0.78rem; color: var(--mts-c-muted); white-space: nowrap; }
.mts-pdp-stockbox-foot { margin-top: 0.6rem; font-size: 0.8rem; }
.mts-pdp-stockbox-foot a { color: var(--mts-c-primary); text-decoration: none; }
.mts-pdp-stockbox-foot a:hover { text-decoration: underline; }

/* --- Cart Pickup Stub ------------------------------------------------- */
.mts-cart-pickup {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.75rem; align-items: start;
    margin: 0.75rem 0;
    padding: 0.85rem 1rem;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: var(--mts-radius);
    color: #78350f;
    font-size: 0.88rem;
}
.mts-cart-pickup-icon { color: #b45309; }
.mts-cart-pickup-title { font-weight: 600; margin-bottom: 0.15rem; }
.mts-cart-pickup-text { color: #92400e; }
.mts-cart-pickup-link { display: inline-block; margin-left: 0.6rem; color: var(--mts-c-primary); font-size: 0.82rem; text-decoration: none; }
.mts-cart-pickup-link:hover { text-decoration: underline; }
.mts-cart-pickup-badge { font-size: 0.7rem; font-weight: 700; padding: 0.2rem 0.5rem; background: #f59e0b; color: #fff; border-radius: 9999px; align-self: center; text-transform: uppercase; letter-spacing: 0.04em; }
.mts-cart-pickup.is-active { background: #ecfdf5; border-color: #6ee7b7; color: #065f46; }
.mts-cart-pickup.is-active .mts-cart-pickup-icon { color: #047857; }
.mts-cart-pickup.is-active .mts-cart-pickup-text { color: #065f46; }
.mts-cart-pickup-actions { display: flex; align-items: center; gap: 0.5rem; margin-top: 0.5rem; flex-wrap: wrap; }
.mts-cart-pickup-btn { padding: 0.4rem 0.85rem; font-size: 0.82rem; font-weight: 600; border-radius: 0.35rem; cursor: pointer; border: 1px solid transparent; font-family: inherit; transition: all 0.15s; }
.mts-cart-pickup-btn-on { background: #16a34a; color: #fff; border-color: #16a34a; }
.mts-cart-pickup-btn-on:hover { background: #15803d; border-color: #15803d; }
.mts-cart-pickup-btn-off { background: transparent; color: #047857; border-color: #6ee7b7; }
.mts-cart-pickup-btn-off:hover { background: #d1fae5; }

/* --- Reserve-Drawer (Phase 7c, shopify-style slide-in von rechts) ---- */
.mts-drawer[hidden] { display: none !important; }
.mts-drawer {
    position: fixed; inset: 0; z-index: 10600;
    display: flex; justify-content: flex-end;
    pointer-events: none;
}
.mts-drawer-backdrop {
    position: absolute; inset: 0;
    background: rgba(15, 23, 42, 0.0);
    backdrop-filter: blur(0px);
    transition: background 0.35s ease, backdrop-filter 0.35s ease;
    pointer-events: none;
}
.mts-drawer.is-open { pointer-events: auto; }
.mts-drawer.is-open .mts-drawer-backdrop {
    background: rgba(15, 23, 42, 0.42);
    backdrop-filter: blur(4px);
    pointer-events: auto;
}
.mts-drawer-panel {
    position: relative;
    width: 100%; max-width: 480px;
    height: 100%;
    background: #fff;
    box-shadow: -24px 0 56px rgba(15, 23, 42, 0.18);
    border-top-left-radius: 0;
    display: flex; flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}
.mts-drawer-head {
    background: linear-gradient(180deg, var(--mts-c-primary-tint) 0%, transparent 100%);
    padding-bottom: 1.4rem;
}
.mts-drawer.is-open .mts-drawer-panel { transform: translateX(0); }
@media (prefers-reduced-motion: reduce) {
    .mts-drawer-panel, .mts-drawer-backdrop { transition: none; }
}
.mts-drawer-head {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 1rem;
    padding: 1.4rem 1.5rem 1.1rem;
}
.mts-drawer-eyebrow {
    margin: 0 0 0.2rem; font-size: 0.72rem; letter-spacing: 0.08em;
    text-transform: uppercase; font-weight: 700; color: var(--mts-c-primary);
}
.mts-drawer-head h3 {
    margin: 0; font-size: 1.35rem; font-weight: 700; color: #0f172a;
    line-height: 1.2;
}
.mts-drawer-close {
    border: 0; background: transparent; cursor: pointer;
    padding: 0.4rem; color: #64748b;
    border-radius: 999px;
    transition: background 0.15s, color 0.15s;
}
.mts-drawer-close:hover { background: rgba(15, 23, 42, 0.06); color: #0f172a; }
.mts-drawer-body {
    flex: 1; overflow-y: auto;
    padding: 0 1.5rem 1rem;
    display: flex; flex-direction: column; gap: 0.8rem;
}
.mts-drawer-foot {
    padding: 1rem 1.5rem 1.5rem;
    border-top: 1px solid rgba(15, 23, 42, 0.06);
}
.mts-drawer-footnote { margin: 0; font-size: 0.78rem; color: #64748b; line-height: 1.5; }
.mts-drawer-empty { color: #64748b; padding: 1rem 0; }
.mts-drawer-error {
    margin: 0; padding: 0.85rem 1rem;
    background: rgba(220, 38, 38, 0.06);
    color: #b91c1c;
    border-radius: 0.6rem;
    font-size: 0.88rem;
}

/* Reserve-Card (no border, no grey bg - clean shadow + hover lift) */
.mts-rc {
    background: #fff;
    border-radius: 14px;
    padding: 1.1rem 1.15rem 1rem;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 2px 8px rgba(15, 23, 42, 0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    position: relative;
    overflow: hidden;
}
.mts-rc::before {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; background: transparent;
    transition: background 0.18s ease;
}
.mts-rc:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(15, 23, 42, 0.10); }
.mts-rc.is-current::before { background: linear-gradient(180deg, var(--mts-c-primary-soft), var(--mts-c-primary)); }
.mts-rc-state-in::before    { background: #16a34a; }
.mts-rc-state-low::before   { background: #d97706; }
.mts-rc-state-out::before   { background: #94a3b8; }
.mts-rc-state-unknown::before { background: #cbd5e1; }
.mts-rc-head {
    display: flex; justify-content: space-between; align-items: center;
    gap: 0.5rem; margin-bottom: 0.55rem;
}
.mts-rc-state-pill {
    display: inline-flex; align-items: center; gap: 0.45rem;
    font-size: 0.78rem; color: #475569; font-weight: 600;
}
.mts-rc-dot {
    width: 9px; height: 9px; border-radius: 50%; background: #cbd5e1;
    box-shadow: 0 0 0 3px rgba(203, 213, 225, 0.25);
}
.mts-rc-state-in    .mts-rc-dot { background: #16a34a; box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.16); }
.mts-rc-state-low   .mts-rc-dot { background: #d97706; box-shadow: 0 0 0 4px rgba(217, 119, 6, 0.16); }
.mts-rc-state-out   .mts-rc-dot { background: #94a3b8; }
.mts-rc-state-unknown .mts-rc-dot { background: #cbd5e1; }
.mts-rc-state-label { color: #1e293b; }
.mts-rc-state-in    .mts-rc-state-label { color: #15803d; }
.mts-rc-state-low   .mts-rc-state-label { color: #b45309; }
.mts-rc-qty {
    font-size: 0.72rem; padding: 0.1rem 0.5rem; border-radius: 999px;
    background: rgba(15, 23, 42, 0.05); color: #475569;
}
.mts-rc-badges { display: inline-flex; gap: 0.3rem; flex-wrap: wrap; justify-content: flex-end; }
.mts-rc-badge {
    font-size: 0.66rem; font-weight: 700; padding: 0.18rem 0.55rem;
    border-radius: 999px;
}
.mts-rc-badge-current {
    background: linear-gradient(135deg, var(--mts-c-primary-soft) 0%, var(--mts-c-primary) 100%);
    color: var(--mts-c-primary-onbg);
}
.mts-rc-badge-primary { background: var(--mts-c-primary-dark); color: #fff; }
.mts-rc-name { margin: 0 0 0.3rem; font-size: 1.02rem; font-weight: 700; color: #0f172a; line-height: 1.25; }
.mts-rc-addr { margin: 0 0 0.6rem; font-size: 0.83rem; color: #64748b; line-height: 1.4; }
.mts-rc-tags { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-bottom: 0.75rem; }
.mts-rc-tag {
    font-size: 0.7rem; padding: 0.2rem 0.55rem;
    border-radius: 999px; background: rgba(15, 23, 42, 0.045); color: #475569;
}
.mts-rc-actions { margin-top: 0.3rem; }
.mts-rc-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
    width: 100%; padding: 0.7rem 1rem;
    border-radius: 10px;
    font-size: 0.92rem; font-weight: 600; line-height: 1;
    cursor: pointer;
    transition: transform 0.12s, box-shadow 0.18s, background 0.18s;
    text-decoration: none;
    border: 0;
    font-family: inherit;
}
.mts-rc-btn-primary {
    background: linear-gradient(135deg, var(--mts-c-primary-soft) 0%, var(--mts-c-primary) 100%);
    color: var(--mts-c-primary-onbg);
    box-shadow: 0 1px 2px rgba(255, 140, 0, 0.20), 0 4px 14px rgba(255, 140, 0, 0.28);
    letter-spacing: 0.01em;
}
.mts-rc-btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(255, 140, 0, 0.32), 0 8px 22px rgba(255, 140, 0, 0.22);
    background: linear-gradient(135deg, #FFA000 0%, var(--mts-c-primary-dark) 100%);
}
.mts-rc-btn-primary:active { transform: translateY(0); }
.mts-rc-btn-primary.is-loading { opacity: 0.6; cursor: progress; }
.mts-rc-btn-primary[disabled] { opacity: 0.5; cursor: not-allowed; }
.mts-rc-btn-ghost {
    background: transparent; color: #1e293b;
    box-shadow: inset 0 0 0 1.5px rgba(15, 23, 42, 0.12);
}
.mts-rc-btn-ghost:hover { box-shadow: inset 0 0 0 1.5px #0f172a; }
.mts-rc-btn-disabled { background: rgba(15, 23, 42, 0.06); color: #94a3b8; cursor: not-allowed; }
.mts-rc-err {
    margin-top: 0.6rem; padding: 0.5rem 0.7rem;
    background: rgba(220, 38, 38, 0.08); color: #b91c1c;
    border-radius: 0.5rem; font-size: 0.82rem;
}
.mts-rc-success { animation: mtsRcPulse 0.4s ease-out; }
@keyframes mtsRcPulse {
    0%   { transform: scale(0.98); }
    50%  { transform: scale(1.01); }
    100% { transform: scale(1); }
}
.mts-rc-success-box { text-align: center; padding: 0.8rem 0.4rem; }
.mts-rc-success-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 52px; height: 52px; border-radius: 50%;
    background: rgba(22, 163, 74, 0.12); color: #15803d;
    margin-bottom: 0.6rem;
}
.mts-rc-success-box h5 { margin: 0 0 0.35rem; font-size: 1rem; font-weight: 700; color: #15803d; }
.mts-rc-success-box p { margin: 0 0 0.25rem; font-size: 0.9rem; color: #1e293b; }
.mts-rc-success-box strong { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 1.05rem; letter-spacing: 0.04em; }
.mts-rc-success-sub { color: #64748b !important; font-size: 0.82rem !important; }

/* Skeleton placeholder waehrend Verfuegbarkeit laedt */
.mts-drawer-skeleton { display: flex; flex-direction: column; gap: 0.8rem; }
.mts-skeleton-card {
    height: 145px; border-radius: 14px;
    background: linear-gradient(90deg, rgba(15,23,42,0.04) 0%, rgba(15,23,42,0.08) 50%, rgba(15,23,42,0.04) 100%);
    background-size: 220% 100%;
    animation: mtsShimmer 1.4s linear infinite;
}
@keyframes mtsShimmer {
    0%   { background-position: 220% 0; }
    100% { background-position: -20% 0; }
}

/* --- Modal ------------------------------------------------------------ */
/* Borderless, mehr Whitespace, Hover-Lift statt Border-Wechsel, Apple-style.
   Service-Tags wurden aus dem Markup entfernt (User-Praeferenz 2026-05-11):
   das Modal ist ein Picker, keine Service-Uebersicht. */
.mts-modal[hidden] { display: none !important; }
.mts-modal { position: fixed; inset: 0; z-index: 10500; display: flex; align-items: center; justify-content: center; padding: 1rem; }
.mts-modal-backdrop { position: absolute; inset: 0; background: rgba(15,23,42,0.45); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.mts-modal-card {
    position: relative; width: 100%;
    max-width: 560px; max-height: 86vh;
    display: flex; flex-direction: column;
    background: #fff; border-radius: 20px;
    box-shadow: 0 1px 2px rgba(15,23,42,0.06), 0 24px 64px -16px rgba(15,23,42,0.24);
    overflow: hidden;
    animation: mtsModalIn 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes mtsModalIn { from { transform: translateY(12px) scale(0.985); opacity: 0; } to { transform: translateY(0) scale(1); opacity: 1; } }
.mts-modal-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.5rem 1.6rem 0.85rem;
    border: 0;
}
.mts-modal-head h3 {
    margin: 0; font-size: 1.35rem; font-weight: 700;
    color: #0f172a; letter-spacing: -0.01em; line-height: 1.2;
}
.mts-modal-close {
    border: 0; background: transparent; cursor: pointer;
    width: 38px; height: 38px;
    display: inline-flex; align-items: center; justify-content: center;
    color: #64748b; border-radius: 999px;
    transition: background 0.18s ease, color 0.18s ease;
}
.mts-modal-close:hover { background: rgba(15,23,42,0.06); color: #0f172a; }
.mts-modal-body { padding: 0.5rem 1.6rem 1.2rem; overflow-y: auto; }
.mts-modal-intro {
    font-size: 0.95rem; color: #475569; line-height: 1.5;
    margin: 0 0 1.1rem;
}
.mts-modal-search {
    width: 100%; box-sizing: border-box;
    padding: 0.8rem 1rem 0.8rem 2.6rem;
    background: #f5f7fa;
    border: 0;
    border-radius: 12px;
    font-size: 0.95rem;
    font-family: inherit;
    color: #0f172a;
    margin-bottom: 1rem;
    transition: background 0.18s ease, box-shadow 0.18s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: 0.85rem center;
    background-size: 18px 18px;
}
.mts-modal-search::placeholder { color: #94a3b8; }
.mts-modal-search:focus {
    outline: none;
    background: #fff;
    box-shadow: 0 0 0 3px var(--mts-c-primary-ring), inset 0 0 0 1.5px var(--mts-c-primary);
}
.mts-modal-branch-list {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 0.25rem;
}
.mts-modal-branch-item {
    border-radius: 14px;
}
.mts-modal-branch-btn {
    width: 100%; text-align: left;
    padding: 0.95rem 1.1rem;
    background: transparent;
    border: 0;
    border-radius: 14px;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.18s ease, transform 0.12s ease;
    display: block;
}
.mts-modal-branch-btn:hover {
    background: #f5f7fa;
    transform: none;
}
.mts-modal-branch-item.is-current .mts-modal-branch-btn {
    background: var(--mts-c-primary-tint);
    box-shadow: inset 0 0 0 1.5px var(--mts-c-primary);
}
.mts-modal-branch-item.is-current .mts-modal-branch-btn:hover {
    background: rgba(255, 140, 0, 0.16);
}
.mts-modal-branch-name {
    display: flex; align-items: center; gap: 0.55rem; flex-wrap: wrap;
    font-weight: 600; color: #0f172a;
    font-size: 1.02rem; line-height: 1.3;
    letter-spacing: -0.005em;
}
.mts-modal-branch-primary {
    font-size: 0.65rem;
    padding: 0.2rem 0.55rem;
    background: linear-gradient(135deg, var(--mts-c-primary-soft) 0%, var(--mts-c-primary) 100%);
    color: var(--mts-c-primary-onbg);
    border-radius: 9999px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.mts-modal-branch-active {
    font-size: 0.65rem;
    padding: 0.2rem 0.55rem;
    background: var(--mts-c-primary-dark);
    color: #fff;
    border-radius: 9999px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.mts-modal-branch-addr {
    display: block;
    font-size: 0.88rem;
    color: #64748b;
    margin-top: 0.3rem;
    line-height: 1.4;
}
/* Service-Tags-Container im Modal entfernt (Markup-Edit), CSS bleibt
   als no-op falls altes Markup im Cache irgendwo persistiert. */
.mts-modal-branch-tags { display: none; }
.mts-modal-foot {
    padding: 1rem 1.6rem 1.4rem;
    border: 0;
    background: transparent;
    text-align: right;
}
.mts-modal-allbranches {
    font-size: 0.9rem;
    color: var(--mts-c-primary-dark);
    font-weight: 600;
    text-decoration: none;
    transition: color 0.18s ease;
}
.mts-modal-allbranches:hover { color: var(--mts-c-primary); text-decoration: none; }

/* === Storefront Pages: Filialfinder + Detail (Apple-style polish) ====== */
/* Design tokens, lokal scoped damit der Rest der Storefront-Komponenten
   nicht beeinflusst wird. */
.mts-page {
    --mts-ink:        #0b1220;
    --mts-ink-soft:   #4a5568;
    --mts-ink-muted:  #6b7280;
    --mts-line:       rgba(15, 23, 42, 0.08);
    --mts-line-soft:  rgba(15, 23, 42, 0.04);
    --mts-surface:    #ffffff;
    --mts-surface-2:  #f5f7fa;
    --mts-accent:     #FF8C00;
    --mts-accent-2:   #FFB300;
    --mts-radius-lg:  20px;
    --mts-radius-md:  14px;
    --mts-radius-sm:  10px;
    --mts-shadow-1:   0 1px 2px rgba(15,23,42,0.04), 0 8px 24px -10px rgba(15,23,42,0.10);
    --mts-shadow-2:   0 1px 2px rgba(15,23,42,0.06), 0 24px 60px -22px rgba(15,23,42,0.22);
    max-width: 1200px;
    margin: 2.5rem auto 4rem;
    padding: 0 1.25rem;
    color: var(--mts-ink);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Inter, system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* Hero / Page-Head -------------------------------------------------- */
.mts-page-head {
    margin: 1.5rem 0 2.25rem;
    padding: 2.25rem 2.5rem 2rem;
    border-radius: var(--mts-radius-lg);
    background:
        radial-gradient(ellipse 75% 80% at 12% 0%, rgba(255,179,0,0.14), transparent 60%),
        radial-gradient(ellipse 70% 70% at 100% 0%, rgba(255,140,0,0.10), transparent 65%),
        linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    border: 1px solid var(--mts-line);
    position: relative;
    overflow: hidden;
}
.mts-page-head::after {
    content: '';
    position: absolute;
    right: -40px;
    top: -40px;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,179,0,0.10) 0%, transparent 65%);
    pointer-events: none;
}
.mts-page-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--mts-accent);
    margin: 0 0 0.85rem;
}
.mts-page-eyebrow::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--mts-accent);
    box-shadow: 0 0 0 4px rgba(255,140,0,0.22);
}
.mts-page-title {
    font-size: clamp(2rem, 3.4vw, 2.85rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.1;
    margin: 0 0 0.6rem;
    color: var(--mts-ink);
}
.mts-page-lead {
    font-size: clamp(1rem, 1.2vw, 1.1rem);
    line-height: 1.55;
    color: var(--mts-ink-soft);
    max-width: 60ch;
    margin: 0;
}

/* Filter Bar -------------------------------------------------------- */
.mts-tag-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0 0 2rem;
    padding: 0;
    border: 0;
}
.mts-tag-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.55rem 1.1rem;
    border: 1px solid var(--mts-line);
    border-radius: 9999px;
    background: var(--mts-surface);
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--mts-ink);
    text-decoration: none !important;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.12s ease;
}
.mts-tag-pill:hover {
    background: var(--mts-surface-2);
    border-color: rgba(15,23,42,0.16);
    color: var(--mts-ink);
}
.mts-tag-pill.is-active {
    background: var(--mts-ink);
    border-color: var(--mts-ink);
    color: #fff;
}
.mts-tag-pill.is-active:hover {
    background: #1f2937;
    border-color: #1f2937;
    color: #fff;
}

/* Service-Tag-Chips: farbcodiert pro Service-Typ ------------------- */
.mts-tag-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.22rem 0.65rem;
    background: #eef2f7;
    color: #1f2937;
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    border-radius: 9999px;
}
/* Sprachneutrale Heuristik per Attribut-Selector — der View liefert den
   Service-Tag-Text direkt, also greifen wir auf den Inhalt indirekt zu via
   class-Toggle wäre sauberer; hier matchen wir den deutschen Standard. */
.mts-tag-chip:where([data-tag="Verkauf"], :is(span:where(:not([data-tag])):where(:where([data-tag])))) { background: #e0f2fe; color: #075985; }
/* Fallback farb-codiert via JS / data-tag — siehe storefront.js (Phase D.2) */
.mts-tag-chip[data-tag="Verkauf"]      { background: #e0f2fe; color: #075985; }
.mts-tag-chip[data-tag="Werkstatt"]    { background: #fef3c7; color: #92400e; }
.mts-tag-chip[data-tag="Leasing"]      { background: #ecfccb; color: #3f6212; }
.mts-tag-chip[data-tag="Versicherung"] { background: #ede9fe; color: #5b21b6; }
.mts-tag-chip[data-tag="Probefahrt"]   { background: #cffafe; color: #155e75; }
.mts-tag-chip[data-tag="Service"]      { background: #ffe4e6; color: #9f1239; }

/* Empty-State ------------------------------------------------------- */
.mts-empty {
    text-align: center;
    padding: 4.5rem 1.5rem;
    color: var(--mts-ink-muted);
    background: var(--mts-surface-2);
    border-radius: var(--mts-radius-lg);
    border: 1px dashed var(--mts-line);
}
.mts-empty svg { color: var(--mts-ink-muted); opacity: 0.6; margin-bottom: 0.85rem; }
.mts-empty h2 { margin: 0 0 0.4rem; color: var(--mts-ink); font-size: 1.25rem; font-weight: 600; }
.mts-empty p { margin: 0; }

/* Branch Cards ------------------------------------------------------ */
.mts-branch-grid {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}
.mts-branch-card {
    position: relative;
    background: var(--mts-surface);
    border: 1px solid var(--mts-line);
    border-radius: var(--mts-radius-lg);
    box-shadow: var(--mts-shadow-1);
    display: flex;
    flex-direction: column;
    padding: 1.75rem 1.75rem 1.5rem;
    overflow: hidden;
    transition: transform 0.22s cubic-bezier(.4,0,.2,1), box-shadow 0.22s cubic-bezier(.4,0,.2,1), border-color 0.22s;
}
.mts-branch-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--mts-shadow-2);
    border-color: rgba(15,23,42,0.12);
}
.mts-branch-card.is-current {
    border-color: var(--mts-accent);
    box-shadow: 0 0 0 1px var(--mts-accent), var(--mts-shadow-2);
}
.mts-branch-card.is-current::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, var(--mts-accent), var(--mts-accent-2));
    z-index: 1;
}
/* Stretched-Link-Pattern: Title-Link spannt sich unsichtbar ueber die ganze Card.
   Inline-Links (Phone/Email/Details) bleiben darueber klickbar via z-index. */
.mts-branch-card-title-link {
    color: inherit;
    text-decoration: none !important;
}
.mts-branch-card-title-link::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
}
.mts-branch-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
    margin-bottom: 0.35rem;
}
.mts-branch-card-name {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: -0.01em;
    color: var(--mts-ink);
    flex: 1;
    min-width: 0;
    text-wrap: balance;
}
.mts-branch-card-name a { color: inherit; text-decoration: none !important; }
.mts-branch-card:hover .mts-branch-card-name a { color: var(--mts-accent); }
.mts-branch-card-badges {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.3rem;
    flex-shrink: 0;
}
.mts-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.28rem 0.65rem;
    font-size: 0.66rem;
    font-weight: 700;
    border-radius: 9999px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
}
.mts-badge-primary  { background: #fef3c7; color: #854d0e; }
.mts-badge-current  { background: var(--mts-accent); color: #fff; }
.mts-badge-distance { background: #eef2ff; color: #3730a3; }

.mts-branch-card-address {
    font-style: normal;
    margin: 1rem 0 0;
    color: var(--mts-ink-soft);
    font-size: 0.92rem;
    line-height: 1.5;
    padding-left: 1.5rem;
    background-repeat: no-repeat;
    background-position: 0 0.18rem;
    background-size: 1rem 1rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13S3 17 3 10a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E");
}

.mts-branch-card-meta {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    margin: 1.25rem 0 0;
    padding-top: 1.25rem;
    border-top: 1px solid var(--mts-line-soft);
    font-size: 0.92rem;
    position: relative;
}
.mts-branch-card-meta::before {
    content: 'Kontakt';
    position: absolute;
    top: -0.5rem;
    left: 0;
    background: var(--mts-surface);
    padding: 0 0.5rem 0 0;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--mts-ink-muted);
}
.mts-branch-card-meta dt { display: none; }
.mts-branch-card-meta dd {
    margin: 0;
    padding-left: 1.7rem;
    background-repeat: no-repeat;
    background-position: 0 50%;
    background-size: 1rem 1rem;
    line-height: 1.4;
}
.mts-branch-card-meta dt:has(+ dd:first-of-type) + dd,
.mts-branch-card-meta dd:nth-of-type(1) {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E");
}
.mts-branch-card-meta dd:nth-of-type(2) {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/%3E%3Cpolyline points='22,6 12,13 2,6'/%3E%3C/svg%3E");
}
.mts-branch-card-meta a {
    color: var(--mts-ink);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s;
    position: relative;
    z-index: 2;
}
.mts-branch-card-meta a:hover { color: var(--mts-accent); }

.mts-branch-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin: 1.25rem 0 0;
    padding-top: 1.25rem;
    border-top: 1px solid var(--mts-line-soft);
    position: relative;
}
.mts-branch-card-tags::before {
    content: 'Vor Ort';
    position: absolute;
    top: -0.5rem;
    left: 0;
    background: var(--mts-surface);
    padding: 0 0.5rem 0 0;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--mts-ink-muted);
}

.mts-branch-card-actions {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin: auto 0 0;
    padding-top: 1.5rem;
    background: transparent;
    border-top: 0;
    position: relative;
    z-index: 2;
}

/* Buttons ---------------------------------------------------------- */
.mts-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.7rem 1.1rem;
    font-size: 0.88rem;
    font-weight: 600;
    border-radius: 9999px;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.12s ease;
    text-decoration: none !important;
    line-height: 1.15;
    font-family: inherit;
    white-space: nowrap;
}
.mts-btn:active { transform: scale(0.98); }
.mts-btn-primary {
    background: linear-gradient(135deg, var(--mts-c-primary-soft) 0%, var(--mts-c-primary) 100%);
    color: var(--mts-c-primary-onbg);
    border-color: transparent;
    box-shadow: 0 1px 2px rgba(255,140,0,0.18), 0 4px 14px rgba(255,140,0,0.26);
    flex: 1 1 auto;
    min-width: 0;
    letter-spacing: 0.01em;
}
.mts-btn-primary:hover {
    background: linear-gradient(135deg, #FFA000 0%, var(--mts-c-primary-dark) 100%);
    border-color: transparent;
    color: var(--mts-c-primary-onbg);
    box-shadow: 0 4px 14px rgba(255,140,0,0.32), 0 8px 22px rgba(255,140,0,0.22);
    transform: translateY(-1px);
}
.mts-btn-current {
    background: var(--mts-c-primary-tint);
    color: var(--mts-c-primary-dark);
    border-color: var(--mts-c-primary-ring);
    cursor: default;
    flex: 1 1 auto;
    min-width: 0;
}
.mts-btn-ghost {
    background: transparent;
    color: var(--mts-ink-soft);
    border-color: var(--mts-line);
    flex: 0 0 auto;
    padding: 0.7rem 1rem;
}
.mts-btn-ghost:hover {
    background: var(--mts-surface-2);
    border-color: rgba(15,23,42,0.15);
    color: var(--mts-ink);
}

/* --- Detail-Page ------------------------------------------------------ */
.mts-breadcrumb {
    display: flex;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--mts-ink-muted);
    margin: 0 0 1.5rem;
    padding: 0;
}
.mts-breadcrumb a { color: var(--mts-ink-muted); text-decoration: none; transition: color 0.15s; }
.mts-breadcrumb a:hover { color: var(--mts-accent); }
.mts-bc-sep { opacity: 0.4; }

.mts-detail-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}
.mts-detail-badges { margin-top: 0.6rem; display: flex; gap: 0.4rem; }

.mts-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}
.mts-detail-card {
    background: var(--mts-surface);
    border: 1px solid var(--mts-line);
    border-radius: var(--mts-radius-lg);
    padding: 1.75rem 1.85rem;
    box-shadow: var(--mts-shadow-1);
    transition: box-shadow 0.22s ease, transform 0.22s ease;
}
.mts-detail-card:hover { box-shadow: var(--mts-shadow-2); transform: translateY(-2px); }
.mts-detail-card h2 {
    font-size: 0.78rem;
    font-weight: 700;
    margin: 0 0 1.1rem;
    color: var(--mts-ink-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border: 0;
    padding: 0;
}
.mts-detail-card address {
    font-style: normal;
    margin: 0 0 0.85rem;
    line-height: 1.55;
    font-size: 0.98rem;
    color: var(--mts-ink);
}
.mts-detail-card address strong { font-weight: 600; }
.mts-detail-card p { margin: 0.45rem 0; font-size: 0.95rem; color: var(--mts-ink); }
.mts-detail-card p a { color: var(--mts-ink); text-decoration: none; font-weight: 500; transition: color 0.15s; }
.mts-detail-card p a:hover { color: var(--mts-accent); }
.mts-detail-label { color: var(--mts-ink-muted); margin-right: 0.45rem; font-size: 0.85rem; }

.mts-hours-table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
.mts-hours-table th, .mts-hours-table td {
    padding: 0.6rem 0.4rem;
    text-align: left;
    border-bottom: 1px solid var(--mts-line-soft);
    font-weight: 400;
    color: var(--mts-ink);
}
.mts-hours-table th { color: var(--mts-ink-soft); }
.mts-hours-table tr:last-child th, .mts-hours-table tr:last-child td { border-bottom: 0; }
.mts-hours-table tr.is-today {
    background: linear-gradient(90deg, var(--mts-c-primary-tint), transparent);
    border-radius: var(--mts-radius-sm);
}
.mts-hours-table tr.is-today th, .mts-hours-table tr.is-today td { font-weight: 700; color: var(--mts-accent); }
.mts-hours-closed { color: var(--mts-ink-muted); font-style: italic; }
.mts-tag-cloud { display: flex; flex-wrap: wrap; gap: 0.4rem; }

@media (max-width: 720px) {
    .mts-page { margin: 1.5rem auto 3rem; padding: 0 0.75rem; }
    .mts-page-head { padding: 1.75rem 1.5rem 1.5rem; margin: 0.75rem 0 1.5rem; }
    .mts-branch-grid { grid-template-columns: 1fr; gap: 1rem; }
    .mts-branch-card-link { padding: 1.5rem 1.25rem 1rem; }
    .mts-branch-card-actions { padding: 1rem 1.25rem 1.25rem; flex-wrap: wrap; }
    .mts-branch-card-actions .mts-btn-ghost { margin-left: 0; flex: 1; }
    .mts-detail-head { flex-direction: column; align-items: flex-start; }
    .mts-modal-card { max-height: 92vh; }
}

/* --- Color-Swatch als Kreis (Phase 6, 2026-05-11) ---------------------
   Smartstore-Default rendert PVAV.Color als eckiges ".choice-box-element"
   mit Border (border-radius-md + 1px solid). Wir wollen einen randlosen
   Kreis im Apple-Style. Scope: NUR Color-Boxes (die haben inline
   background-color), Size-Boxes (Text-Pills) bleiben rechteckig.
   --------------------------------------------------------------------- */
.choice-box-element[style*="background-color"] {
    border-radius: 50% !important;
    border: 0 !important;
    box-shadow: none !important;
    width: 28px !important;
    min-width: 28px !important;
    height: 28px !important;
    line-height: 28px !important;
    padding: 0 !important;
    display: inline-block;
    vertical-align: middle;
    overflow: hidden;
    transition: transform 0.18s cubic-bezier(.22,.61,.36,1), box-shadow 0.18s ease;
}

/* Wrapper randlos + tap-target ~44x44 (Padding 8px um den 28px-Kreis).
   :has() wird von allen modernen Browsern unterstuetzt (Chrome 105+,
   Safari 15.4+, Firefox 121+). Aelterer Browser sieht den Kreis mit
   alter Wrapper-Border - akzeptabler Fallback, fault tolerant. */
.choice-box-content:has(> .choice-box-element[style*="background-color"]),
.choice-box:has(.choice-box-element[style*="background-color"]) .choice-box-label,
.choice-box:has(.choice-box-element[style*="background-color"]) .choice-box-content {
    border: 0 !important;
    background: transparent !important;
    padding: 6px !important;
    border-radius: 50% !important;
    box-shadow: none !important;
    line-height: 1 !important;
}

.choice-box:has(.choice-box-element[style*="background-color"]) {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

/* Smartstore-Default-Selected-State (.choice-box-control-native:checked + ...)
   ueberschreiben - kein gray-700-Border, kein inset-2px-white, kein heller
   Outer-Ring. Apple-Watch-Style: enger schwarzer Ring direkt am Kreis. */
.choice-box-control-native:checked + .choice-box-label .choice-box-element[style*="background-color"],
.choice-box-control-native:checked + .choice-box-content .choice-box-element[style*="background-color"],
.choice-box.selected:has(.choice-box-element[style*="background-color"]) .choice-box-element {
    box-shadow: 0 0 0 2px #000 !important;
}

/* Hover (nicht-selected): leichter Lift. */
.choice-box:has(.choice-box-element[style*="background-color"]):not(.selected):hover .choice-box-element {
    transform: scale(1.10);
}

/* Unavailable: ausgegraut + Strike (Smartstore-Default-Strike via `&:after`
   passt nicht zum Kreis - wir nutzen statt dessen Opacity + grayscale). */
.choice-box.unavailable:has(.choice-box-element[style*="background-color"]) .choice-box-element {
    filter: grayscale(0.85);
    opacity: 0.55;
}
.choice-box.unavailable:has(.choice-box-element[style*="background-color"]) .choice-box-element::after {
    display: none !important;
}

