:root{--hero-height: 400px;--cta-position: 600px;--spacing-unit: 1rem;--max-content-width: 900px}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;min-height:100%}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0b0b0b;color:#fff;overflow-x:hidden}#root{width:100%;min-height:100vh}.app{display:grid;grid-template-rows:var(--hero-height) 1fr auto;grid-template-columns:1fr;min-height:100vh;position:relative;-webkit-tap-highlight-color:transparent;touch-action:manipulation;overflow-x:hidden}.graph-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1}.logo{position:fixed;top:2.5rem;left:2.5rem;z-index:10;font-size:clamp(2rem,4.5vw,5rem);font-weight:800;letter-spacing:.1em;text-transform:uppercase;user-select:none;-webkit-user-select:none}.hero-section{grid-row:1;position:relative;z-index:2;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:9rem 2rem 2rem;background:linear-gradient(180deg,#0b0b0bfa,#0b0b0be6,#0b0b0b99 60%,#0b0b0b33 85%,#0b0b0b00)}.cta-wrapper{position:fixed;top:var(--cta-position);left:50%;transform:translate(-50%,-50%);z-index:5;display:flex;align-items:center;justify-content:center;pointer-events:none}.cta-wrapper .cta-button{pointer-events:all}.mission-statement{font-size:clamp(1.6rem,4vw,3rem);font-weight:700;line-height:1.3;max-width:24ch;margin:0 auto 2rem;letter-spacing:-.02em;text-shadow:0 4px 30px rgba(0,0,0,.9),0 2px 10px rgba(0,0,0,.8);padding:0 .5rem;background:#0b0b0b99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:8px;padding:1rem 1.5rem}.value-props{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem;margin:0 auto;font-size:1rem;font-weight:500;color:#ffffffe6;letter-spacing:.03em;width:100%;max-width:900px;padding:0 1rem}.value-props>div{display:inline-flex;align-items:center;justify-content:center;flex-direction:row;gap:.75rem}.value-props .separator{opacity:.4;font-size:.9rem;-webkit-user-select:none;user-select:none}.value-prop-item{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all .3s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.value-prop-badge{padding:.5rem 1rem;background:#0b0b0bb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;border:1px solid rgba(255,255,255,.15);transition:all .3s ease;white-space:nowrap}.value-prop-item:hover .value-prop-badge{background:#0b0b0bd9;border-color:#ffffff4d}.value-prop-item:focus{outline:2px solid rgba(255,255,255,.3);outline-offset:4px;border-radius:8px}.value-prop-item:focus:not(:focus-visible){outline:none}.value-prop-description{position:absolute;top:calc(100% + .5rem);left:50%;transform:translate(-50%);width:max-content;max-width:280px;padding:.75rem 1rem;background:#0b0b0bf2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:.75rem;font-weight:400;line-height:1.5;text-align:center;color:#ffffffd9;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease,transform .3s ease;transform:translate(-50%) translateY(-5px);z-index:10;pointer-events:none}@media (hover: hover) and (pointer: fine){.value-prop-item:hover .value-prop-description{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}}@media (hover: none) and (pointer: coarse){.value-prop-description{position:relative;top:auto;left:auto;transform:none;margin-top:.5rem;max-height:0;overflow:hidden;padding:0 1rem;opacity:0}.value-prop-item.active .value-prop-description{max-height:200px;padding:.75rem 1rem;opacity:1;visibility:visible;transition:max-height .3s ease,padding .3s ease,opacity .3s ease}.value-prop-item:active .value-prop-badge{transform:scale(.98)}}.cta-button{font-family:inherit;font-size:1.125rem;font-weight:600;color:#0b0b0b;background:linear-gradient(135deg,#fff,#e0e0e0);border:none;padding:1.125rem 3rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);letter-spacing:.05em;position:relative;border-radius:12px;box-shadow:0 4px 20px #fff3;text-transform:uppercase;min-height:48px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;-webkit-user-select:none}.cta-button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;padding:2px;background:linear-gradient(135deg,#fff,#888);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease}.cta-button:hover,.cta-button:focus{transform:translateY(-3px);box-shadow:0 8px 30px #ffffff4d;background:linear-gradient(135deg,#fff,#f5f5f5)}.cta-button:hover:before,.cta-button:focus:before{opacity:1}.cta-button:focus{outline:3px solid rgba(255,255,255,.6);outline-offset:4px}.cta-button:focus:not(:focus-visible){outline:none}.cta-button:focus-visible{outline:3px solid rgba(255,255,255,.6);outline-offset:4px}.cta-button:active{transform:translateY(-1px);box-shadow:0 4px 20px #fff3}@media (hover: none) and (pointer: coarse){.cta-button:active{transform:scale(.98);box-shadow:0 2px 15px #ffffff40}}.contact-section{grid-row:3;position:fixed;bottom:0;left:0;right:0;z-index:10;padding:1rem 2rem;text-align:center;background:#0b0b0be6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.1)}.contact-email{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem;color:#fffc;text-decoration:none;transition:all .2s ease;font-weight:400}.contact-email:hover,.contact-email:focus{color:#fff}.contact-email:focus{outline:2px solid rgba(255,255,255,.3);outline-offset:3px;border-radius:4px}.contact-email:focus:not(:focus-visible){outline:none}.contact-email svg{width:16px;height:16px;opacity:.8}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.cta-button,.contact-email,.value-props span{transition:none}}@media (orientation: portrait) and (min-height: 900px){.logo{top:2.5rem;left:2.5rem;font-size:clamp(2.2rem,5vw,3.5rem);z-index:10}.hero-section{padding-top:9rem}.mission-statement{font-size:clamp(1.8rem,4.5vw,3rem);margin-bottom:2.5rem}}@media (max-width: 768px){.logo{top:1.75rem;left:1.75rem;font-size:clamp(1.75rem,5vw,2.5rem);z-index:10}.hero-section{padding:7.5rem 1.5rem 1.5rem}.mission-statement{font-size:clamp(1.3rem,4.2vw,2rem);margin-bottom:1.5rem;max-width:24ch;line-height:1.35}.value-props{font-size:.875rem;gap:.75rem}.value-prop-badge{padding:.5rem .9rem;font-size:.875rem}.value-prop-description{font-size:.7rem;max-width:240px}.cta-button{font-size:1rem;padding:1rem 2.5rem}.contact-section{padding:.875rem 1.5rem}.contact-email{font-size:.875rem}}@media (max-width: 480px){.logo{top:1.25rem;left:1.25rem;font-size:clamp(1.5rem,6vw,2rem);z-index:10;letter-spacing:.08em}.hero-section{padding:6.5rem 1rem 1.5rem}.mission-statement{font-size:clamp(1.15rem,4.8vw,1.5rem);margin-bottom:1rem;max-width:100%;line-height:1.35;padding:.75rem 1rem}.value-props{font-size:.8rem;gap:.5rem;margin-bottom:1.75rem;flex-direction:column;width:100%;max-width:320px;align-items:center}.value-props>div{width:100%;flex-direction:column;gap:.5rem}.value-props .separator{display:none}.value-prop-item{width:100%}.value-prop-badge{width:100%;text-align:center;padding:.45rem .85rem;font-size:.75rem}.value-prop-description{font-size:.7rem;max-width:100%;width:100%}.cta-button{width:100%;max-width:320px;padding:.95rem 1.75rem;font-size:.9rem}.contact-section{padding:.875rem 1rem}.contact-email{font-size:.85rem}.contact-email svg{width:14px;height:14px}}@media (max-width: 360px){.logo{font-size:clamp(1.35rem,5.5vw,1.75rem);top:1.1rem;left:1.1rem;z-index:10;letter-spacing:.06em}.hero-section{padding:6.25rem .75rem 1.25rem}.mission-statement{font-size:clamp(1rem,4.8vw,1.35rem);margin-bottom:.85rem;line-height:1.35;padding:.65rem .85rem}.value-props{font-size:.7rem;max-width:290px;margin-bottom:1.5rem}.value-prop-badge{font-size:.7rem;padding:.4rem .75rem}.value-prop-description{font-size:.65rem}.cta-button{font-size:.85rem;max-width:290px;padding:.875rem 1.5rem}}@media (max-height: 500px) and (orientation: landscape){.logo{top:.85rem;left:1.25rem;font-size:clamp(1.15rem,3.2vw,1.65rem);z-index:10}.hero-section{padding:5rem 1rem .75rem}.mission-statement{font-size:clamp(.95rem,2.6vw,1.3rem);margin-bottom:.75rem;line-height:1.3}.value-props{font-size:.75rem;gap:.5rem}.cta-button{padding:.75rem 2rem;font-size:.875rem}.contact-section{padding:.5rem 1rem;position:relative}}
