50dfca59e1
P1 Medien: eigener Admin-Bereich /admin/medien (Grid, Mehrfach-Upload, Drag&Drop, Alt-Text, URL kopieren, Loeschen). Upload konvertiert JPG/PNG via sharp zu WebP (Qualitaet 82, max 2000px), Original wird verworfen; WebP/SVG/GIF/AVIF unveraendert; Konvertierungsfehler -> Original behalten statt 500. media um alt/width/height erweitert. Wiederverwendbarer Medien-Picker (public/media-picker.js) ersetzt den URL-Prompt im Block-Editor, Produkt-Editor (Karte/Galerie/Varianten-Bild), Slides und Popups. JSON-Quelle /api/admin/media (session-gesichert). P2 Varianten: products.options_json + Tabelle product_variants. Produkt-Editor mit Options-Definition + Matrix-Generator (Preis-Override/Bestand/SKU/Bild/aktiv je Variante). PDP-Selektoren -> Variante; Cart/Checkout tragen sku+Options, Order-Item bekommt sku/variant, Variantenpreis serverseitig verifiziert. Produkte ohne Optionen unveraendert. P3 Litestream: Binary im Dockerfile, docker-entrypoint.sh (Restore+replicate nur bei LITESTREAM_REPLICA_URL, sonst reiner Node-Start), litestream.yml, Backup-Status unter Einstellungen, README + .env.example. P4 Analytics: Bestseller, Top-Suchbegriffe, Umsatz/Quelle, Umsatz-Zeitreihe, AOV, Wiederkaufrate, Lager-Warnungen. Neue Dep sharp. +19 Unit-Tests (49 gesamt gruen), Build + Smoke (P1-P4) gruen.
299 lines
25 KiB
CSS
299 lines
25 KiB
CSS
/* hd-commerce Admin — „Warmth & Approachability" (ui-ux-design-pro).
|
|
Helles, warmes Papier-Off-White, eine Akzentfarbe (Brand, aus settings),
|
|
weiche getönte Schatten + Hairlines (EINE Tiefe-Strategie), Fraunces für Titel.
|
|
Var-Namen bleiben stabil (Inline-Styles der Seiten hängen daran). */
|
|
:root{
|
|
/* Flächen — warmes Papier; Sidebar = Canvas, Cards = Weiß (kein Farb-Fragmentieren) */
|
|
--s-bg:#f6f3ec; /* App-Canvas + Sidebar */
|
|
--s-surface:#ffffff; /* Cards/erhöht */
|
|
--s-sunken:#f1ebe1; /* Inputs/Tabellenkopf/inset */
|
|
/* Hairlines — warm, niedrige Deckkraft, 3 Stufen */
|
|
--s-line-soft:rgba(58,46,34,.06);
|
|
--s-border:rgba(58,46,34,.11);
|
|
--s-border-2:rgba(58,46,34,.18);
|
|
/* Text — warmes Ink, 4 Stufen */
|
|
--s-ink:#2b2620; /* primär */
|
|
--s-text:#4c453c; /* sekundär */
|
|
--s-subtle:#766c5f; /* tertiär */
|
|
--s-faint:#9a9082; /* muted */
|
|
/* Akzent (Brand, via Inline-Style überschrieben) + Tönung */
|
|
--accent:#b8566a; --accent-dark:#8d3f50;
|
|
--s-acc-l:color-mix(in srgb,var(--accent) 12%, #fff);
|
|
--s-acc-ring:color-mix(in srgb,var(--accent) 26%, transparent);
|
|
/* Semantik — warm abgestimmt */
|
|
--s-green-bg:#e5f0e7; --s-green-t:#2f6b4f;
|
|
--s-amber-bg:#fbf0db; --s-amber-t:#7c4d10;
|
|
--s-red:#fbe7e3; --s-red-t:#9a2b1c;
|
|
--s-blue:#eaedfb; --s-blue-t:#37508c;
|
|
--s-gray:#ece5da; --s-gray-t:#5a5249;
|
|
/* Radius + getönte Schatten (eine Strategie) */
|
|
--s-radius:14px; --s-radius-sm:9px;
|
|
--s-shadow:0 1px 2px rgba(60,45,33,.05), 0 6px 16px -10px rgba(60,45,33,.14);
|
|
--s-shadow-pop:0 12px 32px -10px rgba(60,45,33,.26);
|
|
--s-font:'Public Sans Variable',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
|
|
--s-display:'Fraunces Variable',Georgia,'Times New Roman',serif;
|
|
--s-ease:cubic-bezier(.2,.6,.2,1);
|
|
}
|
|
*{box-sizing:border-box}
|
|
.admin-body{margin:0;background:var(--s-bg);color:var(--s-text);font-family:var(--s-font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
|
|
.admin-body a{color:inherit;text-decoration:none}
|
|
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
|
|
.admin-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
|
|
|
|
/* Sidebar — gleiche Fläche wie Canvas + Hairline (fragmentiert nicht) */
|
|
.s-side{background:var(--s-bg);border-right:1px solid var(--s-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
|
|
.s-brand{display:flex;align-items:center;gap:11px;padding:18px 16px 16px;border-bottom:1px solid var(--s-line-soft)}
|
|
.s-brand-logo{width:34px;height:34px;border-radius:10px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800;font-size:15px;box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 2px 6px -2px color-mix(in srgb,var(--accent) 60%, transparent)}
|
|
.s-brand-name{font-family:var(--s-display);font-weight:560;font-size:16px;color:var(--s-ink);line-height:1.1;letter-spacing:-.01em}
|
|
.s-brand-sub{font-size:11px;color:var(--s-faint);margin-top:1px}
|
|
.s-nav{padding:12px 10px;display:flex;flex-direction:column;gap:2px;flex:1;overflow:auto}
|
|
.s-nav a{position:relative;display:flex;align-items:center;gap:11px;padding:8px 11px;border-radius:9px;font-weight:500;font-size:13.5px;color:var(--s-text);transition:background .15s var(--s-ease),color .15s var(--s-ease)}
|
|
.s-nav a svg{width:18px;height:18px;flex:none;color:var(--s-subtle);transition:color .15s var(--s-ease)}
|
|
.s-nav a:hover{background:var(--s-surface);color:var(--s-ink)}
|
|
.s-nav a:hover svg{color:var(--s-ink)}
|
|
.s-nav a.active{background:var(--s-acc-l);color:var(--accent-dark);font-weight:600}
|
|
.s-nav a.active svg{color:var(--accent-dark)}
|
|
.s-nav a.active::before{content:'';position:absolute;left:-10px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)} /* Lesezeichen-Marker = Signatur */
|
|
.s-nav-sec{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--s-faint);padding:16px 12px 6px;font-weight:700}
|
|
.s-side-foot{padding:13px 16px;border-top:1px solid var(--s-line-soft);font-size:12px;color:var(--s-faint)}
|
|
.s-side-foot a{color:var(--accent);font-weight:600}
|
|
|
|
/* Main + Topbar */
|
|
.s-main{display:flex;flex-direction:column;min-width:0}
|
|
.s-topbar{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--s-bg) 82%, transparent);backdrop-filter:saturate(1.4) blur(8px);-webkit-backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--s-border);padding:14px 30px;display:flex;align-items:center;justify-content:space-between;gap:16px}
|
|
.s-crumbs{font-size:12px;color:var(--s-faint);margin-bottom:3px;display:flex;align-items:center;gap:6px}
|
|
.s-crumbs a{color:var(--s-subtle);transition:color .15s}.s-crumbs a:hover{color:var(--accent)}
|
|
.s-title{font-family:var(--s-display);font-size:23px;font-weight:560;color:var(--s-ink);letter-spacing:-.015em;line-height:1.1}
|
|
.s-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
|
|
.s-content{padding:26px 30px 72px;max-width:1140px;width:100%}
|
|
|
|
/* Buttons — Zustände vollständig */
|
|
.s-btn{display:inline-flex;align-items:center;gap:7px;border-radius:var(--s-radius-sm);font-size:13px;font-weight:600;padding:8px 14px;cursor:pointer;border:1px solid var(--s-border-2);background:var(--s-surface);color:var(--s-text);font-family:inherit;transition:background .15s var(--s-ease),border-color .15s,transform .15s,box-shadow .15s}
|
|
.s-btn:hover{background:var(--s-bg);color:var(--s-ink);transform:translateY(-1px);box-shadow:var(--s-shadow)}
|
|
.s-btn:active{transform:translateY(0);box-shadow:none}
|
|
.s-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
|
|
.s-btn.s-btn-primary,a.s-btn-primary{background:var(--accent);border-color:transparent;color:#fff;box-shadow:0 1px 0 rgba(0,0,0,.06),0 4px 10px -4px color-mix(in srgb,var(--accent) 55%, transparent)}
|
|
.s-btn.s-btn-primary:hover,a.s-btn-primary:hover{background:var(--accent-dark);color:#fff;box-shadow:0 2px 0 rgba(0,0,0,.06),0 8px 18px -6px color-mix(in srgb,var(--accent) 60%, transparent)}
|
|
.s-btn-danger{color:var(--s-red-t);border-color:color-mix(in srgb,var(--s-red-t) 26%, #fff);background:var(--s-surface)}
|
|
.s-btn-danger:hover{background:var(--s-red);color:var(--s-red-t)}
|
|
.s-btn-sm{padding:5px 10px;font-size:12px}
|
|
|
|
/* Cards */
|
|
.s-card{background:var(--s-surface);border:1px solid var(--s-border);border-radius:var(--s-radius);box-shadow:var(--s-shadow)}
|
|
.s-card-pad{padding:20px 22px}
|
|
.s-card-head{padding:15px 22px;border-bottom:1px solid var(--s-line-soft);font-weight:700;color:var(--s-ink);font-size:14px;display:flex;justify-content:space-between;align-items:center}
|
|
.s-grid{display:grid;gap:18px}.s-stack{display:flex;flex-direction:column;gap:18px}
|
|
|
|
/* KPIs */
|
|
.s-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
|
|
.s-kpi{background:var(--s-surface);border:1px solid var(--s-border);border-radius:var(--s-radius);padding:18px 20px;box-shadow:var(--s-shadow);transition:transform .18s var(--s-ease),box-shadow .18s}
|
|
.s-kpi:hover{transform:translateY(-2px);box-shadow:0 2px 4px rgba(60,45,33,.05),0 14px 28px -14px rgba(60,45,33,.22)}
|
|
.s-kpi-label{font-size:11px;color:var(--s-subtle);font-weight:600;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:7px}
|
|
.s-kpi-val{font-size:28px;font-weight:700;color:var(--s-ink);margin-top:9px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
|
|
.s-kpi-sub{font-size:12px;color:var(--s-faint);margin-top:3px}
|
|
|
|
/* Tabellen */
|
|
.s-table-wrap{overflow:auto}
|
|
.s-table{width:100%;border-collapse:collapse;font-size:13.5px}
|
|
.s-table th{text-align:left;padding:11px 16px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--s-subtle);font-weight:700;background:var(--s-sunken);border-bottom:1px solid var(--s-border);white-space:nowrap}
|
|
.s-table th:first-child{border-top-left-radius:var(--s-radius)}.s-table th:last-child{border-top-right-radius:var(--s-radius)}
|
|
.s-table td{padding:13px 16px;border-bottom:1px solid var(--s-line-soft);vertical-align:middle}
|
|
.s-table tr:last-child td{border-bottom:none}
|
|
.s-table tbody tr.clk{cursor:pointer;transition:background .12s}
|
|
.s-table tbody tr.clk:hover{background:var(--s-bg)}
|
|
.s-table .num{text-align:right;font-variant-numeric:tabular-nums}
|
|
.s-prodcell{display:flex;align-items:center;gap:12px}
|
|
.s-prodcell img{width:40px;height:48px;object-fit:cover;border-radius:7px;border:1px solid var(--s-border);background:var(--s-sunken)}
|
|
.s-prodcell .nm{font-weight:600;color:var(--s-ink)}
|
|
.s-muted{color:var(--s-faint)}
|
|
.s-link{color:var(--accent);font-weight:600}
|
|
|
|
/* Badges — Punkt + warm getönte Pille */
|
|
.s-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 11px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.5}
|
|
.s-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.9}
|
|
.s-badge.green{background:var(--s-green-bg);color:var(--s-green-t)}
|
|
.s-badge.amber{background:var(--s-amber-bg);color:var(--s-amber-t)}
|
|
.s-badge.gray{background:var(--s-gray);color:var(--s-gray-t)}
|
|
.s-badge.red{background:var(--s-red);color:var(--s-red-t)}
|
|
.s-badge.blue{background:var(--s-blue);color:var(--s-blue-t)}
|
|
|
|
/* Formulare — Inputs „inset", eigene Controls */
|
|
.s-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
|
|
.s-field{min-width:0;display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
|
|
.s-field.full{grid-column:1/-1}
|
|
.s-label{font-size:13px;font-weight:600;color:var(--s-text)}
|
|
.s-input,.s-textarea,.s-select{min-width:0;border:1px solid var(--s-border-2);border-radius:9px;padding:10px 12px;font:inherit;font-size:14px;background:#fcfbf8;color:var(--s-ink);width:100%;font-family:inherit;transition:border-color .15s,box-shadow .15s,background .15s}
|
|
.s-input::placeholder,.s-textarea::placeholder{color:var(--s-faint)}
|
|
.s-textarea{min-height:130px;resize:vertical;line-height:1.55}
|
|
.s-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23766c5f' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px;cursor:pointer}
|
|
.s-input:focus,.s-textarea:focus,.s-select:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px var(--s-acc-ring)}
|
|
.s-input[type=color]{padding:4px;height:42px;cursor:pointer;background:#fff}
|
|
.s-help{font-size:12px;color:var(--s-faint)}
|
|
.s-check{display:flex;align-items:center;gap:9px;font-size:14px;cursor:pointer}
|
|
.s-check input{width:17px;height:17px;accent-color:var(--accent);cursor:pointer}
|
|
.s-two-col{display:grid;grid-template-columns:1fr 330px;gap:18px;align-items:start}
|
|
|
|
/* Flash, Empty, Sektionstitel */
|
|
.s-flash{background:var(--s-green-bg);color:var(--s-green-t);border:1px solid color-mix(in srgb,var(--s-green-t) 22%, #fff);padding:11px 16px;border-radius:10px;font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:9px}
|
|
.s-empty{padding:48px 24px;text-align:center;color:var(--s-faint)}
|
|
.s-section-title{font-size:13px;font-weight:700;color:var(--s-ink);margin:0 0 4px;letter-spacing:.01em}
|
|
|
|
/* Funnel + Balken */
|
|
.s-funnel{display:flex;flex-direction:column;gap:10px}
|
|
.s-funnel-row{display:flex;align-items:center;gap:14px}
|
|
.s-funnel-row .fl{width:140px;font-size:13px;color:var(--s-subtle);font-weight:600;flex:none}
|
|
.s-funnel-bar{flex:1;height:32px;background:var(--s-sunken);border-radius:8px;overflow:hidden;position:relative}
|
|
.s-funnel-fill{height:100%;background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 78%, #fff));border-radius:8px;display:flex;align-items:center;padding:0 11px;color:#fff;font-size:12px;font-weight:700;min-width:40px;font-variant-numeric:tabular-nums;transition:width .5s var(--s-ease)}
|
|
.s-funnel-mini{display:flex;align-items:center;gap:10px;margin-top:6px}
|
|
.s-fm-step{flex:1;text-align:center;background:var(--s-sunken);border-radius:10px;padding:13px 8px}
|
|
.s-fm-step .v{font-size:21px;font-weight:700;color:var(--s-ink);font-variant-numeric:tabular-nums}
|
|
.s-fm-step .l{font-size:11px;color:var(--s-subtle);font-weight:600;margin-top:2px}
|
|
.s-fm-arrow{color:var(--s-faint);font-size:18px}
|
|
.s-bar-track{height:8px;background:var(--s-sunken);border-radius:999px;overflow:hidden}
|
|
.s-bar-track i{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .5s var(--s-ease)}
|
|
|
|
/* Medien + Tabs */
|
|
.s-media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
|
|
.s-media-item{border:1px solid var(--s-border);border-radius:10px;overflow:hidden;background:var(--s-surface);box-shadow:var(--s-shadow);transition:transform .18s var(--s-ease)}
|
|
.s-media-item:hover{transform:translateY(-2px)}
|
|
.s-media-item img{width:100%;height:112px;object-fit:cover;background:var(--s-sunken)}
|
|
.s-media-item .mi{padding:9px 11px;font-size:11px;color:var(--s-subtle);display:flex;flex-direction:column;gap:6px}
|
|
.s-tabs{display:flex;gap:6px;border-bottom:1px solid var(--s-border);margin-bottom:22px;flex-wrap:wrap}
|
|
.s-tab{padding:10px 15px;font-size:13.5px;font-weight:600;color:var(--s-subtle);border-bottom:2px solid transparent;cursor:pointer;transition:color .15s}
|
|
.s-tab:hover{color:var(--s-ink)}
|
|
.s-tab.active{color:var(--accent-dark);border-color:var(--accent)}
|
|
|
|
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
|
|
@media(max-width:860px){.admin-shell{grid-template-columns:1fr}.s-side{position:static;height:auto}.s-nav{flex-direction:row;flex-wrap:wrap}.s-nav a.active::before{display:none}.s-kpis{grid-template-columns:1fr 1fr}.s-form-grid{grid-template-columns:1fr}.s-two-col{grid-template-columns:1fr}}
|
|
|
|
/* ===== v2: Login ===== */
|
|
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center;background:
|
|
radial-gradient(1200px 600px at 50% -10%, color-mix(in srgb,var(--accent) 9%, transparent), transparent 60%),
|
|
var(--s-bg)}
|
|
.login-wrap{width:100%;max-width:420px;padding:24px}
|
|
.login-card{background:var(--s-surface);border:1px solid var(--s-border);border-radius:18px;padding:34px 32px 26px;box-shadow:var(--s-shadow-pop);text-align:left}
|
|
.login-logo{width:52px;height:52px;border-radius:14px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800;font-size:23px;margin:0 auto 16px;box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 6px 18px -8px color-mix(in srgb,var(--accent) 70%, transparent)}
|
|
.login-title{font-family:var(--s-display);font-weight:560;font-size:25px;color:var(--s-ink);text-align:center;margin:0;letter-spacing:-.02em}
|
|
.login-sub{text-align:center;color:var(--s-subtle);font-size:13.5px;margin:4px 0 22px}
|
|
.login-error{background:var(--s-red);color:var(--s-red-t);border:1px solid color-mix(in srgb,var(--s-red-t) 26%, #fff);padding:10px 14px;border-radius:10px;font-weight:600;font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px}
|
|
.login-error::before{content:'!';display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:var(--s-red-t);color:#fff;font-size:12px;font-weight:800;flex:none}
|
|
.login-remember{margin:2px 0 18px;font-size:13.5px;color:var(--s-text)}
|
|
.login-submit{width:100%;justify-content:center;padding:11px;font-size:14px}
|
|
.login-foot{text-align:center;color:var(--s-faint);font-size:11.5px;margin:18px 0 0}
|
|
|
|
/* ===== v2: Account-Menü + ⌘K-Trigger ===== */
|
|
.s-cmdk-trigger{gap:9px;padding:7px 10px}
|
|
.s-kbd{font-size:11px;font-weight:700;color:var(--s-subtle);background:var(--s-sunken);border:1px solid var(--s-border);border-radius:6px;padding:1px 6px;letter-spacing:.02em}
|
|
.s-account{position:relative}
|
|
.s-account-btn{display:flex;align-items:center;gap:9px;background:var(--s-surface);border:1px solid var(--s-border-2);border-radius:var(--s-radius-sm);padding:5px 11px 5px 6px;cursor:pointer;font-family:inherit;transition:background .15s,box-shadow .15s,transform .15s}
|
|
.s-account-btn:hover{background:var(--s-bg);box-shadow:var(--s-shadow);transform:translateY(-1px)}
|
|
.s-acct-av{width:28px;height:28px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;flex:none}
|
|
.s-acct-meta{display:flex;flex-direction:column;line-height:1.15;text-align:left}
|
|
.s-acct-name{font-size:13px;font-weight:600;color:var(--s-ink);max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
|
.s-acct-role{font-size:11px;color:var(--s-faint)}
|
|
.s-account-menu[hidden]{display:none}
|
|
.s-account-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--s-surface);border:1px solid var(--s-border);border-radius:12px;box-shadow:var(--s-shadow-pop);padding:6px;min-width:170px;z-index:40;display:flex;flex-direction:column;gap:2px}
|
|
.s-account-menu a{padding:9px 12px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--s-text);transition:background .12s}
|
|
.s-account-menu a:hover{background:var(--s-bg);color:var(--s-ink)}
|
|
.s-account-menu a.danger{color:var(--s-red-t)}
|
|
.s-account-menu a.danger:hover{background:var(--s-red)}
|
|
|
|
/* ===== v2: Command-Palette ===== */
|
|
.s-cmdk{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh}
|
|
.s-cmdk[hidden]{display:none}
|
|
.s-cmdk-backdrop{position:absolute;inset:0;background:rgba(43,38,32,.34);backdrop-filter:blur(2px);animation:fade .15s var(--s-ease)}
|
|
.s-cmdk-panel{position:relative;width:100%;max-width:560px;background:var(--s-surface);border:1px solid var(--s-border);border-radius:16px;box-shadow:var(--s-shadow-pop);overflow:hidden;animation:pop .16s var(--s-ease)}
|
|
.s-cmdk-input{width:100%;border:none;border-bottom:1px solid var(--s-line-soft);padding:17px 20px;font:inherit;font-size:16px;color:var(--s-ink);background:transparent;outline:none}
|
|
.s-cmdk-input::placeholder{color:var(--s-faint)}
|
|
.s-cmdk-list{list-style:none;margin:0;padding:8px;max-height:46vh;overflow:auto}
|
|
.s-cmdk-item{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-radius:10px;cursor:pointer;font-size:14px;color:var(--s-text)}
|
|
.s-cmdk-item em{font-style:normal;font-size:11px;color:var(--s-faint);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
|
|
.s-cmdk-item.active{background:var(--s-acc-l);color:var(--accent-dark)}
|
|
.s-cmdk-item.active em{color:color-mix(in srgb,var(--accent-dark) 70%, transparent)}
|
|
|
|
/* ===== v2: Toasts ===== */
|
|
.s-toasts{position:fixed;right:20px;bottom:20px;z-index:120;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
|
|
.s-toast{background:var(--s-ink);color:#fff;padding:12px 18px;border-radius:11px;font-size:13.5px;font-weight:600;box-shadow:var(--s-shadow-pop);opacity:0;transform:translateY(8px);transition:opacity .25s var(--s-ease),transform .25s var(--s-ease);max-width:340px}
|
|
.s-toast.show{opacity:1;transform:translateY(0)}
|
|
.s-toast.ok{background:#2f6b4f}
|
|
.s-toast.err{background:var(--s-red-t)}
|
|
|
|
/* ===== v2: Empty-States, Skeleton, KPI-Trend ===== */
|
|
.s-emptystate{text-align:center;padding:54px 24px;display:flex;flex-direction:column;align-items:center;gap:12px}
|
|
.s-emptystate .es-icon{width:56px;height:56px;border-radius:16px;background:var(--s-acc-l);color:var(--accent-dark);display:grid;place-items:center}
|
|
.s-emptystate .es-icon svg{width:28px;height:28px}
|
|
.s-emptystate h3{font-family:var(--s-display);font-weight:560;font-size:18px;color:var(--s-ink);margin:0}
|
|
.s-emptystate p{color:var(--s-subtle);font-size:13.5px;margin:0;max-width:360px}
|
|
.s-kpi-trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;margin-top:6px;font-variant-numeric:tabular-nums}
|
|
.s-kpi-trend.up{color:var(--s-green-t)}.s-kpi-trend.down{color:var(--s-red-t)}
|
|
.s-kpi-spark{height:30px;margin-top:8px}
|
|
.s-quick{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
|
|
.s-quick a{display:flex;align-items:center;gap:11px;padding:14px 16px;border:1px solid var(--s-border);border-radius:12px;background:var(--s-surface);box-shadow:var(--s-shadow);font-weight:600;color:var(--s-ink);transition:transform .15s var(--s-ease),box-shadow .15s}
|
|
.s-quick a:hover{transform:translateY(-2px);box-shadow:var(--s-shadow-pop)}
|
|
.s-quick a svg{width:20px;height:20px;color:var(--accent)}
|
|
.s-feed{display:flex;flex-direction:column}
|
|
.s-feed-row{display:flex;align-items:center;gap:12px;padding:11px 22px;border-bottom:1px solid var(--s-line-soft);font-size:13px}
|
|
.s-feed-row:last-child{border-bottom:none}
|
|
.s-feed-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex:none}
|
|
.s-feed-row .t{color:var(--s-faint);margin-left:auto;font-size:12px;white-space:nowrap}
|
|
@keyframes fade{from{opacity:0}to{opacity:1}}
|
|
@keyframes pop{from{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:none}}
|
|
|
|
/* v2.3 — Bewertungs-Zähler in der Nav */
|
|
.s-nav-badge{margin-left:auto;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}
|
|
|
|
/* v2.4 — Medien-Picker-Modal + Varianten-Matrix */
|
|
.mp-overlay{position:fixed;inset:0;background:rgba(20,24,30,.46);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:300;padding:24px}
|
|
.mp-overlay.open{display:flex;animation:fade .15s var(--s-ease)}
|
|
.mp-modal{width:min(920px,96vw);max-height:90vh;display:flex;flex-direction:column;background:var(--s-bg);border:1px solid var(--s-border);border-radius:16px;box-shadow:0 24px 70px rgba(0,0,0,.32);overflow:hidden;animation:pop .18s var(--s-ease)}
|
|
.mp-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--s-border);font-family:var(--s-display);font-size:16px;color:var(--s-ink)}
|
|
.mp-head-actions{display:flex;align-items:center;gap:8px}
|
|
.mp-upbtn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border:1px solid var(--accent);color:var(--accent-dark);border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;background:var(--s-surface)}
|
|
.mp-upbtn:hover{background:var(--s-acc-ring)}
|
|
.mp-close{width:30px;height:30px;border:none;background:var(--s-sunken);border-radius:8px;cursor:pointer;color:var(--s-subtle);font-size:15px}
|
|
.mp-close:hover{background:var(--s-border);color:var(--s-ink)}
|
|
.mp-drop{margin:14px 18px 0;padding:12px;border:1px dashed var(--s-border-2);border-radius:10px;text-align:center;font-size:12.5px;color:var(--s-faint);transition:.15s}
|
|
.mp-drop.over{border-color:var(--accent);background:var(--s-acc-ring);color:var(--accent-dark)}
|
|
.mp-msg{margin:8px 18px 0;font-size:12.5px;min-height:0;color:var(--s-faint);display:none}
|
|
.mp-msg.show{display:block}
|
|
.mp-msg.ok{color:var(--s-green-t,#1a7f4b)}
|
|
.mp-msg.err{color:var(--s-red-t,#b3261e)}
|
|
.mp-grid{flex:1;overflow:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:13px;padding:16px 18px}
|
|
.mp-empty{grid-column:1/-1;text-align:center;color:var(--s-faint);padding:40px 10px;font-size:13.5px}
|
|
.mp-card{position:relative;border:1px solid var(--s-border);border-radius:11px;overflow:hidden;background:var(--s-surface);cursor:pointer;transition:.15s}
|
|
.mp-card:hover{box-shadow:var(--s-shadow-pop);transform:translateY(-2px)}
|
|
.mp-card.sel{border-color:var(--accent);box-shadow:0 0 0 2px var(--s-acc-ring)}
|
|
.mp-thumb{height:104px;background:var(--s-sunken)}
|
|
.mp-thumb img{width:100%;height:100%;object-fit:cover}
|
|
.mp-meta{padding:7px 9px;display:flex;flex-direction:column;gap:2px}
|
|
.mp-name{font-size:11px;color:var(--s-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
|
.mp-size{font-size:10.5px;color:var(--s-faint)}
|
|
.mp-card-acts{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:.15s}
|
|
.mp-card:hover .mp-card-acts{opacity:1}
|
|
.mp-ico{width:26px;height:26px;border:none;border-radius:7px;background:rgba(255,255,255,.92);box-shadow:var(--s-shadow);cursor:pointer;font-size:12px;display:grid;place-items:center}
|
|
.mp-ico:hover{background:#fff}
|
|
.mp-del:hover{color:#b3261e}
|
|
.mp-foot{display:flex;align-items:center;gap:10px;padding:12px 18px;border-top:1px solid var(--s-border)}
|
|
.mp-sel{font-size:12.5px;color:var(--s-subtle);font-weight:600}
|
|
.mp-btn{padding:8px 16px;border:1px solid var(--s-border);border-radius:9px;background:var(--s-surface);font-size:13px;font-weight:600;cursor:pointer;color:var(--s-ink);font-family:inherit}
|
|
.mp-btn:hover{border-color:var(--s-border-2)}
|
|
.mp-primary{background:var(--accent);border-color:var(--accent);color:#fff}
|
|
.mp-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
|
|
|
|
/* Bild-Feld mit Vorschau + Picker */
|
|
.s-imgfield{display:flex;gap:8px;align-items:center}
|
|
.s-imgfield .s-input{flex:1}
|
|
.s-imgthumb{width:42px;height:42px;border-radius:8px;object-fit:cover;background:var(--s-sunken);border:1px solid var(--s-border);flex:none}
|
|
|
|
/* Varianten-Matrix */
|
|
.s-vopts{display:flex;flex-direction:column;gap:10px}
|
|
.s-vopt-row{display:grid;grid-template-columns:160px 1fr auto;gap:8px;align-items:center}
|
|
.s-vtable{width:100%;border-collapse:collapse;font-size:12.5px}
|
|
.s-vtable th,.s-vtable td{padding:7px 8px;border-bottom:1px solid var(--s-line-soft);text-align:left;vertical-align:middle}
|
|
.s-vtable th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--s-faint);font-weight:700}
|
|
.s-vtable input.s-vin{width:100%;padding:6px 8px;border:1px solid var(--s-border);border-radius:7px;font-size:12.5px;font-family:inherit}
|
|
.s-vtable td.num input{text-align:right}
|
|
.s-vtable .s-vimg{width:34px;height:34px;border-radius:6px;object-fit:cover;background:var(--s-sunken);border:1px solid var(--s-border);cursor:pointer}
|
|
.s-vrow-off{opacity:.5}
|
|
.s-vbadge{font-size:11px;color:var(--s-subtle)}
|