/* =========================================================
   CM.CSS — Committees Page  |  Blue Theme
   Hero: Split left-right with floating icon cards
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root{
  --blue-900:#0a1628;
  --blue-800:#0d2137;
  --blue-700:#0d47a1;
  --blue-600:#1565c0;
  --blue-500:#1976d2;
  --blue-400:#42a5f5;
  --blue-300:#90caf9;
  --blue-200:#bbdefb;
  --blue-100:#e3f2fd;
  --blue-50:#f0f7ff;
  --gold:#ffc107;
  --accent:#ff6d00;
  --radius:14px;
  --shadow:0 4px 24px rgba(13,71,161,.10);
}

*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:'Inter',sans-serif;color:#1e293b;background:#f8fafc}

/* ======== HERO — split ======== */
.hero{
  position:relative;
  min-height:520px;
  overflow:hidden;
  display:flex;
  align-items:center;
}
.hero-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.62) 50%,rgba(0,0,0,.72) 100%),
             url('../images/cfl/cm.jpg') center/cover no-repeat;
  z-index:0;
}
/* Keep CM hero image/tint from being overridden by unified-colors.css */
.hero .hero-bg{
  background:linear-gradient(135deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.66) 50%,rgba(0,0,0,.78) 100%),
             url('../images/cfl/cm.jpg') center/cover no-repeat !important;
}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 75% 30%,rgba(66,165,245,.18) 0%,transparent 55%),
             radial-gradient(circle at 20% 80%,rgba(25,118,210,.15) 0%,transparent 50%);
}
.hero-bg::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:80px;
  background:linear-gradient(to top,#f8fafc,transparent);z-index:1;
}

.hero-grid{
  position:relative;z-index:2;
  max-width:1280px;width:100%;margin:0 auto;
  padding:100px 40px 60px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}

/* Left */
.hero-left{color:#fff}
.hero-crumb{
  display:inline-block;
  font-size:.78rem;letter-spacing:.3px;
  color:rgba(255,255,255,.6);margin-bottom:18px;
}
.hero-crumb a{color:rgba(255,255,255,.75);text-decoration:none}
.hero-crumb a:hover{color:#fff}
.hero-crumb i{font-size:.65rem;vertical-align:middle;margin:0 4px}

.hero-left h1{
  font-size:3.4rem;font-weight:800;line-height:1.1;margin:0 0 18px;
}
.hero-left h1 span{
  background:linear-gradient(90deg,var(--blue-300),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-left p{font-size:1.05rem;line-height:1.7;color:rgba(255,255,255,.78);max-width:460px;margin-bottom:28px}

.hero-stats{display:flex;gap:32px}
.stat{text-align:center}
.stat strong{display:block;font-size:1.8rem;font-weight:800;color:#fff}
.stat small{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.55)}

/* Right — floating cards */
.hero-right{
  position:relative;
  height:380px;
}
.hero-circle{
  position:absolute;
  width:320px;height:320px;border-radius:50%;
  border:2px dashed rgba(255,255,255,.12);
  top:50%;left:50%;transform:translate(-50%,-50%);
  animation:spinSlow 30s linear infinite;
}
@keyframes spinSlow{to{transform:translate(-50%,-50%) rotate(360deg)}}

.float-card{
  position:absolute;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  padding:18px 22px;
  display:flex;align-items:center;gap:12px;
  color:#fff;
  font-weight:600;font-size:.88rem;
  box-shadow:0 8px 32px rgba(0,0,0,.18);
  transition:transform .35s,box-shadow .35s;
  cursor:default;
  animation:floatUp 3s ease-in-out infinite alternate;
}
.float-card:hover{transform:translateY(-6px) scale(1.04);box-shadow:0 12px 40px rgba(0,0,0,.25)}
.float-card i{font-size:1.5rem;color:var(--blue-300)}

.fc1{top:8%;left:10%;animation-delay:0s}
.fc2{top:5%;right:5%;animation-delay:.4s}
.fc3{top:42%;left:28%;animation-delay:.8s}
.fc4{top:55%;right:8%;animation-delay:1.2s}
.fc5{bottom:5%;left:15%;animation-delay:1.6s}

@keyframes floatUp{
  0%{transform:translateY(0)}
  100%{transform:translateY(-12px)}
}

/* ======== TABS STRIP ======== */
.tabs-strip{
  display:flex;justify-content:center;flex-wrap:wrap;gap:8px;
  padding:10px 20px;
  position:sticky;top:0;z-index:100;
  background:rgba(248,250,252,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(13,71,161,.08);
}
.tab{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 22px;
  border:none;border-radius:50px;
  background:transparent;
  font-family:inherit;font-size:.84rem;font-weight:600;
  color:#64748b;cursor:pointer;
  transition:all .25s;
}
.tab i{font-size:1.05rem}
.tab:hover{color:var(--blue-700);background:var(--blue-100)}
.tab.active{
  color:#fff;
  background:linear-gradient(135deg,var(--blue-700),var(--blue-500));
  box-shadow:0 4px 18px rgba(13,71,161,.30);
}

/* ======== PANELS ======== */
.panels{max-width:1100px;margin:0 auto;padding:40px 20px 80px}
.panel{display:none;animation:fadeSlide .4s ease}
.panel.show{display:block}
@keyframes fadeSlide{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.panel-header{
  display:flex;align-items:center;gap:18px;
  margin-bottom:32px;
}
.panel-badge{
  width:56px;height:56px;border-radius:16px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue-700),var(--blue-500));
  color:#fff;font-size:1.6rem;
  box-shadow:0 6px 20px rgba(13,71,161,.25);
  flex-shrink:0;
}
.panel-header h2{font-size:1.5rem;font-weight:700;margin:0;color:var(--blue-900)}
.panel-header p{margin:4px 0 0;font-size:.88rem;color:#64748b}

/* ======== TABLE CARD ======== */
.card-table{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  margin-bottom:32px;
}
.card-table__bar{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding:16px 24px;
  border-bottom:1px solid var(--blue-100);
}
.card-table__count{
  font-size:.88rem;font-weight:600;color:var(--blue-700);
  display:flex;align-items:center;gap:6px;
}
.card-table__search{
  display:flex;align-items:center;gap:6px;
  background:var(--blue-50);border-radius:8px;
  padding:7px 14px;
}
.card-table__search i{color:var(--blue-400);font-size:.95rem}
.card-table__search input{
  border:none;outline:none;background:transparent;
  font-family:inherit;font-size:.84rem;width:160px;
}

.card-table__scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.86rem}
thead{background:var(--blue-50)}
thead th{
  padding:12px 16px;font-weight:700;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.8px;
  color:var(--blue-700);text-align:left;
  white-space:nowrap;
}
tbody tr{transition:background .2s}
tbody tr:hover{background:var(--blue-50)}
tbody td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#334155}

/* Role badges */
.badge{
  display:inline-block;
  padding:3px 12px;border-radius:50px;
  font-size:.72rem;font-weight:700;
  letter-spacing:.3px;text-transform:uppercase;
}
.badge--chair{background:linear-gradient(135deg,var(--blue-700),var(--blue-500));color:#fff}
.badge--member{background:var(--blue-100);color:var(--blue-700)}
.badge--ext{background:#fef3c7;color:#92400e}
.badge--student{background:#d1fae5;color:#065f46}

/* ======== HELPLINE ======== */
.helpline{
  display:flex;gap:24px;
  padding:28px 32px;
  border-radius:var(--radius);
  background:linear-gradient(135deg,var(--blue-800),var(--blue-700));
  color:#fff;
  align-items:flex-start;
  box-shadow:0 8px 32px rgba(13,71,161,.25);
}
.helpline__icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:grid;place-items:center;
  font-size:1.5rem;flex-shrink:0;
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.25)}50%{box-shadow:0 0 0 12px rgba(255,255,255,0)}}

.helpline__body h4{font-size:1.1rem;font-weight:700;margin:0 0 6px}
.helpline__num{font-size:1.45rem;font-weight:800;margin:0 0 12px;color:var(--gold)}
.helpline__num small{font-size:.75rem;font-weight:400;color:rgba(255,255,255,.6)}
.helpline__links{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:10px}
.helpline__links a{
  color:var(--blue-200);font-size:.82rem;text-decoration:none;
  display:inline-flex;align-items:center;gap:4px;
  transition:color .2s;
}
.helpline__links a:hover{color:#fff}
.helpline__note{color:rgba(255,255,255,.5);font-size:.72rem}

/* ======== RESPONSIVE ======== */
@media(max-width:992px){
  .hero-grid{grid-template-columns:1fr;gap:30px;padding:100px 24px 40px}
  .hero-right{height:260px}
  .float-card{padding:12px 16px;font-size:.8rem}
  .fc1{top:5%;left:5%}
  .fc2{top:0;right:0}
  .fc3{top:38%;left:20%}
  .fc4{top:50%;right:2%}
  .fc5{bottom:2%;left:8%}
  .hero-circle{width:220px;height:220px}
}
@media(max-width:768px){
  .hero-left h1{font-size:2.4rem}
  .hero-stats{gap:20px}
  .stat strong{font-size:1.4rem}
  .hero-right{display:none}
  .tabs-strip{gap:4px;padding:8px 12px}
  .tab{padding:8px 14px;font-size:.76rem}
  .tab span{display:none}
  .tab i{font-size:1.15rem}
  .panels{padding:24px 12px 60px}
  .helpline{flex-direction:column;padding:20px}
  .card-table__bar{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .hero{min-height:auto}
  .hero-grid{padding:90px 16px 30px}
  .hero-left h1{font-size:2rem}
}
