:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#007aff;text-decoration:none;transition:opacity .2s}a:hover{opacity:.8}body{margin:0;padding:0;display:block;width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#d2d2d7;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#86868b}:root{--primary-color: #1d1d1f;--secondary-color: #86868b;--background-color: #ffffff;--card-background: #f5f5f7;--accent-color: #007AFF;--accent-hover: #0056CC;--shadow-sm: 0 2px 10px rgba(0, 0, 0, .05);--shadow-md: 0 8px 25px rgba(0, 0, 0, .1);--shadow-lg: 0 16px 40px rgba(0, 0, 0, .12);--border-radius-sm: 12px;--border-radius-md: 18px;--border-radius-lg: 24px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}img,video{max-width:100%;height:auto}html,body{margin:0;padding:0;width:100%;min-height:100vh;overflow-x:hidden}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--background-color);color:var(--primary-color);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.App{display:flex;flex-direction:column;flex-grow:1;width:100%;min-height:100vh;background-color:var(--background-color)}.navbar{position:fixed;top:0;left:0;right:0;padding:1.5rem 0;z-index:1000;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.05);transition:var(--transition);width:100%}body.home-page .navbar{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:none}body.home-page .navbar .nav-logo,body.home-page .navbar button{color:#fff}body.home-page .navbar .nav-links{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}body.home-page .navbar button:hover{background:#ffffff26}.navbar.sticky{background:#fffffffa;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);padding:1rem 0;box-shadow:var(--shadow-md)}body.home-page .navbar.sticky{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.05)}body.home-page .navbar.sticky .nav-logo,body.home-page .navbar.sticky button{color:var(--primary-color)}body.home-page .navbar.sticky .nav-links{background:#00000008;border:1px solid rgba(0,0,0,.05)}body.home-page .navbar.sticky button:hover{background:#0000000d}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 2rem;width:100%}.nav-logo{font-size:2rem;font-weight:600;background:none;border:none;cursor:pointer;letter-spacing:-.5px;transition:var(--transition);color:var(--primary-color)}.nav-links{display:flex;gap:.5rem;border-radius:var(--border-radius-md);padding:.5rem;transition:var(--transition);background:#00000008;border:1px solid rgba(0,0,0,.05)}.navbar .hamburger-menu{display:none;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.hamburger-line{display:block;width:2rem;height:.25rem;background:var(--primary-color);border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}body.home-page .navbar:not(.sticky) .hamburger-line{background:#fff}.hamburger-menu.open .hamburger-line:first-child{transform:rotate(45deg)}.hamburger-menu.open .hamburger-line:nth-child(2){opacity:0}.hamburger-menu.open .hamburger-line:nth-child(3){transform:rotate(-45deg)}.navbar button{background:none;border:none;padding:.7rem 1.2rem;border-radius:var(--border-radius-sm);font-weight:500;font-size:.95rem;cursor:pointer;transition:var(--transition);white-space:nowrap;color:var(--primary-color)}.navbar button:hover{transform:translateY(-1px)}.slideshow-container{position:relative;width:100%;height:100vh;overflow:hidden}.slide{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:0;transition:opacity 1.2s ease-in-out;transform:scale(1)}.slide.active{opacity:1;transform:scale(1)}.slideshow-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,rgba(0,0,0,.4) 0%,transparent 40%,transparent 70%,rgba(0,0,0,.1) 100%)}.main-content{position:relative;z-index:10;flex-grow:1}body.content-page .main-content{padding-top:80px}body.home-page .main-content{margin-top:-4rem}.content-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;flex-direction:column;gap:2rem}.content-island{background:var(--background-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:3rem;transition:var(--transition);border:1px solid rgba(0,0,0,.05);position:relative;overflow:hidden;width:100%}.content-island:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.content-headline{font-weight:700;font-size:2rem;margin-bottom:1.5rem;line-height:1.3;color:#333;width:100%;word-break:break-word;overflow-wrap:break-word}.content-island.text-center{text-align:center}.content-island.text-center .text-content{max-width:800px;margin:0 auto}.content-split-layout{display:flex;align-items:center;gap:3rem;width:100%}.content-split-layout.left-image{flex-direction:row}.content-split-layout.right-image{flex-direction:row-reverse}.block-image-wrapper{flex:1;border-radius:var(--border-radius-md);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/3;height:300px;width:auto}.block-image-wrapper img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.content-island:hover .block-image-wrapper img{transform:scale(1.02)}.block-text-wrapper{flex:1;font-size:1.1rem;line-height:1.7;color:var(--primary-color)}.text-content{font-size:1.1rem;color:var(--primary-color);word-break:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.text-bold{font-weight:700;font-size:1.4rem}.text-verse{font-style:italic}.services-section{padding:6rem 0}.services-header{margin-bottom:5rem;max-width:800px}.section-subtitle{font-size:1.25rem;color:var(--secondary-color);margin-top:1rem;font-weight:400;line-height:1.5}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:0;border-top:1px solid rgba(0,0,0,.1)}.service-card-premium{padding:3.5rem 2.5rem;display:flex;flex-direction:column;position:relative;transition:background-color .4s ease;border-right:1px solid rgba(0,0,0,.1);border-bottom:1px solid rgba(0,0,0,.1);min-height:400px}.service-card-premium:last-child{border-right:none}.service-card-premium:hover{background-color:#fcfcfd}.service-number{font-size:.85rem;font-weight:600;color:var(--secondary-color);margin-bottom:3rem;opacity:.5;letter-spacing:.1em}.service-icon-premium{color:var(--primary-color);margin-bottom:2rem;transition:transform .4s cubic-bezier(.16,1,.3,1)}.service-card-premium:hover .service-icon-premium{transform:translateY(-5px);color:var(--accent-color)}.service-card-premium h3{font-size:1.75rem;font-weight:600;margin-bottom:1.5rem;letter-spacing:-.03em;color:var(--primary-color)}.service-card-premium p{font-size:1.05rem;line-height:1.6;color:var(--secondary-color);margin-bottom:3rem;flex-grow:1}.service-link-premium{display:inline-flex;align-items:center;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;color:var(--primary-color);background:none;border:none;padding:0;cursor:pointer;position:relative;width:max-content;transition:color .3s ease}.service-link-premium:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:1.5px;background-color:var(--accent-color);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}.service-card-premium:hover .service-link-premium{color:var(--accent-color)}.service-card-premium:hover .service-link-premium:after{transform:scaleX(1)}@media(max-width:900px){.services-grid{grid-template-columns:1fr}.service-card-premium{border-right:none;min-height:auto;padding:3rem 1.5rem}}.coming-soon-container{min-height:80vh;display:flex;justify-content:center;align-items:center;padding:4rem 2rem;background:radial-gradient(circle at center,#fff,#f5f5f7);position:relative;overflow:hidden}.coming-soon-container:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}.coming-soon-content{background:#fffc;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.5);border-radius:32px;padding:5rem 3rem;text-align:center;max-width:720px;width:100%;box-shadow:0 20px 50px #0000000d,0 0 0 1px #00000005;z-index:1;animation:contentFadeIn .8s cubic-bezier(.16,1,.3,1)}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.coming-soon-badge{display:inline-block;padding:.5rem 1.25rem;background:var(--accent-color);color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;border-radius:999px;margin-bottom:2rem;box-shadow:0 4px 12px #007aff33}.coming-soon-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;line-height:1.1;letter-spacing:-.04em;margin-bottom:1.5rem;color:var(--primary-color)}.coming-soon-text{font-size:1.15rem;line-height:1.7;color:var(--secondary-color);margin-bottom:3rem;max-width:500px;margin-left:auto;margin-right:auto}.back-home-btn{display:inline-flex;align-items:center;gap:.75rem;background:var(--primary-color);color:#fff;border:none;padding:1rem 2.5rem;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 10px 20px #0000001a}.back-home-btn:hover{transform:translateY(-2px);box-shadow:0 15px 30px #00000026;background:#000}.back-home-btn svg{transition:transform .3s ease}.back-home-btn:hover svg{transform:translate(4px)}.footer{background:var(--primary-color);color:#fff;padding:4rem 0 2rem;margin-top:auto;width:100%}.footer-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,250px),1fr));gap:3rem;width:100%}.footer-section h3{font-size:1.3rem;font-weight:600;margin-bottom:1.5rem;color:#fff}.footer-section ul{list-style:none}.footer-section li{margin-bottom:.8rem}.footer-section button{color:#86868b;background:none;border:none;cursor:pointer;font-size:1rem;padding:0;transition:var(--transition);text-align:left}.footer-section button:hover{color:#fff;transform:translate(4px)}.footer-section p{color:#86868b;line-height:1.6;font-size:1rem}.social-links{display:flex;flex-direction:column;gap:1rem}.social-link{display:flex;align-items:center;gap:.8rem;padding:.8rem 1.2rem;background:#ffffff0d;border-radius:var(--border-radius-sm);transition:var(--transition);color:#86868b;text-decoration:none;border:1px solid rgba(255,255,255,.05)}.social-link:hover{background:#ffffff1a;transform:translate(4px);color:#fff}.footer-bottom{max-width:1200px;margin:3rem auto 0;padding:2rem 2rem 0;border-top:1px solid rgba(255,255,255,.1);text-align:center;width:100%}.copyright{color:#86868b;font-size:.9rem}@media(max-width:1024px){.nav-container,.content-container,.footer-content{padding:0 1.5rem;width:100%}.content-island{padding:2.5rem}body.home-page .main-content{margin-top:-100px}}@media(max-width:768px){.navbar{padding:1rem 0}.nav-container{flex-direction:row;justify-content:space-between;align-items:center;padding:0 1.25rem}.nav-logo{font-size:1.1rem;text-align:left}.text-bold{font-size:1.1rem}.navbar .hamburger-menu{display:flex}.nav-links{position:absolute;top:100%;left:0;width:100%;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;align-items:center;padding:1.5rem 0;border-radius:var(--border-radius-md);box-shadow:var(--shadow-md);transform:translateY(-150%);opacity:0;transition:all .4s ease-in-out;pointer-events:none;border-top:1px solid rgba(0,0,0,.05)}.nav-links.mobile-open{transform:translateY(0);opacity:1;pointer-events:auto}body.home-page .navbar:not(.sticky) .nav-links{border:none}body.home-page .navbar:not(.sticky) .nav-links button{color:#fff}.navbar button{width:90%;margin:.25rem 0;padding:1rem;font-size:1.1rem}.main-content{padding-top:0}body.content-page .main-content{padding-top:70px}body.home-page .main-content{margin-top:-80px}.content-container{padding:0 1rem;gap:1.5rem}.content-island{padding:2rem 1.5rem;border-radius:var(--border-radius-md)}.content-headline{font-size:1.7rem;margin-bottom:1.5rem}.content-split-layout,.content-split-layout.left-image,.content-split-layout.right-image{flex-direction:column;gap:1.5rem}.block-image-wrapper{width:100%;aspect-ratio:16/9}.block-text-wrapper{width:100%;word-break:break-word;overflow-wrap:break-word}.section-title{font-size:2.2rem;margin-bottom:2rem}.services-grid{grid-template-columns:1fr;gap:1.5rem}.footer-content{grid-template-columns:1fr;gap:2rem;padding:0 1rem;text-align:center}.footer-section button{text-align:center;width:100%}.social-links{align-items:center}}@media(max-width:480px){.navbar button{font-size:.85rem;padding:.5rem .8rem}.nav-logo{font-size:.95rem;text-align:left}.section-title{font-size:1.8rem}.content-island{padding:1.5rem 1rem}body.home-page .main-content{margin-top:-60px}}:root{--pg-bg-page: #f5f5f7;--pg-bg-card: #ffffff;--pg-bg-soft: #f2f2f7;--pg-accent: #0071e3;--pg-accent-soft: rgba(0, 113, 227, .12);--pg-text-primary: #1d1d1f;--pg-text-secondary: #6e6e73;--pg-border-subtle: rgba(0, 0, 0, .06);--pg-radius-xl: 28px;--pg-radius-lg: 24px;--pg-radius-md: 16px;--pg-radius-pill: 999px;--pg-shadow-soft: 0 18px 45px rgba(0, 0, 0, .12);--pg-shadow-card: 0 16px 30px rgba(0, 0, 0, .08);--pg-shadow-hover: 0 24px 45px rgba(0, 0, 0, .16);--pg-transition-fast: .25s ease-out;--pg-transition-med: .4s cubic-bezier(.19, 1, .22, 1);--pg-font-sans: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Arial, sans-serif}.project-grid-page{min-height:calc(100vh - 80px);padding:4rem 2rem 0;position:relative;font-family:var(--pg-font-sans);color:var(--pg-text-primary);background:radial-gradient(circle at top left,#fff 0,#f5f5f7 40%,#e9ecf5)}.page-header{text-align:center;margin:0 auto 4rem;max-width:900px}.page-title{font-size:clamp(3.1rem,4vw,3.8rem);font-weight:700;letter-spacing:-.045em;line-height:1.05;margin-bottom:1rem;background:linear-gradient(135deg,#111,#3a3a3c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{font-size:1.1rem;color:var(--secondary-color);font-weight:400;max-width:640px;margin:0 auto;line-height:1.6}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr));gap:2rem;max-width:1240px;margin:0 auto;padding:0 .5rem}.project-card{background:#fffffff5;border-radius:24px;overflow:hidden;cursor:pointer;border:1px solid rgba(255,255,255,.7);box-shadow:0 0 0 1px #00000005,0 14px 35px #0f0f0f1f;transition:transform var(--pg-transition-med),box-shadow var(--pg-transition-med),border-color .25s ease,background .25s ease;position:relative;animation:fadeInUp .6s ease-out backwards}.project-card:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.7),transparent 40%);opacity:0;transition:opacity .35s ease-out;pointer-events:none}.project-card:hover{transform:translateY(-10px) scale(1.01);box-shadow:var(--pg-shadow-hover);border-color:#fffffff2;background:#fffffffa}.project-card:hover:before{opacity:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.project-image{position:relative;width:100%;height:260px;overflow:hidden;background:linear-gradient(135deg,#d2d2dc,#f2f2f7)}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.19,1,.22,1)}.project-card:hover .project-image img{transform:scale(1.06)}.image-placeholder{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:flex-start;padding:2rem 2.1rem;color:#f5f5f7;font-size:1.4rem;font-weight:600;letter-spacing:-.03em;background:radial-gradient(circle at top left,#5856d6,#0071e3 50%,#5e5ce6);position:relative;overflow:hidden}.image-placeholder:before{content:"";position:absolute;inset:-60%;background:conic-gradient(from 220deg,transparent 10%,rgba(255,255,255,.24) 18%,transparent 26%);animation:shimmer 4.2s linear infinite;mix-blend-mode:screen}@keyframes shimmer{0%{transform:translate(-10%) rotate(0)}to{transform:translate(10%) rotate(360deg)}}.image-placeholder.large{font-size:1.9rem;min-height:420px;padding:2.4rem;align-items:center;justify-content:center}.project-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0000 20%,#000000c7);display:flex;align-items:flex-end;padding:2.1rem 2.3rem;opacity:0;transition:opacity var(--pg-transition-med)}.project-card:hover .project-overlay{opacity:1}.project-info h3{color:#fff;font-size:1.4rem;font-weight:600;margin-bottom:.6rem;letter-spacing:-.03em}.project-info p{color:#ffffffd9;font-size:.98rem;margin-bottom:1rem;line-height:1.5}.view-project{color:#fff;font-weight:500;font-size:.95rem;opacity:0;transform:translate(-6px);transition:all .35s ease;display:inline-flex;align-items:center;gap:.4rem}.project-card:hover .view-project{opacity:1;transform:translate(0)}.project-modal-overlay{position:fixed;inset:0;z-index:2000;display:flex;justify-content:center;align-items:center;padding:2rem;animation:fadeIn .22s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.modal-backdrop{position:absolute;inset:0;background:#00000073;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}.floating-island-wrapper{position:relative;z-index:2001;display:inline-flex;flex-direction:column;align-items:center}.floating-island{position:relative;background:#fffffff0;backdrop-filter:blur(40px) saturate(220%);-webkit-backdrop-filter:blur(40px) saturate(220%);border-radius:var(--pg-radius-xl);max-width:1000px;width:min(1000px,94vw);height:min(720px,80vh);max-height:80vh;overflow:hidden;box-shadow:0 30px 70px #0000004d,0 0 0 1px #ffffffe6,inset 0 1px #ffffffe6;animation:islandAppear .4s cubic-bezier(.19,1,.22,1);display:flex;flex-direction:column}@keyframes islandAppear{0%{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.island-content{display:grid;grid-template-columns:1.05fr 1.1fr;flex:1;min-height:0}.modal-images{background:#f5f5f7f5;padding:1.5rem;display:flex;flex-direction:column;border-right:1px solid rgba(0,0,0,.04);height:100%;overflow:hidden}.main-image{position:relative;flex:1;border-radius:22px;overflow:hidden;background:#fff;box-shadow:0 10px 25px #00000014,0 0 0 1px #00000008;display:flex;align-items:center;justify-content:center}.main-image img{width:100%;height:100%;object-fit:cover}.nav-button{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:var(--pg-radius-pill);border:1px solid rgba(255,255,255,.4);background:#ffffffb3;backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);box-shadow:0 8px 24px #0000001f,0 0 0 1px #00000005;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#1d1d1f;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:10}.nav-button.prev{left:1rem}.nav-button.next{right:1rem}.nav-button:hover{background:#fffffff2;transform:translateY(-50%) scale(1.1);box-shadow:0 12px 32px #0003,0 0 0 1px #0000000d}.nav-button:active{transform:translateY(-50%) scale(.92)}.nav-button svg{width:48px;height:48px;stroke-width:5px}.image-counter{position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%);padding:.4rem 1rem;border-radius:var(--pg-radius-pill);background:#00000040;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fffffff2;font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(255,255,255,.1);pointer-events:none}.modal-info-scroll{height:100%;overflow-y:auto;overflow-x:hidden;background:#fffffffa}.modal-info{padding:2.2rem 2.4rem 2rem;box-sizing:border-box}.modal-info h2{font-size:2.1rem;font-weight:700;margin-bottom:1.3rem;letter-spacing:-.045em;background:linear-gradient(135deg,#111,#2c2c2e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.project-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1.1rem;margin-bottom:1.6rem;padding-bottom:1.6rem;border-bottom:1px solid rgba(0,0,0,.06)}.meta-item strong{text-transform:uppercase;font-size:.7rem;letter-spacing:.14em;color:#86868b;display:block;margin-bottom:.15rem}.meta-item span{font-size:1rem;font-weight:600;color:#1d1d1f}.project-description{font-size:.98rem;line-height:1.7;color:var(--secondary-color);margin-bottom:1.8rem}.project-features{margin-bottom:1.8rem}.project-features h4{font-size:.95rem;text-transform:uppercase;letter-spacing:.13em;color:#86868b;margin-bottom:.7rem}.project-features ul{list-style:none;margin:0;padding:0}.project-features li{position:relative;padding-left:1.2rem;margin-bottom:.4rem;font-size:.96rem;color:var(--pg-text-primary)}.project-features li:before{content:"•";position:absolute;left:0;top:0;color:var(--pg-accent)}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem}.tag{padding:.25rem .7rem;border-radius:var(--pg-radius-pill);font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;background:var(--pg-accent-soft);color:var(--pg-accent)}.floating-close-button{position:absolute;bottom:-60px;left:50%;transform:translate(-50%);border:none;border-radius:var(--pg-radius-pill);background:#fffffffa;backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1d1d1f;font-size:.95rem;font-weight:500;box-shadow:0 10px 30px #0000002e,0 0 0 1px #0000000f;transition:transform .22s ease,box-shadow .22s ease,background .22s ease}.floating-close-button:hover{background:#fff;transform:translate(-50%) translateY(-2px);box-shadow:0 18px 40px #0000003d,0 0 0 1px #00000017}.floating-close-button:active{transform:translate(-50%) translateY(0) scale(.97)}@media(max-width:900px){.project-grid-page{padding:5.5rem 1.5rem 3.5rem}.project-modal-overlay{padding:1rem}.floating-island{width:min(1000px,96vw);height:auto;max-height:85vh}.island-content{grid-template-columns:1fr;overflow-y:auto}.modal-images{border-right:none;border-bottom:1px solid rgba(0,0,0,.04);height:350px;flex:none}}@media(max-width:600px){.project-grid-page{padding:5rem 1.2rem 3rem}.page-title{font-size:2.3rem}.projects-grid{grid-template-columns:1fr}.project-modal-overlay{padding:.5rem}.floating-island{width:100%;height:auto;max-height:90vh;border-radius:20px}.modal-info{padding:1.7rem 1.5rem 1.5rem}.modal-info h2{font-size:1.7rem}}.ribbon-gallery{width:100%;overflow:hidden;padding:6rem 0;display:flex;flex-direction:column;gap:1.5rem;background-color:transparent;z-index:5}.ribbon-row{width:100%;overflow:hidden;display:flex}.ribbon-track{display:flex;gap:1.5rem;width:max-content;animation:marquee 120s linear infinite}.ribbon-row-1 .ribbon-track{animation-duration:100s}.ribbon-row-2 .ribbon-track{animation-duration:130s;animation-direction:reverse;margin-left:-200px}.ribbon-row-3 .ribbon-track{animation-duration:110s;margin-left:-100px}.ribbon-item{flex:0 0 auto;width:350px;height:250px;border-radius:var(--border-radius-md);overflow:hidden;background:var(--card-background);box-shadow:var(--shadow-sm);transition:transform .5s cubic-bezier(.4,0,.2,1)}.ribbon-item:hover{transform:scale(1.05);z-index:10;box-shadow:var(--shadow-md)}.ribbon-item img{width:100%;height:100%;object-fit:cover}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(max-width:768px){.ribbon-gallery{padding:3rem 0;gap:1rem}.ribbon-item{width:250px;height:180px}}
