/* 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,");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)}