.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-40px;left:0;padding:8px 16px;background:var(--accent-primary);color:#fff;font-weight:600;z-index:9999;border-radius:0 0 4px;text-decoration:none;transition:top .2s}.skip-link:focus{top:0}:root{--bg-primary: #121212;--bg-secondary: #1e1e1e;--bg-tertiary: #2d2d2d;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--accent-primary: #2e7d32;--accent-secondary: #388e3c;--accent-light: #66bb6a;--border-color: #333;--shadow: 0 4px 6px rgba(0, 0, 0, .1);--card-bg: #252525}body{margin:0;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn-danger{background:linear-gradient(135deg,#b71c1c,#880e4f)}.grid-container{columns:4 300px;column-gap:16px;width:100%}.project-card{display:inline-block;width:100%;background:var(--card-bg);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0003,0 1px 2px #0000004d;margin-bottom:16px;transition:all .3s cubic-bezier(.25,.8,.25,1);border:1px solid var(--border-color)}.project-card:hover{box-shadow:0 14px 28px #0000004d,0 10px 10px #00000040;transform:translateY(-3px);border-color:var(--accent-primary)}.project-card img{width:100%;height:auto;display:block;object-fit:cover}.project-info{padding:16px}.project-info h3{margin:0 0 8px;font-size:1.2em;color:var(--text-primary)}.project-info p{margin:0 0 12px;font-size:.9em;color:var(--text-secondary);line-height:1.4}.category{display:inline-block;background:#2e7d3233;color:var(--accent-light);padding:4px 8px;border-radius:4px;font-size:.8em;font-weight:700;border:1px solid rgba(46,125,50,.3)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:linear-gradient(160deg,#1a2320,#0d1b11);box-shadow:3px 0 20px #0000004d;padding:25px;overflow-y:auto;z-index:100;border-right:1px solid var(--border-color)}.sidebar h2{margin-top:0;margin-bottom:20px;color:var(--text-secondary);font-size:1.5rem;font-weight:600;text-align:center;position:relative}.sidebar>h2{margin-top:0;margin-bottom:20px;color:var(--text-secondary);font-size:1.5rem;font-weight:600;text-align:center;position:relative}.sidebar>h2:after{display:none}.sidebar ul{list-style:none;padding:0;margin:0}.sidebar li{padding:12px 15px;margin-bottom:8px;background:var(--bg-tertiary);border-radius:8px;cursor:pointer;transition:all .3s ease;border:1px solid var(--border-color);font-weight:500;color:var(--text-primary);display:flex;align-items:center;box-shadow:0 2px 5px #0003}.sidebar li:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d;border-color:var(--accent-primary)}.sidebar li.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border-color:var(--accent-secondary);font-weight:600;box-shadow:0 4px 10px #2e7d3266}.sidebar li:before{content:"•";color:var(--accent-primary);margin-right:10px;font-size:1.5rem;opacity:.7}.sidebar li.active:before{color:#fff;opacity:1}.sidebar li.inactive-filter{opacity:.6;background:var(--bg-tertiary)}.sidebar li:last-child{margin-bottom:0}.category-count{background:#444;color:var(--text-primary);border-radius:10px;padding:2px 8px;font-size:.8rem;margin-left:auto;font-weight:600}.sidebar li.active .category-count{background:#fff3;color:#fff}.filter-section{margin-bottom:25px}.filter-section h2{margin-top:0;margin-bottom:15px;color:var(--text-secondary);font-size:1.2rem;font-weight:600;text-align:left;position:relative}.no-tags{color:var(--text-secondary);font-style:italic;padding:10px 15px;text-align:center}.tags-list{max-height:200px;overflow-y:auto}.tag-input-container{position:relative;margin-bottom:10px}.tag-input{width:100%;padding:10px 30px 10px 15px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;box-sizing:border-box}.tag-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2e7d3233}.clear-tag-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%}.clear-tag-btn:hover{background:#ffffff1a;color:var(--text-primary)}.tag-hint{color:var(--text-secondary);font-size:.8rem;margin:5px 0 0;padding:0;text-align:left}.sidebar-header{text-align:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.sidebar-header h1{margin:0 0 5px;color:var(--accent-light);font-size:1.8rem;font-weight:700}.sidebar-header h2{margin:0;color:var(--text-secondary);font-size:1.1rem;font-weight:400}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:linear-gradient(160deg,#1a2320,#0d1b11);box-shadow:3px 0 20px #0000004d;padding:25px;overflow-y:auto;z-index:100;border-right:1px solid var(--border-color);transition:all .3s ease}.sidebar.collapsed{left:-330px;width:280px;padding:25px}.sidebar-toggle{position:fixed;top:12px;left:12px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;z-index:300;font-size:20px;font-weight:700;transition:all .3s ease}.sidebar.collapsed .sidebar-toggle{transform:none}.sidebar-toggle:hover{background:var(--accent-primary);color:#fff}.contact-section{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:10px}.btn-contact{width:100%;padding:12px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:1rem;box-shadow:0 4px 15px #2e7d324d}.btn-contact:hover{background:linear-gradient(135deg,var(--accent-secondary) 0%,var(--accent-primary) 100%);transform:translateY(-2px);box-shadow:0 6px 20px #2e7d3266}.public-index{display:flex;margin-left:320px;transition:margin-left .3s ease}.public-index.sidebar-collapsed{margin-left:0}.public-index main{flex:1;padding:20px 5%}.loading,.error{text-align:center;padding:40px;font-size:1.2em}.error{color:#f44336}.btn{display:inline-block;padding:10px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;text-decoration:none;text-align:center;transition:background-color .3s;color:#fff}.btn-primary{background-color:var(--accent-primary)}.btn-primary:hover{background-color:var(--accent-secondary)}.btn-secondary{background-color:#757575;color:#fff}.btn-secondary:hover{background-color:#616161}.btn-edit{background-color:#43a047;color:#fff;margin-right:5px}.btn-edit:hover{background-color:#2e7d32}.btn-delete{background-color:#e53935;color:#fff;margin-right:5px}.btn-delete:hover{background-color:#c62828}.btn-move{background-color:#ffb300;color:#212121;width:30px;height:30px;padding:0;display:inline-flex;align-items:center;justify-content:center}.btn-move:hover{background-color:#ff8f00}.btn:disabled{opacity:.5;cursor:not-allowed;background-color:#666}.admin-panel{max-width:1200px;margin:20px auto;padding:25px;background:var(--bg-secondary);border-radius:12px;box-shadow:0 8px 32px #0003;border:1px solid rgba(255,255,255,.05)}.admin-panel header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,rgba(46,125,50,.1) 0%,transparent 100%);padding:15px;border-radius:8px}.admin-header-actions{display:flex;gap:12px}.project-form{background:var(--bg-tertiary);padding:25px;border-radius:12px;box-shadow:0 6px 20px #00000026;margin-bottom:25px;border:1px solid rgba(255,255,255,.05);transition:transform .3s ease,box-shadow .3s ease}.project-form:hover{transform:translateY(-2px);box-shadow:0 10px 25px #0003}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--accent-light);font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2e7d3233;background:#2e7d320d}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.blog-editor-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:15px;transition:border-color .3s ease,box-shadow .3s ease;min-height:300px}.blog-editor-content .ProseMirror{padding:12px 15px;min-height:300px;outline:none;text-align:left}.blog-editor-content:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #2e7d3233;background:#2e7d320d}.project-list{background:var(--bg-tertiary);padding:20px;border-radius:12px;box-shadow:0 6px 20px #00000026;border:1px solid rgba(255,255,255,.05)}.project-list h2{color:var(--accent-light);margin-top:0;margin-bottom:20px;font-size:1.4rem;border-bottom:2px solid var(--accent-primary);padding-bottom:10px;display:inline-block}.project-list ul{list-style:none;padding:0;margin:0}.project-list-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;padding:15px;margin-bottom:15px;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.project-list-item:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0003;border-color:var(--accent-primary)}.project-info{flex:1;min-width:250px}.project-info h3{margin:0 0 8px;color:var(--accent-light);font-size:1.2rem}.project-info p{margin:0 0 8px;color:var(--text-secondary);font-size:.9rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.category{display:inline-block;background:#2e7d3233;color:var(--accent-light);padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:600;border:1px solid rgba(46,125,50,.3)}.image-name{font-weight:600;color:var(--accent-light);margin-top:8px;font-size:.9rem}.image-tags{margin-top:5px;display:flex;flex-wrap:wrap;gap:5px}.tag{background:#9b9b9b33;color:var(--text-secondary);padding:2px 8px;border-radius:20px;font-size:.7rem;font-weight:600;border:1px solid var(--border-color)}.sort-order{display:inline-block;background:#9b9b9b33;color:var(--text-secondary);padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:600;margin-left:10px;border:1px solid var(--border-color)}.project-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:5px;margin-top:10px;max-width:200px}.project-thumbnail{width:100%;height:60px;object-fit:cover;border-radius:4px;border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.project-thumbnail:hover{transform:scale(1.05);box-shadow:0 0 8px #2e7d3280;z-index:1;position:relative}.more-images-overlay{display:flex;align-items:center;justify-content:center;background:#0009;color:#fff;font-size:.7rem;font-weight:700;border-radius:4px;border:1px solid var(--border-color)}.project-actions{display:flex;flex-direction:column;gap:8px;min-width:120px;align-items:flex-end}.reorder-buttons{display:flex;gap:5px}.admin-panel .btn{padding:10px 18px;border-radius:8px;font-weight:600;transition:all .3s ease;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--bg-tertiary);border-radius:12px;box-shadow:0 10px 30px #0000004d;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color);position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px 15px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;color:var(--accent-light);font-size:1.5rem}.close-button{background:none;border:none;font-size:1.8rem;cursor:pointer;color:var(--text-secondary);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s}.close-button:hover{background-color:#ffffff1a;color:var(--text-primary)}.contact-form{padding:20px 25px 25px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--accent-light);font-size:.95rem}.form-group input,.form-group textarea{width:100%;padding:12px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2e7d3233;background:#2e7d320d}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.success-message{padding:25px;text-align:center}.success-message p{margin-bottom:20px;color:#a5d6a7;font-size:1.1rem}.error-message{background:#f4433633;color:#f44336;padding:12px;border-radius:8px;margin-bottom:15px;text-align:center;border:1px solid rgba(244,67,54,.3)}.change-password-form{background:var(--bg-tertiary);padding:25px;border-radius:12px;box-shadow:0 6px 20px #00000026;border:1px solid rgba(255,255,255,.05);max-width:500px;margin:20px auto}.change-password-form h2{color:var(--accent-light);margin-top:0;margin-bottom:20px;text-align:center}.change-password-form .form-group{margin-bottom:20px}.change-password-form .form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--accent-light);font-size:.95rem}.change-password-form .form-group input{width:100%;padding:12px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-primary);color:var(--text-primary);transition:all .3s ease}.change-password-form .form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2e7d3233;background:#2e7d320d}.change-password-form .form-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.change-password-form .success{background:#4caf5033;color:#a5d6a7;padding:12px;border-radius:8px;margin-bottom:15px;text-align:center;border:1px solid rgba(76,175,80,.3)}.admin-panel .btn-primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;box-shadow:0 4px 15px #2e7d324d}.admin-panel .btn-primary:hover{background:linear-gradient(135deg,var(--accent-secondary) 0%,var(--accent-primary) 100%);transform:translateY(-2px);box-shadow:0 6px 20px #2e7d3266}.admin-panel .btn-secondary{background:linear-gradient(135deg,#616161,#424242);color:#fff;box-shadow:0 4px 15px #6161614d}.admin-panel .btn-secondary:hover{background:linear-gradient(135deg,#424242,#616161);transform:translateY(-2px);box-shadow:0 6px 20px #61616166}.admin-panel .btn-edit{background:linear-gradient(135deg,#43a047,#2e7d32);color:#fff;padding:8px 15px;box-shadow:0 4px 15px #43a0474d}.admin-panel .btn-edit:hover{background:linear-gradient(135deg,#2e7d32,#43a047);transform:translateY(-2px);box-shadow:0 6px 20px #43a04766}.admin-panel .btn-delete{background:linear-gradient(135deg,#b71c1c,#880e4f);color:#fff;padding:8px 15px;box-shadow:0 4px 15px #b71c1c4d}.admin-panel .btn-delete:hover{background:linear-gradient(135deg,#880e4f,#b71c1c);transform:translateY(-2px);box-shadow:0 6px 20px #b71c1c66}.admin-panel .btn-move{padding:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:8px;background:linear-gradient(135deg,#ffb300,#ff8f00);color:#212121;box-shadow:0 4px 15px #ffb3004d}.admin-panel .btn-move:hover{background:linear-gradient(135deg,#ff8f00,#ffb300);transform:translateY(-2px);box-shadow:0 6px 20px #ffb30066}.admin-panel .btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.section-heading{display:flex;align-items:center;gap:12px;margin-bottom:16px}.section-heading h2{margin:0}.btn-add-icon{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.btn-add-icon:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#0d1b11,#1a2320)}.login-form{width:100%;max-width:400px;background:var(--bg-tertiary);padding:30px;border-radius:10px;box-shadow:0 10px 25px #0000004d;border:1px solid var(--border-color)}.login-form h2{text-align:center;margin-bottom:20px;color:var(--text-primary)}.login-form .form-group{margin-bottom:20px}.login-form button,.image-upload{width:100%}.upload-area{border:2px dashed #555;border-radius:8px;padding:40px;text-align:center;margin-bottom:20px;transition:all .3s ease;background-color:var(--bg-tertiary)}.upload-area.drag-active{border-color:var(--accent-primary);background-color:#2e7d321a}.upload-area p{margin:0 0 15px;color:var(--text-secondary)}.image-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;margin-top:20px}.image-preview-item{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 2px 5px #0003;border:1px solid var(--border-color)}.image-preview-item{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 2px 5px #0003;border:1px solid var(--border-color);display:flex;flex-direction:column}.image-preview-item img{width:100%;height:150px;object-fit:cover;display:block}.image-info{padding:8px;background:var(--bg-primary);border-top:1px solid var(--border-color)}.image-info input{width:100%;padding:6px;margin-bottom:5px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;background:var(--bg-secondary);color:var(--text-primary)}.image-info input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #2e7d3233}.image-controls{position:absolute;top:5px;right:5px;display:flex;flex-direction:column;gap:5px}.image-controls button{padding:5px;width:25px;height:25px;display:flex;align-items:center;justify-content:center;font-size:12px;border-radius:4px;background-color:#0009;color:#fff;border:1px solid var(--border-color)}.image-controls button:hover{background-color:var(--accent-primary)}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000e6;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.lightbox-content{position:relative;max-width:90%;max-height:90%;display:flex;flex-direction:column;align-items:center}.lightbox-image-container{position:relative;display:flex;justify-content:center;align-items:center;width:100%;height:80vh}.lightbox-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;box-shadow:0 4px 20px #00000080}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#0009;color:#fff;border:none;width:60px;height:60px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .3s ease;z-index:1002}.lightbox-nav:hover{background:#2e7d32cc;transform:translateY(-50%) scale(1.1)}.lightbox-nav:disabled{opacity:.3;cursor:not-allowed}.lightbox-prev{left:-80px}.lightbox-next{right:-80px}.lightbox-close{position:absolute;top:-40px;right:0;background:#0009;color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;justify-content:center;align-items:center;z-index:1002;transition:all .3s ease}.lightbox-close:hover{background:#dc3545cc;transform:scale(1.1)}.lightbox-info{color:#fff;margin-top:15px;text-align:center;font-size:16px;width:100%}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:150}.blog-sidebar-btn{display:block;box-sizing:border-box;text-align:center}.blog-page main{padding:40px 5%;max-width:860px}body.blog-light-body{background-color:#f7f7f5}.blog-page.blog-light{--bg-primary: #f7f7f5;--bg-secondary: #ffffff;--bg-tertiary: #ededeb;--text-primary: #1a1a1a;--text-secondary:#555550;--accent-primary: #2e7d32;--accent-secondary:#388e3c;--accent-light: #1b5e20;--border-color: #d4d4cf;--card-bg: #ffffff;background-color:var(--bg-primary);color:var(--text-primary)}.blog-page.blog-light .sidebar{background:linear-gradient(160deg,#82b085,#f1f8e9);box-shadow:3px 0 20px #00000014}.blog-page.blog-light .sidebar h1{color:var(--accent-primary)}.blog-page.blog-light .sidebar h2{color:var(--text-secondary)}.blog-page.blog-light .sidebar li{background:#fff;border-color:var(--border-color);color:var(--text-primary);box-shadow:0 1px 3px #0000000f}.blog-page.blog-light .sidebar li:hover{background:#f0f4f0;border-color:var(--accent-primary)}.blog-page.blog-light .sidebar li.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border-color:var(--accent-secondary)}.blog-page.blog-light .sidebar li:before{color:var(--accent-primary)}.blog-page.blog-light .category-count{background:#e0e0e0;color:var(--text-secondary)}.blog-page.blog-light .sidebar-toggle{background:#fff;border-color:var(--border-color);color:var(--text-primary)}.blog-page.blog-light .filter-section h3{color:var(--text-secondary)}.blog-page.blog-light .blog-post-view-body blockquote{background:#2e7d320d;color:var(--text-secondary)}.blog-page.blog-light .blog-post-view-body code{background:#ececec}.blog-page.blog-light .blog-post-view-body pre{background:#ececec;border-color:var(--border-color)}.blog-theme-toggle{background:none;border:1px solid rgba(255,255,255,.2);color:var(--text-secondary);border-radius:20px;padding:3px 10px;font-size:1rem;cursor:pointer;margin-top:8px;transition:all .2s ease}.blog-theme-toggle:hover{background:#ffffff1a;color:var(--text-primary)}.blog-page.blog-light .blog-theme-toggle{border-color:var(--border-color);color:var(--text-secondary)}.blog-page.blog-light .blog-theme-toggle:hover{background:#0000000d;color:var(--text-primary)}.blog-post-list-title{flex:1;line-height:1.3;font-size:.95rem}.blog-post-list-date{white-space:nowrap;font-size:.75rem!important;margin-left:8px;flex-shrink:0}.blog-post-view{padding-bottom:60px}.blog-post-view-title{margin:0 0 10px;font-size:2.2rem;color:var(--accent-light);line-height:1.2}.blog-post-view-date{display:block;color:var(--text-secondary);font-size:.95rem;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.blog-post-view-body{color:var(--text-primary);line-height:1.75;font-size:1.05rem;text-align:left}.blog-post-view-body h1,.blog-post-view-body h2,.blog-post-view-body h3{color:var(--accent-light);margin-top:1.8em;margin-bottom:.5em}.blog-post-view-body p{margin:0 0 1.2em}.blog-post-view-body a{color:var(--accent-light);text-decoration:underline}.blog-post-view-body a:hover{color:#fff}.blog-post-view-body img{max-width:100%;border-radius:8px;margin:16px 0;border:1px solid var(--border-color)}.blog-post-view-body blockquote{border-left:3px solid var(--accent-primary);margin:1.2em 0;padding:8px 20px;background:#2e7d3212;color:var(--text-secondary);border-radius:0 4px 4px 0}.blog-post-view-body code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace;font-size:.9em}.blog-post-view-body pre{background:var(--bg-tertiary);padding:16px;border-radius:8px;overflow-x:auto;border:1px solid var(--border-color)}.blog-post-view-body ul,.blog-post-view-body ol{padding-left:1.8em;margin:0 0 1.2em}.blog-post-view-body hr{border:none;border-top:1px solid var(--border-color);margin:2em 0}.blog-empty-state{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--text-secondary);font-size:1.1rem}@media(max-width:1200px){.grid-container{columns:3 300px}.public-index,.public-index.sidebar-collapsed{margin-left:0}.public-index main{padding-top:60px}.sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;border-radius:0;margin:0;padding-top:60px;overflow-y:auto;transition:left .3s ease;z-index:200}.sidebar.collapsed{left:-330px;width:280px;padding:60px 25px 25px}.sidebar-toggle{position:fixed;top:12px;left:10px;z-index:300;width:40px;height:40px;font-size:20px;margin:0;border-radius:6px}.sidebar.collapsed .sidebar-toggle{transform:none}.sidebar-backdrop{display:block}.sidebar-backdrop.hidden{display:none}.lightbox-nav{width:50px;height:50px;font-size:20px}.lightbox-prev{left:-70px}.lightbox-next{right:-70px}}@media(max-width:900px){.grid-container{columns:2 300px}.lightbox-nav{width:45px;height:45px;font-size:18px}.lightbox-prev{left:-60px}.lightbox-next{right:-60px}}@media(max-width:768px){.lightbox-nav{width:40px;height:40px;font-size:16px}.lightbox-prev{left:-50px}.lightbox-next{right:-50px}}@media(max-width:620px){.grid-container{columns:1 300px}.lightbox-overlay{background-color:#000000f2}.lightbox-image-container{height:70vh}.lightbox-nav{width:35px;height:35px;font-size:16px}.lightbox-prev{left:-40px}.lightbox-next{right:-40px}.lightbox-close{top:-35px;width:35px;height:35px;font-size:20px}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media(prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin infinite 20s linear}}.App-header{background-color:#282c34;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:calc(10px + 2vmin);color:#fff}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
