/* ===========================================================================
   UzbekGenerals.uz — TACTICAL HUD / COMMAND CENTER design system
   Graphite base · amber command accent · cyan signal · condensed UPPERCASE.
   Class names are kept stable so all page templates inherit this look.
   ======================================================================== */
* { box-sizing: border-box; margin: 0; padding: 0; }
:root {
    --bg:    #0d1117;   /* graphite base */
    --bg-2:  #11161f;   /* panel */
    --bg-3:  #161d29;   /* raised / inputs */
    --line:  #243042;   /* tactical hairline */
    --line-2:#33445c;
    --amber: #f5a623;   /* command accent */
    --amber-2:#ffc24a;
    --cyan:  #35d0c0;   /* live / signal */
    --red:   #e5484d;   /* alert */
    --text:  #c9d4e0;
    --muted: #74849b;
    --head: "Oswald", "Arial Narrow", sans-serif;
    --body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html { -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--body);
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    /* Faint tactical grid + vignette */
    background-image:
        linear-gradient(rgba(53,208,192,0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(53,208,192,0.035) 1px, transparent 1px),
        radial-gradient(120% 80% at 50% -10%, rgba(245,166,35,0.06), transparent 60%);
    background-size: 44px 44px, 44px 44px, 100% 100%;
}
/* Scanline overlay */
body::after {
    content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 1;
    background: repeating-linear-gradient(to bottom, rgba(0,0,0,0) 0 3px, rgba(0,0,0,0.10) 3px 4px);
    mix-blend-mode: multiply; opacity: .35;
}
.container { max-width: 1140px; margin: 0 auto; padding: 0 22px; width: 100%; position: relative; z-index: 2; }

a { color: var(--amber); text-decoration: none; }
a:hover { color: var(--amber-2); }

h1, h2, h3 { font-family: var(--head); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: #eef3f8; line-height: 1.1; }
h1 { font-size: 34px; }
h2 { font-size: 20px; color: var(--amber); letter-spacing: .08em; margin-bottom: 14px; }
h3 { font-size: 16px; letter-spacing: .05em; margin-bottom: 6px; }
p { color: var(--text); margin-bottom: 10px; }
.muted { color: var(--muted); }

/* ── Header / command bar ─────────────────────────────────────────────── */
.site-header {
    background: linear-gradient(180deg, #0f141d, #0b0f16);
    border-bottom: 1px solid var(--line);
    box-shadow: 0 1px 0 rgba(245,166,35,0.35);   /* amber signal hairline */
    position: sticky; top: 0; z-index: 50;
}
.site-header .container { display: flex; align-items: center; gap: 20px; min-height: 66px; flex-wrap: wrap; }
.logo { display: flex; align-items: center; gap: 12px; }
.logo .mark {
    width: 42px; height: 42px; display: flex; align-items: center; justify-content: center;
    font-family: var(--head); font-weight: 700; font-size: 15px; letter-spacing: .5px;
    color: var(--amber); background: #0b0f16; position: relative;
    clip-path: polygon(0 0, calc(100% - 9px) 0, 100% 9px, 100% 100%, 9px 100%, 0 calc(100% - 9px));
    border: 1px solid var(--amber);
}
.logo .word { font-family: var(--head); font-weight: 700; font-size: 20px; letter-spacing: .06em; color: #eef3f8; text-transform: uppercase; }
.logo .word small { display: block; font-family: var(--body); font-size: 9px; color: var(--muted); font-weight: 500; letter-spacing: .22em; text-transform: uppercase; }

.nav { display: flex; gap: 4px; align-items: center; margin-left: auto; flex-wrap: wrap; }
.nav a {
    font-family: var(--head); font-weight: 500; text-transform: uppercase; letter-spacing: .06em;
    font-size: 13px; color: var(--text); padding: 8px 10px; border-bottom: 2px solid transparent;
}
.nav a:hover { color: #fff; }
.nav a.active { color: var(--amber); border-bottom-color: var(--amber); }
.lang { display: flex; gap: 4px; align-items: center; margin-left: 6px; }
.lang a { font-family: var(--head); font-size: 11px; letter-spacing: .08em; color: var(--muted); padding: 3px 7px; border: 1px solid var(--line); }
.lang a.active { color: #0b0f16; background: var(--amber); border-color: var(--amber); }

/* ── Buttons (angular, chamfered) ─────────────────────────────────────── */
.btn {
    display: inline-block; font-family: var(--head); font-weight: 600; text-transform: uppercase;
    letter-spacing: .08em; font-size: 14px; cursor: pointer;
    background: var(--amber); color: #0b0f16; padding: 11px 22px; border: none;
    clip-path: polygon(9px 0, 100% 0, 100% calc(100% - 9px), calc(100% - 9px) 100%, 0 100%, 0 9px);
    transition: background .15s, box-shadow .15s, transform .05s;
}
.btn:hover { background: var(--amber-2); color: #0b0f16; box-shadow: 0 0 18px rgba(245,166,35,0.35); }
.btn:active { transform: translateY(1px); }
.btn.ghost { background: transparent; color: var(--amber); box-shadow: inset 0 0 0 1px var(--amber); }
.btn.ghost:hover { background: rgba(245,166,35,0.10); box-shadow: inset 0 0 0 1px var(--amber-2), 0 0 14px rgba(245,166,35,0.20); }
.btn.sm { padding: 7px 14px; font-size: 12px; clip-path: polygon(7px 0,100% 0,100% calc(100% - 7px),calc(100% - 7px) 100%,0 100%,0 7px); }

/* ── Layout ───────────────────────────────────────────────────────────── */
main { flex: 1; padding: 34px 0 56px; }
main > .container > h1 { position: relative; padding-left: 16px; margin-bottom: 20px; }
main > .container > h1::before { content: ""; position: absolute; left: 0; top: 4px; bottom: 4px; width: 4px; background: var(--amber); box-shadow: 0 0 12px rgba(245,166,35,0.5); }

.grid { display: grid; gap: 16px; }
.grid.c3 { grid-template-columns: repeat(3, 1fr); }
.grid.c2 { grid-template-columns: repeat(2, 1fr); }

/* HUD panel: hairline border + amber/cyan corner brackets */
.panel {
    background: linear-gradient(180deg, rgba(22,29,41,0.85), rgba(17,22,31,0.85));
    border: 1px solid var(--line);
    padding: 22px; margin-bottom: 20px; position: relative;
}
.panel::before, .panel::after {
    content: ""; position: absolute; width: 16px; height: 16px; pointer-events: none;
}
.panel::before { top: -1px; left: -1px; border-top: 2px solid var(--amber); border-left: 2px solid var(--amber); }
.panel::after  { bottom: -1px; right: -1px; border-bottom: 2px solid var(--cyan); border-right: 2px solid var(--cyan); }

/* ── Hero ─────────────────────────────────────────────────────────────── */
.hero {
    text-align: center; padding: 62px 20px 46px; position: relative;
    border-bottom: 1px solid var(--line);
    background:
        radial-gradient(80% 120% at 50% -20%, rgba(245,166,35,0.10), transparent 60%),
        repeating-linear-gradient(135deg, rgba(245,166,35,0.05) 0 2px, transparent 2px 11px);
}
.hero::before {
    content: "// UZBEKISTAN  \00B7  GENERALS COMMAND  \00B7  ZERO HOUR";
    display: inline-block; font-family: var(--head); letter-spacing: .35em; font-size: 11px;
    color: var(--cyan); margin-bottom: 16px; text-transform: uppercase;
}
.hero .mark-lg {
    width: 96px; height: 96px; margin: 0 auto 20px; display: flex; align-items: center; justify-content: center;
    font-family: var(--head); font-weight: 700; font-size: 34px; letter-spacing: 1px; color: var(--amber);
    background: #0b0f16; border: 2px solid var(--amber);
    clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 18px 100%, 0 calc(100% - 18px));
    box-shadow: 0 0 30px rgba(245,166,35,0.25);
}
.hero h1 { font-size: 52px; letter-spacing: .06em; padding: 0; }
.hero h1::before { display: none; }
.hero .tagline { color: var(--muted); font-size: 16px; letter-spacing: .04em; margin: 8px auto 26px; max-width: 640px; text-transform: uppercase; font-family: var(--head); }
.hero .cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* ── Stat readouts (chips) ────────────────────────────────────────────── */
.chips { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 30px; }
.chip {
    background: var(--bg-2); border: 1px solid var(--line); padding: 16px 24px; min-width: 150px; text-align: center; position: relative;
    clip-path: polygon(0 0, calc(100% - 11px) 0, 100% 11px, 100% 100%, 11px 100%, 0 calc(100% - 11px));
}
.chip .n { font-family: var(--head); font-weight: 700; font-size: 32px; color: var(--amber); line-height: 1; }
.chip .n.live { color: var(--cyan); text-shadow: 0 0 14px rgba(53,208,192,0.5); }
.chip .l { font-family: var(--head); font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .16em; margin-top: 8px; }
.chip .l::before { content: "▸ "; color: var(--amber); }

/* ── Tables (command console) ─────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 11px 13px; border-bottom: 1px solid var(--line); font-size: 14px; }
th { font-family: var(--head); color: var(--amber); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; background: rgba(245,166,35,0.04); }
tbody tr { transition: background .12s; }
tbody tr:hover td { background: rgba(53,208,192,0.06); box-shadow: inset 3px 0 0 var(--cyan); }

/* ── Badges (angular tags) ────────────────────────────────────────────── */
.badge {
    display: inline-block; padding: 3px 10px; font-family: var(--head); font-size: 11px; font-weight: 600;
    text-transform: uppercase; letter-spacing: .06em; border: 1px solid transparent;
    clip-path: polygon(5px 0, 100% 0, 100% calc(100% - 5px), calc(100% - 5px) 100%, 0 100%, 0 5px);
}
.badge.usa   { background: rgba(45,108,200,0.18); color: #76b3ff; border-color: #2d6cc8; }
.badge.china { background: rgba(229,72,77,0.16);  color: #ff8a8e; border-color: #e5484d; }
.badge.gla   { background: rgba(201,169,106,0.16);color: #d9b977; border-color: #b08f4a; }
.badge.role  { background: rgba(53,208,192,0.14); color: var(--cyan); border-color: #2a9d92; }
.badge.muted { background: rgba(116,132,155,0.14);color: #9aa7bb; border-color: var(--line-2); }

/* ── Forms ────────────────────────────────────────────────────────────── */
label { display: block; font-family: var(--head); font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .1em; margin: 14px 0 5px; }
input, select, textarea {
    width: 100%; background: var(--bg-3); color: var(--text); border: 1px solid var(--line);
    padding: 11px 13px; font-size: 14px; font-family: var(--body);
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 1px var(--amber), 0 0 14px rgba(245,166,35,0.18); }
input[type=checkbox] { width: auto; accent-color: var(--amber); }

.alert { padding: 11px 14px; margin-bottom: 14px; font-size: 14px; border-left: 3px solid; }
.alert.err { background: rgba(229,72,77,0.10); border-color: var(--red); color: #ff9498; }
.alert.ok  { background: rgba(53,208,192,0.10); border-color: var(--cyan); color: #88e6da; }

/* ── News / event tiles ───────────────────────────────────────────────── */
.news-card {
    display: block; background: var(--bg-2); border: 1px solid var(--line); position: relative; overflow: hidden;
    transition: border-color .15s, transform .12s, box-shadow .15s;
}
.news-card:hover { border-color: var(--amber); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.4); }
.news-card::before { content: ""; position: absolute; top: -1px; left: -1px; width: 14px; height: 14px; border-top: 2px solid var(--amber); border-left: 2px solid var(--amber); z-index: 2; }
.news-card img { width: 100%; height: 156px; object-fit: cover; display: block; filter: grayscale(0.25) contrast(1.05); }
.news-card .body { padding: 14px; }
.news-card h3 { color: var(--amber); }

/* ── Footer ───────────────────────────────────────────────────────────── */
.site-footer { border-top: 1px solid var(--line); box-shadow: 0 -1px 0 rgba(245,166,35,0.25); background: #0b0f16; padding: 22px 0; color: var(--muted); font-size: 12px; }
.site-footer .container { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; align-items: center; }
.site-footer .container span:first-child { font-family: var(--head); letter-spacing: .12em; text-transform: uppercase; }

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 760px) {
    .grid.c3, .grid.c2 { grid-template-columns: 1fr; }
    .nav { width: 100%; gap: 2px; }
    .nav a { padding: 7px 7px; font-size: 12px; }
    .hero h1 { font-size: 34px; }
    .hero::before { letter-spacing: .2em; font-size: 9px; }
}
