/* =====================================================
   TropiaV Roleplay – Regelwerk Styles (Neustedt Look)
   Farbwelt: maritimes Blau & Sandgelb, clean & modern
   ===================================================== */
:root{
  /* === Farben (angepasst an Neustedt / Index) === */
  --bg: #08171e;               /* dunkles Meeresblau */
  --bg-elev: #0d1f27;          /* leicht heller für Cards */
  --text: #e8f1f6;             /* helles Weißblau */
  --text-dim: #b9c9d3;         /* sekundärer Text */
  --brand: #f6c84c;            /* helles Sandgelb */
  --brand-2: #f0b428;          /* satteres Gelb für Highlights */
  --accent: #2f88ad;           /* helles Meerblau */
  --muted: #12232b;            /* dunkler Hintergrundton */

  /* === Layout & Effekte === */
  --radius: 14px;
  --shadow-1: 0 6px 18px rgba(0,0,0,.35);
  --shadow-2: 0 14px 36px rgba(0,0,0,.45);
  --container: 1200px;
  --h-header: 72px;

  /* === Spacing === */
  --gap-1: .5rem;
  --gap-2: 1rem;
  --gap-3: 1.5rem;
  --gap-4: 2rem;
  --gap-6: 3rem;

  /* === Typo-Scale === */
  --fs-xs: clamp(.85rem, .8vw, .95rem);
  --fs-sm: clamp(.95rem, .9vw, 1rem);
  --fs-md: clamp(1rem, 1vw, 1.05rem);
  --fs-lg: clamp(1.15rem, 1.4vw, 1.25rem);
  --fs-xl: clamp(1.4rem, 2.2vw, 1.9rem);
  --fs-2xl: clamp(1.8rem, 3vw, 2.4rem);
  --fs-3xl: clamp(2.2rem, 4vw, 3rem);

  /* === Line Clamp === */
  --clamp-desktop: 3;
  --clamp-tablet: 4;
  --clamp-mobile: 6;
}

/* =========================
   Reset & Base
   ========================= */
*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }
img,svg,video{ display:block; max-width:100%; }

body{
  font-family: 'Akrobat', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(900px 600px at 80% -10%, rgba(47,136,173,.08), transparent 55%),
              radial-gradient(900px 600px at 10% 110%, rgba(246,200,76,.06), transparent 55%),
              var(--bg);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
  padding-top: var(--h-header);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* =========================
   Grundlayout
   ========================= */
.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(16px, 3vw, 32px);
}
.prose, :where(.hero-content, .section .container, .footer .container){
  margin-inline: auto;
  max-width: 68ch;
}

/* =========================
   Typografie
   ========================= */
h1,h2,h3,h4,h5{ line-height:1.2; letter-spacing:.2px; overflow-wrap:anywhere; hyphens:auto; text-wrap:balance; }
h1{ font-size: var(--fs-3xl); color: var(--brand); }
h2{ font-size: var(--fs-2xl); color: var(--accent); }
h3{ font-size: var(--fs-xl); color: var(--text); }
h4{ font-size: var(--fs-lg); }

p{ color: var(--text-dim); font-size: var(--fs-md); }
small, .text-xs{ font-size: var(--fs-xs); color: var(--text-dim); }

/* =========================
   Vertikale Rhythmik
   ========================= */
:where(.hero-content, .section .container, .footer .container)
  > :where(h1,h2,h3,h4,p,ul,ol,blockquote){
  margin-bottom: 1rem;
}

/* =========================
   Links & Fokus
   ========================= */
a{ color: var(--brand); text-decoration:none; transition:.25s color ease; }
a:hover{ color: var(--accent); }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:8px; }

/* =========================
   Header / Navigation
   ========================= */
.header{
  position: fixed; inset:0 0 auto 0; height: var(--h-header);
  display:flex; align-items:center; z-index:100;
  background: rgba(8,23,30,.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.05);
  box-shadow: var(--shadow-1);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; height:100%; }
.logo{
  font-size:1.25rem; font-weight:900; color: var(--brand);
  letter-spacing:.6px; text-transform:uppercase;
}
.logo span{ color: var(--text); }

.nav ul{ list-style:none; display:flex; gap:clamp(14px, 2vw, 24px); align-items:center; }
.nav a{
  display:inline-block; padding:10px 14px; border-radius:10px; font-weight:700;
  color:var(--text-dim); transition:transform .15s ease, color .25s ease;
}
.nav a:hover{ transform:translateY(-1px); color:var(--brand); }

/* =========================
   Hero
   ========================= */
.hero{
  min-height: calc(100vh - var(--h-header));
  background: radial-gradient(700px 400px at 75% 10%, rgba(47,136,173,.18), transparent 55%),
              radial-gradient(900px 520px at 10% 110%, rgba(246,200,76,.12), transparent 60%),
              var(--bg);
  display:grid; place-items:center; text-align:center;
}
.hero-content h1{ color: var(--brand); margin-bottom:.4rem; }
.hero-content p{ color: var(--text-dim); margin-top:.5rem; }
.hero-cta{ margin-top:var(--gap-3); display:flex; gap:var(--gap-2); flex-wrap:wrap; justify-content:center; }

.btn{
  display:inline-block; padding:12px 20px; border-radius:12px;
  background: var(--brand); color:#0f1c21; font-weight:800; font-size: var(--fs-sm);
  transition: all .25s var(--ease); box-shadow: var(--shadow-1);
}
.btn:hover{ background: var(--accent); transform:translateY(-1px); }
.btn--ghost{
  background: transparent; border:1px solid var(--brand); color: var(--brand);
}
.btn--ghost:hover{
  background: var(--brand); color:#0f1c21;
}

/* =========================
   Sektionen
   ========================= */
.section{ padding: clamp(48px, 7vw, 100px) 0; background: transparent; }
.section .container{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0));
  border: 1px solid rgba(255,255,255,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: clamp(20px, 3vw, 40px);
}
.section header{ margin-bottom: var(--gap-3); text-align:center; }

/* =========================
   Cards & Grids
   ========================= */
.grid-2{ display:grid; gap:var(--gap-3); grid-template-columns:repeat(2,1fr); }
.grid-3{ display:grid; gap:var(--gap-3); grid-template-columns:repeat(3,1fr); }
.grid-4{ display:grid; gap:var(--gap-3); grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .grid-3{grid-template-columns:repeat(2,1fr);} }
@media (max-width:650px){ .grid-2, .grid-3, .grid-4{grid-template-columns:1fr;} }

.card{
  background: var(--bg-elev);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  padding:clamp(16px,2.5vw,24px);
  box-shadow:var(--shadow-1);
  transition:transform .2s ease, box-shadow .25s ease, border-color .25s ease;
  text-align:center;
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-2);
  border-color: var(--accent);
}
.card h3{ color: var(--brand); }
.card p{ color: var(--text-dim); }

/* =========================
   Galerie
   ========================= */
.gallery{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:var(--gap-3); }
.gallery img{
  width:100%; aspect-ratio:1/1; object-fit:cover;
  border-radius:12px; cursor:zoom-in;
  box-shadow:var(--shadow-1);
  transition:transform .25s ease, box-shadow .25s ease;
}
.gallery img:hover{
  transform:scale(1.02);
  box-shadow:var(--shadow-2);
  border-color: var(--accent);
}

/* =========================
   Footer
   ========================= */
.footer{
  background:#0a1f28;
  border-top:2px solid var(--accent);
  margin-top:var(--gap-6);
}
.footer .container{
  padding:28px 0;
  color:var(--text-dim);
  text-align:center;
  font-size:var(--fs-sm);
}

/* =========================
   Utils
   ========================= */
.center{ display:flex; align-items:center; justify-content:center; }
.stack{ display:flex; flex-direction:column; gap:var(--gap-2); align-items:center; }
.max-w{ max-width:68ch; margin-inline:auto; }
.mt-2{ margin-top:var(--gap-2); }
.mt-4{ margin-top:var(--gap-4); }
.mb-4{ margin-bottom:var(--gap-4); }

/* =========================
   Animationen
   ========================= */
@keyframes gradient{
  0%{ background-position:0% 50%; }
  50%{ background-position:100% 50%; }
  100%{ background-position:0% 50%; }
}
@media (prefers-reduced-motion: reduce){
  .btn, .card, .gallery img, .nav a{ transition:none; }
}
