@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --ink: #05030a;
  --ink-soft: #0b0711;
  --panel: rgba(12, 7, 18, .82);
  --ivory: #f2eadc;
  --muted: #aaa0ad;
  --gold: #d3ae68;
  --gold-light: #f0d69c;
  --violet: #8a39c9;
  --violet-bright: #bb72ef;
  --line: rgba(222, 188, 119, .2);
  --line-soft: rgba(255,255,255,.09);
  --serif: 'Cinzel', Georgia, serif;
  --sans: 'Inter', 'Segoe UI', sans-serif;
  --shell: min(1180px, calc(100vw - 48px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ivory); background: var(--ink); font-family: var(--sans); font-weight: 300; line-height: 1.7; overflow-x: hidden; }
body::before { content: ''; position: fixed; inset: 0; z-index: -3; background: radial-gradient(circle at 20% 20%, rgba(80, 24, 112, .12), transparent 28%), radial-gradient(circle at 80% 70%, rgba(35, 48, 106, .1), transparent 32%), #05030a; }
a { color: inherit; }
img { max-width: 100%; }
button, input, textarea, select { font: inherit; }
::selection { background: rgba(187,114,239,.35); color: #fff; }

.topbar { position: fixed; inset: 0 0 auto; z-index: 100; height: 80px; display: flex; align-items: center; justify-content: space-between; gap: 32px; padding: 0 max(24px, 4vw); background: linear-gradient(180deg, rgba(3,2,7,.96), rgba(3,2,7,.72)); border-bottom: 1px solid rgba(255,255,255,.06); backdrop-filter: blur(18px); }
.brand { display: flex; align-items: center; gap: 13px; color: var(--gold-light); text-decoration: none; }
.brand__sigil { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 50%; color: var(--violet-bright); font-size: 20px; box-shadow: inset 0 0 16px rgba(140,57,201,.18), 0 0 22px rgba(140,57,201,.12); }
.brand__word { font: 500 16px/1 var(--serif); letter-spacing: .2em; text-transform: uppercase; }
.brand__word small { display: block; margin-top: 7px; color: #8f8492; font: 400 8px/1 var(--sans); letter-spacing: .23em; }
.nav { display: flex; align-items: center; gap: 5px; }
.nav > a, .nav-group__trigger { border: 0; background: none; color: #c9c0c9; padding: 11px 14px; text-decoration: none; text-transform: uppercase; letter-spacing: .12em; font-size: 11px; cursor: pointer; transition: color .2s ease, background .2s ease; }
.nav > a:hover, .nav-group__trigger:hover, .nav > a:focus-visible, .nav-group__trigger:focus-visible { color: var(--gold-light); background: rgba(255,255,255,.035); outline: none; }
.nav-search { margin-left: 5px; font-size: 21px !important; line-height: 1; }
.nav-account { border: 1px solid var(--line) !important; border-radius: 999px; }
.nav-group { position: relative; }
.nav-group__trigger span { color: var(--gold); margin-left: 4px; }
.nav-dropdown { position: absolute; top: calc(100% + 14px); left: 50%; width: 220px; padding: 10px; opacity: 0; visibility: hidden; transform: translate(-50%, -8px); background: rgba(7,4,11,.97); border: 1px solid var(--line); box-shadow: 0 24px 70px rgba(0,0,0,.65); transition: .2s ease; }
.nav-dropdown::before { content: ''; position: absolute; inset: -15px 0 auto; height: 15px; }
.nav-group:hover .nav-dropdown, .nav-group:focus-within .nav-dropdown, .nav-group.open .nav-dropdown { opacity: 1; visibility: visible; transform: translate(-50%, 0); }
.nav-dropdown a { display: block; padding: 11px 12px; color: var(--ivory); text-decoration: none; font-family: var(--serif); font-size: 13px; border-bottom: 1px solid rgba(255,255,255,.05); }
.nav-dropdown a:last-child { border: 0; }
.nav-dropdown a:hover { color: var(--gold-light); background: rgba(211,174,104,.06); }
.nav-dropdown small { display: block; margin-bottom: 1px; color: #776d79; font: 500 8px/1.3 var(--sans); text-transform: uppercase; letter-spacing: .18em; }
.nav-toggle { display: none; width: 42px; height: 42px; padding: 10px; border: 1px solid var(--line); background: transparent; }
.nav-toggle span { display: block; width: 100%; height: 1px; margin: 6px 0; background: var(--gold-light); transition: transform .2s ease; }

.site-main { min-height: 80vh; }
.content-shell { width: var(--shell); margin-inline: auto; }
.kicker, .eyebrow { margin: 0 0 15px; color: var(--gold); font-size: 10px; font-weight: 600; letter-spacing: .32em; text-transform: uppercase; }
h1, h2, h3 { font-family: var(--serif); font-weight: 400; }
.portal-hero { position: relative; min-height: 100svh; display: flex; align-items: center; isolation: isolate; overflow: hidden; background: url('/assets/backgrounds/bg-2.png') center/cover no-repeat; }
.portal-hero::before { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(90deg, rgba(3,2,7,.9) 0%, rgba(3,2,7,.62) 38%, rgba(3,2,7,.18) 63%, rgba(3,2,7,.45) 100%), linear-gradient(180deg, rgba(3,2,7,.25), rgba(3,2,7,.2) 66%, var(--ink)); }
.portal-hero__mist { position: absolute; inset: auto -15% -20% 20%; z-index: -1; height: 55%; background: radial-gradient(ellipse, rgba(100,48,159,.17), transparent 65%); filter: blur(40px); }
.portal-hero__content { width: var(--shell); margin: 65px auto 0; }
.portal-hero h1 { max-width: 780px; margin: 0; font-size: clamp(52px, 7vw, 104px); line-height: .98; letter-spacing: -.025em; text-transform: uppercase; text-shadow: 0 10px 70px #000; }
.portal-hero h1 em { color: var(--gold-light); font-style: normal; font-size: .7em; letter-spacing: .07em; }
.hero-lead { max-width: 590px; margin: 28px 0 0; color: #c6bdc7; font-size: clamp(16px, 1.4vw, 19px); line-height: 1.8; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.button, .btn { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0 22px; border: 1px solid var(--line); border-radius: 0; color: var(--ivory); background: rgba(255,255,255,.035); text-decoration: none; text-transform: uppercase; letter-spacing: .14em; font-size: 10px; font-weight: 600; transition: transform .2s ease, color .2s ease, border-color .2s ease, background .2s ease; }
.button:hover, .btn:hover { transform: translateY(-2px); border-color: var(--gold); color: #fff; }
.button--gold, .btn.primary { color: #130c05; border-color: var(--gold); background: linear-gradient(135deg, #9e7737, #e1c17d); box-shadow: 0 12px 40px rgba(166,116,45,.18); }
.button--quiet, .btn.ghost { backdrop-filter: blur(10px); }
.scroll-cue { position: absolute; left: 50%; bottom: 28px; display: grid; justify-items: center; gap: 7px; color: #746b77; text-decoration: none; text-transform: uppercase; letter-spacing: .24em; font-size: 8px; transform: translateX(-50%); }
.scroll-cue span { display: block; width: 1px; height: 34px; background: linear-gradient(var(--gold), transparent); }

.world-intro { padding: 120px 0 140px; }
.section-heading { max-width: 700px; margin-bottom: 48px; }
.section-heading--center { margin-inline: auto; text-align: center; }
.section-heading h2, .soulbook-manifesto h2, .final-portal h2, .page-hero h1 { margin: 0; font-size: clamp(34px, 4.5vw, 62px); line-height: 1.1; text-transform: uppercase; letter-spacing: .025em; }
.section-heading p:last-child { max-width: 610px; margin: 20px auto 0; color: var(--muted); }
.world-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(222,188,119,.15); border: 1px solid rgba(222,188,119,.15); }
.world-card { position: relative; min-height: 330px; display: flex; flex-direction: column; justify-content: space-between; padding: 24px 26px 28px; overflow: hidden; isolation: isolate; color: var(--ivory); background: #0a0710 center/cover; text-decoration: none; }
.world-card::before { content: ''; position: absolute; inset: 0; z-index: -2; opacity: .3; filter: saturate(.65); transform: scale(1.03); transition: opacity .45s ease, transform .7s ease, filter .45s ease; }
.world-card::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(5,3,10,.32), rgba(5,3,10,.7) 56%, rgba(5,3,10,.98)); transition: background .4s ease; }
.world-card:hover::before { opacity: .68; filter: saturate(1); transform: scale(1.08); }
.world-card:hover::after { background: linear-gradient(180deg, rgba(5,3,10,.14), rgba(5,3,10,.5) 55%, rgba(5,3,10,.96)); }
.world-card--books::before { background: url('/assets/books/edda-de.png') center 25%/cover; }
.world-card--audio::before { background: url('/assets/albums/wege-durch-die-dunkelheit.jpg') center/cover; }
.world-card--comics::before { background: url('/assets/backgrounds/bg-3.png') center/cover; }
.world-card--anime::before { background: url('/assets/anime/fenrir_edda_anime.webp') center/cover; }
.world-card--games::before { background: url('/assets/games/fenrirs_ragnarok_cardgame.jpg') center/cover; }
.world-card--lore::before { background: url('/assets/realms/asgard.webp') center/cover; }
.world-card__number { align-self: flex-end; color: rgba(255,255,255,.35); font: 400 9px/1 var(--sans); letter-spacing: .2em; }
.world-card__icon { color: var(--gold-light); font: 400 34px/1 var(--serif); text-shadow: 0 0 28px rgba(187,114,239,.8); }
.world-card p { margin: 0 0 3px; color: #9c919e; font-size: 9px; font-weight: 500; letter-spacing: .22em; text-transform: uppercase; }
.world-card h3 { margin: 0 0 17px; font-size: 27px; text-transform: uppercase; letter-spacing: .06em; }
.world-card__link { color: var(--gold); font-size: 9px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; opacity: .75; }

.soulbook-manifesto { min-height: 720px; display: grid; grid-template-columns: 1.15fr .85fr; align-items: stretch; background: #08050d; border-block: 1px solid rgba(255,255,255,.05); }
.soulbook-manifesto__visual { min-height: 620px; background: linear-gradient(90deg, transparent 65%, #08050d), linear-gradient(0deg, rgba(5,3,10,.45), transparent), url('/assets/backgrounds/bg-4.png') center/cover; }
.soulbook-manifesto__copy { align-self: center; max-width: 570px; padding: 80px 9vw 80px 40px; }
.soulbook-mark { width: min(390px, 100%); margin: 2px 0 28px; filter: drop-shadow(0 0 26px rgba(142,60,199,.22)); }
.soulbook-manifesto h2 { font-size: clamp(36px, 4.2vw, 64px); }
.soulbook-manifesto__copy > p:not(.kicker) { margin: 27px 0; color: var(--muted); }
.text-arrow { display: inline-flex; gap: 22px; color: var(--gold-light); text-decoration: none; text-transform: uppercase; letter-spacing: .17em; font-size: 10px; font-weight: 600; }
.text-arrow span { transition: transform .2s ease; }
.text-arrow:hover span { transform: translateX(6px); }

.featured { padding: 130px 0; }
.feature-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature-tile { position: relative; min-height: 480px; overflow: hidden; isolation: isolate; background: #0b0711; text-decoration: none; }
.feature-tile img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; filter: saturate(.75); transition: transform .7s ease, filter .4s ease; }
.feature-tile__shade { position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, transparent 20%, rgba(5,3,10,.25) 45%, rgba(5,3,10,.97)); }
.feature-tile > div { position: absolute; inset: auto 28px 28px; }
.feature-tile p { margin: 0; color: var(--gold); font-size: 9px; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; }
.feature-tile h3 { margin: 5px 0 13px; font-size: 25px; line-height: 1.25; }
.feature-tile div span { color: #a59ba8; font-size: 9px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
.feature-tile:hover img { transform: scale(1.06); filter: saturate(1.05); }

.final-portal { min-height: 620px; display: grid; place-items: center; padding: 90px 24px; text-align: center; background: linear-gradient(180deg, var(--ink), transparent 20%, rgba(5,3,10,.7)), linear-gradient(90deg, rgba(5,3,10,.8), rgba(5,3,10,.24), rgba(5,3,10,.8)), url('/assets/backgrounds/bg-1.png') center/cover; }
.final-portal > div { max-width: 800px; }
.final-portal .hero-actions { justify-content: center; }

.footer { display: flex; justify-content: space-between; gap: 40px; width: var(--shell); margin: 0 auto; padding: 42px 0; border-top: 1px solid var(--line-soft); color: #716875; }
.footer strong { display: block; color: var(--gold-light); font: 500 14px/1.3 var(--serif); letter-spacing: .16em; text-transform: uppercase; }
.footer span { display: block; margin-top: 7px; font-size: 10px; letter-spacing: .08em; }
.footer nav { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; }
.footer a { color: #8c828f; text-decoration: none; font-size: 9px; letter-spacing: .12em; text-transform: uppercase; }
.footer a:hover { color: var(--gold-light); }

/* Innenseiten */
.page-hero { position: relative; min-height: 510px; display: flex; align-items: flex-end; padding: 150px max(24px, calc((100vw - 1180px)/2)) 70px; overflow: hidden; isolation: isolate; background: #09060e center/cover; }
.page-hero::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(90deg, rgba(5,3,10,.94), rgba(5,3,10,.48) 58%, rgba(5,3,10,.2)), linear-gradient(0deg, var(--ink), transparent 70%); }
.page-hero--books { background-image: url('/assets/backgrounds/bg-4.png'); }
.page-hero--audio { background-image: url('/assets/backgrounds/bg-3.png'); }
.page-hero--comics { background-image: url('/assets/backgrounds/bg-1.png'); }
.page-hero--anime { background-image: url('/assets/anime/fenrir_edda_anime.webp'); }
.page-hero--games { background-image: url('/assets/games/fenrirs_ragnarok_cardgame.jpg'); background-position: center 25%; }
.page-hero > div { max-width: 700px; }
.page-hero p:last-child { max-width: 610px; color: #b7adb9; }
.catalog { width: var(--shell); margin: 0 auto; padding: 90px 0 130px; }
.catalog-head { display: flex; justify-content: space-between; align-items: end; gap: 30px; margin-bottom: 36px; }
.catalog-head h2 { margin: 0; font-size: clamp(28px, 3vw, 42px); text-transform: uppercase; }
.catalog-head p { max-width: 500px; margin: 0; color: var(--muted); font-size: 13px; }
.catalog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 34px 20px; }
.media-card { background: rgba(255,255,255,.018); border-bottom: 1px solid var(--line); }
.media-card__image { position: relative; display: block; overflow: hidden; aspect-ratio: 4/3; background: #100a15; }
.media-card--portrait .media-card__image { aspect-ratio: 2/3; }
.media-card__image img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.82); transition: transform .55s ease, filter .4s ease; }
.media-card:hover .media-card__image img { transform: scale(1.035); filter: saturate(1); }
.media-card__body { padding: 22px 4px 26px; }
.media-card__meta, .badge, .tag { display: inline-block; margin-bottom: 9px; color: var(--gold); font-size: 9px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; }
.media-card h3 { margin: 0 0 9px; font-size: 21px; }
.media-card p { margin: 0 0 18px; color: #978e9a; font-size: 13px; line-height: 1.65; }
.media-card__links { display: flex; flex-wrap: wrap; gap: 14px; }
.media-card__links a { color: var(--gold-light); text-decoration: none; font-size: 9px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
.track-list { display: grid; gap: 1px; margin-top: 18px; background: rgba(255,255,255,.06); }
.track { display: grid; grid-template-columns: 34px 1fr auto; gap: 12px; align-items: center; padding: 10px 0; background: var(--ink); color: #a99fab; font-size: 11px; }
.track img { width: 34px; height: 34px; object-fit: cover; }
.track strong { color: #ddd4df; font-weight: 400; }
.empty-state { grid-column: 1/-1; padding: 45px; border: 1px solid var(--line); color: var(--muted); text-align: center; }

/* Kompatibilität für Detail-, Such- und Formularseiten */
.section, .panel { width: var(--shell); margin: 0 auto; padding: 140px 0 90px; }
.section-head { margin-bottom: 32px; }
.section h1, .panel h1 { font-size: clamp(38px,5vw,68px); text-transform: uppercase; }
.section h2 { font-size: clamp(28px,3.5vw,48px); }
.glass, .glass-block, .feature-card, .album-card, .book-card, .team-card, .partner-card, .news-card, .mini-card { background: rgba(13,8,18,.82); border: 1px solid var(--line); }
.glass-block { padding: 30px; }
.feature-grid, .cover-grid, .book-grid, .team-grid, .news-grid, .cards-strip, .grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(230px,1fr)); gap: 20px; }
.feature-card, .album-card, .book-card, .team-card, .partner-card, .mini-card, .card { overflow: hidden; background: rgba(13,8,18,.82); border: 1px solid var(--line); }
.feature-card img, .album-card img, .team-card img, .partner-card img, .card img { display: block; width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.book-card img { display: block; width: 100%; aspect-ratio: 2/3; object-fit: cover; }
.card-info, .card-body { padding: 20px; }
.card-info h3, .card-body h3 { color: var(--gold-light); }
.card-info p, .card-body p { color: var(--muted); font-size: 13px; }
.detail-hero { display: grid; grid-template-columns: 1fr 380px; gap: 45px; }
.detail-hero aside img { width: 100%; }
.form { max-width: 700px; }
label { display: block; margin-top: 14px; color: var(--muted); font-size: 12px; }
input, textarea, select { width: 100%; padding: 13px; color: var(--ivory); background: #0a0710; border: 1px solid var(--line); }

.reveal { opacity: 0; transform: translateY(18px); transition: opacity .8s ease, transform .8s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; } .reveal { opacity: 1; transform: none; } }

@media (max-width: 980px) {
  :root { --shell: min(100% - 32px, 760px); }
  .topbar { height: 70px; }
  .nav-toggle { display: block; }
  .nav { position: absolute; inset: 70px 0 auto; display: none; align-items: stretch; padding: 18px 24px 28px; background: rgba(5,3,10,.98); border-bottom: 1px solid var(--line); }
  .topbar.open .nav { display: flex; flex-direction: column; }
  .nav > a, .nav-group__trigger { width: 100%; padding: 13px 0; text-align: left; border-bottom: 1px solid rgba(255,255,255,.06); }
  .nav-dropdown { position: static; display: none; width: 100%; padding: 2px 0 10px 15px; opacity: 1; visibility: visible; transform: none; background: transparent; border: 0; box-shadow: none; }
  .nav-group.open .nav-dropdown { display: block; transform: none; }
  .nav-group:hover .nav-dropdown { display: none; }
  .nav-group.open:hover .nav-dropdown { display: block; }
  .world-grid, .catalog-grid { grid-template-columns: repeat(2, 1fr); }
  .feature-row { grid-template-columns: 1fr 1fr; }
  .soulbook-manifesto { grid-template-columns: 1fr; }
  .soulbook-manifesto__visual { min-height: 500px; background: linear-gradient(0deg, #08050d, transparent 35%), url('/assets/backgrounds/bg-4.png') center/cover; }
  .soulbook-manifesto__copy { max-width: 760px; padding: 40px 32px 90px; }
  .detail-hero { grid-template-columns: 1fr; }
  .detail-hero aside { max-width: 400px; }
}

@media (max-width: 620px) {
  :root { --shell: calc(100% - 28px); }
  .brand__word { font-size: 13px; }
  .portal-hero { min-height: 810px; background-position: 57% center; }
  .portal-hero::before { background: linear-gradient(180deg, rgba(3,2,7,.55), rgba(3,2,7,.5) 35%, rgba(3,2,7,.92) 76%, var(--ink)); }
  .portal-hero__content { align-self: flex-end; margin-bottom: 100px; }
  .portal-hero h1 { font-size: clamp(42px, 14vw, 65px); }
  .hero-lead { font-size: 14px; line-height: 1.7; }
  .world-intro { padding: 90px 0; }
  .world-grid, .catalog-grid, .feature-row { grid-template-columns: 1fr; }
  .world-card { min-height: 280px; }
  .soulbook-manifesto__visual { min-height: 370px; }
  .featured { padding: 90px 0; }
  .feature-tile { min-height: 420px; }
  .final-portal { min-height: 540px; }
  .footer { flex-direction: column; }
  .footer nav { gap: 14px; }
  .page-hero { min-height: 470px; padding-bottom: 50px; }
  .catalog { padding: 70px 0 90px; }
  .catalog-head { display: block; }
  .catalog-head p { margin-top: 12px; }
}
