/* =====================================================
   TropiaV Roleplay – Regelwerk Styles (Neustedt Look)
   Clean / modern / behördlich
   ===================================================== */

:root{
  /* Farben */
  --bg: #08171e;
  --bg-elev: #0d1f27;
  --text: #e8f1f6;
  --text-dim: #b9c9d3;

  --brand: #f6c84c;
  --brand-2: #f0b428;
  --accent: #2f88ad;

  --muted: #12232b;

  /* Layout */
  --radius: 16px;
  --radius-sm: 12px;
  --shadow-1: 0 10px 26px rgba(0,0,0,.32);
  --shadow-2: 0 18px 46px rgba(0,0,0,.45);
  --container: 1200px;
  --h-header: 72px;

  /* Borders / Glass */
  --stroke: rgba(255,255,255,.08);
  --stroke-2: rgba(255,255,255,.12);
  --glass: rgba(8,23,30,.68);

  /* Motion */
  --ease: cubic-bezier(.2,.8,.2,1);

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

  /* Typo */
  --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.35rem, 2.2vw, 1.85rem);
  --fs-2xl: clamp(1.75rem, 3vw, 2.35rem);
  --fs-3xl: clamp(2.15rem, 4vw, 2.95rem);
}

/* =========================
   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 82% -10%, rgba(47,136,173,.10), transparent 55%),
    radial-gradient(900px 600px at 12% 110%, rgba(246,200,76,.07), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 30%),
    var(--bg);
  color: var(--text);
  line-height: 1.65;
  overflow-x: hidden;
  padding-top: var(--h-header);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* nicer text rendering */
::selection{ background: rgba(246,200,76,.22); color: var(--text); }

/* =========================
   Grundlayout
   ========================= */
.container{
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(16px, 3vw, 32px);
}

/* =========================
   Typografie
   ========================= */
h1,h2,h3,h4,h5{
  line-height:1.15;
  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(--text); }
h3{ font-size: var(--fs-xl); color: var(--text); }
h4{ font-size: var(--fs-lg); color: var(--text); }

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

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

/* =========================
   Links & Fokus
   ========================= */
a{
  color: var(--brand);
  text-decoration: none;
  transition: color .2s var(--ease), opacity .2s var(--ease);
}
a:hover{ color: var(--accent); opacity: .98; }

:focus-visible{
  outline: 2px solid rgba(47,136,173,.75);
  outline-offset: 3px;
  border-radius: 10px;
}

/* =========================
   Header / Navigation
   ========================= */
.header{
  position: fixed; inset:0 0 auto 0;
  height: var(--h-header);
  display:flex; align-items:center;
  z-index:100;

  background: var(--glass);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  border-bottom: 1px solid rgba(255,255,255,.06);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:100%;
  gap: 18px;
}

.logo{
  display:flex; align-items:baseline; gap:.55rem;
  font-size:1.15rem;
  font-weight: 900;
  letter-spacing:.75px;
  text-transform: uppercase;
  color: var(--brand);
}
.logo span{
  color: var(--text);
  font-weight: 800;
  letter-spacing:.35px;
  opacity: .95;
}

.nav ul{
  list-style:none;
  display:flex;
  gap: clamp(10px, 1.6vw, 18px);
  align-items:center;
}

.nav a{
  display:inline-flex;
  align-items:center;
  gap:.5rem;

  padding: 10px 14px;
  border-radius: 12px;

  font-weight: 800;
  color: rgba(185,201,211,.92);

  background: rgba(255,255,255,0);
  border: 1px solid rgba(255,255,255,0);
  transition: transform .18s var(--ease), background .22s var(--ease), border-color .22s var(--ease), color .22s var(--ease);
}

.nav a:hover{
  transform: translateY(-1px);
  color: var(--text);
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
}

/* =========================
   Hero
   ========================= */
.hero{
  min-height: calc(100vh - var(--h-header));
  background:
    radial-gradient(720px 420px at 75% 10%, rgba(47,136,173,.18), transparent 55%),
    radial-gradient(920px 540px at 10% 110%, rgba(246,200,76,.12), transparent 60%),
    var(--bg);
  display:grid;
  place-items:center;
  text-align:center;
}

.hero-content{
  padding-block: clamp(28px, 5vw, 58px);
}

.hero-content h1{
  color: var(--brand);
  margin-bottom: .45rem;
  text-shadow: 0 10px 34px rgba(0,0,0,.35);
}

.hero-content p{
  max-width: 70ch;
  margin-inline:auto;
  color: rgba(185,201,211,.95);
}

.hero-cta{
  margin-top: var(--gap-3);
  display:flex;
  gap: var(--gap-2);
  flex-wrap:wrap;
  justify-content:center;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding: 12px 18px;
  border-radius: 14px;

  background: var(--brand);
  color: #0f1c21;

  font-weight: 900;
  font-size: var(--fs-sm);

  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow-1);

  transition: transform .18s var(--ease), box-shadow .22s var(--ease), background .22s var(--ease);
}
.btn:hover{
  background: var(--brand-2);
  transform: translateY(-1px);
  box-shadow: var(--shadow-2);
}
.btn--ghost{
  background: transparent;
  border: 1px solid rgba(246,200,76,.35);
  color: var(--brand);
  box-shadow: none;
}
.btn--ghost:hover{
  background: rgba(246,200,76,.12);
  border-color: rgba(246,200,76,.55);
  transform: translateY(-1px);
}

/* =========================
   Sektionen
   ========================= */
.section{
  padding: clamp(44px, 7vw, 92px) 0;
  background: transparent;
}

/* Section-Container: cleaner, weniger “boxig”, trotzdem Card-Look */
.section .container{
  display:flex;
  flex-direction:column;
  align-items:center;

  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius);

  box-shadow: var(--shadow-1);
  padding: clamp(18px, 2.8vw, 38px);
}

/* Header innerhalb Section */
.section header{
  margin-bottom: var(--gap-3);
  text-align:center;
}

/* Überschriften: dezenter Akzent statt knalliges blau */
.section h2{
  position: relative;
  padding-bottom: .7rem;
}
.section h2::after{
  content:"";
  display:block;
  width: 86px;
  height: 2px;
  border-radius: 999px;
  margin: .75rem auto 0;
  background: linear-gradient(90deg, transparent, rgba(246,200,76,.75), transparent);
}

/* =========================
   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: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0)) , var(--bg-elev);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius);
  padding: clamp(16px, 2.4vw, 22px);
  box-shadow: var(--shadow-1);
  transition: transform .18s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
  text-align:center;
}

.card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
  border-color: rgba(47,136,173,.45);
}

.card h3{ color: var(--brand); }
.card p{ color: rgba(185,201,211,.95); }

/* =========================
   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: 14px;
  cursor: zoom-in;
  border: 1px solid rgba(255,255,255,.06);

  box-shadow: var(--shadow-1);
  transition: transform .18s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
}

.gallery img:hover{
  transform: scale(1.015);
  box-shadow: var(--shadow-2);
  border-color: rgba(47,136,173,.45);
}

/* =========================
   Footer
   ========================= */
.footer{
  background: #071a21;
  border-top: 1px solid rgba(47,136,173,.35);
  margin-top: var(--gap-6);
}

.footer .container{
  padding: 26px 0;
  color: rgba(185,201,211,.9);
  text-align:center;
  font-size: var(--fs-sm);
}

/* =========================
   Utilities
   ========================= */
.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); }

/* =========================
   Reduced Motion
   ========================= */
@media (prefers-reduced-motion: reduce){
  .btn, .card, .gallery img, .nav a{ transition:none; }
}
