/* ============================ */
/* css/styles.css               */
/* ============================ */
:root{
  /* Colors: primary Carolina Blue, accents navy, gray, black */
  --carolina:#7BAFD4; /* Carolina Blue */
  --navy:#002244;     /* Navy */
  --gray:#A5ACAF;     /* Wolf Gray */
  --black:#000000;    /* Black */
  --bg:#f6f8fa;       /* background */
  --white:#ffffff;
  --shadow:0 8px 24px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:'Archivo',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#102a43;background:var(--bg)}
img{max-width:100%;display:block}
.container{width:min(1140px,92vw);margin-inline:auto}

/* Header */
.site-header{position:sticky;top:0;z-index:1000;background:linear-gradient(180deg,var(--carolina),#5c9dc7);color:var(--black);box-shadow:var(--shadow)}
.brand{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem}
.logo{display:flex;align-items:center;gap:.6rem;color:#06162a;text-decoration:none;font-weight:800}
.logo .mark{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--navy);color:var(--white);font-weight:900}
.logo .text{text-transform:uppercase;letter-spacing:.4px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer}
.nav-toggle span{display:block;width:24px;height:2px;background:#06162a;margin:5px 0}
.site-nav{display:flex;gap:.4rem;flex-wrap:wrap;padding:.2rem 1rem 1rem}
.site-nav a{color:#06162a;text-decoration:none;font-weight:700;padding:.5rem .8rem;border-radius:10px}
.site-nav a:hover{background:rgba(255,255,255,.6)}
.site-nav a.active{background:var(--navy);color:var(--white)}

@media (max-width: 860px){
  .nav-toggle{display:block}
  .site-nav{display:none}
  .site-nav.open{display:flex;flex-direction:column}
}

/* Hero */
.hero{position:relative}
.hero-media{height:44vh;min-height:300px;background:url('../img/IMG_7504.JPG') center/cover no-repeat}
.hero .hero-inner{position:absolute;inset:0;display:grid;align-content:center;color:var(--white);text-shadow:0 2px 10px rgba(0,0,0,.4)}
.hero h1{margin:0 0 .4rem;font-size:clamp(2rem,5vw,3.4rem);font-weight:900}
.accent{color:#e6f5ff}
.tag{font-size:1.1rem}
.cta-row{margin-top:1rem;display:flex;gap:.6rem;flex-wrap:wrap}

.hero-compact .hero-media{height:28vh;min-height:220px}

/* Grid / Cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-block:1.2rem}
.gap-lg{gap:1.25rem}
.gap-xl{gap:1.5rem}
.card{background:var(--white);border-radius:14px;box-shadow:var(--shadow);padding:1rem}
.card-title{margin-top:.2rem}
.more{display:inline-block;margin-top:.5rem;font-weight:700;color:var(--navy)}

@media (max-width: 980px){.grid{grid-template-columns:1fr 1fr}}
@media (max-width: 640px){.grid{grid-template-columns:1fr}}

/* Buttons */
.btn{display:inline-block;background:var(--navy);color:var(--white);text-decoration:none;font-weight:800;border:none;border-radius:12px;padding:.7rem 1rem}
.btn:hover{filter:brightness(1.08)}
.btn-outline{background:transparent;color:var(--white);outline:2px solid var(--white)}
.btn-small{padding:.45rem .75rem;border-radius:10px}

/* Page header */
.page-header{padding-block:1rem 1.2rem;border-bottom:4px solid var(--carolina)}
.page-header .sub{color:#51606e;margin:.25rem 0 0}

/* News */
.news-list{display:grid;gap:1rem;margin-block:1rem 2rem}
.news-card{display:grid;grid-template-columns:220px 1fr;gap:1rem;background:var(--white);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.news-card .thumb img{height:100%;object-fit:cover}
.news-card .copy{padding:1rem}
.news-card h2{margin:.2rem 0}
.news-card .meta{color:#5b6775;font-size:.9rem}
@media (max-width:720px){.news-card{grid-template-columns:1fr}}

/* Roster */
.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-block:1rem 2rem}
.player-card{background:var(--white);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.player-card img{aspect-ratio:4/5;object-fit:cover}
.player-info{padding:.8rem}

/* Schedule */
.table-wrap{background:var(--white);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;margin-block:1rem 2rem}
.schedule-table{width:100%;border-collapse:collapse}
.schedule-table thead th{background:var(--navy);color:var(--white);text-align:left;padding:.8rem}
.schedule-table td{padding:.7rem;border-top:1px solid #e6e9ee}
.schedule-table tbody tr:hover{background:#f7f9fb}

/* Instagram */
.insta-frame{border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.news-briefs{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.news-briefs a{color:#0b2a45;text-decoration:none;font-weight:700}
.news-briefs .kicker{display:inline-block;background:var(--gray);color:#001;padding:.1rem .4rem;border-radius:4px;font-size:.75rem;margin-right:.4rem}

/* Sponsors */
.sponsor-rail{display:flex;gap:1rem;align-items:center;overflow:auto;padding:.25rem}
.sponsor-rail img{height:70px;width:auto}
.form-section{margin-block:1.25rem 2rem}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.form-grid .full{grid-column:1/-1}
label span{display:block;font-weight:800;margin-bottom:.25rem}
input,textarea{width:100%;padding:.7rem .8rem;border:1px solid #ccd6e0;border-radius:12px;font:inherit}
input:focus,textarea:focus{outline:3px solid rgba(123,175,212,.35);border-color:var(--carolina)}
.form-note{color:#5b6775}

/* Footer */
.site-footer{margin-top:2rem;background:var(--navy);color:var(--gray)}
.footer-inner{padding:1rem;text-align:center}

/* Utilities */
.opponent{font-size:1.25rem;font-weight:900}
.meta{color:#5b6775}

/* Mobile nav JS hook */
@media (max-width:860px){
  .site-nav{padding:0 1rem 1rem}
}