.projects-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.projects-header{text-align:center;margin-bottom:3rem}.projects-title{font-size:2.5rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;position:relative;display:inline-block}[data-theme=dark] .projects-title::before,[data-theme=dark] .projects-title::after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}[data-theme=dark] .projects-title::before{color:var(--neon-cyan);z-index:-1;animation:glitch-shift 3s infinite}[data-theme=dark] .projects-title::after{color:var(--neon-magenta);z-index:-2;animation:glitch-shift 3s infinite reverse}@keyframes glitch-shift{0%,90%,100%{clip-path:inset(0 0 0 0);transform:translate(0)}92%{clip-path:inset(20% 0 40% 0);transform:translate(-3px,1px)}94%{clip-path:inset(60% 0 10% 0);transform:translate(3px,-1px)}96%{clip-path:inset(10% 0 70% 0);transform:translate(-2px,0)}98%{clip-path:inset(50% 0 20% 0);transform:translate(2px,1px)}}[data-theme=light] .projects-title{color:var(--text-primary)}.projects-subtitle{color:var(--text-secondary);margin-top:.5rem;font-size:1rem}.project-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1.5rem}.filter-btn{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:2px;padding:.3rem .85rem;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:rgba(var(--accent-rgb),.15);border-color:var(--accent);color:var(--accent)}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.project-grid--home{max-width:1200px;margin:0 auto}.project-card{position:relative;border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:all .3s ease;cursor:pointer;background:var(--bg-surface)}[data-theme=dark] .project-card{border:1px solid rgba(var(--accent-rgb),.2);box-shadow:0 0 5px rgba(var(--accent-rgb),.1),0 0 15px rgba(var(--accent-rgb),.05)}[data-theme=dark] .project-card:hover{border-color:rgba(var(--accent-rgb),.6);box-shadow:0 0 10px rgba(var(--accent-rgb),.3),0 0 40px rgba(var(--accent-rgb),.12),0 0 80px rgba(var(--accent-rgb),.04);transform:translateY(-4px)}[data-theme=light] .project-card{border:1px solid var(--border-color);box-shadow:0 2px 8px rgba(var(--accent-rgb),.06)}[data-theme=light] .project-card:hover{border-color:transparent;background-image:linear-gradient(var(--bg-surface),var(--bg-surface)),linear-gradient(135deg,var(--accent),var(--accent-hover));background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 8px 24px rgba(var(--accent-rgb),.12),0 2px 8px rgba(var(--accent-rgb),.08);transform:translateY(-4px)}.card-thumb{position:relative;width:100%;height:180px;overflow:hidden;background:var(--bg-elevated)}.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,filter .4s ease}.project-card:hover .card-thumb img{transform:scale(1.05)}[data-theme=dark] .project-card:hover .card-thumb img{filter:brightness(1.1)saturate(1.2)}.card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}[data-theme=dark] .card-thumb-placeholder{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%)}[data-theme=light] .card-thumb-placeholder{background:linear-gradient(135deg,#e8e8ee 0%,#d8d8e0 50%,#c8c8d0 100%)}[data-theme=dark] .card-thumb .card-scanlines{position:absolute;inset:0;z-index:1;pointer-events:none;background:repeating-linear-gradient( 0,transparent,transparent 2px,rgba(0,0,0,6%) 2px,rgba(0,0,0,6%) 4px );opacity:0;transition:opacity .3s ease}[data-theme=dark] .project-card:hover .card-thumb .card-scanlines{opacity:1}[data-theme=light] .card-scanlines{display:none}.card-body{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.card-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;width:fit-content}.status-dot{width:7px;height:7px;border-radius:50%}.card-status--active{color:var(--status-active)}.card-status--active .status-dot{background:var(--status-active);box-shadow:0 0 4px var(--status-active),0 0 10px var(--status-active);animation:status-pulse 2s ease-in-out infinite}.card-status--completed{color:var(--status-completed)}.card-status--completed .status-dot{background:var(--status-completed);box-shadow:0 0 4px var(--status-completed),0 0 10px var(--status-completed)}.card-status--archived{color:var(--status-archived)}.card-status--archived .status-dot{background:var(--status-archived)}@keyframes status-pulse{0%,100%{opacity:1}50%{opacity:.5}}.card-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);position:relative;margin:0}[data-theme=dark] .project-card:hover .card-title{animation:glitch-text .4s ease}@keyframes glitch-text{0%,100%{text-shadow:none}15%{text-shadow:-2px 0 var(--neon-magenta),2px 0 var(--neon-cyan)}30%{text-shadow:2px 0 var(--neon-magenta),-2px 0 var(--neon-cyan)}45%{text-shadow:-1px 0 var(--neon-magenta),1px 0 var(--neon-cyan)}60%{text-shadow:1px 0 var(--neon-magenta),-1px 0 var(--neon-cyan)}}[data-theme=light] .project-card:hover .card-title{color:var(--accent);transition:color .2s ease}.card-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin:0}.card-techs{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.25rem}.tech-badge{font-size:.7rem;padding:.15rem .5rem;border-radius:2px;font-weight:600;letter-spacing:.03em}[data-theme=dark] .tech-badge{background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.3);color:var(--accent-text)}[data-theme=light] .tech-badge{background:linear-gradient(135deg,rgba(var(--accent-rgb),.08),rgba(var(--accent-rgb),.05));border:1px solid rgba(var(--accent-rgb),.2);color:var(--accent)}.card-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.card-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:600;padding:.3rem .65rem;border-radius:2px;text-decoration:none;transition:all .2s ease;text-transform:uppercase;letter-spacing:.04em}[data-theme=dark] .card-link{background:rgba(255,255,255,5%);border:1px solid rgba(255,255,255,.1);color:var(--text-secondary)}[data-theme=dark] .card-link:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}[data-theme=light] .card-link{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary)}[data-theme=light] .card-link:hover{border-color:var(--accent);color:var(--accent)}[data-theme=light] .card-link--blog:hover{border-color:var(--neon-cyan);color:var(--neon-cyan);background:rgba(var(--neon-cyan-rgb),.06)}[data-theme=light] .card-link--showcase:hover{border-color:var(--neon-magenta);color:var(--neon-magenta);background:rgba(var(--neon-magenta-rgb),.06)}[data-theme=light] .card-link--demo:hover{border-color:var(--neon-green);color:var(--neon-green);background:rgba(var(--neon-green-rgb),.06)}[data-theme=light] .card-link--github:hover{border-color:var(--text-primary);color:var(--text-primary);background:rgba(0,0,0,4%)}[data-theme=dark] .card-link--blog:hover{border-color:var(--neon-cyan);color:var(--neon-cyan);box-shadow:0 0 8px rgba(var(--neon-cyan-rgb),.3)}[data-theme=dark] .card-link--showcase:hover{border-color:var(--neon-magenta);color:var(--neon-magenta);box-shadow:0 0 8px rgba(var(--neon-magenta-rgb),.3)}[data-theme=dark] .card-link--demo:hover{border-color:var(--neon-green);color:var(--neon-green);box-shadow:0 0 8px rgba(var(--neon-green-rgb),.3)}[data-theme=dark] .card-link--github:hover{border-color:var(--text-primary);color:var(--text-primary)}.home-section{padding:3rem 0}.section-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;border:none;padding:0}.section-label{color:var(--accent-text)}.section-more{text-align:center;margin-top:2rem}.more-link{color:var(--text-secondary);font-size:.9rem;transition:color .2s ease}.more-link:hover{color:var(--accent)}.section-divider{font-family:d2coding,jetbrains mono,fira code,Consolas,monospace;font-size:.8rem;color:var(--text-muted);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle);opacity:.6}.section-divider span{color:var(--accent)}.recent-posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.recent-post-card{position:relative;display:flex;flex-direction:column;gap:.25rem;padding:1.25rem;border:1px solid var(--border-color);background:var(--bg-secondary);text-decoration:none;transition:all .2s ease}.recent-post-card:hover{border-color:var(--accent);transform:translateY(-3px)}[data-theme=dark] .recent-post-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.4)}[data-theme=light] .recent-post-card:hover{box-shadow:0 4px 16px rgba(0,0,0,8%)}.recent-post-featured{grid-column:1/-1;border-left:3px solid var(--accent)}.post-card-badge{display:inline-block;width:fit-content;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);background:rgba(var(--accent-rgb),.1);padding:.15rem .5rem;margin-bottom:.25rem}.post-card-date{font-size:.75rem;color:var(--text-muted);font-family:d2coding,jetbrains mono,monospace}.post-card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;border:none;padding:0}.recent-post-featured .post-card-title{font-size:1.15rem}.post-card-desc{font-size:.85rem;color:var(--text-secondary);margin:.15rem 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.post-card-tags{display:flex;gap:.35rem;margin-top:.5rem}.post-card-tag{font-size:.7rem;padding:.1rem .4rem;background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-muted)}.stats-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:2rem}[data-theme=dark] .stats-card{box-shadow:0 0 20px rgba(0,0,0,.3)}[data-theme=light] .stats-card{box-shadow:0 2px 12px rgba(0,0,0,6%)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1.5rem;text-align:center}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:2rem;font-weight:800;font-family:jetbrains mono,fira code,Consolas,monospace;color:var(--text-primary)}[data-theme=dark] .stat-value{color:var(--accent-text);text-shadow:0 0 10px rgba(var(--accent-rgb),.4)}[data-theme=light] .stat-value{color:var(--accent-text)}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stats-footer{text-align:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.stats-dashboard-link{font-size:.85rem;color:var(--text-secondary);transition:color .2s ease}.stats-dashboard-link:hover{color:var(--accent)}@media(max-width:480px){.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-value{font-size:1.5rem}}.guestbook-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:1.5rem}[data-theme=dark] .guestbook-card{box-shadow:0 0 20px rgba(0,0,0,.3)}[data-theme=light] .guestbook-card{box-shadow:0 2px 12px rgba(0,0,0,6%)}.guestbook-page{max-width:800px;margin:0 auto;padding:3rem 1.5rem}.guestbook-header{margin-bottom:2rem}.guestbook-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.guestbook-desc{color:var(--text-secondary);font-size:.95rem}.guestbook-comments{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:1.5rem}[data-theme=dark] .guestbook-comments{box-shadow:0 0 20px rgba(0,0,0,.3)}[data-theme=light] .guestbook-comments{box-shadow:0 2px 12px rgba(0,0,0,6%)}.guestbook-notice{color:var(--text-muted);text-align:center;padding:3rem 1rem}.guestbook-notice code{background:var(--code-bg);padding:.15em .35em;border-radius:2px;font-size:.875em}.blog-comments{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color)}.comments-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;border:none;padding:0}.about-card{display:flex;align-items:stretch;min-height:360px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;overflow:hidden}[data-theme=dark] .about-card{box-shadow:0 0 20px rgba(0,0,0,.3)}[data-theme=light] .about-card{box-shadow:0 2px 12px rgba(0,0,0,6%)}.about-main{display:flex;gap:1.5rem;align-items:center;flex:1;min-width:0;padding:2rem}.about-aside{display:flex;align-items:center;padding:2rem 2.5rem;border-left:1px solid var(--border-color);background:var(--bg-surface)}.about-stats{display:flex;flex-direction:column;gap:1.25rem}.about-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem}.about-stat-value{font-size:1.5rem;font-weight:800;font-family:jetbrains mono,fira code,Consolas,monospace}[data-theme=dark] .about-stat-value{color:var(--accent-text);text-shadow:0 0 10px rgba(var(--accent-rgb),.4)}[data-theme=light] .about-stat-value{color:var(--accent-text)}.about-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.about-avatar{flex-shrink:0}.about-avatar img{width:200px;height:200px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color)}.about-body{flex:1;min-width:0}.about-name{font-size:1.4rem;font-weight:700;margin:0 0 .5rem;border:none;padding:0}.about-bio{font-size:1rem;color:var(--text-secondary);margin:0 0 .75rem;line-height:1.6}.about-detail{font-size:.9rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1rem}.about-detail p{margin-bottom:.5rem}.about-detail strong{color:var(--text-primary)}.about-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.about-link-item{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;border-radius:2px;font-size:.8rem;font-weight:500;text-decoration:none;border:1px solid var(--border-color);color:var(--text-secondary);transition:all .2s ease}.about-link-item:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .about-link-item:hover{box-shadow:0 0 8px rgba(var(--accent-rgb),.2)}[data-theme=light] .about-link-item:hover{background:rgba(var(--accent-rgb),.06)}@media(max-width:768px){.about-card{flex-direction:column;min-height:auto}.about-aside{border-left:none;border-top:1px solid var(--border-color);padding:1.5rem 2rem}.about-stats{flex-direction:row;gap:2rem}}@media(max-width:640px){.about-main{flex-direction:column;align-items:center;text-align:center}.about-links{justify-content:center}.about-avatar img{width:110px;height:110px}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:55vh;padding:4rem 1.5rem 2rem}.dragon-scene{display:flex;flex-direction:column;align-items:center;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle);margin-bottom:.75rem}.dragon-bubble{font-family:jetbrains mono,fira code,Consolas,courier new,monospace;font-size:.85rem;line-height:1.35;color:var(--text-primary);margin:0;white-space:pre;text-align:left}.dragon-wrap{position:relative;display:inline-block;font-family:jetbrains mono,fira code,Consolas,courier new,monospace;font-size:.85rem;line-height:1.35}.dragon-art{color:var(--accent);margin:0;user-select:none;pointer-events:none;font-family:inherit;font-size:inherit;line-height:inherit}.dragon-eye{position:absolute;width:12px;height:12px;background:rgba(255,255,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2;transform:translate(-50%,-50%)}[data-theme=dark] .dragon-eye{box-shadow:0 0 6px rgba(255,255,255,.2)}.dragon-eye--l{top:calc(2.5 * 1.35em);left:8.5ch}.dragon-eye--r{top:calc(2.5 * 1.35em);left:12.5ch}.dragon-pupil{width:5px;height:5px;background:#1a1a2e;border-radius:50%;transition:transform .08s ease-out;position:relative}.dragon-pupil::after{content:'';position:absolute;width:2px;height:2px;background:#fff;border-radius:50%;top:1px;right:1px}.dragon-eye::before{content:'';position:absolute;inset:-1px;background:var(--code-bg);border-radius:50%;transform:scaleY(0);transform-origin:top;z-index:3;animation:dragon-blink 5s ease infinite}@keyframes dragon-blink{0%,92%,100%{transform:scaleY(0)}95%,97%{transform:scaleY(1)}}.hero-terminal{width:100%;max-width:560px;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}[data-theme=dark] .hero-terminal{box-shadow:0 8px 32px rgba(0,0,0,.5)}[data-theme=light] .hero-terminal{box-shadow:0 4px 20px rgba(0,0,0,8%)}.terminal-bar{display:flex;align-items:center;gap:.75rem;padding:.55rem 1rem;background:var(--bg-elevated);border-bottom:1px solid var(--border-color)}.terminal-dots{display:flex;gap:6px}.td{width:10px;height:10px;border-radius:50%}.td-close{background:#ff5f57}.td-min{background:#febc2e}.td-max{background:#28c840}.terminal-path{font-family:d2coding,jetbrains mono,fira code,Consolas,monospace;font-size:.8rem;color:var(--text-muted)}.terminal-body{padding:1.25rem;background:var(--code-bg);font-family:d2coding,jetbrains mono,fira code,Consolas,monospace}.term-input-row{display:flex;align-items:center;gap:.6rem}.t-prompt{color:var(--accent);font-weight:700;flex-shrink:0;font-size:.85rem}#hero-term-in{flex:1;background:0 0;border:none;outline:none;color:var(--text-primary);font-family:inherit;font-size:.9rem;padding:0;caret-color:var(--accent)}#hero-term-in::placeholder{color:var(--text-muted);opacity:.3}.hero-links{display:flex;gap:1.25rem;justify-content:center;margin-top:2rem}.hero-btn{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.8rem;font-size:.85rem;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.1em;transition:all .2s ease;border:1px solid var(--border-color);color:var(--text-primary);background:var(--bg-secondary)}.hero-btn svg{flex-shrink:0}.hero-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.hero-btn::before,.hero-btn::after{content:"";position:absolute;width:6px;height:6px;border:1px solid var(--text-muted);transition:border-color .2s ease}.hero-btn::before{top:-1px;left:-1px;border-right:none;border-bottom:none}.hero-btn::after{bottom:-1px;right:-1px;border-left:none;border-top:none}.hero-btn:hover::before,.hero-btn:hover::after{border-color:var(--accent)}.hero-btn--accent{background:var(--accent);border-color:var(--accent);color:#fff}.hero-btn--accent::before,.hero-btn--accent::after{border-color:var(--accent-hover)}.hero-btn--accent:hover{color:#fff}[data-theme=dark] .hero-btn--accent:hover{box-shadow:0 0 20px rgba(var(--accent-rgb),.4)}[data-theme=light] .hero-btn--accent:hover{background:var(--accent-hover);box-shadow:0 4px 16px rgba(var(--accent-rgb),.3)}.project-hero{position:relative;min-height:300px;display:flex;align-items:flex-end;overflow:hidden}.project-hero-bg{position:absolute;inset:0;background-size:cover;background-position:50%;opacity:.3}.project-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg-primary) 0%,transparent 100%)}.project-hero-content{position:relative;z-index:2;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.project-hero-title{font-size:2.5rem;font-weight:800;position:relative}.project-hero-desc{font-size:1.1rem;color:var(--text-secondary);margin-top:.5rem}.project-body{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.project-meta-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.project-techs{display:flex;flex-wrap:wrap;gap:.4rem}.project-action-links{display:flex;gap:.5rem}.project-content{margin-bottom:3rem}.related-posts{border-top:1px solid var(--border-color);padding-top:1.5rem}.related-posts h2{font-size:1.2rem;margin-bottom:.75rem}.related-posts ul{list-style:none;padding:0}.related-posts li{padding:.35rem 0}.related-posts a{color:var(--text-secondary);transition:color .2s ease}.related-posts a:hover{color:var(--accent)}.project-modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}.project-modal-overlay.open{opacity:1;pointer-events:all}.project-modal{position:relative;width:90%;max-width:700px;max-height:85vh;border-radius:4px;overflow:hidden;overflow-y:auto;background:var(--bg-secondary);transform:scale(.9)translateY(20px);transition:transform .35s cubic-bezier(.16,1,.3,1)}.project-modal-overlay.open .project-modal{transform:scale(1)translateY(0)}[data-theme=dark] .project-modal{border:1px solid rgba(var(--accent-rgb),.3);box-shadow:0 0 30px rgba(var(--accent-rgb),.15),0 25px 50px rgba(0,0,0,.5)}[data-theme=light] .project-modal{border:1px solid rgba(var(--accent-rgb),.2);box-shadow:0 25px 50px rgba(0,0,0,.1),0 0 0 1px rgba(var(--accent-rgb),.05)}.modal-close{position:absolute;top:.75rem;right:.75rem;z-index:10;background:rgba(0,0,0,.5);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease}.modal-close:hover{background:rgba(0,0,0,.7);transform:scale(1.1)}.modal-hero{position:relative;min-height:200px;overflow:hidden}.modal-hero img{width:100%;height:240px;object-fit:cover}.modal-hero-placeholder{width:100%;height:200px}[data-theme=dark] .modal-hero-placeholder{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%)}[data-theme=light] .modal-hero-placeholder{background:linear-gradient(135deg,#e8e8ee 0%,#d8d8e0 50%,#c8c8d0 100%)}.modal-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg-secondary) 10%,rgba(0,0,0,.3) 60%,transparent 100%)}[data-theme=light] .modal-hero-overlay{background:linear-gradient(to top,var(--bg-secondary) 10%,rgba(255,255,255,.4) 60%,transparent 100%)}.modal-hero-info{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;z-index:2}.modal-title{font-size:1.75rem;font-weight:800;margin:.5rem 0 0;position:relative}[data-theme=dark] .modal-title{color:#fff;text-shadow:-1px -1px 0 rgba(0,0,0,.6),1px -1px 0 rgba(0,0,0,.6),-1px 1px 0 rgba(0,0,0,.6),1px 1px 0 rgba(0,0,0,.6);animation:glitch-text .5s ease}[data-theme=light] .modal-title{color:var(--text-primary);text-shadow:-1px -1px 0 rgba(255,255,255,.8),1px -1px 0 rgba(255,255,255,.8),-1px 1px 0 rgba(255,255,255,.8),1px 1px 0 rgba(255,255,255,.8)}.modal-desc{font-size:.95rem;margin:.5rem 0 0}[data-theme=dark] .modal-desc{color:rgba(255,255,255,.85);text-shadow:0 1px 3px rgba(0,0,0,.6)}[data-theme=light] .modal-desc{color:var(--text-secondary);text-shadow:0 1px 3px rgba(255,255,255,.6)}.modal-body{padding:1.25rem 1.5rem 1.5rem}.modal-techs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.modal-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.modal-links .card-link{font-size:.8rem;padding:.4rem .85rem}.modal-content{border-top:1px solid var(--border-color);padding-top:1.25rem}@media(max-width:768px){.project-grid{grid-template-columns:1fr}.hero{min-height:auto;padding:2rem 1rem 1rem}.hero-terminal{max-width:100%}.terminal-body{padding:1rem}.dragon-wrap{font-size:.7rem}.dragon-eye{width:10px;height:10px}.dragon-pupil{width:4px;height:4px}.recent-posts-grid{grid-template-columns:1fr}.recent-post-featured{grid-column:1}.projects-title{font-size:2rem}.project-hero-title{font-size:1.8rem}.project-meta-bar{flex-direction:column;align-items:flex-start}.project-modal{width:95%;max-height:90vh}.modal-title{font-size:1.3rem}}