/* TTV Rees - Custom Styles */

:root {
    --ttv-bg-top: #031334;
    --ttv-bg-bottom: #010b24;
    --ttv-surface: rgba(7, 22, 56, 0.84);
    --ttv-surface-strong: rgba(6, 18, 45, 0.95);
    --ttv-border: rgba(140, 166, 219, 0.25);
    --ttv-text: #d5def3;
    --ttv-text-muted: #9db1de;
    --ttv-heading: #f0f5ff;
    --ttv-accent: #3ea7ff;
    --ttv-accent-hover: #6bbcff;
    --ttv-placeholder: #8ea1cd;
    --ttv-navbar-top: #062051;
    --ttv-accent-soft: rgba(62, 167, 255, 0.15);
    --ttv-accent-focus-shadow: rgba(62, 167, 255, 0.2);
    --ttv-input-bg: rgba(6, 18, 45, 0.75);
    --ttv-input-bg-focus: rgba(6, 18, 45, 0.9);
    --ttv-table-striped: rgba(62, 167, 255, 0.06);
    --ttv-table-hover: rgba(62, 167, 255, 0.12);
    --ttv-primary: #1f7fe0;
    --ttv-outline-border: #5a8cd8;
    --ttv-outline-text: #b8d0ff;
}

/* General */
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, var(--ttv-bg-top) 0%, var(--ttv-bg-bottom) 100%);
    color: var(--ttv-text);
}

main {
    flex: 1;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--ttv-heading);
}

a {
    color: var(--ttv-accent);
}

a:hover {
    color: var(--ttv-accent-hover);
}

.text-muted {
    color: var(--ttv-text-muted) !important;
}

/* Header + Navbar */
.site-header-top {
    background: linear-gradient(180deg, #12255f 0%, #0f1d4d 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.site-logo {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.site-logo-icon {
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: #fff;
    background: linear-gradient(135deg, #3ea7ff 0%, #1f7fe0 100%);
}

.site-logo-title {
    display: block;
    color: #f0f5ff;
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.1;
}

.site-logo-subtitle {
    display: block;
    color: #9db1de;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.site-search {
    width: min(520px, 100%);
    display: inline-flex;
    gap: 0.4rem;
}

.site-search .form-control {
    border-radius: 999px;
}

.site-search .btn {
    border-radius: 999px;
    width: 2.25rem;
}

.site-contact-label {
    color: #f0f5ff;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 0.68rem;
    font-weight: 700;
}

.site-contact-link {
    color: #cbd7f3;
    text-decoration: none;
    font-size: 0.85rem;
}

.site-contact-link:hover {
    color: #ffffff;
}

.site-social {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.site-social a,
.site-social-icon {
    color: #8fa7dd;
    font-size: 0.86rem;
}

.site-social a:hover {
    color: #f0f5ff;
}

.site-navbar {
    border-bottom: 1px solid var(--ttv-border);
    background: linear-gradient(180deg, #223164 0%, #1a264f 100%) !important;
}

.site-navbar .nav-link {
    color: var(--ttv-heading) !important;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.77rem;
    padding: 0.9rem 0.95rem !important;
}

.site-navbar .nav-link:hover,
.site-navbar .nav-link:focus {
    color: #ffffff !important;
    background: rgba(62, 167, 255, 0.2);
}

.dropdown-menu {
    background-color: var(--ttv-surface-strong);
    border: 1px solid var(--ttv-border);
}

.dropdown-item {
    color: var(--ttv-text);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--ttv-accent-soft);
    color: var(--ttv-heading);
}

.navbar-brand i {
    margin-right: 0.25rem;
}

/* Footer */
.site-footer {
    background: linear-gradient(180deg, #031334 0%, #010b24 100%);
    color: #d5def3;
}

.site-footer-title {
    font-size: 0.875rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 0.95rem;
}

.site-footer-link {
    display: inline-block;
    margin-bottom: 0.55rem;
    color: #9db1de;
    text-decoration: none;
    transition: color 0.2s ease;
}

.site-footer-link:hover {
    color: #f0f5ff;
}

.site-footer-text {
    color: #9db1de;
    line-height: 1.7;
}

.site-footer-divider {
    margin: 2.2rem 0 1.8rem;
    border-color: rgba(255, 255, 255, 0.12);
}

.site-footer-brand {
    color: #3ea7ff;
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 0.8rem;
}

.site-footer-copy {
    color: #7182a8;
    font-size: 0.875rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.site-footer-meta {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.site-footer-meta-link {
    color: #8ea1cd;
    font-size: 0.875rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
}

.site-footer-meta-link:hover {
    color: #f0f5ff;
}

.site-footer-separator {
    color: #516389;
    font-size: 0.8rem;
}

/* Cards */
.card {
    background: var(--ttv-surface);
    border: 1px solid var(--ttv-border);
    color: var(--ttv-text);
    transition: box-shadow 0.2s ease;
}

.card .card-footer {
    border-top-color: var(--ttv-border);
}

.card:hover {
    box-shadow: 0 0.35rem 0.9rem rgba(0, 0, 0, 0.35) !important;
}

/* Home */
.home-hero {
    background: radial-gradient(circle at 15% 20%, rgba(62, 167, 255, 0.2), rgba(6, 18, 45, 0.92) 55%);
}

.home-featured-image {
    width: 100%;
    height: 340px;
    object-fit: cover;
}

.home-kicker {
    background: rgba(62, 167, 255, 0.2);
    border: 1px solid rgba(140, 166, 219, 0.35);
    color: var(--ttv-heading);
}

.home-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.home-stat-card {
    background: rgba(3, 16, 42, 0.9);
    border: 1px solid var(--ttv-border);
    border-radius: 0.75rem;
    padding: 0.85rem 0.9rem;
}

.home-sidebar-title {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    background: rgba(62, 167, 255, 0.14);
    border-bottom: 1px solid var(--ttv-border);
}

.home-event-item {
    padding: 0.9rem 1rem;
    border-bottom: 1px solid var(--ttv-border);
}

.home-event-item:last-child {
    border-bottom: 0;
}

.home-stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--ttv-heading);
}

.team-card {
    overflow: hidden;
}

.team-photo {
    width: 100%;
    height: 180px;
    object-fit: cover;
    background: rgba(6, 18, 45, 0.95);
    border-bottom: 1px solid var(--ttv-border);
}

.team-meta li {
    margin-bottom: 0.45rem;
    display: flex;
    gap: 0.45rem;
    align-items: baseline;
}

.team-meta i {
    color: var(--ttv-accent);
}

/* Legal pages */
.legal-page .card h5 {
    margin-bottom: 0.8rem;
}

/* Forms and tables */
.form-control,
.form-select,
.input-group-text {
    background-color: var(--ttv-input-bg);
    border-color: var(--ttv-border);
    color: var(--ttv-text);
}

.form-control:focus,
.form-select:focus {
    background-color: var(--ttv-input-bg-focus);
    border-color: var(--ttv-accent);
    box-shadow: 0 0 0 0.2rem var(--ttv-accent-focus-shadow);
    color: var(--ttv-heading);
}

.form-control::placeholder {
    color: var(--ttv-placeholder);
}

.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--ttv-text);
    --bs-table-border-color: var(--ttv-border);
    --bs-table-striped-bg: var(--ttv-table-striped);
    --bs-table-hover-bg: var(--ttv-table-hover);
}

.btn-primary {
    background-color: var(--ttv-primary);
    border-color: var(--ttv-primary);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--ttv-accent);
    border-color: var(--ttv-accent);
}

.btn-outline-primary {
    border-color: var(--ttv-outline-border);
    color: var(--ttv-outline-text);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--ttv-accent);
    border-color: var(--ttv-accent);
    color: var(--ttv-bg-top);
}

/* Blog Content */
.blog-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0.375rem;
}

/* Strichliste - Tablet-optimized */
.product-btn {
    min-width: 120px;
    font-size: 1.1rem;
}
.product-btn.active {
    transform: scale(1.05);
}

.person-row {
    cursor: pointer;
    user-select: none;
}
.person-row:active {
    background-color: #e3f2fd !important;
}

/* Kasse POS */
.pos-product-btn {
    min-height: 80px;
    font-size: 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

/* Tournament Bracket */
.bracket-round {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    min-width: 200px;
}

.bracket-match {
    border: 1px solid var(--ttv-border);
    border-radius: 0.375rem;
    margin: 0.5rem 0;
    background: var(--ttv-surface-strong);
}

.bracket-match .player {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--ttv-border);
    display: flex;
    justify-content: space-between;
}

.bracket-match .player:last-child {
    border-bottom: none;
}

.bracket-match .player.winner {
    background-color: rgba(25, 135, 84, 0.25);
    font-weight: bold;
}

.bracket-match .player.bye {
    color: #6c757d;
    font-style: italic;
}

/* Check-in button */
.btn-checkin {
    min-width: 140px;
}

/* Dashboard cards */
.card .fs-1 {
    line-height: 1;
}

/* Mobile responsive improvements */
@media (max-width: 768px) {
    .site-contact {
        width: 100%;
        text-align: left !important;
    }

    .home-featured-image {
        height: 220px;
    }

    .product-btn {
        min-width: 90px;
        padding: 0.5rem !important;
        font-size: 0.9rem;
    }

    .pos-product-btn {
        min-height: 60px;
        font-size: 0.85rem;
    }

    .site-footer-title {
        margin-bottom: 0.65rem;
    }

    .site-footer-divider {
        margin-top: 1.5rem;
    }
}

/* Print styles */
@media print {
    .navbar, footer, .btn, form {
        display: none !important;
    }
}
