/* =============================================================
   Star Globe × 青葉アグロラ — Stylesheet
   ============================================================= */

:root {
  --cardinal:      #2d5a3d;
  --cardinal-dark: #1e3d2a;
  --cardinal-btn:  #2d5a3d;
  --gold:          #b5872a;
  --gold-light:    #d4a843;
  --black:     #2e2d29;
  --dark-gray: #4d4b46;
  --mid-gray:  #767674;
  --light-bg:  #f4f4f4;
  --white:     #ffffff;
  --warm-off:  #f9f6f1;
  --font-serif: 'Source Serif 4', 'Noto Serif JP', Georgia, serif;
  --font-sans:  'Noto Sans JP', 'Helvetica Neue', Arial, sans-serif;
}

/* --- Reset --- */
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-sans); color:var(--black); background:var(--white); line-height:1.6; }

/* =============================================================
   Navigation — Utility
   ============================================================= */
.nav-utility { background:var(--black); padding:0.55rem 0; }
.nav-utility-inner { max-width:1200px; margin:0 auto; padding:0 2rem; display:flex; justify-content:space-between; align-items:center; }
.nav-utility-brand { color:#fff; font-family:var(--font-serif); font-size:1.1rem; font-weight:400; text-decoration:none; }
.nav-utility-brand strong { color:var(--gold-light); }
.nav-utility-links { display:flex; gap:2rem; list-style:none; }
.nav-utility-links a { color:rgba(255,255,255,.75); font-size:.78rem; text-decoration:none; transition:color .2s; }
.nav-utility-links a:hover { color:#fff; }

.btn-login { background:transparent; color:rgba(255,255,255,.85); border:1px solid rgba(255,255,255,.4); font-size:.75rem; padding:.4rem 1rem; border-radius:2px; text-decoration:none; transition:background .2s,border-color .2s,color .2s; white-space:nowrap; }
.btn-login:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.7); color:#fff; }

/* =============================================================
   Navigation — Main
   ============================================================= */
.nav-main { background:var(--white); border-bottom:1px solid #ddd; position:sticky; top:0; z-index:100; }
.nav-main-inner { max-width:1200px; margin:0 auto; padding:0 2rem; display:flex; align-items:stretch; }
.nav-main-links { display:flex; list-style:none; }
.nav-main-links li a { display:block; color:var(--black); text-decoration:none; font-size:.88rem; padding:1rem 1.1rem; border-bottom:3px solid transparent; transition:border-color .2s,color .2s; }
.nav-main-links li a:hover { border-bottom-color:var(--cardinal); color:var(--cardinal); }

/* =============================================================
   Hamburger & Mobile Menu
   ============================================================= */
.hamburger { display:none; background:none; border:none; cursor:pointer; padding:.5rem; }
.hamburger span { display:block; width:22px; height:2px; background:#fff; margin:5px 0; transition:transform .3s,opacity .3s; }
.hamburger[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.hamburger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-menu { display:none; background:var(--white); border-bottom:1px solid #ddd; padding:1rem 2rem; }
.mobile-menu.is-open { display:block; }
.mobile-menu a { display:block; color:var(--black); text-decoration:none; font-size:.92rem; padding:.7rem 0; border-bottom:1px solid #eee; }
.mobile-menu a:last-child { border-bottom:none; }
.mobile-menu a:hover { color:var(--cardinal); }
.mobile-menu .mobile-login { display:inline-block; margin-top:.8rem; background:var(--cardinal); color:#fff; padding:.6rem 1.5rem; font-size:.85rem; font-weight:700; text-decoration:none; }

/* =============================================================
   Hero
   ============================================================= */
.hero { position:relative; height:88vh; min-height:560px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.hero-bg { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(0,0,0,.35),rgba(0,0,0,.55)),linear-gradient(135deg,#1e3d2a 0%,#2d5a3d 40%,#3a7a54 70%,#1a3025 100%); background-size:cover; background-position:center; }
.hero-bg.has-image { background-size:cover; background-position:center; }
.hero-bg::after { content:''; position:absolute; inset:0; background-image:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(181,135,42,.18) 0%,transparent 60%),radial-gradient(ellipse 50% 80% at 10% 80%,rgba(45,90,61,.3) 0%,transparent 50%); }
.hero-content { position:relative; z-index:2; text-align:center; max-width:860px; padding:0 2rem; }
.hero-eyebrow { font-size:.85rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-light); margin-bottom:1.2rem; }
.hero-title { font-family:var(--font-serif); font-size:clamp(3rem,7vw,5.5rem); font-weight:300; color:#fff; line-height:1.12; margin-bottom:1.5rem; }
.hero-subtitle { font-size:clamp(1rem,2vw,1.2rem); color:rgba(255,255,255,.82); max-width:580px; margin:0 auto 2.5rem; line-height:1.7; }
.hero-cta-row { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* =============================================================
   Buttons
   ============================================================= */
.btn { display:inline-block; text-decoration:none; font-size:.9rem; font-weight:700; letter-spacing:.04em; padding:.85rem 2rem; border-radius:0; transition:background .2s,color .2s; cursor:pointer; border:none; }
.btn-primary { background:var(--cardinal-btn); color:#fff; }
.btn-primary:hover { background:var(--cardinal-dark); }
.btn-outline-white { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.7); }
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:#fff; }
.btn-outline { background:transparent; color:var(--cardinal); border:2px solid var(--cardinal); }
.btn-outline:hover { background:var(--cardinal); color:#fff; }
.btn-sm { padding:.5rem 1.2rem; font-size:.8rem; }
.btn-danger { background:#c0392b; color:#fff; }
.btn-danger:hover { background:#a93226; }

/* =============================================================
   Explore Bar
   ============================================================= */
.explore-bar { background:var(--cardinal-btn); text-align:center; padding:1rem; }
.explore-bar a { color:#fff; font-size:.95rem; font-weight:700; letter-spacing:.06em; text-decoration:none; }

/* =============================================================
   Section Utilities
   ============================================================= */
.container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.section-header { text-align:center; margin-bottom:3rem; }
.section-header h2 { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3rem); font-weight:700; color:var(--black); margin-bottom:.75rem; }
.section-header p { font-size:1.05rem; color:var(--dark-gray); max-width:680px; margin:0 auto; line-height:1.7; }
.section-rule { border:none; border-top:1px solid #ddd; max-width:1200px; margin:0 auto; }

.link-chevron { color:var(--cardinal); font-weight:700; text-decoration:none; font-size:.9rem; display:inline-flex; align-items:center; gap:.3rem; transition:gap .2s; }
.link-chevron:hover { gap:.6rem; }
.link-chevron::after { content:'›'; font-size:1.1rem; }

/* =============================================================
   Mission
   ============================================================= */
.mission { background:var(--white); padding:6rem 2rem; text-align:center; }
.mission-text { font-family:var(--font-serif); font-size:clamp(1.35rem,2.8vw,1.9rem); font-weight:300; line-height:1.65; color:var(--black); max-width:880px; margin:0 auto 2.5rem; }
.mission-text strong { font-weight:600; color:var(--cardinal); }

/* =============================================================
   Card Sections & Grids
   ============================================================= */
.card-section { padding:5rem 0; }
.card-section.bg-light { background:var(--light-bg); }
.card-section.bg-white { background:var(--white); }
.card-section.bg-warm  { background:var(--warm-off); }

.card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2.5rem; }
.card-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:2.5rem; }

.card { background:var(--white); border:1px solid #e0e0e0; box-shadow:0 2px 8px rgba(0,0,0,.05); transition:box-shadow .25s; }
.card:hover { box-shadow:0 6px 20px rgba(0,0,0,.1); }
.card-img { width:100%; aspect-ratio:16/10; overflow:hidden; background:var(--light-bg); position:relative; }
.card-img img { width:100%; height:100%; object-fit:cover; }
.card-img-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; background:linear-gradient(135deg,var(--cardinal) 0%,#3a7a54 100%); color:rgba(255,255,255,.6); }
.card-body { padding:1.5rem; }
.card-title { font-family:var(--font-serif); font-size:1.2rem; font-weight:700; color:var(--black); margin-bottom:.6rem; }
.card-desc { font-size:.88rem; color:var(--dark-gray); line-height:1.7; margin-bottom:1rem; }

/* =============================================================
   Quote Band
   ============================================================= */
.quote-band { background:linear-gradient(rgba(30,61,42,.82),rgba(30,61,42,.82)),linear-gradient(135deg,#2d5a3d,#1a3025); padding:6rem 2rem; text-align:center; color:#fff; }
.quote-band blockquote { font-family:var(--font-serif); font-size:clamp(1.5rem,3.5vw,2.3rem); font-weight:300; font-style:italic; line-height:1.55; max-width:820px; margin:0 auto 1.5rem; }
.quote-band cite { display:block; font-style:normal; font-size:.9rem; color:rgba(255,255,255,.75); letter-spacing:.04em; margin-top:.8rem; }
.quote-band cite strong { color:var(--gold-light); font-weight:600; display:block; font-size:1rem; margin-bottom:.2rem; }

/* =============================================================
   Program Cards
   ============================================================= */
.prog-card { background:var(--white); border:1px solid #e0e0e0; transition:box-shadow .25s; }
.prog-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.1); }
.prog-card-head { padding:1.4rem 1.6rem 0; }
.prog-cat { font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--cardinal); font-weight:700; margin-bottom:.5rem; }
.prog-name { font-family:var(--font-serif); font-size:1.05rem; font-weight:700; color:var(--black); margin-bottom:.4rem; line-height:1.4; }
.prog-time { font-size:.78rem; color:var(--mid-gray); margin-bottom:.8rem; }
.prog-body { padding:0 1.6rem 1.4rem; font-size:.85rem; color:var(--dark-gray); line-height:1.75; }
.cat-header { font-family:var(--font-serif); font-size:1.3rem; font-weight:700; color:var(--cardinal-dark); border-bottom:2px solid var(--cardinal); padding-bottom:.5rem; margin-bottom:1.5rem; }

/* =============================================================
   Schedule Table
   ============================================================= */
.schedule-outer { overflow-x:auto; margin-top:2rem; }
.schedule-tbl { width:100%; border-collapse:collapse; font-size:.82rem; min-width:700px; }
.schedule-tbl th { background:var(--cardinal); color:#fff; padding:.85rem 1rem; text-align:center; font-weight:600; letter-spacing:.04em; }
.schedule-tbl th:first-child { text-align:left; }
.schedule-tbl td { padding:.85rem 1rem; border-bottom:1px solid #e8e8e8; vertical-align:top; text-align:center; color:var(--black); }
.schedule-tbl td:first-child { text-align:left; font-weight:700; font-size:.8rem; color:var(--cardinal-dark); background:#f9f9f9; white-space:nowrap; }
.schedule-tbl tr:hover td { background:rgba(45,90,61,.03); }
.schedule-tbl tr:hover td:first-child { background:#f0f0f0; }
.stag { display:inline-block; font-size:.72rem; padding:.25rem .65rem; margin:.2rem; white-space:nowrap; line-height:1.5; border-radius:2px; }
.stag-green { background:var(--cardinal); color:#fff; }
.stag-gold  { background:var(--gold); color:#fff; }
.stag-light { background:transparent; border:1px solid #aaa; color:var(--dark-gray); }
.stag-rust  { background:#8c4a2a; color:#fff; }
.stag-sage  { background:#5a8a6a; color:#fff; }

/* =============================================================
   Pricing
   ============================================================= */
.pricing-plan-hero { background:var(--cardinal); color:#fff; padding:2.5rem; margin-bottom:.5rem; }
.pricing-plan-hero h3 { font-family:var(--font-serif); font-size:1.5rem; font-weight:700; margin-bottom:.5rem; }
.pricing-plan-hero .big-price { font-family:var(--font-serif); font-size:3.2rem; font-weight:700; color:var(--gold-light); line-height:1; margin-bottom:.4rem; }
.pricing-plan-hero p { font-size:.88rem; opacity:.85; line-height:1.7; }

.price-tbl { width:100%; border-collapse:collapse; font-size:.85rem; }
.price-tbl th { background:#f4f4f4; border-bottom:2px solid #ddd; padding:.65rem 1rem; text-align:left; font-weight:700; font-size:.78rem; color:var(--black); letter-spacing:.04em; }
.price-tbl td { padding:.65rem 1rem; border-bottom:1px solid #eee; color:var(--black); }
.price-tbl .price-num { font-family:var(--font-serif); font-size:1.1rem; font-weight:700; color:var(--cardinal); }
.price-tbl .highlight td { background:rgba(45,90,61,.05); }
.price-note { font-size:.8rem; color:var(--mid-gray); margin-top:.7rem; padding-left:.8rem; border-left:3px solid var(--gold); line-height:1.75; }
.pricing-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; }
.pricing-block h3 { font-family:var(--font-serif); font-size:1.15rem; font-weight:700; color:var(--cardinal-dark); border-bottom:2px solid var(--cardinal); padding-bottom:.6rem; margin-bottom:1.2rem; }

/* =============================================================
   Guide Table
   ============================================================= */
.guide-tbl { width:100%; border-collapse:collapse; font-size:.88rem; }
.guide-tbl thead th { background:var(--cardinal); color:#fff; padding:.75rem 1.2rem; text-align:left; font-weight:600; }
.guide-tbl tbody tr:nth-child(odd) td { background:var(--warm-off); }
.guide-tbl tbody tr:nth-child(even) td { background:var(--white); }
.guide-tbl td { padding:.85rem 1.2rem; border-bottom:1px solid #e8e8e8; line-height:1.65; }
.guide-tbl td:first-child { font-weight:700; color:var(--cardinal-dark); }

/* =============================================================
   Festival Roles
   ============================================================= */
.fest-roles { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:2.5rem; }
.fest-role { background:var(--white); border-top:4px solid var(--cardinal); padding:1.5rem; }
.fest-role-icon { font-size:1.8rem; margin-bottom:.8rem; display:block; }
.fest-role-title { font-family:var(--font-serif); font-size:1rem; font-weight:700; color:var(--black); margin-bottom:.5rem; }
.fest-role-desc { font-size:.84rem; color:var(--dark-gray); line-height:1.75; }

/* =============================================================
   CTA Section
   ============================================================= */
.cta-section { background:var(--cardinal-dark); padding:6rem 2rem; text-align:center; color:#fff; }
.cta-section h2 { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3rem); font-weight:300; color:#fff; margin-bottom:1rem; line-height:1.35; }
.cta-section p { font-size:1.05rem; color:rgba(255,255,255,.75); margin-bottom:2.5rem; max-width:540px; margin-left:auto; margin-right:auto; }
.cta-section .contact-row { display:flex; gap:2.5rem; justify-content:center; flex-wrap:wrap; margin-top:2.5rem; font-size:.88rem; color:rgba(255,255,255,.6); }
.cta-section .contact-row a { color:var(--gold-light); text-decoration:none; }

/* =============================================================
   Footer
   ============================================================= */
footer { background:var(--black); color:rgba(255,255,255,.5); padding:2rem; text-align:center; font-size:.78rem; letter-spacing:.05em; }
footer a { color:rgba(255,255,255,.6); text-decoration:none; }

/* =============================================================
   Reports Page
   ============================================================= */
.reports-header { background:var(--cardinal-dark); color:#fff; padding:4rem 2rem; text-align:center; }
.reports-header h1 { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3rem); font-weight:300; margin-bottom:.5rem; }
.reports-header p { font-size:1rem; color:rgba(255,255,255,.7); }

.filter-bar { background:var(--white); border-bottom:1px solid #ddd; padding:1rem 0; }
.filter-bar-inner { max-width:1200px; margin:0 auto; padding:0 2rem; display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.filter-tabs { display:flex; gap:.5rem; flex-wrap:wrap; }
.filter-tab { padding:.4rem 1rem; font-size:.8rem; border:1px solid #ddd; background:var(--white); color:var(--dark-gray); text-decoration:none; transition:all .2s; cursor:pointer; }
.filter-tab:hover, .filter-tab.active { background:var(--cardinal); color:#fff; border-color:var(--cardinal); }
.filter-select { padding:.4rem .8rem; font-size:.82rem; border:1px solid #ddd; background:var(--white); color:var(--black); }

.report-card { background:var(--white); border:1px solid #e8e8e8; transition:box-shadow .2s; }
.report-card:hover { box-shadow:0 4px 16px rgba(0,0,0,.08); }
.report-card-img { width:100%; aspect-ratio:16/10; overflow:hidden; background:var(--light-bg); }
.report-card-img img { width:100%; height:100%; object-fit:cover; }
.report-card-body { padding:1.2rem; }
.report-card-cat { font-size:.7rem; font-weight:700; color:var(--cardinal); letter-spacing:.1em; text-transform:uppercase; margin-bottom:.4rem; }
.report-card-title { font-family:var(--font-serif); font-size:1.05rem; font-weight:700; color:var(--black); margin-bottom:.4rem; line-height:1.4; }
.report-card-date { font-size:.75rem; color:var(--mid-gray); margin-bottom:.5rem; }
.report-card-excerpt { font-size:.82rem; color:var(--dark-gray); line-height:1.6; margin-bottom:.8rem; }

.pagination { display:flex; justify-content:center; gap:.5rem; padding:3rem 0; }
.pagination a, .pagination span { display:inline-block; padding:.5rem 1rem; font-size:.85rem; border:1px solid #ddd; color:var(--dark-gray); text-decoration:none; }
.pagination a:hover { background:var(--light-bg); }
.pagination .current { background:var(--cardinal); color:#fff; border-color:var(--cardinal); }

/* Report Detail */
.report-detail-header { background:var(--cardinal-dark); color:#fff; padding:3rem 2rem; }
.breadcrumb { font-size:.8rem; color:rgba(255,255,255,.6); margin-bottom:1.5rem; }
.breadcrumb a { color:rgba(255,255,255,.7); text-decoration:none; }
.breadcrumb a:hover { color:#fff; }
.report-detail-header h1 { font-family:var(--font-serif); font-size:clamp(1.5rem,3vw,2.5rem); font-weight:300; margin-bottom:.8rem; }
.report-meta { font-size:.85rem; color:rgba(255,255,255,.6); }
.report-meta span { margin-right:1.5rem; }

.report-body { max-width:800px; margin:0 auto; padding:3rem 2rem; font-size:1rem; line-height:1.85; color:var(--black); }
.report-body h2 { font-family:var(--font-serif); font-size:1.5rem; font-weight:700; color:var(--cardinal-dark); margin:2.5rem 0 1rem; padding-bottom:.4rem; border-bottom:2px solid var(--cardinal); }
.report-body h3 { font-size:1.2rem; font-weight:700; color:var(--black); margin:2rem 0 .8rem; }
.report-body img { max-width:100%; margin:1.5rem 0; }
.report-body blockquote { border-left:4px solid var(--gold); padding:1rem 1.5rem; background:var(--warm-off); margin:1.5rem 0; font-style:italic; color:var(--dark-gray); }
.report-body ul, .report-body ol { padding-left:1.5rem; margin:1rem 0; }

.related-reports { background:var(--light-bg); padding:4rem 0; }

/* =============================================================
   Login / Signup Pages
   ============================================================= */
.auth-page { min-height:80vh; display:flex; align-items:center; justify-content:center; background:var(--light-bg); padding:3rem 2rem; }
.auth-card { background:var(--white); max-width:440px; width:100%; padding:3rem; box-shadow:0 2px 12px rgba(0,0,0,.08); }
.auth-card h1 { font-family:var(--font-serif); font-size:1.8rem; font-weight:700; color:var(--cardinal-dark); margin-bottom:.5rem; }
.auth-card .auth-subtitle { font-size:.9rem; color:var(--mid-gray); margin-bottom:2rem; }

.form-group { margin-bottom:1.2rem; }
.form-group label { display:block; font-size:.82rem; font-weight:700; color:var(--dark-gray); margin-bottom:.4rem; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:.7rem 1rem; font-size:.9rem; border:1px solid #ddd; background:var(--white);
  color:var(--black); font-family:var(--font-sans); transition:border-color .2s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline:none; border-color:var(--cardinal);
}
.form-group textarea { min-height:120px; resize:vertical; }
.form-error { color:#c0392b; font-size:.82rem; margin-top:.3rem; }
.form-success { color:var(--cardinal); font-size:.9rem; margin-bottom:1rem; padding:.8rem; background:rgba(45,90,61,.08); border-left:3px solid var(--cardinal); }

.auth-card .btn { width:100%; text-align:center; margin-top:.5rem; }
.auth-links { margin-top:1.5rem; text-align:center; font-size:.82rem; color:var(--mid-gray); }
.auth-links a { color:var(--cardinal); text-decoration:none; }

/* =============================================================
   Portal Layout (Member / Admin)
   ============================================================= */
.portal-layout { display:flex; min-height:100vh; }

.portal-sidebar {
  width:250px; background:var(--cardinal-dark); color:#fff; display:flex; flex-direction:column;
  position:fixed; top:0; left:0; bottom:0; z-index:200; transition:transform .3s;
}
.portal-sidebar.is-closed { transform:translateX(-100%); }
.portal-brand { padding:1.2rem 1.5rem; border-bottom:1px solid rgba(255,255,255,.1); }
.portal-brand a { color:#fff; text-decoration:none; font-family:var(--font-serif); font-size:1.1rem; }
.portal-user { padding:1.2rem 1.5rem; border-bottom:1px solid rgba(255,255,255,.1); }
.portal-user-name { font-weight:700; font-size:.95rem; }
.portal-user-role { font-size:.75rem; color:rgba(255,255,255,.5); margin-top:.2rem; }

.portal-nav { flex:1; padding:.8rem 0; overflow-y:auto; }
.portal-nav a { display:block; padding:.65rem 1.5rem; color:rgba(255,255,255,.75); text-decoration:none; font-size:.85rem; transition:background .2s,color .2s; }
.portal-nav a:hover { background:rgba(255,255,255,.08); color:#fff; }
.portal-nav a.active { background:rgba(255,255,255,.12); color:#fff; border-left:3px solid var(--gold-light); padding-left:calc(1.5rem - 3px); }

.portal-logout { padding:1rem 1.5rem; border-top:1px solid rgba(255,255,255,.1); }
.portal-logout a { color:rgba(255,255,255,.5); text-decoration:none; font-size:.8rem; }
.portal-logout a:hover { color:#fff; }

.portal-main { flex:1; margin-left:250px; background:var(--light-bg); min-height:100vh; }
.portal-topbar { background:var(--white); border-bottom:1px solid #ddd; padding:1rem 2rem; display:flex; align-items:center; gap:1rem; position:sticky; top:0; z-index:100; }
.portal-page-title { font-family:var(--font-serif); font-size:1.3rem; font-weight:700; color:var(--black); }
.portal-menu-toggle { display:none; background:none; border:none; font-size:1.3rem; cursor:pointer; color:var(--black); padding:.3rem; }
.portal-content { padding:2rem; }

/* Portal cards */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.5rem; margin-bottom:2rem; }
.stat-card { background:var(--white); padding:1.5rem; border-left:4px solid var(--cardinal); }
.stat-card-value { font-family:var(--font-serif); font-size:2rem; font-weight:700; color:var(--cardinal); }
.stat-card-label { font-size:.82rem; color:var(--mid-gray); margin-top:.2rem; }

.portal-card { background:var(--white); padding:1.5rem; margin-bottom:1.5rem; }
.portal-card h2 { font-family:var(--font-serif); font-size:1.1rem; font-weight:700; color:var(--black); margin-bottom:1rem; padding-bottom:.5rem; border-bottom:1px solid #eee; }

.data-table { width:100%; border-collapse:collapse; font-size:.85rem; }
.data-table th { background:var(--light-bg); padding:.65rem 1rem; text-align:left; font-weight:700; font-size:.78rem; color:var(--dark-gray); border-bottom:2px solid #ddd; }
.data-table td { padding:.65rem 1rem; border-bottom:1px solid #eee; color:var(--black); vertical-align:middle; }
.data-table tr:hover td { background:rgba(45,90,61,.02); }

.status-badge { display:inline-block; padding:.2rem .6rem; font-size:.7rem; font-weight:700; border-radius:2px; }
.status-published { background:var(--cardinal); color:#fff; }
.status-draft { background:var(--mid-gray); color:#fff; }
.status-pending { background:var(--gold); color:#fff; }
.status-active { background:var(--cardinal); color:#fff; }
.status-present { background:var(--cardinal); color:#fff; }
.status-absent { background:#c0392b; color:#fff; }
.status-late { background:#e67e22; color:#fff; }
.status-makeup { background:#2980b9; color:#fff; }

/* Quick links grid */
.quick-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
.quick-link { background:var(--white); border:1px solid #e8e8e8; padding:1.5rem; text-decoration:none; color:var(--black); transition:box-shadow .2s; display:flex; align-items:center; gap:1rem; }
.quick-link:hover { box-shadow:0 4px 12px rgba(0,0,0,.08); }
.quick-link-icon { font-size:1.8rem; }
.quick-link-label { font-weight:700; font-size:.92rem; }

/* Chat */
.chat-layout { display:flex; height:calc(100vh - 120px); background:var(--white); }
.chat-sidebar { width:240px; border-right:1px solid #ddd; overflow-y:auto; }
.chat-channel { padding:.8rem 1rem; border-bottom:1px solid #eee; cursor:pointer; font-size:.85rem; color:var(--dark-gray); }
.chat-channel:hover { background:var(--light-bg); }
.chat-channel.active { background:rgba(45,90,61,.08); color:var(--cardinal); font-weight:700; border-left:3px solid var(--cardinal); }
.chat-channel .unread-badge { background:var(--cardinal); color:#fff; font-size:.65rem; padding:.1rem .4rem; border-radius:8px; margin-left:.5rem; }

.chat-main { flex:1; display:flex; flex-direction:column; }
.chat-header { padding:1rem 1.5rem; border-bottom:1px solid #ddd; font-weight:700; }
.chat-messages { flex:1; overflow-y:auto; padding:1rem 1.5rem; }
.chat-message { margin-bottom:1rem; }
.chat-message-header { font-size:.78rem; color:var(--mid-gray); margin-bottom:.2rem; }
.chat-message-header strong { color:var(--black); }
.chat-message-body { font-size:.9rem; line-height:1.6; }
.chat-input-bar { border-top:1px solid #ddd; padding:1rem 1.5rem; display:flex; gap:.8rem; }
.chat-input { flex:1; border:1px solid #ddd; padding:.6rem 1rem; font-size:.88rem; font-family:var(--font-sans); resize:none; }
.chat-input:focus { outline:none; border-color:var(--cardinal); }

/* Calendar */
.calendar { background:var(--white); }
.calendar-header { display:flex; justify-content:space-between; align-items:center; padding:1rem; }
.calendar-header h3 { font-family:var(--font-serif); font-size:1.1rem; }
.calendar-grid { display:grid; grid-template-columns:repeat(7,1fr); }
.calendar-day-header { text-align:center; font-size:.75rem; font-weight:700; color:var(--mid-gray); padding:.5rem; }
.calendar-day { min-height:80px; border:1px solid #eee; padding:.3rem; font-size:.75rem; }
.calendar-day.today { background:rgba(45,90,61,.05); }
.calendar-day .day-num { font-weight:700; margin-bottom:.2rem; }
.calendar-day .day-event { background:var(--cardinal); color:#fff; padding:.1rem .3rem; font-size:.65rem; margin-bottom:.1rem; border-radius:1px; }

/* Tab navigation */
.tab-nav { display:flex; gap:0; border-bottom:2px solid #ddd; margin-bottom:2rem; }
.tab-nav a { padding:.8rem 1.5rem; text-decoration:none; color:var(--mid-gray); font-size:.88rem; font-weight:500; border-bottom:2px solid transparent; margin-bottom:-2px; transition:all .2s; }
.tab-nav a:hover { color:var(--cardinal); }
.tab-nav a.active { color:var(--cardinal); border-bottom-color:var(--cardinal); font-weight:700; }

/* =============================================================
   Responsive
   ============================================================= */
@media (max-width:960px) {
  .nav-utility-links { display:none; }
  .hamburger { display:block; }
  .nav-main-links { display:none; }
  .card-grid { grid-template-columns:1fr 1fr; }
  .pricing-grid { grid-template-columns:1fr; }
  .fest-roles { grid-template-columns:1fr 1fr; }

  .portal-sidebar { transform:translateX(-100%); }
  .portal-sidebar.is-open { transform:translateX(0); }
  .portal-main { margin-left:0; }
  .portal-menu-toggle { display:block; }
  .chat-sidebar { width:180px; }
}

@media (max-width:680px) {
  .card-grid,.card-grid-2 { grid-template-columns:1fr; }
  .fest-roles { grid-template-columns:1fr; }
  .hero-cta-row { flex-direction:column; align-items:center; }
  .quick-grid { grid-template-columns:1fr; }
  .stat-grid { grid-template-columns:1fr 1fr; }
  .chat-layout { flex-direction:column; }
  .chat-sidebar { width:100%; max-height:200px; border-right:none; border-bottom:1px solid #ddd; }
}

@media (min-width:961px) {
  .mobile-menu { display:none !important; }
}
