/*
Theme Name: Surge Worlds (FSE)
Theme URI: https://surgeworlds.com/
Author: Echo (ChatGPT)
Description: Minimal FSE shell for Surge Worlds: sticky header + footer + brand background + optional light character cards.
Requires at least: 6.2
Tested up to: 6.9
Requires PHP: 7.4
Version: 0.2.6
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: surge-worlds-fse
Tags: full-site-editing, editor-style, wide-blocks
*/

:root{
  --sw-bg: #07080c;
  --sw-text: #eef2ff;
  --sw-muted: #aab3c6;
  --sw-gold: #f4c45f;
  --sw-blue: #4cc3ff;
  --sw-border: rgba(244,196,95,.25);

  --sw-card-bg: #f4f6fb;
  --sw-card-text: #0e111a;
  --sw-card-muted: #4b5563;
  --sw-card-link: #1a86ff;
  --sw-card-link-hover: #0f5fd6;
}

body {
  background: var(--sw-bg);
  color: var(--sw-text);
}

/* =========================================================
   Sticky footer layout (footer stays at bottom of viewport)
   ========================================================= */
html, body {
  height: 100%;
}
.wp-site-blocks {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.wp-site-blocks > main.wp-block-group {
  flex: 1 0 auto;
}
.wp-site-blocks > header,
.wp-site-blocks > footer {
  flex: 0 0 auto;
}

/* Sticky header */
.wp-site-blocks .sw-header{
  position: sticky;
  top: 0;
  z-index: 999;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--sw-border);
}

html { scroll-padding-top: 140px; }

/* Header logo sizing (allow bigger logo) */
.sw-header .wp-block-site-logo img{
  max-height: 88px;
  width: auto;
}
.sw-header .wp-block-site-title {
  display: none;
}

/* Scope theme link styling to header/footer only */
.sw-header a,
.sw-footer a {
  color: var(--sw-blue);
  text-decoration: none;
}
.sw-header a:hover,
.sw-footer a:hover {
  color: var(--sw-gold);
}

.sw-header .sw-links a {
  font-weight: 700;
  letter-spacing: .02em;
  white-space: nowrap;
}

/* Search styling (header only) */
.sw-header .sw-search .wp-block-search__inside-wrapper{
  border-radius: 999px;
  padding: 2px;
  border: 1px solid rgba(76,195,255,.35);
  background: rgba(7,8,12,.55);
}
.sw-header .sw-search input.wp-block-search__input{
  border: 0;
  background: transparent;
  color: var(--sw-text);
  padding-left: 12px;
  min-width: 240px;
}
.sw-header .sw-search button.wp-block-search__button{
  border-radius: 999px;
}

/* Character cards (opt-in) */
.surge-character-cards .card,
.surge-character-cards .character-card,
.surge-character-cards .sw-card,
.surge-character-cards .MuiCard-root,
.surge-character-cards [class*="card"] {
  background: var(--sw-card-bg);
  color: var(--sw-card-text);
  border-radius: 12px;
  padding: 16px 18px;
  box-shadow: 0 4px 12px rgba(0,0,0,.15), 0 1px 2px rgba(0,0,0,.08);
  transition: transform .12s ease, box-shadow .12s ease;
}
.surge-character-cards .card:hover,
.surge-character-cards .character-card:hover,
.surge-character-cards .sw-card:hover,
.surge-character-cards .MuiCard-root:hover,
.surge-character-cards [class*="card"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.12);
}
.surge-character-cards a {
  color: var(--sw-card-link);
  font-weight: 600;
}
.surge-character-cards a:hover {
  color: var(--sw-card-link-hover);
}
.surge-character-cards button,
.surge-character-cards .button,
.surge-character-cards .btn {
  background: var(--sw-card-link);
  color: #ffffff;
  border-radius: 8px;
  border: none;
  padding: 8px 12px;
  font-weight: 700;
}
.surge-character-cards button:hover,
.surge-character-cards .button:hover,
.surge-character-cards .btn:hover {
  background: var(--sw-card-link-hover);
}
