/* ============================================================
   OPTIC SETTINGS — style.css
   Chrome / metallic gaming aesthetic. Alle Styles zentral.
   ============================================================ */
:root{
  --bg:#050506;--bg2:#0c0d10;--panel:#121419;--ink:#e9ebee;--mute:#8a8d94;
  --line:rgba(255,255,255,.10);--accent:#7ba9c9;--bolt:#bfe6ff;
  --ok:#5fd58a;--warn:#e7c14a;--err:#e76d6d;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Chakra Petch',sans-serif;line-height:1.5;overflow-x:hidden;min-height:100vh}
a{color:inherit;text-decoration:none}

/* ---- background atmosphere ---- */
.grain{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.glow{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(1100px 600px at 50% -10%,rgba(190,225,255,.10),transparent 60%),radial-gradient(700px 500px at 90% 20%,rgba(255,255,255,.04),transparent 60%),radial-gradient(900px 700px at 0% 90%,rgba(120,140,170,.06),transparent 60%)}

/* ---- cog chrome fill ---- */
.hero-cog, .brand .cog, .cogfill { fill: url(#chromeGrad); }
/* ---- chrome text ---- */
.chrome{font-family:'Saira',sans-serif;font-weight:900;font-style:italic;background:linear-gradient(180deg,#fff 0%,#dfe2e6 16%,#9aa0a8 34%,#fff 49%,#6c7075 52%,#c6cbd2 70%,#f6f8fb 86%,#aeb3ba 100%);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- nav ---- */
nav.topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px clamp(16px,4vw,48px);background:linear-gradient(180deg,rgba(5,5,6,.92),rgba(5,5,6,.55));backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer}
.brand .cog{width:24px;height:24px;animation:spin 18s linear infinite}
.cogfill path,.brand .cog path{fill:url(#chromeGrad)}
.brand b{font-family:'Saira';font-weight:900;font-style:italic;font-size:18px;letter-spacing:.5px}
.navlinks{display:flex;gap:24px;font-weight:600;font-size:13px;letter-spacing:1px;text-transform:uppercase;flex:1;justify-content:center}
.navlinks a{color:var(--mute);position:relative;transition:.2s;cursor:pointer}
.navlinks a:hover,.navlinks a.active{color:#fff}
.navlinks a.active::after{content:'';position:absolute;left:0;bottom:-6px;width:100%;height:2px;background:linear-gradient(90deg,#fff,var(--accent))}
.navright{display:flex;align-items:center;gap:12px}
@media(max-width:880px){.navlinks{display:none}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- buttons ---- */
.btn{font-family:'Chakra Petch';font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:13px;padding:11px 24px;border:none;cursor:pointer;transition:.22s;display:inline-flex;align-items:center;gap:8px;clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
.btn-chrome{background:linear-gradient(180deg,#fff,#cfd3d8 45%,#7e8288 55%,#e9ecef);color:#0a0a0c;box-shadow:0 6px 22px rgba(190,225,255,.2)}
.btn-chrome:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(190,225,255,.38)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.26)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff}
.btn-sm{padding:7px 14px;font-size:11px}
.btn-danger{background:linear-gradient(180deg,#f4a3a3,#c45757);color:#160606}
.btn-danger:hover{transform:translateY(-2px)}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important}

/* ---- badges ---- */
.badge{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:2px;border:1px solid var(--line)}
.badge.dev{color:var(--bolt);border-color:rgba(191,230,255,.5);background:rgba(191,230,255,.08)}
.badge.admin{color:var(--warn);border-color:rgba(231,193,74,.5);background:rgba(231,193,74,.08)}
.badge.user{color:var(--mute)}
.badge.ok{color:var(--ok);border-color:rgba(95,213,138,.4)}
.badge.draft,.badge.banned{color:var(--mute)}
.badge.banned{color:var(--err);border-color:rgba(231,109,109,.4)}

/* ---- view + layout ---- */
#view{position:relative;z-index:1;padding-top:62px;min-height:100vh}
.wrap{max-width:1240px;margin:0 auto;padding:clamp(40px,6vw,80px) clamp(18px,5vw,64px)}
.kicker{font-weight:600;letter-spacing:.45em;text-transform:uppercase;font-size:12px;color:var(--accent)}
.h-title{font-size:clamp(34px,5.4vw,62px);margin-top:8px;line-height:1}
.lead{color:var(--mute);max-width:560px;margin-top:14px;font-size:clamp(15px,1.4vw,18px)}
.muted{color:var(--mute)}
.stack{display:flex;flex-direction:column;gap:8px}
.between{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ---- hero ---- */
header.hero{position:relative;min-height:calc(100vh - 62px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 18px}
.hero-cog{position:absolute;width:min(54vw,560px);height:min(54vw,560px);top:48%;left:50%;transform:translate(-50%,-50%);opacity:.13;transition:opacity .4s;animation:heroCogFloat 8s ease-in-out infinite}
.hero-cog path{fill:url(#chromeGrad)}
.bolt{position:absolute;opacity:0;mix-blend-mode:screen;filter:drop-shadow(0 0 12px var(--bolt))}
.bolt path{fill:var(--bolt)}
.bolt.b1{top:16%;left:14%;width:36px;animation:flash 6s 1s infinite}
.bolt.b2{top:24%;right:12%;width:44px;animation:flash 7s 3.4s infinite}
@keyframes flash{0%,92%,100%{opacity:0}93%{opacity:.85}94%{opacity:.1}95%{opacity:.7}97%{opacity:0}}
.hero h1{position:relative;z-index:2;line-height:.82}
.hero h1 .l1{display:block;font-size:clamp(58px,15vw,180px)}
.hero h1 .l2{display:block;font-size:clamp(26px,7vw,84px);font-weight:800;letter-spacing:.32em;text-indent:.32em;margin-top:4px}
.hero .tag{position:relative;z-index:2;max-width:520px;color:var(--mute);margin-top:22px;font-size:clamp(15px,1.4vw,18px)}
.hero .cta{position:relative;z-index:2;display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;justify-content:center}
.fade{opacity:0;transform:translateY(24px);animation:rise .8s forwards}
@keyframes rise{to{opacity:1;transform:translateY(0)}}

/* ---- grids / cards ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:42px}
.card{position:relative;padding:26px 24px 28px;background:linear-gradient(160deg,rgba(22,24,28,.9),rgba(8,9,11,.92));border:1px solid var(--line);overflow:hidden;clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px));transition:.3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);border-color:rgba(190,225,255,.4)}
.card .num{font-family:'Teko';font-size:42px;color:rgba(255,255,255,.16);font-weight:700;line-height:1}
.card h3{font-family:'Saira';font-style:italic;font-weight:800;font-size:21px;margin:4px 0 8px}
.card p{color:var(--mute);font-size:15px;flex:1}
.card .meta{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.card .price{font-family:'Teko';font-size:34px;margin:14px 0}
.card .foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}

/* ---- panels ---- */
.panel{background:linear-gradient(160deg,rgba(20,22,26,.95),rgba(8,9,11,.95));border:1px solid var(--line);clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,18px 100%,0 calc(100% - 18px))}

/* ---- dashboard layout ---- */
.dash{display:grid;grid-template-columns:230px 1fr;gap:24px;align-items:start}
@media(max-width:840px){.dash{grid-template-columns:1fr}}
.side{padding:22px 18px;position:sticky;top:78px}
.side .me{display:flex;align-items:center;gap:10px;padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:14px}
.side .me .av{width:40px;height:40px;border-radius:3px;background:linear-gradient(180deg,#fff,#7e8288);color:#0a0a0c;display:grid;place-items:center;font-family:'Saira';font-weight:900;font-style:italic;font-size:18px}
.side .me small{color:var(--mute);font-size:12px;display:block}
.navitem{display:flex;align-items:center;gap:10px;padding:11px 12px;color:var(--mute);font-weight:600;font-size:14px;cursor:pointer;border-left:2px solid transparent;transition:.18s}
.navitem:hover{color:#fff;background:rgba(255,255,255,.04)}
.navitem.active{color:#fff;border-left-color:var(--accent);background:rgba(190,225,255,.06)}

/* ---- stat chips ---- */
.chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:22px}
.chip{padding:16px 18px;border:1px solid var(--line);background:rgba(255,255,255,.02)}
.chip .v{font-family:'Teko';font-size:40px;line-height:.9;font-weight:700}
.chip .k{color:var(--mute);text-transform:uppercase;letter-spacing:2px;font-size:11px;margin-top:4px}

/* ---- tables ---- */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;color:var(--mute);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:600;padding:12px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:13px 14px;border-bottom:1px solid rgba(255,255,255,.05)}
.tbl tr:hover td{background:rgba(255,255,255,.03)}
.tbl .actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}
.tbl select{padding:6px 8px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--ink);font-family:'Chakra Petch'}

/* ---- forms ---- */
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--mute);margin-bottom:7px;font-weight:600}
.field input,.field select{width:100%;padding:12px 14px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--ink);font-family:'Chakra Petch';font-size:15px;outline:none;transition:.2s}
.field input:focus,.field select:focus{border-color:var(--accent);background:rgba(190,225,255,.05)}
.field input:disabled{opacity:.7}
.field select option{background:#0c0d10}

/* ---- auth ---- */
.authwrap{max-width:430px;margin:0 auto;padding:90px 18px 60px}
.authcard{padding:36px 32px}
.authcard h2{font-family:'Saira';font-style:italic;font-weight:900;font-size:30px;margin-bottom:6px}
.authcard .sub{color:var(--mute);margin-bottom:24px;font-size:14px}
.switchline{text-align:center;margin-top:18px;color:var(--mute);font-size:14px}
.switchline a{color:var(--accent);cursor:pointer;font-weight:600}
.seed{margin-top:20px;padding:14px;border:1px dashed var(--line);font-size:12px;color:var(--mute);line-height:1.8}
.seed code{color:#fff;font-family:'JetBrains Mono',monospace}

/* ---- console ---- */
.conbar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.live{display:inline-flex;align-items:center;gap:6px;font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--ok)}
.live i{width:8px;height:8px;border-radius:50%;background:var(--ok);animation:pulse 1.4s infinite}
.live.off{color:var(--err)} .live.off i{background:var(--err);animation:none}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(95,213,138,.5)}50%{opacity:.5;box-shadow:0 0 0 6px rgba(95,213,138,0)}}
.console{background:#04060a;border:1px solid var(--line);height:440px;overflow-y:auto;padding:14px 16px;font-family:'JetBrains Mono',monospace;font-size:12.5px;line-height:1.7}
.console .ln{display:flex;gap:10px;white-space:pre-wrap;word-break:break-word}
.console .t{color:#4b5563;flex-shrink:0}
.console .lvl{flex-shrink:0;font-weight:600;width:46px}
.lvl.INFO{color:#7ba9c9}.lvl.AUTH{color:var(--ok)}.lvl.WARN{color:var(--warn)}.lvl.ERR{color:var(--err)}.lvl.API{color:#b08fe0}.lvl.SYS{color:#9aa0a8}
.console .src{color:#6b7280;flex-shrink:0}.console .msg{color:#cbd2da}
.console::-webkit-scrollbar{width:8px}.console::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15)}

/* ---- tabs ---- */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.tab{padding:11px 18px;color:var(--mute);font-weight:600;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;transition:.18s}
.tab:hover{color:#fff}.tab.active{color:#fff;border-bottom-color:var(--accent)}

/* ---- modal ---- */
.modal-bg{position:fixed;inset:0;z-index:80;background:rgba(2,3,5,.78);backdrop-filter:blur(4px);display:grid;place-items:center;padding:18px;animation:fadein .2s}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{width:100%;max-width:480px;padding:30px 28px}
.modal h3{font-family:'Saira';font-style:italic;font-weight:900;font-size:24px;margin-bottom:20px}
.modal .row{display:flex;gap:14px}.modal .row>*{flex:1}
.modal .foot{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}

/* ---- toast ---- */
#toasts{position:fixed;right:18px;bottom:18px;z-index:120;display:flex;flex-direction:column;gap:10px}
.toast{padding:13px 18px;background:#14161b;border:1px solid var(--line);border-left:3px solid var(--accent);font-size:14px;min-width:240px;animation:slidein .25s;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.toast.ok{border-left-color:var(--ok)}.toast.err{border-left-color:var(--err)}
@keyframes slidein{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ---- footer ---- */
footer.f{position:relative;z-index:1;text-align:center;padding:46px 18px;border-top:1px solid var(--line);color:var(--mute);font-size:13px}
footer.f .fb{font-family:'Saira';font-style:italic;font-weight:900;font-size:20px;margin-bottom:8px}

/* ---- access screens ---- */
.noaccess{max-width:520px;margin:0 auto;text-align:center;padding:120px 18px}
.noaccess .big{font-family:'Teko';font-size:120px;line-height:1;color:rgba(255,255,255,.14)}

/* ---- loader ---- */
.loader{display:grid;place-items:center;padding:120px 18px;color:var(--mute);letter-spacing:3px;text-transform:uppercase;font-size:13px}

/* ============================================================
   SHOP MODULE
   ============================================================ */
.page-shop{ max-width:1240px;margin:0 auto;padding:clamp(40px,6vw,80px) clamp(18px,5vw,64px) }

/* ── Intro ── */
.shop-head{ text-align:center;margin-bottom:42px }
.shop-head .h-title{ font-size:clamp(36px,6vw,68px);display:block;margin:0 auto }
.shop-head .lead{ margin:14px auto 0 }

/* ── Filter-Tabs ── */
.filter-tabs{ display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:38px }
.filter-tab{
  font-family:'Chakra Petch';font-weight:600;font-size:13px;letter-spacing:1.5px;
  text-transform:uppercase;padding:9px 22px;background:transparent;border:1px solid var(--line);
  color:var(--mute);cursor:pointer;transition:.2s;
  clip-path:polygon(6px 0,100% 0,100% calc(100% - 6px),calc(100% - 6px) 100%,0 100%,0 6px)
}
.filter-tab:hover{ color:#fff;border-color:rgba(255,255,255,.4) }
.filter-tab.is-active{
  color:#fff;border-color:var(--accent);
  background:rgba(190,225,255,.08);
  box-shadow:0 0 18px rgba(190,225,255,.12)
}

/* ── Product Grid ── */
.product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(270px,1fr));
  gap:22px;
  margin-bottom:40px
}

/* ── Product Card ── */
.product-card{
  position:relative;
  display:flex;flex-direction:column;gap:0;
  padding:28px 24px 24px;
  background:linear-gradient(160deg,rgba(22,24,28,.92),rgba(8,9,11,.95));
  border:1px solid var(--line);
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px));
  transition:.28s
}
.product-card:hover{ transform:translateY(-6px);border-color:rgba(190,225,255,.4) }
.product-card--featured{ border-color:rgba(190,225,255,.28) }

.product-card__badge{
  position:absolute;top:14px;right:14px;
  font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  padding:4px 10px;border-radius:1px;
  background:linear-gradient(90deg,#bfe6ff,#7ba9c9);color:#04060a
}
.product-card__icon{
  font-size:28px;line-height:1;margin-bottom:12px;
  filter:drop-shadow(0 0 10px rgba(190,225,255,.4))
}
.product-card__name{
  font-family:'Saira';font-style:italic;font-weight:800;font-size:20px;
  margin-bottom:6px;line-height:1.1
}
.product-card__price{
  font-size:clamp(26px,4vw,34px);line-height:1;margin-bottom:12px
}
.product-card__desc{
  color:var(--mute);font-size:14px;line-height:1.55;margin-bottom:14px;flex:1
}
.product-card__features{
  list-style:none;margin:0 0 20px;padding:0;
  display:flex;flex-direction:column;gap:5px
}
.product-card__features li{
  font-size:13px;color:var(--mute);padding-left:18px;position:relative
}
.product-card__features li::before{
  content:'✓';position:absolute;left:0;color:var(--ok);font-weight:700;font-size:11px
}
.product-card__action{ width:100%;justify-content:center;margin-top:auto }

/* ── Order Hint ── */
.order-hint{
  display:flex;align-items:center;gap:16px;
  padding:20px 24px;margin-top:8px;
  border:1px solid var(--line);background:rgba(255,255,255,.02)
}
.order-hint__num{
  font-family:'Teko';font-size:38px;font-weight:700;color:var(--accent);
  flex-shrink:0;line-height:1
}
.order-hint strong{ display:block;margin-bottom:3px }
.order-hint .muted{ font-size:14px }

/* ── Modal ── */
.shop-modal{
  position:fixed;inset:0;z-index:80;
  display:grid;place-items:center;padding:18px;
  pointer-events:none
}
.shop-modal:not([hidden]){ pointer-events:auto }
.shop-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(2,3,5,.8);backdrop-filter:blur(5px);
  opacity:0;transition:opacity .25s
}
.shop-modal.is-open .shop-modal__backdrop{ opacity:1 }
.shop-modal__dialog{
  position:relative;width:100%;max-width:500px;
  padding:32px 28px;
  transform:translateY(24px) scale(.97);opacity:0;
  transition:transform .25s,opacity .25s
}
.shop-modal.is-open .shop-modal__dialog{ transform:translateY(0) scale(1);opacity:1 }
.shop-modal__close{
  position:absolute;top:14px;right:16px;
  background:none;border:none;color:var(--mute);font-size:24px;
  cursor:pointer;line-height:1;transition:.2s
}
.shop-modal__close:hover{ color:#fff }
.shop-modal__title{ font-size:clamp(22px,4vw,30px);margin:6px 0 4px;display:block }
.shop-modal__price{
  font-family:'Teko';font-size:36px;font-weight:700;
  color:var(--ink);margin-bottom:14px;line-height:1
}
.shop-modal__user{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;background:rgba(255,255,255,.03);
  border:1px solid var(--line);margin-bottom:18px
}
.shop-modal__uid{
  font-family:'JetBrains Mono',monospace;font-size:13px;
  color:var(--accent)
}
.shop-modal__section{ margin-bottom:18px }
.shop-modal__label{
  font-size:11px;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--mute);font-weight:600;margin-bottom:8px
}
.shop-modal__steps{
  padding-left:20px;display:flex;flex-direction:column;gap:7px;
  color:var(--mute);font-size:14px
}
.shop-modal__steps li::marker{ color:var(--accent) }
.shop-modal__steps code{
  font-family:'JetBrains Mono',monospace;font-size:12px;
  background:rgba(255,255,255,.06);padding:1px 6px
}
.shop-modal__cta{ width:100%;justify-content:center;margin-top:4px }

/* ── Copy Row ── */
.copy-row{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;
  background:rgba(255,255,255,.04);border:1px solid var(--line)
}
.copy-row__code{
  font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--ink);flex:1;word-break:break-all
}
.copy-row .btn{ flex-shrink:0;transition:.2s }
.copy-row .is-copied{ border-color:var(--ok);color:var(--ok) }

/* ============================================================
   UID CARD + DOWNLOADS
   ============================================================ */
.uid-card{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 18px;margin:20px 0 0;
  background:rgba(190,225,255,.05);border:1px solid rgba(190,225,255,.2);
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))
}
.uid-label{
  font-size:11px;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--mute);font-weight:600;margin-bottom:5px
}
.uid-value{
  font-family:'JetBrains Mono',monospace;font-size:16px;
  font-weight:600;color:var(--bolt);letter-spacing:.05em
}

/* ============================================================
   FILE UPLOAD ZONE
   ============================================================ */
.upload-zone{
  padding:36px 24px;text-align:center;cursor:pointer;
  border:2px dashed var(--line);transition:.2s;
  clip-path:none; /* kein clip-path für Drop-Zone */
}
.upload-zone.is-drag,.upload-zone:hover{
  border-color:var(--accent);background:rgba(190,225,255,.06)
}
.upload-zone__icon{
  font-size:40px;margin-bottom:14px;opacity:.5;
  filter:drop-shadow(0 0 14px var(--accent))
}
.upload-zone__text{font-size:16px;margin-bottom:6px}
.upload-zone__browse{color:var(--accent);cursor:pointer;font-weight:600;text-decoration:underline}
.upload-zone__hint{font-size:13px}
.upload-progress{padding:14px 0 4px}
.upload-progress__bar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.upload-progress__fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--bolt));transition:width .3s;border-radius:2px}
.upload-progress__label{font-size:12px;color:var(--mute);margin-top:7px;display:block;text-align:left}

/* ============================================================
   PRODUKT-BILD + COMMUNITY-KARTEN
   ============================================================ */
.product-card__img{
  width:100%;height:160px;overflow:hidden;margin:-26px -24px 16px;width:calc(100% + 48px);
  border-bottom:1px solid var(--line);
}
.product-card__img img{
  width:100%;height:100%;object-fit:cover;transition:.3s;display:block;
}
.product-card:hover .product-card__img img{ transform:scale(1.04); }

.product-card--community{ border-color:rgba(95,213,138,.2); }
.product-card--community:hover{ border-color:rgba(95,213,138,.5); }

/* ============================================================
   DEV CONSOLE INPUT
   ============================================================ */
.con-input-row{
  display:flex;gap:8px;margin-top:10px;align-items:center
}
.con-level-sel{
  padding:9px 10px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:12px;
  flex-shrink:0;width:76px
}
.con-msg-input{
  flex:1;padding:10px 14px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:13px;outline:none;
  transition:.2s
}
.con-msg-input:focus{border-color:var(--accent);background:rgba(190,225,255,.05)}

/* ── System-Bars ── */
.sys-bar-row{display:flex;align-items:center;gap:14px;font-size:13px}
.sys-bar-row>span:first-child{width:80px;color:var(--mute);flex-shrink:0}
.sys-bar-row>span:last-child{width:200px;flex-shrink:0;text-align:right;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--mute)}
.sys-bar{flex:1;height:8px;background:rgba(255,255,255,.08);border-radius:4px;overflow:hidden}
.sys-bar__fill{height:100%;border-radius:4px;transition:width .4s}

/* ── Preset Tags ── */
.preset-tags{display:flex;flex-wrap:wrap;gap:8px;min-height:36px;margin-bottom:4px}
.preset-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;background:rgba(190,225,255,.08);border:1px solid rgba(190,225,255,.25);
  font-size:13px;font-weight:600
}
.preset-tag button{background:none;border:none;color:var(--mute);cursor:pointer;font-size:15px;line-height:1;padding:0}
.preset-tag button:hover{color:var(--err)}
.preset-input{
  flex:1;padding:9px 12px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--ink);font-family:'Chakra Petch';font-size:13px;outline:none
}
.preset-input:focus{border-color:var(--accent)}
.preset-cat-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.preset-cat-id,.preset-cat-label{
  flex:1;padding:8px 12px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--ink);font-family:'Chakra Petch';font-size:13px;outline:none
}
.preset-cat-id{flex:0 0 130px}
.tbl-select{
  padding:5px 8px;background:rgba(255,255,255,.04);border:1px solid var(--line);
  color:var(--ink);font-family:'Chakra Petch';font-size:12px
}

/* ============================================================
   NEUE SIDEBAR (kein separates Dashboard)
   ============================================================ */
.side-usercard{
  display:flex;align-items:center;gap:12px;
  padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:12px
}
.side-av{
  width:44px;height:44px;flex-shrink:0;border-radius:3px;
  background:linear-gradient(180deg,#fff,#7e8288);color:#0a0a0c;
  display:grid;place-items:center;
  font-family:'Saira';font-weight:900;font-style:italic;font-size:18px
}
.side-userinfo{ min-width:0 }
.side-username{ font-weight:700;font-size:15px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis }
.side-uid-row{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;background:rgba(190,225,255,.06);
  border:1px solid rgba(190,225,255,.18);margin-bottom:10px
}
.side-uid-code{ font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--bolt);flex:1 }
.side-uid-copy{
  background:none;border:none;color:var(--mute);cursor:pointer;font-size:14px;
  padding:2px 4px;transition:.15s;flex-shrink:0
}
.side-uid-copy:hover{ color:#fff }
.side-meta{ margin-bottom:14px;display:flex;flex-direction:column;gap:5px }
.side-meta-row{ display:flex;align-items:center;gap:8px;font-size:12px;color:var(--mute);overflow:hidden }
.side-meta-row span:first-child{ flex-shrink:0 }
.side-divider{ height:1px;background:var(--line);margin:8px 0 10px }

/* ── Broadcasts ── */
.broadcast-bar{ width:100%;position:relative;z-index:3 }
.broadcast-msg{
  padding:14px 24px;font-size:15px;font-weight:600;letter-spacing:.2px;
  border-bottom:1px solid rgba(255,255,255,.08)
}
.bc-info{ background:rgba(123,169,201,.18);color:#c8e4ff }
.bc-warn{ background:rgba(231,193,74,.18);color:#ffe89a }
.bc-err{  background:rgba(231,109,109,.22);color:#ffcece }

/* ============================================================
   NEUE ANIMATIONEN & HOVER-EFFEKTE
   ============================================================ */

/* ── Zahnrad-Float (kein Drehen) ── */
@keyframes heroCogFloat{
  0%,100%{ transform:translate(-50%,-50%) scale(1) rotate(0deg); }
  25%{     transform:translate(-50%,-52%) scale(1.012) rotate(.8deg); }
  50%{     transform:translate(-50%,-50%) scale(.988) rotate(0deg); }
  75%{     transform:translate(-50%,-48%) scale(1.006) rotate(-.6deg); }
}
.hero:hover .hero-cog{ opacity:.2; }

/* ── Button Shine-Sweep ── */
.btn{overflow:hidden;}
.btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.28) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform 0s;
}
.btn{position:relative;}
.btn:hover::after{ transform:translateX(120%); transition:transform .45s ease; }
.btn-chrome:hover{ transform:translateY(-3px) scale(1.02); box-shadow:0 16px 36px rgba(190,225,255,.45); }
.btn-ghost:hover{  transform:translateY(-2px); box-shadow:0 8px 24px rgba(255,255,255,.08); }

/* ── Card — Premium 3D-Tilt + Glow-Border ── */
.card,.product-card,.panel{
  --mx:0; --my:0;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.card:hover,.product-card:hover{
  transform:translateY(-8px) perspective(600px) rotateX(calc(var(--my) * 1.5deg)) rotateY(calc(var(--mx) * -1.5deg));
  box-shadow:0 20px 50px rgba(0,0,0,.6), 0 0 0 1px rgba(190,225,255,.5), inset 0 1px 0 rgba(255,255,255,.06);
}
/* Glow-Border-Sweep auf Card-Hover */
.card::before,.product-card::before{
  content:'';position:absolute;inset:-1px;
  background:conic-gradient(from var(--border-angle,0deg), transparent 0deg, rgba(190,225,255,.7) 40deg, transparent 80deg);
  border-radius:inherit;z-index:-1;opacity:0;transition:opacity .3s;
}
.card:hover::before,.product-card:hover::before{ opacity:1; animation:borderSpin 1.8s linear infinite; }
@keyframes borderSpin{ to{ --border-angle: 360deg; } }
@property --border-angle{ syntax:'<angle>'; inherits:false; initial-value:0deg; }

/* ── Nav-Links ── */
.navlinks a{transition:color .2s, text-shadow .2s;}
.navlinks a:hover,.navlinks a.active{
  text-shadow:0 0 18px rgba(190,225,255,.6), 0 0 40px rgba(190,225,255,.3);
}

/* ── Sidebar Navitem ── */
.navitem{transition:color .18s, background .18s, border-color .18s, padding-left .18s;}
.navitem:hover{ padding-left:18px; }
.navitem.active{ padding-left:18px; }

/* ── Filter-Tabs ── */
.filter-tab{position:relative;overflow:hidden;transition:color .2s,border-color .25s,box-shadow .25s;}
.filter-tab::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(190,225,255,.12),rgba(190,225,255,.04));
  transform:translateY(100%);transition:transform .25s;
}
.filter-tab:hover::before,.filter-tab.is-active::before{ transform:translateY(0); }
.filter-tab.is-active{
  box-shadow:0 4px 20px rgba(190,225,255,.2), inset 0 1px 0 rgba(255,255,255,.08);
}

/* ── Table Rows ── */
.tbl tr{ transition:background .15s; }
.tbl tr:hover td{
  background:rgba(190,225,255,.06);
  box-shadow:inset 3px 0 0 var(--accent);
}

/* ── Badge hover ── */
.badge{ transition:filter .2s; }
.badge:hover{ filter:brightness(1.3); }

/* ── Chip hover ── */
.chip{
  transition:transform .2s, border-color .2s, box-shadow .2s;
  border:1px solid var(--line);
}
.chip:hover{
  transform:translateY(-3px);
  border-color:rgba(190,225,255,.35);
  box-shadow:0 8px 24px rgba(0,0,0,.4), 0 0 0 1px rgba(190,225,255,.2);
}

/* ── Shop-Modal öffnen ── */
.shop-modal__dialog{
  transition:transform .3s cubic-bezier(.34,1.56,.64,1), opacity .25s;
}
.shop-modal.is-open .shop-modal__dialog{
  transform:translateY(0) scale(1);
  animation:modalBounce .35s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modalBounce{
  0%{  transform:translateY(30px) scale(.93); opacity:0; }
  100%{transform:translateY(0)   scale(1);   opacity:1; }
}

/* ── Product-Card Image hover ── */
.product-card:hover .product-card__img img{
  transform:scale(1.07);
  filter:brightness(1.1);
}

/* ── Logo-Hover auf Home ── */
.hero h1.chrome:hover{
  filter:drop-shadow(0 0 30px rgba(190,225,255,.5)) drop-shadow(0 0 60px rgba(190,225,255,.2));
  cursor:default;
}

/* ── Input-Focus-Animation ── */
.field input:focus,.field select:focus{
  box-shadow:0 0 0 3px rgba(123,169,201,.2), 0 4px 12px rgba(0,0,0,.3);
  transform:none;
}

/* ── Panel subtle hover ── */
.panel:not(.side):not(.shop-modal__dialog){
  transition:border-color .25s, box-shadow .25s;
}
.panel:not(.side):not(.shop-modal__dialog):hover{
  border-color:rgba(255,255,255,.16);
}

/* ── Upload-Zone enhanced ── */
.upload-zone{transition:border-color .25s,background .25s,box-shadow .25s,transform .2s;}
.upload-zone:hover{
  transform:scale(1.01);
  box-shadow:0 8px 32px rgba(123,169,201,.15);
}
.upload-zone.is-drag{
  transform:scale(1.02);
  box-shadow:0 12px 40px rgba(123,169,201,.3);
  border-style:solid;
}

/* ── Copy-Row Button ── */
.copy-row .btn{ position:relative;overflow:hidden; }
.copy-row .is-copied{
  background:linear-gradient(180deg,rgba(95,213,138,.3),rgba(95,213,138,.15));
  border-color:var(--ok);
  animation:copyPulse .3s ease;
}
@keyframes copyPulse{
  0%{transform:scale(.95)}50%{transform:scale(1.05)}100%{transform:scale(1)}
}

/* ── Preset Tags ── */
.preset-tag{transition:background .2s,border-color .2s,transform .15s;}
.preset-tag:hover{ background:rgba(190,225,255,.18); border-color:rgba(190,225,255,.5); transform:translateY(-1px); }

/* ── System-Bars animated fill ── */
.sys-bar__fill{
  animation:barFill .8s cubic-bezier(.4,0,.2,1) both;
}
@keyframes barFill{ from{width:0!important} }

/* ── Scroll-Fade-In für Cards ── */
@keyframes cardIn{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}
.product-grid .product-card{
  animation:cardIn .5s ease both;
}
.product-grid .product-card:nth-child(1){animation-delay:.0s}
.product-grid .product-card:nth-child(2){animation-delay:.06s}
.product-grid .product-card:nth-child(3){animation-delay:.12s}
.product-grid .product-card:nth-child(4){animation-delay:.18s}
.product-grid .product-card:nth-child(5){animation-delay:.24s}
.product-grid .product-card:nth-child(6){animation-delay:.30s}


/* ============================================================
   DASHBOARD
   ============================================================ */
.db-main{ display:flex;flex-direction:column;gap:20px;min-width:0 }

.db-header{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  padding-bottom:18px;border-bottom:1px solid var(--line);
}

/* Stat-Chips */
.db-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
@media(max-width:900px){.db-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.db-stats{grid-template-columns:1fr 1fr}}
.db-stat{
  padding:18px 16px;background:linear-gradient(160deg,rgba(22,24,28,.9),rgba(8,9,11,.95));
  border:1px solid var(--line);text-align:center;cursor:pointer;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.db-stat:hover{
  border-color:rgba(190,225,255,.45);transform:translateY(-4px);
  box-shadow:0 10px 28px rgba(0,0,0,.4),0 0 0 1px rgba(190,225,255,.3);
}
.db-stat__icon{ font-size:22px;margin-bottom:8px;opacity:.7 }
.db-stat__val{
  font-family:'Teko';font-size:42px;font-weight:700;line-height:1;display:block;
}
.db-stat__label{
  font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--mute);margin-top:5px;
}

/* Account-Info Block */
.db-account{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;padding:22px 24px;flex-wrap:wrap;
}
.db-account__left{ display:flex;align-items:center;gap:16px }
.db-av{
  width:52px;height:52px;flex-shrink:0;border-radius:4px;
  background:linear-gradient(180deg,#fff,#7e8288);color:#0a0a0c;
  display:grid;place-items:center;
  font-family:'Saira';font-weight:900;font-style:italic;font-size:22px;
}
.db-account__name{ font-family:'Saira';font-weight:800;font-style:italic;font-size:20px }
.db-uid-block{ text-align:right }
.db-uid{
  font-family:'JetBrains Mono',monospace;font-size:16px;
  font-weight:600;color:var(--bolt);letter-spacing:.08em;
}

/* Card-Grid */
.db-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;
}
.db-card{
  background:linear-gradient(160deg,rgba(20,22,26,.95),rgba(8,9,11,.97));
  border:1px solid var(--line);
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px));
  transition:border-color .25s;
}
.db-card:hover{ border-color:rgba(190,225,255,.3) }
.db-card__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;border-bottom:1px solid var(--line);
}
.db-card__head h3{
  font-family:'Saira';font-style:italic;font-weight:800;font-size:16px;margin:0;
}
.db-card__body{ padding:8px 4px }

/* Items in Cards */
.db-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:2px;transition:background .15s;
}
.db-item:hover{ background:rgba(255,255,255,.04) }
.db-item__icon{
  font-size:22px;width:32px;text-align:center;flex-shrink:0;
  filter:drop-shadow(0 0 8px rgba(190,225,255,.3));
}
.db-item__info{
  flex:1;min-width:0;
  display:flex;flex-direction:column;gap:2px;
}
.db-item__info b{ font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis }
.db-item__info span{ font-size:12px }
.db-empty{ padding:18px 14px;font-size:13px }

@media(max-width:840px){ .db-grid{grid-template-columns:1fr} }

/* ============================================================
   BROADCAST-BAR (immer oben, jede Seite)
   ============================================================ */
#bc-bar{
  position:sticky;top:62px;z-index:49;
}
.bc-strip{
  display:flex;align-items:center;gap:14px;
  padding:11px clamp(16px,4vw,48px);
  font-size:14px;font-weight:600;letter-spacing:.2px;
  animation:bcSlideDown .35s cubic-bezier(.34,1.4,.64,1);
}
@keyframes bcSlideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.bc-strip.bc-info{ background:rgba(123,169,201,.22);color:#c8e4ff;border-bottom:1px solid rgba(123,169,201,.3); }
.bc-strip.bc-warn{ background:rgba(231,193,74,.2); color:#ffe89a;border-bottom:1px solid rgba(231,193,74,.35); }
.bc-strip.bc-err{  background:rgba(231,109,109,.22);color:#ffcece;border-bottom:1px solid rgba(231,109,109,.35); }
.bc-icon{ font-size:18px;flex-shrink:0 }
.bc-msg{  flex:1 }
.bc-close{
  background:none;border:none;color:inherit;opacity:.6;cursor:pointer;
  font-size:20px;line-height:1;padding:0 4px;flex-shrink:0;
  transition:opacity .2s;
}
.bc-close:hover{ opacity:1 }

/* Wenn bc-bar vorhanden → view braucht kein extra padding oben */
#bc-bar:empty + #view,
#bc-bar:not(:has(.bc-strip)) + #view{ padding-top:62px; }

/* ============================================================
   HOME — FEATURE-KACHELN
   ============================================================ */
.home-features{
  position:relative;z-index:1;
  background:rgba(255,255,255,.018);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:clamp(50px,7vw,90px) clamp(18px,5vw,64px);
}
.home-features__inner{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;
}
.feat-card{
  padding:32px 26px;text-align:center;
  background:linear-gradient(160deg,rgba(22,24,28,.9),rgba(8,9,11,.95));
  border:1px solid var(--line);
  clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,14px 100%,0 calc(100% - 14px));
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.feat-card:hover{
  transform:translateY(-6px);
  border-color:rgba(190,225,255,.45);
  box-shadow:0 16px 40px rgba(0,0,0,.5),0 0 0 1px rgba(190,225,255,.25);
}
.feat-card__icon{
  font-size:42px;display:block;margin-bottom:16px;
  filter:drop-shadow(0 0 14px rgba(190,225,255,.5));
  animation:iconFloat 4s ease-in-out infinite;
}
.feat-card:nth-child(2) .feat-card__icon{animation-delay:.4s}
.feat-card:nth-child(3) .feat-card__icon{animation-delay:.8s}
.feat-card:nth-child(4) .feat-card__icon{animation-delay:1.2s}
@keyframes iconFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-5px)}
}
.feat-card__title{
  font-family:'Saira';font-style:italic;font-weight:800;font-size:17px;
  margin-bottom:10px;letter-spacing:.3px;
  background:linear-gradient(180deg,#fff 0%,#dfe2e6 60%,#9aa0a8 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.feat-card__desc{ color:var(--mute);font-size:14px;line-height:1.6 }

/* ============================================================
   HOME — STATS
   ============================================================ */
.home-stats{
  position:relative;z-index:1;
  padding:clamp(50px,6vw,80px) clamp(18px,5vw,64px);
  background:var(--bg);
  border-bottom:1px solid var(--line);
}
.home-stats__inner{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:30px;text-align:center;
}
.stat-block{ position:relative }
.stat-block::after{
  content:'';position:absolute;right:0;top:10%;height:80%;
  width:1px;background:var(--line);
}
.stat-block:last-child::after{ display:none }
.stat-block__val{
  font-size:clamp(52px,8vw,90px);line-height:1;font-weight:900;
  display:inline-block;font-style:italic;font-family:'Saira';
}
.stat-block__suf{
  font-family:'Saira';font-size:40px;font-weight:900;
  background:linear-gradient(180deg,#fff,#7e8288);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;vertical-align:top;margin-top:8px;
}
.stat-block__label{
  display:block;margin-top:12px;color:var(--mute);
  text-transform:uppercase;letter-spacing:3px;font-size:12px;font-weight:600;
}

@media(max-width:600px){
  .stat-block::after{display:none}
  .home-stats__inner{gap:20px}
}

/* ============================================================
   CUSTOM SELECT / DROPDOWN — Chrome-Theme
   Einheitliches Design für alle <select> im Projekt
   ============================================================ */

select,
.tbl-select,
.tbl select,
.con-level-sel,
.field select,
.preset-cat-id,
.preset-cat-label {
  appearance: none;
  -webkit-appearance: none;
  background-color: #0d0f13;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8d94' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 32px !important;
  border: 1px solid rgba(255,255,255,.12);
  color: #e9ebee;
  font-family: 'Chakra Petch', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .2s, background-color .2s, box-shadow .2s;
  border-radius: 0;
}

select:hover,
.tbl-select:hover,
.con-level-sel:hover {
  border-color: rgba(190,225,255,.45);
  background-color: #111318;
}

select:focus,
.tbl-select:focus,
.con-level-sel:focus,
.field select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(123,169,201,.18);
  background-color: #111318;
}

/* Option-Styling (nur Chromium, andere Browser begrenzt) */
select option {
  background-color: #0d0f13;
  color: #e9ebee;
  padding: 10px 14px;
  font-weight: 600;
}

select option:checked,
select option:focus {
  background-color: #1a2a3a;
  color: #bfe6ff;
}

/* Spezifisch: Rollen-Dropdown in Tabellen */
.tbl select[data-set-role],
.tbl select[data-role] {
  padding: 6px 32px 6px 10px !important;
  font-size: 12px;
  min-width: 80px;
  clip-path: polygon(0 0, calc(100% - 6px) 0, 100% 6px, 100% 100%, 6px 100%, 0 calc(100% - 6px));
}

/* Aktive/selektierte Option farbig hervorheben */
select[data-set-role] option[value="dev"],
select option:has(+ option + option) {
  color: var(--bolt);
}

/* Größere Dropdowns in Modals und Forms */
.modal select,
.field select {
  padding: 12px 36px 12px 14px !important;
  font-size: 14px;
  background-color: rgba(255,255,255,.04);
  border-color: var(--line);
}

.modal select:hover,
.field select:hover {
  background-color: rgba(255,255,255,.07);
  border-color: rgba(190,225,255,.4);
}

/* Filter-Level-Select in Console */
.con-level-sel {
  padding: 8px 28px 8px 10px !important;
  font-size: 12px;
  background-color: rgba(255,255,255,.04);
  width: auto;
  min-width: 80px;
}

/* Preset-Category inputs (nicht select, aber gleicher Look) */
.preset-cat-id,
.preset-cat-label {
  background-image: none;
  padding-right: 12px !important;
}

/* Hover-Animation: kleiner Glow-Effekt */
select:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.4);
}

/* Option-Gruppe hover-Farben für Rollen per JS gesetzt */
.opt-dev   { color: var(--bolt) !important; }
.opt-admin { color: var(--warn) !important; }
.opt-user  { color: var(--mute) !important; }

/* ============================================================
   PRODUKT-DETAIL SEITE
   ============================================================ */
.pd-layout{
  display:grid;grid-template-columns:1fr 1.4fr;gap:32px;align-items:start;
}
@media(max-width:760px){.pd-layout{grid-template-columns:1fr}}
.pd-image{
  width:100%;border-radius:2px;overflow:hidden;
  border:1px solid var(--line);
  clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,18px 100%,0 calc(100% - 18px));
}
.pd-image img{width:100%;height:auto;display:block;max-height:400px;object-fit:cover;}
.pd-icon{
  font-size:80px;text-align:center;padding:60px 20px;
  background:linear-gradient(160deg,rgba(22,24,28,.9),rgba(8,9,11,.95));
  border:1px solid var(--line);
  clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,18px 100%,0 calc(100% - 18px));
  filter:drop-shadow(0 0 20px rgba(190,225,255,.3));
}
.pd-price{line-height:1;margin-bottom:0!important}

/* Product card actions row */
.product-card__actions{
  display:flex;gap:8px;margin-top:auto;align-items:center;
}
.product-card__actions .btn{flex:1;justify-content:center;}
