/* ==========================================================================
   FAIR-Kauf e.K. — Relaunch
   Design system & components
   Palette anchored to the original brand blue (#2d5c88) + a single warm accent.
   Type: Bricolage Grotesque (display) · Hanken Grotesk (body) · Spline Sans Mono (tags)
   ========================================================================== */

/* ----- Fonts (self-hosted, variable) ----- */
@font-face{
  font-family:"Bricolage Grotesque";
  src:url("../fonts/bricolage-grotesque.woff2") format("woff2");
  font-weight:200 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Hanken Grotesk";
  src:url("../fonts/hanken-grotesk.woff2") format("woff2");
  font-weight:300 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Hanken Grotesk";
  src:url("../fonts/hanken-grotesk-italic.woff2") format("woff2");
  font-weight:300 800; font-style:italic; font-display:swap;
}
@font-face{
  font-family:"Spline Sans Mono";
  src:url("../fonts/spline-sans-mono.woff2") format("woff2");
  font-weight:300 700; font-style:normal; font-display:swap;
}

/* ----- Tokens ----- */
:root{
  /* colour — derived from the live site, deepened for contrast */
  --ink:#15293a;          /* near-navy: headings, dark sections */
  --ink-soft:#3a4d5e;     /* secondary text */
  --brand:#2d5c88;        /* signature steel blue (exact from original) */
  --brand-dk:#214a6f;     /* hover / pressed */
  --steel:#6c8dab;        /* muted secondary blue — eyebrows, lines, icons */
  --mist:#eaf0f5;         /* pale blue surface */
  --mist-2:#dde7f0;       /* slightly deeper pale blue */
  --paper:#fbfcfd;        /* page background */
  --white:#ffffff;
  --accent:#ff6900;       /* warm orange — the ONE accent, used sparingly */
  --line:#dde4ec;         /* hairlines */
  --line-dk:rgba(255,255,255,.16);

  /* type */
  --display:"Bricolage Grotesque","Trebuchet MS",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:"Spline Sans Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;

  /* scale & rhythm */
  --container:1220px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --section-y:clamp(4.5rem,9vw,8rem);
  --radius:18px;
  --radius-sm:11px;
  --shadow-sm:0 1px 2px rgba(21,41,58,.06),0 6px 18px rgba(21,41,58,.06);
  --shadow-md:0 18px 50px -20px rgba(21,41,58,.35);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----- Reset / base ----- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:118px}
body{
  font-family:var(--body);
  font-weight:400;
  font-size:clamp(1rem,.97rem + .15vw,1.075rem);
  line-height:1.6;
  color:var(--ink-soft);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
button{font:inherit; color:inherit; cursor:pointer; background:none; border:none}
ul{list-style:none; padding:0}
::selection{background:var(--brand); color:#fff}

:focus-visible{outline:3px solid var(--accent); outline-offset:3px; border-radius:4px}

/* ----- Layout helpers ----- */
.container{width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(3rem,6vw,4.5rem)}

/* ----- Typography ----- */
h1,h2,h3,h4{font-family:var(--display); color:var(--ink); line-height:1.05; font-weight:700; letter-spacing:-.02em}
.display{
  font-family:var(--display); color:var(--ink);
  font-weight:760; letter-spacing:-.035em; line-height:1.0;
  font-size:clamp(2.6rem,2rem + 4.2vw,5.1rem);
}
.h2{font-size:clamp(1.95rem,1.5rem + 1.9vw,3rem); letter-spacing:-.03em}
.h3{font-size:clamp(1.25rem,1.1rem + .6vw,1.6rem); letter-spacing:-.02em}
.lead{font-size:clamp(1.1rem,1.03rem + .35vw,1.32rem); line-height:1.55; color:var(--ink-soft)}
.measure{max-width:62ch}
.measure-sm{max-width:46ch}

/* Signature device: monospace "Lager-/Spec-Tag" */
.tag{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--mono); font-weight:500;
  font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brand);
}
.tag::before{
  content:""; inline-size:8px; block-size:8px; border-radius:2px;
  background:var(--accent); flex:none;
}
.tag--light{color:#bcd0e2}
.tag--plain::before{display:none}

/* small inline mono metadata */
.mono{font-family:var(--mono); font-weight:400; font-variant-numeric:tabular-nums}

/* ----- Buttons ----- */
.btn{
  --bg:var(--brand); --fg:#fff; --bd:var(--brand);
  display:inline-flex; align-items:center; gap:.6em;
  padding:.95em 1.55em; border-radius:999px;
  background:var(--bg); color:var(--fg); border:1.5px solid var(--bd);
  font-family:var(--body); font-weight:600; font-size:.97rem; letter-spacing:-.01em;
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  will-change:transform;
}
.btn .ar{transition:transform .3s var(--ease)}
.btn:hover{background:var(--brand-dk); border-color:var(--brand-dk); transform:translateY(-2px); box-shadow:0 14px 26px -12px rgba(33,74,111,.7)}
.btn:hover .ar{transform:translateX(4px)}
.btn--ghost{--bg:transparent; --fg:var(--ink); --bd:var(--line)}
.btn--ghost:hover{--bg:var(--ink); background:var(--ink); color:#fff; border-color:var(--ink)}
.btn--on-dark{--bg:#fff; --fg:var(--ink); --bd:#fff}
.btn--on-dark:hover{background:var(--mist); border-color:var(--mist); color:var(--ink)}
.btn--ghost-dark{--bg:transparent; --fg:#fff; --bd:var(--line-dk)}
.btn--ghost-dark:hover{background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.4); color:#fff; transform:translateY(-2px)}

.textlink{
  display:inline-flex; align-items:center; gap:.5em;
  font-weight:600; color:var(--brand);
  border-bottom:2px solid color-mix(in srgb,var(--brand) 22%,transparent);
  padding-bottom:1px; transition:color .2s,border-color .2s;
}
.textlink:hover{color:var(--brand-dk); border-color:var(--accent)}
.textlink .ar{transition:transform .25s var(--ease)}
.textlink:hover .ar{transform:translateX(3px)}

/* ==========================================================================
   Utility bar + Header
   ========================================================================== */
.utilbar{
  background:var(--ink); color:#c4d4e2;
  font-family:var(--mono); font-size:.78rem; letter-spacing:.02em;
}
.utilbar .container{display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height:38px}
.utilbar a{color:#c4d4e2; transition:color .2s}
.utilbar a:hover{color:#fff}
.utilbar__group{display:flex; align-items:center; gap:1.6rem}
.utilbar__item{display:inline-flex; align-items:center; gap:.5em}
.utilbar__item svg{inline-size:14px; block-size:14px; color:var(--steel)}

.site-header{
  position:sticky; top:0; z-index:60;
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s, background .3s;
}
.site-header.is-scrolled{
  border-bottom-color:var(--line);
  box-shadow:0 6px 24px -18px rgba(21,41,58,.5);
  background:color-mix(in srgb,var(--paper) 96%,transparent);
}
.nav{display:flex; align-items:center; justify-content:space-between; gap:1.5rem; min-height:78px}

/* wordmark */
.brand{display:flex; align-items:center; gap:.7rem; flex:none}
.brand__mark{inline-size:38px; block-size:38px; border-radius:9px; flex:none}
.brand__text{display:flex; flex-direction:column; line-height:1}
.brand__word{font-family:var(--display); font-weight:780; font-size:1.42rem; letter-spacing:-.02em; color:var(--ink)}
.brand__word b{color:var(--brand); font-weight:780}
.brand__word .dot{color:var(--accent)}
.brand__tag{font-family:var(--mono); font-size:.59rem; letter-spacing:.18em; text-transform:uppercase; color:var(--steel); margin-top:3px}

/* desktop nav */
.nav__links{display:flex; align-items:center; gap:.35rem}
.nav__link{
  position:relative; padding:.55em .85em; border-radius:8px;
  font-weight:550; font-size:.97rem; color:var(--ink-soft);
  transition:color .2s, background .2s;
}
.nav__link:hover{color:var(--ink); background:var(--mist)}
.nav__link::after{
  content:""; position:absolute; left:.85em; right:.85em; bottom:.32em; height:2px;
  background:var(--accent); border-radius:2px; transform:scaleX(0); transform-origin:left;
  transition:transform .28s var(--ease);
}
.nav__link:hover::after,.nav__link.is-active::after{transform:scaleX(1)}
.nav__actions{display:flex; align-items:center; gap:.75rem; flex:none}

/* hamburger */
.nav__toggle{display:none; inline-size:46px; block-size:46px; border-radius:11px; border:1px solid var(--line); align-items:center; justify-content:center}
.nav__toggle span{position:relative; inline-size:20px; block-size:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease)}
.nav__toggle span::before,.nav__toggle span::after{content:""; position:absolute; left:0; inline-size:20px; block-size:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease)}
.nav__toggle span::before{top:-6px}
.nav__toggle span::after{top:6px}

/* mobile drawer */
.drawer{
  position:fixed; inset:0 0 0 auto; z-index:80; inline-size:min(86vw,360px);
  background:var(--paper); transform:translateX(100%);
  transition:transform .4s var(--ease); box-shadow:var(--shadow-md);
  display:flex; flex-direction:column; padding:1.4rem;
}
.drawer__head{display:flex; align-items:center; justify-content:space-between; margin-bottom:1.4rem}
.drawer__close{inline-size:44px; block-size:44px; border-radius:11px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:var(--ink)}
.drawer a.drawer__link{
  display:flex; align-items:center; justify-content:space-between;
  padding:.95rem .25rem; font-family:var(--display); font-weight:600; font-size:1.3rem;
  color:var(--ink); border-bottom:1px solid var(--line);
}
.drawer a.drawer__link .ar{color:var(--steel)}
.drawer__foot{margin-top:auto; padding-top:1.4rem; display:flex; flex-direction:column; gap:.85rem}
.drawer__meta{font-family:var(--mono); font-size:.8rem; color:var(--ink-soft); line-height:1.7}
.scrim{position:fixed; inset:0; z-index:70; background:rgba(11,22,33,.5); opacity:0; visibility:hidden; transition:opacity .35s, visibility .35s; backdrop-filter:blur(2px)}
body.drawer-open{overflow:hidden}
body.drawer-open .drawer{transform:translateX(0)}
body.drawer-open .scrim{opacity:1; visibility:visible}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{position:relative; isolation:isolate; color:#fff; overflow:hidden}
.hero__bg{position:absolute; inset:0; z-index:-2}
.hero__bg img{inline-size:100%; block-size:100%; object-fit:cover; transform:scale(1.06); animation:heroZoom 22s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg,rgba(13,28,42,.55) 0%,rgba(13,28,42,.30) 32%,rgba(13,28,42,.78) 100%),
    linear-gradient(100deg,rgba(21,41,58,.85) 0%,rgba(21,41,58,.25) 55%,rgba(21,41,58,0) 80%);
}
.hero__inner{display:flex; flex-direction:column; justify-content:flex-end; min-height:clamp(560px,86vh,860px); padding-block:clamp(3rem,7vw,5rem)}
.hero__eyebrow{color:#cfe0ee}
.hero__eyebrow.tag::before{background:var(--accent)}
.hero h1{color:#fff; margin-block:1.1rem .9rem; max-width:15ch; text-shadow:0 2px 30px rgba(8,18,28,.35)}
.hero__lead{color:#e7eef5; max-width:54ch; font-size:clamp(1.08rem,1rem + .5vw,1.4rem)}
.hero__cta{display:flex; flex-wrap:wrap; gap:.85rem; margin-top:2rem}

/* stock-tag strip */
.specstrip{
  margin-top:clamp(2.4rem,5vw,3.6rem); padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.18);
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem 1.5rem;
}
.spec{display:flex; align-items:flex-start; gap:.6rem; font-family:var(--mono); font-size:.82rem; letter-spacing:.01em; color:#e7eef5; line-height:1.35}
.spec svg{flex:none; inline-size:18px; block-size:18px; color:var(--accent); margin-top:1px}

/* ==========================================================================
   Section heading block
   ========================================================================== */
.sec-head{max-width:64ch}
.sec-head .tag{margin-bottom:1rem}
.sec-head h2{margin-bottom:.9rem}
.sec-head.center{margin-inline:auto; text-align:center}
.sec-head.center .tag{justify-content:center}

/* ==========================================================================
   Werte (values)
   ========================================================================== */
.werte{background:var(--white); border-block:1px solid var(--line)}
.werte__grid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,3vw,2.6rem); margin-top:clamp(2.4rem,5vw,3.4rem)}
.value{position:relative; padding-top:1.6rem; border-top:2px solid var(--mist-2)}
.value::before{content:""; position:absolute; top:-2px; left:0; inline-size:46px; block-size:2px; background:var(--brand)}
.value__no{font-family:var(--mono); font-size:.78rem; letter-spacing:.12em; color:var(--steel); margin-bottom:.7rem; display:block}
.value h3{margin-bottom:.55rem; color:var(--ink)}
.value p{color:var(--ink-soft); font-size:1.02rem}
.value strong{color:var(--brand); font-weight:600}

/* ==========================================================================
   Leistungen (services)
   ========================================================================== */
.leistungen{background:var(--mist)}
.leist__layout{display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(1.6rem,4vw,4rem); align-items:start; margin-top:clamp(2.2rem,4vw,3rem)}
.leist__media{position:sticky; top:120px; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-md)}
.leist__media img{aspect-ratio:4/5; object-fit:cover; inline-size:100%; transition:transform .9s var(--ease)}
.leist__media:hover img{transform:scale(1.04)}
.leist__mediacap{
  position:absolute; left:1rem; bottom:1rem; right:1rem;
  display:flex; align-items:center; gap:.7rem;
  background:rgba(13,28,42,.55); backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.18); border-radius:12px;
  padding:.7rem .9rem; color:#fff; font-family:var(--mono); font-size:.78rem; letter-spacing:.04em;
}
.leist__list{display:flex; flex-direction:column}
.leist-item{padding:1.6rem 0; border-bottom:1px solid var(--mist-2); display:grid; grid-template-columns:auto 1fr; gap:1.1rem 1.3rem; align-items:start}
.leist-item:first-child{padding-top:0}
.leist-item:last-child{border-bottom:none; padding-bottom:0}
.leist-item__ico{
  inline-size:54px; block-size:54px; border-radius:13px; flex:none;
  display:flex; align-items:center; justify-content:center;
  background:var(--white); border:1px solid var(--line); color:var(--brand);
  transition:background .3s var(--ease), color .3s var(--ease), transform .3s var(--ease);
}
.leist-item__ico svg{inline-size:26px; block-size:26px}
.leist-item:hover .leist-item__ico{background:var(--brand); color:#fff; transform:translateY(-2px)}
.leist-item__tag{font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--steel); display:block; margin-bottom:.3rem}
.leist-item h3{font-size:1.28rem; margin-bottom:.45rem; color:var(--ink)}
.leist-item p{font-size:1.0rem; color:var(--ink-soft)}

/* ==========================================================================
   Sortiment (catalogue)
   ========================================================================== */
.sortiment .sec-head{display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1.2rem; max-width:100%}
.sortiment .sec-head .left{max-width:60ch}
.tiles{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.5rem); margin-top:clamp(2.2rem,4vw,3rem)}
.tile{
  position:relative; display:block; border-radius:var(--radius); overflow:hidden;
  aspect-ratio:3/4; isolation:isolate; box-shadow:var(--shadow-sm);
  transition:box-shadow .4s var(--ease), transform .4s var(--ease);
}
.tile:hover{transform:translateY(-4px); box-shadow:var(--shadow-md)}
.tile img{position:absolute; inset:0; inline-size:100%; block-size:100%; object-fit:cover; z-index:-2; transition:transform .8s var(--ease)}
.tile:hover img{transform:scale(1.06)}
.tile::after{content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg,rgba(13,28,42,0) 38%,rgba(13,28,42,.82) 100%)}
.tile__body{position:absolute; inset:auto 0 0 0; padding:1.3rem 1.35rem; color:#fff; display:flex; flex-direction:column; gap:.3rem}
.tile__kicker{font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:#cfe0ee}
.tile__name{font-family:var(--display); font-weight:700; font-size:1.55rem; letter-spacing:-.02em; display:flex; align-items:center; justify-content:space-between; gap:.5rem}
.tile__name .ar{transition:transform .3s var(--ease)}
.tile:hover .tile__name .ar{transform:translate(4px,-4px)}
.tile__desc{font-size:.92rem; color:#dbe6f0; max-width:34ch}

/* category chips */
.chips{margin-top:clamp(1.6rem,3vw,2.2rem); display:flex; flex-wrap:wrap; gap:.6rem; align-items:center}
.chips__label{font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--steel); margin-right:.4rem}
.chip{
  display:inline-flex; align-items:center; gap:.45em;
  padding:.5em 1em; border-radius:999px; border:1px solid var(--line);
  background:var(--white); font-size:.92rem; font-weight:550; color:var(--ink-soft);
  transition:border-color .2s, color .2s, background .2s, transform .2s;
}
.chip:hover{border-color:var(--brand); color:var(--brand); transform:translateY(-1px)}
.chip--accent{border-color:color-mix(in srgb,var(--accent) 45%,transparent); color:#c0560a}
.chip--accent .pct{color:var(--accent); font-weight:700}

/* ==========================================================================
   CTA band
   ========================================================================== */
.ctaband{position:relative; isolation:isolate; color:#fff; overflow:hidden}
.ctaband__bg{position:absolute; inset:0; z-index:-2}
.ctaband__bg img{inline-size:100%; block-size:100%; object-fit:cover}
.ctaband__bg::after{content:""; position:absolute; inset:0; background:linear-gradient(95deg,rgba(20,38,55,.93) 0%,rgba(20,38,55,.74) 48%,rgba(20,38,55,.40) 100%)}
.ctaband__inner{padding-block:clamp(4rem,8vw,7rem); max-width:60ch}
.ctaband h2{color:#fff; font-size:clamp(2rem,1.5rem + 2.4vw,3.4rem)}
.ctaband p{color:#dce6ef; margin-top:1rem; font-size:clamp(1.05rem,1rem + .4vw,1.3rem)}
.ctaband__cta{margin-top:2rem; display:flex; flex-wrap:wrap; gap:.85rem; align-items:center}

/* ==========================================================================
   Kontakt + Footer
   ========================================================================== */
.kontakt{background:var(--ink); color:#cdd9e4}
.kontakt__grid{display:grid; grid-template-columns:1.15fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:start}
.kontakt .tag{color:#9db6cd}
.kontakt h2{color:#fff; margin:.9rem 0 1.1rem}
.kontakt__lead{color:#b8c8d6; max-width:46ch; margin-bottom:2rem}
.kontakt__cards{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
.kcard{background:rgba(255,255,255,.04); border:1px solid var(--line-dk); border-radius:var(--radius-sm); padding:1.2rem 1.3rem}
.kcard h4{color:#fff; font-size:.82rem; font-family:var(--mono); font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:#9db6cd; margin-bottom:.7rem}
.kcard a,.kcard p{color:#e6eef5; font-size:1.02rem; line-height:1.6}
.kcard a{display:inline-flex; align-items:center; gap:.5em; transition:color .2s}
.kcard a:hover{color:#fff}
.kcard .big{font-family:var(--display); font-weight:600; font-size:1.28rem; color:#fff; letter-spacing:-.01em}

.hours{display:flex; flex-direction:column; gap:.55rem; font-family:var(--mono); font-size:.92rem}
.hours__row{display:flex; align-items:baseline; justify-content:space-between; gap:1rem; color:#dbe6f0}
.hours__row span:first-child{color:#9db6cd}
.hours__note{color:#8aa3b8; font-size:.82rem; margin-top:.3rem}

.site-footer{background:#0f2030; color:#7f93a4; border-top:1px solid var(--line-dk)}
.site-footer .container{display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1rem; padding-block:1.6rem}
.site-footer__links{display:flex; gap:1.4rem; flex-wrap:wrap}
.site-footer a{color:#9db0c0; font-size:.92rem; transition:color .2s}
.site-footer a:hover{color:#fff}
.site-footer__legal{font-size:.84rem; font-family:var(--mono)}

/* ==========================================================================
   Reveal on scroll
   ========================================================================== */
.reveal{opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1; transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1024px){
  .leist__layout{grid-template-columns:1fr}
  .leist__media{position:relative; top:auto; max-width:520px}
  .leist__media img{aspect-ratio:16/10}
  .kontakt__grid{grid-template-columns:1fr}
}
@media (max-width:860px){
  html{scroll-padding-top:84px}
  .utilbar{display:none}
  .nav__links{display:none}
  .nav__actions .btn{display:none}
  .nav__toggle{display:flex}
  .specstrip{grid-template-columns:1fr 1fr}
  .werte__grid{grid-template-columns:1fr; gap:1.8rem}
  .tiles{grid-template-columns:1fr; gap:1.1rem}
  .tile{aspect-ratio:4/3}
  .kontakt__cards{grid-template-columns:1fr}
  .sortiment .sec-head{align-items:flex-start}
}
@media (max-width:480px){
  .specstrip{grid-template-columns:1fr}
  .hero__cta .btn{flex:1 1 auto; justify-content:center}
  .brand__mark{inline-size:34px; block-size:34px}
}

/* ----- Motion preferences ----- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important}
  .hero__bg img{transform:none}
  .reveal{opacity:1; transform:none}
}

/* ==========================================================================
   Sub-pages: simple header + legal prose
   ========================================================================== */
.subhead{position:sticky; top:0; z-index:60; background:color-mix(in srgb,var(--paper) 94%,transparent); backdrop-filter:blur(12px); border-bottom:1px solid var(--line)}
.subhead .nav{min-height:72px}
.subhead .back{display:inline-flex; align-items:center; gap:.55em; font-weight:600; color:var(--ink-soft); transition:color .2s}
.subhead .back:hover{color:var(--brand)}
.subhead .back svg{transition:transform .25s var(--ease)}
.subhead .back:hover svg{transform:translateX(-3px)}

.legal{padding-block:clamp(3rem,6vw,5.5rem)}
.legal .container{max-width:820px}
.legal .tag{margin-bottom:1rem}
.legal h1{font-size:clamp(2.2rem,1.7rem + 2vw,3.2rem); letter-spacing:-.03em; margin-bottom:1.4rem}
.legal h2{font-size:1.4rem; margin:2.4rem 0 .8rem; color:var(--ink)}
.legal p{margin-bottom:1rem; color:var(--ink-soft)}
.legal a{color:var(--brand); border-bottom:1px solid color-mix(in srgb,var(--brand) 25%,transparent)}
.legal a:hover{color:var(--brand-dk)}
.legal address{font-style:normal; font-family:var(--mono); font-size:.95rem; line-height:1.9; background:var(--mist); border:1px solid var(--line); border-radius:var(--radius-sm); padding:1.2rem 1.4rem; color:var(--ink)}
.legal .note{font-size:.9rem; background:#fff5ec; border:1px solid #ffd9b8; border-radius:var(--radius-sm); padding:1rem 1.2rem; color:#8a4b12}
.legal .note strong{color:#a8480a}

/* ==========================================================================
   ========================  PHP-APP ERWEITERUNGEN  =========================
   Unterseiten, Angebote, Modal, Verwaltung, Einrichtung
   ========================================================================== */

/* ----- Sub-page hero (Angebote) ----- */
.page-hero{background:var(--mist); border-bottom:1px solid var(--line); padding-block:clamp(2.6rem,6vw,4.2rem) clamp(2rem,4vw,3rem)}
.page-hero .tag{margin-bottom:1rem}
.page-hero__pct{color:var(--accent); font-weight:700}
.page-hero__title{font-size:clamp(2.2rem,1.7rem + 2.6vw,3.6rem); margin-bottom:.8rem}
.page-hero__lead{max-width:60ch; color:var(--ink-soft); font-size:clamp(1.05rem,1rem + .4vw,1.25rem)}

/* ----- Category hero ----- */
.cat-hero{position:relative; isolation:isolate; color:#fff; overflow:hidden}
.cat-hero__bg{position:absolute; inset:0; z-index:-2}
.cat-hero__bg img{width:100%; height:100%; object-fit:cover}
.cat-hero__bg::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(13,28,42,.5) 0%,rgba(13,28,42,.35) 40%,rgba(13,28,42,.85) 100%)}
.cat-hero .container{padding-block:clamp(3rem,7vw,5.5rem)}
.cat-hero .tag{margin-bottom:.9rem}
.cat-hero__title{color:#fff; font-size:clamp(2.4rem,1.9rem + 3vw,4.2rem); margin-bottom:1rem}
.cat-hero__lead{color:#e7eef5; max-width:60ch; font-size:clamp(1.05rem,1rem + .45vw,1.3rem)}
.breadcrumb{display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; font-family:var(--mono); font-size:.78rem; letter-spacing:.04em; color:#cfe0ee; margin-bottom:1.4rem}
.breadcrumb a{color:#cfe0ee; transition:color .2s; border-bottom:1px solid transparent}
.breadcrumb a:hover{color:#fff; border-color:var(--accent)}
.breadcrumb__current{color:#fff}

/* ----- Category body ----- */
.cat-subs{display:flex; flex-wrap:wrap; gap:.6rem; align-items:center; margin-bottom:clamp(2.4rem,5vw,3.4rem)}
.chip--static{cursor:default; background:var(--mist); border-color:var(--mist-2); color:var(--ink-soft)}
.chip--static:hover{transform:none; border-color:var(--mist-2); color:var(--ink-soft)}
.cat-offers-head{margin-top:1rem; margin-bottom:clamp(1.6rem,3vw,2.2rem)}
.cat-cta{margin-top:clamp(2.6rem,5vw,3.6rem); background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.6rem,3vw,2.4rem); display:flex; flex-wrap:wrap; gap:1.5rem; align-items:center; justify-content:space-between; box-shadow:var(--shadow-sm)}
.cat-cta h2{margin-bottom:.4rem}
.cat-cta p{color:var(--ink-soft); max-width:52ch}
.cat-cta__actions{display:flex; flex-wrap:wrap; gap:.75rem}

/* ----- Offer grid + cards ----- */
.offers .sec-head{margin-bottom:clamp(1.6rem,3vw,2.2rem)}
.offer-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.1rem,2.2vw,1.6rem)}
.offer-card{display:flex}
.offer-card__btn{display:flex; flex-direction:column; width:100%; text-align:left; background:var(--white); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease)}
.offer-card__btn:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--mist-2)}
.offer-card__media{position:relative; aspect-ratio:4/3; background:var(--mist); overflow:hidden}
.offer-card__media img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease)}
.offer-card__btn:hover .offer-card__media img{transform:scale(1.05)}
.offer-card__noimg{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:700; letter-spacing:-.02em; color:var(--steel); font-size:1.3rem}
.offer-card__noimg b{color:var(--brand)}
.offer-badge{position:absolute; top:.7rem; left:.7rem; background:var(--accent); color:#fff; font-family:var(--mono); font-size:.72rem; font-weight:600; letter-spacing:.04em; padding:.32em .7em; border-radius:999px; box-shadow:0 4px 12px -4px rgba(255,105,0,.6)}
.offer-card__count{position:absolute; bottom:.7rem; right:.7rem; background:rgba(13,28,42,.7); color:#fff; backdrop-filter:blur(4px); font-family:var(--mono); font-size:.7rem; letter-spacing:.04em; padding:.3em .65em; border-radius:999px}
.offer-card__body{display:flex; flex-direction:column; gap:.5rem; padding:1.1rem 1.2rem 1.2rem}
.offer-card__cat{font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--steel)}
.offer-card__title{font-family:var(--display); font-weight:700; font-size:1.2rem; letter-spacing:-.015em; color:var(--ink); line-height:1.15}
.offer-card__desc{font-size:.92rem; color:var(--ink-soft); line-height:1.5}
.offer-card__foot{margin-top:auto; padding-top:.6rem; display:flex; align-items:center; justify-content:space-between; gap:1rem}
.offer-card__more{display:inline-flex; align-items:center; gap:.4em; font-weight:600; font-size:.9rem; color:var(--brand); flex:none}
.offer-card__more .ar{transition:transform .25s var(--ease)}
.offer-card__btn:hover .offer-card__more .ar{transform:translateX(3px)}

.offer-price{display:flex; align-items:baseline; gap:.5rem; flex-wrap:wrap}
.offer-price__old{font-family:var(--mono); font-size:.85rem; color:var(--steel); text-decoration:line-through}
.offer-price__now{font-family:var(--display); font-weight:700; font-size:1.3rem; color:var(--ink); letter-spacing:-.01em}
.offer-price--ask{font-family:var(--mono); font-size:.82rem; letter-spacing:.04em; color:var(--brand); text-transform:uppercase}

.offers-hint{margin-top:clamp(1.6rem,3vw,2.2rem); font-size:.85rem; color:var(--steel); font-family:var(--mono); line-height:1.6; max-width:70ch}

.offers-empty{background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(2rem,5vw,3.2rem); text-align:center; box-shadow:var(--shadow-sm)}
.offers-empty .tag{justify-content:center; margin-bottom:1rem}
.offers-empty h2{margin-bottom:.7rem}
.offers-empty p{color:var(--ink-soft); max-width:48ch; margin:0 auto 1.5rem}
.offers-empty__cta{display:flex; flex-wrap:wrap; gap:.75rem; justify-content:center}

/* ----- Offer modal ----- */
.offer-modal{position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:clamp(1rem,3vw,2rem)}
.offer-modal[hidden]{display:none}
.offer-modal__scrim{position:absolute; inset:0; background:rgba(11,22,33,.62); backdrop-filter:blur(3px)}
.offer-modal__panel{position:relative; z-index:1; width:min(960px,100%); max-height:92vh; overflow:auto; background:var(--paper); border-radius:var(--radius); box-shadow:var(--shadow-md); animation:modalIn .3s var(--ease)}
@keyframes modalIn{from{opacity:0; transform:translateY(14px) scale(.99)}to{opacity:1; transform:none}}
.offer-modal__close{position:absolute; top:.7rem; right:.7rem; z-index:3; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.92); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-size:1.5rem; line-height:1; color:var(--ink); box-shadow:var(--shadow-sm); transition:background .2s, transform .2s}
.offer-modal__close:hover{background:#fff; transform:rotate(90deg)}
.offer-modal__grid{display:grid; grid-template-columns:1.05fr .95fr}
.offer-modal__media{background:var(--mist); padding:clamp(1rem,2.5vw,1.6rem)}
.offer-modal__info{padding:clamp(1.5rem,3.5vw,2.4rem); display:flex; flex-direction:column; gap:.9rem}
.offer-modal__info .tag{margin-bottom:.2rem}
.offer-modal__title{font-size:clamp(1.5rem,1.2rem + 1.4vw,2.1rem); color:var(--ink); letter-spacing:-.02em}
.offer-modal__price{display:flex; align-items:baseline; gap:.7rem; flex-wrap:wrap}
.offer-modal__price .offer-price__now{font-size:1.7rem}
.offer-modal__desc{color:var(--ink-soft); line-height:1.65}
.offer-modal__cta{margin-top:.6rem; display:flex; flex-wrap:wrap; gap:.7rem}

.offer-gallery{display:flex; flex-direction:column; gap:.7rem}
.offer-gallery__main{position:relative; aspect-ratio:4/3; border-radius:var(--radius-sm); overflow:hidden; background:var(--white); border:1px solid var(--line)}
.offer-gallery__main img{width:100%; height:100%; object-fit:cover}
.offer-gallery__thumbs{display:flex; flex-wrap:wrap; gap:.5rem}
.offer-gallery__thumb{width:64px; height:64px; border-radius:9px; overflow:hidden; border:2px solid transparent; background:var(--white); padding:0; transition:border-color .2s}
.offer-gallery__thumb img{width:100%; height:100%; object-fit:cover}
.offer-gallery__thumb.is-active{border-color:var(--brand)}
.offer-gallery__noimg{aspect-ratio:4/3; display:flex; align-items:center; justify-content:center; border-radius:var(--radius-sm); background:var(--white); border:1px solid var(--line); font-family:var(--display); font-weight:700; color:var(--steel); font-size:1.4rem}
.offer-gallery__noimg b{color:var(--brand)}
body.modal-open{overflow:hidden}

/* ----- Auth / setup card (install + login) ----- */
.setup{min-height:100vh; margin:0; background:linear-gradient(160deg,var(--ink) 0%,#0f2030 100%); display:flex; align-items:center; justify-content:center; padding:2rem 1.2rem; color:var(--ink-soft)}
.setup__wrap{width:100%; max-width:560px}
.authcard{background:var(--paper); border-radius:var(--radius); box-shadow:var(--shadow-md); padding:clamp(1.6rem,4vw,2.6rem)}
.authcard__brand{display:flex; align-items:center; gap:.7rem; margin-bottom:1.4rem}
.authcard__brand .brand__word{font-size:1.4rem}
.authcard__title{font-size:clamp(1.5rem,1.2rem + 1.2vw,2rem); color:var(--ink); margin-bottom:.5rem}
.authcard__lead{color:var(--ink-soft); margin-bottom:1.4rem}
.authcard__back{display:inline-block; margin-top:1.2rem; font-weight:600; color:var(--brand); font-size:.92rem}
.authcard__back:hover{color:var(--brand-dk)}
.setup__foot{text-align:center; color:#7f93a4; font-family:var(--mono); font-size:.78rem; margin-top:1.2rem}
.setup__note{border-radius:var(--radius-sm); padding:1rem 1.2rem; margin-bottom:1.3rem; font-size:.92rem; line-height:1.55}
.setup__note ul{margin:.5rem 0 0; padding-left:1.1rem; list-style:disc}
.setup__note--error{background:#fdecec; border:1px solid #f5c2c2; color:#92302f}
.setup__note--warn{background:#fff5ec; border:1px solid #ffd9b8; color:#8a4b12}
.setup__note code,.authcard code{background:rgba(21,41,58,.08); padding:.1em .4em; border-radius:4px; font-family:var(--mono); font-size:.88em}

/* ----- Forms (shared: setup + admin) ----- */
.form__legend{font-family:var(--mono); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--steel); margin:1.4rem 0 .8rem; padding-bottom:.4rem; border-bottom:1px solid var(--line)}
.form__legend:first-of-type{margin-top:0}
.field{margin-bottom:1rem; display:flex; flex-direction:column}
.field > label{font-weight:600; font-size:.92rem; color:var(--ink); margin-bottom:.4rem}
.field__hint{font-weight:400; color:var(--steel); font-size:.84em}
.field input[type=text],.field input[type=password],.field input[type=number],.field input[type=file],.field select,.field textarea{
  font:inherit; color:var(--ink); background:var(--white); border:1.5px solid var(--line); border-radius:var(--radius-sm); padding:.7em .9em; width:100%; transition:border-color .2s, box-shadow .2s;
}
.field input[type=file]{padding:.55em .7em}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 3px rgba(45,92,136,.15)}
.field textarea{resize:vertical; min-height:120px; line-height:1.5}
.field .req{color:var(--accent)}
.form__row{display:flex; gap:1rem; flex-wrap:wrap}
.form__row .field{flex:1 1 180px; margin-bottom:1rem}
.field--grow{flex:1 1 200px}
.field--port{flex:0 0 110px}
.field--sort{flex:0 0 130px}
.check{flex-direction:row; align-items:center; gap:.6rem; font-weight:500; color:var(--ink-soft); cursor:pointer}
.check input{width:18px; height:18px; accent-color:var(--brand)}
.form__actions{display:flex; gap:.8rem; flex-wrap:wrap; margin-top:1.4rem; padding-top:1.2rem; border-top:1px solid var(--line)}
.btn--block{width:100%; justify-content:center; margin-top:.6rem}

.imggrid{display:flex; flex-wrap:wrap; gap:.8rem}
.imgthumb{width:120px; border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden; background:var(--white); display:flex; flex-direction:column}
.imgthumb img{width:100%; height:90px; object-fit:cover; display:block}
.imgthumb__keep{display:flex; align-items:center; gap:.4rem; font-size:.78rem; color:var(--ink-soft); padding:.45rem .55rem}
.imgthumb__keep input{accent-color:var(--brand)}
.imgpreview{display:flex; flex-wrap:wrap; gap:.6rem; margin-top:.7rem}
.imgpreview img{width:90px; height:70px; object-fit:cover; border-radius:8px; border:1px solid var(--line)}

/* ----- Admin chrome ----- */
.admin{background:var(--mist); min-height:100vh}
.adminbar{position:sticky; top:0; z-index:60; background:var(--ink); color:#e6eef5}
.adminbar__inner{max-width:1100px; margin-inline:auto; padding:.8rem var(--gutter); display:flex; align-items:center; justify-content:space-between; gap:1rem}
.adminbar__brand{display:flex; align-items:center; gap:.6rem; color:#fff}
.adminbar__word{font-family:var(--display); font-weight:700; font-size:1.1rem}
.adminbar__word b{color:#7fb0db}
.adminbar__word .dot{color:var(--accent)}
.adminbar__word em{font-style:normal; font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:#9db6cd; margin-left:.3rem}
.adminbar__actions{display:flex; align-items:center; gap:1rem}
.adminbar__link{color:#cfe0ee; font-size:.9rem; transition:color .2s}
.adminbar__link:hover{color:#fff}
.adminbar__user{font-family:var(--mono); font-size:.82rem; color:#9db6cd; padding-left:1rem; border-left:1px solid var(--line-dk)}
.btn--sm{padding:.5em .9em; font-size:.85rem}
.adminbar .btn--ghost{--bg:transparent; --fg:#fff; --bd:var(--line-dk)}
.adminbar .btn--ghost:hover{background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.4); color:#fff}

.adminmain{padding:clamp(1.6rem,4vw,2.8rem) 0}
.adminwrap{max-width:1100px; margin-inline:auto; padding-inline:var(--gutter)}
.adminhead{display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:1.6rem}
.adminhead .tag{margin-bottom:.6rem}
.adminhead__lead{color:var(--ink-soft); margin-top:.4rem; max-width:60ch}

.flash{border-radius:var(--radius-sm); padding:.9rem 1.1rem; margin-bottom:1.2rem; font-size:.94rem}
.flash--success{background:#e8f6ee; border:1px solid #b6e2c8; color:#1f6b40}
.flash--error{background:#fdecec; border:1px solid #f5c2c2; color:#92302f}
.flash ul{margin:.5rem 0 0; padding-left:1.1rem; list-style:disc}

.emptybox{background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.6rem,4vw,2.6rem); text-align:center; box-shadow:var(--shadow-sm)}
.emptybox h2{margin-bottom:.6rem}
.emptybox p{color:var(--ink-soft); max-width:52ch; margin:0 auto 1.4rem}
.emptybox__actions{display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center; align-items:center}
.emptybox__actions form{margin:0}

.tablewrap{background:var(--white); border:1px solid var(--line); border-radius:var(--radius); overflow:auto; box-shadow:var(--shadow-sm)}
.atable{width:100%; border-collapse:collapse; font-size:.94rem}
.atable th{text-align:left; font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--steel); background:var(--mist); padding:.8rem 1rem; border-bottom:1px solid var(--line); white-space:nowrap}
.atable td{padding:.75rem 1rem; border-bottom:1px solid var(--line); vertical-align:middle; color:var(--ink-soft)}
.atable tr:last-child td{border-bottom:none}
.atable__thumb{width:74px}
.atable__thumb img{width:58px; height:44px; object-fit:cover; border-radius:7px; border:1px solid var(--line)}
.atable__noimg{display:inline-flex; width:58px; height:44px; align-items:center; justify-content:center; border-radius:7px; background:var(--mist); color:var(--steel)}
.atable__title{font-weight:600; color:var(--ink); border-bottom:1px solid transparent}
.atable__title:hover{color:var(--brand); border-color:var(--brand)}
.atable__price{font-family:var(--mono); white-space:nowrap}
.atable__actions{white-space:nowrap; text-align:right}
.atable__actions .btn{margin-left:.4rem}
.inline-form{display:inline}
.pill{display:inline-block; margin-left:.5rem; background:var(--mist-2); color:var(--brand-dk); font-family:var(--mono); font-size:.68rem; letter-spacing:.04em; padding:.2em .55em; border-radius:999px; vertical-align:middle}
.muted{color:var(--steel)}
.dot-state{display:inline-flex; align-items:center; gap:.4em; font-size:.86rem}
.dot-state::before{content:""; width:8px; height:8px; border-radius:50%}
.dot-state--on{color:#1f6b40}
.dot-state--on::before{background:#27ae60}
.dot-state--off{color:var(--steel)}
.dot-state--off::before{background:var(--steel)}
.btn--danger{--bg:transparent; --fg:#b3261e; --bd:#e6b4b1}
.btn--danger:hover{--bg:#b3261e; background:#b3261e; color:#fff; border-color:#b3261e; transform:translateY(-1px)}
.card-form{background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,3.5vw,2.2rem); box-shadow:var(--shadow-sm)}

/* ----- Responsive (app) ----- */
@media (max-width:860px){
  .offer-grid{grid-template-columns:1fr 1fr}
  .offer-modal__grid{grid-template-columns:1fr}
  .cat-cta{flex-direction:column; align-items:flex-start}
}
@media (max-width:560px){
  .offer-grid{grid-template-columns:1fr}
}
