/* ===========================================================================
   ATHLETENHALLE · Supplement Shop
   Aesthetik: athletisch / industrial-premium. Schwarz + Signal-Gelb.
   Kondensierte Display-Typo, scharfe Kanten, Tiefe durch Grain & Glow,
   choreografierter Seitenaufbau. Mobile-first, ohne Framework.
   =========================================================================== */

:root {
    --bg:          #08080a;
    --bg-elev:     #111114;
    --bg-elev-2:   #17171b;
    --line:        rgba(255,255,255,.07);
    --line-strong: rgba(255,255,255,.16);
    --text:        #f5f5f6;
    --muted:       #87878f;
    --faint:       #56565d;
    --accent:      #eeee22;
    --accent-2:    #fafa66;
    --gold:        #d4a212;
    --danger:      #ff5a45;
    --ok:          #34c759;
    --info:        #5ab0ff;

    --r-sm: 4px;
    --r:    9px;
    --r-lg: 16px;

    --shadow:      0 18px 50px -20px rgba(0,0,0,.8);
    --shadow-glow: 0 0 0 1px rgba(238,238,34,.5), 0 16px 40px -16px rgba(238,238,34,.25);

    --font-display: 'Anton', 'Archivo', sans-serif;
    --font-head:    'Archivo', system-ui, sans-serif;
    --font-body:    'Hanken Grotesk', system-ui, sans-serif;

    --maxw: 1200px;
    --pad: clamp(16px, 4vw, 28px);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
    /* atmosphärische Tiefe */
    background-image:
        radial-gradient(1100px 600px at 88% -8%, rgba(238,238,34,.10), transparent 60%),
        radial-gradient(900px 700px at -10% 0%, rgba(255,255,255,.035), transparent 55%);
    background-attachment: fixed;
}

/* Feines Film-Korn über allem (Textur, kein Inhalt) */
.grain {
    position: fixed; inset: 0; z-index: 1; pointer-events: none;
    opacity: .045; mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection { background: var(--accent); color: #000; }

::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: #0c0c0e; }
::-webkit-scrollbar-thumb { background: #2a2a30; border-radius: 99px; border: 3px solid #0c0c0e; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ---- Typografie ---------------------------------------------------------- */
h1, h2, h3 { font-family: var(--font-head); font-weight: 800; line-height: 1.05; margin: 0 0 .5rem; letter-spacing: -.01em; }
h1 { font-size: clamp(1.7rem, 3.5vw, 2.4rem); text-transform: uppercase; }
h2 { font-size: clamp(1.2rem, 2.4vw, 1.5rem); text-transform: uppercase; }
p  { margin: 0 0 1rem; }
a  { color: var(--accent); text-decoration: none; transition: color .15s; }
a:hover { color: var(--accent-2); }
strong { font-weight: 700; }

.accent { color: var(--accent); }
.muted  { color: var(--muted); }
.center { text-align: center; }
.text-right { text-align: right; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }

/* ---- Header / Nav -------------------------------------------------------- */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(8,8,10,.72);
    backdrop-filter: blur(16px) saturate(1.5);
    -webkit-backdrop-filter: blur(16px) saturate(1.5);
    border-bottom: 1px solid var(--line);
}
.site-header::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent) 18%, var(--accent) 82%, transparent);
    opacity: .55;
}
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 70px; gap: 20px; }
.brand { display: inline-flex; align-items: center; gap: 10px; }
.brand-logo { height: 30px; width: auto; display: block; transition: transform .25s; }
.brand:hover .brand-logo { transform: scale(1.03); }
.brand-sub {
    font-family: var(--font-head); font-size: .58rem; font-weight: 700; color: var(--muted);
    letter-spacing: .42em; text-transform: uppercase; padding-left: 8px; border-left: 1px solid var(--line-strong);
}

.main-nav { display: flex; align-items: center; gap: 30px; }
.main-nav a {
    position: relative; color: var(--text); font-family: var(--font-head);
    font-size: .82rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
}
.main-nav a:not(.btn-nav)::after {
    content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 2px;
    background: var(--accent); transition: right .25s cubic-bezier(.2,.7,.2,1);
}
.main-nav a:not(.btn-nav):hover { color: #fff; }
.main-nav a:not(.btn-nav):hover::after { right: 0; }

/* Logout ist ein POST-Formular, der Button sieht aus wie ein Nav-Link */
.nav-form { margin: 0; display: inline-flex; }
.nav-link-btn {
    background: none; border: 0; cursor: pointer; padding: 0; color: var(--text);
    font-family: var(--font-head); font-size: .82rem; font-weight: 600;
    letter-spacing: .08em; text-transform: uppercase; transition: color .15s;
}
.nav-link-btn:hover { color: var(--accent); }

.cart-link { display: inline-flex; align-items: center; gap: 7px; }
.cart-link .badge {
    background: var(--accent); color: #000; font-family: var(--font-head); font-weight: 800;
    border-radius: 99px; min-width: 20px; height: 20px; padding: 0 6px; font-size: .72rem;
    display: inline-flex; align-items: center; justify-content: center; letter-spacing: 0;
}
.btn-nav {
    background: var(--accent); color: #000 !important; padding: 9px 18px; border-radius: var(--r-sm);
    font-family: var(--font-head); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; font-size: .82rem;
    transition: transform .18s, box-shadow .18s, background .18s;
}
.btn-nav:hover { background: var(--accent-2); transform: translateY(-2px); box-shadow: 0 10px 24px -10px rgba(238,238,34,.6); }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; width: 30px; height: 24px; padding: 0; position: relative; }
.nav-toggle span { position: absolute; left: 0; height: 2px; width: 100%; background: var(--accent); transition: transform .25s, opacity .2s; }
.nav-toggle span:nth-child(1) { top: 2px; }
.nav-toggle span:nth-child(2) { top: 11px; }
.nav-toggle span:nth-child(3) { top: 20px; }
body.nav-open .nav-toggle span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
body.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* ---- Inhalt -------------------------------------------------------------- */
.main-content { position: relative; z-index: 2; padding: 36px var(--pad) 70px; min-height: 62vh; }
.main-content > .container,
main.container.main-content { padding-left: var(--pad); padding-right: var(--pad); }

/* ---- Hero ---------------------------------------------------------------- */
.hero { position: relative; padding: 40px 0 48px; }
.hero-glow {
    position: absolute; top: -120px; right: -80px; width: 520px; height: 520px; z-index: -1;
    background: radial-gradient(circle, rgba(238,238,34,.22), transparent 62%);
    filter: blur(30px); pointer-events: none;
}
.eyebrow {
    display: inline-flex; align-items: center; gap: 9px;
    font-family: var(--font-head); font-size: .74rem; font-weight: 600; letter-spacing: .22em;
    text-transform: uppercase; color: var(--muted); margin-bottom: 22px;
    animation: fade-up .6s both;
}
.eyebrow-dot { width: 8px; height: 8px; border-radius: 99px; background: var(--accent); box-shadow: 0 0 0 0 rgba(238,238,34,.6); animation: pulse 2.2s infinite; }
.hero-title {
    font-family: var(--font-display); font-weight: 400;
    font-size: clamp(3.2rem, 13vw, 8.5rem); line-height: .82; letter-spacing: .005em;
    text-transform: uppercase; margin: 0 0 26px; color: #fff;
    animation: fade-up .7s .05s both;
}
.hero-title .accent {
    color: var(--accent); -webkit-text-stroke: 0;
    text-shadow: 0 0 40px rgba(238,238,34,.35);
}
.hero-sub { max-width: 540px; color: var(--muted); font-size: 1.05rem; animation: fade-up .7s .12s both; }
.hero-meta {
    display: flex; flex-wrap: wrap; gap: 14px 30px; margin-top: 26px;
    font-family: var(--font-head); font-size: .82rem; text-transform: uppercase; letter-spacing: .06em;
    color: var(--muted); animation: fade-up .7s .2s both;
}
.hero-meta span { display: inline-flex; align-items: center; gap: 8px; }
.hero-meta span + span { padding-left: 30px; border-left: 1px solid var(--line); }
.hero-meta strong { color: var(--accent); font-weight: 800; font-size: 1.05rem; }

/* ---- Section head -------------------------------------------------------- */
.section-head { display: flex; align-items: center; gap: 18px; margin: 18px 0 26px; }
.section-title { font-family: var(--font-head); font-weight: 800; text-transform: uppercase; letter-spacing: .04em; font-size: 1.1rem; margin: 0; white-space: nowrap; }
.section-rule { flex: 1; height: 1px; background: linear-gradient(90deg, var(--line-strong), transparent); }

/* ---- Cards / Sections ---------------------------------------------------- */
.card {
    background: linear-gradient(180deg, var(--bg-elev), #0e0e11);
    border: 1px solid var(--line); border-radius: var(--r-lg);
    padding: clamp(20px, 3vw, 30px); margin-bottom: 22px;
    box-shadow: var(--shadow);
}
.card.narrow { max-width: 470px; margin-left: auto; margin-right: auto; }

/* ---- Buttons ------------------------------------------------------------- */
.btn {
    --b: var(--accent);
    display: inline-flex; align-items: center; justify-content: center; gap: 9px;
    background: var(--b); color: #000; border: 0; border-radius: var(--r-sm);
    padding: 13px 26px; cursor: pointer;
    font-family: var(--font-head); font-weight: 700; font-size: .9rem; letter-spacing: .07em; text-transform: uppercase;
    transition: transform .18s, box-shadow .18s, background .18s, color .18s, border-color .18s;
}
.btn:hover { background: var(--accent-2); transform: translateY(-2px); box-shadow: 0 14px 30px -12px rgba(238,238,34,.55); }
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: .45; cursor: not-allowed; transform: none; box-shadow: none; }
.btn-block { display: flex; width: 100%; }
.btn-ghost {
    background: transparent; color: var(--text); border: 1px solid var(--line-strong); box-shadow: none;
}
.btn-ghost:hover { background: transparent; border-color: var(--accent); color: var(--accent); transform: translateY(-2px); box-shadow: none; }
.btn-danger { background: transparent; color: var(--danger); border: 1px solid rgba(255,90,69,.5); box-shadow: none; }
.btn-danger:hover { background: rgba(255,90,69,.08); color: var(--danger); border-color: var(--danger); box-shadow: none; }
.btn-sm { padding: 8px 15px; font-size: .76rem; }

/* ---- Formulare ----------------------------------------------------------- */
.field { margin-bottom: 18px; }
.field label, .checkbox-row label { font-family: var(--font-head); }
.field label { display: block; margin-bottom: 7px; font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
input, select, textarea {
    width: 100%; padding: 13px 15px; background: var(--bg-elev-2);
    border: 1px solid var(--line-strong); border-radius: var(--r-sm);
    color: var(--text); font-size: 1rem; font-family: var(--font-body); transition: border-color .15s, box-shadow .15s, background .15s;
}
input::placeholder, textarea::placeholder { color: var(--faint); }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px rgba(238,238,34,.14); background: #1c1c20; }
select { appearance: none; -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23eeee22' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 15px center; padding-right: 38px; }
.checkbox-row { display: flex; gap: 11px; align-items: flex-start; }
.checkbox-row input { width: auto; margin-top: 3px; accent-color: var(--accent); }
.checkbox-row label { color: var(--text); margin: 0; font-family: var(--font-body); text-transform: none; letter-spacing: 0; font-size: .95rem; }

/* ---- Flash-Meldungen ----------------------------------------------------- */
.flash {
    position: relative; padding: 13px 16px 13px 18px; border-radius: var(--r-sm); margin-bottom: 16px;
    font-size: .95rem; background: var(--bg-elev-2); border: 1px solid var(--line);
    animation: fade-up .4s both;
}
.flash::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; border-radius: 3px 0 0 3px; }
.flash-success { color: #c8f5d2; } .flash-success::before { background: var(--ok); }
.flash-error   { color: #ffc8c1; } .flash-error::before   { background: var(--danger); }
.flash-info    { color: #f4f4b6; } .flash-info::before    { background: var(--accent); }

/* ---- Produktraster ------------------------------------------------------- */
.product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(245px, 1fr)); gap: 18px; }
.product-card {
    position: relative; background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r);
    overflow: hidden; display: flex; flex-direction: column; color: var(--text);
    transition: transform .25s cubic-bezier(.2,.7,.2,1), border-color .25s, box-shadow .25s;
    animation: fade-up .6s cubic-bezier(.2,.7,.2,1) backwards;
    animation-delay: calc(var(--i, 0) * 55ms);
}
.product-card:hover { transform: translateY(-5px); border-color: rgba(238,238,34,.45); box-shadow: var(--shadow-glow); }
.product-card .thumb {
    position: relative; aspect-ratio: 1/1; overflow: hidden;
    background: radial-gradient(circle at 50% 32%, #fafafa, #e4e4e8 78%);
    display: flex; align-items: center; justify-content: center;
}
.product-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s cubic-bezier(.2,.7,.2,1); }
.product-card:hover .thumb img { transform: scale(1.06); }
.product-card .thumb .ph { color: #c7c7cc; font-size: 2.6rem; font-family: var(--font-display); }
.thumb-brand {
    position: absolute; top: 11px; left: 11px; z-index: 2;
    font-family: var(--font-head); font-size: .6rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    color: #fff; background: rgba(12,12,14,.82); padding: 4px 9px; border-radius: 99px; backdrop-filter: blur(4px);
}
.product-card .body { padding: 16px 16px 17px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.product-card .pname { font-family: var(--font-head); font-weight: 700; font-size: 1.06rem; line-height: 1.2; letter-spacing: -.01em; }
.card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.product-card .price { font-family: var(--font-head); font-weight: 800; font-size: 1.08rem; color: var(--accent); letter-spacing: -.01em; }
.product-card .price em { font-style: normal; font-weight: 600; font-size: .72rem; color: var(--faint); text-transform: uppercase; letter-spacing: .08em; }
.card-cta { color: var(--faint); font-size: 1.2rem; line-height: 1; transition: transform .25s, color .25s; }
.product-card:hover .card-cta { color: var(--accent); transform: translateX(5px); }

/* ---- Produktdetail ------------------------------------------------------- */
.product-detail { display: grid; grid-template-columns: 1.05fr 1fr; gap: 32px; align-items: start; padding: clamp(20px,3vw,32px); }
.product-detail .media {
    aspect-ratio: 1/1; border-radius: var(--r); overflow: hidden;
    background: radial-gradient(circle at 50% 32%, #fafafa, #e4e4e8 78%);
    display: flex; align-items: center; justify-content: center; border: 1px solid var(--line);
}
.product-detail .media img { width: 100%; height: 100%; object-fit: cover; }
.product-detail .media .ph { color: #c7c7cc; font-size: 4.5rem; font-family: var(--font-display); }
.product-detail .brand-tag { display: inline-block; font-family: var(--font-head); font-size: .72rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 10px; }
.product-detail h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); margin-bottom: 14px; }

/* ---- Tabellen (Warenkorb / Admin) --------------------------------------- */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 14px 12px; border-bottom: 1px solid var(--line); }
th { font-family: var(--font-head); color: var(--muted); font-weight: 600; font-size: .68rem; text-transform: uppercase; letter-spacing: .1em; }
tbody tr { transition: background .15s; }
tbody tr:hover { background: rgba(255,255,255,.02); }
td .qty { width: 74px; }
.totals { font-family: var(--font-head); font-size: 1.25rem; font-weight: 800; }

/* ---- Statusbadges -------------------------------------------------------- */
.status { font-family: var(--font-head); padding: 4px 11px; border-radius: 99px; font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.status-neu        { background: rgba(238,238,34,.16); color: var(--accent); }
.status-bearbeitet { background: rgba(90,176,255,.16); color: var(--info); }
.status-abgeholt   { background: rgba(52,199,89,.16);  color: #7ee29a; }
.status-storniert  { background: rgba(255,90,69,.16);  color: #ff9d92; }

/* ---- Notice -------------------------------------------------------------- */
.notice { background: var(--bg-elev-2); border: 1px solid var(--line); border-left: 3px solid var(--accent); padding: 14px 18px; border-radius: 0 var(--r-sm) var(--r-sm) 0; color: var(--muted); font-size: .95rem; }

/* ---- Footer -------------------------------------------------------------- */
.site-footer { position: relative; z-index: 2; background: #060608; border-top: 1px solid var(--line); padding: 48px 0 34px; margin-top: 50px; }
.footer-top { display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; padding-bottom: 30px; border-bottom: 1px solid var(--line); }
.footer-logo { height: 30px; width: auto; opacity: .92; margin-bottom: 14px; }
.footer-tagline { color: var(--muted); font-size: .9rem; margin: 0; max-width: 320px; }
.footer-nav { display: flex; flex-direction: column; gap: 11px; }
.footer-nav-label { font-family: var(--font-head); font-size: .66rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--faint); margin-bottom: 3px; }
.footer-nav a { color: var(--muted); font-size: .92rem; width: max-content; }
.footer-nav a:hover { color: var(--accent); }
.footer-copy { color: var(--faint); font-size: .8rem; padding-top: 22px; }

/* ---- Legal-Text ---------------------------------------------------------- */
.legal h2 { margin-top: 30px; color: var(--accent); }
.legal h1 { margin-bottom: 6px; }
.legal p, .legal li { color: #cdcdd2; }
.legal a { text-decoration: underline; }

/* ---- Animationen --------------------------------------------------------- */
@keyframes fade-up { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
@keyframes pulse {
    0%   { box-shadow: 0 0 0 0 rgba(238,238,34,.55); }
    70%  { box-shadow: 0 0 0 9px rgba(238,238,34,0); }
    100% { box-shadow: 0 0 0 0 rgba(238,238,34,0); }
}

/* ---- Responsiv ----------------------------------------------------------- */
@media (max-width: 760px) {
    .nav-toggle { display: block; }
    .main-nav {
        display: none; position: absolute; top: 70px; left: 0; right: 0;
        background: #0a0a0c; box-shadow: 0 28px 48px -12px rgba(0,0,0,.85); flex-direction: column; align-items: stretch;
        gap: 0; padding: 10px var(--pad) 18px; border-bottom: 1px solid var(--line);
    }
    body.nav-open .main-nav { display: flex; animation: fade-up .25s both; }
    .main-nav a { padding: 14px 0; border-bottom: 1px solid var(--line); }
    .nav-form { width: 100%; border-bottom: 1px solid var(--line); }
    .nav-link-btn { padding: 14px 0; width: 100%; text-align: left; }
    .main-nav a:not(.btn-nav)::after { display: none; }
    .btn-nav { width: 100%; text-align: center; margin-top: 12px; }
    .product-detail { grid-template-columns: 1fr; }
    .hero-meta span + span { padding-left: 0; border-left: 0; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto; }
}

/* -- Passwort-Live-Hinweise (Registrierung / Reset) ------------------------ */
.pw-hint { font-size: .85rem; margin: 6px 0 0; min-height: 1.2em; color: #9a9a9a; }
.pw-hint.pw-bad  { color: #e07a6a; }
.pw-hint.pw-weak { color: #d9a05b; }
.pw-hint.pw-ok   { color: #eeee22; }
.pw-hint.pw-good { color: #8fc97a; }

/* ==== Mobile-Tabellen ======================================================= */
/* Admin-/Datentabellen: horizontal wischbar im Karten-Rahmen statt abgeschnitten */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table-scroll table { min-width: 620px; }

/* Shop-Tabellen (Warenkorb/Kasse): auf Mobile als gestapelte Positions-Karten */
@media (max-width: 640px) {
    table.stack-mobile thead { display: none; }
    table.stack-mobile, table.stack-mobile tbody,
    table.stack-mobile tr, table.stack-mobile td { display: block; width: 100%; }
    table.stack-mobile tr { padding: 12px 0; border-bottom: 1px solid var(--line-strong); }
    table.stack-mobile td {
        display: flex; justify-content: space-between; align-items: center;
        gap: 16px; padding: 5px 0; border: 0; text-align: right;
    }
    table.stack-mobile td::before {
        content: attr(data-label);
        font-family: var(--font-head); color: var(--muted); font-weight: 600;
        font-size: .68rem; text-transform: uppercase; letter-spacing: .1em;
        text-align: left; flex-shrink: 0;
    }
    table.stack-mobile td.stack-product { font-weight: 700; font-size: 1.02rem; justify-content: flex-start; text-align: left; padding-bottom: 8px; }
    table.stack-mobile td.stack-product::before,
    table.stack-mobile td.stack-action::before { display: none; }
    table.stack-mobile td.stack-action { justify-content: flex-end; padding-top: 8px; }
}

/* Checkboxen & Radios in Markenfarbe statt Browser-Blau */
input[type="checkbox"], input[type="radio"] { accent-color: var(--accent); }

/* ==== Staging-Banner (nur Testumgebung, via config app.staging) ============= */
.staging-banner {
    background: #d4a212; color: #0a0a0a; text-align: center;
    font-family: var(--font-head); font-weight: 700; font-size: .82rem;
    letter-spacing: .04em; padding: 7px 14px; position: sticky; top: 0; z-index: 999;
}

/* ==== Mitglieder-Dashboard ================================================= */
.dash { padding: 8px 0 0; }
.dash-hello { font-family: var(--font-head); font-weight: 800; font-size: clamp(1.6rem,4vw,2.2rem); margin: 0 0 24px; }
.dash-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.dash-tile {
    position: relative; display: flex; flex-direction: column; gap: 6px;
    background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-lg);
    padding: 22px; color: var(--text); transition: transform .18s, border-color .18s, box-shadow .18s;
}
a.dash-tile:hover { transform: translateY(-3px); border-color: var(--line-strong); box-shadow: var(--shadow); color: var(--text); }
.dash-ico { font-size: 30px; line-height: 1; }
.dash-title { font-family: var(--font-head); font-weight: 800; font-size: 1.15rem; text-transform: uppercase; letter-spacing: .02em; margin-top: 6px; }
.dash-desc { color: var(--muted); font-size: .92rem; }
.dash-tile.is-soon { opacity: .55; cursor: default; }
.dash-badge {
    position: absolute; top: 14px; right: 14px; background: var(--gold); color: #0a0a0a;
    font-family: var(--font-head); font-weight: 700; font-size: .62rem; letter-spacing: .06em;
    text-transform: uppercase; padding: 3px 8px; border-radius: 99px;
}
