@import url(https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Libre+Franklin:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap);:root{--bg-primary:#fafaf8;--bg-secondary:#f1f0ec;--bg-tertiary:#e8e7e3;--bg-card:#fff;--bg-card-hover:#f7f7f5;--accent-primary:#7ba899;--accent-secondary:#5b8f7e;--accent-soft:#a8d5c2;--accent-blue:#89abc4;--accent-blue-soft:#b3cfdf;--accent-warm:#c4a87b;--text-primary:#2a2a28;--text-secondary:#5c5c58;--text-muted:#8a8a85;--text-accent:#5b8f7e;--border-subtle:#00000012;--border-accent:#7ba8994d;--gradient-brand:linear-gradient(135deg,#7ba899,#89abc4);--gradient-card:linear-gradient(145deg,#7ba8990f,#89abc408);--shadow-card:0 1px 3px #0000000a,0 4px 12px #00000008;--shadow-hover:0 4px 20px #0000000f;--shadow-btn:0 1px 2px #0000000f,inset 0 1px 0 #ffffffb3;--font-heading:"DM Serif Display",Georgia,serif;--font-body:"Libre Franklin",-apple-system,sans-serif;--font-mono:"IBM Plex Mono",monospace;--sidebar-width:308px;--header-height:64px;--radius:10px;--radius-sm:6px;--navbar-bg:#fafaf8e0;--sidebar-bg:var(--bg-secondary);--selection-bg:#7ba89940;--scrollbar-thumb:#c4c4be;--code-bg:#7ba89914;--code-color:#5b8f7e}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#222;--bg-tertiary:#2c2c2c;--bg-card:#262626;--bg-card-hover:#2e2e2e;--accent-primary:#8fbfad;--accent-secondary:#a8d5c2;--accent-soft:#5b8f7e;--accent-blue:#9dbdd4;--accent-blue-soft:#6a97b4;--accent-warm:#d4b88a;--text-primary:#e8e8e4;--text-secondary:#a8a8a3;--text-muted:#6e6e69;--text-accent:#a8d5c2;--border-subtle:#ffffff0f;--border-accent:#8fbfad40;--gradient-brand:linear-gradient(135deg,#8fbfad,#9dbdd4);--gradient-card:linear-gradient(145deg,#8fbfad0d,#9dbdd405);--shadow-card:0 1px 3px #0003,0 4px 12px #00000026;--shadow-hover:0 4px 20px #00000040;--shadow-btn:0 1px 2px #0000004d,inset 0 1px 0 #ffffff0a;--navbar-bg:#1a1a1ae6;--sidebar-bg:var(--bg-secondary);--selection-bg:#8fbfad4d;--scrollbar-thumb:#444;--code-bg:#8fbfad1a;--code-color:#a8d5c2}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fafaf8;background:var(--bg-primary);color:#2a2a28;color:var(--text-primary);font-family:Libre Franklin,-apple-system,sans-serif;font-family:var(--font-body);line-height:1.65;transition:background .3s ease,color .3s ease}a{color:#5b8f7e;color:var(--accent-secondary);text-decoration:none;transition:color .2s ease}a:hover{color:#7ba899;color:var(--accent-primary)}::selection{background:#7ba89940;background:var(--selection-bg);color:#2a2a28;color:var(--text-primary)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#c4c4be;background:var(--scrollbar-thumb);border-radius:3px}.app{display:flex;flex-direction:column;min-height:100vh}.app-body{display:flex;flex:1 1;margin-top:var(--header-height)}.main-content{flex:1 1;margin-left:var(--sidebar-width);min-height:calc(100vh - var(--header-height));padding:32px 36px}.main-content.no-sidebar{margin-left:0;padding:32px 48px}.navbar{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:var(--navbar-bg);border-bottom:1px solid var(--border-subtle);height:var(--header-height);justify-content:space-between;left:0;padding:0 40px;position:fixed;right:0;top:0;transition:background .3s ease;z-index:1000}.navbar,.navbar-brand{align-items:center;display:flex}.navbar-brand{color:var(--text-primary);gap:14px;text-decoration:none}.navbar-brand .brand-logo{align-items:center;background:var(--accent-primary);border:none;border-radius:8px;box-shadow:0 1px 4px #0000001a;color:#fff;display:flex;font-family:"DM Serif Display",Georgia,serif;font-size:.7rem;font-style:italic;font-weight:400;height:26px;justify-content:center;letter-spacing:1px;transition:all .2s ease;width:26px}.navbar-brand:hover .brand-logo{background:var(--accent-hover);box-shadow:0 2px 8px #0003}.navbar-brand .brand-text{font-family:var(--font-heading);font-size:1.2rem;letter-spacing:-.01em}.navbar-brand .brand-text .engineer,.navbar-brand .brand-text .the{color:var(--text-primary)}.navbar-brand .brand-text .wicked{color:var(--accent-secondary)}.navbar-right{gap:4px}.navbar-links,.navbar-right{align-items:center;display:flex}.navbar-links{gap:2px}.navbar-links .nav-link,.navbar-links a{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-family:var(--font-body);font-size:.88rem;font-weight:500;letter-spacing:.01em;padding:8px 16px;text-decoration:none;transition:all .2s ease}.navbar-links .nav-link:hover,.navbar-links a:hover{background:var(--bg-tertiary);color:var(--text-primary)}.navbar-links .nav-link.active,.navbar-links a.active{background:var(--code-bg);color:var(--accent-secondary)}.theme-toggle{align-items:center;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-btn);color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;margin-left:8px;transition:all .2s ease;width:36px}.theme-toggle:hover{border-color:var(--border-accent);color:var(--accent-warm)}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:20px;height:calc(100vh - var(--header-height));left:0;overflow-y:auto;padding:28px 20px;position:fixed;top:var(--header-height);transition:background .3s ease;width:var(--sidebar-width)}.sidebar-section-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.65rem;letter-spacing:1.5px;padding:0 4px;text-transform:uppercase}.sidebar-photo{align-items:center;align-self:center;background:var(--bg-tertiary);border:2px solid var(--border-accent);border-radius:50%;display:flex;height:100px;justify-content:center;object-fit:cover;overflow:hidden;width:100px}.sidebar-photo .photo-placeholder{color:var(--text-muted);font-size:2.2rem}.sidebar-photo-img{border-radius:50%;height:100%;object-fit:cover;width:100%}.sidebar-identity{text-align:center}.sidebar-name{color:var(--text-primary);font-family:var(--font-heading);font-size:1.15rem;font-weight:400}.sidebar-role{color:var(--accent-secondary);font-size:.78rem;font-weight:500;margin-top:3px}.sidebar-title{color:var(--text-muted);font-family:var(--font-mono);font-size:.74rem;font-style:italic;margin-top:4px}.sidebar-bio{color:var(--text-secondary);font-size:.85rem;line-height:1.6;padding:0 4px;text-align:center}.sidebar-divider{background:var(--border-subtle);height:1px;width:100%}.sidebar-skills{display:flex;flex-wrap:wrap;gap:6px;padding:0 2px}.skill-btn{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:5px;box-shadow:var(--shadow-btn);color:var(--text-secondary);cursor:default;font-family:var(--font-mono);font-size:.72rem;padding:5px 11px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.skill-btn:hover{border-color:var(--border-accent);box-shadow:var(--shadow-card);color:var(--accent-secondary);transform:translateY(-1px)}.sidebar-links{gap:8px}.sidebar-link,.sidebar-links{display:flex;justify-content:center}.sidebar-link{align-items:center;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-btn);color:var(--text-muted);cursor:pointer;font-size:1rem;height:36px;text-decoration:none;transition:all .2s ease;width:36px}.sidebar-link:hover{border-color:var(--border-accent);color:var(--accent-secondary);transform:translateY(-1px)}.home-page{max-width:100%}.page-header{margin-bottom:32px}.page-header h1{font-family:var(--font-heading);font-size:2.1rem;font-weight:400;letter-spacing:-.01em;line-height:1.2;margin-bottom:6px}.page-header h1 .highlight{color:var(--accent-secondary);font-style:italic}.page-header p{color:var(--text-secondary);font-size:.92rem}.section-label{align-items:center;color:var(--text-muted);display:flex;font-family:var(--font-mono);font-size:.7rem;gap:8px;letter-spacing:1.5px;margin-bottom:6px;text-transform:uppercase}.section-label:before{background:var(--accent-primary);border-radius:1px;content:"";height:1.5px;width:14px}.blog-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(341px,1fr))}.blog-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow-card);color:inherit;cursor:pointer;display:flex;flex-direction:column;text-decoration:none;transition:all .25s ease}.blog-card,.blog-card-cover{overflow:hidden;position:relative}.blog-card-cover{flex-shrink:0;height:150px;width:100%}.blog-card-cover img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.blog-card:hover .blog-card-cover img,.featured-card:hover .blog-card-cover img{transform:scale(1.03)}.blog-card-body{display:flex;flex:1 1;flex-direction:column;padding:16px 18px}.blog-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.blog-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.blog-card-category{background:var(--code-bg);border:1px solid var(--border-accent);border-radius:4px;color:var(--accent-secondary);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.8px;padding:3px 9px;text-transform:uppercase}.blog-card-date,.blog-card-readtime{color:var(--text-muted);font-size:.78rem}.blog-card-readtime{margin-left:auto}.blog-card h3{font-family:var(--font-heading);font-size:1.045rem;font-weight:400;line-height:1.3;margin-bottom:6px}.blog-card-excerpt,.featured-card .blog-card-excerpt{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box!important;font-size:.8rem;line-height:1.55;margin-bottom:0;overflow:hidden}.blog-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.blog-card-tag{background:var(--bg-secondary);border-radius:3px;color:var(--text-muted);font-family:var(--font-mono);font-size:.72rem;padding:2px 7px}.blog-card-footer{align-items:flex-end;display:flex;justify-content:space-between;margin-top:auto;padding-top:10px}.read-more{align-items:center;color:var(--accent-secondary);display:flex;flex-shrink:0;font-family:var(--font-mono);font-size:.78rem;gap:5px;margin-left:auto;transition:gap .2s ease;white-space:nowrap}.blog-card:hover .read-more{gap:8px}.featured-card{background:var(--bg-card);border:1px solid var(--border-accent);border-radius:var(--radius);box-shadow:var(--shadow-card);color:inherit;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;position:relative;text-decoration:none;transition:all .25s ease}.featured-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.featured-badge{align-items:center;color:var(--accent-warm);display:flex;font-family:var(--font-mono);font-size:.68rem;gap:6px;letter-spacing:1.5px;margin-bottom:10px;text-transform:uppercase}.featured-badge:before{animation:pulse-dot 2.5s ease-in-out infinite;background:var(--accent-warm);border-radius:50%;content:"";height:5px;width:5px}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.featured-card h2{font-family:var(--font-heading);font-size:1.14rem;font-weight:400;line-height:1.3;margin-bottom:10px}.categories-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}.category-btn{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:5px;box-shadow:var(--shadow-btn);color:var(--text-secondary);cursor:pointer;font-family:var(--font-mono);font-size:.76rem;padding:5px 14px;transition:all .2s ease}.category-btn:hover{border-color:var(--border-accent);color:var(--text-primary)}.category-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:none;color:#fff}.projects-page{max-width:100%}.projects-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(341px,1fr))}.project-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow-card);display:flex;flex-direction:column;padding:18px 20px;transition:all .25s ease}.project-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.project-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.project-icon{align-items:center;background:var(--code-bg);border:1px solid var(--border-accent);border-radius:8px;color:var(--accent-secondary);display:flex;font-size:1.1rem;height:40px;justify-content:center;width:40px}.project-links{display:flex;gap:6px}.project-link{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;font-size:.85rem;height:30px;justify-content:center;text-decoration:none;transition:all .2s ease;width:30px}.project-link:hover{border-color:var(--border-accent);color:var(--accent-secondary)}.project-card h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:400;margin-bottom:6px}.project-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.6}.project-tech{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.project-tech-tag{background:var(--code-bg);border:1px solid #89abc426;border-radius:4px;color:var(--accent-blue);font-family:var(--font-mono);font-size:.68rem;padding:3px 9px}.about-page{max-width:100%}.about-section{margin-bottom:32px}.about-section h2{align-items:center;display:flex;font-family:var(--font-heading);font-size:1.3rem;font-weight:400;gap:10px;margin-bottom:14px}.about-section h2 .icon{color:var(--accent-secondary)}.about-section p{color:var(--text-secondary);font-size:.92rem;line-height:1.75;margin-bottom:10px}.skills-grid{display:flex;flex-wrap:wrap;gap:8px}.skill-tag{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:5px;box-shadow:var(--shadow-btn);color:var(--text-secondary);font-family:var(--font-mono);font-size:.76rem;padding:5px 12px;transition:all .2s ease}.skill-tag:hover{border-color:var(--border-accent);color:var(--accent-secondary)}.subscribe-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-top:44px;overflow:hidden;padding:36px;position:relative;text-align:center}.subscribe-section:before{background:var(--gradient-brand);content:"";height:2px;left:0;position:absolute;top:0;width:100%}.subscribe-section h2{font-family:var(--font-heading);font-size:1.35rem;font-weight:400;margin-bottom:6px}.subscribe-section p{color:var(--text-secondary);font-size:.88rem;margin-bottom:20px}.subscribe-form{display:flex;gap:10px;margin:0 auto;max-width:600px}.subscribe-form input{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);flex:1 1;font-family:var(--font-body);font-size:.88rem;outline:none;padding:10px 16px;transition:border-color .2s ease,box-shadow .2s ease}.subscribe-form input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #7ba8991f}.subscribe-form input::placeholder{color:var(--text-muted)}.subscribe-form button{background:var(--accent-primary);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.88rem;font-weight:600;padding:10px 24px;transition:all .2s ease;white-space:nowrap}.subscribe-form button:hover{background:var(--accent-secondary);transform:translateY(-1px)}.subscribe-success{color:var(--accent-secondary);font-family:var(--font-mono);font-size:.82rem;margin-top:10px}.blog-detail{width:100%}.blog-detail-header{margin-bottom:28px}.blog-detail-back{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-family:var(--font-mono);font-size:.78rem;gap:5px;margin-bottom:18px;transition:color .2s ease}.blog-detail-back:hover{color:var(--accent-secondary)}.blog-detail h1{font-family:var(--font-heading);font-size:2rem;font-weight:400;letter-spacing:-.01em;line-height:1.25;margin-bottom:14px}.blog-detail-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.82rem;gap:14px}.blog-detail-cover{border-radius:var(--radius);margin-bottom:28px;max-height:420px;overflow:hidden}.blog-detail-cover img{display:block;height:100%;object-fit:cover;width:100%}.blog-detail-content{color:var(--text-secondary);font-size:.95rem;line-height:1.85}.blog-detail-content h2{font-size:1.3rem;margin:28px 0 14px}.blog-detail-content h2,.blog-detail-content h3{color:var(--text-primary);font-family:var(--font-heading);font-weight:400}.blog-detail-content h3{font-size:1.1rem;margin:22px 0 10px}.blog-detail-content p{margin-bottom:14px}.blog-detail-content code{background:var(--code-bg);border-radius:3px;color:var(--code-color);font-family:var(--font-mono);font-size:.85em;padding:2px 5px}.blog-detail-content pre{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);margin:18px 0;overflow-x:auto;padding:18px}.blog-detail-content pre code{background:none;padding:0}.blog-detail-content ol,.blog-detail-content ul{margin-bottom:14px;padding-left:22px}.blog-detail-content li{margin-bottom:6px}.subscribe-page{padding-top:56px;text-align:center;width:100%}.subscribe-page h1{font-family:var(--font-heading);font-size:2rem;font-weight:400;margin-bottom:10px}.subscribe-page .subtitle{color:var(--text-secondary);font-size:1rem;line-height:1.65;margin-bottom:32px}.subscribe-benefits{display:flex;flex-direction:column;gap:10px;margin:28px 0;text-align:left}.benefit-item{align-items:center;color:var(--text-secondary);display:flex;font-size:.92rem;gap:10px}.benefit-icon{color:var(--accent-secondary);flex-shrink:0;font-size:.95rem}.footer{border-top:1px solid var(--border-subtle);color:var(--text-muted);font-size:.78rem;margin-left:var(--sidebar-width);padding:20px 44px;text-align:center;transition:margin .3s ease}.footer a{color:var(--accent-secondary)}@media (max-width:1024px){.sidebar{display:none}.main-content{margin-left:0;padding:28px 24px}.footer{margin-left:0}.mobile-about-toggle{display:flex}}@media (max-width:768px){.navbar{padding:0 18px}.navbar-links{gap:2px}.navbar-links .nav-link,.navbar-links a{font-size:.8rem;padding:6px 10px}.blog-grid,.projects-grid{grid-template-columns:1fr}.subscribe-form{flex-direction:column}.featured-card{padding:18px}.blog-detail h1{font-size:1.5rem}.page-header h1{font-size:1.6rem}}.mobile-about-toggle{align-items:center;background:var(--accent-primary);border:none;border-radius:50%;bottom:22px;box-shadow:0 2px 12px #00000026;color:#fff;cursor:pointer;display:none;font-size:1.1rem;height:46px;justify-content:center;position:fixed;right:22px;width:46px;z-index:999}.mobile-sidebar-overlay{background:#0006;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:1001}.mobile-sidebar-overlay.open{display:block}.sidebar.mobile-open{display:flex;z-index:1002}@media (max-width:1024px){.mobile-about-toggle{display:flex}}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-card) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.empty-state{color:var(--text-muted);padding:56px 20px;text-align:center}.empty-state .icon{font-size:2.5rem;margin-bottom:14px;opacity:.3}.empty-state h3{color:var(--text-secondary);font-family:var(--font-heading);font-size:1.15rem;font-weight:400;margin-bottom:6px}.empty-state p{font-size:.88rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{animation:fadeUp .4s ease-out}.blog-card,.featured-card,.project-card{animation:fadeUp .35s ease-out backwards}.blog-card:first-child{animation-delay:.05s}.blog-card:nth-child(2){animation-delay:.1s}.blog-card:nth-child(3){animation-delay:.15s}.blog-card:nth-child(4){animation-delay:.2s}.blog-card:nth-child(5){animation-delay:.25s}.project-card:first-child{animation-delay:.05s}.project-card:nth-child(2){animation-delay:.1s}.project-card:nth-child(3){animation-delay:.15s}.project-card:nth-child(4){animation-delay:.2s}.admin-login-wrap{align-items:center;background:#f5f5f3;background:var(--bg-secondary,#f5f5f3);display:flex;justify-content:center;min-height:100vh;padding:24px}.admin-login-card{background:#fff;background:var(--bg-primary,#fff);border:1px solid #e8e8e4;border:1px solid var(--border-subtle,#e8e8e4);border-radius:12px;box-shadow:0 4px 24px #0000000f;max-width:400px;padding:40px;width:100%}.admin-login-brand{align-items:center;display:flex;gap:10px;margin-bottom:28px}.admin-brand-logo{align-items:center;background:#7ba899;background:var(--accent-primary,#7ba899);border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-family:"DM Serif Display",serif;font-size:.65rem;font-style:italic;height:32px;justify-content:center;letter-spacing:1px;width:32px}.admin-brand-label{color:#888;color:var(--text-muted,#888);font-family:IBM Plex Mono,monospace;font-family:var(--font-mono,"IBM Plex Mono",monospace);font-size:.7rem;letter-spacing:2px;text-transform:uppercase}.admin-login-card h1{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-family:"DM Serif Display",serif;font-family:var(--font-heading,"DM Serif Display",serif);font-size:1.6rem;margin:0 0 4px}.admin-login-sub{color:#888;color:var(--text-muted,#888);font-size:.82rem;margin:0 0 28px}.admin-login-form{gap:16px}.admin-field,.admin-login-form{display:flex;flex-direction:column}.admin-field{gap:6px}.admin-field label{color:#555;color:var(--text-secondary,#555);font-size:.78rem;font-weight:600;letter-spacing:.02em}.admin-field input,.admin-field select,.admin-field textarea{background:#fff;background:var(--bg-primary,#fff);border:1px solid #ddd;border:1px solid var(--border-default,#ddd);border-radius:7px;box-sizing:border-box;color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-family:Libre Franklin,sans-serif;font-family:var(--font-body,"Libre Franklin",sans-serif);font-size:.88rem;padding:9px 12px;transition:border-color .2s;width:100%}.admin-field input:focus,.admin-field select:focus,.admin-field textarea:focus{border-color:#7ba899;border-color:var(--accent-primary,#7ba899);outline:none}.admin-pass-wrap{position:relative}.admin-pass-wrap input{padding-right:40px}.admin-pass-toggle{align-items:center;background:none;border:none;color:#aaa;color:var(--text-muted,#aaa);cursor:pointer;display:flex;padding:0;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.admin-error{color:#e05c5c;font-size:.82rem;margin:0}.admin-btn-primary{align-items:center;background:#7ba899;background:var(--accent-primary,#7ba899);border:none;border-radius:7px;color:#fff;cursor:pointer;display:inline-flex;font-family:sans-serif;font-family:var(--font-body,sans-serif);font-size:.85rem;font-weight:600;gap:6px;padding:9px 18px;transition:background .2s}.admin-btn-primary:hover{background:#5b8f7e;background:var(--accent-hover,#5b8f7e)}.admin-btn-ghost{align-items:center;background:#0000;border:1px solid #ddd;border:1px solid var(--border-default,#ddd);border-radius:7px;color:#666;color:var(--text-secondary,#666);cursor:pointer;display:inline-flex;font-family:sans-serif;font-family:var(--font-body,sans-serif);font-size:.83rem;gap:6px;padding:8px 14px;transition:all .2s}.admin-btn-ghost:hover{border-color:#7ba899;border-color:var(--accent-primary,#7ba899);color:#7ba899;color:var(--accent-primary,#7ba899)}.admin-btn-danger{border-color:#e05c5c;color:#e05c5c}.admin-btn-full{justify-content:center;width:100%}.admin-btn-sm{font-size:.8rem;padding:6px 12px}.admin-btn-icon{align-items:center;background:none;border:none;border-radius:6px;color:#aaa;color:var(--text-muted,#aaa);cursor:pointer;display:flex;flex-shrink:0;padding:6px;transition:all .15s}.admin-btn-delete:hover{background:#fef2f2;color:#e05c5c}.admin-dashboard{background:#f7f7f5;background:var(--bg-secondary,#f7f7f5);min-height:100vh}.admin-header{align-items:center;background:#fff;background:var(--bg-primary,#fff);border-bottom:1px solid #eee;border-bottom:1px solid var(--border-subtle,#eee);display:flex;height:60px;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:100}.admin-header-brand{align-items:center;display:flex;gap:10px}.admin-header-title{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-family:serif;font-family:var(--font-heading,serif);font-size:1rem}.admin-header-actions{align-items:center;display:flex;gap:8px}.admin-tabs{background:#fff;background:var(--bg-primary,#fff);border-bottom:1px solid #eee;border-bottom:1px solid var(--border-subtle,#eee);display:flex;gap:2px;padding:16px 32px 0}.admin-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#888;color:var(--text-muted,#888);cursor:pointer;display:flex;font-family:sans-serif;font-family:var(--font-body,sans-serif);font-size:.85rem;gap:6px;margin-bottom:-1px;padding:10px 18px;transition:all .2s}.admin-tab.active{border-bottom-color:#7ba899;border-bottom-color:var(--accent-primary,#7ba899);color:#7ba899;color:var(--accent-primary,#7ba899)}.admin-tab-count{background:#f0f0ed;background:var(--bg-secondary,#f0f0ed);border-radius:20px;font-size:.72rem;font-weight:600;padding:1px 7px}.admin-content{margin:0 auto;max-width:900px;padding:32px}.admin-section-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:20px}.admin-section-header h2{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-family:serif;font-family:var(--font-heading,serif);font-size:1.2rem;margin:0}.admin-section-actions{align-items:center;display:flex;gap:8px}.admin-sync-msg{animation:fadeUp .3s ease;color:#aaa;color:var(--text-muted,#aaa);font-size:.78rem}.admin-form-wrap{background:#fff;background:var(--bg-primary,#fff);border:1px solid #eee;border:1px solid var(--border-subtle,#eee);border-radius:10px;margin-bottom:24px;padding:24px}.admin-form-wrap h3{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-family:serif;font-family:var(--font-heading,serif);font-size:1rem;margin:0 0 18px}.admin-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.admin-field-full{grid-column:1/-1}.admin-content-area{font-family:IBM Plex Mono,monospace!important;font-family:var(--font-mono,"IBM Plex Mono",monospace)!important;font-size:.8rem!important;line-height:1.6;resize:vertical}.admin-form-actions{display:flex;gap:10px;margin-top:18px}.admin-list{display:flex;flex-direction:column;gap:8px}.admin-list-item{align-items:center;background:#fff;background:var(--bg-primary,#fff);border:1px solid #eee;border:1px solid var(--border-subtle,#eee);border-radius:8px;display:flex;gap:14px;padding:14px 16px;transition:border-color .2s}.admin-list-item:hover{border-color:#ddd;border-color:var(--border-default,#ddd)}.admin-list-thumb{border-radius:5px;flex-shrink:0;height:42px;object-fit:cover;width:60px}.admin-list-info{display:flex;flex:1 1;flex-direction:column;gap:3px;min-width:0}.admin-list-label{color:#7ba899;color:var(--accent-primary,#7ba899);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.admin-list-info strong{color:#1a1a1a;color:var(--text-primary,#1a1a1a);font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-list-meta{font-size:.75rem}.admin-empty,.admin-list-meta{color:#aaa;color:var(--text-muted,#aaa)}.admin-empty{font-size:.88rem;padding:40px;text-align:center}.admin-list-actions{display:flex;flex-shrink:0;gap:4px}.admin-image-upload{display:flex;flex-direction:column;gap:10px}.admin-upload-btn{align-self:flex-start}.admin-image-preview{display:inline-block;position:relative}.admin-image-preview img{border:1px solid #eee;border:1px solid var(--border-subtle,#eee);border-radius:6px;display:block;height:100px;object-fit:cover;width:180px}.admin-image-remove{align-items:center;background:#e05c5c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:22px;justify-content:center;line-height:1;position:absolute;right:-8px;top:-8px;width:22px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spin{animation:spin .8s linear infinite}
/*# sourceMappingURL=main.a1445b0f.css.map*/