@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&family=Press+Start+2P&family=VT323&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font-display:"Press Start 2P", monospace;--font-body:"VT323", monospace;--font-mono:"VT323", monospace;--bg-color:#050505;--bg:#050505;--bg2:#ffffff0a;--bg3:#ffffff12;--bg-surface:#ffffff08;--bg-surface-hover:#ffffff14;--border-color:#ffffff1a;--border:#ffffff14;--text-main:#f3f4f6;--text:#f3f4f6;--muted:#9ca3af;--accent-1:#00f2fe;--accent-2:#4facfe;--accent-3:#ff0844;--accent:#00f2fe;--accent2:#4facfe;--accent-gradient:linear-gradient(135deg, #00f2fe, #4facfe);--accent-gradient-alt:linear-gradient(135deg, #ff0844, #ffb199);--glass-shadow:0 8px 32px 0 #0000004d;--glass-border:1px solid #ffffff14;--navbar-height:65px;--footer-banner-h:44px}.light{--bg-color:#fff;--bg:#fff;--bg2:#f1f5f9;--bg3:#e2e8f0;--bg-surface:#ffffffe6;--bg-surface-hover:#fff;--border-color:#0000000d;--border:#0000000d;--text-main:#0f172a;--text:#0f172a;--muted:#64748b;--accent-1:#4f46e5;--accent-2:#7c3aed;--accent-3:#db2777;--accent:#4f46e5;--accent2:#7c3aed;--accent-gradient:linear-gradient(135deg, #4f46e5, #7c3aed);--glass-shadow:0 10px 40px -10px #0000001a;--glass-border:1px solid #0000000d}html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}.blog-root{background-color:var(--bg-color);color:var(--text-main);font-family:var(--font-body);z-index:1;min-height:100vh;font-size:20px;line-height:1.6;transition:background-color .4s,color .4s;position:relative;overflow-x:hidden}.blog-root:before,.blog-root:after{content:"";filter:blur(100px);z-index:-1;opacity:.15;pointer-events:none;border-radius:50%;animation:20s ease-in-out infinite alternate float;position:fixed}.light .blog-root:before,.light .blog-root:after{opacity:.08}.blog-root:before{background:var(--accent-1);width:600px;height:600px;top:-200px;left:-200px}.blog-root:after{background:var(--accent-3);width:500px;height:500px;animation-delay:-10s;bottom:-100px;right:-100px}@keyframes float{0%{transform:translate(0)scale(1)}to{transform:translate(50px,50px)scale(1.1)}}.blog-nav{z-index:1000;-webkit-backdrop-filter:blur(16px);border-bottom:var(--glass-border);background:#050505cc;justify-content:space-between;align-items:center;padding:1.2rem 2rem;display:flex;position:fixed;top:0;left:0;right:0}.light .blog-nav{background:#fffc}.blog-nav-logo{font-family:var(--font-display);color:var(--text-main);background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;text-decoration:none}.blog-nav-links{gap:2rem;list-style:none;display:flex}.blog-nav-links a{color:var(--muted);font-size:.95rem;font-weight:500;text-decoration:none;transition:color .3s;position:relative}.blog-nav-links a:after{content:"";background:var(--accent-gradient);border-radius:2px;width:0;height:2px;transition:width .3s;position:absolute;bottom:-4px;left:0}.blog-nav-links a:hover,.blog-nav-links a.active{color:var(--text-main)}.blog-nav-links a:hover:after,.blog-nav-links a.active:after{width:100%}.nav-actions{align-items:center;gap:1rem;display:flex}.theme-toggle{background:var(--bg-surface);border:var(--glass-border);color:var(--text-main);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:500;transition:all .3s}.theme-toggle:hover{background:var(--bg-surface-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.theme-toggle-icon{font-size:1em}.hero{text-align:center;max-width:900px;margin:0 auto;padding:10rem 2rem 5rem}.hero-eyebrow{font-family:var(--font-mono);color:var(--accent-1);letter-spacing:.2em;text-transform:uppercase;background:var(--bg-surface);border:var(--glass-border);border-radius:30px;margin-bottom:1.5rem;padding:6px 16px;font-size:.85rem;display:inline-block}.hero h1{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:2rem;font-size:clamp(3rem,8vw,5.5rem);font-weight:700;line-height:1.1}.hero h1 em{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal}.hero-sub{color:var(--muted);max-width:600px;margin:0 auto 3rem;font-size:1.125rem;line-height:1.8}.hero-cta{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.btn{cursor:pointer;font-size:.95rem;font-weight:600;font-family:var(--font-body);border:none;border-radius:8px;justify-content:center;align-items:center;padding:14px 32px;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px #00f2fe4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00f2fe66}.btn-outline{background:var(--bg-surface);border:var(--glass-border);color:var(--text-main);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-outline:hover{background:var(--bg-surface-hover);transform:translateY(-2px)}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#b91c1c)}.btn-sm{padding:8px 16px;font-size:.85rem}.home-divider{max-width:900px;margin:0 auto;padding:0 2rem 4rem}.section-label{font-family:var(--font-display);color:var(--text-main);letter-spacing:-.02em;align-items:center;gap:2rem;margin:6rem 0 3rem;font-size:2.2rem;font-weight:700;display:flex}.section-label:after{content:"";background:var(--accent-gradient);opacity:.3;flex:1;height:2px}.post-row{background:var(--bg-surface);border:var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-main);border-radius:12px;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:1rem;padding:1.5rem;text-decoration:none;transition:all .3s;display:flex}.post-row:hover{background:var(--bg-surface-hover);border-color:#fff3;transform:translate(8px)}.post-row-left{flex:1;min-width:0}.post-row-tag{font-family:var(--font-mono);color:var(--accent-1);text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px;font-size:.8rem;font-weight:600}.post-row-title{font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;font-size:1.25rem;font-weight:500;overflow:hidden}.post-row-date{font-family:var(--font-mono);color:var(--muted);font-size:.85rem}.post-row .post-thumbnail{object-fit:cover;border-radius:8px;width:80px;height:60px}.page{min-height:100vh;padding-top:2rem}.page-header{max-width:900px;margin:0 auto;padding:4rem 2rem 3rem}.page-header h2{font-family:var(--font-display);letter-spacing:-.03em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:clamp(3rem,6vw,4.5rem);font-weight:700;display:inline-block}.page-header p{color:var(--muted);max-width:600px;font-size:1.125rem}.blog-controls{flex-wrap:wrap;align-items:center;gap:1rem;max-width:900px;margin:0 auto;padding:0 2rem 2rem;display:flex}.search-input{background:var(--bg-surface);border:var(--glass-border);min-width:250px;color:var(--text-main);font-family:var(--font-body);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;outline:none;flex:1;padding:12px 20px;font-size:.95rem;transition:all .3s}.search-input:focus{border-color:var(--accent-1);box-shadow:0 0 0 2px #00f2fe33}.search-input::placeholder{color:var(--muted)}.tag-filter{cursor:pointer;border:var(--glass-border);background:var(--bg-surface);color:var(--text-main);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-transform:uppercase;letter-spacing:.08em;opacity:.8;border-radius:20px;padding:8px 18px;font-size:.8rem;font-weight:600;transition:all .3s}.tag-filter:hover{opacity:1;background:var(--bg-surface-hover)}.tag-filter.active{background:var(--accent-gradient);color:#fff;opacity:1;border-color:#0000}.blog-list{grid-template-columns:1fr;gap:2rem;max-width:900px;margin:0 auto;padding:0 2rem 5rem;display:grid}.blog-card{background:var(--bg-surface);border:var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text-main);border-radius:16px;gap:2rem;padding:2rem;text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex}.blog-card:hover{background:var(--bg-surface-hover);box-shadow:var(--glass-shadow);border-color:#ffffff26;transform:translateY(-5px)}.blog-card-content{flex:1;min-width:0}.post-thumbnail{object-fit:cover;border-radius:12px;flex-shrink:0;width:200px;height:140px}.blog-card-meta{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.tag-badge{font-family:var(--font-mono);color:var(--accent-1);background:var(--bg3);text-transform:uppercase;letter-spacing:.1em;border:1px solid var(--border);border-radius:6px;padding:6px 12px;font-size:.75rem;font-weight:600}.date-badge{font-family:var(--font-mono);color:var(--muted);font-size:.85rem}.blog-card h3{font-family:var(--font-display);margin-bottom:1rem;font-size:1.75rem;font-weight:600;line-height:1.3}.blog-card p{color:var(--muted);text-align:justify;-webkit-hyphens:auto;hyphens:auto;font-size:1rem;line-height:1.6}.portfolio-grid{flex-direction:column;gap:3rem;max-width:900px;margin:0 auto;padding:0 2rem 5rem;display:flex}.project-card{background:var(--bg-surface);border:var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;flex-direction:column;padding:2.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex}.project-card:hover{box-shadow:var(--glass-shadow);background:var(--bg-surface-hover);border-color:#fff3;transform:translateY(-8px)}.project-top{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.project-name{font-family:var(--font-display);font-size:1.5rem;font-weight:600}.project-links{flex-shrink:0;gap:.5rem;display:flex}.project-link{font-family:var(--font-mono);color:var(--accent-1);text-transform:uppercase;border:1px solid #00f2fe4d;border-radius:6px;padding:6px 12px;font-size:.75rem;text-decoration:none;transition:all .3s}.project-link:hover{border-color:var(--accent-1);background:#00f2fe1a}.project-desc{color:var(--muted);text-align:justify;-webkit-hyphens:auto;hyphens:auto;flex-grow:1;margin-bottom:2rem;font-size:.95rem;line-height:1.7}.tech-tags{flex-wrap:wrap;gap:.5rem;display:flex}.tech-tag{font-family:var(--font-mono);color:var(--text-main);border:var(--glass-border);background:#ffffff0d;border-radius:20px;padding:6px 12px;font-size:.75rem}.post-page{max-width:800px;margin:0 auto;padding:4rem 2rem 6rem}.back-link{font-family:var(--font-mono);color:var(--muted);background:var(--bg-surface);border:var(--glass-border);text-transform:uppercase;letter-spacing:.05em;border-radius:30px;align-items:center;gap:8px;margin-top:2rem;margin-bottom:3rem;padding:8px 16px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.back-link:hover{color:var(--accent-1);background:var(--bg-surface-hover);border-color:var(--accent-1);transform:translate(-4px)}.post-hero-image{object-fit:cover;width:100%;max-height:400px;box-shadow:var(--glass-shadow);border-radius:16px;margin-bottom:3rem}.post-meta{margin-bottom:3rem}.post-tag{font-family:var(--font-mono);color:var(--accent-1);text-transform:uppercase;letter-spacing:.15em;background:var(--bg3);border:1px solid var(--border);border-radius:20px;margin-bottom:1rem;padding:6px 14px;font-size:.8rem;font-weight:600;display:inline-block}.post-title{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:1.5rem;font-size:clamp(2.5rem,6vw,4rem);font-weight:700;line-height:1.1}.post-byline{font-family:var(--font-mono);color:var(--muted);font-size:.95rem}.post-body{color:var(--text-main);font-size:1.125rem;line-height:1.8}.post-body h2{font-family:var(--font-display);margin:3rem 0 1.5rem;font-size:2rem;font-weight:600}.post-body p{text-align:justify;-webkit-hyphens:auto;hyphens:auto;margin-bottom:1.5rem}.post-body code{font-family:var(--font-mono);background:var(--bg-surface);color:var(--accent-1);border-radius:6px;padding:4px 8px;font-size:.9em}.post-body blockquote{border-left:4px solid var(--accent-1);background:var(--bg-surface);border-radius:0 8px 8px 0;margin:2rem 0;padding:1rem 1.5rem;font-style:italic}.about-page,.contact-page{max-width:800px;margin:0 auto;padding:4rem 2rem 6rem}.about-page h2,.contact-page h2{font-family:var(--font-display);margin-bottom:2rem;font-size:3rem;font-weight:700}.skills-grid{flex-wrap:wrap;gap:12px;margin-top:2rem;display:flex}.skill-chip{font-family:var(--font-mono);background:var(--bg-surface);border:var(--glass-border);color:var(--text-main);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:10px 20px;font-size:.95rem;transition:all .3s}.skill-chip:hover{background:var(--accent-gradient);color:#fff;border-color:#0000;transform:translateY(-2px);box-shadow:0 4px 15px #00f2fe4d}.form-group{margin-bottom:2rem}.form-label{font-family:var(--font-display);color:var(--text-main);margin-bottom:10px;font-weight:500;display:block}.form-input{background:var(--bg-surface);border:var(--glass-border);width:100%;color:var(--text-main);font-family:var(--font-body);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;outline:none;padding:14px 20px;font-size:1rem;transition:all .3s}.form-input:focus{border-color:var(--accent-1);background:#ffffff0d;box-shadow:0 0 0 2px #00f2fe33}.contact-channels{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.contact-tile{background:var(--bg-surface);border:var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;align-items:center;gap:1rem;padding:1.5rem;text-decoration:none;transition:all .3s;display:flex}.contact-tile:hover{background:var(--bg-surface-hover);border-color:var(--accent-1);box-shadow:var(--glass-shadow);transform:translateY(-4px)}.contact-icon-box{width:48px;height:48px;color:var(--accent-1);background:#00f2fe1a;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.page{animation:.6s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.loading-dots{justify-content:center;gap:8px;padding:4rem 0;display:flex}.loading-dots span{background:var(--accent-gradient);border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite both dotPulse}.loading-dots span:first-child{animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes dotPulse{0%,80%,to{opacity:.5;transform:scale(0)}40%{opacity:1;box-shadow:0 0 10px var(--accent-1);transform:scale(1)}}@media (width<=768px){.hero{padding:5rem 1.5rem 3rem}.blog-nav{padding:1rem 1.5rem}.blog-list,.portfolio-grid{grid-template-columns:1fr;padding:0 1.5rem 4rem}.blog-card{flex-direction:column}.post-thumbnail{aspect-ratio:16/9;width:100%;height:auto}.page-header{padding:4rem 1.5rem 2rem}.post-row{flex-direction:column;align-items:flex-start}.post-row .post-thumbnail{display:none}.portfolio-grid{grid-template-columns:1fr}.about-page h2,.contact-page h2{font-size:2.2rem}}.hamburger{color:var(--text);cursor:pointer;z-index:1001;background:0 0;border:none;flex-direction:column;gap:5px;padding:8px;display:none}.hamburger span{background:currentColor;border-radius:2px;width:22px;height:2px;transition:all .3s;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (width<=768px){.hamburger{display:flex}.blog-nav-links{-webkit-backdrop-filter:blur(20px);border-left:var(--glass-border);z-index:1000;background:#0a0a14f2;flex-direction:column;gap:2.5rem;width:75%;max-width:320px;height:100vh;padding:5rem 2.5rem;transition:transform .4s cubic-bezier(.16,1,.3,1);position:fixed;top:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-10px 0 40px #00000080}.blog-nav-links.open{transform:translate(0)}.blog-nav-links a{font-size:1.25rem}}.admin-login{background:var(--bg-surface);border:var(--glass-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:20px;max-width:440px;margin:5rem auto;padding:3rem}.admin-login h2{font-family:var(--font-display);margin-bottom:.5rem;font-size:2.2rem;font-weight:700}.admin-login p{color:var(--muted);margin-bottom:2rem;font-size:1rem}.admin-error{color:#ef4444;font-family:var(--font-mono);margin-top:1rem;font-size:.85rem}.admin-panel{max-width:1100px;margin:0 auto;padding:3rem 2rem}.admin-header{border-bottom:var(--glass-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;display:flex}.admin-header h2{font-family:var(--font-display);font-size:2rem;font-weight:700}.admin-header-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-tabs{background:var(--bg-surface);border:var(--glass-border);border-radius:10px;gap:4px;padding:4px;display:flex}.admin-tab{color:var(--muted);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 18px;font-size:.9rem;font-weight:500;transition:all .2s}.admin-tab.active{background:var(--accent-gradient);color:#fff}.admin-table-container{border:var(--glass-border);background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;width:100%;margin-bottom:2rem;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;min-width:600px}.admin-table th{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);text-align:left;border-bottom:var(--glass-border);padding:14px 20px;font-size:.75rem}.admin-table td{border-bottom:var(--glass-border);vertical-align:middle;color:var(--text);padding:16px 20px;font-size:.95rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-surface-hover)}.draft-badge{font-family:var(--font-mono);color:var(--muted);background:#ffffff0f;border-radius:20px;padding:4px 12px;font-size:.75rem}.pub-badge{font-family:var(--font-mono);color:var(--accent-1);background:#00f2fe1a;border-radius:20px;padding:4px 12px;font-size:.75rem}.admin-actions{gap:8px;display:flex}.post-editor{background:var(--bg-surface);border:var(--glass-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;margin-top:1.5rem;padding:2.5rem}.editor-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.editor-row{margin-bottom:1.5rem}.editor-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:8px;font-size:.75rem;display:block}.editor-input{background:var(--bg-surface-hover);border:var(--glass-border);width:100%;color:var(--text);font-family:var(--font-body);border-radius:8px;outline:none;padding:12px 16px;font-size:.95rem;transition:border-color .2s}.editor-input:focus{border-color:var(--accent-1);box-shadow:0 0 0 2px #00f2fe26}.editor-textarea{background:var(--bg-surface-hover);border:var(--glass-border);width:100%;color:var(--text);font-family:var(--font-mono);resize:vertical;border-radius:8px;outline:none;min-height:300px;padding:12px 16px;font-size:.9rem;line-height:1.6;transition:border-color .2s}.editor-textarea:focus{border-color:var(--accent-1)}.editor-footer{border-top:var(--glass-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.editor-footer-left{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.editor-footer-right{gap:10px;display:flex}.toggle-label{font-family:var(--font-mono);color:var(--muted);cursor:pointer;align-items:center;gap:8px;font-size:.85rem;display:flex}.featured-image-preview{object-fit:cover;border:var(--glass-border);border-radius:10px;width:100%;max-height:200px;margin-bottom:1rem}.upload-btn-container{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:1rem;display:flex}.img-utility-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:1rem;display:flex}.success-msg{color:var(--accent-1);font-family:var(--font-mono);font-size:.85rem}.settings-grid{grid-template-columns:1fr 1fr;gap:2.5rem;margin-top:1rem;display:grid}.settings-list{border:var(--glass-border);background:var(--bg-surface);border-radius:10px;overflow:hidden}.settings-row{border-bottom:var(--glass-border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.settings-row:last-child{border-bottom:none}.settings-name{color:var(--text);font-size:.95rem}.settings-slug{font-family:var(--font-mono);color:var(--muted);margin-left:10px;font-size:.75rem}.project-editor-images{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.project-img-slot{background:var(--bg-surface);border:var(--glass-border);border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:10px;display:flex}.project-slot-preview{aspect-ratio:16/10;object-fit:cover;border-radius:6px;width:100%}.project-slot-empty{aspect-ratio:16/10;width:100%;font-family:var(--font-mono);color:var(--muted);border:1px dashed var(--border);background:#ffffff05;border-radius:6px;justify-content:center;align-items:center;font-size:.75rem;display:flex}.project-gallery-slider{scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--accent-1) transparent;gap:16px;margin-top:2rem;padding-bottom:12px;display:flex;overflow-x:auto}.project-gallery-slider::-webkit-scrollbar{height:4px}.project-gallery-slider::-webkit-scrollbar-thumb{background:var(--accent-gradient);border-radius:10px}.project-slider-item{scroll-snap-align:center;aspect-ratio:16/10;border:var(--glass-border);border-radius:10px;flex:0 0 85%;transition:border-color .3s;overflow:hidden}.project-slider-item img{object-fit:cover;cursor:zoom-in;width:100%;height:100%}.project-slider-item:hover{border-color:var(--accent-1)}.contact-intro{color:var(--muted);margin-bottom:2rem;font-size:1.05rem}.contact-meta{flex-wrap:wrap;align-items:center;gap:10px;margin-top:1.5rem;display:flex}.avail-dot{background:#4caf7d;border-radius:50%;flex-shrink:0;width:9px;height:9px;animation:2s ease-in-out infinite pulse;display:inline-block;box-shadow:0 0 8px #4caf7db3}@keyframes pulse{0%,to{box-shadow:0 0 6px #4caf7d99}50%{box-shadow:0 0 14px #4caf7d}}.avail-text{font-family:var(--font-mono);color:#4caf7d;letter-spacing:.04em;font-size:.85rem}.avail-reply{font-family:var(--font-mono);color:var(--muted);font-size:.8rem}.contact-services{flex-wrap:wrap;gap:8px;display:flex}.service-chip{font-family:var(--font-mono);border:var(--glass-border);color:var(--accent-1);background:#00f2fe0d;border-radius:20px;padding:8px 16px;font-size:.8rem}.contact-tile-text{flex-direction:column;flex:1;gap:4px;display:flex;overflow:hidden}.contact-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.7rem}.contact-value{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:500;overflow:hidden}.contact-arrow{color:var(--muted);opacity:.4;flex-shrink:0;transition:all .2s}.contact-tile:hover .contact-arrow{color:var(--accent-1);opacity:1;transform:translate(3px,-3px)}.about-body p{text-align:justify;-webkit-hyphens:auto;hyphens:auto;margin-bottom:1.8rem;font-size:1rem;line-height:1.9}textarea.form-input{resize:vertical;min-height:160px;line-height:1.7}img{max-width:100%;height:auto;display:block}@media (width<=768px){.settings-grid,.editor-grid{grid-template-columns:1fr}.admin-panel{padding:2rem 1.5rem}.admin-header{flex-direction:column;align-items:flex-start}.admin-header-right{justify-content:space-between;width:100%}}:root{--font-game-display:"Press Start 2P", monospace;--font-game-mono:"VT323", monospace}.blog-nav{font-family:var(--font-game-mono);letter-spacing:.05em;box-sizing:border-box;width:100%;font-size:1.25rem;box-shadow:0 4px 10px #00000080;background:#0c101ce6!important;border-bottom:3px solid #3c2a1a!important}.light .blog-nav{background:#f6eedbf2!important;border-bottom:3px solid #8d6428!important}.blog-nav-logo{font-family:var(--font-game-display);text-shadow:2px 2px #000;-webkit-text-fill-color:initial!important;color:#ffeb60!important;background:0 0!important;font-size:1.1rem!important}.light .blog-nav-logo{text-shadow:none;color:#5d3e23!important}.game-screen-wrapper{width:100vw;height:calc(100vh - var(--navbar-height,65px));height:calc(100dvh - var(--navbar-height,65px));margin-top:var(--navbar-height,65px);background-color:#2d2d2d;position:relative;overflow:hidden}.game-world-container{width:100%;height:100%;position:relative}.game-canvas{width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges;display:block}.game-hud{color:#ebdcb9;font-family:var(--font-game-display);letter-spacing:1px;pointer-events:none;z-index:10;background:#0c101cd1;border:2px solid #8d6428;border-radius:4px;padding:8px 16px;font-size:10px;position:absolute;top:16px;box-shadow:0 4px 8px #0006}.game-hud-left{align-items:center;gap:8px;display:flex;left:16px}.game-hud-right{text-align:right;font-family:var(--font-game-mono);font-size:15px;line-height:1.3;right:16px}.hud-line{margin-bottom:2px}.game-footer-banner{color:#ebdcb9;text-align:center;font-family:var(--font-game-mono);letter-spacing:.05em;z-index:10;pointer-events:none;background:#0c101ce6;border-top:3px solid #8d6428;padding:12px 20px;font-size:18px;position:absolute;bottom:0;left:0;right:0}.highlight-key{color:#ffeb60;font-weight:700}.floating-key-prompt{color:#2b1f11;width:20px;height:20px;font-family:var(--font-game-display);pointer-events:none;z-index:5;background:#ffeb60;border:2px solid #5a3d16;border-radius:3px;justify-content:center;align-items:center;font-size:9px;font-weight:700;animation:1s infinite alternate float-key;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 4px #0000004d}@keyframes float-key{0%{transform:translate(-50%,-50%)translateY(0)}to{transform:translate(-50%,-50%)translateY(-4px)}}.game-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;background:#080a12bf;justify-content:center;align-items:center;padding:24px;display:flex;position:absolute;inset:0}.game-modal-content{color:#ebdcb9;width:100%;max-width:860px;max-height:85%;font-family:var(--font-body);background:#161c2df2;border:4px solid #8d6428;border-radius:8px;flex-direction:column;display:flex;box-shadow:0 10px 40px #0009}.light .game-modal-content{color:#382510;background-color:#f6eedb;border-color:#5a3e1a}.game-modal-header{border-bottom:2px dashed #8d6428;justify-content:space-between;align-items:flex-start;padding:16px 24px;display:flex}.game-modal-title{font-family:var(--font-game-display);color:#ffeb60;text-shadow:1px 1px #000;margin-bottom:6px;font-size:14px}.light .game-modal-title{color:#83552a;text-shadow:none}.game-modal-subtitle{font-family:var(--font-game-mono);color:#aeb8bd;margin:0;font-size:16px}.light .game-modal-subtitle{color:#6d5b4a}.game-modal-close{color:#fff;font-family:var(--font-game-display);cursor:pointer;background:#bf4a3b;border:2px solid #5a1e16;border-radius:4px;padding:2px 8px;font-size:12px;transition:all .1s;box-shadow:0 2px 4px #0000004d}.game-modal-close:hover{background:#d15147;transform:scale(1.05)}.game-modal-body{flex:1;padding:24px;overflow-y:auto}.game-modal-content .search-input{color:#ebdcb9;font-family:var(--font-game-mono);background:#0c101c99;border:2px solid #8d6428;border-radius:4px;font-size:18px}.light .game-modal-content .search-input{color:#382510;background:#ffffffb3;border-color:#5a3e1a}.game-modal-content .tag-filters-container{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.game-modal-content .tag-filter{font-family:var(--font-game-mono);color:#ebdcb9;background:#0c101c66;border:2px solid #8d6428;border-radius:4px;padding:4px 12px;font-size:14px}.light .game-modal-content .tag-filter{color:#382510;background:#ffffff4d;border-color:#5a3e1a}.game-modal-content .tag-filter.active{color:#2b1f11;background:#ffeb60;border-color:#8d6428}.game-modal-content .blog-card{color:#ebdcb9;background:#0c101c66;border:2px solid #8d6428;border-radius:8px;gap:1.5rem}.light .game-modal-content .blog-card{color:#382510;background:#ffffff4d;border-color:#5a3e1a}.game-modal-content .blog-card h3{font-family:var(--font-display);color:#ffeb60;font-size:1.4rem}.light .game-modal-content .blog-card h3{color:#5d3e23}.game-modal-content .blog-card p{color:#c9d1d5}.light .game-modal-content .blog-card p{color:#5d4a34}.game-modal-content .project-card{color:#ebdcb9;background:#0c101c66;border:2px solid #8d6428;border-radius:8px}.light .game-modal-content .project-card{color:#382510;background:#ffffff4d;border-color:#5a3e1a}.game-modal-content .project-name{color:#ffeb60}.light .game-modal-content .project-name{color:#5d3e23}.game-modal-content .project-desc{color:#c9d1d5}.light .game-modal-content .project-desc{color:#5d4a34}.game-modal-content .tech-tag{background:#0c101c80;border:1px solid #8d6428}.light .game-modal-content .tech-tag{background:#fff6;border-color:#5a3e1a}.game-modal-content .project-link{color:#ffeb60;border-color:#8d6428}.light .game-modal-content .project-link{color:#83552a;border-color:#5a3e1a}.game-modal-content .skill-chip{font-family:var(--font-game-mono);color:#ebdcb9;background:#0c101c80;border:2px solid #8d6428;border-radius:4px;padding:6px 14px;font-size:16px}.light .game-modal-content .skill-chip{color:#382510;background:#fff6;border-color:#5a3e1a}.game-modal-content .form-input{color:#ebdcb9;background:#0c101c99;border:2px solid #8d6428;border-radius:4px}.light .game-modal-content .form-input{color:#382510;background:#fff9;border-color:#5a3e1a}.game-modal-content .form-label{font-family:var(--font-game-mono);color:#ffeb60;font-size:16px}.light .game-modal-content .form-label{color:#5d3e23}.game-modal-content .btn-primary{color:#2b1f11;font-family:var(--font-game-mono);background:#e0a93c;border:2px solid #5a3d16;border-radius:4px;font-size:18px;box-shadow:0 4px #5a3d16}.game-modal-content .btn-primary:hover{background:#ebd060;transform:translateY(-2px);box-shadow:0 6px #5a3d16}.game-modal-content .btn-outline{background:#0c101c66;border:2px solid #8d6428;border-radius:4px}.light .game-modal-content .btn-outline{background:#ffffff4d;border-color:#5a3e1a}.game-modal-content .back-link{font-family:var(--font-game-mono);background:#0c101c66;border-color:#8d6428;border-radius:4px;font-size:16px}.light .game-modal-content .back-link{background:#ffffff4d;border-color:#5a3e1a}.virtual-dpad{bottom:calc(var(--footer-banner-h,44px) + 12px);z-index:15;-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:4px;display:flex;position:absolute;right:20px}.dpad-row{justify-content:center;gap:4px;display:flex}.dpad-btn{color:#ebdcb9;cursor:pointer;touch-action:manipulation;background:#161c2dd1;border:2px solid #8d6428;border-radius:4px;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex;box-shadow:0 3px #4d3310}.dpad-btn:active{color:#2b1f11;background:#ffeb60;transform:translateY(3px);box-shadow:0 0 #4d3310}.dpad-action{color:#2b1f11;font-family:var(--font-game-display);background:#e0a93c;font-size:11px}.dpad-spacer{box-shadow:none;pointer-events:none;background:0 0;border:none}.hidden-input{display:none!important}.project-gallery-slider{scrollbar-width:thin;gap:8px;padding:8px 0;display:flex;overflow-x:auto}.project-slider-item{cursor:pointer;border:2px solid #8d6428;border-radius:4px;flex-shrink:0;width:140px;height:100px;overflow:hidden}.project-slider-item img{object-fit:cover;width:100%;height:100%}@media (width<=768px){:root{--navbar-height:54px;--footer-banner-h:40px}.blog-nav{box-sizing:border-box;height:var(--navbar-height)!important;min-height:var(--navbar-height)!important;padding:0 12px!important}.blog-nav-logo{white-space:nowrap;flex-shrink:0;font-size:.82rem!important}.theme-toggle{flex-shrink:0;min-width:36px;padding:4px 8px!important}.theme-toggle-icon{font-size:16px;display:inline}.theme-toggle-text{display:none}.nav-actions{flex-shrink:0;gap:4px}.game-screen-wrapper{height:calc(100dvh - var(--navbar-height));margin-top:var(--navbar-height)}.game-hud{letter-spacing:.5px;border-width:1px;padding:5px 10px;font-size:7px;top:10px}.game-hud-left{gap:5px;left:10px}.game-hud-right{font-size:12px;right:10px}.game-footer-banner{border-top-width:2px;padding:8px 12px;font-size:14px;line-height:1.2}.virtual-dpad{bottom:calc(var(--footer-banner-h) + 12px);gap:3px;right:12px}.dpad-btn{border-width:1px;width:40px;height:40px;font-size:16px}.dpad-row{gap:3px}.game-modal-overlay{align-items:flex-end;padding:0}.game-modal-content{width:100%;max-width:100%;max-height:calc(100dvh - var(--navbar-height) - 8px);border-width:2px;border-bottom-style:none;border-bottom-color:currentColor;border-radius:12px 12px 0 0}.game-modal-header{align-items:center;padding:12px 16px}.game-modal-title{margin-bottom:3px;font-size:9px}.game-modal-subtitle{font-size:13px;line-height:1.3}.game-modal-close{flex-shrink:0;min-width:32px;padding:4px 10px;font-size:14px}.game-modal-body{-webkit-overflow-scrolling:touch;padding:12px 14px}.game-modal-content .blog-controls{gap:8px;padding:0 0 12px}.game-modal-content .search-input{min-width:0;font-size:16px}.game-modal-content .tag-filters-container{gap:4px}.game-modal-content .tag-filter{padding:3px 10px;font-size:12px}.game-modal-content .blog-card{flex-direction:column;gap:.75rem;padding:1rem}.game-modal-content .post-thumbnail{aspect-ratio:16/9;border-radius:6px;width:100%;height:auto}.game-modal-content .blog-card h3{font-size:1.1rem}.game-modal-content .blog-card p{font-size:.9rem}.game-modal-content .blog-list{gap:1rem;padding:0 0 2rem}.game-modal-content .portfolio-grid{gap:1.5rem;margin-top:.5rem;padding:0 0 2rem}.game-modal-content .project-card{padding:1rem}.game-modal-content .project-top{flex-direction:column;gap:.5rem;margin-bottom:.75rem}.game-modal-content .project-name{font-size:1.1rem}.game-modal-content .project-links{flex-wrap:wrap}.game-modal-content .post-page{padding:0 0 2rem}.game-modal-content .post-title{font-size:clamp(1.4rem,6vw,2.2rem);line-height:1.2}.game-modal-content .post-body{font-size:1rem}.game-modal-content .about-page{padding:0}.game-modal-content .about-body p{font-size:.95rem}.game-modal-content .skills-grid{gap:8px}.game-modal-content .skill-chip{padding:5px 10px;font-size:14px}.game-modal-content .contact-page{padding:0}.game-modal-content .contact-channels{grid-template-columns:1fr;gap:.75rem}.game-modal-content .form-input{font-size:16px}.game-modal-content .section-label{margin:1.5rem 0 .6rem;font-size:1.4rem}.pagination-controls{gap:.5rem;padding-bottom:1rem}}@media (width<=380px){.game-hud{padding:4px 8px;font-size:6px}.game-modal-title{font-size:8px}.dpad-btn{width:36px;height:36px;font-size:14px}}.game-modal-header-left{align-items:flex-start;gap:10px;display:flex}.game-modal-icon{flex-shrink:0;margin-top:2px;font-size:22px;line-height:1}.library-controls{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.scroll-shelf{flex-direction:column;gap:10px;display:flex}.scroll-empty{font-family:var(--font-game-mono);color:#8d6428;text-align:center;padding:2rem;font-size:18px}.scroll-item{cursor:pointer;background:#5a3d162e;border:2px solid #8d6428;border-radius:4px;align-items:center;gap:14px;padding:12px 14px;transition:all .15s;animation:.3s both scrollFadeIn;display:flex;position:relative}.scroll-item:before{content:"";background:#8d6428;border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.scroll-item:hover{background:#8d642847;border-color:#ffeb60;transform:translate(4px)}.scroll-item:hover:before{background:#ffeb60}@keyframes scrollFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.scroll-roll-icon{filter:drop-shadow(0 2px 4px #00000080);flex-shrink:0;font-size:28px}.scroll-item-body{flex:1;min-width:0}.scroll-item-tag{font-family:var(--font-game-mono);color:#ffeb60;text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px;font-size:13px}.light .scroll-item-tag{color:#83552a}.scroll-item-title{font-family:var(--font-game-display);color:#ebdcb9;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:10px;line-height:1.4;overflow:hidden}.light .scroll-item-title{color:#382510}.scroll-item-date{font-family:var(--font-game-mono);color:#8d9ca4;font-size:13px}.scroll-item-excerpt{font-family:var(--font-game-mono);color:#9aabb3;white-space:nowrap;text-overflow:ellipsis;margin-top:4px;font-size:14px;overflow:hidden}.light .scroll-item-excerpt{color:#6d5b4a}.scroll-item-arrow{color:#8d6428;flex-shrink:0;font-size:14px;transition:transform .15s}.scroll-item:hover .scroll-item-arrow{color:#ffeb60;transform:translate(4px)}.scroll-reading-view{padding-bottom:1rem}.scroll-back-btn{font-family:var(--font-game-mono);color:#ebdcb9;cursor:pointer;background:#0c101c80;border:2px solid #8d6428;border-radius:4px;margin-bottom:16px;padding:6px 14px;font-size:16px;transition:all .15s}.scroll-back-btn:hover{color:#ffeb60;border-color:#ffeb60}.light .scroll-back-btn{color:#382510;background:#fff6;border-color:#5a3e1a}.scroll-open-paper{background:#f5ead0;border:3px solid #c4a050;border-radius:4px;position:relative;box-shadow:0 4px 16px #0006}.scroll-rod{background:linear-gradient(90deg,#6b3d10,#c47a30,#f5d060,#c47a30,#6b3d10);border-radius:3px;height:14px;box-shadow:0 2px 6px #0006}.scroll-rod-top{border-radius:3px 3px 0 0}.scroll-rod-bottom{border-radius:0 0 3px 3px}.scroll-open-content{color:#2a1a08;padding:20px 24px}.scroll-open-content .post-tag{color:#6b3d10;background:#6b3d101f;border-color:#c4a050}.scroll-open-content .post-title{color:#2a1a08}.scroll-open-content .post-byline{color:#6d5b4a}.scroll-open-content .post-body{color:#2a1a08;font-size:1.05rem}.scroll-open-content .post-body h2{color:#5a2a08}.scroll-open-content .post-body code{color:#6b3d10;background:#6b3d101f}.scroll-open-content .post-body blockquote{background:#6b3d1014;border-color:#c4a050}.workshop-search{margin-bottom:16px}.crate-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;padding-bottom:1rem;display:grid}.workshop-empty{color:var(--muted);font-family:var(--font-game-mono);text-align:center;grid-column:1/-1;padding:2rem;font-size:16px}.crate-item{cursor:pointer;border-radius:4px;transition:transform .15s;overflow:hidden}.crate-item:hover{transform:translateY(-3px)}.crate-lid{background:linear-gradient(#8a5a20,#6b3d10);border:2px solid #c4872a;border-radius:4px 4px 0 0;padding:10px 12px 8px;transition:transform .2s;position:relative}.crate-lid.open{transform-origin:bottom;border-radius:4px 4px 0 0;transform:perspective(400px)rotateX(-15deg)}.crate-lid-planks{opacity:.4;flex-direction:column;gap:3px;margin-bottom:6px;display:flex}.crate-plank{background:#ffffff26;border-radius:2px;height:3px}.crate-lid-label{font-family:var(--font-game-display);color:#ffeb60;text-align:center;text-shadow:1px 1px #000;padding:0 20px;font-size:9px}.light .crate-lid-label{color:#f5d060}.crate-latch{color:#e0c060;font-size:14px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.blueprint-panel{background:#0a1628;border:2px solid #c4872a;border-top:none;border-radius:0 0 4px 4px;padding:14px;animation:.2s crateOpen}@keyframes crateOpen{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.blueprint-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.blueprint-title{font-family:var(--font-game-display);color:#4facfe;font-size:9px}.blueprint-links{flex-wrap:wrap;gap:6px;display:flex}.blueprint-link{font-family:var(--font-game-mono);color:#ffeb60;border:1px solid #8d6428;border-radius:3px;padding:2px 8px;font-size:13px;text-decoration:none;transition:all .15s}.blueprint-link:hover{background:#ffeb601a;border-color:#ffeb60}.blueprint-desc{font-family:var(--font-game-mono);color:#a0c8e0;margin-bottom:10px;font-size:15px;line-height:1.5}.blueprint-tags{flex-wrap:wrap;gap:5px;display:flex}.blueprint-tag{font-family:var(--font-game-mono);color:#4facfe;background:#4facfe1a;border:1px solid #2a4a7a;border-radius:3px;padding:2px 8px;font-size:12px}.workshop-pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-bottom:.5rem;display:flex}.pagination-label{font-family:var(--font-game-mono);color:#8d9ca4;font-size:16px}.book-container{gap:0;max-width:720px;min-height:340px;margin:0 auto;display:flex;box-shadow:0 8px 32px #00000080}.book-page{color:#2a1a08;background:#f5ead0;flex:1;padding:24px 22px;position:relative}.book-page-left{border-right:none;border-radius:4px 0 0 4px}.book-page-right{border-radius:0 4px 4px 0}.book-page:before{content:"";pointer-events:none;background:repeating-linear-gradient(#0000,#0000 27px,#8b5a2b1f 28px);width:100%;position:absolute;top:0;bottom:0}.book-spine{background:linear-gradient(90deg,#8a5a20,#c4872a,#8a5a20);flex-shrink:0;width:18px;box-shadow:inset 0 0 8px #0006}.book-page-header{font-family:var(--font-game-display);color:#6b3d10;text-align:center;z-index:1;border-bottom:2px solid #6b3d104d;margin-bottom:14px;padding-bottom:8px;font-size:9px;position:relative}.book-page-content{z-index:1;position:relative}.book-page-content p{font-family:var(--font-game-mono);color:#2a1a08;margin-bottom:12px;font-size:16px;line-height:1.7}.book-skills-grid{flex-direction:column;gap:6px;display:flex}.book-skill-row{align-items:center;gap:8px;animation:.3s both bookSkillIn;display:flex}@keyframes bookSkillIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.book-skill-bullet{color:#6b3d10;flex-shrink:0;font-size:10px}.book-skill-name{font-family:var(--font-game-mono);color:#2a1a08;font-size:17px}.book-page-number{font-family:var(--font-game-mono);color:#8a6040;z-index:1;font-size:14px;position:absolute;bottom:12px;right:20px}.letter-tabs{gap:6px;margin-bottom:16px;display:flex}.letter-tab{font-family:var(--font-game-mono);color:#ebdcb9;cursor:pointer;background:#0c101c66;border:2px solid #8d6428;border-radius:4px;padding:6px 14px;font-size:16px;transition:all .15s}.letter-tab.active,.letter-tab:hover{color:#ffeb60;background:#8d642840;border-color:#ffeb60}.light .letter-tab{color:#382510;background:#ffffff4d;border-color:#5a3e1a}.light .letter-tab.active{color:#5d3e23;border-color:#5d3e23}.letter-paper{color:#2a1a08;background:#f5ead0;border:3px solid #c4a050;border-radius:4px;padding:20px;box-shadow:0 4px 16px #0000004d}.letter-paper-header{border-bottom:2px dashed #c4a050;align-items:flex-start;gap:14px;margin-bottom:14px;padding-bottom:12px;display:flex}.letter-wax-seal{filter:drop-shadow(0 2px 4px #0000004d);flex-shrink:0;font-size:32px}.letter-paper-from{flex-direction:column;flex:1;gap:6px;display:flex}.letter-field{color:#2a1a08;font-family:var(--font-game-mono);background:0 0;border:none;border-bottom:2px dashed #c4a050;outline:none;width:100%;padding:4px 2px;font-size:17px}.letter-field::placeholder{color:#9a8060}.letter-field:focus{border-bottom-color:#6b3d10}.letter-subject-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.letter-meta-row{flex-wrap:wrap;gap:12px;margin-bottom:10px;display:flex}.letter-meta-field{flex:1;align-items:center;gap:8px;display:flex}.letter-label{font-family:var(--font-game-mono);color:#6b3d10;white-space:nowrap;font-size:16px}.letter-select{color:#2a1a08;font-family:var(--font-game-mono);cursor:pointer;background:0 0;border:none;border-bottom:2px dashed #c4a050;outline:none;flex:1;padding:4px 2px;font-size:16px}.letter-body{color:#2a1a08;width:100%;font-family:var(--font-game-mono);resize:none;background:repeating-linear-gradient(#0000,#0000 31px,#8b5a2b33 32px);border:none;outline:none;padding:0;font-size:17px;line-height:2}.letter-footer{border-top:2px dashed #c4a050;margin-top:14px;padding-top:12px}.letter-services{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.letter-paper .service-chip{color:#6b3d10;background:#6b3d101a;border-color:#6b3d104d;font-size:13px}.letter-send-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.letter-send-btn{font-family:var(--font-game-mono);font-size:18px}.letter-sent{font-family:var(--font-game-mono);color:#3a8060;font-size:17px}.letter-error{font-family:var(--font-game-mono);color:#c33;font-size:14px}.direct-contact{padding-top:4px}.observatory-body{flex-direction:column;gap:12px;display:flex}.constellation-canvas{aspect-ratio:2;cursor:crosshair;background:#050a14;border:2px solid #2a4a6b;border-radius:6px;width:100%;max-height:420px;display:block}.constellation-legend{flex-wrap:wrap;justify-content:center;gap:12px;padding:8px 0 4px;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;box-shadow:0 0 6px}.legend-label{font-family:var(--font-game-mono);color:#aeb8bd;font-size:15px}.light .legend-label{color:#4a3a2a}.scholar-dialogue-box{z-index:25;background:#0c101cf7;border:3px solid #8d6428;border-radius:6px;gap:0;width:min(560px,94vw);animation:.25s dialogueSlideUp;display:flex;position:absolute;bottom:60px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #000000b3}@keyframes dialogueSlideUp{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.scholar-portrait{background:linear-gradient(#2a1a40,#1a0e28);border-right:3px solid #8d6428;border-radius:4px 0 0 4px;flex-shrink:0;justify-content:center;align-items:center;width:72px;display:flex}.scholar-portrait-inner{filter:drop-shadow(0 2px 8px #7eb4ff66);font-size:38px}.scholar-dialogue-content{flex:1;padding:14px 16px}.scholar-name{font-family:var(--font-game-display);color:#ffeb60;letter-spacing:1px;margin-bottom:8px;font-size:8px}.scholar-text{font-family:var(--font-game-mono);color:#ebdcb9;min-height:2.5em;margin-bottom:12px;font-size:18px;line-height:1.5}.scholar-dialogue-actions{flex-wrap:wrap;gap:8px;display:flex}.scholar-btn{font-family:var(--font-game-mono);color:#ebdcb9;cursor:pointer;background:#8d642833;border:2px solid #8d6428;border-radius:4px;padding:5px 12px;font-size:15px;transition:all .15s}.scholar-btn:hover{color:#ffeb60;background:#8d642859;border-color:#ffeb60}.scholar-btn-recommend{color:#ffeb60;text-align:left;background:#8d64284d;border-color:#ffeb60;flex:1}.scholar-btn-skip{opacity:.6;font-size:13px}@media (width<=768px){.book-container{flex-direction:column}.book-spine{width:100%;height:12px}.book-page-left{border-radius:4px 4px 0 0}.book-page-right{border-radius:0 0 4px 4px}.crate-grid{grid-template-columns:1fr}.scroll-item-title{font-size:8px}.constellation-canvas{aspect-ratio:4/3;min-height:280px;max-height:none}.scholar-dialogue-box{width:96vw;bottom:50px}.scholar-portrait{width:56px}.scholar-portrait-inner{font-size:28px}.letter-paper{padding:14px}.letter-meta-row{flex-direction:column}}.tavern-board{background:repeating-linear-gradient(90deg,#5a371414 0,#0000 2px 30px),linear-gradient(#4a2e10,#3a2208,#4a2e10);border:3px solid #8d6428;border-radius:6px;grid-template-columns:1fr 1fr;gap:14px;max-width:740px;margin:0 auto;padding:18px;display:grid;position:relative;box-shadow:inset 0 0 30px #00000080,0 6px 24px #0009}.light .tavern-board{background:repeating-linear-gradient(90deg,#8b5a2b1a 0,#0000 2px 30px),linear-gradient(#e8d5b0,#d4bf96,#e8d5b0);border-color:#5a3e1a;box-shadow:inset 0 0 20px #0000001a,0 4px 16px #0003}.tavern-card{background:linear-gradient(135deg,#f5ead0 0%,#ede0c0 40%,#f0e4c8 100%);border:2px solid #8d6428;border-radius:4px;padding:0;transition:transform .15s,box-shadow .15s;position:relative;overflow:visible;box-shadow:2px 3px 8px #0006,inset 0 1px #fff6}.tavern-card:hover{transform:translateY(-2px);box-shadow:3px 5px 12px #00000080,inset 0 1px #fff6}.tavern-card:before{content:"";pointer-events:none;background:radial-gradient(at 20% 80%,#8b5a2b0f 0%,#0000 60%),radial-gradient(at 80% 20%,#8b5a2b0a 0%,#0000 50%);border-radius:3px;position:absolute;inset:0}.tavern-card-corner{z-index:3;background:radial-gradient(circle at 35% 35%,#e8a040,#8d6428 60%,#5a3e1a);border-radius:50%;width:10px;height:10px;position:absolute;box-shadow:inset 0 -1px 2px #0006,0 1px 2px #0000004d}.tavern-card-corner-tl{top:-4px;left:-4px}.tavern-card-corner-tr{top:-4px;right:-4px}.tavern-card-corner-bl{bottom:-4px;left:-4px}.tavern-card-corner-br{bottom:-4px;right:-4px}.tavern-card-header{z-index:1;background:linear-gradient(#8b5a2b1f,#0000);border-bottom:2px solid #8b5a2b4d;align-items:center;gap:8px;padding:10px 14px 8px;display:flex;position:relative}.tavern-card-icon{filter:drop-shadow(0 1px 2px #0000004d);font-size:18px}.tavern-card-title{font-family:var(--font-game-display);color:#6b3d10;text-transform:uppercase;letter-spacing:.08em;text-shadow:0 1px #ffffff4d;font-size:9px}.tavern-card-body{font-family:var(--font-game-mono);color:#2a1a08;z-index:1;padding:12px 14px 14px;font-size:17px;position:relative}.tavern-bard-loading,.tavern-bard-idle{color:#6d5b4a;align-items:center;gap:10px;font-size:16px;display:flex}.tavern-bard-icon{font-size:20px}.tavern-bard-spin{animation:2s linear infinite tavern-spin}@keyframes tavern-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tavern-bard-active{align-items:center;gap:12px;display:flex}.tavern-bard-art img{object-fit:cover;border:2px solid #8d6428;border-radius:3px;width:52px;height:52px;display:block;box-shadow:0 2px 6px #0000004d}.tavern-bard-art-placeholder{background:#8b5a2b26;border:2px solid #8d6428;border-radius:3px;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;display:flex}.tavern-bard-info{flex:1;min-width:0}.tavern-bard-title{font-family:var(--font-game-display);color:#6b3d10;white-space:nowrap;text-overflow:ellipsis;text-shadow:0 1px #ffffff4d;font-size:8px;overflow:hidden}.tavern-bard-artist{font-family:var(--font-game-mono);color:#2a1a08;margin-top:2px;font-size:16px}.tavern-bard-album{font-family:var(--font-game-mono);color:#6d5b4a;margin-top:1px;font-size:14px}.tavern-bard-subtitle{font-family:var(--font-game-mono);color:#8b7355;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;font-size:12px}.tavern-bard-art-sm{border-radius:4px;flex-shrink:0;width:40px;height:40px}.tavern-bard-eq{flex-shrink:0;align-items:flex-end;gap:3px;height:20px;display:flex}.tavern-bard-eq span{background:#8d6428;border-radius:1px;width:3px;animation:.8s ease-in-out infinite alternate tavern-eq}.tavern-bard-eq span:first-child{height:35%;animation-delay:0s}.tavern-bard-eq span:nth-child(2){height:65%;animation-delay:.2s}.tavern-bard-eq span:nth-child(3){height:45%;animation-delay:.4s}.tavern-bard-eq span:nth-child(4){height:75%;animation-delay:.1s}@keyframes tavern-eq{0%{height:20%}to{height:90%}}.tavern-bard-listen{font-family:var(--font-game-mono);color:#f5ead0;background:linear-gradient(135deg,#1db954,#1aa34a);border:1px solid #17943f;border-radius:4px;flex-shrink:0;align-items:center;gap:4px;margin-top:8px;padding:4px 10px;font-size:13px;text-decoration:none;transition:all .2s;display:inline-flex}.tavern-bard-listen:hover{background:linear-gradient(135deg,#1ed760,#1db954);transform:translateY(-1px);box-shadow:0 2px 6px #1db9544d}.tavern-bard-listen-sm{padding:4px 6px;font-size:16px}.tavern-quest-text{color:#2a1a08;margin:0 0 10px;font-size:17px;line-height:1.5}.tavern-quest-divider{background:linear-gradient(90deg,#0000,#8b5a2b66,#0000);height:2px;margin:10px 0}.tavern-quest-meta{flex-wrap:wrap;gap:10px;display:flex}.tavern-quest-stat{background:#8b5a2b1a;border:1px solid #8b5a2b40;border-radius:3px;flex-direction:column;flex:1;gap:2px;padding:6px 10px;display:flex}.tavern-quest-stat-label{font-family:var(--font-game-display);color:#8d6428;text-transform:uppercase;letter-spacing:.1em;font-size:7px}.tavern-quest-stat-value{font-family:var(--font-game-mono);color:#2a1a08;font-size:15px}.tavern-study-list{flex-direction:column;gap:7px;display:flex}.tavern-study-item{color:#2a1a08;background:#8b5a2b14;border-left:3px solid #8d6428;border-radius:0 3px 3px 0;align-items:center;gap:10px;padding:4px 8px;font-size:17px;transition:background .15s;animation:.3s both tavern-fade-in;display:flex}.tavern-study-item:hover{background:#8b5a2b2e}.tavern-study-bullet{color:#8d6428;flex-shrink:0;font-size:10px}.tavern-study-name{font-family:var(--font-game-mono);font-size:17px}@keyframes tavern-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tavern-card-arsenal{grid-column:1/-1}.tavern-arsenal-grid{grid-template-columns:1fr 1fr;gap:10px 18px;display:grid}.tavern-arsenal-item{flex-direction:column;gap:5px;animation:.3s both tavern-fade-in;display:flex}.tavern-arsenal-head{align-items:center;gap:6px;display:flex}.tavern-arsenal-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.tavern-arsenal-name{font-family:var(--font-game-mono);color:#2a1a08;flex:1;font-size:16px}.tavern-arsenal-bar{background:#8b5a2b26;border:1px solid #8b5a2b4d;border-radius:3px;height:10px;position:relative;overflow:hidden}.tavern-arsenal-fill{background:linear-gradient(90deg,#8d6428,#c4872a,#e8a040);border-radius:2px;height:100%;transition:width .6s;box-shadow:inset 0 1px #ffffff4d}.tavern-arsenal-lvl{font-family:var(--font-game-display);color:#6b3d10;text-align:right;text-shadow:0 1px #ffffff4d;flex-shrink:0;min-width:28px;font-size:7px}.tavern-atmosphere{font-family:var(--font-game-mono);color:#ebdcb980;background:#0003;border:1px solid #8d642833;border-radius:4px;flex-wrap:wrap;grid-column:1/-1;justify-content:center;align-items:center;gap:10px;padding:6px 12px;font-size:14px;font-style:italic;display:flex}.light .tavern-atmosphere{color:#5a371480;background:#8b5a2b14;border-color:#8b5a2b26}.tavern-atmo-dot{color:#ebdcb94d;font-size:20px;line-height:1}.light .tavern-atmo-dot{color:#5a37144d}@media (width<=600px){.tavern-board{grid-template-columns:1fr;padding:12px}.tavern-card-arsenal{grid-column:1}.tavern-arsenal-grid{grid-template-columns:1fr}.tavern-atmosphere{flex-direction:column;align-items:center;gap:4px}.tavern-bard-active{flex-wrap:wrap}.tavern-bard-eq{margin-top:4px}.tavern-quest-meta{flex-direction:column}}
