/* Shared styles for components/pages moved from web app */
/* Use system font stack to avoid external Google Fonts dependency */
/* Use local bootstrap-icons for offline support */
@import url('./bootstrap-icons.css');

:root {
    /* system font stack */
    --app-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";

    /* color tokens shared between hosts */
    --bs-primary: #ff6b6b;
    --bs-primary-rgb: 255, 107, 107;
    --bs-secondary: #4ecdc4;
    --bs-secondary-rgb: 78, 205, 196;
    --bs-success: #45b7d1;
    --bs-success-rgb: 69, 183, 209;
    --bs-info: #96ceb4;
    --bs-info-rgb: 150, 206, 180;
    --bs-warning: #feca57;
    --bs-warning-rgb: 254, 202, 87;
    --bs-danger: #ff7675;
    --bs-danger-rgb: 255, 118, 117;
    --bs-light: #f8f9fa;
    --bs-light-rgb: 248, 249, 250;
    --bs-dark: #2d3436;
    --bs-dark-rgb: 45, 52, 54;
    
    /* Custom colors */
    --accent-purple: #a29bfe;
    --accent-purple-rgb: 162, 155, 254;
    --accent-orange: #fd79a8;
    --accent-orange-rgb: 253, 121, 168;
    --accent-mint: #00b894;
    --accent-mint-rgb: 0, 184, 148;
    
    /* Glass effect */
    --glass-bg: rgba(255, 255, 255, 0.25);
    --glass-border: rgba(255, 255, 255, 0.18);
    --backdrop-blur: 16px;
    
    /* Gradients */
    --gradient-primary: linear-gradient(135deg, #ff6b6b 0%, #4ecdc4 100%);
    --gradient-secondary: linear-gradient(135deg, #a29bfe 0%, #fd79a8 100%);
    --gradient-success: linear-gradient(135deg, #45b7d1 0%, #96ceb4 100%);
    --gradient-hero: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    
    /* Shadows */
    --shadow-sm: 0 2px 4px rgba(0,0,0,0.1);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.1);
    --shadow-lg: 0 10px 15px rgba(0,0,0,0.1);
    --shadow-xl: 0 20px 25px rgba(0,0,0,0.15);
    
    /* Animation */
    --transition-base: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    
    /* Platform-customizable hero sizing */
    --hero-h1-size: 3rem;
    --hero-h2-size: 2rem;
    --hero-p-size: 1.2rem;
    
    /* Platform-customizable form control sizing */
    --form-control-min-height: auto;
    --form-control-font-size: 16px;
}

/* Global font family using system font stack */
html, body {
    font-family: var(--app-font);
    margin: 0;
    padding: 0;
}

/* App container for consistent layout */
.app-container {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Glass card used across shared pages */
.glass-card {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--backdrop-blur));
    -webkit-backdrop-filter: blur(var(--backdrop-blur));
    border: 1px solid var(--glass-border);
    border-radius: 20px;
    box-shadow: var(--shadow-lg);
    transition: var(--transition-base);
    color: white;
}

.glass-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-xl);
}

.hero {
    padding: 2rem;
    margin-bottom: 2rem;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #ff6b6b 100%);
    color: white;
    text-align: center;
    border-radius: 20px;
    box-shadow: 0 20px 25px rgba(0, 0, 0, 0.15);
}

/* Text contrast utilities */
.text-contrast { color: white !important; font-weight: 600; text-shadow: 0 2px 4px rgba(0,0,0,0.5); }
.text-contrast-muted { color: rgba(255,255,255,0.9) !important; font-weight:500; text-shadow: 0 1px 2px rgba(0,0,0,0.3); }
.text-contrast-white { color: white !important; font-weight:600; }

/* Player card styling */
.player-card { cursor:pointer; transition: all 0.3s; background: rgba(255,255,255,0.4) !important; border:2px solid rgba(255,255,255,0.3);} 
.player-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: 0 20px 25px rgba(0,0,0,0.15); background: rgba(255,255,255,0.5) !important; }

/* Higher contrast styling for players needing a score this round */
.player-card.needs-score {
    background: rgba(255,255,255,0.9) !important;
    border:2px solid rgba(255,255,255,0.95) !important;
    color: #2d3436 !important;
    box-shadow: 0 6px 18px rgba(0,0,0,0.2);
}
.player-card.needs-score .card-title,
.player-card.needs-score .display-6,
.player-card.needs-score .score-pending,
.player-card.needs-score .score-hint {
    color: #2d3436 !important;
    text-shadow: none;
}
.player-card.needs-score .score-pending {
    background: rgba(254, 202, 87, 0.25);
    padding: 2px 6px;
    border-radius: 6px;
}
.player-card.needs-score:hover {
    background: #ffffff !important;
}

.leader-card { background: linear-gradient(135deg, #a29bfe 0%, #fd79a8 100%) !important; color:white !important; border:2px solid rgba(255,255,255,0.6);} 
.leader-badge { background: linear-gradient(135deg, #45b7d1 0%, #96ceb4 100%); color: white; padding:0.25rem 0.75rem; border-radius:20px; font-size:0.75rem; font-weight:600; }

/* Enhanced button styles */
.btn {
    border-radius: 15px;
    font-weight: 600;
    padding: 12px 24px;
    border: none;
    transition: var(--transition-base);
    font-size: 16px;
}

.btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-primary {
    background: var(--gradient-primary);
    color: white;
}

.btn-secondary {
    background: var(--gradient-secondary);
    color: white;
}

.btn-success {
    background: var(--gradient-success);
    color: white;
}

.btn-lg {
    padding: 16px 32px;
    font-size: 18px;
    border-radius: 20px;
}

/* Enhanced form styling */
.form-control { 
    border-radius:15px; 
    border:2px solid rgba(255,255,255,0.4); 
    background: rgba(255,255,255,0.9); 
    backdrop-filter: blur(10px); 
    padding:12px 16px; 
    color: #2d3436; 
    font-weight:500;
    font-size: 16px;
    transition: var(--transition-base);
}

.form-control:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.2rem rgba(255, 107, 107, 0.25);
    background: rgba(255, 255, 255, 1);
}

.form-control-lg {
    padding: 16px 20px;
    font-size: 18px;
}

.form-label { 
    font-weight:600; 
    color:white !important; 
    margin-bottom:0.5rem; 
}

/* Modal styling */
.modal-content { 
    border:none; 
    border-radius:20px; 
    box-shadow: 0 20px 25px rgba(0,0,0,0.15); 
}

.modal-header { 
    background: linear-gradient(135deg, #ff6b6b 0%, #4ecdc4 100%); 
    color:white; 
    border-radius:20px 20px 0 0; 
}

/* Badge styling */
.badge { 
    border-radius:8px; 
    padding:0.4rem 0.8rem; 
    font-weight:600; 
    font-size:0.75rem; 
}

/* Score status indicators */
.score-pending {
    color: var(--bs-warning) !important;
    font-weight: 600;
    animation: pulse-warning 2s infinite;
    background: linear-gradient(90deg, transparent 0%, rgba(254, 202, 87, 0.3) 50%, transparent 100%);
    background-size: 200% 100%;
    animation: pulse-warning 2s infinite, shimmer 3s infinite;
    padding: 2px 6px;
    border-radius: 8px;
    display: inline-block;
}

.score-entered {
    color: var(--bs-success) !important;
    font-weight: 700;
    background: rgba(69, 183, 209, 0.2);
    padding: 2px 6px;
    border-radius: 8px;
    border: 1px solid rgba(69, 183, 209, 0.4);
}

.score-hint {
    animation: fade-pulse 3s infinite;
}

/* Animations for score indicators */
@keyframes pulse-warning {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

@keyframes shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

@keyframes fade-pulse {
    0%, 100% { opacity: 0.8; }
    50% { opacity: 1; }
}

/* Shared navbar styling (web + MAUI) */
.navbar {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(var(--backdrop-blur));
    -webkit-backdrop-filter: blur(var(--backdrop-blur));
    border-bottom: 1px solid var(--glass-border);
    box-shadow: var(--shadow-md);
    transition: var(--transition-base);
}

/* Toggler (hamburger) consistent styling */
.navbar.navbar-dark .navbar-toggler {
    border-color: rgba(255,255,255,0.55);
    background: rgba(255,255,255,0.08);
    border-radius: 14px;
    min-width: 44px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.75rem;
}
.navbar.navbar-dark .navbar-toggler:focus,
.navbar.navbar-dark .navbar-toggler:hover {
    outline: none;
    background: rgba(255,255,255,0.15);
}
.navbar.navbar-dark .navbar-toggler .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(255,255,255,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
}

/* Brand & links */
.navbar-brand {
    font-weight: 700;
    font-size: 1.5rem;
    color: #ffffff !important; /* Force white brand text */
    text-shadow: 0 2px 4px rgba(0,0,0,0.4);
    display: flex;
    align-items: center;
    gap: 0.35rem;
    letter-spacing: .5px;
    text-decoration: none;
}
.navbar-brand:hover { transform: scale(1.02); }

.navbar .nav-link {
    color: #fff !important;
    font-weight: 500;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
    transition: var(--transition-base);
}
.navbar .nav-link:hover,
.navbar .nav-link:focus {
    color: var(--bs-warning) !important;
    transform: translateY(-1px);
}

/* Mobile collapse panel refinement (shared) */
@media (max-width: 767.98px) {
    .navbar .navbar-collapse.collapse.show {
        /* Use standard Bootstrap collapse panel (transparent so body bg shows) */
        background: transparent;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        border: none;
        border-radius: 0;
        padding: 0.5rem 0;
        margin-top: 0; /* flush under navbar */
        box-shadow: none;
    }
    .navbar .nav-link { text-shadow: none; }
}

/* Ensure confetti canvas is always on top */
canvas[style*="z-index"] {
    z-index: 99999 !important;
}

/* Validation styles */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

/* Error boundary styling */
.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

/* Layout-specific styles moved from web project */
/* Ensure hamburger toggler is visible (white) on glass background */
.navbar.navbar-dark .navbar-toggler {
    border-color: rgba(255,255,255,0.55);
}
.navbar.navbar-dark .navbar-toggler .navbar-toggler-icon {
    /* Force white hamburger bars */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(255,255,255,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* Optional: tweak brand and nav link contrast */
.navbar .navbar-brand,
.navbar .nav-link {
    color: #fff !important;
}
.navbar .nav-link:hover { color: #f8f9fa !important; }

/* Ensure confetti canvas is always on top */
canvas[style*="z-index"] {
    z-index: 99999 !important;
}


/* (navbar-brand styles consolidated above) */

.trophy-icon {
    font-size: 1.5rem;
    background: linear-gradient(135deg, #ffd700 0%, #ffed4e 25%, #ffd700 50%, #ffb347 75%, #ffd700 100%);
    background-size: 200% 200%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: trophy-shimmer 3s ease-in-out infinite;
    filter: drop-shadow(0 2px 4px rgba(255, 215, 0, 0.3));
}

.brand-text {
    color: white !important;
    font-weight: 600;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
    letter-spacing: 0.5px;
}

/* Trophy shimmer animation */
@keyframes trophy-shimmer {
    0%, 100% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
}

/* Button outline styles - consolidated from platform-specific files */
.btn-outline-primary {
    border: 2px solid var(--bs-primary);
    color: var(--bs-primary);
    background: rgba(255, 107, 107, 0.1);
}

.btn-outline-secondary {
    border: 2px solid var(--bs-secondary);
    color: var(--bs-secondary);
    background: rgba(78, 205, 196, 0.1);
}

.btn-outline-success {
    border: 2px solid var(--bs-success);
    color: var(--bs-success);
    background: rgba(69, 183, 209, 0.1);
}

.btn-outline-danger {
    border: 2px solid var(--bs-danger);
    color: var(--bs-danger);
    background: rgba(255, 118, 117, 0.1);
}

/* Legacy button styles - consolidated from platform-specific files */
h1:focus { outline: none; }

a, .btn-link { color: var(--bs-primary); }

.btn-primary { color: var(--primary-foreground); background-color: var(--bs-primary); border-color: var(--bs-primary); }
.btn-outline-secondary { color: var(--foreground); border-color: var(--border); }
.btn-warning { color: var(--accent-foreground); background-color: var(--accent); border-color: var(--accent); }

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem var(--ring);
}

/* Glass card text styling - consolidated from platform-specific files */
.glass-card .card-title,
.glass-card h1, .glass-card h2, .glass-card h3, 
.glass-card h4, .glass-card h5, .glass-card h6 {
    color: white !important;
    font-weight: 600;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.glass-card .display-6 {
    color: white !important;
    font-weight: 700;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.6);
}

.glass-card .text-muted {
    color: rgba(255, 255, 255, 0.9) !important;
    font-weight: 500;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

.glass-card .small {
    color: white !important;
    font-weight: 500;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

.glass-card .text-primary {
    color: var(--bs-warning) !important;
    font-weight: 600;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

/* Form control styling - consolidated from platform-specific files */
.form-control {
    background: rgba(255, 255, 255, 0.3);
    color: var(--bs-dark);
    min-height: var(--form-control-min-height);
    font-size: var(--form-control-font-size);
}

.form-control:focus {
    background: rgba(255, 255, 255, 0.4);
    color: var(--bs-dark);
}

.form-control::placeholder {
    color: rgba(45, 52, 54, 0.6);
}

/* Hero styling - consolidated with CSS custom properties */
.hero h1 {
    font-size: var(--hero-h1-size);
    font-weight: 700;
    margin-bottom: 1rem;
    text-shadow: 0 2px 6px rgba(0,0,0,0.4);
    color: white !important;
}

.hero h2 {
    font-size: var(--hero-h2-size);
    font-weight: 600;
    margin-bottom: 0.5rem;
    text-shadow: 0 2px 4px rgba(0,0,0,0.3);
    color: white !important;
}

.hero p {
    font-size: var(--hero-p-size);
    opacity: 0.95;
    margin-bottom: 2rem;
    text-shadow: 0 1px 3px rgba(0,0,0,0.3);
    color: white !important;
}

.hero .text-muted {
    color: rgba(255, 255, 255, 0.8) !important;
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

/* Alert styling - consolidated from platform-specific files */
.alert {
    border: none;
    border-radius: 12px;
    backdrop-filter: blur(10px);
    font-weight: 500;
    border: 2px solid transparent;
}

.alert-success {
    background: rgba(69, 183, 209, 0.3);
    color: var(--bs-dark) !important;
    border-color: rgba(69, 183, 209, 0.5);
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.8);
}

/* Badge styling - consolidated from platform-specific files */
.badge.bg-warning {
    background-color: var(--bs-warning) !important;
    color: var(--bs-dark) !important;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

/* Card body styling - consolidated from platform-specific files */
.player-card .card-body {
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(8px);
    border-radius: 12px;
    padding: 1.25rem;
}

.leader-card .card-body {
    background: rgba(255, 255, 255, 0.2) !important;
    backdrop-filter: blur(10px);
    border-radius: 12px;
    margin: 0.5rem;
}

.leader-card .card-title,
.leader-card .display-6,
.leader-card .small,
.leader-card .text-primary {
    color: white !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.leader-card .text-muted {
    color: rgba(255, 255, 255, 0.8) !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

/* Accessibility and performance - consolidated from platform-specific files */
@media (prefers-color-scheme: dark) {
    :root {
        --glass-bg: rgba(0, 0, 0, 0.3);
        --glass-border: rgba(255, 255, 255, 0.1);
    }
}

@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Layout content padding - consolidated from platform-specific files */
.content { 
    padding-top: 1.1rem; 
}
