/* ==========================================================================
   CineCritique-Theme — durchgängiger Look (Header · Body · Footer)
   Lädt NACH style.css und überschreibt das Kino-Rot-Theme.
   ========================================================================== */

:root {
    --cc-bg:        #eef0f2;   /* kühles Hellgrau – Seitenhintergrund */
    --cc-bg-2:      #e3e6ea;   /* etwas dunkler – Pills, Upcoming-Karten */
    --cc-surface:   #ffffff;   /* Karten / Footer */
    --cc-ink:       #14171c;   /* Headlines (fast schwarz, kühl) */
    --cc-ink-2:     #4a515b;   /* Fließtext kühl-grau */
    --cc-ink-3:     #828a95;   /* Meta / mono gedämpft */
    --cc-red:       #c41e26;   /* tiefes Blutrot (Akzent) */
    --cc-red-2:     #a3171e;   /* Rot Hover */
    --cc-steel:     #38465a;   /* Stahlblau-Grau (Sekundär) */
    --cc-line:      #dfe2e6;   /* Rahmen / Trennlinien (kühl) */
    --cc-gold:      #d9a23a;   /* Sterne */
    --cc-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --cc-mono: 'Space Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
    --cc-shadow: 0 10px 30px rgba(20,24,33,.10);
    --cc-radius: 14px;
}

/* ---- Basis ------------------------------------------------------------ */
body.cc {
    background: var(--cc-bg);
    color: var(--cc-ink);
    font-family: var(--cc-sans);
    -webkit-font-smoothing: antialiased;
}
.cc h1, .cc h2, .cc h3, .cc h4 { font-family: var(--cc-sans); color: var(--cc-ink); }
.cc .container { max-width: 1240px; padding-left: 32px; padding-right: 32px; }
.cc a { color: var(--cc-ink); }

/* Mono-Utility (Genre, Daten, Rollen) */
.cc .mono, .ed-card__label, .ed-genre, .ed-trend__meta span,
.ed-up__meta span, .ed-more, .cc-search input, .cert {
    font-family: var(--cc-mono);
    letter-spacing: .04em;
}

/* ---- Buttons (global re-skin) ---------------------------------------- */
.cc .btn { border-radius: 10px; font-weight: 700; font-family: var(--cc-sans); }
.cc .btn--primary { background: var(--cc-red); border-color: var(--cc-red); color: #fff; }
.cc .btn--primary:hover { background: var(--cc-red-2); border-color: var(--cc-red-2); }
.cc .btn--ghost { background: #fff; border-color: var(--cc-line); color: var(--cc-ink); }
.cc .btn--ghost:hover { background: var(--cc-bg-2); border-color: #cdd3da; }
.cc-btn {
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--cc-sans); font-weight: 700; font-size: 15px;
    border-radius: 10px; padding: 11px 22px; border: 1px solid transparent;
    cursor: pointer; transition: background .15s, transform .05s; white-space: nowrap;
}
.cc-btn--red { background: var(--cc-red); color: #fff; }
.cc-btn--red:hover { background: var(--cc-red-2); }

/* ======================================================================
   HEADER
   ====================================================================== */
.cc-header {
    background: var(--cc-bg);
    border-bottom: 1px solid var(--cc-line);
    position: sticky; top: 0; z-index: 60;
}
.cc-header__inner { display: flex; align-items: center; gap: 30px; height: 74px; }
.cc-logo {
    font-family: var(--cc-sans); font-weight: 900; font-size: 1.5rem;
    text-transform: uppercase; letter-spacing: -.03em; line-height: 1;
    text-decoration: none; display: inline-flex; white-space: nowrap;
}
.cc-logo__k { color: var(--cc-ink); }
.cc-logo__r { color: var(--cc-red); }
.cc-logo--lg { font-size: 1.95rem; }
.cc-nav { display: flex; gap: 26px; }
.cc-nav__link {
    font-weight: 500; font-size: 1rem; color: var(--cc-ink);
    padding: 4px 0; position: relative; text-decoration: none;
}
.cc-nav__link:hover { color: var(--cc-red); }
.cc-nav__link.is-active { color: var(--cc-red); font-weight: 700; }
.cc-nav__link.is-active::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
    height: 2px; background: var(--cc-red); border-radius: 2px;
}
.cc-header__right { margin-left: auto; display: flex; align-items: center; gap: 16px; }
.cc-search {
    display: flex; align-items: center; gap: 9px;
    background: var(--cc-bg-2); border: 1px solid var(--cc-line);
    border-radius: 999px; padding: 9px 18px; min-width: 260px;
    color: var(--cc-ink-3);
}
.cc-search input {
    border: 0; outline: 0; background: transparent; flex: 1;
    font-size: 14px; color: var(--cc-ink);
}
.cc-search input::placeholder { color: var(--cc-ink-3); }
.cc-burger { display: none; background: 0; border: 0; color: var(--cc-ink); cursor: pointer; padding: 4px; }

@media (max-width: 900px) {
    .cc-nav, .cc-search { display: none; }
    .cc-burger { display: inline-flex; }
    .cc-header__inner { gap: 14px; height: 62px; }
    .cc-logo { font-size: 1.35rem; }
}

/* Drawer im hellen Look */
.cc-drawer { background: #fff; color: var(--cc-ink); }
.cc-drawer .drawer__head { border-bottom: 1px solid var(--cc-line); }
.cc-drawer .drawer__close { color: var(--cc-ink); }
.cc-drawer .drawer__nav a { color: var(--cc-ink); font-weight: 600; }
.cc-drawer .drawer__nav a:hover { background: var(--cc-bg); color: var(--cc-red); }
.cc-drawer .drawer__sep { border-top-color: var(--cc-line); }

/* ======================================================================
   HOME · Editorial (re-skin der .home-ed Struktur)
   ====================================================================== */
.home-ed { background: var(--cc-bg); color: var(--cc-ink); }

/* Section-Titel mit rotem Unterstrich */
.home-ed .ed-section__title, .cc-h2 {
    font-size: 2.5rem; font-weight: 800; letter-spacing: -.02em; margin: 0;
}
.home-ed .ed-section__title::after, .cc-h2::after {
    content: ""; display: block; width: 60px; height: 4px;
    background: var(--cc-red); border-radius: 2px; margin-top: 12px;
}
.home-ed .ed-section { padding-top: 56px; padding-bottom: 8px; }
.home-ed .ed-section__head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 30px; }
.home-ed .ed-more {
    font-size: .8rem; text-transform: uppercase; letter-spacing: .12em;
    color: var(--cc-ink); font-weight: 700; text-decoration: none;
}
.home-ed .ed-more:hover { color: var(--cc-red); }

/* HERO — Backdrop mit Creme-Verlauf, dunkle Schrift unten links */
.home-ed .ed-hero {
    position: relative; min-height: 78vh; display: flex; align-items: flex-end;
    background-image: var(--bg, none); background-size: cover; background-position: center;
    color: var(--cc-ink); overflow: hidden;
}
.home-ed .ed-hero::before {
    content: ""; position: absolute; inset: 0;
    background:
        linear-gradient(to top, var(--cc-bg) 4%, rgba(238,240,242,.5) 34%, rgba(238,240,242,0) 64%),
        linear-gradient(to right, var(--cc-bg) 2%, rgba(238,240,242,.55) 30%, rgba(238,240,242,0) 62%);
}
.home-ed .ed-hero__inner { position: relative; z-index: 1; padding-top: 60px; padding-bottom: 56px; width: 100%; }
.home-ed .ed-hero__content { max-width: 640px; }
.home-ed .ed-badge {
    display: inline-block; background: var(--cc-red); color: #fff;
    font-family: var(--cc-mono); font-size: .72rem; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase; padding: 6px 12px; border-radius: 4px;
}
.home-ed .ed-badge__star { color: #ffe08a; }
.home-ed .ed-hero__title {
    font-size: clamp(2.6rem, 6vw, 4.6rem); font-weight: 900; line-height: .98;
    letter-spacing: -.03em; text-transform: uppercase; margin: 20px 0 18px;
    color: var(--cc-ink);
}
.home-ed .ed-hero__meta { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.home-ed .ed-score {
    background: var(--cc-ink); color: #fff; font-weight: 800; font-size: 1rem;
    padding: 4px 11px; border-radius: 8px;
}
.home-ed .ed-genre { font-family: var(--cc-mono); font-size: .82rem; color: var(--cc-ink-2); text-transform: uppercase; letter-spacing: .1em; }
.home-ed .ed-hero__text { font-size: 1.18rem; line-height: 1.6; color: var(--cc-ink-2); margin: 0 0 28px; max-width: 560px; }
.home-ed .ed-hero__text strong { color: var(--cc-ink); }
.home-ed .ed-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; }
.home-ed .ed-hero__actions .btn { padding: 14px 26px; font-size: 1rem; border-radius: 12px; }

/* Sterne (Gold) */
.cc .stars { display: inline-flex; gap: 2px; }
.cc .star { color: rgba(0,0,0,.18); font-size: 1rem; }
.cc .star--on { color: var(--cc-gold); }

/* LATEST REVIEWS — Karten */
.home-ed .ed-reviews { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 28px; }
.home-ed .ed-card {
    background: var(--cc-surface); border: 1px solid var(--cc-line);
    border-radius: var(--cc-radius); overflow: hidden; text-decoration: none;
    display: flex; flex-direction: column; box-shadow: var(--cc-shadow);
    transition: transform .15s, box-shadow .15s;
}
.home-ed .ed-card:hover { transform: translateY(-4px); box-shadow: 0 16px 38px rgba(20,24,33,.13); }
.home-ed .ed-card__img { position: relative; aspect-ratio: 16/10; background: #e2e6ea; }
.home-ed .ed-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.home-ed .ed-card__stars { position: absolute; top: 12px; left: 12px; }
.home-ed .ed-card__stars .star { font-size: 1.05rem; text-shadow: 0 1px 4px rgba(0,0,0,.6); }
.home-ed .ed-card__stars .star { color: rgba(255,255,255,.45); }
.home-ed .ed-card__stars .star--on { color: var(--cc-gold); }
.home-ed .ed-card__body { padding: 20px 22px 24px; display: flex; flex-direction: column; gap: 10px; }
.home-ed .ed-card__label {
    font-family: var(--cc-mono); font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .1em; color: var(--cc-red);
}
.home-ed .ed-card__title { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em; margin: 0; color: var(--cc-ink); }
.home-ed .ed-card__excerpt { font-size: .98rem; line-height: 1.55; color: var(--cc-ink-2); margin: 0; }

/* TRENDING + SIDEBAR */
.home-ed .ed-grid2 { display: grid; grid-template-columns: 1fr 340px; gap: 56px; padding-top: 56px; padding-bottom: 64px; align-items: start; }
.home-ed .ed-trending .ed-section__head { margin-bottom: 28px; }

/* Trending = Hochkant-Poster mit rotem Fortschrittsbalken */
.home-ed .ed-trend-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.home-ed .ed-trend { display: flex; flex-direction: column; gap: 12px; text-decoration: none; }
.home-ed .ed-trend__img {
    position: relative; aspect-ratio: 2/3; border-radius: 10px; overflow: hidden;
    background: #dde1e6; box-shadow: var(--cc-shadow);
}
.home-ed .ed-trend__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.home-ed .ed-trend__img::after {
    content: ""; position: absolute; left: 0; right: 38%; bottom: 0; height: 5px; background: var(--cc-red);
}
.home-ed .ed-trend__meta h3 { font-size: 1.12rem; font-weight: 800; margin: 0 0 3px; color: var(--cc-ink); }
.home-ed .ed-trend__meta span { font-family: var(--cc-mono); font-size: .8rem; color: var(--cc-ink-3); letter-spacing: .04em; }

/* Sidebar */
.home-ed .ed-side { display: flex; flex-direction: column; gap: 42px; }
.home-ed .ed-panel { }
.home-ed .ed-section__title--sm, .home-ed .ed-panel .ed-section__title { font-size: 1.6rem; }
.home-ed .ed-section__title--sm::after { width: 48px; }
.home-ed .ed-up-list { display: flex; flex-direction: column; gap: 14px; margin-top: 24px; }
.home-ed .ed-up {
    display: flex; align-items: center; gap: 14px; text-decoration: none;
    background: var(--cc-bg-2); border: 1px solid var(--cc-line); border-radius: 12px; padding: 12px;
}
.home-ed .ed-up:hover { border-color: #cdd3da; }
.home-ed .ed-up__thumb { width: 54px; height: 54px; border-radius: 8px; overflow: hidden; background: #dde1e6; flex: none; }
.home-ed .ed-up__thumb img { width: 100%; height: 100%; object-fit: cover; }
.home-ed .ed-up__meta strong { display: block; font-size: 1rem; color: var(--cc-ink); font-weight: 800; }
.home-ed .ed-up__meta span { font-family: var(--cc-mono); font-size: .76rem; color: var(--cc-red); text-transform: uppercase; letter-spacing: .08em; }

/* Über den Kritiker */
.home-ed .ed-about { background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: var(--cc-radius); padding: 26px; box-shadow: var(--cc-shadow); }
.home-ed .ed-about__mark { font-family: var(--cc-sans); font-weight: 800; font-size: 1.4rem; color: var(--cc-red); }
.home-ed .ed-about__mark .logo__main, .home-ed .ed-about__mark .logo__pill { all: unset; color: var(--cc-red); font-weight: 800; }
.home-ed .ed-about__tag { font-family: var(--cc-mono); font-size: .82rem; color: var(--cc-ink-3); margin: 8px 0 12px; }
.home-ed .ed-about__text { font-size: .96rem; line-height: 1.55; color: var(--cc-ink-2); margin: 0 0 18px; }

@media (max-width: 980px) {
    .home-ed .ed-grid2 { grid-template-columns: 1fr; gap: 40px; }
    .home-ed .ed-trend-list { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .home-ed .ed-section__title, .cc-h2 { font-size: 2rem; }
    .home-ed .ed-trend-list { grid-template-columns: 1fr 1fr; }
    .home-ed .ed-hero { min-height: 70vh; }
}

/* ======================================================================
   FOOTER
   ====================================================================== */
.cc-footer { background: var(--cc-surface); border-top: 1px solid var(--cc-line); margin-top: 40px; }
.cc-footer__grid {
    display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: 40px;
    padding-top: 64px; padding-bottom: 48px;
}
.cc-footer__tagline { color: var(--cc-ink-2); font-size: 1rem; line-height: 1.5; max-width: 240px; margin: 16px 0 0; }
.cc-footer__col h4 { font-size: 1.05rem; font-weight: 800; margin: 0 0 18px; color: var(--cc-ink); }
.cc-footer__col a { display: block; color: var(--cc-ink-2); text-decoration: underline; text-underline-offset: 3px; margin-bottom: 12px; font-size: .96rem; }
.cc-footer__col a:hover { color: var(--cc-red); }
.cc-footer__col--attr .tmdb-attr { display: inline-block; margin-bottom: 12px; }
.cc-footer__fine { font-size: .8rem; line-height: 1.5; color: var(--cc-ink-3); margin: 0; }
.cc-footer__bar { border-top: 1px solid var(--cc-line); padding-top: 22px; padding-bottom: 30px; }
.cc-footer__bar span { font-family: var(--cc-mono); font-size: .78rem; color: var(--cc-ink-3); letter-spacing: .03em; }

@media (max-width: 860px) {
    .cc-footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; padding-top: 44px; }
}
@media (max-width: 480px) {
    .cc-footer__grid { grid-template-columns: 1fr; }
}

/* ======================================================================
   DETAILSEITE (Film) · CineCritique „Filmkritik"-Layout
   ====================================================================== */
.cc-detail { background: var(--cc-bg); }
.cc-kicker {
    font-family: var(--cc-mono); font-size: .76rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .16em; color: var(--cc-red);
}
.cc-kicker--dark { color: var(--cc-ink-3); }
.cc-h2--bar { font-size: 1.7rem; font-weight: 800; margin: 0 0 26px; padding-left: 16px; position: relative; color: var(--cc-ink); }
.cc-h2--bar::before { content: ""; position: absolute; left: 0; top: 4px; bottom: 4px; width: 5px; background: var(--cc-red); border-radius: 3px; }

/* HERO mit Backdrop, Verlauf nach Creme, Titel unten links */
.cc-dhero {
    position: relative; min-height: 70vh; display: flex; align-items: flex-end;
    background-image: var(--bg, none); background-size: cover; background-position: center 30%;
    overflow: hidden;
}
.cc-dhero::before {
    content: ""; position: absolute; inset: 0;
    background:
        linear-gradient(to top, var(--cc-bg) 3%, rgba(238,240,242,.45) 32%, rgba(238,240,242,0) 66%),
        linear-gradient(to right, rgba(238,240,242,.7) 0%, rgba(238,240,242,0) 55%);
}
.cc-dhero__inner { position: relative; z-index: 1; width: 100%; display: flex; align-items: flex-end; justify-content: space-between; gap: 30px; padding-top: 60px; padding-bottom: 48px; }
.cc-dhero__text { max-width: 70%; }
.cc-dtitle { font-size: clamp(2.6rem, 6vw, 5rem); font-weight: 900; line-height: .98; letter-spacing: -.03em; color: var(--cc-ink); margin: 14px 0 14px; }
.cc-dmeta { font-size: 1.05rem; color: var(--cc-ink-2); margin: 0; }
.cc-dmeta strong { color: var(--cc-ink); font-weight: 700; }
.cc-dhero__trailer { margin-top: 20px; gap: 8px; }

/* CineScore-Box */
.cc-score {
    flex: none; background: var(--cc-surface); border: 1px solid var(--cc-line);
    border-radius: 14px; box-shadow: var(--cc-shadow); padding: 20px 26px; text-align: right; min-width: 190px;
}
.cc-score__cap { font-family: var(--cc-mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .12em; color: var(--cc-ink-3); }
.cc-score__stars { margin: 8px 0 4px; }
.cc-score__stars .star { font-size: 1.25rem; }
.cc-score__num { font-size: 2.4rem; font-weight: 900; color: var(--cc-ink); line-height: 1; }
.cc-score__num span { font-size: 1.1rem; font-weight: 700; color: var(--cc-ink-3); }
.cc-score__src { display: block; margin-top: 6px; font-family: var(--cc-mono); font-size: .68rem; color: var(--cc-ink-3); }

/* BODY */
.cc-detail__body { background: var(--cc-bg); padding: 56px 0 20px; }
.cc-review { display: grid; grid-template-columns: 300px 1fr; gap: 48px; align-items: start; margin-bottom: 64px; }
.cc-review__aside { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 16px; }
.cc-review__poster { width: 100%; border-radius: 14px; box-shadow: var(--cc-shadow); border-bottom: 5px solid var(--cc-red); }
.cc-review__edit { width: 100%; }
.cc-review__headline { font-size: 2rem; font-weight: 800; letter-spacing: -.02em; color: var(--cc-ink); margin: 0 0 22px; }
.cc-review__tagline { font-size: 1.4rem; font-style: italic; color: var(--cc-ink-3); margin: 0 0 22px; }
.cc-draft { font-family: var(--cc-mono); font-size: .8rem; color: var(--cc-red); margin: 0 0 14px; }

/* Fließtext */
.cc-prose { font-size: 1.12rem; line-height: 1.72; color: var(--cc-ink-2); }
.cc-prose p { margin: 0 0 1.2em; }
.cc-prose strong { color: var(--cc-ink); }
.cc-prose em { color: var(--cc-red); font-style: italic; }
.cc-prose h3 { font-size: 1.7rem; font-weight: 800; color: var(--cc-ink); letter-spacing: -.02em; margin: 1.6em 0 .5em; }
.cc-prose blockquote {
    margin: 1.6em 0; padding: 22px 26px; border-left: 4px solid var(--cc-red);
    background: #edf0f4; border-radius: 0 10px 10px 0;
    font-size: 1.3rem; font-style: italic; font-weight: 600; color: var(--cc-ink);
}
.cc-prose--dropcap > p:first-of-type::first-letter {
    float: left; font-size: 4.2rem; line-height: .8; font-weight: 900;
    color: var(--cc-red); margin: 6px 12px 0 0; font-family: var(--cc-sans);
}
.cc-recommend { display: inline-flex; align-items: center; gap: 8px; margin: 6px 0 0; font-weight: 700; color: var(--cc-ink); }
.cc-recommend span { display: inline-grid; place-items: center; width: 22px; height: 22px; border-radius: 50%; background: var(--cc-red); color: #fff; font-size: .8rem; }
.cc-review__sig { margin-top: 28px; font-family: var(--cc-mono); font-size: .85rem; color: var(--cc-ink-3); }

/* ENSEMBLE */
.cc-ensemble { margin-bottom: 64px; }
.cc-ensemble__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.cc-castcard { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.cc-castcard__photo { width: 56px; height: 56px; border-radius: 50%; overflow: hidden; background: var(--cc-bg-2); flex: none; display: grid; place-items: center; }
.cc-castcard__photo img { width: 100%; height: 100%; object-fit: cover; }
.cc-castcard__noimg { font-size: 1.4rem; }
.cc-castcard__meta strong { display: block; color: var(--cc-ink); font-weight: 700; font-size: 1rem; }
.cc-castcard__meta span { font-family: var(--cc-mono); font-size: .78rem; color: var(--cc-ink-3); }

/* AMAZON */
.cc-buy {
    display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
    background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: var(--cc-radius);
    box-shadow: var(--cc-shadow); padding: 28px 32px; margin-bottom: 56px;
}
.cc-buy__text { flex: 1; min-width: 200px; }
.cc-buy__text h3 { font-size: 1.4rem; font-weight: 800; color: var(--cc-ink); margin: 8px 0 4px; }
.cc-buy__text p { color: var(--cc-ink-2); margin: 0; }
.cc-buy .cc-btn { padding: 14px 28px; }

@media (max-width: 820px) {
    /* Hero kompakt + Text lesbar über dem Backdrop */
    .cc-dhero { min-height: 0; }
    .cc-dhero::before {
        background:
            linear-gradient(to top,
                var(--cc-bg) 16%,
                rgba(238,240,242,.93) 48%,
                rgba(238,240,242,.6) 78%,
                rgba(238,240,242,.3) 100%);
    }
    .cc-dhero__inner { flex-direction: column; align-items: stretch; }
    .cc-dtitle { font-size: clamp(2rem, 9vw, 2.8rem); }
    .cc-dmeta { font-size: .95rem; }

    /* Zwei Score-Boxen nebeneinander */
    .cc-dhero__scores { flex-direction: row; width: 100%; gap: 10px; }
    .cc-dhero__scores .cc-score { flex: 1; min-width: 0; text-align: left; padding: 14px 16px; }
    .cc-dhero__scores .cc-score__num { font-size: 2rem; }

    .cc-review { grid-template-columns: 1fr; gap: 28px; }
    /* Aside als Spalte, Poster zentriert */
    .cc-review__aside { position: static; flex-direction: column; align-items: stretch; }
    .cc-review__poster { width: 62%; max-width: 230px; margin: 0 auto 4px; }
    .cc-ensemble__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ======================================================================
   PERSONEN-DETAIL · Profil-Layout
   ====================================================================== */
.cc-profile { padding-top: 48px; }
.cc-profile__head { display: flex; gap: 36px; align-items: flex-start; padding-bottom: 44px; border-bottom: 1px solid var(--cc-line); }
.cc-profile__photo {
    width: 210px; height: 260px; flex: none; border-radius: 18px; overflow: hidden;
    background: var(--cc-bg-2); box-shadow: var(--cc-shadow); display: grid; place-items: center;
}
.cc-profile__photo img { width: 100%; height: 100%; object-fit: cover; }
.cc-profile__noimg { font-size: 4rem; }
.cc-profile__intro { flex: 1; padding-top: 6px; }
.cc-profile__name { font-size: clamp(2.2rem, 4.5vw, 3.4rem); font-weight: 900; letter-spacing: -.03em; color: var(--cc-ink); margin: 10px 0 16px; }
.cc-profile__lead { font-size: 1.1rem; line-height: 1.6; color: var(--cc-ink-2); max-width: 640px; margin: 0 0 24px; }
.cc-profile__stats { display: flex; gap: 44px; margin-bottom: 22px; }
.cc-profile__stats strong { display: block; font-size: 1.9rem; font-weight: 900; color: var(--cc-ink); line-height: 1; }
.cc-profile__stats span { font-family: var(--cc-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: var(--cc-ink-3); }
.cc-profile__social { display: flex; gap: 12px; }
.cc-soc { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: var(--cc-bg-2); border: 1px solid var(--cc-line); color: var(--cc-ink); }
.cc-soc:hover { background: var(--cc-red); color: #fff; border-color: var(--cc-red); }
.cc-soc svg { width: 18px; height: 18px; }
.cc-soc--txt { width: auto; padding: 0 14px; border-radius: 999px; font-family: var(--cc-mono); font-size: .76rem; font-weight: 700; }

.cc-profile__body { display: grid; grid-template-columns: 1fr 300px; gap: 48px; padding: 44px 0 64px; align-items: start; }
.cc-pblock { margin-bottom: 48px; }
.cc-pblock:last-child { margin-bottom: 0; }

/* Bekannt für – Poster-Grid */
.cc-known { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.cc-poster { text-decoration: none; display: flex; flex-direction: column; gap: 8px; }
.cc-poster__img { position: relative; aspect-ratio: 2/3; border-radius: 10px; overflow: hidden; background: var(--cc-bg-2); box-shadow: var(--cc-shadow); }
.cc-poster__img img { width: 100%; height: 100%; object-fit: cover; }
.cc-poster__badge { position: absolute; top: 8px; left: 8px; background: var(--cc-red); color: #fff; font-family: var(--cc-mono); font-size: .62rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; padding: 3px 7px; border-radius: 4px; }
.cc-poster strong { font-size: .98rem; font-weight: 700; color: var(--cc-ink); line-height: 1.2; }
.cc-poster__year { font-family: var(--cc-mono); font-size: .76rem; color: var(--cc-ink-3); }

/* Biografie */
.cc-profile .person-bio { font-size: 1.05rem; line-height: 1.7; color: var(--cc-ink-2); }
.cc-profile .bio-more { margin-top: 14px; }

/* Filmografie */
.cc-filmo__dept { font-size: 1.05rem; font-weight: 800; color: var(--cc-ink); margin: 28px 0 4px; }
.cc-profile .credits-block { border-top: 1px solid var(--cc-line); }
.cc-profile .credit-yeargroup { display: flex; gap: 20px; padding: 14px 0; border-bottom: 1px solid var(--cc-line); }
.cc-profile .credit-year { font-family: var(--cc-mono); font-weight: 700; color: var(--cc-ink-3); width: 56px; flex: none; }
.cc-profile .credit-items { display: flex; flex-direction: column; gap: 8px; }
.cc-profile .credit-item { color: var(--cc-ink); text-decoration: none; }
.cc-profile .credit-item:hover .credit-title { color: var(--cc-red); }
.cc-profile .credit-title { font-weight: 700; }
.cc-profile .credit-role { color: var(--cc-ink-3); margin-left: 8px; font-size: .92rem; }
.cc-profile .rec-badge { background: var(--cc-red); color: #fff; font-family: var(--cc-mono); font-size: .64rem; text-transform: uppercase; letter-spacing: .06em; padding: 2px 6px; border-radius: 4px; border: 0; }

/* Zur Person */
.cc-profile__facts { background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: var(--cc-radius); box-shadow: var(--cc-shadow); padding: 24px; position: sticky; top: 96px; }
.cc-profile__facts h3 { font-size: 1.15rem; font-weight: 800; margin: 0 0 16px; color: var(--cc-ink); }
.cc-profile__facts dl { margin: 0; display: grid; grid-template-columns: 1fr; gap: 4px; }
.cc-profile__facts dt { font-family: var(--cc-mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; color: var(--cc-ink-3); margin-top: 12px; }
.cc-profile__facts dt:first-child { margin-top: 0; }
.cc-profile__facts dd { margin: 0; color: var(--cc-ink); font-weight: 600; }
.cc-profile__facts .aka { display: block; font-weight: 400; color: var(--cc-ink-2); font-size: .9rem; }

@media (max-width: 860px) {
    .cc-profile__head { flex-direction: column; gap: 22px; }
    .cc-profile__photo { width: 150px; height: 190px; }
    .cc-profile__body { grid-template-columns: 1fr; gap: 36px; }
    .cc-profile__facts { position: static; }
    .cc-known { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 520px) {
    .cc-known { grid-template-columns: repeat(2, 1fr); }
    .cc-profile__stats { gap: 28px; }
}

/* ======================================================================
   HERO-SLIDER (neueste Filme)
   ====================================================================== */
.ed-hero-slider { position: relative; min-height: 78vh; overflow: hidden; }
.ed-hero-slider .ed-hero { position: absolute; inset: 0; min-height: 0; opacity: 0; transition: opacity .7s ease; pointer-events: none; }
.ed-hero-slider .ed-hero.is-active { opacity: 1; pointer-events: auto; }
.ed-hero--welcome { min-height: 78vh; }

/* Pfeile */
.ed-hero__nav {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 4;
    width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--cc-line);
    background: rgba(255,255,255,.82); color: var(--cc-ink); font-size: 1.8rem; line-height: 1;
    cursor: pointer; display: grid; place-items: center; backdrop-filter: blur(4px);
    transition: background .15s;
}
.ed-hero__nav:hover { background: #fff; }
.ed-hero__nav--prev { left: 22px; }
.ed-hero__nav--next { right: 22px; }

/* Punkte */
.ed-hero__dots { position: absolute; left: 0; right: 0; bottom: 22px; z-index: 4; display: flex; justify-content: center; gap: 10px; }
.ed-dot { width: 9px; height: 9px; border-radius: 50%; border: 0; cursor: pointer; background: rgba(22,19,17,.28); transition: background .2s, width .2s; padding: 0; }
.ed-dot:hover { background: rgba(22,19,17,.5); }
.ed-dot.is-active { background: var(--cc-red); width: 26px; border-radius: 5px; }

@media (max-width: 640px) {
    .ed-hero__nav { width: 38px; height: 38px; font-size: 1.4rem; }
    .ed-hero__nav--prev { left: 10px; }
    .ed-hero__nav--next { right: 10px; }
}

/* ---- Detail: Handlung + hervorgehobene Kritik-Box -------------------- */
.cc-review__trailer, .cc-review__edit { width: 100%; }
.cc-synopsis { margin-bottom: 40px; }
.cc-synopsis .cc-h2--bar { font-size: 1.4rem; margin-bottom: 16px; }
.cc-synopsis .cc-prose { font-size: 1.08rem; }

.cc-critic {
    background: var(--cc-surface);
    border: 1px solid var(--cc-line);
    border-left: 5px solid var(--cc-red);
    border-radius: 0 16px 16px 0;
    box-shadow: var(--cc-shadow);
    padding: 30px 34px;
}
.cc-critic__head { display: flex; align-items: center; gap: 14px; padding-bottom: 18px; margin-bottom: 22px; border-bottom: 1px solid var(--cc-line); }
.cc-critic__avatar { width: 46px; height: 46px; border-radius: 50%; background: var(--cc-red); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: 1.2rem; flex: none; }
.cc-critic__label { display: block; font-family: var(--cc-mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .12em; color: var(--cc-red); }
.cc-critic__by { font-size: 1.05rem; font-weight: 800; color: var(--cc-ink); }
.cc-critic__score { margin-left: auto; font-size: 1.8rem; font-weight: 900; color: var(--cc-ink); line-height: 1; }
.cc-critic__score span { font-size: .9rem; font-weight: 700; color: var(--cc-ink-3); }
.cc-critic__headline { font-size: 1.7rem; font-weight: 800; letter-spacing: -.02em; color: var(--cc-ink); margin: 0 0 18px; }
.cc-critic--empty { border-left-color: var(--cc-line); text-align: center; color: var(--cc-ink-2); }
.cc-critic--empty p { margin: 0 0 16px; }

/* Zitat-Quelle (cite) in Kritik-Zitaten */
.cc-prose blockquote { position: relative; }
.cc-prose blockquote cite {
    display: block; margin-top: 14px; font-style: normal; font-weight: 700;
    font-family: var(--cc-mono); font-size: .78rem; text-transform: uppercase;
    letter-spacing: .08em; color: var(--cc-red);
}

/* Hero-Lesbarkeit auf Mobil: stärkere Überblendung hinter dem Text */
@media (max-width: 760px) {
    .home-ed .ed-hero::before {
        background:
            linear-gradient(to top,
                var(--cc-bg) 20%,
                rgba(238,240,242,.94) 46%,
                rgba(238,240,242,.78) 70%,
                rgba(238,240,242,.45) 100%);
    }
    .home-ed .ed-hero__title { font-size: clamp(2.1rem, 9vw, 3rem); }
    .home-ed .ed-hero__text {
        color: var(--cc-ink); font-size: 1rem; line-height: 1.5;
        display: -webkit-box; -webkit-line-clamp: 3; line-clamp: 3;
        -webkit-box-orient: vertical; overflow: hidden;
    }
    /* Pfeile auf Mobil ausblenden (überlappten den Titel) – Punkte + Auto-Wechsel reichen */
    .ed-hero__nav { display: none; }
    .ed-hero__dots { bottom: 14px; }
}

/* ======================================================================
   PHASE 2 – Accounts, Bewertungen, Community
   ====================================================================== */

/* Header: Login-Link + User-Chip */
.cc-header__login { font-weight: 600; color: var(--cc-ink); text-decoration: none; }
.cc-header__login:hover { color: var(--cc-red); }
.cc-userchip { display: inline-flex; align-items: center; gap: 9px; text-decoration: none; background: var(--cc-bg-2); border: 1px solid var(--cc-line); border-radius: 999px; padding: 5px 14px 5px 5px; }
.cc-userchip:hover { border-color: var(--cc-red); }
.cc-userchip__av { width: 30px; height: 30px; border-radius: 50%; background: var(--cc-red); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: .9rem; }
.cc-userchip__name { font-weight: 700; color: var(--cc-ink); font-size: .95rem; }
@media (max-width: 900px) { .cc-header__login, .cc-userchip__name { display: none; } }

/* Hero: zwei Score-Boxen (Kritiker + Community) gestapelt */
.cc-dhero__scores { display: flex; flex-direction: column; gap: 14px; flex: none; }
.cc-score--community { border-top: 3px solid var(--cc-steel); }

/* Community-Score auf Profil-Postern */
.cc-poster__score { position: absolute; top: 8px; right: 8px; background: var(--cc-ink); color: #fff; font-weight: 800; font-size: .9rem; padding: 3px 8px; border-radius: 8px; }
.cc-poster__score small { font-weight: 600; opacity: .7; font-size: .7em; }

/* Auth-Seiten */
.cc-auth { display: flex; justify-content: center; padding: 60px 0 80px; }
.cc-auth__card { width: 100%; max-width: 440px; background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: 18px; box-shadow: var(--cc-shadow); padding: 38px 36px; }
.cc-auth__title { font-size: 2rem; font-weight: 900; letter-spacing: -.02em; margin: 8px 0 22px; }
.cc-auth__error { background: #fdecec; border: 1px solid #f4c9cb; color: #a3171e; border-radius: 10px; padding: 11px 14px; font-size: .92rem; margin: 0 0 18px; }
.cc-auth__form { display: flex; flex-direction: column; gap: 16px; }
.cc-field { display: flex; flex-direction: column; gap: 6px; }
.cc-field > span { font-weight: 700; font-size: .9rem; color: var(--cc-ink); }
.cc-field > span em { font-weight: 400; color: var(--cc-ink-3); font-style: normal; }
.cc-field input { border: 1px solid var(--cc-line); border-radius: 10px; padding: 12px 14px; font-size: 1rem; font-family: var(--cc-sans); background: #fff; color: var(--cc-ink); }
.cc-field input:focus { outline: 2px solid var(--cc-red); border-color: var(--cc-red); }
.cc-field small { color: var(--cc-ink-3); font-size: .8rem; }
.cc-auth__submit { width: 100%; padding: 13px; margin-top: 4px; font-size: 1rem; }
.cc-auth__alt { margin: 20px 0 0; text-align: center; color: var(--cc-ink-2); }
.cc-auth__alt a { color: var(--cc-red); font-weight: 700; text-decoration: none; }

/* Bewertungs-Widget (Detailseite, Aside) */
.cc-rate { background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: 14px; box-shadow: var(--cc-shadow); padding: 18px; text-align: center; }
.cc-rate__label { display: block; font-family: var(--cc-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .1em; color: var(--cc-ink-3); margin-bottom: 10px; }
.cc-rate__stars, .cc-stars10 { display: flex; justify-content: center; gap: 2px; }
/* umgekehrte Reihenfolge (10→1) für den Fill-Effekt nach links */
.cc-rate__stars { flex-direction: row-reverse; }
.cc-star10 { background: none; border: 0; padding: 1px; cursor: pointer; font-size: 1.32rem; line-height: 1; color: #cfd4da; transition: color .1s, transform .1s; }
/* dauerhaft gewählte Wertung */
.cc-star10.is-on { color: var(--cc-gold); }
/* beim Hover erst alle zurücksetzen, dann den überfahrenen + alle davor füllen */
.cc-rate__stars:hover .cc-star10 { color: #cfd4da; }
.cc-rate__stars .cc-star10:hover,
.cc-rate__stars .cc-star10:hover ~ .cc-star10 { color: var(--cc-gold); transform: scale(1.05); }
.cc-stars10--static .cc-star10 { color: #d7dbe0; cursor: default; }
.cc-rate__foot { margin-top: 12px; display: flex; align-items: center; justify-content: center; gap: 12px; }
.cc-rate__mine { font-weight: 800; color: var(--cc-ink); font-size: 1.05rem; }
.cc-rate__mine strong { color: var(--cc-red); font-size: 1.3rem; }
.cc-rate__rm { background: none; border: 0; color: var(--cc-ink-3); text-decoration: underline; cursor: pointer; font-size: .82rem; font-family: var(--cc-sans); }
.cc-rate__rm:hover { color: var(--cc-red); }
.cc-rate__hint { font-size: .82rem; color: var(--cc-ink-3); margin: 10px 0 0; }
.cc-rate__hint a { color: var(--cc-red); }
.cc-rate__login { width: 100%; margin-top: 12px; }
.cc-rate__remove { display: inline; margin: 0; }

/* Profil: Buchstaben-Avatar + "das bist du" */
.cc-profile__photo--user { background: var(--cc-red); color: #fff; font-size: 5rem; font-weight: 900; }
.cc-profile__you { font-size: .9rem; font-weight: 700; color: #fff; background: var(--cc-steel); border-radius: 999px; padding: 4px 12px; vertical-align: middle; margin-left: 8px; }
.cc-profile__body--full { grid-template-columns: 1fr; }

/* Farb-Akzente der drei Score-Boxen */
.cc-dhero__scores .cc-score { border-top: 3px solid var(--cc-red); }
.cc-dhero__scores .cc-score--community { border-top-color: var(--cc-steel); }
.cc-dhero__scores .cc-score--tmdb { border-top-color: #01b4e4; }

/* Mobil: alle Score-Boxen nebeneinander in EINER Zeile (kompakt) */
@media (max-width: 820px) {
    .cc-dhero__scores { flex-direction: row; width: 100%; gap: 8px; }
    .cc-dhero__scores .cc-score { flex: 1 1 0; min-width: 0; text-align: left; padding: 12px 11px; }
    .cc-dhero__scores .cc-score__cap { font-size: .58rem; letter-spacing: .06em; }
    .cc-dhero__scores .cc-score__stars { margin: 6px 0 3px; }
    .cc-dhero__scores .cc-score__stars .star { font-size: .82rem; }
    .cc-dhero__scores .cc-score__num { font-size: 1.5rem; }
    .cc-dhero__scores .cc-score__num span { font-size: .8rem; }
    .cc-dhero__scores .cc-score__src { font-size: .6rem; }
}

/* ======================================================================
   Prozent-Ringe, Kommentar-Feld, Community-Stimmen
   ====================================================================== */

/* Runder Prozent-Ring */
.cc-ring {
    position: relative; width: 84px; height: 84px; border-radius: 50%;
    display: grid; place-items: center; margin: 10px auto 8px;
    background: conic-gradient(var(--ring) calc(var(--pct) * 3.6deg), var(--cc-line) 0);
}
.cc-ring::after { content: ""; position: absolute; inset: 7px; border-radius: 50%; background: var(--cc-surface); }
.cc-ring__val { position: relative; z-index: 1; font-weight: 900; font-size: 1.4rem; color: var(--cc-ink); letter-spacing: -.02em; }
.cc-ring__val small { font-size: .55em; font-weight: 700; color: var(--cc-ink-3); }

/* Score-Boxen mit Ring zentrieren */
.cc-dhero__scores .cc-score { text-align: center; }

@media (max-width: 820px) {
    .cc-dhero__scores .cc-score { text-align: center; padding: 12px 8px; }
    .cc-ring { width: 60px; height: 60px; margin: 8px auto 6px; }
    .cc-ring::after { inset: 5px; }
    .cc-ring__val { font-size: 1rem; }
}

/* Kommentar-Feld im Bewerten-Widget */
.cc-rate__form { display: flex; flex-direction: column; align-items: center; }
.cc-rate__comment {
    width: 100%; margin-top: 12px; border: 1px solid var(--cc-line); border-radius: 10px;
    padding: 10px 12px; font-family: var(--cc-sans); font-size: .92rem; color: var(--cc-ink);
    resize: vertical; background: #fff;
}
.cc-rate__comment:focus { outline: 2px solid var(--cc-red); border-color: var(--cc-red); }
.cc-rate__save { width: 100%; margin-top: 10px; }
.cc-rate__save[disabled] { opacity: .5; cursor: not-allowed; }
.cc-rate__remove { margin-top: 10px; }

/* Community-Stimmen */
.cc-voices { margin-bottom: 56px; }
.cc-voices__list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.cc-voice { background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: 14px; box-shadow: var(--cc-shadow); padding: 22px 24px; }
.cc-voice__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.cc-voice__stars .star { color: rgba(0,0,0,.16); }
.cc-voice__stars .star--on { color: var(--cc-gold); }
.cc-voice__date { font-family: var(--cc-mono); font-size: .76rem; color: var(--cc-ink-3); }
.cc-voice__text { font-size: 1.05rem; line-height: 1.55; color: var(--cc-ink-2); margin: 0 0 18px; }
.cc-voice__user { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.cc-voice__av { width: 38px; height: 38px; border-radius: 50%; background: var(--cc-steel); color: #fff; display: grid; place-items: center; font-weight: 800; }
.cc-voice__user strong { color: var(--cc-ink); font-weight: 700; }
.cc-voice__user:hover strong { color: var(--cc-red); }
.cc-voice__score { margin-left: auto; font-family: var(--cc-mono); font-weight: 700; color: var(--cc-ink-3); font-size: .85rem; }

@media (max-width: 700px) { .cc-voices__list { grid-template-columns: 1fr; } }

/* Sidebar: letzte Community-Kommentare (Startseite) */
.cc-sidecoms { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.cc-sidecom { display: block; text-decoration: none; background: var(--cc-bg-2); border: 1px solid var(--cc-line); border-radius: 12px; padding: 14px; }
.cc-sidecom:hover { border-color: #cdd3da; }
.cc-sidecom__head { display: flex; align-items: center; gap: 9px; margin-bottom: 8px; }
.cc-sidecom__av { width: 28px; height: 28px; border-radius: 50%; background: var(--cc-steel); color: #fff; display: grid; place-items: center; font-weight: 800; font-size: .8rem; flex: none; }
.cc-sidecom__head strong { color: var(--cc-ink); font-weight: 700; font-size: .9rem; }
.cc-sidecom__score { margin-left: auto; font-family: var(--cc-mono); font-weight: 700; font-size: .76rem; color: var(--cc-ink-3); }
.cc-sidecom__text { font-size: .9rem; line-height: 1.45; color: var(--cc-ink-2); margin: 0 0 8px; }
.cc-sidecom__title { font-family: var(--cc-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--cc-red); }

/* Admin-Link im Header */
.cc-header__admin { color: var(--cc-red); font-weight: 800; }

/* ======================================================================
   ADMIN-BEREICH (cc-Look + mobil-optimiert)
   ====================================================================== */
.cc .admin { padding-top: 26px; padding-bottom: 60px; }
.cc .admin__head { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 22px; }
.cc .admin .page__title { font-size: 2rem; font-weight: 900; letter-spacing: -.02em; color: var(--cc-ink); margin: 0; }
.cc .admin-card { background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: var(--cc-radius); box-shadow: var(--cc-shadow); padding: 24px; margin-bottom: 24px; }
.cc .admin-card__title { font-size: 1.2rem; font-weight: 800; color: var(--cc-ink); margin: 0 0 16px; }

.cc .admin-search { display: flex; gap: 10px; }
.cc .admin-search input { flex: 1; min-width: 0; border: 1px solid var(--cc-line); border-radius: 10px; padding: 11px 14px; font-family: var(--cc-sans); font-size: 1rem; background: #fff; color: var(--cc-ink); }
.cc .admin-search input:focus { outline: 2px solid var(--cc-red); border-color: var(--cc-red); }

.cc .admin-results { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }
.cc .admin-result { display: flex; align-items: center; gap: 12px; padding: 8px 10px; border: 1px solid var(--cc-line); border-radius: 10px; background: var(--cc-bg); }
.cc .admin-result__poster { width: 40px; flex: none; }
.cc .admin-result__poster img { width: 40px; border-radius: 6px; display: block; }
.cc .admin-result__info { flex: 1; min-width: 0; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cc .admin-result__info strong { color: var(--cc-ink); }
.cc .admin-result .btn { flex: none; }

/* Kritik-Liste als Karten (ersetzt die Tabelle) */
.cc-adminlist { display: flex; flex-direction: column; gap: 12px; }
.cc-adminrow { display: flex; align-items: center; gap: 16px; padding: 12px; border: 1px solid var(--cc-line); border-radius: 12px; background: var(--cc-bg); }
.cc-adminrow__media { display: flex; align-items: center; gap: 12px; text-decoration: none; flex: 1; min-width: 0; }
.cc-adminrow__thumb { width: 42px; height: 63px; object-fit: cover; border-radius: 6px; flex: none; }
.cc-adminrow__title { font-weight: 700; color: var(--cc-ink); }
.cc-adminrow__media:hover .cc-adminrow__title { color: var(--cc-red); }
.cc-adminrow__meta { display: flex; align-items: center; gap: 12px; flex: none; }
.cc-adminrow__rating { font-family: var(--cc-mono); font-weight: 700; color: var(--cc-ink); }
.cc-adminrow__date { font-family: var(--cc-mono); font-size: .78rem; color: var(--cc-ink-3); }
.cc-adminrow__actions { display: flex; align-items: center; gap: 8px; flex: none; }
.cc-adminrow__actions form { margin: 0; }

.cc .pill { display: inline-block; font-family: var(--cc-mono); font-size: .64rem; text-transform: uppercase; letter-spacing: .05em; padding: 3px 8px; border-radius: 999px; font-weight: 700; }
.cc .pill--green { background: #e3f3e8; color: #1c7a3e; }
.cc .pill--gray { background: var(--cc-bg-2); color: var(--cc-ink-2); }

/* Edit-Formular */
.cc .edit-layout { display: grid; grid-template-columns: 210px 1fr; gap: 24px; align-items: start; }
.cc .edit-movie__poster { width: 100%; border-radius: 12px; box-shadow: var(--cc-shadow); margin-bottom: 12px; }
.cc .edit-movie__title { font-size: 1.05rem; font-weight: 800; color: var(--cc-ink); margin: 0 0 10px; }
.cc .field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.cc .field__label { font-weight: 700; font-size: .9rem; color: var(--cc-ink); }
.cc .field input:not([type=checkbox]):not([type=radio]), .cc .field textarea { width: 100%; border: 1px solid var(--cc-line); border-radius: 10px; padding: 11px 14px; font-family: var(--cc-sans); font-size: 1rem; background: #fff; color: var(--cc-ink); }
.cc .field textarea { resize: vertical; }
.cc .field input:focus, .cc .field textarea:focus { outline: 2px solid var(--cc-red); border-color: var(--cc-red); }

/* Klar gestapelte Optionen (Veröffentlichen / Empfehlung / Kritiker-Tipp) */
.cc-checks { display: flex; flex-direction: column; gap: 10px; margin-bottom: 22px; }
.cc-check { display: flex; align-items: flex-start; gap: 13px; padding: 13px 15px; border: 1px solid var(--cc-line); border-radius: 12px; background: var(--cc-bg); cursor: pointer; transition: border-color .12s, background .12s; }
.cc-check:hover { border-color: #cdd3da; }
.cc-check:has(input:checked) { border-color: var(--cc-red); background: #fbf2f2; }
.cc-check input[type=checkbox] { width: 20px; height: 20px; flex: none; margin: 1px 0 0; accent-color: var(--cc-red); cursor: pointer; }
.cc-check__text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cc-check__text strong { color: var(--cc-ink); font-weight: 700; font-size: .98rem; }
.cc-check__text small { color: var(--cc-ink-3); font-size: .82rem; line-height: 1.4; }
.cc .field-row { display: flex; flex-wrap: wrap; gap: 14px 20px; align-items: center; margin-bottom: 18px; }
.cc .field--narrow { width: 130px; margin-bottom: 0; }
.cc .field--check { flex-direction: row; align-items: center; gap: 8px; margin-bottom: 0; }
.cc .field__hint { color: var(--cc-ink-3); font-size: .82rem; }
.cc .field-group { border: 1px solid var(--cc-line); border-radius: 12px; padding: 16px 18px; margin-bottom: 16px; }
.cc .field-group legend { font-weight: 800; color: var(--cc-ink); padding: 0 6px; }
.cc .edit-form__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.cc .delete-form { margin-top: 20px; }

@media (max-width: 760px) {
    .cc .admin .page__title { font-size: 1.55rem; }
    .cc .admin-card { padding: 16px; }
    .cc .edit-layout { grid-template-columns: 1fr; }
    .cc .edit-movie { max-width: 190px; }
    .cc-adminrow { flex-wrap: wrap; gap: 10px; }
    .cc-adminrow__media { flex-basis: 100%; }
    .cc-adminrow__meta { flex-wrap: wrap; gap: 8px 12px; }
    .cc-adminrow__actions { margin-left: auto; }
}
@media (max-width: 480px) {
    .cc .admin-search { flex-direction: column; }
    .cc .admin-search .btn { width: 100%; }
    .cc .admin-result { flex-wrap: wrap; }
    .cc .admin-result .btn { width: 100%; }
}

/* ======================================================================
   LISTEN-/BROWSE-/KRITIKEN-/FEHLER-SEITEN (cc-Look + mobil)
   ====================================================================== */
.cc .page { padding-top: 34px; padding-bottom: 64px; }
.cc .page--center { text-align: center; padding-top: 70px; padding-bottom: 100px; }
.cc .page__title { font-size: clamp(1.8rem, 4.5vw, 2.6rem); font-weight: 900; letter-spacing: -.02em; color: var(--cc-ink); margin: 0 0 26px; display: flex; align-items: baseline; gap: 10px 14px; flex-wrap: wrap; }
.cc .page__title::after { content: ""; flex-basis: 100%; height: 4px; max-width: 56px; background: var(--cc-red); border-radius: 2px; margin-top: 8px; }
.cc .page__count { font-family: var(--cc-mono); font-size: .8rem; font-weight: 400; color: var(--cc-ink-3); }
.cc .muted { color: var(--cc-ink-3); }

/* Poster-Grid + Karten */
.cc .grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 26px 20px; }
.cc .card { position: relative; display: flex; flex-direction: column; }
.cc .card__poster { position: relative; display: block; aspect-ratio: 2/3; border-radius: 12px; overflow: hidden; background: var(--cc-bg-2); box-shadow: var(--cc-shadow); }
.cc .card__poster img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .25s; }
.cc .card__poster:hover img { transform: scale(1.04); }
.cc .card__noimg { position: absolute; inset: 0; display: grid; place-items: center; padding: 10px; text-align: center; color: var(--cc-ink-3); font-weight: 700; font-size: .85rem; }
.cc .card__badge { position: absolute; top: 8px; left: 8px; z-index: 2; background: var(--cc-red); color: #fff; font-family: var(--cc-mono); font-size: .58rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 7px; border-radius: 4px; }
.cc .card__score { position: relative; margin: -26px 0 0 8px; z-index: 3; width: max-content; }
.cc .card__meta { padding-top: 10px; }
.cc .card__title { font-size: 1rem; font-weight: 700; line-height: 1.25; margin: 0 0 2px; }
.cc .card__title a { color: var(--cc-ink); text-decoration: none; }
.cc .card__title a:hover { color: var(--cc-red); }
.cc .card__date { font-family: var(--cc-mono); font-size: .74rem; color: var(--cc-ink-3); }

/* Score-Ring (Browse-Karten) – helles, konsistentes Badge */
.cc .ring { position: relative; display: grid; place-items: center; background: var(--cc-surface); border-radius: 50%; box-shadow: 0 2px 8px rgba(20,24,33,.2); }
.cc .ring svg { position: absolute; inset: 0; }
.cc .ring__track { stroke: var(--cc-line); }
.cc .ring__bar { stroke: var(--cc-red); }
.cc .ring--high .ring__bar { stroke: #2e9e4f; }
.cc .ring--mid .ring__bar  { stroke: #d9a23a; }
.cc .ring--low .ring__bar  { stroke: var(--cc-red); }
.cc .ring--none .ring__bar { stroke: var(--cc-line); }
.cc .ring__label { position: relative; z-index: 1; color: var(--cc-ink); font-weight: 800; }
.cc .ring--none .ring__label { color: var(--cc-ink-3); }
.cc .ring__pct { font-size: .6em; vertical-align: super; color: var(--cc-ink-3); }

/* Pager */
.cc .pager { display: flex; align-items: center; justify-content: center; gap: 18px; margin-top: 46px; }
.cc .pager__pos { font-family: var(--cc-mono); font-size: .82rem; color: var(--cc-ink-3); }

/* Kritiken-Liste */
.cc .review-list { display: flex; flex-direction: column; gap: 18px; }
.cc .review-item { display: flex; gap: 18px; background: var(--cc-surface); border: 1px solid var(--cc-line); border-radius: 14px; box-shadow: var(--cc-shadow); padding: 16px; text-decoration: none; transition: transform .15s, box-shadow .15s; }
.cc .review-item:hover { transform: translateY(-2px); box-shadow: 0 16px 38px rgba(20,24,33,.13); }
.cc .review-item__poster { width: 94px; flex: none; border-radius: 10px; overflow: hidden; background: var(--cc-bg-2); align-self: flex-start; }
.cc .review-item__poster img { width: 100%; display: block; }
.cc .review-item__body { flex: 1; min-width: 0; }
.cc .review-item__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.cc .review-item__title { font-size: 1.3rem; font-weight: 800; color: var(--cc-ink); margin: 0; line-height: 1.2; }
.cc .review-item__title .muted { font-weight: 600; }
.cc .review-item__headline { font-size: 1rem; color: var(--cc-red); font-weight: 700; margin: 8px 0 6px; }
.cc .review-item__excerpt { color: var(--cc-ink-2); margin: 0; line-height: 1.55; }
.cc .rec-badge { display: inline-block; margin-top: 10px; background: var(--cc-bg-2); border: 1px solid var(--cc-line); color: var(--cc-ink); font-size: .78rem; font-weight: 700; padding: 3px 10px; border-radius: 999px; }
.cc .rec-badge--sm { font-size: .72rem; }

/* Fehlerseiten */
.cc .error-code { font-size: clamp(4rem, 16vw, 7rem); font-weight: 900; color: var(--cc-red); margin: 0 0 6px; letter-spacing: -.04em; line-height: 1; }

@media (max-width: 600px) {
    .cc .grid { grid-template-columns: repeat(2, 1fr); gap: 20px 14px; }
    .cc .review-item { gap: 12px; padding: 12px; }
    .cc .review-item__poster { width: 72px; }
    .cc .review-item__title { font-size: 1.1rem; }
    .cc .review-item__top { flex-wrap: wrap; }
    .cc .pager { gap: 12px; }
}
