@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.3p2_lha1f2xer.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.1qq4vpdcun5oj.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.390ncx5urfkfu.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.21jp631_3pja2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.0wgildi0cnwt9.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.31988l_ccedte.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.2tuy5pz7dlieh.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.2dbetqa9o8jxf.woff2)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.1uyisp29ctx0d.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.1rgnod-3esatf.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.0r6juujl39pe6.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.h-full{height:100%}.grow{flex-grow:1}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}:root{--blue:#377cf6;--blue-dark:#2164de;--ink:#171b24;--muted:#697386;--line:#e7e9ee;--soft:#f8f9fb;--mint:#25e5bd}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:76px}body{color:var(--ink);background:#fff;margin:0;font-family:Arial,Helvetica,sans-serif}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}.container{width:min(1120px,100% - 40px);margin-inline:auto}.site-header{z-index:50;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff0;height:72px;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;height:100%;display:flex}.logo{color:var(--blue);align-items:center;gap:9px;font-size:18px;font-weight:800;display:inline-flex}.logo-mark{background:var(--blue);color:#fff;border-radius:7px;place-items:center;width:30px;height:30px;display:grid}.desktop-nav,.nav-actions{align-items:center;gap:28px;display:flex}.desktop-nav a{color:#323846;font-size:14px;font-weight:600}.desktop-nav a:hover{color:var(--blue)}.button{cursor:pointer;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:0 18px;font-size:13px;font-weight:700;transition:all .2s;display:inline-flex}.button:hover{transform:translateY(-1px)}.button-primary{background:var(--blue);color:#fff;box-shadow:0 8px 20px #377cf633}.button-primary:hover{background:var(--blue-dark)}.button-ghost{color:#303743;background:#fff;border-color:#dfe3ea}.button-light{color:var(--blue);background:#fff}.button-glass{color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border-color:#ffffff4d}.button-large{min-height:48px;padding:0 22px}.full-button{width:100%}.mobile-menu{display:none}.hero{background:#fff;padding:100px 0 92px;overflow:hidden}.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center;gap:80px;display:grid}.eyebrow{color:var(--blue);text-transform:uppercase;letter-spacing:.05em;background:#f1f6ff;border:1px solid #cfe0ff;border-radius:999px;align-items:center;padding:5px 13px;font-size:10px;font-weight:800;display:inline-flex}.hero-copy h1{letter-spacing:-.06em;max-width:630px;margin:18px 0 14px;font-size:clamp(47px,6vw,70px);line-height:.98}.hero-copy h1 span{color:var(--blue)}.hero-copy p{max-width:590px;color:var(--muted);margin:0;font-size:17px;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.hero-visual{min-height:410px;position:relative}.hero-core{aspect-ratio:1;color:#fff;background:#eef3fa;border:10px solid #fff;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:min(350px,100% - 80px);display:flex;position:absolute;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #d9e7fb,0 24px 55px #224a8233}.hero-core img{object-fit:cover;object-position:center 18%;transform:scale(1.02)}.hero-orbit{border:1px dashed #b9d4f4;border-radius:50%;position:absolute}.orbit-one{inset:15px}.orbit-two{inset:-25px}.floating-card{z-index:3;border:1px solid var(--line);background:#fff;border-radius:10px;align-items:center;gap:12px;min-width:180px;padding:14px 16px;font-size:13px;font-weight:800;display:flex;position:absolute;box-shadow:0 14px 35px #14233c24}.floating-card svg{color:var(--blue);font-size:24px}.floating-card small{color:var(--muted);text-transform:uppercase;margin-bottom:3px;font-size:9px;display:block}.card-web{top:28px;left:50%;transform:translate(-50%)}.card-mobile{bottom:64px;right:-28px}.card-backend{bottom:64px;left:-28px}.tech-strip{border-block:1px solid var(--line);background:var(--soft);padding:32px 0 38px}.tech-strip p{text-align:center;color:#9aa1ad;text-transform:uppercase;letter-spacing:.12em;font-size:9px;font-weight:800}.tech-list{color:#737b89;flex-wrap:wrap;justify-content:space-between;gap:20px;margin-top:25px;font-size:14px;font-weight:700;display:flex}.section{padding:90px 0}.section-muted{background:var(--soft)}.section-heading{margin-bottom:44px}.section-heading h2,.contact-copy h2{letter-spacing:-.045em;margin:12px 0 8px;font-size:38px}.section-heading p,.contact-copy>p{max-width:600px;color:var(--muted);margin:0;font-size:15px;line-height:1.65}.split-heading{justify-content:space-between;align-items:end;gap:30px;display:flex}.centered{text-align:center}.centered p{margin-inline:auto}.project-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.home-project-grid{grid-template-columns:repeat(4,1fr);gap:14px}.project-tabs{background:#eef4ff;border:1px solid #dce5f4;border-radius:12px;flex-wrap:wrap;gap:8px;width:fit-content;margin:-22px 0 28px;padding:6px;display:flex;box-shadow:0 8px 22px #377cf614}.project-tabs button{color:#53617a;cursor:pointer;background:0 0;border:0;border-radius:8px;min-height:38px;padding:0 18px;font-size:11px;font-weight:800;transition:all .2s}.project-tabs button:hover,.project-tabs button.active{background:var(--blue);color:#fff;box-shadow:0 7px 16px #377cf640}.home-project-grid .project-image{height:105px}.home-project-grid .project-card-body{padding:12px}.home-project-grid .project-card h3{min-height:36px;font-size:14px}.compact-project-card .project-meta{font-size:8px}.compact-project-card .text-link{margin-top:5px;font-size:10px}.project-card-actions{align-items:center;gap:7px;margin-top:12px;display:flex}.project-card-actions a,.project-action-disabled{border:1px solid var(--line);border-radius:5px;justify-content:center;align-items:center;gap:5px;min-height:29px;padding:0 9px;font-size:9px;font-weight:800;display:inline-flex}.project-action-disabled{color:#9ca3af;cursor:not-allowed}.project-card-actions a:last-child{color:var(--blue);margin-left:auto}.project-card-actions a:hover{background:#f4f7fd;border-color:#b9cff8}.stack-live-button{margin-top:8px}.project-card{border:1px solid var(--line);background:#fff;border-radius:10px;transition:all .25s;overflow:hidden;box-shadow:0 8px 28px #1923370a}.project-card:hover{transform:translateY(-5px);box-shadow:0 16px 35px #1923371a}.project-image{height:190px;display:block;position:relative;overflow:hidden}.project-image img{object-fit:cover;transition:all .4s}.project-card:hover .project-image img{transform:scale(1.035)}.project-card-body{padding:17px}.project-meta{color:var(--blue);text-transform:uppercase;justify-content:space-between;font-size:10px;font-weight:800;display:flex}.project-card h3{margin:8px 0 6px;font-size:18px}.project-card p{min-height:40px;color:var(--muted);margin:0;font-size:13px;line-height:1.55}.project-tags{flex-wrap:wrap;gap:7px;margin:13px 0;display:flex}.project-tags span{color:var(--blue);background:#f0f5ff;border-radius:999px;padding:5px 10px;font-size:9px;font-weight:700}.text-link{align-items:center;gap:7px;font-size:12px;font-weight:800;display:inline-flex}.text-link:hover{color:var(--blue)}.skills-carousel-section{border-block:1px solid var(--line);color:var(--ink);background:#fff;padding:75px 0 90px;overflow:hidden}.skills-carousel-heading{text-align:center}.skills-carousel-heading span{color:var(--blue);letter-spacing:.12em;text-transform:uppercase;font-size:10px;font-weight:800}.skills-carousel-heading h2{letter-spacing:-.04em;margin:10px 0 8px;font-size:36px}.skills-carousel-heading p{color:var(--muted);margin:0;font-size:13px}.skills-carousel{align-items:center;margin-top:45px;display:flex;position:relative}.skills-stage{width:100%;height:220px;position:relative}.skill-bubble{--distance:max(var(--skill-offset), calc(var(--skill-offset) * -1));top:50%;left:calc(50% + var(--skill-offset) * 95px);z-index:calc(20 - var(--distance));width:86px;height:86px;color:var(--ink);opacity:max(.25, calc(1 - var(--distance) * .15));cursor:pointer;background:#f5f7fa;border:1px solid #dce3ed;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:9px;transition:all .35s;display:flex;position:absolute;transform:translate(-50%,-50%)}.skill-bubble svg{color:var(--skill-color);font-size:27px}.skill-bubble strong{font-size:9px}.skill-bubble.active{opacity:1;background:#fff;border:4px solid #3b82f6;width:180px;height:180px;box-shadow:0 0 0 5px #3b82f61f,0 18px 40px #1e375a1f}.skill-bubble.active svg{font-size:58px}.skill-bubble.active strong{font-size:17px}.skills-arrow{z-index:30;width:50px;height:50px;color:var(--ink);cursor:pointer;background:#fff;border:1px solid #d9e1ec;border-radius:50%;flex:none;place-items:center;font-size:25px;display:grid;position:relative}.skills-arrow:hover{background:#edf4ff;border-color:#3b82f6}.skills-dots{justify-content:center;gap:9px;margin-top:15px;display:flex}.skills-dots span{background:#d7dee9;border-radius:999px;width:6px;height:6px}.skills-dots span.active{background:#3b82f6;width:28px}.education-section{background:var(--soft)}.education-layout{grid-template-columns:.75fr 1.25fr;align-items:start;gap:90px;display:grid}.education-intro{position:sticky;top:115px}.education-intro h2{letter-spacing:-.045em;margin:14px 0 10px;font-size:38px}.education-intro p{color:var(--muted);margin:0;font-size:14px;line-height:1.7}.education-timeline{gap:28px;padding-left:42px;display:grid;position:relative}.education-timeline:before{content:"";background:#cbd9ef;width:2px;position:absolute;top:20px;bottom:20px;left:16px}.education-item{min-width:0;position:relative}.education-dot{z-index:1;border:5px solid var(--soft);background:var(--blue);color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;font-size:12px;display:grid;position:absolute;top:22px;left:-42px}.education-card{border:1px solid var(--line);background:#fff;border-radius:10px;min-width:0;padding:25px 28px}.education-period{color:var(--blue);text-transform:uppercase;align-items:center;gap:6px;font-size:10px;font-weight:800;display:inline-flex}.education-card h3{margin:13px 0 5px;font-size:20px}.education-card strong{color:#4c5565;text-transform:uppercase;font-size:12px}.education-card p{color:var(--muted);margin:13px 0 0;font-size:13px;line-height:1.65}.contact-grid{grid-template-columns:.9fr 1.1fr;align-items:start;gap:100px;display:grid}.contact-copy h2{font-size:42px}.contact-line{overflow-wrap:anywhere;align-items:center;gap:12px;margin-top:22px;font-size:12px;font-weight:700;display:flex}.contact-line>span:first-child,.round-socials a{border:1px solid var(--line);width:38px;height:38px;color:var(--muted);border-radius:50%;place-items:center;display:grid}.contact-line small{color:#9aa1ad;text-transform:uppercase;margin-bottom:4px;font-size:9px;display:block}.socials{gap:14px;margin-top:22px;display:flex}.contact-form{border:1px solid var(--line);background:#fff;border-radius:12px;gap:17px;padding:30px;display:grid;box-shadow:0 12px 35px #14233c0f}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.contact-form label{color:#505866;text-transform:uppercase;gap:7px;font-size:9px;font-weight:800;display:grid}.contact-form input,.contact-form textarea{width:100%;color:var(--ink);text-transform:none;border:1px solid #dde2e9;border-radius:5px;outline:none;padding:12px;font-size:12px}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--blue)}.contact-form textarea{resize:vertical;min-height:120px}.contact-form button:disabled{cursor:wait;opacity:.7;transform:none}.form-status{border-radius:6px;margin:0;padding:10px 12px;font-size:11px;line-height:1.5}.form-status-success{color:#087958;background:#e8fff5}.form-status-error{color:#b42318;background:#fff0f0}.footer{border-top:1px solid var(--line);background:var(--soft);color:var(--muted)}.footer-grid{grid-template-columns:1.5fr .7fr 1fr;gap:80px;padding:65px 0;display:grid}.footer-grid>div{min-width:0}.footer-copy{max-width:300px;font-size:13px;line-height:1.6}.footer h3{color:var(--ink);text-transform:uppercase;margin:4px 0 20px;font-size:11px}.footer-links{gap:13px;font-size:12px;display:grid}.footer-email{overflow-wrap:anywhere;align-items:center;gap:7px;font-size:12px;display:flex}.footer p{font-size:12px;line-height:1.5}.footer-bottom{border-top:1px solid var(--line);justify-content:space-between;padding:22px 0;font-size:10px;display:flex}.project-hero{background:#102034;border-radius:12px;place-items:center;height:350px;margin-top:32px;display:grid;position:relative;overflow:hidden}.project-hero>img{object-fit:cover;object-position:center}.project-hero-shade{background:linear-gradient(90deg,#040a12f0,#040a12c2 48%,#040a123d);position:absolute;inset:0}.project-hero-content{color:#fff;justify-content:space-between;align-items:center;gap:70px;width:100%;padding:32px 40px;display:flex;position:relative}.project-hero-copy{max-width:760px}.project-hero-content h1{letter-spacing:-.05em;max-width:800px;margin:15px 0 10px;font-size:clamp(38px,5vw,56px);line-height:1.02}.project-hero-content p{color:#d6dce6;max-width:620px;margin:0;font-size:17px;line-height:1.6}.dark-eyebrow{background:var(--project-accent);border-color:#ffffff40}@supports (color:color-mix(in lab, red, red)){.dark-eyebrow{background:color-mix(in srgb, var(--project-accent) 65%, transparent)}}.dark-eyebrow{color:#fff}.mobile-preview{aspect-ratio:703/1541;background:#fff;border:5px solid #ffffffe6;border-radius:20px;flex:0 0 130px;width:130px;position:relative;overflow:hidden;transform:rotate(3deg);box-shadow:0 28px 65px #0000006b}.mobile-preview img{object-fit:cover}.facts{border-bottom:1px solid var(--line);background:#fff}.facts-grid{grid-template-columns:repeat(4,1fr);gap:20px;padding:28px 0;display:grid}.fact{align-items:center;gap:12px;display:flex}.fact>span{width:38px;height:38px;color:var(--blue);background:#edf4ff;border-radius:8px;place-items:center;display:grid}.fact small,.fact strong{display:block}.fact small{color:#929aa8;text-transform:uppercase;margin-bottom:4px;font-size:8px;font-weight:800}.fact strong{font-size:12px}.detail-grid{grid-template-columns:minmax(0,1fr) 290px;gap:70px;display:grid}.case-study h2{border-left:4px solid var(--blue);margin:0 0 18px;padding-left:14px;font-size:27px}.case-study h2:not(:first-child){margin-top:50px}.case-study>p{color:var(--muted);font-size:15px;line-height:1.75}.challenge-list{gap:16px;display:grid}.challenge{border:1px solid var(--line);background:#fbfbfc;border-radius:10px;gap:14px;padding:22px;display:flex}.challenge>svg{color:var(--blue);flex:none;margin-top:3px}.challenge h3{margin:0 0 7px;font-size:16px}.challenge p{color:var(--muted);margin:0;font-size:13px;line-height:1.6}.stack-card,.cta-card{border:1px solid var(--line);border-radius:12px;padding:24px}.stack-card h3{align-items:center;gap:8px;margin:0 0 16px;font-size:15px;display:flex}.large-tags{border-bottom:1px solid var(--line);padding-bottom:20px}.cta-card{background:var(--blue);color:#fff;border:0;margin-top:20px;box-shadow:0 12px 28px #377cf640}.cta-card h3{margin:0 0 10px;font-size:19px}.cta-card p{color:#e3ecff;margin:0 0 20px;font-size:12px;line-height:1.6}.related-grid{grid-template-columns:repeat(3,1fr)}.related-grid .project-image{height:180px}.loading-page{min-height:70vh;padding:70px}.loading-block,.loading-line{background:#eef1f5;border-radius:10px}.loading-block{height:360px}.loading-line{width:70%;height:22px;margin-top:30px}.loading-line.short{width:45%}@media (max-width:900px){.desktop-nav{display:none}.hero-grid,.contact-grid,.detail-grid{grid-template-columns:1fr}.hero-grid{gap:50px}.hero-copy{text-align:center}.hero-copy p{margin-inline:auto}.hero-actions{justify-content:center}.hero-visual{width:min(480px,100%);margin-inline:auto}.project-grid,.skills-grid,.home-project-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{gap:45px}.education-layout{grid-template-columns:1fr;gap:42px}.education-intro{max-width:620px;position:static}.footer-grid{grid-template-columns:1.25fr 1fr;gap:45px}.footer-grid>div:first-child{grid-column:1/-1}.footer-copy{max-width:520px}.facts-grid{grid-template-columns:repeat(2,1fr)}.detail-grid{gap:40px}.related-grid{grid-template-columns:repeat(2,1fr)}.related-grid article:last-child{display:none}.project-hero{height:340px}.mobile-preview{flex-basis:115px;width:115px}}@media (max-width:620px){.container{width:min(100% - 28px,1120px)}.project-hero{border-radius:9px}.site-header{height:64px}.nav-actions{gap:8px}.nav-actions>.button{display:none}.mobile-menu{display:block;position:relative}.mobile-menu summary{border:1px solid var(--line);border-radius:6px;place-items:center;width:40px;height:40px;font-size:20px;list-style:none;display:grid}.mobile-menu summary::-webkit-details-marker{display:none}.mobile-menu nav{border:1px solid var(--line);background:#fff;border-radius:8px;width:190px;padding:12px;display:grid;position:absolute;top:47px;right:0;box-shadow:0 15px 35px #14233c24}.mobile-menu nav a{padding:11px;font-size:13px}.hero{padding:65px 0}.hero-copy h1{font-size:45px}.hero-copy p{font-size:15px}.hero-actions{display:grid}.hero-visual{min-height:330px}.hero-core{border-width:8px;width:min(270px,100% - 60px)}.orbit-two{inset:0}.floating-card{min-width:auto;padding:10px;font-size:10px}.card-web{top:10px;left:50%}.card-mobile{bottom:42px;right:0}.card-backend{bottom:42px;left:0}.tech-list{justify-content:center}.section{padding:65px 0}.section-heading h2,.contact-copy h2{font-size:31px}.split-heading{flex-direction:column;align-items:start}.project-grid,.skills-grid,.related-grid,.home-project-grid{grid-template-columns:1fr}.project-tabs{flex-wrap:nowrap;width:100%;padding-bottom:5px;overflow-x:auto}.project-tabs button{flex:none}.skills-carousel-section{padding:60px 0 70px}.skills-carousel-heading h2{font-size:30px}.skills-stage{height:180px}.skill-bubble{left:calc(50% + var(--skill-offset) * 68px);width:66px;height:66px}.skill-bubble svg{font-size:21px}.skill-bubble strong{font-size:7px}.skill-bubble.active{width:135px;height:135px}.skill-bubble.active svg{font-size:42px}.skill-bubble.active strong{font-size:13px}.skills-arrow{width:42px;height:42px}.education-layout{grid-template-columns:1fr;gap:38px}.education-intro{position:static}.education-intro h2{font-size:31px}.education-timeline{padding-left:34px}.education-timeline:before{left:12px}.education-dot{border-width:4px;width:28px;height:28px;left:-34px}.education-card{padding:21px}.related-grid article:last-child{display:block}.project-image{height:175px}.home-project-grid .project-image{height:120px}.facts-grid{grid-template-columns:1fr 1fr;gap:18px 8px}.fact{align-items:start}.fact strong{font-size:10px}.project-hero{height:360px}.project-hero-content{padding:28px;display:block}.project-hero-shade{background:#040a12c9}.mobile-preview{display:none}.project-hero-content h1{font-size:36px}.project-hero-content p{font-size:14px}.form-row{grid-template-columns:1fr}.contact-form{padding:20px}.footer-grid{grid-template-columns:1fr;gap:32px;padding:45px 0}.footer-grid>div:first-child{grid-column:auto}.footer h3{margin-bottom:13px}.footer-email{align-items:flex-start}.footer-bottom{text-align:center;flex-direction:column;gap:10px}.project-content{padding-top:55px}.case-study h2{font-size:24px}}
