/* ==========================================================================
   THEME: Farben, Typo, Spacing – Museum Dark (Violet) + Accent Violet
   ========================================================================== */
:root{
  --bg: #0E0716;
  --surface: #160D22;
  --surface-2: rgba(22, 13, 34, 0.72);
  --text: #F4F4F5;
  --text-primary: var(--text);
  --text-secondary: var(--text-2);
  --text-2: #A8A1B3;
  --border: #342845;
  --accent: #7C3AED;

  --maxw: 1400px;
  --pad-m: 24px;
  --pad-d: 48px;

  --r-card: 16px;
  --r-modal: 20px;
  --r-btn: 999px; /* Pill */
  --gutter: 24px;

  --shadow-soft: 0 10px 30px rgba(0,0,0,0.35);
  --shadow-accent: 0 0 0 1px rgba(124,58,237,0.35), 0 0 28px rgba(124,58,237,0.18);

  --ease: cubic-bezier(.2,.8,.2,1);
  --dur: 180ms;
}

/* ==========================================================================
   BASE: Reset + Grundlayout + Fonts
   ========================================================================== */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
a{ color: inherit; text-decoration: none; }
img{ max-width:100%; display:block; }
button, input, select { font: inherit; }

/* ==========================================================================
   LAYOUT: Container + Sections
   ========================================================================== */
.container{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--pad-m);
}
@media (min-width: 900px){
  .container{ padding: 0 var(--pad-d); }
}
.section{ padding: 48px 0; }
@media (min-width: 900px){
  .section{ padding: 64px 0; }
}
.muted{ color: var(--text-2); }

/* ==========================================================================
   HEADER: Sticky Nav mit Blur beim Scroll
   ========================================================================== */
.header{
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(52,40,69,0.35);
  background: rgba(14,7,22,0.35);
  backdrop-filter: blur(0px);
  transition: backdrop-filter var(--dur) var(--ease), background var(--dur) var(--ease);
}
.header.is-scrolled{
  background: rgba(14,7,22,0.72);
  backdrop-filter: blur(10px);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height: 64px;
  padding: 0 var(--pad-m);
}
@media (min-width: 900px){
  .header-inner{ padding: 0 var(--pad-d); }
}
.brand{
  display:flex;
  align-items:center;
  min-width: 180px;
  font-family: Space Grotesk, Inter, system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: 0.2px;
  color: var(--text);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 12px;
  flex: 1;
}
.nav a{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(52,40,69,0.55);
  color: var(--text-2);
  background: transparent;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.nav a:hover{
  color: var(--text);
  background: rgba(22,13,34,0.55);
  border-color: rgba(124,58,237,0.25);
}
.nav a.active{
  color: var(--text);
  background: rgba(124,58,237,0.14);
  border-color: rgba(124,58,237,0.35);
}

.header-right{
  min-width: 180px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 10px;
}

/* ==========================================================================
   HEADER & NAVIGATION
   ========================================================================== */

/* ==========================================================================
   FOOTER: Links mittig + Copyright links
   ========================================================================== */
.footer{
  border-top: 1px solid rgba(52,40,69,0.35);
  margin-top: 64px;
  padding: 24px 0;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.footer-center{
  display:flex;
  gap: 16px;
  justify-content:center;
  flex: 1;
}
.footer a{
  color: var(--text-2);
  padding: 6px 10px;
  border-radius: 999px;
}
.footer a:hover{ color: var(--text); background: rgba(22,13,34,0.7); }

/* ==========================================================================
   TYPO: Headings (Space Grotesk) + Skala
   ========================================================================== */
h1,h2,h3{
  font-family: "Space Grotesk", Inter, system-ui, sans-serif;
  letter-spacing: -0.02em;
  margin: 0 0 12px 0;
}
h1{ font-size: 38px; line-height: 1.1; }
@media (min-width: 900px){ h1{ font-size: 54px; } }
h2{ font-size: 28px; line-height: 1.2; }
@media (min-width: 900px){ h2{ font-size: 32px; } }
.p{ font-size: 16px; color: var(--text-2); margin: 0; }

/* ==========================================================================
   BUTTONS: Primary / Secondary / Link – Pill Style
   ========================================================================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 18px;
  border-radius: var(--r-btn);
  border: 1px solid rgba(52,40,69,0.6);
  cursor:pointer;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease),
              border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  user-select:none;
  white-space: nowrap;
}
.btn:active{ transform: scale(0.98); }
.btn-primary{
  background: var(--accent);
  border-color: rgba(124,58,237,0.65);
  box-shadow: var(--shadow-accent);
  color: white;
}
.btn-primary:hover{ box-shadow: 0 0 0 1px rgba(124,58,237,0.6), 0 0 34px rgba(124,58,237,0.24); }
.btn-ghost{
  background: transparent;
  color: var(--text);
}
.btn-ghost:hover{ background: rgba(22,13,34,0.75); }
.btn-link{
  background: transparent;
  border-color: transparent;
  color: var(--text-2);
  padding: 10px 12px;
}
.btn-link:hover{ color: var(--text); background: rgba(22,13,34,0.7); }

/* ==========================================================================
   HERO (Home): Full-bleed Bild + Overlay unten mittig
   ========================================================================== */

.hero{
  position: relative;
  min-height: 72vh;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  border-bottom: 1px solid rgba(52,40,69,0.35);
}

/* Hintergrundbild */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: url("assets/hero.jpg") center/cover no-repeat;
  transform: scale(1.02);
  z-index: 0;
  pointer-events: none; /* 🔑 WICHTIG */
}

/* Dunkles Overlay */
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(
    ellipse at center,
    rgba(14,7,22,0.25),
    rgba(14,7,22,0.86)
  );
  z-index: 1;
  pointer-events: none; /* 🔑 WICHTIG */
}

/* Inhalt */
.hero-inner{
  position: relative;
  z-index: 2; /* 🔑 über Bild & Overlay */
  width: 100%;
  padding: 0 var(--pad-m) 42px;
}

@media (min-width: 900px){
  .hero-inner{
    padding: 0 var(--pad-d) 56px;
  }
}

/* Textbox */
.hero-overlay{
  max-width: 820px;
  margin: 0 auto;
  text-align:center;
  background: rgba(22,13,34,0.42);
  border: 1px solid rgba(52,40,69,0.55);
  border-radius: var(--r-modal);
  padding: 22px 18px;
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-soft);
}

/* Buttons */
.hero-actions{
  display:flex;
  gap: 12px;
  justify-content:center;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* ==========================================================================
   CARDS: 1:1 Kacheln (Home) + Collection Cards
   ========================================================================== */
.grid-3{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 700px){
  .grid-3{ grid-template-columns: repeat(3, 1fr); gap: 24px; }
}
.tile{
  border-radius: var(--r-card);
  border: 1px solid rgba(52,40,69,0.55);
  background: rgba(22,13,34,0.42);
  overflow:hidden;
  position:relative;
  aspect-ratio: 1 / 1;
  box-shadow: none;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.tile:hover{ transform: translateY(-2px); border-color: rgba(124,58,237,0.35); }
.tile img{ width:100%; height:100%; object-fit:cover; opacity:0.92; }
.tile-label{
  position:absolute;
  left: 12px; bottom: 12px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(14,7,22,0.62);
  border: 1px solid rgba(52,40,69,0.55);
  color: var(--text);
  font-size: 13px;
}

/* ==========================================================================
   HORIZONTAL STRIP: "New Drop" – 5 kleine nebeneinander + "view all"
   ========================================================================== */
.strip-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.strip{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
@media (max-width: 900px){
  .strip{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px){
  .strip{ grid-template-columns: repeat(2, 1fr); }
}
.strip-item{
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(52,40,69,0.55);
  background: rgba(22,13,34,0.42);
  aspect-ratio: 1 / 1;
}
.strip-item img{ width:100%; height:100%; object-fit:cover; }

/* ==========================================================================
   COMMAND BAR (Wallpapers): Toggle + Filter + Suche
   ========================================================================== */
.commandbar{
  position: sticky;
  top: 64px; /* unter Header */
  z-index: 40;
  padding: 12px 0;
  background: rgba(14,7,22,0.72);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(52,40,69,0.35);
}
.command-inner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;}
.toggle{
  display:inline-flex;
  border: 1px solid rgba(52,40,69,0.6);
  border-radius: 999px;
  overflow:hidden;
  background: rgba(22,13,34,0.42);
}
.toggle button{
  padding: 8px 12px;
  background: transparent;
  border: 0;
  color: var(--text-2);
  cursor:pointer;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.toggle button.active{ background: rgba(124,58,237,0.18); color: var(--text); }

.select, .search{
  border: 1px solid rgba(52,40,69,0.6);
  background: rgba(22,13,34,0.42);
  color: var(--text);
  border-radius: 999px;
  padding: 8px 12px;
}
.select{ padding-right: 34px; }
.search{ flex: 1; min-width: 200px; }
.reset{ margin-left: auto; }

/* ==========================================================================
   WALLPAPER GRID: responsive Spalten + Cards mit Hover Overlay
   ========================================================================== */
.wall-grid{
  display:grid;
  gap: 14px;
  padding: 20px 0 10px;
  grid-template-columns: 1fr;
}
@media (min-width: 620px){ .wall-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px){ .wall-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1200px){ .wall-grid{ grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1400px){ .wall-grid{ grid-template-columns: repeat(5, 1fr); } }

.wall-card{
  position:relative;
  border-radius: var(--r-card);
  overflow:hidden;
  border: 1px solid rgba(52,40,69,0.55);
  background: rgba(22,13,34,0.42);
  cursor:pointer;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.wall-card:hover{ transform: translateY(-2px); border-color: rgba(124,58,237,0.35); }
.wall-card .media{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  opacity:0.95;
}
.wall-card .meta-title{
  position:absolute;
  left: 12px; bottom: 12px;
  font-size: 13px;
  color: rgba(244,244,245,0.92);
  text-shadow: 0 4px 14px rgba(0,0,0,0.65);
}
.wall-card .overlay{
  position:absolute; inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  background: rgba(14,7,22,0.45);
  opacity:0;
  transition: opacity var(--dur) var(--ease);
}
.wall-card:hover .overlay{ opacity:1; }
.icon-btn{
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(52,40,69,0.6);
  background: rgba(22,13,34,0.7);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.icon-btn:hover{ border-color: rgba(124,58,237,0.45); box-shadow: var(--shadow-accent); }

.svg{
  width: 18px; height: 18px;
  fill: none;
  stroke: rgba(244,244,245,0.92);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* ==========================================================================
   MODAL (Wallpaper + Just Art): Overlay + Panel + Close
   ========================================================================== */
.modal{
  position: fixed;
  inset: 0;
  z-index: 300;
  display:none;
  align-items:center;
  justify-content:center;
  padding: 18px;
  background: rgba(0,0,0,0.66);
}
.modal.open{ display:flex; }
.modal-panel{
  position: relative;
  z-index: 1;
  width: min(1100px, 100%);
  max-height: 88vh;
  overflow:hidden;
  border-radius: var(--r-modal);
  border: 1px solid rgba(52,40,69,0.65);
  background: rgba(22,13,34,0.92);
  box-shadow: var(--shadow-soft);
  display:grid;
  grid-template-columns: 1.55fr 0.85fr;
}
@media (max-width: 900px){
  .modal-panel{ grid-template-columns: 1fr; }
}
.modal-media{
  background: rgba(14,7,22,0.45);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:auto;
}
/* MODAL MEDIA: immer komplett sichtbar, kein Cropping */
.modal-media{
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:auto; /* erlaubt scroll, falls wirklich zu groß */
}

.modal-media img,
.modal-media video{
  max-width: 100%;
  max-height: 80vh;   /* passt ins Display */
  width: auto;
  height: auto;
  object-fit: contain; /* 🔑 kein Abschneiden */
  display:block;
}
.modal-info{
  padding: 18px 18px 16px;
  overflow:auto;
}
.modal-close{
  z-index: 5;
  position:absolute;
  top: 14px; right: 14px;
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(52,40,69,0.65);
  background: rgba(22,13,34,0.72);
  cursor:pointer;
}
.modal-close:hover{ border-color: rgba(124,58,237,0.45); box-shadow: var(--shadow-accent); }

.pills{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 10px 0 14px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(52,40,69,0.6);
  background: rgba(14,7,22,0.45);
  color: var(--text-2);
  font-size: 13px;
  cursor:pointer;
}
.pill:hover{ color: var(--text); border-color: rgba(124,58,237,0.35); }

/* ==========================================================================
   JUST ART: Masonry Grid + Play Overlay
   ========================================================================== */
.masonry{
  column-count: 1;
  column-gap: 16px;
  padding-top: 24px;
}
@media (min-width: 700px){ .masonry{ column-count: 2; } }
@media (min-width: 1100px){ .masonry{ column-count: 3; } }

.m-item{
  break-inside: avoid;
  margin: 0 0 16px 0;
  border-radius: var(--r-card);
  overflow:hidden;
  border: 1px solid rgba(52,40,69,0.55);
  background: rgba(22,13,34,0.42);
  position:relative;
  cursor:pointer;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.m-item:hover{ transform: translateY(-2px); border-color: rgba(124,58,237,0.35); }
.m-item img, .m-item video{ width:100%; height:auto; display:block; }
.play-badge{
  position:absolute;
  inset:auto 12px 12px auto;
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(52,40,69,0.65);
  background: rgba(0,0,0,0.35);
  display:flex;
  align-items:center;
  justify-content:center;
}

/* ==========================================================================
   SOCIAL PAGE: Buttons Grid
   ========================================================================== */
.social-grid{
  display:grid;
  gap: 14px;
  padding-top: 10px;
}
.social-btn{
  display:block;
  padding: 14px 16px;
  border-radius: var(--r-card);
  border: 1px solid rgba(52,40,69,0.6);
  background: rgba(22,13,34,0.42);
  color: var(--text);
}
.social-btn:hover{ border-color: rgba(124,58,237,0.35); box-shadow: var(--shadow-accent); }

/* ==========================================================================
   TOASTS: kleine Statusmeldungen (Download gestartet, Link kopiert)
   ========================================================================== */
.toast-wrap{
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  z-index: 200;
  display:flex;
  flex-direction:column;
  gap: 10px;
  pointer-events:none;
}
.toast{
  pointer-events:none;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(52,40,69,0.7);
  background: rgba(22,13,34,0.85);
  color: var(--text);
  box-shadow: var(--shadow-soft);
  font-size: 14px;
}

/* ==========================================================================
   SKELETON: Platzhalter, bis Bilder geladen sind
   ========================================================================== */
.skel{
  background: linear-gradient(90deg, rgba(22,13,34,0.35), rgba(22,13,34,0.7), rgba(22,13,34,0.35));
  background-size: 200% 100%;
  animation: skel 1.1s linear infinite;
}
@keyframes skel{
  0%{ background-position: 200% 0; }
  100%{ background-position: -200% 0; }
}

/* ==========================================================================
   REDUCED MOTION: Animationen abschalten, wenn Nutzer es wünscht
   ========================================================================== */
@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

.burger-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;}
.burger-btn span{width:22px;height:2px;background:var(--text);display:block;}

.mobile-menu{position:fixed;top:0;right:0;width:78%;max-width:320px;height:100vh;background:rgba(16,10,26,0.96);backdrop-filter:blur(16px);transform:translateX(100%);transition:transform 0.3s ease;z-index:200;padding:80px 24px;}
.mobile-menu.open{transform:translateX(0);}
.mobile-nav{display:flex;flex-direction:column;gap:18px;}
.mobile-nav a{font-size:1.05rem;color:var(--text);border:1px solid rgba(52,40,69,0.55);border-radius:999px;padding:10px 12px;}
.menu-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.45);opacity:0;pointer-events:none;transition:opacity 0.3s ease;z-index:150;}
.menu-backdrop.show{opacity:1;pointer-events:auto;}

@media (max-width: 860px){
  .nav{display:none;}
  .burger-btn{display:flex;}
  .brand{min-width:auto;}
  .header-right{min-width:auto;}
}

.about-prose{max-width:860px;margin:0 auto;text-align:center;font-size:18px;}
