/* ══════════════════════════════════════════════
   Classes — On2ourage — Page Styles
   ══════════════════════════════════════════════ */
.bg-center{position:fixed;inset:0;background:var(--bg2);pointer-events:none;z-index:-1}
.page{max-width:1280px;margin:0 auto;padding:52px 32px 80px;position:relative;z-index:1}
.page-hero{text-align:center;margin-bottom:52px;}
.eyebrow{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);display:block;margin-bottom:14px;}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(32px,4.5vw,56px);font-weight:900;letter-spacing:-1.2px;line-height:1.06;margin-bottom:16px;}
.page-hero h1 em{color:var(--primary);font-style:italic;}
.page-hero p{font-size:16px;color:var(--text3);font-weight:300;line-height:1.7;max-width:500px;margin:0 auto;}
/* day filter */
.day-filter{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:40px;}
.day-pill{padding:8px 20px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:border-color 0.18s,color 0.18s;}
.day-pill:hover{border-color:var(--primary);color:var(--primary);}
.day-pill.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 14px rgba(128,0,32,0.28);}
/* grid */
.classes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.class-card{background:var(--card);border:1.5px solid var(--border);border-radius:18px;overflow:hidden;cursor:pointer;transition:transform 0.25s,box-shadow 0.25s,border-color 0.25s;}
.class-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(19,10,6,0.12);border-color:var(--border2);}
.cc-banner{height:110px;display:flex;align-items:center;justify-content:center;font-size:44px;position:relative;}
.cc-banner-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(19,10,6,0.14));}
.cc-level-badge{position:absolute;bottom:10px;right:12px;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:3px 9px;border-radius:4px;color:var(--text2);}
.cc-body{padding:20px;}
.cc-name{font-family:'Playfair Display',serif;font-size:17px;font-weight:800;margin-bottom:4px;}
.cc-instructor{font-size:11px;color:var(--text3);font-weight:300;margin-bottom:14px;}
.cc-chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:16px;}
.cc-chip{font-size:10px;font-weight:600;padding:3px 9px;border-radius:5px;background:var(--bg2);color:var(--text2);}
.cc-spots{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.cc-spots-bar-wrap{flex:1;height:4px;background:var(--bg2);border-radius:3px;overflow:hidden;}
.cc-spots-bar{height:100%;border-radius:3px;background:var(--primary);}
.cc-spots-label{font-size:10px;color:var(--text3);}
.cc-btn{display:block;width:100%;padding:10px;border-radius:9px;background:var(--primary);color:#fff;border:none;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;cursor:pointer;text-align:center;text-decoration:none;transition:background 0.15s,transform 0.15s;box-shadow:0 4px 14px rgba(128,0,32,0.28);}
.cc-btn:hover{background:#99001C;transform:translateY(-1px);}
.empty-state{text-align:center;padding:60px 20px;color:var(--text3);}
.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:0.5;}
/* reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.5s ease,transform 0.5s ease;}
.reveal.in{opacity:1;transform:translateY(0);}
@media(max-width:900px){.classes-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:580px){.classes-grid{grid-template-columns:1fr;}.page{padding:40px 20px 60px;}}
