/*
 * Tulostaulu – Stylesheet v2.4 (Perustyylit)
 */

@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&display=swap');

body.tt-active {
    background-image: none !important;
    background-color: #111 !important;
    transition: background 0.4s ease-in-out;
    background-attachment: fixed !important;
}

#tt-root {
    --tt-accent: #4a90d9;
    --tt-btn-bg: rgba(50,50,50,0.8);
    --tt-btn-hover: rgba(80,80,80,1);
    --tt-text: #f0f0f0;
    --tt-text-muted: rgba(255,255,255,0.6);
    --tt-panel-bg: rgba(0,0,0,0.5);
    --tt-border: rgba(255,255,255,0.15);
    --tt-radius: 12px;
    --tt-font: "Monda", sans-serif;
    --tt-mono: "Monda", sans-serif;
    max-width: 900px;
    margin: 0 auto;
    padding: 1rem 1rem;
    font-family: var(--tt-font);
    color: var(--tt-text);
    box-sizing: border-box;
}

.seopress-beacon-el {
    display: none !important;
}
button.cmplz-btn.cmplz-manage-consent.manage-consent-1.cmplz-show {
    display: none;
}

#tt-root *, #tt-root *::before, #tt-root *::after { box-sizing: inherit; }

body.tt-active nav, 
body.tt-active header, 
body.tt-active footer,
body.tt-active #wpadminbar { display: none !important; }

html:has(body.tt-active) { margin-top: 0 !important; padding-top: 0 !important; }

/* ══════════════════════════════════════════════════════════
   YHTEISET PAINIKKEET JA LAATIKOT
   ══════════════════════════════════════════════════════════ */
.tt-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 8px; padding: 12px 20px; border: 1px solid var(--tt-border);
    border-radius: 8px; background: var(--tt-btn-bg); color: #fff;
    font-size: 1rem; font-weight: 600; cursor: pointer; transition: all 0.2s;
    min-height: 44px;
}
.tt-btn:hover { background: var(--tt-btn-hover); border-color: var(--tt-accent); transform: translateY(-2px); }
.tt-btn:active { transform: translateY(0); }
.tt-btn-primary { background: var(--tt-accent); color: #111; border-color: var(--tt-accent); }
.tt-btn-primary:hover { background: #fff; border-color: #fff; color: #111; }
.tt-btn-danger { background: rgba(120,30,30,0.8) !important; color: #ffcccc !important; }
.tt-btn-danger:hover { background: rgba(180,40,40,1) !important; }

button.tt-btn.tt-btn-score.tt-m { margin-left: 0rem; }

.tt-input {
    padding: 12px; background: rgba(0,0,0,0.5); border: 1px solid var(--tt-border);
    color: #fff; border-radius: 8px; font-size: 1rem; outline: none; height: 48px;
}
.tt-input:focus { border-color: var(--tt-accent); }

.tt-input-color {
    padding: 0; width: 48px; height: 48px; cursor: pointer; border: none;
    border-radius: 8px; overflow: hidden;
}
.tt-input-color::-webkit-color-swatch-wrapper { padding: 0; }
.tt-input-color::-webkit-color-swatch { border: none; border-radius: 8px; }

.tt-admin-box {
    background: rgba(0,0,0,0.4); border: 1px solid var(--tt-border);
    border-radius: var(--tt-radius); padding: 20px;
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 5px 20px rgba(0,0,0,0.3);
}

/* ══════════════════════════════════════════════════════════
   PELAAJAKORTIT
   ══════════════════════════════════════════════════════════ */
#tt-players { display: flex; flex-direction: column; gap: 12px; margin-bottom: 30px; }

.tt-card {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 22px; 
    border-radius: var(--tt-radius);
    transition: all 0.2s ease;
    flex-wrap: wrap; gap: 15px;
    background: rgba(255, 255, 255, 0.06);
    border-top: 1px solid #ffffff61;
    border-bottom: 1px solid #3d3d3d;
    border-right: 1px solid #454545;
    border-left: 1px solid #9c9c9c;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.tt-card:hover { transform: scale(1.02); box-shadow: 0 10px 30px rgba(0,0,0,0.5); }
.tt-card-header { display: flex; align-items: center; justify-content: space-between; flex: 1; min-width: 250px; }
.tt-player-left { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; padding-left: 2px; }
.tt-player-color {
    width: 1.5rem; height: 1.5rem; border-radius: 50%; flex-shrink: 0;
    background: radial-gradient(circle at 20% 30%, #fffced, var(--p-color) 50%);
    box-shadow: inset 0px 0px 2px 0px #fffee6, 0px 0px 0px 1px #0313274f, 0px 0px 20px 0px var(--p-color);
    margin-right: 0.25rem;
}
.tt-name { font-size: 1.2rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1; margin: 0; margin-left: 0.75rem; transform: translateY(1px); }
.tt-score { font-family: var(--tt-mono); font-size: 2.8rem; font-weight: 800; letter-spacing: 2px; min-width: 50px; text-align: right; margin-left: 10px; line-height: 1; margin: 0; transform: translateY(3px); }

.tt-card-controls { display: flex; align-items: center; gap: 15px; }
.tt-score-calc { display: flex; align-items: center; background: rgba(0,0,0,0.4); border-radius: 8px; padding: 4px; gap: 4px; }
.tt-btn-score { width: 48px; height: 48px; font-size: 1.6rem; font-weight: bold; border-radius: 6px; padding: 0; }
.tt-input-delta { width: 60px; text-align: center; font-size: 1.3rem; font-weight: bold; height: 48px; background: transparent; border: none; color: #fff; outline: none; }
.tt-input-delta:focus { background: rgba(255,255,255,0.1); border-radius: 4px; }
.tt-btn-delete { width: 44px; height: 44px; padding: 0; font-size: 1.2rem; flex-shrink: 0; }

@keyframes tt-bump { 0% {transform: scale(1);} 50% {transform: scale(1.3);} 100% {transform: scale(1);} }
.tt-anim { animation: tt-bump 0.3s ease-out; color: var(--tt-accent); }

/* ══════════════════════════════════════════════════════════
   ASETTELUT & LAATIKOT
   ══════════════════════════════════════════════════════════ */
.tt-top-nav { display: flex; gap: 10px; margin-bottom: 20px; margin-right: 10px; justify-content: center; flex-wrap: wrap; }
.tt-top-nav .tt-btn { flex: 1; min-width: 140px; }
.tt-admin-container { display: flex; flex-direction: column; gap: 15px; margin-top: 30px; }
.tt-add-inputs { display: flex; flex-direction: row; gap: 10px; width: 100%; margin-bottom: 10px; align-items: center; }

.tt-timer { font-family: var(--tt-mono); font-size: 2.5rem; color: var(--tt-accent); line-height: 1; text-align: center; opacity: 0.75; }
.tt-timer-controls { display: flex; gap: 10px; width: 100%; }
.tt-timer-controls .tt-btn { flex: 1; }

.tt-themes { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.tt-theme-btn { padding: 8px 12px; min-height: auto; border-radius: 20px; font-size: 0.85rem; }
.tt-theme-active { border-color: var(--tt-accent); box-shadow: 0 0 10px var(--tt-accent); }

/* TV-MOODI & MOBIILI */
#tt-root.tt-tv-mode { padding-top: 80px; }
#tt-root.tt-tv-mode .tt-card { padding: 20px 30px; }
#tt-root.tt-tv-mode .tt-name { font-size: 1.6rem; }
#tt-root.tt-tv-mode .tt-score { font-size: 3rem; }
#tt-root.tt-tv-mode .tt-timer { position: fixed; top: 20px; right: 30px; font-size: 2.5rem; z-index: 999; }

@media (max-width: 768px) {
    .tt-card { flex-direction: column; padding: 16px; gap: 0; }
    .tt-card-header { width: 100%; min-width: 0; padding-top: 4px;}
    .tt-card-controls { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
    .tt-score-calc { flex: 1; display: flex; height: 64px; padding: 5px; border-radius: 12px; gap: 5px; }
    .tt-btn-score { flex: 0 0 54px; width: 54px; height: 54px; font-size: 2.2rem; border-radius: 8px; padding: 0; }
    .tt-input-delta { flex: 1; width: 100%; height: 54px; font-size: 1.6rem; }
    .tt-btn-delete { flex: 0 0 42px; width: 42px; height: 42px; font-size: 1.4rem; border-radius: 8px; margin-top:0; }

    

    #tt-root.tt-tv-mode .tt-card { padding: 15px; }
    #tt-root.tt-tv-mode .tt-name { font-size: 1.4rem; }
#tt-root.tt-tv-mode .tt-score {
    font-size: 2rem;
}
    #tt-root.tt-tv-mode .tt-timer { position: relative; top: 0; right: 0; font-size: 2rem; text-align: center; margin-bottom: 20px; }
    #tt-root.tt-tv-mode {
    padding-top: 80px;
    padding: 3rem 1rem;
}

}