/* ==============================
   Invictus Airsoft Austria — Theme (Static Version)
   Datei: index.css
==================================*/


:root{
  --bg-1:#0e1411;
  --bg-2:#0b0f0d;
  --acc-1:#2f7b50;
  --acc-2:#99ffa7;
  --ink-1:#e7f5ea;
  --ink-2:#9fb6a6;
  --muted:#233127;
  --card:#121a16;
  --glass:rgba(15,20,17,.55);
  --blur:10px;
  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink-1);
  background:
    radial-gradient(1200px 600px at -10% -20%, #1b2a22 0%, transparent 60%),
    radial-gradient(1000px 400px at 110% 0%, #102018 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-1), var(--bg-2));
  background-attachment: fixed;
  letter-spacing:.2px;
}

.container{width:min(1100px, 92%); margin:0 auto}

h1,h2,h3,h4{font-family: Rajdhani, system-ui, sans-serif; letter-spacing:.6px}
h1{font-size:1.4rem;margin:0}
h2{font-size:2.2rem;margin:.2rem 0 1rem}
h3.section-title{font-size:1.8rem;margin:0 0 1rem 0;display:flex;gap:.6rem;align-items:center}
h3.section-title::before{content:"";width:12px;height:12px;border-radius:4px;background:linear-gradient(90deg,var(--acc-1),var(--acc-2));box-shadow:0 0 18px var(--acc-2)}

.section{padding:64px 0}
.section.alt{background:linear-gradient(180deg, transparent, rgba(34,50,41,.25))}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid rgba(153,255,167,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter: blur(var(--blur));
  -webkit-backdrop-filter: blur(var(--blur));
}


.nav-wrap{
  position:sticky; top:0; z-index:1000;
  background:rgba(12,16,14,.6);
  backdrop-filter: blur(12px);
  border-bottom:1px solid rgba(153,255,167,.08);
}
.nav{
  display:flex; align-items:center; gap:16px; padding:10px 0;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{
  width:80px;height:60px;border-radius:12px;
  display:grid;place-items:center;
  font-weight:700; letter-spacing:1px;
  color:#0b140f;
  background: none; }
  
    
.brand-text small{color:var(--ink-2)}

.menu{display:flex; list-style:none; gap:8px; padding:0; margin:0; flex-wrap:wrap}
.nav-link{
  position:relative; display:inline-block; padding:10px 14px; border-radius:12px; text-decoration:none; color:var(--ink-1);
  transition: transform .25s ease;
  overflow:hidden;
  isolation:isolate;
}
.nav-link span{position:relative; z-index:2}
.nav-link::before{
  content:""; position:absolute; inset:0; border-radius:12px;
  background: linear-gradient(120deg, transparent 0%, rgba(153,255,167,.06) 40%, transparent 100%);
  transform: translateX(-100%);
  transition: transform .45s ease;
}
.nav-link::after{
  content:""; position:absolute; left:12px; right:12px; bottom:7px; height:2px;
  background:linear-gradient(90deg, transparent, var(--acc-2), transparent);
  transform: scaleX(0);
  transform-origin:center;
  transition: transform .35s ease;
}
.nav-link:hover{transform: translateY(-1px)}
.nav-link:hover::before{transform: translateX(0)}
.nav-link:hover::after{transform: scaleX(1)}


.btn{
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem; padding:.8rem 1.1rem; border-radius:14px;
  border:1px solid rgba(153,255,167,.25);
  text-decoration:none; color:var(--ink-1); font-weight:600;
  transition: transform .2s ease, box-shadow .3s ease, border-color .3s ease;
  will-change: transform;
  cursor:pointer;
}
.btn::before{
  content:""; position:absolute; inset:-1px; border-radius:inherit;
  background: conic-gradient(from 180deg at 50% 50%, rgba(153,255,167,.0), rgba(153,255,167,.28), rgba(153,255,167,.0));
  filter: blur(14px);
  opacity:.0; transition: opacity .35s ease;
}
.btn:hover{transform: translateY(-1px); box-shadow:0 12px 30px rgba(0,0,0,.35);}
.btn:hover::before{opacity:.6}

.btn-cta{
  background: radial-gradient(120% 100% at 0% 0%, rgba(153,255,167,.18), transparent 60%),
              linear-gradient(180deg, rgba(41,93,62,.9), rgba(27,61,42,.9));
  border-color:rgba(153,255,167,.45);
  box-shadow: inset 0 0 0 1px rgba(153,255,167,.25), 0 0 0 0 rgba(153,255,167,.0);
}
.btn-cta:hover{box-shadow: inset 0 0 0 1px rgba(153,255,167,.35), 0 0 25px 0 rgba(153,255,167,.18)}

.btn-ghost{
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border-color:rgba(153,255,167,.25);
}
.btn-ghost:hover{border-color:rgba(153,255,167,.5)}

.btn-mini{
  font-size:.85rem; padding:.45rem .7rem; border-radius:10px;
  background: rgba(255,255,255,.03);
}
.btn-mini:hover{border-color:rgba(153,255,167,.6)}


.hero{ position:relative; padding:80px 0 56px; overflow:hidden; }
.hero-inner{ display:grid; gap:18px; }
.hero-cta{display:flex; gap:10px; flex-wrap:wrap}
.toggles{display:flex; gap:16px; margin-top:10px; flex-wrap:wrap}


.toggle{position:relative; display:inline-flex; align-items:center; gap:.55rem; user-select:none}
.toggle input{display:none}
.toggle .slider{
  width:56px; height:30px; border-radius:999px;
  background:linear-gradient(180deg, #0b1410, #111b15);
  border:1px solid rgba(153,255,167,.25);
  box-shadow: inset 0 2px 8px rgba(0,0,0,.6);
  position:relative; transition: background .25s ease, border-color .25s ease;
}
.toggle .slider::before{
  content:""; position:absolute; top:50%; left:4px; transform:translateY(-50%);
  width:24px; height:24px; border-radius:50%;
  background: radial-gradient(120% 120% at 20% 10%, var(--acc-2), #61d284 40%, #1a4f34 70%);
  box-shadow:0 8px 16px rgba(0,0,0,.45);
  transition: left .25s ease;
}
.toggle input:checked + .slider{border-color:rgba(153,255,167,.6)}
.toggle input:checked + .slider::before{left:28px}
.toggle .toggle-label{font-size:.9rem; color:var(--ink-2)}


.fold{margin:14px 0; overflow:hidden}
.fold summary{list-style:none; cursor:pointer}
.fold summary::-webkit-details-marker{display:none}
.fold .fold-head{
  display:flex; justify-content:space-between; align-items:center; padding:14px 16px;
}
.fold .chev{
  width:18px; height:18px; border-right:2px solid var(--ink-2); border-bottom:2px solid var(--ink-2);
  transform: rotate(-45deg); transition: transform .25s ease;
}
.fold[open] .chev{transform: rotate(45deg)}
.fold .fold-body{padding:0 16px 16px}


.bullets{margin:0; padding-left:18px}
.bullets li{margin:.4rem 0}


.gallery-grid{
  display:grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap:14px; padding:14px;
}
.shot{
  position:relative; margin:0; overflow:hidden; border-radius:16px; border:1px solid rgba(153,255,167,.12);
  background:var(--card);
}
.shot img{width:100%; height:220px; object-fit:cover; display:block; transition: transform .5s ease, filter .5s ease}
.shot::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(80% 50% at 50% 0%, rgba(153,255,167,.18), transparent 60%);
  opacity:.0; transition: opacity .4s ease;
}
.shot:hover img{transform: scale(1.06); filter: saturate(1.1) contrast(1.05)}
.shot:hover::after{opacity:.9}

.shot figcaption{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 12px;
}


.like-btn{
  display:inline-flex; align-items:center; gap:6px;
  background:transparent; color:var(--ink-2); border:1px solid rgba(153,255,167,.25);
  padding:.45rem .6rem; border-radius:999px; cursor:pointer;
  transition: transform .2s ease, border-color .25s ease, color .25s ease;
}
.like-btn:hover{transform: translateY(-1px); border-color: rgba(153,255,167,.6); color:var(--acc-2)}
.like-btn.active{background: rgba(153,255,167,.1); color:var(--acc-2); border-color: rgba(153,255,167,.75)}
.like-btn .count{font-weight:700}


.cards{display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:14px}
.event-card{padding:16px}


label{display:grid; gap:.35rem; font-size:.95rem; color:var(--ink-2)}
input, textarea{
  color:var(--ink-1); background: rgba(255,255,255,.03);
  border:1px solid rgba(153,255,167,.18); border-radius:12px;
  padding:.8rem .9rem; outline:none;
  transition: border-color .25s ease, box-shadow .25s ease;
}
input:focus, textarea:focus{
  border-color: rgba(153,255,167,.6);
  box-shadow: 0 0 0 3px rgba(153,255,167,.12);
}
.contact{padding:16px; display:grid; gap:12px}
.contact .row{display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap:12px}

/* ===== Footer ===== */
.footer{padding:24px 0; border-top:1px solid rgba(153,255,167,.1); background: rgba(0,0,0,.2)}
.footer-inner{display:flex; align-items:center; gap:12px; justify-content:space-between; flex-wrap:wrap}
.footer .btn-mini{margin-left:auto}

/* ===== Utilities ===== */
.hidden{display:none!important}

@media (max-width: 640px){
  .brand-text small{display:none}
}



/* Tactical Mode (Nightvision-Style) */
body.tactical-mode {
  background: #000 !important;
  color: #0f0 !important;
}
body.tactical-mode a { color: #0f0 !important; }
body.tactical-mode header,
body.tactical-mode .card,
body.tactical-mode .footer {
  background: #111 !important;
  border-color: #0f0 !important;
}
body.tactical-mode .btn {
  background: #0f0 !important;
  color: #000 !important;
}

/* Bewegung reduzieren */
body.reduce-motion * {
  animation: none !important;
  transition: none !important;
  scroll-behavior: auto !important;
}
.brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: inherit;
  display: block;
}
/* === Footer Socials === */
.socials{
  display:flex;
  align-items:center;
  gap:10px;
}

.social-link{
  position:relative;
  width:50px; height:50px;
  display:grid; place-items:center;
  border-radius:10px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(153,255,167,.25);
  box-shadow: var(--shadow);
  overflow:hidden;
  transition: transform .18s ease, border-color .25s ease, box-shadow .25s ease;
}

.social-link img{
  width:30px; height:30px; display:block; object-fit:contain;
}

.social-link:hover{
  transform: translateY(-2px) scale(1.06);
  border-color: rgba(153,255,167,.6);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}

/* Tooltip / Pop-up auf Hover */
.social-link .tip{
  position:absolute;
  bottom: calc(100% + 8px);
  left:50%;
  transform: translateX(-50%) scale(.9);
  opacity:0; pointer-events:none;
  padding:6px 8px;
  border-radius:8px;
  font-size:.8rem;
  color: var(--ink-1);
  background: rgba(0,0,0,.85);
  border:1px solid rgba(153,255,167,.25);
  transition: opacity .18s ease, transform .18s ease;
  white-space:nowrap;
}
.social-link:hover .tip{
  opacity:1;
  transform: translateX(-50%) scale(1);
}
.social-link .tip::after{
  content:"";
  position:absolute;
  top:100%; left:50%;
  width:10px; height:10px;
  transform: translateX(-50%) rotate(45deg);
  background: rgba(0,0,0,.85);
  border-right:1px solid rgba(153,255,167,.25);
  border-bottom:1px solid rgba(153,255,167,.25);
}

/* Stimmig im Tactical Mode */
body.tactical-mode .social-link{
  background: rgba(0,255,128,.06);
  border-color: rgba(160,255,190,.35);
}
body.tactical-mode .social-link .tip{
  background: rgba(0,0,0,.92);
  border-color: rgba(160,255,190,.35);
}

/* Logo-Container entsperren (überschreibt die alte 40x40-Regel) */
.nav .brand-mark {
  width: auto !important;
  height: auto !important;
  background: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Standardgröße (PC) */
.nav .brand-mark img {
  height: 60px;    /* deine PC-Größe */
  width: auto;
  display: block;
}

/* Handy: +30px */
@media (max-width: 768px) {
  .nav .brand-mark img {
    height: 90px;  /* 60px + 30px */
  }
  /* optional: etwas mehr Abstand zwischen Logo & Text am Handy */
  .brand { gap: 14px; }
}
.legal-links {
  display: flex;
  gap: 8px;
  font-size: .9rem;
}

.legal-links a {
  color: var(--ink-2);
  text-decoration: none;
  transition: color .25s ease;
}

.legal-links a:hover {
  color: var(--acc-2);
  text-decoration: underline;
}
.erklärung{
  font-size: 20px !important;
}







html, body {
  height: 100%;       /* Seite immer volle Höhe */
  margin: 0;          /* keine Standardabstände */
}

body {
  display: flex;      /* Body als Flex-Container */
  flex-direction: column;
}



.section {
  flex: 1;   /* dehnt den Hauptteil */
}



.footer {
  margin-top: auto;   /* schiebt den Footer an den unteren Rand */
}







.toggles{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.toggle{position:relative;display:inline-flex;align-items:center;gap:.55rem}
.toggle input{display:none}
.toggle .slider{
  width:56px;height:30px;border-radius:999px;
  background:linear-gradient(180deg,#0b1410,#111b15);
  border:1px solid rgba(153,255,167,.25);
  box-shadow:inset 0 2px 8px rgba(0,0,0,.6);
  position:relative;transition:background .25s ease,border-color .25s ease;
}
.toggle .slider::before{
  content:"";
  position:absolute;
  top:50%;
  left:4px;                         /* Startposition links */
  transform:translateY(-50%);       /* vertikal exakt mittig */
  width:24px;
  height:24px;
  border-radius:50%;
  background:radial-gradient(120% 120% at 20% 10%, var(--acc-2), #61d284 40%, #1a4f34 70%);
  box-shadow:0 8px 16px rgba(0,0,0,.45);
  transition:left .25s ease;        /* wir animieren nur 'left' */
  will-change:left;
}
.toggle input:checked + .slider{border-color:rgba(153,255,167,.6)}
.toggle input:checked + .slider::before {
  left: calc(100% - 28px); /* Trackbreite - (Knopfbreite + linker Abstand) */
}

.toggle .toggle-label{font-size:.9rem;color:var(--ink-2)}









/* Toggle im Hero sicher sichtbar */
.hero .toggles { 
  display:flex !important; 
  gap:16px; 
  flex-wrap:wrap; 
  align-items:center; 
  z-index: 5; 
  position: relative; 
}
.hero .toggles .toggle,
.hero .toggles .slider,
.hero .toggles .toggle-label{
  visibility: visible !important;
  opacity: 1 !important;
}

/* Falls der Sticky-Header überlappt, etwas mehr Luft oben */
.hero { padding-top: 120px; }


#codeRain{
  position:fixed; inset:0; z-index:0;
  opacity:0; pointer-events:none;
  transition:opacity .35s ease;
}
body.tactical-mode #codeRain{ opacity:.25; }
body.reduce-motion #codeRain{ display:none !important; }




















