*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;color:#333;background-color:#fff}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}ul,ol{list-style:none}a{text-decoration:none;color:inherit}img{max-width:100%;height:auto;display:block}button{border:none;background:none;cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none}table{border-collapse:collapse;border-spacing:0}fieldset{border:none;margin:0;padding:0}legend{padding:0}main{display:block}h1,h2,h3,h4,h5,h6{margin:0;font-weight:inherit;font-size:inherit}p,blockquote,pre{margin:0}figure{margin:0}hr{margin:0;border:none}form{display:block}details{display:block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none!important}:focus{outline:2px solid #007bff;outline-offset:2px}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid #007bff;outline-offset:2px}button,a,input,textarea,select{transition:all .2s ease-in-out}button,a,input,textarea,select{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}p,h1,h2,h3,h4,h5,h6,span,div{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}*,*:before,*:after{box-sizing:border-box}input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-results-button,input[type=search]::-webkit-search-results-decoration{-webkit-appearance:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.flex{display:flex}.grid{display:grid}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}@media (max-width: 768px){html{font-size:14px}.container{padding:0 .5rem}}@media (max-width: 480px){html{font-size:12px}}@font-face{font-family:IAMAPLAYER;src:url(https://fastly.jsdelivr.net/gh/projectnoonnu/noonfonts_2307-2@1.0/IAMAPLAYER.woff2) format("woff2");font-weight:400;font-style:normal}.header{position:fixed;top:0;left:0;right:0;height:60px;background-color:#fff;border-bottom:1px solid #e8e8e8;z-index:1000;display:flex;align-items:center;justify-content:flex-start;gap:100px;padding:0 20px}.logo{font-weight:700;font-size:1.4rem;color:#37352f;cursor:pointer;transition:color .2s ease;-webkit-user-select:none;user-select:none;font-family:IAMAPLAYER}.logo:hover{color:#666}.nav{display:flex;gap:40px}.nav-link{text-decoration:none;color:#37352f;font-weight:500;font-size:1rem;padding:8px 16px;border-radius:6px;transition:all .2s ease}.nav-link:hover{background-color:#f7f6f3;color:#37352f}.nav-link.active{background-color:#37352f;color:#fff}@media (max-width: 768px){.nav{gap:20px}.nav-link{font-size:.9rem;padding:6px 12px}}.sidebar{position:fixed;left:0;top:60px;width:280px;height:calc(100vh - 60px);background-color:#fafafa;border-right:1px solid #e8e8e8;padding:40px 24px;overflow-y:auto;z-index:999}.profile-section{margin-bottom:40px}.profile-image-container{display:flex;justify-content:center;margin-bottom:24px}.profile-image-placeholder{width:150px;height:150px;border-radius:50%;background-color:#e8e8e8;display:flex;align-items:center;justify-content:center;color:#787774;font-size:.9rem;font-weight:500;border:3px solid #ffffff;box-shadow:0 2px 8px #0000001a;overflow:hidden}.profile-image-placeholder img{width:100%;height:100%;object-fit:cover;object-position:top}.profile-info{text-align:center}.profile-name{font-size:1.5rem;font-weight:600;margin:0 0 8px;color:#37352f}.profile-title{font-size:1rem;color:#787774;margin:0 0 16px;font-weight:500}.profile-description{font-size:.9rem;line-height:1.5;color:#37352f;margin:0}.sidebar-content{border-top:1px solid #e8e8e8;padding-top:32px}.career-info h3{font-size:1.1rem;font-weight:600;margin:0 0 20px;color:#37352f}.career-item{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.career-item:last-child{border-bottom:none;margin-bottom:0}.career-company{font-size:1rem;font-weight:600;color:#37352f;margin-bottom:4px}.career-period{font-size:.9rem;color:#787774;margin-bottom:4px}.career-note{font-size:.65rem;color:#787774;font-style:italic}.contact-info h3{font-size:1.1rem;font-weight:600;margin:0 0 20px;color:#37352f}.contact-item{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-size:.9rem;color:#37352f}.contact-icon{font-size:1rem;width:20px;text-align:center}.contact-link{color:#2e75cc;text-decoration:none;font-weight:500}.contact-link:hover{text-decoration:underline}@media (max-width: 1024px){.sidebar{width:240px;padding:32px 20px}.profile-image-placeholder{width:100px;height:100px;font-size:.8rem}.profile-name{font-size:1.3rem}}@media (max-width: 768px){.sidebar{position:static;width:100%;height:auto;padding:24px 20px;border-right:none;border-bottom:1px solid #e8e8e8}.profile-image-placeholder{width:80px;height:80px;font-size:.7rem}.profile-name{font-size:1.2rem}.sidebar-content{padding-top:24px}}.layout{min-height:100vh;background-color:#fff}.main-content{margin-left:280px;margin-top:60px;min-height:calc(100vh - 60px);padding:80px 40px 40px;background-color:#fff}@media (max-width: 1024px){.main-content{margin-left:240px;padding:32px}}@media (max-width: 768px){.main-content{margin-left:0;margin-top:0;padding:24px 20px}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#37352f}#root{min-height:100vh}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.home-page{max-width:1000px;margin:0 auto;padding:0 20px}.welcome-section{margin-bottom:80px;text-align:center}.welcome-title{font-size:2.5rem;font-weight:700;margin:0 0 16px;color:#37352f;line-height:1.2}.welcome-subtitle{font-size:1.25rem;color:#787774;margin:0;font-weight:400}.intro-text{font-size:1.1rem;color:#555;font-weight:400;line-height:1.6;max-width:600px;margin:16px auto 0}.content-section{margin-bottom:80px}.section-title{font-size:1.75rem;font-weight:600;margin:0 0 32px;color:#37352f;padding-bottom:8px;border-bottom:2px solid #e8e8e8;display:flex;align-items:center;gap:8px}.link-icon{font-size:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.info-item{background-color:#fafafa;padding:24px;border-radius:12px;border:1px solid #e8e8e8;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.info-icon{font-size:2rem;margin-bottom:4px}.info-label{font-size:.9rem;color:#787774;margin-bottom:4px}.info-value{font-size:1.1rem;color:#37352f;font-weight:500;line-height:1.4}.info-value-sub{font-size:.8rem}.about-text{font-size:1.1rem;line-height:1.7;margin:0 0 32px;color:#37352f}.key-points{display:grid;gap:24px}.point{display:flex;align-items:flex-start;gap:16px;padding:24px;background-color:#fafafa;border-radius:12px;border:1px solid #e8e8e8}.point-icon{font-size:2rem;flex-shrink:0}.point-content h3{font-size:1.1rem;font-weight:600;margin:0 0 8px;color:#37352f}.point-content p{font-size:.95rem;line-height:1.5;color:#787774;margin:0}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:32px}.skill-category{background-color:#fafafa;padding:24px;border-radius:12px;border:1px solid #e8e8e8}.category-title{font-size:1.25rem;font-weight:600;margin:0 0 20px;color:#37352f}.skill-items{display:flex;flex-direction:column;gap:16px}.skill-item{display:flex;flex-direction:column;gap:4px}.skill-name{font-weight:600;color:#37352f;font-size:1rem}.skill-desc{font-size:.9rem;color:#787774;line-height:1.5}.skills-section{background:none;margin-bottom:80px}.skills-box{background:#fcf5e3;border-radius:20px;box-shadow:8px 8px 20px #0000001a;padding:28px 18px;max-width:1000px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.skills-row{display:flex;align-items:center;gap:20px;margin-bottom:0}.skills-label{min-width:90px;font-weight:600;font-size:1rem;color:#222;display:flex;align-items:center;gap:8px}.skills-icon{width:22px;height:22px;vertical-align:middle}.skills-badges{display:flex;flex-wrap:wrap;gap:8px}.badge{display:inline-block;padding:4px 12px;border-radius:8px;font-size:.92rem;font-weight:500;color:#fff;box-shadow:0 2px 8px #00000012;letter-spacing:.01em;margin-bottom:2px}.badge-ts{background:linear-gradient(135deg,#3178c6,#4d8ee6)}.badge-js{background:linear-gradient(135deg,#f7df1e,#ffe066);color:#222}.badge-py{background:linear-gradient(135deg,#3776ab,#5a9fd4)}.badge-react-dark{background:linear-gradient(135deg,#61dafb,#21d4fd);color:#222}.badge-gray{background:linear-gradient(135deg,#6c757d,#8e9aaf)}.badge-blue{background:linear-gradient(135deg,#61dafb,#21d4fd);color:#222}.badge-pink{background:linear-gradient(135deg,#ec4899,#f24b6a)}.badge-dark{background:linear-gradient(135deg,#232b36,#374151)}.badge-lightpink{background:linear-gradient(135deg,#f9a8d4,#e9a6b2);color:#222}.badge-sky{background:linear-gradient(135deg,#0ea5e9,#2ec4f1)}.badge-purple{background:linear-gradient(135deg,#8b5cf6,#c44ec4)}.badge-green{background:linear-gradient(135deg,#059669,#1eae6b)}.badge-yellow{background:linear-gradient(135deg,#f59e0b,#ffb300)}.badge-green2{background:linear-gradient(135deg,#10b981,#3ecf8e)}.badge-orange{background:linear-gradient(135deg,#ea580c,#f90)}.badge-black{background:linear-gradient(135deg,#111827,#1f2937)}.badge-blue2{background:linear-gradient(135deg,#1d4ed8,#217ee6)}.badge-red{background:linear-gradient(135deg,#dc2626,#ef4444)}.badge-indigo{background:linear-gradient(135deg,#4f46e5,#6366f1)}.badge-teal{background:linear-gradient(135deg,#0d9488,#14b8a6)}.badge-amber{background:linear-gradient(135deg,#d97706,#f59e0b)}.badge-lime{background:linear-gradient(135deg,#65a30d,#84cc16)}.badge-emerald{background:linear-gradient(135deg,#047857,#10b981)}.badge-cyan{background:linear-gradient(135deg,#0891b2,#06b6d4)}.badge-violet{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}.badge-fuchsia{background:linear-gradient(135deg,#a21caf,#c026d3)}.badge-rose{background:linear-gradient(135deg,#be185d,#e11d48)}.badge-slate{background:linear-gradient(135deg,#475569,#64748b)}@media (max-width: 900px){.skills-box{padding:16px 4px}.skills-label{min-width:70px;font-size:.92rem}.skills-row{gap:10px}}@media (max-width: 600px){.skills-section{padding:0 0 20px;margin:0}.skills-box{padding:8px 2px;gap:10px}.skills-row{flex-direction:column;align-items:flex-start;gap:6px}.skills-label{min-width:0;font-size:.85rem}.skills-badges{gap:6px}.badge{font-size:.85rem;padding:3px 8px}}@media (max-width: 768px){.home-page{padding:0 16px}.projects-grid{grid-template-columns:1fr;gap:24px}.welcome-section,.content-section,.projects-section{margin-bottom:60px}.welcome-title{font-size:2rem}.welcome-subtitle{font-size:1.1rem}.section-title{font-size:1.5rem}.point{flex-direction:column;text-align:center;gap:12px}.skills-grid{grid-template-columns:1fr;gap:24px}.info-grid{grid-template-columns:repeat(2,1fr);gap:16px}.info-item{padding:16px}}@media (max-width: 480px){.welcome-title{font-size:1.75rem}.section-title{font-size:1.3rem}.point{padding:20px}.info-grid{grid-template-columns:1fr}.info-item{padding:20px}}.projects-section{margin-bottom:80px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:32px;margin-top:32px}.portfolio-page{max-width:1000px;margin:0 auto}.portfolio-page .portfolio-header{margin-bottom:60px;text-align:center}.portfolio-page .portfolio-title{font-size:2.5rem;font-weight:700;margin:0 0 16px;color:#37352f;line-height:1.2}.portfolio-page .portfolio-subtitle{font-size:1.25rem;color:#787774;margin:0;font-weight:400}.portfolio-page .projects-section{margin-bottom:60px}.portfolio-page .projects-grid{display:grid;gap:32px}@media (max-width: 768px){.portfolio-page .portfolio-title{font-size:2rem}.portfolio-page .portfolio-subtitle{font-size:1.1rem}}@media (max-width: 480px){.portfolio-page .portfolio-title{font-size:1.75rem}}.project-card{background-color:#fff;border:1px solid #e8e8e8;border-radius:12px;padding:32px;transition:all .2s ease;box-shadow:0 2px 8px #0000000d}.project-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.project-card .project-header{margin-bottom:20px}.project-card .project-title{font-size:1.5rem;font-weight:600;margin:0 0 12px;color:#37352f;line-height:1.3}.project-card .project-meta{display:flex;gap:16px;margin-bottom:12px;flex-wrap:wrap}.project-card .project-period{background-color:#e8f4fd;color:#2e75cc;padding:4px 12px;border-radius:16px;font-size:.85rem;font-weight:500}.project-card .project-role{background-color:#f0f8f0;color:#1eae6b;padding:4px 12px;border-radius:16px;font-size:.85rem;font-weight:500}.project-card .project-solo{background-color:#fff3cd;color:#856404;padding:4px 12px;border-radius:16px;font-size:.85rem;font-weight:500}.project-card .project-tags{display:flex;gap:8px;flex-wrap:wrap}.project-card .tag{background-color:#f1f1ef;color:#787774;padding:4px 12px;border-radius:16px;font-size:.85rem;font-weight:500}.project-card .project-description{font-size:1rem;line-height:1.6;color:#37352f;margin:0 0 24px}.project-card .project-tech-stack{margin-bottom:48px}.project-card .project-tech-stack h4{font-size:1rem;font-weight:600;margin:0 0 16px;color:#37352f}.project-card .tech-categories{display:flex;flex-direction:column;gap:12px}.project-card .tech-category{display:flex;align-items:flex-start;gap:12px}.project-card .tech-label{font-size:.9rem;font-weight:600;color:#787774;min-width:80px;flex-shrink:0}.project-card .tech-items{display:flex;flex-wrap:wrap;gap:6px}.project-card .tech-item{background-color:#f8f9fa;color:#495057;padding:3px 8px;border-radius:12px;font-size:.8rem;font-weight:500;border:1px solid #e9ecef}.project-card .project-features h4{font-size:1rem;font-weight:600;margin:0 0 12px;color:#37352f}.project-card .project-features ul{margin:0 0 24px;padding-left:20px}.project-card .project-features li{margin-bottom:8px;color:#37352f;font-size:.95rem;line-height:1.5}.project-card .project-links{display:flex;gap:16px}.project-card .project-link{color:#7a7a7a;text-decoration:none;font-weight:500;font-size:.95rem;padding:10px 20px;border:2px solid #b4b4b4;border-radius:8px;transition:all .2s ease;background-color:transparent}.project-card .project-link:hover{background-color:#f3f3f3;color:#7a7a7a;transform:translateY(-2px)}.project-card .project-actions{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:20px}.project-card .details-button{background-color:#37352f;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.project-card .details-button:hover{background-color:#555;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.project-card .details-button:active{transform:translateY(0)}@media (max-width: 768px){.project-card{padding:24px}.project-card .project-title{font-size:1.3rem}.project-card .project-meta,.project-card .tech-category{flex-direction:column;gap:8px}.project-card .tech-label{min-width:auto}.project-card .project-actions{flex-direction:column;gap:12px;align-items:stretch}.project-card .details-button{order:-1}.project-card .project-links{flex-direction:column;gap:12px}}@font-face{font-family:swiper-icons;src:url(data:application/font-woff;charset=utf-8;base64,\ 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);font-weight:400;font-style:normal}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--swiper-navigation-size: 44px}.swiper-button-prev,.swiper-button-next{position:absolute;top:var(--swiper-navigation-top-offset, 50%);width:calc(var(--swiper-navigation-size) / 44 * 27);height:var(--swiper-navigation-size);margin-top:calc(0px - (var(--swiper-navigation-size) / 2));z-index:10;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--swiper-navigation-color, var(--swiper-theme-color))}.swiper-button-prev.swiper-button-disabled,.swiper-button-next.swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}.swiper-button-prev.swiper-button-hidden,.swiper-button-next.swiper-button-hidden{opacity:0;cursor:auto;pointer-events:none}.swiper-navigation-disabled .swiper-button-prev,.swiper-navigation-disabled .swiper-button-next{display:none!important}.swiper-button-prev svg,.swiper-button-next svg{width:100%;height:100%;object-fit:contain;transform-origin:center}.swiper-rtl .swiper-button-prev svg,.swiper-rtl .swiper-button-next svg{transform:rotate(180deg)}.swiper-button-prev,.swiper-rtl .swiper-button-next{left:var(--swiper-navigation-sides-offset, 10px);right:auto}.swiper-button-lock{display:none}.swiper-button-prev:after,.swiper-button-next:after{font-family:swiper-icons;font-size:var(--swiper-navigation-size);text-transform:none!important;letter-spacing:0;font-variant:initial;line-height:1}.swiper-button-prev:after,.swiper-rtl .swiper-button-next:after{content:"prev"}.swiper-button-next,.swiper-rtl .swiper-button-prev{right:var(--swiper-navigation-sides-offset, 10px);left:auto}.swiper-button-next:after,.swiper-rtl .swiper-button-prev:after{content:"next"}.swiper-pagination{position:absolute;text-align:center;transition:.3s opacity;transform:translateZ(0);z-index:10}.swiper-pagination.swiper-pagination-hidden{opacity:0}.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled{display:none!important}.swiper-pagination-fraction,.swiper-pagination-custom,.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal{bottom:var(--swiper-pagination-bottom, 8px);top:var(--swiper-pagination-top, auto);left:0;width:100%}.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transform:scale(.33);position:relative}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{transform:scale(.33)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{transform:scale(.33)}.swiper-pagination-bullet{width:var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));height:var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));display:inline-block;border-radius:var(--swiper-pagination-bullet-border-radius, 50%);background:var(--swiper-pagination-bullet-inactive-color, #000);opacity:var(--swiper-pagination-bullet-inactive-opacity, .2)}button.swiper-pagination-bullet{border:none;margin:0;padding:0;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}.swiper-pagination-bullet:only-child{display:none!important}.swiper-pagination-bullet-active{opacity:var(--swiper-pagination-bullet-opacity, 1);background:var(--swiper-pagination-color, var(--swiper-theme-color))}.swiper-vertical>.swiper-pagination-bullets,.swiper-pagination-vertical.swiper-pagination-bullets{right:var(--swiper-pagination-right, 8px);left:var(--swiper-pagination-left, auto);top:50%;transform:translate3d(0,-50%,0)}.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet{margin:var(--swiper-pagination-bullet-vertical-gap, 6px) 0;display:block}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;transform:translateY(-50%);width:8px}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;transition:.2s transform,.2s top}.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 var(--swiper-pagination-bullet-horizontal-gap, 4px)}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;transform:translate(-50%);white-space:nowrap}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s left}.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s right}.swiper-pagination-fraction{color:var(--swiper-pagination-fraction-color, inherit)}.swiper-pagination-progressbar{background:var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));position:absolute}.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color, var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;transform:scale(0);transform-origin:left top}.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{transform-origin:right top}.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite{width:100%;height:var(--swiper-pagination-progressbar-size, 4px);left:0;top:0}.swiper-vertical>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite{width:var(--swiper-pagination-progressbar-size, 4px);height:100%;left:0;top:0}.swiper-pagination-lock{display:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background-color:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px 16px;border-bottom:1px solid #e8e8e8}.modal-title{font-size:1.75rem;font-weight:600;margin:0;color:#37352f;line-height:1.3}.modal-close{background:none;border:none;font-size:2rem;color:#787774;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{background-color:#f1f1ef;color:#37352f}.modal-body{padding:24px 32px 32px}.modal-meta{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.modal-period{background-color:#e8f4fd;color:#2e75cc;padding:6px 16px;border-radius:20px;font-size:.9rem;font-weight:500}.modal-role{background-color:#f0f8f0;color:#1eae6b;padding:6px 16px;border-radius:20px;font-size:.9rem;font-weight:500}.modal-solo{background-color:#fff3cd;color:#856404;padding:6px 16px;border-radius:20px;font-size:.9rem;font-weight:500}.modal-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}.modal-tag{background-color:#f1f1ef;color:#787774;padding:6px 14px;border-radius:20px;font-size:.9rem;font-weight:500}.modal-section{margin-bottom:32px}.modal-section h3{font-size:1.25rem;font-weight:600;margin:0 0 16px;color:#37352f;padding-bottom:8px;border-bottom:2px solid #e8e8e8}.modal-swiper-container{margin-bottom:16px}.modal-main-swiper{width:100%;height:350px;margin-bottom:16px;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.modal-main-swiper .swiper-slide{display:flex;align-items:center;justify-content:center}.modal-image-container{width:100%;height:100%;border-radius:12px;overflow:hidden}.modal-image{width:100%;height:100%;display:block;object-fit:cover}.modal-thumbs-swiper{width:100%;height:80px;margin-top:16px}.modal-thumbs-swiper .swiper-slide{opacity:.6;transition:opacity .3s ease;cursor:pointer}.modal-thumbs-swiper .swiper-slide-thumb-active{opacity:1}.modal-thumb-container{width:100%;height:100%;border-radius:8px;overflow:hidden;border:2px solid transparent;transition:border-color .3s ease}.modal-thumbs-swiper .swiper-slide-thumb-active .modal-thumb-container{border-color:#37352f}.modal-thumb{width:100%;height:100%;display:block;object-fit:cover}.modal-main-swiper .swiper-button-next,.modal-main-swiper .swiper-button-prev{color:#37352f;background-color:#ffffffe6;width:40px;height:40px;border-radius:50%;box-shadow:0 2px 8px #0000001a}.modal-main-swiper .swiper-button-next:after,.modal-main-swiper .swiper-button-prev:after{font-size:16px;font-weight:700}.modal-main-swiper .swiper-button-next:hover,.modal-main-swiper .swiper-button-prev:hover{background-color:#fff;box-shadow:0 4px 12px #0003}.modal-description{font-size:1.1rem;line-height:1.7;color:#37352f;margin:0}.modal-tech-categories{display:flex;flex-direction:column;gap:16px}.modal-tech-category{display:flex;align-items:flex-start;gap:16px}.modal-tech-label{font-size:1rem;font-weight:600;color:#787774;min-width:100px;flex-shrink:0}.modal-tech-items{display:flex;flex-wrap:wrap;gap:8px}.modal-tech-item{background-color:#f8f9fa;color:#495057;padding:6px 12px;border-radius:16px;font-size:.9rem;font-weight:500;border:1px solid #e9ecef}.modal-features{margin:0;padding-left:24px}.modal-features li{margin-bottom:12px;color:#37352f;font-size:1rem;line-height:1.6}.modal-links{display:flex;gap:16px;flex-wrap:wrap}.modal-link{color:#7a7a7a;text-decoration:none;font-weight:500;font-size:1rem;padding:12px 24px;border:2px solid #d4d4d4;border-radius:10px;transition:all .2s ease;background-color:transparent;display:inline-block}.modal-link:hover{background-color:#111;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2e75cc4d}@media (max-width: 768px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-header{padding:20px 24px 12px}.modal-title{font-size:1.5rem}.modal-body{padding:20px 24px 24px}.modal-meta,.modal-tech-category{flex-direction:column;gap:8px}.modal-tech-label{min-width:auto}.modal-links{flex-direction:column;gap:12px}.modal-link{text-align:center}.modal-main-swiper{height:200px}.modal-thumbs-swiper{height:60px}.modal-thumbs-swiper .swiper-slide{width:60px!important}}@media (max-width: 480px){.modal-header{padding:16px 20px 8px}.modal-title{font-size:1.3rem}.modal-body{padding:16px 20px 20px}.modal-section{margin-bottom:24px}.modal-section h3{font-size:1.1rem}.modal-description{font-size:1rem}}.career-page{max-width:1000px;margin:0 auto}.career-page .career-list{display:flex;flex-direction:column;gap:32px}.career-page .career-card{background:#fff;border-radius:16px;box-shadow:0 4px 16px #22223b14;padding:32px 24px;transition:box-shadow .2s}.career-page .career-card:hover{box-shadow:0 8px 32px #22223b29}.career-page .career-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.career-page .career-company{font-size:1.3rem;font-weight:600;color:#4361ee}.career-page .career-period{font-size:1rem;color:#adb5bd}.career-page .career-duration{font-size:.95em;color:#4ea8de;margin-left:4px}.career-page .career-position{font-size:1.1rem;font-weight:500;margin-bottom:12px;color:#22223b}.career-page .career-tasks{margin:0 0 16px;padding-left:18px;color:#495057;font-size:1rem;line-height:1.7}.career-page .career-tasks li{margin-bottom:4px;list-style:disc}.career-page .career-footer{display:flex;justify-content:space-between;align-items:center;font-size:.98rem;color:#495057;border-top:1px solid #e9ecef;padding-top:20px;margin-top:20px}.career-page .career-note{color:#e07a5f;font-weight:500;margin-left:12px}.career-page .career-sections{display:flex;flex-direction:column;gap:8px}.career-page .career-section-title{font-weight:600;font-size:16px}.career-page .career-section-details{font-size:14px}
