:root {
    --color-primary-blue: #0D47A1;
    --color-fire-red: #C62828;
    --color-gold: #FFC107;
    --color-bg: #F5F7FA;
    --color-white: #FFFFFF;
    --color-text: #1F2937;
    --color-muted: #6B7280;
    --color-border: #E5E7EB;
    --font-cn: "Noto Sans SC", sans-serif;
    --font-en: "Inter", sans-serif;
    --font-kh: "Noto Sans Khmer", sans-serif;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
    --shadow-md: 0 10px 24px rgba(15, 23, 42, 0.10);
    --shadow-lg: 0 24px 56px rgba(15, 23, 42, 0.16);
    --container: 1440px;
    --container-narrow: 1180px;
    --space-xs: 8px;
    --space-sm: 12px;
    --space-md: 20px;
    --space-lg: 32px;
    --space-xl: 56px;
    --space-2xl: 96px;
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--color-text); background: var(--color-bg); font-family: var(--font-en); line-height: 1.65; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }
body.is-menu-open { overflow: hidden; }
a { color: var(--color-primary-blue); text-decoration: none; transition: color .18s ease, background-color .18s ease, border-color .18s ease, transform .18s ease; }
a:hover, a:focus-visible { color: var(--color-fire-red); }
img { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; }
.container, .site-header__inner, .site-footer__inner, .site-footer__bottom, .site-main > section, .site-main > article, .content-list, .archive-header, .search-header, .error-404 { width: min(100% - 48px, var(--container)); margin-inline: auto; }
.container-narrow { width: min(100% - 48px, var(--container-narrow)); margin-inline: auto; }
.site-main { min-height: 52vh; padding: calc(80px + var(--space-xl)) 0 var(--space-2xl); }
.site-main > section, .site-main > article { margin-bottom: var(--space-xl); }
.screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.screen-reader-text:focus { z-index: 100000; width: auto; height: auto; clip: auto; top: var(--space-sm); left: var(--space-sm); padding: var(--space-sm) var(--space-md); color: var(--color-white); background: var(--color-primary-blue); border-radius: var(--radius-sm); }
.site-header { position: sticky; top: 0; z-index: 1000; min-height: 80px; color: var(--color-white); background: rgba(13, 71, 161, .9); border-bottom: 1px solid rgba(255,255,255,.16); box-shadow: var(--shadow-sm); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); transition: min-height .2s ease, box-shadow .2s ease, background-color .2s ease; }
body.is-scrolled .site-header, .site-header.is-scrolled { min-height: 64px; background: rgba(13, 71, 161, .97); box-shadow: var(--shadow-md); }
.site-header__inner { min-height: inherit; display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: var(--space-lg); }
.site-branding { display: flex; align-items: center; gap: var(--space-sm); min-width: 300px; }
.site-logo-text { flex: 0 0 auto; display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; color: var(--color-primary-blue); background: var(--color-white); border: 2px solid rgba(255,255,255,.5); border-radius: 50%; font-size: 15px; font-weight: 900; letter-spacing: 0; box-shadow: var(--shadow-sm); }
.site-logo-text:hover, .site-logo-text:focus-visible { color: var(--color-fire-red); background: var(--color-white); }
.custom-logo { max-height: 52px; width: auto; }
.site-branding__text { min-width: 0; }
.site-title { display: inline-flex; align-items: center; color: var(--color-white); font-size: 20px; font-weight: 850; letter-spacing: 0; line-height: 1.18; }
.site-title:hover, .site-title:focus-visible { color: var(--color-gold); }
.site-title-cn { margin: 4px 0 0; color: rgba(255,255,255,.82); font-family: var(--font-cn); font-size: 14px; line-height: 1.3; }
.primary-navigation { justify-self: center; min-width: 0; }
.primary-navigation ul { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 4px; margin: 0; padding: 0; list-style: none; }
.primary-navigation a { display: inline-flex; align-items: center; min-height: 40px; padding: 0 10px; color: rgba(255,255,255,.94); border-radius: var(--radius-sm); font-size: 14px; font-weight: 700; white-space: nowrap; }
.primary-navigation a:hover, .primary-navigation a:focus-visible, .primary-navigation .current-menu-item > a { color: var(--color-white); background: rgba(255,255,255,.14); }
.site-header__tools { display: flex; align-items: center; justify-content: flex-end; gap: var(--space-sm); }
.language-switcher { display: inline-flex; align-items: center; gap: 6px; }
.language-switcher a, .header-search-link { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 0 var(--space-sm); color: var(--color-white); border: 1px solid rgba(255,255,255,.24); border-radius: var(--radius-sm); background: rgba(255,255,255,.08); font-size: 13px; font-weight: 800; white-space: nowrap; }
.language-switcher a:hover, .header-search-link:hover, .language-switcher a:focus-visible, .header-search-link:focus-visible { color: var(--color-primary-blue); background: var(--color-white); }
.menu-toggle { display: none; width: 44px; height: 44px; align-items: center; justify-content: center; color: var(--color-white); background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.24); border-radius: var(--radius-sm); cursor: pointer; }
.menu-toggle__bar { position: relative; width: 20px; height: 2px; background: currentColor; border-radius: 999px; transition: background-color .18s ease; }
.menu-toggle__bar::before, .menu-toggle__bar::after { content: ""; position: absolute; left: 0; width: 20px; height: 2px; background: currentColor; border-radius: 999px; transition: transform .18s ease, top .18s ease; }
.menu-toggle__bar::before { top: -7px; }
.menu-toggle__bar::after { top: 7px; }
body.is-menu-open .menu-toggle__bar { background: transparent; }
body.is-menu-open .menu-toggle__bar::before { top: 0; transform: rotate(45deg); }
body.is-menu-open .menu-toggle__bar::after { top: 0; transform: rotate(-45deg); }
.site-footer { color: rgba(255,255,255,.86); background: #08265A; }
.site-footer__inner { display: grid; grid-template-columns: 1.35fr .85fr 1fr; gap: var(--space-xl); padding: var(--space-xl) 0; }
.site-footer h2, .site-footer h3 { margin: 0 0 var(--space-md); color: var(--color-white); line-height: 1.35; }
.site-footer h2 { font-size: 22px; }
.site-footer h3 { font-size: 18px; }
.site-footer p { margin: 0 0 var(--space-sm); }
.site-footer__cn { color: rgba(255,255,255,.84); font-family: var(--font-cn); font-weight: 700; }
.site-footer ul { margin: 0; padding: 0; list-style: none; }
.site-footer li + li { margin-top: var(--space-xs); }
.site-footer a { color: rgba(255,255,255,.86); }
.site-footer a:hover, .site-footer a:focus-visible { color: var(--color-gold); }
.footer-menu { margin: 0; padding: 0; list-style: none; }
.footer-contact-list { color: rgba(255,255,255,.86); }
.site-footer__bottom { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding: var(--space-md) 0; color: rgba(255,255,255,.72); border-top: 1px solid rgba(255,255,255,.14); font-size: 14px; }
.site-footer__bottom p { margin: 0; }
.footer-menu--legal { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.back-to-top { position: fixed !important; right: var(--space-md) !important; left: auto !important; bottom: var(--space-md) !important; z-index: 900; display: inline-flex; align-items: center; justify-content: center; width: 46px !important; min-width: 46px; height: 46px !important; min-height: 46px; padding: 0; color: var(--color-white); background: var(--color-fire-red); border: 0; border-radius: 50%; box-shadow: var(--shadow-md); cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(8px); transition: opacity .18s ease, transform .18s ease, background-color .18s ease; }
.back-to-top.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.back-to-top:hover, .back-to-top:focus-visible { background: #A71F1F; }
.btn { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0 var(--space-md); border: 1px solid transparent; border-radius: var(--radius-sm); font-weight: 750; line-height: 1; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease, color .18s ease; }
.btn:hover, .btn:focus-visible { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.btn-primary { color: var(--color-white); background: var(--color-fire-red); border-color: var(--color-fire-red); }
.btn-primary:hover, .btn-primary:focus-visible { color: var(--color-white); background: #A71F1F; border-color: #A71F1F; }
.btn-outline { color: var(--color-primary-blue); background: transparent; border-color: var(--color-primary-blue); }
.btn-outline:hover, .btn-outline:focus-visible { color: var(--color-white); background: var(--color-primary-blue); }
.card, .news-card, .stat-card, .gallery-card, .video-card { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); overflow: hidden; }
.card { padding: var(--space-lg); }
.section-title { margin: 0 0 var(--space-lg); color: var(--color-text); font-size: clamp(28px, 3vw, 44px); font-weight: 850; line-height: 1.15; }
.section-title::after { content: ""; display: block; width: 72px; height: 4px; margin-top: var(--space-sm); background: var(--color-fire-red); border-radius: 999px; }
.badge { display: inline-flex; align-items: center; min-height: 28px; padding: 0 var(--space-sm); color: var(--color-primary-blue); background: rgba(13,71,161,.08); border: 1px solid rgba(13,71,161,.16); border-radius: 999px; font-size: 13px; font-weight: 750; }
.news-card, .gallery-card, .video-card { transition: transform .18s ease, box-shadow .18s ease; }
.news-card:hover, .gallery-card:hover, .video-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.notice-list { margin: 0; padding: 0; list-style: none; border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-white); overflow: hidden; }
.notice-list > li { padding: var(--space-md); border-bottom: 1px solid var(--color-border); }
.notice-list > li:last-child { border-bottom: 0; }
.stat-card { padding: var(--space-lg); text-align: center; }
.stat-card strong { display: block; color: var(--color-primary-blue); font-size: clamp(32px, 4vw, 56px); line-height: 1; }
.gallery-card img, .video-card img, .news-card img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; }
@media (max-width: 1280px) { .site-header__inner { gap: var(--space-md); } .site-branding { min-width: 260px; } .primary-navigation a { padding-inline: 8px; font-size: 13px; } }
@media (max-width: 1024px) { .site-header__inner { display: flex; } .menu-toggle { display: inline-flex; } .primary-navigation { position: fixed; top: 80px; left: 0; right: 0; display: none; padding: var(--space-md) 24px var(--space-lg); background: rgba(13,71,161,.98); border-top: 1px solid rgba(255,255,255,.14); box-shadow: var(--shadow-lg); } body.is-scrolled .primary-navigation { top: 64px; } body.is-menu-open .primary-navigation { display: block; } .primary-navigation ul { display: grid; justify-content: stretch; gap: var(--space-xs); } .primary-navigation a { width: 100%; justify-content: flex-start; min-height: 46px; padding-inline: var(--space-md); font-size: 15px; } .site-footer__inner { grid-template-columns: 1fr 1fr; } .site-footer__column--agency { grid-column: 1 / -1; } }
@media (max-width: 768px) { .container, .container-narrow, .site-header__inner, .site-footer__inner, .site-footer__bottom, .site-main > section, .site-main > article, .content-list, .archive-header, .search-header, .error-404 { width: min(100% - 32px, var(--container)); } .site-header { min-height: 72px; } body.is-scrolled .site-header, .site-header.is-scrolled { min-height: 64px; } .primary-navigation { top: 72px; } .site-main { padding-top: calc(72px + var(--space-lg)); padding-bottom: var(--space-xl); } .site-main > section, .site-main > article { margin-bottom: var(--space-lg); } .site-logo-text { width: 48px; height: 48px; font-size: 13px; } .site-title { font-size: 16px; } .site-title-cn { font-size: 12px; } .language-switcher a { min-height: 34px; padding-inline: 8px; } .header-search-link { min-width: 40px; padding-inline: var(--space-xs); } .site-footer__inner { grid-template-columns: 1fr; gap: var(--space-lg); padding: var(--space-lg) 0; } .site-footer__bottom { display: block; } .footer-menu--legal { margin-top: var(--space-sm); } .card, .stat-card { padding: var(--space-md); } .news-card, .gallery-card, .video-card, .stat-card, .card { width: 100%; } }
@media (max-width: 480px) { .container, .container-narrow, .site-header__inner, .site-footer__inner, .site-footer__bottom, .site-main > section, .site-main > article, .content-list, .archive-header, .search-header, .error-404 { width: min(100% - 24px, var(--container)); } .site-branding { min-width: 0; gap: 10px; } .site-logo-text { width: 42px; height: 42px; } .site-title { font-size: 14px; } .site-title-cn { display: none; } .language-switcher { display: none; } .header-search-link { display: none; } .section-title { font-size: 26px; } .btn { width: 100%; } }

/* Stage 11: Hero Banner */
.site-main--front { padding-top: 0; padding-bottom: 0; }
.cfcc-hero { position: relative; min-height: 720px; isolation: isolate; overflow: hidden; display: flex; align-items: center; color: var(--color-white); background: radial-gradient(circle at 78% 16%, rgba(255, 193, 7, .26), transparent 28%), radial-gradient(circle at 12% 82%, rgba(198, 40, 40, .28), transparent 34%), linear-gradient(135deg, #082E67 0%, #0D47A1 45%, #071A33 100%); }
.cfcc-hero::before { content: ""; position: absolute; inset: 0; z-index: -3; background: linear-gradient(115deg, rgba(5, 18, 38, .84), rgba(13, 71, 161, .58) 48%, rgba(198, 40, 40, .32)); }
.cfcc-hero::after { content: ""; position: absolute; inset: auto -10% -28% 38%; z-index: -2; height: 54%; background: linear-gradient(90deg, rgba(255, 193, 7, .18), rgba(198, 40, 40, .22)); transform: skewY(-8deg); filter: blur(1px); }
.cfcc-hero__overlay { position: absolute; inset: 0; z-index: -1; background-image: linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px); background-size: 72px 72px; mask-image: linear-gradient(90deg, rgba(0,0,0,.72), transparent 78%); }
.cfcc-hero__grid span { position: absolute; z-index: -1; border: 1px solid rgba(255,255,255,.14); border-radius: 999px; }
.cfcc-hero__grid span:nth-child(1) { width: 360px; height: 360px; right: 6%; top: 14%; }
.cfcc-hero__grid span:nth-child(2) { width: 520px; height: 520px; right: -160px; bottom: -180px; }
.cfcc-hero__grid span:nth-child(3) { width: 210px; height: 210px; left: 8%; bottom: 12%; }
.cfcc-hero__container { position: relative; display: grid; grid-template-columns: minmax(0, 1fr) 420px; align-items: end; gap: clamp(32px, 6vw, 96px); width: min(100% - 48px, var(--container)); min-height: 720px; padding: calc(80px + var(--space-xl)) 0 var(--space-xl); }
.cfcc-hero__content { max-width: 780px; align-self: center; animation: cfccFadeUp .72s ease both; }
.cfcc-hero__eyebrow { display: inline-flex; align-items: center; min-height: 34px; margin: 0 0 var(--space-md); padding: 0 var(--space-md); color: #10223F; font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 0; background: var(--color-gold); border-radius: 999px; }
.cfcc-hero__title { max-width: 820px; margin: 0; color: var(--color-white); font-size: clamp(48px, 5.2vw, 78px); line-height: 1.04; font-weight: 800; letter-spacing: 0; }
.cfcc-hero__subtitle { margin: var(--space-md) 0 0; color: rgba(255,255,255,.92); font-size: clamp(24px, 2.3vw, 36px); font-weight: 700; }
.cfcc-hero__text { max-width: 660px; margin: var(--space-md) 0 0; color: rgba(255,255,255,.82); font-size: 19px; line-height: 1.75; }
.cfcc-hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-top: var(--space-lg); animation: cfccFadeUp .72s ease .12s both; }
.cfcc-hero__button { min-height: 52px; padding-inline: 24px; font-weight: 800; }
.cfcc-hero__button--emergency { color: var(--color-white); border-color: rgba(255,255,255,.74); background: rgba(255,255,255,.08); }
.cfcc-hero__button--emergency:hover, .cfcc-hero__button--emergency:focus-visible { color: var(--color-primary-blue); background: var(--color-white); border-color: var(--color-white); }
.cfcc-hero__cards { align-self: end; display: grid; gap: var(--space-sm); padding-bottom: var(--space-md); animation: cfccFadeUp .72s ease .22s both; }
.cfcc-hero-card { position: relative; overflow: hidden; min-height: 104px; padding: var(--space-md); color: var(--color-white); background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); border-radius: var(--radius-md); box-shadow: 0 22px 56px rgba(0,0,0,.18); backdrop-filter: blur(14px); }
.cfcc-hero-card::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 4px; background: var(--color-gold); }
.cfcc-hero-card__mark { display: block; color: var(--color-gold); font-size: 13px; font-weight: 800; }
.cfcc-hero-card h2 { margin: var(--space-xs) 0 0; color: var(--color-white); font-size: 20px; line-height: 1.25; }
@keyframes cfccFadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .cfcc-hero__content, .cfcc-hero__actions, .cfcc-hero__cards { animation: none; } }
@media (max-width: 1280px) { .cfcc-hero__container { grid-template-columns: minmax(0, 1fr) 360px; } }
@media (max-width: 1024px) { .cfcc-hero { min-height: 620px; } .cfcc-hero__container { grid-template-columns: 1fr; align-items: center; min-height: 620px; padding-top: calc(80px + var(--space-lg)); } .cfcc-hero__cards { grid-template-columns: repeat(3, minmax(0, 1fr)); padding-bottom: 0; } .cfcc-hero-card { min-height: 96px; } }
@media (max-width: 768px) { .cfcc-hero { min-height: 560px; text-align: center; } .cfcc-hero__container { width: min(100% - 32px, var(--container)); min-height: 560px; gap: var(--space-lg); padding: calc(72px + var(--space-md)) 0 var(--space-lg); } .cfcc-hero__content { max-width: none; } .cfcc-hero__eyebrow { margin-inline: auto; font-size: 12px; } .cfcc-hero__title { font-size: 38px; } .cfcc-hero__subtitle { font-size: 24px; } .cfcc-hero__text { margin-inline: auto; font-size: 16px; line-height: 1.65; } .cfcc-hero__actions { justify-content: center; } .cfcc-hero__button { width: min(100%, 280px); } .cfcc-hero__cards { grid-template-columns: 1fr; gap: var(--space-xs); } .cfcc-hero-card { min-height: 76px; padding: var(--space-sm) var(--space-md); text-align: left; } .cfcc-hero-card h2 { font-size: 18px; } }
@media (max-width: 480px) { .cfcc-hero__title { font-size: 34px; } .cfcc-hero__subtitle { font-size: 21px; } .cfcc-hero__cards { width: 100%; } }

/* Stage 11: Mobile Hero Height Correction */
@media (max-width: 768px) {
  .cfcc-hero { height: 560px; min-height: 560px; }
  .cfcc-hero__container { min-height: 560px; height: 560px; align-content: center; gap: 12px; padding: calc(72px + 12px) 0 14px; overflow: hidden; }
  .cfcc-hero__eyebrow { min-height: 26px; margin-bottom: 8px; padding: 0 10px; font-size: 10px; }
  .cfcc-hero__title { font-size: 30px; line-height: 1.08; }
  .cfcc-hero__subtitle { margin-top: 8px; font-size: 19px; }
  .cfcc-hero__text { margin-top: 8px; font-size: 14px; line-height: 1.45; }
  .cfcc-hero__actions { gap: 8px; margin-top: 12px; }
  .cfcc-hero__button { width: min(100%, 240px); min-height: 40px; padding-inline: 16px; font-size: 14px; }
  .cfcc-hero__cards { gap: 8px; }
  .cfcc-hero-card { min-height: 48px; padding: 8px 14px; }
  .cfcc-hero-card__mark { font-size: 10px; }
  .cfcc-hero-card h2 { margin-top: 2px; font-size: 15px; }
}
@media (max-width: 480px) {
  .cfcc-hero__title { font-size: 29px; }
  .cfcc-hero__subtitle { font-size: 18px; }
}

/* Stage 12: News Notices */
.cfcc-news-notices { background: var(--color-bg); padding: var(--space-2xl) 0; }
.cfcc-news-notices__inner { display: grid; grid-template-columns: minmax(0, 65fr) minmax(320px, 35fr); gap: var(--space-lg); align-items: start; }
.cfcc-section-heading { margin-bottom: var(--space-md); }
.cfcc-section-heading .badge { margin-bottom: var(--space-xs); }
.cfcc-section-heading h2 { margin: 0; color: var(--color-text); font-size: 32px; line-height: 1.2; }
.cfcc-section-heading p { margin: 8px 0 0; color: var(--color-muted); font-size: 16px; }
.cfcc-news-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.news-card { display: flex; flex-direction: column; min-height: 292px; padding: var(--space-md); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); }
.news-card__meta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-xs); color: var(--color-muted); font-size: 13px; }
.news-card h3 { margin: var(--space-md) 0 var(--space-sm); color: var(--color-text); font-size: 20px; line-height: 1.35; }
.news-card h3 a { color: inherit; }
.news-card p { margin: 0; color: var(--color-muted); line-height: 1.65; }
.news-card__link { margin-top: auto; padding-top: var(--space-md); color: var(--color-primary-blue); font-weight: 800; }
.news-card__link:hover, .news-card__link:focus-visible { color: var(--color-fire-red); }
.cfcc-notices-panel { padding: var(--space-md); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); }
.cfcc-notices-panel__head { display: flex; align-items: start; justify-content: space-between; gap: var(--space-md); margin-bottom: var(--space-sm); }
.cfcc-notices-panel .cfcc-section-heading { margin-bottom: 0; }
.cfcc-notices-panel .cfcc-section-heading h2 { font-size: 28px; }
.cfcc-view-all { flex: 0 0 auto; color: var(--color-primary-blue); font-weight: 800; }
.cfcc-view-all:hover, .cfcc-view-all:focus-visible { color: var(--color-fire-red); }
.notice-list { display: grid; gap: 0; margin: 0; padding: 0; list-style: none; }
.notice-list li { display: grid; gap: 6px; padding: var(--space-md) 0; border-top: 1px solid var(--color-border); }
.notice-list time { color: var(--color-muted); font-size: 13px; }
.notice-list a, .notice-list span { color: var(--color-text); font-weight: 700; line-height: 1.45; }
.notice-list a:hover, .notice-list a:focus-visible { color: var(--color-primary-blue); }
@media (max-width: 1024px) { .cfcc-news-notices__inner { grid-template-columns: 1fr; } .cfcc-news-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 768px) { .cfcc-news-notices { padding: var(--space-xl) 0; } .cfcc-news-grid { grid-template-columns: 1fr; } .cfcc-section-heading h2 { font-size: 26px; } .cfcc-notices-panel__head { align-items: flex-start; } .news-card { min-height: auto; } }
@media (max-width: 480px) { .cfcc-notices-panel__head { display: grid; } .cfcc-view-all { justify-self: start; } }

/* Stage 13: Statistics */
.cfcc-statistics { position: relative; background: linear-gradient(180deg, var(--color-white) 0%, var(--color-bg) 100%); padding: var(--space-2xl) 0; overflow: hidden; }
.cfcc-statistics::before { content: ""; position: absolute; inset: 0 0 auto; height: 6px; background: linear-gradient(90deg, var(--color-primary-blue), var(--color-fire-red), var(--color-gold)); }
.cfcc-statistics__inner { position: relative; }
.cfcc-statistics .section-title { max-width: 760px; margin-bottom: var(--space-lg); }
.cfcc-statistics .section-title h2 { margin: 0; color: var(--color-text); font-size: 34px; line-height: 1.2; }
.cfcc-statistics .section-title p { margin: 8px 0 0; color: var(--color-muted); font-size: 16px; }
.cfcc-statistics__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--space-md); }
.stat-card { position: relative; min-height: 186px; padding: var(--space-lg); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-md); overflow: hidden; }
.stat-card::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 5px; background: var(--color-fire-red); }
.stat-card::after { content: ""; position: absolute; right: -28px; top: -28px; width: 112px; height: 112px; border-radius: 50%; background: rgba(13, 71, 161, .08); }
.stat-card__icon { position: relative; z-index: 1; display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; margin-bottom: var(--space-md); color: var(--color-white); background: var(--color-primary-blue); border-radius: 50%; font-weight: 800; }
.stat-card__number { position: relative; z-index: 1; display: block; color: var(--color-primary-blue); font-size: clamp(38px, 3.8vw, 56px); line-height: 1; font-weight: 800; letter-spacing: 0; }
.stat-card__label { position: relative; z-index: 1; margin: var(--space-sm) 0 0; color: var(--color-text); font-size: 16px; font-weight: 800; line-height: 1.35; }
.stat-card:nth-child(even)::before { background: var(--color-primary-blue); }
.stat-card:nth-child(even) .stat-card__icon { background: var(--color-fire-red); }
@media (max-width: 1024px) { .cfcc-statistics__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 768px) { .cfcc-statistics { padding: var(--space-xl) 0; } .cfcc-statistics .section-title h2 { font-size: 28px; } .stat-card { min-height: 156px; padding: var(--space-md); } .stat-card__number { font-size: 38px; } }
@media (max-width: 480px) { .cfcc-statistics__grid { grid-template-columns: 1fr; } }

/* Stage 14: Leadership Activities */
.cfcc-leadership { background: var(--color-white); padding: var(--space-2xl) 0; }
.cfcc-leadership__head { max-width: 820px; margin-bottom: var(--space-lg); }
.cfcc-leadership__head h2 { margin: 0; color: var(--color-text); font-size: 34px; line-height: 1.2; }
.cfcc-leadership__head p { margin: 8px 0 0; color: var(--color-muted); font-size: 16px; }
.cfcc-leadership__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, 1fr); gap: var(--space-lg); align-items: stretch; }
.leadership-card { display: grid; overflow: hidden; background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-md); }
.leadership-card__media { position: relative; min-height: 210px; background: linear-gradient(135deg, rgba(13,71,161,.92), rgba(13,71,161,.72) 42%, rgba(198,40,40,.72)); overflow: hidden; }
.leadership-card__media::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.14) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.10) 1px, transparent 1px); background-size: 44px 44px; opacity: .55; }
.leadership-card__media::after { content: "CFCC"; position: absolute; right: var(--space-md); bottom: var(--space-md); color: rgba(255,255,255,.72); font-size: 34px; font-weight: 800; letter-spacing: 0; }
.leadership-card__body { display: flex; flex-direction: column; padding: var(--space-lg); }
.leadership-card__date { color: var(--color-fire-red); font-size: 13px; font-weight: 800; }
.leadership-card h3 { margin: var(--space-sm) 0; color: var(--color-text); font-size: 23px; line-height: 1.35; }
.leadership-card h3 a { color: inherit; }
.leadership-card p { margin: 0; color: var(--color-muted); line-height: 1.65; }
.leadership-card__link { margin-top: auto; padding-top: var(--space-md); color: var(--color-primary-blue); font-weight: 800; }
.leadership-card__link:hover, .leadership-card__link:focus-visible { color: var(--color-fire-red); }
.leadership-card--featured { min-height: 100%; }
.leadership-card--featured .leadership-card__media { min-height: 320px; }
.leadership-card--featured h3 { font-size: 28px; }
.cfcc-leadership__side { display: grid; gap: var(--space-md); }
.cfcc-leadership__side .leadership-card { grid-template-columns: 180px minmax(0, 1fr); }
.cfcc-leadership__side .leadership-card__media { min-height: 100%; }
.cfcc-leadership__side .leadership-card__media::after { font-size: 20px; }
.cfcc-leadership__side .leadership-card__body { padding: var(--space-md); }
.cfcc-leadership__side .leadership-card h3 { font-size: 19px; }
@media (max-width: 1024px) { .cfcc-leadership__grid { grid-template-columns: 1fr; } .cfcc-leadership__side { grid-template-columns: repeat(2, minmax(0, 1fr)); } .cfcc-leadership__side .leadership-card { grid-template-columns: 1fr; } .cfcc-leadership__side .leadership-card__media { min-height: 180px; } }
@media (max-width: 768px) { .cfcc-leadership { padding: var(--space-xl) 0; } .cfcc-leadership__head h2 { font-size: 28px; } .cfcc-leadership__side { grid-template-columns: 1fr; } .leadership-card__body { padding: var(--space-md); } .leadership-card--featured .leadership-card__media, .leadership-card__media { min-height: 190px; } .leadership-card--featured h3, .leadership-card h3 { font-size: 20px; } }

/* Stage 15: Gallery Videos */
.cfcc-media-section { background: var(--color-bg); padding: var(--space-2xl) 0; }
.cfcc-media-section--videos { background: var(--color-white); padding-top: 0; }
.cfcc-media-section__head { display: flex; align-items: end; justify-content: space-between; gap: var(--space-md); margin-bottom: var(--space-lg); }
.cfcc-media-section__head .section-title { margin-bottom: 0; }
.cfcc-media-section__head h2 { margin: 0; color: var(--color-text); font-size: 34px; line-height: 1.2; }
.cfcc-media-section__head p { margin: 8px 0 0; color: var(--color-muted); font-size: 16px; }
.cfcc-gallery-grid, .cfcc-video-grid { display: grid; gap: var(--space-md); }
.cfcc-gallery-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cfcc-video-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.gallery-card, .video-card { display: grid; background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); overflow: hidden; transition: transform .18s ease, box-shadow .18s ease; }
.gallery-card:hover, .video-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.gallery-card__media, .video-card__media { position: relative; min-height: 190px; background: linear-gradient(135deg, rgba(13,71,161,.92), rgba(13,71,161,.68) 46%, rgba(198,40,40,.72)); overflow: hidden; }
.gallery-card__media::before, .video-card__media::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.14) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.10) 1px, transparent 1px); background-size: 42px 42px; opacity: .58; }
.gallery-card__media::after { content: "Gallery"; position: absolute; right: var(--space-md); bottom: var(--space-md); color: rgba(255,255,255,.78); font-weight: 800; }
.gallery-card__body, .video-card__body { padding: var(--space-md); }
.gallery-card h3, .video-card h3 { margin: 0 0 var(--space-xs); color: var(--color-text); font-size: 18px; line-height: 1.35; }
.gallery-card time, .video-card time { color: var(--color-muted); font-size: 13px; font-weight: 700; }
.video-card__play { position: absolute; left: 50%; top: 50%; width: 58px; height: 58px; transform: translate(-50%, -50%); border-radius: 50%; background: rgba(255,255,255,.92); box-shadow: var(--shadow-md); }
.video-card__play::before { content: ""; position: absolute; left: 23px; top: 18px; width: 0; height: 0; border-top: 11px solid transparent; border-bottom: 11px solid transparent; border-left: 16px solid var(--color-fire-red); }
.video-card__media::after { content: "Video"; position: absolute; right: var(--space-md); bottom: var(--space-md); color: rgba(255,255,255,.78); font-weight: 800; }
@media (max-width: 1024px) { .cfcc-gallery-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .cfcc-video-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 768px) { .cfcc-media-section { padding: var(--space-xl) 0; } .cfcc-media-section--videos { padding-top: 0; } .cfcc-media-section__head { display: block; } .cfcc-media-section__head h2 { font-size: 28px; } .cfcc-gallery-grid, .cfcc-video-grid { grid-template-columns: 1fr; } .gallery-card__media, .video-card__media { min-height: 180px; } }

/* Stage 16: Emergency Contact */
.cfcc-emergency { position: relative; overflow: hidden; color: var(--color-white); background: linear-gradient(135deg, #071A33 0%, #0D47A1 58%, #08224A 100%); padding: var(--space-2xl) 0; }
.cfcc-emergency::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px); background-size: 56px 56px; opacity: .42; }
.cfcc-emergency::after { content: ""; position: absolute; right: -140px; top: -180px; width: 420px; height: 420px; border-radius: 50%; background: rgba(198,40,40,.28); filter: blur(2px); }
.cfcc-emergency__inner { position: relative; z-index: 1; }
.cfcc-emergency__head { max-width: 820px; margin-bottom: var(--space-lg); }
.cfcc-emergency__head h2 { margin: 0; color: var(--color-white); font-size: 34px; line-height: 1.2; }
.cfcc-emergency__head p { margin: 8px 0 0; color: rgba(255,255,255,.76); font-size: 16px; }
.cfcc-emergency__grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); gap: var(--space-lg); align-items: stretch; }
.cfcc-emergency__hotline, .cfcc-emergency__contact { background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius-sm); box-shadow: 0 24px 70px rgba(0,0,0,.20); backdrop-filter: blur(12px); }
.cfcc-emergency__hotline { position: relative; padding: var(--space-xl); overflow: hidden; }
.cfcc-emergency__hotline::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 7px; background: var(--color-fire-red); }
.cfcc-emergency__label { margin: 0; color: rgba(255,255,255,.82); font-size: 18px; font-weight: 800; text-transform: uppercase; letter-spacing: 0; }
.cfcc-emergency__number { display: block; margin-top: var(--space-sm); color: var(--color-white); font-size: clamp(88px, 11vw, 150px); line-height: .9; font-weight: 900; letter-spacing: 0; text-shadow: 0 12px 34px rgba(198,40,40,.34); }
.cfcc-emergency__desc { max-width: 480px; margin: var(--space-md) 0 0; color: rgba(255,255,255,.80); font-size: 18px; line-height: 1.65; }
.cfcc-emergency__contact { padding: var(--space-xl); }
.cfcc-emergency__contact h3 { margin: 0 0 var(--space-md); color: var(--color-white); font-size: 26px; line-height: 1.25; }
.cfcc-contact-list { display: grid; gap: var(--space-md); margin: 0 0 var(--space-lg); padding: 0; list-style: none; }
.cfcc-contact-list li { display: grid; gap: 4px; color: rgba(255,255,255,.82); }
.cfcc-contact-list strong { color: var(--color-gold); font-size: 13px; text-transform: uppercase; letter-spacing: 0; }
.cfcc-contact-list a { color: var(--color-white); font-weight: 800; }
.cfcc-emergency__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.cfcc-emergency .btn-primary { background: var(--color-fire-red); border-color: var(--color-fire-red); color: var(--color-white); }
.cfcc-emergency .btn-outline { color: var(--color-white); border-color: rgba(255,255,255,.72); background: transparent; }
.cfcc-emergency .btn-outline:hover, .cfcc-emergency .btn-outline:focus-visible { color: var(--color-primary-blue); background: var(--color-white); border-color: var(--color-white); }
@media (max-width: 1024px) { .cfcc-emergency__grid { grid-template-columns: 1fr; } }
@media (max-width: 768px) { .cfcc-emergency { padding: var(--space-xl) 0; } .cfcc-emergency__head h2 { font-size: 28px; } .cfcc-emergency__hotline, .cfcc-emergency__contact { padding: var(--space-lg); } .cfcc-emergency__number { font-size: 92px; } .cfcc-emergency__actions { display: grid; } .cfcc-emergency__actions .btn { width: 100%; } }

/* Stage 17: Homepage QA Optimization */
html, body { max-width: 100%; overflow-x: hidden; }
.site-main--front { overflow-x: clip; }
.site-main--front > section { width: 100%; margin-bottom: 0; }
.site-main--front .section-title .badge, .cfcc-media-section__head .badge, .cfcc-emergency__head .badge, .cfcc-leadership__head .badge { margin-bottom: var(--space-xs); }
.site-main--front .section-title h2, .cfcc-media-section__head h2, .cfcc-emergency__head h2, .cfcc-leadership__head h2 { letter-spacing: 0; font-weight: 800; }
.site-main--front .card, .site-main--front .news-card, .site-main--front .stat-card, .site-main--front .leadership-card, .site-main--front .gallery-card, .site-main--front .video-card, .cfcc-emergency__hotline, .cfcc-emergency__contact { border-radius: var(--radius-sm); }
.site-main--front .btn { min-height: 46px; padding: 0 22px; font-weight: 800; }
.cfcc-hero__button { min-height: 52px; }
.cfcc-hero, .cfcc-emergency, .cfcc-media-section, .cfcc-leadership, .cfcc-statistics, .cfcc-news-notices { max-width: 100%; }
.cfcc-hero__grid, .cfcc-hero__overlay { pointer-events: none; overflow: hidden; }
.cfcc-hero__grid span { max-width: 48vw; max-height: 48vw; }
.cfcc-emergency::after { pointer-events: none; }
.cfcc-news-notices, .cfcc-statistics, .cfcc-leadership, .cfcc-media-section, .cfcc-emergency { padding-block: var(--space-2xl); }
.cfcc-media-section--videos { padding-top: 0; }
.cfcc-gallery-grid, .cfcc-video-grid, .cfcc-statistics__grid, .cfcc-news-grid { align-items: stretch; }
.news-card, .stat-card, .leadership-card, .gallery-card, .video-card { will-change: transform; }
@media (min-width: 1281px) { .cfcc-news-notices__inner, .cfcc-leadership__grid, .cfcc-emergency__grid { gap: var(--space-xl); } }
@media (max-width: 1280px) { .cfcc-hero__grid span:nth-child(2) { right: -80px; } .cfcc-emergency::after { right: -96px; } }
@media (max-width: 1024px) { .cfcc-news-notices, .cfcc-statistics, .cfcc-leadership, .cfcc-media-section, .cfcc-emergency { padding-block: var(--space-xl); } .cfcc-media-section--videos { padding-top: 0; } }
@media (max-width: 768px) { .site-main--front .section-title h2, .cfcc-media-section__head h2, .cfcc-emergency__head h2, .cfcc-leadership__head h2 { font-size: 28px; } .site-main--front .btn { min-height: 44px; } .cfcc-hero__button { min-height: 40px; } .cfcc-news-notices, .cfcc-statistics, .cfcc-leadership, .cfcc-media-section, .cfcc-emergency { padding-block: var(--space-xl); } .cfcc-media-section--videos { padding-top: 0; } }
@media (max-width: 480px) { .cfcc-news-notices, .cfcc-statistics, .cfcc-leadership, .cfcc-media-section, .cfcc-emergency { padding-block: var(--space-lg); } .cfcc-media-section--videos { padding-top: 0; } }

/* Stage 20: Archive Single Templates */
.site-main--inner { overflow-x: clip; }
.inner-hero { color: var(--color-white); background: linear-gradient(135deg, #071A33 0%, #0D47A1 68%, #08224A 100%); padding: calc(80px + var(--space-xl)) 0 var(--space-xl); }
.inner-hero .badge { margin-bottom: var(--space-sm); }
.inner-hero h1 { max-width: 980px; margin: 0; color: var(--color-white); font-size: clamp(36px, 4vw, 58px); line-height: 1.12; font-weight: 800; letter-spacing: 0; }
.inner-hero p { max-width: 760px; margin: var(--space-md) 0 0; color: rgba(255,255,255,.78); font-size: 18px; line-height: 1.65; }
.content-list-section, .content-single-section { background: var(--color-bg); padding: var(--space-2xl) 0; }
.content-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.content-card { display: flex; flex-direction: column; min-height: 260px; padding: var(--space-md); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease; }
.content-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.content-card__meta, .content-single__meta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-xs); color: var(--color-muted); font-size: 13px; }
.content-card__title { margin: var(--space-md) 0 var(--space-sm); font-size: 21px; line-height: 1.35; }
.content-card__title a { color: var(--color-text); }
.content-card__title a:hover, .content-card__title a:focus-visible { color: var(--color-primary-blue); }
.content-card__media { display: block; margin: var(--space-sm) 0; border-radius: var(--radius-sm); overflow: hidden; }
.content-card__media img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; }
.content-card p { margin: 0; color: var(--color-muted); line-height: 1.65; }
.content-card__link { margin-top: auto; padding-top: var(--space-md); color: var(--color-primary-blue); font-weight: 800; }
.content-pagination { margin-top: var(--space-lg); }
.content-pagination .nav-links { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.content-pagination a, .content-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; min-height: 40px; padding: 0 var(--space-sm); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
.content-pagination .current { color: var(--color-white); background: var(--color-primary-blue); border-color: var(--color-primary-blue); }
.empty-state { padding: var(--space-xl); background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); }
.empty-state h2 { margin: 0 0 var(--space-sm); color: var(--color-text); }
.empty-state p { color: var(--color-muted); }
.content-single { background: var(--color-white); border: 1px solid var(--color-border); border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); padding: var(--space-xl); }
.content-single__media { margin: 0 0 var(--space-lg); overflow: hidden; border-radius: var(--radius-sm); }
.content-single__media img { width: 100%; max-height: 520px; object-fit: cover; }
.content-single__body { margin-top: var(--space-lg); color: var(--color-text); font-size: 18px; line-height: 1.8; }
.content-single__body p { margin: 0 0 var(--space-md); }
.content-single__body a { color: var(--color-primary-blue); font-weight: 700; }
.content-single__actions { margin-top: var(--space-lg); }
.content-single__nav { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); margin-top: var(--space-lg); padding-top: var(--space-lg); border-top: 1px solid var(--color-border); }
.content-single__nav div:last-child { text-align: right; }
.content-single__nav a { color: var(--color-primary-blue); font-weight: 800; }
.error-actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-top: var(--space-lg); }
.inner-hero--404 { min-height: 520px; display: flex; align-items: center; }
@media (max-width: 1024px) { .content-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 768px) { .inner-hero { padding: calc(72px + var(--space-lg)) 0 var(--space-lg); } .inner-hero h1 { font-size: 34px; } .inner-hero p { font-size: 16px; } .content-list-section, .content-single-section { padding: var(--space-xl) 0; } .content-card-grid { grid-template-columns: 1fr; } .content-single { padding: var(--space-md); } .content-single__body { font-size: 16px; } .content-single__nav { grid-template-columns: 1fr; } .content-single__nav div:last-child { text-align: left; } .error-actions { display: grid; } .error-actions .btn { width: 100%; } }
