html,body{height:100%;width:100%;margin:0;padding:0;background-color:#fff;font-family:Inter,monospace;font-size:.94rem;line-height:1.58}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.24;mix-blend-mode:multiply;filter:contrast(180%) brightness(98%);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.22 0'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)'/%3E%3C/svg%3E");background-size:140px 140px}body:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.28;background:linear-gradient(115deg,#ff4646f2,#ffd246f2,#5affdcf2,#5096fff2,#aa5afff2,#ff5ad2f2);-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Cg fill='none' shape-rendering='crispEdges'%3E%3Cpath d='M0 0H36M0 0V36' stroke='white' stroke-opacity='0.55' stroke-width='2'/%3E%3Cpath d='M12 0V36M24 0V36M0 12H36M0 24H36' stroke='white' stroke-opacity='0.28' stroke-width='1'/%3E%3C/g%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Cg fill='none' shape-rendering='crispEdges'%3E%3Cpath d='M0 0H36M0 0V36' stroke='white' stroke-opacity='0.55' stroke-width='2'/%3E%3Cpath d='M12 0V36M24 0V36M0 12H36M0 24H36' stroke='white' stroke-opacity='0.28' stroke-width='1'/%3E%3C/g%3E%3C/svg%3E");-webkit-mask-size:var(--mesh-size) var(--mesh-size);mask-size:var(--mesh-size) var(--mesh-size);-webkit-mask-repeat:repeat;mask-repeat:repeat}@media (max-width: 768px){html,body,#root{overflow-x:hidden}}@media (prefers-reduced-motion: reduce){body:before{opacity:.16}body:after{opacity:.16}}#root{height:100%;position:relative;z-index:1}:root{--font-xs: .74rem;--font-sm: .92rem;--font-md: 1.1rem;--font-lg: 1.45rem;--font-xl: 2rem;--navbar-height: 3.25rem;--mesh-size: 36px;--mesh-subsize: 12px}h1,h2,h3,h4{line-height:1.28}h1,h2{font-size:var(--font-lg)}p{font-size:clamp(var(--font-xs),2.5vw,var(--font-sm));line-height:1.62;text-align:justify}li{line-height:1.62}:root{display:flex;flex-direction:column;box-sizing:border-box;margin:0;padding:0}.main-container,.page-section{display:flex;flex-direction:column}.this-holds-all{display:flex;flex-direction:column;width:100%;gap:1rem;padding:1rem 5rem;box-sizing:border-box}.this-holds-all--intro{justify-content:center;align-items:center;padding:4rem}@media (max-width: 640px){.page-section--intro{width:100%;overflow-x:hidden}.this-holds-all--intro{width:100%;max-width:100%;align-items:center;padding:0 4rem 1rem;overflow-x:hidden}}.this-holds-all--projects{padding-top:0}.portfolio-title{padding-right:1rem;padding-bottom:1rem}.three-dashed-line{border-top:1px solid lightgray;padding-top:.5rem}.my-description-container{display:grid;grid-template-columns:1fr 4fr;gap:1rem}@media (max-width: 640px){.my-description-container{grid-template-columns:1fr;padding:.5rem 1rem 1rem;min-width:0;max-width:100%;box-sizing:border-box;overflow-x:hidden;gap:.5rem;justify-content:start}.my-description{order:1;min-width:0;max-width:100%;font-size:.72rem;line-height:1.42;text-align:left;box-sizing:border-box;width:100%;overflow-wrap:anywhere}.intro-photo{order:2;min-width:0;max-width:100%;width:100%;box-sizing:border-box;max-height:28svh;aspect-ratio:16 / 9}.intro-photo img{object-fit:cover;padding:.35rem}}.my-description{margin:0;background-color:#e6e6e6;padding:0 1rem;border-radius:.5rem}.desc-spec{color:#1174e1;font-weight:700}.description-image{border:4px solid black;border-radius:.5rem;box-sizing:border-box;height:100%;width:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;justify-self:center}.intro-photo{aspect-ratio:1 / 1}.description-image img{box-sizing:border-box;width:100%;height:100%;object-fit:contain;display:block;padding:.6rem 2rem}.concept-sections{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;box-sizing:border-box;width:100%;background-color:#f4f4f4;border-radius:.5rem}@media (max-width: 640px){.main-container{width:calc(100% + 8rem);margin-inline:-4rem}}.concept-sections--education{display:flex;gap:1rem;width:100%}.education-meta{flex:4}.education-img{flex:1}@media (max-width: 640px){.concept-sections--education{flex-direction:column}.education-meta{order:1;min-width:0;width:100%}.education-img{order:2;min-width:0;max-width:100%;width:100%;box-sizing:border-box;max-height:28svh;aspect-ratio:16 / 9}.education-img img{object-fit:cover;padding:.35rem}}.concept-sections--experience{padding:0}.concept-sections-cols{width:100%;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}[data-scroll-target]{scroll-margin-top:calc(var(--navbar-height, 3.25rem) + 12px)}.project-section-child{display:flex;gap:1rem;box-sizing:border-box}.header-spacer{width:100%;height:47svh;flex-shrink:0}.header--collapsed .header-line{opacity:0;pointer-events:none}.header-container{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;width:100%;z-index:100;height:50svh}.landing-header{position:relative;width:100%;height:100%;flex-shrink:0;background:#0b0b12;overflow:hidden;--header-hue: 0deg;--blob-x: 0px;--blob-y: 0px}.landing-header:after{content:"";position:absolute;inset:-20%;pointer-events:none;background:radial-gradient(75% 85% at 65% 70%,#b9c4fff2,#b9c4ff00 62%),radial-gradient(60% 60% at 20% 25%,#5affdca6,#5affdc00 66%),radial-gradient(55% 55% at 35% 85%,#ffa0dc8c,#ffa0dc00 68%),linear-gradient(120deg,#ff464600 12%,#ff46468c 26%,#ffc84673 35%,#8c78ff8c 46%,#46dcff8c 56%,#46dcff00 70%),linear-gradient(60deg,#0f0f19bf,#0f0f1900 55%),linear-gradient(210deg,#0f0f19bf,#0f0f1900 55%);filter:saturate(1.4) contrast(1.05) hue-rotate(var(--header-hue));transition:transform .9s cubic-bezier(.2,.8,.2,1),filter .7s ease;transform:translate(var(--blob-x),var(--blob-y)) scale(1.08);transform-origin:50% 50%;animation:rainbow-drift 9s ease-in-out infinite alternate;opacity:.95;z-index:0}.landing-header:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.52;background-image:linear-gradient(to left,rgba(255,255,255,.22) 1px,transparent 1px),linear-gradient(to right,rgba(255,255,255,.22) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.22) 1px,transparent 1px),linear-gradient(to right,rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(to left,rgba(255,255,255,.1) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.1) 1px,transparent 1px),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.9  0 0 0 0 0.9  0 0 0 0 0.95  0 0 0 .32 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E"),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.8' numOctaves='1' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='1 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .22 0'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E"),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.8' numOctaves='1' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0  0 1 0 0 0  0 0 1 0 0  0 0 0 .22 0'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");background-size:var(--mesh-size, 36px) var(--mesh-size, 36px),var(--mesh-size, 36px) var(--mesh-size, 36px),var(--mesh-subsize, 12px) var(--mesh-subsize, 12px),var(--mesh-subsize, 12px) var(--mesh-subsize, 12px),220px 220px,180px 180px,180px 180px;background-position:0 0,0 0,0 0,0 0,0 0,4px 2px,-4px -2px;mix-blend-mode:screen;z-index:1}.header-line{height:100%;width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 1.5rem;box-sizing:border-box;transition:opacity .16s ease;position:relative;z-index:3;color:#fff;text-shadow:none;font-size:clamp(1.35rem,2.4vw,2.1rem);font-weight:900;text-align:center;overflow-wrap:anywhere}.header-line__text{line-height:1.08;white-space:nowrap}.header-line__carousel{display:inline-flex;align-items:center;letter-spacing:.02em}.skills-carousel{--carousel-item-height: 1.25em;--carousel-visible: 1;width:auto;height:var(--carousel-item-height);overflow:hidden;position:relative;text-align:center;padding:0 .15rem}.skills-carousel__track{display:flex;flex-direction:column;will-change:transform;transform:translateY(calc((var(--carousel-center-offset) - var(--carousel-index)) * var(--carousel-item-height)))}.skills-carousel__track--animate{transition:transform .62s cubic-bezier(.2,.85,.2,1)}.skills-carousel__item{height:var(--carousel-item-height);display:flex;align-items:center;justify-content:center;white-space:nowrap;color:#fff6;font-weight:inherit;transform:none;transition:color .22s ease}.skills-carousel__item[data-distance="0"]{color:#fff}.skills-carousel__item[data-distance="1"]{color:#fff9}.skills-carousel__item[data-distance="2"]{color:#ffffff61}.skills-carousel__item[data-distance="3"]{color:#ffffff42}.landing-nav{position:absolute;top:0;left:0;right:0;height:var(--navbar-height, 3.25rem);display:flex;justify-items:center;align-items:center;box-sizing:border-box;transform:translateY(-100%);transition:transform .2s ease;pointer-events:none;z-index:4;padding:0 .5rem;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;background:radial-gradient(75% 120% at 65% 85%,#b9c4ff85,#b9c4ff00 58%),radial-gradient(70% 100% at 18% 15%,#5affdc57,#5affdc00 60%),radial-gradient(60% 90% at 38% 90%,#ffa0dc47,#ffa0dc00 64%),linear-gradient(120deg,#ff46466b 12%,#ffc84657 34%,#8c78ff6b 48%,#46dcff61 66%,#0a0a12f2),#070710;background-size:100% 100%;border-bottom:1px solid rgba(255,255,255,.14)}.landing-nav--visible{transform:translateY(0);pointer-events:auto}.landing-nav__inner{width:100%;height:100%;display:flex;align-items:center;gap:.15rem;list-style:none;margin:0;padding:0}.landing-nav__item{display:inline-flex}.landing-nav__link{height:calc(var(--navbar-height, 3.25rem) - .9rem);padding:0 .5rem;border:0;color:#ffffffeb;background:transparent;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap}@media (max-width: 900px){.header-line{flex-wrap:wrap;align-content:center;gap:.35rem .6rem;padding:calc(1rem + env(safe-area-inset-top,0px)) 1.25rem 1rem;font-size:clamp(1.65rem,7vw,3rem)}.landing-nav{padding:0 .35rem}.landing-nav__inner{width:max-content;min-width:100%;justify-content:flex-start;gap:.05rem}.landing-nav__link{padding:0 .45rem;font-size:.95rem}}@media (max-width: 560px){.header-line{gap:.2rem;padding-left:1rem;padding-right:1rem;font-size:clamp(1.1rem,5.4vw,1.45rem)}.header-line__text{white-space:nowrap;max-width:none}.landing-nav__link{padding:0 .4rem;font-size:.85rem}}@media (max-width: 768px){.header-spacer{display:none}.header-container{position:relative;height:clamp(6.5rem,18svh,8rem)}.header-line{flex-wrap:nowrap;max-width:100%;box-sizing:border-box;font-size:clamp(.9rem,4.6vw,1.25rem);overflow:hidden}.header-line__text{max-width:100%;overflow:hidden;text-overflow:clip}.landing-nav{display:none}}.landing-nav__link:hover{text-decoration:underline}.landing-nav__link:focus-visible{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}@media (prefers-reduced-motion: reduce){.header-grid,.skills-carousel__track--animate,.landing-nav{transition:none}.landing-header:before,.landing-header:after{animation:none}}.landing-header-icon{left:0;bottom:0;position:absolute;width:80px;aspect-ratio:1;height:auto;background:#a1afda;border:5px solid lightgray;align-items:center;justify-content:center;font-size:xx-large;padding:0;margin:0}@media (max-width: 768px){.col-status,.col-tags,.col-github{display:none}.cell-with-button button{opacity:1}.table-view th,.table-view td{padding:.5rem}.table-view{font-size:.9rem}}@media (min-width: 769px){.col-status,.col-tags,.col-github{display:table-cell}}.database-container{height:100%;width:100%;flex:1;border-radius:1rem 1rem 0 0;gap:1rem}.table-content{background-color:#f4f4f4;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.table-content .gallery-cols{margin:.75rem 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(28rem,1fr));gap:1rem}.tabs{display:flex;justify-content:left;gap:.3rem;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding-bottom:1rem}.tabs button{border:0;height:5vh;border-radius:25px;padding:0 1rem;font-family:Inter,monospace;cursor:pointer;flex:0 0 auto;white-space:nowrap}.tabs button:hover{background-color:#d3d3d3}.tabs button.active{border:1px solid dimgrey;background-color:#d3d3d3}.table-view{width:100%;justify-content:space-between}.table-view thead th{height:5vh;padding:0 7rem 0 .2rem;border-bottom:1px solid lightgray;border-right:1px solid lightgray;text-align:left}.table-view tbody tr td{height:100%;flex:1;padding:.3rem .2rem;border-bottom:1px solid lightgray;border-right:1px solid lightgray}.tags-column{padding:0 3rem 0 0}.cell-with-button{display:flex;justify-content:space-between;gap:2rem;align-items:center;position:relative}.cell-with-button button{width:5rem;top:0;right:0;margin:0;cursor:zoom-in;border:0;height:5vh;border-radius:5px;padding:0 .5rem;font-family:Inter,monospace}.cell-with-button:hover .open-page-button{background-color:#ff8c00;transition:opacity .5s;opacity:1}.open-page-button{padding:.3rem .6rem;border:1px solid #ccc;border-radius:6px;background:#d3d3d3;cursor:pointer;flex-shrink:0}.rounded-look{border-radius:25px;padding:.2rem 1rem;width:fit-content}.quote-box{min-height:50px;height:50px;max-height:50px;width:auto;background-color:#cecccc;display:flex;flex:1;box-sizing:border-box;align-items:center}.quote-bar{height:90%;width:5px;background-color:#2f4f4f;align-self:center;margin-left:2px}.quote-text{display:flex;flex:1;box-sizing:border-box;padding:10px;font-family:Inter,monospace;font-size:.9rem;line-height:1.45;color:#333;text-transform:uppercase;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;align-items:center}.project-card{height:100%;width:100%;background-color:#dddcdc;border:1px solid darkgrey;border-radius:12px;overflow:hidden;box-shadow:0 4px 8px #0000000f;display:grid;grid-template-columns:1fr 1fr;transition:transform .1s ease;cursor:pointer;box-sizing:border-box;padding:1rem;gap:.5rem}.project-card-left{display:flex;flex-direction:column;gap:.5rem;background-color:#f5f5f5;border-radius:12px;padding:.3rem}.project-card-right{padding:0;top:0}.project-card:hover{background:#a7a7a738;border:1px solid rgba(167,167,167,.22)}.project-card-image{box-sizing:border-box;aspect-ratio:6 / 4;width:100%;top:0;left:0;border:1px solid;border-radius:12px;background-color:#f08080}.project-card-bottom{display:flex;flex-direction:column;align-items:start;box-sizing:border-box;flex:1}.project-card-icon{display:flex;justify-content:center;align-items:center;font-size:xx-large;align-content:center;justify-self:center;align-self:center;max-height:100%;aspect-ratio:1;flex:1;border-radius:12px}.project-card-text{font-size:.86rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:4;height:100%;box-sizing:border-box;justify-content:left;align-content:center;line-height:1.45}.project-modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.project-model-wrapper{background:#fff;width:80%;height:80%;border-radius:12px;padding:2rem;overflow-y:auto;position:relative}.project-modal-content{display:flex;flex-direction:column;width:100%;padding:2rem;position:relative;box-sizing:border-box;border-radius:12px}.project-modal-close{position:absolute;top:10px;right:10px;border:none;background:#d3d3d3;font-size:1.5rem;cursor:pointer;border-radius:30px}.project-modal-header{padding:0 1rem;margin:0}.project-modal-controls{display:flex;flex-direction:column;gap:.5rem;justify-content:space-evenly;padding:0 1rem}.control-row{width:100%;display:flex;gap:1rem;padding:.2rem}.control-value{text-transform:capitalize}.project-modal-controls .control-row .control-name{width:15%}.project-modal-details{background-color:#f4f4f4;height:100%;border-radius:12px;margin-top:1rem;padding:1rem}@media (max-width: 640px){.project-modal-backdrop{align-items:flex-start;padding:.75rem;box-sizing:border-box;overflow-y:auto}.project-model-wrapper{width:100%;height:auto;max-height:calc(100svh - 1.5rem);padding:.75rem;border-radius:.5rem;box-sizing:border-box}.project-modal-content{padding:1rem;border-radius:.5rem}.project-modal-close{top:.75rem;right:.75rem;width:2.25rem;height:2.25rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;line-height:1}.project-modal-header{padding:0 2.5rem 0 0}.project-modal-header h1{margin:0;font-size:1.15rem;line-height:1.35}.project-modal-controls{padding:1rem 0 0;gap:.75rem}.control-row{flex-direction:column;gap:.35rem;padding:0}.project-modal-controls .control-row .control-name{width:100%;font-weight:800}.project-modal-details{margin-top:1rem;padding:.85rem;border-radius:.5rem;height:auto;max-height:none}}.tags-container{display:flex;width:100%;gap:.1rem;align-items:center}.experience-timeline{width:100%}.experience-timeline__list{--timeline-left: 16px;list-style:none;margin:0;padding:0;position:relative}.experience-timeline__list:before{content:"";position:absolute;left:var(--timeline-left);top:2px;bottom:2px;width:2px;background:#0000001f}.experience-timeline__item{position:relative;display:grid;grid-template-columns:calc(var(--timeline-left) * 2) 1fr;column-gap:.75rem;padding:.75rem 0}.experience-timeline__marker{position:absolute;left:calc(var(--timeline-left) - 6px);top:1.1rem;width:12px;height:12px;border-radius:999px;background:#fff;border:2px solid rgba(0,0,0,.6);box-shadow:0 0 0 4px #0000000d}.experience-timeline__content{grid-column:2;background-color:#f4f4f4;border:1px solid rgba(0,0,0,.08);border-radius:.75rem;padding:.85rem 1rem}.experience-timeline__top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.experience-timeline__title{margin:0;font-size:1rem;line-height:1.35}.experience-timeline__org{font-weight:500;opacity:.85}.experience-timeline__dates{font-size:.88rem;opacity:.7;white-space:nowrap}.experience-timeline__meta{margin-top:.25rem;font-size:.88rem;opacity:.75}.experience-timeline__highlights{margin:.6rem 0 0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.15rem}.experience-timeline__highlights li{margin:.25rem 0}.experience-timeline__tech{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.4rem}.experience-timeline__pill{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .55rem;border-radius:999px;font-size:.78rem;background:#0000000f;border:1px solid rgba(0,0,0,.1)}@media (max-width: 740px){.experience-timeline__top{flex-direction:column;align-items:flex-start;gap:.25rem}.experience-timeline__dates{white-space:normal}}.education{width:100%;height:100%;background-color:#f4f4f4;border-radius:.75rem}.education__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem;height:100%;justify-content:center;justify-items:center}.education__item{height:100%;border:1px solid rgba(0,0,0,.08);border-radius:.75rem;padding:.85rem 1rem}.education__top{display:flex;flex-direction:column;align-items:baseline;justify-content:space-between;gap:.4rem}.education__school{margin:0;font-size:1rem;line-height:1.35}.education__dates{font-size:.88rem;opacity:.7;white-space:nowrap}.education__meta{margin-top:.25rem;opacity:.8;display:flex;flex-direction:column;flex-wrap:wrap;gap:.5rem}.education__dot{opacity:.6}.education__highlights{margin:.6rem 0 0;padding-left:1.1rem;line-break:loose}.education__highlights li{margin:.25rem 0}@media (max-width: 740px){.education__top{flex-direction:column;align-items:flex-start;gap:.25rem}.education__dates{white-space:normal}}.current-upskill{width:100%;box-sizing:border-box;background-color:#f4f4f4;border:1px solid rgba(0,0,0,.08);border-radius:.5rem;padding:1rem}.current-upskill__label{margin:0 0 .35rem;color:#1174e1;font-size:.78rem;font-weight:800;text-transform:uppercase}.current-upskill__title{margin:0;font-size:1rem;line-height:1.35;font-weight:200}.current-upskill__meta{margin:.4rem 0 0;opacity:.78;text-align:left}.contact{width:100%;background-color:#f4f4f4;padding-top:0;border:1px solid rgba(0,0,0,.08);border-radius:.5rem;box-sizing:border-box}h4{box-sizing:border-box;padding:1rem 1rem 0}.contact__buttons{box-sizing:border-box;padding:1rem;display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.6rem;justify-content:center}.contact__button{aspect-ratio:2/1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem .85rem;border-radius:1rem;border:1px solid rgba(0,0,0,.12);background:#ffffffb3;color:#111;text-decoration:none;font-family:Inter,monospace;cursor:pointer;transition:transform .12s ease,background-color .12s ease,border-color .12s ease}.contact__button:hover{background:#ffffffe6;border-color:#0003;transform:translateY(-1px)}.contact__button:active{transform:translateY(0)}.contact__button--disabled{opacity:.55;cursor:not-allowed}.contact__icon{width:1.05rem;height:1.05rem}@media (max-width: 640px){.contact h4{margin-bottom:.75rem}.contact__buttons{grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.contact__button{min-width:0;aspect-ratio:auto;padding:.7rem .55rem;border-radius:.75rem;font-size:.9rem}}.portfolio-note{width:100%;box-sizing:border-box;background-color:#f4f4f4;border:1px solid rgba(0,0,0,.08);border-radius:.5rem;padding:1rem}.portfolio-note p{margin:0;text-align:center}.portfolio-note p+p{margin-top:.6rem;color:#1174e1;font-weight:700}
