/* === ORBIS — PAPER ORBIT THEME ===
   Jedyny aktywny motyw. Poprzednie wersje (Bauhaus Dark, Bauhaus Light) usunięte.
   Refaktoryzacja: Faza 0, 2026-05-27
*/

/* ── ZMIENNE ── */
:root{
  --paper:#f7f4ee;
  --paper-warm:#f1ede4;
  --ink:#121212;
  --ink-soft:rgba(18,18,18,.68);
  --line:#d8d5cc;
  --line-strong:#bdb9ad;
  --sage:#718a78;
  --blue-action:#2e86c1;
  --ochre:#d2b34c;
  --rust:#b4573d;
  --clay:#c57c45;
  --violet-action:#9b59b6;
  --plum:#76617b;
  --world-accent:#b4573d;
}

/* ── RESET ── */
html,body{
  background:var(--paper) !important;
  color:var(--ink) !important;
}

*{ text-shadow:none !important; }

button{ font-family:'Syne',system-ui,sans-serif !important; }

/* ── TŁO — ukryj elementy poprzedniego motywu ── */
#gradient-bg,.blob,#particles,#nebula{
  display:none !important;
}

/* ── APP ── */
#app{
  background:var(--paper) !important;
  border:1px solid var(--ink) !important;
  border-radius:18px !important;
  box-shadow:14px 16px 0 rgba(18,18,18,.18) !important;
}

/* ── HEADER ── */
#header,#scene,#hud,#tray{
  background:var(--paper) !important;
  color:var(--ink) !important;
}

#header{
  height:44px !important;
  border-bottom:1px solid var(--line-strong) !important;
  padding:0 18px !important;
}

#tool-actions{
  display:flex !important;
  align-items:center !important;
  flex-shrink:0 !important;
  gap:8px !important;
}

#lvl-nav-label,#stars-badge,#badge-quality,#meta{
  color:var(--ink) !important;
}

#lvl-nav-label{
  font-family:'DM Mono',monospace !important;
  font-size:12px !important;
  letter-spacing:1.5px !important;
}

/* Przyciski nagłówka */
.lvl-arrow,#dbg-btn,#btn-reset-top,#btn-hint-top{
  width:36px !important;
  height:36px !important;
  border:0 !important;
  border-radius:50% !important;
  background:transparent !important;
  color:var(--ink) !important;
  box-shadow:none !important;
  font-family:'DM Mono',monospace !important;
  font-weight:800 !important;
  cursor:pointer !important;
}

.lvl-arrow:hover,#dbg-btn:hover,#btn-reset-top:hover,#btn-hint-top:hover{
  background:rgba(18,18,18,.06) !important;
}

/* "Nowy układ" — wyraźnie inny od resetu: obramowanie, kolor akcji */
#btn-new-layout{
  height:30px !important;
  padding:0 10px !important;
  border:1.5px solid var(--ink) !important;
  border-radius:6px !important;
  background:transparent !important;
  color:var(--ink) !important;
  box-shadow:none !important;
  font-family:'DM Mono',monospace !important;
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:0.5px !important;
  cursor:pointer !important;
  opacity:0.75 !important;
  white-space:nowrap !important;
}
#btn-new-layout:hover{
  opacity:1 !important;
  background:rgba(18,18,18,.06) !important;
}

/* Badge gwiazdek */
#stars-badge{ cursor:pointer !important; }

/* ── PASEK POSTĘPU ŚWIATA ── */
#hud-progress-bar{
  background:transparent !important;
  border-bottom:0 !important;
}

#hud-progress-fill{
  background:var(--ochre) !important;
}

/* ── HUD / TRAY ── */
#hud{
  border-left:1px solid var(--line-strong) !important;
}

#tray{
  padding:22px 16px 12px !important;
  gap:18px !important;
}

/* ── KARTY KLOCKÓW ── */
.tc{
  height:72px !important;
  min-height:72px !important;
  padding:0 !important;
  background:transparent !important;
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  opacity:.98 !important;
  animation:none !important;
  transition:opacity .14s ease, transform .14s ease !important;
}

.tc canvas,.tc.action-tile canvas{
  width:128px !important;
  height:58px !important;
}

.tc:not(.hit-slot):hover,
.tc:not(.hit-slot).sel,
.tc:not(.hit-slot):active{
  background:transparent !important;
  outline:0 !important;
  box-shadow:none !important;
}

.tc:active{
  transform:scale(.985) !important;
}

.tc.dragging-origin{
  visibility:hidden !important;
  pointer-events:none !important;
}

.tc.used{
  display:none !important;
}

.tc.hit-slot{
  background:rgba(180,87,61,.06) !important;
  outline:1px solid rgba(180,87,61,.55) !important;
  outline-offset:4px !important;
}

.tc.action-tile{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
}

.tc.action-tile::before{
  content:none !important;
  display:none !important;
}

.tc-info{
  position:absolute !important;
  right:7px !important;
  top:6px !important;
  width:15px !important;
  height:15px !important;
  border:1px solid rgba(18,18,18,.28) !important;
  border-radius:50% !important;
  color:rgba(18,18,18,.54) !important;
  background:var(--paper) !important;
  font-family:'DM Mono',monospace !important;
  font-size:9px !important;
  line-height:14px !important;
  text-align:center !important;
  pointer-events:auto !important;
}

.tc-info:hover{
  color:var(--paper) !important;
  background:var(--ink) !important;
  border-color:var(--ink) !important;
}

/* Wlot klocków */
@keyframes traySlideIn{
  from{ opacity:0; transform:translateX(18px); }
  to{   opacity:1; transform:translateX(0); }
}
.tc-enter{
  animation:traySlideIn .22s ease-out forwards;
}

/* ── PRZYCISK PLAY ── */
/* Pozycja (left/top) ustawiana wyłącznie przez JS w resize() */
/* Domyślnie niewidoczny — pojawia się TYLKO gdy wszystkie klocki ułożone (.ready) */
#btn-play-top{
  position:absolute !important;
  z-index:16 !important;
  width:56px !important;
  height:56px !important;
  border:2px solid var(--ink) !important;
  border-radius:50% !important;
  background:var(--paper) !important;
  color:var(--ink) !important;
  box-shadow:0 0 0 6px rgba(210,179,76,.28) !important;
  font-size:25px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer !important;
  opacity:0 !important;
  pointer-events:none !important;
  transition:opacity .22s ease !important;
}

#btn-play-top:hover{
  background:#fffdf7 !important;
  box-shadow:0 0 0 8px rgba(210,179,76,.38) !important;
}

#btn-play-top:active{
  transform:scale(.96) !important;
}

#btn-play-top.ready{
  opacity:1 !important;
  pointer-events:auto !important;
  animation:playReadyPulse 1.05s ease-in-out infinite !important;
}

@keyframes playReadyPulse{
  0%,100%{
    transform:scale(1);
    box-shadow:0 0 0 5px rgba(210,179,76,.22);
  }
  50%{
    transform:scale(1.06);
    box-shadow:0 0 0 11px rgba(210,179,76,.36);
  }
}

/* ── ANIMACJE SCENY ── */
@keyframes playPulseRing{
  from{ box-shadow:0 0 0 0 rgba(210,179,76,.58); }
  to{ box-shadow:0 0 0 18px rgba(210,179,76,0); }
}
#scene.play-pulse{ animation:playPulseRing .38s ease-out 1 !important; }

@keyframes trackReadyPulse{
  0%{ box-shadow:inset 0 0 0 0 rgba(18,18,18,0); }
  35%{ box-shadow:inset 0 0 0 1px rgba(18,18,18,.18); }
  100%{ box-shadow:inset 0 0 0 0 rgba(18,18,18,0); }
}
#scene.track-ready{ animation:trackReadyPulse .82s ease-out 1 !important; }

@keyframes trackWinPulse{
  0%{ box-shadow:inset 0 0 0 0 rgba(210,179,76,0); }
  32%{ box-shadow:inset 0 0 0 2px rgba(210,179,76,.32); }
  100%{ box-shadow:inset 0 0 0 0 rgba(210,179,76,0); }
}
#scene.track-win{ animation:trackWinPulse .82s ease-out 1 !important; }

#scene{
  box-shadow:inset -1px 0 0 var(--line) !important;
}

.slot-spring,#scene.play-pulse,#scene.track-ready,#scene.track-win{
  filter:none !important;
}

/* ── GWIAZDKA I SLOT SPRING ── */
@keyframes starPop{
  0%{ transform:scale(1); }
  40%{ transform:scale(1.45); }
  100%{ transform:scale(1); }
}
#sc.star-pop{ display:inline-block; animation:starPop .28s cubic-bezier(.34,1.56,.64,1) forwards; }

@keyframes slotSpring{
  0%{ transform:scale(1); }
  35%{ transform:scale(1.12); }
  65%{ transform:scale(0.95); }
  100%{ transform:scale(1); }
}
.slot-spring{ animation:slotSpring .32s cubic-bezier(.34,1.56,.64,1) forwards !important; }

/* ── OVERLAYS (LEVEL COMPLETE / WORLD SELECT) ── */
#overlay,#world-select,#onboarding,#mechanic-info{
  background:var(--paper) !important;
  color:var(--ink) !important;
}

#overlay.show,#world-select.show{
  display:flex !important;
}

/* B6 FIX: 04-visuals.css ustawia #overlay{position:relative} — nadpisujemy */
#overlay{ position:absolute !important; inset:0 !important; }

#ov-ttl,#ov-ttl.win,#ws-title,#onboarding-title{
  color:var(--ink) !important;
}

#ov-ttl{
  font-size:28px !important;
  letter-spacing:4px !important;
}

#ov-ttl.lose{
  color:var(--rust) !important;
}

#ov-sub,#ov-progress-label,.ov-cond-lbl,
#ov-progress-nums,#ov-quality-nums,#ov-quality-hint,
#ws-total-label{
  color:var(--ink-soft) !important;
}

#ov-progress-bar,#ov-quality-bar{
  background:rgba(18,18,18,.10) !important;
}

#ov-progress-fill,#ov-quality-fill{
  background:var(--world-accent,var(--sage)) !important;
}

.ov-star.earned,#ws-total-stars,.ws-world-stars{
  color:var(--ochre) !important;
}

.ov-star.empty{
  color:rgba(18,18,18,.18) !important;
}

#ov-btn,#ov-btn-worlds,#mechanic-ok{
  border:1px solid var(--ink) !important;
  border-radius:6px !important;
  background:var(--paper) !important;
  color:var(--ink) !important;
  box-shadow:none !important;
}

#ov-btn:hover,#ov-btn-worlds:hover,#mechanic-ok:hover{
  background:rgba(18,18,18,.06) !important;
}

/* ── WORLD SELECT — PEŁNOEKRANOWA ORBITA ── */
/* position:absolute inset:0 pochodzi z 03-overlays.css — NIE nadpisujemy */
#world-select{
  padding:0 !important;
  gap:0 !important;
  overflow:hidden !important;
}

/* SVG wypełnia PEŁNĄ szerokość world-select — eliminuje 82px offset daily */
#ws-orbit-svg{
  position:absolute !important;
  top:0 !important; left:0 !important; bottom:0 !important; right:0 !important;
  width:100% !important;
  height:100% !important;
  display:block !important;
  cursor:grab !important;
  overflow:visible !important;
}

/* #ws-bottom nieużywany — dzienna kulka jest teraz w SVG (top-left) */
#ws-bottom,#ws-worlds{
  display:none !important;
}

/* Bottom area: hint + dzienna */
#ws-bottom, #ws-worlds{
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  gap:6px !important;
  width:100% !important;
  max-width:480px !important;
  padding:0 16px !important;
}
.ws-hint{
  font-family:'DM Mono',monospace !important;
  font-size:9px !important;
  letter-spacing:1px !important;
  color:var(--ink-soft) !important;
  text-align:center !important;
}

/* Karta Dziennej Orbity — HTML, pełna szerokość, duże tap targety */
.ws-daily-row{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  width:100% !important;
  padding:9px 14px !important;
  border:1px solid rgba(210,179,76,0.38) !important;
  background:rgba(210,179,76,0.04) !important;
  cursor:pointer !important;
  border-radius:6px !important;
  min-height:44px !important;
}
.ws-daily-row.done{
  border-color:rgba(113,138,120,0.40) !important;
  background:rgba(113,138,120,0.04) !important;
  cursor:default !important;
}
.ws-daily-row.locked{
  border-color:rgba(18,18,18,0.10) !important;
  background:transparent !important;
  cursor:default !important;
  opacity:0.55 !important;
}
.ws-daily-icon{
  font-size:14px !important;
  color:var(--ochre) !important;
  flex-shrink:0 !important;
}
.ws-daily-row.done .ws-daily-icon{ color:var(--sage) !important; }
.ws-daily-label{
  font-family:'Syne',sans-serif !important;
  font-weight:800 !important;
  font-size:11px !important;
  letter-spacing:2px !important;
  color:var(--ink) !important;
  flex:1 !important;
}
.ws-daily-date{
  font-family:'DM Mono',monospace !important;
  font-size:9px !important;
  color:var(--ink-soft) !important;
  flex-shrink:0 !important;
}
.ws-daily-action{
  font-family:'DM Mono',monospace !important;
  font-size:9px !important;
  letter-spacing:1px !important;
  color:var(--ochre) !important;
  flex-shrink:0 !important;
}
.ws-daily-row.done .ws-daily-action{ color:var(--sage) !important; }
.ws-daily-row.locked .ws-daily-action{ color:var(--ink-soft) !important; }

.ws-world{
  background:var(--paper) !important;
  border:1px solid var(--line-strong) !important;
  border-radius:8px !important;
  box-shadow:none !important;
  color:var(--ink) !important;
}

.ws-world.active{
  border-color:var(--ink) !important;
  border-left:7px solid var(--world-accent,var(--sage)) !important;
  box-shadow:none !important;
}

.ws-world:hover:not(.locked){
  background:#fffdf7 !important;
}

.ws-world.locked{
  opacity:.58 !important;
}

.ws-world-num{ color:rgba(18,18,18,.45) !important; }
.ws-world-name{ color:var(--ink) !important; }
.ws-world-desc{ color:rgba(18,18,18,.50) !important; font-style:italic !important; }
.ws-world-state,.ws-lvl-legend,.ws-unlock-cond,.ws-quality-hint{ color:var(--ink-soft) !important; }
.ws-world-dot{ background:var(--world-accent,var(--sage)) !important; }
.ws-unlock-cond{ color:rgba(18,18,18,.55) !important; font-style:italic !important; }

.ws-lvl-dot{ background:rgba(18,18,18,.10) !important; border-color:rgba(18,18,18,.18) !important; }
.ws-lvl-dot.partial{ background:rgba(210,179,76,.50) !important; border-color:rgba(210,179,76,.85) !important; }
.ws-lvl-dot.quality{ background:var(--ochre) !important; border-color:var(--ink) !important; }

/* Completion bar — Paper Orbit */
.ws-completion-bar{ background:rgba(18,18,18,.10) !important; }
.ws-completion-fill{ background:var(--world-accent,var(--sage)) !important; }
.ws-completion-nums{ color:rgba(18,18,18,.42) !important; }

/* Daily card — Paper Orbit */
.ws-daily{ border-color:rgba(210,179,76,.45) !important; background:rgba(210,179,76,.04) !important; }
.ws-daily-name{ color:var(--ink) !important; }
.ws-daily-date{ color:rgba(18,18,18,.42) !important; }
.ws-daily-status{ color:var(--ochre) !important; }
.ws-daily-status.done{ color:var(--sage) !important; }
.ws-daily-icon{ color:var(--ochre) !important; }
.ws-daily-streak{ color:rgba(18,18,18,.45) !important; }

/* Header world select — Paper Orbit */
#ws-header-title{ color:var(--ink) !important; }
#ws-header-stars{ color:var(--ochre) !important; }

/* ── ONBOARDING ── */
#onboarding{
  align-items:center !important;
  justify-content:center !important;
  background:var(--paper) !important;
}

#onboarding-card{
  width:min(800px,86%) !important;
  grid-template-columns:390px 1fr !important;
  gap:46px !important;
  background:transparent !important;
  color:var(--ink) !important;
  border:0 !important;
  box-shadow:none !important;
  display:grid !important;
  align-items:center !important;
}

#ob-hero{
  min-height:300px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

#ob-orbit-art{
  width:100% !important;
  max-width:380px !important;
  height:auto !important;
  overflow:visible !important;
}

#onboarding-title{
  font-size:50px !important;
  letter-spacing:9px !important;
  color:var(--ink) !important;
  font-weight:900 !important;
  line-height:.92 !important;
  margin:0 0 14px !important;
}

#onboarding-sub{
  color:var(--ink-soft) !important;
  font-family:'DM Mono',monospace !important;
  font-size:11px !important;
  letter-spacing:1.7px !important;
  margin:0 0 26px !important;
}

#onboarding-rules{
  display:flex !important;
  flex-direction:column !important;
  gap:9px !important;
  margin:0 0 28px !important;
}

.ob-rule{
  display:flex !important;
  align-items:flex-start !important;
  gap:12px !important;
  color:var(--ink-soft) !important;
  font-family:'DM Mono',monospace !important;
  font-size:10px !important;
  line-height:1.45 !important;
}

.ob-step{
  width:18px !important;
  height:18px !important;
  flex:0 0 18px !important;
  margin-top:0 !important;
  border:1px solid var(--ink) !important;
  border-radius:3px !important;
  background:var(--ink) !important;
  color:var(--paper) !important;
  font-family:'DM Mono',monospace !important;
  font-size:10px !important;
  font-weight:700 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex-shrink:0 !important;
}

#ob-btn{
  width:auto !important;
  min-width:190px !important;
  padding:13px 24px !important;
  border:1px solid var(--ink) !important;
  border-radius:6px !important;
  background:var(--ink) !important;
  color:var(--paper) !important;
  font-family:'Syne',sans-serif !important;
  font-size:13px !important;
  font-weight:900 !important;
  letter-spacing:4px !important;
  box-shadow:8px 8px 0 rgba(210,179,76,.72) !important;
  cursor:pointer !important;
  transition:transform .14s ease, box-shadow .14s ease, background .14s ease !important;
}

#ob-btn::after{ content:' ->' !important; }

#ob-btn:hover{
  background:#000 !important;
  box-shadow:10px 10px 0 rgba(210,179,76,.82) !important;
}

#ob-btn:active{
  transform:translate(2px,2px) !important;
  box-shadow:4px 4px 0 rgba(210,179,76,.9) !important;
}

/* Onboarding SVG */
.ob-guide{ fill:none !important; stroke:rgba(18,18,18,.20) !important; stroke-width:2 !important; }
.ob-track{ fill:none !important; stroke-linecap:round !important; stroke-linejoin:round !important; }
.ob-track-white-ring{ stroke:var(--ink) !important; stroke-width:9 !important; stroke-dasharray:20 2 15 2 18 2 14 2 19 6 !important; }
.ob-track-blue-ring{ fill:none !important; stroke:var(--sage) !important; stroke-width:9 !important; stroke-dasharray:13 87 !important; stroke-dashoffset:8 !important; animation:obBlueRing 4.8s ease-in-out infinite !important; }
.ob-ghost-ring{ fill:none !important; stroke:var(--ochre) !important; stroke-width:3 !important; stroke-dasharray:12 88 !important; stroke-dashoffset:74 !important; opacity:.68 !important; animation:obGhostPulse 2.4s ease-in-out infinite !important; }
.ob-slot{ fill:var(--paper) !important; stroke:var(--ink) !important; stroke-width:2.5 !important; }
.ob-runner{ fill:var(--paper) !important; transform-origin:260px 176px !important; animation:obRunnerSpin 4.8s linear infinite !important; }
.ob-star-dot{ fill:var(--ochre) !important; }
.ob-star{ fill:var(--ink) !important; }
.ob-danger{ fill:var(--rust) !important; }
.ob-danger-x{ fill:none !important; stroke:var(--ink) !important; stroke-width:3.4 !important; stroke-linecap:round !important; }
.ob-orbit-spin{ transform-origin:260px 176px !important; animation:obOrbitSpin 16s linear infinite !important; }

@keyframes obOrbitSpin{ from{ transform:rotate(0deg); } to{ transform:rotate(360deg); } }
@keyframes obRunnerSpin{ from{ transform:rotate(0deg); } to{ transform:rotate(360deg); } }
@keyframes obBlueRing{
  0%,20%{ stroke-dasharray:0 100; opacity:.35; }
  42%,78%{ stroke-dasharray:13 87; opacity:1; }
  100%{ stroke-dasharray:0 100; opacity:.35; }
}
@keyframes obGhostPulse{
  0%,100%{ opacity:.32; }
  50%{ opacity:.9; }
}

@media (max-width:820px){
  #onboarding-card{
    width:min(520px,84vw) !important;
    grid-template-columns:1fr !important;
    gap:4px !important;
  }
  #ob-hero{ min-height:180px !important; }
  #ob-orbit-art{ max-width:250px !important; }
  #onboarding-title{ font-size:36px !important; letter-spacing:6px !important; }
  #ob-btn{ width:100% !important; }
}

/* ── MECHANIC CARD / TOAST ── */
#mechanic-card,.action-tutorial-modal>div{
  background:var(--paper) !important;
  color:var(--ink) !important;
  border:1px solid var(--ink) !important;
  border-radius:8px !important;
  box-shadow:10px 10px 0 rgba(18,18,18,.16) !important;
}

#game-toast{
  background:var(--paper) !important;
  color:var(--ink) !important;
  border:1px solid var(--ink) !important;
  border-radius:6px !important;
  box-shadow:8px 8px 0 rgba(18,18,18,.14) !important;
  backdrop-filter:none !important;
}

/* ── ELEMENTY WYŁĄCZONE ── */
#xray-semi,#peek-overlay,#btn-peek{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

/* Ukryj RENTGEN gdy overlay lub world-select jest aktywny */
#app:has(#overlay.show) #xray-semi,
#app:has(#world-select.show) #xray-semi,
#app:has(#onboarding:not(.hidden)) #xray-semi{
  visibility:hidden;
  pointer-events:none;
}
