/* === EMBERCREST THEME === */

:root {
  --ember:     #e8621a;
  --amber:     #f5a623;
  --gold:      #f5c842;
  --gold-dim:  #c49b2a;
  --deep-red:  #8b2500;
  --ev-black:  #0d0900;
  --ev-dark:   #1a0e00;
  --ev-surface:#2a1800;
  --ev-text:   #e8d5b0;
  --ev-muted:  #8a6a40;
}

/* ---- Base ---- */
body {
  background: var(--ev-black) !important;
  border-top: 2px solid var(--ember) !important;
}

/* ---- Grain overlay (matches home) ---- */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.035;
  mix-blend-mode: overlay;
  background-image: radial-gradient(rgba(255,255,255,0.4) 1px, transparent 1px);
  background-size: 3px 3px;
}

/* ---- Ember glow behind canvas (game state only) ---- */
body.game::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(232,98,26,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 40% 30% at 50% 85%, rgba(245,168,35,0.09) 0%, transparent 70%);
}

/* ---- Canvas border ---- */
#canvasborder {
  border-color: var(--ev-dark) !important;
  box-shadow:
    0 0 0 1px var(--gold-dim),
    0 0 40px rgba(232,98,26,0.25),
    0 0 80px rgba(232,98,26,0.10) !important;
}

/* ---- Footer ---- */
footer {
  background: rgba(13,9,0,0.92) !important;
  border-top: 1px solid var(--ember) !important;
  color: var(--ev-text) !important;
}

footer #sharing,
footer #credits-link,
footer #credits-link span,
footer #logout-link,
footer #logout-link span {
  color: var(--gold-dim) !important;
  font-family: 'Share Tech Mono', ui-monospace, monospace !important;
  letter-spacing: 0.12em;
}

footer #sharing:hover,
footer #credits-link:hover,
footer #logout-link:hover {
  color: var(--gold) !important;
}

#logout-link {
  display: none;
}

.createcharacter #logout-link,
.loadcharacter #logout-link,
.game #logout-link {
  display: inline-block !important;
}

/* ---- Ember particles container ---- */
#ember-particles {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
}

.ev-particle {
  position: absolute;
  bottom: -20px;
  border-radius: 50%;
  opacity: 0;
  animation: ev-rise linear infinite;
}

@keyframes ev-rise {
  0%   { transform: translateY(0) translateX(0) scale(0.6); opacity: 0; }
  10%  { opacity: 0.85; }
  50%  { opacity: 1; transform: translateY(-50vh) translateX(16px) scale(1); }
  100% { transform: translateY(-100vh) translateX(-8px) scale(0.3); opacity: 0; }
}

/* ---- Credits section ---- */
#seb {
  margin-top: 20px !important;
}

/* ---- Logo override ---- */

/* Kill sprite background on logo + sparks at all breakpoints */
#logo,
.upscaled #logo,
#logosparks,
.upscaled #logosparks {
  background-image: none !important;
  background: transparent !important;
}

/* Stop sparks animation, make invisible */
#logosparks {
  animation: none !important;
  -webkit-animation: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Reset fixed pixel dimensions — let text drive size */
#logo {
  width: auto !important;
  height: auto !important;
  margin-left: 0 !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 0 !important;
}

/* Embercrest logo image */
#logo::before {
  content: "";
  display: block;
  width: clamp(220px, 40vw, 480px);
  height: clamp(60px, 11vw, 130px);
  background: url('../img/common/logo-tittle.png') center / contain no-repeat;
  filter: drop-shadow(0 0 18px rgba(232,98,26,0.7)) drop-shadow(0 3px 0 rgba(0,0,0,0.8));
  animation: ev-logo-pulse 3s ease-in-out infinite !important;
  -webkit-animation: ev-logo-pulse 3s ease-in-out infinite !important;
}

@keyframes ev-logo-pulse {
  0%, 100% { filter: drop-shadow(0 0 18px rgba(232,98,26,0.7)) drop-shadow(0 3px 0 rgba(0,0,0,0.8)); }
  50%       { filter: drop-shadow(0 0 32px rgba(245,168,35,0.9)) drop-shadow(0 3px 0 rgba(0,0,0,0.8)); }
}

/* ---- Scrollbar ---- */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--ev-dark); }
::-webkit-scrollbar-thumb { background: var(--gold-dim); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--amber); }

/* ---- Selection ---- */
::selection { background: var(--ember); color: var(--ev-black); }

/* ---- Login state: strip parchment visuals ---- */
#parchment.login {
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  border: none !important;
}

#parchment.login .parchment-left,
#parchment.login .parchment-right {
  display: none !important;
}

/* parchment-middle becomes full-viewport flex center (keeps #login in DOM) */
#parchment.login .parchment-middle {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  margin: 0 !important;
  background: transparent !important;
  background-image: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 100 !important;
}

/* Hide every article inside parchment-middle EXCEPT #login */
#parchment.login .parchment-middle article:not(#login) {
  display: none !important;
}

/* ---- Show login article, centered as flex child ---- */
.login #login {
  display: flex !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* ---- Login card ---- */
#login {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  background: rgba(13,9,0,0.94) !important;
  border: 1px solid var(--gold-dim) !important;
  box-shadow: 0 0 48px rgba(232,98,26,0.2), inset 0 0 0 1px rgba(245,168,35,0.05) !important;
  padding: 36px 48px 32px !important;
  min-width: 300px !important;
  text-align: center !important;
  opacity: 0;
  pointer-events: none;
}

#login h1 {
  color: var(--gold) !important;
  font-family: 'Cinzel', serif !important;
  font-weight: 700 !important;
  font-size: 18px !important;
  letter-spacing: 0.2em !important;
  margin: 0 0 20px !important;
  text-transform: uppercase !important;
}

#login h1 .left-ornament,
#login h1 .right-ornament {
  display: none !important;
}

#loginform {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin: 0 0 8px;
  width: 100%;
}

#loginform input.stroke {
  display: block !important;
  margin: 0 !important;
  width: 100% !important;
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid var(--ev-muted) !important;
  color: var(--ev-text) !important;
  font-family: 'Share Tech Mono', monospace !important;
  font-size: 13px !important;
  padding: 8px 12px !important;
  border-radius: 0 !important;
  text-align: left !important;
  box-sizing: border-box !important;
  outline: none !important;
  animation: none !important;
}

#loginform input.stroke:focus {
  border-color: var(--amber) !important;
  background: rgba(245,168,35,0.05) !important;
  color: #fff !important;
  animation: none !important;
}

.form-error {
  color: #e84040;
  font-size: 11px;
  min-height: 14px;
  text-align: center;
  font-family: 'Share Tech Mono', monospace;
  margin: 0;
}

.auth-btn {
  display: inline-block;
  background: var(--ember);
  color: var(--ev-text);
  border: 1px solid var(--amber);
  padding: 9px 32px;
  cursor: pointer;
  font-family: 'Cinzel', serif;
  font-size: 13px;
  letter-spacing: 0.1em;
  margin: 8px 0 0;
  transition: background 0.2s, color 0.2s;
  user-select: none;
  text-transform: uppercase;
}

.auth-btn:hover {
  background: var(--amber);
  color: var(--ev-black);
}

.auth-link-row {
  margin-top: 10px;
  font-size: 11px;
  color: var(--ev-muted);
  font-family: 'Share Tech Mono', monospace;
  text-align: center;
}

.auth-link-row .link {
  color: var(--amber);
  cursor: pointer;
  text-decoration: underline;
}

.auth-link-row .link:hover {
  color: var(--gold);
}
