@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Inter:wght@400;500&display=swap";:root{--bg-color:#07070a;--text-main:#fff;--text-muted:#8b8b93;--accent:#5a6bfa;--accent-glow:#5a6bfa66;--card-bg:#ffffff08;--card-bg-hover:#ffffff0f;--card-border:#ffffff14;--glass-blur:blur(20px);--font-display:"Outfit", sans-serif;--font-body:"Inter", sans-serif}[data-theme=light]{--bg-color:#f7f7f9;--text-main:#0f0f13;--text-muted:#6b6b75;--accent:#4f46e5;--accent-glow:#4f46e54d;--card-bg:#fffc;--card-bg-hover:#fff;--card-border:#0000000f}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-color);color:var(--text-main);font-family:var(--font-body);transition:background-color .4s,color .4s;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em;font-weight:700}a{color:inherit;text-decoration:none;transition:all .3s}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.app-main{width:100%;min-height:100vh;position:relative}.ambient-glow{background:radial-gradient(circle, var(--accent-glow) 0%, transparent 60%);z-index:-1;pointer-events:none;width:80vw;height:80vh;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.navbar-container{z-index:1000;background:var(--card-bg);width:min(94%,1200px);height:5rem;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--card-border);border-radius:999px;align-items:center;padding:0 2rem;display:flex;position:fixed;top:1.5rem;left:50%;transform:translate(-50%)}.navbar-content{justify-content:space-between;align-items:center;width:100%;display:flex}.logo{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-main);font-size:1.5rem;font-weight:800}.nav-links{align-items:center;gap:1.5rem;display:flex}.nav-links a{color:var(--text-muted);font-size:.875rem;font-weight:500}.nav-links a:hover,.nav-links a.active{color:var(--text-main)}.nav-cta,.resume-btn{background:var(--text-main);border-radius:999px;padding:.6rem 1.2rem;font-size:.875rem;font-weight:600;color:var(--bg-color)!important}.nav-cta:hover,.resume-btn:hover{transform:scale(1.05)}.theme-toggle,.lang-toggle{background:var(--card-bg);border:1px solid var(--card-border);color:var(--text-main);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;height:36px;padding:0 .8rem;font-size:.75rem;font-weight:600;transition:all .3s;display:flex}.theme-toggle:hover,.lang-toggle:hover{border-color:var(--accent);color:var(--accent)}.nav-actions{align-items:center;gap:.8rem;display:flex}.mobile-menu-btn{background:var(--card-bg-hover);border:1px solid var(--card-border);color:var(--text-main);cursor:pointer;z-index:1001;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:none}@media (width<=768px){.mobile-menu-btn{display:flex}.nav-links{background:var(--card-bg);-webkit-backdrop-filter:blur(60px);border-left:1px solid var(--card-border);z-index:1000;flex-direction:column;align-items:flex-start;gap:1.5rem;width:280px;height:100vh;padding:6rem 2rem 2rem;transition:right .4s cubic-bezier(.4,0,.2,1);position:fixed;top:0;right:-100%}[data-theme=light] .nav-links{background:#fffffff2}[data-theme=dark] .nav-links{background:#0a0a0af2}.nav-links.mobile-active{right:0;box-shadow:-20px 0 40px #00000080}.nav-links a{width:100%;padding:.5rem 0;font-size:1.125rem}.nav-actions{border-top:1px solid var(--card-border);border-bottom:1px solid var(--card-border);gap:1rem;width:100%;padding:1rem 0;display:flex}.nav-cta,.resume-btn{text-align:center;width:100%;padding:.875rem}}.bento-wrapper{max-width:1200px;margin:0 auto;padding:9rem 2rem 4rem}.bento-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:300px;gap:1.5rem;display:grid}.bento-box{background:var(--card-bg);border:1px solid var(--card-border);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:24px;flex-direction:column;padding:2rem;transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s;display:flex;position:relative;overflow:hidden}.bento-box:hover{border-color:var(--card-bg-hover);transform:translateY(-4px);box-shadow:0 20px 40px #0003}.bento-hero{background:linear-gradient(145deg, var(--card-bg) 0%, transparent 100%);flex-direction:row;grid-area:span 2/span 3;justify-content:space-between;align-items:center;gap:2rem;display:flex}.hero-text-content{flex:1}.hero-image-wrapper{background:linear-gradient(135deg, var(--accent) 0%, #3b82f6 100%);width:clamp(120px,15vw,180px);height:clamp(120px,15vw,180px);box-shadow:0 10px 30px var(--accent-glow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:6px;display:flex}.hero-image-wrapper img{object-fit:cover;border:4px solid var(--card-bg);border-radius:50%;width:100%;height:100%}.image-switch-badge{background:var(--accent);color:#fff;border:3px solid var(--card-bg);z-index:5;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .3s cubic-bezier(.2,.8,.2,1);display:flex;position:absolute;bottom:5%;right:5%;box-shadow:0 4px 15px #0006}.image-switch-badge:hover{background:#3b82f6;transform:scale(1.15)rotate(15deg)}.hero-title{color:var(--text-main);font-size:clamp(3rem,6vw,4.5rem);line-height:1.05}.hero-subtitle{color:var(--text-muted);max-width:80%;margin-top:1rem;font-size:clamp(1rem,2vw,1.25rem)}.hero-socials{gap:1rem;margin-top:2rem;display:flex}.social-icon-btn{background:var(--card-bg);border:1px solid var(--card-border);width:48px;height:48px;color:var(--text-main);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:14px;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.social-icon-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 10px 20px var(--accent-glow);transform:translateY(-4px)scale(1.1)}.mt-6{margin-top:1.5rem}.bento-stat{grid-area:span 1/span 1;justify-content:center;align-items:flex-start}.stat-num{font-size:3.5rem;font-family:var(--font-display);color:var(--accent);font-weight:800;line-height:1}.stat-desc{color:var(--text-muted);margin-top:.5rem;font-weight:500}.bento-project{grid-area:span 1/span 2;min-height:300px;padding:0}.project-img-wrapper{background:var(--card-bg);justify-content:center;align-items:center;width:100%;height:60%;display:flex;overflow:hidden}.project-img-wrapper img{object-fit:cover;box-sizing:border-box;width:100%;height:100%;transition:transform .7s}.bento-project:hover .project-img-wrapper img{transform:scale(1.05)}.project-content{flex-direction:column;justify-content:center;height:40%;padding:1.5rem 2rem;display:flex}.project-tag{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.5rem;font-size:.75rem;font-weight:700}.project-title{color:var(--text-main);margin-bottom:.5rem;font-size:1.5rem}.project-desc{color:var(--text-muted);font-size:.875rem}.bento-text{grid-area:span 1/span 2;justify-content:center}.bento-text p{color:var(--text-muted);font-size:1.125rem;line-height:1.6}.bento-contact{background:var(--accent);color:#fff;flex-direction:row;grid-area:span 1/span 4;justify-content:space-between;align-items:center;display:flex}.bento-contact h2{color:#fff;font-size:2.5rem}.ai-chat-container{z-index:1002;position:fixed;bottom:2rem;right:2rem}.chat-toggle{background:linear-gradient(135deg, var(--accent) 0%, #3b82f6 100%);color:#fff;cursor:pointer;width:3.5rem;height:3.5rem;box-shadow:0 10px 30px var(--accent-glow);border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.2,.8,.2,1);display:flex;position:relative}.chat-toggle:hover{box-shadow:0 15px 40px var(--accent-glow);transform:scale(1.1)rotate(10deg)}.toggle-badge{border:2px solid var(--bg-color);background-color:#ef4444;border-radius:50%;width:12px;height:12px;position:absolute;top:0;right:0;box-shadow:0 0 10px #ef444480}.chat-window{background:var(--card-bg);-webkit-backdrop-filter:blur(40px);border:1px solid var(--card-border);width:min(90vw,400px);height:600px;max-height:80vh;font-family:var(--font-body);border-radius:24px;flex-direction:column;display:flex;position:absolute;bottom:4.5rem;right:0;overflow:hidden;box-shadow:0 30px 80px #0006,inset 0 1px #ffffff1a}.chat-header{border-bottom:1px solid var(--card-border);background:linear-gradient(#ffffff0d,#0000);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.header-info{align-items:center;gap:1rem;display:flex}.ai-status{background:linear-gradient(135deg, var(--accent) 0%, #5a6bfa80 100%);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.pulse-dot{background:#fff;border-radius:50%;width:12px;height:12px;animation:2s infinite pulse}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #ffffffb3}70%{transform:scale(1);box-shadow:0 0 0 10px #fff0}to{transform:scale(.95);box-shadow:0 0 #fff0}}.header-info h3{color:var(--text-main);letter-spacing:0;margin:0;font-size:1.1rem;font-weight:700}.header-info p{color:var(--text-muted);margin:0;font-size:.8rem}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:all .2s;display:flex}.close-btn:hover{background:var(--card-bg-hover);color:var(--text-main)}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:1.25rem;padding:1.5rem;display:flex;overflow-y:auto}.message-wrapper{gap:.75rem;max-width:90%;display:flex}.message-wrapper.user{flex-direction:row-reverse;align-self:flex-end}.message-icon{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;width:28px;height:28px;display:flex}.message-bubble{border-radius:18px;padding:.875rem 1.25rem;font-size:.95rem;line-height:1.5}.assistant .message-bubble{background:var(--card-bg-hover);color:var(--text-main);border:1px solid var(--card-border);border-bottom-left-radius:4px}.user .message-bubble{background:linear-gradient(135deg, var(--accent) 0%, #3b82f6 100%);color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 15px #5a6bfa4d}.success-bubble{color:#22c55e!important;background:#22c55e1a!important;border:1px solid #22c55e33!important}.typing-bubble{align-items:center;gap:4px;padding:1rem 1.25rem;display:flex}.typing-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both bounce}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-suggestions{margin-top:1rem}.suggestion-btn{color:var(--accent);cursor:pointer;background:#5a6bfa1a;border:1px solid #5a6bfa33;border-radius:12px;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.suggestion-btn .chevron{opacity:.7;margin-left:auto}.suggestion-btn:hover{background:#5a6bfa33;transform:translateY(-2px)}.ai-contact-form-wrapper{background:var(--card-bg-hover);border:1px solid var(--card-border);border-radius:16px;margin-top:.5rem;padding:1.25rem}.ai-contact-form{flex-direction:column;gap:1rem;display:flex}.form-group input{border:1px solid var(--card-border);width:100%;color:var(--text-main);background:#0003;border-radius:8px;padding:.875rem 1rem;font-family:inherit;font-size:.9rem;transition:all .2s}[data-theme=light] .form-group input{background:#ffffff80}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow);outline:none}.submit-form-btn{background:linear-gradient(135deg, var(--accent) 0%, #3b82f6 100%);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.875rem;font-weight:600;transition:all .3s;display:flex}.submit-form-btn:hover{filter:brightness(1.1);box-shadow:0 5px 15px var(--accent-glow)}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px}.chat-input-area{border-top:1px solid var(--card-border);background:var(--card-bg);align-items:center;gap:.75rem;padding:1.25rem;display:flex}.chat-input-area input{border:1px solid var(--card-border);color:var(--text-main);background:#0003;border-radius:999px;flex:1;padding:.875rem 1.25rem;font-family:inherit;font-size:.95rem;transition:all .2s}[data-theme=light] .chat-input-area input{background:#ffffff80}.chat-input-area input:focus{border-color:var(--accent);background:#0000004d;outline:none}.chat-input-area button{background:var(--card-bg-hover);width:42px;height:42px;color:var(--text-muted);border:1px solid var(--card-border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.2,.8,.2,1);display:flex}.chat-input-area button.active{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.05)}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}.footer{text-align:center;color:var(--text-muted);padding:2rem;font-size:.875rem}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:2000;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;padding:1.5rem;display:flex;position:fixed;top:0;left:0}.contact-modal{background:var(--card-bg);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--card-border);width:min(90vw,450px);font-family:var(--font-body);border-radius:24px;padding:2.5rem;position:relative;box-shadow:0 40px 100px #00000080,inset 0 1px #ffffff1a}.modal-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem;transition:all .2s;display:flex;position:absolute;top:1.5rem;right:1.5rem}.modal-close-btn:hover{background:var(--card-bg-hover);color:var(--text-main);transform:rotate(90deg)}.modal-header{margin-bottom:2rem}.modal-header h2{color:var(--text-main);margin-bottom:.5rem;font-size:2rem;line-height:1.2}.modal-header p{color:var(--text-muted);font-size:.95rem}.modal-success-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:2rem 0;display:flex}.success-icon{color:#22c55e;margin-bottom:1.5rem}.modal-success-state h3{color:var(--text-main);margin-bottom:.5rem;font-size:1.5rem}@media (width<=1024px){.bento-hero{text-align:center;flex-direction:column-reverse;grid-column:span 4;align-items:center;padding:3rem 2rem}.hero-subtitle{max-width:100%;margin:1rem auto 0}.bento-stat{grid-column:span 2}.bento-project,.bento-text{grid-column:span 4}.bento-contact{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 2rem}.bento-contact h2{font-size:2rem}}@media (width<=640px){.bento-grid{grid-template-columns:1fr;grid-auto-rows:auto;gap:1rem}.bento-hero,.bento-stat,.bento-project,.bento-text,.bento-contact{grid-column:span 1}.bento-hero{padding:2.5rem 1.5rem}.hero-title{font-size:2.25rem}.stat-num{font-size:2.75rem}.navbar-container{padding:0 1.25rem}}.projects-page{max-width:1200px;margin:0 auto;padding:9rem 2rem 6rem}.projects-header{margin-bottom:3.5rem}.projects-eyebrow{letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.8rem;font-weight:700;display:block}.projects-title{color:var(--text-main);margin-bottom:1rem;font-size:clamp(2.5rem,6vw,4rem);line-height:1.05}.projects-accent{color:var(--accent)}.projects-subtitle{color:var(--text-muted);max-width:600px;margin-bottom:2rem;font-size:clamp(1rem,2vw,1.15rem);line-height:1.6}.projects-filters{flex-wrap:wrap;gap:.6rem;display:flex}.filter-chip{border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-muted);cursor:pointer;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:999px;padding:.5rem 1.1rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .25s}.filter-chip:hover{border-color:var(--accent);color:var(--accent)}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 15px var(--accent-glow)}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem;display:grid}@media (width<=900px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.projects-grid{grid-template-columns:1fr}}.project-card{background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:20px;flex-direction:column;transition:border-color .3s,box-shadow .3s;display:flex;overflow:hidden}.project-card:hover{border-color:#5a6bfa4d;box-shadow:0 20px 50px #00000040}.pc-accent{flex-shrink:0;width:100%;height:3px}.pc-body{flex-direction:column;flex:1;gap:.5rem;padding:1.5rem 1.5rem 1rem;display:flex}.pc-top{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.pc-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.pc-meta-right{flex-direction:column;align-items:flex-end;gap:.3rem;display:flex}.pc-status{color:var(--accent);background:#5a6bfa1f;border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.pc-status.in-progress{color:#22c55e;background:#22c55e1f}.pc-status.done{color:var(--accent);background:#5a6bfa1f}.pc-year{color:var(--text-muted);font-size:.7rem}.pc-category{letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:700}.pc-title{color:var(--text-main);margin:0;font-size:1.1rem;font-weight:700;line-height:1.3}.pc-desc{color:var(--text-muted);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;flex:1;font-size:.855rem;line-height:1.55;display:-webkit-box;overflow:hidden}.pc-tags{flex-wrap:wrap;gap:.4rem;margin-top:.5rem;display:flex}.pc-tag{background:var(--card-bg-hover);color:var(--text-muted);border:1px solid var(--card-border);border-radius:6px;padding:.2rem .55rem;font-size:.72rem;font-weight:500}.pc-tag-more{color:var(--accent);background:0 0;border-radius:6px;padding:.2rem .55rem;font-size:.72rem;font-weight:600}.pc-footer{border-top:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.pc-type{color:var(--text-muted);font-size:.75rem}.pc-open{color:var(--accent);align-items:center;gap:.3rem;font-size:.8rem;font-weight:600;transition:gap .2s;display:flex}.project-card:hover .pc-open{gap:.5rem}.portfolio-upload-cta{background:var(--card-bg);border:1px dashed var(--card-border);border-radius:20px;padding:2rem}.upload-cta-inner{align-items:center;gap:1.5rem;display:flex}.upload-icon{font-size:2.5rem}.portfolio-upload-cta h3{color:var(--text-main);margin-bottom:.3rem;font-size:1.1rem}.portfolio-upload-cta p{color:var(--text-muted);font-size:.875rem}.project-modal-overlay{-webkit-backdrop-filter:blur(16px);z-index:2000;isolation:isolate;background:#000000bf;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.project-modal{background:var(--card-bg);border:1px solid var(--card-border);border-radius:28px;width:min(95vw,560px);max-height:85vh;padding:2.5rem;position:relative;overflow-y:auto;box-shadow:0 40px 100px #00000080,inset 0 1px #ffffff14}.modal-accent-line{border-radius:28px 28px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.pm-header{align-items:flex-start;gap:1.25rem;margin-top:.5rem;margin-bottom:1.25rem;display:flex}.pm-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.pm-category{text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem;font-size:.75rem;font-weight:700;display:block}.pm-title{color:var(--text-main);margin:0;font-size:1.5rem;line-height:1.2}.pm-meta{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.pm-status{background:var(--card-bg-hover);color:var(--text-main);border-radius:999px;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.8rem;font-weight:600;display:flex}.pm-dot{border-radius:50%;width:7px;height:7px}.pm-status.active .pm-dot{animation:2s infinite pulse}.pm-year,.pm-type{color:var(--text-muted);background:var(--card-bg-hover);border-radius:999px;padding:.3rem .75rem;font-size:.8rem}.pm-desc{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem;line-height:1.65}.pm-highlights{margin-bottom:1.5rem}.pm-highlights h4{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem;font-size:.8rem}.pm-highlights ul{flex-direction:column;gap:.5rem;padding:0;list-style:none;display:flex}.pm-highlights li{color:var(--text-main);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.pm-check{font-size:.7rem}.pm-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.pm-tag{border:1px solid;border-radius:8px;padding:.3rem .75rem;font-size:.8rem;font-weight:500}.pm-images-placeholder{background:var(--card-bg-hover);border:1px dashed var(--card-border);text-align:center;color:var(--text-muted);border-radius:16px;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;font-size:.875rem;display:flex}.pm-images-placeholder p{margin:0}.project-modal::-webkit-scrollbar{width:4px}.project-modal::-webkit-scrollbar-track{background:0 0}.project-modal::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:4px}@media (width<=600px){.projects-page{padding:8rem 1.25rem 4rem}.upload-cta-inner{flex-direction:column;align-items:flex-start}}.project-modal--wide{width:min(95vw,980px);max-height:90vh}.pm-two-col{grid-template-columns:1fr 1fr;align-items:start;gap:2rem;display:grid}@media (width<=720px){.pm-two-col{grid-template-columns:1fr}.project-modal--wide{width:min(95vw,560px)}}.pm-gallery-col{flex-direction:column;gap:1rem;display:flex;position:sticky;top:0}.pm-info-col{flex-direction:column;gap:0;display:flex}.pm-gallery{flex-direction:column;gap:.75rem;display:flex}.pm-gallery-main{background:var(--card-bg-hover);aspect-ratio:4/3;border-radius:16px;position:relative;overflow:hidden}.pm-gallery-img{object-fit:cover;object-position:top;width:100%;height:100%;display:block}.pm-gallery-nav{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:2;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.pm-gallery-nav:hover{background:#000c}.pm-gallery-nav.prev{left:10px}.pm-gallery-nav.next{right:10px}.pm-gallery-counter{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;border-radius:999px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;position:absolute;bottom:10px;right:12px}.pm-gallery-thumbs{scrollbar-width:none;gap:.5rem;padding-bottom:4px;display:flex;overflow-x:auto}.pm-gallery-thumbs::-webkit-scrollbar{display:none}.pm-gallery-thumb{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:10px;flex-shrink:0;width:56px;height:56px;padding:0;transition:border-color .2s,transform .2s;overflow:hidden}.pm-gallery-thumb:hover,.pm-gallery-thumb.active{transform:scale(1.05)}.pm-gallery-thumb img{object-fit:cover;object-position:top;width:100%;height:100%;display:block}.pm-figma-btn{color:#fff;border-radius:12px;justify-content:center;align-items:center;gap:.6rem;padding:.875rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:700;text-decoration:none;transition:filter .2s,transform .2s;display:flex;box-shadow:0 6px 20px #0003}.pm-figma-btn:hover{filter:brightness(1.12);transform:translateY(-2px)}.project-card--featured{border-color:#22c55e40;grid-column:span 1}.project-card--featured:hover{border-color:#22c55e80;box-shadow:0 20px 60px #22c55e26}.pc-preview-img{background:#111;width:100%;height:180px;position:relative;overflow:hidden}.pc-preview-img img{object-fit:cover;object-position:top;width:100%;height:100%;transition:transform .6s}.project-card--featured:hover .pc-preview-img img{transform:scale(1.05)}.pc-preview-overlay{position:absolute;inset:0}.pc-figma-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;letter-spacing:.05em;background:#000000a6;border-radius:999px;align-items:center;gap:.4rem;padding:.3rem .65rem;font-size:.72rem;font-weight:700;display:flex;position:absolute;top:10px;right:10px}.lightbox-overlay{-webkit-backdrop-filter:blur(16px);z-index:9999;background:#000000bf;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.lightbox-inner{background:var(--card-bg);border-radius:24px;max-width:90vw;max-height:90vh;position:relative;overflow:hidden;box-shadow:0 40px 100px #0009}.lightbox-img{object-fit:contain;border-radius:24px;width:auto;max-width:100%;height:auto;max-height:90vh;display:block}.lightbox-close{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10;background:#0006;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.lightbox-close:hover{background:#000c;transform:scale(1.05)}.lang-modal{background:var(--card-bg);border:1px solid var(--card-border);width:100%;max-width:450px;color:var(--text-main);border-radius:28px;padding:2.5rem;position:relative;box-shadow:0 40px 100px #00000080}.lang-modal-title{color:var(--text-main);text-align:center;margin-bottom:.5rem;font-size:1.5rem}.lang-modal-sub{color:var(--text-muted);text-align:center;margin-bottom:2rem;font-size:.95rem}.lang-list{flex-direction:column;gap:1.5rem;display:flex}.lang-item{flex-direction:column;gap:.75rem;display:flex}.lang-row{align-items:center;gap:.75rem;display:flex}.lang-flag{font-size:1.5rem}.lang-name{flex:1;font-size:1.1rem;font-weight:600}.lang-level-badge{letter-spacing:.05em;text-transform:uppercase;border-radius:999px;padding:.2rem .6rem;font-size:.8rem;font-weight:700}.lang-bar-track{background:var(--card-border);border-radius:999px;width:100%;height:6px;overflow:hidden}.lang-bar-fill{border-radius:999px;height:100%}
