/* NOOR Game Management System - Main Styles */

:root{
  --primary:#6366f1;
  --primary-dark:#4f46e5;
  --success:#10b981;
  --danger:#ef4444;
  --warning:#f59e0b;
  --bg:#0f172a;
  --panel:#1e293b;
  --panel-light:#334155;
  --text:#f1f5f9;
  --text-dim:#94a3b8;
  --border:#475569;
  --shadow:0 8px 30px rgba(0,0,0,0.5);
  --shadow-light:0 4px 15px rgba(0,0,0,0.2);
}

/* Animations */
@keyframes snowflake-fall {
    0% { transform: translateY(-10vh) rotate(0deg); opacity: 0; }
    100% { transform: translateY(100vh) rotate(360deg); opacity: 1; }
}

@keyframes pulse {
    from { opacity: 0.9; transform: scaleY(1); }
    to { opacity: 1; transform: scaleY(1.03); }
}

@keyframes logo-glow {
    from { text-shadow: 0 0 5px rgba(99, 102, 241, 0.5); }
    to { text-shadow: 0 0 15px rgba(99, 102, 241, 0.8); }
}

@keyframes clock-pulse {
    from { text-shadow: 0 0 8px rgba(245, 158, 11, 0.6); }
    to { text-shadow: 0 0 15px rgba(245, 158, 11, 0.9); }
}

@keyframes shift-glow {
    from { box-shadow: 0 0 5px var(--success); }
    to { box-shadow: 0 0 15px var(--success); }
}

@keyframes vip-glow {
    from { box-shadow: 0 0 5px var(--warning); }
    to { box-shadow: 0 0 15px var(--warning); }
}

@keyframes status-glow {
    from { box-shadow: 0 0 5px var(--success); }
    to { box-shadow: 0 0 15px var(--success); }
}

@keyframes timer-flash {
    from { opacity: 1; }
    to { opacity: 0.8; }
}

@keyframes timer-flash-red {
    from { opacity: 1; text-shadow: 0 0 5px var(--danger); }
    to { opacity: 0.7; text-shadow: none; }
}

@keyframes modal-appear {
    0% { transform: scale(0.8); opacity: 0; }
    100% { transform: scale(1); opacity: 1; }
}

/* Base Styles */
*{box-sizing:border-box;margin:0;padding:0;font-family:'Segoe UI',Tahoma,sans-serif;}
html{font-size:16px;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
body{background:var(--bg);color:var(--text);overflow:hidden;height:100vh;min-height:100vh;display:flex;flex-direction:column;position:relative;min-width:320px;}

/* Snowfall */
.snowflake {
    color: white;
    font-size: 1em;
    font-family: Arial, sans-serif;
    text-shadow: 0 0 1px #000;
    position: absolute;
    width: 15px;
    height: 15px;
    top: -10%;
    z-index: 10000;
    pointer-events: none;
    animation-name: snowflake-fall;
    animation-timing-function: linear;
    animation-duration: 20s; 
    animation-iteration-count: infinite;
}

/* Login Screen */
.login-screen{position:fixed;inset:0;background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity 0.5s, visibility 0.5s;}
.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;width:100%;}
.login-header{text-align:center;margin-bottom:30px;color:var(--text);}
.login-header .logo{font-size:2.2rem;margin-bottom:8px;font-weight:900;text-shadow:0 0 10px rgba(99,102,241,0.5);}
.login-header h1{font-size:1.1rem;font-weight:300;opacity:0.9;}
.login-box{background:var(--panel);padding:30px;border-radius:15px;box-shadow:var(--shadow);width:100%;max-width:380px;border:1px solid var(--border);}
.login-status{text-align:center;margin-top:8px;color:var(--text-dim);font-size:0.75rem;min-height:1rem}
.login-form h2{color:var(--text);margin-bottom:25px;text-align:center;font-weight:600;}
.input-group{margin-bottom:15px;}
.input-group input{width:100%;padding:10px 12px;border:2px solid var(--border);border-radius:8px;font-size:0.9rem;transition:all 0.3s;background:var(--bg);color:var(--text);}
.input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,0.2);outline:none;}
.login-btn{width:100%;padding:12px;background:var(--primary);color:white;border:none;border-radius:8px;font-size:0.9rem;font-weight:600;cursor:pointer;transition:all 0.3s;}
.login-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 5px 15px rgba(99,102,241,0.4);}
.login-footer{margin-top:25px;text-align:center;padding-top:20px;border-top:1px solid var(--border);}
.login-footer .clock{font-size:1.2rem;font-weight:700;color:var(--warning);font-family:'Courier New',monospace;margin-bottom:4px;text-shadow:0 0 5px rgba(245,158,11,0.5);}
.login-footer .date{font-size:0.75rem;color:var(--text-dim);}

/* New Year Banner */
.new-year-banner {
    background: linear-gradient(90deg, #ff4e50 0%, #fc913a 50%, #f9d423 100%);
    color: white;
    text-align: center;
    padding: 8px 0;
    font-weight: 700;
    font-size: 1.1rem;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
    animation: pulse 1.5s infinite alternate;
}

/* Topbar */
.topbar{background:var(--panel);padding:15px 25px;display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid var(--border);box-shadow:var(--shadow);position:relative;z-index:100;}
.topbar-brand{display:flex;flex-direction:column;gap:2px;}
.club-name{font-size:1.5rem;font-weight:900;color:var(--primary);text-transform:uppercase;text-shadow:0 0 5px rgba(99, 102, 241, 0.5);animation: logo-glow 2s infinite alternate;}
.brand-subtitle{font-size:0.7rem;color:var(--text-dim);font-weight:400;}
.nav{display:flex;gap:10px;}
.nav button{background:transparent;border:none;color:var(--text);padding:10px 18px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease-in-out;}
.nav button:hover{background:var(--panel-light);transform:scale(1.05);}
.nav button.active{background:var(--primary);color:#fff;box-shadow:0 4px 10px rgba(99, 102, 241, 0.5);transform:scale(1.05);}
.topbar-right{display:flex;align-items:center;gap:15px;}

/* User Profile Dropdown */
.profile-dropdown{position:relative;}
.profile-btn{display:flex;align-items:center;gap:10px;background:var(--panel);padding:10px 15px;border-radius:12px;border:1px solid var(--border);cursor:pointer;transition:all 0.3s;color:var(--text);}
.profile-btn:hover{background:var(--panel-light);border-color:var(--primary);}
.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;box-shadow:0 2px 8px rgba(99,102,241,0.3);letter-spacing:1px;}
.user-info{display:flex;flex-direction:column;gap:2px;}
.user-name{font-weight:700;font-size:0.95rem;color:var(--text);}
.user-role{font-size:0.75rem;color:var(--text-dim);}
.dropdown-arrow{font-size:0.7rem;color:var(--text-dim);transition:transform 0.3s;}
.profile-btn.active .dropdown-arrow{transform:rotate(180deg);}

/* Profile Menu */
.profile-menu{position:absolute;top:calc(100% + 10px);right:0;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);min-width:280px;z-index:1000;padding:10px;animation:slideDown 0.3s ease;}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:translateY(0);}}
.profile-menu-section{padding:10px 0;}
.profile-menu-title{font-weight:700;font-size:0.85rem;color:var(--primary);margin-bottom:8px;padding:0 5px;}
.balance-item{display:flex;justify-content:space-between;padding:6px 8px;border-radius:6px;margin-bottom:4px;background:var(--bg);}
.balance-item span{color:var(--text-dim);font-size:0.75rem;}
.balance-item strong{color:var(--text);font-size:0.75rem;}
.shift-status-item{padding:8px 10px;margin-bottom:8px;}
.shift-indicator-small{padding:5px 10px;border-radius:6px;font-size:0.7rem;font-weight:600;background:var(--panel-light);color:var(--text-dim);}
.shift-indicator-small.active{background:var(--success);color:white;box-shadow:0 0 10px var(--success);}
.profile-menu-divider{height:1px;background:var(--border);margin:5px 0;}
.profile-menu-btn{width:100%;padding:8px 12px;background:var(--panel-light);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:0.75rem;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all 0.2s;margin-bottom:4px;}
.profile-menu-btn:hover{background:var(--primary);color:white;transform:translateX(3px);}
.profile-menu-btn span{font-size:1.1rem;}
.profile-menu-logout{background:var(--danger);color:white;border-color:var(--danger);}
.profile-menu-logout:hover{background:#dc2626;transform:translateX(3px);}

/* Subscription Info */
.subscription-info{padding:10px;background:var(--bg);border-radius:8px;margin-bottom:10px;}
.subscription-status{margin-bottom:5px;}
.subscription-badge{padding:6px 12px;border-radius:8px;font-size:0.85rem;font-weight:600;background:var(--panel-light);color:var(--text-dim);}
.subscription-badge.active{background:linear-gradient(135deg,var(--success),#10b981);color:white;box-shadow:0 0 10px var(--success);}
.subscription-details{font-size:0.85rem;color:var(--text-dim);margin-top:5px;}
.subscription-details strong{color:var(--text);}

/* Subscription Plans */
.subscription-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin:20px 0;}
.plan-card{background:var(--panel);border:2px solid var(--border);border-radius:12px;padding:20px;position:relative;transition:all 0.3s;}
.plan-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.plan-popular{border-color:var(--primary);box-shadow:0 0 20px rgba(99,102,241,0.3);}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--primary);color:white;padding:4px 12px;border-radius:20px;font-size:0.75rem;font-weight:700;}
.plan-header{text-align:center;margin-bottom:15px;}
.plan-header h4{color:var(--text);margin-bottom:8px;font-size:1rem;}
.plan-price{font-size:1.4rem;font-weight:800;color:var(--primary);margin-bottom:4px;}
.plan-discount{font-size:0.7rem;color:var(--success);font-weight:600;}
.plan-features{list-style:none;padding:0;margin:15px 0;}
.plan-features li{padding:6px 0;color:var(--text-dim);font-size:0.75rem;}

.btn-sm{padding:6px 10px;font-size:0.85rem;}
.clock-container{display:flex;flex-direction:column;align-items:center;}
.clock{font-size:1.6rem;font-weight:800;color:var(--warning);font-family:'Dank Mono',monospace;text-shadow:0 0 8px rgba(245, 158, 11, 0.6);animation: clock-pulse 1s infinite alternate;}
.date{font-size:0.75rem;color:var(--text-dim);margin-top:4px;}

/* Balance Boxes */
.balance-group{display:flex;gap:15px;}
.balance-box{padding:6px 12px;border-radius:8px;font-weight:700;color:#fff;box-shadow:var(--shadow-light);text-align:center;transition:transform 0.3s, box-shadow 0.3s;}
.balance-box:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.3);}
.balance-total{background:var(--success);color:#fff;}
.balance-cash{background:#3b82f6;}
.balance-transfer{background:#f97316;}
.balance-debt{background:var(--danger);color:#fff;}
.balance-box div:first-child{font-size:0.65rem;opacity:0.8;}
.balance-box div:last-child{font-size:0.9rem;}

.shift-indicator{background:var(--warning);padding:8px 14px;border-radius:8px;font-weight:700;color:#000;font-size:0.85rem;box-shadow:var(--shadow-light);transition:all 0.3s;}
.shift-indicator.open{background:var(--success);color:#fff;animation: shift-glow 2s infinite alternate;}

/* Main Layout */
.main-container{flex:1;display:flex;overflow:hidden;}
.left-panel{width:300px;background:var(--panel);border-right:2px solid var(--border);padding:15px;overflow-y:auto;transition:width 0.3s;}
.content-area{flex:1;padding:20px;overflow-y:auto;transition:all 0.3s;}
.right-panel{width:300px;background:var(--panel);border-left:2px solid var(--border);padding:15px;overflow-y:auto;transition:width 0.3s;}

/* Left Panel Stats */
.notes-section,.stats-section,.debtors-preview{background:var(--panel-light);padding:15px;border-radius:12px;margin-bottom:15px;box-shadow:var(--shadow-light);transition:transform 0.3s, box-shadow 0.3s;}
.notes-section:hover,.stats-section:hover,.debtors-preview:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.section-title{font-size:1rem;font-weight:800;color:var(--primary);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.notes-section textarea{width:100%;min-height:100px;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:0.8rem;resize:vertical;transition:border-color 0.3s, box-shadow 0.3s;}
.notes-section textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(99, 102, 241, 0.3);}
.stat-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--border);font-size:0.85rem;transition:background 0.3s;}
.stat-item:hover{background:rgba(255,255,255,0.05);border-radius:5px;}
.stat-item:last-child{border:none;}
.stat-value{font-weight:800;color:var(--success);}
.active-sessions{background:var(--bg);padding:12px;border-radius:8px;margin-top:12px;transition:all 0.3s;}
.active-sessions:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.2);}
.session-row{display:flex;justify-content:space-between;padding:6px;font-size:0.8rem;border-bottom:1px solid var(--border);transition:background 0.3s;}
.session-row:hover{background:rgba(255,255,255,0.05);}
.debtor-row{display:flex;justify-content:space-between;padding:6px;font-size:0.8rem;border-bottom:1px solid var(--border);color:var(--danger);transition:background 0.3s;}
.debtor-row:hover{background:rgba(255,255,255,0.05);}
.debtor-preview-item{display:flex;align-items:center;gap:8px;padding:8px;border-bottom:1px solid var(--border);transition:all 0.3s;}
.debtor-preview-item:hover{background:rgba(239,68,68,0.1);border-radius:8px;}
.debtor-preview-item:last-child{border-bottom:none;}
.debtor-rank{font-weight:800;font-size:0.85rem;color:var(--warning);min-width:30px;}
.debtor-name{flex:1;font-size:0.8rem;color:var(--text);}
.debtor-amount{font-weight:700;color:var(--danger);font-size:0.8rem;}

/* Game Cards */
.game-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-top:20px;}
.game-card{background:var(--panel);border:2px solid var(--border);border-radius:15px;padding:18px;position:relative;transition:all .4s;box-shadow:var(--shadow-light);overflow:hidden;}
.game-card::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);transition:left 0.5s;}
.game-card:hover::before{left:100%;}
.game-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.game-card.vip{border-color:var(--warning);background:linear-gradient(135deg,var(--panel) 0%,rgba(245,158,11,0.15) 100%);}
.vip-badge{position:absolute;top:12px;right:12px;background:var(--warning);color:#000;padding:5px 12px;border-radius:6px;font-weight:800;font-size:0.75rem;box-shadow:var(--shadow-light);animation: vip-glow 2s infinite alternate;}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.card-title{font-size:1.1rem;font-weight:800;color:var(--text);}
.status-badge{padding:5px 10px;border-radius:6px;font-size:0.75rem;font-weight:700;transition:background 0.3s;}
.status-free{background:var(--border);color:var(--text-dim);}
.status-active{background:var(--success);color:#fff;animation: status-glow 1.5s infinite alternate;}
.timer-display{font-size:2.2rem;font-weight:800;color:var(--primary);font-family:'Courier New',monospace;text-align:center;margin:15px 0;animation: timer-flash 1s infinite alternate;border-radius:8px;padding:4px;transition:all 0.3s;}
.game-card.time-low .timer-display{color:var(--danger);animation: timer-flash-red 0.5s infinite alternate;}
.cost-display{text-align:center;font-size:1rem;color:var(--warning);margin:8px 0;font-weight:600;}
.game-buttons{display:flex;gap:10px;margin-bottom:20px;}

/* Buttons */
.btn{padding:8px 12px;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:0.8rem;transition:all .3s ease-in-out;flex:1;box-shadow:var(--shadow-light);position:relative;overflow:hidden;}
.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s;}
.btn:hover::before{left:100%;}
.btn-primary{background:var(--primary);color:#fff;}
.btn-success{background:var(--success);color:#fff;}
.btn-danger{background:var(--danger);color:#fff;}
.btn-warning{background:var(--warning);color:#000;}
.btn:hover{opacity:0.9;transform:scale(1.03);box-shadow:0 5px 15px rgba(0,0,0,0.3);}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}

/* Bar Items */
.bar-items-list{background:var(--bg);padding:12px;border-radius:8px;max-height:200px;overflow-y:auto;margin-top:12px;border:1px solid var(--border);transition:all 0.3s;}
.bar-items-list:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.2);}
.bar-item-row{display:flex;justify-content:space-between;align-items:center;padding:6px;border-bottom:1px dashed var(--border);font-size:0.8rem;transition:background 0.3s;}
.bar-item-row:hover{background:rgba(255,255,255,0.05);}
.bar-item-row:last-child{border:none;}
.remove-item{background:var(--danger);color:#fff;border:none;padding:3px 8px;border-radius:6px;cursor:pointer;font-size:0.8rem;transition:transform 0.2s, background 0.3s;}
.remove-item:hover{transform:scale(1.1);background:#dc2626;}
.bar-total{background:var(--success);color:#fff;padding:10px;border-radius:8px;text-align:center;font-weight:800;margin-top:10px;transition:all 0.3s;}
.bar-total:hover{transform:scale(1.02);}

/* Receipts */
.receipt-filters{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap;}
.filter-btn{background:var(--panel-light);color:var(--text);border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:0.8rem;font-weight:600;transition:all 0.3s;}
.filter-btn:hover{background:var(--primary-dark);transform:translateY(-2px);}
.filter-btn.active{background:var(--primary);color:#fff;box-shadow:0 0 10px rgba(99, 102, 241, 0.5);transform:translateY(-2px);}
.receipt-item{background:var(--panel-light);padding:12px;border-radius:8px;margin-bottom:12px;font-size:0.8rem;border-left:4px solid var(--primary);box-shadow:var(--shadow-light);transition:all 0.3s;}
.receipt-item:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.receipt-header{font-weight:800;color:var(--primary);margin-bottom:8px;font-size:0.9rem;display:flex;justify-content:space-between;align-items:center;}
.receipt-item.cancelled .receipt-header { color: var(--danger); }
.receipt-item.cancelled { border-left-color: var(--danger); }
.receipt-row{display:flex;justify-content:space-between;margin:5px 0;color:var(--text-dim);}
.receipt-row strong{color:var(--text);}
.receipt-total{background:var(--success);color:#fff;padding:12px;border-radius:8px;text-align:center;font-weight:800;margin-top:15px;font-size:1rem;box-shadow:var(--shadow);transition:all 0.3s;}
.receipt-total:hover{transform:scale(1.02);}
.btn-print{background:var(--primary);color:#fff;padding:5px 10px;font-size:0.8rem;border:none;border-radius:5px;cursor:pointer;transition:all 0.3s;}
.btn-print:hover{background:var(--primary-dark);transform:scale(1.05);}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,0.9);display:flex;align-items:center;justify-content:center;z-index:10001;opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s;}
.modal.show{opacity:1;visibility:visible;}
.modal-content{background:var(--panel);padding:20px;border-radius:15px;min-width:400px;max-width:650px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);transform:scale(0.9);transition:transform 0.3s;animation: modal-appear 0.3s ease-out;}
.modal.show .modal-content{transform:scale(1);}
.table-management-modal .modal-content{max-width:800px;}
.modal-header{font-size:1.4rem;font-weight:800;color:var(--primary);margin-bottom:20px;text-align:center;}
.modal-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-bottom:20px;}
.modal-btn{padding:15px;border:2px solid var(--border);background:var(--panel-light);color:var(--text);border-radius:12px;cursor:pointer;font-weight:700;text-align:center;transition:all .3s;position:relative;overflow:hidden;font-size:0.85rem;}
.modal-btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.1),transparent);transition:left 0.5s;}
.modal-btn:hover::before{left:100%;}
.modal-btn:hover{border-color:var(--primary);background:var(--primary-dark);color:#fff;transform:scale(1.05);}
.modal-btn.active{border-color:var(--success);background:var(--success);color:#fff;transform:scale(1.05);}
.modal-close{display:flex;justify-content:center;gap:15px;margin-top:25px;}
.modal-input{width:100%;padding:8px 10px;border:2px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:0.8rem;margin-bottom:12px;transition:border-color 0.3s, box-shadow 0.3s;}
.modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(99, 102, 241, 0.3);}
.modal-text{text-align:center;margin:20px 0;color:var(--text);line-height:1.7;}

/* Forms */
.form-group{margin-bottom:15px;}
.form-group label{display:block;margin-bottom:5px;color:var(--text);font-weight:600;font-size:0.75rem;}
.form-group input,.form-group textarea{width:100%;padding:10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:0.85rem;transition:border-color 0.3s, box-shadow 0.3s;}
.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(99, 102, 241, 0.3);}
.form-group textarea{min-height:100px;resize:vertical;}

/* Bar Products Grid */
.bar-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;margin-top:15px;}
.bar-product-card{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:18px;border-radius:12px;text-align:center;cursor:pointer;transition:all .3s;box-shadow:var(--shadow-light);position:relative;overflow:hidden;}
.bar-product-card::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s;}
.bar-product-card:hover::before{left:100%;}
.bar-product-card:hover{transform:translateY(-8px) scale(1.05);box-shadow:var(--shadow);}
.product-name{font-weight:800;font-size:1rem;margin-bottom:8px;}
.product-price{font-size:0.85rem;opacity:0.9;}

/* Tables */
.data-table{width:100%;border-collapse:collapse;margin-top:20px;transition:all 0.3s;}
.data-table:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.2);}
.data-table th,.data-table td{padding:10px;text-align:left;border-bottom:1px solid var(--border);font-size:0.85rem;transition:background 0.3s;}
.data-table th{background:var(--panel-light);font-weight:800;color:var(--primary);position:sticky;top:0;}
.data-table tr:hover{background:var(--panel-light);}

/* Debtors */
.debtors-list{margin-top:20px;}
.debtor-card{background:var(--panel-light);padding:15px;border-radius:12px;margin-bottom:12px;border-left:4px solid var(--danger);box-shadow:var(--shadow-light);transition:all 0.3s;}
.debtor-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.debtor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.debtor-name{font-weight:800;color:var(--danger);font-size:1rem;}
.debtor-total{font-weight:800;color:var(--danger);font-size:1.1rem;}
.debtor-details{background:var(--bg);padding:12px;border-radius:8px;margin:12px 0;font-size:0.75rem;border:1px solid var(--border);transition:all 0.3s;}
.debtor-details:hover{transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.2);}
.debt-item{display:flex;justify-content:space-between;padding:6px;border-bottom:1px dashed var(--border);font-size:0.8rem;transition:background 0.3s;}
.debt-item:hover{background:rgba(255,255,255,0.05);}
.debtor-actions{display:flex;gap:10px;margin-top:15px;}

#addUserForm{background:var(--panel-light);padding:15px;border-radius:8px;margin-top:15px;border:1px solid var(--border);}

/* Scrollbar */
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px;transition:background 0.3s;}
::-webkit-scrollbar-thumb:hover{background:var(--primary-dark);}

/* Inline utility classes for legacy inline styles */
.text-center { text-align: center; }
.mt-15 { margin-top: 15px; }
.mb-15 { margin-bottom: 15px; }
.color-dim { color: var(--text-dim); }
.color-danger { color: var(--danger); }
.fw-700 { font-weight: 700; }
.fw-800 { font-weight: 800; }
.grid-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
.full-width { width: 100%; }
.hidden { display: none; }
.text-muted { color: #64748b; }
.link-accent { color: #667eea; font-weight: 600; }
.modal-footer-center { margin-top: 20px; text-align: center; }
.section-subtitle { color: var(--primary); font-size: 1rem; margin: 15px 0 10px; }
.flex-column-5 { display: flex; flex-direction: column; gap: 5px; }
.club-info-banner { font-size: 0.85rem; color: var(--warning); font-weight: 600; }
.mt-8 { margin-top: 8px; }
.mt-10 { margin-top: 10px; }
.mt-20 { margin-top: 20px; }
.mt-30 { margin-top: 30px; }
.mb-20 { margin-bottom: 20px; }
.stat-highlight { border-top: 2px solid var(--primary); padding-top: 10px; margin-top: 10px; }
.icon-xl { font-size: 2rem; margin-bottom: 8px; }
.modal-grid-2 { grid-template-columns: repeat(2, 1fr); }
.modal-grid-3 { grid-template-columns: repeat(3, 1fr); }
.modal-close-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px; }
.grid-span-full { grid-column: 1 / -1; }
.scrollable-list { max-height: 200px; overflow-y: auto; padding-right: 10px; }
.text-warning { color: var(--warning); }
.text-primary { color: var(--primary); }
.text-success { color: var(--success); }
.color-blue { color: #3b82f6; }
.modal-danger { background: var(--danger); }
.text-white { color: #fff; }
.text-xl { font-size: 1.5rem; }
.modal-wide { max-width: 750px; }
.grid-2col-lg { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.grid-2col-tight { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.btn-blue { background: #3b82f6; color: #fff; }
.page-title { color: var(--primary); margin-bottom: 20px; }
.text-danger { color: var(--danger); }
.table-container { max-height: 80vh; overflow-y: auto; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.p-20 { padding: 20px; }
.out-of-stock { background: var(--danger); opacity: 0.6; cursor: not-allowed; }
.product-stock { font-size: 0.8rem; margin-top: 5px; color: #fff; }
.low-stock { color: var(--warning); }
.payment-summary { background: var(--bg); padding: 15px; border-radius: 8px; margin-bottom: 15px; }
.payment-row { display: flex; justify-content: space-between; margin: 5px 0; }
.payment-total { display: flex; justify-content: space-between; margin-top: 10px; padding-top: 10px; border-top: 2px solid var(--primary); }
.total-label { font-size: 1.1rem; }
.total-amount { font-size: 1.2rem; color: var(--success); }
.payment-product { font-size: 1.2rem; margin-bottom: 10px; }
.payment-total-simple { font-size: 1.4rem; color: var(--success); }
.debtor-name-display { margin-bottom: 10px; font-size: 1.2rem; }
.debt-total-display { display: flex; justify-content: space-between; margin-top: 10px; padding-top: 10px; border-top: 2px solid var(--danger); }
.debt-amount { font-size: 1.2rem; color: var(--danger); }

/* Bar Products Management */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 12px; text-align: left; }
.table thead { background: var(--panel); position: sticky; top: 0; z-index: 1; }
.table tbody tr { border-bottom: 1px solid var(--border); transition: background 0.2s; }
.table tbody tr:hover { background: var(--panel-light); }
.btn-small { padding: 6px 12px; font-size: 0.85rem; margin: 0 3px; }

/* Media Queries - Mobile Optimization */
@media (max-width: 768px) {
  /* Tugmalar */
  .btn{padding:10px 12px;font-size:0.85rem;min-height:40px;}
  
  /* Login screen */
  .login-box{padding:20px 15px;width:96%;}
  .login-header .logo{font-size:1.8rem;}
  .login-header h1{font-size:1.1rem;}
  .login-form input{font-size:0.95rem;padding:12px;}
  .login-btn{padding:12px;font-size:1rem;min-height:46px;}
  
  /* Sidebar */
  .sidebar{max-width:280px;}
  .stat-item{padding:8px;}
  .stat-label{font-size:0.7rem;}
  .stat-value{font-size:1.1rem;}
  
  /* Form */
  .form-group{margin-bottom:10px;}
  .form-group label{font-size:0.85rem;}
  .form-group input,.form-group select,.form-group textarea{font-size:0.9rem;padding:10px;}
}

/* Landscape mode (gorizontal telefon) */
@media (max-height: 600px) and (orientation: landscape) {
  .login-container{padding:5px;}
  .login-box{padding:15px;max-height:90vh;overflow-y:auto;}
  .login-header{margin-bottom:10px;}
  .login-header .logo{font-size:1.5rem;}
  .login-header h1{font-size:1rem;}
  .login-form{gap:8px;}
  .login-form input{padding:10px;}
  .modal{align-items:flex-start;padding-top:10px;}
  .modal-content{max-height:90vh;overflow-y:auto;margin:0;}
  .input-modal{max-height:90vh;overflow-y:auto;}
  .page-content{padding:8px;}
  .topbar{padding:8px;}
}

/* Touch-friendly improvements */
@media (hover: none) and (pointer: coarse) {
  .btn{min-height:44px;padding:12px 16px;}
  .nav button{min-height:44px;}
  .table-buttons button{min-height:44px;}
  input,select,textarea{min-height:44px;font-size:16px !important;}
}

/* Settings Modal */
.settings-modal-content{max-width:900px;width:90vw;}
.settings-section{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border);}
.settings-section:last-child{border-bottom:none;margin-bottom:0;}
.settings-section h3{font-size:0.95rem;font-weight:600;color:var(--primary);margin-bottom:12px;display:flex;align-items:center;gap:6px;}
.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;}
.settings-actions{display:flex;flex-direction:column;gap:8px;}
.version-info{text-align:center;padding:15px;background:var(--bg);border-radius:8px;color:var(--text-dim);}
.version-info small{font-size:0.85rem;}

/* Notes Topbar Button */
.notes-topbar-btn{display:flex;align-items:center;gap:6px;background:var(--primary);color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-weight:600;font-size:0.8rem;transition:all .3s;}
.notes-topbar-btn:hover{background:var(--primary-dark);transform:translateY(-2px);}
.notes-topbar-btn svg{flex-shrink:0;}

/* Notes Modal */
.notes-modal-content{max-width:850px;width:90vw;max-height:80vh;}
.notes-container{display:grid;grid-template-columns:250px 1fr;gap:15px;height:55vh;}
.notes-list{border-right:1px solid var(--border);padding-right:15px;overflow-y:auto;}
.note-item{padding:10px;margin-bottom:6px;background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .3s;}
.note-item:hover{border-color:var(--primary);transform:translateX(4px);}
.note-item.active{border-color:var(--primary);background:rgba(99,102,241,0.1);}
.note-item-title{font-weight:600;margin-bottom:3px;color:var(--text);font-size:0.85rem;}
.note-item-preview{font-size:0.7rem;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.note-item-date{font-size:0.65rem;color:var(--text-dim);margin-top:3px;}
.notes-editor{display:flex;flex-direction:column;gap:10px;}
.notes-textarea{min-height:350px;resize:vertical;width:100%;padding:8px 10px;border:2px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:0.8rem;font-family:inherit;}
.notes-actions{display:flex;gap:10px;}
.notes-empty{text-align:center;color:var(--text-dim);padding:40px;}

/* Receipt Filter Container */
.receipt-filter-container{display:flex;gap:8px;margin-bottom:8px;}
.receipt-filter-dropdown{flex:1;padding:6px 10px;border:2px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:0.8rem;cursor:pointer;transition:border-color .3s;}
.receipt-filter-dropdown:focus{border-color:var(--primary);outline:none;}
.receipt-date-input{flex:1;padding:6px 10px;border:2px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:0.8rem;transition:border-color .3s;}
.receipt-date-input:focus{border-color:var(--primary);outline:none;}

/* Table Management Modal */
.table-management-modal{max-width:700px;width:90vw;}
.add-table-section{background:var(--panel-light);padding:15px;border-radius:8px;margin-bottom:20px;}
.section-subtitle{font-size:0.9rem;font-weight:700;color:var(--primary);margin-bottom:12px;}
.add-table-form{display:grid;grid-template-columns:1fr 1.5fr auto;gap:10px;align-items:center;}
.tables-list-section{background:var(--panel-light);padding:15px;border-radius:8px;}
.tables-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto;}
.table-management-item{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:12px;display:flex;justify-content:space-between;align-items:center;transition:all 0.3s;}
.table-management-item:hover{border-color:var(--primary);transform:translateX(4px);}
.table-management-item.active{border-color:var(--success);background:rgba(16,185,129,0.05);}
.table-management-item.running{border-color:var(--warning);background:rgba(245,158,11,0.05);}
.table-info{flex:1;}
.table-name{font-size:0.9rem;font-weight:700;color:var(--text);margin-bottom:4px;}
.table-details{display:flex;gap:8px;align-items:center;}
.table-id{font-size:0.75rem;color:var(--text-dim);font-family:monospace;}
.badge{padding:2px 8px;border-radius:4px;font-size:0.65rem;font-weight:600;}
.badge-success{background:var(--success);color:#fff;}
.badge-warning{background:var(--warning);color:#000;}
.table-actions{display:flex;gap:6px;}
.btn-icon{background:var(--panel-light);border:1px solid var(--border);padding:6px;border-radius:6px;cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center;}
.btn-icon:hover:not(:disabled){background:var(--primary);border-color:var(--primary);}
.btn-icon:hover:not(:disabled) svg{stroke:#fff;}
.btn-icon.btn-danger{border-color:var(--danger);}
.btn-icon.btn-danger:hover:not(:disabled){background:var(--danger);}
.btn-icon:disabled{opacity:0.5;cursor:not-allowed;}

/* Queue Management Styles */
.queue-modal{max-width:850px;width:95vw;}
.queue-add-form{display:grid;grid-template-columns:2fr 1.5fr 1fr auto;gap:10px;align-items:center;}
.queue-list{display:flex;flex-direction:column;gap:12px;max-height:450px;overflow-y:auto;}
.queue-item{background:var(--bg);border:2px solid var(--border);border-radius:10px;padding:15px;transition:all 0.3s;}
.queue-item:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.1);}
.queue-item.waiting{border-left:4px solid var(--warning);}
.queue-item.called{border-left:4px solid var(--primary);background:rgba(59,130,246,0.05);}
.queue-item.served{border-left:4px solid var(--success);background:rgba(16,185,129,0.05);opacity:0.7;}
.queue-item-header{display:flex;gap:15px;align-items:center;margin-bottom:10px;}
.queue-number{background:var(--primary);color:#fff;font-size:1.2rem;font-weight:700;width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.queue-info{flex:1;min-width:0;}
.queue-customer-name{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:4px;}
.queue-details{font-size:0.75rem;color:var(--text-dim);display:flex;gap:8px;flex-wrap:wrap;}
.queue-status{flex-shrink:0;}
.status-badge{padding:6px 12px;border-radius:6px;font-size:0.75rem;font-weight:600;white-space:nowrap;}
.status-waiting{background:rgba(245,158,11,0.15);color:var(--warning);border:1px solid var(--warning);}
.status-called{background:rgba(59,130,246,0.15);color:var(--primary);border:1px solid var(--primary);}
.status-served{background:rgba(16,185,129,0.15);color:var(--success);border:1px solid var(--success);}
.queue-actions{display:flex;gap:8px;justify-content:flex-end;}
.btn-icon.btn-success{border-color:var(--success);}
.btn-icon.btn-success:hover{background:var(--success);}
.btn-icon.btn-primary{border-color:var(--primary);}
.btn-icon.btn-primary:hover{background:var(--primary);}
.empty-state{text-align:center;padding:40px;color:var(--text-dim);font-size:1.1rem;}
.table-price{font-size:0.8rem;color:var(--success);font-weight:600;padding:2px 8px;background:rgba(16,185,129,0.1);border-radius:4px;}

