/* ===================================================================
   The Bloc — Public landing page (Phase 2 #3)
   Stand-alone styles for `/` (unauth). Same visual language as the
   admin dashboard but scoped to .bloc-public so nothing leaks.
   =================================================================== */

@font-face {
    font-family: 'Space Grotesk';
    src: url('../fonts/space-grotesk-var.woff2') format('woff2-variations'),
         url('../fonts/space-grotesk-var.woff2') format('woff2');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Overpass Mono';
    src: url('../fonts/overpass-mono-var.woff2') format('woff2-variations'),
         url('../fonts/overpass-mono-var.woff2') format('woff2');
    font-weight: 300 700;
    font-style: normal;
    font-display: swap;
}

* { box-sizing: border-box; }

.bloc-public {
    --surface: #0A0E1A;
    --card-fill: rgba(10, 14, 26, .6);
    --text: #BBB4A3;
    --muted: #777268;
    --accent-primary: #FF6A1F;
    --accent-secondary: #4A6BFF;
    --border: rgba(74, 107, 255, .25);
    --border-strong: rgba(74, 107, 255, .4);
    --halftone-dot: rgba(74, 107, 255, .18);

    margin: 0;
    min-height: 100vh;
    background: var(--surface);
    background-image: radial-gradient(circle at 1px 1px, var(--halftone-dot) 1px, transparent 0);
    background-size: 6px 6px;
    color: var(--text);
    font-family: 'Space Grotesk', system-ui, sans-serif;
    line-height: 1.45;
}

/* --- Header strip --- */

.bp-header {
    background: var(--card-fill);
    border-bottom: 1px solid var(--border);
    padding: 14px 22px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}
.bp-wordmark {
    display: block;
    height: 30px;
    width: auto;
}
.bp-auth {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.bp-login,
.bp-dashboard-btn {
    color: var(--accent-primary);
    text-decoration: none;
    padding: 7px 12px;
    border: 1px solid var(--accent-primary);
    transition: background .12s, color .12s;
}
.bp-login:hover,
.bp-dashboard-btn:hover {
    background: var(--accent-primary);
    color: var(--surface);
}
.bp-user {
    color: var(--muted);
}
.bp-logout {
    color: var(--muted);
    background: none;
    border: 0;
    padding: 0;
    font: inherit;
    cursor: pointer;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.bp-logout:hover { color: var(--accent-primary); }

/* --- Main wrapper --- */

.bp-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: 36px 22px;
    display: flex;
    flex-direction: column;
    gap: 22px;
}

/* --- Hero --- */

.bp-hero {
    background: var(--card-fill);
    border: 1px solid var(--border-strong);
    padding: 36px 28px;
    text-align: center;
}
.bp-hero-eyebrow {
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--accent-secondary);
    margin-bottom: 10px;
}
.bp-hero-address {
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: clamp(28px, 5vw, 44px);
    font-weight: 700;
    color: var(--text);
    letter-spacing: -.01em;
    line-height: 1;
    word-break: break-all;
    background: transparent;
    border: 0;
    padding: 8px 4px;
    cursor: pointer;
    transition: color .12s;
}
.bp-hero-address:hover { color: var(--accent-primary); }
.bp-hero-copy-hint {
    margin-top: 6px;
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--muted);
}
.bp-hero-copy-hint.copied { color: var(--accent-primary); }
.bp-hero-status {
    margin-top: 22px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    border: 1px solid var(--border);
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 12px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text);
    white-space: nowrap;
}
.bp-hero-status-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--muted);
}
.bp-hero-status--online .bp-hero-status-dot { background: var(--accent-primary); }
.bp-hero-status--offline .bp-hero-status-dot { background: #f87171; }
.bp-hero-status--online { color: var(--accent-primary); }
.bp-hero-status--offline { color: #f87171; }

/* --- Map card --- */

.bp-map {
    background: var(--card-fill);
    border: 1px solid var(--border);
    overflow: hidden;
}
.bp-map-head {
    padding: 12px 18px;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.bp-map-title {
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent-secondary);
}
.bp-map-full {
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent-primary);
    text-decoration: none;
}
.bp-map-full:hover { filter: brightness(1.2); }
.bp-map iframe {
    display: block;
    width: 100%;
    height: 540px;
    border: 0;
}
@media (max-width: 768px) {
    .bp-map iframe { height: 380px; }
}

/* --- Footer --- */

.bp-foot {
    border-top: 1px solid var(--border);
    padding: 18px 22px;
    text-align: center;
    font-family: 'Overpass Mono', ui-monospace, monospace;
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--muted);
}
