:root{--ink: #0f0f0f;--muted: #525252;--faint: #a3a3a3;--line: #e7e7e5;--paper: #f7f7f5;--card: #ffffff;--accent: #171717;--max: 1200px;--radius: 14px;--radius-lg: 20px}.app{min-height:100vh;background:var(--paper);color:var(--ink);font-size:clamp(1rem,.35vw + .94rem,1.0625rem)}.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 clamp(1.25rem,4vw,2.5rem)}.main-header{border-bottom:1px solid var(--line);background:#f7f7f5e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-container{max-width:var(--max);margin:0 auto;padding:1rem clamp(1.25rem,4vw,2.5rem);display:flex;align-items:center;justify-content:space-between}.header-logo-image{display:block;height:clamp(84px,6vw,100px);width:auto;max-width:180px;object-fit:contain}.header-nav{display:flex;align-items:center;gap:clamp(1.25rem,3vw,2.25rem)}.nav-link{font-size:clamp(.9375rem,1.2vw,1.0625rem);font-weight:500;color:var(--muted);text-decoration:none}.nav-link:hover{color:var(--ink)}.login-btn{font:inherit;font-size:.9375rem;font-weight:600;padding:.55rem 1.35rem;color:#fafaf9;background:var(--accent);border:none;border-radius:10px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.login-btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px #0f0f0f26}.login-btn:focus-visible{outline:2px solid var(--ink);outline-offset:3px}.login-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#0f0f0f66;animation:fadeIn .2s ease}.login-modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1101;width:min(28rem,calc(100vw - 2rem));padding:2rem 2rem 1.75rem;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:0 24px 64px #0000001f;animation:fadeIn .2s ease}.login-modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:none;background:var(--paper);color:var(--muted);cursor:pointer;border-radius:10px;display:flex;align-items:center;justify-content:center}.login-modal-close:hover{background:var(--line);color:var(--ink)}.login-modal-title{font-size:1.35rem;font-weight:700;margin:0 2.5rem .65rem 0;letter-spacing:-.02em}.login-modal-body{font-size:1rem;line-height:1.6;color:var(--muted);margin-bottom:.5rem}.login-modal-email-line{margin-bottom:1.35rem}.login-modal-email{font-size:1.0625rem;font-weight:600;color:var(--ink);text-decoration:underline;text-underline-offset:4px}.login-modal-email:hover{opacity:.75}.login-modal-cta{width:100%;font:inherit;font-weight:600;font-size:1rem;padding:.75rem;border:none;border-radius:10px;background:var(--accent);color:#fafaf9;cursor:pointer}.login-modal-cta:hover{opacity:.92}.hero-section{padding:clamp(3.5rem,10vw,6.5rem) 0 clamp(3rem,8vw,5rem)}.hero-grid{display:grid;gap:clamp(2rem,5vw,3.5rem);align-items:stretch}@media (min-width: 960px){.hero-grid{grid-template-columns:1fr minmax(17rem,22rem);align-items:center;gap:3rem 4rem}}.hero-main{position:relative;padding-left:clamp(1.1rem,2vw,1.5rem);max-width:38rem}@media (min-width: 960px){.hero-main{max-width:none}}.hero-mark{position:absolute;left:0;top:.2rem;bottom:.15rem;width:4px;background:var(--ink);border-radius:3px}.hero-label{font-size:.8125rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:1rem}.hero-title{font-size:clamp(2.5rem,5.5vw + 1rem,4.25rem);font-weight:800;line-height:1.05;letter-spacing:-.035em;margin-bottom:clamp(1.25rem,3vw,1.75rem)}.hero-title-break{display:block;color:var(--muted);font-weight:700}.hero-subtitle{font-size:clamp(1.0625rem,1.5vw,1.25rem);line-height:1.65;color:var(--muted);max-width:36rem}.hero-aside{display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px) and (max-width: 959px){.hero-aside{flex-direction:row}}.hero-stat{flex:1;padding:clamp(1.25rem,3vw,1.65rem) clamp(1.35rem,3vw,1.75rem);border:1px solid var(--line);border-radius:var(--radius);background:var(--card);box-shadow:0 1px #fffc inset;transition:border-color .2s ease,box-shadow .2s ease}.hero-stat:hover{border-color:#d4d4d4;box-shadow:0 12px 40px #0000000f}.hero-stat-value{display:block;font-size:clamp(1.25rem,2.5vw,1.65rem);font-weight:800;letter-spacing:-.03em;margin-bottom:.35rem}.hero-stat-label{font-size:clamp(.8125rem,1.2vw,.9375rem);color:var(--faint);line-height:1.4}.pipeline-section{padding:clamp(3rem,8vw,5rem) 0;border-top:1px solid var(--line)}.section-head{margin-bottom:clamp(2rem,4vw,2.75rem);max-width:40rem}.section-title{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem}.section-lede{font-size:clamp(1rem,1.5vw,1.125rem);color:var(--muted);line-height:1.5}.pipeline-grid{display:grid;gap:clamp(1rem,2vw,1.5rem);grid-template-columns:1fr}@media (min-width: 640px){.pipeline-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.pipeline-grid{grid-template-columns:repeat(4,1fr)}}.pipeline-card{position:relative;padding:clamp(1.5rem,3vw,2rem);min-height:clamp(11rem,22vw,13.5rem);border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--card);transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;display:flex;flex-direction:column}.pipeline-card:hover{transform:translateY(-4px);border-color:#d6d6d4;box-shadow:0 20px 48px #00000014}.pipeline-card-num{font-size:.75rem;font-weight:800;letter-spacing:.08em;color:var(--faint);margin-bottom:1rem;font-variant-numeric:tabular-nums}.pipeline-card-title{font-size:clamp(1.0625rem,1.5vw,1.2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:.65rem;line-height:1.25}.pipeline-card-text{font-size:clamp(.875rem,1.2vw,.9375rem);line-height:1.55;color:var(--muted);margin-top:auto}.pipeline-card-accent{border-color:#d4d4d4;background:linear-gradient(160deg,#fafaf9,#fff 55%);box-shadow:0 0 0 1px #0f0f0f0a}.pipeline-card-accent .pipeline-card-num{color:var(--ink)}.requirements-section{padding:clamp(3rem,8vw,5rem) 0 clamp(4rem,12vw,7rem);border-top:1px solid var(--line)}.requirements-block{max-width:52rem;margin:0 auto}.requirements-title{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem}.requirements-subtitle{font-size:clamp(1rem,1.5vw,1.125rem);color:var(--muted);line-height:1.6;margin-bottom:1.35rem;max-width:42rem}.requirements-price{font-weight:800;color:var(--ink)}.requirements-input{width:100%;min-height:clamp(14rem,28vw,20rem);padding:clamp(1rem,2vw,1.35rem);font:inherit;font-size:clamp(.9375rem,1.2vw,1.0625rem);line-height:1.55;color:var(--ink);border:1px solid var(--line);border-radius:var(--radius);background:var(--card);resize:vertical;margin-bottom:1rem;transition:border-color .2s ease,box-shadow .2s ease}.requirements-input::placeholder{color:var(--faint)}.requirements-input:focus{outline:none;border-color:#a3a3a3;box-shadow:0 0 0 4px #0000000a}.generate-btn{width:100%;max-width:24rem;font:inherit;font-weight:600;font-size:1.0625rem;padding:.85rem 1.25rem;border:none;border-radius:var(--radius);background:var(--line);color:var(--faint);cursor:not-allowed;display:flex;align-items:center;justify-content:center;gap:.6rem}.generate-btn:hover:not(:disabled){opacity:.95}.spinner{width:18px;height:18px;border:2px solid rgba(0,0,0,.1);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.footer{padding:clamp(2rem,5vw,3rem) 0 clamp(2.5rem,6vw,4rem);border-top:1px solid var(--line);text-align:center}.footer-link{font-size:clamp(1rem,1.5vw,1.125rem);font-weight:600;color:var(--muted);text-decoration:none}.footer-link:hover{color:var(--ink)}.footer-content{display:flex;flex-direction:column;gap:.75rem;align-items:center}.footer-contact{display:flex;gap:1.25rem;flex-wrap:wrap;justify-content:center}.footer-contact-link{font-size:.95rem;color:var(--faint);text-decoration:none}.footer-contact-link:hover{color:var(--ink)}.pricing-section,.projects-section{padding:2rem 0}.pricing-grid,.projects-grid{display:grid;gap:1rem}.pricing-card,.project-card{border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem;background:var(--card)}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:1000}.project-panel{position:fixed;top:0;width:100%;max-width:min(28rem,100vw);height:100vh;background:var(--card);border-left:1px solid var(--line);z-index:1001;overflow-y:auto;box-shadow:-12px 0 48px #00000014}.panel-right{right:0}.panel-left{left:0}.panel-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:1px solid var(--line);border-radius:10px;background:var(--paper);cursor:pointer}.panel-content{padding:clamp(2.5rem,5vw,3.5rem) clamp(1.5rem,4vw,2rem)}.panel-header{margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--line)}.panel-category{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:.35rem}.panel-title{font-size:clamp(1.5rem,3vw,1.85rem);font-weight:800;letter-spacing:-.02em;margin-bottom:.5rem}.panel-tech{font-size:.875rem;color:var(--muted)}.panel-body{display:flex;flex-direction:column;gap:1.5rem}.project-panel .section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin-bottom:.5rem}.section-text{font-size:1rem;line-height:1.65;color:var(--muted)}.features-list{list-style:none}.feature-item{display:flex;gap:.5rem;font-size:1rem;color:var(--muted);margin-bottom:.35rem}.feature-dot{width:5px;height:5px;margin-top:.5rem;flex-shrink:0;background:var(--ink);border-radius:50%}.panel-link{display:inline-flex;align-items:center;gap:.35rem;font-size:1rem;font-weight:600;padding:.65rem 1.1rem;background:var(--accent);color:#fafaf9;text-decoration:none;border-radius:10px}.panel-link:hover{opacity:.9}@media (max-width: 480px){.nav-link{display:none}}::selection{background:#d4d4d4}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fafaf9;color:#171717}#root{width:100%;min-height:100vh}
