/* =========================================================================
   AKIL – Hauptstylesheet
   Farb-Variablen werden in header.php aus den Einstellungen gesetzt.
   ========================================================================= */

*,*::before,*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    font-family: var(--font);
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
    transition: background .3s ease, color .3s ease;
    overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

h1,h2,h3,h4 { line-height: 1.2; margin: 0 0 .5em; font-weight: 700; }
h1 { font-size: clamp(2rem, 5vw, 3.4rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); }

.container { width: min(1180px, 92%); margin-inline: auto; }
section { padding: clamp(3rem, 7vw, 6rem) 0; }

.section-head { text-align: center; max-width: 680px; margin: 0 auto 3rem; }
.section-head p { color: var(--muted); font-size: 1.1rem; }

/* ---- Buttons ---------------------------------------------------------- */
.btn {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .8rem 1.6rem; border: 0; border-radius: 999px;
    background: var(--primary); color: #fff; font: inherit; font-weight: 600;
    cursor: pointer; transition: transform .15s ease, box-shadow .2s ease, opacity .2s;
    box-shadow: 0 6px 20px -8px var(--primary); text-decoration: none;
}
.btn:hover { transform: translateY(-2px); text-decoration: none; opacity: .95; }
.btn-ghost { background: transparent; color: var(--text); box-shadow: none; border: 1px solid var(--muted); }
.btn-accent { background: var(--accent); box-shadow: 0 6px 20px -8px var(--accent); }
.btn-danger { background: #dc2626; box-shadow: none; }
.btn-block { width: 100%; justify-content: center; }
.btn-sm { padding: .45rem .9rem; font-size: .85rem; }

/* ---- Header / Navigation --------------------------------------------- */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: color-mix(in srgb, var(--bg) 85%, transparent);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
}
.nav-wrap { display: flex; align-items: center; justify-content: space-between; height: 68px; }
.brand { font-weight: 800; font-size: 1.4rem; color: var(--text); letter-spacing: -.02em; }
.brand:hover { text-decoration: none; }
.brand-logo { height: 40px; width: auto; }
.brand-name { background: linear-gradient(120deg, var(--primary), var(--accent)); -webkit-background-clip: text; background-clip: text; color: transparent; }

.nav-list { list-style: none; display: flex; align-items: center; gap: 1.6rem; margin: 0; padding: 0; }
.nav-list a { color: var(--text); font-weight: 500; position: relative; }
.nav-list a::after {
    content:''; position:absolute; left:0; bottom:-6px; height:2px; width:0;
    background: var(--primary); transition: width .25s ease;
}
.nav-list a:hover { text-decoration: none; }
.nav-list a:hover::after { width: 100%; }

.theme-toggle, .nav-toggle {
    background: var(--surface); border: 1px solid color-mix(in srgb, var(--muted) 25%, transparent);
    color: var(--text); border-radius: 12px; cursor: pointer; display: inline-flex;
    align-items: center; justify-content: center; padding: .5rem; transition: background .2s;
}
.theme-toggle:hover { background: color-mix(in srgb, var(--primary) 14%, var(--surface)); }
.theme-toggle .icon-moon { display: none; }
html[data-theme="dark"] .theme-toggle .icon-sun { display: none; }
html[data-theme="dark"] .theme-toggle .icon-moon { display: block; }

.nav-toggle { display: none; flex-direction: column; gap: 4px; width: 42px; height: 38px; }
.nav-toggle span { width: 20px; height: 2px; background: var(--text); border-radius: 2px; transition: .3s; }

/* ---- Hero ------------------------------------------------------------- */
.hero {
    position: relative; text-align: center; padding: clamp(4rem,10vw,8rem) 0;
    background:
        radial-gradient(1000px 500px at 70% -10%, color-mix(in srgb, var(--primary) 22%, transparent), transparent),
        radial-gradient(800px 400px at 10% 10%, color-mix(in srgb, var(--accent) 16%, transparent), transparent);
}
.hero h1 { letter-spacing: -.03em; margin-bottom: .3em; }
.hero .lead { font-size: clamp(1.1rem,2.5vw,1.4rem); color: var(--muted); max-width: 620px; margin: 0 auto 2rem; }

/* ---- Karussell -------------------------------------------------------- */
.carousel { position: relative; border-radius: var(--radius); overflow: hidden; box-shadow: 0 30px 60px -30px rgba(0,0,0,.45); background: var(--surface); }
.carousel-track { display: flex; transition: transform .6s cubic-bezier(.22,.61,.36,1); }
.carousel-slide { min-width: 100%; position: relative; aspect-ratio: 16/9; background: var(--surface); }
.carousel-slide img { width: 100%; height: 100%; object-fit: cover; }
.carousel-caption {
    position: absolute; left: 0; right: 0; bottom: 0; padding: 2rem 1.5rem 1.2rem;
    background: linear-gradient(transparent, rgba(0,0,0,.65)); color:#fff; font-weight:600;
}
.carousel-btn {
    position: absolute; top: 50%; transform: translateY(-50%);
    background: rgba(0,0,0,.4); color:#fff; border:0; width:46px; height:46px;
    border-radius: 50%; cursor:pointer; font-size:1.4rem; display:grid; place-items:center;
    transition: background .2s; z-index: 2;
}
.carousel-btn:hover { background: rgba(0,0,0,.7); }
.carousel-prev { left: 14px; } .carousel-next { right: 14px; }
.carousel-dots { display:flex; gap:.5rem; justify-content:center; margin-top:1rem; }
.carousel-dots button { width:10px; height:10px; border-radius:50%; border:0; background: color-mix(in srgb, var(--muted) 50%, transparent); cursor:pointer; padding:0; transition: .2s; }
.carousel-dots button.active { background: var(--primary); transform: scale(1.3); }

/* ---- Galerie (Grid + Lightbox) --------------------------------------- */
.gallery-grid {
    display: grid; gap: 14px;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.gallery-item {
    position: relative; border-radius: 14px; overflow: hidden; cursor: pointer;
    aspect-ratio: 1; background: var(--surface); box-shadow: 0 10px 30px -18px rgba(0,0,0,.5);
}
.gallery-item img,
.gallery-item > video { width:100%; height:100%; object-fit: cover; transition: transform .5s ease; display:block; image-orientation: from-image; }
.carousel-slide img,
.lightbox img { image-orientation: from-image; }
.gallery-item:hover img,
.gallery-item:hover > video { transform: scale(1.08); }
.gallery-item.is-video .gi-play {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    width:60px; height:60px; border-radius:50%; background:rgba(0,0,0,.55);
    color:#fff; font-size:1.6rem; display:flex; align-items:center; justify-content:center;
    pointer-events:none; z-index:2; padding-left:.25rem;
}
.carousel-slide video { width:100%; height:100%; object-fit:cover; display:block; }
.lightbox-video { max-width: 92vw; max-height: 86vh; border-radius: 10px; background:#000; }

/* Drehen-Buttons in der öffentlichen Galerie (nur für Eingeloggte sichtbar) */
.gi-rotate {
    position:absolute; top:8px; left:8px; z-index:3;
    display:flex; gap:2px;
    background: rgba(0,0,0,.55); border-radius:.4rem; padding:2px;
    opacity:0; transition: opacity .2s;
}
.gallery-item:hover .gi-rotate,
.gallery-item:focus-within .gi-rotate { opacity:1; }
.gi-rotate .rot-btn {
    background: transparent; color:#fff; border:0;
    width:26px; height:26px; padding:0; font-size:1rem;
    cursor:pointer; border-radius:.3rem;
}
.gi-rotate .rot-btn:hover { background: rgba(255,255,255,.18); }
.gi-rotate .rot-btn:disabled { opacity:.4; cursor:wait; }

.lightbox-rotate {
    position:absolute; bottom:22px; left:50%; transform:translateX(-50%);
    display:flex; gap:.4rem;
    background: rgba(0,0,0,.55); padding:.4rem .6rem; border-radius:.5rem;
}
.lightbox-rotate .rot-btn-lb {
    background: rgba(255,255,255,.12); color:#fff; border:0;
    padding:.4rem .7rem; border-radius:.35rem; cursor:pointer; font-size:.9rem;
}
.lightbox-rotate .rot-btn-lb:hover { background: rgba(255,255,255,.22); }
.lightbox-rotate .rot-btn-lb:disabled { opacity:.5; cursor:wait; }

.merk-rotate-row { align-items:center; flex-wrap:wrap; }
.merk-rotate-label { font-size:.85rem; color: var(--muted); margin-right:.2rem; }

/* Upload-Log */
.ul-ok  { color:#16a34a; font-weight:600; }
.ul-err { color:#dc2626; font-weight:600; }
.ul-msg { max-width:380px; font-size:.85rem; color: var(--muted); word-break:break-word; }
.gi-noimg {
    width:100%; height:100%; display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:.5rem;
    background: linear-gradient(135deg, #2a2a2a, #444);
    color:#fff; text-align:center; padding:1rem;
}
.gi-noimg-ext {
    font-weight:700; font-size:1.4rem; letter-spacing:.08em;
    padding:.25rem .75rem; border:2px solid rgba(255,255,255,.4); border-radius:.4rem;
}
.gi-noimg-name { font-size:.8rem; opacity:.8; word-break:break-all; }
.gallery-item::after {
    content:''; position:absolute; inset:0;
    background: linear-gradient(transparent 55%, rgba(0,0,0,.5));
    opacity:0; transition: opacity .3s;
}
.gallery-item:hover::after { opacity: 1; }
.gallery-empty { text-align:center; color: var(--muted); padding: 3rem; border: 2px dashed color-mix(in srgb, var(--muted) 35%, transparent); border-radius: var(--radius); }

.lightbox {
    position: fixed; inset: 0; background: rgba(0,0,0,.92); display:none;
    align-items:center; justify-content:center; z-index: 1000; padding: 2rem;
}
.lightbox.open { display: flex; }
.lightbox img { max-width: 92vw; max-height: 86vh; border-radius: 10px; object-fit: contain; }
.lightbox-close, .lightbox-nav {
    position: absolute; background: rgba(255,255,255,.12); color:#fff; border:0;
    width: 52px; height: 52px; border-radius: 50%; font-size: 1.6rem; cursor: pointer;
}
.lightbox-close { top: 22px; right: 22px; }
.lightbox-nav { top: 50%; transform: translateY(-50%); }
.lb-prev { left: 22px; } .lb-next { right: 22px; }

/* ---- About ------------------------------------------------------------ */
.about { background: var(--surface); }
.about-text { max-width: 760px; margin: 0 auto; text-align: center; font-size: 1.15rem; color: var(--muted); white-space: pre-line; }

/* ---- Formulare / Kontakt --------------------------------------------- */
.form-card {
    max-width: 640px; margin: 0 auto; background: var(--surface);
    padding: clamp(1.5rem, 4vw, 2.5rem); border-radius: var(--radius);
    box-shadow: 0 30px 60px -40px rgba(0,0,0,.5);
}
.field { margin-bottom: 1.1rem; }
.field label { display:block; font-weight:600; margin-bottom:.4rem; font-size:.95rem; }
.field input, .field textarea, .field select {
    width: 100%; padding: .8rem 1rem; border-radius: 12px; font: inherit;
    background: var(--bg); color: var(--text);
    border: 1px solid color-mix(in srgb, var(--muted) 35%, transparent);
    transition: border-color .2s, box-shadow .2s;
}
.field input:focus, .field textarea:focus, .field select:focus {
    outline: none; border-color: var(--primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 25%, transparent);
}
.field textarea { min-height: 140px; resize: vertical; }
.field-check { display:flex; align-items:flex-start; gap:.6rem; font-size:.9rem; color: var(--muted); }
.field-check input { width:auto; margin-top:.2rem; }
.hp { position: absolute; left: -9999px; }   /* Honeypot */

/* ---- Flash-Meldungen -------------------------------------------------- */
.flash { padding: .9rem 1.2rem; border-radius: 12px; margin: 1rem 0; font-weight: 500; }
.flash-success { background: #dcfce7; color: #166534; }
.flash-error   { background: #fee2e2; color: #991b1b; }
.flash-info    { background: #dbeafe; color: #1e40af; }
html[data-theme="dark"] .flash-success { background:#064e3b; color:#a7f3d0; }
html[data-theme="dark"] .flash-error   { background:#7f1d1d; color:#fecaca; }
html[data-theme="dark"] .flash-info    { background:#1e3a8a; color:#bfdbfe; }

/* ---- Footer ----------------------------------------------------------- */
.site-footer { background: var(--surface); margin-top: 4rem; border-top: 1px solid color-mix(in srgb, var(--muted) 20%, transparent); }
.footer-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 2rem; padding: 3rem 0 2rem; }
.footer-brand { font-size: 1.4rem; font-weight: 800; }
.footer-tagline { color: var(--muted); }
.footer-col h4 { font-size: 1rem; }
.footer-links { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.4rem; }
.footer-links a, .footer-col a { color: var(--muted); }
.footer-bottom { padding: 1.2rem 0; border-top: 1px solid color-mix(in srgb, var(--muted) 20%, transparent); color: var(--muted); font-size:.9rem; text-align:center; }

.to-top {
    position: fixed; right: 22px; bottom: 22px; width: 46px; height: 46px;
    border-radius: 50%; border:0; background: var(--primary); color:#fff; font-size:1.2rem;
    cursor:pointer; opacity:0; pointer-events:none; transition: opacity .3s, transform .3s;
    box-shadow: 0 10px 24px -10px var(--primary); z-index: 90;
}
.to-top.show { opacity:1; pointer-events:auto; }
.to-top:hover { transform: translateY(-3px); }

/* =========================================================================
   ADMIN-Bereich (Login, Upload, Einstellung)
   ========================================================================= */
.admin-shell { min-height: 100vh; background: var(--bg); }
.admin-bar {
    background: var(--surface); border-bottom: 1px solid color-mix(in srgb, var(--muted) 20%, transparent);
    padding: .8rem 0;
}
.admin-bar .container { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.admin-bar .brand-name { font-size: 1.2rem; }
.admin-user { color: var(--muted); font-size:.9rem; }
.admin-nav { display:flex; gap:.5rem; flex-wrap: wrap; }

/* Login */
.login-wrap { min-height: 100vh; display:grid; place-items:center; padding: 2rem;
    background: radial-gradient(900px 500px at 50% -10%, color-mix(in srgb, var(--primary) 25%, transparent), var(--bg)); }
.login-card { width: min(420px, 100%); background: var(--surface); padding: 2.5rem; border-radius: var(--radius); box-shadow: 0 40px 80px -40px rgba(0,0,0,.6); }
.login-card h1 { text-align:center; font-size: 1.6rem; }
.login-card .muted { text-align:center; color: var(--muted); margin-bottom: 1.6rem; }

/* Tabs */
.tabs { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom: 1.6rem; border-bottom: 1px solid color-mix(in srgb, var(--muted) 20%, transparent); }
.tab-btn {
    background: transparent; border:0; border-bottom: 3px solid transparent;
    padding: .7rem 1rem; cursor:pointer; color: var(--muted); font: inherit; font-weight:600; border-radius: 8px 8px 0 0;
}
.tab-btn:hover { background: color-mix(in srgb, var(--primary) 10%, transparent); color: var(--text); }
.tab-btn.active { color: var(--primary); border-bottom-color: var(--primary); }
.tab-panel { display:none; animation: fade .3s ease; }
.tab-panel.active { display:block; }
@keyframes fade { from { opacity:0; transform: translateY(6px); } to { opacity:1; transform:none; } }

.card { background: var(--surface); border-radius: var(--radius); padding: 1.5rem; margin-bottom: 1.5rem; border:1px solid color-mix(in srgb, var(--muted) 14%, transparent); }
.card h3 { margin-top: 0; }
.grid-2 { display:grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1rem; }
.grid-3 { display:grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 1rem; }

.color-row { display:flex; align-items:center; gap:.6rem; }
.color-row input[type=color] { width: 46px; height: 40px; padding: 2px; border-radius: 10px; }
.badge { display:inline-block; padding:.2rem .6rem; border-radius:999px; font-size:.78rem; font-weight:600; }
.badge-admin { background:#fef3c7; color:#92400e; } .badge-editor { background:#e0e7ff; color:#3730a3; }
.admin-only-note { font-size:.8rem; color: var(--accent); font-weight:600; }

/* Tabellen (Log, Benutzer) */
.table-wrap { overflow-x:auto; border-radius: 12px; border:1px solid color-mix(in srgb, var(--muted) 18%, transparent); }
table.data { width:100%; border-collapse: collapse; font-size:.88rem; }
table.data th, table.data td { padding:.6rem .8rem; text-align:left; border-bottom:1px solid color-mix(in srgb, var(--muted) 14%, transparent); white-space: nowrap; }
table.data th { background: color-mix(in srgb, var(--muted) 10%, transparent); position: sticky; top:0; }
table.data tr:hover td { background: color-mix(in srgb, var(--primary) 6%, transparent); }
.stat-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.stat { background: var(--surface); border-radius: 14px; padding: 1.2rem; text-align:center; border:1px solid color-mix(in srgb, var(--muted) 14%, transparent); }
.stat .num { font-size:1.8rem; font-weight:800; color: var(--primary); }
.stat .lbl { color: var(--muted); font-size:.85rem; }

.toggle { display:flex; align-items:center; gap:.6rem; cursor:pointer; }
.toggle input { width:auto; }
.help { font-size:.82rem; color: var(--muted); margin-top:.3rem; }
.sticky-save { position: sticky; bottom: 0; background: color-mix(in srgb, var(--bg) 92%, transparent); backdrop-filter: blur(8px); padding: 1rem 0; margin-top: 1rem; border-top:1px solid color-mix(in srgb, var(--muted) 18%, transparent); display:flex; gap:.8rem; }

/* ---- Upload (Dropzone) ------------------------------------------------ */
.dropzone {
    border: 2.5px dashed color-mix(in srgb, var(--primary) 50%, var(--muted));
    border-radius: var(--radius); padding: clamp(2rem,6vw,4rem); text-align:center;
    background: var(--surface); cursor:pointer; transition: .25s;
}
.dropzone.dragover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 12%, var(--surface)); transform: scale(1.01); }
.dropzone .dz-icon { font-size: 3rem; }
.dropzone h3 { margin:.6rem 0 .3rem; }
.dropzone p { color: var(--muted); margin:0; }
.dz-previews { display:grid; grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); gap:12px; margin-top:1.5rem; }
.dz-item { position:relative; border-radius:12px; overflow:hidden; background: var(--surface); border:1px solid color-mix(in srgb, var(--muted) 18%, transparent); }
.dz-item img { aspect-ratio:1; object-fit: cover; width:100%; }
.dz-item .dz-meta { padding:.4rem .5rem; font-size:.72rem; color: var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dz-item .dz-bar { height:4px; background: color-mix(in srgb, var(--muted) 25%, transparent); }
.dz-item .dz-bar span { display:block; height:100%; width:0; background: var(--primary); transition: width .3s; }
.dz-item.done .dz-bar span { background: #22c55e; }
.dz-item.error { border-color:#dc2626; }
.dz-item.error .dz-bar span { background:#dc2626; }
.dz-remove { position:absolute; top:6px; right:6px; background:rgba(0,0,0,.6); color:#fff; border:0; width:24px; height:24px; border-radius:50%; cursor:pointer; }

/* Bild-Verwaltung in Einstellung */
.manage-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); gap:12px; }
.manage-item { position:relative; border-radius:12px; overflow:hidden; border:1px solid color-mix(in srgb, var(--muted) 18%, transparent); }
.manage-item img { aspect-ratio:1; object-fit:cover; width:100%; }
.manage-item .del { position:absolute; top:6px; right:6px; }

/* ---- Mobile ----------------------------------------------------------- */
@media (max-width: 820px) {
    .nav-toggle { display:flex; order: 3; }
    .nav-list {
        position: absolute; top: 68px; right: 0; left: 0;
        flex-direction: column; align-items: flex-start; gap: 0;
        background: var(--bg); border-bottom: 1px solid color-mix(in srgb, var(--muted) 20%, transparent);
        padding: .5rem 6%; max-height: 0; overflow: hidden; transition: max-height .3s ease;
    }
    .nav-list.open { max-height: 420px; padding-block: 1rem; }
    .nav-list li { width: 100%; }
    .nav-list a { display:block; padding:.7rem 0; }
    .admin-bar .container { flex-direction: column; align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
    * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* =========================================================================
   Bild-Verwaltung (Karten mit Umbenennen & Wasserzeichen)
   ========================================================================= */
.manage-grid { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }
.manage-item {
    display: flex; flex-direction: column; overflow: hidden;
    background: var(--bg); border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--muted) 18%, transparent);
}
.mi-thumb { position: relative; aspect-ratio: 4/3; background: var(--surface); }
.mi-thumb img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: auto; }
.mi-badge {
    position: absolute; top: 8px; left: 8px; background: var(--accent); color: #1a1205;
    font-size: .72rem; font-weight: 700; padding: .2rem .55rem; border-radius: 999px;
}
.mi-body { padding: .7rem; display: flex; flex-direction: column; gap: .55rem; }
.mi-rename { display: flex; align-items: center; gap: .25rem; }
.mi-rename input {
    flex: 1; min-width: 0; padding: .4rem .55rem; font-size: .85rem; border-radius: 9px;
    background: var(--bg); color: var(--text);
    border: 1px solid color-mix(in srgb, var(--muted) 35%, transparent);
}
.mi-rename input:focus { outline: none; border-color: var(--primary); }
.mi-ext { font-size: .8rem; color: var(--muted); }
.mi-meta { font-size: .74rem; color: var(--muted); }
.mi-actions { display: flex; flex-wrap: wrap; gap: .35rem; align-items:center; }
.mi-actions form { display: inline; }
.mi-rotate { display:inline-flex; gap:2px; border:1px solid color-mix(in srgb, var(--muted) 25%, transparent); border-radius:.4rem; padding:2px; }
.mi-rotate .btn { padding:.15rem .4rem; font-size:.78rem; }

/* Mehrfach-Auswahl in der Bilderverwaltung */
.mi-select {
    position:absolute; top:8px; left:8px; z-index:3;
    background: rgba(0,0,0,.55); border-radius:.4rem; padding:.2rem .35rem;
    display:flex; align-items:center; cursor:pointer;
}
.mi-select input { width:18px; height:18px; cursor:pointer; accent-color:#3b82f6; }
.manage-item { position:relative; }
.manage-item.is-selected { outline:3px solid #3b82f6; outline-offset:-3px; }

.bulk-toolbar {
    position: sticky; top: 0; z-index: 5;
    display:flex; flex-wrap:wrap; align-items:center; gap:.8rem;
    padding:.6rem .8rem; margin: .5rem 0 1rem;
    background: var(--surface);
    border:1px solid color-mix(in srgb, var(--muted) 18%, transparent);
    border-radius:.6rem;
    backdrop-filter: blur(8px);
}
.bulk-count { font-size:.9rem; color: var(--muted); margin-left:auto; }
.bulk-actions { display:flex; flex-wrap:wrap; gap:.35rem; }
.bulk-actions button[disabled] { opacity:.45; cursor:not-allowed; }

/* =========================================================================
   Wasserzeichen-Editor (Modal)
   ========================================================================= */
.wm-overlay {
    position: fixed; inset: 0; z-index: 1100; display: none;
    background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
    align-items: center; justify-content: center; padding: 1.2rem;
}
.wm-overlay.open { display: flex; }
.wm-dialog {
    width: min(960px, 100%); max-height: 92vh; overflow: auto;
    background: var(--bg); border-radius: var(--radius);
    box-shadow: 0 40px 90px -30px rgba(0,0,0,.7);
}
.wm-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1rem 1.3rem; border-bottom: 1px solid color-mix(in srgb, var(--muted) 18%, transparent);
}
.wm-x { background: none; border: 0; font-size: 1.6rem; cursor: pointer; color: var(--muted); line-height: 1; }
.wm-body { display: grid; grid-template-columns: 1.4fr 1fr; gap: 1.3rem; padding: 1.3rem; }
.wm-canvas-wrap {
    background: var(--surface); border-radius: 12px; padding: .6rem;
    display: grid; place-items: center; min-height: 240px;
}
.wm-canvas-wrap canvas { max-width: 100%; max-height: 60vh; border-radius: 8px; }
.wm-controls .field { margin-bottom: .7rem; }
.wm-controls input[type=range] { width: 100%; }
.wm-foot { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: .4rem; }

@media (max-width: 720px) {
    .wm-body { grid-template-columns: 1fr; }
}

/* =========================================================================
   Duplikat-Erkennung
   ========================================================================= */
.dup-group {
    border: 1px solid color-mix(in srgb, var(--muted) 22%, transparent);
    border-radius: 12px; padding: .8rem; margin-top: 1rem;
}
.dup-head { font-weight: 600; font-size: .9rem; margin-bottom: .6rem; color: var(--muted); }
.dup-items { display: flex; flex-wrap: wrap; gap: .7rem; }
.dup-item {
    width: 150px; border-radius: 10px; overflow: hidden; cursor: pointer;
    border: 2px solid transparent; background: var(--bg);
    box-shadow: 0 6px 18px -12px rgba(0,0,0,.5);
}
.dup-item img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.dup-item .dup-name {
    display: block; font-size: .7rem; color: var(--muted); padding: .3rem .45rem 0;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dup-item .dup-pick {
    display: flex; align-items: center; gap: .35rem; padding: .35rem .45rem .5rem; font-size: .78rem;
}
.dup-item .dup-pick input { width: auto; }
.dup-item .dup-pick em { color: #16a34a; font-style: normal; font-weight: 600; }
.dup-item.keep { border-color: #16a34a; }
.dup-item:has(input:checked) { border-color: #dc2626; }

/* =========================================================================
   Bild-Anfrage ("Anfragen"-Button + Chips)
   ========================================================================= */
/* Hervorgehobener Upload-Link in der Navigation */
.nav-list a.nav-upload {
    color: var(--primary); font-weight: 700;
}

.inquire-btn {
    position: absolute; left: 8px; right: 8px; bottom: 8px; z-index: 4;
    border: 0; border-radius: 999px; padding: .5rem .7rem; cursor: pointer;
    font: inherit; font-weight: 600; font-size: .85rem;
    background: color-mix(in srgb, var(--primary) 92%, transparent); color: #fff;
    opacity: 0; transform: translateY(8px);
    transition: opacity .2s, transform .2s, background .2s;
    box-shadow: 0 8px 20px -10px rgba(0,0,0,.6);
}
.gallery-item:hover .inquire-btn { opacity: 1; transform: none; }
.inquire-btn:hover { background: var(--primary); }
@media (hover: none) { .inquire-btn { opacity: 1; transform: none; } } /* Touch: immer sichtbar */

.inquire-btn-lb {
    position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 1001;
    border: 0; border-radius: 999px; padding: .7rem 1.4rem; cursor: pointer;
    font: inherit; font-weight: 600; background: var(--primary); color: #fff;
    box-shadow: 0 10px 30px -12px rgba(0,0,0,.7);
}
.inquire-btn-lb:hover { filter: brightness(1.08); }
/* download-btn-lb teilt die Optik von .inquire-btn-lb (gleiche Klasse im HTML) */
a.inquire-btn-lb { text-decoration: none; display: inline-block; }

/* ---- Download-Button je Bild (Optik wie .inquire-btn) ---------------- */
.download-btn {
    position: absolute; left: 8px; right: 8px; bottom: 8px; z-index: 4;
    border: 0; border-radius: 999px; padding: .5rem .7rem; cursor: pointer;
    font: inherit; font-weight: 600; font-size: .85rem; text-align: center; text-decoration: none;
    background: color-mix(in srgb, var(--primary) 92%, transparent); color: #fff;
    opacity: 0; transform: translateY(8px);
    transition: opacity .2s, transform .2s, background .2s;
    box-shadow: 0 8px 20px -10px rgba(0,0,0,.6);
}
.gallery-item:hover .download-btn { opacity: 1; transform: none; }
.download-btn:hover { background: var(--primary); }
@media (hover: none) { .download-btn { opacity: 1; transform: none; } } /* Touch: immer sichtbar */

/* ---- Hero-Hintergrundbild ------------------------------------------- */
.hero-has-bg { background-size: contain; background-position: center; background-repeat: no-repeat; }
.hero-has-bg .hero-overlay {
    position: absolute; inset: 0; z-index: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.62));
}
.hero-has-bg .container { position: relative; z-index: 1; }
.hero-has-bg h1 { color: #fff; }
.hero-has-bg .lead { color: rgba(255,255,255,.92); }

/* Hero-Höhe einstellbar (groß / bildschirmfüllend) */
.hero.hero-h-large { min-height: 70vh; display: flex; align-items: center; }
.hero.hero-h-full  { min-height: 100vh; display: flex; align-items: center; }
.hero.hero-h-large .container,
.hero.hero-h-full  .container { width: 100%; }

/* ---- „Hochgeladen von …" in der Galerie ----------------------------- */
.gi-uploader { font-size: .72rem; font-weight: 500; opacity: .9; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.inq-chips { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: .5rem; }
.inq-chip {
    display: inline-flex; align-items: center; gap: .4rem; max-width: 250px;
    background: var(--bg); border: 1px solid color-mix(in srgb, var(--muted) 30%, transparent);
    border-radius: 999px; padding: .25rem .45rem .25rem .25rem; font-size: .8rem;
}
.inq-chip img { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex: none; }
.inq-chip-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.inq-chip button { border: 0; background: none; cursor: pointer; font-size: 1.15rem; line-height: 1; color: var(--muted); padding: 0 .1rem; }
.inq-chip button:hover { color: #dc2626; }
#inquiryField { background: var(--surface); }

/* =========================================================================
   Erfolgsmeldung Kontakt (mit angefragten Bildern)
   ========================================================================= */
.contact-success {
    max-width: 640px; margin: 0 auto 1.5rem; text-align: center;
    background: color-mix(in srgb, #16a34a 12%, var(--surface));
    border: 1px solid color-mix(in srgb, #16a34a 40%, transparent);
    border-radius: var(--radius); padding: 2rem 1.5rem;
    animation: fade .35s ease;
}
.contact-success .cs-icon {
    width: 56px; height: 56px; margin: 0 auto .8rem; border-radius: 50%;
    background: #16a34a; color: #fff; font-size: 1.8rem; display: grid; place-items: center;
}
.contact-success h3 { margin: 0 0 .3rem; }
.contact-success p { color: var(--muted); margin: .3rem 0; }
.contact-success .cs-note { font-weight: 600; color: var(--text); }
.cs-images { margin-top: 1.2rem; }
.cs-images-title { font-size: .85rem; color: var(--muted); margin-bottom: .5rem; }
.cs-thumbs { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-bottom: 1rem; }
.cs-thumbs img { width: 90px; height: 90px; object-fit: cover; border-radius: 10px; }
html[data-theme="dark"] .contact-success { background: color-mix(in srgb, #16a34a 18%, var(--surface)); }

/* =========================================================================
   Posteingang
   ========================================================================= */
.tab-badge { display:inline-block; background:#dc2626; color:#fff; border-radius:999px; font-size:.7rem; font-weight:700; padding:.05rem .45rem; margin-left:.15rem; vertical-align:middle; }
.inbox-item { border:1px solid color-mix(in srgb, var(--muted) 18%, transparent); border-radius:12px; padding:1rem; margin-bottom:1rem; background:var(--bg); }
.inbox-item.unread { border-left:4px solid var(--primary); background: color-mix(in srgb, var(--primary) 6%, var(--bg)); }
.inbox-head { display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem; align-items:center; }
.inbox-time { color:var(--muted); font-size:.8rem; white-space:nowrap; }
.inbox-meta { color:var(--muted); font-size:.8rem; margin:.5rem 0; }
.inbox-body { white-space:pre-wrap; margin:.6rem 0; line-height:1.5; }
.inbox-images { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:.6rem; }
.inbox-images img { width:70px; height:70px; object-fit:cover; border-radius:8px; }
.inbox-actions { display:flex; gap:.4rem; flex-wrap:wrap; }
.inbox-actions form { display:inline; }

/* =========================================================================
   Merkliste
   ========================================================================= */
.merk-btn {
    position:absolute; top:8px; right:8px; z-index:4;
    width:36px; height:36px; border-radius:50%; border:0; cursor:pointer;
    background:rgba(0,0,0,.45); color:#fff; font-size:1.15rem; line-height:1;
    display:grid; place-items:center; transition:transform .2s, background .2s;
}
.merk-btn:hover { background:rgba(0,0,0,.7); transform:scale(1.12); }
.merk-btn.active { background:#e11d48; }

.merk-btn-lb {
    position:absolute; top:22px; left:22px; z-index:1001;
    border:0; border-radius:999px; padding:.6rem 1.1rem; cursor:pointer; font:inherit; font-weight:600;
    background:rgba(255,255,255,.15); color:#fff;
}
.merk-btn-lb.active { background:#e11d48; }

.merk-fab {
    position:fixed; left:22px; bottom:22px; z-index:95;
    min-width:52px; height:52px; padding:0 16px; border-radius:999px; border:0; cursor:pointer;
    background:var(--primary); color:#fff; font-size:1.2rem; font-weight:700;
    box-shadow:0 10px 26px -10px var(--primary); display:flex; align-items:center; gap:.4rem;
    transition:transform .2s;
}
.merk-fab:hover { transform:translateY(-3px); }
.merk-fab-count {
    background:#fff; color:var(--primary); border-radius:999px; font-size:.8rem;
    min-width:20px; height:20px; display:inline-grid; place-items:center; padding:0 5px;
}

.merk-overlay { position:fixed; inset:0; z-index:1200; display:none; background:rgba(0,0,0,.5); }
.merk-overlay.open { display:block; }
.merk-drawer {
    position:absolute; top:0; right:0; height:100%; width:min(380px,92%);
    background:var(--bg); box-shadow:-20px 0 60px -20px rgba(0,0,0,.5);
    display:flex; flex-direction:column; animation:merkSlide .25s ease;
}
@keyframes merkSlide { from { transform:translateX(100%); } to { transform:none; } }
.merk-head { display:flex; align-items:center; justify-content:space-between; padding:1rem 1.2rem; border-bottom:1px solid color-mix(in srgb,var(--muted) 18%,transparent); }
.merk-x { background:none; border:0; font-size:1.6rem; cursor:pointer; color:var(--muted); line-height:1; }
.merk-body { flex:1; overflow:auto; padding:1rem 1.2rem; display:flex; flex-direction:column; gap:.6rem; }
.merk-empty { padding:0 1.2rem 1rem; color:var(--muted); font-size:.9rem; }
.merk-item { display:flex; align-items:center; gap:.7rem; }
.merk-item img { width:54px; height:54px; object-fit:cover; border-radius:8px; flex:none; }
.merk-name { flex:1; min-width:0; font-size:.85rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.merk-rm { border:0; background:none; color:var(--muted); font-size:1.3rem; cursor:pointer; line-height:1; }
.merk-rm:hover { color:#dc2626; }
.merk-actions { border-top:1px solid color-mix(in srgb,var(--muted) 18%,transparent); padding:1rem 1.2rem; display:flex; flex-direction:column; gap:.6rem; }
.merk-row { display:flex; gap:.4rem; flex-wrap:wrap; }
.merk-row .btn { flex:1; }
.merk-import { display:flex; gap:.4rem; }
.merk-import input { flex:1; padding:.5rem .6rem; border-radius:9px; border:1px solid color-mix(in srgb,var(--muted) 35%,transparent); background:var(--bg); color:var(--text); }
.merk-msg { font-size:.82rem; color:var(--primary); min-height:1.1em; }

/* Toast-Benachrichtigung */
.akil-toast {
    position:fixed; left:50%; bottom:90px; transform:translateX(-50%) translateY(20px);
    background:#0f172a; color:#fff; padding:.7rem 1.2rem; border-radius:999px;
    font-size:.9rem; font-weight:600; opacity:0; pointer-events:none; z-index:1300;
    transition:opacity .25s ease, transform .25s ease; box-shadow:0 12px 30px -10px rgba(0,0,0,.6);
}
.akil-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* =========================================================================
   Verkauf, Preise, Galerie-Captions & Filter
   ========================================================================= */
/* Dauerhaft sichtbare Tags (Verkauft + Preisschild) oben links */
.gi-tags { position:absolute; top:10px; left:10px; z-index:3; display:flex; flex-direction:column; gap:7px; align-items:flex-start; }
.sold-badge {
    background:#dc2626; color:#fff; font-weight:800; font-size:.7rem; letter-spacing:.05em;
    padding:.25rem .6rem; border-radius:6px; transform:rotate(-4deg);
    box-shadow:0 4px 10px -3px rgba(0,0,0,.5);
}

/* Orangefarbenes Preisschild im Etikett-Look (gewellte Ober-/Unterkante) */
.price-tag {
    display:inline-block; --w:5px;
    background:linear-gradient(165deg,#ffa345,#ef580a);
    color:#2b1400; font-weight:800; font-size:.95rem; line-height:1.1; letter-spacing:.01em;
    padding:.5rem .85rem; transform:rotate(-3deg);
    text-shadow:0 1px 0 rgba(255,255,255,.3);
    filter:drop-shadow(0 3px 4px rgba(0,0,0,.45));
    -webkit-mask:
        radial-gradient(var(--w) at 50% 0,    #0000 96%, #000) repeat-x 0 0    / calc(2*var(--w)) var(--w),
        radial-gradient(var(--w) at 50% 100%, #0000 96%, #000) repeat-x 0 100% / calc(2*var(--w)) var(--w),
        linear-gradient(#000 0 0) no-repeat 50% 50% / 100% calc(100% - 2*var(--w));
    mask:
        radial-gradient(var(--w) at 50% 0,    #0000 96%, #000) repeat-x 0 0    / calc(2*var(--w)) var(--w),
        radial-gradient(var(--w) at 50% 100%, #0000 96%, #000) repeat-x 0 100% / calc(2*var(--w)) var(--w),
        linear-gradient(#000 0 0) no-repeat 50% 50% / 100% calc(100% - 2*var(--w));
}
.lightbox-caption .price-tag { font-size:1.1rem; transform:rotate(-2deg); }
.gi-caption {
    position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.6rem .7rem .6rem;
    background:linear-gradient(transparent, rgba(0,0,0,.72)); color:#fff;
    display:flex; flex-direction:column; align-items:flex-start; gap:.15rem;
    opacity:0; transition:opacity .25s;
}
.gallery-item:hover .gi-caption { opacity:1; }
.gi-title { font-weight:600; font-size:.85rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }
.gi-price { font-weight:800; font-size:.85rem; white-space:nowrap; }
@media (hover:none) { .gi-caption { opacity:1; } }
/* Platz für den Download-/Anfragen-Button schaffen, damit er die Bildunterschrift nicht verdeckt */
.gallery-item:has(.inquire-btn) .gi-caption,
.gallery-item:has(.download-btn) .gi-caption { padding-bottom: 3.2rem; }

.gallery-filter { display:flex; gap:.5rem; justify-content:center; margin-bottom:1.5rem; flex-wrap:wrap; }
.gf-btn {
    border:1px solid color-mix(in srgb,var(--muted) 35%,transparent); background:var(--surface); color:var(--text);
    padding:.45rem 1.1rem; border-radius:999px; cursor:pointer; font:inherit; font-weight:600; font-size:.85rem;
}
.gf-btn.active { background:var(--primary); color:#fff; border-color:var(--primary); }

.lightbox-caption {
    position:absolute; left:0; right:0; bottom:0; padding:2rem 1.2rem 1.2rem;
    background:linear-gradient(transparent, rgba(0,0,0,.8)); color:#fff;
    display:flex; flex-wrap:wrap; gap:.3rem 1rem; align-items:baseline; justify-content:center; text-align:center;
}
/* Wenn der „Anfragen"-Button vorhanden ist, Caption darüber anheben */
.lightbox:has(.inquire-btn-lb) .lightbox-caption { padding-bottom: 5rem; }
.lc-title { font-weight:700; font-size:1.05rem; width:100%; }
.lc-desc { width:100%; font-size:.9rem; opacity:.85; }
.lc-price { font-weight:800; }
.lc-sold { background:#dc2626; color:#fff; padding:.1rem .5rem; border-radius:5px; font-weight:800; font-size:.8rem; }

/* =========================================================================
   Cookie-Consent-Banner
   ========================================================================= */
.consent {
    position:fixed; left:0; right:0; bottom:0; z-index:1400; background:var(--surface);
    border-top:1px solid color-mix(in srgb,var(--muted) 25%,transparent);
    box-shadow:0 -10px 40px -20px rgba(0,0,0,.5);
}
.consent-inner { display:flex; align-items:center; gap:1rem; padding:1rem 0; flex-wrap:wrap; }
.consent-text { flex:1; min-width:240px; font-size:.88rem; color:var(--text); }
.consent-btns { display:flex; gap:.5rem; }

/* =========================================================================
   Admin: Bild-Badges & Detailformular
   ========================================================================= */
.mi-badges { position:absolute; top:8px; left:8px; display:flex; flex-direction:column; gap:4px; align-items:flex-start; }
.mi-badges .mi-badge { position:static; }
.mi-badge-sold { background:#dc2626; color:#fff; }
.mi-badge-warn { background:#f59e0b; color:#1a1205; }
.mi-details { margin-top:.5rem; border-top:1px solid color-mix(in srgb,var(--muted) 14%,transparent); padding-top:.5rem; }
.mi-details summary { cursor:pointer; font-size:.82rem; color:var(--muted); font-weight:600; }
.mi-meta-form { margin-top:.6rem; }
.mi-meta-form .field { margin-bottom:.5rem; }
.mi-meta-form input, .mi-meta-form textarea { padding:.45rem .6rem; font-size:.85rem; }
