/*
Theme Name:  eric.metze.us
Theme URI:   https://eric.metze.us
Description: Custom theme for eric.metze.us — Nerd Practitioner portfolio and timeline.
Version:     1.2.1
Author:      The Duumvirati
Author URI:  https://eric.metze.us
License:     GPL-2.0+
Text Domain: eric-metze-us
*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--color-bg:#0d0d0d;--color-surface:#161616;--color-border:#2a2a2a;--color-text:#e8e8e8;--color-muted:#888;--color-accent:#c8a96e;--color-accent-dk:#a8893e;--color-link:#c8a96e;--font-sans:'Inter',system-ui,-apple-system,sans-serif;--font-mono:'JetBrains Mono','Fira Code',monospace;--radius:6px;--max-w:1200px;--max-w-prose:720px;--nav-h:64px;--transition:0.2s ease}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.7;-webkit-font-smoothing:antialiased}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--color-link);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-accent-dk)}
.metze-container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.metze-container--prose{max-width:var(--max-w-prose);margin:0 auto;padding:0 24px}
.site-header{position:sticky;top:0;z-index:100;height:var(--nav-h);background:rgba(13,13,13,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.site-header__logo{font-size:1.1rem;font-weight:700;letter-spacing:-0.02em;color:var(--color-text);white-space:nowrap}
.site-header__logo span{color:var(--color-accent)}
.site-header__logo:hover{color:var(--color-text)}
.site-nav{display:flex;align-items:center;gap:2rem;list-style:none}
.site-nav a{font-size:0.875rem;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;color:var(--color-muted);transition:color var(--transition)}
.site-nav a:hover,.site-nav .current-menu-item a{color:var(--color-accent)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--color-text)}
.nav-toggle span{display:block;width:22px;height:2px;background:currentColor;margin:4px 0;transition:all var(--transition)}
.metze-hero{min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column;justify-content:center;padding:80px 24px;max-width:var(--max-w);margin:0 auto}
.metze-hero__eyebrow{font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1rem}
.metze-hero__title{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;line-height:1.05;letter-spacing:-0.03em;margin-bottom:1.5rem}
.metze-hero__bio{font-size:1.15rem;color:var(--color-muted);max-width:600px;line-height:1.8;margin-bottom:2.5rem}
.metze-hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.metze-btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.75rem 1.5rem;border-radius:var(--radius);font-size:0.875rem;font-weight:600;letter-spacing:0.03em;text-transform:uppercase;transition:all var(--transition);cursor:pointer;border:none}
.metze-btn--primary{background:var(--color-accent);color:#0d0d0d}
.metze-btn--primary:hover{background:var(--color-accent-dk);color:#0d0d0d}
.metze-btn--outline{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}
.metze-btn--outline:hover{background:var(--color-accent);color:#0d0d0d}
.metze-section{padding:80px 0}
.metze-section__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2.5rem;gap:1rem;flex-wrap:wrap}
.metze-section__title{font-size:1.75rem;font-weight:700;letter-spacing:-0.02em}
.metze-section__link{font-size:0.8rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-muted);white-space:nowrap}
.metze-section__link:hover{color:var(--color-accent)}
.metze-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.metze-grid-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition),transform var(--transition)}
.metze-grid-item:hover{border-color:var(--color-accent);transform:translateY(-3px)}
.metze-grid-item__inner{display:flex;flex-direction:column;height:100%;color:var(--color-text)}
.metze-grid-item__inner:hover{color:var(--color-text)}
.metze-grid-item img{width:100%;aspect-ratio:16/9;object-fit:cover}
.metze-grid-item__placeholder{width:100%;aspect-ratio:16/9;background:var(--color-border)}
.metze-grid-item__thumb{position:relative}
.metze-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2.5rem;color:#fff;opacity:0;transition:opacity var(--transition);text-shadow:0 2px 12px rgba(0,0,0,.7)}
.metze-grid-item:hover .metze-play-icon{opacity:1}
.metze-platform-badge{position:absolute;bottom:8px;right:8px;padding:2px 8px;border-radius:3px;font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.05em}
.metze-platform-youtube{background:#ff0000;color:#fff}
.metze-platform-vimeo{background:#1ab7ea;color:#fff}
.metze-grid-item__meta{padding:16px;flex:1}
.metze-grid-item__title{font-size:1rem;font-weight:600;margin-bottom:4px;line-height:1.3}
.metze-grid-item__sub,.metze-grid-item__date{font-size:0.8rem;color:var(--color-muted)}
.metze-video-wrap{position:relative;width:100%;overflow:hidden;background:#000}
.metze-ratio-16x9{padding-top:56.25%}
.metze-ratio-4x3{padding-top:75%}
.metze-video-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.metze-posts-list{display:flex;flex-direction:column;gap:0}
.metze-post-card{padding:24px 0;border-bottom:1px solid var(--color-border);display:flex;gap:24px;align-items:flex-start}
.metze-post-card__date{font-size:0.75rem;color:var(--color-muted);white-space:nowrap;min-width:90px;padding-top:4px;font-variant-numeric:tabular-nums}
.metze-post-card__body{flex:1}
.metze-post-card__title{font-size:1.1rem;font-weight:600;line-height:1.3;margin-bottom:6px}
.metze-post-card__title a{color:var(--color-text)}
.metze-post-card__title a:hover{color:var(--color-accent)}
.metze-post-card__excerpt{font-size:0.9rem;color:var(--color-muted)}
.metze-post-header{padding:80px 0 40px}
.metze-post-header__cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.metze-cat-badge{padding:3px 10px;border:1px solid var(--color-border);border-radius:3px;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--color-muted)}
.metze-post-header__title{font-size:clamp(1.75rem,4vw,3rem);font-weight:800;line-height:1.1;letter-spacing:-0.02em;margin-bottom:24px}
.metze-post-header__meta{display:flex;gap:16px;font-size:0.85rem;color:var(--color-muted)}
.metze-post-content{padding:40px 0 80px}
.metze-post-content p{margin-bottom:1.5em}
.metze-post-content h2{font-size:1.5rem;font-weight:700;margin:2em 0 0.75em}
.metze-post-content h3{font-size:1.2rem;font-weight:600;margin:1.75em 0 0.5em}
.metze-post-content ul,.metze-post-content ol{margin:0 0 1.5em 1.5em}
.metze-post-content li{margin-bottom:0.4em}
.metze-post-content blockquote{border-left:3px solid var(--color-accent);padding:0.5em 1.5em;margin:1.5em 0;color:var(--color-muted);font-style:italic}
.metze-post-content code{font-family:var(--font-mono);font-size:0.875em;background:var(--color-surface);padding:2px 6px;border-radius:3px}
.metze-post-content pre{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25em;overflow-x:auto;margin-bottom:1.5em}
.metze-post-content pre code{background:none;padding:0}
.metze-post-content img{border-radius:var(--radius);margin:1.5em 0}
.metze-post-content a{text-decoration:underline;text-underline-offset:3px}
.metze-timeline{position:relative;padding-left:0}
.metze-timeline__year-group{padding-left:100px;position:relative;margin-bottom:0}
.metze-timeline__year{position:absolute;left:0;top:16px;font-size:0.8rem;font-weight:700;color:var(--color-accent);letter-spacing:0.05em;width:80px;text-align:right}
.metze-timeline__item{display:flex;gap:20px;padding:20px 0;border-left:1px solid var(--color-border);padding-left:28px;position:relative}
.metze-timeline__icon{position:absolute;left:-12px;top:20px;width:24px;height:24px;background:var(--color-bg);border:1px solid var(--color-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.metze-timeline__icon .dashicons{font-size:14px;width:14px;height:14px;color:var(--color-accent)}
.metze-timeline__content{flex:1}
.metze-timeline__title{font-size:1rem;font-weight:600;margin-bottom:4px}
.metze-timeline__month{font-size:0.8rem;color:var(--color-muted);display:block;margin-bottom:8px}
.metze-timeline__body{font-size:0.9rem;color:var(--color-muted)}
.metze-timeline__embed{margin-top:12px}
.metze-single-video__embed{margin-bottom:40px}
.metze-single-meta{display:flex;gap:24px;flex-wrap:wrap;padding:24px 0;border-top:1px solid var(--color-border);margin-top:40px}
.metze-single-meta__item{display:flex;flex-direction:column;gap:4px}
.metze-single-meta__label{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--color-muted)}
.metze-single-meta__value{font-size:0.95rem;font-weight:500}
.metze-pagination{display:flex;justify-content:center;gap:8px;padding:48px 0}
.metze-pagination a,.metze-pagination span{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:0.875rem;color:var(--color-muted);transition:all var(--transition)}
.metze-pagination a:hover{border-color:var(--color-accent);color:var(--color-accent)}
.metze-pagination .current{border-color:var(--color-accent);color:var(--color-accent);background:rgba(200,169,110,0.1)}
/* Resume embed */
.metze-resume-embed{width:100%;min-height:80vh;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;background:var(--color-surface)}
.metze-resume-embed iframe{width:100%;min-height:80vh;border:0}
.metze-resume-fallback{text-align:center;padding:60px 24px;color:var(--color-muted)}
.metze-resume-fallback a{display:inline-block;margin-top:16px}
.site-footer{border-top:1px solid var(--color-border);padding:40px 0;margin-top:80px}
.site-footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;max-width:var(--max-w);margin:0 auto;padding:0 24px;font-size:0.8rem;color:var(--color-muted)}
.site-footer__links{display:flex;gap:1.5rem}
.site-footer__links a{color:var(--color-muted)}
.site-footer__links a:hover{color:var(--color-accent)}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
.metze-divider{border:none;border-top:1px solid var(--color-border);margin:48px 0}
@media(max-width:768px){.site-nav{display:none;flex-direction:column;gap:0;position:absolute;top:var(--nav-h);left:0;right:0;background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:16px 0}.site-nav.is-open{display:flex}.site-nav a{padding:12px 24px;display:block}.nav-toggle{display:block}.metze-post-card{flex-direction:column;gap:8px}.metze-post-card__date{min-width:auto}.metze-timeline__year-group{padding-left:0}.metze-timeline__year{position:static;text-align:left;margin-bottom:8px;display:block}.metze-timeline__item{padding-left:20px}.metze-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.metze-grid{grid-template-columns:1fr}.metze-hero__title{font-size:2rem}}

.metze-hero--slim{min-height:0;padding:80px 24px 60px}
.metze-hero--slim .metze-hero__inner{width:100%;max-width:var(--max-w);margin:0 auto}
.metze-hero__inner{width:100%;max-width:var(--max-w);margin:0 auto}
