:root{ --bg:#0c0f14;
  --card:#111622;
  --muted:#8b93a1;
  --text:#e8ecf1;
  --primary:#6c5ce7;
  --border:#243044;
  --accent:#22c55e;
  --warn:#f59e0b; 
  --drawer-w: min(640px, 92vw);
}

*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font:15px/1.5 Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",sans-serif}
.wrap{max-width:1600px;margin:28px auto;padding:0 18px}
h1{font-size:26px;margin:0 0 6px;font-weight:800}
.sub{color:var(--muted);margin-bottom:18px;font-size:14px}
.grid{display:grid;gap:18px}
@media(min-width:1100px){.grid{grid-template-columns:2.2fr 1fr}}
.card{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01));border:1px solid var(--border);border-radius:18px;padding:14px 14px;box-shadow:0 10px 24px rgba(0,0,0,.25)}
footer { text-align:center; margin-top:18px; opacity:.8; }

/* Einheitliche, schlanke Scrollbar – nur Thumb sichtbar */
body, #options, .list, .drawer__panel, .drawer__col--left .list, .drawer__col--right #coupons {
  /* Firefox */
  scrollbar-width: thin;                 /* dünn */
  scrollbar-color: var(--primary) transparent; /* Thumb / Track */
}

/* Chrome/Edge/Safari */
body::-webkit-scrollbar,
#options::-webkit-scrollbar,
.list::-webkit-scrollbar,
.drawer__panel::-webkit-scrollbar,
.drawer__col--left .list::-webkit-scrollbar,
.drawer__col--right #coupons::-webkit-scrollbar {
  width: 8px;
  height: 8px;
  background: transparent;               /* Track unsichtbar */
}

body::-webkit-scrollbar-track,
#options::-webkit-scrollbar-track,
.list::-webkit-scrollbar-track,
.drawer__panel::-webkit-scrollbar-track,
.drawer__col--left .list::-webkit-scrollbar-track,
.drawer__col--right #coupons::-webkit-scrollbar-track {
  background: transparent;               /* Track ausblenden */
}

body::-webkit-scrollbar-thumb,
#options::-webkit-scrollbar-thumb,
.list::-webkit-scrollbar-thumb,
.drawer__panel::-webkit-scrollbar-thumb,
.drawer__col--left .list::-webkit-scrollbar-thumb,
.drawer__col--right #coupons::-webkit-scrollbar-thumb {
  background: var(--primary);            /* nur der “graue” Balken → primär */
  border-radius: 999px;
  border: 2px solid transparent;         /* etwas Abstand zum Rand */
  background-clip: padding-box;
}

/* Ecken/Buttons aus */
*::-webkit-scrollbar-corner { background: transparent; }
*::-webkit-scrollbar-button  { display: none; width: 0; height: 0; }


#options{
  column-count: 1;    
  column-gap: 14px;
}
@media (min-width: 1000px){
  #options{ column-count: 2; }
}
@media (min-width: 1400px){
  #options{ column-count: 3; }
}
.category{
  display:block;
  break-inside: avoid;
  margin: 0 0 14px;
  height:auto;
}
.category{ margin:0; }
.category, .opt{ height:auto; }
.category{display:block;background:#0c1322;border:1px solid #1c2740;border-radius:14px;padding:12px;margin:0 0 14px;break-inside:avoid}
.cat-title{font-weight:800;margin-top:2px;letter-spacing:.2px}
.opt{display:flex;align-items:center;justify-content:space-between;background:#0d1629;border:1px solid var(--border);padding:9px 10px;border-radius:12px;transition:transform .08s ease,border-color .2s,box-shadow .2s;margin-top:8px}
.opt:hover{transform:translateY(-1px);border-color:#344765}
.opt.selected{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),0 0 12px rgba(108,92,231,.35)}
.opt input[type=checkbox]{transform:scale(1.05)}
.price{opacity:.9;font-variant-numeric:tabular-nums}
.qty{display:flex;align-items:center;gap:6px}
.btn{appearance:none;border:1px solid var(--border);background:#0b1220;color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer}
.btn:hover{border-color:var(--primary)}
.btn.primary{background:var(--primary);border-color:var(--primary)}
.btn.ghost{background:transparent}
.btn.danger{background:#1a0f12;border-color:#4d1d20;color:#ffb4b4}
.btn.danger:hover{border-color:#bd1414}
.tag{display:inline-block;padding:4px 8px;border:1px solid var(--border);border-radius:999px;color:var(--muted);font-size:12px}
.list{max-height:280px;overflow:auto;border:1px dashed var(--border);border-radius:12px;padding:10px;background:#0c1322}
.line{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px dashed #203048}
.line:last-child{border-bottom:0}
.muted{color:var(--muted)}
input[type="checkbox"]{
  appearance:none;         
  -webkit-appearance:none;
  width:18px; height:18px;
  margin:0;
  border:1px solid var(--border);
  background:#0b1220;     
  border-radius:4px;
  display:inline-grid;
  place-content:center;
  transition:background .2s, border-color .2s, box-shadow .2s, transform .05s;
}
input[type="checkbox"]:hover{ border-color:#344765 }
input[type="checkbox"]:active{ transform:scale(.96) }

input[type="checkbox"]::before{
  content:"";
  width:12px; height:12px;
  transform:scale(0);
  transform-origin:center;
  transition:transform .12s ease-out;
  clip-path: polygon(14% 44%, 8% 58%, 43% 90%, 95% 20%, 82% 9%, 42% 70%);
  background: #fff;
}
input[type="checkbox"]:checked{
  background: var(--primary);
  border-color: var(--primary);
  box-shadow: 0 0 12px rgba(108,92,231,.35);
}
input[type="checkbox"]:checked::before{ transform:scale(1) }
input[type="checkbox"]:focus-visible{
  outline:none;
  box-shadow: 0 0 0 2px rgba(108,92,231,.55);
}
input[type="checkbox"]:disabled{
  opacity:.6; cursor:not-allowed;
  box-shadow:none;
}

.total{font-size:22px;font-weight:900}
.discount{color:var(--accent)}
.coupon{display:flex;align-items:flex-start;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#0f172a}
.coupon:hover{ border-color:#2f4c33 }
.coupon input[type=checkbox]{transform:scale(1.05);margin-top:2px}
.input{background:#0b1220;border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:10px;min-width:60px}
.select{background:#0b1220;border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:10px}
.footer{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
@media(min-width:1100px){ .card.sticky{position:sticky;top:16px}}
.topbar a{margin-left:auto;text-decoration:none}
#gate{
  position:fixed; inset:0; z-index:9999;
  background:var(--bg);
  display:flex; align-items:center; justify-content:center;
}
.gate-card{
  background:#0e1422; border:1px solid var(--border); border-radius:16px;
  padding:18px; width: min(92vw, 480px);
  box-shadow:0 10px 24px rgba(0,0,0,.35);
}
.gate-title{font-size:20px;font-weight:800;margin-bottom:10px}
.gate-row{display:flex;gap:10px;align-items:center}
.btn.green{background:#0f1a10;border-color:#1d4d1f;color:#c1ffb4}
.btn.green:hover{border-color:#22bd14}
.header-logo{
  width: 28px;
  height: 28px;
  object-fit: contain;
  margin-right: 8px;
}
.top, .toolbar{
  display: flex;
  align-items: center;
  gap: 10px;
}

.tag.type-fam{ 
  border-color:#3b82f6; 
  color:#cfe2ff; 
  background:rgba(59,130,246,.08);
}
.tag.type-gov{ 
  border-color:#a78bfa; 
  color:#e9ddff; 
  background:rgba(167,139,250,.10);
}
.tag.type-biz{ 
  border-color:#f59e0b; 
  color:#ffe7c2; 
  background:rgba(245,158,11,.08);
}

.chip.type-fam{
  border-color:#3b82f6;
  background:rgba(59,130,246,.08);
  color:#cfe2ff;
}
.chip.type-gov{
  border-color:#a78bfa;
  background:rgba(167,139,250,.10);
  color:#e9ddff;
}
.chip.type-biz{
  border-color:#f59e0b;
  background:rgba(245,158,11,.08);
  color:#ffe7c2;
}

/* ==== COMPACT OVERRIDES (4 Spalten, wenig Scroll) ==== */

/* mehr Breite nutzen */
.wrap{ max-width:1920px }

/* linke Seite größer, rechte (Summary) schmaler */
@media (min-width:1100px){
  .grid{ grid-template-columns: 3fr 0.9fr; }
}

/* 4 Spalten für Kategorien */
#options{ column-count:1; column-gap:14px; }
@media (min-width:900px){  #options{ column-count:2 } }
@media (min-width:1200px){ #options{ column-count:3 } }
@media (min-width:1400px){ #options{ column-count:4 } }

/* Typografie kompakter */
body{ font-size:13px; line-height:1.45 }
h1{ font-size:22px; margin-bottom:4px }

/* Karten enger */
.card{ padding:10px 12px; border-radius:14px }

/* Kategorien kompakt, Abstand bleibt 14px */
.category{
  padding:8px 9px;
  margin:0 0 14px;
  border-radius:10px;
}
.cat-title{
  font-size:13px;
  margin:0 0 4px;
}

/* Optionen flach und klein */
.opt{
  padding:6px 8px;
  margin-top:6px;
  border-radius:8px;
  min-height:30px;
}
.price{ font-size:12.5px }
.qty{ gap:4px }

/* kleinere Checkboxen */
input[type="checkbox"]{ width:16px; height:16px }
input[type="checkbox"]::before{ width:10px; height:10px }

/* Inputs/Buttons kompakt */
.input,.select{ height:28px; padding:6px 8px; font-size:13px; border-radius:8px }
.btn{ height:28px; padding:6px 8px; font-size:13px; border-radius:8px }

/* Chips & Tags kleiner */
.tag{ font-size:11px; padding:3px 7px }
.chip{ padding:8px 10px; min-width:140px; border-radius:12px }
.chip .num{ font-size:16px }

/* Listen enger */
.list{ max-height:240px; padding:8px }
.line{ padding:6px 0; gap:10px }

/* Summen etwas kleiner */
.total{ font-size:22px }

.drawer{
  position: fixed;
  right: 16px;               /* gleiche Ecke wie vorher */
  bottom: 16px;
  width: var(--drawer-w);    /* Breite fest; Panel und Handle teilen sich das */
  z-index: 1000;
}

/* Handle bleibt GANZ unten; Panel sitzt im selben Container darüber */
.drawer__handle{
  width: 100%;
  display:flex; align-items:center; gap:10px; justify-content:space-between;
  padding: 8px 12px;
  border:1px solid var(--border);
  background:#0b1220;
  box-shadow:0 8px 18px rgba(0,0,0,.25);
  border-radius:12px;
  color: var(--text);
  cursor:pointer;
}
.drawer__title{ color: var(--border); font-weight:800; }

/* iPhone-Strich zwischen Titel & Badge */
.drawer__grip{
  flex:1 1 auto; max-width:140px; height:8px; border-radius:999px;
  background: rgba(36,48,68,.55);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
  margin: 0 8px;
}

/* Panel: über dem Handle nach oben */
.drawer__panel{
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px); /* 10px Abstand ÜBER dem Handle */
  width: 100%;
  max-height: min(78vh, 700px);
  overflow: hidden;
  padding: 12px;
  border:1px solid var(--border);
  background:#0c1322;
  border-radius:14px;

  transform-origin: bottom right;
  transform: translateY(8px);
  opacity:0; visibility:hidden;
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
}

/* geöffnet */
.drawer[data-open="true"] .drawer__panel{
  opacity:1; visibility:visible; transform: translateY(0);
}

/* Scrollen ab vielen Posten */
#activeList{ max-height: 240px; overflow:auto; }

/* falls es noch alte „Preview/Meter“-Elemente gibt → ausblenden */
.drawer__preview, .drawer__meter{ display:none !important; }

/* 2-spaltiges Layout im Drawer */
.drawer__cols{
  display:grid;
  grid-template-columns: 1.25fr 1fr;
  gap:12px;
  align-items:start;
}

.drawer__col{ min-width:0; } /* für sauberes Overflow */
.drawer__col--left .list{ max-height: 280px; overflow:auto; }
.drawer__col--right #coupons{ max-height: 180px; overflow:auto; }

/* mobil/eng: stapeln */
@media (max-width: 900px){
  .drawer__cols{ grid-template-columns: 1fr; }
  .drawer__col--left .list{ max-height: 220px; }
}



    .drawer[data-open="true"] .drawer__panel{
      opacity:1; visibility:visible; transform: translateY(0) scale(1);
    }
    .drawer__grid{
      display:grid; gap:12px;
      grid-template-columns: 1.2fr 1fr;
    }
    @media (max-width: 900px){ .drawer__grid{ grid-template-columns: 1fr; } }

    /* Auswahl-Liste scrollen, ab ~5 Einträgen */
    #activeList{
      max-height: 240px; /* ≈5-7 Zeilen */
      overflow:auto;
      border:1px dashed var(--border);
      border-radius:12px;
      padding:10px; background:#0c1322;
    }

    /* Options-Layout (vier Spalten) kompakt */
    #options{ column-count: 1; column-gap: 14px; }
    @media (min-width: 1000px){ #options{ column-count: 2; } }
    @media (min-width: 1400px){ #options{ column-count: 3; } }
    @media (min-width: 1700px){ #options{ column-count: 4; } }

    .category{ display:block; break-inside:avoid; margin:0 0 14px; background:#0c1322;
      border:1px solid var(--border); border-radius:14px; padding:10px; }
    .cat-title{ font-weight:800; margin:0 0 6px; letter-spacing:.2px; font-size:14px; }
    .opt{ display:flex; align-items:center; justify-content:space-between;
      background:#0d1629; border:1px solid var(--border); border-radius:10px;
      padding:7px 8px; margin-top:6px; }
    .opt:hover{ border-color:#344765 }
    .opt.selected{ border-color:var(--primary); box-shadow:0 0 0 1px var(--primary),0 0 10px rgba(108,92,231,.25) }
    .qty{ display:flex; align-items:center; gap:6px }
    .price{ opacity:.9; font-variant-numeric:tabular-nums; font-size:13px }
    .btn{ padding:6px 10px; border-radius:10px }
    .input{ padding:6px 8px; border-radius:10px }
    .select{ padding:6px 10px; border-radius:10px }

    /* Kopfzeile */
    .header-logo{ width:28px; height:28px; object-fit:contain; margin-right:8px }
    .top, .toolbar{ display:flex; align-items:center; gap:10px }