.project-card-modern{position:relative;background:rgba(24,24,24,.4);border-radius:1.5rem;overflow:hidden;transition:all .4s cubic-bezier(.175,.885,.32,2.2);border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px rgba(0,0,0,.3),0 0 0 1px rgba(255,255,255,.05);width:100%;height:100%;display:flex;flex-direction:column}.project-card-modern:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.15)}.project-card-glass-effect{position:absolute;inset:0;z-index:1;border-radius:1.5rem}.project-card-glass-tint{position:absolute;inset:0;z-index:2;background:rgba(255,255,255,.05);border-radius:1.5rem}.project-card-glass-shine{position:absolute;inset:0;z-index:3;border-radius:1.5rem;box-shadow:inset 1px 1px 2px rgba(255,255,255,.1),inset -1px -1px 2px rgba(255,255,255,.05)}.project-card-content{position:relative;z-index:4;flex:1 1;display:flex;flex-direction:column}.project-image-container{aspect-ratio:16/9;width:100%;overflow:hidden;border-radius:1.5rem 1.5rem 0 0;flex-shrink:0}.project-image-modern{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .4s ease}.project-card-modern:hover .project-image-modern{transform:scale(1.05)}.project-image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.1) 50%,rgba(0,0,0,.3))}.project-info{padding:2rem;flex:1 1;display:flex;flex-direction:column;gap:1rem}.project-category-badge{display:inline-block;background:rgba(255,255,255,.12);color:#fff;padding:.5rem 1rem;border-radius:2rem;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;width:-moz-fit-content;width:fit-content;border:1px solid rgba(255,255,255,.2)}.project-title-modern{font-size:1.5rem;font-weight:700;color:#fff;margin:0;line-height:1.3;letter-spacing:.02em}.project-description-modern{color:rgba(255,255,255,.8);font-size:1rem;line-height:1.6;margin:0;flex:1 1}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.project-tag{background:rgba(0,0,0,.5);color:rgba(255,255,255,.9);padding:.4rem .8rem;border-radius:1rem;font-size:.8rem;font-weight:500;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.project-tag:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}.project-actions{display:flex;flex-direction:column;gap:.8rem;margin-top:1rem}.project-action-btn{position:relative;display:flex;align-items:center;justify-content:center;padding:.78rem 1.5rem;border-radius:2rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .3s ease;border:1px solid rgba(255,255,255,.2);overflow:hidden;flex:1 1;box-shadow:0 8px 16px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.08);background:rgba(30,30,30,.7)}.project-action-btn.primary{color:#fff}.project-action-btn.primary:hover{background:rgba(0,0,0,.45);border-color:rgba(255,255,255,.4);transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.2),inset 3px 3px 6px rgba(255,255,255,.3),inset -3px -3px 6px rgba(255,255,255,.2)}.project-action-btn.secondary{color:rgba(255,255,255,.9)}.project-action-btn.secondary:hover{background:rgba(0,0,0,.5);border-color:rgba(255,255,255,.3);transform:translateY(-2px)}.project-action-btn.summary{color:#fff}.project-action-btn.summary:hover{background:rgba(0,0,0,.45);border-color:rgba(255,255,255,.4);box-shadow:0 12px 24px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.2),inset 3px 3px 6px rgba(255,255,255,.3),inset -3px -3px 6px rgba(255,255,255,.2);transform:translateY(-2px)}.project-action-btn span{position:relative;z-index:2}.project-action-btn:before{content:"";position:absolute;inset:0;z-index:0;background:rgba(255,255,255,.1)}.project-action-btn:after{content:"";position:absolute;inset:0;z-index:1;box-shadow:inset 2px 2px 4px rgba(255,255,255,.2),inset -2px -2px 4px rgba(255,255,255,.1)}@media (max-width:600px){.project-card-modern{max-width:98vw}.project-info{padding:1.5rem}.project-title-modern{font-size:1.3rem}.project-description-modern{font-size:.95rem}.project-actions{gap:.8rem}.project-action-btn{padding:.68rem 1rem}}.project-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.08);padding:1.5rem;margin:1rem 0;text-align:center;transition:box-shadow .2s}.project-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.15)}.project-image{width:100%;max-width:300px;border-radius:6px;margin-bottom:1rem}.project-modal-backdrop{position:fixed;top:80px;right:0;bottom:0;left:0;z-index:90;display:flex;align-items:flex-start;justify-content:center;padding:1.25rem 2rem 2rem;background:rgba(0,0,0,.72);box-sizing:border-box}.project-modal-shell{width:min(1200px,100%);height:100%;max-height:900px;overflow:hidden;position:relative;border-radius:1.5rem;background:linear-gradient(160deg,rgba(26,29,34,.9),rgba(10,12,16,.88));border:1px solid rgba(255,255,255,.14);box-shadow:0 24px 80px rgba(0,0,0,.45)}.project-modal-header{position:-webkit-sticky;position:sticky;top:0;z-index:4;display:flex;justify-content:flex-end;padding:.6rem .8rem;min-height:3.2rem;background:linear-gradient(180deg,rgba(13,16,22,.98),rgba(13,16,22,.72))}.project-modal-close{position:static;width:42px;height:42px;border-radius:2rem;border:1px solid rgba(255,255,255,.28);background:rgba(0,0,0,.35);color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2;box-shadow:0 8px 16px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.08),inset 2px 2px 4px rgba(255,255,255,.2),inset -2px -2px 4px rgba(255,255,255,.1)}.project-modal-scroll{height:100%;min-height:0}.project-modal-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);min-height:100%;align-items:start}.project-modal-carousel{width:min(100%,48rem);margin-inline:auto;padding:1.5rem 1.2rem 1.2rem;display:grid;grid-template-rows:auto auto;align-content:start;grid-gap:1rem;gap:1rem;min-height:0;min-width:0;overflow:hidden}.project-modal-image-frame{position:relative;width:100%;display:flex;align-items:center;justify-content:center;border-radius:1rem;overflow:hidden;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);aspect-ratio:16/10;height:auto;min-height:16rem;max-height:26rem}.project-modal-main-image{display:block;width:auto;height:auto;max-width:100%;max-height:100%;margin:0 auto;object-fit:contain;object-position:center center;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:rgba(0,0,0,.2)}.project-modal-main-image:active{cursor:-webkit-grabbing;cursor:grabbing}.project-modal-image-frame .project-modal-arrow{opacity:0}.project-modal-image-frame:hover .project-modal-arrow{opacity:1}.project-modal-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:2rem;border:1px solid rgba(255,255,255,.35);background:rgba(0,0,0,.35);color:#fff;font-size:1.8rem;line-height:.9;cursor:pointer;transition:opacity .22s ease,box-shadow .22s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 16px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.08),inset 2px 2px 4px rgba(255,255,255,.2),inset -2px -2px 4px rgba(255,255,255,.1)}.project-modal-arrow:hover{box-shadow:0 12px 24px rgba(0,0,0,.38),0 0 0 1px rgba(255,255,255,.2),inset 3px 3px 6px rgba(255,255,255,.3),inset -3px -3px 6px rgba(255,255,255,.2)}.project-modal-arrow-left{left:.8rem}.project-modal-arrow-right{right:.8rem}.project-modal-thumbs{display:flex;gap:.6rem;overflow-x:auto;padding-bottom:.1rem}.project-modal-thumb{border:1px solid rgba(255,255,255,.22);background:transparent;border-radius:.6rem;padding:0;width:84px;height:58px;overflow:hidden;flex-shrink:0;opacity:.65;cursor:pointer}.project-modal-thumb.active{opacity:1;border-color:rgba(150,236,255,.8)}.project-modal-thumb img{width:100%;height:100%;object-fit:cover}.project-modal-details{border-left:1px solid rgba(255,255,255,.09);padding:1.8rem 1.4rem 2.5rem;overflow-y:auto;max-height:100%;min-height:0;min-width:0}@media (min-width:769px){.project-modal-scroll{overflow:hidden}.project-modal-layout{height:100%;min-height:0}.project-modal-carousel{align-self:stretch}.project-modal-details{height:100%;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}}.project-modal-details h2{margin:0 0 .8rem;font-size:1.65rem}.project-modal-description{color:rgba(255,255,255,.86);line-height:1.6}.project-modal-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin:1rem 0}.project-modal-tags span{font-size:.8rem;border-radius:999px;padding:.4rem .8rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16)}.project-modal-tech h3{margin-top:1.2rem;margin-bottom:.65rem}.project-modal-software-section+.project-modal-software-section{margin-top:1rem}.project-modal-tech ul{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.65rem;color:rgba(255,255,255,.85);line-height:1.45}.project-modal-feature{display:flex;align-items:flex-start;gap:.5rem}.project-modal-feature.bulleted:before{content:"•";color:rgba(150,236,255,.95);line-height:1.2}.project-modal-feature-text.strong{font-weight:700;color:rgba(255,255,255,.96)}.project-modal-tech p{color:rgba(255,255,255,.78)}@media (min-width:769px) and (max-width:900px){.project-modal-backdrop{top:72px;padding:.9rem .9rem 1rem}.project-modal-shell{height:100%;max-height:100%}.project-modal-layout{grid-template-columns:minmax(0,.98fr) minmax(300px,1.02fr);grid-template-rows:1fr;height:100%}.project-modal-carousel{width:100%;padding:.85rem .85rem .7rem;gap:.65rem}.project-modal-image-frame{min-height:13rem;max-height:20rem;aspect-ratio:16/10}.project-modal-details{border-left:1px solid rgba(255,255,255,.09);border-top:0;padding:1.2rem 1rem 2rem;overflow-y:auto;max-height:100%}}@media (max-width:768px){.project-modal-backdrop{z-index:1200;top:80px;bottom:0;align-items:flex-start;padding:.75rem .75rem .9rem}.project-modal-shell{width:100%;height:100%;max-height:100%;margin-top:0;border-radius:1rem;display:flex;flex-direction:column}.project-modal-header{padding:.55rem .65rem;min-height:3.1rem}.project-modal-scroll{overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1 1;min-height:0}.project-modal-layout{min-height:0;grid-template-columns:1fr;grid-template-rows:auto auto}.project-modal-carousel{padding:.75rem .9rem .8rem;gap:.7rem;width:100%}.project-modal-image-frame{min-height:12.5rem;max-height:15.5rem}.project-modal-details{padding:1rem 1rem 1.2rem;overflow:visible;border-left:0;border-top:1px solid rgba(255,255,255,.08)}.project-modal-details h2{font-size:1.45rem;line-height:1.25}.project-modal-description{font-size:.98rem;line-height:1.55}.project-modal-tags span{font-size:.78rem;padding:.35rem .7rem}}@media (max-width:600px){.project-modal-backdrop{top:80px;padding:.65rem .65rem .85rem}.project-modal-shell{height:100%;max-height:100%;margin-top:0;border-radius:1.2rem}.project-modal-layout{grid-template-rows:auto auto}.project-modal-carousel{padding:3.6rem .85rem .75rem}.project-modal-image-frame{min-height:220px;height:min(34vh,240px);max-height:240px}.project-modal-details{padding:.95rem 1rem 1.1rem}.project-modal-close{width:44px;height:44px}.project-modal-thumb{width:68px;height:48px}}.projects-page{min-height:100vh;background:#000;color:#fff;position:relative;overflow-x:hidden;padding-top:80px}.projects-bg-pattern{position:absolute;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(255,255,255,.02) 0,rgba(255,255,255,.02) 4px);z-index:1;pointer-events:none;will-change:transform}.projects-hero{position:relative;z-index:2;padding:4rem 0 6rem;text-align:center}.projects-hero-content{max-width:90%;margin:0 auto;padding:0 2rem}.projects-title{font-size:clamp(4rem,8vw,8rem);font-weight:800;margin-bottom:2rem;color:#fff;text-transform:uppercase;letter-spacing:.05em;text-shadow:0 4px 20px rgba(255,255,255,.1)}.projects-description{font-size:1.2rem;line-height:1.7;color:rgba(255,255,255,.8);max-width:800px;margin:0 auto;font-weight:400;text-align:justify}.projects-container{position:relative;z-index:2;max-width:1400px;margin:0 auto;padding:0 2rem 4rem;display:flex;flex-direction:column;gap:4rem;align-items:stretch}.projects-section{width:100%}.projects-section-title{margin:0;font-size:clamp(1.8rem,3vw,2.5rem);font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:rgba(255,255,255,.96)}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:3rem;gap:3rem;margin-top:1.4rem;justify-content:center;align-items:stretch}.no-projects{grid-column:1/-1;text-align:center;padding:4rem 0;color:rgba(255,255,255,.6);font-size:1.2rem}@media (max-width:1200px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem}}@media (max-width:900px){.projects-hero{padding:2rem 0 4rem}.projects-title{font-size:clamp(3rem,10vw,6rem)}.projects-description{font-size:1.1rem}.projects-grid{grid-template-columns:1fr;gap:2rem;justify-content:center}.projects-container{padding:0 1rem 4rem}}@media (max-width:600px){.projects-hero-content{padding:0 1rem}.projects-description{font-size:1rem;line-height:1.6}}.projects-filter-bar{display:flex;justify-content:center;align-items:center;gap:.9rem;margin:2rem 0 0;z-index:3;position:relative;flex-wrap:wrap}.projects-filter-label{font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.72);font-weight:600}.projects-filter-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem;border-radius:999px;background:linear-gradient(160deg,rgba(255,255,255,.18),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.26);box-shadow:0 10px 35px rgba(0,0,0,.48),inset 0 1px 0 rgba(255,255,255,.28),inset 0 -6px 12px rgba(0,0,0,.32);backdrop-filter:blur(24px) saturate(130%);-webkit-backdrop-filter:blur(24px) saturate(130%)}.filter-btn{background:transparent;color:rgba(255,255,255,.86);border:1px solid transparent;outline:none;padding:.72rem 1.3rem;border-radius:999px;font-size:.98rem;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:transform .25s ease,color .25s ease,background .25s ease,box-shadow .25s ease;position:relative;overflow:hidden;white-space:nowrap}.filter-btn:after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(120deg,rgba(255,255,255,.24),transparent 45%,rgba(255,255,255,.12));opacity:0;transition:opacity .24s ease;pointer-events:none}.filter-btn:focus,.filter-btn:hover{color:#fff;background:rgba(255,255,255,.08);transform:translateY(-1px)}.filter-btn:focus:after,.filter-btn:hover:after{opacity:.9}.filter-btn.active{background:linear-gradient(160deg,rgba(255,255,255,.32),rgba(164,183,255,.17));color:#f6f8ff;border-color:rgba(255,255,255,.38);box-shadow:0 8px 22px rgba(65,85,160,.45),inset 0 1px 0 rgba(255,255,255,.45),inset 0 -3px 10px rgba(0,0,0,.22);transform:translateY(-1px)}.filter-btn.active:after{opacity:1}@media (max-width:900px){.projects-filter-bar{gap:.7rem;margin:1.2rem 0 0}.projects-filter-label{width:100%;text-align:center}.projects-filter-pill{max-width:100%}.filter-btn{font-size:.92rem;padding:.64rem 1rem}}@media (max-width:600px){.projects-filter-bar{flex-direction:column;gap:.55rem;margin:1rem 0 0}.projects-filter-pill{width:min(94vw,520px);justify-content:space-between;padding:.33rem}.filter-btn{flex:1 1;font-size:.82rem;padding:.62rem .7rem}}.projects-grid{transition:opacity .35s cubic-bezier(.4,0,.2,1)}.projects-grid>*{justify-self:center;width:100%;height:100%}