  :root{
    /* An das Noxoria-ControlPanel angeglichen (Akzent: Orange) */
    --bg:#0f1216; --bg-alt:#161b22; --surface:#1b222c; --surface-2:#212a36;
    --border:#283140; --border-2:#3a475a;
    --text:#e6edf3; --text-dim:#8b97a7; --head:#f3f5f9;
    --green:#f08c00; --green-2:#ffa726; --green-deep:#cf7600;
    --green-soft:rgba(240,140,0,.14);
    --shadow:0 10px 30px rgba(0,0,0,.35);
    --nav-h:74px;
  }
  *{ box-sizing:border-box; margin:0; padding:0; }
  html{ scroll-behavior:smooth; }
  body{
    font-family:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    background:var(--bg); color:var(--text); line-height:1.65;
    -webkit-font-smoothing:antialiased;
  }
  a{ color:inherit; text-decoration:none; }
  img{ display:block; max-width:100%; }
  .wrap{ max-width:1200px; margin:0 auto; padding:0 24px; }
  .accent{ color:var(--green); }
  :focus-visible{ outline:2px solid var(--green); outline-offset:2px; border-radius:4px; }

  /* divider title */
  .sec-h{ text-align:center; }
  .sec-h h2{ font-size:26px; letter-spacing:2px; color:var(--head); font-weight:700; }
  .sec-h .rule{ width:54px; height:3px; background:var(--green); border-radius:2px; margin:14px auto 0; }
  .sec-h p{ color:var(--text-dim); margin-top:18px; }

  /* ============ NAV ============ */
  header.nav{
    position:sticky; top:0; z-index:100; height:var(--nav-h);
    background:rgba(15,18,22,.85); backdrop-filter:blur(14px);
    border-bottom:1px solid var(--border);
  }
  .nav-inner{ max-width:1280px; margin:0 auto; padding:0 28px; height:100%; display:flex; align-items:center; gap:30px; }
  .logo{ font-size:24px; font-weight:700; color:var(--head); letter-spacing:.5px; }
  .logo b{ color:var(--green); }
  nav.menu{ display:flex; align-items:center; gap:6px; margin-left:14px; }
  nav.menu > a, .drop > button{
    font:inherit; background:none; border:none; color:var(--text-dim); cursor:pointer;
    font-size:14px; font-weight:600; letter-spacing:.5px; padding:10px 14px; border-radius:8px;
    display:flex; align-items:center; gap:6px; transition:color .15s, background .15s;
  }
  nav.menu > a:hover, .drop > button:hover{ color:var(--head); background:rgba(255,255,255,.04); }
  .drop{ position:relative; }
  .drop > button svg{ width:11px; height:11px; fill:currentColor; transition:transform .2s; }
  .drop.open > button svg{ transform:rotate(180deg); }
  .drop-menu{
    position:absolute; top:calc(100% + 8px); left:0; min-width:210px;
    max-height:min(74vh,460px); overflow-y:auto;
    background:var(--surface); border:1px solid var(--border); border-radius:10px;
    box-shadow:var(--shadow); padding:6px; opacity:0; visibility:hidden; transform:translateY(-6px);
    transition:.16s;
  }
  .drop.open .drop-menu, .drop:hover .drop-menu{ opacity:1; visibility:visible; transform:translateY(0); }
  .drop-menu a{ display:block; padding:9px 12px; font-size:14px; color:var(--text); border-radius:7px; }
  .drop-menu a:hover{ background:var(--green-soft); color:var(--green); }
  .nav-cta{ margin-left:auto; display:flex; align-items:center; gap:14px; }
  .btn-cp{
    border:1px solid var(--green); color:var(--green); padding:10px 20px; border-radius:8px;
    font-size:13px; font-weight:700; letter-spacing:1px; transition:.15s;
  }
  .btn-cp:hover{ background:var(--green); color:#1a1205; box-shadow:0 8px 24px rgba(240,140,0,.3); }
  .burger{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:8px; }
  .burger span{ width:24px; height:2px; background:var(--head); border-radius:2px; transition:.2s; }

  /* ============ HERO ============ */
  .hero{
    position:relative; min-height:560px; display:flex; align-items:center;
    background:linear-gradient(rgba(12,15,20,.5),rgba(12,15,20,.62)), url('/assets/hintergrund.png') center/cover;
    overflow:hidden;
  }
  .hero::after{ content:""; position:absolute; inset:0;
    background:linear-gradient(90deg, rgba(12,15,20,.75) 0%, rgba(12,15,20,.2) 55%, transparent 100%); }
  .hero-grid{ position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; width:100%; }
  .hero-title{ display:inline-block; font-size:46px; line-height:1.05; font-weight:800; color:#1a1205;
    background:var(--green); padding:6px 16px; border-radius:6px; box-shadow:0 10px 30px rgba(207,118,0,.35); }
  .hero-sub{ font-size:19px; color:#dfe4ec; margin-top:24px; max-width:430px; }
  .hero-ip{ margin-top:22px; font-size:17px; font-weight:600; color:#fff;
    background:rgba(0,0,0,.4); display:inline-block; padding:8px 16px; border-radius:8px; border:1px solid var(--border-2); }
  .hero-ip .accent{ font-weight:700; }
  .hero-actions{ margin-top:26px; display:flex; gap:14px; flex-wrap:wrap; }
  .btn{ padding:13px 26px; border-radius:9px; font-weight:700; font-size:14px; letter-spacing:.5px; cursor:pointer; border:1px solid transparent; transition:.15s; }
  .btn-green{ background:linear-gradient(180deg,var(--green-2),var(--green)); color:#1a1205; }
  .btn-green:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(240,140,0,.3); }
  .btn-ghost{ border-color:var(--border-2); color:var(--head); }
  .btn-ghost:hover{ border-color:var(--green); color:var(--green); }
  /* video placeholder */
  .video{
    position:relative; aspect-ratio:16/10; border-radius:14px; overflow:hidden;
    border:1px solid var(--border-2); box-shadow:var(--shadow);
    background:linear-gradient(135deg,#1a2433,#0e1722);
    /* TODO: hier dein YouTube-Embed/Trailer einsetzen */
    display:flex; align-items:center; justify-content:center; cursor:pointer;
  }
  .video::before{ content:""; position:absolute; inset:0; opacity:.25;
    background:repeating-linear-gradient(45deg,#ffffff08 0 12px,transparent 12px 24px); }
  .play{ width:78px; height:78px; border-radius:50%; background:rgba(240,140,0,.92);
    display:flex; align-items:center; justify-content:center; transition:.2s; z-index:2; }
  .video:hover .play{ transform:scale(1.08); box-shadow:0 0 0 14px rgba(240,140,0,.12); }
  .play svg{ width:30px; height:30px; fill:#1a1205; margin-left:4px; }

  /* ============ FEATURES ============ */
  section{ padding:78px 0; }
  .features{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
  .feat{ text-align:center; padding:34px 26px; background:var(--surface); border:1px solid var(--border);
    border-radius:16px; transition:.18s; }
  .feat:hover{ transform:translateY(-6px); border-color:var(--green); box-shadow:var(--shadow); }
  .feat .ico{ width:78px; height:78px; margin:0 auto 22px; border-radius:50%;
    background:linear-gradient(135deg,var(--green-2),var(--green-deep));
    display:flex; align-items:center; justify-content:center; box-shadow:0 10px 26px rgba(207,118,0,.3); }
  .feat .ico svg{ width:36px; height:36px; fill:#1a1205; }
  .feat h3{ color:var(--head); font-size:18px; letter-spacing:1px; margin-bottom:14px; }
  .feat p{ color:var(--text-dim); font-size:15px; }

  /* ============ ÜBER ============ */
  .about{ background:var(--bg-alt); border-top:1px solid var(--border); border-bottom:1px solid var(--border); position:relative; overflow:hidden; }
  .about .map{ position:absolute; right:-40px; top:50%; transform:translateY(-50%); width:55%; opacity:.05; pointer-events:none; }
  .about-grid{ position:relative; display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center; }
  .about h2{ color:var(--head); font-size:24px; margin-bottom:6px; }
  .about .rule{ width:54px; height:3px; background:var(--green); border-radius:2px; margin:10px 0 24px; }
  .about .lead{ color:var(--text); margin-bottom:8px; }
  .about .lead .accent{ font-weight:600; }
  .checks{ margin-top:26px; display:grid; gap:14px; }
  .check{ display:flex; align-items:center; gap:12px; color:var(--text); }
  .check svg{ width:22px; height:22px; fill:none; stroke:var(--green); stroke-width:2; flex:0 0 auto; }
  .about-type{ background:linear-gradient(135deg,var(--surface),var(--bg)); border:1px solid var(--border);
    border-radius:16px; padding:60px 30px; text-align:center; }
  .about-type .small{ color:var(--text-dim); font-size:14px; letter-spacing:2px; margin-bottom:14px; }
  .typewrap{ font-size:30px; font-weight:800; color:var(--head); }
  #tw{ color:var(--green); }
  .caret{ display:inline-block; width:3px; background:var(--green); margin-left:2px; animation:blink 1s steps(1) infinite; }
  @keyframes blink{ 50%{ opacity:0; } }

  /* ============ GALLERY ============ */
  .gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:150px; grid-auto-flow:dense; gap:14px; margin-top:18px; }
  .shot{ border-radius:12px; overflow:hidden; border:1px solid var(--border); position:relative;
    background:linear-gradient(135deg,#16202c,#0f1822); transition:.2s; cursor:pointer; }
  .shot img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
  .shot.empty::after{ content:"Screenshot"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
    color:#3a475a; font-size:13px; letter-spacing:1px; }
  .shot.empty::before{ content:""; position:absolute; inset:0; opacity:.4;
    background:repeating-linear-gradient(45deg,#ffffff06 0 14px,transparent 14px 28px); }
  .shot:hover{ transform:scale(1.02); border-color:var(--green); }
  .shot:hover img{ filter:brightness(1.08); }
  .shot.big{ grid-row:span 2; grid-column:span 2; }
  .gallery-note{ text-align:center; color:var(--text-dim); margin-top:24px; }

  /* ============ REVIEWS ============ */
  .reviews-sec{ background:var(--bg-alt); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
  .reviews{ display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-top:44px; }
  .review{ background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:30px; position:relative; }
  .review .q{ font-size:48px; line-height:1; color:var(--green); font-family:Georgia,serif; }
  .review p{ color:var(--text); margin:6px 0 22px; }
  .reviewer{ display:flex; align-items:center; gap:14px; }
  .reviewer img,.reviewer .ava{ width:46px; height:46px; border-radius:50%; background:var(--surface-2); object-fit:cover; }
  .reviewer b{ color:var(--head); display:block; }
  .reviewer span{ color:var(--green); font-size:13px; }

  /* ============ FRAKTIONEN ============ */
  .frak-grid{ display:grid; grid-template-columns:260px 1fr; gap:40px; align-items:center; }
  .frak-intro h2{ color:var(--head); font-size:30px; line-height:1.2; }
  .frak-intro h2 .accent{ display:block; }
  .frak-intro p{ color:var(--text-dim); margin-top:16px; }
  .carousel{ position:relative; overflow:hidden; }
  .track{ display:flex; transition:transform .5s cubic-bezier(.4,0,.2,1); }
  .slide{ min-width:100%; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
  .fcard{ background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:22px; text-align:center;
    transition:.18s; }
  .fcard:hover{ transform:translateY(-6px); border-color:var(--green); box-shadow:var(--shadow); }
  .fcard h3{ color:var(--green); font-size:20px; font-weight:600; padding-bottom:14px; border-bottom:2px solid var(--border); margin-bottom:6px; }
  .fskin{ height:200px; display:flex; align-items:flex-end; justify-content:center; padding:14px 0; }
  .fskin .fig{ width:88px; filter:drop-shadow(0 12px 18px rgba(0,0,0,.5)); }
  .fskin img.fig{ width:auto; height:190px; object-fit:contain; transition:transform .18s; }
  .fcard:hover img.fig{ transform:scale(1.05); }
  .fcard .flink{ font-size:12px; font-weight:700; letter-spacing:1px; color:var(--text-dim); border-bottom:1px solid transparent; }
  .fcard:hover .flink{ color:var(--green); border-color:var(--green); }
  .carousel-nav{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:26px; }
  .dot{ width:9px; height:9px; border-radius:50%; background:var(--border-2); border:none; cursor:pointer; transition:.2s; }
  .dot.active{ background:var(--green); width:24px; border-radius:5px; }
  .arrow{ position:absolute; top:42%; transform:translateY(-50%); width:42px; height:42px; border-radius:50%;
    background:var(--surface); border:1px solid var(--border); color:var(--head); cursor:pointer; z-index:5;
    display:flex; align-items:center; justify-content:center; transition:.15s; }
  .arrow:hover{ background:var(--green); color:#1a1205; border-color:var(--green); }
  .arrow.prev{ left:-10px; } .arrow.next{ right:-10px; }
  .arrow svg{ width:16px; height:16px; fill:currentColor; }

  /* ============ ZAHLEN ============ */
  .zahlen{ background:var(--bg-alt); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
  .stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; }
  .stat{ text-align:center; padding:20px; }
  .stat .sico{ width:54px; height:54px; margin:0 auto 16px; fill:none; stroke:var(--green); stroke-width:1.6; }
  .stat .num{ font-size:38px; font-weight:800; color:var(--head); }
  .stat .lbl{ color:var(--text-dim); font-size:13px; letter-spacing:1px; margin-top:6px; }

  /* ============ TEAM ============ */
  .team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:48px; }
  .tcard{ background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:26px 16px; text-align:center; transition:.18s; }
  .tcard:hover{ transform:translateY(-5px); border-color:var(--green); box-shadow:var(--shadow); }
  .thead{ width:92px; height:92px; margin:0 auto 16px; border-radius:50%; overflow:hidden;
    background:linear-gradient(135deg,var(--surface-2),var(--bg)); display:flex; align-items:center; justify-content:center; position:relative; }
  .thead img{ width:100%; height:100%; object-fit:cover; image-rendering:pixelated; }
  .thead.noimg::after{ content:attr(data-letter); color:var(--green); font-size:30px; font-weight:800; }
  .tcard .tname{ color:var(--head); font-weight:700; }
  .tcard .trole{ font-size:13px; margin-top:4px; display:inline-flex; align-items:center; gap:5px; }
  .trole.admin{ color:#e06363; } .trole.mod{ color:var(--green); } .trole.frak{ color:#d98b3c; }
  .trole svg{ width:13px; height:13px; fill:currentColor; }

  /* ============ FOOTER ============ */
  footer{ background:#0a0c10; border-top:1px solid var(--border); padding:60px 0 0; }
  .foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:50px; }
  .foot h4{ color:var(--head); font-size:14px; letter-spacing:2px; margin-bottom:8px; }
  .foot .rule{ width:34px; height:3px; background:var(--green); border-radius:2px; margin-bottom:20px; }
  .foot p{ color:var(--text-dim); font-size:14px; }
  .foot .ip{ color:var(--green); font-size:20px; font-weight:700; margin-top:18px; }
  .flinks a{ display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--border);
    color:var(--text); font-size:14px; transition:.15s; }
  .flinks a:hover{ color:var(--green); padding-left:6px; }
  .flinks a svg{ width:12px; height:12px; fill:currentColor; }
  .contact .crow{ display:flex; align-items:flex-start; gap:12px; margin-bottom:18px; }
  .contact .cico{ width:34px; height:34px; border-radius:8px; background:var(--surface); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
  .contact .cico svg{ width:16px; height:16px; fill:var(--green); }
  .contact b{ color:var(--head); font-size:13px; display:block; }
  .contact span{ color:var(--text-dim); font-size:13px; }
  .foot-bottom{ border-top:1px solid var(--border); margin-top:50px; padding:24px 0; }
  .foot-bottom .wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
  .foot-legal{ color:var(--text-dim); font-size:13px; }
  .foot-legal a{ color:var(--text); } .foot-legal a:hover{ color:var(--green); }
  .foot-legal .dim{ display:block; margin-top:6px; color:#555c6b; }
  .socials{ display:flex; gap:10px; }
  .socials a{ width:34px; height:34px; border-radius:8px; background:var(--surface); display:flex; align-items:center; justify-content:center; color:var(--text-dim); transition:.15s; }
  .socials a:hover{ background:var(--green); color:#1a1205; }
  .socials svg{ width:16px; height:16px; fill:currentColor; }

  /* back to top */
  .top{ position:fixed; right:24px; bottom:24px; width:46px; height:46px; border-radius:50%;
    background:var(--green); color:#1a1205; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transition:.2s; z-index:90; box-shadow:0 10px 26px rgba(240,140,0,.35); }
  .top.show{ opacity:1; visibility:visible; }
  .top svg{ width:18px; height:18px; fill:currentColor; }

  /* responsive */
  @media (max-width:980px){
    .hero-grid,.about-grid,.frak-grid,.foot-grid{ grid-template-columns:1fr; }
    .features,.stats,.team-grid{ grid-template-columns:repeat(2,1fr); }
    .reviews{ grid-template-columns:1fr; }
    .about .map{ display:none; }
    nav.menu,.nav-cta .btn-cp{ display:none; }
    nav.menu.open{ display:flex; position:absolute; top:var(--nav-h); left:0; right:0; flex-direction:column; align-items:stretch;
      background:var(--surface); border-bottom:1px solid var(--border); padding:12px; gap:2px; }
    nav.menu.open .drop,nav.menu.open .drop-menu{ position:static; box-shadow:none; opacity:1; visibility:visible; transform:none; border:none; }
    .burger{ display:flex; }
    .gallery{ grid-template-columns:repeat(2,1fr); }
    .slide{ grid-template-columns:1fr; }
  }
  @media (max-width:560px){
    .features,.stats,.team-grid,.gallery{ grid-template-columns:1fr; }
    .hero-title{ font-size:34px; }
  }
  /* Reduzierte Bewegung respektieren */
  @media (prefers-reduced-motion: reduce){
    *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  }

/* Hero zentriert (Video entfernt) */
.hero-center{ position:relative; z-index:2; text-align:center; display:flex; flex-direction:column; align-items:center; padding:40px 0; }
.hero-center .hero-sub{ margin-left:auto; margin-right:auto; }
.hero-center .hero-actions{ justify-content:center; }
.hero::after{ background:linear-gradient(rgba(12,15,20,.30), rgba(12,15,20,.55)); }

/* ============ REGELN (nutzt ausschließlich bestehende Theme-Tokens) ============ */
.rules-tools{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; justify-content:space-between; margin:32px 0 8px; }
.rules-search{ flex:1 1 280px; min-width:220px; background:var(--surface); border:1px solid var(--border); color:var(--text);
  font:inherit; font-size:15px; padding:12px 16px; border-radius:10px; transition:border-color .15s, box-shadow .15s; }
.rules-search::placeholder{ color:var(--text-dim); }
.rules-search:focus{ outline:none; border-color:var(--green); box-shadow:0 0 0 3px var(--green-soft); }
.rules-filter{ display:flex; flex-wrap:wrap; gap:8px; }
.rfbtn{ font:inherit; cursor:pointer; background:var(--surface); border:1px solid var(--border); color:var(--text-dim);
  font-size:13px; font-weight:600; letter-spacing:.3px; padding:9px 14px; border-radius:8px;
  display:inline-flex; align-items:center; gap:7px; transition:color .15s, background .15s, border-color .15s; }
.rfbtn:hover{ color:var(--head); border-color:var(--border-2); }
.rfbtn.active{ background:var(--green-soft); border-color:var(--green); color:var(--green); }
.rfcount{ font-size:11px; font-weight:700; background:rgba(255,255,255,.06); color:var(--text-dim); padding:1px 8px; border-radius:20px; }
.rfbtn.active .rfcount{ background:var(--green); color:#1a1205; }

.rules-cat{ margin-top:38px; }
.rules-cat-h{ color:var(--head); font-size:18px; letter-spacing:1px; display:flex; align-items:center; gap:10px;
  padding-bottom:12px; border-bottom:1px solid var(--border); margin-bottom:14px; }
.rules-cat-h span{ font-size:12px; font-weight:700; color:var(--text-dim); background:var(--surface);
  border:1px solid var(--border); padding:2px 10px; border-radius:20px; letter-spacing:0; }
.rules-list{ display:grid; gap:10px; }

.rule-item{ background:var(--surface); border:1px solid var(--border); border-radius:12px; overflow:hidden; transition:border-color .15s; }
.rule-item[open]{ border-color:var(--border-2); }
.rule-item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; gap:12px; padding:15px 20px; user-select:none; }
.rule-item summary::-webkit-details-marker{ display:none; }
.rule-item summary:hover .rule-title{ color:var(--green); }
.rule-title{ flex:1; font-size:16px; font-weight:600; color:var(--head); transition:color .15s; }
.rule-tag{ flex-shrink:0; font-size:11px; font-weight:700; letter-spacing:.5px; text-transform:uppercase; padding:3px 9px; border-radius:6px;
  white-space:nowrap; background:rgba(255,91,91,.12); color:#ff6b6b; border:1px solid rgba(255,91,91,.3); }
.rule-tag.info{ background:var(--green-soft); color:var(--green); border-color:rgba(240,140,0,.3); }
.rule-chev{ flex-shrink:0; width:16px; height:16px; fill:var(--text-dim); transition:transform .2s; }
.rule-item[open] .rule-chev{ transform:rotate(180deg); }
.rule-body{ padding:4px 20px 18px; border-top:1px solid var(--border); }
.rule-def{ color:var(--text); font-size:15px; line-height:1.7; margin-top:14px; }
.rule-pen{ margin-top:16px; display:flex; gap:12px; align-items:flex-start; flex-wrap:wrap;
  background:rgba(255,91,91,.06); border:1px solid rgba(255,91,91,.2); border-left:3px solid #ff6b6b; border-radius:8px; padding:12px 14px; }
.rule-pen-label{ flex-shrink:0; font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#ff6b6b; padding-top:2px; }
.rule-pen-text{ color:var(--text); font-size:14px; line-height:1.6; }
.rules-empty{ text-align:center; color:var(--text-dim); padding:46px 0; font-size:16px; }
.drop-menu a.active{ background:var(--green-soft); color:var(--green); }
@media (max-width:560px){ .rules-tools{ flex-direction:column; align-items:stretch; } .rule-item summary{ flex-wrap:wrap; } }

/* Regeln: deaktivierte Kategorien (kommen später) – ausgegraut & nicht interaktiv */
.rfbtn.disabled{ opacity:.4; cursor:not-allowed; pointer-events:none; }
.rules-cat.disabled{ opacity:.45; pointer-events:none; }
.rules-cat.disabled .rule-item summary{ cursor:not-allowed; }
.rules-cat.disabled .rules-cat-h span{ background:var(--green-soft); color:var(--green); border-color:rgba(240,140,0,.3); text-transform:uppercase; letter-spacing:.5px; }

/* ============ GALERIE-LIGHTBOX ============ */
.gallery .shot{ cursor:pointer; }
.lightbox{ position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; padding:30px;
  background:rgba(8,10,14,.9); backdrop-filter:blur(4px);
  opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s ease; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:12px; border:1px solid var(--border-2);
  box-shadow:0 24px 70px rgba(0,0,0,.6); transform:scale(.92); transition:transform .25s ease; }
.lightbox.open img{ transform:scale(1); }
.lb-btn{ position:absolute; z-index:2; display:flex; align-items:center; justify-content:center;
  background:rgba(20,26,34,.72); border:1px solid var(--border-2); color:var(--head); cursor:pointer;
  font-family:inherit; line-height:1; transition:background .15s, color .15s, border-color .15s; }
.lb-btn:hover{ background:var(--green); color:#1a1205; border-color:var(--green); }
.lb-close{ top:18px; right:24px; width:46px; height:46px; border-radius:50%; font-size:28px; }
.lb-prev,.lb-next{ top:50%; transform:translateY(-50%); width:54px; height:54px; border-radius:50%; font-size:22px; }
.lb-prev{ left:24px; } .lb-next{ right:24px; }
@media (max-width:560px){ .lb-prev{ left:8px; } .lb-next{ right:8px; } .lb-btn{ width:42px; height:42px; } .lightbox{ padding:14px; } }

/* ============ KARTE (Dynmap-Embed) ============ */
.map-embed{ position:relative; width:100%; height:75vh; min-height:440px; margin-top:30px;
  border:1px solid var(--border-2); border-radius:14px; overflow:hidden; box-shadow:var(--shadow); background:var(--surface); }
.map-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; }
.map-note{ text-align:center; color:var(--text-dim); margin-top:18px; }
