html{--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f7;--color-bg-dark: #000000;--color-text-primary: #1d1d1f;--color-text-secondary: #6e6e73;--color-text-light: #ffffff;--color-brand-primary: #0071e3;--color-brand-secondary: #5e5ce6;--color-accent: #06c;--color-success: #30d158;--color-warning: #ff9500;--color-error: #ff3b30;--color-header-bg: rgba(255, 255, 255, .8);--color-header-border: rgba(0, 0, 0, .05);--color-text-nav-link: rgba(0, 0, 0, .85);--color-logo-dev: #fbbf24;--color-hamburger: #1d1d1f}html[data-theme=dark]{--color-bg-primary: #0a0a0a;--color-bg-secondary: #1a1a1a;--color-bg-dark: #000000;--color-text-primary: #f5f5f5;--color-text-secondary: #a1a1a6;--color-text-light: #ffffff;--color-brand-primary: #0071e3;--color-brand-secondary: #5e5ce6;--color-accent: #06c;--color-success: #30d158;--color-warning: #ff9500;--color-error: #ff3b30;--color-header-bg: rgba(0, 0, 0, .8);--color-header-border: rgba(255, 255, 255, .1);--color-text-nav-link: #8c8c94;--color-logo-dev: #fcd34d;--color-hamburger: #f5f5f5}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:3rem;margin:3rem 0}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.projects-grid{grid-template-columns:1fr;gap:2rem;margin:2rem 0}}@media(max-width:640px){.projects-grid{gap:1rem;margin:1rem 0}}.project-card{height:100%;cursor:pointer;perspective:1000px}.project-card .card-front{height:100%;display:flex;flex-direction:column;background-color:var(--color-bg-secondary);border-radius:1rem;overflow:hidden;border:2px solid rgba(0,113,227,.1);transition:all .4s cubic-bezier(.34,1.56,.64,1);transform:translateY(0);box-shadow:0 10px 30px #0000001a}.project-card:hover .card-front,.project-card.hovered .card-front{transform:translateY(-12px);border-color:#0071e34d;box-shadow:0 20px 50px #0071e326}@media(max-width:768px){.project-card:hover .card-front,.project-card.hovered .card-front{transform:translateY(-6px)}}@media(max-width:640px){.project-card:hover .card-front,.project-card.hovered .card-front{transform:translateY(-4px)}}.project-card .card-image-wrapper{position:relative;width:100%;height:240px;overflow:hidden;background:linear-gradient(135deg,var(--color-bg-secondary),var(--color-bg-primary))}@media(max-width:768px){.project-card .card-image-wrapper{height:180px}}@media(max-width:640px){.project-card .card-image-wrapper{height:150px}}.project-card .card-image-wrapper .card-image{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card .card-image-wrapper .card-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease;backdrop-filter:blur(2px)}.project-card .card-image-wrapper .card-overlay .view-more{color:#fff;font-weight:700;font-size:1.125rem;text-align:center;padding:.75rem}.project-card .card-image-wrapper:hover .card-image{transform:scale(1.08)}.project-card .card-image-wrapper:hover .card-overlay{opacity:1}.project-card .card-content{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;flex:1;justify-content:space-between}@media(max-width:768px){.project-card .card-content{padding:1rem;gap:.5rem}}@media(max-width:640px){.project-card .card-content{padding:.75rem;gap:.5rem}}.project-card .card-content .card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.project-card .card-content .card-header .card-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.2;flex:1}@media(max-width:768px){.project-card .card-content .card-header .card-title{font-size:1.25rem}}@media(max-width:640px){.project-card .card-content .card-header .card-title{font-size:1.125rem}}.project-card .card-content .card-header .card-status{display:inline-block;padding:.25rem .75rem;background-color:#0071e31a;color:#0071e3;border-radius:9999px;font-size:.75rem;font-weight:500;white-space:nowrap;flex-shrink:0}@media(max-width:640px){.project-card .card-content .card-header .card-status{padding:.25rem .5rem;font-size:.75rem}}.project-card .card-content .card-description{font-size:1rem;color:var(--color-text-secondary);line-height:1.5;margin:0;flex:1}@media(max-width:768px){.project-card .card-content .card-description{font-size:.875rem}}.project-card .card-content .card-tags{display:flex;flex-wrap:wrap;gap:.5rem}@media(max-width:640px){.project-card .card-content .card-tags{gap:.25rem}}.project-card .card-content .card-tags .tag{display:inline-block;padding:.25rem .5rem;background-color:#0071e314;color:#0071e3;border-radius:.25rem;font-size:.75rem;font-weight:500;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}@media(max-width:640px){.project-card .card-content .card-tags .tag{padding:.25rem;font-size:.75rem}}.project-card .card-content .card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid rgba(110,110,115,.1)}.project-card .card-content .card-footer .card-year{font-size:.875rem;color:var(--color-text-secondary);font-weight:500}.project-card .card-content .card-footer .card-links{display:flex;gap:.5rem}@media(max-width:640px){.project-card .card-content .card-footer .card-links{gap:.25rem}}.project-card .card-content .card-footer .card-links .link-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:#0071e31a;border-radius:9999px;text-decoration:none;font-size:1.125rem;transition:all .3s ease;border:1px solid transparent}@media(max-width:640px){.project-card .card-content .card-footer .card-links .link-icon{width:28px;height:28px;font-size:1rem}}.project-card .card-content .card-footer .card-links .link-icon:hover{background-color:#0071e3;color:#000;transform:scale(1.1)}.project-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .3s ease;backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.project-modal{background-color:var(--color-bg-primary);border-radius:1.5rem;max-width:1000px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 25px 50px #0000004d;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.project-modal{max-height:95vh;max-width:100%}}.project-modal .modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;background-color:#0071e31a;border:none;border-radius:9999px;font-size:1.25rem;cursor:pointer;transition:all .3s ease;z-index:10;display:flex;align-items:center;justify-content:center}.project-modal .modal-close:hover{background-color:#0071e3;color:#000;transform:rotate(90deg)}.project-modal .modal-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;padding:3rem}@media(max-width:768px){.project-modal .modal-content{grid-template-columns:1fr;gap:2rem;padding:2rem}}.project-modal .modal-content .modal-image{width:100%;height:auto;border-radius:1rem;object-fit:cover;box-shadow:0 10px 30px #0003}.project-modal .modal-content .modal-details{display:flex;flex-direction:column;gap:1.5rem}.project-modal .modal-content .modal-details .modal-header h2{font-size:2.25rem;margin:0 0 .75rem;color:var(--color-text-primary);line-height:1.2}.project-modal .modal-content .modal-details .modal-header .modal-description{font-size:1.125rem;color:var(--color-text-secondary);margin:0;line-height:1.5}.project-modal .modal-content .modal-details .modal-body{flex:1}.project-modal .modal-content .modal-details .modal-body .modal-text{font-size:1rem;color:var(--color-text-secondary);line-height:1.75}.project-modal .modal-content .modal-details .modal-body .modal-text p{margin:0 0 .75rem}.project-modal .modal-content .modal-details .modal-body .modal-text p:last-child{margin-bottom:0}.project-modal .modal-content .modal-details .modal-body .modal-text strong{color:#0071e3;font-weight:700}.project-modal .modal-content .modal-details .modal-body .modal-text ul,.project-modal .modal-content .modal-details .modal-body .modal-text ol{margin:.75rem 0;padding-left:1.5rem}.project-modal .modal-content .modal-details .modal-body .modal-text ul li,.project-modal .modal-content .modal-details .modal-body .modal-text ol li{margin-bottom:.5rem}.project-modal .modal-content .modal-details .modal-tags{display:flex;flex-wrap:wrap;gap:.5rem}.project-modal .modal-content .modal-details .modal-tags .tag{padding:.5rem .75rem;background-color:#0071e31a;color:#0071e3;border-radius:9999px;font-size:.875rem;font-weight:500;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;border:1px solid rgba(0,113,227,.2)}.project-modal .modal-content .modal-details .modal-tags .tag.large{font-size:1rem}.project-modal .modal-content .modal-details .modal-actions{display:flex;gap:.75rem;flex-wrap:wrap}.project-modal .modal-content .modal-details .modal-actions .btn{flex:1;min-width:150px;padding:.75rem 2rem;font-weight:500;border-radius:1rem;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:all .3s ease;border:none;cursor:pointer;font-size:1rem}.project-modal .modal-content .modal-details .modal-actions .btn.btn-primary{background-color:#0071e3;color:#000}.project-modal .modal-content .modal-details .modal-actions .btn.btn-primary:hover{background-color:#178aff;transform:translateY(-2px);box-shadow:0 10px 25px #0071e34d}.project-modal .modal-content .modal-details .modal-actions .btn.btn-secondary{background-color:transparent;color:#0071e3;border:2px solid #0071e3}.project-modal .modal-content .modal-details .modal-actions .btn.btn-secondary:hover{background-color:#0071e31a;transform:translateY(-2px)}.project-modal{scrollbar-color:rgba(0,113,227,.3) transparent;scrollbar-width:thin}.project-modal::-webkit-scrollbar{width:8px}.project-modal::-webkit-scrollbar-track{background:transparent}.project-modal::-webkit-scrollbar-thumb{background:#0071e34d;border-radius:4px}.project-modal::-webkit-scrollbar-thumb:hover{background:#0071e380}
