body{margin:0;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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;right:0;z-index:1000}.navbar-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:1.5rem;font-weight:700;color:#667eea;text-decoration:none}.navbar-links{display:flex;gap:2rem;align-items:center}.navbar-toggle{display:none;flex-direction:column;justify-content:center;gap:.3rem;width:2.5rem;height:2.5rem;border:none;background:transparent;cursor:pointer;padding:0}.navbar-toggle-bar{height:3px;width:100%;background:#667eea;border-radius:999px;transition:transform .2s ease}.nav-link{color:#555;text-decoration:none;font-weight:600;transition:color .3s ease;position:relative}.nav-link:hover,.nav-link.active{color:#667eea}.nav-link.active:after{content:"";position:absolute;bottom:-.5rem;left:0;right:0;height:2px;background:#667eea}@media(max-width:768px){.navbar-content{padding:1rem}.navbar-brand{font-size:1.2rem}.navbar-toggle{display:flex}.navbar-links{position:absolute;top:100%;right:0;left:0;background:#fff;display:none;flex-direction:column;gap:0;border-bottom:1px solid rgba(0,0,0,.05);box-shadow:0 8px 16px #0f172a14;transform-origin:top;animation:menu-retract .25s ease forwards}.navbar-links.open{display:flex;animation:menu-drop .25s ease forwards}.nav-link{padding:1rem 1.5rem;border-top:1px solid rgba(0,0,0,.05);font-size:1rem}.nav-link:first-child{border-top:none}}@keyframes menu-drop{0%{opacity:0;transform:scaleY(.9) translateY(-8px)}to{opacity:1;transform:scaleY(1) translateY(0)}}@keyframes menu-retract{0%{opacity:1;transform:scaleY(1) translateY(0)}to{opacity:0;transform:scaleY(.95) translateY(-8px)}}.home{min-height:100vh}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:120px 20px 80px;text-align:center;min-height:60vh;display:flex;align-items:center;justify-content:center}.hero-content h1{font-size:3rem;margin-bottom:.5rem;font-weight:700}.subtitle{font-size:1.5rem;margin-bottom:1.5rem;opacity:.9}.description{font-size:1.1rem;max-width:600px;margin:0 auto 2rem;line-height:1.6}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{padding:12px 30px;border-radius:25px;text-decoration:none;font-weight:600;transition:transform .3s ease,box-shadow .3s ease}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-primary{background:#fff;color:#667eea}.btn-secondary{background:transparent;color:#fff;border:2px solid white}.about-section{padding:60px 20px;background:#f8f9fa}.container{max-width:1200px;margin:0 auto}.about-section h2{text-align:center;font-size:2.5rem;margin-bottom:2rem;color:#333}.about-section p{font-size:1.1rem;line-height:1.8;color:#555;text-align:center;max-width:800px;margin:0 auto}.social-section{padding:60px 20px;background:#fff}.social-section h2{text-align:center;font-size:2.5rem;margin-bottom:2rem;color:#333}.social-links{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.social-link{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;background:#f8f9fa;border-radius:10px;text-decoration:none;color:#333;transition:transform .3s ease,box-shadow .3s ease;min-width:120px}.social-link:hover{transform:translateY(-5px);box-shadow:0 6px 20px #00000026}.social-icon{font-size:2.5rem}.social-name{font-weight:600;text-transform:capitalize}@media(max-width:768px){.hero-content h1{font-size:2rem}.subtitle{font-size:1.2rem}.description{font-size:1rem}}.portfolio{min-height:100vh;padding:80px 20px 40px;background:#f8f9fa}.portfolio-header{text-align:center;margin-bottom:60px}.portfolio-header h1{font-size:3rem;color:#333;margin-bottom:.5rem}.portfolio-header p{font-size:1.2rem;color:#666}.projects-container{max-width:1200px;margin:0 auto}.loading{text-align:center;padding:100px 20px;font-size:1.5rem;color:#666}.no-projects{text-align:center;padding:100px 20px}.no-projects p{font-size:1.2rem;color:#666}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.project-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000026}.project-image{width:100%;height:200px;overflow:hidden;background:#e9ecef}.project-image img{width:100%;height:100%;object-fit:cover}.project-content{padding:1.5rem}.project-content h3{font-size:1.5rem;color:#333;margin-bottom:.75rem}.project-description{color:#666;line-height:1.6;margin-bottom:1rem}.technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-tag{background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:15px;font-size:.85rem;font-weight:500}.project-links{display:flex;gap:1rem;margin-top:1rem}.project-link{padding:.5rem 1rem;background:#f8f9fa;color:#333;text-decoration:none;border-radius:6px;font-weight:600;transition:background .3s ease}.project-link:hover{background:#e9ecef}@media(max-width:768px){.portfolio-header h1{font-size:2rem}.projects-grid{grid-template-columns:1fr}}.bio{padding:2rem 1rem;max-width:900px;margin:0 auto}.bio-header{text-align:center;margin-bottom:2rem}.bio-content{display:flex;flex-direction:column;gap:2rem}.bio-image{align-self:center;max-width:320px;width:100%}.bio-image img{width:100%;border-radius:12px;object-fit:cover;box-shadow:0 12px 30px #0000001a}.bio-text{font-size:1.1rem;line-height:1.7;color:#333}.bio-text p+p{margin-top:1rem}.page-loading,.page-error,.bio.empty{text-align:center;padding:4rem 1rem}@media(min-width:768px){.bio-content{flex-direction:row}.bio-image{flex:0 0 320px}.bio-text{flex:1}}.certificates{padding:2rem 1rem;max-width:1100px;margin:0 auto}.certificates-header{text-align:center;margin-bottom:2rem}.certificate-grid{display:grid;gap:1.5rem}.certificate-card{display:grid;gap:1rem;padding:1.5rem;border-radius:12px;background:#fff;box-shadow:0 10px 25px #0000000d}.certificate-image{width:100%;max-height:220px;overflow:hidden;border-radius:10px}.certificate-image img{width:100%;height:100%;object-fit:cover}.certificate-organization{font-weight:600;color:#444}.certificate-issuedAt{font-size:.95rem;color:#666}.empty-state{text-align:center;padding:3rem 1rem;border-radius:12px;background:#00000008}@media(min-width:768px){.certificate-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}.contact{max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem;color:#1f2933}.contact-header{margin-bottom:2.5rem;text-align:center}.contact-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#0b2545}.contact-header p{color:#4a5568;max-width:620px;margin:0 auto}.contact-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.contact-card{border:1px solid #d1d5db;border-radius:12px;padding:1.5rem;background:#fff;box-shadow:0 12px 24px #0f172a14;display:flex;flex-direction:column;gap:.5rem}.contact-card h3{font-size:1.35rem;color:#0b2545;margin-bottom:.25rem}.contact-type{font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;font-size:.75rem}.contact-value{font-size:1rem;color:#1f2933;word-break:break-word}.contact-action{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:999px;background:#2563eb;color:#fff;text-decoration:none;font-weight:600;transition:background .2s ease,transform .2s ease}.contact-action:hover{background:#1d4ed8;transform:translateY(-2px)}.page-loading,.page-error,.empty-state{text-align:center;padding:3rem 1rem;color:#4a5568}.page-error{color:#b91c1c}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 8px 30px #0003;width:100%;max-width:400px}.login-container h1{text-align:center;color:#333;margin-bottom:2rem;font-size:2rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#555;font-weight:600}.form-group input{padding:.75rem;border:2px solid #e9ecef;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:6px;text-align:center;font-weight:500}.btn-login{padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s ease}.btn-login:hover:not(:disabled){background:#5568d3}.btn-login:disabled{background:#aaa;cursor:not-allowed}@media(max-width:768px){.login-container{padding:2rem}}.form-modal{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-bottom:2rem}.form h3{margin:0 0 1.5rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:600}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:2px solid #e9ecef;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;font-family:inherit}.checkbox-group{display:flex;align-items:center}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;margin:0}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-weight:500}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn-cancel,.btn-submit{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:1rem}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.btn-submit{background:#667eea;color:#fff}.btn-submit:hover:not(:disabled){background:#5568d3}.btn-submit:disabled{background:#aaa;cursor:not-allowed}.admin{min-height:100vh;background:#f8f9fa}.admin-header{background:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.admin-header h1{margin:0;color:#333}.admin-user{display:flex;align-items:center;gap:1rem}.btn-logout{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.btn-logout:hover{background:#c82333}.admin-content{max-width:1200px;margin:0 auto;padding:2rem}.admin-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #dee2e6}.tab{padding:.75rem 1.5rem;background:transparent;border:none;color:#666;cursor:pointer;font-size:1rem;font-weight:600;transition:color .3s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.tab:hover{color:#333}.tab.active{color:#667eea;border-bottom-color:#667eea}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h2{margin:0;color:#333}.section-helper{margin-top:.5rem;color:#6b7280;font-size:.95rem;max-width:640px}.section-message{background:#fff;border:1px solid #dbeafe;color:#1e40af;padding:1rem 1.25rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.section-message.error{border-color:#fecaca;color:#b91c1c;background:#fef2f2}.btn-add{padding:.75rem 1.5rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.btn-add:hover{background:#5568d3}.items-list{display:grid;gap:1rem}.item-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.item-card h3{margin:0 0 .5rem;color:#333}.item-subtitle{margin:0 0 .5rem;color:#4b5563;font-weight:600}.item-card p{margin:0 0 1rem;color:#666}.item-meta{margin-bottom:1rem;color:#6b7280;font-size:.9rem}.item-note{margin:1rem 0 0;color:#6b7280;font-size:.85rem;font-style:italic}.item-actions{display:flex;gap:.5rem}.btn-edit,.btn-delete{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:600}.btn-edit{background:#28a745;color:#fff}.btn-edit:hover{background:#218838}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}.btn-delete:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed}.empty-state{background:#fff;padding:2rem;border-radius:8px;border:1px dashed #d1d5db;text-align:center;color:#6b7280}.bio-preview{display:flex;gap:1.5rem;background:#fff;padding:2rem;border-radius:12px;box-shadow:0 12px 24px #0f172a14}.bio-preview-image{flex:0 0 220px}.bio-preview-image img{width:220px;height:220px;object-fit:cover;border-radius:16px;box-shadow:0 8px 16px #0f172a1f}.bio-preview-text{display:flex;flex-direction:column;gap:1rem;color:#1f2937;line-height:1.6}.bio-preview-text p{margin:0}@media(max-width:768px){.admin-header{flex-direction:column;gap:1rem;text-align:center}.section-header{flex-direction:column;gap:1rem}.bio-preview{flex-direction:column;align-items:center;text-align:center}.bio-preview-image,.bio-preview-image img{width:180px;height:180px}}*{margin:0;padding:0;box-sizing:border-box}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{min-height:100vh}.main-content{padding-top:70px}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.5rem;color:#666}
