@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";.portfolio{background-color:#0a0a0f;min-height:100vh;position:relative;overflow-x:hidden}.portfolio__main{z-index:5;position:relative}.starfield{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;inset:0}.moon-canvas{width:var(--moon-size);height:var(--moon-size);position:relative}.moon-canvas__glow{inset:var(--moon-glow-inset);pointer-events:none;background:radial-gradient(circle,#c8daff38 0%,#b4c8ff1f 40%,#0000 70%);border-radius:50%;position:absolute}.moon-canvas__glow--pulse{animation:3s ease-in-out infinite moonPulseScale}.moon-canvas__halo{inset:var(--moon-halo-inset);pointer-events:none;filter:blur(var(--moon-blur));background:radial-gradient(circle,#d2e1ff4d 0%,#0000 65%);border-radius:50%;position:absolute}.moon-canvas__surface{z-index:1;filter:drop-shadow(0 0 var(--moon-shadow-large) #c8daffcc) drop-shadow(0 0 var(--moon-shadow-small) #d2e4ff99);border-radius:50%;display:block;position:relative}.hero-section{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero-section__content{z-index:20;text-align:center;max-width:720px;padding:0 1.5rem;position:relative}.hero-section__eyebrow{letter-spacing:.32em;text-transform:uppercase;color:#becde6bf;margin-bottom:1.25rem;font-size:.75rem;font-weight:500}.hero-section__title{color:#fff;letter-spacing:-.02em;margin-bottom:1.25rem;font-size:clamp(3rem,8vw,6rem);font-weight:800;line-height:1.05}.hero-section__description{color:#b4c3e1cc;letter-spacing:.01em;margin-bottom:2.75rem;font-size:clamp(1rem,2.5vw,1.25rem);font-weight:400;line-height:1.6}.hero-section__description-highlight{color:#d2e1fff2;font-style:italic}.hero-section__actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.hero-section__button{letter-spacing:.06em;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:999px;padding:.75rem 2rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:all .25s;display:inline-block}.hero-section__button--primary{color:#fff;background:#c8d7ff1a;border:1px solid #d2e1ff8c;box-shadow:0 0 24px #b4d2ff38,inset 0 0 12px #c8dcff0f}.hero-section__button--primary:hover{background:#c8d7ff2e;transform:translateY(-2px);box-shadow:0 0 36px #b4d2ff61,inset 0 0 16px #c8dcff1a}.hero-section__button--secondary{color:#bed2ffcc;background:#82a0ff0d;border:1px solid #a0b9ff59;box-shadow:0 0 16px #96afff1f}.hero-section__button--secondary:hover{background:#82a0ff1f;transform:translateY(-2px);box-shadow:0 0 24px #96afff38}.hero-section__scroll{z-index:20;color:#a0b4dc80;cursor:pointer;flex-direction:column;align-items:center;gap:.35rem;text-decoration:none;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero-section__scroll-text{letter-spacing:.2em;text-transform:uppercase;font-size:.65rem}.hero-section__arc{pointer-events:none;z-index:2;opacity:.18;width:100%;height:100%;position:absolute;inset:0}.about-section{max-width:1150px;margin:0 auto;padding:clamp(3rem,8vw,6rem) clamp(1.5rem,6vw,5rem);position:relative}.about-section__header{align-items:center;gap:1rem;margin-bottom:1.8rem;display:flex}.about-section__moon{opacity:.85;flex-shrink:0}.about-section__grid{grid-template-columns:minmax(320px,420px) minmax(0,1fr);align-items:start;gap:clamp(2.5rem,6vw,5rem);display:grid}.about-section__photo-wrap{justify-content:center;align-items:center;height:100%;display:flex}.about-section__content{flex-direction:column;gap:1.25rem;display:flex}.about-section__lead{color:#d2e1ffeb;font-size:clamp(1rem,2vw,1.125rem);font-weight:400;line-height:1.8}.about-section__name{color:#fff;font-weight:600}.about-section__text{color:#b4c8f0c7;font-size:clamp(.95rem,1.8vw,1.05rem);line-height:1.8}.about-section__photo-image{object-fit:cover;border-radius:inherit;width:100%;height:100%;display:block}.about-section__photo-shell{width:340px;height:420px;position:relative}.about-section__photo-glow{filter:blur(16px);pointer-events:none;z-index:0;background:radial-gradient(circle,#b4d2ff4d 0%,#8caaff2e 35%,#6e87e614 55%,#0000 75%);border-radius:50%;position:absolute;inset:-50px}.about-section__photo-card{z-index:1;background:linear-gradient(145deg,#1e233ceb 0%,#12142ac7 100%);border:1px solid #b4d2ff2e;border-radius:1.75rem;flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;height:100%;padding:.65rem;display:flex;position:relative;overflow:hidden;box-shadow:0 0 65px #8caaff29,0 0 120px #6e87e61a,inset 0 0 30px #6482ff0d}.about-section__photo-star{background:#d2e4ffb3;border-radius:50%;width:3px;height:3px;position:absolute;box-shadow:0 0 8px #c8daffd9}.about-section__photo-text{letter-spacing:.18em;text-transform:uppercase;color:#a0b9e673;font-size:.7rem;font-weight:500}@media (width<=900px){.about-section__grid{grid-template-columns:1fr;align-items:center}.about-section__photo-shell{width:300px;height:370px}}@media (width<=480px){.about-section__photo-shell{width:260px;height:320px}.about-section__photo-glow{inset:-35px}}.skills-section{max-width:1100px;margin:0 auto;padding:clamp(4rem,10vw,8rem) clamp(1.5rem,6vw,5rem);position:relative}.skills-section__grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(1.5rem,4vw,2.5rem);display:grid}.skills-section__card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#14162d8c;border:1px solid #b4d2ff1a;border-radius:1.25rem;flex-direction:column;gap:1.25rem;padding:2rem 1.75rem;display:flex}.skills-section__card-header{align-items:center;gap:.6rem;display:flex}.skills-section__icon{font-size:1.1rem;line-height:1}.skills-section__label{letter-spacing:.22em;text-transform:uppercase;opacity:.85;font-size:.72rem;font-weight:600}.skills-section__badges{flex-wrap:wrap;justify-content:center;align-items:center;gap:.6rem;display:flex}.skills-section__badge{letter-spacing:.04em;color:var(--accent);border:1px solid var(--border);background:var(--glow);cursor:default;border-radius:999px;padding:.45rem 1.05rem;font-size:.82rem;font-weight:500;transition:all .25s;display:inline-block}.skills-section__badge:hover{background:var(--hover-bg);box-shadow:0 0 18px var(--hover-glow), 0 0 6px var(--hover-glow-soft);border-color:var(--hover-border);color:#fff}.projects-section{max-width:1100px;margin:0 auto;padding:clamp(4rem,10vw,5rem) clamp(1.5rem,6vw,3rem);position:relative}.projects-section__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1.25rem,2vw,1.75rem);display:grid}.projects-section__card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#12142ab3;border:1px solid #b4d2ff1f;border-radius:1.25rem;flex-direction:column;transition:border-color .3s,box-shadow .3s;display:flex;overflow:hidden}.projects-section__card:hover{border-color:#b4d2ff61;box-shadow:0 0 40px #a0c3ff1a,0 0 0 1px #b4d2ff1a}.projects-section__card-body{flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex}.projects-section__card-title{color:#fff;letter-spacing:-.01em;font-size:1.1rem;font-weight:700}.projects-section__card-description{color:#b4c8f0bf;flex:1;font-size:.875rem;line-height:1.7}.projects-section__tags{flex-wrap:wrap;gap:.45rem;display:flex}.projects-section__tag{letter-spacing:.05em;color:#c8daffbf;background:#96b4ff12;border:1px solid #b4d2ff2e;border-radius:999px;padding:.25rem .7rem;font-size:.7rem;font-weight:500}.projects-section__actions{flex-wrap:wrap;gap:.75rem;margin-top:.25rem;display:flex}.projects-section__thumbnail{background:linear-gradient(135deg,#141832f2 0%,#0e1024fa 100%);justify-content:center;align-items:center;width:100%;height:180px;display:flex;position:relative;overflow:hidden}.projects-section__thumbnail-glow{background:radial-gradient(circle, var(--project-tint) 0%, transparent 70%);filter:blur(28px);pointer-events:none;border-radius:50%;width:70%;height:70%;position:absolute}.projects-section__thumbnail-grid{pointer-events:none;background-image:linear-gradient(#b4d2ff0a 1px,#0000 1px),linear-gradient(90deg,#b4d2ff0a 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}.projects-section__thumbnail-initials{color:#c8daff2e;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;font-family:inherit;font-size:2.5rem;font-weight:800;position:relative}.projects-section__button{letter-spacing:.05em;cursor:pointer;border-radius:999px;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.775rem;font-weight:600;text-decoration:none;transition:all .22s;display:inline-flex}.projects-section__button--primary{color:#dcebffe6;background:#b4d2ff12;border:1px solid #c8dcff59}.projects-section__button--primary:hover{color:#fff;background:#b4d2ff29;border-color:#c8dcffa6;box-shadow:0 0 16px #b4d2ff2e}.projects-section__button--secondary{color:#b4cdffb3;background:0 0;border:1px solid #a0b9ff38}.projects-section__button--secondary:hover{color:#fff;background:#a0b9ff14;border-color:#a0b9ff73;box-shadow:0 0 16px #b4d2ff2e}.projects-section__thumbnail{background:#141832f2;width:100%;height:180px;position:relative;overflow:hidden}.projects-section__thumbnail-image{object-fit:cover;width:100%;height:100%;display:block}@media (width<=980px){.projects-section__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.projects-section__grid{grid-template-columns:1fr}}.contact-section{padding:clamp(3rem,8vw,5rem) clamp(1.5rem,6vw,5rem) clamp(2rem,5vw,3.5rem);position:relative}.contact-section__inner{max-width:600px;margin:0 auto;position:relative}.contact-section__header{text-align:center;margin-bottom:3rem}.contact-section__eyebrow{letter-spacing:.32em;text-transform:uppercase;color:#becde699;margin-bottom:1rem;font-size:.7rem;font-weight:500}.contact-section__title{color:#fff;letter-spacing:-.02em;margin-bottom:1rem;font-size:clamp(1.75rem,5vw,2.75rem);font-weight:800;line-height:1.15}.contact-section__intro{color:#b4c8f0a6;max-width:420px;margin:0 auto;font-size:.925rem;line-height:1.7}.contact-section__form{flex-direction:column;gap:1.25rem;display:flex}.contact-section__row{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.contact-section__button{letter-spacing:.06em;color:#fff;cursor:pointer;background:#b4d2ff1a;border:1px solid #c8dcff73;border-radius:999px;align-self:flex-start;align-items:center;gap:.5rem;padding:.8rem 2rem;font-size:.875rem;font-weight:600;transition:box-shadow .25s,background .25s;display:inline-flex;box-shadow:0 0 28px #b4d2ff33,inset 0 0 14px #c8dcff0f}.contact-section__button:hover{background:#b4d2ff2e;box-shadow:0 0 40px #b4d2ff59,inset 0 0 18px #c8dcff1a}.contact-section__success{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#12142a99;border:1px solid #b4d2ff2e;border-radius:1.25rem;padding:3rem 2rem}.contact-section__success-icon{background:#b4d2ff1a;border:1px solid #b4d2ff4d;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 1.25rem;display:flex;box-shadow:0 0 24px #b4d2ff38}.contact-section__success-icon-svg{color:#c8dcffd9}.contact-section__success-title{color:#fff;margin-bottom:.5rem;font-size:1.1rem;font-weight:700}.contact-section__success-text{color:#b4c8f0a6;font-size:.875rem}.contact-field{flex-direction:column;gap:.45rem;display:flex}.contact-field__label{color:#bed2fa99;letter-spacing:.04em;font-size:.75rem;font-weight:500}.contact-field__input{color:#dcebffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-sizing:border-box;background:#12162ea6;border:1px solid #b4d2ff24;border-radius:.75rem;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.contact-field__input::placeholder{color:#aabee673}.contact-field__input:focus,.contact-field__input:focus-visible{border-color:#b4d2ff66;box-shadow:0 0 0 3px #a0c3ff12}.contact-field__input--textarea{resize:vertical;min-height:130px;padding:.875rem 1rem}.contact-section__scroll{color:#a0b4dc80;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:.35rem;margin:2rem auto 0;padding:0;text-decoration:none;display:flex}.contact-section__scroll-text{letter-spacing:.2em;text-transform:uppercase;font-size:.65rem}.contact-section__arc{pointer-events:none;opacity:.18;z-index:1;width:100%;height:100%;position:absolute;inset:0;transform:scaleX(-1)}@media (width<=640px){.contact-section__row{grid-template-columns:1fr}.contact-section__button{justify-content:center;align-self:stretch}}.footer-section{border-top:1px solid #ffffff0d;flex-direction:column;justify-content:flex-end;align-items:center;min-height:90px;padding-bottom:2rem;display:flex;position:relative;overflow:hidden}.footer-section__stars{pointer-events:none;position:absolute;inset:0;overflow:hidden}.footer-section__star{background:#d2e4fff2;border-radius:50%;animation-name:twinkle;animation-timing-function:ease-in-out;animation-iteration-count:infinite;position:absolute}.footer-section__glow{pointer-events:none;background:radial-gradient(80% 60% at 50% 100%,#78a0ff12 0%,#0000 70%);position:absolute;inset:0}.footer-section__content{text-align:center;z-index:2;position:relative}.footer-section__copyright{color:#b9cdf073;letter-spacing:.08em;margin-bottom:.55rem;font-size:.8rem;font-weight:400}.footer-section__tagline{color:#a0b9e647;letter-spacing:.16em;text-transform:uppercase;font-size:.72rem;font-style:italic;font-weight:300}.footer-section__socials{border-top:1px solid #ffffff0f;justify-content:center;gap:1.5rem;padding-bottom:2rem;display:flex}.footer-section__social-link{color:#bed2ffa6;background:#8caaff0d;border:1px solid #b4d2ff26;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;text-decoration:none;transition:all .25s;display:flex}.footer-section__social-link:hover{color:#fff;background:#b4d2ff1a;border-color:#b4d2ff73;box-shadow:0 0 20px #b4d2ff38}:root{--color-bg:#0a0a0f;--color-text:#f4f7ff;--color-white:#fff;--color-heading-line:#c8daffe6;--color-heading-line-soft:#b4c8ff4d;--color-heading-glow:#c8daff8c;--color-border-soft:#b4d2ff2e;--color-border-faint:#b4d2ff1a;--color-text-muted:#b4c8f0a6}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--color-bg);color:var(--color-text);font-family:Plus Jakarta Sans,sans-serif;overflow-x:hidden}a{color:inherit}button,input,textarea{font:inherit}.section-heading{margin-bottom:4rem}.section-heading__title{color:var(--color-white);letter-spacing:-.02em;margin-bottom:.5rem;font-size:clamp(2.3rem,6vw,3.5rem);font-weight:800;line-height:1}.section-heading__line{background:linear-gradient(90deg, var(--color-heading-line) 0%, var(--color-heading-line-soft) 70%, transparent 100%);width:182px;height:2px;box-shadow:0 0 12px var(--color-heading-glow);border-radius:999px}.section-shell{max-width:1100px;margin:0 auto}@keyframes moonPulseGlow{0%,to{box-shadow:0 0 20px 6px #b4d2ff59,0 0 50px 15px #a0beff2e,0 0 90px 30px #8caaff14}50%{box-shadow:0 0 30px 10px #b4d2ff8c,0 0 70px 25px #a0beff47,0 0 120px 50px #8caaff24}}@keyframes moonPulseScale{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}@keyframes twinkle{0%,to{opacity:.25;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}@keyframes twinkleSlow{0%,to{opacity:.8}50%{opacity:.1}}@keyframes twinkleFast{0%,to{opacity:.9}50%{opacity:.3}}
