/* This file contains the large stylesheet previously embedded in index.html */

/* Reset and variables */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --primary:#0a0a0a;--secondary:#8B0000;--accent:#DC143C;--accent-glow:#FFFFFF;
  --text:#FFFFFF;--text-secondary:#FFE4E1;--border:#DC143C;--success:#FFFFFF;
  --warning:#f59e0b;--glass:rgba(220,20,60,0.08);--glass-border:rgba(220,20,60,0.3);
}

body{
  font-family:'Inter',sans-serif;
  background:linear-gradient(135deg,#8B0000 0%,#DC143C 50%,#8B0000 100%);
  color:var(--text);min-height:100vh;overflow-x:hidden;position:relative;
}
body::before{content:'';position:fixed;top:0;left:0;width:100%;height:100%;
  background:
    radial-gradient(circle at 20% 50%, rgba(255,255,255,0.1) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,0.1) 0%, transparent 50%),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,0.1) 0%, transparent 50%);
  pointer-events:none;z-index:-1;
}

.container{max-width:1400px;margin:0 auto;padding:2rem;}
header{text-align:center;margin-bottom:3rem;position:relative;}
.logo-container.banner{
  background:linear-gradient(135deg,#1a1a1a 0%,#2a2a2a 100%);
  border-radius:18px;padding:.75rem .75rem !important;margin-bottom:1.25rem;border:3px solid var(--accent);
  box-shadow:0 15px 40px rgba(220,20,60,0.4),inset 0 1px 0 rgba(255,255,255,0.1);
  position:relative;overflow:hidden;display:flex;justify-content:center;align-items:center;
}
.logo-container.banner::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(45deg, rgba(220,20,60,0.1) 0%, rgba(255,255,255,0.05) 50%, rgba(220,20,60,0.1) 100%);
  pointer-events:none;
}
.banner-logo{max-width:600px;width:100%;height:auto;filter:drop-shadow(0 0 30px rgba(220,20,60,0.7));
  animation:bannerGlow 3s ease-in-out infinite alternate;position:relative;z-index:1;
  border-radius:12px;display:block;object-fit:cover;
}
@keyframes bannerGlow{from{filter:drop-shadow(0 0 30px rgba(220,20,60,0.7)) brightness(1);transform:scale(1);}
  to{filter:drop-shadow(0 0 50px rgba(255,0,0,0.9)) brightness(1.1);transform:scale(1.02);}
}

/* subtitle */
.subtitle{font-size:1.6rem;color:var(--text-secondary);font-weight:600;letter-spacing:0.15em;
  text-transform:uppercase;margin-top:1.5rem;text-shadow:0 2px 4px rgba(0,0,0,0.5);
}

/* controls */
.controls{display:flex;justify-content:space-between;gap:0.5rem;margin-bottom:3rem;flex-wrap:nowrap;}
.classification-btn{
  background:linear-gradient(135deg, rgba(220,20,60,0.25) 0%, rgba(255,0,0,0.15) 100%);
  border:3px solid rgba(220,20,60,0.6);color:var(--text);padding:1rem 1.5rem;border-radius:50px;
  font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;
  backdrop-filter:blur(15px);position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:0.05em;
  text-shadow:0 1px 2px rgba(0,0,0,0.3);flex:1;text-align:center;min-width:0;white-space:nowrap;display:flex;align-items:center;justify-content:center;min-height:60px;
}
.classification-btn.active{background:linear-gradient(135deg,var(--accent) 0%,#FF3333 100%);border-color:#FFFFFF;
  box-shadow:0 10px 35px rgba(220,20,60,0.7),0 0 25px rgba(255,255,255,0.3),inset 0 1px 0 rgba(255,255,255,0.3);
  transform:translateY(-2px);color:#FFFFFF;
}

/* rankings container */
.rankings-container{background:linear-gradient(135deg, rgba(139,0,0,0.95) 0%, rgba(220,20,60,0.9) 50%, rgba(139,0,0,0.95) 100%);
  border:3px solid var(--accent-glow);border-radius:25px;backdrop-filter:blur(25px);padding:3rem;animation:slideUp .8s ease-out;
  box-shadow:0 25px 80px rgba(0,0,0,0.6),inset 0 1px 0 rgba(255,255,255,0.2),0 0 60px rgba(220,20,60,0.3);position:relative;overflow:hidden;contain:layout paint;
}
.rankings-container::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.6),transparent);}
@keyframes slideUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}

/* loading / preloader */
.loading{text-align:center;padding:4rem;font-size:1.2rem;color:var(--text-secondary);}
.loading::after{content:'';display:inline-block;width:20px;height:20px;border:2px solid var(--accent);border-radius:50%;border-top-color:transparent;animation:spin 1s linear infinite;margin-left:10px;}
@keyframes spin{to{transform:rotate(360deg);}}

/* table base */
.rankings-table{width:100%;table-layout:fixed;font-size:1rem;font-family:'Inter',sans-serif;}
.rankings-table th{background:linear-gradient(135deg, rgba(220,20,60,0.4) 0%, rgba(255,0,0,0.3) 100%);padding:1.75rem 1.5rem;text-align:left;font-family:'Oswald',sans-serif;font-weight:600;color:#FFFFFF;text-transform:uppercase;letter-spacing:0.08em;font-size:1.05rem;border-bottom:4px solid var(--accent-glow);position:sticky;top:0;backdrop-filter:blur(10px);text-shadow:0 2px 4px rgba(0,0,0,0.7);}
.rankings-table td{padding:0.6rem 0.6rem;border-bottom:1px solid var(--glass-border);transition:all .3s ease;vertical-align:middle;}
.rankings-table tr{transition:all .3s ease;position:relative;background:rgba(255,255,255,0.02);}
.rankings-table tr:nth-child(even){background:rgba(220,38,38,0.03);}
.rankings-table tr:hover{background:linear-gradient(135deg, rgba(220,20,60,0.2) 0%, rgba(255,0,0,0.15) 100%);transform:scale(1.005);box-shadow:0 5px 20px rgba(220,20,60,0.3);}

/* rank bubble */
.rank-number{font-family:'Oswald',sans-serif;font-weight:800;font-size:1.4rem;color:#FFFFFF;width:70px;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,0.5);
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-glow) 100%);border-radius:50%;width:60px;height:60px;font-size:1.6rem;box-shadow:0 4px 15px rgba(220,20,60,0.5);display:flex;align-items:center;justify-content:center;margin:0 auto;
}

/* team and logo */
.team-name{font-weight:700;font-size:1.1rem;color:var(--text);letter-spacing:-0.01em;text-align:left;}
.team-name>div{display:flex;align-items:center;gap:12px;min-width:0;}
.team-name .team-logo{flex:0 0 auto;width:84px!important;height:84px!important;object-fit:contain;border-radius:8px;padding:0px!important;}
.team-name span{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;}
.record{color:var(--text-secondary);font-size:.95rem;font-weight:500;}
.rpi-score{font-family:'Oswald',sans-serif;font-weight:800;font-size:1.2rem;color:var(--success);text-align:center;background:rgba(16,185,129,0.1);border-radius:8px;padding:.5rem 1rem;margin:0 auto;display:inline-block;}

/* bracket & playoff */
.playoff-controls{text-align:center;margin:2rem 0;}
.generate-bracket-btn{background:linear-gradient(135deg,var(--accent) 0%,#FF3333 100%);border:3px solid #FFFFFF;color:#FFFFFF;padding:1rem 2rem;border-radius:50px;font-family:'Oswald',sans-serif;font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(15px);box-shadow:0 10px 35px rgba(220,20,60,0.7);text-transform:uppercase;letter-spacing:0.1em;display:none;}
.generate-bracket-btn.visible{display:inline-block;animation:slideUp .5s ease-out;}
.bracket-container{background:linear-gradient(135deg, rgba(139,0,0,0.95) 0%, rgba(220,20,60,0.9) 50%, rgba(139,0,0,0.95) 100%);border:3px solid var(--accent-glow);border-radius:25px;backdrop-filter:blur(25px);padding:3rem;margin-top:2rem;display:none;}
.bracket-container.visible{display:block;animation:slideUp .8s ease-out;}
.bracket-title{text-align:center;font-family:'Oswald',sans-serif;font-size:2.5rem;font-weight:800;color:#FFFFFF;margin-bottom:3rem;text-shadow:0 4px 8px rgba(0,0,0,0.7);}

/* region and team-list styles (kept concise here) */
.bracket-regions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:start;
  width:100%;
  max-width:100% !important;
  margin:0 !important;
  padding-left:0.5rem;
  padding-right:0.5rem;
}
.region{
  display:flex;
  flex-direction:column;
  align-items:center;
  background:rgba(255,255,255,0.05);
  border:2px solid var(--accent-glow);
  border-radius:15px;
  padding:2rem;
  box-sizing:border-box;
  width:100%;
  max-width:none; /* allow full-width expansion */
  margin:0;       /* remove centering constraint */
  overflow:hidden;
}
.region-title{text-align:center;font-family:'Oswald',sans-serif;font-size:1.8rem;font-weight:700;color:#FFFFFF;margin-bottom:2rem;text-transform:uppercase;letter-spacing:0.1em;}
.team-list{display:flex;flex-direction:column;gap:.4rem;width:100%;max-width:680px;}
.team-item{background:linear-gradient(135deg, rgba(220,20,60,0.3) 0%, rgba(255,0,0,0.2) 100%);border:2px solid rgba(220,20,60,0.6);border-radius:8px;padding:.6rem;display:flex;justify-content:space-between;align-items:center;transition:all .18s ease;}
.team-item:hover{transform:translateX(5px);border-color:var(--accent-glow);box-shadow:0 5px 20px rgba(220,20,60,0.4);}
.team-seed{font-family:'Oswald',sans-serif;font-weight:800;font-size:1.1rem;color:white;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-glow) 100%);width:35px;height:35px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.team-name-bracket{font-weight:600;font-size:1rem;color:#FFFFFF;flex:1;margin-left:1rem;}
.team-rpi{font-weight:700;font-size:.9rem;color:var(--text-secondary);}

/* preloader */
.preloader{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--primary);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease;}
.preloader.hidden{opacity:0;pointer-events:none;}
.preloader-spinner{width:50px;height:50px;border:3px solid var(--glass-border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;}

/* mobile / responsive rules (kept from original CSS) */
@media (max-width:768px){
  .container{padding:1rem;}
  /* make the banner image fill more of the banner container on mobile */
  .logo-container.banner { padding:0.5rem !important; border-radius:12px; }
  .banner-logo {
    width: 100%;
    height: auto;
    max-height: 220px; /* prevents excessively tall banners on some images */
    max-width: 100%;
    border-radius: 10px;
    object-fit: cover;
    display: block;
  }
  .team-name .team-logo{width:40px;height:40px;padding:4px;}
  .rankings-container{padding:1rem;overflow-x:auto;width:100%;max-width:100%;}
  .controls{flex-direction:column;gap:1rem;}
  .classification-btn{width:100%;}
  .bracket-regions{grid-template-columns:1fr;gap:2rem; padding: 0.02rem !important;}
  /* reduce heavy padding for bracket region and team cards on mobile */
  .region { padding: 0.2rem !important; }
  .team-item { padding: 0.4rem !important; margin-bottom: 0.45rem !important; }

  /* make bracket RPI values smaller on mobile for compactness */
  .collapsible-region .team-rpi {
    font-size: 0.72rem !important;
    line-height: 1 !important;
    min-width: 36px !important;
    text-align: right !important;
  }

  .rankings-table, .rankings-table thead, .rankings-table tbody, .rankings-table tr, .rankings-table th, .rankings-table td{display:block;width:100%;}
  .rankings-table thead{display:none;}
  .collapsible-region .team-rpi { font-size:0.75rem !important; min-width:40px !important; text-align:right !important; font-weight:600; }
}

/* desktop touchups */
@media (min-width:769px){
  .container{max-width:none!important;}
  /* desktop: let banner be taller and fill width more, with slightly larger rounding */
  .logo-container.banner { padding:1.5rem 2rem; border-radius:20px; }
  .banner-logo { max-width:100%; height:200px; border-radius:14px; object-fit:cover; }
  .rankings-container,.bracket-container{width:100% !important;max-width:100% !important;margin-left:auto !important;margin-right:auto !important;padding-left:2rem;padding-right:2rem;}
}

/* small utility tweaks kept */
.fade-in{animation:none!important;opacity:1!important;transform:none!important;transition:none!important;}