/* Page styles extracted from views/pages/home.php. */

.home-clean {
            padding-bottom: 56px;
        }

        .hero-clean {
            padding: 34px 0 24px;
        }

        .hero-shell {
            position: relative;
            overflow: hidden;
            border-radius: 36px;
            border: 1px solid rgba(229,231,235,0.9);
            background:
                linear-gradient(135deg, rgba(255,255,255,0.96), rgba(248,250,252,0.94)),
                url('/assets/images/hero-grid-pattern.svg'),
                url('/assets/images/hero-trust-bg.svg');
            background-repeat: no-repeat, repeat, no-repeat;
            background-position: center, center, right center;
            background-size: cover, 180px, 620px;
            box-shadow: 0 24px 60px rgba(15,23,42,0.08);
            padding: 48px;
        }

        .hero-shell::before {
            content: "";
            position: absolute;
            top: -80px;
            right: -60px;
            width: 340px;
            height: 340px;
            background: radial-gradient(circle, rgba(96,165,250,0.18), transparent 66%);
            pointer-events: none;
        }

        .hero-grid {
            position: relative;
            z-index: 1;
            display: grid;
            grid-template-columns: 1.02fr 0.98fr;
            gap: 36px;
            align-items: center;
            min-width: 0;
        }

        .hero-copy,
        .hero-visual {
            min-width: 0;
        }

        .hero-copy h1 {
            font-size: clamp(1.75rem, 2.5vw, 2.45rem);
            line-height: 1.1;
            letter-spacing: -0.025em;
            font-weight: 700;
            margin-bottom: 16px;
            max-width: 680px;
        }

        .hero-copy p {
            font-size: 1.04rem;
            line-height: 1.78;
            color: var(--muted);
            max-width: 620px;
            margin-bottom: 24px;
        }

        .hero-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-bottom: 16px;
        }

        .hero-subnote {
            color: var(--muted);
            line-height: 1.7;
            font-size: 0.95rem;
        }

        .hero-trust-inline {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-top: 18px;
        }

        .hero-trust-inline span {
            display: inline-flex;
            align-items: center;
            padding: 8px 12px;
            border-radius: 999px;
            background: rgba(255,255,255,0.86);
            border: 1px solid var(--line);
            color: var(--muted);
            font-size: 0.88rem;
            font-weight: 600;
        }

        .hero-visual {
            position: relative;
            min-height: 500px;
        }

        .hero-orb {
            position: absolute;
            inset: 70px 40px auto auto;
            width: 260px;
            height: 260px;
            border-radius: 999px;
            background: radial-gradient(circle, rgba(96,165,250,0.24), rgba(96,165,250,0.06), transparent 72%);
            filter: blur(6px);
            pointer-events: none;
        }

        .hero-floating {
            position: absolute;
            border-radius: 26px;
            border: 1px solid rgba(229,231,235,0.9);
            background: rgba(255,255,255,0.94);
            box-shadow: 0 20px 40px rgba(15,23,42,0.08);
            backdrop-filter: blur(10px);
        }

        .hero-company-card {
            top: 12px;
            left: 18px;
            width: 290px;
            padding: 20px;
        }

        .hero-company-head {
            display: flex;
            gap: 14px;
            align-items: center;
            margin-bottom: 14px;
        }

        .hero-company-logo {
            width: 58px;
            height: 58px;
            border-radius: 18px;
            background: linear-gradient(135deg, #eff6ff, #dbeafe);
            display: grid;
            place-items: center;
            font-weight: 800;
            color: #1e3a8a;
            font-size: 1.2rem;
        }

        .hero-company-card h3 {
            margin: 0 0 4px;
            font-size: 1.05rem;
            letter-spacing: -0.02em;
        }

        .hero-company-meta {
            color: var(--muted);
            font-size: 0.9rem;
        }

        .hero-score-card {
            top: 78px;
            right: 8px;
            width: 220px;
            padding: 20px;
            background: linear-gradient(180deg, #0f172a, #111827);
            color: white;
            border-color: rgba(255,255,255,0.04);
            box-shadow: 0 20px 46px rgba(15,23,42,0.18);
        }

        .hero-score-card .badge-lite {
            display: inline-flex;
            align-items: center;
            padding: 6px 10px;
            border-radius: 999px;
            background: rgba(255,255,255,0.08);
            color: #bfdbfe;
            font-size: 0.8rem;
            font-weight: 700;
            margin-bottom: 12px;
        }

        .hero-score-value {
            font-size: 2.6rem;
            line-height: 1;
            font-weight: 800;
            letter-spacing: -0.05em;
            margin-bottom: 6px;
        }

        .hero-score-card .muted {
            color: #cbd5e1;
        }

        .hero-review-card {
            left: 58px;
            bottom: 54px;
            width: 320px;
            padding: 20px;
        }

        .hero-review-card h4 {
            margin: 10px 0 8px;
            font-size: 1rem;
            letter-spacing: -0.02em;
        }

        .hero-review-card p {
            color: var(--muted);
            line-height: 1.7;
            margin: 0;
        }

        .hero-widget-card {
            right: 26px;
            bottom: 4px;
            width: 250px;
            padding: 18px;
        }

        .hero-widget-badge {
            display: inline-flex;
            align-items: center;
            padding: 6px 10px;
            border-radius: 999px;
            background: #ecfdf5;
            color: #059669;
            font-size: 0.8rem;
            font-weight: 700;
            margin-bottom: 10px;
        }

        .hero-widget-name {
            font-size: 1.02rem;
            font-weight: 800;
            margin-bottom: 6px;
        }

        .hero-widget-score {
            font-size: 2rem;
            line-height: 1;
            font-weight: 800;
            letter-spacing: -0.04em;
            margin: 6px 0 4px;
        }

        .hero-mini-line {
            display: grid;
            grid-template-columns: 1fr auto;
            gap: 10px;
            align-items: center;
            margin-top: 14px;
            font-size: 0.9rem;
            color: var(--muted);
        }

        .hero-mini-bar {
            height: 8px;
            border-radius: 999px;
            background: #e5e7eb;
            overflow: hidden;
        }

        .hero-mini-bar span {
            display: block;
            width: 84%;
            height: 100%;
            border-radius: 999px;
            background: linear-gradient(90deg, #2563eb, #60a5fa);
        }

        .section-clean {
            padding: 34px 0;
        }

        .section-head-clean {
            display: flex;
            justify-content: space-between;
            align-items: end;
            gap: 20px;
            margin-bottom: 18px;
        }

        .section-head-clean h2 {
            margin-bottom: 8px;
            font-size: clamp(1.7rem, 3vw, 2.4rem);
            letter-spacing: -0.03em;
        }

        .section-head-clean p {
            color: var(--muted);
            max-width: 760px;
            line-height: 1.7;
            margin-bottom: 0;
        }

        .search-panel {
            border: 1px solid var(--line);
            border-radius: 28px;
            background: linear-gradient(180deg, #ffffff, #fbfdff);
            box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
            padding: 26px;
        }

        .search-shell-clean {
            display: grid;
            grid-template-columns: 1.2fr 0.9fr 0.9fr auto;
            gap: 12px;
        }

        .search-shell-clean input,
        .search-shell-clean select {
            width: 100%;
            padding: 14px 16px;
            border: 1px solid var(--line);
            border-radius: 16px;
            font: inherit;
            background: #fff;
            color: var(--text);
            outline: none;
        }

        .proof-strip {
            display: grid;
            grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr);
            gap: 26px;
            align-items: center;
            padding: 26px;
            border-radius: 26px;
            border: 1px solid rgba(20, 184, 166, 0.18);
            background:
                linear-gradient(135deg, rgba(255,255,255,0.96), rgba(240,253,250,0.86)),
                radial-gradient(circle at 88% 18%, rgba(37, 99, 235, 0.12), transparent 32%);
            box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
        }

        .proof-copy h2 {
            margin: 8px 0 8px;
            font-size: clamp(1.45rem, 2.2vw, 2rem);
            line-height: 1.15;
            letter-spacing: -0.02em;
        }

        .proof-copy p {
            margin: 0;
            color: var(--muted);
            line-height: 1.7;
            max-width: 660px;
        }

        .proof-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-top: 18px;
        }

        .proof-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 12px;
        }

        .proof-item {
            min-height: 118px;
            padding: 18px;
            border-radius: 20px;
            border: 1px solid rgba(148, 163, 184, 0.20);
            background: rgba(255,255,255,0.78);
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.88);
        }

        .proof-item small {
            display: block;
            color: var(--muted);
            margin-bottom: 9px;
            font-size: 0.82rem;
            font-weight: 800;
            text-transform: uppercase;
            letter-spacing: 0.04em;
        }

        .proof-item strong {
            display: block;
            font-size: 1.08rem;
            line-height: 1.25;
            letter-spacing: -0.01em;
        }

        .proof-item span {
            display: block;
            margin-top: 8px;
            color: var(--muted);
            font-size: 0.92rem;
            line-height: 1.45;
        }

        .proof-item.is-free {
            border-color: rgba(16, 185, 129, 0.34);
            background: linear-gradient(180deg, rgba(236,253,245,0.95), rgba(255,255,255,0.84));
        }

        .section-soft-panel {
            border: 1px solid var(--line);
            border-radius: 28px;
            background: linear-gradient(180deg, #ffffff, #fbfdff);
            box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
            padding: 26px;
        }

        .categories-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 18px;
        }

        .category-card {
            border: 1px solid var(--line);
            border-radius: 24px;
            padding: 22px;
            background:
                radial-gradient(circle at top right, rgba(96,165,250,0.08), transparent 30%),
                linear-gradient(180deg, #ffffff, #fbfdff);
            box-shadow: 0 12px 26px rgba(15, 23, 42, 0.04);
            transition: transform 0.18s ease, box-shadow 0.18s ease;
        }

        .category-card:hover,
        .company-card:hover,
        .review-card:hover {
            transform: translateY(-2px);
            box-shadow: 0 18px 34px rgba(15, 23, 42, 0.07);
        }

        .category-icon {
            width: 54px;
            height: 54px;
            border-radius: 18px;
            background: #eff6ff;
            display: grid;
            place-items: center;
            font-size: 1.2rem;
            margin-bottom: 14px;
        }

        .companies-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 18px;
        }

        .company-card {
            border: 1px solid var(--line);
            border-radius: 26px;
            padding: 22px;
            background: linear-gradient(180deg, #ffffff, #fbfdff);
            box-shadow: 0 12px 26px rgba(15, 23, 42, 0.04);
            transition: transform 0.18s ease, box-shadow 0.18s ease;
        }

        .company-head {
            display: flex;
            gap: 14px;
            align-items: center;
            margin-bottom: 14px;
        }

        .logo-clean {
            width: 58px;
            height: 58px;
            border-radius: 20px;
            background: linear-gradient(135deg, #eff6ff, #dbeafe);
            display: grid;
            place-items: center;
            font-weight: 800;
            color: #1e3a8a;
            box-shadow: inset 0 0 0 1px rgba(37,99,235,0.06);
        }


        /* homepage business highlight */
        .company-card.is-business {
            position: relative;
            overflow: hidden;
            border-color: rgba(217,119,6,0.38);
            background:
                linear-gradient(135deg, rgba(255,251,235,0.86), rgba(255,255,255,0.98) 40%),
                #fff;
            box-shadow: 0 22px 48px rgba(146,64,14,0.14), 0 0 0 3px rgba(217,119,6,0.08);
        }

.company-card.is-business .logo-clean {
            background: linear-gradient(135deg, #7a4f10, #d99a18 52%, #f3c451);
            color: #111827;
            box-shadow: 0 14px 28px rgba(146,64,14,0.20);
        }

        .company-card.is-business .pill {
            background: #fef3c7;
            color: #92400e;
            border: 1px solid rgba(217,119,6,0.22);
        }
        .company-rating-row {
            display: flex;
            justify-content: space-between;
            gap: 12px;
            align-items: end;
            margin-top: 16px;
        }

        .company-rating-row strong {
            font-size: 1.3rem;
            letter-spacing: -0.03em;
        }

        .reviews-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 18px;
        }

        .review-card {
            border: 1px solid var(--line);
            border-radius: 24px;
            padding: 22px;
            background: linear-gradient(180deg, #ffffff, #fbfdff);
            box-shadow: 0 12px 26px rgba(15, 23, 42, 0.04);
            transition: transform 0.18s ease, box-shadow 0.18s ease;
        }

        .review-card blockquote {
            margin: 0;
            color: #273142;
            line-height: 1.7;
        }

        .widget-feature-shell {
            border-radius: 30px;
            overflow: hidden;
            border: 1px solid var(--line);
            box-shadow: 0 18px 40px rgba(15, 23, 42, 0.07);
            background: linear-gradient(135deg, #111827, #1d4ed8 72%, #2563eb);
            color: white;
        }

        .widget-feature-grid {
            display: grid;
            grid-template-columns: 1.1fr 0.9fr;
            gap: 0;
        }

        .widget-feature-copy,
        .widget-feature-side {
            padding: 30px;
        }

        .widget-feature-copy p {
            color: rgba(255,255,255,0.86);
            line-height: 1.75;
        }

        .widget-feature-list {
            display: grid;
            gap: 10px;
            margin-top: 16px;
            color: rgba(255,255,255,0.9);
        }

        .widget-feature-side {
            background: rgba(255,255,255,0.06);
            border-left: 1px solid rgba(255,255,255,0.08);
        }

        .widget-code-box {
            background: rgba(11,18,32,0.75);
            color: #d8e1f0;
            border-radius: 20px;
            padding: 18px;
            font-size: 0.92rem;
            line-height: 1.7;
            overflow: auto;
            margin-top: 16px;
        }

        .widget-live-box {
            background: white;
            color: #111827;
            border-radius: 24px;
            padding: 20px;
            box-shadow: 0 16px 34px rgba(15, 23, 42, 0.12);
        }

        .widget-live-box .badge-lite {
            display: inline-flex;
            align-items: center;
            padding: 6px 10px;
            border-radius: 999px;
            background: #ecfdf5;
            color: #059669;
            font-size: 0.82rem;
            font-weight: 700;
            margin-bottom: 10px;
        }

        .cta-clean {
            border-radius: 32px;
            overflow: hidden;
            border: 1px solid var(--line);
            box-shadow: 0 20px 48px rgba(15, 23, 42, 0.08);
            background:
                radial-gradient(circle at top right, rgba(125,180,255,0.18), transparent 28%),
                linear-gradient(135deg, #111827, #1e3a8a 68%, #2563eb);
            color: white;
            padding: 34px;
        }

        .cta-clean p {
            color: rgba(255,255,255,0.84);
            max-width: 760px;
            line-height: 1.75;
        }

        .cta-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-top: 18px;
        }


        /* hero-trust-inline one-line */
        .hero-trust-inline {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, auto));
            justify-content: start;
            align-items: center;
            gap: 10px;
            max-width: 100%;
        }

        .hero-trust-inline span {
            white-space: nowrap;
            min-width: 0;
        }

        /* discovery subtle lift */
        .search-panel {
            box-shadow: 0 18px 42px rgba(15,23,42,0.07), inset 0 1px 0 rgba(255,255,255,0.75);
        }

        .search-panel .section-head-clean::after {
            content: "Bewertungen schneller finden";
            display: inline-flex;
            margin-top: 12px;
            padding: 6px 10px;
            border-radius: 8px;
            background: #eff6ff;
            color: #1d4ed8;
            font-size: 0.78rem;
            font-weight: 800;
        }

        .category-card {
            display: flex;
            flex-direction: column;
        }

        .category-card .card-cta {
            margin-top: auto;
            padding-top: 12px;
        }

        @media (max-width: 540px) {
            .hero-trust-inline {
                display: flex;
                flex-wrap: nowrap;
                overflow-x: auto;
                padding-bottom: 4px;
            }
        }
        @media (max-width: 1120px) {
            .hero-grid,
            .categories-grid,
            .companies-grid,
            .reviews-grid,
            .proof-strip,
            .proof-grid,
            .widget-feature-grid {
                grid-template-columns: 1fr 1fr;
            }
        }

        @media (max-width: 980px) {
            .hero-clean {
                padding-top: 22px;
            }

            .hero-shell {
                padding: 34px;
                border-radius: 28px;
                background-size: cover, 150px, 420px;
                background-position: center, center, right top;
            }

            .hero-grid {
                grid-template-columns: 1fr;
                gap: 28px;
            }

            .hero-copy h1,
            .hero-copy p {
                max-width: 720px;
            }

            .hero-actions {
                margin-bottom: 14px;
            }

            .hero-visual {
                width: min(100%, 650px);
                min-height: 420px;
                margin: 0 auto;
            }

            .hero-company-card {
                left: 0;
            }

            .hero-score-card {
                right: 0;
            }

            .hero-review-card {
                left: 24px;
                bottom: 40px;
            }

            .hero-widget-card {
                right: 0;
            }
        }

        @media (max-width: 760px) {
            .hero-grid,
            .categories-grid,
            .companies-grid,
            .reviews-grid,
            .proof-strip,
            .proof-grid,
            .widget-feature-grid,
            .search-shell-clean {
                grid-template-columns: 1fr;
            }

            .hero-shell,
            .section-soft-panel,
            .search-panel,
            .cta-clean {
                padding: 26px;
                border-radius: 22px;
            }

            .hero-visual {
                min-height: auto;
                display: grid;
                gap: 14px;
            }

            .hero-floating,
            .hero-company-card,
            .hero-score-card,
            .hero-review-card,
            .hero-widget-card {
                position: relative;
                inset: auto;
                width: 100%;
            }

            .hero-orb {
                display: none;
            }
        }

        @media (max-width: 560px) {
            .home-clean {
                padding-bottom: 34px;
            }

            .hero-clean {
                padding: 14px 0 18px;
            }

            .hero-shell {
                padding: 22px;
                border-radius: 18px;
                overflow: hidden;
            }

            .hero-grid,
            .hero-copy,
            .hero-visual,
            .hero-floating {
                max-width: 100%;
                min-width: 0;
            }

            .hero-copy h1 {
                font-size: clamp(1.55rem, 8vw, 2rem);
                line-height: 1.16;
                margin-bottom: 12px;
            }

            .hero-copy p {
                font-size: 0.98rem;
                line-height: 1.65;
                margin-bottom: 18px;
            }

            .hero-actions {
                display: grid;
                grid-template-columns: 1fr;
            }

            .hero-actions .btn {
                width: 100%;
                min-height: 44px;
                padding: 11px 12px;
                white-space: normal;
                line-height: 1.25;
                text-align: center;
            }

            .hero-subnote {
                overflow-wrap: anywhere;
            }

            .hero-trust-inline {
                display: grid;
                grid-template-columns: 1fr;
                overflow: visible;
                padding-bottom: 0;
            }

            .hero-trust-inline span {
                width: 100%;
                white-space: normal;
                line-height: 1.35;
            }

            .hero-company-head {
                align-items: flex-start;
            }

            .hero-company-head > div {
                min-width: 0;
            }

            .hero-company-card h3,
            .hero-company-meta,
            .hero-widget-name,
            .hero-review-card h4,
            .hero-review-card p {
                overflow-wrap: anywhere;
            }

            .hero-floating,
            .hero-company-card,
            .hero-score-card,
            .hero-review-card,
            .hero-widget-card {
                padding: 16px;
            }

            .hero-company-logo {
                width: 50px;
                height: 50px;
                border-radius: 14px;
            }

            .hero-score-value {
                font-size: 2.2rem;
            }

            .hero-widget-score {
                font-size: 1.7rem;
            }
        }
