/* ============================================================
   HEARTQUARTERS — Y2K DREAM HUB
   Design tokens
   ============================================================ */
:root{
  --baby-blue:#BFE8FF;
  --sky-blue:#9FD8FF;
  --powder-blue:#D6EFFF;
  --pearl:#FAFCFF;
  --white:#FFFFFF;
  --pink:#FFD3E8;
  --lavender:#E4D7FF;
  --silver:#E7ECF4;
  --pale-yellow:#FFF6C6;
  --ink:#3E5C82;
  --ink-soft:#7E97B8;
  --shadow:rgba(110,160,210,0.25);

  --font-display:'Baloo 2', system-ui, sans-serif;
  --font-body:'Quicksand', system-ui, sans-serif;
  --font-pixel:'Press Start 2P', monospace;

  --radius-lg:26px;
  --radius-md:18px;
  --radius-sm:12px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:
    radial-gradient(circle at 15% 10%, var(--pink) 0, transparent 35%),
    radial-gradient(circle at 85% 15%, var(--lavender) 0, transparent 40%),
    radial-gradient(circle at 50% 90%, var(--pale-yellow) 0, transparent 35%),
    linear-gradient(180deg, var(--powder-blue), var(--baby-blue) 40%, var(--powder-blue));
  background-attachment:fixed;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ink);
  margin:0 0 .4em;
  line-height:1.2;
}

a{color:#5B9BD5; text-decoration:none;}
a:hover{text-decoration:underline;}

img{max-width:100%; display:block;}

.visually-hidden{
  position:absolute; width:1px; height:1px; overflow:hidden;
  clip:rect(0 0 0 0); white-space:nowrap;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
  html{scroll-behavior:auto;}
}

/* Focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, [tabindex]:focus-visible{
  outline:3px solid #5B9BD5;
  outline-offset:2px;
  border-radius:8px;
}

/* ============================================================
   FLOATING DECORATIONS
   ============================================================ */
#floaties{
  position:fixed; inset:0; pointer-events:none; z-index:1; overflow:hidden;
}
.floatie{
  position:absolute;
  bottom:-10vh;
  opacity:.45;
  animation:floatUp linear infinite;
  color:#5B9BD5;
  filter:drop-shadow(0 0 4px rgba(255,255,255,.6));
}
.floatie svg{ width:100%; height:100%; display:block; }
@keyframes floatUp{
  0%{ transform:translateY(0) translateX(0) rotate(0deg); opacity:0; }
  10%{ opacity:.6; }
  50%{ transform:translateY(-55vh) translateX(20px) rotate(180deg); }
  90%{ opacity:.5; }
  100%{ transform:translateY(-110vh) translateX(-15px) rotate(360deg); opacity:0; }
}

/* ============================================================
   TOP BAR / NAV
   ============================================================ */
#topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,0.65);
  backdrop-filter:blur(14px);
  border-bottom:2px solid rgba(255,255,255,0.8);
  box-shadow:0 4px 20px var(--shadow);
}
.topbar-inner{
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; gap:18px;
  padding:10px 16px;
}
.brand{
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:800;
  font-size:1.3rem; color:var(--ink);
  white-space:nowrap;
  background:none; border:none; padding:0; cursor:pointer;
}
.brand:hover{ opacity:.8; }
.brand .back-icon{display:inline-block; width:22px; height:22px; color:#5B9BD5;}
.nav-icon{ width:16px; height:16px; flex-shrink:0; vertical-align:-3px; }

.nav-scroll{
  flex:1; overflow-x:auto; scrollbar-width:thin;
}
.nav-list{
  display:flex; gap:6px; list-style:none; margin:0; padding:4px 2px;
}
.nav-list button{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-body); font-weight:700; font-size:.85rem;
  color:var(--ink); background:rgba(255,255,255,.55);
  border:2px solid transparent; border-radius:999px;
  padding:8px 14px; cursor:pointer; white-space:nowrap;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.nav-list button:hover{ transform:translateY(-2px); background:var(--white); }
.nav-list button.active{
  background:linear-gradient(135deg, var(--baby-blue), var(--lavender));
  border-color:var(--white);
  box-shadow:0 3px 10px var(--shadow);
}

@media (max-width:760px){
  .brand span.brand-text{ display:none; }
  .topbar-inner{ gap:14px; padding:10px 12px; }
  .brand{ padding:6px; }
}

/* ============================================================
   LAYOUT / SECTIONS
   ============================================================ */
main{ max-width:1200px; margin:0 auto; padding:24px 16px 24px; position:relative; z-index:2; }
.page{ display:none; animation:fadeIn .4s ease; }
.page.active{ display:block; }
@keyframes fadeIn{ from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);} }

.page-header{ text-align:center; margin-bottom:28px; }
.page-header h1{ font-size:2.1rem; }
.page-header p{ color:var(--ink-soft); max-width:640px; margin:6px auto 0; }

.eyebrow{
  display:inline-block; font-family:var(--font-pixel); font-size:.6rem;
  letter-spacing:.05em; color:#fff; background:var(--sky-blue);
  padding:6px 10px; border-radius:8px; margin-bottom:10px;
  box-shadow:2px 2px 0 var(--shadow);
}

/* ============================================================
   WINDOW FRAME (signature element)
   ============================================================ */
.winframe{
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius-lg);
  box-shadow:0 10px 30px var(--shadow);
  margin-bottom:24px;
  overflow:hidden;
}
.winframe-title{
  display:flex; align-items:center; gap:10px;
  background:linear-gradient(90deg, var(--baby-blue), var(--powder-blue));
  padding:10px 14px;
  border-bottom:1px solid rgba(255,255,255,.7);
}
.winframe-dots{ display:flex; gap:6px; }
.winframe-dots span{
  width:11px; height:11px; border-radius:50%; display:block;
  box-shadow:inset 0 1px 2px rgba(255,255,255,.8);
}
.winframe-dots span:nth-child(1){ background:var(--pink); }
.winframe-dots span:nth-child(2){ background:var(--pale-yellow); }
.winframe-dots span:nth-child(3){ background:#BFF0CE; }
.winframe-title h3{
  font-family:var(--font-pixel); font-size:.7rem; margin:0;
  color:var(--ink); letter-spacing:.03em;
}
.winframe-body{ padding:20px; }
@media (max-width:600px){ .winframe-body{ padding:14px; } }

/* ============================================================
   BUTTONS / CHIPS
   ============================================================ */
.btn{
  font-family:var(--font-body); font-weight:700; font-size:.9rem;
  color:var(--ink); background:linear-gradient(180deg,#fff, var(--powder-blue));
  border:2px solid var(--white); border-radius:999px;
  padding:10px 20px; cursor:pointer;
  box-shadow:0 4px 0 var(--sky-blue);
  transition:transform .12s ease, box-shadow .12s ease;
}
.btn:hover{ transform:translateY(2px); box-shadow:0 2px 0 var(--sky-blue); }
.btn:active{ transform:translateY(4px); box-shadow:0 0 0 var(--sky-blue); }
.btn.pink{ background:linear-gradient(180deg,#fff, var(--pink)); box-shadow:0 4px 0 #f3a9c7; }
.btn.pink:hover{ box-shadow:0 2px 0 #f3a9c7; }
.btn.pink:active{ box-shadow:0 0 0 #f3a9c7; }
.btn:disabled{ opacity:.5; cursor:not-allowed; transform:none; box-shadow:0 4px 0 var(--silver); }

.chip{
  display:inline-block; font-size:.75rem; font-weight:700;
  background:var(--white); border-radius:999px; padding:4px 12px;
  margin:2px; color:var(--ink); border:1px solid var(--powder-blue);
}

/* ============================================================
   HOME PAGE
   ============================================================ */
.hero{
  text-align:center; padding:48px 16px 28px; position:relative;
}
.hq-title-btn{
  display:inline-block;
  font-family:var(--font-pixel);
  font-size:clamp(1.1rem, 3.5vw, 1.6rem);
  letter-spacing:.06em;
  color:#ffffff;
  background:#a9d9f8;
  padding:14px 32px;
  border-radius:16px;
  box-shadow:3px 3px 0 rgba(80,160,210,0.35);
  margin-bottom:4px;
  line-height:1.4;
  border:none; cursor:pointer;
  transition:transform .1s ease, box-shadow .1s ease;
}
.hq-title-btn:hover{
  transform:translateY(-2px);
  box-shadow:3px 5px 0 rgba(80,160,210,0.4);
}
.hq-title-btn:active{ transform:translateY(1px); }

.hq-tooltip{
  position:relative; z-index:10;
  background:#fff; border:2px solid var(--powder-blue);
  border-radius:var(--radius-md); padding:18px 20px 16px;
  max-width:320px; margin:10px auto 0;
  text-align:left; font-size:.88rem; line-height:1.5;
  box-shadow:0 8px 24px rgba(122,200,232,0.2);
  animation:fadeIn .2s ease;
}
.hq-tooltip-close{
  position:absolute; top:10px; right:12px;
  background:none; border:none; cursor:pointer;
  font-size:.85rem; color:var(--ink-soft); padding:2px 6px;
}
.hq-tooltip-close:hover{ color:var(--ink); }
.hero p.tagline{
  font-size:1.05rem; color:var(--ink-soft); max-width:560px; margin:0 auto 22px;
}
.hero-logo{
  margin-bottom:-10px;
  animation:bob 3s ease-in-out infinite;
  display:flex; justify-content:center;
}
.hero-logo .hero-icon{
  width:320px; height:320px; object-fit:contain;
  filter:drop-shadow(0 4px 14px rgba(122,200,232,0.4));
}
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }

.quick-nav{
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:18px;
}
.quick-nav .btn{
  display:inline-flex; align-items:center; gap:8px; font-size:.85rem; padding:10px 18px;
}
.quick-nav .btn svg{ width:18px; height:18px; flex-shrink:0; }

.home-grid{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:18px;
}
.update-item, .sched-item{
  display:flex; gap:12px; align-items:flex-start;
  padding:10px 0; border-bottom:1px dashed var(--powder-blue);
}
.update-item:last-child, .sched-item:last-child{ border-bottom:none; }
.update-badge{
  flex-shrink:0; width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:var(--baby-blue); color:var(--ink);
}
.update-badge svg{ width:18px; height:18px; }
.update-text strong{ display:block; color:var(--ink); }
.update-text span{ font-size:.8rem; color:var(--ink-soft); }

/* ============================================================
   ABOUT PAGES
   ============================================================ */
.about-flex{ display:flex; gap:22px; flex-wrap:wrap; align-items:flex-start; }
.about-flex .about-art{
  flex:0 0 160px; text-align:center;
}
.about-art .blob{
  width:140px; height:140px; margin:0 auto;
  border-radius:42% 58% 60% 40% / 45% 45% 55% 55%;
  background:linear-gradient(145deg, var(--baby-blue), var(--lavender));
  display:flex; align-items:center; justify-content:center; font-size:3rem;
  box-shadow:0 8px 24px var(--shadow);
  animation:morph 8s ease-in-out infinite;
}
@keyframes morph{
  0%,100%{ border-radius:42% 58% 60% 40% / 45% 45% 55% 55%; }
  50%{ border-radius:60% 40% 45% 55% / 55% 60% 40% 45%; }
}
.about-flex .about-text{ flex:1; min-width:240px; }

.social-links{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.social-links a{
  display:flex; align-items:center; gap:8px;
  background:var(--white); border:2px solid var(--powder-blue);
  border-radius:999px; padding:8px 16px; font-weight:700; font-size:.85rem;
  color:var(--ink); transition:transform .12s ease, background .12s ease;
}
.social-links a:hover{ transform:translateY(-2px); background:var(--baby-blue); text-decoration:none; }
.social-links svg{ width:18px; height:18px; }

.term-list{ display:grid; gap:12px; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.term-card{
  background:var(--white); border-radius:var(--radius-md); padding:14px 16px;
  border:1px solid var(--powder-blue);
}
.term-card h4{ font-size:.95rem; margin-bottom:4px; display:flex; align-items:center; gap:8px; }
.term-card p{ margin:0; font-size:.85rem; color:var(--ink-soft); }
.term-icon{ width:18px; height:18px; flex-shrink:0; color:#5B9BD5; }
.term-icon-badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:26px; height:26px; border-radius:50%; background:var(--baby-blue); color:var(--ink);
  flex-shrink:0;
}
.term-icon-badge svg{ width:14px; height:14px; }

/* Voting step-by-step */
.vote-steps{ display:flex; flex-direction:column; gap:14px; }
.vote-step{
  display:flex; gap:14px; align-items:flex-start;
  background:var(--white); border-radius:var(--radius-md); padding:14px 16px;
  border:1px solid var(--powder-blue);
}
.vote-step-num{
  flex-shrink:0; display:flex; flex-direction:column; align-items:center; gap:4px;
  font-family:var(--font-pixel); font-size:.55rem; color:#5B9BD5; min-width:50px; text-align:center;
}
.vote-step-body h4{ font-size:.95rem; margin-bottom:6px; }
.vote-step-body ul{ margin:0; padding-left:20px; font-size:.85rem; color:var(--ink-soft); }
.vote-step-body li{ margin-bottom:3px; }

/* Voting table */
table.voting-table{ font-size:.8rem; min-width:900px; }
table.voting-table th{ white-space:normal; }
table.voting-table td{ vertical-align:top; }

/* ============================================================
   MEMBER PROFILES
   ============================================================ */
.member-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px;
}
.member-card{
  background:var(--white); border-radius:var(--radius-lg);
  border:3px solid var(--white);
  box-shadow:0 8px 22px var(--shadow);
  overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease;
}
.member-card:hover{ transform:translateY(-6px) rotate(-1deg); box-shadow:0 14px 28px var(--shadow); }
.member-photo{
  height:150px; display:flex; flex-direction:column; align-items:center; justify-content:center;
  position:relative; background-size:cover; background-position:center;
}
.member-photo::after{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.6), transparent 60%);
  pointer-events:none;
}
.member-photo.placeholder{
  border:2px dashed rgba(255,255,255,.8);
}
.member-photo .photo-placeholder-icon{
  width:36px; height:36px; color:rgba(62,92,130,.35); position:relative; z-index:1;
}
.member-photo .photo-placeholder-text{
  font-size:.7rem; color:rgba(62,92,130,.5); margin-top:4px; position:relative; z-index:1;
  font-weight:700;
}
.member-emoji-badge{
  position:absolute; bottom:8px; right:8px; z-index:2;
  width:32px; height:32px; border-radius:50%; background:var(--white);
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
  box-shadow:0 3px 8px var(--shadow);
}
.member-info{ padding:14px 16px 18px; }
.member-info h3{ font-size:1.15rem; margin-bottom:0; }
.member-info .korean{ font-size:.8rem; color:var(--ink-soft); margin-bottom:8px; }
.member-meta{ font-size:.78rem; line-height:1.7; margin-bottom:8px; }
.member-meta b{ color:var(--ink); }
.member-fact{ font-size:.82rem; color:#5C6F8B; border-top:1px dashed var(--powder-blue); padding-top:8px; }
.member-fact .label{ font-family:var(--font-pixel); font-size:.55rem; color:#5B9BD5; display:block; margin-bottom:4px; }
.label{ font-family:var(--font-pixel); font-size:.55rem; color:#5B9BD5; }

/* ============================================================
   UNITS / DYNAMICS
   ============================================================ */
.unit-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:16px; }
.unit-card{
  background:linear-gradient(160deg,#fff, var(--powder-blue));
  border-radius:var(--radius-md); padding:16px; border:1px solid var(--white);
}
.unit-card h4{ font-size:1rem; margin-bottom:6px; }
.unit-card .members{ font-weight:700; color:#5B9BD5; margin-bottom:6px; font-size:.9rem; }
.unit-card p{ margin:0; font-size:.85rem; color:var(--ink-soft); }

.hakyuha-table{ width:100%; border-collapse:collapse; font-size:.88rem; table-layout:fixed; }
.hakyuha-table th, .hakyuha-table td{ padding:8px 10px; text-align:left; border-bottom:1px solid var(--powder-blue); }
.hakyuha-table th{ font-family:var(--font-pixel); font-size:.6rem; color:#5B9BD5; }
.hakyuha-table th:first-child, .hakyuha-table td:first-child{ width:32%; white-space:nowrap; }
.hakyuha-table th:nth-child(2), .hakyuha-table td:nth-child(2){ width:42%; }
.hakyuha-table th:last-child, .hakyuha-table td:last-child{ width:26%; }
@media (max-width:600px){
  .hakyuha-table{ font-size:.78rem; }
  .hakyuha-table th, .hakyuha-table td{ padding:7px 6px; }
  .hakyuha-table th:first-child, .hakyuha-table td:first-child{ width:30%; }
  .hakyuha-table th:nth-child(2), .hakyuha-table td:nth-child(2){ width:44%; }
  .hakyuha-table th:last-child, .hakyuha-table td:last-child{ width:26%; }
}

/* ============================================================
   CONTENT MASTERLIST
   ============================================================ */
.filter-bar{
  display:flex; flex-wrap:wrap; gap:10px; margin-bottom:16px; align-items:center;
}
.filter-bar select, .filter-bar input{
  font-family:var(--font-body); font-size:.85rem;
  border:2px solid var(--powder-blue); border-radius:999px;
  padding:8px 14px; background:var(--white); color:var(--ink);
}
table.masterlist{ width:100%; border-collapse:collapse; font-size:.85rem; }
table.masterlist th, table.masterlist td{
  text-align:left; padding:10px 8px; border-bottom:1px solid var(--powder-blue);
}
table.masterlist th{
  font-family:var(--font-pixel); font-size:.58rem; color:#5B9BD5; cursor:pointer; user-select:none;
  white-space:nowrap;
}
table.masterlist th:hover{ color:var(--ink); }
table.masterlist tbody tr:hover{ background:rgba(191,232,255,.3); }
.tag{
  display:inline-block; font-size:.7rem; font-weight:700; padding:3px 10px;
  border-radius:999px; background:#D6EFFF; color:#3a7cb8;
  line-height:1.3;
}
@media (max-width:600px){
  .tag{
    display:block; width:fit-content; max-width:100%;
    border-radius:10px; padding:4px 8px; font-size:.68rem; line-height:1.25;
  }
}
.watch-link{
  display:inline-block; font-size:.75rem; font-weight:700; white-space:nowrap;
  padding:5px 12px; border-radius:999px; background:var(--baby-blue);
  color:var(--ink); border:1px solid var(--white); transition:transform .12s ease, background .12s ease;
}
.watch-link:hover{ background:var(--pink); transform:translateY(-1px); text-decoration:none; }
.no-results{ text-align:center; color:var(--ink-soft); padding:24px; font-size:.9rem; }

/* Achievement award/win tables */
table.achievement-table tr.group-row td{
  font-family:var(--font-pixel); font-size:.6rem; letter-spacing:.05em;
  color:#5B9BD5; background:var(--powder-blue); padding-top:10px; padding-bottom:10px;
  border-bottom:1px solid var(--white);
}
table.achievement-table td{ vertical-align:top; }
.award-tag{ display:inline-block; margin:2px 4px 2px 0; }

/* ============================================================
   DISCOGRAPHY
   ============================================================ */
.era-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px; }
.album-art{
  width:100%; aspect-ratio:1/1; border-radius:var(--radius-md);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  margin-bottom:10px; box-shadow:inset 0 0 0 6px rgba(255,255,255,.6);
  background-size:cover; background-position:center;
}
.album-art.placeholder{ border:2px dashed rgba(255,255,255,.8); }
.album-art .photo-placeholder-icon{ width:44px; height:44px; color:rgba(62,92,130,.35); }
.album-art .photo-placeholder-text{ font-size:.75rem; color:rgba(62,92,130,.5); margin-top:6px; font-weight:700; }
.era-card h4{ margin-bottom:2px; }
.era-card .era-date{ font-size:.78rem; color:var(--ink-soft); margin-bottom:6px; }
.stream-links{ display:flex; gap:8px; margin-bottom:10px; }
.stream-links a{
  display:inline-flex; align-items:center; gap:6px; font-size:.78rem; font-weight:700;
  background:var(--white); border:1px solid var(--powder-blue); border-radius:999px;
  padding:6px 12px; color:var(--ink); transition:transform .12s ease, background .12s ease;
}
.stream-links a:hover{ background:var(--baby-blue); transform:translateY(-1px); text-decoration:none; }
.stream-links svg{ width:14px; height:14px; }
.era-card ul{ margin:8px 0 0; padding-left:20px; font-size:.85rem; }
.era-card li{ margin-bottom:2px; }
.era-card li.placeholder{ color:var(--ink-soft); font-style:italic; }

/* ============================================================
   ACHIEVEMENTS
   ============================================================ */
.badge-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; }
.badge{
  background:var(--white); border-radius:var(--radius-md);
  padding:18px 12px; text-align:center; border:2px solid var(--pale-yellow);
  box-shadow:0 6px 16px var(--shadow);
}
.badge.empty{
  border:2px dashed var(--silver); background:transparent; box-shadow:none; color:var(--ink-soft);
}
.badge .icon{ font-size:2.2rem; display:block; margin-bottom:6px; }
.badge h4{ font-size:.85rem; margin-bottom:2px; }
.badge p{ font-size:.75rem; color:var(--ink-soft); margin:0; }
.icon-badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:50%; background:var(--baby-blue); color:var(--ink);
  flex-shrink:0;
}
.icon-badge svg{ width:18px; height:18px; }

/* ============================================================
   SCHEDULE / CALENDAR
   ============================================================ */
.cal-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.cal-header h3{ font-family:var(--font-display); font-size:1.1rem; margin:0; }
.cal-grid{
  display:grid; grid-template-columns:repeat(7,1fr); gap:4px; text-align:center;
}
.cal-grid .dow{ font-family:var(--font-pixel); font-size:.55rem; color:#5B9BD5; padding:6px 0; }
.cal-cell{
  aspect-ratio:1/1; border-radius:10px; background:var(--white);
  border:1px solid var(--powder-blue); font-size:.8rem; padding:4px;
  display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
  position:relative; min-height:46px;
}
.cal-cell.empty{ background:transparent; border:none; }
.cal-cell.has-event{ background:linear-gradient(160deg,#fff,var(--pink)); border-color:var(--pink); }
.cal-cell .dot{ margin-top:2px; line-height:0; }
.cal-cell .dot svg{ width:10px; height:10px; color:#5B9BD5; }
@media (max-width:600px){ .cal-cell{ font-size:.7rem; min-height:36px; } }

.event-list{ margin-top:18px; display:flex; flex-direction:column; gap:10px; }
.event-card{
  display:flex; gap:12px; align-items:center;
  background:var(--white); border-radius:var(--radius-md); padding:10px 14px;
  border-left:6px solid var(--baby-blue);
}
.event-card .ev-date{
  font-family:var(--font-pixel); font-size:.6rem; color:#5B9BD5;
  white-space:nowrap; flex-shrink:0;
}
.event-card .ev-info{ flex:1; min-width:0; }
.event-card .ev-info strong{ display:block; font-size:.92rem; }
.event-card .ev-info span{ font-size:.78rem; color:var(--ink-soft); }

@media (max-width:600px){
  .event-card{ padding:10px 12px; }
  .event-card .ev-date{ font-size:.56rem; }
}

/* ============================================================
   BACK BUTTON (arcade game pages)
   ============================================================ */
.back-btn{
  display:inline-flex; align-items:center; gap:6px; font-size:.8rem;
  padding:8px 16px; margin-bottom:14px;
}
.back-btn svg{ width:16px; height:16px; }

/* ============================================================
   DUO NICKNAMES TABLE
   ============================================================ */
.duo-table td:first-child{ font-weight:700; white-space:nowrap; }

/* ============================================================
   FAN DIRECTORY
   ============================================================ */
.fan-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.fan-card{
  background:var(--white); border-radius:var(--radius-md); padding:14px 16px;
  border:1px solid var(--powder-blue);
}
.fan-card .fan-cat{ font-family:var(--font-pixel); font-size:.55rem; color:#5B9BD5; display:block; margin-bottom:6px; }
.fan-card h4{ font-size:1.15rem; margin-bottom:10px; }
.fan-visit-btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--white); border:2px solid var(--powder-blue);
  border-radius:999px; padding:7px 16px; font-weight:700; font-size:.8rem;
  color:var(--ink); transition:transform .12s ease, background .12s ease;
}
.fan-visit-btn:hover{ transform:translateY(-2px); background:var(--baby-blue); text-decoration:none; }

/* ============================================================
   ARCADE
   ============================================================ */
.arcade-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:18px; }
.game-card .winframe-body h3{ display:flex; align-items:center; gap:8px; font-size:1.15rem; }
.arcade-game-btn{
  display:block; width:100%; text-align:left; font-family:inherit;
  border:none; padding:0; background:rgba(255,255,255,.7); cursor:pointer;
}
.arcade-game-btn:hover{ transform:translateY(-4px); box-shadow:0 14px 28px var(--shadow); }
.arcade-game-btn .winframe-body p{ margin-bottom:14px; }
@media (max-width:600px){
  .arcade-game-btn .winframe-body p{ font-size:.95rem; line-height:1.45; }
  .arcade-game-btn .winframe-body h3{ font-size:1.05rem; }
}
.arcade-play-btn{ display:inline-block; margin-top:10px; }
.arcade-game-btn .btn{ pointer-events:none; }
.game-stage{
  background:linear-gradient(160deg,var(--powder-blue),var(--white));
  border-radius:var(--radius-md); padding:16px; min-height:120px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
}
.memory-game-host{
  position:relative; width:100%; max-width:320px;
}
.memory-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:8px; width:100%;
}
.memory-game-host .game-overlay{
  border-radius:var(--radius-md);
}
.memory-card{
  aspect-ratio:1/1; border-radius:10px; background:var(--baby-blue);
  display:flex; align-items:center; justify-content:center; font-size:1.6rem;
  cursor:pointer; user-select:none; transition:transform .15s;
  border:2px solid var(--white);
}
.memory-card svg{ width:24px; height:24px; color:var(--white); }
.memory-card.flipped{ background:var(--white); }
.memory-card.matched{ background:var(--pale-yellow); opacity:.7; cursor:default; }
.game-meta{ font-size:.85rem; color:var(--ink-soft); display:flex; gap:14px; }

/* ============================================================
   ARCADE: UNICORN RUSH (Dino-style runner)
   ============================================================ */
.game-host{
  position:relative; background:var(--powder-blue); overflow:hidden;
  border-radius:var(--radius-md); width:100%; max-width:500px;
  box-shadow:inset 0 0 0 6px rgba(255,255,255,.6);
}
#gameCanvas{
  display:block; width:100%; aspect-ratio:500/270;
  image-rendering:pixelated; image-rendering:crisp-edges;
}
.game-overlay{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background:rgba(214,239,255,0.92);
  text-align:center; padding:16px;
}
.go-content{ text-align:center; }
.go-title{
  font-family:'Press Start 2P', monospace; font-size:1.1rem;
  color:var(--ink); letter-spacing:2px;
}
.go-sub{
  font-family:var(--font-body); font-size:.75rem; font-weight:700;
  color:var(--ink-soft); margin-top:6px; letter-spacing:1px;
}
.go-hint{
  font-family:var(--font-body); font-size:.7rem;
  color:var(--ink-soft); margin-top:10px;
}
.go-btn{
  margin-top:16px;
  padding:10px 28px; border-radius:999px;
  background:linear-gradient(180deg,#fff, var(--pink));
  color:var(--ink); border:2px solid var(--white);
  font-family:var(--font-display); font-weight:700; font-size:.9rem;
  letter-spacing:1px; cursor:pointer;
  box-shadow:0 4px 0 #f3a9c7;
  transition:transform .12s ease, box-shadow .12s ease;
}
.go-btn:hover{ transform:translateY(2px); box-shadow:0 2px 0 #f3a9c7; }

.quiz-question{ font-weight:700; margin-bottom:10px; text-align:center; }
.quiz-options{ display:flex; flex-direction:column; gap:8px; width:100%; max-width:340px; }
.quiz-options button{
  font-family:var(--font-body); font-size:.88rem; text-align:left;
  border:2px solid var(--powder-blue); background:var(--white); border-radius:var(--radius-sm);
  padding:10px 14px; cursor:pointer;
}
.quiz-options button.correct{ background:#D7F4DD; border-color:#9AE0AC; }
.quiz-options button.wrong{ background:#FFE0E6; border-color:#FFB3C2; }
.quiz-progress{ font-size:.8rem; color:var(--ink-soft); }

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  text-align:center; padding:28px 16px 40px; font-size:.78rem; color:var(--ink-soft);
  position:relative; z-index:2;
}
footer .heart-divider{ display:flex; justify-content:center; gap:10px; margin-bottom:8px; }
footer .heart-divider svg{ width:18px; height:18px; color:#5B9BD5; }

/* ============================================================
   RESPONSIVE TWEAKS
   ============================================================ */
@media (max-width:480px){
  .hero{ padding:32px 8px 20px; }
  .winframe-body{ padding:12px; }
}