/* =========================================================
   mang.quest // brutalist hexagonal network command center
   ========================================================= */

:root {
    --concrete: #A0988A;
    --concrete-dark: #5A5248;
    --burnt: #D4763A;
    --amber: #E8A050;
    --offwhite: #F0E8D8;
    --charcoal: #2A2A28;
    --rust: #A05030;

    --concrete-shadow: rgba(42, 42, 40, 0.18);
    --concrete-deep: #8B8377;

    --hex-w: 180px;
    --hex-h: 208px;
    --hex-clip: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
    background: var(--concrete);
    color: var(--charcoal);
    font-family: 'IBM Plex Sans', system-ui, sans-serif;
    font-weight: 400;
    line-height: 1.6;
    overflow-x: hidden;
    min-height: 100%;
}

/* Concrete texture overlay */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image:
        radial-gradient(circle at 13% 27%, rgba(42,42,40,0.08) 0 1px, transparent 1px),
        radial-gradient(circle at 73% 64%, rgba(42,42,40,0.07) 0 1px, transparent 1px),
        radial-gradient(circle at 41% 88%, rgba(240,232,216,0.05) 0 1px, transparent 1px),
        radial-gradient(circle at 88% 12%, rgba(42,42,40,0.06) 0 1px, transparent 1px);
    background-size: 7px 7px, 11px 11px, 13px 13px, 9px 9px;
    mix-blend-mode: multiply;
    z-index: 1;
    opacity: 0.85;
}

body { position: relative; }

/* =========================================================
   Organic blob layer
   ========================================================= */
.blob-layer {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}
.blob {
    position: absolute;
    fill: var(--concrete-deep);
    opacity: 0.32;
    filter: blur(40px);
    will-change: transform;
}
.blob-1 { width: 540px; height: 540px; top: -120px; left: -140px; animation: blobFloat1 28s ease-in-out infinite; }
.blob-2 { width: 460px; height: 460px; bottom: -160px; right: -120px; animation: blobFloat2 34s ease-in-out infinite; }
.blob-3 { width: 380px; height: 380px; top: 38%; left: 52%; animation: blobFloat3 24s ease-in-out infinite; opacity: 0.22; }

@keyframes blobFloat1 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(60px,40px) scale(1.07); } }
@keyframes blobFloat2 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-50px,-30px) scale(0.96); } }
@keyframes blobFloat3 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-40px,30px) scale(1.05); } }

/* =========================================================
   HERO
   ========================================================= */
.hero {
    position: relative;
    z-index: 2;
    min-height: 100vh;
    padding: 32px 48px 48px;
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    grid-template-rows: auto 1fr auto;
    gap: 32px 48px;
    border-bottom: 3px solid var(--charcoal);
}

.hero-frame {
    grid-column: 1;
    grid-row: 1 / span 2;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-width: 0;
}

.hero-meta {
    display: flex;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}
.meta-tag {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 6px 10px;
    background: var(--charcoal);
    color: var(--offwhite);
    border-left: 3px solid var(--burnt);
}

.logotype {
    font-family: 'Bebas Neue', 'Impact', sans-serif;
    font-weight: 400;
    color: var(--charcoal);
    letter-spacing: 0.04em;
    line-height: 0.86;
    margin: 8px 0 16px;
}
.logo-line {
    display: block;
    font-size: clamp(72px, 13vw, 200px);
}
.logo-line:nth-child(2) {
    color: var(--burnt);
    margin-left: clamp(16px, 4vw, 64px);
}

.hero-strap {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    gap: 32px;
    align-items: end;
    margin-top: auto;
    border-top: 2px solid var(--charcoal);
    padding-top: 20px;
}
.strap-text {
    font-size: clamp(13px, 0.95vw, 16px);
    color: var(--charcoal);
    max-width: 56ch;
}
.strap-stats {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.strap-stats li {
    display: flex;
    flex-direction: column;
    border-left: 2px solid var(--burnt);
    padding-left: 10px;
}
.stat-num {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(28px, 3.5vw, 52px);
    color: var(--charcoal);
    letter-spacing: 0.02em;
    line-height: 1;
}
.stat-lbl {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.14em;
    color: var(--charcoal);
    text-transform: uppercase;
    margin-top: 4px;
}

/* MINIMAP */
.minimap {
    grid-column: 2;
    grid-row: 1 / span 2;
    background: var(--charcoal);
    color: var(--offwhite);
    padding: 18px 18px 14px;
    border: 2px solid var(--charcoal);
    box-shadow: 12px 12px 0 0 var(--burnt);
    display: flex;
    flex-direction: column;
    align-self: start;
    min-height: 380px;
}
.minimap-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    border-bottom: 1px dashed rgba(240,232,216,0.3);
    padding-bottom: 8px;
    margin-bottom: 10px;
}
.mm-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 18px;
    color: var(--burnt);
    letter-spacing: 0.08em;
}
.mm-coord {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.1em;
    color: var(--offwhite);
    opacity: 0.7;
}
.minimap-svg {
    flex: 1;
    width: 100%;
    height: auto;
    min-height: 280px;
}
.minimap-svg .mm-hex {
    fill: transparent;
    stroke: var(--burnt);
    stroke-width: 1.4;
    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;
    animation: mmStroke 1.5s ease-out forwards;
}
.minimap-svg .mm-hex.mm-hex-active { fill: rgba(212,118,58,0.16); }
.minimap-svg .mm-hex.mm-hex-alert { stroke: var(--rust); }
.minimap-svg .mm-line {
    stroke: var(--amber);
    stroke-width: 1;
    opacity: 0;
    animation: mmFade 0.8s ease-out 1.2s forwards;
}
.minimap-svg .mm-dot {
    fill: var(--burnt);
    opacity: 0;
    animation: mmFade 0.6s ease-out 1.6s forwards;
}
.minimap-svg .mm-dot-amber { fill: var(--amber); }
@keyframes mmStroke { to { stroke-dashoffset: 0; } }
@keyframes mmFade { to { opacity: 1; } }

.minimap-foot {
    display: flex;
    gap: 14px;
    margin-top: 12px;
    padding-top: 8px;
    border-top: 1px dashed rgba(240,232,216,0.3);
}
.mm-legend {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.dot { width: 8px; height: 8px; display: inline-block; border-radius: 50%; }
.dot-orange { background: var(--burnt); }
.dot-amber { background: var(--amber); }
.dot-rust { background: var(--rust); }

/* TICKER */
.hero-sidebar {
    grid-column: 1 / span 2;
    grid-row: 3;
    border-top: 2px solid var(--charcoal);
    border-bottom: 2px solid var(--charcoal);
    background: var(--charcoal);
    color: var(--burnt);
    overflow: hidden;
    height: 32px;
    display: flex;
    align-items: center;
}
.sidebar-row {
    display: flex;
    width: max-content;
    animation: ticker 60s linear infinite;
}
.ticker-line {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
    white-space: nowrap;
    color: var(--burnt);
    text-transform: uppercase;
}
@keyframes ticker {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* =========================================================
   GRID SECTION
   ========================================================= */
.grid-section {
    position: relative;
    z-index: 2;
    padding: 64px 48px 80px;
    border-bottom: 3px solid var(--charcoal);
}

.grid-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    gap: 4px 24px;
    align-items: end;
    margin-bottom: 32px;
    border-bottom: 2px solid var(--charcoal);
    padding-bottom: 16px;
}
.section-title {
    font-family: 'Bebas Neue', sans-serif;
    font-weight: 400;
    color: var(--charcoal);
    font-size: clamp(32px, 4.5vw, 64px);
    letter-spacing: 0.04em;
    grid-row: 1;
    grid-column: 1;
}
.section-sub {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--concrete-dark);
    grid-row: 2;
    grid-column: 1;
}
.grid-controls {
    grid-row: 1 / span 2;
    grid-column: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-self: end;
}
.ctrl-btn {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: transparent;
    color: var(--charcoal);
    border: 2px solid var(--charcoal);
    padding: 8px 12px;
    cursor: pointer;
    transition: all 0.18s ease-out;
}
.ctrl-btn:hover { background: var(--charcoal); color: var(--burnt); }
.ctrl-btn.is-active { background: var(--burnt); color: var(--charcoal); border-color: var(--burnt); }

/* HEX GRID STAGE */
.grid-stage {
    position: relative;
    display: flex;
    justify-content: center;
}
.connections {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
}
.connections .conn-line {
    stroke: var(--burnt);
    stroke-width: 2;
    opacity: 0.3;
    transition: opacity 0.2s ease, stroke 0.2s ease;
}
.connections .conn-line.is-hot {
    stroke: var(--amber);
    opacity: 1;
}
.connections .conn-dot {
    fill: var(--burnt);
    opacity: 0.5;
    transition: fill 0.2s ease, opacity 0.2s ease;
}
.connections .conn-dot.is-hot { fill: var(--amber); opacity: 1; }

.hex-grid {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.hex-cell {
    position: relative;
    width: var(--hex-w);
    height: var(--hex-h);
    cursor: pointer;
    transition: transform 0.4s cubic-bezier(.2,.7,.2,1), z-index 0s 0.4s;
    will-change: transform;
    transform-origin: center center;
    opacity: 0;
    transform: scale(0.9);
}
.hex-cell.is-in {
    opacity: 1;
    transform: scale(1);
    transition: transform 0.5s cubic-bezier(.2,.7,.2,1), opacity 0.5s ease-out;
}
.hex-cell::before {
    content: '';
    position: absolute;
    inset: -3px;
    background: var(--burnt);
    clip-path: var(--hex-clip);
    z-index: 0;
    transition: background 0.2s ease;
}
.hex-cell::after {
    content: '';
    position: absolute;
    inset: 0;
    clip-path: var(--hex-clip);
    background:
        radial-gradient(circle at 30% 20%, rgba(240,232,216,0.04) 0 1px, transparent 1px),
        radial-gradient(circle at 70% 60%, rgba(212,118,58,0.06) 0 1px, transparent 1px),
        var(--concrete-dark);
    background-size: 5px 5px, 8px 8px, auto;
    z-index: 1;
}
.hex-cell.hex-alert::before { background: var(--rust); }
.hex-cell.hex-alert::after {
    background:
        radial-gradient(circle at 30% 20%, rgba(240,232,216,0.04) 0 1px, transparent 1px),
        radial-gradient(circle at 70% 60%, rgba(160,80,48,0.10) 0 1px, transparent 1px),
        var(--concrete-dark);
    background-size: 5px 5px, 8px 8px, auto;
}

.hex-cell:hover {
    transform: scale(1.08);
    z-index: 4;
    transition: transform 0.25s cubic-bezier(.2,.7,.2,1), z-index 0s;
}
.hex-cell:hover::before { background: var(--amber); }
.hex-cell.is-connected { transform: scale(1.04); z-index: 3; transition: transform 0.25s cubic-bezier(.2,.7,.2,1); }
.hex-cell.is-connected::before { background: var(--amber); }

.hex-cell.is-dim { opacity: 0.28; }

.hex-cell.expanded {
    transform: scale(2);
    z-index: 10;
    transition: transform 0.4s cubic-bezier(.2,.7,.2,1), z-index 0s;
}
.hex-cell.expanded::before { background: var(--amber); }
.hex-cell.expanded .hex-inner .hex-tag,
.hex-cell.expanded .hex-inner .hex-title,
.hex-cell.expanded .hex-inner .hex-id { opacity: 0.18; }
.hex-cell.expanded .data-viz { opacity: 1; pointer-events: auto; transform: scale(1); }

.hex-inner {
    position: absolute;
    inset: 0;
    z-index: 2;
    padding: 28px 22px;
    color: var(--offwhite);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    overflow: hidden;
    clip-path: var(--hex-clip);
}
.hex-tag {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 9px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--burnt);
    margin-bottom: 6px;
    transition: opacity 0.3s ease;
}
.hex-cell.hex-alert .hex-tag { color: var(--rust); }
.hex-title {
    font-family: 'Bebas Neue', sans-serif;
    font-weight: 400;
    font-size: 28px;
    letter-spacing: 0.04em;
    color: var(--offwhite);
    line-height: 1;
    margin-bottom: 6px;
    transition: opacity 0.3s ease;
}
.hex-id {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.14em;
    color: var(--offwhite);
    opacity: 0.5;
    transition: opacity 0.3s ease;
}

/* DATA VIZ inside hex */
.data-viz {
    position: absolute;
    inset: 18%;
    opacity: 0;
    pointer-events: none;
    transform: scale(0.96);
    transition: opacity 0.32s ease 0.08s, transform 0.32s ease 0.08s;
    color: var(--offwhite);
    font-family: 'IBM Plex Mono', monospace;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    gap: 4px;
}
.dv-title {
    font-size: 6px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--burnt);
    text-align: center;
    margin-bottom: 2px;
}
.dv-bars {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.dv-bars .bar {
    position: relative;
    height: 7px;
    background: rgba(240,232,216,0.08);
    overflow: hidden;
}
.dv-bars .bar::after {
    content: '';
    position: absolute;
    inset: 0;
    width: var(--w, 40%);
    background: var(--burnt);
}
.dv-bars .bar.bar-rust::after { background: var(--rust); }
.dv-bars .bar span {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    padding-left: 4px;
    font-size: 5px;
    letter-spacing: 0.14em;
    color: var(--offwhite);
    z-index: 2;
    text-transform: uppercase;
}

.dv-graph { width: 100%; max-height: 60%; }
.dv-graph line { stroke: var(--burnt); stroke-width: 1; }
.dv-graph circle { fill: var(--burnt); }
.dv-graph circle:first-of-type { fill: var(--amber); }

.dv-spark { width: 100%; height: 38px; }
.dv-spark polyline { stroke: var(--burnt); stroke-width: 1.5; fill: none; }

.dv-ring {
    position: relative;
    width: 50%;
    margin: 0 auto;
    aspect-ratio: 1;
}
.dv-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.dv-ring .ring-bg { fill: none; stroke: rgba(240,232,216,0.12); stroke-width: 5; }
.dv-ring .ring-fg {
    fill: none;
    stroke: var(--burnt);
    stroke-width: 5;
    stroke-linecap: butt;
    stroke-dasharray: calc(2 * 3.14159 * 24);
    stroke-dashoffset: calc(2 * 3.14159 * 24 * (1 - var(--p) / 100));
}
.dv-ring .ring-num {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Bebas Neue', sans-serif;
    font-size: 14px;
    color: var(--burnt);
    letter-spacing: 0.04em;
}
.dv-ring .ring-num i { font-style: normal; font-size: 9px; margin-left: 1px; opacity: 0.7; }

/* =========================================================
   TELEMETRY
   ========================================================= */
.telemetry {
    position: relative;
    z-index: 2;
    padding: 64px 48px;
    background: var(--concrete);
    border-bottom: 3px solid var(--charcoal);
}
.tel-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 28px;
    gap: 24px;
    border-bottom: 2px solid var(--charcoal);
    padding-bottom: 12px;
    flex-wrap: wrap;
}
.tel-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 14px;
}
.tel-card {
    background: var(--charcoal);
    color: var(--offwhite);
    padding: 18px 18px 14px;
    border-left: 4px solid var(--burnt);
    position: relative;
    overflow: hidden;
}
.tel-card::after {
    content: '';
    position: absolute;
    top: 0; right: 0; width: 80px; height: 80px;
    background: radial-gradient(circle at 70% 20%, rgba(212,118,58,0.16), transparent 60%);
    pointer-events: none;
}
.tel-card-alert { border-left-color: var(--rust); }
.tel-card-alert::after { background: radial-gradient(circle at 70% 20%, rgba(160,80,48,0.22), transparent 60%); }
.tel-label {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--burnt);
    margin-bottom: 6px;
}
.tel-card-alert .tel-label { color: var(--rust); }
.tel-value {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 56px;
    letter-spacing: 0.02em;
    color: var(--offwhite);
    line-height: 1;
}
.tel-unit {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--offwhite);
    opacity: 0.6;
    margin: 4px 0 8px;
}
.tel-bar {
    height: 4px;
    background: rgba(240,232,216,0.1);
    position: relative;
    overflow: hidden;
}
.tel-bar i {
    position: absolute;
    inset: 0;
    width: 0;
    background: var(--burnt);
    animation: tBarIn 1.4s cubic-bezier(.2,.7,.2,1) forwards;
}
.tel-card-alert .tel-bar i { background: var(--rust); }
@keyframes tBarIn { to { width: var(--w); } }

/* =========================================================
   DOCTRINE
   ========================================================= */
.doctrine {
    position: relative;
    z-index: 2;
    padding: 80px 48px;
    background: var(--charcoal);
    color: var(--offwhite);
    display: grid;
    grid-template-columns: minmax(220px, 0.6fr) minmax(0, 1fr);
    gap: 48px;
    border-bottom: 3px solid var(--burnt);
}
.doctrine-aside {
    border-right: 2px solid var(--burnt);
    padding-right: 24px;
}
.doc-mark {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--burnt);
    display: block;
    margin-bottom: 12px;
}
.doctrine-title {
    font-family: 'Bebas Neue', sans-serif;
    font-weight: 400;
    font-size: clamp(36px, 5vw, 76px);
    line-height: 0.9;
    letter-spacing: 0.04em;
    color: var(--offwhite);
    margin-bottom: 16px;
}
.doctrine-sub {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--burnt);
}
.doctrine-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
}
.doc-card {
    border: 2px solid rgba(240,232,216,0.18);
    padding: 18px 20px 22px;
    position: relative;
    transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.doc-card:hover {
    border-color: var(--burnt);
    background: rgba(212,118,58,0.06);
    transform: translateY(-2px);
}
.doc-num {
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.18em;
    color: var(--burnt);
}
.doc-card h3 {
    font-family: 'Bebas Neue', sans-serif;
    font-weight: 400;
    font-size: 28px;
    letter-spacing: 0.04em;
    margin: 6px 0 8px;
}
.doc-card p {
    font-size: 13px;
    line-height: 1.55;
    color: var(--offwhite);
    opacity: 0.86;
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer {
    position: relative;
    z-index: 2;
    padding: 24px 48px;
    background: var(--concrete);
    color: var(--charcoal);
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    gap: 24px;
    flex-wrap: wrap;
    border-top: 2px solid var(--charcoal);
}
.foot-block {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.foot-block-end { text-align: right; align-items: flex-end; }
.foot-mark { font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 0.06em; color: var(--burnt); }
.foot-coord, .foot-line, .foot-stamp { color: var(--charcoal); opacity: 0.85; }
.foot-clock {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 22px;
    letter-spacing: 0.04em;
    color: var(--burnt);
}

/* =========================================================
   OVERLAY (click-out for expanded cell)
   ========================================================= */
.overlay {
    position: fixed;
    inset: 0;
    background: rgba(42,42,40,0);
    z-index: 5;
    pointer-events: none;
    transition: background 0.3s ease;
}
.overlay.is-on {
    background: rgba(42,42,40,0.55);
    pointer-events: auto;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1100px) {
    .hero {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto auto;
        gap: 24px;
        padding: 24px 28px 36px;
    }
    .hero-frame { grid-column: 1; grid-row: 1; }
    .minimap { grid-column: 1; grid-row: 2; box-shadow: 8px 8px 0 0 var(--burnt); }
    .hero-sidebar { grid-column: 1; grid-row: 4; }
    .hero-strap { grid-template-columns: 1fr; }
    .strap-stats { grid-template-columns: repeat(4, 1fr); }
    .grid-section, .telemetry, .doctrine, .footer { padding-left: 28px; padding-right: 28px; }
    .doctrine { grid-template-columns: 1fr; }
    .doctrine-aside { border-right: none; border-bottom: 2px solid var(--burnt); padding-right: 0; padding-bottom: 16px; }
}

@media (max-width: 700px) {
    :root { --hex-w: 132px; --hex-h: 152px; }
    .hero { padding: 20px 18px 28px; }
    .grid-section, .telemetry, .doctrine, .footer { padding-left: 18px; padding-right: 18px; }
    .strap-stats { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .grid-controls { grid-row: auto; grid-column: 1; }
    .grid-header { grid-template-columns: 1fr; }
    .hex-cell.expanded { transform: scale(1.6); }
    .footer { flex-direction: column; }
    .foot-block-end { text-align: left; align-items: flex-start; }
}
