/* gif.ninja — shared site chrome + content-page styles.
   Loaded by every page so the nav, footer, and typography stay consistent. */

:root {
    --bg: #0a0a0a;
    --bg-2: #1a1a2e;
    --bg-3: #16213e;
    --purple: #8a2be2;
    --pink: #ff1493;
    --grad: linear-gradient(135deg, #8a2be2 0%, #ff1493 100%);
    --text: #ece9f5;
    --muted: rgba(255, 255, 255, 0.72);
    --faint: rgba(255, 255, 255, 0.5);
    --card: rgba(255, 255, 255, 0.03);
    --border: rgba(255, 255, 255, 0.1);
    --border-soft: rgba(255, 255, 255, 0.08);
    --sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

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

body {
    font-family: var(--sans);
    background: linear-gradient(135deg, var(--bg) 0%, var(--bg-2) 50%, var(--bg-3) 100%);
    min-height: 100vh;
    color: var(--text);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    display: flex;
    flex-direction: column;
}

a { color: var(--pink); text-decoration: none; }
a:hover { text-decoration: underline; }

:focus-visible { outline: 3px solid var(--pink); outline-offset: 3px; border-radius: 4px; }

/* ── Top nav ─────────────────────────────────────────── */
.site-nav {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
    padding: 18px clamp(16px, 4vw, 32px);
}
.site-nav__brand { display: inline-flex; align-items: center; }
.site-nav__brand img { height: 60px; width: auto; display: block; }
.site-nav__links { display: flex; gap: clamp(14px, 3vw, 28px); align-items: center; }
.site-nav__links a {
    color: var(--muted);
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-decoration: none;
    transition: color 0.2s ease;
}
.site-nav__links a:hover { color: #fff; text-decoration: none; }
.site-nav__links a[aria-current="page"] {
    color: #fff;
    background: var(--grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ── Content pages (article) ─────────────────────────── */
.container {
    position: relative;
    z-index: 1;
    flex: 1 0 auto;
    width: 100%;
    max-width: 820px;
    margin: 0 auto;
    padding: clamp(20px, 4vw, 40px) clamp(16px, 4vw, 32px) 60px;
}
.content { }
.content h1 {
    font-size: clamp(28px, 5vw, 40px);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin-bottom: 18px;
    text-wrap: balance;
    background: var(--grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.content h2 {
    font-size: clamp(20px, 3vw, 25px);
    font-weight: 700;
    color: #fff;
    margin: 40px 0 14px;
    letter-spacing: -0.01em;
}
.content h3 { font-size: 17px; font-weight: 650; color: #fff; margin: 24px 0 10px; }
.content p { color: var(--muted); margin-bottom: 16px; max-width: 65ch; }
.content ul, .content ol { color: var(--muted); margin: 0 0 16px 22px; }
.content li { margin-bottom: 8px; }
.content strong { color: #fff; }
.content .lede { font-size: clamp(16px, 2vw, 18px); color: rgba(255,255,255,0.8); margin-bottom: 8px; }
.content .updated { color: var(--faint); font-size: 14px; margin-bottom: 28px; }

.card {
    background: var(--card);
    border: 1px solid var(--border-soft);
    border-radius: 16px;
    padding: clamp(22px, 4vw, 34px);
    margin-bottom: 20px;
}

.content details {
    border-top: 1px solid var(--border-soft);
    padding: 15px 0;
}
.content details summary {
    cursor: pointer;
    font-weight: 600;
    color: #fff;
    font-size: 15px;
    list-style: none;
}
.content details summary::-webkit-details-marker { display: none; }
.content details summary::before { content: "＋ "; color: var(--purple); font-weight: 700; }
.content details[open] summary::before { content: "－ "; }
.content details p { margin: 10px 0 0; font-size: 14.5px; color: rgba(255,255,255,0.68); }

.back-link { display: inline-block; margin-bottom: 20px; font-weight: 600; color: var(--muted); }
.back-link:hover { color: #fff; text-decoration: none; }

.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 32px;
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    background: var(--grad);
    border: none;
    border-radius: 12px;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(138, 43, 226, 0.4); text-decoration: none; }

/* ── Ad slot ─────────────────────────────────────────── */
.adslot { margin: 30px auto; max-width: 728px; }
.adslot__label {
    font-size: 10px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.3);
    text-align: center;
    margin-bottom: 6px;
}
.adslot__placeholder {
    min-height: 120px;
    border: 1px dashed rgba(255, 255, 255, 0.15);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.25);
    font-size: 12px;
}

/* ── Footer ──────────────────────────────────────────── */
.site-footer {
    position: relative;
    z-index: 1;
    flex-shrink: 0;
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
    padding: 28px clamp(16px, 4vw, 32px) 40px;
    border-top: 1px solid var(--border-soft);
    text-align: center;
    color: var(--faint);
    font-size: 13px;
}
.site-footer__links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 20px;
    justify-content: center;
    margin-bottom: 12px;
}
.site-footer__links a { color: var(--muted); font-weight: 500; }
.site-footer__links a:hover { color: #fff; text-decoration: none; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
    }
}
