/* Home page styling for Survival Fantasy – Roguelike PRO (pl-PL) */
:root {
  --home-accent: #8f6cff;
  --home-bg: #0d0f14;
  --home-bg-alt: #12151c;
  --home-text: #e4e7ef;
  --home-muted: #b8bfd1;
  --home-border: #2a2f3a;
  --home-success: #39c07f;
}

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

.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); border: 0; }

.home-wrap { max-width: 1200px; margin: 0 auto; padding: 2rem 1rem; }

.home-hero { position: relative; overflow: clip; border-bottom: 1px solid var(--home-border); background: linear-gradient(180deg, rgba(18,21,28,0.8), rgba(13,15,20,1)); }
.home-hero__content { padding-top: 1rem; padding-bottom: 1rem; }
.home-hero .home-kicker { color: var(--home-muted); letter-spacing: .08em; text-transform: uppercase; font-size: .875rem; margin: 0 0 .5rem; }
.home-hero h1 { font-size: clamp(1.8rem, 2.6vw + 1rem, 3rem); margin: .25rem 0 .75rem; }
.home-lead { color: var(--home-muted); max-width: 60ch; }

.home-hero__media { position: relative; margin: 1rem 0 0; border-radius: 12px; overflow: hidden; }
.home-hero__media img { width: 100%; height: auto; display: block; }
.home-hero__media::after { content: ""; position: absolute; inset: 0; background: radial-gradient(80% 60% at 60% 40%, rgba(143,108,255,0.25), transparent), linear-gradient(180deg, transparent 60%, rgba(13,15,20,.9)); pointer-events: none; }

.home-cta { display: flex; gap: .75rem; flex-wrap: wrap; margin: 1rem 0; }
.home-cta--stack { flex-direction: column; align-items: flex-start; }

.home-btn { --btn-bg: transparent; --btn-bd: var(--home-border); --btn-fg: var(--home-text); appearance: none; border: 1px solid var(--btn-bd); background: var(--btn-bg); color: var(--btn-fg); padding: .7rem 1rem; border-radius: .6rem; cursor: pointer; text-decoration: none; font-weight: 600; transition: all .2s ease; }
.home-btn:hover, .home-btn:focus-visible { border-color: var(--home-accent); color: #fff; box-shadow: 0 0 0 4px rgba(143,108,255,.15); outline: none; }
.home-btn--primary { --btn-bg: linear-gradient(180deg, #8f6cff, #6c4aff); --btn-bd: #6c4aff; --btn-fg: #fff; }
.home-btn--ghost { --btn-bg: rgba(255,255,255,.04); }

.home-search { margin-top: .75rem; }
.home-search label { display: block; margin-bottom: .35rem; font-weight: 600; }
.home-search__row { display: flex; gap: .5rem; align-items: center; }
.home-search input[type="search"] { flex: 1; min-width: 12rem; padding: .7rem .9rem; border-radius: .6rem; border: 1px solid var(--home-border); background: var(--home-bg-alt); color: var(--home-text); }
.home-search input[type="search"]:focus { outline: none; border-color: var(--home-accent); box-shadow: 0 0 0 4px rgba(143,108,255,.15); }
.home-help { margin-top: .4rem; color: var(--home-muted); font-size: .85rem; }

.home-quicknav { border-top: 1px solid var(--home-border); background: rgba(18,21,28,.7); backdrop-filter: blur(4px); }
.home-quicknav ul { list-style: none; display: flex; gap: 1rem; flex-wrap: wrap; padding: .75rem 1rem; margin: 0 auto; max-width: 1200px; }
.home-quicknav a { color: var(--home-muted); text-decoration: none; border-bottom: 1px dashed transparent; }
.home-quicknav a:hover, .home-quicknav a:focus-visible { color: #fff; border-color: var(--home-accent); outline: none; }

.home-section { background: var(--home-bg); border-top: 1px solid var(--home-border); }
.home-section--alt { background: var(--home-bg-alt); }
.home-section--cta { background: radial-gradient(80% 80% at 80% 20%, rgba(143,108,255,.12), transparent), var(--home-bg); }
.home-section--sitelinks { background: var(--home-bg); padding-bottom: 3rem; }

.home-grid { display: grid; gap: 1.5rem; align-items: start; }
.home-grid--2col { grid-template-columns: 1fr; }
.home-grid--3col { grid-template-columns: 1fr; }

@media (min-width: 768px) {
  .home-grid--2col { grid-template-columns: 1.1fr .9fr; }
  .home-grid--3col { grid-template-columns: repeat(3, 1fr); }
}

.home-media img { width: 100%; height: auto; border-radius: 12px; border: 1px solid var(--home-border); background: #0b0d12; }

.home-list { margin: .75rem 0; padding-left: 1.25rem; }
.home-list li { margin: .35rem 0; }
.home-list--cols { columns: 1; column-gap: 2rem; }
@media (min-width: 992px) { .home-list--cols { columns: 2; } }
.home-list--compact { padding-left: 1.25rem; }

.home-card { background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01)); border: 1px solid var(--home-border); border-radius: 12px; padding: 1rem; }
.home-card h3 { margin-top: 0; }

.home-steps { counter-reset: step; list-style: none; padding-left: 0; }
.home-steps li { counter-increment: step; position: relative; padding-left: 2.25rem; margin: .75rem 0; }
.home-steps li::before { content: counter(step); position: absolute; left: 0; top: 0; width: 1.6rem; height: 1.6rem; display: grid; place-items: center; border-radius: .4rem; background: rgba(143,108,255,.15); color: #fff; border: 1px solid var(--home-accent); font-weight: 700; }

.home-note, .home-download-note, .home-metric, .home-update, .home-stats { background: rgba(255,255,255,.02); border: 1px solid var(--home-border); border-radius: 12px; padding: 1rem; }

.home-faq details { background: rgba(255,255,255,.02); border: 1px solid var(--home-border); border-radius: 10px; padding: .75rem 1rem; margin-bottom: .75rem; }
.home-faq summary { cursor: pointer; font-weight: 700; }
.home-faq summary:focus-visible { outline: 3px solid rgba(143,108,255,.35); border-radius: 6px; }

.home-inline-cta { margin-top: .75rem; }
.home-link { color: var(--home-accent); text-underline-offset: 3px; }
.home-link:hover, .home-link:focus-visible { color: #aa95ff; outline: none; }

.home-sitelinks { display: flex; flex-wrap: wrap; gap: .75rem 1.25rem; list-style: none; margin: 0; padding: 0; }
.home-sitelinks a { color: var(--home-muted); text-decoration: none; }
.home-sitelinks a:hover, .home-sitelinks a:focus-visible { color: #fff; outline: none; text-decoration: underline; }
