/* ==========================================================================
   Locedo 2026 – Frontend-Stylesheet (mobile-first, ohne Build-Step)
   Shop-Themefarben (--c-primary/--c-accent …) werden in base.html.twig
   pro Shop injiziert und überschreiben die Defaults hier.
   ========================================================================== */
:root {
    /* Markenfarben (per Shop überschreibbar) */
    --c-primary: #0a6cff;
    --c-primary-dark: #0850c4;
    --c-accent: #10b981;
    --c-accent-dark: #0c8f66;

    /* Neutrale Palette */
    --c-text: #14181f;
    --c-muted: #667085;
    --c-border: #e7e9ee;
    --c-bg: #f4f6f9;        /* Seitenhintergrund */
    --c-surface: #ffffff;   /* Karten/Header */
    --c-soft: #eef1f5;      /* Bildflächen */

    /* Form */
    --radius: 14px;
    --radius-sm: 9px;
    --radius-pill: 999px;
    --shadow-sm: 0 1px 2px rgba(16,24,40,.06), 0 1px 3px rgba(16,24,40,.05);
    --shadow: 0 6px 20px rgba(16,24,40,.08);
    --shadow-lg: 0 16px 40px rgba(16,24,40,.14);
    --maxw: 1240px;
    --ring: 0 0 0 3px color-mix(in srgb, var(--c-primary) 30%, transparent);

    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color-scheme: light;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    color: var(--c-text);
    background: var(--c-bg);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
a { color: var(--c-primary); text-decoration: none; transition: color .15s; }
a:hover { color: var(--c-primary-dark); }
img { max-width: 100%; height: auto; }
h1, h2, h3 { line-height: 1.2; letter-spacing: -.012em; }
h1 { font-size: clamp(1.6rem, 1.1rem + 2.2vw, 2.4rem); font-weight: 800; }
h2 { font-size: clamp(1.25rem, 1rem + 1vw, 1.6rem); font-weight: 750; }
:focus-visible { outline: none; box-shadow: var(--ring); border-radius: 6px; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 1.1rem; }
.muted { color: var(--c-muted); }
.empty { padding: 3rem 1rem; color: var(--c-muted); text-align: center; background: var(--c-surface);
    border: 1px dashed var(--c-border); border-radius: var(--radius); }

/* ---------------- Header ---------------- */
.site-header {
    background: var(--c-surface); /* Fallback */
    background: color-mix(in srgb, var(--c-surface) 88%, transparent);
    backdrop-filter: saturate(140%) blur(10px);
    border-bottom: 1px solid var(--c-border);
    position: sticky; top: 0; z-index: 50;
}
.header-inner { display: flex; align-items: center; gap: 1.2rem; padding: .85rem 1.1rem; flex-wrap: wrap; }
.logo { display: inline-flex; align-items: center; }
.logo img { max-height: 42px; width: auto; display: block; }
.logo-text {
    font-weight: 850; font-size: 1.5rem; letter-spacing: -.03em;
    background: linear-gradient(90deg, var(--c-primary), var(--c-accent));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.searchbar { display: flex; flex: 1 1 320px; box-shadow: var(--shadow-sm); border-radius: var(--radius-pill); }
.searchbar input {
    flex: 1; padding: .7rem 1.1rem; border: 1px solid var(--c-border); border-right: 0;
    border-radius: var(--radius-pill) 0 0 var(--radius-pill); font-size: 1rem; background: var(--c-surface);
}
.searchbar input:focus { outline: none; box-shadow: none; }
.searchbar:focus-within { box-shadow: var(--ring); }
.searchbar button {
    padding: .7rem 1.4rem; border: 0; background: var(--c-primary); color: #fff; font-weight: 650;
    border-radius: 0 var(--radius-pill) var(--radius-pill) 0; cursor: pointer; transition: background .15s;
}
.searchbar button:hover { background: var(--c-primary-dark); }
.main-nav { display: flex; gap: 1rem; }
.main-nav a { font-weight: 650; color: var(--c-text); }
.main-nav a:hover { color: var(--c-primary); }

/* Burger-Button (auf allen Viewports, mit Label) */
.nav-burger { display: inline-flex; align-items: center; gap: .55rem; padding: .55rem .9rem; flex: 0 0 auto;
    border: 1px solid var(--c-border); border-radius: var(--radius-pill); background: var(--c-surface);
    cursor: pointer; font: inherit; font-weight: 650; color: var(--c-text); transition: .14s; }
.nav-burger:hover { border-color: var(--c-primary); color: var(--c-primary); box-shadow: var(--shadow-sm); }
.nav-burger__icon { display: flex; flex-direction: column; gap: 3px; width: 18px; }
.nav-burger__icon span { display: block; height: 2px; background: currentColor; border-radius: 2px; }

/* Off-Canvas-Seitenmenü */
.menu-overlay { position: fixed; inset: 0; background: rgba(16,24,40,.45); opacity: 0; visibility: hidden;
    transition: .2s; z-index: 90; }
.side-menu { position: fixed; top: 0; left: 0; height: 100%; width: min(420px, 92vw); background: var(--c-surface);
    z-index: 95; transform: translateX(-100%); transition: transform .28s cubic-bezier(.4,0,.2,1); box-shadow: var(--shadow-lg);
    display: flex; flex-direction: column; }
body.menu-open .menu-overlay { opacity: 1; visibility: visible; }
body.menu-open .side-menu { transform: translateX(0); }
body.menu-open { overflow: hidden; }
.side-menu__head { display: flex; justify-content: space-between; align-items: center; padding: 1.2rem 1.4rem;
    border-bottom: 1px solid var(--c-border); font-weight: 800; font-size: 1.15rem;
    background: linear-gradient(135deg, color-mix(in srgb, var(--c-primary) 10%, var(--c-surface)), var(--c-surface)); }
.side-menu__close { background: var(--c-soft); border: 0; width: 34px; height: 34px; border-radius: 50%;
    font-size: 1.1rem; cursor: pointer; color: var(--c-muted); transition: .14s; }
.side-menu__close:hover { background: var(--c-border); color: var(--c-text); }
.side-menu__body { overflow-y: auto; padding: .6rem .7rem 2.5rem; }

.catmenu { list-style: none; margin: 0; padding: 0; }
.catmenu .catmenu { display: none; margin: .1rem 0 .3rem .35rem; padding-left: .65rem; border-left: 2px solid var(--c-border); }
.catmenu__item.is-open > .catmenu { display: block; }
.catmenu__row { display: flex; align-items: center; gap: .3rem; }
.catmenu__row > a { flex: 1 1 auto; display: block; padding: .7rem .9rem; border-radius: var(--radius-sm);
    color: var(--c-text); font-weight: 600; }
.catmenu__row > a:hover { background: var(--c-soft); color: var(--c-primary); }
/* Unterebenen etwas kleiner/leichter */
.catmenu .catmenu .catmenu__row > a { font-weight: 500; font-size: .92rem; padding-top: .5rem; padding-bottom: .5rem; }
.catmenu__toggle { flex: 0 0 auto; display: grid; place-items: center; width: 36px; height: 36px;
    border: 1px solid var(--c-border); background: var(--c-surface); font-size: 1.3rem; color: var(--c-muted);
    cursor: pointer; line-height: 1; border-radius: var(--radius-sm); transition: border-color .18s, color .18s; }
.catmenu__toggle:hover { border-color: var(--c-primary); color: var(--c-primary); }
/* Nur das +-Zeichen dreht sich zu × – nicht der ganze Button */
.catmenu__toggle span { display: block; line-height: 1; transition: transform .18s ease; }
.catmenu__item.is-open > .catmenu__row > .catmenu__toggle { color: var(--c-primary); border-color: var(--c-primary); }
.catmenu__item.is-open > .catmenu__row > .catmenu__toggle span { transform: rotate(45deg); }

/* Kategorie-Kacheln (Startseite) */
.cat-tiles-section { margin: 2.4rem 0; }
.cat-tiles-section > h2 { margin: 0 0 1rem; }
.cat-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 1rem; }
.cat-tile { display: flex; flex-direction: column; align-items: center; gap: .7rem; padding: 1.2rem .8rem;
    background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius); text-align: center;
    color: var(--c-text); transition: .14s; }
.cat-tile:hover { box-shadow: var(--shadow); transform: translateY(-3px); color: var(--c-primary); }
.cat-tile__media { width: 70px; height: 70px; border-radius: 50%; background: var(--c-soft); display: grid;
    place-items: center; overflow: hidden; }
.cat-tile__media img { width: 100%; height: 100%; object-fit: cover; }
.cat-tile__initial { font-size: 1.7rem; font-weight: 800; color: var(--c-primary); }
.cat-tile__title { font-size: .9rem; font-weight: 600; }

/* Hero-Suche */
.hero-search { display: flex; gap: .5rem; margin: 1.4rem 0 .2rem; max-width: 540px; }
.hero-search input { flex: 1; padding: .8rem 1.1rem; border: 1px solid var(--c-border); border-radius: var(--radius-pill);
    font-size: 1rem; background: var(--c-surface); }
.hero-search input:focus { outline: none; box-shadow: var(--ring); }
.hero-search .btn { padding-inline: 1.6rem; }

/* ---------------- Buttons ---------------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
    padding: .62rem 1.15rem; border-radius: var(--radius-pill); font-weight: 650;
    cursor: pointer; border: 1px solid var(--c-border); background: var(--c-surface); color: var(--c-text);
    transition: transform .08s, box-shadow .15s, background .15s; white-space: nowrap;
}
.btn:hover { box-shadow: var(--shadow-sm); }
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--c-primary); color: #fff; border-color: transparent; }
.btn--primary:hover { background: var(--c-primary-dark); color: #fff; box-shadow: var(--shadow); }

/* ---------------- Hero ---------------- */
.hero {
    margin: 1.4rem 0 1.8rem; padding: clamp(2rem, 5vw, 3.4rem) clamp(1.2rem, 4vw, 3rem);
    border-radius: calc(var(--radius) + 6px);
    background: var(--c-surface); /* Fallback */
    background:
        radial-gradient(1200px 300px at 100% -20%, color-mix(in srgb, var(--c-accent) 18%, transparent), transparent),
        linear-gradient(135deg, color-mix(in srgb, var(--c-primary) 12%, var(--c-surface)), var(--c-surface));
    border: 1px solid var(--c-border);
}
.hero h1 { margin: 0 0 .5rem; max-width: 18ch; }
.hero p { color: var(--c-muted); font-size: clamp(1rem, .9rem + .4vw, 1.18rem); margin: 0; max-width: 52ch; }
.hero-points { list-style: none; display: flex; flex-wrap: wrap; gap: 1.2rem; margin: 1.4rem 0 0; padding: 0;
    font-size: .92rem; font-weight: 600; color: var(--c-text); }
.hero-points li { display: inline-flex; align-items: center; gap: .45rem; }
.hero-points li::before { content: "✓"; display: grid; place-items: center; width: 22px; height: 22px;
    border-radius: 50%; background: color-mix(in srgb, var(--c-accent) 18%, transparent); color: var(--c-accent-dark);
    font-size: .8rem; font-weight: 800; }

/* ---------------- Breadcrumb ---------------- */
.breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; gap: .45rem; padding: 1rem 0 .4rem; margin: 0; font-size: .88rem; color: var(--c-muted); }
.breadcrumb a { color: var(--c-muted); }
.breadcrumb a:hover { color: var(--c-primary); }
.breadcrumb li:not(:last-child)::after { content: "›"; margin-left: .45rem; color: var(--c-border); }
.breadcrumb [aria-current="page"] { color: var(--c-text); font-weight: 600; }

/* ---------------- Product grid & cards ---------------- */
.product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(185px, 1fr)); gap: 1.1rem; }
.product-card {
    border: 1px solid var(--c-border); border-radius: var(--radius); background: var(--c-surface);
    overflow: hidden; transition: transform .14s ease, box-shadow .18s ease, border-color .18s;
}
.product-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: transparent; }
.product-card__link { display: flex; flex-direction: column; height: 100%; padding: .9rem; color: inherit; }
.product-card__link:hover { color: inherit; }
.product-card__media {
    aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
    background: var(--c-soft); border-radius: var(--radius-sm); margin-bottom: .75rem; padding: .8rem; overflow: hidden;
}
.product-card__media img { max-height: 100%; max-width: 100%; object-fit: contain; transition: transform .25s; }
.product-card:hover .product-card__media img { transform: scale(1.045); }
.product-card__title { font-size: .94rem; font-weight: 600; margin: .1rem 0 .35rem; display: -webkit-box;
    -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.5em; }
.product-card__brand { font-size: .78rem; color: var(--c-muted); margin: 0 0 .5rem; text-transform: uppercase; letter-spacing: .03em; }
.product-card__price { font-size: 1.18rem; font-weight: 820; color: var(--c-text); margin: auto 0 0; letter-spacing: -.02em; }
.product-card__compare {
    display: inline-block; margin: .5rem 0 0; padding: .2rem .55rem; font-size: .76rem; font-weight: 650;
    color: var(--c-accent-dark); background: color-mix(in srgb, var(--c-accent) 14%, transparent);
    border-radius: var(--radius-pill);
}

/* ---------------- Listing ---------------- */
.listing-header { padding: .6rem 0 .2rem; }
.listing-header__count { color: var(--c-muted); margin: .2rem 0 0; }
.listing-header--image { padding: 2.2rem 1.6rem; border-radius: var(--radius); background-size: cover;
    background-position: center; color: #fff; margin-bottom: .4rem; }
.listing-header--image h1 { color: #fff; }
.listing-header--image .listing-header__count { color: rgba(255,255,255,.85); }
.listing-toolbar { display: flex; justify-content: flex-end; align-items: center; padding: .2rem 0 1.1rem; }
.sort-form { display: inline-flex; align-items: center; gap: .5rem; font-size: .9rem; color: var(--c-muted); }
.sort-form select, .facets__toggle, select {
    padding: .5rem .7rem; border: 1px solid var(--c-border); border-radius: var(--radius-sm);
    background: var(--c-surface); font: inherit; color: var(--c-text);
}

/* Listing-Layout mit Facetten */
.listing-layout { display: grid; grid-template-columns: 1fr; gap: 1.6rem; }
.listing-main { min-width: 0; }

.active-filters { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; margin: .4rem 0 1.1rem; }
.filter-chip { display: inline-flex; gap: .45rem; align-items: center; padding: .4rem .8rem; background: var(--c-surface);
    border: 1px solid var(--c-border); border-radius: var(--radius-pill); font-size: .85rem; box-shadow: var(--shadow-sm); }
.filter-chip:hover { border-color: var(--c-primary); }
.filter-chip span { color: var(--c-muted); font-weight: 800; }
.filter-reset { font-size: .85rem; color: var(--c-muted); }

.facets { position: relative; }
.facets__toggle { display: none; width: 100%; font-weight: 650; cursor: pointer; }
.facets__panel { display: flex; flex-direction: column; gap: .7rem; }
.facet { border: 1px solid var(--c-border); border-radius: var(--radius); padding: .5rem 1rem; background: var(--c-surface); box-shadow: var(--shadow-sm); }
.facet__title { font-weight: 700; cursor: pointer; padding: .5rem 0; list-style: none; font-size: .95rem; }
.facet__title::-webkit-details-marker { display: none; }
.facet__title::after { content: "–"; float: right; color: var(--c-muted); }
.facet:not([open]) .facet__title::after { content: "+"; }
.facet__list { list-style: none; margin: 0 0 .5rem; padding: 0; max-height: 240px; overflow-y: auto; }
.facet__value { display: flex; align-items: center; gap: .55rem; padding: .32rem 0; color: var(--c-text); font-size: .9rem; }
.facet__value:hover { color: var(--c-primary); }
.facet__check { width: 18px; height: 18px; border: 1.5px solid var(--c-border); border-radius: 5px; flex: 0 0 auto; transition: .12s; }
.facet__value.is-active .facet__check { background: var(--c-primary); border-color: var(--c-primary); box-shadow: inset 0 0 0 2.5px #fff; }
.facet__value.is-active { font-weight: 650; }
.facet__label { flex: 1; text-transform: capitalize; }
.facet__count { color: var(--c-muted); font-size: .8rem; }

@media (min-width: 900px) {
    .listing-layout { grid-template-columns: 270px 1fr; align-items: start; }
}
@media (max-width: 899px) {
    .facets__toggle { display: block; }
    .facets__panel { display: none; margin-top: .6rem; }
    .facets.is-open .facets__panel { display: flex; }
}

/* ---------------- Pagination ---------------- */
.pagination { display: flex; gap: .8rem; align-items: center; justify-content: center; padding: 2.2rem 0; }
.pagination a { padding: .55rem 1.1rem; border: 1px solid var(--c-border); border-radius: var(--radius-pill); background: var(--c-surface); font-weight: 600; }
.pagination a:hover { border-color: var(--c-primary); box-shadow: var(--shadow-sm); }
.pagination__status { color: var(--c-muted); font-size: .9rem; }

/* ---------------- Product detail ---------------- */
.product-detail { display: grid; grid-template-columns: 1fr; gap: 1.8rem; padding: 1rem 0 .5rem; }
.product-detail__media { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center; padding: 1.5rem; }
.product-detail__info h1 { margin: 0 0 .5rem; }
.product-detail__brand { color: var(--c-muted); margin: 0 0 1rem; }
.product-detail__price { font-size: 1.1rem; padding: 1rem 1.2rem; background: var(--c-surface);
    border: 1px solid var(--c-border); border-radius: var(--radius); display: inline-block; }
.product-detail__price strong { font-size: 1.9rem; color: var(--c-primary); letter-spacing: -.02em; }
.product-detail__desc { color: #3a4150; margin-top: 1.2rem; }

/* ---------------- Offers (Preisvergleich) ---------------- */
.offers { margin: 2.4rem 0; }
.offers-table { width: 100%; border-collapse: separate; border-spacing: 0; background: var(--c-surface);
    border: 1px solid var(--c-border); border-radius: var(--radius); overflow: hidden; }
.offers-table th { padding: .85rem 1rem; text-align: left; font-size: .78rem; text-transform: uppercase;
    letter-spacing: .04em; color: var(--c-muted); background: var(--c-soft); }
.offers-table td { padding: .9rem 1rem; border-top: 1px solid var(--c-border); vertical-align: middle; }
.offers-table tbody tr:hover { background: color-mix(in srgb, var(--c-primary) 4%, transparent); }
.offers-table tbody tr:first-child td { border-top: 0; }
.offers-table tbody tr:first-child { background: color-mix(in srgb, var(--c-accent) 7%, transparent); }
.offers-table tbody tr:first-child td:first-child::before {
    content: "Bester Preis"; display: inline-block; margin-right: .5rem; padding: .12rem .5rem;
    font-size: .68rem; font-weight: 700; color: #fff; background: var(--c-accent-dark); border-radius: var(--radius-pill);
    vertical-align: middle;
}
.offers-table__price { font-weight: 820; white-space: nowrap; font-size: 1.05rem; }
.offers-table__shop { display: block; font-weight: 650; }
.offers-table__brand { display: block; font-size: .8rem; color: var(--c-muted); }

/* Amazon-Alternative */
.alt-amazon { display: flex; align-items: center; gap: .8rem; margin: 1.4rem 0; color: var(--c-muted); }
.btn--amazon { background: #ff9900; color: #111; border-color: transparent; }
.btn--amazon:hover { background: #f08804; color: #111; }

/* ---------------- Slider ---------------- */
.product-slider { margin: 2.8rem 0; }
.product-slider > h2 { margin: 0 0 1rem; }
.slider { position: relative; }
.slider__track { display: flex; gap: 1.1rem; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth;
    padding: .3rem .2rem 1rem; scrollbar-width: thin; }
.slider__track::-webkit-scrollbar { height: 7px; }
.slider__track::-webkit-scrollbar-thumb { background: var(--c-border); border-radius: 4px; }
.slider__item { flex: 0 0 auto; width: 200px; scroll-snap-align: start; }
.slider__btn { position: absolute; top: 38%; z-index: 2; width: 42px; height: 42px; display: grid; place-items: center;
    border-radius: 50%; border: 1px solid var(--c-border); background: var(--c-surface); cursor: pointer;
    box-shadow: var(--shadow); color: var(--c-text); transition: .12s; }
.slider__btn:hover { background: var(--c-primary); color: #fff; border-color: transparent; }
.slider__btn--prev { left: -10px; }
.slider__btn--next { right: -10px; }

/* ---------------- Partner ---------------- */
.partner-list { display: flex; flex-wrap: wrap; gap: .6rem; }
.partner-box { display: inline-flex; align-items: center; gap: .6rem; padding: .7rem 1rem; border: 1px solid var(--c-border);
    border-radius: var(--radius); background: var(--c-surface); box-shadow: var(--shadow-sm); transition: .14s; }
.partner-box:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.partner-box img { max-height: 40px; width: auto; }

/* ---------------- Category SEO text ---------------- */
.category-text { margin: 2.5rem 0 1rem; padding: 1.6rem 1.8rem; background: var(--c-surface);
    border: 1px solid var(--c-border); border-radius: var(--radius); color: #3a4150; }
.category-text h2, .category-text h3 { margin-top: 1.2rem; }

/* ---------------- CMS / Blog ---------------- */
.cms-page, .blog { padding: 1.4rem 0; }
.page-container, .blog-container { background: var(--c-surface); border: 1px solid var(--c-border);
    border-radius: var(--radius); padding: clamp(1.2rem, 3vw, 2.4rem); }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.2rem; }
.blog-card { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius);
    padding: 1.3rem; transition: .14s; }
.blog-card:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.blog-card h2 { font-size: 1.15rem; margin: 0 0 .5rem; }

/* ---------------- Footer ---------------- */
.site-footer { border-top: 1px solid var(--c-border); margin-top: 3.5rem; padding: 2.2rem 0; color: var(--c-muted);
    font-size: .9rem; background: var(--c-surface); }
.site-footer nav { display: flex; gap: 1.2rem; flex-wrap: wrap; margin-top: .6rem; }
.site-footer a { color: var(--c-muted); }
.site-footer a:hover { color: var(--c-primary); }

/* ---------------- Error ---------------- */
.error-page { text-align: center; padding: 5rem 1rem; }
.error-page h1 { font-size: 5rem; margin: 0; background: linear-gradient(90deg, var(--c-primary), var(--c-accent));
    -webkit-background-clip: text; background-clip: text; color: transparent; }

@media (min-width: 768px) {
    .product-detail { grid-template-columns: 420px 1fr; }
}
/* Burger-Label auf sehr kleinen Screens ausblenden (nur Icon) */
@media (max-width: 560px) {
    .nav-burger { padding: .55rem; }
    .nav-burger__label { display: none; }
}
@media (max-width: 560px) {
    .header-inner { gap: .7rem; }
    .main-nav { width: 100%; order: 3; }
    .product-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: .8rem; }
}
