*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:1.5rem}:root{--bg:#0a0a0f;--surface:#13131a;--surface-2:#1a1a24;--border:#2a2a3a;--text:#e4e4ed;--text-muted:#8888a0;--accent:#6c5ce7;--accent-glow:#6c5ce74d;--accent-subtle:#6c5ce71a}:root,body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.skip-link{z-index:9999;background:var(--accent);color:#fff;border-radius:0 0 8px 8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:top .2s;position:absolute;top:-100%;left:.5rem}.skip-link:focus{outline-offset:2px;outline:2px solid #fff;top:0}.site-nav{border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);background:#0a0a0fcc;justify-content:center;gap:2rem;padding:1rem 2rem;display:flex;position:sticky;top:0}.site-nav a{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;font-size:.88rem;font-weight:500;text-decoration:none;transition:color .2s}.site-nav a:hover,.site-nav a:focus{color:var(--accent)}.hero{text-align:center;padding:4rem 2rem 3rem}h1{letter-spacing:-.02em;background:linear-gradient(90deg,#e4e4ed 0%,#c084fc 50%,#e4e4ed 100%) 0 0/200% 100%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:3.5rem;font-weight:700}@media (prefers-reduced-motion:no-preference){h1{animation:4s ease-in-out infinite shimmer}}@keyframes shimmer{0%,to{background-position:0%}50%{background-position:100%}}.bio-cta{color:var(--text);border:1px solid var(--border);background:0 0;border-radius:8px;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:border-color .2s,color .2s,box-shadow .2s,transform .2s;display:inline-flex}.bio-cta:hover,.bio-cta:focus{border-color:var(--accent);color:var(--accent);box-shadow:0 0 16px var(--accent-glow);transform:translateY(-1px)}.bio-cta:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media (width<=480px){h1{font-size:2.2rem}.hero{padding:2.5rem 1.25rem 2rem}.bio{padding:0 .25rem}}.tagline{color:var(--text-muted);margin-bottom:0;font-size:1.2rem}.hero-cta{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1.5rem;display:flex}.cta-btn{cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex}.cta-btn:hover,.cta-btn:focus{transform:translateY(-2px)}.cta-btn:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.cta-btn[href*=promo]{background:var(--accent,#6c5ce7);color:#fff;box-shadow:0 4px 16px #6c5ce766}.cta-btn[href*=promo]:hover{background:#7c6cf0;box-shadow:0 8px 24px #6c5ce780}.cta-btn:not([href*=promo]){color:var(--text);border:1px solid var(--border);background:0 0}.cta-btn:not([href*=promo]):hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 16px var(--accent-glow)}.cta-btn svg{flex-shrink:0}.about{border-top:1px solid var(--border);padding:3rem 2rem}.about-inner{grid-template-columns:280px 1fr;align-items:start;gap:3rem;max-width:900px;margin:0 auto;display:grid}@media (width<=700px){.about-inner{grid-template-columns:1fr}}.character-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;padding:1.5rem}.character-avatar{margin-bottom:1.25rem}.avatar-ring{border:2px solid var(--accent);width:140px;height:140px;box-shadow:0 0 24px var(--accent-glow);background:var(--accent-subtle);border-radius:50%;justify-content:center;align-items:center;margin:0 auto .75rem;display:flex;overflow:hidden}.avatar-portrait{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.character-badge{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);border:1px solid var(--accent);border-radius:4px;padding:.2rem .6rem;font-size:.7rem;font-weight:700;display:inline-block}.character-meta{text-align:left;flex-direction:column;gap:.5rem;display:flex}.meta-row{border-bottom:1px solid var(--border);justify-content:space-between;gap:.5rem;min-width:0;padding-bottom:.4rem;font-size:.82rem;display:flex}.meta-row:last-child{border-bottom:none}.meta-label{color:var(--text-muted);flex-shrink:0}.meta-value{color:var(--text);text-align:right;text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.accent-swatch{align-items:center;gap:.4rem;display:flex}.swatch{background:var(--accent);border-radius:3px;flex-shrink:0;width:12px;height:12px;display:inline-block}.bio h2{margin-bottom:1rem;font-size:1.8rem}.bio p{color:var(--text-muted);margin-bottom:1rem;font-size:.98rem;line-height:1.7}.traits{flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;display:flex}.trait{text-transform:uppercase;letter-spacing:.06em;background:var(--accent-subtle);color:var(--accent);border:1px solid var(--accent);border-radius:20px;padding:.25rem .75rem;font-size:.78rem;font-weight:600}.mission{border-top:1px solid var(--border);text-align:center;padding:3rem 2rem}.mission-inner{max-width:640px;margin:0 auto}.mission h2{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:1rem;font-size:1.4rem;font-weight:600}.mission-statement{color:var(--text);font-size:1.2rem;font-style:italic;line-height:1.7}.projects-section{border-top:1px solid var(--border);max-width:1200px;margin:0 auto;padding:3rem 2rem}.section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);text-align:center;margin-bottom:1.5rem;font-size:1.4rem;font-weight:600}.projects{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;display:grid}.card{color:var(--text);background:var(--surface);border:1px solid var(--border);aspect-ratio:5/7;border-radius:16px;flex-direction:column;text-decoration:none;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;position:relative;overflow:hidden}@media (prefers-reduced-motion:no-preference){.card:hover{box-shadow:0 24px 60px var(--card-glow,var(--accent-glow));border-color:var(--card-accent,var(--accent));transform:translateY(-10px)rotate(1deg)}}.card:focus-visible{outline:2px solid var(--card-accent,var(--accent));outline-offset:3px}.card-face{background:linear-gradient(160deg, var(--card-face-from,#1e1e2d) 0%, var(--card-face-to,#0d0d1a) 100%);border-bottom:1px solid var(--card-accent,var(--border));flex:0 0 58%;justify-content:center;align-items:center;display:flex;position:relative}.card-status{text-transform:uppercase;letter-spacing:.1em;color:var(--card-accent,var(--accent));border:1px solid var(--card-accent,var(--accent));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:3px;padding:.15rem .4rem;font-size:.6rem;font-weight:700;position:absolute;top:.6rem;right:.6rem}.card-face .card-icon{width:88px;height:88px;filter:drop-shadow(0 4px 16px var(--card-glow,#6c5ce766));border-radius:14px;transition:transform .25s,filter .25s;display:block}@media (prefers-reduced-motion:no-preference){.card:hover .card-face .card-icon{filter:drop-shadow(0 8px 28px var(--card-glow,#6c5ce799));transform:scale(1.08)}}.card-body{flex-direction:column;flex:1;gap:.4rem;min-height:0;padding:.875rem 1rem 1rem;display:flex}.card h3{color:var(--text);font-size:1rem;font-weight:700;line-height:1.2}.card p{color:var(--text-muted);-webkit-line-clamp:4;-webkit-box-orient:vertical;flex:1;font-size:.78rem;line-height:1.45;display:-webkit-box;overflow:hidden}.card--character-builder{--card-accent:#f59e0b;--card-glow:#f59e0b4d;--card-face-from:#2d1e00;--card-face-to:#0e0900}.card--voidborne{--card-accent:#14b8a6;--card-glow:#14b8a64d;--card-face-from:#001f1c;--card-face-to:#000e0c}.card--aegis{--card-accent:#3b82f6;--card-glow:#3b82f64d;--card-face-from:#001233;--card-face-to:#00071a}.card--dnd{--card-accent:#ef4444;--card-glow:#ef44444d;--card-face-from:#2d0000;--card-face-to:#0d0000}.card--astra{--card-accent:#f97316;--card-glow:#f973164d;--card-face-from:#2d1000;--card-face-to:#0d0500}.card--promo{--card-accent:#ff6b2b;--card-glow:#ff6b2b4d;--card-face-from:#2d1000;--card-face-to:#0d0500}.card--claw3d{--card-accent:#6c5ce7;--card-glow:#6c5ce74d;--card-face-from:#1a0f2d;--card-face-to:#0d0a1a}@media (width<=560px){.projects{grid-template-columns:repeat(2,1fr);gap:.875rem}.card-face .card-icon{width:64px;height:64px}}@media (width<=340px){.projects{grid-template-columns:1fr}}.site-footer{border-top:1px solid var(--border);margin-top:2rem;padding:2rem}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;max-width:900px;margin:0 auto;display:flex}.footer-brand{flex-direction:column;gap:.25rem;display:flex}.footer-logo{color:var(--text);font-size:1rem;font-weight:700}.footer-copy{color:var(--text-muted);font-size:.8rem}.footer-links{gap:1.5rem;display:flex}.footer-links a{color:var(--text-muted);padding:.25rem 0;font-size:.85rem;text-decoration:none;transition:color .2s}.footer-links a:hover,.footer-links a:focus{color:var(--accent)}@media (width<=480px){.footer-links{flex-wrap:wrap;gap:.25rem .5rem;width:100%}.footer-links a{align-items:center;min-width:44px;min-height:44px;padding:.5rem .25rem;display:flex}}.footer-social{align-items:center;gap:1rem;display:flex}.social-link{color:var(--text-muted);border:1px solid var(--border);background:var(--surface);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;text-decoration:none;transition:color .2s,border-color .2s,box-shadow .2s;display:flex}.social-link:hover{color:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.social-link svg{display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}::selection{background:var(--accent);color:#fff}.sw-update-banner{z-index:9999;border-bottom:1px solid var(--accent);background:linear-gradient(135deg,#1e1e2d 0%,#2a1a3a 100%);justify-content:center;align-items:center;gap:.75rem;padding:.75rem 1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:transform .4s cubic-bezier(.22,1,.36,1);display:flex;position:fixed;top:0;left:0;right:0;transform:translateY(-100%);box-shadow:0 4px 20px #6c5ce740}.sw-update-banner--visible{transform:translateY(0)}.sw-update-banner__text{color:#e4e4ed;font-size:.9rem;font-weight:500}.sw-update-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;padding:.4rem .9rem;font-family:inherit;font-size:.8rem;font-weight:600;transition:background .2s,box-shadow .2s;display:inline-flex}.sw-update-btn:hover,.sw-update-btn:focus{box-shadow:0 0 12px var(--accent-glow);background:#7c6cf0}.sw-close-btn{border:1px solid var(--border);color:#8888a0;cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-family:inherit;font-size:1.1rem;line-height:1;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.sw-close-btn:hover,.sw-close-btn:focus{color:#e4e4ed;background:#ffffff0d;border-color:#8888a0}@media (prefers-reduced-motion:reduce){.sw-update-banner{transition:none}}
