:root{
  --blue-electric:#3a18ff;
  --blue-electric-2:#5a2bff;
  --blue-deep:#0a2160;
  --red-flag:#e30a17;
  --red-script:#ff1633;
  --cyan:#21d4d4;
  --navy:#0b3a8c;
  --ink:#0d1f4f;
  --yellow:#fff44f;
  --bg:#f6f6f4;
  --paper:#ffffff;
  --card-grey:#eceaea;
  --grain: 0.04;
}

*{box-sizing:border-box;margin:0;padding:0}

html,body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Archivo', system-ui, sans-serif;
  min-height:100vh;
  overflow-x:hidden;
}

/* Arka plan grid */
.grid-bg{
  position:fixed;
  inset:0;
  background-image:
    linear-gradient(rgba(13,31,79,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13,31,79,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events:none;
  z-index:0;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}

/* Floating elemanlar */
.floaters{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
}
.floater{
  position:absolute;
  font-size:18px;
  color:var(--blue-electric);
  opacity:.35;
  animation:float 9s ease-in-out infinite;
}
.f1{top:8%;  left:55%; animation-delay:0s; color:var(--red-flag)}
.f2{top:18%; left:88%; animation-delay:1.5s; color:var(--cyan)}
.f3{top:70%; left:6%;  animation-delay:3s; color:var(--blue-electric)}
.f4{top:85%; left:48%; animation-delay:2s; color:var(--navy)}
.f5{top:40%; left:96%; animation-delay:4s; color:var(--red-flag)}

@keyframes float{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-22px) rotate(180deg)}
}

/* POSTER LAYOUT */
.poster{
  position:relative;
  z-index:2;
  max-width:1280px;
  margin:0 auto;
  padding:40px 32px 80px;
  display:grid;
  grid-template-columns: 360px 1fr;
  grid-template-rows: auto;
  gap:32px;
  min-height:100vh;
  align-items:start;
}

/* -------- SOL BİLGİ KARTI -------- */
.info-card{
  position:relative;
  background: linear-gradient(135deg, var(--blue-electric) 0%, var(--blue-electric-2) 60%, #6a3cff 100%);
  color:#fff;
  padding:38px 32px 36px;
  border-radius:4px;
  box-shadow:
    0 30px 60px -20px rgba(58,24,255,.45),
    0 8px 20px -10px rgba(58,24,255,.3);
  overflow:hidden;
  transform: translateY(20px);
  opacity:0;
  animation: cardIn .9s cubic-bezier(.2,.7,.2,1) .1s forwards;
}

/* Card içi parıltı */
.info-card::before{
  content:"";
  position:absolute;
  inset:-50%;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 40%);
  pointer-events:none;
  animation: shimmer 8s ease-in-out infinite;
}

@keyframes shimmer{
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(8%, 6%)}
}

@keyframes cardIn{
  to{transform:translateY(0); opacity:1}
}

.tags{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:6px;
  font-weight:800;
  font-size:38px;
  line-height:1.05;
  letter-spacing:-0.5px;
}
.tags li{
  opacity:0;
  transform: translateX(-16px);
  animation: slideIn .6s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay: calc(.4s + var(--d));
  position:relative;
}
.tags li:hover{
  color:var(--yellow);
  cursor:default;
}

@keyframes slideIn{
  to{opacity:1; transform:translateX(0)}
}

.divider{
  height:1px;
  background: rgba(255,255,255,.7);
  margin:24px 0;
}
.divider.thin{margin:18px 0}

.location{
  display:flex;
  flex-direction:column;
  gap:2px;
  color:var(--yellow);
  font-weight:800;
  font-size:34px;
  line-height:1.05;
  letter-spacing:-0.5px;
}
.loc-line{
  opacity:0;
  animation: fadeUp .6s ease-out forwards;
}
.loc-line:nth-child(1){animation-delay:1s}
.loc-line:nth-child(2){animation-delay:1.15s}

@keyframes fadeUp{
  from{opacity:0; transform:translateY(8px)}
  to{opacity:1; transform:translateY(0)}
}

.date-wrap{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.date{
  font-weight:900;
  font-size:26px;
  letter-spacing:0.5px;
  color:#fff;
  opacity:0;
  animation: fadeUp .6s ease-out 1.4s forwards;
}
.countdown{
  font-weight:600;
  font-size:13px;
  letter-spacing:1px;
  color: rgba(255,255,255,.85);
  text-transform:uppercase;
  opacity:0;
  animation: fadeUp .6s ease-out 1.6s forwards;
}

/* Köşe süslemeleri */
.corner{
  position:absolute;
  width:14px;
  height:14px;
  border:2px solid rgba(255,255,255,.5);
}
.tl{top:10px;left:10px; border-right:none; border-bottom:none}
.tr{top:10px;right:10px; border-left:none; border-bottom:none}
.bl{bottom:10px;left:10px; border-right:none; border-top:none}
.br{bottom:10px;right:10px; border-left:none; border-top:none}

/* -------- KASKON LOGO -------- */
.kaskon-badge{
  grid-column:1;
  margin-top:-8px;
  padding:18px 24px;
  background:var(--card-grey);
  border-radius:2px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  opacity:0;
  animation:fadeUp .6s ease-out 1.1s forwards;
}
.kaskon-placeholder{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  position:relative;
}
.kaskon-text{
  font-weight:900;
  font-size:24px;
  color:#7a7a7a;
  letter-spacing:0.5px;
}
.e-shape{
  position:absolute;
  top:-2px;
  left:90px;
  width:34px;
  height:34px;
  border-radius:50%;
  background: conic-gradient(from 0deg, #3a18ff, #2da9e0, #6dd35c, #ffea3a, #ff7a1f, #e30a17, #3a18ff);
  display:flex;
  align-items:center;
  justify-content:center;
  animation: spinSlow 12s linear infinite;
}
.e-letter{
  background:#fff;
  width:22px;
  height:22px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:900;
  color:#333;
}
@keyframes spinSlow{
  to{transform:rotate(360deg)}
}
.kaskon-sub{
  font-size:9px;
  font-weight:700;
  letter-spacing:1.2px;
  color:#999;
  margin-top:6px;
}

/* -------- HERO -------- */
.hero{
  grid-column:2;
  grid-row: 1 / span 2;
  position:relative;
  min-height:640px;
}

/* D ŞEKLİ KOMPOZİSYONU */
.d-shape{
  position:relative;
  width:520px;
  height:520px;
  margin: 20px 0 0 auto;
  border-radius: 260px 260px 260px 16px;
  overflow:hidden;
  display:grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  box-shadow:
    0 40px 80px -30px rgba(11,58,140,.45),
    0 10px 30px -10px rgba(227,10,23,.2);
  opacity:0;
  transform: scale(.92);
  animation: dIn 1s cubic-bezier(.2,.7,.2,1) .3s forwards;
}

@keyframes dIn{
  to{opacity:1; transform:scale(1)}
}

.quarter{
  position:relative;
  overflow:hidden;
}

/* Placeholder pattern alanları */
.pattern-placeholder{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  font-family:'Archivo';
  font-size:11px;
  font-weight:700;
  letter-spacing:.5px;
  text-align:center;
  padding:8px;
}
.ph-label{
  background: rgba(0,0,0,.4);
  color:#fff;
  padding:6px 10px;
  border-radius:3px;
  backdrop-filter: blur(2px);
  border:1px dashed rgba(255,255,255,.6);
  line-height:1.3;
}

.pattern-red{
  background: linear-gradient(135deg, #c40411 0%, #e30a17 50%, #8a0510 100%);
  color:#fff;
}
.pattern-red::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(0,0,0,.18) 0 12px, transparent 12px 24px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,.05) 0 12px, transparent 12px 24px);
  opacity:.6;
}

.pattern-navy{
  background: linear-gradient(135deg, #0a2160 0%, #1538a0 60%, #0b3a8c 100%);
  color:#fff;
}
.pattern-navy::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 25% 25%, rgba(255,255,255,.12) 8px, transparent 9px),
    radial-gradient(circle at 75% 75%, rgba(255,255,255,.12) 8px, transparent 9px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 8px, transparent 8px 24px);
  background-size: 60px 60px, 60px 60px, auto;
}

.pattern-light{
  background: #e9e8e6;
  color:#777;
}

.pattern-cyan{
  background: linear-gradient(135deg, #21d4d4 0%, #36e0ff 50%, #1aa8c0 100%);
  color:#fff;
}
.pattern-cyan::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 2px, transparent 2px 14px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.18) 0 2px, transparent 2px 14px);
  opacity:.5;
}

/* Ay (crescent) - sol üst kırmızı çeyrekte */
.crescent{
  position:absolute;
  top:38%;
  left:18%;
  width:160px;
  height:160px;
  transform:translate(-50%,-50%);
  z-index:3;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.2));
  animation: pulse 4s ease-in-out infinite;
}

@keyframes pulse{
  0%,100%{transform:translate(-50%,-50%) scale(1)}
  50%{transform:translate(-50%,-50%) scale(1.04)}
}

/* Yıldız - merkezde */
.star{
  position:absolute;
  top:54%;
  left:54%;
  width:90px;
  height:90px;
  transform:translate(-50%,-50%) rotate(-12deg);
  z-index:4;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.3));
  animation: starSpin 18s linear infinite;
}

@keyframes starSpin{
  from{transform:translate(-50%,-50%) rotate(-12deg)}
  to{transform:translate(-50%,-50%) rotate(348deg)}
}

/* -------- BAŞLIK -------- */
.title-block{
  position:absolute;
  bottom:30px;
  left:0;
  right:auto;
  width:auto;
  z-index:5;
}

.discover{
  font-family:'Archivo';
  font-weight:900;
  font-size:clamp(54px, 7vw, 92px);
  line-height:.9;
  color:var(--ink);
  letter-spacing:-2px;
  display:flex;
  flex-direction:column;
}
.word{
  display:inline-block;
  opacity:0;
  transform: translateY(30px) skewY(4deg);
  animation: wordIn .8s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay: var(--d);
}
@keyframes wordIn{
  to{opacity:1; transform:translateY(0) skewY(0)}
}

.festival-script{
  font-family:'Dancing Script', cursive;
  font-weight:700;
  font-size:clamp(56px, 7vw, 96px);
  color:var(--red-script);
  display:inline-block;
  transform: translate(40px, -18px) rotate(-4deg);
  position:relative;
  opacity:0;
  animation: scriptIn 1s cubic-bezier(.2,.7,.2,1) .7s forwards;
  text-shadow: 0 4px 18px rgba(255,22,51,.25);
}
@keyframes scriptIn{
  to{opacity:1; transform:translate(40px, -18px) rotate(-4deg)}
}
.festival-script::before{
  content:"";
  position:absolute;
  left:0; bottom:8px;
  width:0;
  height:3px;
  background: var(--red-script);
  animation: underline 1s ease-out 1.4s forwards;
}
@keyframes underline{
  to{width:60%}
}

/* Nazar */
.evil-eye{
  position:absolute;
  bottom:-30px;
  left:200px;
  width:62px;
  height:62px;
  opacity:0;
  animation: eyeIn .6s cubic-bezier(.5,1.6,.4,1) 1.6s forwards, eyeFloat 5s ease-in-out 2.2s infinite;
  filter: drop-shadow(0 6px 12px rgba(10,61,138,.4));
  cursor:pointer;
  transition: transform .3s ease;
}
.evil-eye:hover{
  transform: scale(1.15) rotate(15deg);
}
@keyframes eyeIn{
  from{opacity:0; transform:scale(0)}
  to{opacity:1; transform:scale(1)}
}
@keyframes eyeFloat{
  0%,100%{transform: translateY(0) rotate(-6deg)}
  50%{transform: translateY(-10px) rotate(6deg)}
}

/* -------- BYLINE -------- */
.byline{
  position:relative;
  z-index:2;
  text-align:center;
  padding:24px 0 40px;
  font-size:12px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--ink);
  opacity:.55;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}
.dot{
  width:6px;
  height:6px;
  background:var(--red-flag);
  border-radius:50%;
}

/* -------- RESPONSIVE -------- */
@media (max-width: 900px){
  .poster{
    grid-template-columns: 1fr;
    padding: 24px 18px 60px;
  }
  .info-card{
    max-width:none;
  }
  .tags{font-size:32px}
  .location{font-size:28px}
  .kaskon-badge{margin-top:0}
  .hero{
    grid-column:1;
    grid-row:auto;
    min-height: auto;
  }
  .d-shape{
    width:min(90vw, 440px);
    height:min(90vw, 440px);
    margin: 30px auto 0;
    border-radius: 50% 50% 50% 12px;
  }
  .title-block{
    position:relative;
    bottom:auto;
    margin-top:24px;
    text-align:center;
  }
  .discover{align-items:center}
  .festival-script{transform: translate(0, -10px) rotate(-4deg)}
  .evil-eye{
    left:50%;
    bottom:-46px;
    transform:translateX(-50%);
  }
}
