:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow-x:hidden}body{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}.app{width:100%;min-height:100vh;display:flex;flex-direction:column}.navbar{background-color:#282c34;padding:1rem 0;color:#fff;box-shadow:0 2px 4px #0000001a}.nav-container{width:100%;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.nav-menu{display:flex;list-style:none;gap:2rem;margin-left:3rem}.nav-menu a{color:#fff;text-decoration:none;font-weight:500;transition:color .3s}.nav-menu a:hover{color:#61dafb}.main-content{flex:1;width:100%;padding:2rem}.home-page,.projects-page,.blog-page,.gallery-page{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}h1{font-size:2.5rem;margin-bottom:1.5rem;color:#282c34}h2{font-size:1.5rem;margin-bottom:.5rem;color:#333}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin-top:2rem}.project-card{border:1px solid #ddd;border-radius:8px;padding:1.5rem;background:#fff;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s}.project-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.project-card img{width:100%;height:200px;object-fit:cover;border-radius:4px;margin-bottom:1rem}.project-card p{color:#666;margin-bottom:1rem;line-height:1.6}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-badge{background-color:#61dafb;color:#282c34;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.project-links{display:flex;gap:1rem}.project-links a{color:#61dafb;text-decoration:none;font-weight:500}.project-links a:hover{text-decoration:underline}.posts-list{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.post-preview{border-bottom:1px solid #eee;padding-bottom:2rem}.post-preview:last-child{border-bottom:none}.excerpt{color:#666;line-height:1.6;margin-bottom:1rem}.post-meta{display:flex;gap:1.5rem;color:#999;font-size:.9rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.gallery-item{position:relative;overflow:hidden;border-radius:8px;box-shadow:0 2px 8px #0000001a}.gallery-item img{width:100%;height:250px;object-fit:cover;transition:transform .3s}.gallery-item:hover img{transform:scale(1.05)}.caption{padding:1rem;background:#fff;font-size:.9rem;color:#666}.loading,.error{text-align:center;padding:3rem;font-size:1.2rem}.error{color:#d32f2f}.home-page{display:flex;flex-direction:column;gap:5rem}.hero{display:flex;align-items:center;justify-content:space-between;gap:3rem;padding:3rem 0 1rem}.hero-text{flex:1}.hero-greeting{font-size:1.1rem;color:#61dafb;font-weight:500;margin-bottom:.25rem}.hero-name{font-size:3.5rem;font-weight:800;color:#282c34;margin:0 0 .4rem;line-height:1.1}.hero-title{font-size:1.4rem;color:#555;margin-bottom:1rem}.hero-subtitle{font-size:1.05rem;color:#666;line-height:1.7;max-width:520px;margin-bottom:2rem}.hero-links{display:flex;gap:1rem;flex-wrap:wrap}.btn-outline{display:inline-block;padding:.6rem 1.2rem;border:2px solid #282c34;border-radius:6px;color:#282c34;font-weight:600;text-decoration:none;transition:background-color .2s,color .2s}.btn-outline:hover{background-color:#282c34;color:#fff}.btn-primary{display:inline-block;text-decoration:none}.hero-image{flex-shrink:0;width:280px;height:280px;border-radius:50%;overflow:hidden;border:4px solid #61dafb;box-shadow:0 8px 32px #61dafb33}.hero-image img{width:100%;height:100%;object-fit:cover}.about-section h2,.tech-section h2,.contact-section h2{font-size:1.8rem;margin-bottom:1.5rem;color:#282c34;padding-bottom:.75rem;border-bottom:2px solid #61dafb;display:inline-block}.about-content{display:flex;flex-direction:column;gap:1rem}.about-content p{color:#555;line-height:1.8;font-size:1.05rem;max-width:760px}.about-details{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:.5rem}.about-detail-item{display:flex;flex-direction:column;gap:.2rem}.detail-label{font-size:.8rem;font-weight:700;color:#61dafb;text-transform:uppercase;letter-spacing:.05em}.about-detail-item span:last-child{color:#333;font-size:.95rem}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}.tech-group{background:#f9f9f9;border:1px solid #eee;border-radius:10px;padding:1.25rem}.tech-group h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#61dafb;font-weight:700;margin-bottom:.75rem}.tech-badges{display:flex;flex-wrap:wrap;gap:.4rem}.contact-section{padding-bottom:2rem}.contact-section>p{color:#666;margin-bottom:1.5rem;font-size:1.05rem}.contact-links{display:flex;flex-wrap:wrap;gap:1rem}.contact-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:1px solid #ddd;border-radius:8px;color:#333;text-decoration:none;font-size:.95rem;transition:border-color .2s,color .2s}.contact-link:hover{border-color:#61dafb;color:#61dafb}.contact-icon{font-weight:700;font-size:1rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{margin-bottom:0}.btn-primary{background-color:#61dafb;color:#282c34;border:none;padding:.6rem 1.2rem;border-radius:6px;font-weight:600;cursor:pointer;font-size:.95rem;transition:background-color .2s}.btn-primary:hover{background-color:#4fc3e8}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:transparent;color:#555;border:1px solid #ccc;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;font-size:.9rem;transition:border-color .2s}.btn-secondary:hover{border-color:#888}.btn-danger{background-color:transparent;color:#d32f2f;border:1px solid #d32f2f;padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;font-size:.9rem}.btn-danger:hover{background-color:#fdecea}.nav-auth{margin-left:auto}.nav-auth .btn-secondary{color:#fff;border-color:#ffffff80;font-size:.85rem}.nav-auth .btn-secondary:hover{border-color:#fff}.owner-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.card-body{padding:1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:10px;padding:2rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-large{max-width:720px}.modal h2{margin-bottom:1.5rem}.modal form{display:flex;flex-direction:column;gap:1rem}.modal input,.modal textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit}.modal input:focus,.modal textarea:focus{outline:none;border-color:#61dafb}.modal textarea{min-height:120px;resize:vertical}.content-editor{min-height:300px;font-family:monospace;font-size:.9rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.form-error{color:#d32f2f;font-size:.9rem;margin:0}.upload-field{display:flex;flex-direction:column;gap:.5rem}.upload-field label{font-weight:500;font-size:.9rem;color:#555}.img-preview{width:100%;max-height:200px;object-fit:cover;border-radius:6px;border:1px solid #eee}.search-bar{display:flex;gap:.75rem;margin-bottom:2rem}.search-bar input{flex:1;padding:.6rem 1rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.draft-badge{background-color:#fff3e0;color:#e65100;padding:.2rem .6rem;border-radius:4px;font-size:.8rem;font-weight:600}.empty-state{text-align:center;color:#999;font-size:1.1rem;padding:3rem}.gallery-item{position:relative}.gallery-delete-btn{position:absolute;top:.5rem;right:.5rem;background:#0009;color:#fff;border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.gallery-item:hover .gallery-delete-btn{opacity:1}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;cursor:pointer}.post-preview h2 a{color:#282c34;text-decoration:none;transition:color .2s}.post-preview h2 a:hover{color:#61dafb}.post-detail{max-width:760px;margin:0 auto}.back-link{display:inline-block;color:#666;text-decoration:none;font-size:.95rem;margin-bottom:1.5rem;transition:color .2s}.back-link:hover{color:#61dafb}.post-detail-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid #eee}.post-detail-header h1{font-size:2.2rem;margin:.75rem 0 .5rem;line-height:1.3}.post-detail-meta{display:flex;gap:1.5rem;color:#999;font-size:.9rem;margin-bottom:.5rem}.post-detail-excerpt{color:#666;font-size:1.1rem;line-height:1.6;margin-top:.75rem}.post-detail-body{line-height:1.8;font-size:1.05rem;color:#333}.post-detail-body h1,.post-detail-body h2,.post-detail-body h3{margin:2rem 0 1rem;color:#282c34}.post-detail-body p{margin-bottom:1.25rem}.post-detail-body a{color:#61dafb}.post-detail-body ul,.post-detail-body ol{margin:1rem 0 1.25rem 1.5rem}.post-detail-body li{margin-bottom:.4rem}.post-detail-body blockquote{border-left:4px solid #61dafb;margin:1.5rem 0;padding:.5rem 1.25rem;color:#555;background:#f9f9f9;border-radius:0 4px 4px 0}.post-detail-body pre{margin:1.5rem 0;border-radius:6px;overflow-x:auto;font-size:.9rem}.post-detail-body code{background:#f0f0f0;padding:.2rem .4rem;border-radius:3px;font-size:.9em}.post-detail-body table{width:100%;border-collapse:collapse;margin:1.5rem 0}.post-detail-body th,.post-detail-body td{border:1px solid #ddd;padding:.6rem 1rem;text-align:left}.post-detail-body th{background:#f5f5f5;font-weight:600}.post-detail-body tr:nth-child(2n){background:#fafafa}.comments-section{margin-top:3rem;padding-top:2rem;border-top:1px solid #eee}.comments-section h2{margin-bottom:1.5rem;font-size:1.4rem}.comment-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2.5rem}.comment-form textarea{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit;resize:vertical}.comment-form textarea:focus{outline:none;border-color:#61dafb}.comment-form .btn-primary{align-self:flex-start}.comments-list{display:flex;flex-direction:column;gap:1.25rem}.comment{background:#fafafa;border:1px solid #eee;border-radius:8px;padding:1rem 1.25rem}.comment-header{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.comment-author{font-weight:600;color:#282c34;font-size:.95rem}.comment-date{color:#999;font-size:.85rem}.comment-delete-btn{margin-left:auto;background:none;border:none;color:#d32f2f;font-size:.8rem;cursor:pointer;padding:.2rem .5rem}.comment-delete-btn:hover{text-decoration:underline}.comment-content{color:#444;line-height:1.6;margin:0}@media(max-width:768px){.main-content{padding:1.5rem 1rem}.nav-container{padding:0 1rem}.nav-menu{gap:1rem}.nav-logo{font-size:1.1rem}.nav-menu a{font-size:.85rem}.nav-auth .btn-secondary{font-size:.8rem;padding:.4rem .6rem}.hero{flex-direction:column-reverse;text-align:center;padding:1.5rem 0;gap:1.5rem}.hero-name{font-size:2.5rem}.hero-subtitle{max-width:100%}.hero-links{justify-content:center}.hero-image{width:180px;height:180px}.about-details{flex-direction:column;gap:1rem}.tech-grid{grid-template-columns:1fr 1fr}.contact-links{flex-direction:column}.projects-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(2,1fr)}.post-detail{max-width:100%}.modal{padding:1.5rem}.modal-large{max-width:100%}.page-header{flex-wrap:wrap;gap:.75rem}}@media(max-width:480px){.tech-grid,.gallery-grid{grid-template-columns:1fr}.nav-menu{gap:.6rem}}.footer{background-color:#282c34;color:#fff;text-align:center;padding:2rem;margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:1rem}.footer p{margin:0;color:#ffffff80;font-size:.85rem}.footer-social{display:flex;gap:1.5rem}.footer-social a{color:#fff9;font-size:1.5rem;transition:color .2s;display:flex;align-items:center}.footer-social a:hover{color:#61dafb}
