/*
Theme Name: Seite 55
Theme URI: https://seite55.de
Description: Pixel-arcade portal for free German browser games. Self-hosted HTML5 games + SEO content. Vanilla CSS, self-hosted fonts, no CDN dependencies.
Version: 1.0.0
Author: Seite 55
Text Domain: seite55
*/

/* ============================================================ TOKENS */
:root{
  --pink:#FFADAD; --sky:#A0C4FF; --mint:#CAFFBF; --butter:#FDFFB6;
  --cream:#FDFCF0; --ink:#161616; --line:#0f0f0f;
  --paper:#ffffff; --muted:#5b5b5b;
  --shadow: 4px 4px 0 0 var(--line);
  --shadow-sm: 2px 2px 0 0 var(--line);
  --wrap:1240px;
  --font-pixel:"Pixelify Sans", system-ui, sans-serif;
  --font-body:"Nunito Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

/* ============================================================ RESET */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--font-body);font-size:18px;line-height:1.7;
  font-weight:600;}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--font-pixel);line-height:1.15;font-weight:700;letter-spacing:.01em}
.sr-only{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}

/* ============================================================ PIXEL PRIMITIVES */
.pixel-border{border:4px solid var(--line);box-shadow:var(--shadow);background:var(--paper)}
.pixel-border-sm{border:2px solid var(--line);box-shadow:var(--shadow-sm)}
.pixel-btn{transition:transform .05s, box-shadow .05s}
.pixel-btn:active{transform:translate(4px,4px);box-shadow:0 0 0 0 var(--line)}
.s55-ic{width:1.1em;height:1.1em;vertical-align:-.15em}

/* CRT scanlines (very subtle) */
.scanlines{position:fixed;inset:0;z-index:9999;pointer-events:none;
  background:linear-gradient(rgba(0,0,0,0) 50%, rgba(0,0,0,.025) 50%);
  background-size:100% 4px;mix-blend-mode:multiply}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:10000}
.skip-link:focus{left:8px;top:8px}

/* ============================================================ HEADER */
.site-head{position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:6px solid var(--line)}
.head-inner{display:flex;align-items:center;gap:18px;min-height:84px}
.brand{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.brand-mark{display:inline-flex;padding:5px;background:var(--line);line-height:0}
.brand-word{font-family:var(--font-pixel);font-size:1.5rem;font-weight:700;letter-spacing:-.02em}
.primary-nav{display:flex;gap:10px;margin-left:8px}
.navlink{font-family:var(--font-pixel);font-size:.8rem;padding:9px 14px;border:2px solid var(--line);
  box-shadow:var(--shadow-sm);background:var(--paper);transition:transform .05s,box-shadow .05s}
.navlink:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 0 var(--line)}
.navlink:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--line)}
.nl-blue{background:var(--sky)} .nl-pink{background:var(--pink)} .nl-mint{background:var(--mint)} .nl-butter{background:var(--butter)}
.head-search{margin-left:auto;display:flex;gap:8px;align-items:stretch}
.head-search input{border:2px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;padding:10px 12px;
  font-family:var(--font-body);font-weight:700;width:190px;max-width:38vw}
.head-search input:focus{outline:3px solid var(--sky);outline-offset:1px}
.head-search button{border:2px solid var(--line);box-shadow:var(--shadow-sm);background:var(--butter);padding:0 12px;display:grid;place-items:center}
.nav-toggle{display:none;border:2px solid var(--line);box-shadow:var(--shadow-sm);background:var(--pink);padding:8px 10px;margin-left:auto}

/* ============================================================ SECTIONS / HEADINGS */
.section{padding:54px 0}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  border-bottom:4px solid var(--line);padding-bottom:12px;margin-bottom:30px}
.section-head h2{font-size:1.7rem;margin:0}
.section-link{font-family:var(--font-pixel);font-size:.78rem}
.section-link:hover{text-decoration:underline}

/* ============================================================ HERO (featured game) */
.hero{margin:34px 0}
.hero-card{display:grid;grid-template-columns:1.3fr .9fr;gap:34px;align-items:center;
  background:var(--sky);padding:40px}
.hero-badge{display:inline-block;background:var(--line);color:#fff;font-family:var(--font-pixel);
  font-size:.7rem;padding:7px 12px;margin-bottom:18px}
.hero h1{font-size:2.7rem;margin:0 0 18px}
.hero h1 .out{color:#fff;text-shadow:4px 4px 0 var(--line)}
.hero p{font-size:1.15rem;max-width:46ch;margin:0 0 26px}
.hero-cta{display:inline-flex;align-items:center;gap:12px;background:var(--line);color:#fff;
  font-family:var(--font-pixel);font-size:.95rem;padding:16px 26px;border:4px solid var(--line);box-shadow:var(--shadow)}
.hero-cta .s55-ic{width:1.4em;height:1.4em}
.hero-art{aspect-ratio:1;background:var(--line);display:grid;place-items:center;padding:10px;overflow:hidden}
.hero-art img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated}

/* ============================================================ ARCADE CABINET TILE GRID */
.cab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(184px,1fr));gap:26px}
.cab{display:flex;flex-direction:column;background:#fff;color:var(--ink)}
.cab-marquee{font-family:var(--font-pixel);font-size:.62rem;text-transform:uppercase;
  padding:7px 8px;text-align:center;border-bottom:4px solid var(--line);line-height:1.2}
.cab-screen{position:relative;aspect-ratio:4/3;background:#1d1d1d;margin:7px;border:3px solid var(--line);
  display:grid;place-items:center;overflow:hidden}
.cab-screen img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cab-ic{color:#fff;opacity:.5}.cab-ic .s55-ic{width:48px;height:48px}
.cab-play{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.45);
  color:#fff;opacity:0;transition:opacity .12s}.cab-play .s55-ic{width:40px;height:40px}
.cab:hover .cab-play{opacity:1}
.cab-title{font-family:var(--font-pixel);font-size:.7rem;padding:9px 8px;border-top:4px solid var(--line);
  background:#fff;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cab-controls{display:flex;align-items:center;justify-content:space-between;padding:0 12px;height:30px;border-top:4px solid var(--line)}
.cab-stick{width:11px;height:11px;border-radius:50%;background:#e23b3b;border:2px solid var(--line)}
.cab-dot{width:8px;height:8px;background:#FFD23F;border:2px solid var(--line);display:inline-block;margin-left:6px}

/* ============================================================ GENRE STRIP */
.genre-band{background:var(--mint);border-top:6px solid var(--line);border-bottom:6px solid var(--line);padding:54px 0}
.genre-band h2{text-align:center;font-size:1.9rem;margin:0 0 34px}
.genre-row{display:flex;flex-wrap:wrap;gap:18px;justify-content:center}
.genre-card{display:flex;flex-direction:column;align-items:center;gap:12px;width:148px;padding:22px 14px;background:#fff;text-align:center}
.genre-card .s55-ic{width:36px;height:36px}
.genre-card span{font-family:var(--font-pixel);font-size:.72rem}
.genre-card:hover{background:var(--line);color:#fff}

/* ============================================================ NEW 2026 STRIP */
.quest{background:var(--line);color:#fff;padding:38px}
.quest-top{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:30px;
  border-top:6px solid;border-image:linear-gradient(90deg,var(--pink),var(--butter),var(--sky)) 1;padding-top:22px}
.quest h2{font-size:1.8rem;margin:0 0 6px}
.quest-top p{margin:0;color:#bdbdbd;font-size:.95rem}
.quest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quest-item{background:#222;border:4px solid var(--line);box-shadow:var(--shadow);padding:18px}
.quest-item:hover{border-color:var(--pink)}
.quest-thumb{aspect-ratio:16/9;display:grid;place-items:center;margin-bottom:14px;border:3px solid var(--line)}
.quest-thumb .s55-ic{width:46px;height:46px;color:var(--line)}
.quest-item h3{font-size:.95rem;margin:0 0 6px}
.quest-item p{font-size:.85rem;color:#bdbdbd;margin:0}

/* ============================================================ RATGEBER CARDS */
.art-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:26px}
.art-card{background:#fff;display:flex;flex-direction:column}
.art-card .art-thumb{aspect-ratio:16/9;background:var(--butter);border-bottom:4px solid var(--line);overflow:hidden}
.art-card .art-body{padding:18px}
.art-card h3{font-size:1rem;margin:0 0 8px;line-height:1.3}
.art-card p{font-size:.92rem;color:var(--muted);margin:0;font-weight:600}
.art-card:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 0 var(--line)}

/* ============================================================ ABOUT BLURB */
.about{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.about h2{font-size:1.6rem;margin:0 0 14px}

/* ============================================================ SINGLE GAME / ARTICLE */
.single-wrap{max-width:880px;margin:0 auto;padding:34px 20px 60px}
.single-wide{max-width:1100px}
.crumbs{font-family:var(--font-pixel);font-size:.66rem;color:var(--muted);margin-bottom:18px}
.crumbs a:hover{text-decoration:underline}
.page-title{font-size:2.2rem;margin:0 0 8px}
.lede{font-size:1.18rem;color:#2c2c2c;margin:0 0 26px}

/* Game stage */
.game-stage{margin:0 0 30px}
.game-screen{background:#101010;padding:8px;position:relative}
.game-screen .game-frame{display:block;width:100%;aspect-ratio:var(--aspect,4/3);border:0;background:#000}
.game-poster{display:block;width:100%;aspect-ratio:var(--aspect,4/3);object-fit:cover;image-rendering:pixelated}
.game-start{position:absolute;inset:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  background:rgba(16,16,16,.45);color:#fff;border:0;cursor:pointer;font-family:var(--font-pixel);font-size:1rem}
.game-start .s55-ic{width:64px;height:64px;background:var(--butter);color:var(--line);border:4px solid var(--line);box-shadow:var(--shadow);padding:14px;border-radius:50%}
.game-start:hover .s55-ic{transform:scale(1.06)}
.game-bar{display:flex;align-items:center;gap:16px;margin-top:10px}
.game-fs{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-pixel);font-size:.72rem;
  background:var(--butter);border:2px solid var(--line);box-shadow:var(--shadow-sm);padding:9px 14px}
.game-controls{font-size:.92rem;color:var(--muted);font-weight:700}
.game-stage:fullscreen,.game-screen:fullscreen{background:#000;display:grid;place-items:center}
.game-screen:fullscreen .game-frame{height:100vh;aspect-ratio:auto}

/* Prose */
.prose{font-size:1.06rem}
.prose h2{font-size:1.5rem;margin:2em 0 .6em;padding-bottom:.3em;border-bottom:4px solid var(--line)}
.prose h3{font-size:1.12rem;margin:1.6em 0 .5em}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em}
.prose li{margin:.35em 0}
.prose a{color:#0a4fb4;text-decoration:underline;text-decoration-thickness:2px}
.prose a:hover{background:var(--butter)}
.prose img{margin:1.4em 0;border:4px solid var(--line);box-shadow:var(--shadow)}
.prose figure{margin:1.6em 0}
.prose figure svg{border:4px solid var(--line);box-shadow:var(--shadow);background:#fff;width:100%;height:auto}
.prose figcaption{font-size:.85rem;color:var(--muted);margin-top:6px}
.prose blockquote{border-left:6px solid var(--sky);margin:1.4em 0;padding:.4em 1em;background:#fff}
.prose table{width:100%;border-collapse:collapse;margin:1.4em 0;background:#fff;border:3px solid var(--line)}
.prose th,.prose td{border:2px solid var(--line);padding:10px 12px;text-align:left;font-size:.95rem}
.prose th{background:var(--sky);font-family:var(--font-pixel);font-size:.74rem}

/* FAQ */
.faq{margin:2.4em 0}
.faq h2{margin-bottom:1em}
.faq-item{background:#fff;border:3px solid var(--line);box-shadow:var(--shadow-sm);margin:0 0 12px;padding:0}
.faq-item>summary{font-family:var(--font-pixel);font-size:.82rem;padding:14px 16px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:12px}
.faq-item>summary::-webkit-details-marker{display:none}
.faq-item>summary::after{content:"+";font-size:1.2rem}
.faq-item[open]>summary::after{content:"–"}
.faq-item>*:not(summary){padding:0 16px 14px}
.embed-box{background:#fff;border:3px solid var(--line);box-shadow:var(--shadow-sm);margin:1.4em 0;padding:0}
.embed-box>summary{font-family:var(--font-pixel);font-size:.74rem;padding:12px 16px;cursor:pointer}
.embed-box>*:not(summary){padding:0 16px 14px}
.embed-box code{display:block;white-space:pre-wrap;word-break:break-all;background:#f3f3f3;border:2px solid var(--line);padding:8px;font-size:.8rem}

/* Related games */
.related{margin-top:46px}
.related h2{font-size:1.3rem;border-bottom:4px solid var(--line);padding-bottom:10px;margin-bottom:22px}

/* tag chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.chip{font-family:var(--font-pixel);font-size:.62rem;background:var(--mint);border:2px solid var(--line);padding:6px 10px}

/* ============================================================ ARCHIVE / TAX HEADER */
.arch-head{background:var(--pink);border-bottom:6px solid var(--line);padding:40px 0}
.arch-head h1{font-size:2rem;margin:0 0 8px}
.arch-head p{margin:0;max-width:60ch;font-weight:700}

/* ============================================================ FOOTER */
.site-foot{background:var(--line);color:#fff;border-top:6px solid var(--line);margin-top:60px;padding:50px 0 26px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px}
.foot-brand .brand-word{color:#fff;font-size:1.4rem}
.foot-brand p{color:#b9b9b9;font-size:.92rem;max-width:42ch;margin:12px 0 0;font-weight:600}
.foot-col h4{font-family:var(--font-pixel);font-size:.8rem;margin:0 0 14px}
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{margin:9px 0}
.foot-col a{color:#d8d8d8;font-size:.92rem}
.foot-col a:hover{color:#fff;text-decoration:underline}
.foot-base{border-top:3px solid #333;margin-top:34px;padding-top:18px}
.foot-base p{color:#8c8c8c;font-family:var(--font-pixel);font-size:.66rem;margin:0}

/* ============================================================ 404 / SEARCH */
.notice{max-width:680px;margin:60px auto;text-align:center}
.notice h1{font-size:2.2rem;margin:0 0 14px}

/* ============================================================ PAGINATION */
.s55-pagination{display:flex;gap:8px;justify-content:center;margin:40px 0;flex-wrap:wrap}
.s55-pagination .page-numbers{font-family:var(--font-pixel);font-size:.74rem;padding:8px 12px;border:2px solid var(--line);box-shadow:var(--shadow-sm);background:#fff}
.s55-pagination .current{background:var(--sky)}

/* ============================================================ RESPONSIVE */
@media(max-width:920px){
  .hero-card{grid-template-columns:1fr}
  .hero-art{max-width:360px}
  .about{grid-template-columns:1fr}
  .quest-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:17px}
  .nav-toggle{display:inline-flex}
  .primary-nav{display:none;position:absolute;top:84px;left:0;right:0;flex-direction:column;background:var(--cream);
    border-bottom:6px solid var(--line);padding:16px 20px;gap:10px}
  .primary-nav.open{display:flex}
  .head-search{display:none}
  .hero h1{font-size:2rem}
  .page-title{font-size:1.7rem}
  .foot-grid{grid-template-columns:1fr}
}
