/* ═══════════════════════════════════════════════════════
   SUNSET DRIVE — dagdelean Portfolyo
   Tek tema, sıfır inline stil (sıkı CSP uyumlu)
   ═══════════════════════════════════════════════════════ */

:root{
  --sky-a:#3b1d60; --sky-b:#ff5e8a; --sky-c:#ffb24c;
  --grid:#ff3d9e; --glow:#ff77b8; --sun-cut:#ff5e8a;
  --ink:#0d0820; --panel:rgba(13,8,32,.85); --pix:#ff77b8;
  --cyan:#53f5ff; --gold:#ffd23f; --green:#5dff8a; --txt:#fdeaff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'VT323',monospace;font-size:20px;line-height:1.5;
  color:var(--txt);background:var(--ink);overflow-x:hidden;
  -webkit-text-size-adjust:100%;
}
a{color:inherit;text-decoration:none}
::selection{background:var(--cyan);color:var(--ink)}
.psans{font-family:'Pixelify Sans',sans-serif}
.dim{color:#b89fd6}

/* erişilebilirlik */
.skip{position:fixed;top:-60px;left:12px;z-index:999;background:var(--gold);color:var(--ink);
  font-family:'Pixelify Sans',sans-serif;font-weight:700;padding:10px 18px;transition:top .2s}
.skip:focus{top:12px}
a:focus-visible,[role="button"]:focus-visible{outline:3px dashed var(--cyan);outline-offset:3px}
.noscript-note{position:relative;z-index:50;background:var(--gold);color:var(--ink);
  font-family:'Pixelify Sans',sans-serif;text-align:center;padding:12px 16px}
/* JS yokken title/hud engel olmasın */
.no-js #title,.no-js #hud{display:none}
.no-js .rev{opacity:1;transform:none}
.no-js .bar i{width:80%}

/* ════════ SAHNE ════════ */
#scene{position:fixed;inset:0;z-index:0;overflow:hidden;
  background:linear-gradient(var(--sky-a) 0%,var(--sky-b) 52%,var(--sky-c) 66%)}
#stars{position:absolute;inset:0;opacity:0}
#stars i{position:absolute;width:3px;height:3px;background:#fff;animation:tw 2.6s ease-in-out infinite}
@keyframes tw{50%{opacity:.2}}
#sun{position:absolute;left:50%;bottom:33vh;transform:translateX(-50%);
  width:min(46vh,340px);height:min(46vh,340px);border-radius:50%;
  background:linear-gradient(#fff6c8 0%,var(--gold) 28%,#ff7a59 62%,#ff3d9e 100%);
  box-shadow:0 0 90px 18px rgba(255,160,110,.55)}
#sun::after{content:"";position:absolute;inset:0;border-radius:50%;
  background:repeating-linear-gradient(180deg,transparent 0 26px,var(--sun-cut) 26px 34px);
  -webkit-mask:linear-gradient(transparent 35%,#000 36%);mask:linear-gradient(transparent 35%,#000 36%)}
.mtn{position:absolute;bottom:32vh;left:0;right:0;height:22vh}
.mtn.m1{background:#241147;clip-path:polygon(0 100%,0 62%,6% 62%,6% 44%,13% 44%,13% 58%,20% 58%,20% 36%,27% 36%,27% 52%,34% 52%,34% 64%,42% 64%,42% 48%,50% 48%,50% 70%,58% 70%,58% 40%,65% 40%,65% 56%,72% 56%,72% 30%,80% 30%,80% 50%,88% 50%,88% 62%,95% 62%,95% 46%,100% 46%,100% 100%)}
.mtn.m2{background:#170b38;height:15vh;clip-path:polygon(0 100%,0 70%,8% 70%,8% 52%,17% 52%,17% 66%,28% 66%,28% 44%,38% 44%,38% 60%,49% 60%,49% 72%,60% 72%,60% 50%,70% 50%,70% 64%,81% 64%,81% 42%,90% 42%,90% 58%,100% 58%,100% 100%)}
#floor{position:absolute;left:0;right:0;bottom:0;height:33vh;perspective:240px;perspective-origin:50% 0;
  background:var(--ink);overflow:hidden}
#gridplane{position:absolute;left:-70%;right:-70%;top:-8px;height:340%;
  transform:rotateX(74deg);transform-origin:50% 0;
  background:
    repeating-linear-gradient(90deg,var(--grid) 0 3px,transparent 3px 86px),
    repeating-linear-gradient(0deg,var(--grid) 0 3px,transparent 3px 64px);
  animation:gmove 1s linear infinite}
@keyframes gmove{to{background-position:0 64px,0 64px}}
#horizon{position:absolute;left:0;right:0;bottom:33vh;height:4px;background:var(--glow);
  box-shadow:0 0 26px 6px var(--glow);z-index:2}

/* sprite'lar */
.sprite{position:relative;display:block}
.scene-sprite{position:absolute}
.sp-px{position:absolute;top:0;left:0;width:1px;height:1px}
#car{left:max(4vw,30px);bottom:calc(33vh - 86px);z-index:6;animation:carbob .55s steps(2) infinite}
@keyframes carbob{50%{transform:translateY(3px)}}
#palmL{left:2vw;bottom:33vh;z-index:3;transform-origin:bottom center;animation:sway 5s ease-in-out infinite}
#palmR{right:3vw;bottom:33vh;z-index:3;transform:scaleX(-1);transform-origin:bottom center;animation:sway 6s ease-in-out infinite reverse}
@keyframes sway{50%{rotate:2.2deg}}

/* CRT */
#crt{position:fixed;inset:0;z-index:90;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 2px,transparent 2px 4px)}
#crt::after{content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 58%,rgba(0,0,0,.42))}

/* ════════ TITLE SCREEN ════════ */
#title{position:fixed;inset:0;z-index:500;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:26px;cursor:pointer;text-align:center;padding:20px;border:none;
  background:linear-gradient(#1c0d3e 0%,#ff5e8a 60%,#ffb24c 78%,#1c0d3e 78.3%)}
#title .logo{font-family:'Pixelify Sans',sans-serif;font-weight:700;font-size:clamp(44px,9vw,104px);
  line-height:.95;color:var(--gold);letter-spacing:.02em;
  text-shadow:0 4px 0 #c43e85,0 8px 0 #57156b,0 14px 24px rgba(0,0,0,.5)}
#title .logo span{display:block;color:#fff;font-size:.42em;letter-spacing:.3em;text-shadow:0 3px 0 #c43e85}
#title .press{font-family:'Press Start 2P',monospace;font-size:clamp(10px,2vw,15px);color:#fff;
  animation:blink 1.1s steps(1) infinite;margin-top:10px}
#title .coin{font-size:19px;color:#ffd9f1;opacity:.85}
#title .rom{position:absolute;bottom:22px;left:0;right:0;font-size:16px;color:#ffd9f1;opacity:.6}
@keyframes blink{50%{opacity:0}}
#title.bye{animation:titleout .5s steps(6) forwards}
@keyframes titleout{to{opacity:0;visibility:hidden}}

/* ════════ HUD ════════ */
#hud{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;justify-content:space-between;
  align-items:center;gap:10px;padding:10px 16px;
  font-family:'Press Start 2P',monospace;font-size:10px;color:#fff;text-shadow:2px 2px 0 #000;
  background:linear-gradient(rgba(13,8,32,.88),rgba(13,8,32,.55) 80%,transparent);
  transition:opacity .6s}
#hud.is-hidden{opacity:0;pointer-events:none}
#hud .lv{color:var(--gold);animation:blink 1.6s steps(1) infinite}
#hud .hearts{color:#ff4f6d;letter-spacing:2px}
.hud-gold{color:var(--gold)}

/* ════════ İÇERİK ════════ */
main{position:relative;z-index:10}
.gap{height:46vh}
.gap.big{height:62vh}
.stage{max-width:880px;margin:0 auto;padding:0 18px 18vh}

.panel{background:var(--panel);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  padding:30px 30px 34px;position:relative;
  clip-path:polygon(0 12px,6px 12px,6px 6px,12px 6px,12px 0,calc(100% - 12px) 0,calc(100% - 12px) 6px,calc(100% - 6px) 6px,calc(100% - 6px) 12px,100% 12px,100% calc(100% - 12px),calc(100% - 6px) calc(100% - 12px),calc(100% - 6px) calc(100% - 6px),calc(100% - 12px) calc(100% - 6px),calc(100% - 12px) 100%,12px 100%,12px calc(100% - 6px),6px calc(100% - 6px),6px calc(100% - 12px),0 calc(100% - 12px));
  box-shadow:inset 0 0 0 4px var(--pix)}
.panel--gold{box-shadow:inset 0 0 0 4px var(--gold)}
.panel-note{margin-top:18px}

.lvl-tag{font-family:'Press Start 2P',monospace;font-size:10px;color:var(--ink);background:var(--gold);
  display:inline-block;padding:7px 12px;margin-bottom:16px;box-shadow:4px 4px 0 rgba(0,0,0,.45)}
h1,h2{font-family:'Pixelify Sans',sans-serif;font-weight:700;font-size:clamp(30px,5vw,46px);
  line-height:1.05;color:#fff;text-shadow:3px 3px 0 #c43e85;margin-bottom:14px}
h1 .c,h2 .c{color:var(--cyan);text-shadow:3px 3px 0 #19647a}
.sub{color:#ffc9e8;font-size:21px;margin-bottom:22px}
.sub--tight{margin-bottom:14px}

/* oyuncu kartı */
.player{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start}
.avatar-box{padding:12px;background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 3px var(--cyan)}
.pinfo{font-size:19px;display:grid;gap:3px;margin-bottom:18px}
.pinfo .row{display:flex;gap:10px;flex-wrap:wrap}
.pinfo .k{color:var(--cyan);min-width:120px}
.stats{display:grid;gap:10px}
.stat .sl{display:flex;justify-content:space-between;font-size:18px;color:#ffc9e8}
.bar{height:16px;background:rgba(255,255,255,.1);box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
  margin-top:3px;position:relative}
.bar i{position:absolute;inset:2px auto 2px 2px;width:0;
  background:repeating-linear-gradient(90deg,var(--green) 0 10px,#2fae57 10px 12px);
  transition:width 1.1s steps(12)}
.bar.gold i{background:repeating-linear-gradient(90deg,var(--gold) 0 10px,#cf9c12 10px 12px)}
.bar.pink i{background:repeating-linear-gradient(90deg,#ff77b8 0 10px,#cf4f8c 10px 12px)}
.bar.cyan i{background:repeating-linear-gradient(90deg,var(--cyan) 0 10px,#2ba6b5 10px 12px)}

/* görevler */
.quests{display:grid;gap:16px;margin-top:6px}
.quest{display:grid;grid-template-columns:1fr auto;gap:8px 18px;background:rgba(255,255,255,.05);
  padding:18px 20px;box-shadow:inset 0 0 0 3px rgba(255,119,184,.5);transition:.2s}
.quest:hover{box-shadow:inset 0 0 0 3px var(--cyan);transform:translate(2px,-2px)}
.quest h3{font-family:'Pixelify Sans',sans-serif;font-weight:600;font-size:24px;color:#fff}
.quest .done{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--green);
  align-self:center;white-space:nowrap}
.quest p{grid-column:1/-1;font-size:19px;color:#dcc6f0}
.quest .meta{grid-column:1/-1;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;font-size:17px}
.quest .xp{color:var(--gold)}
.quest .go{color:var(--cyan)}
.quest .go::after{content:" ►";animation:blink 1.2s steps(1) infinite}

/* kayıtlar */
.saves{display:grid;gap:12px}
.save{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;
  background:rgba(255,255,255,.05);padding:14px 18px;box-shadow:inset 0 0 0 3px rgba(83,245,255,.35)}
.save .disk{font-size:30px}
.save b{font-family:'Pixelify Sans',sans-serif;font-weight:600;font-size:21px;color:#fff;display:block}
.save small{font-size:17px;color:#b89fd6;display:block;line-height:1.4}
.save .yr{font-family:'Press Start 2P',monospace;font-size:9px;color:var(--cyan);white-space:nowrap}

/* başarımlar */
.achs{display:grid;gap:12px}
.ach{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;padding:16px 18px;
  background:linear-gradient(90deg,rgba(255,210,63,.16),rgba(255,210,63,.04));
  box-shadow:inset 0 0 0 3px var(--gold)}
.ach .tr{font-size:32px;text-shadow:0 0 14px rgba(255,210,63,.8)}
.ach b{font-family:'Pixelify Sans',sans-serif;font-weight:600;font-size:21px;color:var(--gold);display:block}
.ach small{font-size:17px;color:#ecdcb0;display:block;line-height:1.4}
.ach .unlocked{font-family:'Press Start 2P',monospace;font-size:7px;color:var(--green);display:block;margin-top:4px}

/* final */
.hiscore{font-family:'Press Start 2P',monospace;font-size:11px;line-height:2.6;margin:18px 0 26px;color:#fff}
.hiscore .r1{color:var(--gold)}
.hiscore .r2{color:var(--cyan);animation:blink 1.3s steps(1) infinite}
.btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.abtn{font-family:'Pixelify Sans',sans-serif;font-weight:700;font-size:20px;color:var(--ink);
  background:var(--gold);padding:14px 24px;border:none;cursor:pointer;transition:.12s;
  box-shadow:0 6px 0 #b8860b,4px 10px 0 rgba(0,0,0,.4)}
.abtn:hover{filter:brightness(1.08)}
.abtn:active{transform:translateY(5px);box-shadow:0 1px 0 #b8860b,2px 4px 0 rgba(0,0,0,.4)}
.abtn.c{background:var(--cyan);box-shadow:0 6px 0 #1d7c8a,4px 10px 0 rgba(0,0,0,.4)}
.abtn.c:active{box-shadow:0 1px 0 #1d7c8a,2px 4px 0 rgba(0,0,0,.4)}
.abtn.p{background:var(--pix);box-shadow:0 6px 0 #a8447c,4px 10px 0 rgba(0,0,0,.4)}
.abtn.p:active{box-shadow:0 1px 0 #a8447c,2px 4px 0 rgba(0,0,0,.4)}
.abtn.g{background:var(--green);box-shadow:0 6px 0 #2c8a4c,4px 10px 0 rgba(0,0,0,.4)}
.abtn.g:active{box-shadow:0 1px 0 #2c8a4c,2px 4px 0 rgba(0,0,0,.4)}
.continue{margin-top:30px;font-family:'Press Start 2P',monospace;font-size:10px;color:#ffc9e8}
.continue b{color:var(--gold);font-size:14px}

footer{position:relative;z-index:10;text-align:center;padding:20px 16px 26px;
  font-size:17px;color:#cbb3e6;text-shadow:1px 1px 0 #000}
footer a{text-decoration:underline}

/* reveal */
.rev{opacity:0;transform:translateY(22px);transition:.6s steps(8)}
.rev.in{opacity:1;transform:none}

/* ════════ 404 ════════ */
.e404{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:18px;padding:20px}
.e404 .code{font-family:'Pixelify Sans',sans-serif;font-weight:700;font-size:clamp(70px,16vw,160px);
  color:var(--gold);text-shadow:0 5px 0 #c43e85,0 10px 0 #57156b;line-height:1}
.e404 p{font-size:22px;color:#ffc9e8;max-width:440px}

/* ════════ RESPONSIVE ════════ */
@media(max-width:720px){
  body{font-size:18px}
  .gap{height:32vh}
  .gap.big{height:52vh}
  .stage{padding:0 12px 12vh}
  .panel{padding:20px 16px 24px}
  .sub{font-size:19px}
  #hud{font-size:8px;padding:8px 10px}
  .hud-hide{display:none}
  .player{grid-template-columns:1fr}
  .avatar-box{justify-self:center}
  .pinfo .k{min-width:96px}
  .quest{grid-template-columns:1fr}
  .quest .done{justify-self:start}
  .save{grid-template-columns:auto 1fr}
  .save .yr{display:none}
  #car{transform:scale(.62);transform-origin:bottom left}
  #palmR{display:none}
  .hiscore{font-size:9px}
  .abtn{font-size:18px;padding:12px 18px;flex:1;text-align:center}
}
@media(max-width:380px){
  .lvl-tag{font-size:8px}
  h1,h2{font-size:26px}
}

/* ════════ REDUCED MOTION ════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .rev{opacity:1;transform:none}
}
