:root{--color-primary:#00d4ff;--color-primary-dark:#00a8cc;--color-primary-light:#5ce1ff;--color-text-primary:#fff;--color-text-secondary:#a0a8b0;--color-text-muted:#6b7280;--color-bg-primary:#0a0a0f;--color-bg-secondary:#12121a;--color-bg-tertiary:#1a1a25;--color-border:#2a2a3a;--color-border-light:#1f1f2e;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", Consolas, Monaco, "Courier New", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #00d4ff1a;--shadow-md:0 4px 6px -1px #00d4ff26, 0 2px 4px -2px #00d4ff1a;--shadow-lg:0 10px 15px -3px #00d4ff33, 0 4px 6px -4px #00d4ff1a;--shadow-xl:0 20px 25px -5px #00d4ff40, 0 8px 10px -6px #00d4ff1a;--shadow-glow:0 0 20px #00d4ff4d, 0 0 40px #00d4ff1a;--transition-fast:.2s ease;--transition-base:.3s ease;--transition-slow:.4s ease;--ease-smooth:cubic-bezier(.4, 0, .2, 1);--ease-bounce:cubic-bezier(.34, 1.56, .64, 1);--ease-out:cubic-bezier(0, 0, .2, 1);--header-height:4rem;--max-width:1200px;--content-width:720px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul,ol{list-style:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #00d4ff66}50%{opacity:.8;box-shadow:0 0 0 10px #00d4ff00}}@keyframes gradient{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--color-primary), 0 0 10px var(--color-primary), 0 0 15px var(--color-primary)}50%{box-shadow:0 0 10px var(--color-primary), 0 0 20px var(--color-primary), 0 0 30px var(--color-primary)}}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.container{width:100%;max-width:var(--max-width);padding:0 var(--space-6);margin:0 auto}.content-container{width:100%;max-width:var(--content-width);padding:0 var(--space-6);margin:0 auto}.page-enter-active,.page-leave-active{transition:opacity .3s,transform .3s}.page-enter-from{opacity:0;transform:translateY(10px)}.page-leave-to{opacity:0;transform:translateY(-10px)}@media (width<=768px){:root{--text-5xl:2.25rem;--text-4xl:1.875rem;--text-3xl:1.5rem}.container,.content-container{padding:0 var(--space-4)}}::selection{background-color:var(--color-primary);color:var(--color-bg-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.hover-lift{transition:transform var(--transition-base) var(--ease-smooth), box-shadow var(--transition-base) var(--ease-smooth)}.hover-lift:hover{box-shadow:var(--shadow-glow);transform:translateY(-4px)}.hover-scale{transition:transform var(--transition-base) var(--ease-smooth)}.hover-scale:hover{transform:scale(1.02)}.link-underline{display:inline-block;position:relative}.link-underline:after{content:"";background-color:var(--color-primary);width:0;height:2px;box-shadow:0 0 10px var(--color-primary);transition:width var(--transition-base) var(--ease-out);position:absolute;bottom:0;left:0}.link-underline:hover:after{width:100%}.tech-grid{background-image:linear-gradient(#00d4ff08 1px,#0000 1px),linear-gradient(90deg,#00d4ff08 1px,#0000 1px);background-size:50px 50px}.header[data-v-19d78e43]{z-index:100;height:var(--header-height);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:#0a0a0fb3;border-bottom:1px solid #0000;transition:background-color .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s,border-bottom-color .3s;position:fixed;top:0;left:0;right:0}.header.is-scrolled[data-v-19d78e43]{background-color:#0a0a0ff2;border-bottom-color:#00d4ff33;box-shadow:0 4px 20px #0000004d}.header-container[data-v-19d78e43]{justify-content:space-between;align-items:center;height:100%;display:flex}.logo[data-v-19d78e43]{align-items:center;gap:var(--space-2);font-weight:700;font-size:var(--text-xl);color:var(--color-text-primary);transition:all var(--transition-fast);display:flex}.logo[data-v-19d78e43]:hover{text-shadow:0 0 20px #00d4ff80;transform:scale(1.02)}.logo-icon[data-v-19d78e43]{color:var(--color-primary);font-size:var(--text-2xl);text-shadow:0 0 10px #00d4ff80}.logo-text[data-v-19d78e43]{background:linear-gradient(135deg, var(--color-text-primary), var(--color-primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.nav[data-v-19d78e43]{align-items:center;gap:var(--space-8);display:flex}.nav-link[data-v-19d78e43]{font-size:var(--text-base);color:var(--color-text-secondary);padding:var(--space-2) 0;transition:color var(--transition-fast);font-weight:500;position:relative}.nav-link[data-v-19d78e43]:after{content:"";background:var(--color-primary);width:0;height:2px;box-shadow:0 0 10px var(--color-primary);transition:width var(--transition-base);border-radius:var(--radius-full);position:absolute;bottom:0;left:0}.nav-link[data-v-19d78e43]:hover{color:var(--color-text-primary)}.nav-link.is-active[data-v-19d78e43]{color:var(--color-primary);text-shadow:0 0 10px #00d4ff4d}.nav-link.is-active[data-v-19d78e43]:after{width:100%}.admin-link[data-v-19d78e43]{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);color:var(--color-primary);background:#00d4ff1a;border:1px solid #00d4ff33;transition:all .3s;display:flex}.admin-link[data-v-19d78e43]:hover{border-color:var(--color-primary);background:#00d4ff33;box-shadow:0 0 15px #00d4ff33}.admin-link svg[data-v-19d78e43]{width:16px;height:16px}.mobile-menu-btn[data-v-19d78e43]{padding:var(--space-2);z-index:102;background:0 0;display:none}.hamburger[data-v-19d78e43]{flex-direction:column;gap:5px;width:24px;display:flex}.hamburger span[data-v-19d78e43]{background:var(--color-text-primary);width:100%;height:2px;transition:transform var(--transition-base), opacity var(--transition-base);border-radius:var(--radius-full);display:block;box-shadow:0 0 5px #00d4ff4d}.hamburger.is-open span[data-v-19d78e43]:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.is-open span[data-v-19d78e43]:nth-child(2){opacity:0}.hamburger.is-open span[data-v-19d78e43]:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu-overlay[data-v-19d78e43]{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;background:#000000b3;display:none;position:fixed;inset:0}@media (width<=768px){.nav[data-v-19d78e43]{width:70%;max-width:300px;height:100vh;padding:calc(var(--header-height) + var(--space-8)) var(--space-6);transition:right var(--transition-slow);z-index:101;background:#12121afa;border-left:1px solid #00d4ff33;flex-direction:column;justify-content:flex-start;position:fixed;top:0;right:-100%;box-shadow:-10px 0 30px #00000080}.nav.is-open[data-v-19d78e43]{right:0}.nav-link[data-v-19d78e43]{font-size:var(--text-lg);padding:var(--space-3) 0}.nav-link[data-v-19d78e43]:after{display:none}.admin-link[data-v-19d78e43]{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);justify-content:center}.mobile-menu-btn[data-v-19d78e43],.mobile-menu-overlay[data-v-19d78e43]{display:block}}.footer[data-v-b663b5ce]{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);padding:var(--space-16) 0 var(--space-8)}.footer-container[data-v-b663b5ce]{gap:var(--space-12);flex-direction:column;display:flex}.footer-content[data-v-b663b5ce]{gap:var(--space-12);grid-template-columns:4fr 1fr;align-items:start;display:grid}.footer-brand[data-v-b663b5ce]{gap:var(--space-3);flex-direction:column;display:flex}.footer-logo[data-v-b663b5ce]{align-items:center;gap:var(--space-2);font-size:var(--text-xl);color:var(--color-text-primary);font-weight:700;display:flex}.footer-logo .logo-icon[data-v-b663b5ce]{color:var(--color-primary)}.footer-desc[data-v-b663b5ce]{color:var(--color-text-secondary);font-size:var(--text-sm)}.footer-links[data-v-b663b5ce]{gap:var(--space-16);justify-content:flex-start;display:flex}.footer-section[data-v-b663b5ce]{gap:var(--space-4);flex-direction:column;display:flex}.footer-title[data-v-b663b5ce]{font-size:var(--text-sm);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.footer-list[data-v-b663b5ce]{gap:var(--space-2);flex-direction:column;display:flex}.footer-list a[data-v-b663b5ce]{font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--transition-fast)}.footer-list a[data-v-b663b5ce]:hover{color:var(--color-primary)}.footer-bottom[data-v-b663b5ce]{padding-top:var(--space-8);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.copyright[data-v-b663b5ce],.made-with[data-v-b663b5ce]{font-size:var(--text-sm);color:var(--color-text-muted)}@media (width<=768px){.footer[data-v-b663b5ce]{padding:var(--space-10) 0 var(--space-6)}.footer-content[data-v-b663b5ce]{gap:var(--space-8);grid-template-columns:1fr}.footer-links[data-v-b663b5ce]{gap:var(--space-8);justify-content:flex-start}.footer-bottom[data-v-b663b5ce]{gap:var(--space-2);text-align:center;flex-direction:column}}.layout[data-v-62dd36e4]{flex-direction:column;min-height:100vh;display:flex}.main[data-v-62dd36e4]{padding-top:var(--header-height);flex:1}.project-card[data-v-16cd1bf2]{background:var(--color-bg-tertiary);border-radius:var(--radius-xl);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-base);will-change:transform;position:relative;overflow:hidden}.project-card[data-v-16cd1bf2]:before{content:"";border-radius:var(--radius-xl);-webkit-mask-composite:xor;opacity:0;background:linear-gradient(135deg,#00d4ff4d,#8b5cf64d);padding:1px;transition:opacity .3s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.project-card[data-v-16cd1bf2]:hover{border-color:#00d4ff4d;box-shadow:0 20px 40px #0006,0 0 30px #00d4ff1a}.project-card[data-v-16cd1bf2]:hover:before{opacity:1}.project-image-wrapper[data-v-16cd1bf2]{aspect-ratio:16/10;position:relative;overflow:hidden}.project-image[data-v-16cd1bf2]{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.project-card:hover .project-image[data-v-16cd1bf2]{transform:scale(1.05)}.project-overlay[data-v-16cd1bf2]{opacity:0;transition:opacity var(--transition-base);background:linear-gradient(#0a0a0f66,#0a0a0fe6);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.project-card:hover .project-overlay[data-v-16cd1bf2]{opacity:1}.view-btn[data-v-16cd1bf2]{padding:var(--space-3) var(--space-6);color:var(--color-primary);font-size:var(--text-sm);border-radius:var(--radius-full);border:1px solid var(--color-primary);transition:all var(--transition-base);background:0 0;font-weight:600;transform:translateY(10px);box-shadow:0 0 15px #00d4ff33}.project-card:hover .view-btn[data-v-16cd1bf2]{background:#00d4ff1a;transform:translateY(0)}.view-btn[data-v-16cd1bf2]:hover{background:#00d4ff33;box-shadow:0 0 25px #00d4ff66}.project-content[data-v-16cd1bf2]{padding:var(--space-5)}.project-tags[data-v-16cd1bf2]{gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.project-tag[data-v-16cd1bf2]{padding:var(--space-1) var(--space-2);color:var(--color-primary);font-size:var(--text-xs);border-radius:var(--radius-sm);background:#00d4ff1a;border:1px solid #00d4ff33;font-weight:500;transition:all .2s}.project-tag[data-v-16cd1bf2]:hover{background:#00d4ff33;box-shadow:0 0 10px #00d4ff33}.project-title[data-v-16cd1bf2]{font-size:var(--text-lg);color:var(--color-text-primary);margin-bottom:var(--space-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.project-desc[data-v-16cd1bf2]{font-size:var(--text-sm);color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.6;display:-webkit-box;overflow:hidden}@media (width<=768px){.project-content[data-v-16cd1bf2]{padding:var(--space-4)}.project-title[data-v-16cd1bf2]{font-size:var(--text-base)}}.home[data-v-d329b4e1]{background-color:var(--color-bg-primary);overflow-x:hidden}.hero[data-v-d329b4e1]{background:linear-gradient(135deg, var(--color-bg-primary) 0%, var(--color-bg-secondary) 100%);justify-content:center;align-items:center;height:100vh;padding:0;display:flex;position:relative;overflow:hidden}.hero-background[data-v-d329b4e1]{pointer-events:none;position:absolute;inset:0;overflow:hidden}.tech-grid[data-v-d329b4e1]{opacity:.5;background-image:linear-gradient(#00d4ff08 1px,#0000 1px),linear-gradient(90deg,#00d4ff08 1px,#0000 1px);background-size:50px 50px;position:absolute;inset:0}.scanline[data-v-d329b4e1]{background:linear-gradient(90deg, transparent, var(--color-primary), transparent);opacity:.3;height:2px;animation:4s linear infinite scanline;position:absolute;top:0;left:0;right:0}.floating-shape[data-v-d329b4e1]{border-radius:var(--radius-lg);opacity:.4;position:absolute}.shape-1[data-v-d329b4e1]{background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary));width:80px;height:80px;animation:6s ease-in-out infinite float-d329b4e1;top:20%;left:10%;box-shadow:0 0 30px #00d4ff4d}.shape-2[data-v-d329b4e1]{background:linear-gradient(135deg,#8b5cf6,#6366f1);border-radius:50%;width:120px;height:120px;animation:8s ease-in-out 1s infinite float-d329b4e1;top:60%;right:10%;box-shadow:0 0 40px #8b5cf64d}.shape-3[data-v-d329b4e1]{background:linear-gradient(135deg,#f59e0b,#f97316);width:60px;height:60px;animation:7s ease-in-out .5s infinite float-d329b4e1;bottom:20%;left:20%;transform:rotate(45deg);box-shadow:0 0 25px #f59e0b4d}.gradient-orb[data-v-d329b4e1]{filter:blur(80px);opacity:.3;border-radius:50%;position:absolute}.orb-1[data-v-d329b4e1]{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);width:400px;height:400px;top:-100px;right:-100px}.orb-2[data-v-d329b4e1]{background:linear-gradient(135deg,#f59e0b,#f97316);width:300px;height:300px;bottom:-50px;left:-50px}.hero-layout[data-v-d329b4e1]{z-index:1;justify-content:space-between;align-items:center;width:100%;height:100%;display:flex;position:relative}.hero-content[data-v-d329b4e1]{text-align:left;width:45%;padding-left:8%;padding-right:5%}.hero-badge[data-v-d329b4e1]{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-primary);margin-bottom:var(--space-6);background:#00d4ff1a;border:1px solid #00d4ff33;font-weight:500;display:inline-flex}.badge-dot[data-v-d329b4e1]{background:var(--color-primary);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-d329b4e1}.hero-title[data-v-d329b4e1]{font-size:var(--text-5xl);color:var(--color-text-primary);margin-bottom:var(--space-6);letter-spacing:-.02em;text-shadow:0 0 40px #00d4ff33;font-weight:800;line-height:1.1}.gradient-text[data-v-d329b4e1]{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle[data-v-d329b4e1]{font-size:var(--text-xl);color:var(--color-text-secondary);margin-bottom:var(--space-10);line-height:1.7}.hero-stats[data-v-d329b4e1]{justify-content:flex-start;align-items:center;gap:var(--space-8);display:flex}.stat-item[data-v-d329b4e1]{align-items:flex-start;gap:var(--space-1);flex-direction:column;display:flex}.stat-number[data-v-d329b4e1]{font-size:var(--text-3xl);color:var(--color-primary);text-shadow:0 0 20px #00d4ff66;font-weight:800}.stat-label[data-v-d329b4e1]{font-size:var(--text-sm);color:var(--color-text-secondary)}.stat-divider[data-v-d329b4e1]{background:linear-gradient(to bottom, transparent, var(--color-border), transparent);width:1px;height:40px}.hero-carousel[data-v-d329b4e1]{right:40px;top:calc(var(--header-height) + 40px);justify-content:flex-end;align-items:center;width:68%;max-width:900px;display:flex;position:absolute;bottom:80px}.bookmark-container[data-v-d329b4e1]{border-radius:50%;width:100%;height:100%;position:relative;overflow:hidden;box-shadow:0 0 60px #00d4ff33,0 0 100px #00d4ff1a,inset 0 0 60px #0000004d}.bookmark-container[data-v-d329b4e1]:before{content:"";background:linear-gradient(135deg, var(--color-primary), #8b5cf6);-webkit-mask-composite:xor;z-index:5;pointer-events:none;border-radius:50%;padding:2px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.bookmark-images[data-v-d329b4e1]{width:100%;height:100%;position:relative}.bookmark-image[data-v-d329b4e1]{opacity:0;transition:none;position:absolute;inset:0}.bookmark-image.active[data-v-d329b4e1]{opacity:1}.bookmark-image img[data-v-d329b4e1]{object-fit:cover;width:100%;height:100%}.bookmark-gradient[data-v-d329b4e1]{background: radial-gradient(circle at center, transparent 60%, var(--color-bg-primary) 100%);pointer-events:none;z-index:2;position:absolute;inset:0}.bookmark-info[data-v-d329b4e1]{justify-content:center;align-items:center;gap:var(--space-3);z-index:3;text-align:center;display:flex;position:absolute;bottom:15%;left:50%;transform:translate(-50%)}.bookmark-title[data-v-d329b4e1]{color:#fff;font-size:var(--text-xl);text-shadow:0 2px 10px #00000080;font-weight:600}.bookmark-badge[data-v-d329b4e1]{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00d4ff4d;border:1px solid #00d4ff66}.bookmark-indicators[data-v-d329b4e1]{gap:var(--space-2);z-index:3;flex-direction:column;display:flex;position:absolute;bottom:8%;right:8%}.indicator[data-v-d329b4e1]{border-radius:var(--radius-full);cursor:pointer;background:#fff6;border:none;width:6px;height:6px;transition:all .3s}.indicator[data-v-d329b4e1]:hover{background:#fffc;transform:scale(1.3)}.indicator.active[data-v-d329b4e1]{background:var(--color-primary);height:24px;box-shadow:0 0 10px var(--color-primary)}.bookmark-nav[data-v-d329b4e1]{cursor:pointer;opacity:0;z-index:3;width:44px;height:44px;color:var(--color-primary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a0a0fb3;border:1px solid #00d4ff66;border-radius:50%;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute}.bookmark-container:hover .bookmark-nav[data-v-d329b4e1]{opacity:1}.bookmark-nav[data-v-d329b4e1]:hover{border-color:var(--color-primary);background:#00d4ff33;transform:scale(1.1);box-shadow:0 0 20px #00d4ff66}.bookmark-nav.prev[data-v-d329b4e1]{top:50%;left:5%;transform:translateY(-50%)}.bookmark-nav.prev[data-v-d329b4e1]:hover{transform:translateY(-50%)scale(1.1)}.bookmark-nav.next[data-v-d329b4e1]{top:50%;right:5%;transform:translateY(-50%)}.bookmark-nav.next[data-v-d329b4e1]:hover{transform:translateY(-50%)scale(1.1)}.bookmark-nav svg[data-v-d329b4e1]{width:18px;height:18px}.bookmark-placeholder[data-v-d329b4e1]{background:var(--color-bg-secondary);justify-content:center;align-items:center;gap:var(--space-4);border-radius:50%;flex-direction:column;width:80%;height:80%;display:flex;box-shadow:0 0 60px #00d4ff1a,inset 0 0 60px #0003}.bookmark-placeholder.error[data-v-d329b4e1]{background:#ef44441a}.bookmark-icon[data-v-d329b4e1]{opacity:.6;font-size:48px}.bookmark-icon svg[data-v-d329b4e1]{width:64px;height:64px;color:var(--color-text-secondary)}.bookmark-text[data-v-d329b4e1]{font-size:var(--text-lg);color:var(--color-text-secondary);font-weight:600}.bookmark-hint[data-v-d329b4e1]{font-size:var(--text-sm);color:var(--color-text-muted)}.scroll-hint[data-v-d329b4e1]{bottom:var(--space-8);align-items:center;gap:var(--space-2);opacity:.6;flex-direction:column;animation:2s ease-in-out infinite bounce-d329b4e1;display:flex;position:absolute;left:50%;transform:translate(-50%)}.scroll-mouse[data-v-d329b4e1]{border:2px solid var(--color-text-secondary);border-radius:var(--radius-full);width:24px;height:36px;padding-top:var(--space-1);justify-content:center;display:flex}.scroll-wheel[data-v-d329b4e1]{background:var(--color-primary);border-radius:var(--radius-full);width:4px;height:8px;animation:2s ease-in-out infinite scrollWheel-d329b4e1}.scroll-text[data-v-d329b4e1]{font-size:var(--text-xs);color:var(--color-text-secondary)}.projects-section[data-v-d329b4e1]{padding:var(--space-16) 0 var(--space-24);background:var(--color-bg-secondary);position:relative}.projects-section[data-v-d329b4e1]:before{content:"";background:linear-gradient(90deg, transparent, var(--color-border), transparent);height:1px;position:absolute;top:0;left:0;right:0}.filter-section[data-v-d329b4e1]{margin-bottom:var(--space-10)}.filter-tags[data-v-d329b4e1]{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.filter-tag[data-v-d329b4e1]{padding:var(--space-2) var(--space-4);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;font-weight:500;transition:all .3s}.filter-tag[data-v-d329b4e1]:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px);box-shadow:0 0 15px #00d4ff33}.filter-tag.active[data-v-d329b4e1]{border-color:var(--color-primary);color:var(--color-primary);background:#00d4ff26;box-shadow:0 0 15px #00d4ff4d}.projects-grid[data-v-d329b4e1]{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(350px,1fr));display:grid}.empty-state[data-v-d329b4e1]{text-align:center;padding:var(--space-16) 0}.empty-icon[data-v-d329b4e1]{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--color-text-muted)}.empty-state h3[data-v-d329b4e1]{font-size:var(--text-xl);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:600}.empty-state p[data-v-d329b4e1]{color:var(--color-text-secondary)}.cta-section[data-v-d329b4e1]{padding:var(--space-24) 0;background:var(--color-bg-primary)}.cta-card[data-v-d329b4e1]{justify-content:space-between;align-items:center;gap:var(--space-8);padding:var(--space-10) var(--space-12);border-radius:var(--radius-2xl);color:#fff;background:linear-gradient(135deg,#00d4ff1a,#8b5cf61a);border:1px solid #00d4ff33;display:flex;position:relative;overflow:hidden}.cta-card[data-v-d329b4e1]:before{content:"";background:linear-gradient(135deg, var(--color-primary), #8b5cf6);opacity:.1;z-index:0;position:absolute;inset:0}.cta-content[data-v-d329b4e1]{z-index:1;position:relative}.cta-title[data-v-d329b4e1]{font-size:var(--text-2xl);margin-bottom:var(--space-2);color:var(--color-text-primary);font-weight:700}.cta-desc[data-v-d329b4e1]{font-size:var(--text-base);color:var(--color-text-secondary)}.btn[data-v-d329b4e1]{z-index:1;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg);font-weight:600;transition:all .3s;display:inline-flex;position:relative}.btn-glow[data-v-d329b4e1]{color:var(--color-primary);border:1px solid var(--color-primary);background:0 0;box-shadow:0 0 10px #00d4ff33}.btn-glow[data-v-d329b4e1]:hover{background:#00d4ff1a;transform:translateY(-2px);box-shadow:0 0 20px #00d4ff66,0 0 40px #00d4ff33}@keyframes float-d329b4e1{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse-d329b4e1{0%,to{opacity:1;box-shadow:0 0 #00d4ff66}50%{opacity:.8;box-shadow:0 0 0 10px #00d4ff00}}@keyframes bounce-d329b4e1{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(-10px)}}@keyframes scrollWheel-d329b4e1{0%,to{opacity:1;transform:translateY(0)}50%{opacity:.5;transform:translateY(8px)}}@media (width<=1024px){.hero-layout[data-v-d329b4e1]{flex-direction:column}.hero-content[data-v-d329b4e1]{width:100%;padding:var(--space-20) var(--space-6) var(--space-6);text-align:center}.hero-title[data-v-d329b4e1]{font-size:var(--text-3xl)}.hero-subtitle[data-v-d329b4e1]{font-size:var(--text-base)}.hero-stats[data-v-d329b4e1]{justify-content:center;gap:var(--space-4);flex-wrap:wrap}.stat-item[data-v-d329b4e1]{align-items:center}.stat-divider[data-v-d329b4e1]{display:none}.hero-carousel[data-v-d329b4e1]{width:100%;max-width:100%;height:350px;position:relative;top:0;bottom:0;right:0}.bookmark-container[data-v-d329b4e1]{border-radius:50%;width:300px;height:300px;margin:0 auto}.bookmark-container[data-v-d329b4e1]:before{display:none}.bookmark-gradient[data-v-d329b4e1]{width:20%}.bookmark-info[data-v-d329b4e1]{left:15%}.bookmark-nav[data-v-d329b4e1]{opacity:1}.scroll-hint[data-v-d329b4e1]{display:none}.projects-grid[data-v-d329b4e1]{grid-template-columns:1fr}.filter-tags[data-v-d329b4e1]{gap:var(--space-2)}.filter-tag[data-v-d329b4e1]{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.cta-card[data-v-d329b4e1]{text-align:center;padding:var(--space-8);flex-direction:column}.floating-shape[data-v-d329b4e1]{display:none}}@media (width>=1025px) and (width<=1400px){.hero-content[data-v-d329b4e1]{padding-left:6%}.hero-carousel[data-v-d329b4e1]{width:42%;right:30px;top:calc(var(--header-height) + 30px);width:60%;bottom:60px}.bookmark-container[data-v-d329b4e1]{border-radius:50%}}.about-page[data-v-17fa4e44]{padding:var(--space-12) 0 var(--space-24)}.about-header[data-v-17fa4e44]{text-align:center;margin-bottom:var(--space-12)}.page-title[data-v-17fa4e44]{font-size:var(--text-4xl);color:var(--color-text-primary);margin-bottom:var(--space-3);letter-spacing:-.02em;font-weight:800}.page-subtitle[data-v-17fa4e44]{font-size:var(--text-lg);color:var(--color-text-secondary)}.profile-section[data-v-17fa4e44]{gap:var(--space-12);margin-bottom:var(--space-16);grid-template-columns:auto 1fr;align-items:start;display:grid}.about-avatar[data-v-17fa4e44]{flex-shrink:0}.avatar-placeholder[data-v-17fa4e44]{background:linear-gradient(135deg, var(--color-primary-light), var(--color-primary));border-radius:var(--radius-2xl);width:200px;height:200px;box-shadow:var(--shadow-lg);justify-content:center;align-items:center;font-size:80px;display:flex}.about-intro[data-v-17fa4e44]{gap:var(--space-4);flex-direction:column;display:flex}.intro-title[data-v-17fa4e44]{font-size:var(--text-2xl);color:var(--color-text-primary);font-weight:700}.intro-text[data-v-17fa4e44]{font-size:var(--text-lg);color:var(--color-text-secondary);line-height:1.8}.social-links[data-v-17fa4e44]{gap:var(--space-3);margin-top:var(--space-4);display:flex}.social-link[data-v-17fa4e44]{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-bg-secondary);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);font-weight:500;display:inline-flex}.social-link[data-v-17fa4e44]:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px)}.social-link svg[data-v-17fa4e44]{width:18px;height:18px}.skills-section[data-v-17fa4e44]{margin-bottom:var(--space-16)}.section-title[data-v-17fa4e44]{font-size:var(--text-2xl);color:var(--color-text-primary);margin-bottom:var(--space-8);text-align:center;font-weight:700}.skills-grid[data-v-17fa4e44]{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.skill-item[data-v-17fa4e44]{gap:var(--space-2);flex-direction:column;display:flex}.skill-header[data-v-17fa4e44]{margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-start;display:flex}.skill-info[data-v-17fa4e44]{gap:var(--space-1);flex-direction:column;display:flex}.skill-name[data-v-17fa4e44]{color:var(--color-text-primary);font-weight:600;font-size:var(--text-base)}.skill-desc[data-v-17fa4e44]{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:400}.skill-level[data-v-17fa4e44]{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.skill-bar[data-v-17fa4e44]{background:var(--color-bg-secondary);border-radius:var(--radius-full);height:8px;overflow:hidden}.skill-progress[data-v-17fa4e44]{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light));border-radius:var(--radius-full);height:100%;transition:width 1s}.interests-section[data-v-17fa4e44]{margin-bottom:var(--space-16)}.interests-grid[data-v-17fa4e44]{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));display:grid}.interest-card[data-v-17fa4e44]{padding:var(--space-6);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center;transition:all var(--transition-base)}.interest-card[data-v-17fa4e44]:hover{box-shadow:var(--shadow-lg);border-color:#0000;transform:translateY(-4px)}.interest-icon[data-v-17fa4e44]{margin-bottom:var(--space-3);font-size:48px;display:block}.interest-title[data-v-17fa4e44]{font-size:var(--text-lg);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:600}.interest-desc[data-v-17fa4e44]{font-size:var(--text-sm);color:var(--color-text-secondary)}.contact-section[data-v-17fa4e44]{margin-top:var(--space-8)}.contact-card[data-v-17fa4e44]{justify-content:space-between;align-items:center;gap:var(--space-8);padding:var(--space-10) var(--space-12);background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-2xl);color:#fff;display:flex}.contact-title[data-v-17fa4e44]{font-size:var(--text-2xl);margin-bottom:var(--space-2);font-weight:700}.contact-desc[data-v-17fa4e44]{font-size:var(--text-base);opacity:.9}.btn[data-v-17fa4e44]{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg);transition:all var(--transition-base);white-space:nowrap;font-weight:600;display:inline-flex}.btn-primary[data-v-17fa4e44]{color:var(--color-primary);background:#fff}.btn-primary[data-v-17fa4e44]:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-icon[data-v-17fa4e44]{width:18px;height:18px;transition:transform var(--transition-fast)}.btn:hover .btn-icon[data-v-17fa4e44]{transform:translate(3px)}@media (width<=768px){.about-page[data-v-17fa4e44]{padding:var(--space-8) 0 var(--space-16)}.page-title[data-v-17fa4e44]{font-size:var(--text-3xl)}.profile-section[data-v-17fa4e44]{text-align:center;gap:var(--space-8);grid-template-columns:1fr}.avatar-placeholder[data-v-17fa4e44]{width:150px;height:150px;margin:0 auto;font-size:60px}.social-links[data-v-17fa4e44]{justify-content:center}.skills-grid[data-v-17fa4e44]{grid-template-columns:1fr}.interests-grid[data-v-17fa4e44]{grid-template-columns:repeat(2,1fr)}.contact-card[data-v-17fa4e44]{text-align:center;padding:var(--space-8);flex-direction:column}}@media (width<=480px){.interests-grid[data-v-17fa4e44]{grid-template-columns:1fr}}.project-detail[data-v-8179b92d]{min-height:100vh;padding:var(--space-8) 0 var(--space-16)}.detail-container[data-v-8179b92d]{max-width:var(--content-width);padding:0 var(--space-6);margin:0 auto}.detail-header[data-v-8179b92d]{margin-bottom:var(--space-10)}.back-btn[data-v-8179b92d]{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-6);font-weight:500;display:inline-flex}.back-btn[data-v-8179b92d]:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-bg-primary)}.header-meta[data-v-8179b92d]{text-align:center}.header-tags[data-v-8179b92d]{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.tag[data-v-8179b92d]{padding:var(--space-1) var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:500}.project-title[data-v-8179b92d]{font-size:var(--text-4xl);color:var(--color-text-primary);margin-bottom:var(--space-3);letter-spacing:-.02em;font-weight:800;line-height:1.2}.project-date[data-v-8179b92d]{font-size:var(--text-sm);color:var(--color-text-muted)}.article-body[data-v-8179b92d]{position:relative}.text-block[data-v-8179b92d]{font-size:var(--text-lg);color:var(--color-text-primary);margin-bottom:var(--space-6);text-align:justify;line-height:1.9}.text-block[data-v-8179b92d]:first-of-type{font-size:var(--text-xl);color:var(--color-text-secondary);line-height:1.8}.image-block[data-v-8179b92d]{cursor:pointer;transition:all var(--transition-base);margin:0}.image-block:hover .image-wrapper[data-v-8179b92d]{transform:scale(1.01)}.image-wrapper[data-v-8179b92d]{border-radius:var(--radius-lg);transition:transform var(--transition-base);background:var(--color-bg-tertiary);overflow:hidden}.image-wrapper img[data-v-8179b92d]{width:100%;height:auto;transition:transform var(--transition-slow);display:block}.image-block:hover .image-wrapper img[data-v-8179b92d]{transform:scale(1.02)}.image-block.hero[data-v-8179b92d]{margin-bottom:var(--space-10)}.image-block.hero .image-wrapper[data-v-8179b92d]{border-radius:var(--radius-xl);max-height:480px}.image-block.hero img[data-v-8179b92d]{object-fit:cover;width:100%;height:480px}.image-block.full[data-v-8179b92d]{margin:var(--space-8) 0;clear:both}.image-block.full .image-wrapper[data-v-8179b92d]{border-radius:var(--radius-xl)}.image-block.full img[data-v-8179b92d]{object-fit:cover;width:100%;max-height:500px}.image-block.float-right[data-v-8179b92d]{float:right;width:48%;margin:var(--space-2) 0 var(--space-4) var(--space-6)}.image-block.float-right .image-wrapper[data-v-8179b92d]{border-radius:var(--radius-lg)}.image-block.float-left[data-v-8179b92d]{float:left;width:48%;margin:var(--space-2) var(--space-6) var(--space-4) 0}.image-block.float-left .image-wrapper[data-v-8179b92d]{border-radius:var(--radius-lg)}.video-section[data-v-8179b92d]{clear:both;padding-top:var(--space-6)}.section-title[data-v-8179b92d]{font-size:var(--text-2xl);color:var(--color-text-primary);margin-bottom:var(--space-6);text-align:center;font-weight:700}.video-wrapper[data-v-8179b92d]{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);background:#000;overflow:hidden}.video-wrapper video[data-v-8179b92d]{width:100%;max-height:500px;display:block}.detail-footer[data-v-8179b92d]{clear:both;text-align:center;padding-top:var(--space-12);margin-top:var(--space-8);border-top:1px solid var(--color-border-light)}.lightbox-overlay[data-v-8179b92d]{z-index:9999;padding:var(--space-8);background:#000000eb;justify-content:center;align-items:center;animation:.25s fadeIn-8179b92d;display:flex;position:fixed;inset:0}.lightbox-close[data-v-8179b92d]{top:var(--space-6);right:var(--space-6);color:#fff;cursor:pointer;width:48px;height:48px;transition:background var(--transition-fast);z-index:1;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.lightbox-close[data-v-8179b92d]:hover{background:#ffffff40}.lightbox-image[data-v-8179b92d]{object-fit:contain;border-radius:var(--radius-lg);max-width:100%;max-height:90vh;animation:.3s scaleIn-8179b92d}@keyframes fadeIn-8179b92d{0%{opacity:0}to{opacity:1}}@keyframes scaleIn-8179b92d{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.loading-state[data-v-8179b92d]{justify-content:center;align-items:center;min-height:60vh;display:flex}.loading-state[data-v-8179b92d]:after{content:"";border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin-8179b92d}@keyframes spin-8179b92d{to{transform:rotate(360deg)}}@media (width<=768px){.project-detail[data-v-8179b92d]{padding:var(--space-4) 0 var(--space-10)}.detail-container[data-v-8179b92d]{padding:0 var(--space-4)}.project-title[data-v-8179b92d]{font-size:var(--text-2xl)}.text-block[data-v-8179b92d]{font-size:var(--text-base);line-height:1.8}.text-block[data-v-8179b92d]:first-of-type{font-size:var(--text-lg)}.image-block.float-right[data-v-8179b92d],.image-block.float-left[data-v-8179b92d]{float:none;width:100%;margin:var(--space-6) 0}.image-block.hero .image-wrapper[data-v-8179b92d]{max-height:240px}.image-block.hero img[data-v-8179b92d]{height:240px}.image-block.full img[data-v-8179b92d]{max-height:300px}.lightbox-overlay[data-v-8179b92d]{padding:var(--space-4)}.lightbox-close[data-v-8179b92d]{top:var(--space-3);right:var(--space-3);width:40px;height:40px}}@media (width>=769px) and (width<=1024px){.detail-container[data-v-8179b92d]{padding:0 var(--space-8)}}.login-page[data-v-aa44bb6d]{min-height:100vh;padding:var(--space-6);background:linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-primary) 100%);justify-content:center;align-items:center;display:flex}.login-container[data-v-aa44bb6d]{width:100%;max-width:420px}.login-card[data-v-aa44bb6d]{background:var(--color-bg-primary);border-radius:var(--radius-2xl);padding:var(--space-10);box-shadow:var(--shadow-xl);border:1px solid var(--color-border)}.login-header[data-v-aa44bb6d]{text-align:center;margin-bottom:var(--space-8)}.login-icon[data-v-aa44bb6d]{margin-bottom:var(--space-4);font-size:48px}.login-title[data-v-aa44bb6d]{font-size:var(--text-2xl);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:700}.login-subtitle[data-v-aa44bb6d]{font-size:var(--text-sm);color:var(--color-text-secondary)}.login-form[data-v-aa44bb6d]{gap:var(--space-5);flex-direction:column;display:flex}.form-group[data-v-aa44bb6d]{gap:var(--space-2);flex-direction:column;display:flex}.form-label[data-v-aa44bb6d]{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:500}.form-input[data-v-aa44bb6d]{padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg-primary);transition:all var(--transition-fast)}.form-input[data-v-aa44bb6d]:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-input[data-v-aa44bb6d]::placeholder{color:var(--color-text-muted)}.form-input[data-v-aa44bb6d]:disabled{opacity:.6;cursor:not-allowed}.error-message[data-v-aa44bb6d]{padding:var(--space-3) var(--space-4);color:#ef4444;border-radius:var(--radius-lg);font-size:var(--text-sm);text-align:center;background:#ef44441a}.login-btn[data-v-aa44bb6d]{padding:var(--space-4) var(--space-6);background:var(--color-primary);color:#fff;font-size:var(--text-base);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:var(--space-2);border:none;font-weight:600;display:flex}.login-btn[data-v-aa44bb6d]:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.login-btn[data-v-aa44bb6d]:disabled{opacity:.7;cursor:not-allowed}.loading-spinner[data-v-aa44bb6d]{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin-aa44bb6d}@keyframes spin-aa44bb6d{to{transform:rotate(360deg)}}.login-footer[data-v-aa44bb6d]{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border);text-align:center}.back-link[data-v-aa44bb6d]{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--transition-fast);display:inline-flex}.back-link[data-v-aa44bb6d]:hover{color:var(--color-primary)}.back-link svg[data-v-aa44bb6d]{width:16px;height:16px}@media (width<=480px){.login-card[data-v-aa44bb6d]{padding:var(--space-6)}.login-title[data-v-aa44bb6d]{font-size:var(--text-xl)}}.admin-page[data-v-e3ce8040]{padding:var(--space-8) 0 var(--space-24);min-height:calc(100vh - var(--header-height))}.admin-header[data-v-e3ce8040]{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;display:flex}.page-title[data-v-e3ce8040]{font-size:var(--text-3xl);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:800}.page-subtitle[data-v-e3ce8040]{font-size:var(--text-base);color:var(--color-text-secondary)}.header-actions[data-v-e3ce8040]{gap:var(--space-3);display:flex}.btn[data-v-e3ce8040]{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer;border:none;font-weight:600;display:inline-flex}.btn svg[data-v-e3ce8040]{width:18px;height:18px}.btn-primary[data-v-e3ce8040]{background:var(--color-primary);color:#fff}.btn-primary[data-v-e3ce8040]:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary[data-v-e3ce8040]{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.btn-secondary[data-v-e3ce8040]:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-danger[data-v-e3ce8040]{color:#fff;background:#ef4444}.btn-danger[data-v-e3ce8040]:hover{background:#dc2626}.stats-bar[data-v-e3ce8040]{gap:var(--space-4);margin-bottom:var(--space-8);grid-template-columns:repeat(3,1fr);display:grid}.stat-card[data-v-e3ce8040]{padding:var(--space-5);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center}.stat-value[data-v-e3ce8040]{font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:var(--space-1);font-weight:800;display:block}.stat-label[data-v-e3ce8040]{font-size:var(--text-sm);color:var(--color-text-secondary)}.projects-list[data-v-e3ce8040]{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.empty-state[data-v-e3ce8040]{padding:var(--space-16);text-align:center}.empty-icon[data-v-e3ce8040]{margin-bottom:var(--space-4);font-size:64px}.empty-state h3[data-v-e3ce8040]{font-size:var(--text-xl);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:600}.empty-state p[data-v-e3ce8040]{color:var(--color-text-secondary)}.project-items[data-v-e3ce8040]{flex-direction:column;display:flex}.project-item[data-v-e3ce8040]{gap:var(--space-5);padding:var(--space-5);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);grid-template-columns:120px 1fr auto;display:grid}.project-item[data-v-e3ce8040]:last-child{border-bottom:none}.project-item[data-v-e3ce8040]:hover{background:var(--color-bg-secondary)}.project-item.unpublished[data-v-e3ce8040]{opacity:.7}.project-cover[data-v-e3ce8040]{border-radius:var(--radius-lg);width:120px;height:80px;position:relative;overflow:hidden}.project-cover img[data-v-e3ce8040]{object-fit:cover;width:100%;height:100%}.status-badge[data-v-e3ce8040]{top:var(--space-1);left:var(--space-1);padding:var(--space-1) var(--space-2);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-sm);background:#000000b3;font-weight:500;position:absolute}.project-info[data-v-e3ce8040]{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.project-title[data-v-e3ce8040]{font-size:var(--text-lg);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.project-desc[data-v-e3ce8040]{font-size:var(--text-sm);color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5;display:-webkit-box;overflow:hidden}.project-meta[data-v-e3ce8040]{align-items:center;gap:var(--space-3);margin-top:auto;display:flex}.project-date[data-v-e3ce8040]{font-size:var(--text-xs);color:var(--color-text-muted)}.project-tags[data-v-e3ce8040]{gap:var(--space-1);display:flex}.tag[data-v-e3ce8040]{padding:var(--space-1) var(--space-2);color:var(--color-primary);font-size:var(--text-xs);border-radius:var(--radius-sm);background:#2563eb1a}.project-actions[data-v-e3ce8040]{gap:var(--space-2);align-items:center;display:flex}.action-btn[data-v-e3ce8040]{border-radius:var(--radius-lg);cursor:pointer;width:40px;height:40px;transition:all var(--transition-fast);background:var(--color-bg-secondary);border:none;justify-content:center;align-items:center;display:flex}.action-btn svg[data-v-e3ce8040]{width:18px;height:18px}.action-btn.publish[data-v-e3ce8040]{color:var(--color-text-secondary)}.action-btn.publish.published[data-v-e3ce8040]{color:var(--color-primary);background:#2563eb1a}.action-btn.edit[data-v-e3ce8040]{color:var(--color-text-secondary)}.action-btn.edit[data-v-e3ce8040]:hover{background:var(--color-primary);color:#fff}.action-btn.delete[data-v-e3ce8040]{color:#ef4444}.action-btn.delete[data-v-e3ce8040]:hover{color:#fff;background:#ef4444}.modal-overlay[data-v-e3ce8040]{z-index:1000;padding:var(--space-4);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content[data-v-e3ce8040]{background:var(--color-bg-primary);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-xl)}.modal-header[data-v-e3ce8040]{padding:var(--space-5) var(--space-5) 0}.modal-header h3[data-v-e3ce8040]{font-size:var(--text-lg);color:var(--color-text-primary);font-weight:700}.modal-body[data-v-e3ce8040]{padding:var(--space-4) var(--space-5)}.modal-body p[data-v-e3ce8040]{color:var(--color-text-secondary);margin-bottom:var(--space-2)}.modal-body .warning[data-v-e3ce8040]{color:#ef4444;font-size:var(--text-sm)}.modal-footer[data-v-e3ce8040]{gap:var(--space-3);padding:0 var(--space-5) var(--space-5);justify-content:flex-end;display:flex}.loading-screen[data-v-e3ce8040],.unauthorized-screen[data-v-e3ce8040]{text-align:center;min-height:60vh;padding:var(--space-8);flex-direction:column;justify-content:center;align-items:center;display:flex}.loading-screen .loading-spinner[data-v-e3ce8040]{border:3px solid var(--color-border);border-top-color:var(--color-primary);width:48px;height:48px;margin-bottom:var(--space-4);border-radius:50%;animation:1s linear infinite spin-e3ce8040}@keyframes spin-e3ce8040{to{transform:rotate(360deg)}}.loading-screen p[data-v-e3ce8040]{color:var(--color-text-secondary)}.unauthorized-screen h2[data-v-e3ce8040]{font-size:var(--text-2xl);color:var(--color-text-primary);margin-bottom:var(--space-3);font-weight:700}.unauthorized-screen p[data-v-e3ce8040]{color:var(--color-text-secondary);margin-bottom:var(--space-6)}.form-group[data-v-e3ce8040]{margin-bottom:var(--space-4)}.form-label[data-v-e3ce8040]{font-size:var(--text-sm);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:600;display:block}.form-input[data-v-e3ce8040]{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-primary);color:var(--color-text-primary);transition:border-color var(--transition-fast);box-sizing:border-box}.form-input[data-v-e3ce8040]:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-message[data-v-e3ce8040]{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);margin-bottom:var(--space-4)}.form-message.success[data-v-e3ce8040]{color:#16a34a;background:#22c55e1a}.form-message.error[data-v-e3ce8040]{color:#dc2626;background:#ef44441a}.password-modal[data-v-e3ce8040]{max-width:400px}@media (width<=768px){.admin-header[data-v-e3ce8040]{gap:var(--space-4);flex-direction:column}.header-actions[data-v-e3ce8040]{width:100%}.header-actions .btn[data-v-e3ce8040]{flex:1;justify-content:center}.stats-bar[data-v-e3ce8040]{grid-template-columns:1fr}.project-item[data-v-e3ce8040]{grid-template-rows:auto auto;grid-template-columns:80px 1fr}.project-cover[data-v-e3ce8040]{width:80px;height:60px}.project-actions[data-v-e3ce8040]{padding-top:var(--space-3);border-top:1px solid var(--color-border);grid-column:1/-1;justify-content:flex-end}.project-meta[data-v-e3ce8040]{flex-wrap:wrap}}.edit-page[data-v-9370ca7a]{background:var(--color-bg-secondary);min-height:100vh;padding:var(--space-8) 0 var(--space-16)}.loading-screen[data-v-9370ca7a],.unauthorized-screen[data-v-9370ca7a]{justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;min-height:100vh;display:flex}.loading-screen p[data-v-9370ca7a],.unauthorized-screen p[data-v-9370ca7a]{color:var(--color-text-secondary)}.edit-header[data-v-9370ca7a]{text-align:center;margin-bottom:var(--space-10)}.edit-title[data-v-9370ca7a]{font-size:var(--text-3xl);color:var(--color-text-primary);margin-bottom:var(--space-3);justify-content:center;align-items:center;gap:var(--space-3);font-weight:700;display:flex}.title-icon[data-v-9370ca7a]{font-size:var(--text-2xl)}.edit-subtitle[data-v-9370ca7a]{color:var(--color-text-secondary)}.edit-form[data-v-9370ca7a]{max-width:800px;margin:0 auto}.form-section[data-v-9370ca7a]{background:var(--color-bg-primary);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6);border:1px solid var(--color-border)}.section-title[data-v-9370ca7a]{font-size:var(--text-lg);color:var(--color-text-primary);margin-bottom:var(--space-5);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.section-hint[data-v-9370ca7a]{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:400}.form-group[data-v-9370ca7a]{margin-bottom:var(--space-5)}.form-label[data-v-9370ca7a]{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-2);font-weight:500;display:block}.form-input[data-v-9370ca7a],.form-textarea[data-v-9370ca7a]{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--color-text-primary);transition:all .2s}.form-input[data-v-9370ca7a]:focus,.form-textarea[data-v-9370ca7a]:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #00d4ff1a}.form-textarea[data-v-9370ca7a]{resize:vertical;min-height:120px}.image-upload-area[data-v-9370ca7a],.video-upload-area[data-v-9370ca7a]{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;transition:all .2s}.image-upload-area[data-v-9370ca7a]:hover,.video-upload-area[data-v-9370ca7a]:hover{border-color:var(--color-primary);background:#00d4ff05}.file-input[data-v-9370ca7a]{display:none}.upload-btn[data-v-9370ca7a]{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-base);color:var(--color-text-primary);cursor:pointer;font-weight:500;transition:all .2s;display:inline-flex}.upload-btn[data-v-9370ca7a]:hover{border-color:var(--color-primary);color:var(--color-primary)}.upload-btn svg[data-v-9370ca7a]{width:20px;height:20px}.upload-hint[data-v-9370ca7a]{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-3)}.image-preview-list[data-v-9370ca7a]{gap:var(--space-3);margin-top:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid}.image-preview-item[data-v-9370ca7a]{aspect-ratio:1;border-radius:var(--radius-lg);border:2px solid var(--color-border);cursor:move;transition:all .2s;position:relative;overflow:hidden}.image-preview-item[data-v-9370ca7a]:hover{border-color:var(--color-primary)}.image-preview-item img[data-v-9370ca7a]{object-fit:cover;width:100%;height:100%}.image-actions[data-v-9370ca7a]{top:var(--space-2);right:var(--space-2);gap:var(--space-1);opacity:0;transition:opacity .2s;display:flex;position:absolute}.image-preview-item:hover .image-actions[data-v-9370ca7a]{opacity:1}.action-btn[data-v-9370ca7a]{border-radius:var(--radius-md);cursor:pointer;background:#0009;border:none;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.action-btn svg[data-v-9370ca7a]{color:#fff;width:14px;height:14px}.action-btn[data-v-9370ca7a]:hover,.action-btn.active[data-v-9370ca7a]{background:var(--color-primary)}.action-btn.delete[data-v-9370ca7a]:hover{background:#ef4444}.cover-badge[data-v-9370ca7a]{bottom:var(--space-2);left:var(--space-2);padding:var(--space-1) var(--space-2);background:var(--color-primary);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-sm);font-weight:500;position:absolute}.video-preview[data-v-9370ca7a]{margin-top:var(--space-5)}.video-preview video[data-v-9370ca7a]{border-radius:var(--radius-lg);background:var(--color-bg-secondary);width:100%;max-height:300px}.remove-video-btn[data-v-9370ca7a]{align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:#ef4444;cursor:pointer;background:#ef44441a;border:1px solid #ef44444d;transition:all .2s;display:inline-flex}.remove-video-btn[data-v-9370ca7a]:hover{background:#ef444433}.remove-video-btn svg[data-v-9370ca7a]{width:16px;height:16px}.tag-input-area[data-v-9370ca7a]{gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.tag-input-area .form-input[data-v-9370ca7a]{flex:1}.tag-list[data-v-9370ca7a]{gap:var(--space-2);flex-wrap:wrap;display:flex}.tag-item[data-v-9370ca7a]{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-primary);background:#00d4ff1a;border:1px solid #00d4ff33;display:inline-flex}.tag-remove[data-v-9370ca7a]{width:18px;height:18px;font-size:var(--text-lg);color:var(--color-primary);cursor:pointer;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;transition:opacity .2s;display:flex}.tag-remove[data-v-9370ca7a]:hover{opacity:1}.checkbox-label[data-v-9370ca7a]{align-items:center;gap:var(--space-3);cursor:pointer;display:flex}.checkbox-label input[type=checkbox][data-v-9370ca7a]{width:20px;height:20px;accent-color:var(--color-primary)}.checkbox-label span[data-v-9370ca7a]{color:var(--color-text-secondary)}.upload-progress[data-v-9370ca7a]{margin-bottom:var(--space-6)}.progress-bar[data-v-9370ca7a]{background:var(--color-bg-tertiary);border-radius:var(--radius-full);height:8px;overflow:hidden}.progress-fill[data-v-9370ca7a]{background:linear-gradient(90deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-full);height:100%;transition:width .3s}.progress-text[data-v-9370ca7a]{text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}.form-actions[data-v-9370ca7a]{justify-content:flex-end;gap:var(--space-4);padding-top:var(--space-6);border-top:1px solid var(--color-border);display:flex}.btn[data-v-9370ca7a]{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg);cursor:pointer;border:none;font-weight:500;transition:all .2s;display:inline-flex}.btn[data-v-9370ca7a]:disabled{opacity:.6;cursor:not-allowed}.btn-primary[data-v-9370ca7a]{background:var(--color-primary);color:#fff}.btn-primary[data-v-9370ca7a]:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 4px 12px #00d4ff4d}.btn-secondary[data-v-9370ca7a]{background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary[data-v-9370ca7a]:hover:not(:disabled){background:var(--color-bg-secondary);color:var(--color-text-primary)}.loading-spinner-small[data-v-9370ca7a]{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin-9370ca7a}@keyframes spin-9370ca7a{to{transform:rotate(360deg)}}@media (width<=768px){.edit-page[data-v-9370ca7a]{padding:var(--space-4) 0 var(--space-8)}.edit-title[data-v-9370ca7a]{font-size:var(--text-2xl)}.form-section[data-v-9370ca7a]{padding:var(--space-4)}.image-preview-list[data-v-9370ca7a]{grid-template-columns:repeat(3,1fr)}.form-actions[data-v-9370ca7a]{flex-direction:column-reverse}.btn[data-v-9370ca7a]{justify-content:center;width:100%}}
