body {
    padding-bottom: 144px;
    background:
        radial-gradient(circle at top left, rgba(247, 201, 72, .18), transparent 28rem),
        linear-gradient(180deg, #fbfcff 0%, var(--page) 42%, #eef3fb 100%);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 20;
    background: rgba(255, 255, 255, .9);
    border-bottom: 1px solid rgba(220, 227, 238, .82);
    backdrop-filter: blur(18px);
}
.header-content {
    min-height: 68px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}
.logo {
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
    line-height: 1;
    letter-spacing: 0;
}
.logo span { color: var(--muted); font-size: 12px; }
.logo strong { color: var(--ink); font-size: 22px; }
.logo small { margin-top: 4px; color: var(--ve-red); font-weight: 900; }
.desktop-nav { display: none; gap: 6px; flex-wrap: wrap; justify-content: flex-end; font-size: 13px; font-weight: 850; }
.desktop-nav a {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    padding: 9px 11px;
    border-radius: var(--radius);
    color: #354155;
}
.desktop-nav a:hover { background: var(--surface-2); color: var(--ink); }
.desktop-nav a.is-active { background: var(--ink); color: #fff; box-shadow: var(--shadow-sm); }
.desktop-nav a.nav-cta { background: rgba(214, 69, 69, .1); color: var(--danger); }
.desktop-nav a.nav-cta:hover, .desktop-nav a.nav-cta.is-active { background: var(--ve-red); color: #fff; }
.desktop-nav a.nav-donate { background: rgba(247, 201, 72, .25); color: #5d4300; }
.desktop-nav a.nav-donate:hover, .desktop-nav a.nav-donate.is-active { background: var(--ve-yellow); color: #17120a; }

.hero {
    position: relative;
    overflow: hidden;
    color: #fff;
    padding: 58px 0 46px;
    background:
        linear-gradient(135deg, rgba(18, 23, 34, .92), rgba(31, 95, 191, .82)),
        url('../img/hero.jpg');
    background-size: cover;
    background-position: center;
}
.hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 5px;
    background: linear-gradient(90deg, var(--ve-yellow) 0 33%, var(--ve-blue) 33% 66%, var(--ve-red) 66% 100%);
}
.hero .container { position: relative; z-index: 1; }
.hero-date {
    display: inline-flex;
    min-height: 34px;
    align-items: center;
    margin: 0 0 16px;
    padding: 7px 10px;
    border: 1px solid rgba(255, 255, 255, .28);
    border-radius: var(--radius);
    color: #fff4bd;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}
.hero h1 { max-width: 840px; margin: 0 0 18px; color: #fff; font-size: clamp(40px, 12vw, 72px); line-height: .98; letter-spacing: 0; }
.hero p { max-width: 700px; margin: 0 0 18px; color: rgba(255, 255, 255, .88); font-size: 17px; }
.hero-actions { display: grid; gap: 12px; margin-top: 24px; }

.ops-hero {
    position: relative;
    overflow: hidden;
    padding: 26px 0 18px;
    color: #fff;
    background:
        radial-gradient(circle at 88% 8%, rgba(247, 201, 72, .28), transparent 17rem),
        radial-gradient(circle at 0% 38%, rgba(214, 69, 69, .22), transparent 18rem),
        linear-gradient(155deg, #07111f 0%, #12275a 54%, #1f5fbf 100%);
}
.ops-hero::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 6px;
    background: linear-gradient(90deg, var(--ve-yellow), var(--ve-blue), var(--ve-red));
}
.ops-shell { position: relative; z-index: 1; display: grid; gap: 18px; }
.ops-hero-main { display: grid; gap: 14px; }
.ops-kicker {
    margin: 0;
    color: var(--ve-yellow);
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.ops-hero h1 {
    max-width: 900px;
    margin: 0;
    color: #fff;
    font-size: clamp(42px, 14vw, 84px);
    line-height: .96;
    letter-spacing: 0;
}
.ops-hero p { max-width: 760px; margin: 0; color: rgba(255,255,255,.86); font-size: 17px; }
.ops-hero-actions { display: grid; gap: 10px; }
.ops-hero-actions .btn { width: 100%; min-height: 52px; }
.ops-day-card {
    display: grid;
    gap: 4px;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 22px;
    background: rgba(255,255,255,.12);
    box-shadow: 0 24px 60px rgba(0,0,0,.22);
    backdrop-filter: blur(16px);
}
.ops-day-card span, .ops-day-card small { color: rgba(255,255,255,.78); font-weight: 900; }
.ops-day-card strong { color: #fff; font-size: clamp(54px, 22vw, 96px); line-height: .9; }
.ops-quick-strip { position: sticky; top: 68px; z-index: 19; padding: 10px 0; background: rgba(248,250,252,.88); border-bottom: 1px solid var(--border); backdrop-filter: blur(16px); }
.ops-quick-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.ops-quick-grid a {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: #fff;
    color: var(--ink);
    font-size: 12px;
    font-weight: 950;
    box-shadow: var(--shadow-sm);
}
.ops-section-tight { padding-top: 22px; padding-bottom: 0; }
.ops-stat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.ops-stat {
    display: grid;
    gap: 4px;
    min-height: 124px;
    align-content: end;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}
.ops-stat:nth-child(1) { border-top: 5px solid var(--ve-yellow); }
.ops-stat:nth-child(2) { border-top: 5px solid var(--ve-red); }
.ops-stat:nth-child(3) { border-top: 5px solid var(--ve-blue); }
.ops-stat:nth-child(4) { border-top: 5px solid #22c55e; }
.ops-stat:nth-child(5) { border-top: 5px solid #8b5cf6; }
.ops-stat:nth-child(6) { border-top: 5px solid #0ea5a4; }
.ops-stat span, .ops-stat small { color: var(--muted); font-size: 12px; font-weight: 900; }
.ops-stat strong { color: var(--ink); font-size: 34px; line-height: 1; }
.ops-dashboard-grid, .ops-map-news-grid, .ops-help-grid { display: grid; gap: 16px; }
.ops-panel, .ops-help-card {
    overflow: hidden;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 24px;
    background: rgba(255,255,255,.92);
    box-shadow: var(--shadow-sm);
}
.ops-panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.ops-panel-head h2 { margin: 3px 0 0; color: var(--ink); font-size: 24px; line-height: 1.05; }
.ops-panel-head a { color: var(--ve-blue); font-size: 13px; font-weight: 950; }
.ops-diary-list, .ops-card-list, .ops-mini-timeline, .ops-zone-list { display: grid; gap: 10px; }
.ops-diary-item, .ops-content-card, .ops-timeline-item, .ops-zone-item, .ops-help-link {
    display: grid;
    gap: 4px;
    padding: 13px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: var(--surface);
}
.ops-diary-item:hover, .ops-content-card:hover, .ops-timeline-item:hover, .ops-zone-item:hover, .ops-help-link:hover { background: var(--surface-2); }
.ops-diary-item span, .ops-content-card span, .ops-timeline-item span, .ops-zone-item span, .ops-help-link span { color: var(--muted); font-size: 12px; font-weight: 900; }
.ops-diary-item strong, .ops-content-card strong, .ops-timeline-item strong, .ops-zone-item strong, .ops-help-link strong { color: var(--ink); line-height: 1.2; }
.ops-diary-item small, .ops-content-card small, .ops-timeline-item small, .ops-zone-item small { color: var(--muted); font-weight: 750; }
.ops-content-card.danger { border-left: 5px solid var(--ve-red); }
.ops-content-card.event { border-left: 5px solid var(--ve-blue); }
.ops-timeline-item { position: relative; padding-left: 22px; }
.ops-timeline-item::before {
    content: "";
    position: absolute;
    left: 9px;
    top: 18px;
    bottom: 18px;
    width: 4px;
    border-radius: 999px;
    background: linear-gradient(180deg, var(--ve-yellow), var(--ve-blue), var(--ve-red));
}
.ops-map-panel { background: linear-gradient(180deg, #fff 0%, #f4f7fb 100%); }
.ops-css-map {
    position: relative;
    min-height: 230px;
    display: grid;
    place-items: center;
    margin-bottom: 14px;
    border-radius: 22px;
    background:
        linear-gradient(135deg, rgba(31,95,191,.08), rgba(247,201,72,.12)),
        #eef4ff;
    overflow: hidden;
}
.ops-map-core {
    position: relative;
    z-index: 2;
    width: 112px;
    height: 112px;
    display: grid;
    place-items: center;
    border-radius: 34px 46px 30px 42px;
    background: linear-gradient(135deg, var(--ve-yellow), var(--ve-blue) 52%, var(--ve-red));
    color: #fff;
    font-size: 34px;
    font-weight: 950;
    box-shadow: 0 22px 50px rgba(31,95,191,.28);
}
.ops-map-ring { position: absolute; border: 1px solid rgba(31,95,191,.2); border-radius: 999px; }
.ops-map-ring-a { width: 180px; height: 180px; }
.ops-map-ring-b { width: 250px; height: 250px; }
.ops-map-ring-c { width: 330px; height: 330px; }
.ops-zone-item { grid-template-columns: 1fr auto; align-items: center; }
.ops-zone-item span { grid-column: 1; }
.ops-zone-item small { grid-row: 1 / span 2; grid-column: 2; color: var(--ve-blue); font-weight: 950; }
.ops-help-card.primary { color: #fff; background: linear-gradient(145deg, var(--ink), #1f5fbf); border-color: rgba(255,255,255,.12); }
.ops-help-card.primary h2, .ops-help-card.primary h3 { color: #fff; }
.ops-help-card.primary p { color: rgba(255,255,255,.82); }
.ops-help-card h2 { margin: 6px 0 10px; color: var(--ink); font-size: 30px; line-height: 1.05; }
.ops-help-card h3 { margin-top: 0; color: var(--ink); }

.feature-card { background: var(--ink); color: #fff; border-color: rgba(255,255,255,.12); box-shadow: var(--shadow-md); }
.feature-card h2, .feature-card h3 { color: #fff; }
.feature-card p { color: #d8deea; }
.stat-card:nth-child(1) { --accent: var(--ve-yellow); }
.stat-card:nth-child(2) { --accent: var(--ve-blue); }
.stat-card:nth-child(3) { --accent: var(--ve-red); }
.stat-card:nth-child(4) { --accent: #2fb36d; }
.stat-card:nth-child(5) { --accent: #7c5cff; }
.stat-card:nth-child(6) { --accent: #0ea5a4; }

.video-feed-hero {
    padding: 46px 0 30px;
    color: #fff;
    border-bottom: 5px solid var(--ve-yellow);
    background: linear-gradient(135deg, var(--ink), #1b4f93);
}
.video-feed-hero h1 { margin: 0 0 12px; color: #fff; font-size: clamp(40px, 11vw, 64px); line-height: 1; }
.video-feed-hero p { max-width: 680px; margin: 0; color: #dbe4f2; }
.video-feed-actions { display: grid; gap: 12px; margin-top: 24px; }
.video-feed-section { padding-top: 22px; }
.video-feed-layout { display: grid; gap: 18px; }
.video-feed-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    box-shadow: var(--shadow-sm);
}
.video-feed-panel h2 { margin: 0 0 14px; color: var(--ink); font-size: 20px; }
.video-filter-form { display: grid; gap: 12px; }
.video-feed-list { display: grid; gap: 22px; max-width: 620px; width: 100%; margin: 0 auto; }
.video-feed-card {
    overflow: hidden;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
    scroll-margin-top: 86px;
}
.video-frame { position: relative; width: 100%; aspect-ratio: 9 / 16; background: #0b1020; overflow: hidden; }
.video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-placeholder {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 10px;
    padding: 22px;
    color: #fff;
    background: linear-gradient(150deg, rgba(31, 95, 191, .92), rgba(18, 23, 34, .95));
}
.video-placeholder span { align-self: flex-start; padding: 7px 10px; border-radius: 999px; background: rgba(255,255,255,.14); font-weight: 900; font-size: 12px; }
.video-placeholder strong { font-size: 28px; line-height: 1.05; }
.video-placeholder small { color: #dbe4f2; word-break: break-word; }
.video-feed-body { display: grid; gap: 12px; padding: 18px; }
.video-feed-body h2 { margin: 0; color: var(--ink); font-size: 24px; line-height: 1.15; }
.video-feed-body p { margin: 0; }
.video-meta-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.video-card-actions { display: grid; gap: 10px; margin-top: 2px; }
.video-action { background: var(--surface); color: var(--ink); border-color: var(--border); }
.video-action:hover { background: var(--surface-2); }
.video-action.is-active { background: var(--ve-blue); color: #fff; border-color: var(--ve-blue); }
.video-empty-state { max-width: 620px; margin: 0 auto; width: 100%; }

.floating-report {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: 84px;
    z-index: 31;
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 18px;
    border-radius: var(--radius);
    background: var(--ve-red);
    color: #fff;
    font-weight: 900;
    box-shadow: 0 16px 34px rgba(214, 69, 69, .28);
}
.floating-report:hover { background: #be353c; color: #fff; }
.mobile-nav {
    position: fixed;
    bottom: 10px;
    left: 10px;
    right: 10px;
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    overflow: hidden;
    background: rgba(255,255,255,.96);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    backdrop-filter: blur(14px);
}
.mobile-nav a {
    min-height: 58px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 11px 2px;
    color: #364154;
    font-size: 10px;
    font-weight: 900;
    text-align: center;
}
.mobile-nav a:hover { background: var(--surface-2); color: var(--ink); }
.mobile-nav a.is-active { background: var(--ink); color: #fff; }

.site-footer { margin-top: 40px; padding: 34px 0 154px; background: #111827; color: #fff; }
.site-footer .container { display: grid; gap: 8px; }
.site-footer p { margin: 0; }
.site-footer .small { max-width: 760px; color: #cbd5e1; font-size: 14px; }
.site-footer a { color: #fff; font-weight: 850; }

@media (max-width: 767px) {
    .section-head { display: grid; }
}
@media (min-width: 640px) {
    .hero-actions, .video-feed-actions, .ops-hero-actions { display: flex; flex-wrap: wrap; }
    .ops-hero-actions .btn { width: auto; }
    .ops-quick-grid { grid-template-columns: repeat(6, 1fr); }
    .ops-stat-grid { grid-template-columns: repeat(3, 1fr); }
    .video-card-actions { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 768px) {
    body { padding-bottom: 0; }
    .desktop-nav { display: flex; }
    .floating-report { left: auto; right: 22px; bottom: 22px; min-width: 248px; }
    .mobile-nav { display: none; }
    .site-footer { padding-bottom: 34px; }
    .hero { padding: 96px 0 76px; }
    .hero p { font-size: 21px; }
    .ops-hero { padding: 70px 0 54px; }
    .ops-shell { grid-template-columns: minmax(0, 1fr) 260px; align-items: end; }
    .ops-dashboard-grid, .ops-map-news-grid { grid-template-columns: minmax(0, 1.08fr) minmax(0, .92fr); }
    .ops-help-grid { grid-template-columns: minmax(0, 1.2fr) minmax(0, .9fr) minmax(0, .9fr); }
    .ops-stat-grid { grid-template-columns: repeat(6, 1fr); }
    .ops-stat { min-height: 150px; }
    .video-feed-hero { padding: 70px 0 48px; }
    .video-feed-layout { grid-template-columns: 280px minmax(0, 1fr); align-items: start; }
    .video-feed-panel { position: sticky; top: 88px; }
}
@media (min-width: 1120px) {
    .ops-hero h1 { font-size: 86px; }
    .ops-panel, .ops-help-card { padding: 22px; }
}