:root{
    --bg:#0b0b0d;
    --panel:#141417;
    --panel-2:#1b1b1f;
    --line:#26262b;
    --line-2:#33333a;
    --text:#f4f4f2;
    --muted:#9a9aa2;
    --faint:#63636b;
    --accent:#e0a049;      /* muted amber, sat < 80% */
    --accent-ink:#1a1206;
    --danger:#d16a5a;
    --ok:#79b884;
    --radius:16px;
    --shadow:0 20px 50px -20px rgba(0,0,0,.7);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    background:var(--bg);
    color:var(--text);
    font-family:"Outfit",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
    -webkit-font-smoothing:antialiased;
    min-height:100dvh;
    letter-spacing:-.01em;
  }
  /* fixed grain overlay */
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  }
  .wrap{max-width:1240px;margin:0 auto;padding:0 24px}

  /* ---------- header ---------- */
  header.site{
    position:sticky;top:0;z-index:40;
    background:rgba(11,11,13,.72);
    backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid var(--line);
    transition:transform .35s cubic-bezier(.16,1,.3,1);
    will-change:transform;
  }
  header.site.hide{transform:translateY(-100%)}

  /* scroll-fortschrittsbalken */
  .scrollprog{
    position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
    background:linear-gradient(90deg,var(--accent),#eab05a);
    box-shadow:0 0 10px rgba(224,160,73,.5);
    transition:width .08s linear;
  }
  .bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;padding:16px 24px;max-width:1240px;margin:0 auto}
  .brand{display:flex;align-items:center;gap:12px;min-width:0}
  .mark{width:40px;height:40px;border-radius:11px;object-fit:cover;flex:none;border:1px solid var(--line-2);background:var(--panel-2);display:block}
  .brand h1{font-size:16px;font-weight:700;margin:0;line-height:1.05;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .brand span{display:block;font-size:11px;font-weight:500;color:var(--faint);letter-spacing:.06em;text-transform:uppercase}

  .search{position:relative;width:100%;max-width:520px;justify-self:center}
  .search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--faint)}
  .search input{
    width:100%;height:44px;padding:0 44px 0 42px;border-radius:12px;
    background:var(--panel);border:1px solid var(--line);color:var(--text);
    font:inherit;font-size:15px;outline:none;transition:border-color .2s,background .2s;
  }
  .search input::placeholder{color:var(--faint)}
  .search input:focus{border-color:var(--line-2);background:var(--panel-2)}
  .search .clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:0;background:transparent;color:var(--faint);cursor:pointer;width:30px;height:30px;border-radius:8px;display:none;place-items:center}
  .search .clear:hover{color:var(--text);background:var(--line)}
  .search.has-value .clear{display:grid}

  .btn{
    display:inline-flex;align-items:center;gap:8px;height:44px;padding:0 16px;border-radius:12px;
    font:inherit;font-weight:600;font-size:14px;cursor:pointer;white-space:nowrap;
    border:1px solid var(--line-2);background:var(--panel);color:var(--text);
    transition:transform .12s,background .2s,border-color .2s;
  }
  .btn:hover{background:var(--panel-2)}
  .btn:active{transform:scale(.97)}
  .btn.accent{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
  .btn.accent:hover{background:#eab05a}
  .btn.ghost{background:transparent}
  .btn.small{height:38px;padding:0 13px;font-size:13px}
  .btn.icon{padding:0;width:44px;justify-content:center}

  /* ---------- hero strip ---------- */
  .strip{padding:56px 0 26px}
  .eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600;margin:0 0 14px}
  .strip h2{font-size:clamp(34px,6vw,64px);line-height:.98;letter-spacing:-.035em;margin:0;font-weight:800;max-width:16ch}
  .strip p{color:var(--muted);font-size:16px;line-height:1.6;max-width:52ch;margin:18px 0 0}
  .meta-row{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:26px;color:var(--faint);font-size:13px;font-weight:500}
  .meta-row b{color:var(--text);font-variant-numeric:tabular-nums;font-weight:700}

  /* ---------- admin toolbar ---------- */
  .adminbar{
    display:none;align-items:center;gap:12px;flex-wrap:wrap;
    margin:28px 0 6px;padding:14px 16px;border-radius:14px;
    background:linear-gradient(180deg,rgba(224,160,73,.10),rgba(224,160,73,.02));
    border:1px solid rgba(224,160,73,.28);
  }
  body.admin .adminbar{display:flex}
  .adminbar .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 4px rgba(121,184,132,.15)}
  .adminbar .lbl{font-weight:600;font-size:14px}
  .adminbar .lbl small{display:block;color:var(--faint);font-weight:500;font-size:12px}
  .adminbar .spacer{flex:1}

  /* ---------- catalog ---------- */
  main{position:relative;z-index:2;padding-bottom:100px}
  .count{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:34px 0 18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
  .count h3{margin:0;font-size:14px;font-weight:600;letter-spacing:.02em;color:var(--muted)}
  .count h3 b{color:var(--text);font-variant-numeric:tabular-nums}
  .count .q{color:var(--faint);font-size:13px}

  .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
  @media(max-width:1080px){.grid{grid-template-columns:repeat(3,1fr)}}
  @media(max-width:760px){.grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:460px){.grid{grid-template-columns:1fr}}

  .card{
    position:relative;border-radius:var(--radius);overflow:hidden;
    background:var(--panel);border:1px solid var(--line);
    transition:transform .18s cubic-bezier(.16,1,.3,1),border-color .2s;
  }
  .card:hover{transform:translateY(-3px);border-color:var(--line-2)}
  .thumb{aspect-ratio:4/3;background:var(--panel-2);position:relative;overflow:hidden}
  .thumb img{width:100%;height:100%;object-fit:cover;display:block}
  .thumb .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--faint);gap:8px;text-align:center;font-size:12px;letter-spacing:.05em}
  .thumb .ph svg{width:34px;height:34px;opacity:.5}
  .card .body{padding:14px 15px 16px}
  .card .title{font-weight:600;font-size:15px;line-height:1.3;margin:0 0 10px;min-height:2.6em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .card .price{font-weight:800;font-size:18px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
  .card .price .cur{color:var(--accent);font-size:14px;margin-left:2px}
  .card .del{
    position:absolute;top:10px;right:10px;z-index:3;width:34px;height:34px;border-radius:10px;
    display:none;place-items:center;cursor:pointer;border:1px solid var(--line-2);
    background:rgba(11,11,13,.7);backdrop-filter:blur(6px);color:var(--danger);
    transition:transform .12s,background .2s;
  }
  .card .del:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
  .card .del:active{transform:scale(.9)}
  body.admin .card .del{display:grid}
  .card .del svg{width:16px;height:16px}

  /* skeleton */
  .sk .thumb, .sk .l{background:linear-gradient(100deg,var(--panel-2) 30%,#242429 50%,var(--panel-2) 70%);background-size:200% 100%;animation:sh 1.2s infinite}
  .sk .l{height:12px;border-radius:6px;margin:0 15px 12px}
  .sk .l.a{margin-top:16px;width:80%}
  .sk .l.b{width:40%;height:18px}
  @keyframes sh{to{background-position:-200% 0}}

  /* empty state */
  .empty{
    grid-column:1/-1;border:1px dashed var(--line-2);border-radius:20px;
    padding:64px 28px;text-align:center;background:
      radial-gradient(120% 90% at 50% -20%,rgba(224,160,73,.06),transparent 60%);
  }
  .empty .ico{width:56px;height:56px;margin:0 auto 20px;border-radius:16px;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--line);color:var(--faint)}
  .empty h4{margin:0 0 8px;font-size:20px;letter-spacing:-.02em}
  .empty p{margin:0 auto;color:var(--muted);max-width:44ch;line-height:1.6;font-size:15px}
  .empty .btn{margin-top:22px}

  /* ---------- modal ---------- */
  .overlay{position:fixed;inset:0;z-index:60;display:none;place-items:center;padding:24px;
    background:rgba(6,6,8,.66);backdrop-filter:blur(6px)}
  .overlay.open{display:grid;animation:fade .2s ease}
  @keyframes fade{from{opacity:0}to{opacity:1}}
  .modal{
    width:100%;max-width:440px;background:var(--panel);border:1px solid var(--line-2);
    border-radius:20px;box-shadow:var(--shadow);overflow:hidden;
    animation:pop .24s cubic-bezier(.16,1,.3,1);
  }
  .modal.wide{max-width:520px}
  @keyframes pop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
  .modal .head{padding:22px 24px 6px}
  .modal .head h3{margin:0;font-size:20px;letter-spacing:-.02em}
  .modal .head p{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.5}
  .modal .head .x{position:absolute;top:16px;right:16px}
  .modal form{padding:18px 24px 24px}
  .field{margin-bottom:14px}
  .field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:7px;letter-spacing:.01em}
  .field input[type=text],.field input[type=password],.field input[type=number],.field input[type=url]{
    width:100%;height:46px;padding:0 14px;border-radius:11px;background:var(--panel-2);
    border:1px solid var(--line);color:var(--text);font:inherit;font-size:15px;outline:none;transition:border-color .2s;
  }
  .field input:focus{border-color:var(--accent)}
  .field .hint{font-size:12px;color:var(--faint);margin-top:6px;line-height:1.4}
  .two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .seg{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;background:var(--panel-2);border:1px solid var(--line);border-radius:11px;margin-bottom:12px}
  .seg button{height:36px;border:0;background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:13px;border-radius:8px;cursor:pointer;transition:background .18s,color .18s}
  .seg button.on{background:var(--panel);color:var(--text);box-shadow:0 1px 0 rgba(255,255,255,.03)}
  .drop{
    border:1px dashed var(--line-2);border-radius:12px;padding:18px;text-align:center;cursor:pointer;
    background:var(--panel-2);transition:border-color .2s,background .2s;color:var(--muted);font-size:14px;
  }
  .drop:hover{border-color:var(--accent);color:var(--text)}
  .drop input{display:none}
  .preview{margin-top:12px;border-radius:11px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;display:none;background:var(--panel-2)}
  .preview.show{display:block}
  .preview img{width:100%;height:100%;object-fit:cover;display:block}
  .msg{font-size:13px;font-weight:600;margin:2px 0 12px;min-height:18px}
  .msg.err{color:var(--danger)}
  .msg.ok{color:var(--ok)}
  .actions{display:flex;gap:10px;margin-top:6px}
  .actions .btn{flex:1;justify-content:center}

  footer{position:relative;z-index:2;border-top:1px solid var(--line);padding:30px 0;color:var(--faint);font-size:13px}
  footer .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
  footer a{color:var(--muted);text-decoration:none}
  footer a:hover{color:var(--text)}

  /* ---------- nav ---------- */
  .nav{display:flex;gap:2px;justify-self:center}
  .nav a{padding:9px 14px;border-radius:9px;color:var(--muted);text-decoration:none;font-size:14px;font-weight:600;transition:color .18s,background .18s}
  .nav a:hover{color:var(--text);background:var(--panel)}
  .nav a.active{color:var(--text);background:var(--panel-2)}

  /* ---------- section shell ---------- */
  .section{padding:40px 0 14px;scroll-margin-top:86px}
  .sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin:0 0 24px}
  .sec-head .eyebrow{margin:0 0 12px}
  .sec-head h3.big{margin:0;font-size:clamp(26px,4.2vw,42px);letter-spacing:-.03em;font-weight:800;line-height:1}
  .sec-head p.sub{margin:12px 0 0;color:var(--muted);font-size:15px;max-width:54ch;line-height:1.55}

  /* section search (big) */
  .sec-search{position:relative;margin:0 0 22px;max-width:none;justify-self:stretch}
  .sec-search svg{left:18px;width:20px;height:20px}
  .sec-search input{height:58px;padding:0 50px;border-radius:14px;font-size:17px}
  .sec-search .clear{right:12px}

  /* ---------- reviews ---------- */
  .reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  @media(max-width:900px){.reviews{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:600px){.reviews{grid-template-columns:1fr}}
  .review{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px}
  .stars{display:flex;gap:3px;color:var(--accent);margin-bottom:13px}
  .stars svg{width:16px;height:16px;fill:currentColor}
  .stars .off{color:var(--line-2)}
  .review .txt{margin:0 0 18px;color:var(--text);line-height:1.6;font-size:15px}
  .review .who{display:flex;align-items:center;gap:11px}
  .review .av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--line);font-weight:700;font-size:15px;color:var(--accent);flex:none}
  .review .who b{display:block;font-size:14px;font-weight:600}
  .review .who span{font-size:12px;color:var(--faint)}
  .review .del{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:9px;display:none;place-items:center;cursor:pointer;border:1px solid var(--line-2);background:var(--panel-2);color:var(--danger);transition:transform .12s,background .2s}
  .review .del:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
  .review .del:active{transform:scale(.9)}
  .review .del svg{width:15px;height:15px}
  body.admin .review .del{display:grid}
  .review .gtag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--faint);border:1px solid var(--line);border-radius:20px;padding:2px 9px;margin-left:8px;vertical-align:middle}
  .review .gtag i{width:6px;height:6px;border-radius:50%;background:var(--accent);font-style:normal}

  /* google summary */
  .sec-actions{display:flex;gap:10px;flex-wrap:wrap}
  .gsummary{display:flex;align-items:center;gap:12px;margin-top:14px}
  .gsummary b{font-size:22px;font-weight:800;letter-spacing:-.02em}
  .gsummary span{font-size:13px;color:var(--faint)}
  .gstars{position:relative;font-size:18px;line-height:1;letter-spacing:2px}
  .gstars-base{color:var(--line-2)}
  .gstars-fill{position:absolute;inset:0;color:var(--accent);overflow:hidden;white-space:nowrap}
  .more-wrap{display:flex;justify-content:center;margin-top:24px}
  .more-wrap:empty{display:none}


  /* rating input */
  .rate{display:flex;gap:6px}
  .rate button{border:0;background:transparent;padding:2px;cursor:pointer;color:var(--line-2);transition:color .12s,transform .12s}
  .rate button svg{width:30px;height:30px;fill:currentColor}
  .rate button:hover{transform:scale(1.12)}
  .rate button.on{color:var(--accent)}

  /* ---------- standort ---------- */
  .loc{display:grid;grid-template-columns:1fr 1.15fr;gap:20px;align-items:stretch}
  @media(max-width:820px){.loc{grid-template-columns:1fr}}
  .loc .info{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
  .loc .info h4{margin:0 0 10px;font-size:19px;letter-spacing:-.01em}
  .addr{color:var(--muted);line-height:1.7;font-size:15px;margin:0 0 20px;white-space:pre-line}
  .hours{width:100%;border-collapse:collapse;font-size:14px}
  .hours td{padding:10px 0;border-bottom:1px solid var(--line);color:var(--muted)}
  .hours td:last-child{text-align:right;color:var(--text);font-variant-numeric:tabular-nums;font-weight:600}
  .hours tr:last-child td{border-bottom:0}
  .hours tr.today td{color:var(--accent)}
  .hours tr.today td:last-child{color:var(--accent)}
  .map{position:relative;min-height:330px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--panel-2)}
  .map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.2) contrast(1.05)}
  .map .maplink{position:absolute;right:16px;bottom:16px;z-index:2;box-shadow:var(--shadow)}

  /* ---------- kontakt ---------- */
  .contact{display:grid;grid-template-columns:.9fr 1.1fr;gap:20px;align-items:start}
  @media(max-width:820px){.contact{grid-template-columns:1fr}}
  .contact form{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
  .contact .intro td:first-child{color:var(--faint)}
  textarea{width:100%;min-height:130px;padding:12px 14px;border-radius:11px;background:var(--panel-2);border:1px solid var(--line);color:var(--text);font:inherit;font-size:15px;outline:none;resize:vertical;transition:border-color .2s;line-height:1.5}
  textarea:focus{border-color:var(--accent)}

  @media(max-width:680px){
    .bar{grid-template-columns:1fr auto;gap:12px}
    .nav{grid-column:1/-1;order:3;justify-self:stretch;overflow-x:auto;padding-bottom:2px}
    .nav a{white-space:nowrap}
    .brand span{display:none}
    .sec-head{flex-direction:column;align-items:flex-start}
  }

/* ---------- browse CTA (startseite -> artikel-seite) ---------- */
.browse{display:flex;justify-content:center;margin-top:28px}
.browse a{
  display:inline-flex;align-items:center;gap:10px;height:52px;padding:0 26px;border-radius:14px;
  font-weight:600;font-size:15px;text-decoration:none;
  background:var(--panel);border:1px solid var(--line-2);color:var(--text);
  transition:transform .12s,background .2s,border-color .2s;
}
.browse a:hover{background:var(--panel-2);border-color:var(--accent);transform:translateY(-1px)}
.browse a:active{transform:scale(.98)}
.browse a svg{width:18px;height:18px}
.browse a b{color:var(--accent);font-weight:700}

/* ---------- back link (artikel-seite -> home) ---------- */
.backlink{display:inline-flex;align-items:center;gap:7px;color:var(--muted);text-decoration:none;font-size:14px;font-weight:600;padding:9px 12px;border-radius:9px;transition:color .18s,background .18s}
.backlink:hover{color:var(--text);background:var(--panel)}
.backlink svg{width:16px;height:16px}
