.modal-content{background:#fff;border:2px solid #000;width:100%;max-width:1200px;max-height:90vh;padding:3rem;position:relative;overflow-y:auto}.about-modal{max-width:1200px!important}.modal-close{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:2rem;line-height:1;transition:opacity .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{opacity:.6}.tech-sections-wrapper{grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:2.5rem;display:grid}.tech-section{margin-bottom:0}.tech-section h2{text-transform:uppercase;letter-spacing:1px;border-bottom:2px solid #000;margin:0 0 1rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:700}.tech-grid{flex-wrap:wrap;gap:.75rem;display:flex}.note-section{background:#f5f5f5;border:2px solid #000;margin-top:3rem;padding:1.5rem}.note-text{color:#333;margin:0;font-size:1rem;line-height:1.6}.note-text strong{color:#000;font-weight:700}@media (max-width:768px){.modal-content{padding:2rem 1.5rem}.tech-sections-wrapper{grid-template-columns:1fr;gap:1.5rem}.tech-section{margin-bottom:1.5rem}.tech-section:last-child{margin-bottom:0}.tech-section h2{font-size:1.125rem}}.header{z-index:100;background:#fff;border-bottom:1px solid #000;position:fixed;top:0;left:0;right:0}.nav{align-items:center;gap:2rem;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex}.nav-link{color:#000;text-transform:uppercase;letter-spacing:1px;cursor:pointer;background:0 0;border:none;padding:0;font-size:.875rem;font-weight:500;text-decoration:none;transition:opacity .2s}.nav-link:hover{opacity:.6}.nav-button{font-family:inherit}.donate-link{color:#000;background:#ffd230;border:1px solid #ffd230;padding:.5rem 1rem;font-weight:600;transition:all .3s}.donate-link:hover{color:#fff;background:#06f;border-color:#06f}.admin-link{color:#721c24;margin-left:auto;font-weight:600}.banner{background-color:#ffd230;background-image:url(/assets/banner-bg-p8GbKn9L.png);background-size:cover;border-bottom:1px solid #000;padding:9rem 2rem 3rem}.banner-content{align-items:center;gap:3rem;max-width:1200px;margin:0 auto;display:flex}.photo-container{flex-shrink:0}.profile-photo{object-fit:cover;background-image:url(/assets/avatar-Cu5Qs3fg.jpg);background-size:cover;border:2px solid #fff;border-radius:50%;width:200px;min-width:300px;height:200px;min-height:300px}.intro{flex:1}.name{letter-spacing:-1px;margin:0 0 .5rem;font-size:3rem;font-weight:700}.tagline{text-transform:uppercase;letter-spacing:2px;margin:0 0 1rem;font-size:1.125rem;font-weight:500}.description{color:#333;max-width:600px;margin:0;font-size:1rem;line-height:1.6}@media (max-width:768px){.banner-content{text-align:center;flex-direction:column}.name{font-size:2rem}}.project-card{position:relative}.thumbnail-link{color:inherit;text-decoration:none;display:block;position:relative}.thumbnail{aspect-ratio:16/9;background:#f5f5f5;border:2px solid #000;width:100%;transition:transform .2s;overflow:hidden}.thumbnail:hover{transform:scale(.98)}.thumbnail img{object-fit:cover;width:100%;height:100%;display:block}.tooltip{z-index:10;background:#fffffffa;border:2px solid #000;padding:1.5rem;animation:.2s fadeIn;position:absolute;inset:0 0 60px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tooltip-content{height:100%;overflow-y:auto}.tooltip-title{text-transform:uppercase;letter-spacing:1px;margin:0 0 .75rem;font-size:1.25rem;font-weight:700}.tooltip-description{color:#333;margin:0;font-size:.875rem;line-height:1.6}.star-button{cursor:pointer;background:0 0;border:1px solid #000;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:flex}.star-button:hover{color:#fff;background:#000}.star-button:hover .star-icon{stroke:#fff;fill:#fff}.star-icon{width:20px;height:20px;transition:all .2s}.star-count{text-align:left;min-width:20px}.home{min-height:100vh}.projects-section{padding:4rem 2rem}.container{max-width:1200px;margin:0 auto}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;display:grid}.no-projects,.loading-message,.error-message{text-align:center;padding:3rem;font-size:1rem}.no-projects,.loading-message{color:#666}.error-message{color:#721c24;background:#f8d7da;border:2px solid #721c24;max-width:600px;margin:0 auto}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}}.modal-message{margin:0 0 .5rem;font-size:1rem;line-height:1.6}.modal-message strong{font-weight:700}.modal-warning{color:#721c24;margin:0 0 2rem;font-size:.875rem;font-weight:500}.modal-actions{justify-content:flex-end;gap:1rem;display:flex}@media (max-width:600px){.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.project-banner{background:#f5f5f5;border-bottom:2px solid #000;width:100%;height:400px;overflow:hidden}.project-banner img{object-fit:cover;width:100%;height:100%}.project-content{max-width:900px;margin:0 auto;padding:3rem 2rem}.project-header{justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:1.5rem;display:flex}.project-title{text-transform:uppercase;letter-spacing:2px;flex:1;margin:0;font-size:3rem;font-weight:700}.project-actions{flex-shrink:0;gap:1rem;display:flex}.project-meta{margin-bottom:3rem}.star-button-large{cursor:pointer;text-transform:uppercase;letter-spacing:1px;background:0 0;border:2px solid #000;align-items:center;gap:.75rem;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex}.star-button-large:hover{color:#fff;background:#000}.star-button-large:hover .star-icon-large{stroke:#fff;fill:#fff}.star-icon-large{width:24px;height:24px;transition:all .2s}.project-description,.project-link{margin-bottom:3rem}.project-description h2,.project-link h2,.project-technologies h2{text-transform:uppercase;letter-spacing:1px;margin:0 0 1rem;font-size:1.5rem;font-weight:700}.project-description p{color:#333;margin:0;font-size:1.125rem;line-height:1.8}.external-link{color:#000;word-break:break-all;border-bottom:2px solid #000;padding-bottom:2px;font-size:1.125rem;text-decoration:none;transition:opacity .2s;display:inline-block}.external-link:hover{opacity:.6}@media (max-width:768px){.project-title{font-size:2rem}.project-banner{height:250px}.project-header{flex-direction:column;align-items:stretch}.project-actions{width:100%}.project-actions .btn{flex:1}}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.project-form{max-width:700px}.thumbnail-preview{border:2px solid #000;max-width:400px;margin-top:1rem}.thumbnail-preview img{width:100%;display:block}.contact{min-height:100vh;padding:6rem 2rem 4rem}.contact-content{max-width:700px}.contact-intro{color:#333;margin:0 0 3rem;font-size:1.25rem;line-height:1.6}.contact-info{flex-direction:column;gap:2rem;display:flex}.contact-item{border-top:2px solid #000;padding-top:1rem}.contact-item h2{text-transform:uppercase;letter-spacing:1px;color:#666;margin:0 0 .5rem;font-size:1rem;font-weight:600}.contact-item a{color:#000;font-size:1.25rem;font-weight:500;text-decoration:none;transition:opacity .2s}.contact-item a:hover{opacity:.6}.donate-list{flex-direction:row;justify-content:space-between;align-items:center;max-width:100%;margin:3rem auto 0;display:flex}.section-title{margin-bottom:2rem}.qr-link{transition:opacity .2s;display:block}.qr-link:hover{opacity:.8}.qr-code{background-image:url(/assets/qr-mono-uah-Dlm24vw1.png);background-position:50%;background-repeat:no-repeat;background-size:contain;border:2px solid #000;width:288px;height:500px}@media (max-width:768px){.qr-code{width:250px;height:250px}}.login-page{background:#f5f5f5;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-container{background:#fff;border:2px solid #000;width:100%;max-width:450px;padding:3rem}.login-title{text-transform:uppercase;letter-spacing:2px;text-align:center;margin:0 0 2rem;font-size:2rem;font-weight:700}.error-message{color:#721c24;text-align:center;background:#f8d7da;border:2px solid #721c24;margin-bottom:2rem;padding:1rem;font-weight:500}.login-form{flex-direction:column;gap:1.5rem;display:flex}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#000;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.page-wrapper{min-height:100vh;padding:6rem 2rem 4rem}.page-title{text-transform:uppercase;letter-spacing:2px;margin:0;font-size:2.5rem;font-weight:700}.section-title{text-transform:uppercase;letter-spacing:1px;margin:0 0 1rem;font-size:1.5rem;font-weight:700}.btn{text-transform:uppercase;letter-spacing:1px;cursor:pointer;border:2px solid #000;padding:.875rem 2rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#000}.btn-primary:hover:not(:disabled),.btn-secondary{color:#000;background:#fff}.btn-secondary:hover:not(:disabled){color:#fff;background:#000}.btn-danger{color:#721c24;background:#fff;border-color:#721c24}.btn-danger:hover:not(:disabled){color:#fff;background:#721c24}.btn-large{padding:1rem 3rem;font-size:1rem}.form-group{margin-bottom:1.5rem}.form-label{text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.form-input,.form-textarea{border:2px solid #000;outline:none;width:100%;padding:.875rem;font-family:inherit;font-size:1rem;transition:background .2s}.form-input:focus,.form-textarea:focus{background:#f9f9f9}.form-textarea{resize:vertical;min-height:120px}.form-file{cursor:pointer;border:2px solid #000;width:100%;padding:.5rem;font-family:inherit}.message{border:2px solid #000;margin-bottom:2rem;padding:1rem;font-weight:500}.message.success{color:#155724;background:#d4edda;border-color:#155724}.message.error{color:#721c24;background:#f8d7da;border-color:#721c24}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border:2px solid #000;width:100%;max-width:500px;padding:2.5rem}.modal-title{text-transform:uppercase;letter-spacing:1px;margin:0 0 1.5rem;font-size:1.75rem;font-weight:700}.tech-tag{text-transform:uppercase;letter-spacing:1px;background:#fff;border:1px solid #000;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-block}.tech-list{flex-wrap:wrap;gap:.75rem;display:flex}.border-box{background:#fff;border:2px solid #000;padding:2rem}.border-top{border-top:2px solid #000;padding-top:1rem}
