/* LastStand Theme — playful/joyful + consistent layout
   ใช้คู่กับ Tailwind/Bootstrap ได้ (แนะนำปิด Tailwind preflight)
   Prefix: ls-
*/

/* -------- Root Variables -------- */
:root{
  /* base */
  --ls-bg: #f8fafc;       /* gray-50 */
  --ls-surface: #ffffff;  /* white */
  --ls-border: #e5e7eb;   /* gray-200 */
  --ls-text: #111827;     /* gray-900 */
  --ls-muted: #6b7280;    /* gray-500 */

  /* playful palette */
  --ls-accent: #f97316;       /* orange-500 */
  --ls-accent-600: #ea5800;   /* orange-600 */
  --ls-accent-700: #c2410c;   /* orange-700 */
  --ls-accent-50: #fff7ed;    /* orange-50 */
  --ls-secondary: #6366f1;    /* indigo-500 */
  --ls-secondary-50: #eef2ff; /* indigo-50 */
  --ls-mint: #10b981;         /* emerald-500 */

  /* layout */
  --ls-nav-height-m: 4rem;  /* 64px */
  --ls-nav-height-d: 5rem;  /* 80px */
  --ls-container-px: 1rem;

  /* typography */
  --ls-leading: 1.6;
  --ls-prose-max: 72ch;
}

/* -------- Base -------- */
body{ background: var(--ls-bg); color: var(--ls-text); }



/* -------- Containers (max-width) -------- */
.ls-container,
.ls-container-wide,
.ls-container-narrow{
  margin-left:auto; margin-right:auto;
  padding-left:var(--ls-container-px); padding-right:var(--ls-container-px);
}

/* standard */
@media (min-width:640px){ .ls-container{ max-width:1536px; } }

/* wide (hero/dashboard) */
@media (min-width:640px){ .ls-container-wide{ max-width:1680px; } }

/* narrow (forms/reading) */
@media (min-width:640px){ .ls-container-narrow{ max-width:1024px; } }

/* full-bleed helper */
.ls-fullbleed{ width:100vw; position:relative; left:50%; right:50%; margin-left:-50vw; margin-right:-50vw; }

/* -------- Surfaces / Cards -------- */
.ls-surface{ background:var(--ls-surface); }
.ls-card{
  background:var(--ls-surface);
  border:1px solid var(--ls-border);
  border-radius:1rem; /* 16px */
  box-shadow:0 1px 2px rgba(0,0,0,.05);
}

/* playful hero gradient */
.ls-hero-card{
  background: linear-gradient(135deg, var(--ls-accent-50), var(--ls-secondary-50));
  border:1px solid var(--ls-border);
  border-radius:1rem;
  box-shadow:0 10px 24px rgba(0,0,0,.06);
}

/* -------- Carousel dots -------- */
.ls-dot{
  height:10px; width:10px; border-radius:9999px;
  border:1px solid #e5e7eb; background:#fff;
  opacity:.7; transition:transform .2s ease, opacity .2s ease, background .2s ease, box-shadow .2s ease;
}
.ls-dot.is-active{
  background:var(--ls-accent); opacity:1; transform:scale(1.15);
  box-shadow:0 0 0 4px rgba(249,115,22,.15);
}


/* -------- Heading accent -------- */
.ls-heading{
  font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--ls-text);
  position:relative; display:inline-block; padding-bottom:.35rem;
}
.ls-heading::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  bottom:0; height:3px; width:140px; border-radius:9999px;
  background:linear-gradient(90deg, var(--ls-accent), var(--ls-secondary));
}

/* -------- Date row tint -------- */
.ls-date-row{
  background:linear-gradient(90deg, var(--ls-accent-50), var(--ls-secondary-50));
  color:#374151;
}

/* -------- Nav spacer -------- */
.ls-nav-spacer{ height:var(--ls-nav-height-m); }
@media (min-width:768px){ .ls-nav-spacer{ height:var(--ls-nav-height-d); } }

/* -------- Hero sizes / Image behavior -------- */
.ls-hero-h{ height:46vw; }
@media (min-width:640px){ .ls-hero-h{ height:420px; } }
@media (min-width:1024px){ .ls-hero-h{ height:520px; } }
@media (min-width:1280px){ .ls-hero-h{ height:600px; } }

.ls-img-contain{ object-fit:contain; object-position:center; }
.ls-img-cover{ object-fit:cover; object-position:center; }

/* -------- Link glow (hover) -------- */
.ls-link-glow{
  transition: color .15s ease, text-shadow .15s ease;
}
.ls-link-glow:hover{
  text-decoration:underline;
  text-shadow:0 0 0 rgba(0,0,0,0), 0 0 12px rgba(99,102,241,.25);
}

/* -------- List row hover -------- */
.ls-row{ transition: background-color .15s ease, box-shadow .15s ease; }
.ls-row:hover{
  background:#fff;
  box-shadow:0 6px 18px rgba(99,102,241,.06);
}

/* -------- Prose -------- */
.ls-prose{ max-width:var(--ls-prose-max); line-height:var(--ls-leading); color:var(--ls-text); }
.ls-prose p{ margin:0 0 1em; }
.ls-prose h1,.ls-prose h2,.ls-prose h3{ line-height:1.25; margin:1.2em 0 .6em; }
.ls-prose ul,.ls-prose ol{ padding-left:1.25em; margin:0 0 1em; }

/* -------- Footer -------- */
.ls-footer{ background:var(--ls-surface); border-top:1px solid var(--ls-border); }

/* -------- Dark Theme (optional) -------- */
[data-theme="dark"]{
  --ls-bg:#0b0f17;
  --ls-surface:#0f172a;
  --ls-border:#1f2937;
  --ls-text:#e5e7eb;
  --ls-muted:#9ca3af;
}

.game-card {
    border-radius: 1rem;
    background: var(--card-bg);
    box-shadow: 0 4px 8px rgba(0,0,0,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.game-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.12);
}

/* ใส่ใน laststand-theme.css */
.ls-clamp-2{ display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.ls-clamp-3{ display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }

.ajaxloader{
  display: none;
}

/* Overlay ตรง base.html มีโครงไว้แล้ว */
.div-screen-blocker {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.6);
  display: none;            /* แสดงเมื่อมี .add-flex */
  z-index: 9999;
}
.div-screen-blocker.add-flex {
  display: flex; align-items: center; justify-content: center;
}
.div-disp-screen-blocker { max-width: 90vw; max-height: 90vh; }
.inv-slip-big {
  max-width: 90vw; max-height: 90vh;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}