/* ================================================================
   Shop – öffentliche Seiten
   Farben werden als CSS-Variablen per inline <style> gesetzt:
     --shop-color1  (Hauptfarbe / Hero)
     --shop-color2  (Navbar / Footer)
     --shop-color4  (Akzentfarbe / Buttons)
   ================================================================ */

/* ── Sticky-Footer Layout ───────────────────────────────────────── */
body { display: flex; flex-direction: column; min-height: 100vh; }
body > .container, body > .container-fluid { padding-bottom: 20px; }

/* ── Navbar: Warenkorb-Button ────────────────────────────────────── */
.shop-cart-btn { position: relative; color: rgba(255,255,255,0.85); text-decoration: none; padding: 6px 10px; border-radius: 5px; font-size: 1.1rem; transition: color 0.15s; display: inline-flex; align-items: center; }
.shop-cart-btn:hover { color: #fff; text-decoration: none; }
.shop-cart-badge { position: absolute; top: -2px; right: -4px; background: var(--shop-color4); color: #fff; font-size: 0.62rem; font-weight: 700; min-width: 16px; height: 16px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; padding: 0 3px; line-height: 1; }

/* ── detail.php: In-den-Warenkorb-Button ─────────────────────────── */
.btn-warenkorb { background: var(--shop-color4); color: #fff; border: none; border-radius: 5px; padding: 11px 20px; font-size: 0.92rem; cursor: pointer; width: 100%; display: flex; align-items: center; justify-content: center; gap: 7px; font-weight: 600; transition: opacity 0.15s; text-decoration: none; }
.btn-warenkorb:hover { opacity: 0.88; color: #fff; }
.btn-warenkorb:disabled { opacity: 0.6; cursor: not-allowed; }

/* ── warenkorb.php ───────────────────────────────────────────────── */
.wk-table { background: #fff; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); overflow: hidden; margin-bottom: 16px; }
.wk-row { display: flex; align-items: center; padding: 12px 16px; border-bottom: 1px solid #f4f4f4; gap: 12px; }
.wk-row:last-child { border-bottom: none; }
.wk-header { background: #f8f9fa; font-size: 0.75rem; font-weight: 700; color: #aaa; text-transform: uppercase; letter-spacing: 0.05em; }
.wk-einrichtung { background: #fafcfa; }
.wk-col-produkt { flex: 1 1 auto; font-size: 0.9rem; font-weight: 600; color: #333; line-height: 1.45; }
.wk-col-preis { flex: 0 0 130px; text-align: right; font-size: 0.9rem; color: #333; }
.wk-col-preis-gesamt { flex: 0 0 130px; text-align: right; font-size: 0.95rem; font-weight: 700; color: var(--shop-color4); }
.wk-col-del { flex: 0 0 38px; text-align: center; }
.wk-del-btn { background: none; border: none; color: #ccc; cursor: pointer; padding: 5px; border-radius: 4px; transition: color 0.15s; line-height: 1; }
.wk-del-btn:hover { color: #e74c3c; }
.wk-gesamt-box { background: #fff; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); padding: 18px 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.wk-gesamt-label { font-size: 0.85rem; color: #888; margin-bottom: 2px; }
.wk-gesamt-preis { font-size: 1.65rem; font-weight: 700; color: var(--shop-color4); }
@media (max-width: 600px) {
    .wk-header { display: none; }
    .wk-row { flex-wrap: wrap; }
    .wk-col-produkt { flex: 1 1 100%; }
    .wk-col-preis, .wk-col-preis-gesamt { flex: 1 1 auto; }
    .wk-col-del { flex: 0 0 38px; }
}

/* ── Länderauswahl / MwSt. ──────────────────────────────────────── */
.shop-land-select { background: rgba(255,255,255,0.12); color: #fff; border: 1px solid rgba(255,255,255,0.3); border-radius: 5px; padding: 4px 8px; font-size: 0.8rem; cursor: pointer; appearance: none; -webkit-appearance: none; }
.shop-land-select option { background: #333; color: #fff; }
.shop-land-select:focus { outline: none; border-color: rgba(255,255,255,0.6); }
.shop-land-badge { font-size: 0.78rem; color: rgba(255,255,255,0.7); white-space: nowrap; }
.shop-mwst-hinweis { font-size: 0.72rem; color: #aaa; display: block; margin-top: 2px; }

/* ── Basis ──────────────────────────────────────────────────────── */
body { font-family: 'Open Sans', sans-serif; background: #f4f7fa; min-height: 100vh; display: flex; flex-direction: column; }

/* ── Navbar ─────────────────────────────────────────────────────── */
.shop-navbar { background: var(--shop-color2); padding: 0; }
.shop-navbar img { max-height: 38px; }
.shop-nav-logo { display: flex; align-items: center; text-decoration: none; padding: 10px 0; flex-shrink: 0; }
.shop-nav-logo span { color: #fff; font-size: 1.1rem; font-weight: 600; }
.shop-nav-links { display: flex; align-items: stretch; margin-left: 8px; }
.shop-nav-link { color: rgba(255,255,255,0.72); text-decoration: none; padding: 0 14px; font-size: 0.87rem; display: flex; align-items: center; gap: 5px; border-bottom: 3px solid transparent; transition: color 0.15s, border-bottom-color 0.15s; min-height: 58px; white-space: nowrap; }
.shop-nav-link:hover { color: #fff; text-decoration: none; border-bottom-color: rgba(255,255,255,0.35); }
.shop-nav-link.active { color: #fff; font-weight: 600; border-bottom-color: rgba(255,255,255,0.9); }
.shop-burger { display: none; background: none; border: none; color: #fff; cursor: pointer; padding: 8px 6px; margin-left: 8px; line-height: 1; font-size: 1.3rem; }
.shop-burger:focus { outline: none; }
@media (max-width: 768px) {
    .shop-navbar { position: relative; }
    .shop-nav-links { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; background: var(--shop-color2); padding: 6px 0; z-index: 999; box-shadow: 0 4px 12px rgba(0,0,0,0.18); margin-left: 0; }
    .shop-nav-links.open { display: flex; }
    .shop-nav-link { min-height: 46px; padding: 0 20px; border-bottom: none !important; border-left: 3px solid transparent; font-size: 0.95rem; }
    .shop-nav-link:hover { border-left-color: rgba(255,255,255,0.35); }
    .shop-nav-link.active { border-left-color: rgba(255,255,255,0.9); }
    .shop-burger { display: flex; align-items: center; }
}

/* ── Hero ───────────────────────────────────────────────────────── */
.shop-hero { background: linear-gradient(135deg, var(--shop-color1) 0%, color-mix(in srgb, var(--shop-color1) 70%, #000) 100%); color: #fff; padding: 50px 0 40px; }
.shop-hero h1 { font-size: 1.8rem; font-weight: 700; margin-bottom: 6px; }
.shop-hero p { opacity: 0.85; margin: 0; }
.shop-hero .breadcrumb-item a { color: rgba(255,255,255,0.75); }
.shop-hero .breadcrumb-item.active { color: rgba(255,255,255,0.95); }
.shop-hero .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.5); }

/* ── Footer ─────────────────────────────────────────────────────── */
.shop-footer { background: var(--shop-color2); color: rgba(255,255,255,0.6); padding: 30px 0 20px; font-size: 0.8rem; margin-top: auto; }
.shop-footer a { color: rgba(255,255,255,0.7); }
.shop-footer a:hover { color: #fff; }

/* ── Buttons ────────────────────────────────────────────────────── */
.btn-detail { background: var(--shop-color4); color: #fff; border: none; border-radius: 5px; padding: 8px 18px; font-size: 0.85rem; text-decoration: none; display: inline-block; }
.btn-detail:hover { opacity: 0.88; color: #fff; text-decoration: none; }
.btn-vergleich { background: transparent; color: var(--shop-color4); border: 1px solid var(--shop-color4); border-radius: 5px; padding: 7px 14px; font-size: 0.82rem; text-decoration: none; display: inline-block; }
.btn-vergleich:hover { background: var(--shop-color4); color: #fff; text-decoration: none; }
.btn-back { background: transparent; color: var(--shop-color4); border: 1px solid var(--shop-color4); border-radius: 5px; padding: 8px 18px; font-size: 0.85rem; text-decoration: none; display: inline-block; }
.btn-back:hover { background: var(--shop-color4); color: #fff; text-decoration: none; }

/* ── index.php: Gruppennavigation ───────────────────────────────── */
.gruppe-nav { background: #fff; border-bottom: 1px solid #e0e0e0; padding: 0; }
.gruppe-nav .nav-link { color: #555; padding: 14px 20px; font-size: 0.9rem; border-bottom: 3px solid transparent; }
.gruppe-nav .nav-link:hover,
.gruppe-nav .nav-link.active { color: var(--shop-color4); border-bottom-color: var(--shop-color4); }

/* ── index.php: Gruppen-Kacheln ─────────────────────────────────── */
.gruppe-card { background: #fff; border: 1px solid #e8eaee; border-radius: 10px; box-shadow: 0 2px 10px rgba(0,0,0,0.07); padding: 32px 24px; text-align: center; text-decoration: none; display: block; color: inherit; transition: box-shadow 0.18s, border-color 0.18s, transform 0.18s; height: 100%; }
.gruppe-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.1); border-color: var(--shop-color1); transform: translateY(-2px); text-decoration: none; color: inherit; }
.gruppe-card .gruppe-icon { width: 56px; height: 56px; border-radius: 50%; background: color-mix(in srgb, var(--shop-color4) 13%, transparent); display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; }
.gruppe-card .gruppe-icon i { font-size: 1.5rem; color: var(--shop-color4); }
.gruppe-card .gruppe-name { font-size: 1.1rem; font-weight: 700; color: var(--shop-color1); margin-bottom: 8px; }
.gruppe-card .gruppe-desc { font-size: 0.85rem; color: #888; }
.gruppe-card .gruppe-arrow { color: var(--shop-color4); margin-top: 16px; font-size: 0.85rem; }

/* ── index.php: Produkt-Karten ───────────────────────────────────── */
.produkt-card { background: #fff; border: 1px solid #e8eaee; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); padding: 22px; height: 100%; display: flex; flex-direction: column; position: relative; transition: box-shadow 0.18s, border-color 0.18s, transform 0.18s; }
.produkt-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.1); border-color: var(--shop-color1); transform: translateY(-2px); }
.produkt-card.empfohlen { border: 2px solid var(--shop-color4); }
.produkt-card.empfohlen:hover { border-color: var(--shop-color4); }
.produkt-card.aktion { border: 2px solid #e74c3c; }
.produkt-card.aktion:hover { border-color: #e74c3c; }
.badge-empfohlen { position: absolute; top: -1px; right: 16px; background: var(--shop-color4); color: #fff; font-size: 0.72rem; padding: 3px 10px; border-radius: 0 0 6px 6px; font-weight: 600; letter-spacing: 0.03em; }
.badge-aktion { position: absolute; top: -1px; right: 16px; background: #e74c3c; color: #fff; font-size: 0.72rem; padding: 3px 10px; border-radius: 0 0 6px 6px; font-weight: 600; letter-spacing: 0.03em; }
.badge-neu { position: absolute; top: 12px; left: 12px; background: #28a745; color: #fff; font-size: 0.7rem; padding: 2px 8px; border-radius: 4px; }
.produkt-name { font-size: 1.15rem; font-weight: 700; color: var(--shop-color1); line-height: 1.3; background: #f0f2f5; border-radius: 6px; padding: 8px 10px; margin: -4px -4px 12px; }
.produkt-kurzbeschreibung { color: #777; font-size: 0.83rem; margin-bottom: 14px; flex-grow: 1; }
.varianten-hinweis { font-size: 0.78rem; color: #888; margin-top: 8px; display: flex; align-items: center; gap: 4px; }
.produkt-preis { font-size: 1.5rem; font-weight: 700; color: var(--shop-color4); line-height: 1.1; }
.produkt-preis .aktionspreis { font-size: 1.15rem; color: #e74c3c; font-weight: 700; }
.produkt-preis .preis-original { text-decoration: line-through; color: #aaa; font-size: 0.8rem; font-weight: normal; }
.produkt-preis small { font-size: 0.72rem; color: #999; font-weight: normal; }
.feature-list { list-style: none; padding: 0; margin: 0 0 14px; border-top: 1px solid #f0f0f0; padding-top: 12px; }
.feature-list li { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; border-bottom: 1px solid #f8f8f8; font-size: 0.82rem; }
.feature-list li:last-child { border-bottom: none; }
.feature-list .feat-name { color: #666; }
.feature-list .feat-val { font-weight: 600; color: #333; text-align: right; margin-left: 8px; }
.no-produkte { color: #999; font-style: italic; }

/* ── detail.php: Preis-Box ───────────────────────────────────────── */
.preis-box { background: #fff; border-radius: 8px; padding: 20px 24px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); margin-bottom: 24px; }
.preis-box .preis-wert { font-size: 2rem; font-weight: 700; color: var(--shop-color4); }
.preis-box .preis-sub { color: #888; font-size: 0.85rem; }

/* ── detail.php: Inhalts-Karten ─────────────────────────────────── */
.card-section { background: #fff; border-radius: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); margin-bottom: 24px; overflow: hidden; }
.card-section .card-section-header { background: var(--shop-color1); color: #fff; padding: 12px 20px; font-weight: 600; font-size: 0.95rem; }
.card-section .card-section-body { padding: 0; }
.kat-label { background: #f8f9fa; padding: 8px 20px 6px; font-size: 0.78rem; font-weight: 700; color: #999; text-transform: uppercase; letter-spacing: 0.05em; border-bottom: 1px solid #eee; }
.feat-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 20px; border-bottom: 1px solid #f4f4f4; font-size: 0.87rem; }
.feat-row:last-child { border-bottom: none; }
.feat-row .feat-name { color: #555; }
.feat-row .feat-name small { display: block; color: #aaa; font-size: 0.75rem; }
.feat-row .feat-val { font-weight: 600; color: #333; text-align: right; }
.feat-row .feat-val a { color: var(--shop-color4); text-decoration: none; }
.feat-row .feat-val a:hover { text-decoration: underline; }
table.vergleich-table td.feat-val-col a { color: var(--shop-color4); text-decoration: none; }
table.vergleich-table td.feat-val-col a:hover { text-decoration: underline; }

/* ── detail.php: Varianten-Kacheln ──────────────────────────────── */
.varianten-kacheln { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 20px; }
.variante-kachel { border: 2px solid #e0e0e0; border-radius: 8px; padding: 12px 18px; cursor: pointer; background: #fff; transition: border-color 0.15s, box-shadow 0.15s; min-width: 120px; text-align: center; user-select: none; text-decoration: none; display: inline-block; }
.variante-kachel:hover { border-color: var(--shop-color4); box-shadow: 0 2px 8px rgba(0,0,0,0.08); }
.variante-kachel.aktiv { border-color: var(--shop-color4); background: color-mix(in srgb, var(--shop-color4) 7%, #fff); box-shadow: 0 2px 10px rgba(0,0,0,0.1); }
.variante-kachel .vk-name { font-weight: 700; font-size: 0.95rem; color: #333; }
.variante-kachel.aktiv .vk-name { color: var(--shop-color4); }
.variante-kachel .vk-preis { font-size: 1rem; font-weight: 700; color: var(--shop-color4); margin-top: 4px; }
.variante-kachel .vk-preis-aktions { color: #e74c3c; }
.variante-kachel .vk-preis-original { text-decoration: line-through; color: #aaa; font-size: 0.78rem; font-weight: normal; }
.variante-kachel .vk-ab { font-size: 0.72rem; color: #999; }

/* ── detail.php: Zusatzprodukte ─────────────────────────────────── */
.zusatz-card { background: #f8f9fa; border: 1px solid #e8e8e8; border-radius: 6px; padding: 14px 18px; display: flex; justify-content: space-between; align-items: center; }
.zusatz-card .zusatz-name { font-weight: 600; color: #333; }
.zusatz-card .zusatz-preis { color: var(--shop-color4); font-weight: 700; }

/* ── vergleich.php ───────────────────────────────────────────────── */
.vergleich-wrap { overflow-x: auto; margin-top: 24px; }
table.vergleich-table { border-collapse: separate; border-spacing: 0; width: 100%; min-width: 600px; }
table.vergleich-table th.produkt-col { background: #fff; border-top: 3px solid #e0e0e0; border-left: 1px solid #e8e8e8; border-right: 1px solid #e8e8e8; padding: 20px 16px 16px; text-align: center; vertical-align: top; }
table.vergleich-table th.produkt-col.empfohlen { border-top-color: var(--shop-color4); }
table.vergleich-table th.produkt-col.aktion { border-top-color: #e74c3c; }
.produkt-kopf-name { font-size: 1rem; font-weight: 700; color: var(--shop-color1); margin-bottom: 6px; }
.produkt-kopf-kurz { font-size: 0.8rem; color: #888; margin-bottom: 12px; }
.produkt-kopf-preis { font-size: 1.3rem; font-weight: 700; color: var(--shop-color4); }
.produkt-kopf-preis small { font-size: 0.7rem; color: #aaa; font-weight: normal; }
.produkt-kopf-aktionspreis { color: #e74c3c; }
.produkt-kopf-original { text-decoration: line-through; color: #bbb; font-size: 0.85rem; font-weight: normal; }
.badge-empfohlen-kopf { background: var(--shop-color4); color: #fff; font-size: 0.7rem; padding: 2px 10px; border-radius: 20px; display: inline-block; margin-bottom: 8px; }
.badge-aktion-kopf { background: #e74c3c; color: #fff; font-size: 0.7rem; padding: 2px 10px; border-radius: 20px; display: inline-block; margin-bottom: 8px; }
.badge-aktion-hero { background: #e74c3c; color: #fff; font-size: 0.72rem; padding: 3px 12px; border-radius: 20px; display: inline-block; vertical-align: middle; margin-left: 10px; font-weight: 600; letter-spacing: 0.03em; }
/* ── Info-Icon Popover (feat-Beschreibungen) ─────────────────────── */
.feat-info-icon { display: inline-flex; align-items: center; color: #bbb; cursor: pointer; position: relative; margin-left: 5px; vertical-align: middle; }
.feat-info-icon svg, .feat-info-icon i { width: 14px; height: 14px; font-size: 13px; line-height: 1; }

table.vergleich-table td.feat-label-col { background: #f8f9fa; font-size: 0.83rem; color: #555; padding: 9px 14px; border-bottom: 1px solid #f0f0f0; white-space: nowrap; width: 20%; font-weight: 500; }
table.vergleich-table td.feat-val-col { background: #fff; text-align: center; padding: 9px 12px; font-size: 0.87rem; font-weight: 600; color: #333; border-bottom: 1px solid #f4f4f4; border-left: 1px solid #f0f0f0; border-right: 1px solid #f0f0f0; }
table.vergleich-table tr.kat-row td { background: color-mix(in srgb, var(--shop-color1) 8%, transparent); color: var(--shop-color1); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; padding: 8px 14px; border-top: 2px solid #e8e8e8; }
table.vergleich-table td.btn-col { background: #fff; padding: 16px 12px; text-align: center; border-left: 1px solid #e8e8e8; border-right: 1px solid #e8e8e8; border-bottom: 1px solid #e8e8e8; border-bottom-left-radius: 6px; border-bottom-right-radius: 6px; }

/* ── domains.php: Domain-Hero ───────────────────────────────── */
.domain-hero { background: linear-gradient(135deg, var(--shop-color1) 0%, color-mix(in srgb, var(--shop-color1) 70%, #000) 100%); color: #fff; padding: 60px 0 50px; text-align: center; }
.domain-hero h1 { font-size: 2.2rem; font-weight: 800; margin-bottom: 8px; }
.domain-hero p { font-size: 1rem; opacity: 0.85; margin-bottom: 30px; }
.domain-hero .breadcrumb-item a { color: rgba(255,255,255,0.75); }
.domain-hero .breadcrumb-item.active { color: rgba(255,255,255,0.95); }
.domain-hero .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.5); }

/* ── domains.php: Suchfeld ──────────────────────────────────── */
.domain-search-wrap { max-width: 660px; margin: 0 auto; position: relative; }
.domain-search-form { display: flex; box-shadow: 0 6px 30px rgba(0,0,0,0.25); border-radius: 50px; overflow: hidden; }
.domain-search-prefix { background: #fff; color: #aaa; padding: 0 0 0 22px; display: flex; align-items: center; font-size: 1.1rem; border-right: none; white-space: nowrap; }
.domain-search-input { flex: 1; border: none; padding: 16px 8px 16px 4px; font-size: 1.15rem; background: #fff; outline: none; color: #333; min-width: 0; }
.domain-search-input::placeholder { color: #bbb; }
.domain-search-btn { background: var(--shop-color4); color: #fff; border: none; padding: 16px 30px; font-size: 1rem; font-weight: 700; cursor: pointer; white-space: nowrap; transition: opacity 0.15s; letter-spacing: 0.02em; }
.domain-search-btn:hover { opacity: 0.88; }
.domain-search-hint { margin-top: 12px; font-size: 0.82rem; opacity: 0.7; }
.domain-search-hint span { background: rgba(255,255,255,0.15); border-radius: 4px; padding: 2px 8px; margin: 0 3px; }

/* ── domains.php: Suchergebnisse ────────────────────────────── */
#domain-results { display: none; }
.results-section { background: #fff; border-bottom: 1px solid #e8e8e8; padding: 24px 0 30px; }
.results-header { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; margin-bottom: 16px; }
.results-title { font-size: 0.8rem; font-weight: 700; color: #aaa; text-transform: uppercase; letter-spacing: 0.06em; flex: 1 1 auto; margin: 0; }
.results-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.result-filter-btn { padding: 4px 14px; border-radius: 20px; border: 1.5px solid #ddd; background: #fff; color: #555; font-size: 0.78rem; font-weight: 600; cursor: pointer; transition: all 0.15s; }
.result-filter-btn:hover { border-color: var(--shop-color4); color: var(--shop-color4); }
.result-filter-btn.active { background: var(--shop-color4); border-color: var(--shop-color4); color: #fff; }
.result-list { display: flex; flex-direction: column; gap: 8px; }
.result-card { border-radius: 8px; padding: 14px 18px; border: 2px solid #e8e8e8; background: #fff; display: flex; align-items: center; gap: 16px; transition: box-shadow 0.15s; }
.result-card.avail { border-color: #28a745; }
.result-card.unavail { border-color: #f0a500; background: #fffbf0; }
.result-card.typed { box-shadow: 0 2px 12px rgba(0,0,0,0.09); }
.result-card.typed.avail { border-color: var(--shop-color4); }
.result-card.hidden-filter { display: none; }
.result-icon { flex: 0 0 32px; text-align: center; font-size: 1.3rem; }
.result-icon.ok { color: #28a745; }
.result-icon.ko { color: #f0a500; }
.result-main { flex: 1 1 auto; min-width: 0; }
.result-domain { font-size: 1.05rem; font-weight: 700; color: #222; word-break: break-all; line-height: 1.2; }
.result-domain .result-sld { color: #555; }
.result-domain .result-tld { color: var(--shop-color4); }
.result-domain .result-tld.unavail-tld { color: #f0a500; }
.result-status-text { font-size: 0.78rem; color: #aaa; margin-top: 2px; }
.result-status-text.ok { color: #28a745; }
.result-badges { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 5px; }
.result-badge { font-size: 0.65rem; padding: 2px 6px; border-radius: 4px; font-weight: 600; }
.result-badge.top { background: #fff3cd; color: #856404; }
.result-badge.neu { background: #d4edda; color: #155724; }
.result-badge.privacy { background: #d1ecf1; color: #0c5460; }
.result-badge.dnssec { background: #e2d9f3; color: #4a235a; }
.result-badge.trustee { background: #f8d7da; color: #721c24; }
.result-preis-col { flex: 0 0 auto; text-align: right; min-width: 120px; }
.result-preis { font-size: 1.25rem; font-weight: 700; color: var(--shop-color4); line-height: 1.1; }
.result-preis-mwst { font-size: 0.68rem; color: #aaa; }
.result-preis-verl { font-size: 0.75rem; color: #999; margin-top: 2px; }
.result-preis-alt-line { font-size: 0.75rem; text-decoration: line-through; color: #ccc; }
.result-btn-col { flex: 0 0 auto; }
.result-btn { background: var(--shop-color4); color: #fff; border: none; border-radius: 6px; padding: 9px 16px; font-size: 0.82rem; font-weight: 600; text-align: center; cursor: pointer; text-decoration: none; transition: opacity 0.15s; white-space: nowrap; display: inline-block; }
.result-btn:hover { opacity: 0.88; color: #fff; text-decoration: none; }
.result-card.unavail .result-btn { background: var(--shop-color1); }

/* ── domains.php: Spinner & Error ───────────────────────────── */
.domain-spinner { display: none; text-align: center; padding: 40px 0; }
.domain-spinner .spinner-border { color: var(--shop-color4); width: 2.5rem; height: 2.5rem; }
.domain-spinner p { color: #888; margin-top: 14px; font-size: 0.9rem; }
.domain-error { display: none; background: #fef0f0; border: 1px solid #f5c6cb; border-radius: 8px; padding: 14px 20px; color: #721c24; margin: 20px 0; font-size: 0.9rem; }

/* ── domains.php: TLD-Übersicht ─────────────────────────────── */
.tld-section { padding: 36px 0 50px; }
.tld-section-title { font-size: 1.2rem; font-weight: 700; color: #333; margin-bottom: 6px; }
.tld-section-sub { color: #888; font-size: 0.88rem; margin-bottom: 24px; }
.tld-type-filters { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.tld-type-btn { padding: 6px 16px; border-radius: 20px; border: 1.5px solid #ddd; background: #fff; color: #555; font-size: 0.82rem; font-weight: 600; cursor: pointer; transition: all 0.15s; }
.tld-type-btn:hover { border-color: var(--shop-color1); color: var(--shop-color1); }
.tld-type-btn.active { background: var(--shop-color1); border-color: var(--shop-color1); color: #fff; }
.region-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 24px; }
.region-tab { padding: 6px 16px; border-radius: 20px; border: 1.5px solid #ddd; background: #fff; color: #555; font-size: 0.82rem; font-weight: 600; cursor: pointer; transition: all 0.15s; }
.region-tab:hover { border-color: var(--shop-color4); color: var(--shop-color4); }
.region-tab.active { background: var(--shop-color4); border-color: var(--shop-color4); color: #fff; }
.tld-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px; }
.tld-card { background: #fff; border-radius: 8px; border: 1.5px solid #e8e8e8; padding: 14px 14px 12px; cursor: pointer; transition: border-color 0.15s, box-shadow 0.15s, transform 0.1s; position: relative; }
.tld-card:hover { border-color: var(--shop-color4); box-shadow: 0 3px 12px rgba(0,0,0,0.09); transform: translateY(-1px); }
.tld-card.top-tld { border-color: color-mix(in srgb, var(--shop-color4) 40%, #e8e8e8); }
.tld-card .tld-name { font-size: 1.25rem; font-weight: 800; color: var(--shop-color1); margin-bottom: 2px; }
.tld-card .tld-preis { font-size: 0.9rem; font-weight: 700; color: var(--shop-color4); }
.tld-card .tld-preis small { font-weight: 400; color: #aaa; font-size: 0.72rem; }
.tld-card .tld-preis-alt { font-size: 0.72rem; text-decoration: line-through; color: #ccc; }
.tld-card .tld-badges { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 6px; }
.tld-card .tld-badge { font-size: 0.62rem; padding: 1px 5px; border-radius: 3px; font-weight: 700; }
.tld-card .tld-badge-top { background: #fff3cd; color: #856404; }
.tld-card .tld-badge-neu { background: #d4edda; color: #155724; }
.tld-card .tld-badge-priv { background: #d1ecf1; color: #0c5460; }
.tld-card .tld-badge-dns { background: #e2d9f3; color: #4a235a; }

/* ── domains.php: Responsive ────────────────────────────────── */
@media (max-width: 576px) {
    .domain-hero h1 { font-size: 1.5rem; }
    .domain-search-prefix { font-size: 0.95rem; padding-left: 14px; }
    .domain-search-input { font-size: 1rem; }
    .domain-search-btn { padding: 16px 16px; font-size: 0.9rem; }
    .result-card { flex-wrap: wrap; }
    .result-preis-col { min-width: 0; }
    .result-list { gap: 6px; }
    .tld-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }
}
