*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}input:where(:not([type])),input:where([type=date]),input:where([type=datetime-local]),input:where([type=email]),input:where([type=month]),input:where([type=number]),input:where([type=password]),input:where([type=search]),input:where([type=tel]),input:where([type=text]),input:where([type=time]),input:where([type=url]),input:where([type=week]),select,select:where([multiple]),textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow:0 0 #0000}input:where(:not([type])):focus,input:where([type=date]):focus,input:where([type=datetime-local]):focus,input:where([type=email]):focus,input:where([type=month]):focus,input:where([type=number]):focus,input:where([type=password]):focus,input:where([type=search]):focus,input:where([type=tel]):focus,input:where([type=text]):focus,input:where([type=time]):focus,input:where([type=url]):focus,input:where([type=week]):focus,select:focus,select:where([multiple]):focus,textarea:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder,textarea::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder,textarea::placeholder{color:#6b7280;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-year-field{padding-top:0;padding-bottom:0}select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}select:where([multiple]),select:where([size]:not([size="1"])){background-image:none;background-position:0 0;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}input:where([type=checkbox]),input:where([type=radio]){-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}input:where([type=checkbox]){border-radius:0}input:where([type=radio]){border-radius:100%}input:where([type=checkbox]):focus,input:where([type=radio]):focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}input:where([type=checkbox]):checked,input:where([type=radio]):checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}input:where([type=checkbox]):checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0'/%3E%3C/svg%3E")}@media (forced-colors:active) {input:where([type=checkbox]):checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}input:where([type=radio]):checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E")}@media (forced-colors:active) {input:where([type=radio]):checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}input:where([type=checkbox]):checked:focus,input:where([type=checkbox]):checked:hover,input:where([type=radio]):checked:focus,input:where([type=radio]):checked:hover{border-color:transparent;background-color:currentColor}input:where([type=checkbox]):indeterminate{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}@media (forced-colors:active) {input:where([type=checkbox]):indeterminate{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}input:where([type=checkbox]):indeterminate:focus,input:where([type=checkbox]):indeterminate:hover{border-color:transparent;background-color:currentColor}input:where([type=file]){background:unset;border-color:inherit;border-width:0;border-radius:0;padding:0;font-size:unset;line-height:inherit}input:where([type=file]):focus{outline:1px solid ButtonText;outline:1px auto -webkit-focus-ring-color}:root{--radius:24px;--radius-sm:16px;--transition:all 0.35s cubic-bezier(0.4,0,0.2,1)}[data-theme=light]{--bg-page:#fafafa;--bg-card:#fff;--bg-card-alt:#f5f5f5;--bg-dark:#0a0a0a;--accent:#1e3a5f;--accent-light:#2d4a6f;--accent-muted:rgba(30,58,95,.06);--accent-secondary:#0a0a0a;--text-primary:#0a0a0a;--text-secondary:#525252;--text-muted:#a3a3a3;--border:#e5e5e5;--border-hover:#d4d4d4;--shadow:0 1px 2px rgba(0,0,0,.03),0 4px 16px rgba(0,0,0,.03);--shadow-hover:0 8px 30px rgba(0,0,0,.06)}[data-theme=dark]{--bg-page:#0a0a0a;--bg-card:#141414;--bg-card-alt:#1f1f1f;--bg-dark:#000;--accent:#6b8cae;--accent-light:#8ba4c0;--accent-muted:rgba(107,140,174,.12);--accent-secondary:#4a5568;--text-primary:#fafafa;--text-secondary:#a3a3a3;--text-muted:#525252;--border:#262626;--border-hover:#404040;--shadow:0 1px 2px rgba(0,0,0,.3),0 4px 16px rgba(0,0,0,.3);--shadow-hover:0 8px 30px rgba(0,0,0,.4)}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-page);color:var(--text-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.font-display,h1,h2,h3,h4{font-family:Plus Jakarta Sans,sans-serif;letter-spacing:-.02em}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.container{max-width:1280px;margin:0 auto;padding:0 24px}.hero{padding-top:120px;padding-bottom:80px}.bento-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.hero-main{grid-column:span 6;grid-row:span 3;padding:40px;display:flex;flex-direction:column;justify-content:space-between}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.1;letter-spacing:-.03em;margin-bottom:20px}.hero-title .accent{background:linear-gradient(135deg,var(--accent) 0,var(--accent-light) 50%,var(--accent) 100%);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 6s ease-in-out infinite}.hero-subtitle{font-size:1.15rem;color:var(--text-secondary);max-width:480px;line-height:1.7;margin-bottom:32px}.hero-cta{display:flex;gap:12px;flex-wrap:wrap}.photo-card{grid-column:span 3;grid-row:span 3;padding:6px;background:linear-gradient(135deg,#1e3a5f,#0a0a0a);overflow:hidden}[data-theme=dark] .photo-card{background:linear-gradient(135deg,#6b8cae,#1f1f1f)}.photo-card:after{content:"";position:absolute;inset:6px;border-radius:20px;box-shadow:inset 0 0 30px hsla(0,0%,100%,.1);pointer-events:none;transition:box-shadow .4s ease}.photo-card:hover:after{box-shadow:inset 0 0 50px hsla(0,0%,100%,.2)}.photo-img{width:100%;height:100%;min-height:300px;-o-object-fit:cover;object-fit:cover;border-radius:20px}.role-card{grid-column:span 3;padding:24px;display:flex;flex-direction:column;justify-content:space-between;min-height:140px}.role-card.primary{background:var(--accent)!important;border:none!important}.role-card.primary,.role-card.primary .role-icon,.role-card.primary .role-label,.role-card.primary .role-title,.role-card.primary p{color:#fff!important}.role-card.primary .role-label{color:hsla(0,0%,100%,.8)!important}.role-card.secondary{background:var(--accent-secondary)!important;color:#fff!important;border:none!important}.role-card.secondary .role-icon,.role-card.secondary .role-label,.role-card.secondary .role-title,.role-card.secondary p{color:#fff!important}.role-card.secondary .role-label{color:hsla(0,0%,100%,.8)!important}[data-theme=dark] .role-card.secondary{background:#1f1f1f!important}.role-icon{font-size:1.75rem;margin-bottom:12px}.role-label{font-size:.8rem;opacity:.8}.role-title{font-family:Plus Jakarta Sans,sans-serif;font-size:1.15rem;font-weight:700}.tech-card{grid-column:span 5;padding:24px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-label{font-size:.85rem;color:var(--text-muted);font-weight:500}.card-badge{font-size:.75rem;color:var(--accent);font-weight:500}.tech-tags{display:flex;flex-wrap:wrap;gap:8px}.tech-tag.alt{background:var(--bg-card-alt);color:var(--text-secondary)}.company-card{grid-column:span 2;padding:24px;background:var(--bg-dark)!important;border:none!important}.company-card,.company-card .role-icon,.company-card .role-label,.company-card .role-title,.company-card p{color:#fff!important}.company-card .role-label{color:hsla(0,0%,100%,.6)!important}.location-card{grid-column:span 2;padding:24px;background:var(--accent-muted)}.location-card .role-label{color:var(--text-secondary)}.location-card .role-title{color:var(--accent)}.quote-card{grid-column:span 3;padding:24px;background:var(--bg-card);border-left:3px solid var(--accent);display:flex;align-items:center;position:relative}.quote-card:after{content:'"';position:absolute;top:10px;right:20px;font-size:4rem;font-family:Plus Jakarta Sans,serif;color:var(--accent);opacity:.1;line-height:1}.quote-text{font-style:italic;color:var(--text-secondary);font-size:1rem;line-height:1.6}.section-header{text-align:center;margin-bottom:60px}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.service-card{padding:36px;text-align:center}.service-title{font-size:1.25rem;font-weight:700;margin-bottom:10px}.service-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.about-text{color:var(--text-secondary);font-size:1.1rem;line-height:1.9}.about-text strong{color:var(--text-primary)}.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}.about-stat{padding:24px;text-align:center}.about-stat.accent{background:var(--accent);color:#fff;border:none}.about-stat.secondary{background:var(--accent-secondary);color:#fff;border:none}[data-theme=dark] .about-stat.secondary{background:#1f1f1f}.about-stat.dark{background:var(--bg-dark);color:#fff;border:none}.stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:2.5rem;font-weight:700;color:var(--text-primary)}.about-stat.accent .stat-value,.about-stat.dark .stat-value,.about-stat.secondary .stat-value{color:#fff}.stat-label{font-size:.85rem;opacity:.8;margin-top:4px;color:var(--text-secondary)}.about-stat.accent .stat-label,.about-stat.dark .stat-label,.about-stat.secondary .stat-label{color:hsla(0,0%,100%,.8)}.hobbies-card{grid-column:span 2;padding:24px}.hobbies-title{font-size:.85rem;color:var(--text-muted);margin-bottom:14px}.hobbies-tags{display:flex;flex-wrap:wrap;gap:10px}.hobby-tag{padding:10px 16px;background:var(--bg-card-alt);border-radius:100px;font-size:.9rem;display:flex;align-items:center;gap:8px}.projects-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;align-items:start}.project-featured{grid-column:span 8;padding:36px;display:flex;gap:32px;cursor:pointer}.project-content{flex:1}.project-label{font-size:.75rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}.project-title{font-size:1.75rem;font-weight:700;margin-bottom:12px}.project-desc{color:var(--text-secondary);margin-bottom:20px;line-height:1.6}.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.project-tag{padding:6px 12px;background:var(--accent-muted);color:var(--accent);font-size:.8rem;font-weight:500;border-radius:6px}.project-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;text-decoration:none;transition:var(--transition)}.project-link:hover{gap:12px}.project-link span{display:inline-block;transition:transform .3s ease}.project-link:hover span{transform:translateX(6px)}.project-image{width:200px;height:160px;background:var(--bg-card-alt);border:1px solid var(--border);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:3rem;flex-shrink:0}.project-small{grid-column:span 4;padding:24px;cursor:pointer;display:flex;flex-direction:column}.project-small.dark{background:var(--bg-dark);color:#fff;border:none}.project-small.accent{background:var(--accent);color:#fff;border:none}.project-small-image{height:100px;background:var(--bg-card-alt);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin-bottom:16px}.project-small.dark .project-small-image{background:hsla(0,0%,100%,.1)}.project-small.accent .project-small-image{background:hsla(0,0%,100%,.2)}.project-small-title{font-weight:700;margin-bottom:4px;color:var(--text-primary)}.project-small.accent .project-small-title,.project-small.dark .project-small-title{color:#fff}.project-small-desc{font-size:.85rem;color:var(--text-secondary);flex-grow:1}.project-small.accent .project-small-desc,.project-small.dark .project-small-desc{color:hsla(0,0%,100%,.7)}.experience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.exp-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}.exp-company{font-weight:700}.exp-date{font-size:.85rem;color:var(--text-muted)}.exp-title{font-weight:700;margin-bottom:8px}.exp-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.7}.exp-desc strong{color:var(--text-primary);font-weight:600}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.contact-main{background:var(--accent)!important;padding:48px;border:none}.contact-main,.contact-main .contact-desc,.contact-main .contact-title,.contact-main h2,.contact-main p{color:#fff!important}.contact-title{font-size:2.5rem;font-weight:700;margin-bottom:16px;line-height:1.2;color:#fff}.contact-desc{font-size:1.1rem;opacity:.9;margin-bottom:32px;line-height:1.6;color:hsla(0,0%,100%,.9)}.contact-links{display:grid;grid-template-columns:1fr 1fr;gap:16px}.contact-link{padding:24px;text-decoration:none;color:var(--text-primary)}.contact-link-icon{width:48px;height:48px;background:var(--bg-dark);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:var(--transition)}.contact-link:hover .contact-link-icon{transform:scale(1.1)}.contact-link-icon.phone-icon{background:var(--accent-secondary)}[data-theme=dark] .contact-link-icon.phone-icon{background:#1f1f1f}.contact-link-title{font-weight:700;margin-bottom:2px}.contact-link-handle{font-size:.85rem;color:var(--text-muted)}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:28px;transition:transform .2s ease,box-shadow .35s ease,border-color .35s ease;box-shadow:var(--shadow);position:relative;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover);border-color:var(--border-hover)}.card:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,transparent,rgba(30,58,95,.1) 50%,transparent);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;opacity:0;transition:opacity .4s ease;pointer-events:none}.card:hover:before{opacity:1}[data-theme=dark] .card:before{background:linear-gradient(135deg,transparent,rgba(107,140,174,.2) 50%,transparent)}.btn-primary{padding:14px 28px;background:linear-gradient(135deg,var(--accent) 0,var(--accent-light) 100%);color:#fff;font-weight:600;border-radius:12px;text-decoration:none;transition:var(--transition);display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;box-shadow:0 4px 15px rgba(30,58,95,.3)}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);transition:left .5s ease}.btn-primary:hover:before{left:100%}.btn-primary:hover{box-shadow:0 8px 25px rgba(30,58,95,.4);transform:translateY(-2px)}[data-theme=dark] .btn-primary{box-shadow:0 4px 15px rgba(107,140,174,.3)}[data-theme=dark] .btn-primary:hover{box-shadow:0 8px 25px rgba(107,140,174,.4)}.btn-secondary{padding:14px 28px;background:transparent;border:2px solid var(--border);color:var(--text-primary);font-weight:600;border-radius:12px;text-decoration:none;transition:var(--transition)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.header{position:fixed;top:0;left:0;right:0;z-index:50;background:hsla(0,0%,98%,.7);border-bottom:1px solid var(--border);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}[data-theme=dark] .header{background:hsla(0,0%,4%,.7)}.header-inner{max-width:1280px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.logo{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.25rem;color:var(--text-primary);text-decoration:none;transition:all .3s ease}.logo:hover{transform:scale(1.05)}.logo-dot{color:var(--accent);display:inline-block;animation:logoDot 3s ease-in-out infinite}.nav{gap:4px}.header-actions,.nav{display:flex;align-items:center}.header-actions{gap:12px}.btn-header{padding:10px 20px;background:var(--accent);color:#fff;font-weight:600;font-size:.9rem;border-radius:10px;text-decoration:none;transition:var(--transition)}.btn-header:hover{background:var(--accent-light);transform:translateY(-2px)}.nav-link{padding:8px 16px;font-size:.9rem;color:var(--text-secondary);text-decoration:none;border-radius:8px;transition:var(--transition);position:relative}.nav-link:after{content:"";position:absolute;bottom:4px;left:16px;right:16px;height:2px;background:var(--accent);transform:scaleX(0);transition:transform .3s ease}.nav-link:hover{color:var(--text-primary);background:var(--bg-card-alt)}.nav-link:hover:after{transform:scaleX(1)}.theme-toggle{width:40px;height:40px;border-radius:10px;background:var(--bg-card);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:var(--transition)}.theme-toggle:hover{border-color:var(--border-hover);background:var(--bg-card-alt)}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(34,197,94,.1);border-radius:100px;font-size:.8rem;font-weight:500;color:#16a34a;width:-moz-fit-content;width:fit-content;margin-bottom:32px}[data-theme=dark] .status-badge{background:rgba(34,197,94,.15);color:#4ade80}.status-dot{width:8px;height:8px;animation:pulse 2s infinite;position:relative}.status-dot,.status-dot:after{background:#22c55e;border-radius:50%}.status-dot:after{content:"";position:absolute;inset:-3px;opacity:0;animation:ripple 2s ease-out infinite}.tech-tag{padding:8px 14px;background:var(--accent-muted);color:var(--accent);font-size:.85rem;font-weight:500;border-radius:8px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:default}.tech-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(30,58,95,.15)}.section{padding:100px 0}.section-label{font-size:.85rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.section-title{font-size:2.75rem;font-weight:700;letter-spacing:-.02em}.service-icon{width:64px;height:64px;background:var(--accent-muted);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin:0 auto 20px;transition:all .4s cubic-bezier(.4,0,.2,1)}.service-card:hover .service-icon{transform:scale(1.1) rotate(5deg);background:var(--accent)}.project-card{cursor:pointer}.exp-card{padding:32px;border-left:4px solid var(--accent);position:relative;overflow:hidden}.exp-card:after{content:"";position:absolute;top:0;left:0;width:4px;height:0;background:linear-gradient(180deg,var(--accent),transparent);transition:height .4s ease}.exp-card:hover:after{height:100%}.exp-logo{width:48px;height:48px;background:var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:1.1rem}.exp-card:nth-child(2){border-left-color:var(--accent-secondary)}.exp-card:nth-child(2) .exp-logo{background:var(--accent-secondary)}[data-theme=dark] .exp-card:nth-child(2) .exp-logo{background:#1f1f1f}.exp-card:nth-child(3){border-left-color:var(--text-muted)}.exp-card:nth-child(3) .exp-logo{background:var(--text-muted)}.contact-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;background:#fff;color:var(--accent);font-weight:700;border-radius:100px;text-decoration:none;transition:var(--transition);position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1)}.contact-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(30,58,95,.1);border-radius:50%;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.contact-btn:hover:before{width:300px;height:300px}.contact-btn:hover{transform:scale(1.03);box-shadow:0 8px 30px rgba(0,0,0,.15)}.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.modal.hidden{display:none}.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:var(--bg-card);border-radius:var(--radius);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;padding:32px;box-shadow:var(--shadow-hover)}.modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:var(--bg-card-alt);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-secondary);transition:var(--transition)}.modal-close:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.project-detail{display:flex;flex-direction:column;gap:24px}.project-detail-image{width:100%;height:300px;background:var(--bg-card-alt);border-radius:var(--radius);overflow:hidden}.project-detail-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.project-detail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:700;color:var(--accent);background:var(--accent-muted)}.project-detail-info{display:flex;flex-direction:column;gap:20px}.project-detail-title{font-family:Plus Jakarta Sans,sans-serif;font-size:2rem;font-weight:700;color:var(--text-primary)}.project-detail-desc{color:var(--text-secondary);font-size:1rem;line-height:1.8}.project-detail-section{display:flex;flex-direction:column;gap:12px}.project-detail-label{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.project-detail-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.project-detail-links .btn-primary,.project-detail-links .btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem}.footer{background:hsla(0,0%,98%,.7);border-top:1px solid var(--border);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}[data-theme=dark] .footer{background:hsla(0,0%,4%,.7)}.footer-inner{max-width:1280px;margin:0 auto;padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px}.footer-text{font-size:.9rem;color:var(--text-muted);text-align:center}.visible{visibility:visible}.static{position:static}.mt-12{margin-top:3rem}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-5{height:1.25rem}.min-h-screen{min-height:100vh}.w-5{width:1.25rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-fade-in-up{animation:fadeInUp .8s ease forwards}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.items-center{align-items:center}.justify-center{justify-content:center}.gap-3{gap:.75rem}.overflow-x-hidden{overflow-x:hidden}.py-12{padding-top:3rem;padding-bottom:3rem}.text-center{text-align:center}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.noise-overlay{z-index:1000;opacity:.03;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 400'%3E%3Cfilter id='a'%3E%3CfeTurbulence baseFrequency='.9' numOctaves='4' stitchTiles='stitch' type='fractalNoise'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E")}.gradient-bg,.noise-overlay{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none}.gradient-bg{z-index:-1;overflow:hidden}.gradient-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;animation:float 20s ease-in-out infinite}[data-theme=light] .blob-1{width:600px;height:600px;background:linear-gradient(135deg,rgba(30,58,95,.3),rgba(30,58,95,.1));top:-200px;right:-100px}[data-theme=light] .blob-2{width:500px;height:500px;background:linear-gradient(135deg,rgba(30,58,95,.2),rgba(107,140,174,.1));bottom:20%;left:-150px;animation-delay:-7s}[data-theme=light] .blob-3{width:400px;height:400px;background:linear-gradient(135deg,rgba(107,140,174,.25),rgba(30,58,95,.1));top:40%;right:10%;animation-delay:-14s}[data-theme=dark] .blob-1{width:600px;height:600px;background:linear-gradient(135deg,rgba(107,140,174,.2),rgba(30,58,95,.1));top:-200px;right:-100px}[data-theme=dark] .blob-2{width:500px;height:500px;background:linear-gradient(135deg,rgba(30,58,95,.15),rgba(107,140,174,.05));bottom:20%;left:-150px;animation-delay:-7s}[data-theme=dark] .blob-3{width:400px;height:400px;background:linear-gradient(135deg,rgba(107,140,174,.15),rgba(30,58,95,.05));top:40%;right:10%;animation-delay:-14s}.grid-pattern{position:fixed;top:0;left:0;right:0;bottom:0;z-index:-1;background-image:linear-gradient(rgba(30,58,95,.03) 1px,transparent 0),linear-gradient(90deg,rgba(30,58,95,.03) 1px,transparent 0);background-size:60px 60px;pointer-events:none}[data-theme=dark] .grid-pattern{background-image:linear-gradient(rgba(107,140,174,.05) 1px,transparent 0),linear-gradient(90deg,rgba(107,140,174,.05) 1px,transparent 0)}.bento-grid .card{opacity:0;animation:cardReveal .6s ease forwards}.bento-grid .card:first-child{animation-delay:.1s}.bento-grid .card:nth-child(2){animation-delay:.15s}.bento-grid .card:nth-child(3){animation-delay:.2s}.bento-grid .card:nth-child(4){animation-delay:.25s}.bento-grid .card:nth-child(5){animation-delay:.3s}.bento-grid .card:nth-child(6){animation-delay:.35s}.bento-grid .card:nth-child(7){animation-delay:.4s}.bento-grid .card:nth-child(8){animation-delay:.45s}.bento-grid .card:nth-child(9){animation-delay:.5s}.scroll-animate{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.scroll-animate.visible{opacity:1;transform:translateY(0)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes ripple{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(2.5)}}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-20px) scale(1.02)}}@keyframes logoDot{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes cardReveal{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:1024px){.container{padding:0 20px}.header-inner{padding:16px 20px}.section{padding:60px 0}.section-title{font-size:2rem}.bento-grid{grid-template-columns:repeat(6,1fr)}.hero-main{grid-column:span 6;grid-row:span 2}.hero-title{font-size:2.5rem}.photo-card{grid-row:span 2}.photo-card,.role-card{grid-column:span 3}.tech-card{grid-column:span 6}.company-card,.location-card{grid-column:span 3}.quote-card{grid-column:span 6}.services-grid{grid-template-columns:repeat(2,1fr)}.about-grid{grid-template-columns:1fr;gap:40px}.about-cards{grid-template-columns:repeat(4,1fr)}.hobbies-card{grid-column:span 4}.projects-grid{grid-template-columns:repeat(6,1fr)}.project-featured{grid-column:span 6;flex-direction:column}.project-image{width:100%;height:200px}.project-small{grid-column:span 3}.experience-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{grid-template-columns:1fr}.contact-links{grid-template-columns:repeat(2,1fr)}.btn-header,.nav{display:none}}@media (max-width:640px){.container{padding:0 16px}.header-inner{padding:12px 16px}.section{padding:50px 0}.section-title{font-size:1.75rem}.card{border-radius:16px;padding:20px}.btn-primary,.btn-secondary{width:100%;text-align:center;justify-content:center}.modal-content{padding:24px;margin:16px}.hero{padding-top:100px;padding-bottom:50px}.bento-grid{grid-template-columns:1fr}.hero-main{grid-column:span 1;padding:28px}.hero-title{font-size:2rem}.hero-cta{flex-direction:column}.photo-card{grid-column:span 1;grid-row:span 1}.photo-img{min-height:250px}.company-card,.location-card,.quote-card,.role-card,.tech-card{grid-column:span 1}.services-grid{grid-template-columns:1fr}.about-cards{grid-template-columns:repeat(2,1fr)}.hobbies-card{grid-column:span 2}.hobbies-tags{justify-content:center}.projects-grid{grid-template-columns:1fr}.project-featured,.project-small{grid-column:span 1}.experience-grid{grid-template-columns:1fr}.contact-main{padding:32px}.contact-title{font-size:1.75rem}.contact-links{grid-template-columns:1fr}}@media (max-width:380px){.section-title{font-size:1.5rem}.hero-title{font-size:1.75rem}.contact-title{font-size:1.5rem}}