*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #667eea;--primary-dark: #5568d3;--secondary: #764ba2;--bg-light: #f7fafc;--bg-white: #ffffff;--text-dark: #1a202c;--text-gray: #718096;--border: #e2e8f0;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15);--radius: 12px;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-light);color:var(--text-dark);line-height:1.6}#app{min-height:100vh}.gallery-view{min-height:100vh;padding:40px 20px}.header{text-align:center;margin-bottom:60px;animation:fadeInDown .6s ease-out;position:relative;display:flex;flex-direction:column;align-items:center}.lang-toggle{margin-top:16px;padding:6px 16px;border:1px solid var(--border);border-radius:20px;background:var(--bg-white);color:var(--text-gray);font-size:14px;cursor:pointer;transition:var(--transition)}.lang-toggle:hover{border-color:var(--primary);color:var(--primary)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.logo-container{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:12px}.site-logo{filter:drop-shadow(0 4px 6px rgba(102,126,234,.3));transition:transform .3s ease}.site-logo:hover{transform:scale(1.05) rotate(5deg)}.title{font-size:48px;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:0}.subtitle{font-size:20px;color:var(--text-gray);font-weight:400}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;padding:0 24px 48px;max-width:1400px;margin:0 auto}.tag-filter{display:flex;gap:12px;padding:0 24px 24px;max-width:1400px;margin:0 auto;flex-wrap:wrap;align-items:center}.tag-pill{padding:8px 16px;border-radius:20px;border:2px solid rgba(102,126,234,.3);background:#ffffff0d;color:var(--text-dark);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tag-pill:hover{background:#667eea33;border-color:#667eea80;transform:translateY(-2px)}.tag-pill.active{background:linear-gradient(135deg,var(--primary),var(--secondary));border-color:transparent;color:#fff;box-shadow:0 4px 12px #667eea66}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.project-card{background:var(--bg-white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:var(--transition);cursor:pointer;animation:slideUp .6s ease-out backwards}.project-card:nth-child(1){animation-delay:.1s}.project-card:nth-child(2){animation-delay:.2s}.project-card:nth-child(3){animation-delay:.3s}.project-card:nth-child(4){animation-delay:.4s}.project-card:nth-child(5){animation-delay:.5s}.project-card:nth-child(6){animation-delay:.6s}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.project-thumbnail{width:100%;height:200px;overflow:hidden;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%)}.project-thumbnail img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.project-card:hover .project-thumbnail img{transform:scale(1.1)}.project-info{padding:24px}.project-title{font-size:20px;font-weight:600;color:var(--text-dark);margin-bottom:8px;line-height:1.3}.project-description{font-size:14px;color:var(--text-gray);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.empty-state{grid-column:1 / -1;text-align:center;padding:80px 20px;color:var(--text-gray)}.empty-state h2{font-size:28px;color:var(--text-dark);margin-bottom:16px}.empty-state p{font-size:16px;margin-bottom:12px}.empty-state code{background:var(--bg-white);padding:4px 8px;border-radius:4px;font-family:Monaco,Courier New,monospace;color:var(--primary);border:1px solid var(--border)}.empty-state .hint{font-size:14px;color:var(--text-gray);margin-top:8px}.project-view{position:relative;width:100vw;height:100vh;background:var(--bg-white);overflow:hidden;display:flex}.project-iframe{flex:1;height:100vh;border:none;background:#fff;transition:margin-right .3s ease;min-width:0}.floating-toolbar{position:fixed;top:16px;right:16px;z-index:100;display:flex;gap:8px;padding:8px;border-radius:50px;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 16px #00000014;border:1px solid rgba(255,255,255,.3)}.toolbar-button{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:50%;cursor:pointer;transition:all .2s ease;color:var(--text-dark);position:relative}.toolbar-button:hover{background:var(--primary);color:#fff;transform:scale(1.1)}.toolbar-button:active{transform:scale(.95)}.toolbar-button svg{flex-shrink:0}.toolbar-button:after{content:attr(title);position:absolute;bottom:-36px;right:0;padding:6px 12px;background:#000c;color:#fff;font-size:12px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease}.toolbar-button:hover:after{opacity:1}.drawer-overlay{display:none}.prompt-drawer{position:relative;width:450px;height:100vh;background:var(--bg-white);border-left:1px solid var(--border);z-index:50;display:flex;flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1),opacity .2s ease;overflow:hidden;flex-shrink:0}.prompt-drawer.collapsed{width:0;opacity:0;border-left:none}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:24px 30px;border-bottom:1px solid var(--border);background:var(--bg-white);flex-shrink:0}.drawer-title{font-size:20px;font-weight:600;color:var(--text-dark);margin:0}.close-drawer-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:var(--bg-light);border-radius:8px;cursor:pointer;transition:var(--transition);color:var(--text-gray)}.close-drawer-button:hover{background:var(--primary);color:#fff;transform:rotate(90deg)}.drawer-content{flex:1;overflow-y:auto;padding:30px}.markdown-body{color:var(--text-dark);line-height:1.8}.markdown-body h1{font-size:28px;font-weight:700;margin-top:0;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border);color:var(--text-dark)}.markdown-body h2{font-size:22px;font-weight:600;margin-top:32px;margin-bottom:16px;color:var(--text-dark)}.markdown-body h3{font-size:18px;font-weight:600;margin-top:24px;margin-bottom:12px;color:var(--text-dark)}.markdown-body p{margin-bottom:16px;color:var(--text-dark)}.markdown-body ul,.markdown-body ol{margin-bottom:16px;padding-left:24px}.markdown-body li{margin-bottom:8px;color:var(--text-dark)}.markdown-body code{background:var(--bg-light);padding:2px 6px;border-radius:4px;font-family:Monaco,Courier New,monospace;font-size:13px;color:var(--primary);border:1px solid var(--border)}.markdown-body pre{background:var(--bg-light);padding:16px;border-radius:8px;overflow-x:auto;margin-bottom:16px;border:1px solid var(--border)}.markdown-body pre code{background:none;padding:0;border:none;color:var(--text-dark);font-size:13px;line-height:1.6}.markdown-body blockquote{border-left:4px solid var(--primary);padding-left:16px;margin:16px 0;color:var(--text-gray);font-style:italic}.markdown-body a{color:var(--primary);text-decoration:none;transition:var(--transition)}.markdown-body a:hover{color:var(--primary-dark);text-decoration:underline}.markdown-body strong{font-weight:600;color:var(--text-dark)}.markdown-body em{font-style:italic}.markdown-body hr{border:none;border-top:1px solid var(--border);margin:24px 0}@media(max-width:768px){.title{font-size:32px}.subtitle{font-size:16px}.projects-grid{grid-template-columns:1fr;gap:20px;padding:0 10px}.gallery-view{padding:30px 16px}.header{margin-bottom:30px}.project-view{flex-direction:column}.prompt-drawer{position:fixed;top:0;right:0;width:100%;height:100%;z-index:200;border-left:none;transform:translate(0)}.prompt-drawer.collapsed{width:100%;transform:translate(100%);opacity:1}.floating-toolbar{top:16px;bottom:auto;right:16px;background:#fffffff2;box-shadow:0 4px 20px #0003}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}
