/* UserPages style.css
   Projekt: Pistenrettung Steiermark
   Stand: 2026-02-04
*/

:root{
  --bg:#f5f7fb;
  --card:#ffffff;
  --text:#17212b;
  --muted:#5b6773;
  --accent:#0b5cff;
  --border:rgba(0,0,0,.08);
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius:14px;
}

*{box-sizing:border-box}

html,body{height:100%}

body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  margin:0;
  color:var(--text);
  line-height:1.65;
}

/* Layout helpers */
.wrap{max-width:980px;margin:0 auto;padding:1rem 1.25rem;}
.muted{color:var(--muted)}
.center{text-align:center}
.mt-0{margin-top:0}
.mt-1{margin-top:.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}

/* Header */
header{
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--border);
  position:sticky;
  top:0;
  z-index:10;
}

.topbar{
  display:flex;
  gap:.75rem;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}

.brand{display:flex;flex-direction:column;gap:.15rem}
.brand h1{font-size:1.05rem;margin:0;font-weight:700}
.brand small{color:var(--muted)}

.actions{display:flex;gap:.5rem;flex-wrap:wrap}

/* Buttons */
a.button,button{
  appearance:none;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  padding:.55rem .8rem;
  border-radius:.75rem;
  text-decoration:none;
  cursor:pointer;
  font-size:.95rem;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
  transition:transform .12s ease, box-shadow .12s ease, background-color .12s ease, border-color .12s ease;
}

a.button:hover,button:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(0,0,0,.08);
}

a.button:active,button:active{transform:translateY(0)}

a.button.primary{
  border-color:rgba(11,92,255,.25);
  color:var(--accent);
}

/* Hero */
.hero{
  background:linear-gradient(135deg, rgba(11,92,255,.08), rgba(255,255,255,.7));
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.25rem 1.25rem;
  box-shadow:var(--shadow);
}

.hero h2{margin:.1rem 0 .5rem;font-size:1.35rem}
.hero p{margin:.25rem 0;color:var(--muted);max-width:720px}

/* Chips / badges */
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}
.chip{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.35rem .55rem;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.8);
  font-size:.9rem;
  color:var(--text);
}
.dot{width:.5rem;height:.5rem;border-radius:999px;background:var(--accent);display:inline-block}
.badge{
  display:inline-block;
  padding:.2rem .5rem;
  border-radius:999px;
  background:rgba(11,92,255,.08);
  border:1px solid rgba(11,92,255,.18);
  color:var(--accent);
  font-weight:600;
  font-size:.85rem;
  white-space:nowrap;
}

/* Cards & Sections */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.15rem 1.25rem;
  margin-top:1rem;
}

.section{margin-top:1.25rem}
.section h3{
  margin:0 0 .5rem;
  font-size:1.1rem;
  display:flex;
  align-items:center;
  gap:.5rem;
}
.section h3:before{
  content:"";
  width:10px;height:10px;
  border-radius:3px;
  background:var(--accent);
}

.meta{
  color:var(--muted);
  font-size:.92rem;
  margin:-.1rem 0 .8rem;
}

p{margin:.5rem 0}
ul{margin:.4rem 0 0;padding-left:1.1rem}
li{margin:.35rem 0}

/* Note / callout */
.note{
  margin-top:.7rem;
  padding:.75rem .85rem;
  border-radius:12px;
  border:1px dashed rgba(11,92,255,.25);
  background:rgba(11,92,255,.05);
  color:var(--text);
}

/* Figure / images */
.grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin-top:1rem;
}
@media(max-width:800px){
  .grid{grid-template-columns:1fr}
}

figure {
    margin: 0;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: #fff;
    justify-self: center;
}
    figure img {
        width: auto;
        height: auto;
        display: block
    }

figcaption{
  padding:.5rem .75rem;
  font-size:.9rem;
  color:var(--muted);
  background:#fafbff;
  border-top:1px solid var(--border);
}

/* TOC / Navigation (optional) */
.layout{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:1rem;
  align-items:start;
}

nav.toc{
  position:sticky;
  top:88px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:.9rem;
  box-shadow:var(--shadow);
}
@media(max-width:900px) {
    .layout {
        grid-template-columns: 1fr;
    }

    nav.toc {
        position: static;
        top: auto;
    }
}
nav.toc h3{margin:0 0 .5rem;font-size:1rem}
nav.toc a{
  display:block;
  padding:.45rem .55rem;
  border-radius:.6rem;
  text-decoration:none;
  color:var(--text);
  border:1px solid transparent;
}
nav.toc a:hover{
  background:rgba(11,92,255,.06);
  border-color:rgba(11,92,255,.12);
}
nav.toc small{color:var(--muted);display:block;margin-top:.5rem}

.sponsor-ticker {
    border: 1px solid var(--border);
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    padding: .75rem 0;
}

    .sponsor-ticker .track {
        display: flex;
        align-items: center;
        gap: 2rem;
        width: max-content;
        animation: sponsor-scroll 20s linear infinite;
        will-change: transform;
    }

    /* Logo-Größe */
    .sponsor-ticker img {
        height: 48px;
        width: auto;
        display: block;
        opacity: .9;
    }

    /* Optional: Pause bei Hover */
    .sponsor-ticker:hover .track {
        animation-play-state: paused;
    }

/* Endlos-Scroll: wir schieben um "die Hälfte", weil wir dupliziert haben */
@keyframes sponsor-scroll {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

/* Respektiert Systemeinstellung "weniger Bewegung" */
@media (prefers-reduced-motion: reduce) {
    .sponsor-ticker .track {
        animation: none;
    }
}


@keyframes scroll-left {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
    /* weil wir dupliziert haben */
}

/* Footer */
footer{
  color:var(--muted);
  font-size:.9rem;
  padding:1.2rem 0 2.5rem;
  text-align:center;
}

/* Print */
@media print{
  header, nav.toc, .actions, footer{display:none !important}
  body{background:#fff}
  .hero,.card{box-shadow:none;border-color:transparent}
  .wrap{max-width:none}
  .layout{grid-template-columns:1fr}
}
