/* css/style.css */
:root { 
    --primary: #7b9e58; 
    --primary-hover: #9bbd78; 
    --accent: #bef264; 
    --text-dark: #f8fafc; 
    --text-light: #94a3b8; 
    --border: #2c3e29; 
    --bg-gradient: linear-gradient(135deg, #283618 0%, #000000 100%); 
    --card-bg: rgba(20, 26, 18, 0.85); 
}

* { box-sizing: border-box; margin: 0; padding: 0; font-family: 'Poppins', sans-serif; }

body { background: var(--bg-gradient); color: var(--text-dark); line-height: 1.6; display: flex; flex-direction: column; min-height: 100vh; overflow-x: hidden; padding: 20px; font-size: 0.9rem; }

/* Header & Container */
.container, .dashboard-container { flex: 1; max-width: 1600px; width: 96%; margin: 0 auto 2rem; position: relative; z-index: 1; }
.header, header { padding: 1rem 2rem; display: flex; align-items: center; justify-content: space-between; background: rgba(10, 10, 10, 0.6); backdrop-filter: blur(10px); border-radius: 12px; border: 1px solid var(--border); margin-bottom: 20px; }
.logo-container { display: flex; align-items: center; gap: 12px; text-decoration: none; color: #fff; }

.header h2  { font-size: 1.1rem; font-weight: 400; letter-spacing: -0.5px; margin: 0;}
/*.logo-ball { width: 22px; height: 22px; background-color: var(--accent); border-radius: 50%; box-shadow: 0 0 10px rgba(190, 242, 100, 0.4); }*/

/* Buttons */
.btn, .btn-small { background: var(--primary); color: #000; border: none; border-radius: 6px; cursor: pointer; font-weight: 400; transition: background 0.2s; padding: 8px 16px; font-size: 0.9rem; }
.btn-small { padding: 8px; width: 100%; }
.btn:hover, .btn-small:hover { background: var(--accent); }
.btn-success { background: #22c55e; color: white; } .btn-success:hover { background: #16a34a; }
.btn-danger { background: rgba(239, 68, 68, 0.2); color: #fca5a5; border: 1px solid #ef4444; } .btn-danger:hover { background: #ef4444; color: white;}
.btn-logout { background: transparent; border: 1px solid var(--border); color: var(--text-light); padding: 0.5rem 1rem; border-radius: 8px; font-weight: 400; text-decoration: none; transition: all 0.2s; font-size: 0.9rem; }
.btn-logout:hover { border-color: #ef4444; color: #fca5a5; background: rgba(239, 68, 68, 0.1); }
.btn-outline { background: transparent; border: 1px solid var(--primary); color: var(--primary); padding: 5px 15px; border-radius: 6px; cursor: pointer; font-weight: 400; transition: all 0.2s; font-size: 0.9rem;}
.btn-outline:hover { background: var(--primary); color: #000; }

/* Grid & Panels */
.grid { display: grid; grid-template-columns: 1fr 2fr 1.5fr; gap: 25px; }
.content-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 25px; }
@media (max-width: 1200px) { .grid, .content-grid { grid-template-columns: 1fr; } }

.panel { background: var(--card-bg); padding: 25px; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,0.5); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,0.05); }
.panel h3 { margin-top: 0; margin-bottom: 20px; color: var(--primary-hover); border-bottom: 1px solid var(--border); padding-bottom: 10px; font-weight: 400; font-size: 1.05rem;}

/* Courts */
.courts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
.court-card { border: 1px solid var(--border); padding: 15px; border-radius: 8px; text-align: center; display: flex; flex-direction: column; justify-content: space-between; background: rgba(0,0,0,0.3); min-height: 140px;}
.court-card.active { border-color: #ef4444; background: rgba(239, 68, 68, 0.1); }
.court-card.open { border-color: var(--primary); background: rgba(123, 158, 88, 0.1); }
.court-card.pending { border-color: #eab308; background: rgba(234, 179, 8, 0.1); }
.court-card h4 { font-size: 0.9rem; color: var(--text-light); margin-bottom: 5px; font-weight: 400; }
.court-card p { font-weight: 400; color: #fff; margin: auto 0;}
.court-timer { font-family: monospace; font-size: 1.25rem; font-weight: 400; color: var(--accent); background: #000; padding: 5px 10px; border-radius: 6px; border: 1px solid #3f4a3c; display: inline-block; margin: 10px auto; letter-spacing: 2px; }

/* Status Banners */
.status-banner { border-radius: 16px; padding: 2rem; text-align: center; margin-bottom: 2rem; box-shadow: 0 10px 30px rgba(0,0,0,0.5); backdrop-filter: blur(10px); animation: slideDown 0.5s ease-out; }
.status-banner h2 { font-size: 1.5rem; font-weight: 400; margin-bottom: 0.5rem; }
.status-banner p { font-size: 0.9rem; opacity: 0.9; color: var(--text-dark); font-weight: 400; }
.status-idle { background: rgba(255, 255, 255, 0.05); border: 1px solid var(--border); color: #f8fafc; }
.status-waiting { background: rgba(59, 130, 246, 0.15); border: 1px solid #3b82f6; color: #93c5fd; }
.status-playing { background: rgba(190, 242, 100, 0.1); border: 1px solid var(--accent); color: var(--accent); }
.status-pending { background: rgba(234, 179, 8, 0.15); border: 1px solid #eab308; color: #fde047; }
.status-rejected { background: rgba(239, 68, 68, 0.15); border: 1px solid #ef4444; color: #fca5a5; }
@keyframes slideDown { from { opacity: 0; transform: translateY(-20px); } to { opacity: 1; transform: translateY(0); } }

/* Form Elements */
input, select { width: 100%; padding: 10px; margin-bottom: 12px; border-radius: 6px; border: 1px solid var(--border); background: rgba(0,0,0,0.5); color: #fff; box-sizing: border-box; font-family: 'Poppins', sans-serif; font-size: 0.9rem;}
select option { background: #1a2318; color: #fff; }
input::placeholder { color: #64748b; }
label { font-weight: 400; font-size: 0.9rem; margin-bottom: 5px; display: block; color: var(--text-light);}
.dynamic-inputs { background: rgba(0,0,0,0.2); padding: 15px; border-radius: 8px; margin-bottom: 15px; border: 1px solid var(--border); }

/* Tables & Lists */
table { width: 100%; border-collapse: collapse; }
td, th { padding: 10px; border-bottom: 1px solid var(--border); text-align: left; font-weight: 400; font-size: 0.9rem;}
ul { list-style: none; }
li { padding: 1rem 0; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }
li:last-child { border-bottom: none; }
.list-title { font-weight: 400; color: #fff; display: block; font-size: 0.9rem;}
.list-subtitle { font-size: 0.85rem; color: var(--text-light); }
.empty-state { text-align: center; color: var(--text-light); padding: 2rem 0; font-style: italic; }

/* Badges & Alerts */
.badge { padding: 4px 8px; border-radius: 6px; font-size: 0.85rem; font-weight: 400; background: rgba(255,255,255,0.05); color: var(--text-light); border: 1px solid var(--border); display: inline-block;}
.badge-done { background: rgba(255,255,255,0.05); color: var(--text-light); border: 1px solid var(--border); }
.alert { padding: 15px; border-radius: 8px; margin-bottom: 20px; font-weight: 400; font-size: 0.9rem;}
.alert-success { background: rgba(34, 197, 94, 0.15); color: #86efac; border: 1px solid #22c55e; }
.alert-error { background: rgba(239, 68, 68, 0.15); color: #fca5a5; border: 1px solid #ef4444; }
.notification-bar { background: rgba(234, 179, 8, 0.1); border-left: 6px solid #eab308; padding: 15px 20px; margin-bottom: 20px; border-radius: 8px; display: flex; justify-content: space-between; align-items: center; box-shadow: 0 4px 6px rgba(0,0,0,0.5); }

/* Modals */
.modal-overlay { display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.8); z-index:9999; justify-content:center; align-items:center; }
.modal-content { background: var(--card-bg); width: 450px; max-width: 90%; border: 1px solid var(--border); padding: 25px; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,0.8); backdrop-filter: blur(10px);}
.profile-row { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border); }
.profile-row:last-child { border-bottom: none; }
.profile-label { color: var(--text-light); font-weight: 400; font-size: 0.9rem; }
.profile-value { color: #fff; font-weight: 400; text-align: right; font-size: 0.9rem; }

/* Simple-DataTables Overrides */
.dataTable-wrapper { font-family: 'Poppins', sans-serif; color: var(--text-dark); font-size: 0.9rem; } 
.dataTable-input { background: rgba(0,0,0,0.5); color: #fff; border: 1px solid var(--border); border-radius: 6px; padding: 6px 10px; outline: none; font-size: 0.9rem; }
.dataTable-input:focus { border-color: var(--primary); }
.dataTable-selector { background: rgba(0,0,0,0.5); color: #fff; border: 1px solid var(--border); border-radius: 6px; padding: 4px 8px; outline: none; font-size: 0.9rem; }
.dataTable-table > tbody > tr > td, .dataTable-table > thead > tr > th { border-bottom: 1px solid var(--border); padding: 8px 10px; font-weight: 400; font-size: 0.9rem;}
.dataTable-table > thead > tr > th { text-align: left; color: var(--text-light); }
.dataTable-pagination a { color: var(--text-light); border-radius: 4px; border: 1px solid transparent; padding: 4px 8px; font-size: 0.9rem; }
.dataTable-pagination .active a, .dataTable-pagination a:hover { background: var(--primary); color: #000; border-color: var(--primary); }
.dataTable-info { color: var(--text-light); font-size: 0.85rem; font-weight: 400; }

/* Horizontal Paddle Rack Layout */
.paddle-rack { display: flex; gap: 20px; overflow-x: auto; padding: 20px 10px; background: rgba(0, 0, 0, 0.4); border-radius: 12px; border: 1px solid var(--border); scroll-behavior: smooth; }
.paddle-rack::-webkit-scrollbar { height: 8px; }
.paddle-rack::-webkit-scrollbar-track { background: rgba(0,0,0,0.2); border-radius: 4px; }
.paddle-rack::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.paddle-rack::-webkit-scrollbar-thumb:hover { background: var(--primary); }
.paddle-container { display: flex; flex-direction: column; align-items: center; flex-shrink: 0; width: 160px; position: relative; }
.paddle-rank { font-size: 0.8rem; color: var(--accent); margin-bottom: 5px; text-transform: uppercase; letter-spacing: 1px; }
.paddle-face { width: 140px; height: 170px; background: rgba(30, 41, 26, 0.9); border: 2px solid var(--primary); border-radius: 40px 40px 30px 30px; display: flex; flex-direction: column; justify-content: space-between; padding: 15px 10px; text-align: center; position: relative; box-shadow: 0 8px 20px rgba(0,0,0,0.4); transition: transform 0.2s, border-color 0.2s; }
.paddle-face:hover { transform: translateY(-5px); border-color: var(--accent); }
.paddle-face.my-paddle { border-color: var(--accent); background: rgba(123, 158, 88, 0.15); box-shadow: 0 0 15px rgba(190, 242, 100, 0.2); }
.paddle-handle { width: 24px; height: 50px; background: linear-gradient(90deg, #111 0%, #333 50%, #111 100%); border-radius: 0 0 4px 4px; border: 1px solid #000; position: relative; box-shadow: 0 4px 10px rgba(0,0,0,0.5); }
.paddle-names { font-size: 0.85rem; color: #fff; word-wrap: break-word; margin-top: 10px; line-height: 1.3; }
.paddle-type { font-size: 0.75rem; color: var(--text-light); margin-bottom: 5px; }
.paddle-holes { display: flex; justify-content: center; gap: 8px; opacity: 0.3; margin-bottom: 5px; }
.hole { width: 5px; height: 5px; background: var(--text-light); border-radius: 50%; }

/* Time Limit Warning Border Animation */
.court-card.time-warning { border-color: #f97316; background: rgba(249, 115, 22, 0.08); animation: soft-pulse 2s infinite ease-in-out; }
@keyframes soft-pulse { 0% { box-shadow: 0 0 0 0 rgba(249, 115, 22, 0.3); } 70% { box-shadow: 0 0 0 6px rgba(249, 115, 22, 0); } 100% { box-shadow: 0 0 0 0 rgba(249, 115, 22, 0); } }
.leaderboard-rank { color: var(--accent); width: 40px; }

/* Waiting Queue Row Layout */
.waiting-list-container { display: flex; flex-direction: column; gap: 10px; }
.waiting-row-card { background: rgba(0, 0, 0, 0.3); border: 1px solid var(--border); border-radius: 8px; padding: 12px; display: flex; align-items: center; justify-content: space-between; gap: 15px; }