/* ============================================================
   DSGVO GLASS EDITORIAL – components.css
   ============================================================ */

/* ============================================================
   READING PROGRESS
   ============================================================ */
.reading-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 0%;
    height: 2px;
    background: linear-gradient(90deg, var(--clr-accent-dim), var(--clr-accent), #e0f2fe);
    z-index: 9999;
    box-shadow: 0 0 12px var(--clr-accent-glow);
    transition: width .1s linear;
}

/* ============================================================
   SITE HEADER – Glass strip
   ============================================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 800;
    padding: 0;
}

.site-header__inner {
    background: rgba(6, 8, 16, 0.88);
    backdrop-filter: blur(24px) saturate(1.6);
    -webkit-backdrop-filter: blur(24px) saturate(1.6);
    border-bottom: 1px solid var(--clr-glass-border);
    box-shadow: 0 1px 0 rgba(255,255,255,0.06), 0 4px 30px rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    height: 60px;
    padding: 0 var(--sp-xl);
    gap: var(--sp-xl);
    border-radius: 0 0 var(--glass-radius) var(--glass-radius);
    border-left: 1px solid var(--clr-glass-border);
    border-right: 1px solid var(--clr-glass-border);
}

/* Logo */
.site-header__brand { flex-shrink: 0; }

.site-header__logo-text {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    gap: 1px;
}

.site-header__logo-name {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--clr-text);
    letter-spacing: -.02em;
    line-height: 1;
}

.site-header__logo-tag {
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--clr-accent);
    display: flex;
    align-items: center;
    gap: 5px;
    text-shadow: 0 0 10px var(--clr-accent-glow);
}

/* Nav */
.nav { flex: 1; }

.nav__list {
    display: flex;
    align-items: center;
    gap: 2px;
}

.nav__link {
    padding: 7px 12px;
    font-size: 12px;
    font-weight: 500;
    color: var(--clr-muted);
    border-radius: 8px;
    transition: color var(--dur-sm) var(--ease), background var(--dur-sm) var(--ease);
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 4px;
}

.nav__link:hover,
.nav__item.current-menu-item .nav__link {
    color: var(--clr-text);
    background: rgba(255,255,255,0.06);
}

.nav__item.current-menu-item .nav__link { color: var(--clr-accent); }

/* Dropdown */
.nav__dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 180px;
    background: rgba(8, 12, 22, 0.95);
    backdrop-filter: blur(20px);
    border: 1px solid var(--clr-glass-border);
    border-radius: 12px;
    padding: 6px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all var(--dur-sm) var(--ease);
    box-shadow: 0 0 30px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.06);
}

.nav__item--has-dropdown { position: relative; }
.nav__item--has-dropdown:hover .nav__dropdown,
.nav__item--has-dropdown:focus-within .nav__dropdown {
    opacity: 1; visibility: visible; transform: translateY(0);
}

.nav__chevron { font-size: 12px; transition: transform var(--dur-sm) var(--ease); }
.nav__item--has-dropdown:hover .nav__chevron { transform: rotate(90deg); }

/* Header actions */
.site-header__actions {
    display: flex;
    align-items: center;
    gap: var(--sp-md);
    margin-left: auto;
}

/* Search */
.search-form { position: relative; }

.search-field {
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--clr-glass-border);
    border-radius: 100px;
    color: var(--clr-text);
    font-family: var(--font-mono);
    font-size: 11px;
    padding: 7px 34px 7px 14px;
    width: 160px;
    outline: none;
    transition: border-color var(--dur-sm), width var(--dur-md) var(--ease), box-shadow var(--dur-sm);
}

.search-field::placeholder { color: var(--clr-muted); }

.search-field:focus {
    border-color: rgba(56,189,248,0.5);
    box-shadow: 0 0 12px rgba(56,189,248,0.15);
    width: 200px;
}

.search-submit {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: var(--clr-muted);
    font-size: 12px;
    padding: 0;
    transition: color var(--dur-sm);
}
.search-submit:hover { color: var(--clr-accent); }

/* Mobile toggle */
.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px;
}
.nav-toggle__bar {
    display: block;
    width: 20px;
    height: 1.5px;
    background: var(--clr-muted);
    border-radius: 1px;
    transition: transform var(--dur-md) var(--ease), opacity var(--dur-md);
}

/* ============================================================
   CATEGORY STRIPE
   ============================================================ */
.category-stripe {
    padding: 8px 0;
}

.category-stripe__inner-wrap {
    padding: 0;
}

.category-stripe__inner {
    background: rgba(6, 8, 16, 0.75);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 100px;
    padding: 8px 20px;
    display: flex;
    align-items: center;
    gap: var(--sp-md);
    overflow-x: auto;
    scrollbar-width: none;
}
.category-stripe__inner::-webkit-scrollbar { display: none; }

.category-stripe__link {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--clr-muted);
    text-decoration: none;
    white-space: nowrap;
    padding: 2px 0;
    border-bottom: 1px solid transparent;
    transition: color var(--dur-sm), border-color var(--dur-sm);
}
.category-stripe__link:hover,
.category-stripe__link.is-active {
    color: var(--clr-accent);
    border-bottom-color: var(--clr-accent);
    text-shadow: 0 0 10px var(--clr-accent-glow);
}

/* ============================================================
   HERO POST
   ============================================================ */
.hero-post {
    padding: var(--sp-md) 0 0;
    animation: fadeUp .7s var(--ease) both;
}

.hero-post__wrap {
    position: relative;
    border-radius: var(--glass-radius);
    overflow: hidden;
    box-shadow: var(--glass-shadow);
    border: 1px solid var(--clr-glass-border);
    min-height: 480px;
    display: flex;
    align-items: flex-end;
}

/* Background image */
.hero-post__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(.4) saturate(.7);
    transition: filter var(--dur-lg) var(--ease);
}
.hero-post__wrap:hover .hero-post__image { filter: brightness(.5) saturate(.8); }

/* Gradient overlay */
.hero-post__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(6,8,16,.98) 0%,
        rgba(6,8,16,.75) 35%,
        rgba(6,8,16,.2) 100%
    );
}

/* Glass content box */
.hero-post__content {
    position: relative;
    z-index: 2;
    padding: var(--sp-xl);
    width: 100%;
    background: linear-gradient(to top, rgba(6,8,16,0.7), transparent);
    backdrop-filter: blur(4px);
}

.hero-post__meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--sp-sm);
    margin-bottom: var(--sp-md);
    animation: fadeUp .6s .1s var(--ease) both;
}

.hero-post__title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -.03em;
    color: #fff;
    margin-bottom: var(--sp-md);
    animation: fadeUp .6s .15s var(--ease) both;
}
.hero-post__title a { color: #fff; }
.hero-post__title a:hover { color: var(--clr-accent); text-shadow: 0 0 20px var(--clr-accent-glow); }

.hero-post__excerpt {
    font-size: 1rem;
    color: rgba(255,255,255,.7);
    max-width: 55ch;
    line-height: 1.65;
    margin-bottom: var(--sp-xl);
    animation: fadeUp .6s .2s var(--ease) both;
}

.hero-post__footer {
    display: flex;
    align-items: center;
    gap: var(--sp-xl);
    animation: fadeUp .6s .25s var(--ease) both;
}

.hero-post__author {
    display: flex;
    align-items: center;
    gap: var(--sp-sm);
}
.hero-post__avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 1px solid var(--clr-glass-border);
    object-fit: cover;
}
.hero-post__author-name { font-size: 13px; font-weight: 500; color: rgba(255,255,255,.8); }

/* DSGVO corner badge */
.hero-post__badge {
    position: absolute;
    top: var(--sp-md);
    right: var(--sp-md);
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(6,8,16,.7);
    border: 1px solid rgba(56,189,248,.3);
    border-radius: 100px;
    padding: 5px 12px;
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: .14em;
    color: var(--clr-accent);
    backdrop-filter: blur(10px);
    text-shadow: 0 0 10px var(--clr-accent-glow);
}

/* ============================================================
   NEWS TICKER
   ============================================================ */
.news-ticker {
    padding: 6px 0;
}
.news-ticker__wrap {
    background: rgba(6,8,16,.7);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 100px;
    padding: 8px 20px;
    display: flex;
    align-items: center;
    gap: var(--sp-lg);
    overflow: hidden;
}
.news-ticker__track {
    display: flex;
    gap: var(--sp-xl);
    overflow-x: auto;
    scrollbar-width: none;
    flex: 1;
}
.news-ticker__track::-webkit-scrollbar { display: none; }
.news-ticker__item {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .08em;
    color: var(--clr-muted);
    white-space: nowrap;
    text-decoration: none;
    flex-shrink: 0;
    transition: color var(--dur-sm);
}
.news-ticker__item::before { content: '▸ '; color: var(--clr-accent); }
.news-ticker__item:hover { color: var(--clr-text); }

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-header {
    padding: var(--sp-xl) 0 var(--sp-md);
}
.section-header__title {
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 3vw, 2rem);
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--clr-text);
}

/* ============================================================
   BLOG LAYOUT
   ============================================================ */
.blog-layout {
    padding: 0 0 var(--sp-2xl);
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 240px;
    gap: var(--sp-xl);
    align-items: start;
}

/* Homepage: no sidebar column – posts span full hero width */
.blog-layout--full {
    grid-template-columns: 1fr;
}

.posts-area { min-width: 0; }

/* Posts grid */
.posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sp-md);
}

/* On full-width layout the first card spans all columns */
.blog-layout--full .posts-grid .post-card:first-child {
    grid-column: 1 / -1;
    flex-direction: row;
}
.blog-layout--full .posts-grid .post-card:first-child .post-card__image-wrap {
    flex: 0 0 50%;
    max-height: 340px;
}
.blog-layout--full .posts-grid .post-card:first-child .post-card__body {
    padding: var(--sp-xl);
    justify-content: center;
}

/* ============================================================
   POST CARD – Glass
   ============================================================ */
.post-card {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur)) saturate(1.3);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(1.3);
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: border-color var(--dur-md) var(--ease),
                box-shadow var(--dur-md) var(--ease),
                transform var(--dur-md) var(--ease);
}

.post-card:hover {
    border-color: rgba(255,255,255,0.32);
    box-shadow: var(--glass-shadow-hover);
    transform: translateY(-5px);
}

/* Wide card spans full columns */
.post-card--wide {
    grid-column: 1 / -1;
    flex-direction: row;
}
.post-card--wide .post-card__image-wrap {
    flex: 0 0 50%;
    max-height: 320px;
}
.post-card--wide .post-card__body {
    padding: var(--sp-xl);
    justify-content: center;
}

.post-card__image-link { display: block; overflow: hidden; }
.post-card__image-wrap { position: relative; overflow: hidden; max-height: 200px; }
.post-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--dur-lg) var(--ease), filter var(--dur-md) var(--ease);
    filter: saturate(.75) brightness(.85);
}
.post-card:hover .post-card__image { transform: scale(1.05); filter: saturate(1) brightness(1); }

.post-card__dsgvo-pin {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 26px;
    height: 26px;
    background: rgba(6,8,16,.75);
    border: 1px solid rgba(56,189,248,.3);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(8px);
}

.post-card__placeholder {
    height: 160px;
    background: linear-gradient(135deg, rgba(56,189,248,.05) 0%, rgba(6,8,16,.8) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}
.post-card__placeholder svg { width: 48px; height: 48px; opacity: .3; }

.post-card__body {
    padding: var(--sp-md) var(--sp-lg);
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 6px;
}

.post-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.post-card__title {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 600;
    line-height: 1.25;
    flex: 1;
}
.post-card__title a { color: var(--clr-text); transition: color var(--dur-sm); }
.post-card__title a:hover { color: var(--clr-accent); text-shadow: 0 0 12px var(--clr-accent-glow); }

.post-card__excerpt {
    font-size: .875rem;
    color: var(--clr-muted);
    line-height: 1.6;
}

.post-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--sp-sm);
    margin-top: auto;
    border-top: 1px solid rgba(255,255,255,.07);
}

.post-card__author { display: flex; align-items: center; gap: 7px; }
.post-card__author-avatar { border-radius: 50%; width: 22px; height: 22px; object-fit: cover; }
.post-card__author-name { font-size: 11px; color: var(--clr-muted); }

.post-card__read-link {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .1em;
    color: var(--clr-accent);
    text-shadow: 0 0 8px var(--clr-accent-glow);
    transition: letter-spacing var(--dur-sm);
}
.post-card__read-link:hover { letter-spacing: .15em; color: var(--clr-accent); }

/* ============================================================
   CATEGORY BADGE
   ============================================================ */
.category-badge {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 9px;
    font-weight: 500;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--clr-accent);
    background: rgba(56,189,248,.1);
    border: 1px solid rgba(56,189,248,.2);
    border-radius: 100px;
    padding: 3px 9px;
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--dur-sm), box-shadow var(--dur-sm);
    text-shadow: 0 0 8px var(--clr-accent-glow);
}
.category-badge:hover {
    background: rgba(56,189,248,.18);
    box-shadow: 0 0 12px var(--clr-accent-glow);
    color: var(--clr-accent);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-radius: 100px;
    padding: 10px 22px;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--dur-sm) var(--ease);
}

.btn--primary {
    background: rgba(56,189,248,.15);
    color: var(--clr-accent);
    border-color: rgba(56,189,248,.35);
    backdrop-filter: blur(10px);
    box-shadow: 0 0 16px rgba(56,189,248,.1);
    text-shadow: 0 0 8px var(--clr-accent-glow);
}
.btn--primary:hover {
    background: rgba(56,189,248,.25);
    border-color: rgba(56,189,248,.6);
    box-shadow: 0 0 30px rgba(56,189,248,.2);
    color: var(--clr-accent);
}

/* ============================================================
   POST HERO (single.php)
   ============================================================ */
.post-hero {
    padding: var(--sp-lg) 0 0;
    animation: fadeUp .6s var(--ease) both;
}



.post-hero__glass {
    background: var(--clr-glass-bg);
    backdrop-filter: blur(var(--glass-blur)) saturate(1.4);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(1.4);
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-xl);
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
}

/* Subtle inner glow top */
.post-hero__glass::before {
    content: '';
    position: absolute;
    top: 0;
    left: 20%;
    right: 20%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
}

.post-hero__grid-bg {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(56,189,248,.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(56,189,248,.03) 1px, transparent 1px);
    background-size: 44px 44px;
    pointer-events: none;
}

.post-hero__meta-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--sp-sm);
    margin-bottom: var(--sp-lg);
    animation: fadeUp .5s .1s var(--ease) both;
}
.post-hero__sep { color: rgba(255,255,255,.15); }

.post-hero__title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -.03em;
    color: var(--clr-text);
    max-width: 22ch;
    margin-bottom: var(--sp-lg);
    animation: fadeUp .5s .15s var(--ease) both;
}

.post-hero__excerpt {
    font-size: 1rem;
    color: var(--clr-text-soft);
    max-width: 58ch;
    line-height: 1.7;
    margin-bottom: var(--sp-xl);
    animation: fadeUp .5s .2s var(--ease) both;
}

.post-hero__byline {
    display: flex;
    align-items: center;
    gap: var(--sp-md);
    padding-top: var(--sp-lg);
    border-top: 1px solid rgba(255,255,255,.08);
    animation: fadeUp .5s .25s var(--ease) both;
}
.post-hero__avatar {
    width: 42px; height: 42px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.2);
    object-fit: cover;
}
.post-hero__author-name { font-size: 13px; font-weight: 600; color: var(--clr-text); }
.post-hero__share { margin-left: auto; }

.share-btn {
    background: rgba(255,255,255,.06);
    border: 1px solid var(--clr-glass-border);
    border-radius: 100px;
    color: var(--clr-muted);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .1em;
    padding: 6px 14px;
    cursor: pointer;
    transition: all var(--dur-sm);
}
.share-btn:hover { color: var(--clr-accent); border-color: rgba(56,189,248,.4); box-shadow: 0 0 12px var(--clr-accent-glow); }

/* ============================================================
   FEATURED IMAGE (single)
   ============================================================ */
.post-featured-image {
    padding: var(--sp-md) 0 0;
    animation: fadeUp .6s .3s var(--ease) both;
}
.post-featured-image__inner {
    position: relative;
    border-radius: var(--glass-radius);
    overflow: hidden;
    border: 1px solid var(--clr-glass-border);
    box-shadow: var(--glass-shadow);
}
.post-featured-image__inner img {
    width: 100%;
    max-height: 500px;
    object-fit: cover;
    display: block;
    filter: saturate(.85) brightness(.9);
    transition: filter var(--dur-lg) var(--ease);
}
.post-featured-image__inner:hover img { filter: saturate(1) brightness(1); }
.post-featured-image__badge {
    position: absolute;
    top: var(--sp-md);
    right: var(--sp-md);
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(6,8,16,.8);
    border: 1px solid rgba(56,189,248,.3);
    border-radius: 100px;
    padding: 5px 12px;
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: .14em;
    color: var(--clr-accent);
    backdrop-filter: blur(10px);
    text-shadow: 0 0 10px var(--clr-accent-glow);
}
.post-featured-image__caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 8px 14px;
    background: rgba(6,8,16,.7);
    backdrop-filter: blur(6px);
}

/* ============================================================
   ARTICLE BODY
   ============================================================ */
.post-article {
    padding: var(--sp-md) 0 var(--sp-2xl);
    animation: fadeUp .6s .35s var(--ease) both;
}

.post-article__inner {
    display: block;
}

/* Sticky ToC */
.post-toc {
    display: none;
}
.post-toc__glass {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-md);
}
.post-toc__label { display: block; margin-bottom: var(--sp-sm); padding-bottom: 8px; border-bottom: 1px solid rgba(255,255,255,.07); }
#toc-nav a {
    display: block;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--clr-muted);
    padding: 5px 0 5px 10px;
    border-left: 2px solid transparent;
    text-decoration: none;
    line-height: 1.4;
    transition: color var(--dur-sm), border-color var(--dur-sm);
}
#toc-nav a:hover, #toc-nav a.is-active { color: var(--clr-accent); border-left-color: var(--clr-accent); text-shadow: 0 0 8px var(--clr-accent-glow); }

/* Content glass box */
.post-content-glass {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur)) saturate(1.3);
    -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(1.3);
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-xl);
    position: relative;
    overflow: hidden;
}
.post-content-glass::before {
    content: '';
    position: absolute;
    top: 0; left: 15%; right: 15%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
}

/* ============================================================
   TYPOGRAPHY: POST CONTENT
   ============================================================ */
.post-content {
    font-size: 1.02rem;
    line-height: 1.88;
    color: var(--clr-text-soft);
    min-width: 0;
}
.post-content p { margin-bottom: 1.55em; }

/* Drop cap */
.post-content > p:first-of-type::first-letter {
    font-family: var(--font-display);
    font-size: 3.8em;
    font-weight: 700;
    float: left;
    line-height: .82;
    margin: .05em .14em 0 0;
    color: var(--clr-accent);
    text-shadow: 0 0 20px var(--clr-accent-glow);
}

.post-content h2 {
    font-family: var(--font-display);
    font-size: 1.55rem;
    font-weight: 700;
    color: var(--clr-text);
    margin: 2.2em 0 .7em;
    padding-bottom: .5em;
    border-bottom: 1px solid rgba(255,255,255,.08);
    letter-spacing: -.02em;
}

.post-content h3 {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--clr-text);
    margin: 2em 0 .6em;
}

.post-content h4 {
    font-family: var(--font-mono);
    font-size: .85rem;
    font-weight: 500;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--clr-accent);
    margin: 1.8em 0 .5em;
    text-shadow: 0 0 8px var(--clr-accent-glow);
}

.post-content a { color: var(--clr-accent); text-decoration-color: rgba(56,189,248,.3); text-underline-offset: 3px; }
.post-content a:hover { text-decoration-color: var(--clr-accent); }

.post-content blockquote {
    border-left: 2px solid var(--clr-accent);
    margin: 2em 0;
    padding: var(--sp-lg) var(--sp-xl);
    background: rgba(56,189,248,.05);
    border-radius: 0 var(--glass-radius) var(--glass-radius) 0;
    backdrop-filter: blur(8px);
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-style: italic;
    color: var(--clr-text);
    line-height: 1.6;
    box-shadow: inset 0 0 20px rgba(56,189,248,.03);
}

.post-content code {
    font-family: var(--font-mono);
    font-size: .85em;
    background: rgba(56,189,248,.08);
    color: #7dd3fc;
    border: 1px solid rgba(56,189,248,.15);
    padding: 2px 7px;
    border-radius: 5px;
}

.post-content pre {
    background: rgba(6,8,16,.8);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--glass-radius);
    padding: var(--sp-lg) var(--sp-xl);
    overflow-x: auto;
    margin: 2em 0;
    backdrop-filter: blur(8px);
}
.post-content pre code { background: none; border: none; padding: 0; font-size: .85rem; line-height: 1.7; }

.post-content ul, .post-content ol { padding-left: 1.8em; margin-bottom: 1.6em; }
.post-content li { margin-bottom: .5em; }
.post-content ul li::marker { color: var(--clr-accent); }

.post-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 2em 0;
    font-size: .9rem;
}
.post-content th {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--clr-muted);
    padding: 10px 14px;
    border-bottom: 1px solid rgba(255,255,255,.1);
    text-align: left;
}
.post-content td { padding: 10px 14px; border-bottom: 1px solid rgba(255,255,255,.05); color: var(--clr-text-soft); }
.post-content tr:hover td { background: rgba(56,189,248,.03); }

/* DSGVO card inside content */
.dsgvo-card {
    background: rgba(56,189,248,.05);
    border: 1px solid rgba(56,189,248,.2);
    border-left: 3px solid var(--clr-accent);
    border-radius: 0 var(--glass-radius) var(--glass-radius) 0;
    padding: var(--sp-lg) var(--sp-xl);
    margin: 2em 0;
    backdrop-filter: blur(8px);
    box-shadow: 0 0 20px rgba(56,189,248,.05);
}
.dsgvo-card__header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.dsgvo-card__body { font-size: .92rem; color: var(--clr-text-soft); line-height: 1.7; }

/* ============================================================
   POST FOOTER ELEMENTS
   ============================================================ */
.post-footer {
    padding: 0 0 var(--sp-2xl);
}
.post-footer__inner {
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
}

/* Tags */
.post-tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: var(--sp-lg);
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
}

.tag-chip {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--clr-muted);
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 100px;
    padding: 4px 11px;
    text-decoration: none;
    transition: all var(--dur-sm);
}
.tag-chip:hover {
    color: var(--clr-accent);
    border-color: rgba(56,189,248,.35);
    box-shadow: 0 0 10px var(--clr-accent-glow);
}

/* Author card */
.author-card {
    display: grid;
    grid-template-columns: 72px 1fr;
    gap: var(--sp-lg);
    align-items: start;
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-xl);
}
.author-card__avatar { width: 72px; height: 72px; border-radius: 50%; border: 1px solid rgba(255,255,255,.2); object-fit: cover; }
.author-card__name { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--clr-text); margin-bottom: 6px; }
.author-card__bio { font-size: .88rem; line-height: 1.65; color: var(--clr-muted); margin-bottom: var(--sp-sm); }
.author-card__link { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; color: var(--clr-accent); text-shadow: 0 0 8px var(--clr-accent-glow); }

/* Post navigation */
.post-navigation {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-md);
}
.post-nav-link {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: var(--sp-lg);
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    text-decoration: none;
    transition: border-color var(--dur-md), box-shadow var(--dur-md);
}
.post-nav-link:hover { border-color: rgba(255,255,255,.28); box-shadow: var(--glass-shadow-hover); }
.post-nav-link--next { text-align: right; }
.post-nav-link__title { font-family: var(--font-display); font-size: .95rem; font-weight: 600; color: var(--clr-text); line-height: 1.3; }

/* ============================================================
   RELATED POSTS
   ============================================================ */
.related-posts {
    padding: 0 0 var(--sp-2xl);
}

.related-posts__heading {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--clr-muted);
    margin-bottom: var(--sp-lg);
    display: flex;
    align-items: center;
    gap: var(--sp-md);
}
.related-posts__heading::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,.07); }
.related-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--sp-md); }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination {
    margin-top: var(--sp-xl);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--clr-muted);
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(10px);
    border: 1px solid var(--clr-glass-border);
    border-radius: 8px;
    text-decoration: none;
    transition: all var(--dur-sm);
}
.pagination .current,
.pagination .page-numbers:hover {
    color: var(--clr-accent);
    border-color: rgba(56,189,248,.4);
    box-shadow: 0 0 14px rgba(56,189,248,.12);
    text-shadow: 0 0 8px var(--clr-accent-glow);
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
    position: sticky;
    top: 74px;
}
.widget {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-lg);
}
.widget__title {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--clr-muted);
    margin-bottom: var(--sp-md);
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.widget-recent__list { display: flex; flex-direction: column; gap: 10px; }
.widget-recent__item { display: flex; flex-direction: column; gap: 2px; }
.widget-recent__link { font-size: .88rem; font-weight: 500; color: var(--clr-text-soft); transition: color var(--dur-sm); }
.widget-recent__link:hover { color: var(--clr-accent); text-shadow: 0 0 8px var(--clr-accent-glow); }
.widget-categories__list { display: flex; flex-direction: column; }
.widget-categories__item a {
    display: flex; justify-content: space-between; align-items: center;
    font-size: .88rem; color: var(--clr-muted);
    padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,.05);
    text-decoration: none; transition: color var(--dur-sm);
}
.widget-categories__item a:hover { color: var(--clr-accent); }
.widget-categories__count { font-family: var(--font-mono); font-size: 10px; color: rgba(255,255,255,.15); }

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-section {
    padding: 0 0 var(--sp-2xl);
}

.comments-section__title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; color: var(--clr-text); margin-bottom: var(--sp-xl); }
.comment-list { display: flex; flex-direction: column; gap: var(--sp-md); }
.comment-body {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-lg);
}
.comment-header { display: flex; align-items: center; gap: var(--sp-md); margin-bottom: var(--sp-md); }
.comment-avatar { border-radius: 50%; width: 40px; height: 40px; object-fit: cover; border: 1px solid rgba(255,255,255,.15); }
.comment-author-name { font-size: 13px; font-weight: 600; color: var(--clr-text); display: block; }
.comment-text { font-size: .92rem; color: var(--clr-text-soft); line-height: 1.7; }
.comment-text p { margin-bottom: .7em; }
.comment-actions { margin-left: auto; }
.comment-actions a { font-family: var(--font-mono); font-size: 10px; color: var(--clr-muted); transition: color var(--dur-sm); }
.comment-actions a:hover { color: var(--clr-accent); }
.comment-form { margin-top: var(--sp-2xl); }
.comment-form label { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--clr-muted); margin-bottom: 6px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    width: 100%;
    background: rgba(255,255,255,.04);
    border: 1px solid var(--clr-glass-border);
    border-radius: 10px;
    color: var(--clr-text);
    font-family: var(--font-body);
    font-size: .95rem;
    padding: 10px 14px;
    outline: none;
    backdrop-filter: blur(8px);
    transition: border-color var(--dur-sm), box-shadow var(--dur-sm);
}
.comment-form input:focus, .comment-form textarea:focus {
    border-color: rgba(56,189,248,.4);
    box-shadow: 0 0 14px rgba(56,189,248,.1);
}
.comment-form textarea { min-height: 130px; resize: vertical; }
.comment-form p { margin-bottom: var(--sp-md); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { }
.site-footer__inner {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-xl);
}
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--sp-xl); margin-bottom: var(--sp-xl); padding-bottom: var(--sp-xl); border-bottom: 1px solid rgba(255,255,255,.07); }
.footer-brand__name { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--clr-text); letter-spacing: -.02em; margin-bottom: 6px; }
.footer-brand__desc { font-size: .85rem; color: var(--clr-muted); line-height: 1.6; }
.footer-col__title { font-family: var(--font-mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--clr-muted); margin-bottom: var(--sp-md); }
.footer-col__links { display: flex; flex-direction: column; gap: 8px; }
.footer-col__links a { font-size: .88rem; color: var(--clr-muted); text-decoration: none; transition: color var(--dur-sm); }
.footer-col__links a:hover { color: var(--clr-accent); text-shadow: 0 0 8px var(--clr-accent-glow); }
.footer-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--sp-md); }
.footer-bar__copy { font-family: var(--font-mono); font-size: 10px; color: var(--clr-muted); letter-spacing: .06em; }
.footer-badges { display: flex; gap: 8px; }
.footer-badge {
    display: flex; align-items: center; gap: 5px;
    font-family: var(--font-mono); font-size: 9px; letter-spacing: .12em;
    color: var(--clr-muted);
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 100px; padding: 4px 10px;
}
.footer-badge__dot { width: 5px; height: 5px; border-radius: 50%; background: var(--clr-accent); box-shadow: 0 0 6px var(--clr-accent); }

/* ============================================================
   MISC PAGES
   ============================================================ */
.archive-header, .page-header {
    padding: var(--sp-xl) 0 var(--sp-md);
}
.archive-header__inner, .page-header__inner {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-xl);
}
.archive-header__title, .page-header__title {
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 3vw, 2.2rem);
    font-weight: 700;
    color: var(--clr-text);
    margin-bottom: 8px;
    letter-spacing: -.02em;
}
.archive-header__desc { color: var(--clr-muted); font-size: .92rem; }
.page-content, .error-404-content, .no-results-content {
    padding: var(--sp-md) 0 var(--sp-2xl);
}
.page-content__glass, .error-404-content__glass, .no-results-content__glass {
    background: var(--clr-glass-bg-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--clr-glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
    padding: var(--sp-xl);
}
.entry-content p { color: var(--clr-text-soft); line-height: 1.8; margin-bottom: 1.4em; }

.error-404__code { font-family: var(--font-mono); font-size: 64px; color: rgba(255,255,255,.06); display: block; line-height: 1; margin-bottom: var(--sp-md); }
.error-404__title { font-family: var(--font-display); font-size: 1.8rem; font-weight: 700; color: var(--clr-text); margin-bottom: var(--sp-md); }
.error-404__text { color: var(--clr-muted); margin-bottom: var(--sp-xl); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
/* Mobile nav */
    .nav {
        display: none;
        position: fixed;
        inset: 60px 0 0;
        background: rgba(6,8,16,.97);
        backdrop-filter: blur(20px);
        padding: var(--sp-xl);
        overflow-y: auto;
        border-top: 1px solid var(--clr-glass-border);
    }
    .nav.is-open { display: block; }
    .nav__list { flex-direction: column; gap: 4px; }
    .nav__link { padding: 12px 16px; font-size: 15px; border-radius: 10px; }
    .nav-toggle { display: flex; }
    .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
    .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }
    .nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

    .site-header__inner { padding: 0 var(--sp-md); }
    .search-field { width: 120px; }
    .search-field:focus { width: 150px; }
}

/* Portrait phones: show only 1/3 of each image */

