.home-page{min-height:100vh;position:relative}.home-hero{justify-content:center;align-items:center;min-height:100vh;padding:8rem 2rem 4rem;display:flex}.home-content{grid-template-columns:1fr 1.5fr;align-items:start;gap:5rem;width:100%;max-width:1200px;display:grid}.home-left-column{flex-direction:column;align-items:center;gap:2rem;display:flex}.home-image-container{justify-content:center;width:100%;display:flex}.home-profile-image{aspect-ratio:1;border-radius:var(--radius);width:100%;max-width:400px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.04),0 8px 32px rgba(0,0,0,.06)}.home-profile-image img{object-fit:cover;object-position:center 0%;filter:brightness(1.15)contrast(1.05);width:100%;height:100%}.home-text-content{flex-direction:column;gap:2rem;padding-top:3rem;display:flex}.home-title{letter-spacing:-.03em;color:var(--foreground);text-align:center;margin:0;font-size:max(2.5rem,min(5vw,3.5rem));font-weight:600;line-height:1.1}.home-blurb{flex-direction:column;gap:1.5rem;display:flex}.home-blurb p{color:var(--foreground);opacity:.8;margin:0;font-size:1.125rem;line-height:1.7}.home-cta{justify-content:center;gap:1rem;margin-top:0;display:flex}.cta-button{border-radius:calc(var(--radius)*.5);letter-spacing:-.01em;justify-content:center;align-items:center;padding:.875rem 2rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.cta-button.primary{color:#fff;background:#c00014;box-shadow:0 2px 4px rgba(192,0,20,.2),0 4px 12px rgba(192,0,20,.15)}.cta-button.primary:hover{background:#a00011;transform:translateY(-2px);box-shadow:0 4px 8px rgba(192,0,20,.3),0 8px 24px rgba(192,0,20,.25)}.cta-button.secondary{color:var(--foreground);border:1.5px solid var(--border-subtle);background:0 0}.cta-button.secondary:hover{border-color:var(--foreground);background:rgba(0,0,0,.03)}@media (prefers-color-scheme:dark){.cta-button.secondary:hover{background:rgba(255,255,255,.05)}}@media (max-width:900px){.home-content{grid-template-columns:1fr;gap:3rem}.home-left-column{order:-1}.home-profile-image{max-width:300px}.home-text-content{text-align:center;align-items:center;padding-top:0}.home-cta{justify-content:center}}@media (max-width:640px){.home-hero{padding:6rem 1.5rem 3rem}.home-left-column{gap:1.5rem}.home-profile-image{max-width:250px}.home-blurb p{font-size:1rem}.home-cta{flex-direction:column;width:100%;max-width:300px}.cta-button{width:100%}}.home-section{padding:max(5rem,min(10vh,8rem)) 2rem}.home-container{max-width:1200px;margin:0 auto}.home-section-title{letter-spacing:-.03em;color:var(--foreground);text-align:center;margin-bottom:2rem;font-size:max(2.5rem,min(5vw,3rem));font-weight:600;line-height:1.1}.home-section-intro{color:var(--foreground);opacity:.75;text-align:center;max-width:800px;margin:0 auto 3rem;font-size:1.125rem;line-height:1.7}.home-about{background:linear-gradient(transparent,rgba(0,0,0,.01),transparent)}@media (prefers-color-scheme:dark){.home-about{background:linear-gradient(transparent,rgba(255,255,255,.02),transparent)}}.home-about-content{max-width:900px;margin:0 auto}.home-about-text{flex-direction:column;gap:1.5rem;display:flex}.home-about-text p{color:var(--foreground);opacity:.8;margin:0;font-size:1.125rem;line-height:1.8}.home-timeline{background:var(--background);overflow-x:hidden}.home-timeline-horizontal{scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.1) transparent;align-items:flex-start;gap:max(2rem,min(5vw,4rem));padding:3rem 0;display:flex;position:relative;overflow-x:auto;overflow-y:visible}.home-timeline-horizontal::-webkit-scrollbar{height:6px}.home-timeline-horizontal::-webkit-scrollbar-track{background:0 0}.home-timeline-horizontal::-webkit-scrollbar-thumb{background:rgba(0,0,0,.1);border-radius:3px}@media (prefers-color-scheme:dark){.home-timeline-horizontal::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1)}.home-timeline-horizontal{scrollbar-color:rgba(255,255,255,.1) transparent}}.home-timeline-line{z-index:0;background:linear-gradient(90deg,transparent,rgba(0,0,0,.1) 10%,rgba(0,0,0,.1) 90%,transparent);height:2px;position:absolute;top:60px;left:0;right:0}@media (prefers-color-scheme:dark){.home-timeline-line{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1) 10%,rgba(255,255,255,.1) 90%,transparent)}}.home-timeline-item-horizontal{text-align:center;scroll-snap-align:center;z-index:1;flex-direction:column;flex:none;align-items:center;min-width:max(160px,min(20vw,200px));display:flex;position:relative}.home-timeline-dot{background:var(--foreground);border:3px solid var(--background);width:16px;height:16px;box-shadow:0 0 0 2px var(--foreground);z-index:2;border-radius:50%;flex-shrink:0;margin-bottom:1.5rem;position:relative}.home-timeline-content-horizontal{flex-direction:column;gap:.5rem;display:flex}.home-timeline-date{letter-spacing:.02em;color:var(--foreground);opacity:.6;font-size:.875rem;font-weight:600}.home-timeline-title-horizontal{letter-spacing:-.01em;color:var(--foreground);margin:0;font-size:1.125rem;font-weight:600;line-height:1.3}.home-timeline-description-horizontal{color:var(--foreground);opacity:.7;margin:0;font-size:.9375rem;line-height:1.6}@media (max-width:768px){.home-timeline-horizontal{gap:2rem;padding:2.5rem 0}.home-timeline-item-horizontal{min-width:140px}.home-timeline-line{top:50px}.home-timeline-dot{width:14px;height:14px;margin-bottom:1.25rem}.home-timeline-date{font-size:.8125rem}.home-timeline-title-horizontal{font-size:1rem}.home-timeline-description-horizontal{font-size:.875rem}}.home-development{background:linear-gradient(transparent,rgba(0,0,0,.016),transparent);position:relative;overflow:hidden}@media (prefers-color-scheme:dark){.home-development{background:linear-gradient(transparent,rgba(255,255,255,.024),transparent)}}.dev-header{text-align:center;margin-bottom:3rem}.dev-subtitle{color:#c00014;opacity:.85;margin-top:.25rem;font-size:1.125rem;font-weight:400}.dev-journey{grid-template-columns:1.5fr 1fr;align-items:start;gap:4rem;max-width:1200px;margin-bottom:5rem;margin-left:auto;margin-right:auto;display:grid}.dev-journey-content{flex-direction:column;gap:1.5rem;display:flex}.dev-journey-label{text-transform:uppercase;letter-spacing:.1em;color:var(--foreground);opacity:.5;font-size:.875rem;font-weight:600}.dev-journey-title{letter-spacing:-.02em;color:var(--foreground);margin:0;font-size:2rem;font-weight:600;line-height:1.2}.dev-journey-text{color:var(--foreground);opacity:.8;margin:0;font-size:1.0625rem;line-height:1.8}.dev-timeline{border:1px solid var(--border-subtle);background:linear-gradient(135deg,rgba(0,0,0,.02),rgba(0,0,0,.01));border-radius:20px;flex-direction:column;gap:1.25rem;padding:1.75rem 2rem 1.75rem 2.5rem;display:flex;position:relative}@media (prefers-color-scheme:dark){.dev-timeline{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}}.dev-timeline:before{content:"";background:rgba(0,0,0,.12);width:2px;position:absolute;top:2rem;bottom:2rem;left:calc(1.5rem + 4px)}@media (prefers-color-scheme:dark){.dev-timeline:before{background:rgba(255,255,255,.15)}}.dev-timeline-item{grid-template-rows:auto auto;grid-template-columns:auto 1fr;align-items:start;gap:.75rem 1.25rem;display:grid;position:relative}.dev-timeline-dot{z-index:2;width:10px;height:10px;box-shadow:0 0 0 3px var(--background);background:#c00014;border-radius:50%;position:absolute;top:.5rem;left:-1rem}.dev-timeline-date{color:var(--foreground);opacity:.45;text-transform:uppercase;letter-spacing:.05em;grid-area:1/2;margin-bottom:-.25rem;font-size:.8125rem;font-weight:700}.dev-timeline-event{color:var(--foreground);opacity:.9;grid-area:2/2;font-size:1.0625rem;font-weight:500;line-height:1.4}.dev-tech-stack{max-width:1200px;margin-bottom:5rem;margin-left:auto;margin-right:auto}.dev-section-heading{letter-spacing:-.02em;color:var(--foreground);text-align:center;margin-bottom:2rem;font-size:1.75rem;font-weight:600}.dev-tech-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;max-width:900px;margin:0 auto;display:grid}.dev-tech-badge{border:1px solid var(--border-subtle);background:linear-gradient(135deg,rgba(0,0,0,.02),rgba(0,0,0,.01));border-radius:12px;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;transition:all .3s;display:flex}@media (prefers-color-scheme:dark){.dev-tech-badge{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}}.dev-tech-badge:hover{border-color:rgba(0,0,0,.12);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.06)}@media (prefers-color-scheme:dark){.dev-tech-badge:hover{border-color:rgba(255,255,255,.15);box-shadow:0 8px 24px rgba(0,0,0,.2)}}.dev-tech-name{color:var(--foreground);text-align:center;font-size:.9375rem;font-weight:600}.dev-tech-category{color:var(--foreground);opacity:.5;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.dev-projects{max-width:1200px;margin-bottom:5rem;margin-left:auto;margin-right:auto}.dev-projects-grid{grid-template-columns:repeat(auto-fit,minmax(min(340px,100%),1fr));gap:2rem;display:grid}.dev-project-card{border:1px solid var(--border-subtle);background:linear-gradient(135deg,rgba(0,0,0,.02),rgba(0,0,0,.01));border-radius:20px;padding:2rem;transition:all .4s;position:relative;overflow:hidden}@media (prefers-color-scheme:dark){.dev-project-card{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}}.dev-project-card:hover{border-color:rgba(0,0,0,.15);transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.12)}@media (prefers-color-scheme:dark){.dev-project-card:hover{border-color:rgba(255,255,255,.2);box-shadow:0 16px 48px rgba(0,0,0,.4)}}.dev-project-link{color:inherit;flex-direction:column;gap:1.5rem;height:100%;text-decoration:none;display:flex}.dev-project-header{align-items:flex-start;gap:1rem;display:flex}.dev-project-icon{opacity:.8;border-radius:12px;flex-shrink:0;width:48px;height:48px;transition:opacity .3s}.dev-project-card:hover .dev-project-icon{opacity:1}.dev-project-name{letter-spacing:-.02em;color:var(--foreground);margin:0;font-size:1.5rem;font-weight:600;line-height:1.3}.dev-project-tagline{color:var(--foreground);opacity:.6;margin:.25rem 0 0;font-size:.875rem;line-height:1.4}.dev-project-description{color:var(--foreground);opacity:.8;flex:1;margin:0;font-size:1rem;line-height:1.7}.dev-project-highlights{flex-wrap:wrap;gap:.625rem;display:flex}.dev-project-highlight{color:var(--foreground);opacity:.7;background:rgba(0,0,0,.04);border-radius:6px;padding:.375rem .875rem;font-size:.8125rem;font-weight:500;display:inline-block}@media (prefers-color-scheme:dark){.dev-project-highlight{background:rgba(255,255,255,.08)}}.dev-project-arrow{color:var(--foreground);opacity:.6;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;transition:all .3s;display:flex}.dev-project-card:hover .dev-project-arrow{opacity:1;gap:.75rem}.dev-project-arrow svg{transition:transform .3s}.dev-project-card:hover .dev-project-arrow svg{transform:translate(3px)}.dev-stats-footer{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;max-width:1000px;margin:0 auto;display:grid}.dev-stat-card{text-align:center;border:1px solid var(--border-subtle);background:linear-gradient(135deg,rgba(0,0,0,.02),rgba(0,0,0,.01));border-radius:16px;padding:2.5rem 2rem;transition:all .3s}@media (prefers-color-scheme:dark){.dev-stat-card{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}}.dev-stat-card:hover{border-color:rgba(0,0,0,.12);transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}@media (prefers-color-scheme:dark){.dev-stat-card:hover{border-color:rgba(255,255,255,.15);box-shadow:0 12px 32px rgba(0,0,0,.3)}}.dev-stat-number{letter-spacing:-.03em;color:var(--foreground);margin-bottom:.75rem;font-size:3rem;font-weight:700;line-height:1}.dev-stat-label{color:var(--foreground);opacity:.6;font-size:.9375rem;font-weight:500;line-height:1.4}@media (max-width:900px){.dev-journey{grid-template-columns:1fr;gap:3rem}.dev-journey-title{font-size:1.75rem}.dev-timeline{gap:1rem;padding:1.5rem 1.5rem 1.5rem 2rem}.dev-timeline:before{top:1.75rem;bottom:1.75rem;left:calc(1.25rem + 4px)}.dev-timeline-dot{left:-.75rem}.dev-tech-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.dev-projects-grid{grid-template-columns:1fr}.dev-stats-footer{grid-template-columns:repeat(2,1fr)}.dev-stat-number{font-size:2.5rem}}@media (max-width:640px){.dev-tech-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem}.dev-tech-badge{padding:1rem .75rem}.dev-stats-footer{grid-template-columns:1fr;gap:1.5rem}.dev-stat-card{padding:2rem 1.5rem}}.home-service{background:var(--background)}.service-header{text-align:center;margin-bottom:3rem}.service-subtitle{color:#c00014;opacity:.85;margin-top:.25rem;font-size:1.125rem;font-weight:400}.service-story{grid-template-columns:1fr 1.5fr;align-items:start;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.service-image-container{position:-webkit-sticky;position:sticky;top:2rem}.service-image-placeholder{aspect-ratio:4/5;border:1px solid var(--border-subtle);background:linear-gradient(135deg,rgba(0,0,0,.02),rgba(0,0,0,.01));border-radius:20px;justify-content:center;align-items:center;width:100%;max-height:450px;display:flex;overflow:hidden}@media (prefers-color-scheme:dark){.service-image-placeholder{background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02))}}.placeholder-text{color:var(--foreground);opacity:.3;text-transform:uppercase;letter-spacing:.1em;font-size:1rem;font-weight:500}.service-image{object-fit:cover;object-position:right center;width:100%;height:100%;display:block}.service-content{flex-direction:column;gap:1.5rem;display:flex}.service-label{text-transform:uppercase;letter-spacing:.1em;color:var(--foreground);opacity:.5;font-size:.875rem;font-weight:600}.service-title{letter-spacing:-.02em;color:var(--foreground);margin:0;font-size:2rem;font-weight:600;line-height:1.2}.service-text{color:var(--foreground);opacity:.8;margin:0;font-size:1.0625rem;line-height:1.8}@media (max-width:900px){.service-story{grid-template-columns:1fr;gap:3rem}.service-image-container{position:relative;top:0}.service-image-placeholder{max-width:400px;margin:0 auto}.service-title{font-size:1.75rem}}@media (max-width:768px){.home-section{padding:max(4rem,min(8vh,6rem)) 1.5rem}}
