*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#ece8df;--bg-card:#f5f2ec;--black:#2d2820;--gray-dark:#4a453e;--gray:#605b56;--gray-light:#dedad1;--white:#fff;--accent:#b33000;--accent-hover:#8f2600;--accent-soft:#b3300014;--accent-on-dark:#ff5218;--green:#34c759;--green-soft:#34c7591a;--serif:var(--font-fraunces);--radius:4px;--shadow-soft:0 4px 24px #0000000f;--shadow-medium:0 8px 32px #00000014;--shadow-strong:0 16px 48px #0000001f;--container-max:1120px;--safe-bottom:env(safe-area-inset-bottom,20px)}html{scroll-behavior:smooth;scroll-padding-top:72px}body{font-family:var(--font-inter);color:var(--black);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;&.no-scroll{touch-action:none;overflow:hidden}}::selection{background:var(--accent);color:var(--white)}img{max-width:100%;height:auto;display:block}a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}.skip-link{background:var(--accent);color:var(--white);z-index:10000;padding:8px 16px;font-weight:500;text-decoration:none;transition:transform .2s;position:fixed;top:0;left:0;transform:translateY(-100%);&:focus{transform:translateY(0)}}.page-wrap{flex-direction:column;min-height:100vh;display:flex}main{flex:1}.container{max-width:var(--container-max);margin:0 auto;padding:0 24px}header{z-index:1002;-webkit-backdrop-filter:saturate(180%)blur(20px);background:#ffffffd9;border-bottom:1px solid #00000014;position:sticky;top:0;& nav{max-width:var(--container-max);justify-content:space-between;align-items:center;height:56px;margin:0 auto;padding:0 24px;display:flex}}.logo{color:var(--black);letter-spacing:-.02em;font-size:1.125rem;font-weight:700;text-decoration:none;& span{color:var(--accent)}&:hover{text-decoration:none}}.back-btn{color:var(--gray-dark);align-items:center;gap:6px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex;& svg{width:16px;height:16px}&:hover{color:var(--accent);text-decoration:none}}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:15px 28px;font-size:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex;& svg{width:16px;height:16px}}.btn-primary{background:var(--accent);color:var(--white);box-shadow:0 4px 14px #0071e34d;&:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 20px #0071e366}}.btn-secondary{color:var(--black);background:0 0;border:1px solid #d2d2d7;&:hover{border-color:var(--black)}}footer{background:var(--black);color:var(--white);padding:56px 24px 32px}.footer-grid{max-width:var(--container-max);grid-template-columns:1fr 1fr;gap:40px;margin:0 auto;display:grid;@media (width<=1024px){grid-template-columns:1fr;gap:32px}}.footer-brand{margin-bottom:12px;font-size:1.125rem;font-weight:700;& span{color:var(--accent-on-dark)}}.footer-desc{color:#fff9;margin-bottom:16px;font-size:.9375rem}.footer-contact{& a{color:var(--white);margin-bottom:4px;font-size:.9375rem;text-decoration:none;display:block;&:hover{color:var(--accent)}}}.footer-legal{text-align:right;color:#ffffff80;font-size:.8125rem;line-height:1.7;@media (width<=1024px){text-align:left}}.footer-bottom{max-width:var(--container-max);color:#ffffff80;border-top:1px solid #ffffff1a;align-items:center;margin:40px auto 0;padding-top:24px;font-size:.8125rem;display:flex;& a{color:inherit;text-decoration:none;transition:color .2s;&:hover{color:var(--accent-on-dark)}}}.footer-separator{opacity:.5;margin:0 12px}.reveal{transition:opacity .7s,transform .7s}.js-loaded .reveal{opacity:0;transform:translateY(24px)}.js-loaded .reveal.active{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.contact{background:var(--gray-light);padding:100px 0;@media (width<=768px){padding:64px 0}}.contact-wrapper{text-align:center;max-width:640px;margin:0 auto;& h2{color:var(--black);margin-bottom:14px;font-size:2rem;font-weight:700}}.contact-intro{color:var(--gray);margin-bottom:48px;font-size:1.0625rem;line-height:1.6}.contact-cards{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:48px;display:grid;@media (width<=768px){grid-template-columns:1fr}}.contact-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:32px 24px;text-decoration:none;transition:transform .3s,box-shadow .3s;&:hover{box-shadow:var(--shadow-medium);transform:translateY(-4px)}}.contact-card-icon{background:var(--accent-soft);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex;& svg{width:24px;height:24px;stroke:var(--accent)}}.contact-card-label{color:var(--gray);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-size:.75rem;font-weight:600}.contact-card-value{color:var(--black);font-size:1.125rem;font-weight:600}@media (hover:none){.contact-card:active{transform:scale(.98)}}section{padding:100px 0;@media (width<=768px){padding:64px 0}}.nav-links{align-items:center;gap:28px;list-style:none;display:flex;& a{color:var(--gray-dark);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s;&:hover{color:var(--accent)}}@media (width<=768px){display:none}}.nav-cta{background:var(--black);border-radius:var(--radius);padding:9px 18px;color:var(--white)!important;transition:background .2s!important;&:hover{background:var(--accent)!important}}.mobile-toggle{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:44px;height:44px;padding:8px;display:none;& span{background:var(--black);border-radius:2px;width:18px;height:2px;margin:2px 0;transition:transform .3s,opacity .3s;display:block}&.active{& span:first-child{transform:translateY(6px)rotate(45deg)}& span:nth-child(2){opacity:0}& span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}}@media (width<=768px){flex-direction:column;display:flex}}.mobile-menu{background:var(--bg);z-index:1001;padding:80px 24px 24px;display:none;position:fixed;inset:0;overflow-y:auto;&.active{display:block}& ul{list-style:none}& a{color:var(--black);border-bottom:1px solid var(--gray-light);padding:16px 0;font-size:1.125rem;font-weight:500;text-decoration:none;display:block;&:hover,&:focus{color:var(--accent)}}}.hero{padding:100px 0 80px;& h1{font-family:var(--serif);font-variation-settings:"opsz" clamp(36, 5.25vw, 66), "SOFT" 30;letter-spacing:-.02em;color:var(--black);margin-bottom:24px;font-size:clamp(3rem,7vw,5.5rem);font-weight:500;line-height:1.05;& em{color:var(--accent);font-style:italic}}@media (width<=1024px){padding:80px 0 60px}@media (width<=768px){padding:55px 0 50px}}.hero-layout{grid-template-columns:1.15fr 1fr;align-items:center;gap:48px;display:grid;@media (width<=1024px){grid-template-columns:1fr;gap:40px}}.hero-collage{aspect-ratio:1;width:100%;position:relative;@media (width<=1024px){max-width:440px;margin:0 auto}@media (width<=480px){aspect-ratio:1/1.1;max-width:340px}}.collage-card{background:var(--white);padding:10px 10px 14px;transition:transform .4s cubic-bezier(.2,.8,.2,1);position:absolute;box-shadow:0 2px 16px #2d282024,0 1px #2d28200f;& img{aspect-ratio:4/3;object-fit:cover;width:100%}&:hover{z-index:10;transform:rotate(0)scale(1.04)!important}}.collage-label{text-transform:uppercase;letter-spacing:.12em;color:var(--gray);margin:8px 0 0;font-size:10px}.collage-card--a{width:54%;top:0;left:0;transform:rotate(-3deg)}.collage-card--b{width:50%;top:22%;right:0;transform:rotate(4deg)}.collage-card--c{z-index:2;width:56%;bottom:0;left:14%;transform:rotate(-1.5deg)}.hero-badge{background:var(--white);color:var(--gray-dark);border-radius:var(--radius);box-shadow:var(--shadow-soft);border:1px solid #00000014;align-items:center;gap:8px;margin-bottom:20px;padding:8px 14px;font-size:.8125rem;font-weight:600;display:inline-flex}.hero-badge-dot{background:var(--green);width:8px;height:8px;box-shadow:0 0 0 3px var(--green-soft);border-radius:50%}.hero-subtitle{color:var(--gray);max-width:520px;margin-bottom:28px;font-size:clamp(1.0625rem,2.5vw,1.2rem);line-height:1.6;& strong{color:var(--black);font-weight:600}}.hero-buttons{flex-wrap:wrap;gap:14px;margin-bottom:16px;display:flex;@media (width<=768px){flex-direction:column}}.hero-note{color:var(--gray);font-size:.875rem;& strong{color:var(--gray-dark)}}.section-header{text-align:center;margin-bottom:60px}.section-label{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;font-size:.8125rem;font-weight:600}.section-title{font-family:var(--serif);font-variation-settings:"opsz" clamp(21, 3vw, 30), "SOFT" 30;letter-spacing:-.02em;color:var(--black);margin-bottom:14px;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:400}.section-subtitle{color:var(--gray);max-width:560px;margin:0 auto;font-size:1.0625rem}.portfolio{background:var(--gray-light)}.portfolio-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin:0;padding:0;list-style:none;display:grid;@media (width<=1024px){grid-template-columns:repeat(2,1fr)}@media (width<=768px){scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:16px;margin:0 -24px;padding:0 24px 30px;overflow-x:auto;display:flex!important;&::-webkit-scrollbar{display:none}}}.portfolio-item{background:var(--white);aspect-ratio:4/3;cursor:pointer;transition:transform .4s,box-shadow .4s;position:relative;overflow:hidden;&:hover{box-shadow:var(--shadow-strong);transform:translateY(-6px);& img{transform:scale(1.04)}& .portfolio-info{opacity:1;transform:translateY(0)}}& .glightbox,& .portfolio-item--linked>a{width:100%;height:100%;color:inherit;text-decoration:none;display:block}& img{object-fit:cover;width:100%;height:100%;transition:transform .6s}&.tapped .portfolio-info{opacity:1;transform:translateY(0)}@media (width<=768px){scroll-snap-align:start;aspect-ratio:4/3;flex:0 0 85vw;height:auto;scroll-margin-left:24px;box-shadow:0 4px 12px #00000014}}.portfolio-placeholder{width:100%;height:100%;font-family:var(--font-inter);color:var(--white);text-align:center;justify-content:center;align-items:center;padding:32px;font-size:1.5rem;font-weight:700;line-height:1.2;display:flex}.portfolio-tag{border-radius:var(--radius);text-transform:uppercase;letter-spacing:.08em;background:var(--white);color:var(--gray-dark);box-shadow:var(--shadow-soft);padding:5px 12px;font-size:.6875rem;font-weight:600;position:absolute;top:14px;left:14px}.portfolio-info{opacity:0;background:linear-gradient(#0000,#000000bf);padding:24px;transition:all .3s;position:absolute;bottom:0;left:0;right:0;transform:translateY(8px);& h3{color:var(--white);margin-bottom:2px;font-size:1.0625rem;font-weight:600}& p{color:#ffffffb3;font-size:.875rem}@media (width<=768px){pointer-events:none;background:linear-gradient(#0000,#000000e6);transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateY(10px)}}.portfolio-dots{display:none;@media (width<=768px){justify-content:center;gap:6px;margin-top:16px;display:flex}& span{background:#d2d2d7;border-radius:50%;width:6px;height:6px;transition:background .3s,transform .3s;&.active{background:var(--black);transform:scale(1.3)}}}.services{background:var(--white)}.services-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid;@media (width<=1024px){grid-template-columns:1fr;gap:16px}}.service-card{background:var(--gray-light);border-radius:var(--radius);padding:40px 32px;transition:transform .3s,box-shadow .3s;&:hover{box-shadow:var(--shadow-medium);transform:translateY(-4px)}& h3{color:var(--black);margin-bottom:10px;font-size:1.25rem;font-weight:600}& p{color:var(--gray);font-size:.9375rem;line-height:1.6}}.service-icon{background:var(--white);border-radius:var(--radius);width:48px;height:48px;box-shadow:var(--shadow-soft);justify-content:center;align-items:center;margin-bottom:20px;display:flex;& svg{width:24px;height:24px;stroke:var(--accent)}}.process{background:var(--gray-light)}.timeline{counter-reset:timeline-counter;max-width:800px;margin:0 auto;padding:0;list-style:none;position:relative;&:before{content:"";background:linear-gradient(180deg, var(--accent) 0%, #d2d2d7 100%);width:2px;position:absolute;top:0;bottom:0;left:28px}@media (width<=768px){&:before{left:20px}}}.timeline-item{counter-increment:timeline-counter;padding-bottom:48px;padding-left:76px;position:relative;&:last-child{padding-bottom:0}&:before{content:counter(timeline-counter);background:var(--white);border:2px solid var(--accent);width:56px;height:56px;color:var(--accent);box-shadow:var(--shadow-soft);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:1.125rem;font-weight:700;display:flex;position:absolute;top:0;left:0}&.milestone:before{background:var(--accent);color:var(--white)}&.payment{&:before{background:var(--green);border-color:var(--green);color:var(--white)}& .timeline-phase{color:var(--green)}}&:hover .timeline-content{box-shadow:var(--shadow-medium);transform:translate(4px)}@media (width<=768px){padding-bottom:32px;padding-left:56px;&:before{width:40px;height:40px;font-size:.875rem}}}.timeline-content{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px 28px;transition:transform .3s,box-shadow .3s;& h3{color:var(--black);margin-bottom:8px;font-size:1.125rem;font-weight:600}& p{color:var(--gray);margin:0;font-size:.9375rem;line-height:1.6}@media (width<=768px){padding:20px}}.timeline-phase{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;font-size:.6875rem;font-weight:600;display:inline-block}.timeline-note{background:var(--gray-light);border-radius:var(--radius);color:var(--gray-dark);align-items:center;gap:6px;margin-top:12px;padding:6px 12px;font-size:.8125rem;font-weight:500;display:inline-flex;&.free{background:var(--green-soft);color:#15803d}}.pricing{background:var(--white)}.pricing-card{background:var(--black);color:var(--white);border-radius:var(--radius);text-align:center;max-width:600px;margin:0 auto;padding:64px 48px;& h3{color:#fffc;margin-bottom:8px;font-size:1.125rem;font-weight:500}@media (width<=768px){padding:48px 28px}}.pricing-amount{letter-spacing:-.04em;margin-bottom:8px;font-size:clamp(3.5rem,10vw,5rem);font-weight:800;line-height:1;& span{color:#fff9;font-size:1.5rem;font-weight:500}}.pricing-desc{color:#fff9;margin-bottom:40px;font-size:.9375rem}.pricing-features{text-align:left;margin-bottom:40px;list-style:none;& li{border-bottom:1px solid #ffffff1a;align-items:center;gap:14px;padding:14px 0;font-size:.9375rem;display:flex;&:last-child{border-bottom:none}}& svg{width:18px;height:18px;stroke:var(--accent);flex-shrink:0}}.pricing-cta{background:var(--white);color:var(--black);border-radius:var(--radius);padding:16px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s;display:block;&:hover{background:var(--accent);color:var(--white)}}.pricing-note{color:#ffffff80;margin-top:20px;font-size:.8125rem}.seo-block{background:var(--gray-light)}.seo-content{max-width:760px;margin:0 auto;& h2{color:var(--black);margin-bottom:32px;font-size:1.75rem;font-weight:700}& p{color:var(--gray);margin-bottom:24px;font-size:1rem;line-height:1.75}& strong{color:var(--black);font-weight:600}}.faq{background:var(--white)}.faq-container{max-width:720px;margin:0 auto}.faq-item{border-bottom:1px solid var(--gray-light);& summary{cursor:pointer;color:var(--black);justify-content:space-between;align-items:center;padding:22px 0;font-size:1.0625rem;font-weight:600;list-style:none;display:flex;&::-webkit-details-marker{display:none}&:after{content:"+";color:var(--gray);font-size:1.25rem;transition:transform .3s}}&[open] summary:after{transform:rotate(45deg)}}.faq-answer{color:var(--gray);padding-bottom:22px;font-size:.9375rem;line-height:1.7}.sticky-cta{bottom:calc(20px + var(--safe-bottom));background:var(--accent);color:var(--white);border-radius:var(--radius);z-index:900;text-align:center;justify-content:center;align-items:center;gap:8px;padding:16px 24px;font-size:1rem;font-weight:600;text-decoration:none;transition:transform .3s,opacity .3s,background .2s;display:none;position:fixed;left:20px;right:20px;box-shadow:0 4px 20px #0071e366;& svg{width:18px;height:18px}&:hover{background:var(--accent-hover)}&.hidden{opacity:0;pointer-events:none;transform:translateY(150px)}@media (width<=768px){display:inline-flex}}@media (hover:none){.btn:active,.portfolio-item a:active,.pricing-cta:active,.sticky-cta:active{transform:scale(.98)}}
