@charset "UTF-8";*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-size:1rem;line-height:1.6;color:#000000e0;background-color:#fafafa;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:inherit;text-decoration:none;transition:color .2s cubic-bezier(.4,0,.2,1)}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;background:none}ul,ol{list-style:none}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:70px}.container-custom{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}@media (max-width: 768px){.container-custom{padding:0 16px}}.navbar{position:fixed;top:0;left:0;right:0;height:70px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #f0f0f0;z-index:1000;transition:all .2s cubic-bezier(.4,0,.2,1)}.navbar .navbar-container{height:100%;display:flex;align-items:center;justify-content:space-between}.navbar .navbar-brand{font-size:1.25rem;font-weight:600;color:#000000e0;transition:color .2s cubic-bezier(.4,0,.2,1)}.navbar .navbar-brand:hover{color:#7b2ffd}.navbar .navbar-menu{display:flex;align-items:center;gap:32px}@media (max-width: 768px){.navbar .navbar-menu{display:none}}.navbar .navbar-menu .nav-link{color:#000000a6;font-size:.95rem;font-weight:500;padding:8px 0;position:relative;transition:color .2s cubic-bezier(.4,0,.2,1)}.navbar .navbar-menu .nav-link:hover,.navbar .navbar-menu .nav-link.active{color:#7b2ffd}.navbar .navbar-menu .nav-link.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:#7b2ffd;border-radius:2px}.navbar .navbar-toggle{display:none;flex-direction:column;gap:5px;padding:8px}@media (max-width: 768px){.navbar .navbar-toggle{display:flex}}.navbar .navbar-toggle .toggle-bar{width:24px;height:2px;background:#000000e0;border-radius:2px;transition:all .2s cubic-bezier(.4,0,.2,1)}.navbar .navbar-mobile-menu{display:none;position:absolute;top:70px;left:0;right:0;background:#fff;border-bottom:1px solid #f0f0f0;padding:16px 24px;box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}@media (max-width: 768px){.navbar .navbar-mobile-menu{display:block}}.navbar .navbar-mobile-menu .mobile-nav-link{display:block;padding:12px 0;color:#000000a6;font-size:1rem;border-bottom:1px solid #f0f0f0}.navbar .navbar-mobile-menu .mobile-nav-link:last-child{border-bottom:none}.navbar .navbar-mobile-menu .mobile-nav-link:hover{color:#7b2ffd}.footer{background:#fff;border-top:1px solid #f0f0f0;padding:40px 0;margin-top:auto}.footer .footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}@media (max-width: 768px){.footer .footer-content{flex-direction:column;text-align:center}}.footer .footer-text{color:#00000073;font-size:.9rem}.footer .footer-links{display:flex;gap:24px}.footer .footer-links a{color:#000000a6;font-size:.9rem}.footer .footer-links a:hover{color:#7b2ffd}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 24px;font-size:.95rem;font-weight:500;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;border:none;text-decoration:none}.btn.btn-primary{background:#7b2ffd;color:#fff}.btn.btn-primary:hover{background:#9b6dfe;transform:translateY(-1px);box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a}.btn.btn-primary:active{transform:translateY(0)}.btn.btn-outline{background:transparent;border:1px solid #e8e8e8;color:#000000e0}.btn.btn-outline:hover{border-color:#7b2ffd;color:#7b2ffd;background:#7b2ffd0a}.btn.btn-ghost{background:transparent;color:#000000a6}.btn.btn-ghost:hover{color:#7b2ffd;background:#7b2ffd0a}.btn.btn-lg{padding:14px 32px;font-size:1.05rem}.btn.btn-sm{padding:6px 16px;font-size:.875rem}.card{background:#fff;border-radius:12px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden}.card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a}.card .card-image{width:100%;height:200px;object-fit:cover;transition:transform .2s cubic-bezier(.4,0,.2,1)}.card .card-image--placeholder{background:linear-gradient(135deg,#7b2ffd26,#fafafaf2)}.card .card-body{padding:20px}.card .card-category{display:inline-block;padding:4px 12px;background:#7b2ffd14;color:#7b2ffd;border-radius:20px;font-size:.8rem;font-weight:500;margin-bottom:12px}.card .card-title{font-size:1.15rem;font-weight:600;color:#000000e0;margin-bottom:12px;line-height:1.4}@media (min-width: 768px){.card .card-title{font-size:1.25rem}}.card .card-excerpt{color:#000000a6;font-size:.95rem;line-height:1.6;margin-bottom:16px}.card .card-footer{padding:16px 20px;border-top:1px solid #f0f0f0;background:transparent}.card .card-meta{display:flex;align-items:center;gap:16px;color:#00000073;font-size:.85rem}.hero{text-align:center;padding:80px 24px;background:linear-gradient(135deg,#7b2ffd0d,#7b2ffd05);border-radius:16px;margin-bottom:48px;position:relative;overflow:hidden}@media (min-width: 768px){.hero{padding:100px 40px}}.hero.hero-with-landscape{background-image:url(/landscape.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;min-height:500px;display:flex;align-items:center;justify-content:center}@media (min-width: 768px){.hero.hero-with-landscape{min-height:600px}}.hero.hero-with-landscape .hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#ffffffd9,#fff3,#ffffff1a);z-index:1}.hero.hero-with-landscape .hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto}.hero.hero-with-landscape .hero-content .hero-buttons{display:flex;gap:16px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:32px}@media (max-width: 767.98px){.hero.hero-with-landscape .hero-content .hero-buttons{flex-direction:column;gap:12px;margin-top:24px}}.hero.hero-with-landscape .hero-content .btn-icon{width:18px;height:18px;margin-left:8px;transition:transform .2s cubic-bezier(.4,0,.2,1)}.hero.hero-with-landscape .hero-content .btn:hover .btn-icon{transform:translate(4px)}.hero.hero-with-landscape .hero-title{color:#000000e0;text-shadow:0 2px 8px rgba(255,255,255,.5)}.hero.hero-with-landscape .hero-subtitle{color:#000000a6;text-shadow:0 1px 4px rgba(255,255,255,.5)}.hero.hero-with-image{display:grid;grid-template-columns:1fr;gap:40px;align-items:center;text-align:left}@media (min-width: 992px){.hero.hero-with-image{grid-template-columns:1fr 1fr;gap:60px}}.hero.hero-with-image .hero-content{order:2}@media (min-width: 992px){.hero.hero-with-image .hero-content{order:1;text-align:left}}.hero.hero-with-image .hero-image-wrapper{order:1;margin-bottom:24px}@media (min-width: 992px){.hero.hero-with-image .hero-image-wrapper{order:2;margin-bottom:0}}.hero.hero-with-image .hero-image-wrapper .hero-image{width:100%;height:auto;border-radius:16px;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a;object-fit:cover;aspect-ratio:16/9}@media (min-width: 768px){.hero.hero-with-image .hero-image-wrapper .hero-image{aspect-ratio:2/1}}@media (min-width: 992px){.hero.hero-with-image .hero-image-wrapper .hero-image{aspect-ratio:16/9;max-height:400px}}.hero.hero-with-image .hero-title{text-align:center}@media (min-width: 992px){.hero.hero-with-image .hero-title{text-align:left}}.hero.hero-with-image .hero-subtitle{text-align:center}@media (min-width: 992px){.hero.hero-with-image .hero-subtitle{text-align:left}}.hero .hero-title{font-size:2rem;font-weight:700;color:#000000e0;margin-bottom:16px}@media (min-width: 768px){.hero .hero-title{font-size:3rem}}.hero .hero-subtitle{font-size:1.05rem;color:#000000a6;max-width:600px;margin:0 auto 32px;line-height:1.8}@media (min-width: 768px){.hero .hero-subtitle{font-size:1.2rem}}.hero.hero-banner{border-radius:0;margin-bottom:0;padding:0;min-height:60vh;display:flex;align-items:center;justify-content:center}@media (min-width: 768px){.hero.hero-banner{min-height:80vh}}@media (min-width: 1024px){.hero.hero-banner{min-height:90vh}}.hero.hero-banner .hero-banner-image{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0}.hero.hero-banner .hero-banner-image .banner-image{width:100%;height:100%;object-fit:cover;object-position:center}.hero.hero-banner .hero-banner-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#7b2ffdb3,#7b2ffd80,#7b2ffdb3);z-index:1}.hero.hero-banner .hero-banner-content{position:relative;z-index:2;text-align:center;max-width:900px;padding:60px 24px}@media (min-width: 768px){.hero.hero-banner .hero-banner-content{padding:80px 24px}}.hero.hero-banner .hero-title{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:20px;text-shadow:0 4px 16px rgba(0,0,0,.3)}@media (min-width: 768px){.hero.hero-banner .hero-title{font-size:3.5rem}}@media (min-width: 1024px){.hero.hero-banner .hero-title{font-size:4rem}}.hero.hero-banner .hero-subtitle{font-size:1.15rem;color:#fffffff2;max-width:700px;margin:0 auto 40px;line-height:1.8;text-shadow:0 2px 8px rgba(0,0,0,.3)}@media (min-width: 768px){.hero.hero-banner .hero-subtitle{font-size:1.35rem}}.page-wrapper{min-height:100vh;display:flex;flex-direction:column}.page-header{margin-bottom:40px}.page-header .page-title{font-size:2rem;font-weight:700;color:#000000e0;margin-bottom:8px}@media (min-width: 768px){.page-header .page-title{font-size:2.5rem}}.page-header .page-subtitle{color:#00000073;font-size:1rem}.module-section .module-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f0f0f0}.module-section .module-header .module-title{font-size:1.75rem;font-weight:700;color:#000000e0;margin:0}@media (max-width: 767.98px){.module-section .module-header .module-title{font-size:1.5rem}}.module-section .module-header .module-link{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;color:#7b2ffd;font-size:.95rem;font-weight:500;background:#7b2ffd0a;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none}.module-section .module-header .module-link:hover{background:#7b2ffd14;color:#5a1fd9;transform:translate(4px)}.module-section .module-header .module-link:hover .link-icon{transform:translate(4px)}.module-section .module-header .module-link .link-icon{width:18px;height:18px;transition:transform .2s cubic-bezier(.4,0,.2,1)}@media (max-width: 767.98px){.module-section .module-header .module-link{padding:6px 12px;font-size:.9rem}.module-section .module-header .module-link span{display:none}}.module-section .module-content .empty-state{padding:60px 24px;background:#fff;border-radius:16px;border:1px solid #f0f0f0}@media (max-width: 767.98px){.module-section .module-content .empty-state{padding:40px 16px}}.portfolio-card-preview .tech-stack{margin-top:12px;padding-top:12px;border-top:1px solid #f0f0f0;font-size:.85rem}.portfolio-card-preview .tech-stack .tech-label{color:#00000073;margin-right:4px}.portfolio-card-preview .tech-stack .tech-value{color:#7b2ffd;font-weight:500}.note-card-preview .note-content-preview{color:#000000a6;font-size:.95rem;line-height:1.6;margin-bottom:12px}.note-card-preview .note-tags{display:flex;gap:6px;flex-wrap:wrap}.note-card-preview .note-tags .tag-sm{padding:3px 10px;font-size:.75rem}.grid{display:grid;gap:24px}.grid.grid-1,.grid.grid-2{grid-template-columns:repeat(1,1fr)}@media (min-width: 640px){.grid.grid-2{grid-template-columns:repeat(2,1fr)}}.grid.grid-3{grid-template-columns:repeat(1,1fr)}@media (min-width: 640px){.grid.grid-3{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.grid.grid-3{grid-template-columns:repeat(3,1fr)}}.input,.select{width:100%;padding:12px 16px;font-size:.95rem;border:1px solid #e8e8e8;border-radius:8px;background:#fff;color:#000000e0;transition:all .2s cubic-bezier(.4,0,.2,1)}.input:hover,.select:hover{border-color:#7b2ffd}.input:focus,.select:focus{outline:none;border-color:#7b2ffd;box-shadow:0 0 0 3px #7b2ffd14}.input::placeholder,.select::placeholder{color:#00000040}.select{cursor:pointer}.tag{display:inline-block;padding:4px 12px;background:#7b2ffd14;color:#7b2ffd;border-radius:20px;font-size:.8rem;font-weight:500}.breadcrumb{display:flex;align-items:center;gap:8px;padding:16px 0;margin-bottom:24px;flex-wrap:wrap}.breadcrumb .breadcrumb-item{color:#00000073;font-size:.9rem}.breadcrumb .breadcrumb-item a{color:#000000a6}.breadcrumb .breadcrumb-item a:hover{color:#7b2ffd}.breadcrumb .breadcrumb-item.active{color:#000000e0}.breadcrumb .breadcrumb-item+.breadcrumb-item:before{content:"/";margin-right:8px;color:#00000040}.article-card{background:#fff;border-radius:16px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;overflow:hidden}.article-card .article-cover{width:100%;height:400px;object-fit:cover}@media (max-width: 768px){.article-card .article-cover{height:250px}}.article-card .article-body{padding:40px}@media (max-width: 768px){.article-card .article-body{padding:24px}}.article-card .article-header{margin-bottom:32px}.article-card .article-meta{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.article-card .article-title{font-size:2rem;font-weight:700;color:#000000e0;line-height:1.3;margin-bottom:16px}@media (max-width: 768px){.article-card .article-title{font-size:1.5rem}}.article-card .article-content{color:#000000e0;line-height:1.8;font-size:1.05rem}.article-card .article-content p{margin-bottom:20px;line-height:1.8}.article-card .article-content h1,.article-card .article-content h2,.article-card .article-content h3,.article-card .article-content h4,.article-card .article-content h5,.article-card .article-content h6{margin-top:32px;margin-bottom:16px;font-weight:600;line-height:1.4;color:#000000e6}.article-card .article-content h1:first-child,.article-card .article-content h2:first-child,.article-card .article-content h3:first-child,.article-card .article-content h4:first-child,.article-card .article-content h5:first-child,.article-card .article-content h6:first-child{margin-top:0}.article-card .article-content h1{font-size:2rem;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.article-card .article-content h2{font-size:1.75rem;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.article-card .article-content h3{font-size:1.5rem}.article-card .article-content h4{font-size:1.25rem}.article-card .article-content h5{font-size:1.1rem}.article-card .article-content h6{font-size:1rem;color:#000000a6}.article-card .article-content a{color:#7b2ffd;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1)}.article-card .article-content a:hover{color:#9b6dfe;text-decoration:underline}.article-card .article-content ul,.article-card .article-content ol{margin-bottom:20px;padding-left:32px}.article-card .article-content ul li,.article-card .article-content ol li{margin-bottom:8px;line-height:1.8}.article-card .article-content ul{list-style-type:disc}.article-card .article-content ul ul{list-style-type:circle}.article-card .article-content ul ul ul{list-style-type:square}.article-card .article-content ol{list-style-type:decimal}.article-card .article-content ol ol{list-style-type:lower-alpha}.article-card .article-content ol ol ol{list-style-type:lower-roman}.article-card .article-content blockquote{margin:24px 0;padding:12px 20px;background-color:#f8f9fa;border-left:4px solid #7B2FFD;color:#000000a6;font-style:italic}.article-card .article-content blockquote p{margin-bottom:0}.article-card .article-content blockquote cite{display:block;margin-top:8px;font-size:.9em;color:#00000073}.article-card .article-content code{padding:2px 6px;background-color:#f5f5f5;border-radius:4px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;font-size:.9em;color:#e83e8c}.article-card .article-content pre{margin:24px 0;padding:16px 20px;background-color:#282c34;border-radius:8px;overflow-x:auto}.article-card .article-content pre code{padding:0;background-color:transparent;color:#abb2bf;font-size:.9rem;line-height:1.6}.article-card .article-content img{max-width:100%;height:auto;margin:24px 0;border-radius:8px;box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005;display:block}.article-card .article-content table{width:100%;margin:24px 0;border-collapse:collapse;border-spacing:0;border-radius:8px;overflow:hidden;box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}.article-card .article-content table thead{background-color:#f8f9fa}.article-card .article-content table thead th{padding:12px 16px;text-align:left;font-weight:600;color:#000000e0;border-bottom:2px solid #e8e8e8}.article-card .article-content table tbody tr{transition:background-color .2s cubic-bezier(.4,0,.2,1)}.article-card .article-content table tbody tr:hover{background-color:#f8f9fa}.article-card .article-content table tbody tr td{padding:12px 16px;border-bottom:1px solid #f0f0f0}.article-card .article-content table tbody tr:last-child td{border-bottom:none}.article-card .article-content hr{margin:32px 0;border:none;border-top:2px solid #f0f0f0}.article-card .article-content strong{font-weight:600;color:#000000e6}.article-card .article-content em{font-style:italic}.article-card .article-content del,.article-card .article-content s{color:#00000073}.article-card .article-content sup,.article-card .article-content sub{font-size:.75em;vertical-align:baseline}.article-card .article-content sup{vertical-align:super}.article-card .article-content sub{vertical-align:sub}.article-card .article-content video{max-width:100%;margin:24px 0;border-radius:8px;box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}.article-card .article-content iframe{width:100%;margin:24px 0;border:none;border-radius:8px;box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}.article-card .article-content>*:first-child{margin-top:0}.article-card .article-content>*:last-child{margin-bottom:0}.loading{display:flex;align-items:center;justify-content:center;padding:80px 24px}.loading .spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#7b2ffd;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:80px 24px}.empty-state .empty-icon{font-size:4rem;margin-bottom:16px;opacity:.5}.empty-state .empty-text{color:#00000073;font-size:1.05rem}.visible-mobile{display:none}@media (max-width: 767.98px){.visible-mobile{display:block}}@media (max-width: 767.98px){.hidden-mobile{display:none}}.text-center{text-align:center}.text-primary{color:#7b2ffd}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mt-5{margin-top:48px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.mb-5{margin-bottom:48px}.py-1{padding-top:8px;padding-bottom:8px}.py-2{padding-top:16px;padding-bottom:16px}.py-3{padding-top:24px;padding-bottom:24px}.py-4{padding-top:32px;padding-bottom:32px}.py-5{padding-top:48px;padding-bottom:48px}.portfolio-grid{display:grid;gap:16px;grid-template-columns:repeat(1,1fr)}@media (min-width: 576px){.portfolio-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media (min-width: 992px){.portfolio-grid{grid-template-columns:repeat(3,1fr);gap:20px}}@media (min-width: 1200px){.portfolio-grid{grid-template-columns:repeat(4,1fr);gap:24px}}.portfolio-card{background:#fff;border-radius:12px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden;display:flex;flex-direction:column}@media (max-width: 575.98px){.portfolio-card .portfolio-cover{width:100%;height:200px;object-fit:cover}.portfolio-card .portfolio-excerpt{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.9rem}.portfolio-card .portfolio-techs{gap:8px}.portfolio-card .portfolio-techs .tag{font-size:14px;padding:4px 10px}}@media (min-width: 576px) and (max-width: 991.98px){.portfolio-card:hover{transform:translateY(-3px);border-color:#d4af37;box-shadow:0 4px 12px #d4af374d}}@media (min-width: 992px){.portfolio-card:hover{transform:translateY(-5px) rotateX(2deg);box-shadow:0 8px 24px #7b2ffd33,0 4px 12px #7b2ffd26;border-color:#7b2ffd}}.portfolio-card .portfolio-cover{width:100%;height:200px;object-fit:cover;transition:transform .2s cubic-bezier(.4,0,.2,1)}.portfolio-card .portfolio-body{padding:16px;flex:1;display:flex;flex-direction:column;gap:8px}@media (min-width: 992px){.portfolio-card .portfolio-body{padding:20px;gap:10px}}.portfolio-card .portfolio-category{display:inline-flex;align-items:center;padding:4px 12px;background:#7b2ffd14;color:#7b2ffd;border-radius:20px;font-size:.8rem;font-weight:500;width:fit-content;max-width:100%}.portfolio-card .portfolio-title{font-size:1.15rem;font-weight:600;color:#000000e0;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media (min-width: 992px){.portfolio-card .portfolio-title{font-size:1.25rem}}.portfolio-card .portfolio-excerpt{color:#000000a6;font-size:.9rem;line-height:1.6;margin-bottom:12px;flex:1}.portfolio-card .portfolio-techs{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}.portfolio-card .portfolio-actions{display:flex;border-top:1px solid #f0f0f0}.portfolio-card .portfolio-actions .btn-view-detail{flex:1;display:block;text-align:center;padding:12px;color:#000000a6;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;border-right:1px solid #f0f0f0}.portfolio-card .portfolio-actions .btn-view-detail:hover{background:#7b2ffd0a;color:#7b2ffd}.portfolio-card .portfolio-actions .btn-view-detail:last-child{border-right:none}.portfolio-card .portfolio-actions .portfolio-link{flex:1;display:block;text-align:center;padding:12px;color:#7b2ffd;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none}.portfolio-card .portfolio-actions .portfolio-link:hover{background:#7b2ffd0a}.portfolio-card .portfolio-actions:only-child .btn-view-detail,.portfolio-card .portfolio-actions:only-child .portfolio-link{border-right:none}.portfolio-filter-section{background:#fff;border-radius:16px;padding:20px 24px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a}@media (max-width: 767.98px){.portfolio-filter-section{padding:16px;border-radius:12px}}.portfolio-filter-section .filter-label{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:.95rem;font-weight:600;color:#000000e0}.portfolio-filter-section .filter-label .filter-icon{width:18px;height:18px;color:#7b2ffd}@media (max-width: 767.98px){.portfolio-filter-section .filter-label{font-size:.9rem;margin-bottom:12px}.portfolio-filter-section .filter-label .filter-icon{width:16px;height:16px}}.portfolio-filter-section .filter-buttons{display:flex;gap:10px;flex-wrap:wrap}@media (max-width: 767.98px){.portfolio-filter-section .filter-buttons{gap:8px}}.filter-btn{padding:10px 20px;background:#7b2ffd14;color:#000000a6;border:1px solid transparent;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.filter-btn:hover{background:#7b2ffd1f;color:#7b2ffd;transform:translateY(-1px)}.filter-btn.active{background:#7b2ffd;color:#fff;border-color:#7b2ffd;box-shadow:0 2px 8px #7b2ffd4d}.filter-btn.active:hover{background:#5a1fd9;border-color:#5a1fd9}.filter-btn:active{transform:translateY(0)}.filter-btn.clear-btn{background:#0000001a;color:#000000a6}.filter-btn.clear-btn:hover{background:#00000026;color:#000000e0}@media (max-width: 767.98px){.filter-btn{padding:8px 16px;font-size:.9rem;flex:1;min-width:calc(50% - 4px);text-align:center}}@media (max-width: 479.98px){.filter-btn{min-width:100%}}.filter-hint{margin-top:12px;padding:8px 12px;background:#7b2ffd0d;border-radius:8px;font-size:.85rem;color:#7b2ffd;text-align:right}@media (max-width: 767.98px){.filter-hint{margin-top:10px;font-size:.8rem}}.notes-filter-section{background:#fff;border-radius:16px;padding:20px 24px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;display:flex;align-items:center;gap:16px}@media (max-width: 767.98px){.notes-filter-section{padding:16px;border-radius:12px;flex-direction:column;align-items:flex-start;gap:12px}}.notes-filter-section .filter-label{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:#000000e0;white-space:nowrap}.notes-filter-section .filter-label .filter-icon{width:18px;height:18px;color:#7b2ffd}@media (max-width: 767.98px){.notes-filter-section .filter-label{font-size:.9rem}}.notes-filter-section .filter-dropdown{position:relative;flex:1;max-width:280px}@media (max-width: 767.98px){.notes-filter-section .filter-dropdown{max-width:100%}}.notes-filter-section .filter-dropdown .dropdown-trigger{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#fff;border:2px solid #e8e8e8;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.notes-filter-section .filter-dropdown .dropdown-trigger:hover{border-color:#7b2ffd}.notes-filter-section .filter-dropdown .dropdown-trigger .selected-value{font-size:.95rem;font-weight:500;color:#000000e0}.notes-filter-section .filter-dropdown .dropdown-trigger .dropdown-arrow{width:18px;height:18px;margin-left:8px;color:#000000a6;transition:transform .2s cubic-bezier(.4,0,.2,1)}.notes-filter-section .filter-dropdown .dropdown-trigger .dropdown-arrow.arrow-up{transform:rotate(180deg)}.custom-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 4px 16px #0000001f;z-index:1000;overflow:hidden;animation:dropdownSlideIn .2s ease}.custom-dropdown-menu .dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;color:#000000e0;font-size:.95rem;cursor:pointer;transition:all .15s ease}.custom-dropdown-menu .dropdown-item:hover{background:#7b2ffd0a;color:#7b2ffd}.custom-dropdown-menu .dropdown-item.active{background:#7b2ffd14;color:#7b2ffd;font-weight:500}.custom-dropdown-menu .dropdown-item.active .check-icon{opacity:1;transform:scale(1)}.custom-dropdown-menu .dropdown-item .check-icon{width:16px;height:16px;opacity:0;transform:scale(.8);transition:all .2s cubic-bezier(.4,0,.2,1)}.custom-dropdown-menu .dropdown-item:not(:last-child){border-bottom:1px solid #f0f0f0}.notes-layout{display:grid;gap:24px;grid-template-columns:repeat(1,1fr)}@media (max-width: 575.98px){.notes-layout .notes-content{width:100%}.notes-layout .notes-content img{max-width:100%;height:auto;border-radius:8px}.notes-layout .notes-content pre,.notes-layout .notes-content code{font-size:16px;line-height:2}.notes-layout .category-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px}.notes-layout .category-tabs .tab-btn{min-width:44px;height:44px;padding:0 16px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:14px;white-space:nowrap}}@media (min-width: 576px) and (max-width: 991.98px){.notes-layout{grid-template-columns:repeat(2,1fr);gap:16px}.notes-layout .notes-content pre,.notes-layout .notes-content code{font-size:14px}}@media (min-width: 992px){.notes-layout{grid-template-columns:repeat(3,1fr);gap:24px}}@media (min-width: 992px) and (min-width: 1200px){.notes-layout{grid-template-columns:repeat(4,1fr)}}.note-card{background:#fff;border-radius:12px;border:1px solid #f0f0f0;padding:0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.note-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a}.note-card:hover .note-cover{transform:scale(1.05)}.note-card .note-cover{width:100%;height:200px;object-fit:cover;transition:transform .2s cubic-bezier(.4,0,.2,1);border-radius:12px 12px 0 0}.note-card .note-header{padding:20px 20px 0;display:flex;flex-direction:column;gap:6px}.note-card .note-header .note-category{display:inline-flex;align-items:center;padding:4px 12px;background:#7b2ffd14;color:#7b2ffd;border-radius:20px;font-size:.8rem;font-weight:500;width:fit-content}.note-card .note-header .note-title{font-size:1.15rem;font-weight:600;color:#000000e0;line-height:1.4;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.note-card .note-header .note-meta{font-size:.85rem;color:#00000073}.note-card .note-content{padding:0 20px;color:#000000a6;line-height:1.6;font-size:.95rem;flex:1}.note-card .note-content p{margin:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.note-card .note-content img{max-width:100%;height:auto;border-radius:8px;margin:16px 0}.note-card .note-content pre{background:#f5f5f5;padding:16px;border-radius:8px;overflow-x:auto;margin:16px 0;font-family:Consolas,Monaco,monospace;font-size:14px;line-height:1.6}.note-card .note-content pre code{font-family:inherit}.note-card .note-content code{background:#7b2ffd14;padding:2px 6px;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:.9em}.note-card .note-content pre code{background:transparent;padding:0}.note-card .note-footer{margin-top:16px;padding:16px 20px 20px;border-top:1px solid #f0f0f0;display:flex;justify-content:space-between;align-items:center}.category-filter{margin-bottom:32px}.category-filter.mobile-mode .category-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:thin}.category-filter.mobile-mode .category-tabs::-webkit-scrollbar{height:4px}.category-filter.mobile-mode .category-tabs::-webkit-scrollbar-thumb{background:#e8e8e8;border-radius:2px}.category-filter.mobile-mode .sidebar-filter,.category-filter.desktop-mode .category-tabs{display:none}.category-filter.desktop-mode .sidebar-filter{display:block}.category-filter.desktop-mode .sidebar-filter .filter-group{background:#fff;border:1px solid #f0f0f0;border-radius:12px;padding:20px;margin-bottom:16px}.category-filter.desktop-mode .sidebar-filter .filter-group .filter-title{font-size:1rem;font-weight:600;color:#000000e0;margin-bottom:12px}.category-filter.desktop-mode .sidebar-filter .filter-group .filter-list{list-style:none;padding:0;margin:0}.category-filter.desktop-mode .sidebar-filter .filter-group .filter-list li{margin-bottom:8px}.category-filter.desktop-mode .sidebar-filter .filter-group .filter-list li button{width:100%;text-align:left;padding:8px 12px;border-radius:8px;color:#000000a6;transition:all .2s cubic-bezier(.4,0,.2,1)}.category-filter.desktop-mode .sidebar-filter .filter-group .filter-list li button:hover{background:#7b2ffd0a;color:#7b2ffd}.category-filter.desktop-mode .sidebar-filter .filter-group .filter-list li button.active{background:#7b2ffd14;color:#7b2ffd;font-weight:500}.tab-btn{background:#fff;border:1px solid #e8e8e8;color:#000000a6;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.tab-btn:hover{border-color:#7b2ffd;color:#7b2ffd}.tab-btn.active{background:#7b2ffd;border-color:#7b2ffd;color:#fff}.interests-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}@media (max-width: 575.98px){.interests-grid{grid-template-columns:repeat(1,1fr);gap:16px}}.interest-card{background:#fff;border-radius:16px;border:1px solid #f0f0f0;padding:24px;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a;transition:all .2s cubic-bezier(.4,0,.2,1);text-align:center}.interest-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a;border-color:#7b2ffd}.interest-card .interest-icon{font-size:3rem;margin-bottom:16px;display:block}.interest-card .interest-title{font-size:1.2rem;font-weight:600;color:#000000e0;margin-bottom:12px}.interest-card .interest-description{color:#000000a6;line-height:1.6;margin-bottom:16px}.interest-card .interest-tags{display:flex;justify-content:center;flex-wrap:wrap;gap:8px}.code-highlight .keyword{color:#d73a49}.code-highlight .string{color:#032f62}.code-highlight .number{color:#005cc5}.code-highlight .comment{color:#6a737d;font-style:italic}.code-highlight .function{color:#6f42c1}.code-highlight .class{color:#22863a}.code-highlight .variable{color:#e36209}.code-highlight .operator{color:#d73a49}.code-with-line-numbers pre{position:relative;padding-left:50px}.code-with-line-numbers pre:before{content:"";position:absolute;left:0;top:0;bottom:0;width:40px;background:#0000000d;border-right:1px solid #e8e8e8}.search-filter-container{display:grid;gap:16px;grid-template-columns:1fr}@media (min-width: 768px){.search-filter-container{grid-template-columns:2fr 1fr;gap:20px}}@media (max-width: 767.98px){.search-filter-container .search-box{order:1}.search-filter-container .filter-box{order:2}}.search-box .search-input-wrapper{display:flex;align-items:stretch;background:#fff;border:2px solid #e8e8e8;border-radius:12px;overflow:hidden;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}.search-box .search-input-wrapper:hover{border-color:#cfcfcf}.search-box .search-input-wrapper:focus-within{border-color:#7b2ffd;box-shadow:0 0 0 3px #7b2ffd14}.search-box .search-input-wrapper .search-input{flex:1;border:none;outline:none;padding:14px 20px;font-size:15px;color:#000000e0;background:transparent}.search-box .search-input-wrapper .search-input::placeholder{color:#00000073}@media (max-width: 767.98px){.search-box .search-input-wrapper .search-input{padding:12px 16px;font-size:14px}}.search-box .search-input-wrapper .search-btn{display:flex;align-items:center;gap:8px;padding:0 24px;background:#7b2ffd;color:#fff;border:none;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.search-box .search-input-wrapper .search-btn:hover{background:#9b6dfe}.search-box .search-input-wrapper .search-btn:active{transform:scale(.98)}.search-box .search-input-wrapper .search-btn .anticon{font-size:16px}@media (max-width: 767.98px){.search-box .search-input-wrapper .search-btn{padding:0 16px}.search-box .search-input-wrapper .search-btn .btn-text{display:none}.search-box .search-input-wrapper .search-btn .anticon{font-size:18px}}.filter-box{display:flex;align-items:center;gap:12px;background:#fff;border:2px solid #e8e8e8;border-radius:12px;padding:0 20px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}.filter-box:hover{border-color:#cfcfcf}.filter-box:focus-within{border-color:#7b2ffd;box-shadow:0 0 0 3px #7b2ffd14}.filter-box .filter-label{display:flex;align-items:center;gap:6px;color:#000000a6;font-size:15px;font-weight:500;white-space:nowrap}.filter-box .filter-label .anticon{font-size:16px;color:#7b2ffd}@media (max-width: 767.98px){.filter-box .filter-label{font-size:14px}.filter-box .filter-label span:last-child{display:none}}.filter-box .filter-select{flex:1;border:none;outline:none;padding:14px 0;font-size:15px;color:#000000e0;background:transparent;cursor:pointer;min-width:120px}.filter-box .filter-select option{padding:8px;font-size:15px}@media (max-width: 767.98px){.filter-box .filter-select{padding:12px 0;font-size:14px;min-width:100px}}.filter-trigger{cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.filter-trigger:hover{opacity:.8}.filter-trigger .selected-value{color:#000000e0;font-weight:500;margin-left:8px}.filter-trigger .dropdown-arrow{width:16px;height:16px;margin-left:8px;transition:transform .2s ease}.filter-trigger .dropdown-arrow.arrow-up{transform:rotate(180deg)}.custom-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 4px 16px #0000001f;z-index:1000;overflow:hidden;animation:dropdownSlideIn .2s ease}.custom-dropdown .dropdown-item{padding:12px 20px;color:#000000e0;font-size:15px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center}.custom-dropdown .dropdown-item:hover{background:#7b2ffd0a;color:#7b2ffd}.custom-dropdown .dropdown-item.active{background:#7b2ffd14;color:#7b2ffd;font-weight:500}.custom-dropdown .dropdown-item.active:before{content:"✓";margin-right:8px;font-size:14px}.custom-dropdown .dropdown-item:not(:last-child){border-bottom:1px solid #f0f0f0}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 767.98px){.custom-dropdown{left:-20px;right:-20px;border-radius:8px}.custom-dropdown .dropdown-item{padding:14px 20px;font-size:14px}}.search-filter-section{background:#fff;border-radius:16px;padding:24px;border:1px solid #f0f0f0;box-shadow:0 2px 8px #0000000f,0 1px 4px #0000000a}@media (max-width: 767.98px){.search-filter-section{padding:16px;border-radius:12px}}.category-buttons{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.category-buttons .category-label{display:flex;align-items:center;gap:8px;font-size:.95rem;font-weight:600;color:#000000e0}.category-buttons .category-label .filter-icon{width:18px;height:18px;color:#7b2ffd}.category-buttons .category-label .clear-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;margin-left:8px;background:transparent;border:1px solid #e8e8e8;border-radius:8px;font-size:.85rem;color:#000000a6;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.category-buttons .category-label .clear-btn svg{width:14px;height:14px}.category-buttons .category-label .clear-btn:hover{background:#7b2ffd0a;border-color:#7b2ffd;color:#7b2ffd}@media (max-width: 767.98px){.category-buttons .category-label{font-size:.9rem;width:100%;margin-bottom:8px}.category-buttons .category-label .filter-icon{width:16px;height:16px}}.category-buttons .category-btn-group{display:flex;gap:8px;flex-wrap:wrap;flex:1}@media (max-width: 767.98px){.category-buttons .category-btn-group{width:100%;gap:6px}}.category-btn{padding:10px 20px;background:#7b2ffd14;color:#000000a6;border:1px solid transparent;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.category-btn .check-icon{width:14px;height:14px;opacity:0;transform:scale(.5);transition:all .2s cubic-bezier(.4,0,.2,1)}.category-btn:hover{background:#7b2ffd1f;color:#7b2ffd;transform:translateY(-1px)}.category-btn.active{background:#7b2ffd;color:#fff;border-color:#7b2ffd;box-shadow:0 2px 8px #7b2ffd4d}.category-btn.active .check-icon{opacity:1;transform:scale(1)}.category-btn.active:hover{background:#5a1fd9;border-color:#5a1fd9}.category-btn.clear-btn{background:#7b2ffd0a;color:#000000a6;border-color:#e8e8e8}.category-btn.clear-btn svg{width:16px;height:16px}.category-btn.clear-btn:hover{background:#7b2ffd14;border-color:#7b2ffd;color:#7b2ffd;transform:translateY(-1px)}.category-btn:active{transform:translateY(0)}@media (max-width: 767.98px){.category-btn{padding:8px 16px;font-size:.9rem;flex:1;min-width:calc(50% - 4px);text-align:center}.category-btn .check-icon{display:none}}@media (max-width: 479.98px){.category-btn{min-width:100%}}.search-box-full{width:100%}.search-box-full .search-input-wrapper{display:flex;align-items:stretch;background:#fff;border:2px solid #e8e8e8;border-radius:12px;overflow:hidden;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #00000008,0 1px 6px -1px #00000005,0 2px 4px #00000005}.search-box-full .search-input-wrapper:hover{border-color:#cfcfcf}.search-box-full .search-input-wrapper:focus-within{border-color:#7b2ffd;box-shadow:0 0 0 3px #7b2ffd14}.search-box-full .search-input-wrapper .search-input{flex:1;border:none;outline:none;padding:14px 20px;font-size:15px;color:#000000e0;background:transparent}.search-box-full .search-input-wrapper .search-input::placeholder{color:#00000073}@media (max-width: 767.98px){.search-box-full .search-input-wrapper .search-input{padding:12px 16px;font-size:14px}}.search-box-full .search-input-wrapper .search-btn{display:flex;align-items:center;gap:8px;padding:0 24px;background:#7b2ffd;color:#fff;border:none;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.search-box-full .search-input-wrapper .search-btn:hover{background:#9b6dfe}.search-box-full .search-input-wrapper .search-btn:active{transform:scale(.98)}.search-box-full .search-input-wrapper .search-btn .search-icon{width:18px;height:18px}@media (max-width: 767.98px){.search-box-full .search-input-wrapper .search-btn{padding:0 16px}.search-box-full .search-input-wrapper .search-btn .btn-text{display:none}.search-box-full .search-input-wrapper .search-btn .search-icon{width:20px;height:20px}}@media (max-width: 575.98px){.search-filter-container{gap:12px}.search-box,.filter-box{border-radius:8px}.search-filter-section{padding:16px}.category-btn{padding:10px 14px;font-size:.875rem}}@media (prefers-color-scheme: dark){.search-filter-container .search-input-wrapper,.search-filter-container .filter-box{background:#ffffff0d;border-color:#ffffff1a}.search-filter-container .search-input,.search-filter-container .filter-select{color:#fff}.search-filter-container .filter-label{color:#ffffffa6}}
