:root {
    --demo-cyan: #18b7b9;
    --demo-cyan-dark: #0f8f91;
    --demo-ink: #101820;
    --demo-purple: #7c3cff;
    --demo-pink: #ff3d8b;
    --demo-yellow: #ffd84d;
    --demo-muted: rgba(255,255,255,.72);
}

.foto-demo-body {
    min-height: 100vh;
    margin: 0;
    background: var(--demo-ink);
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.foto-demo-entry {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    color: #fff;
}

.foto-demo-bg {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(10,16,24,.96) 0%, rgba(10,16,24,.78) 44%, rgba(10,16,24,.36) 100%),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
    transform: scale(1.04);
}

.foto-demo-glow {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 16% 24%, rgba(24,183,185,.38), transparent 30rem),
        radial-gradient(circle at 82% 18%, rgba(255,61,139,.28), transparent 28rem),
        radial-gradient(circle at 68% 82%, rgba(124,60,255,.28), transparent 30rem);
}

.min-vh-demo {
    min-height: 100vh;
    padding-top: clamp(3rem, 6vw, 6rem);
    padding-bottom: clamp(3rem, 6vw, 6rem);
}

.demo-entry-copy {
    position: relative;
    z-index: 2;
}

.demo-back-link {
    display: inline-flex;
    margin-bottom: 1.5rem;
    color: rgba(255,255,255,.78);
    text-decoration: none;
    font-weight: 800;
}

.demo-back-link:hover {
    color: #fff;
}

.demo-kicker {
    display: inline-flex;
    padding: .6rem 1rem;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.22);
    backdrop-filter: blur(18px);
    font-weight: 900;
}

.demo-entry-copy h1 {
    margin: 1.4rem 0 0;
    max-width: 800px;
    font-size: clamp(3.2rem, 7vw, 7.2rem);
    line-height: .88;
    letter-spacing: -.08em;
    font-weight: 950;
}

.demo-entry-copy h1 span {
    display: block;
    color: #a4f4f5;
}

.demo-entry-copy p {
    max-width: 680px;
    margin-top: 1.7rem;
    color: var(--demo-muted);
    font-size: clamp(1.08rem, 1.55vw, 1.32rem);
    line-height: 1.72;
}

.demo-facts {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1.8rem;
}

.demo-facts span {
    display: inline-flex;
    padding: .65rem .9rem;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.86);
    font-weight: 800;
    backdrop-filter: blur(14px);
}

.demo-access-grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 1200px) {
    .demo-access-grid {
        grid-template-columns: 1fr 1fr;
    }

    .admin-card {
        transform: translateY(44px);
    }
}

.demo-access-card {
    position: relative;
    overflow: hidden;
    min-height: 440px;
    padding: clamp(1.4rem, 3vw, 2rem);
    border-radius: 36px;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.24);
    backdrop-filter: blur(28px);
    box-shadow: 0 36px 120px rgba(0,0,0,.30);
    color: #fff;
    display: flex;
    flex-direction: column;
}

.demo-access-card::before {
    content: "";
    position: absolute;
    inset: -40% -30% auto auto;
    width: 260px;
    height: 260px;
    border-radius: 50%;
    background: rgba(24,183,185,.26);
    filter: blur(4px);
}

.admin-card::before {
    background: rgba(255,61,139,.24);
}

.access-icon {
    position: relative;
    z-index: 2;
    width: 64px;
    height: 64px;
    border-radius: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    color: #fff;
    font-size: 1.5rem;
    font-weight: 950;
    box-shadow: 0 22px 55px rgba(24,183,185,.28);
}

.admin-card .access-icon {
    background: linear-gradient(135deg, var(--demo-pink), var(--demo-yellow));
    color: #1a1300;
}

.demo-access-card h2 {
    position: relative;
    z-index: 2;
    font-size: 2rem;
    line-height: 1;
    letter-spacing: -.05em;
    font-weight: 950;
}

.demo-access-card p {
    position: relative;
    z-index: 2;
    margin-top: .8rem;
    color: rgba(255,255,255,.76);
    line-height: 1.65;
}

.demo-access-card ul {
    position: relative;
    z-index: 2;
    margin: 1rem 0 1.5rem;
    padding-left: 1.1rem;
    color: rgba(255,255,255,.80);
    line-height: 1.8;
}

.demo-access-card .btn {
    position: relative;
    z-index: 2;
    margin-top: auto;
    border-radius: 999px;
    padding: .9rem 1.1rem;
    font-weight: 950;
}

.demo-btn-primary {
    border: 0;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    color: #fff;
}

.demo-btn-primary:hover {
    color: #fff;
    transform: translateY(-1px);
}

.demo-btn-glass {
    border: 1px solid rgba(255,255,255,.34);
    background: rgba(255,255,255,.13);
    color: #fff;
}

.demo-btn-glass:hover {
    color: #fff;
    background: rgba(255,255,255,.22);
}

@media (max-width: 991.98px) {
    .demo-entry-copy h1 {
        max-width: 760px;
    }

    .demo-access-card {
        min-height: auto;
    }
}

@media (max-width: 575.98px) {
    .demo-entry-copy h1 {
        letter-spacing: -.055em;
    }

    .demo-facts span {
        border-radius: 18px;
    }
}

/* ------------------------------------------------------------
   Kundenlogin / Demo-Login
------------------------------------------------------------ */

.foto-login-page {
    position: relative;
    min-height: 100vh;
    overflow: hidden;
    color: #fff;
}

.foto-login-bg {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(10,16,24,.96) 0%, rgba(10,16,24,.72) 48%, rgba(10,16,24,.28) 100%),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
    transform: scale(1.04);
}

.foto-login-glow {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 22%, rgba(24,183,185,.34), transparent 30rem),
        radial-gradient(circle at 82% 20%, rgba(255,61,139,.28), transparent 28rem),
        radial-gradient(circle at 70% 82%, rgba(124,60,255,.30), transparent 30rem);
}

.login-glass-card {
    position: relative;
    z-index: 2;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    border-radius: 38px;
    background: rgba(255,255,255,.16);
    border: 1px solid rgba(255,255,255,.26);
    backdrop-filter: blur(30px);
    box-shadow: 0 36px 120px rgba(0,0,0,.34);
    color: #fff;
}

.login-card-icon {
    width: 70px;
    height: 70px;
    border-radius: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    color: #fff;
    font-size: 1.7rem;
    font-weight: 950;
    box-shadow: 0 24px 60px rgba(24,183,185,.30);
}

.login-glass-card h2 {
    font-size: clamp(2rem, 3vw, 2.7rem);
    line-height: .98;
    letter-spacing: -.055em;
    font-weight: 950;
    margin-bottom: 1rem;
}

.login-glass-card p {
    color: rgba(255,255,255,.76);
    line-height: 1.65;
    margin-bottom: 1.5rem;
}

.login-glass-card p strong {
    color: #fff;
}

.login-glass-card .form-control {
    height: calc(4rem + 2px);
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.28);
    background: rgba(255,255,255,.88);
    font-weight: 900;
    letter-spacing: .05em;
}

.login-glass-card .form-control:focus {
    border-color: var(--demo-cyan);
    box-shadow: 0 0 0 .25rem rgba(24,183,185,.22);
}

.login-glass-card .form-floating > label {
    color: #667085;
}

.login-card-note {
    margin-top: 1.4rem;
    padding: .9rem 1rem;
    border-radius: 20px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.78);
    font-weight: 800;
    text-align: center;
}

@media (max-width: 991.98px) {
    .login-glass-card {
        max-width: 560px;
        margin: 0 auto;
    }
}

/* ------------------------------------------------------------
   Login-Seite: mehr Luft und bessere Zentrierung
------------------------------------------------------------ */

.foto-login-container {
    padding-left: clamp(1.25rem, 4vw, 4rem);
    padding-right: clamp(1.25rem, 4vw, 4rem);
}

.foto-login-page .row {
    margin-left: 0;
    margin-right: 0;
}

.login-glass-card {
    max-width: 520px;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 992px) {
    .login-glass-card {
        margin-left: auto;
        margin-right: 0;
    }
}

@media (max-width: 991.98px) {
    .foto-login-container {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .login-glass-card {
        margin-top: 1rem;
        margin-bottom: 2rem;
    }
}

@media (max-width: 575.98px) {
    .foto-login-container {
        padding-left: .85rem;
        padding-right: .85rem;
    }

    .login-glass-card {
        border-radius: 28px;
        padding: 1.25rem;
    }
}

/* ------------------------------------------------------------
   Galerie / Kundenauswahl
------------------------------------------------------------ */

.foto-gallery-body {
    background:
        radial-gradient(circle at top left, rgba(24,183,185,.18), transparent 28rem),
        radial-gradient(circle at top right, rgba(255,61,139,.12), transparent 26rem),
        #101820;
}

.gallery-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(16, 24, 32, .82);
    backdrop-filter: blur(22px);
    border-bottom: 1px solid rgba(255,255,255,.12);
}

.gallery-header-inner {
    min-height: 76px;
    padding: 0 clamp(1rem, 4vw, 3rem);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.gallery-brand {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    color: #fff;
    text-decoration: none;
}

.gallery-brand span {
    width: 44px;
    height: 44px;
    border-radius: 17px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    font-weight: 950;
}

.gallery-brand strong {
    font-weight: 950;
    letter-spacing: -.03em;
}

.gallery-nav {
    display: flex;
    gap: .65rem;
    flex-wrap: wrap;
}

.gallery-nav a {
    color: rgba(255,255,255,.78);
    text-decoration: none;
    font-weight: 800;
    padding: .55rem .8rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.14);
}

.gallery-nav a:hover {
    color: #fff;
    background: rgba(255,255,255,.12);
}

.gallery-page {
    color: #fff;
}

.gallery-hero {
    padding: clamp(3rem, 7vw, 6rem) 0 clamp(2rem, 5vw, 4rem);
    background:
        linear-gradient(180deg, rgba(16,24,32,.88), rgba(16,24,32,.48)),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
}

.gallery-hero h1 {
    margin: 1.2rem 0 0;
    max-width: 980px;
    font-size: clamp(3rem, 6vw, 6.5rem);
    line-height: .9;
    letter-spacing: -.075em;
    font-weight: 950;
}

.gallery-hero h1 span {
    display: block;
    color: #a4f4f5;
}

.gallery-hero p {
    max-width: 720px;
    margin-top: 1.4rem;
    color: rgba(255,255,255,.78);
    font-size: 1.15rem;
    line-height: 1.75;
}

.gallery-summary-card {
    padding: 1.4rem;
    border-radius: 32px;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.22);
    backdrop-filter: blur(24px);
    box-shadow: 0 30px 90px rgba(0,0,0,.24);
}

.summary-line {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: .8rem 0;
    border-bottom: 1px solid rgba(255,255,255,.12);
}

.summary-line span {
    color: rgba(255,255,255,.72);
    font-weight: 800;
}

.summary-line strong {
    color: #fff;
    font-weight: 950;
}

.gallery-content {
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
}

.gallery-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1400px) {
    .gallery-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.gallery-photo-card {
    overflow: hidden;
    border-radius: 34px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(18px);
    box-shadow: 0 26px 80px rgba(0,0,0,.20);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.gallery-photo-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 36px 110px rgba(0,0,0,.28);
}

.gallery-photo-card.is-selected {
    border-color: rgba(24,183,185,.75);
    box-shadow: 0 36px 120px rgba(24,183,185,.22);
}

.gallery-photo-card.is-released {
    border-color: rgba(255,216,77,.72);
}

.gallery-photo-image {
    position: relative;
    min-height: 330px;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(24,183,185,.28), rgba(124,60,255,.20)),
        repeating-linear-gradient(45deg, rgba(255,255,255,.10), rgba(255,255,255,.10) 10px, rgba(255,255,255,.04) 10px, rgba(255,255,255,.04) 20px);
}

.gallery-photo-image img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 360px;
    object-fit: cover;
    display: block;
}

.gallery-photo-image img.is-missing {
    display: none;
}

.gallery-photo-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    text-align: center;
    color: rgba(255,255,255,.72);
    font-size: 2rem;
    font-weight: 950;
    letter-spacing: -.05em;
}

.gallery-watermark {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    z-index: 4;
    padding: .5rem .8rem;
    border-radius: 999px;
    background: rgba(255,255,255,.78);
    color: #101820;
    font-size: .82rem;
    font-weight: 950;
    box-shadow: 0 14px 40px rgba(0,0,0,.18);
}

.photo-heart {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 5;
    width: 52px;
    height: 52px;
    border: 0;
    border-radius: 50%;
    background: rgba(255,255,255,.86);
    color: var(--demo-pink);
    font-size: 1.35rem;
    font-weight: 950;
    box-shadow: 0 18px 48px rgba(0,0,0,.20);
}

.gallery-photo-card.is-selected .photo-heart {
    background: var(--demo-pink);
    color: #fff;
}

.gallery-photo-body {
    padding: 1.25rem;
}

.gallery-photo-body h2 {
    margin: 0;
    color: #fff;
    font-size: 1.35rem;
    font-weight: 950;
    letter-spacing: -.035em;
}

.gallery-photo-body p {
    margin: .35rem 0 0;
    color: rgba(255,255,255,.62);
}

.photo-status {
    display: inline-flex;
    padding: .4rem .65rem;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: rgba(255,255,255,.76);
    font-size: .8rem;
    font-weight: 900;
    white-space: nowrap;
}

.gallery-photo-card.is-selected .photo-status {
    background: rgba(24,183,185,.22);
    color: #a4f4f5;
}

.gallery-photo-card.is-released .photo-status {
    background: rgba(255,216,77,.24);
    color: #ffe891;
}

.photo-actions {
    margin-top: 1rem;
}

.demo-btn-outline {
    border: 1px solid rgba(255,255,255,.24);
    background: rgba(255,255,255,.08);
    color: #fff;
    font-weight: 900;
    border-radius: 999px;
}

.demo-btn-outline:hover {
    background: rgba(255,255,255,.18);
    color: #fff;
}

.comment-label {
    display: block;
    margin-top: 1rem;
    color: rgba(255,255,255,.78);
    font-size: .9rem;
    font-weight: 900;
}

.comment-label textarea {
    margin-top: .45rem;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.20);
    background: rgba(255,255,255,.88);
    min-height: 96px;
}

.gallery-result {
    margin-top: 2rem;
    padding: clamp(1.4rem, 4vw, 2.5rem);
    border-radius: 34px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: #fff;
}

.gallery-result h2 {
    font-weight: 950;
    letter-spacing: -.04em;
}

.gallery-result ul {
    margin-bottom: 0;
}

@media (max-width: 767.98px) {
    .gallery-header-inner {
        align-items: flex-start;
        flex-direction: column;
        padding-top: 1rem;
        padding-bottom: 1rem;
    }

    .gallery-photo-image {
        min-height: 260px;
    }

    .gallery-photo-image img {
        height: 290px;
    }
}

/* ------------------------------------------------------------
   Galerie: mehr Luft, weniger gedrückt
------------------------------------------------------------ */

.gallery-container {
    padding-left: clamp(1rem, 3vw, 2.5rem);
    padding-right: clamp(1rem, 3vw, 2.5rem);
}

.gallery-hero {
    padding: clamp(2.5rem, 5vw, 4.5rem) 0 clamp(2rem, 4vw, 3.5rem);
}

.gallery-hero h1 {
    max-width: 900px;
    font-size: clamp(2.4rem, 5vw, 5.4rem);
    line-height: .94;
}

.gallery-hero p {
    max-width: 680px;
}

.gallery-summary-card {
    max-width: 420px;
    margin-left: auto;
}

.gallery-content {
    padding-top: clamp(2rem, 4vw, 3.5rem);
}

.gallery-grid {
    gap: clamp(1rem, 2vw, 1.8rem);
}

/* Karten etwas ruhiger */
.gallery-photo-card {
    border-radius: 28px;
}

.gallery-photo-image {
    min-height: 260px;
}

.gallery-photo-image img {
    height: 300px;
}

.gallery-photo-body {
    padding: 1.1rem;
}

.gallery-photo-body h2 {
    font-size: 1.2rem;
}

.gallery-photo-body p {
    font-size: .95rem;
}

/* Nicht zu früh auf 3 Spalten gehen */
@media (min-width: 1200px) {
    .gallery-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1600px) {
    .gallery-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .gallery-summary-card {
        max-width: none;
        margin-left: 0;
    }
}

@media (max-width: 575.98px) {
    .gallery-container {
        padding-left: .9rem;
        padding-right: .9rem;
    }

    .gallery-hero h1 {
        font-size: clamp(2.2rem, 14vw, 3.6rem);
    }

    .gallery-photo-image {
        min-height: 230px;
    }

    .gallery-photo-image img {
        height: 250px;
    }
}

/* ------------------------------------------------------------
   Paketbasierte Fotoauswahl: 6 aus 12
------------------------------------------------------------ */

.foto-selection-body {
    background:
        radial-gradient(circle at top left, rgba(24,183,185,.18), transparent 28rem),
        radial-gradient(circle at top right, rgba(255,61,139,.12), transparent 26rem),
        #101820;
}

.selection-page {
    color: #fff;
}

.selection-container {
    padding-left: clamp(1rem, 3vw, 2.5rem);
    padding-right: clamp(1rem, 3vw, 2.5rem);
}

.selection-hero {
    padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3rem);
    background:
        linear-gradient(180deg, rgba(16,24,32,.90), rgba(16,24,32,.60)),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
}

.selection-hero h1 {
    margin: 1.2rem 0 0;
    max-width: 980px;
    font-size: clamp(2.7rem, 5.6vw, 6rem);
    line-height: .92;
    letter-spacing: -.075em;
    font-weight: 950;
}

.selection-hero h1 span {
    display: block;
    color: #a4f4f5;
}

.selection-hero p {
    max-width: 760px;
    margin-top: 1.4rem;
    color: rgba(255,255,255,.78);
    font-size: 1.12rem;
    line-height: 1.75;
}

.selection-summary-card {
    max-width: 430px;
    margin-left: auto;
    padding: 1.5rem;
    border-radius: 34px;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.22);
    backdrop-filter: blur(24px);
    box-shadow: 0 30px 90px rgba(0,0,0,.24);
}

.summary-label {
    color: rgba(255,255,255,.72);
    font-weight: 900;
}

.summary-big {
    margin-top: .4rem;
    font-size: clamp(3rem, 5vw, 4.8rem);
    line-height: 1;
    letter-spacing: -.06em;
    font-weight: 950;
}

.selection-summary-card p {
    color: rgba(255,255,255,.72);
    margin: .4rem 0 1rem;
}

.selection-progress {
    height: .9rem;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    overflow: hidden;
}

.selection-progress span {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    transition: width .25s ease;
}

.selection-hint {
    padding: .85rem 1rem;
    border-radius: 18px;
    background: rgba(255,255,255,.10);
    color: rgba(255,255,255,.78);
    font-weight: 800;
    text-align: center;
}

.selection-content {
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
}

.selection-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.8rem);
}

@media (min-width: 768px) {
    .selection-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1600px) {
    .selection-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.selection-photo-card {
    overflow: hidden;
    border-radius: 30px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(18px);
    box-shadow: 0 26px 80px rgba(0,0,0,.20);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, opacity .2s ease;
}

.selection-photo-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 36px 110px rgba(0,0,0,.28);
}

.selection-photo-card.is-selected {
    border-color: rgba(24,183,185,.90);
    box-shadow: 0 36px 120px rgba(24,183,185,.24);
}

.selection-photo-card.is-locked {
    opacity: .42;
}

.selection-photo-card.is-locked:hover {
    transform: none;
}

.selection-photo-image {
    position: relative;
    min-height: 270px;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(24,183,185,.28), rgba(124,60,255,.20)),
        repeating-linear-gradient(45deg, rgba(255,255,255,.10), rgba(255,255,255,.10) 10px, rgba(255,255,255,.04) 10px, rgba(255,255,255,.04) 20px);
}

.selection-photo-image img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 310px;
    object-fit: cover;
    display: block;
}

.selection-photo-image img.is-missing {
    display: none;
}

.selection-photo-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    text-align: center;
    color: rgba(255,255,255,.72);
    font-size: 2rem;
    font-weight: 950;
    letter-spacing: -.05em;
}

.selection-lock-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    text-align: center;
    background: rgba(16,24,32,.62);
    backdrop-filter: blur(6px);
}

.selection-photo-card.is-locked .selection-lock-overlay {
    display: flex;
}

.selection-lock-overlay span {
    display: block;
    font-size: 2rem;
    margin-bottom: .5rem;
}

.selection-lock-overlay strong,
.selection-lock-overlay small {
    display: block;
}

.selection-lock-overlay strong {
    font-weight: 950;
}

.selection-lock-overlay small {
    color: rgba(255,255,255,.72);
}

.selection-pick-button {
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    z-index: 6;
    border: 0;
    border-radius: 999px;
    padding: .75rem 1rem;
    background: rgba(255,255,255,.88);
    color: #101820;
    font-weight: 950;
    box-shadow: 0 18px 48px rgba(0,0,0,.20);
}

.selection-pick-button:disabled {
    cursor: not-allowed;
}

.selection-photo-card.is-selected .selection-pick-button {
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    color: #fff;
}

.pick-selected {
    display: none;
}

.selection-photo-card.is-selected .pick-default {
    display: none;
}

.selection-photo-card.is-selected .pick-selected {
    display: inline;
}

.selection-photo-body {
    padding: 1.15rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}

.selection-photo-body h2 {
    margin: 0;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 950;
    letter-spacing: -.035em;
}

.selection-photo-body p {
    margin: .35rem 0 0;
    color: rgba(255,255,255,.62);
}

.selection-status {
    display: inline-flex;
    padding: .4rem .65rem;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: rgba(255,255,255,.76);
    font-size: .8rem;
    font-weight: 900;
    white-space: nowrap;
}

.selection-photo-card.is-selected .selection-status {
    background: rgba(24,183,185,.22);
    color: #a4f4f5;
}

.selection-photo-card.is-locked .selection-status {
    background: rgba(255,255,255,.10);
    color: rgba(255,255,255,.60);
}

.selection-result {
    margin-top: 2rem;
    padding: clamp(1.4rem, 4vw, 2.5rem);
    border-radius: 34px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: #fff;
}

.selection-result h2 {
    font-weight: 950;
    letter-spacing: -.04em;
}

.selection-result-success {
    color: #a4f4f5;
}

.selection-result-warning {
    color: #ffd84d;
}

.selected-list {
    margin-top: 1.4rem;
}

.selected-list h3 {
    font-weight: 950;
}

@media (max-width: 991.98px) {
    .selection-summary-card {
        max-width: none;
        margin-left: 0;
    }
}

@media (max-width: 575.98px) {
    .selection-container {
        padding-left: .9rem;
        padding-right: .9rem;
    }

    .selection-hero h1 {
        font-size: clamp(2.2rem, 14vw, 3.6rem);
    }

    .selection-photo-image {
        min-height: 230px;
    }

    .selection-photo-image img {
        height: 250px;
    }

    .selection-photo-body {
        flex-direction: column;
    }
}

/* ------------------------------------------------------------
   Ergebnisbereich: ZIP-Hinweis direkt im Abschlussbereich
------------------------------------------------------------ */

.selection-download-area {
    margin-top: 1.6rem;
    padding: 1.2rem;
    border-radius: 26px;
    background: rgba(24,183,185,.12);
    border: 1px solid rgba(24,183,185,.22);
}

.selection-download-area > p {
    margin: .8rem 0 0;
    color: rgba(255,255,255,.72);
    font-weight: 700;
}

.selection-download-info {
    margin-top: 1rem;
    padding: 1.2rem;
    border-radius: 22px;
    background: rgba(255,255,255,.92);
    color: #101820;
    box-shadow: 0 22px 70px rgba(0,0,0,.18);
}

.selection-download-info h3 {
    margin: 0 0 .8rem;
    font-size: 1.35rem;
    font-weight: 950;
    letter-spacing: -.035em;
}

.selection-download-info p {
    color: #4f5f6a;
    line-height: 1.65;
}

.download-demo-box {
    padding: 1rem;
    border-radius: 20px;
    background: rgba(24,183,185,.10);
    color: #0f8f91;
    font-weight: 800;
}

.download-demo-small {
    margin: 1rem 0 0;
    font-size: .92rem;
}

/* ------------------------------------------------------------
   Admin-Demo Dashboard
------------------------------------------------------------ */

.admin-dashboard-body {
    background:
        radial-gradient(circle at top left, rgba(24,183,185,.18), transparent 28rem),
        radial-gradient(circle at top right, rgba(255,61,139,.12), transparent 26rem),
        #101820;
}

.admin-dashboard {
    color: #fff;
}

.admin-container {
    padding-left: clamp(1rem, 3vw, 2.5rem);
    padding-right: clamp(1rem, 3vw, 2.5rem);
}

.admin-hero {
    padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3rem);
    background:
        linear-gradient(180deg, rgba(16,24,32,.92), rgba(16,24,32,.62)),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
}

.admin-hero h1 {
    margin: 1.2rem 0 0;
    max-width: 920px;
    font-size: clamp(2.8rem, 5.8vw, 6.2rem);
    line-height: .9;
    letter-spacing: -.075em;
    font-weight: 950;
}

.admin-hero h1 span {
    display: block;
    color: #a4f4f5;
}

.admin-hero p {
    max-width: 720px;
    margin-top: 1.4rem;
    color: rgba(255,255,255,.78);
    font-size: 1.15rem;
    line-height: 1.75;
}

.admin-status-card,
.admin-kpi-card,
.admin-panel {
    border-radius: 32px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(22px);
    box-shadow: 0 26px 90px rgba(0,0,0,.22);
}

.admin-status-card {
    padding: 1.5rem;
}

.admin-status-card span,
.admin-kpi-card span,
.admin-label {
    display: inline-flex;
    color: #a4f4f5;
    font-weight: 950;
    font-size: .9rem;
    margin-bottom: .6rem;
}

.admin-status-card strong {
    display: block;
    font-size: 1.55rem;
    line-height: 1.1;
    font-weight: 950;
    letter-spacing: -.04em;
}

.admin-status-card small {
    display: block;
    margin-top: .8rem;
    color: rgba(255,255,255,.68);
    font-weight: 700;
}

.admin-content {
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
}

.admin-kpi-card {
    height: 100%;
    padding: 1.4rem;
}

.admin-kpi-card.highlight {
    border-color: rgba(24,183,185,.55);
    box-shadow: 0 28px 95px rgba(24,183,185,.18);
}

.admin-kpi-card strong {
    display: block;
    font-size: 1.55rem;
    font-weight: 950;
    letter-spacing: -.04em;
    color: #fff;
}

.admin-kpi-card small {
    display: block;
    margin-top: .65rem;
    color: rgba(255,255,255,.62);
    line-height: 1.45;
}

.admin-panel {
    padding: clamp(1.35rem, 3vw, 2rem);
}

.admin-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.admin-panel h2 {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.7rem);
    line-height: 1;
    letter-spacing: -.055em;
    font-weight: 950;
}

.admin-selected-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .9rem;
}

.admin-selected-item {
    padding: 1rem;
    border-radius: 22px;
    background:
        radial-gradient(circle at top right, rgba(24,183,185,.22), transparent 8rem),
        rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.15);
}

.admin-selected-item span {
    display: block;
    color: #fff;
    font-weight: 950;
}

.admin-selected-item small {
    color: rgba(255,255,255,.62);
    font-weight: 700;
}

.admin-note {
    padding: 1rem;
    border-radius: 22px;
    background: rgba(24,183,185,.12);
    color: rgba(255,255,255,.78);
    line-height: 1.6;
    font-weight: 700;
}

.admin-feature-list {
    display: grid;
    gap: 1rem;
    margin-top: 1.5rem;
}

.admin-feature-list div {
    padding: 1rem;
    border-radius: 22px;
    background: rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.13);
}

.admin-feature-list strong {
    display: block;
    font-weight: 950;
    color: #fff;
    margin-bottom: .35rem;
}

.admin-feature-list span {
    color: rgba(255,255,255,.66);
    line-height: 1.55;
}

.admin-icon {
    background: linear-gradient(135deg, var(--demo-pink), var(--demo-yellow));
    color: #1a1300;
}

@media (max-width: 767.98px) {
    .admin-selected-grid {
        grid-template-columns: 1fr;
    }
}

/* ------------------------------------------------------------
   Admin-Dashboard 2.0 · visuelles Projekt-Cockpit
------------------------------------------------------------ */

.adash-page {
    color: #fff;
    background:
        radial-gradient(circle at top left, rgba(24,183,185,.18), transparent 28rem),
        radial-gradient(circle at top right, rgba(255,61,139,.12), transparent 26rem),
        #101820;
    min-height: 100vh;
}

.adash-container {
    padding-left: clamp(1rem, 3vw, 2.5rem);
    padding-right: clamp(1rem, 3vw, 2.5rem);
}

.adash-hero {
    padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3rem);
    background:
        linear-gradient(180deg, rgba(16,24,32,.92), rgba(16,24,32,.58)),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
}

.adash-hero h1 {
    margin: 1.2rem 0 0;
    max-width: 980px;
    font-size: clamp(2.8rem, 5.8vw, 6.2rem);
    line-height: .9;
    letter-spacing: -.075em;
    font-weight: 950;
}

.adash-hero h1 span {
    display: block;
    color: #a4f4f5;
}

.adash-hero p {
    max-width: 760px;
    margin-top: 1.4rem;
    color: rgba(255,255,255,.78);
    font-size: 1.15rem;
    line-height: 1.75;
}

.adash-status-card,
.adash-kpi,
.adash-panel {
    border-radius: 32px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(22px);
    box-shadow: 0 26px 90px rgba(0,0,0,.22);
}

.adash-status-card {
    padding: 1.5rem;
}

.adash-status-top span,
.adash-kpi span,
.adash-label {
    display: inline-flex;
    color: #a4f4f5;
    font-size: .9rem;
    font-weight: 950;
    margin-bottom: .55rem;
}

.adash-status-top strong {
    display: block;
    font-size: 1.55rem;
    line-height: 1.1;
    letter-spacing: -.04em;
    font-weight: 950;
}

.adash-status-card p {
    margin: .8rem 0 0;
    color: rgba(255,255,255,.72);
    font-weight: 800;
}

.adash-progress {
    height: .9rem;
    margin-top: 1.2rem;
    border-radius: 999px;
    background: rgba(255,255,255,.16);
    overflow: hidden;
}

.adash-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
}

.adash-content {
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
}

.adash-kpi-row {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1rem;
}

@media (min-width: 768px) {
    .adash-kpi-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .adash-kpi-row {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.adash-kpi {
    padding: 1.3rem;
}

.adash-kpi-highlight {
    border-color: rgba(24,183,185,.56);
    box-shadow: 0 28px 95px rgba(24,183,185,.18);
}

.adash-kpi strong {
    display: block;
    color: #fff;
    font-size: 1.45rem;
    line-height: 1.1;
    font-weight: 950;
    letter-spacing: -.04em;
}

.adash-kpi small {
    display: block;
    margin-top: .65rem;
    color: rgba(255,255,255,.62);
    line-height: 1.45;
}

.adash-panel {
    padding: clamp(1.25rem, 3vw, 2rem);
}

.adash-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: 1.4rem;
}

.adash-panel h2 {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    line-height: 1;
    letter-spacing: -.055em;
    font-weight: 950;
}

.adash-photo-wall {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .9rem;
}

@media (min-width: 768px) {
    .adash-photo-wall {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1400px) {
    .adash-photo-wall {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.adash-photo {
    overflow: hidden;
    border-radius: 24px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.14);
    transition: transform .2s ease, opacity .2s ease, border-color .2s ease;
}

.adash-photo:hover {
    transform: translateY(-3px);
}

.adash-photo.is-picked {
    border-color: rgba(24,183,185,.72);
    box-shadow: 0 18px 60px rgba(24,183,185,.16);
}

.adash-photo.is-muted {
    opacity: .42;
}

.adash-photo-img {
    position: relative;
    min-height: 150px;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(24,183,185,.28), rgba(124,60,255,.20)),
        repeating-linear-gradient(45deg, rgba(255,255,255,.10), rgba(255,255,255,.10) 10px, rgba(255,255,255,.04) 10px, rgba(255,255,255,.04) 20px);
}

.adash-photo-img img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 170px;
    object-fit: cover;
    display: block;
}

.adash-photo-img img.is-missing {
    display: none;
}

.adash-photo-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.72);
    font-weight: 950;
}

.adash-picked-badge,
.adash-muted-badge {
    position: absolute;
    left: .75rem;
    bottom: .75rem;
    z-index: 4;
    padding: .4rem .65rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 950;
}

.adash-picked-badge {
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    color: #fff;
}

.adash-muted-badge {
    background: rgba(255,255,255,.78);
    color: #101820;
}

.adash-photo-caption {
    padding: .8rem;
}

.adash-photo-caption strong {
    color: #fff;
    font-weight: 950;
}

.adash-side-stack {
    display: grid;
    gap: 1rem;
}

.adash-sticky {
    position: sticky;
    top: 96px;
}

.adash-picked-list {
    display: grid;
    gap: .75rem;
    margin-top: 1.25rem;
}

.adash-picked-list div {
    padding: .9rem;
    border-radius: 20px;
    background:
        radial-gradient(circle at top right, rgba(24,183,185,.20), transparent 8rem),
        rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.13);
}

.adash-picked-list span {
    display: block;
    color: #fff;
    font-weight: 950;
}

.adash-picked-list small {
    color: rgba(255,255,255,.62);
    font-weight: 700;
}

.adash-action-box {
    margin-top: 1.4rem;
    padding: 1rem;
    border-radius: 22px;
    background: rgba(24,183,185,.12);
    border: 1px solid rgba(24,183,185,.22);
}

.adash-action-box strong {
    display: block;
    margin-bottom: .35rem;
    font-weight: 950;
}

.adash-action-box p,
.adash-text {
    color: rgba(255,255,255,.70);
    line-height: 1.6;
}

@media (max-width: 1199.98px) {
    .adash-sticky {
        position: static;
    }
}

@media (max-width: 575.98px) {
    .adash-photo-wall {
        grid-template-columns: 1fr;
    }
}

/* ------------------------------------------------------------
   Admin-Arbeitsseite · ruhiger, echter, weniger Werbung
------------------------------------------------------------ */

.admin-workspace-body {
    background:
        radial-gradient(circle at top left, rgba(24,183,185,.12), transparent 28rem),
        radial-gradient(circle at top right, rgba(255,61,139,.08), transparent 26rem),
        #101820;
}

.admin-workspace {
    color: #fff;
    min-height: 100vh;
}

.admin-workspace-container {
    padding-left: clamp(1rem, 3vw, 2.5rem);
    padding-right: clamp(1rem, 3vw, 2.5rem);
}

.admin-workspace-head {
    padding: clamp(2rem, 5vw, 4rem) 0 2rem;
    background:
        linear-gradient(180deg, rgba(16,24,32,.94), rgba(16,24,32,.72)),
        url("../img/cover-hero.jpg");
    background-size: cover;
    background-position: center;
}

.admin-title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.admin-small-label,
.admin-card-label {
    display: inline-flex;
    color: #a4f4f5;
    font-size: .88rem;
    font-weight: 950;
    margin-bottom: .55rem;
}

.admin-title-row h1 {
    margin: 0;
    font-size: clamp(2.4rem, 5vw, 4.8rem);
    line-height: .95;
    letter-spacing: -.06em;
    font-weight: 950;
}

.admin-title-row p {
    margin: .75rem 0 0;
    color: rgba(255,255,255,.72);
    font-size: 1.1rem;
}

.admin-status-pill {
    padding: .75rem 1rem;
    border-radius: 999px;
    background: rgba(24,183,185,.18);
    border: 1px solid rgba(24,183,185,.30);
    color: #a4f4f5;
    font-weight: 950;
    white-space: nowrap;
}

.admin-progress-line {
    height: .8rem;
    max-width: 560px;
    margin-top: 1.5rem;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    overflow: hidden;
}

.admin-progress-line span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
}

.admin-progress-text {
    margin-top: .6rem;
    color: rgba(255,255,255,.70);
    font-weight: 800;
}

.admin-workspace-content {
    padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
}

.admin-info-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
    .admin-info-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .admin-info-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.admin-info-card,
.admin-main-panel {
    border-radius: 30px;
    background: rgba(255,255,255,.11);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(20px);
    box-shadow: 0 24px 80px rgba(0,0,0,.20);
}

.admin-info-card {
    padding: 1.3rem;
}

.admin-info-card-active {
    border-color: rgba(24,183,185,.48);
    box-shadow: 0 24px 90px rgba(24,183,185,.13);
}

.admin-info-card h2 {
    margin: 0;
    color: #fff;
    font-size: 1.35rem;
    line-height: 1.1;
    font-weight: 950;
    letter-spacing: -.04em;
}

.admin-info-card p,
.admin-muted-text {
    margin: .8rem 0 0;
    color: rgba(255,255,255,.68);
    line-height: 1.55;
}

.admin-contact-list {
    display: grid;
    gap: .55rem;
    margin-top: .9rem;
}

.admin-contact-list a {
    color: rgba(255,255,255,.82);
    text-decoration: none;
    font-weight: 800;
}

.admin-contact-list a:hover {
    color: #fff;
}

.admin-radio-list {
    display: grid;
    gap: .55rem;
    margin-top: 1rem;
}

.admin-radio-list label {
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: .65rem .75rem;
    border-radius: 16px;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.74);
    font-weight: 800;
    cursor: pointer;
}

.admin-radio-list label.is-current {
    background: rgba(24,183,185,.18);
    color: #a4f4f5;
    border: 1px solid rgba(24,183,185,.32);
}

.admin-radio-list input {
    accent-color: var(--demo-cyan);
}

.admin-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
    margin-top: 1rem;
}

.admin-btn-light,
.admin-btn-danger {
    border-radius: 999px;
    font-weight: 900;
}

.admin-btn-light {
    border: 1px solid rgba(255,255,255,.22);
    background: rgba(255,255,255,.10);
    color: #fff;
}

.admin-btn-light:hover {
    background: rgba(255,255,255,.20);
    color: #fff;
}

.admin-btn-danger {
    border: 1px solid rgba(255,61,139,.35);
    background: rgba(255,61,139,.14);
    color: #fff;
}

.admin-btn-danger:hover {
    background: rgba(255,61,139,.28);
    color: #fff;
}

.admin-main-panel {
    padding: clamp(1.25rem, 3vw, 2rem);
}

.admin-panel-title {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
}

.admin-panel-title h2,
.admin-main-panel h2 {
    margin: 0;
    color: #fff;
    font-size: clamp(1.7rem, 3vw, 2.5rem);
    line-height: 1;
    letter-spacing: -.055em;
    font-weight: 950;
}

.admin-panel-title p {
    max-width: 640px;
    margin: .75rem 0 0;
    color: rgba(255,255,255,.66);
    line-height: 1.6;
}

.admin-picked-photo-list {
    display: grid;
    gap: 1rem;
}

.admin-picked-photo-row {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    border-radius: 26px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.13);
}

.admin-picked-thumb {
    position: relative;
    min-height: 132px;
    overflow: hidden;
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(24,183,185,.28), rgba(124,60,255,.20)),
        repeating-linear-gradient(45deg, rgba(255,255,255,.10), rgba(255,255,255,.10) 10px, rgba(255,255,255,.04) 10px, rgba(255,255,255,.04) 20px);
}

.admin-picked-thumb img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 150px;
    object-fit: cover;
    display: block;
}

.admin-picked-thumb img.is-missing {
    display: none;
}

.admin-picked-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.72);
    font-weight: 950;
}

.admin-picked-topline {
    display: flex;
    justify-content: space-between;
    gap: .75rem;
    align-items: center;
    margin-bottom: .8rem;
}

.admin-picked-topline h3 {
    margin: 0;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 950;
    letter-spacing: -.035em;
}

.admin-picked-topline span {
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(24,183,185,.18);
    color: #a4f4f5;
    font-size: .8rem;
    font-weight: 950;
}

.admin-picked-info label {
    display: block;
    color: rgba(255,255,255,.76);
    font-weight: 850;
}

.admin-picked-info textarea {
    margin-top: .45rem;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.20);
    background: rgba(255,255,255,.90);
}

.admin-side-stack {
    display: grid;
    gap: 1rem;
}

.admin-output-actions {
    display: grid;
    gap: .75rem;
    margin-top: 1.2rem;
}

.admin-disabled-panel {
    opacity: .58;
    filter: grayscale(.25);
}

.admin-disabled-options {
    display: grid;
    gap: .6rem;
    margin-top: 1rem;
}

.admin-disabled-options div {
    padding: .75rem .9rem;
    border-radius: 18px;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.72);
    font-weight: 800;
}

@media (max-width: 767.98px) {
    .admin-picked-photo-row {
        grid-template-columns: 1fr;
    }

    .admin-picked-thumb img {
        height: 230px;
    }

    .admin-title-row {
        flex-direction: column;
    }
}
/* ------------------------------------------------------------
   Admin-Korrekturen: Projekt, Notizen, Ausgabe
------------------------------------------------------------ */

.admin-project-name {
    margin: .55rem 0 0;
    color: rgba(255,255,255,.70);
    font-weight: 850;
    line-height: 1.45;
}

.admin-picked-info {
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.admin-note-label {
    display: flex;
    flex-direction: column;
    flex: 1;
    color: rgba(255,255,255,.76);
    font-weight: 850;
}

.admin-note-label textarea {
    flex: 1;
    min-height: 130px;
    resize: vertical;
}

.admin-note-actions {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
    margin-top: .75rem;
}

.admin-note-status {
    color: #a4f4f5;
    font-weight: 900;
    font-size: .9rem;
}

.admin-output-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
}

.admin-output-grid .btn {
    min-height: 46px;
}

@media (max-width: 575.98px) {
    .admin-output-grid {
        grid-template-columns: 1fr;
    }
}

/* ------------------------------------------------------------
   Admin: Bildzeilen sauber, Notizfläche groß
------------------------------------------------------------ */

.admin-picked-photo-row {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 1.1rem;
    padding: 1rem;
    border-radius: 26px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.13);
    align-items: stretch;
}

.admin-picked-thumb {
    position: relative;
    width: 220px;
    min-height: 170px;
    overflow: hidden;
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(24,183,185,.28), rgba(124,60,255,.20));
}

.admin-picked-thumb img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    min-height: 170px;
    object-fit: cover;
    display: block;
}

.admin-picked-thumb img.is-missing {
    display: none;
}

.admin-picked-placeholder {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,.72);
    font-weight: 950;
}

.admin-picked-info {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.admin-picked-topline {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: .75rem;
}

.admin-picked-topline h3 {
    margin: 0;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 950;
    letter-spacing: -.035em;
}

.admin-note-title {
    display: block;
    margin-top: .25rem;
    color: rgba(255,255,255,.72);
    font-weight: 850;
    font-size: .92rem;
}

.admin-picked-badge-text {
    flex: 0 0 auto;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(24,183,185,.18);
    color: #a4f4f5;
    font-size: .8rem;
    font-weight: 950;
}

.admin-note-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 170px;
    gap: .85rem;
    flex: 1;
}

.admin-note-row textarea {
    width: 100%;
    min-height: 126px;
    height: 100%;
    resize: vertical;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.20);
    background: rgba(255,255,255,.92);
}

.admin-note-side {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    align-items: stretch;
    justify-content: flex-start;
}

.admin-note-side .btn {
    white-space: normal;
    line-height: 1.15;
    min-height: 44px;
}

.admin-note-status {
    min-height: 1.2rem;
    color: #a4f4f5;
    font-weight: 900;
    font-size: .9rem;
}

/* ------------------------------------------------------------
   Admin: Ausgabe-Buttons ruhiger gruppieren
------------------------------------------------------------ */

.admin-output-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .9rem;
    margin-top: 1.2rem;
}

.admin-output-group {
    padding: 1rem;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.13);
    background: rgba(255,255,255,.07);
}

.admin-output-group h3 {
    margin: 0 0 .75rem;
    color: #fff;
    font-size: 1rem;
    font-weight: 950;
    letter-spacing: -.025em;
}

.admin-output-group .btn {
    width: 100%;
    min-height: 42px;
    border-radius: 999px;
    font-weight: 900;
}

.admin-output-group .btn + .btn {
    margin-top: .55rem;
}

.admin-btn-zip {
    border: 1px solid rgba(24,183,185,.32);
    background: rgba(24,183,185,.15);
    color: #a4f4f5;
}

.admin-btn-zip:hover {
    background: rgba(24,183,185,.28);
    color: #fff;
}

.admin-btn-print {
    border: 1px solid rgba(255,216,77,.30);
    background: rgba(255,216,77,.13);
    color: #ffe891;
}

.admin-btn-print:hover {
    background: rgba(255,216,77,.25);
    color: #fff;
}

@media (max-width: 991.98px) {
    .admin-picked-photo-row {
        grid-template-columns: 180px minmax(0, 1fr);
    }

    .admin-picked-thumb {
        width: 180px;
    }

    .admin-note-row {
        grid-template-columns: 1fr;
    }

    .admin-note-side {
        flex-direction: row;
        align-items: center;
    }
}

@media (max-width: 575.98px) {
    .admin-picked-photo-row {
        grid-template-columns: 1fr;
    }

    .admin-picked-thumb {
        width: 100%;
        min-height: 230px;
    }

    .admin-picked-thumb img {
        min-height: 230px;
    }

    .admin-output-split {
        grid-template-columns: 1fr;
    }
}

/* ------------------------------------------------------------
   Admin-Projektformular · Demo-Ansicht
------------------------------------------------------------ */

.admin-form-top-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 1rem;
}

.admin-project-switch {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .75rem;
    align-items: end;
    margin-top: .9rem;
}

.admin-form-label {
    display: block;
    margin-bottom: .4rem;
    color: rgba(255,255,255,.78);
    font-weight: 850;
}

.admin-form-control,
.admin-project-switch .form-select {
    min-height: 48px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.18);
    background-color: rgba(255,255,255,.92);
    color: #101820;
    font-weight: 750;
}

.admin-form-control:focus,
.admin-project-switch .form-select:focus {
    border-color: var(--demo-cyan);
    box-shadow: 0 0 0 .25rem rgba(24,183,185,.20);
}

.admin-package-choice {
    display: grid;
    gap: .75rem;
}

.admin-package-choice label {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .85rem .95rem;
    border-radius: 18px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.13);
    color: rgba(255,255,255,.78);
    font-weight: 850;
    cursor: pointer;
}

.admin-package-choice label.is-current {
    background: rgba(24,183,185,.16);
    border-color: rgba(24,183,185,.35);
    color: #a4f4f5;
}

.admin-package-choice input {
    accent-color: var(--demo-cyan);
}

.admin-package-note {
    padding: 1rem;
    border-radius: 20px;
    background: rgba(24,183,185,.12);
    border: 1px solid rgba(24,183,185,.22);
    color: rgba(255,255,255,.78);
    line-height: 1.6;
}

.admin-upload-demo {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 1rem;
}

.admin-upload-box {
    min-height: 180px;
    border-radius: 28px;
    border: 2px dashed rgba(24,183,185,.45);
    background:
        radial-gradient(circle at top right, rgba(24,183,185,.16), transparent 14rem),
        rgba(255,255,255,.07);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    text-align: center;
    color: rgba(255,255,255,.78);
}

.admin-upload-box strong {
    color: #fff;
    font-size: 1.35rem;
    font-weight: 950;
}

.admin-upload-box span {
    font-weight: 850;
}

.admin-upload-box small {
    color: rgba(255,255,255,.56);
}

.admin-upload-preview {
    display: grid;
    gap: .75rem;
}

.admin-upload-preview div {
    padding: 1rem;
    border-radius: 20px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.13);
    color: rgba(255,255,255,.80);
    font-weight: 850;
}

.admin-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.admin-form-actions .btn {
    border-radius: 999px;
    font-weight: 900;
}

@media (max-width: 991.98px) {
    .admin-form-top-grid,
    .admin-upload-demo {
        grid-template-columns: 1fr;
    }

    .admin-project-switch {
        grid-template-columns: 1fr;
    }
}

/* ------------------------------------------------------------
   Admin: kompakte Projektumschaltung + Kundenkarte
------------------------------------------------------------ */

.admin-project-mini-switch {
    display: inline-grid;
    grid-template-columns: auto minmax(220px, 320px) auto;
    gap: .6rem;
    align-items: center;
    margin-top: 1rem;
    padding: .6rem;
    border-radius: 999px;
    background: rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.14);
}

.admin-project-mini-switch span {
    padding-left: .45rem;
    color: rgba(255,255,255,.72);
    font-weight: 900;
    white-space: nowrap;
}

.admin-project-mini-switch .form-select {
    min-height: 36px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.20);
    background-color: rgba(255,255,255,.92);
    color: #101820;
    font-weight: 800;
}

.admin-project-mini-switch .btn {
    border-radius: 999px;
    white-space: nowrap;
}

.admin-card-headline {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: .75rem;
    margin-bottom: .4rem;
}

.admin-card-headline .admin-card-label {
    margin-bottom: 0;
}

.is-demo-link {
    opacity: .75;
}

.is-demo-link::after {
    content: " · Demo";
    opacity: .65;
    font-size: .8em;
}

@media (max-width: 767.98px) {
    .admin-project-mini-switch {
        display: grid;
        grid-template-columns: 1fr;
        border-radius: 24px;
        width: 100%;
    }

    .admin-project-mini-switch span {
        padding-left: 0;
    }

    .admin-card-headline {
        flex-direction: column;
    }
}

/* ------------------------------------------------------------
   Login-Formulare & Demo-Buttons verbessern
------------------------------------------------------------ */

/* Hauptbuttons in der Demo kräftiger und klar als Button sichtbar */
.demo-btn-primary,
.login-glass-card .demo-btn-primary,
.selection-summary-card .demo-btn-primary,
.selection-download-area .demo-btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;

    min-height: 54px;
    padding: .9rem 1.4rem;

    border: 0;
    border-radius: 999px;

    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    color: #fff;

    font-weight: 950;
    text-decoration: none;
    line-height: 1.1;

    box-shadow: 0 18px 46px rgba(24, 183, 185, .28);
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

.demo-btn-primary:hover,
.demo-btn-primary:focus {
    color: #fff;
    transform: translateY(-1px);
    filter: brightness(1.05);
    box-shadow: 0 24px 62px rgba(124, 60, 255, .32);
}

/* Sekundäre Demo-Buttons ebenfalls deutlicher */
.demo-btn-glass,
.demo-btn-outline,
.admin-btn-light,
.admin-btn-zip,
.admin-btn-print {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 48px;
    padding: .8rem 1.15rem;

    border-radius: 999px;
    font-weight: 900;
    text-decoration: none;
    line-height: 1.1;
}

/* Login-Karte: Formularfelder luftiger */
.login-glass-card .form-floating {
    margin-bottom: 1rem;
}

.login-glass-card .form-control {
    min-height: 64px;
    padding-left: 1.35rem;
    padding-right: 1.35rem;

    border-radius: 24px;
    border: 2px solid rgba(255, 255, 255, .32);

    background: rgba(255, 255, 255, .94);
    color: #101820;

    font-size: 1.05rem;
    font-weight: 850;
}

/* Floating-Label nicht mehr direkt am linken Rand kleben lassen */
.login-glass-card .form-floating > label {
    left: .35rem;
    padding-left: 1rem;
    padding-right: 1rem;
    color: #667085;
    font-weight: 850;
}

/* Wenn das Label hochwandert, soll es sauber lesbar bleiben */
.login-glass-card .form-floating > .form-control:focus ~ label,
.login-glass-card .form-floating > .form-control:not(:placeholder-shown) ~ label {
    color: #0f8f91;
    opacity: 1;
}

/* Fokus sichtbarer, aber nicht hässlich */
.login-glass-card .form-control:focus {
    border-color: var(--demo-cyan);
    box-shadow: 0 0 0 .25rem rgba(24, 183, 185, .24);
}

/* Button im Login immer schön breit und sichtbar */
.login-glass-card button[type="submit"] {
    width: 100%;
    margin-top: .5rem;
}

/* Kleine Login-Hinweisbox etwas ruhiger */
.login-card-note {
    margin-top: 1.4rem;
    padding: 1rem 1.1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .18);
    color: rgba(255, 255, 255, .80);
    font-weight: 800;
    text-align: center;
}

/* ------------------------------------------------------------
   Kundenseite: Paket-Kästchen schöner / ruhiger
------------------------------------------------------------ */

.selection-summary-card {
    max-width: 430px;
    margin-left: auto;
    padding: 1.6rem;
    border-radius: 34px;

    background:
        radial-gradient(circle at top right, rgba(255, 61, 139, .18), transparent 12rem),
        radial-gradient(circle at bottom left, rgba(24, 183, 185, .22), transparent 14rem),
        rgba(255, 255, 255, .13);

    border: 1px solid rgba(255, 255, 255, .22);
    backdrop-filter: blur(26px);
    box-shadow: 0 32px 100px rgba(0, 0, 0, .28);
}

.summary-label {
    display: inline-flex;
    padding: .45rem .75rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .16);
    color: #a4f4f5;
    font-size: .86rem;
    font-weight: 950;
}

.summary-big {
    margin-top: 1rem;
    font-size: clamp(3.2rem, 5vw, 5.4rem);
    line-height: .9;
    letter-spacing: -.07em;
    font-weight: 950;
    color: #fff;
}

.summary-big span {
    color: #a4f4f5;
}

.selection-summary-card p {
    margin: .65rem 0 1.1rem;
    color: rgba(255, 255, 255, .72);
    font-size: 1.05rem;
    font-weight: 750;
}

.selection-progress {
    height: 1rem;
    padding: .18rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .14);
    overflow: hidden;
}

.selection-progress span {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    box-shadow: 0 0 22px rgba(24, 183, 185, .35);
    transition: width .25s ease;
}

.selection-summary-card .demo-btn-primary {
    width: 100%;
    min-height: 54px;
    margin-top: 1.15rem;
    border-radius: 999px;
    font-size: .98rem;
    font-weight: 950;
}

.selection-hint {
    margin-top: 1rem;
    padding: .95rem 1rem;
    border-radius: 22px;

    background: rgba(16, 24, 32, .38);
    border: 1px solid rgba(255, 255, 255, .12);

    color: rgba(255, 255, 255, .82);
    font-weight: 850;
    text-align: center;
    line-height: 1.35;
}

/* Wenn das Paket voll ist, wirkt der Hinweis positiver */
.selection-summary-card.is-complete .selection-hint {
    background: rgba(24, 183, 185, .18);
    border-color: rgba(24, 183, 185, .30);
    color: #a4f4f5;
}

/* ------------------------------------------------------------
   Kundenauswahl: gewählte Fotos als Thumbnail-Reihe
------------------------------------------------------------ */

.selected-thumb-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .75rem;
    margin-top: 1rem;
}

.selected-thumb-item {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .5rem .7rem;
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    border: 1px solid rgba(255,255,255,.16);
    color: #fff;
    font-weight: 850;
}

.selected-thumb-item:not(:last-child)::after {
    content: "|";
    position: absolute;
    right: -.55rem;
    color: rgba(255,255,255,.42);
    font-weight: 950;
}

.selected-thumb-item img {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    object-fit: cover;
    flex: 0 0 auto;
    box-shadow: 0 10px 28px rgba(0,0,0,.22);
}

.selected-thumb-item span {
    white-space: nowrap;
    font-size: .92rem;
}

@media (max-width: 575.98px) {
    .selected-thumb-strip {
        gap: .6rem;
    }

    .selected-thumb-item {
        border-radius: 18px;
    }

    .selected-thumb-item:not(:last-child)::after {
        display: none;
    }

    .selected-thumb-item img {
        width: 38px;
        height: 38px;
    }
}

/* ------------------------------------------------------------
   Sticky Paketleiste unter Header
------------------------------------------------------------ */

.selection-sticky-bar {
    position: sticky;
    top: 76px;
    z-index: 950;
    padding: .65rem clamp(1rem, 3vw, 2.5rem);
    background: rgba(16, 24, 32, .86);
    border-bottom: 1px solid rgba(255,255,255,.12);
    backdrop-filter: blur(22px);

    opacity: 0;
    transform: translateY(-100%);
    pointer-events: none;
    transition: opacity .22s ease, transform .22s ease;
}

.selection-sticky-bar.is-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.selection-sticky-inner {
    max-width: 1500px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: auto minmax(160px, 1fr) auto;
    align-items: center;
    gap: 1rem;
}

.selection-sticky-info {
    display: flex;
    align-items: baseline;
    gap: .6rem;
    color: #fff;
    white-space: nowrap;
}

.selection-sticky-info span {
    color: rgba(255,255,255,.68);
    font-weight: 850;
    font-size: .9rem;
}

.selection-sticky-info strong {
    color: #a4f4f5;
    font-weight: 950;
}

.selection-sticky-progress {
    height: .65rem;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    overflow: hidden;
}

.selection-sticky-progress span {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(135deg, var(--demo-cyan), var(--demo-purple));
    transition: width .25s ease;
}

.selection-sticky-bar .demo-btn-primary {
    min-height: 40px;
    padding: .55rem 1rem;
    font-size: .9rem;
    box-shadow: none;
}

.selection-sticky-bar .demo-btn-primary:disabled {
    opacity: .55;
    cursor: not-allowed;
    filter: grayscale(.2);
}

@media (max-width: 767.98px) {
    .selection-sticky-bar {
        top: 122px;
    }

    .selection-sticky-inner {
        grid-template-columns: 1fr;
        gap: .55rem;
    }

    .selection-sticky-info {
        justify-content: space-between;
    }

    .selection-sticky-bar .demo-btn-primary {
        width: 100%;
    }
}