/* ============================================================
   GTI7 – Spiele-Portal CSS
   ============================================================ */

/* ---- Hero ---- */
.games-hero {
    background: linear-gradient(135deg, #1a1f35 0%, #0d1117 100%);
    border-bottom: 1px solid var(--c-border);
    padding: 3rem 0 2.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.games-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 0%, #4A9EFF18 0%, transparent 70%);
    pointer-events: none;
}
.games-hero__inner { max-width: 700px; margin: 0 auto; padding: 0 1.5rem; position: relative; }
.games-hero__icon  { font-size: 3rem; color: var(--c-accent); margin-bottom: .75rem; }
.games-hero__title { font-size: 2.5rem; font-weight: 700; margin: 0 0 .5rem; background: linear-gradient(135deg, #fff, #4A9EFF); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.games-hero__sub   { color: var(--c-muted); font-size: 1rem; margin: 0 0 1.5rem; }
.games-hero__stats { display: flex; gap: 2rem; justify-content: center; }
.games-hero__stat  { display: flex; flex-direction: column; }
.games-hero__stat-value { font-size: 1.75rem; font-weight: 700; color: var(--c-accent); line-height: 1; }
.games-hero__stat-label { font-size: .75rem; color: var(--c-muted); margin-top: .25rem; }

/* ---- Layout ---- */
.games-portal   { max-width: 1200px; margin: 0 auto; }
.games-layout   { display: grid; grid-template-columns: 1fr 300px; gap: 2rem; padding: 2rem 1.5rem; }
@media (max-width: 900px) { .games-layout { grid-template-columns: 1fr; } }

/* ---- Katalog ---- */
.games-section-title { font-size: 1.1rem; font-weight: 600; color: var(--c-text); margin: 0 0 1rem; display: flex; align-items: center; gap: .5rem; }
.games-section-title i { color: var(--c-accent); }
.games-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; }

.game-card {
    display: flex; align-items: center; gap: 1rem;
    background: var(--c-surface); border: 1px solid var(--c-border);
    border-radius: 12px; padding: 1.25rem; text-decoration: none; color: inherit;
    transition: border-color .2s, transform .2s, box-shadow .2s;
    cursor: pointer;
}
.game-card:hover {
    border-color: var(--c-accent);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(74,158,255,.12);
}
.game-card__icon {
    width: 52px; height: 52px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; flex-shrink: 0;
}
.game-card__body  { flex: 1; min-width: 0; }
.game-card__name  { font-weight: 600; font-size: 1rem; margin-bottom: .25rem; }
.game-card__desc  { font-size: .8rem; color: var(--c-muted); line-height: 1.4; margin-bottom: .5rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.game-card__meta  { display: flex; flex-wrap: wrap; gap: .35rem; }
.game-card__arrow { color: var(--c-muted); font-size: .9rem; flex-shrink: 0; }

.game-badge { font-size: .7rem; padding: .2rem .5rem; border-radius: 20px; font-weight: 600; }
.game-badge--solo   { background: #2ECC7122; color: #2ECC71; }
.game-badge--mp     { background: #4A9EFF22; color: #4A9EFF; }
.game-badge--points { background: #F1C40F22; color: #F1C40F; }

/* ---- Sidebar-Widgets ---- */
.games-sidebar       { display: flex; flex-direction: column; gap: 1rem; }
.games-widget        { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 12px; overflow: hidden; }
.games-widget__title { padding: .875rem 1rem; font-weight: 600; font-size: .85rem; border-bottom: 1px solid var(--c-border); display: flex; align-items: center; gap: .5rem; }
.games-widget__title i { color: var(--c-accent); }
.games-widget__row   { display: flex; align-items: center; gap: .75rem; padding: .625rem 1rem; border-bottom: 1px solid var(--c-border); }
.games-widget__row:last-child { border-bottom: none; }
.games-widget__game-icon { width: 28px; text-align: center; font-size: 1rem; }
.games-widget__game-info { flex: 1; min-width: 0; }
.games-widget__game-name { font-size: .85rem; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.games-widget__game-meta { font-size: .75rem; color: var(--c-muted); }
.games-widget__pts  { font-size: .85rem; font-weight: 700; color: var(--c-gold); white-space: nowrap; }
.games-widget__time { font-size: .75rem; color: var(--c-muted); white-space: nowrap; }

.games-widget--login { padding: 2rem 1.5rem; text-align: center; }
.games-widget__lock-icon { font-size: 2.5rem; color: var(--c-muted); margin-bottom: .75rem; display: block; }
.games-widget__login-text { font-size: .875rem; color: var(--c-muted); line-height: 1.5; }

/* ---- Highscore-Ränge ---- */
.games-hs-rank { width: 28px; height: 28px; border-radius: 50%; background: var(--c-bg); display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; flex-shrink: 0; }
.games-hs-rank--gold   { background: #F1C40F22; color: #F1C40F; }
.games-hs-rank--silver { background: #BDC3C722; color: #BDC3C7; }
.games-hs-rank--bronze { background: #E67E2222; color: #E67E22; }

/* ============================================================
   Spiel-Seite
   ============================================================ */
.game-play-page    { max-width: 1200px; margin: 0 auto; padding: 1.5rem; }
.game-play-header  { display: flex; align-items: center; gap: 1.5rem; margin-bottom: 1.5rem; }
.game-back-btn     { color: var(--c-muted); text-decoration: none; font-size: .875rem; display: flex; align-items: center; gap: .4rem; padding: .4rem .75rem; border-radius: 8px; border: 1px solid var(--c-border); transition: color .2s, border-color .2s; }
.game-back-btn:hover { color: var(--c-text); border-color: var(--c-accent); }
.game-play-title   { display: flex; align-items: center; gap: 1rem; }
.game-play-icon    { width: 56px; height: 56px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.game-play-title h1 { margin: 0; font-size: 1.75rem; font-weight: 700; }
.game-play-sub     { font-size: .875rem; color: var(--c-muted); margin-top: .15rem; }

.game-play-layout  { display: grid; grid-template-columns: auto 280px; gap: 1.5rem; align-items: start; }
@media (max-width: 900px) { .game-play-layout { grid-template-columns: 1fr; } }
.game-play-main    { min-width: 0; }

/* ---- Snake ---- */
.snake-container   { display: flex; flex-direction: column; align-items: center; gap: 1rem; }
.snake-hud         { display: flex; gap: 2rem; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 10px; padding: .75rem 1.5rem; }
.snake-hud__item   { text-align: center; }
.snake-hud__label  { display: block; font-size: .7rem; color: var(--c-muted); text-transform: uppercase; letter-spacing: .05em; }
.snake-hud__value  { display: block; font-size: 1.4rem; font-weight: 700; color: var(--c-text); line-height: 1.2; }

#snakeCanvas       { border-radius: 12px; border: 2px solid var(--c-border); max-width: 100%; }
#tetrisCanvas      { border-radius: 12px; border: 2px solid var(--c-border); }

.snake-overlay     { position: absolute; inset: 0; background: rgba(13,17,23,.92); border-radius: 12px; display: flex; align-items: center; justify-content: center; z-index: 10; }
.snake-container, .tetris-container { position: relative; }

.snake-overlay__box   { text-align: center; padding: 2rem; }
.snake-overlay__icon  { font-size: 3rem; color: var(--c-accent); margin-bottom: 1rem; }
.snake-overlay__box h2 { margin: 0 0 .5rem; font-size: 1.75rem; }
.snake-overlay__box p  { color: var(--c-muted); margin: 0 0 1.5rem; max-width: 280px; }
.snake-overlay__points { background: var(--c-gold); color: #000; font-weight: 700; padding: .4rem 1rem; border-radius: 20px; margin-bottom: 1rem; display: inline-block; }

/* Mobile D-Pad */
.snake-mobile-controls { display: none; }
@media (max-width: 700px) { .snake-mobile-controls { display: flex; justify-content: center; } }
.snake-dpad { display: grid; grid-template-columns: repeat(3, 52px); grid-template-rows: repeat(3, 52px); gap: 4px; }
.dpad-btn  { width: 52px; height: 52px; border-radius: 10px; border: 1px solid var(--c-border); background: var(--c-surface); color: var(--c-text); font-size: 1.1rem; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background .1s; }
.dpad-btn:active { background: var(--c-accent); }
.dpad-up     { grid-column: 2; grid-row: 1; }
.dpad-left   { grid-column: 1; grid-row: 2; }
.dpad-center { grid-column: 2; grid-row: 2; background: transparent; border-color: transparent; cursor: default; }
.dpad-right  { grid-column: 3; grid-row: 2; }
.dpad-down   { grid-column: 2; grid-row: 3; }

/* ---- Tetris ---- */
.tetris-container  { display: flex; flex-direction: column; align-items: center; gap: 1rem; }
.tetris-hud        { display: flex; gap: 2rem; background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 10px; padding: .75rem 1.5rem; }
.tetris-area       { display: flex; gap: 1rem; align-items: flex-start; }
.tetris-next       { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 10px; padding: .75rem; text-align: center; }
.tetris-next__label { font-size: .7rem; color: var(--c-muted); margin-bottom: .5rem; }
.tetris-mobile-row { display: flex; gap: .4rem; }

/* ---- Multiplayer ---- */
.mp-container      { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 14px; padding: 1.5rem; }
.mp-section-title  { font-size: 1rem; font-weight: 600; margin: 0 0 1rem; display: flex; align-items: center; gap: .5rem; }
.mp-section-title i { color: var(--c-accent); }
.mp-sessions       { display: flex; flex-direction: column; gap: .75rem; margin-bottom: .5rem; }
.mp-session-card   { display: flex; align-items: center; justify-content: space-between; background: var(--c-bg); border: 1px solid var(--c-border); border-radius: 10px; padding: .875rem 1rem; }
.mp-session-player { display: flex; align-items: center; gap: .75rem; }
.mp-session-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.mp-session-avatar--default { background: var(--c-accent); color: #fff; font-weight: 700; display: flex; align-items: center; justify-content: center; font-size: 1rem; }
.mp-session-name   { font-weight: 600; font-size: .9rem; }
.mp-session-time   { font-size: .75rem; color: var(--c-muted); }
.mp-empty          { text-align: center; color: var(--c-muted); padding: 1.5rem; font-size: .875rem; display: flex; align-items: center; justify-content: center; gap: .5rem; }

.mp-waiting        { flex-direction: column; align-items: center; text-align: center; padding: 2rem; }
.mp-waiting__spinner { font-size: 2.5rem; color: var(--c-accent); margin-bottom: 1rem; }
.mp-waiting h3     { margin: 0 0 .5rem; }
.mp-waiting__sub   { color: var(--c-muted); font-size: .875rem; margin: 0 0 1rem; }
.mp-waiting__link  { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: 8px; padding: .5rem 1rem; font-size: .75rem; color: var(--c-muted); word-break: break-all; }

.mp-login-prompt   { text-align: center; padding: 3rem 1rem; }
.mp-login-prompt i { margin-bottom: 1rem; }
.mp-login-prompt h3 { margin: 0 0 .5rem; }
.mp-login-prompt p { color: var(--c-muted); margin-bottom: 1.5rem; }

.mp-result         { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: 12px; padding: 1.5rem; text-align: center; margin-top: 1rem; font-size: 1.1rem; font-weight: 600; }

/* Tic-Tac-Toe Board */
.ttt-status  { text-align: center; font-weight: 600; margin-bottom: 1rem; color: var(--c-text); }
.ttt-board   { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; max-width: 300px; margin: 0 auto 1.5rem; }
.ttt-cell    { aspect-ratio: 1; background: var(--c-bg); border: 2px solid var(--c-border); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 2.5rem; cursor: pointer; transition: border-color .15s, background .15s; }
.ttt-cell:hover:not(.ttt-cell--x):not(.ttt-cell--o) { background: var(--c-surface); border-color: var(--c-accent); }
.ttt-cell--x { color: #E74C3C; border-color: #E74C3C44; background: #E74C3C0A; cursor: default; }
.ttt-cell--o { color: #4A9EFF; border-color: #4A9EFF44; background: #4A9EFF0A; cursor: default; }
.ttt-players { display: flex; align-items: center; justify-content: center; gap: 1.5rem; margin-bottom: 1rem; }
.ttt-player  { display: flex; align-items: center; gap: .5rem; font-weight: 500; font-size: .95rem; }
.ttt-sym     { font-size: 1.2rem; }
.ttt-sym--x  { color: #E74C3C; }
.ttt-sym--o  { color: #4A9EFF; }
.ttt-vs      { font-weight: 700; color: var(--c-muted); }

/* Pong */
.pong-status { text-align: center; font-weight: 600; margin-bottom: .75rem; }
.c4-status   { text-align: center; font-weight: 600; margin-bottom: .75rem; }

/* ---- Bowling specifics ---- */
.bowling-wrapper canvas { display:block; }
@media (max-width:640px) {
    .bowling-wrapper canvas { width:100% !important; height:auto !important; }
    .bowling-power-bar { width:140px; }
}

/* kbd Style */
kbd { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 4px; padding: .1rem .35rem; font-size: .8rem; font-family: monospace; }
