/* bitman — IT für soziale Dienste
   Design tokens + global styles
   Primary amber sampled from logo: #FEB100 */

:root{
  --c-amber:#FEB100;
  --c-amber-deep:#E59E00;
  --c-amber-soft:#FFF4D6;
  --c-ink:#0E1116;
  --c-ink-2:#1A1D24;
  --c-ink-3:#2A2F3A;
  --c-muted:#5A6270;
  --c-muted-2:#8A91A0;
  --c-line:#E7E4DC;
  --c-line-2:#EFEDE5;
  --c-surface:#FFFFFF;
  --c-bg:#FBF7EE;        /* warm cream */
  --c-bg-2:#F4EFE3;      /* deeper cream */
  --c-bg-dark:#0E1116;

  --radius-xs:6px;
  --radius-s:12px;
  --radius-m:18px;
  --radius-l:28px;
  --radius-xl:40px;

  --shadow-s:0 1px 2px rgba(14,17,22,.04), 0 2px 8px rgba(14,17,22,.04);
  --shadow-m:0 2px 6px rgba(14,17,22,.05), 0 14px 40px rgba(14,17,22,.08);
  --shadow-l:0 30px 60px -20px rgba(14,17,22,.18), 0 8px 24px -10px rgba(14,17,22,.10);

  --pad:clamp(20px, 4vw, 80px);
  --maxw:1240px;

  --f-display:'Plus Jakarta Sans','Helvetica Neue',Helvetica,Arial,sans-serif;
  --f-body:'Plus Jakarta Sans','Helvetica Neue',Helvetica,Arial,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.55;
  color:var(--c-ink);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11";
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:0}

/* density modifier */
body[data-density="compact"]{font-size:16px}
body[data-density="compact"] .section{padding-block:clamp(56px,7vw,96px)}

/* image radius modifier */
body[data-imgshape="sharp"] .img-soft,
body[data-imgshape="sharp"] .img-soft img{border-radius:0!important}

/* ─── Layout ─────────────────────────────────────────────── */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(72px,9vw,128px)}
.section-tight{padding-block:clamp(48px,6vw,80px)}
.bleed-amber{background:var(--c-amber);color:var(--c-ink)}
.bleed-cream{background:var(--c-bg-2)}
.bleed-ink{background:var(--c-bg-dark);color:#F4F1EA}
.bleed-ink .muted{color:#A6ABB6}

/* ─── Type ───────────────────────────────────────────────── */
.eyebrow{
  font-family:var(--f-mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--c-muted);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";display:inline-block;width:18px;height:2px;background:var(--c-amber);
}
h1,h2,h3,h4{font-family:var(--f-display);margin:0;letter-spacing:-0.02em;line-height:1.05}
h1{font-size:clamp(40px,6vw,80px);font-weight:700;text-wrap:balance}
h2{font-size:clamp(30px,4vw,52px);font-weight:600;text-wrap:balance}
h3{font-size:clamp(20px,1.6vw,24px);font-weight:600;letter-spacing:-0.01em}
h4{font-size:15px;font-weight:600;letter-spacing:0}
p{margin:0;text-wrap:pretty}
.lede{font-size:clamp(18px,1.4vw,22px);line-height:1.55;color:var(--c-ink-3);max-width:60ch}
.muted{color:var(--c-muted)}
.mono{font-family:var(--f-mono);font-size:12px;letter-spacing:.04em}

/* ─── Buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;
  border-radius:999px;
  font-weight:600;font-size:15px;
  transition:transform .15s ease, background .2s, color .2s, box-shadow .2s;
  white-space:nowrap;
}
.btn-primary{background:var(--c-ink);color:#fff}
.btn-primary:hover{background:#000;transform:translateY(-1px);box-shadow:0 10px 24px -10px rgba(14,17,22,.4)}
.btn-amber{background:var(--c-amber);color:var(--c-ink)}
.btn-amber:hover{background:var(--c-amber-deep);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--c-ink);box-shadow:inset 0 0 0 1px var(--c-line)}
.btn-ghost:hover{background:#fff;box-shadow:inset 0 0 0 1px var(--c-ink)}
.btn-light{background:#fff;color:var(--c-ink)}
.btn-light:hover{background:#F4F1EA}
.btn .arr{display:inline-block;transition:transform .2s ease;transform:translateX(0)}
.btn:hover .arr{transform:translateX(3px)}

/* ─── Header ─────────────────────────────────────────────── */
.hdr{
  position:sticky;top:0;z-index:100;
  background:rgba(251,247,238,.85);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s, background .25s, box-shadow .25s;
}
.hdr[data-scrolled="true"]{
  background:rgba(255,255,255,.92);
  border-bottom-color:var(--c-line);
}
.hdr-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:96px;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
.brand img{height:56px;width:auto}
.brand .brand-sub{
  display:none;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;
  color:var(--c-muted);text-transform:uppercase;border-left:1px solid var(--c-line);
  padding-left:14px;line-height:1.2;
}
@media (min-width:900px){.brand .brand-sub{display:block}}
.nav{display:none;gap:6px;align-items:center}
@media (min-width:980px){.nav{display:flex}}
.nav a{
  padding:9px 14px;border-radius:999px;font-size:15px;font-weight:500;color:var(--c-ink-2);
  transition:background .15s, color .15s;
}
.nav a:hover{background:rgba(14,17,22,.06)}
.hdr-cta{display:flex;align-items:center;gap:10px}
.menu-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:999px;
  background:transparent;color:var(--c-ink);
}
@media (min-width:980px){.menu-btn{display:none}}
.menu-btn:hover{background:rgba(14,17,22,.06)}
.menu-btn .bars{display:block;width:18px;height:2px;background:currentColor;position:relative}
.menu-btn .bars::before,.menu-btn .bars::after{
  content:"";position:absolute;left:0;width:18px;height:2px;background:currentColor;
  transition:transform .25s;
}
.menu-btn .bars::before{top:-6px}
.menu-btn .bars::after{top:6px}
.menu-btn[aria-expanded="true"] .bars{background:transparent}
.menu-btn[aria-expanded="true"] .bars::before{transform:translateY(6px) rotate(45deg)}
.menu-btn[aria-expanded="true"] .bars::after{transform:translateY(-6px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:96px 0 0 0;background:var(--c-bg);z-index:90;
  padding:24px var(--pad);display:flex;flex-direction:column;gap:6px;
  transform:translateY(-12px);opacity:0;pointer-events:none;
  transition:transform .25s, opacity .25s;
}
.mobile-menu[data-open="true"]{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu a{
  font-size:22px;font-weight:600;padding:14px 0;
  border-bottom:1px solid var(--c-line);
}

/* ─── Hero ───────────────────────────────────────────────── */
.hero{position:relative;padding-block:clamp(56px,7vw,120px)}
.hero-grid{
  display:grid;gap:clamp(32px,5vw,72px);
  grid-template-columns:1fr;
  align-items:center;
}
@media (min-width:980px){
  .hero-grid{grid-template-columns:1.1fr 1fr}
  body[data-hero="centered"] .hero-grid{grid-template-columns:1fr;text-align:center;justify-items:center}
  body[data-hero="centered"] .hero-media{display:none}
  body[data-hero="centered"] .hero-text{max-width:880px}
  body[data-hero="centered"] .lede{margin-inline:auto}
  body[data-hero="centered"] .hero-meta{justify-content:center}
}
.hero h1 .amber-mark{
  color:var(--c-amber);
  position:relative;display:inline-block;
}
.hero h1 .amber-mark::after{
  content:none;
}
.hero .lede{margin-top:22px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:24px 32px;margin-top:36px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--c-muted);
}
.hero-meta b{color:var(--c-ink);font-weight:600}

.hero-media{position:relative}
.hero-media .img-wrap{
  position:relative;border-radius:var(--radius-l);overflow:hidden;
  aspect-ratio:4/5;background:var(--c-line-2);
  box-shadow:var(--shadow-l);
}
.hero-media .img-wrap img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;left:-18px;top:32px;
  background:#fff;border-radius:var(--radius-m);
  padding:14px 18px;box-shadow:var(--shadow-m);
  display:flex;flex-direction:column;gap:2px;min-width:160px;
}
.hero-badge .num{font-family:var(--f-display);font-size:36px;font-weight:700;letter-spacing:-0.03em;line-height:1}
.hero-badge .num .pct{color:var(--c-amber)}
.hero-badge .phone{font-family:var(--f-display);font-size:22px;font-weight:600;letter-spacing:-0.01em;color:var(--c-amber);line-height:1.1}
.hero-badge .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--c-muted)}
.hero-badge.b2{left:auto;right:-18px;top:auto;bottom:32px;text-align:right;align-items:flex-end}
@media (max-width:640px){
  .hero-badge{left:12px;top:12px;padding:10px 14px;min-width:0}
  .hero-badge.b2{right:12px;bottom:12px;left:auto;top:auto}
  .hero-badge .num{font-size:24px}
}

/* logo stripes decorative */
.hero-deco{
  position:absolute;right:-40px;top:60px;width:240px;height:240px;pointer-events:none;
  opacity:.07;z-index:0;
}
@media (max-width:980px){.hero-deco{display:none}}

/* ─── Trust strip ────────────────────────────────────────── */
.trust{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:0;
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
}
.trust-cell{
  padding:32px 24px;
  border-right:1px solid var(--c-line);
  display:flex;flex-direction:column;gap:6px;
}
.trust-cell:last-child{border-right:0}
.trust-cell .big{
  font-family:var(--f-display);font-size:clamp(34px,3.6vw,48px);
  font-weight:700;letter-spacing:-0.03em;line-height:1;
}
.trust-cell .big .accent{color:var(--c-amber)}
.trust-cell .lbl{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--c-muted);
}

/* ─── Section header pattern ─────────────────────────────── */
.section-head{
  display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:64px;align-items:end;
}
@media (min-width:880px){
  .section-head{grid-template-columns:auto 1fr auto;gap:48px}
}
.section-head .title-block{display:flex;flex-direction:column;gap:14px;max-width:32ch}
.section-head .section-lede{color:var(--c-ink-3);font-size:18px;line-height:1.55;max-width:44ch}
.section-head .section-cta{align-self:end}

/* ─── Services grid ──────────────────────────────────────── */
.svc-grid{
  display:grid;gap:1px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  background:var(--c-line);
  border:1px solid var(--c-line);
  border-radius:var(--radius-l);
  overflow:hidden;
}
.svc{
  background:#fff;padding:36px 28px;
  display:flex;flex-direction:column;gap:18px;
  min-height:260px;
  position:relative;
  transition:background .2s;
}
.svc:hover{background:#FFFBF0}
.svc:hover .svc-num{color:var(--c-amber)}
.svc:hover .svc-arr{transform:translate(3px,-3px);color:var(--c-ink)}
.svc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.svc-num{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;color:var(--c-muted);
  transition:color .2s;
}
.svc-arr{
  display:inline-flex;width:34px;height:34px;border-radius:999px;
  align-items:center;justify-content:center;color:var(--c-muted);
  border:1px solid var(--c-line);
  transition:transform .2s ease, color .2s;
}
.svc h3{margin-top:auto}
.svc p{font-size:15px;color:var(--c-muted);line-height:1.5}

/* abstract logo-glyph icon */
.glyph{
  display:inline-block;width:40px;height:40px;position:relative;
}
.glyph i{
  position:absolute;background:var(--c-amber);border-radius:2px;
  width:6px;height:28px;top:2px;transform:skewX(-20deg);transform-origin:bottom left;
}
.glyph i:nth-child(1){left:2px}
.glyph i:nth-child(2){left:13px}
.glyph i:nth-child(3){left:24px}
.glyph i:nth-child(4){left:33px;top:30px;width:7px;height:7px;border-radius:50%;transform:none}

/* ─── Branchen ───────────────────────────────────────────── */
.branchen{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.bran-card{
  position:relative;border-radius:var(--radius-l);overflow:hidden;
  aspect-ratio:4/5;background:var(--c-ink);color:#fff;
}
.bran-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.bran-card:hover img{transform:scale(1.04)}
.bran-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(14,17,22,0) 30%, rgba(14,17,22,.85) 100%);
}
.bran-card .bran-body{
  position:absolute;inset:auto 0 0 0;padding:28px 28px 26px;z-index:1;
  display:flex;flex-direction:column;gap:8px;
}
.bran-card .bran-tag{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--c-amber);
}
.bran-card h3{color:#fff;font-size:24px}
.bran-card p{font-size:14px;color:#D8D5CE;line-height:1.5}

/* ─── Why bitman ─────────────────────────────────────────── */
.why-grid{
  display:grid;gap:clamp(24px,4vw,56px);align-items:center;
  grid-template-columns:1fr;
}
@media (min-width:980px){
  .why-grid{grid-template-columns:1fr 1fr}
}
.why-points{display:flex;flex-direction:column;gap:8px}
.why-point{
  display:grid;grid-template-columns:auto 1fr;gap:24px;
  padding:24px 0;border-top:1px solid var(--c-line);
}
.why-point:last-child{border-bottom:1px solid var(--c-line)}
.why-point .pn{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;color:var(--c-amber);
  padding-top:4px;
}
.why-point h3{font-size:22px;margin-bottom:8px}
.why-point p{font-size:15px;color:var(--c-muted);line-height:1.55}

.collage{
  position:relative;aspect-ratio:1/1;
}
.collage .cimg{
  position:absolute;border-radius:var(--radius-m);overflow:hidden;
  box-shadow:var(--shadow-m);
}
.collage .cimg img{width:100%;height:100%;object-fit:cover}
.collage .c1{left:0;top:0;width:62%;height:62%}
.collage .c2{right:0;top:14%;width:42%;height:48%}
.collage .c3{left:14%;bottom:0;width:54%;height:42%}
.collage .stripe,
.why-single .stripe{
  position:absolute;right:-12px;bottom:-12px;background:var(--c-amber);
  padding:14px 22px;border-radius:var(--radius-s);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-ink);font-weight:600;
}

.why-single{
  position:relative;aspect-ratio:4/5;
}
.why-single img{width:100%;height:100%;object-fit:cover}

/* ─── Process ────────────────────────────────────────────── */
.proc{
  display:grid;gap:24px;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.proc-step{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-m);
  padding:28px 24px 32px;display:flex;flex-direction:column;gap:12px;position:relative;
}
.proc-step .pi{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;color:var(--c-muted);
}
.proc-step h3{font-size:22px}
.proc-step p{font-size:14.5px;color:var(--c-muted);line-height:1.5}
.proc-step .dot{
  position:absolute;right:24px;top:24px;width:10px;height:10px;border-radius:50%;
  background:var(--c-amber);
}

/* ─── Gallery ────────────────────────────────────────────── */
.gallery{
  display:grid;gap:14px;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:140px;
}
.gallery .g{
  border-radius:var(--radius-m);overflow:hidden;background:var(--c-line-2);
  position:relative;
}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gallery .g:hover img{transform:scale(1.05)}
.gallery .g1{grid-column:span 7;grid-row:span 2}
.gallery .g2{grid-column:span 5;grid-row:span 1}
.gallery .g3{grid-column:span 5;grid-row:span 1}
.gallery .g4{grid-column:span 4;grid-row:span 1}
.gallery .g5{grid-column:span 4;grid-row:span 1}
.gallery .g6{grid-column:span 4;grid-row:span 1}
@media (max-width:880px){
  .gallery{grid-template-columns:repeat(6,1fr);grid-auto-rows:120px}
  .gallery .g1{grid-column:span 6;grid-row:span 2}
  .gallery .g2,.gallery .g3{grid-column:span 3;grid-row:span 1}
  .gallery .g4,.gallery .g5,.gallery .g6{grid-column:span 2;grid-row:span 1}
}

/* ─── Pull quote ─────────────────────────────────────────── */
.pull{
  border-radius:var(--radius-xl);padding:clamp(48px,7vw,96px) clamp(28px,5vw,72px);
  display:grid;gap:32px;align-items:center;
  grid-template-columns:1fr;
}
@media (min-width:880px){.pull{grid-template-columns:auto 1fr}}
.pull-mark{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(80px,12vw,160px);line-height:.7;letter-spacing:-0.05em;
  color:var(--c-ink);
}
.pull q{
  font-family:var(--f-display);font-size:clamp(26px,3vw,40px);font-weight:600;
  line-height:1.2;letter-spacing:-0.02em;
  quotes:"" "";display:block;text-wrap:balance;
}
.pull .attr{
  margin-top:24px;font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--c-ink-2);
}

/* ─── CTA / Contact ──────────────────────────────────────── */
.cta-wrap{
  background:var(--c-ink);color:#fff;border-radius:var(--radius-xl);
  padding:clamp(40px,6vw,72px);
  display:grid;gap:48px;
  grid-template-columns:1fr;
}
@media (min-width:980px){.cta-wrap{grid-template-columns:1.1fr 1fr}}
.cta-wrap h2{color:#fff}
.cta-wrap .muted{color:#A6ABB6}
.cta-form{
  background:#1A1D24;border-radius:var(--radius-m);padding:28px;
  display:flex;flex-direction:column;gap:14px;
}
.cta-form label{
  display:flex;flex-direction:column;gap:6px;font-family:var(--f-mono);font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;color:#A6ABB6;
}
.cta-form input,.cta-form textarea,.cta-form select{
  background:#0E1116;color:#fff;border:1px solid #2A2F3A;border-radius:10px;
  padding:13px 14px;font:inherit;font-size:15px;letter-spacing:0;
  text-transform:none;font-family:var(--f-body);
  transition:border-color .15s, background .15s;
}
.cta-form input:focus,.cta-form textarea:focus,.cta-form select:focus{
  outline:none;border-color:var(--c-amber);background:#13161D;
}
.cta-form textarea{min-height:90px;resize:vertical}
.cta-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.cta-form .row{grid-template-columns:1fr}}
.cta-form .submit-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px}
.cta-form .err{color:#FEB100;font-family:var(--f-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.cta-success{
  background:#1A1D24;border-radius:var(--radius-m);padding:48px 28px;text-align:center;
  display:flex;flex-direction:column;gap:14px;align-items:center;justify-content:center;
}
.cta-success .check{
  width:56px;height:56px;border-radius:50%;background:var(--c-amber);color:var(--c-ink);
  display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:28px;
}

.contact-list{display:flex;flex-direction:column;gap:18px;margin-top:8px}
.contact-list a{
  display:flex;flex-direction:column;gap:3px;padding:14px 0;border-bottom:1px solid #2A2F3A;
}
.contact-list a:last-child{border-bottom:0}
.contact-list .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#A6ABB6}
.contact-list .val{font-size:18px;font-weight:600}
.contact-list a:hover .val{color:var(--c-amber)}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--c-line)}
.faq-item{border-bottom:1px solid var(--c-line)}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:24px 0;text-align:left;font-size:19px;font-weight:600;
  font-family:var(--f-display);color:var(--c-ink);
  background:transparent;
}
.faq-q:hover{color:var(--c-amber-deep)}
.faq-q .ic{
  width:32px;height:32px;border-radius:50%;background:var(--c-line-2);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:20px;line-height:1;font-weight:400;color:var(--c-ink);
  transition:transform .25s, background .15s;
}
.faq-item[data-open="true"] .ic{transform:rotate(45deg);background:var(--c-amber)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .3s ease;
}
.faq-a-inner{padding:0 0 24px;color:var(--c-muted);font-size:16px;max-width:70ch;line-height:1.6}
.faq-item[data-open="true"] .faq-a{max-height:300px}

/* ─── Footer ─────────────────────────────────────────────── */
.ftr{background:var(--c-bg-dark);color:#D8D5CE;padding:80px 0 32px}
.ftr-grid{
  display:grid;gap:48px;
  grid-template-columns:1fr;
}
@media (min-width:780px){.ftr-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.ftr-brand{display:flex;flex-direction:column;gap:18px;max-width:32ch}
.ftr-brand .lockup{display:flex;align-items:center;gap:14px}
.ftr-brand .lockup img{height:32px;filter:brightness(0) invert(1) saturate(0) hue-rotate(0deg)}
.ftr-brand p{color:#A6ABB6;font-size:15px;line-height:1.6}
.ftr-col h4{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:#8A8A8A;margin-bottom:18px;font-weight:500;
}
.ftr-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ftr-col a{color:#D8D5CE;font-size:15px}
.ftr-col a:hover{color:var(--c-amber)}
.ftr-bottom{
  margin-top:80px;padding-top:24px;border-top:1px solid #2A2F3A;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:#8A8A8A;
}

/* image radius helper */
.img-soft{border-radius:var(--radius-l);overflow:hidden}
.img-soft img{display:block;width:100%;height:100%;object-fit:cover}

/* fade-in on intersection */
.fade-in{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.fade-in.in{opacity:1;transform:none}

/* ─── Admin Panel (Besucherzähler) ────────────────────────── */
.admin-panel{
  position: fixed;
  bottom: 24px; left: 24px;
  background: #0E1116;
  color: #fff;
  border: 1px solid #2A2F3A;
  border-radius: 16px;
  padding: 28px 28px 24px;
  min-width: 280px;
  max-width: 320px;
  box-shadow: 0 24px 60px rgba(0,0,0,.5);
  z-index: 9999;
  font-family: var(--f-display);
}
.admin-close{
  position: absolute; top: 10px; right: 14px;
  background: transparent; border: 0; color: #A6ABB6;
  font-size: 22px; cursor: pointer; line-height: 1;
  padding: 4px 8px; border-radius: 6px;
}
.admin-close:hover{ color: #fff; background: rgba(255,255,255,.06) }
.admin-eyebrow{
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--c-amber);
  margin-bottom: 6px;
}
.admin-title{
  font-size: 18px; font-weight: 600; margin-bottom: 18px;
  letter-spacing: -0.01em;
}
.admin-panel input{
  width: 100%; padding: 12px 14px;
  background: #1A1F26;
  border: 1px solid #2A2F3A;
  border-radius: 8px;
  color: #fff;
  font-size: 15px;
  margin-bottom: 12px;
  box-sizing: border-box;
  font-family: var(--f-display);
}
.admin-panel input:focus{ outline: 2px solid var(--c-amber); outline-offset: 0; border-color: transparent }
.admin-err{
  color: #FFB8AE; font-size: 13px;
  margin-bottom: 12px;
  font-family: var(--f-mono);
}
.admin-btn{
  width: 100%; padding: 12px;
  background: var(--c-amber);
  color: var(--c-ink);
  border: 0; border-radius: 8px;
  font-weight: 600; font-size: 15px;
  cursor: pointer;
  font-family: var(--f-display);
  transition: background .15s;
}
.admin-btn:hover{ background: var(--c-amber-deep) }
.admin-big{
  font-size: 56px; font-weight: 700;
  letter-spacing: -0.03em; line-height: 1;
  margin-bottom: 6px;
  font-family: var(--f-display);
  color: #fff;
}
.admin-sublabel{
  font-family: var(--f-mono);
  font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase;
  color: #A6ABB6;
  margin-bottom: 20px;
}
.admin-row{ display: flex; gap: 20px; }
.admin-link{
  background: transparent; border: 0;
  color: #A6ABB6;
  font-size: 12px; letter-spacing: .04em;
  cursor: pointer; padding: 0;
  font-family: var(--f-mono);
  transition: color .15s;
}
.admin-link:hover{ color: var(--c-amber) }
@media (max-width: 640px){
  .admin-panel{ left: 12px; right: 12px; bottom: 12px; max-width: none }
}
