/* ==========================================================================
   Lightworkers Event (Işık İşçileri) — Front-Only CSS - Neon Parti Teması
   Dosya: /assets/css/style.css
   Amaç: Tailwind CDN'i tamamlayan, performans dostu stiller
   ========================================================================== */

/* 1) Renk Tokenları (global) - Neon Parti Teması */
:root{
  /* Neon Parti Teması Ana Renkleri */
  --dark-bg: #101419;          /* Ana koyu zemin */
  --card-bg: #1A1E26;          /* Kart/panel zemini */
  --neon-pink: #F600FF;        /* Canlı pembe */
  --neon-blue: #00E0FF;        /* Elektrik mavisi */
  
  /* Eski renkler (geriye uyumluluk) */
  --ink: #101419;              /* ana arka plan (güncellendi) */
  --panel: #1A1E26;            /* kart/panel zemini (güncellendi) */
  --panel-2: #b9b9b9;
  --brand-yellow: #F7B500;     /* "ışık" vurgusu */
  --brand-blue: #00E0FF;       /* neon mavi (güncellendi) */
  --brand-red: #F600FF;        /* neon pembe (güncellendi) */
  
  --muted: rgba(255,255,255,.72);
  --border: rgba(255,255,255,.10);
  --border-2: rgba(255,255,255,.16);
  --shadow: 0 10px 25px -10px rgba(0,0,0,.35);
  --neon-shadow: 0 0 20px rgba(246, 0, 255, 0.3), 0 0 40px rgba(0, 224, 255, 0.2);
  --radius-xl: 1.25rem;
  --radius-lg: 1rem;
}
:root{
  --ink: #0F0F14;              /* ana arka plan (gece) */
  --panel: #1E1E27;            /* kart/panel zemini */
  --panel-2: #b9b9b9;
  --brand-yellow: #F7B500;     /* “ışık” vurgusu */
  --brand-blue: #2F80ED;       /* ışın mavisi */
  --brand-red: #E53935;        /* aksiyon (bilet) */
  --muted: rgba(255,255,255,.72);
  --border: rgba(255,255,255,.10);
  --border-2: rgba(255,255,255,.16);
  --shadow: 0 10px 25px -10px rgba(0,0,0,.35);
  --radius-xl: 1.25rem;
  --radius-lg: 1rem;
}

/* 2) Global Temel */
*,
*::before,
*::after { box-sizing: border-box; }

html, body {
  height: 100%;
  background: var(--ink);
  color: #fff;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img { display:block; max-width:100%; height:auto; }
a { transition: color .15s ease, opacity .15s ease, background-color .15s ease; }
hr.hr-soft { height:1px; width:100%; background: var(--border); border:0; }

/* Scrollbar (WebKit) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: #0b0b10; }
::-webkit-scrollbar-thumb { background: #2a2a35; border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: #37374a; }

/* 3) Yardımcılar */
.text-muted { color: var(--muted); }
.border-soft { border: 1px solid var(--border); }
.shadow-soft { box-shadow: var(--shadow); }
.rounded-2xl { border-radius: var(--radius-xl); }
.rounded-xl  { border-radius: .9rem; }
.rounded-lg  { border-radius: var(--radius-lg); }
.glass { background: rgba(255,255,255,.04); border:1px solid var(--border); backdrop-filter: blur(8px); }
.brand-gradient { background: linear-gradient(135deg, var(--brand-yellow), var(--brand-blue)); }
.brand-text { background: linear-gradient(135deg, #fff, #b2d3ff); -webkit-background-clip: text; background-clip:text; color: transparent; }
.beam { position:relative; isolation:isolate; }
.beam::after{
  content:""; position:absolute; inset:-20%;
  background:
    radial-gradient(ellipse at 20% -10%, rgba(247,181,0,.16), transparent 45%),
    radial-gradient(ellipse at 90% 0%, rgba(47,128,237,.14), transparent 40%);
  z-index:-1; filter: blur(22px);
}

/* 4) Sticky/blur üst katmanlar */
.sticky,
.backdrop-blur { -webkit-backdrop-filter: saturate(140%) blur(8px); backdrop-filter: saturate(140%) blur(8px); }

/* 5) Butonlar */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:.55rem; padding:.75rem 1rem; border-radius:.9rem;
  font-weight: 800; text-decoration:none; transition: .2s ease;
  border: 1px solid transparent; line-height:1;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary   { background: var(--brand-red); color: #0b0b10; }
.btn-primary:hover { opacity:.95; }

.btn-ghost     { background: transparent; border-color: var(--border); color: #fff; }
.btn-ghost:hover { background: rgba(255,255,255,.05); }

.btn-accent    { background: var(--brand-yellow); color: #0b0b10; }
.btn-accent:hover { opacity:.92; }

.btn-outline   { background: transparent; color:#fff; border-color: var(--border-2); }
.btn-outline:hover { background: rgba(255,255,255,.06); }

.btn-sm { padding:.45rem .7rem; font-weight:800; border-radius:.7rem; font-size:.85rem; }
.btn-lg { padding:.95rem 1.2rem; border-radius:1rem; font-size:1.06rem; }

/* 6) Rozet / Etiketler */
.badge {
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.28rem .6rem; font-size:.75rem; border-radius:999px;
  line-height:1; border:1px solid var(--border); background: rgba(255,255,255,.05);
}
.badge--success { background: rgba(16,185,129,.15); border-color: rgba(16,185,129,.25); color:#86efac; }
.badge--danger  { background: rgba(239,68,68,.18); border-color: rgba(239,68,68,.28); color:#fca5a5; }
.badge--warn    { background: rgba(247,181,0,.12); border-color: rgba(247,181,0,.22); color:#ffe08a; }

.pill {
  display:inline-flex; align-items:center; gap:.4rem; padding:.38rem .68rem;
  border-radius:999px; font-size:.78rem; border:1px solid var(--border);
  background: rgba(255,255,255,.05);
}

/* 7) Kartlar */
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.card-header { padding: 1rem 1.25rem; border-bottom: 1px solid var(--border); }
.card-body   { padding: 1rem 1.25rem; }
.card-foot   { padding: 1rem 1.25rem; border-top: 1px solid var(--border); }
.hover-lift { transition: transform .18s ease, box-shadow .18s ease; }
.hover-lift:hover { transform: translateY(-3px); box-shadow: var(--shadow); }

/* 8) Hero */
.hero { position:relative; overflow:hidden; border-radius: var(--radius-xl); }
.hero::before{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.35));
  z-index:1;
}
.hero .hero-inner { position:relative; z-index:2; }

/* 9) Tooltip */
.tooltip { position: relative; cursor: help; }
.tooltip:hover::after{
  content: attr(data-title);
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  background: #11131a; color:#fff; padding:.45rem .6rem; font-size:.75rem;
  border:1px solid var(--border); border-radius:.6rem; white-space:nowrap; z-index: 10;
  box-shadow: var(--shadow);
}

/* 10) Formlar */
.input, .select, .textarea {
  width:100%; background: var(--panel); color:#fff;
  border:1px solid var(--border); border-radius:.9rem;
  padding:.65rem .9rem; outline:none; transition: .2s ease;
}
.input::placeholder, .textarea::placeholder { color: rgba(255,255,255,.4); }
.input:focus, .select:focus, .textarea:focus {
  border-color: rgba(47,128,237,.5); box-shadow: 0 0 0 4px rgba(47,128,237,.18);
}

.input-group {
  display:flex; align-items:center; gap:.55rem;
  background: var(--panel); border:1px solid var(--border); border-radius:.9rem; padding:.55rem .8rem;
}
.input-group input{ background:transparent; border:0; outline:none; color:#fff; width:100%; }
.input-group .icon{ color: rgba(255,255,255,.55); }

/* 11) Toast */
.toast {
  background: var(--panel); border:1px solid var(--border); color:#fff;
  border-radius: .9rem; padding:.65rem .9rem; display:flex; align-items:center; gap:.55rem;
  animation: slideIn .2s ease;
}
@keyframes slideIn {
  from { transform: translateY(-6px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}

/* 12) Etkinlik kartı mikro dokunuşlar */
.event-card:hover img { transform: scale(1.03); transition: transform .35s ease; }
.event-meta { color: var(--muted); font-size: .9rem; display:flex; gap:.65rem; align-items:center; }

/* 13) Koltuk Planı (tickets — mock) */
.seat-grid { display:grid; gap:.35rem; grid-template-columns: repeat(18, minmax(0,1fr)); }
.seat {
  width: 1.85rem; height: 1.85rem; border-radius:.45rem;
  background: #2a2a36; border:1px solid #363646; position:relative;
  cursor:pointer; transition: .15s ease;
}
.seat:hover { background:#323246; }
.seat--sel { background: var(--brand-yellow); border-color: #000; box-shadow: 0 0 0 3px rgba(247,181,0,.25); }
.seat--off { background: #262634; border-style:dashed; border-color:#414156; cursor:not-allowed; opacity:.6; }
.seat.vip { outline: 2px dashed rgba(47,128,237,.5); outline-offset: 2px; }
.row-label, .col-label { color: rgba(255,255,255,.55); font-size:.7rem; }

/* 14) Ürün Grid */
.product-tile {
  position:relative; overflow:hidden; border-radius:1rem; border:1px solid var(--border); background: var(--panel);
}
.product-tile .thumb { aspect-ratio: 4/5; width: 100%; object-fit: cover; transition: transform .3s ease; }
.product-tile:hover .thumb { transform: scale(1.03); }
.stock-badge {
  position:absolute; top:.6rem; left:.6rem; font-size:.7rem;
  padding:.25rem .5rem; border-radius:.6rem; background: rgba(239,68,68,.95); color:#fff;
}
.price { font-weight: 800; letter-spacing:.2px; }

/* 15) Tipografi / Prose */
.prose { color:#fff; }
.prose h1,.prose h2,.prose h3{ font-weight:800; line-height:1.15; margin: .6em 0 .35em; }
.prose p { color: var(--muted); margin:.66rem 0; }
.prose a { color:#fff; text-decoration: underline; }
.prose code { background: rgba(255,255,255,.06); padding:.15rem .3rem; border-radius:.35rem; }
.kbd { font-family: ui-monospace,SFMono-Regular,Menlo,monospace; font-size:.8em; padding:.12rem .35rem; border:1px solid var(--border); border-radius:.4rem; background:#141722; }

/* 16) Banner/uyarı kutuları */
.note   { background: rgba(47,128,237,.12); border:1px solid rgba(47,128,237,.32); color:#cae1ff; padding:.8rem 1rem; border-radius:.9rem; }
.warn   { background: rgba(247,181,0,.12);  border:1px solid rgba(247,181,0,.3);  color:#ffe28f; padding:.8rem 1rem; border-radius:.9rem; }
.danger { background: rgba(229,57,53,.12);  border:1px solid rgba(229,57,53,.3);  color:#ffb3ae; padding:.8rem 1rem; border-radius:.9rem; }

/* 17) Navigasyon linkleri */
.nav-link { color:rgba(255,255,255,.8); }
.nav-link:hover { color:#fff; }
.nav-link.is-active { color: var(--brand-yellow); }

/* 18) Animasyonlar (ışık temalı) */
@keyframes float {
  0% { transform: translateY(0) }
  50%{ transform: translateY(-6px) }
  100%{ transform: translateY(0) }
}
.float { animation: float 5s ease-in-out infinite; }

@keyframes pulseRing {
  0% { box-shadow: 0 0 0 0 rgba(247,181,0,.45); }
  70%{ box-shadow: 0 0 0 16px rgba(247,181,0,0); }
  100%{ box-shadow: 0 0 0 0 rgba(247,181,0,0); }
}
.pulse-ring { animation: pulseRing 2.2s cubic-bezier(.66,0,0,1) infinite; }

@keyframes shimmer {
  0% { background-position: -450px 0; }
  100% { background-position: 450px 0; }
}
.skeleton {
  position: relative;
  background: #20202a;
  background-image: linear-gradient(90deg, #20202a 0px, #2b2b36 40px, #20202a 80px);
  background-size: 600px; animation: shimmer 1.15s infinite linear;
  border-radius: .85rem;
}

/* 19) CTA nabız (Bilet Al) */
.cta-pulse{ position:relative; }
.cta-pulse::after{
  content:""; position:absolute; inset:-6px; border-radius: 1rem;
  border:2px solid rgba(247,181,0,.7); animation: pulseRing 1.8s infinite;
  pointer-events:none;
}

/* 20) Marquee (opsiyonel duyuru) */
.marquee { overflow:hidden; white-space:nowrap; mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); }
.marquee > span { display:inline-block; padding-left:100%; animation: marquee 16s linear infinite; }
@keyframes marquee {
  0% { transform: translateX(0) }
  100% { transform: translateX(-100%) }
}

/* 21) A11y – klavye odak görünürlüğü */
:focus-visible {
  outline: 3px solid rgba(47,128,237,.65);
  outline-offset: 2px;
  border-radius: .35rem;
}

/* 22) Tablolar (legal vb.) */
.table-min { width:100%; border-collapse: collapse; border:1px solid var(--border); }
.table-min th, .table-min td { padding:.7rem .8rem; border-top:1px solid var(--border); }
.table-min thead th { background: #1b1b25; text-align:left; }

/* 23) Mobil ince ayar */
@media (max-width: 640px){
  .btn{ padding:.65rem .9rem; }
  .seat { width: 1.55rem; height: 1.55rem; }
}

/* 24) Logo kapsayıcı (footer/header için daha net görünüm) */
.logo-tile {
  display:inline-flex; align-items:center; justify-content:center;
  height: 44px; width: 44px; border-radius: 12px; background: var(--panel); border:1px solid var(--border);
}

/* 25) Header haze band (yüksek görünürlük için) */
.haze {
  position:relative; isolation:isolate;
  background: linear-gradient(180deg, rgba(15,15,20,.85), rgba(15,15,20,.65));
}
.haze::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(1000px 40px at 50% 0, rgba(247,181,0,.08), transparent),
              radial-gradient(1000px 40px at 50% 0, rgba(47,128,237,.06), transparent);
}

/* 26) “Lightworkers” motifli section başlık çizgisi */
.section-title {
  position:relative; padding-top:.4rem;
}
.section-title::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background: linear-gradient(90deg, rgba(247,181,0,.7), rgba(47,128,237,.4), rgba(255,255,255,0));
  border-radius: 2px;
}
