/* ===== styles.css (updated) ===== */
/* (full file with minimal edits: added z-index & pointer-events for close button and telegram-btn) */
/* ADDED: Styles for modal time and status display */

:root{
  --bg:#0a0f1a;
  --card:#1a1f2e;
  --card-hover:#22283a;
  --text:#e2e8ff;
  --text-muted:#8a94b3;
  --accent-primary:#6b63ff;
  --accent-secondary:#00d4ff;
  --live:#ff4757;
  --upcoming:#2ed573;
  --finished:#57606f;
  --border:rgba(255,255,255,0.08);
  --radius:12px;
  --radius-lg:16px;
  --gradient:linear-gradient(135deg,#6b63ff,#00d4ff);
  --gradient-card:linear-gradient(145deg,#1a1f2e,#151a28);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

/* Reset */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}
.container{max-width:1400px;margin:0 auto;padding:0 20px}

/* Telegram Floating Button (hidden on desktop; visible on mobile) */
.telegram-float{position:fixed;bottom:0;right:13px;z-index: 2147483647 !important;display:none;background:var(--gradient-card);border-radius:10px;padding:3px 5px 3px 10px;box-shadow:0 10px 30px rgba(0,0,0,0.3);border:1px solid var(--border);transition:all .3s ease}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.telegram-btn{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:600; pointer-events:auto}
.telegram-text{font-size:14px}

/* Show telegram on small screens only */
@media (max-width: 768px) {
  #telegramFloat {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
}

/* Desktop hide */
@media (min-width: 769px) {
  #telegramFloat {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
  }
}

/* Header */
.site-header{background:rgba(10,15,26,0.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.header-inner{max-width:1400px;margin:0 auto;padding:15px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px}
.logo{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:800}
.logo-icon{font-size:28px}
.logo-text{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo-highlight{color:var(--accent-secondary)}
.hamburger{display:none;background:none;border:1px solid var(--border);color:var(--text);padding:8px;border-radius:8px;cursor:pointer;font-size:20px}

/* Search & Filters */
.header-controls{display:flex;align-items:center;gap:15px;flex:1;max-width:800px}
.search-wrap{flex:1;position:relative;max-width:400px}
.search-wrap.large{max-width:500px}
.search-wrap input{width:100%;padding:12px 40px 12px 15px;background:rgba(255,255,255,0.03);border:2px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;transition:all .3s ease}
.search-wrap input:focus{outline:none;border-color:var(--accent-primary);background:rgba(107,99,255,0.08)}
.icon-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px}
.filters{display:flex;gap:10px}
.filters select{padding:10px 15px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;cursor:pointer;min-width:140px}

/* Main Content */
.date-header{margin:30px 0 20px;padding:0 10px}
.date-header h2{font-size:24px;font-weight:700}
#currentDate{color:var(--accent-secondary);font-weight:600}

/* Cards grid */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:40px}
.match-card{background:var(--gradient-card);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border);transition:all .3s ease;position:relative;overflow:hidden}
.match-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient)}
.match-card:hover{transform:translateY(-5px);border-color:rgba(107,99,255,0.3);box-shadow:0 20px 50px rgba(0,0,0,0.4)}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.competition{font-size:13px;font-weight:600;color:var(--accent-secondary);text-transform:uppercase;letter-spacing:.5px}
.match-time{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:5px}

/* ★★★★ REVISED MATCH-TEAMS LAYOUT ★★★★ */
.match-teams{display:flex;flex-direction:column;gap:15px;margin:20px 0}

/* Gambar vs Gambar */
.teams-logos{display:flex;align-items:center;justify-content:center;gap:20px;width:100%}
.team-logo-container{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}
.team-logo{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.03);border-radius:12px;padding:15px;border:1px solid var(--border);transition:all .3s ease}
.team-logo:hover{transform:scale(1.05);border-color:rgba(107,99,255,0.3)}
.team-logo img{width:100%;height:100%;object-fit:contain}
.vs-badge{font-weight:800;font-size:14px;color:var(--text-muted);background:rgba(255,255,255,0.03);padding:8px 16px;border-radius:20px;margin:0 10px}

/* Nama Jam Nama */
.teams-names{display:flex;align-items:center;justify-content:space-between;width:100%;gap:15px;margin-top:10px}
.team-name-container{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1}
.team-name{font-weight:700;font-size:16px;text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 5px}
.time-center{display:flex;flex-direction:column;align-items:center;gap:3px;padding:0 15px}
.time-display{font-size:14px;font-weight:600;color:var(--accent-secondary);white-space:nowrap}
.time-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}

.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:15px;border-top:1px solid var(--border);gap:10px;flex-wrap:wrap}
.status{padding:6px 15px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;flex-shrink:0}
.status-live{background:rgba(255,71,87,0.12);color:var(--live);border:1px solid rgba(255,71,87,0.25)}
.status-upcoming{background:rgba(46,213,115,0.12);color:var(--upcoming);border:1px solid rgba(46,213,115,0.25)}
.status-finished{background:rgba(87,96,111,0.12);color:var(--finished);border:1px solid rgba(87,96,111,0.25)}
.card-actions{display:flex;gap:10px;flex-shrink:0}
.btn{padding:10px 20px;border-radius:var(--radius);border:none;cursor:pointer;font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;transition:all .3s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--gradient);color:#fff;box-shadow:0 4px 12px rgba(107,99,255,0.2)}
.btn-primary:hover{box-shadow:0 6px 20px rgba(107,99,255,0.3)}
.btn-secondary{background:rgba(255,255,255,0.03);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:rgba(255,255,255,0.06)}
.btn-sm{padding:8px 15px;font-size:13px}
.btn-icon{font-size:16px}

/* No results */
.no-results{text-align:center;padding:60px 20px;max-width:500px;margin:40px auto}
.no-results.hidden{display:none}
.no-results-icon{font-size:60px;margin-bottom:20px;opacity:.5}
.no-results h3{font-size:24px;margin-bottom:10px;color:var(--text)}
.no-results p{color:var(--text-muted);font-size:16px}

/* Modal */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.9);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:0;opacity:0;animation:fadeIn .3s ease forwards;overflow-y:auto}
@keyframes fadeIn{to{opacity:1}}
.modal-overlay.hidden{display:none}
.modal-container{width:100%;max-width:800px;animation:slideUp .4s ease}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.player-modal .modal-container{max-width:900px}
.modal-card{background:var(--gradient-card);border-radius:var(--radius-lg);padding:30px;border:1px solid rgba(107,99,255,0.12);position:relative;max-height:90vh;overflow-y:auto}
.close-btn{position:absolute;top:20px;right:20px;background:rgba(255,255,255,0.06);border:1px solid var(--border);color:var(--text);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;z-index:10;transition:all .3s ease}
.close-btn:hover{background:rgba(255,255,255,0.1);transform:rotate(90deg)}

/* Pre-match Modal */
.modal-header{text-align:center;margin-bottom:30px}
.modal-header h3{font-size:28px;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.modal-teams{display:flex;align-items:center;justify-content:center;gap:40px;margin:40px 0}
.modal-team{flex:1;display:flex;flex-direction:column;align-items:center}
.modal-team .team-logo{width:120px;height:120px;margin-bottom:15px;padding:20px;background:rgba(255,255,255,0.03);border-radius:20px;border:2px solid var(--border)}
.modal-team .team-logo img{width:100%;height:100%;object-fit:contain}
.modal-team .team-name{font-size:22px;font-weight:700;text-align:center;max-width:100%;word-break:break-word}
.modal-vs{display:flex;flex-direction:column;align-items:center;gap:10px;padding:0 20px}
.modal-vs .vs-text{font-size:20px;font-weight:800;color:var(--text-muted)}
.modal-vs .match-time{font-size:18px;font-weight:600;color:var(--accent-secondary)}

/* Countdown & progress */
.countdown-wrapper{margin:40px 0}
.countdown-title{text-align:center;color:var(--text-muted);margin-bottom:20px;font-size:16px}
.countdown-display{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}
.countdown-item{background:rgba(255,255,255,0.03);border-radius:var(--radius);padding:15px;min-width:80px;text-align:center;border:1px solid rgba(107,99,255,0.08);flex:1;max-width:100px}
.countdown-item span{display:block;font-size:32px;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.countdown-item small{display:block;font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.countdown-separator{font-size:24px;font-weight:800;color:var(--accent-secondary);margin:0 5px;align-self:center}

/* Match info & progress */
.match-info{display:flex;justify-content:center;gap:30px;margin:30px 0;flex-wrap:wrap}
.info-item{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,0.03);padding:12px 20px;border-radius:var(--radius);border:1px solid var(--border)}
.progress-container{margin:30px 0}
.progress-label{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14px;color:var(--text-muted);flex-wrap:wrap;gap:5px}
#progress-percent{color:var(--accent-secondary);font-weight:600}
.progress-bar{height:8px;background:rgba(255,255,255,0.03);border-radius:4px;overflow:hidden}
.progress-fill{height:100%;background:var(--gradient);width:0%;transition:width 1s ease;border-radius:4px}
.modal-actions{display:flex;gap:15px;justify-content:center;margin-top:30px}

/* Player modal specifics */
.player-header{text-align:center;margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:10px}
.match-title{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:10px;flex-wrap:wrap}
.match-title h4{font-size:22px;font-weight:700;margin:0;text-align:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.match-title .vs-text{color:var(--text-muted);font-weight:800;padding:0 15px;flex-shrink:0}
.competition-name{font-size:14px;color:var(--accent-secondary);text-transform:uppercase;letter-spacing:1px}
.match-time-modal{font-size:14px;color:var(--text-muted);margin-top:5px}
.status-modal{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-top:5px;text-transform:uppercase;letter-spacing:0.5px}
.status-modal.status-live{background:rgba(255,71,87,0.12);color:var(--live);border:1px solid rgba(255,71,87,0.25)}
.status-modal.status-upcoming{background:rgba(46,213,115,0.12);color:var(--upcoming);border:1px solid rgba(46,213,115,0.25)}
.status-modal.status-finished{background:rgba(87,96,111,0.12);color:var(--finished);border:1px solid rgba(87,96,111,0.25)}
.ad-banner{margin-bottom:20px;text-align:center;background:rgba(0,0,0,0.25);border-radius:var(--radius);padding:10px;border:1px solid var(--border)}
#adsterra-banner-728x90{min-height:90px;display:flex;align-items:center;justify-content:center;width:100%}
.video-container{background:#000;border-radius:var(--radius);overflow:hidden;margin-bottom:25px;position:relative;aspect-ratio:16/9}
.video-wrapper{width:100%;height:100%;position:relative}
.player-loader{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.8);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text);gap:20px;padding:20px;text-align:center}
.player-loader.hidden{display:none}
.loader-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,0.06);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Stream options */
.stream-options{margin-top:20px}
.stream-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,0.04);flex-wrap:wrap;gap:10px}
.stream-header h4{font-size:16px;margin:0;color:var(--text);font-weight:600}
.stream-actions{display:flex;gap:8px;flex-shrink:0}
.btn-refresh{background:rgba(0,212,255,0.08);border:1px solid rgba(0,212,255,0.18);color:var(--accent-secondary);padding:6px 12px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .2s ease;white-space:nowrap}
.btn-refresh:hover{background:rgba(0,212,255,0.12);transform:translateY(-1px)}
.btn-refresh.loading{opacity:.7;cursor:not-allowed}
.stream-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.stream-buttons .btn{flex:1;min-width:140px;justify-content:center;position:relative}
.stream-buttons .btn.active{background:var(--gradient);border-color:var(--accent-primary);box-shadow:0 4px 12px rgba(107,99,255,0.12)}

/* Footer */
.site-footer{margin-top:60px;padding:40px 0 20px;border-top:1px solid var(--border);background:rgba(10,15,26,0.5)}
.footer-content{max-width:1400px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-bottom:30px}
.footer-section h4{font-size:18px;margin-bottom:15px;color:var(--text);font-weight:700}
.footer-section p{color:var(--text-muted);font-size:14px;margin-bottom:15px;line-height:1.6}
.footer-stats{display:flex;gap:20px;margin-top:15px}
.stat-item{display:flex;flex-direction:column;align-items:center}
.stat-number{font-size:24px;font-weight:800;color:var(--accent-secondary)}
.stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px}
.league-tags{display:flex;flex-wrap:wrap;gap:8px}
.league-tag{padding:6px 12px;background:rgba(255,255,255,0.03);border-radius:var(--radius);font-size:12px;color:var(--text-muted);transition:all .3s ease;cursor:pointer}
.league-tag:hover{background:rgba(107,99,255,0.12);color:var(--text)}
.social-links{display:flex;flex-direction:column;gap:10px}
.social-link{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;padding:8px 15px;background:rgba(255,255,255,0.03);border-radius:var(--radius);transition:all .3s ease}
.social-link:hover{background:rgba(107,99,255,0.08);transform:translateX(5px)}
.social-icon{font-size:18px}
.disclaimer{max-width:1400px;margin:0 auto;padding:15px 20px;background:rgba(255,71,87,0.08);border-radius:var(--radius);color:var(--live);font-size:13px;text-align:center;border:1px solid rgba(255,71,87,0.12);line-height:1.6}
.copyright{display:block;text-align:center;margin-top:20px;color:var(--text-muted);font-size:12px;padding:0 20px}

/* ★★★★ RESPONSIVE DESIGN ★★★★ */

/* Tablet */
@media (max-width:1200px){.cards-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}
@media (max-width:992px){
  .header-controls{order:3;width:100%;flex-direction:column;gap:15px}
  .search-wrap{max-width:100%!important}
  .filters{display:none;width:100%}
  .filters.open{display:flex;flex-direction:column}
  .filters select{width:100%}
  .hamburger{display:flex}
  .cards-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
  .team-logo{width:70px;height:70px;padding:12px}
  .modal-teams{flex-direction:column;gap:30px}
  .modal-team .team-logo{width:100px;height:100px}
  .modal-team .team-name{font-size:20px}
  .countdown-display{gap:5px}
  .countdown-item{min-width:70px;padding:12px}
  .countdown-item span{font-size:28px}
  .countdown-separator{display:none}
  .stream-buttons .btn{min-width:calc(50% - 5px)}
  .player-header{gap:8px}
  .match-title h4{font-size:20px}
}

/* Mobile Landscape & Small Tablets */
@media (max-width:768px){
  .telegram-float{display:block}
  .cards-grid{grid-template-columns:1fr;gap:15px}
  .match-card{padding:15px}
  .match-teams{gap:12px}
  .teams-logos{gap:15px}
  .team-logo{width:60px;height:60px;padding:10px}
  .vs-badge{font-size:12px;padding:6px 12px}
  .teams-names{gap:10px}
  .team-name{font-size:14px}
  .time-center{padding:0 10px}
  .time-display{font-size:13px}
  .time-label{font-size:10px}
  .modal-container{max-width:95%}
  .modal-card{padding:20px}
  .modal-team .team-logo{width:80px;height:80px;padding:15px}
  .modal-team .team-name{font-size:18px}
  .countdown-item{min-width:60px;padding:12px}
  .countdown-item span{font-size:24px}
  .match-info{flex-direction:column;gap:15px;align-items:center}
  .modal-actions{flex-direction:column}
  .stream-header{flex-direction:column;align-items:flex-start;gap:10px}
  .stream-actions{width:100%}
  .btn-refresh{width:100%;justify-content:center}
  .stream-buttons .btn{min-width:100%}
  .footer-content{grid-template-columns:1fr;gap:30px}
  .player-header{gap:6px}
  .match-title h4{font-size:18px}
  .match-title .vs-text{padding:0 10px}
  .match-time-modal{font-size:12px}
  .status-modal{font-size:11px;padding:3px 10px}
}

/* Mobile Portrait */
@media (max-width:480px){
  .container{padding:0 15px}
  .header-inner{padding:10px 15px}
  .logo{font-size:20px}
  .logo-icon{font-size:24px}
  .date-header h2{font-size:20px}
  .card-footer{flex-direction:column;gap:15px;align-items:stretch}
  .card-actions{width:100%}
  .btn{flex:1;justify-content:center}
  .team-logo{width:50px;height:50px;padding:8px}
  .team-name{font-size:13px}
  .vs-badge{font-size:11px;padding:5px 10px}
  .match-title{flex-direction:column;gap:5px}
  .match-title h4{font-size:18px}
  .vs-text{padding:5px 0}
  .player-modal .modal-container{max-width:95vw}
  .ad-banner{padding:5px}
  .modal-card{padding:15px}
  .close-btn{width:32px;height:32px;font-size:16px;top:10px;right:10px}
  .telegram-icon{font-size:24px}
  .player-header{gap:5px}
  .match-title h4{font-size:16px}
  .competition-name{font-size:12px}
}

/* Extra small mobile */
@media (max-width:360px){
  .team-logo{width:45px;height:45px;padding:6px}
  .team-name{font-size:12px}
  .time-display{font-size:12px}
  .time-label{font-size:9px}
  .btn{padding:8px 12px;font-size:13px}
  .player-header{gap:4px}
  .match-title h4{font-size:15px}
  .competition-name{font-size:11px}
  .match-time-modal{font-size:11px}
  .status-modal{font-size:10px;padding:2px 8px}
}

/* Small height screens */
@media (max-height:600px){
  .modal-card{max-height:95vh;padding:15px}
  .modal-teams{margin:20px 0}
  .modal-team .team-logo{width:60px;height:60px;padding:10px}
  .countdown-wrapper{margin:20px 0}
  .countdown-item{padding:8px;min-width:50px}
  .countdown-item span{font-size:20px}
  .player-header{gap:6px}
  .match-title h4{font-size:18px}
}