@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Fira+Code:wght@400;500;600&display=swap";:root{--bg-primary: #1e1e1e;--bg-secondary: #252526;--bg-tertiary: #2d2d30;--bg-elevated: #3e3e42;--accent-primary: #007acc;--accent-hover: #1a8cd8;--accent-active: #0062a3;--text-primary: #cccccc;--text-secondary: #858585;--text-bright: #ffffff;--border-color: #3e3e42;--border-active: #007acc;--success: #4ec9b0;--warning: #ce9178;--error: #f48771;--info: #9cdcfe;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Fira Code", "Consolas", monospace;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--z-dropdown: 1000;--z-modal: 2000;--z-tooltip: 3000}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--bg-elevated: #ffffff;--text-primary: #212529;--text-secondary: #6c757d;--text-muted: #adb5bd;--text-bright: #000000;--accent-primary: #0d6efd;--accent-hover: #0a58ca;--accent-secondary: #6610f2;--border-color: #dee2e6;--success: #198754;--warning: #ffc107;--danger: #dc3545;--info: #0dcaf0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--text-bright);font-weight:600;line-height:1.3;margin-bottom:var(--spacing-md)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:var(--spacing-md)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}code{font-family:var(--font-mono);background-color:var(--bg-tertiary);padding:.125rem .375rem;border-radius:var(--radius-sm);font-size:.875em}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:#4e4e52}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-sans);font-size:.875rem;font-weight:500;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background-color:var(--accent-primary);color:var(--text-bright);border-color:var(--accent-primary)}.btn-primary:hover{background-color:var(--accent-hover);color:var(--text-bright);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active{background-color:var(--accent-active);transform:translateY(0)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background-color:var(--bg-elevated);border-color:var(--border-active);color:var(--text-bright)}.btn-danger{background-color:var(--error);color:var(--text-bright);border-color:var(--error)}.btn-danger:hover{background-color:#ff6b6b;border-color:#ff6b6b;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.input,.textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-sans);font-size:.875rem;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:focus,.textarea:focus{outline:none;border-color:var(--accent-primary);background-color:var(--bg-secondary);box-shadow:0 0 0 3px #007acc1a}.textarea{min-height:120px;resize:vertical;font-family:var(--font-mono)}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-interactive{cursor:pointer}.glass{background:#252526cc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--bg-elevated);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-secondary)}.text-bright{color:var(--text-bright)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-error{color:var(--error)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1200px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){html{font-size:14px}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media(max-width:480px){html{font-size:13px}}.ql-container{font-family:var(--font-sans);font-size:.875rem;background-color:var(--bg-tertiary);border-color:var(--border-color)!important;border-radius:0 0 var(--radius-md) var(--radius-md)}.ql-toolbar{background-color:var(--bg-secondary);border-color:var(--border-color)!important;border-radius:var(--radius-md) var(--radius-md) 0 0}.ql-editor{min-height:300px;color:var(--text-primary)}.ql-editor.ql-blank:before{color:var(--text-secondary);font-style:normal}.ql-stroke{stroke:var(--text-secondary)!important}.ql-fill{fill:var(--text-secondary)!important}.ql-picker-label{color:var(--text-secondary)!important}.ql-toolbar button:hover .ql-stroke,.ql-toolbar button.ql-active .ql-stroke{stroke:var(--accent-primary)!important}.ql-toolbar button:hover .ql-fill,.ql-toolbar button.ql-active .ql-fill{fill:var(--accent-primary)!important}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-base)}.sidebar-header{padding:var(--spacing-xl) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.sidebar-logo{font-family:"Orbitron",var(--font-mono);font-size:1.5rem;font-weight:900;color:var(--accent-primary);margin:0;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--info) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{font-size:.75rem;color:var(--text-secondary);margin:var(--spacing-xs) 0 0 0;font-weight:400}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.nav-item{margin-bottom:var(--spacing-xs)}.nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;font-family:var(--font-sans);font-size:.875rem;position:relative}.nav-link:hover{background-color:var(--bg-tertiary);color:var(--text-bright)}.nav-link.active{background-color:var(--bg-elevated);color:var(--accent-primary);border-left:5px solid var(--accent-primary)}.nav-link.nav-child.active{background-color:var(--bg-elevated);color:var(--text-primary);border-left:none!important}.nav-link.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.nav-icon{font-size:1.125rem;display:flex;align-items:center}.nav-label{flex:1;text-align:left}.nav-parent{justify-content:space-between}.nav-arrow{font-size:1.25rem;transition:transform var(--transition-fast);font-weight:300}.nav-parent.expanded .nav-arrow{transform:rotate(90deg)}.nav-children{display:flex;flex-direction:column;background-color:var(--bg-primary);animation:slideDown var(--transition-fast)}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.nav-child{padding-left:calc(var(--spacing-lg) + var(--spacing-md));font-size:.8125rem;position:relative;transition:all var(--transition-fast)}.nav-child:hover{background-color:var(--bg-elevated);color:var(--accent-primary);border-left-color:var(--accent-primary);padding-left:calc(var(--spacing-lg) + var(--spacing-md) + 4px)}.nav-child.active{background-color:var(--bg-elevated);color:var(--accent-primary);font-weight:600}.nav-child .nav-icon{font-size:.9rem;flex-shrink:0}.nav-child .nav-label{flex:1}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--spacing-sm)}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%}.theme-toggle-text,.btn-text{transition:opacity var(--transition-fast)}.w-full{width:100%;justify-content:center}.desktop-sidebar-toggle{display:none;position:fixed;left:260px;top:var(--spacing-md);z-index:101;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm);color:var(--text-primary);font-size:1.25rem;cursor:pointer;transition:left var(--transition-base);box-shadow:var(--shadow-md)}.desktop-sidebar-toggle:hover{background-color:var(--bg-elevated);color:var(--accent-primary)}.sidebar.collapsed{transform:translate(-280px)}body.sidebar-collapsed .desktop-sidebar-toggle{left:var(--spacing-md)}.mobile-header{display:none}.mobile-logo{font-family:"Orbitron",var(--font-mono);font-size:1.25rem;font-weight:900;color:var(--accent-primary);margin:0;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--info) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mobile-menu-toggle{display:none;position:fixed;top:var(--spacing-md);right:var(--spacing-md);z-index:1001;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm);color:var(--text-primary);font-size:1.5rem;cursor:pointer;transition:all var(--transition-fast)}.mobile-menu-toggle:hover{background-color:var(--bg-elevated);color:var(--accent-primary)}.sidebar-overlay{display:none}@media(min-width:769px){.desktop-sidebar-toggle{display:flex;align-items:center;justify-content:center}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar.collapsed{transform:translate(-100%)}.mobile-header{display:flex;justify-content:center;align-items:center;position:fixed;top:0;left:0;right:0;height:60px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:1000;padding:0 var(--spacing-md)}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center}.sidebar-overlay{display:block;position:fixed;inset:0;background-color:#00000080;z-index:99;animation:fadeIn var(--transition-fast)}.desktop-sidebar-toggle,.sidebar-subtitle{display:none}.main-content{padding-top:60px}}.nav-child .nav-label{display:flex;align-items:center;justify-content:space-between}.category-count{font-size:.75rem;color:var(--text-secondary);margin-left:var(--spacing-xs);font-weight:400}.nav-child.active .category-count{font-weight:600}.global-loader-overlay{position:fixed;inset:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-in-out}.global-loader-container{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg)}.loader-spinner{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;width:100%;height:100%;border:3px solid transparent;border-radius:50%;animation:spin 2s cubic-bezier(.68,-.55,.265,1.55) infinite}.spinner-ring:nth-child(1){border-top-color:var(--accent-primary);animation-delay:0s;width:100%;height:100%}.spinner-ring:nth-child(2){border-right-color:var(--info);animation-delay:-.5s;width:80%;height:80%}.spinner-ring:nth-child(3){border-bottom-color:var(--success);animation-delay:-1s;width:60%;height:60%}.spinner-core{position:absolute;width:30px;height:30px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--info) 100%);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.loader-text{font-size:1rem;color:var(--text-secondary);font-weight:500;letter-spacing:.5px;animation:textPulse 1.5s ease-in-out infinite}@keyframes textPulse{0%,to{opacity:.6}50%{opacity:1}}.global-loader-overlay.fade-out{animation:fadeOut .3s ease-in-out forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.home-container{max-width:2000px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg)}.hero-section{text-align:center;padding:var(--spacing-2xl) 0 0 0;margin-bottom:var(--spacing-2xl)}.hero-title{font-size:3rem;font-weight:700;margin-bottom:var(--spacing-lg);line-height:1.2}.gradient-text{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--info) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.125rem;color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:1.8}.post-excerpt{color:var(--text-secondary);line-height:1.6;margin:0;font-size:.9375rem;overflow-wrap:anywhere;word-break:break-word}@media(max-width:768px){.hero-title{font-size:2rem}.hero-description{font-size:1rem}.hero-section{display:none}.posts-grid{grid-template-columns:1fr}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.login-card{width:100%;max-width:420px;padding:var(--spacing-2xl);animation:fadeIn var(--transition-base)}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-icon{font-size:3rem;color:var(--accent-primary);margin-bottom:var(--spacing-md)}.login-header h2{margin-bottom:var(--spacing-sm)}.login-form,.form-group{margin-bottom:var(--spacing-lg)}.error-message{padding:var(--spacing-md);background-color:#f487711a;border:1px solid var(--error);border-radius:var(--radius-md);color:var(--error);font-size:.875rem;margin-bottom:var(--spacing-lg);animation:shake .3s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.login-footer{padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.login-footer p{margin:0;font-size:.8125rem}.login-divider{display:flex;align-items:center;text-align:center;margin:var(--spacing-xl) 0;position:relative}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.login-divider span{padding:0 var(--spacing-md);color:var(--text-muted);font-size:.875rem;font-weight:500}.sns-login-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.btn-sns{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);width:100%}.btn-sns:disabled{opacity:.6;cursor:not-allowed}.btn-sns svg{font-size:1.25rem}.btn-google{background:#fff;color:#3c4043;border:1px solid #dadce0}.btn-google:hover:not(:disabled){background:#f8f9fa;box-shadow:0 2px 8px #00000026;transform:translateY(-2px);border-color:#dadce0}.btn-google svg{color:#4285f4}.btn-github{background:#24292e;color:#fff;border:1px solid #24292e}.btn-github:hover:not(:disabled){background:#1b1f23;box-shadow:0 1px 3px #0000004d;transform:translateY(-1px)}.btn-facebook{background:#1877f2;color:#fff;border:1px solid #1877f2}.btn-facebook:hover:not(:disabled){background:#166fe5;box-shadow:0 1px 3px #1877f24d;transform:translateY(-1px)}[data-theme=dark] .btn-google{background:#ffffff1a;color:#e8eaed;border-color:#fff3}[data-theme=dark] .btn-google:hover:not(:disabled){background:#ffffff26}@media(max-width:480px){.login-card{padding:var(--spacing-xl)}.btn-sns{font-size:.875rem;padding:var(--spacing-sm) var(--spacing-md)}.btn-sns svg{font-size:1.125rem}}.about-container{max-width:1200px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg)}.about-header{text-align:center;margin-bottom:var(--spacing-2xl)}.about-header h1{font-size:3rem;margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-badges{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;margin-top:var(--spacing-md)}.badge-item{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background-color:var(--bg-secondary);border-radius:2rem;font-size:1rem;color:var(--text-primary);font-weight:500;transition:all var(--transition-base);border:1px solid var(--border-color)}.badge-item:hover{transform:translateY(-2px);background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-primary);box-shadow:var(--shadow-md)}.badge-icon{font-size:1.1em}.badge-divider{color:var(--text-tertiary);font-size:.8rem}.about-section{margin-bottom:var(--spacing-2xl)}.about-section h2{font-size:1.75rem;margin-bottom:var(--spacing-lg);color:var(--text-bright)}.about-section.card{padding:var(--spacing-xl)}.about-intro{font-size:1.125rem;line-height:1.8;color:var(--text-primary);margin-bottom:var(--spacing-md)}.tech-stack-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md)}.tech-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);text-align:center}.tech-icon{font-size:3rem;transition:transform var(--transition-base)}.tech-item:hover .tech-icon{transform:scale(1.1)}.tech-item span{font-family:var(--font-mono);font-size:.9375rem;color:var(--text-primary)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg)}.skill-category{padding:var(--spacing-lg)}.skill-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.skill-icon{font-size:1.5rem;color:var(--accent-primary)}.skill-header h3{font-size:1.25rem;margin:0;color:var(--text-bright)}.skill-list{list-style:none;padding:0;margin:0}.skill-list li{padding:var(--spacing-xs) 0;color:var(--text-secondary);font-size:.9375rem;position:relative;padding-left:var(--spacing-md)}.skill-list li:before{content:"▹";position:absolute;left:0;color:var(--accent-primary)}.contact-links{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.contact-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;color:var(--text-primary);font-family:var(--font-mono);font-size:1rem;transition:all var(--transition-base)}.contact-link svg{font-size:1.5rem;color:var(--accent-primary)}.contact-link:hover{transform:translateY(-2px)}.blog-info{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color)}.blog-info p{line-height:1.8;margin-bottom:var(--spacing-md)}.blog-info p:last-child{margin-bottom:0;text-align:center;font-size:.875rem}@media(max-width:768px){.about-header h1{font-size:2rem}.about-badges{gap:var(--spacing-sm)}.badge-item{font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm)}.badge-divider{display:none}.tech-stack-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.skills-grid{grid-template-columns:1fr}.contact-links{flex-direction:column}.contact-link{width:100%;justify-content:center}}.post-list-container{max-width:2000px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg)}.post-list-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.header-text{flex:1}.post-list-header h1{margin-top:0;margin-bottom:var(--spacing-xs);line-height:1}.search-bar-container{flex-shrink:0;width:350px}.search-input-wrapper{position:relative;width:100%}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:1.125rem}.search-input{padding-left:calc(var(--spacing-md) * 3)}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.post-card{display:block;padding:var(--spacing-xl);text-decoration:none;color:inherit;height:100%}.post-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);gap:var(--spacing-sm);flex-wrap:wrap}.post-category,.post-date{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.8125rem;color:var(--text-secondary)}.post-category{background-color:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-family:var(--font-mono)}.post-title{font-size:1.25rem;margin-bottom:var(--spacing-md);color:var(--text-bright);line-height:1.4;overflow-wrap:anywhere;word-break:break-word}.post-excerpt{color:var(--text-secondary);line-height:1.6;margin:0;margin-bottom:var(--spacing-md);font-size:.9375rem;overflow-wrap:anywhere;word-break:break-word}.post-card-footer{display:flex;justify-content:flex-end;align-items:center;padding-top:var(--spacing-sm);border-top:1px solid var(--border-color)}.post-comment-count{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.8125rem;color:var(--text-secondary);font-family:var(--font-mono)}.post-comment-count svg{font-size:.875rem}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.loading-indicator{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);color:var(--text-secondary)}.end-message{display:none;width:0px;height:0px}.scroll-top-fab{position:fixed;bottom:2rem;right:2rem;width:3.5rem;height:3.5rem;border-radius:50%;background-color:var(--bg-secondary);color:var(--text-bright);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:100;transition:all var(--transition-base);border:1px solid var(--border-color);cursor:pointer;font-size:1.5rem}.scroll-top-fab:hover{background-color:var(--accent-primary);border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:var(--shadow-xl)}.scroll-top-fab:active{transform:translateY(0)}.add-new-fab{position:fixed;bottom:6.5rem;right:2rem;width:3.5rem;height:3.5rem;border-radius:50%;background-color:var(--accent-primary);color:var(--text-bright);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);z-index:100;transition:all var(--transition-base);border:none;cursor:pointer;font-size:1.5rem}.add-new-fab:hover{background-color:var(--accent-primary);transform:translateY(-4px) rotate(90deg);box-shadow:var(--shadow-xl);filter:brightness(1.1)}.add-new-fab:active{transform:translateY(0) rotate(90deg)}.tech-stack-section{margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-color)}.tech-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:center}.tech-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:.875rem;transition:all var(--transition-fast);text-decoration:none}.tech-tag-icon{font-size:1rem;flex-shrink:0}.tech-tag:hover{border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(max-width:768px){.post-list-header{margin-top:40px;margin-bottom:10px;flex-direction:column;align-items:flex-start;position:relative}.search-bar-container{width:100%;padding:0;margin:0 0 10px}.post-list-header h1{margin-bottom:var(--spacing-xs)}.text-muted{margin-bottom:0}.posts-grid{grid-template-columns:1fr}.add-new-fab svg{transition:transform var(--transition-base)}.add-new-fab:hover svg{transform:rotate(90deg)}}.comments-section{margin-top:3rem;padding:2rem 0;background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-sm);max-width:100%}.comments-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.comments-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.comments-header svg{color:var(--primary-color)}.comment-form{margin-bottom:2rem}.comment-input{width:100%;padding:1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:.95rem;line-height:1.6;resize:vertical;transition:all .3s ease;margin-bottom:1rem}.comment-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.comment-input:disabled{opacity:.6;cursor:not-allowed}.comment-submit-btn{display:flex;align-items:center;gap:.5rem;margin-left:auto}.comment-login-notice{padding:1.5rem;background:var(--bg-secondary);border-radius:8px;text-align:center;margin-bottom:2rem}.comment-login-notice p{margin:0;color:var(--text-secondary)}.comments-loading,.comments-empty{padding:0;margin:0;text-align:center;width:0px;height:0px;overflow:hidden}.comments-loading{display:flex;flex-direction:column;align-items:center;gap:1rem}.comments-list{display:flex;flex-direction:column;gap:1.5rem}.comment-item{padding:1.5rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.comment-author{font-weight:600;color:#1a8cd8!important;font-size:.95rem}.comment-date{font-size:.85rem;color:var(--text-secondary)}.comment-content{margin:0;color:var(--text-primary);line-height:1.6;white-space:pre-wrap;word-break:break-word}.comment-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-icon{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:var(--bg-primary);color:var(--primary-color)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-danger-icon:hover{background:#ef44441a;color:var(--danger-color)}.comment-edit-form{margin-top:.5rem}.comment-edit-actions{display:flex;gap:.5rem;margin-top:.5rem}.btn-sm{padding:.5rem 1rem;font-size:.875rem}@media(max-width:768px){.comments-section{padding:1.5rem 0;margin-top:2rem}.comments-header h2{font-size:1.25rem}.comment-input{font-size:.9rem;padding:.875rem}.comment-item{padding:1rem}.comment-header{flex-direction:column;align-items:flex-start}.comment-edit-actions{flex-direction:column}.comment-edit-actions .btn{width:100%}}@media(prefers-color-scheme:dark){.comment-item{background:#ffffff08}}.comment-meta-info{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.85rem;color:var(--text-secondary);flex-wrap:wrap;gap:.5rem}.char-count.error{color:var(--danger-color);font-weight:700}.captcha-container{display:flex;align-items:center;gap:1rem;margin:1rem 0;padding:1rem;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);flex-wrap:wrap}.captcha-label{font-size:.95rem;color:var(--text-primary)}.captcha-input{width:120px;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);text-align:center;font-size:1rem}.captcha-input:focus{outline:none;border-color:var(--primary-color)}.captcha-input::-webkit-outer-spin-button,.captcha-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.captcha-input[type=number]{-moz-appearance:textfield}.related-posts-container{margin-top:var(--spacing-2xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-color)}.related-posts-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);font-size:1.25rem;color:var(--text-bright)}.view-all-link{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.9rem;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-base)}.view-all-link:hover{color:var(--accent-primary)}.related-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-md)}.related-post-card{display:flex;flex-direction:column;padding:var(--spacing-lg);height:100%;text-decoration:none;background-color:var(--bg-secondary);border:1px solid var(--border-color);transition:all var(--transition-base)}.related-post-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:var(--shadow-md)}.related-post-content{display:flex;flex-direction:column;height:100%}.related-post-subject{font-size:1.1rem;margin-bottom:var(--spacing-sm);color:var(--text-bright);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex-grow:1}.related-post-meta{display:flex;align-items:center;font-size:.85rem;color:var(--text-secondary);margin-top:auto}.related-post-date{display:flex;align-items:center;gap:var(--spacing-xs)}@media(max-width:768px){.related-posts-grid{grid-template-columns:1fr}.related-post-card{padding:var(--spacing-md)}}.table-of-contents{position:fixed;z-index:50;transition:opacity var(--transition-fast),transform var(--transition-fast)}.table-of-contents.closed{width:auto}.table-of-contents.open{width:280px;background:#252526f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);transform-origin:top right}.table-of-contents.dragging{cursor:grabbing;-webkit-user-select:none;user-select:none;opacity:.9}.toc-icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#252526f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.25rem;cursor:grab;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.toc-icon-btn:hover{background:#2d2d30fa;color:var(--accent-primary);border-color:var(--accent-primary);transform:scale(1.05);box-shadow:var(--shadow-lg)}.toc-icon-btn:active{cursor:grabbing}.toc-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.toc-drag-handle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-secondary);cursor:grab;transition:all var(--transition-fast);border-radius:var(--radius-sm)}.toc-drag-handle:hover{color:var(--accent-primary);background:#007acc1a}.toc-drag-handle:active{cursor:grabbing}.toc-title{flex:1;font-size:1rem;font-weight:600;margin:0;color:var(--text-bright)}.toc-close-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-sm)}.toc-close-btn:hover{color:var(--error);background:#f487711a}.toc-list{list-style:none;padding:var(--spacing-md);margin:0;max-height:calc(100vh - 200px);overflow-y:auto;cursor:default}.toc-item{margin-bottom:var(--spacing-xs)}.toc-link{display:block;text-decoration:none;color:var(--text-secondary);font-size:.875rem;padding:6px 10px;border-radius:6px;transition:all var(--transition-base);line-height:1.5;border-left:2px solid transparent;cursor:pointer}.toc-link:hover{color:var(--accent-primary);background-color:#007acc0d;transform:translate(2px)}.toc-link.active{color:var(--accent-primary);font-weight:600;background-color:#007acc1a;border-left-color:var(--accent-primary)}.toc-level-1 .toc-link{padding-left:10px;font-weight:500}.toc-level-2 .toc-link{padding-left:20px;font-size:.85rem}.toc-level-3 .toc-link{padding-left:30px;font-size:.8rem;color:var(--text-secondary)}.toc-list::-webkit-scrollbar{width:4px}.toc-list::-webkit-scrollbar-track{background:transparent}.toc-list::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:4px}.toc-list::-webkit-scrollbar-thumb:hover{background-color:var(--accent-primary)}@media(max-width:768px){.table-of-contents{position:static;width:100%;margin-top:var(--spacing-lg)}.toc-drag-handle{display:none}.toc-list{max-height:400px}}.post-detail-container{max-width:2000px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg);overflow-x:hidden;width:100%;box-sizing:border-box}.post-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.post-actions{display:flex;gap:var(--spacing-sm)}.post-content{padding:var(--spacing-2xl);overflow-x:hidden}.post-content.card:hover{transform:none;box-shadow:none;border-color:var(--border-color)}.post-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.post-category-badge,.post-date-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.8125rem;color:var(--text-secondary)}.post-category-badge{font-family:var(--font-mono);color:var(--accent-primary)}.post-title-detail{font-size:2.5rem;margin-bottom:var(--spacing-xl);line-height:1.3;padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--border-color);overflow-wrap:anywhere;word-break:break-word;word-wrap:break-word}.share-buttons{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg) 0;margin-top:var(--spacing-2xl);border-top:1px solid var(--border-color)}.share-label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary);font-weight:500}.share-icons{display:flex;gap:var(--spacing-sm)}.share-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:50%;cursor:pointer;transition:all var(--transition-fast);font-size:1.125rem}.share-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.share-btn:active{transform:translateY(0)}.share-twitter{background-color:#1da1f2;color:#fff}.share-twitter:hover{background-color:#1a8cd8}.share-facebook{background-color:#1877f2;color:#fff}.share-facebook:hover{background-color:#1664d9}.share-kakao{background-color:#fee500;color:#3c1e1e}.share-kakao:hover{background-color:#fdd800}.post-body{font-size:1rem;line-height:1.8;color:var(--text-primary);overflow-wrap:anywhere;word-break:break-word;word-wrap:break-word;max-width:100%;overflow-x:hidden}.post-body *{max-width:100%!important;box-sizing:border-box}.post-body h1,.post-body h2,.post-body h3,.post-body h4,.post-body h5,.post-body h6{color:var(--text-bright);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md);overflow-wrap:anywhere;word-break:break-word}.post-body h1{font-size:2rem}.post-body h2{font-size:1.75rem}.post-body h3{font-size:1.5rem}.post-body h4{font-size:1.25rem}.post-body p{margin-bottom:var(--spacing-lg)}.post-body ul,.post-body ol{margin-bottom:var(--spacing-lg);padding-left:var(--spacing-xl)}.post-body li{margin-bottom:var(--spacing-sm)}.post-body pre{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-lg);white-space:pre-wrap!important;word-break:break-all!important;overflow-wrap:anywhere!important;max-width:100%!important;margin-bottom:var(--spacing-lg);box-sizing:border-box}.post-body .code-toolbar{max-width:100%!important;overflow-x:hidden!important;box-sizing:border-box!important;margin-bottom:var(--spacing-lg)}.post-body .code-toolbar pre{white-space:pre-wrap!important;word-break:break-all!important;overflow-wrap:anywhere!important;max-width:100%!important;margin:0!important}.post-body code{font-family:var(--font-mono);font-size:.875em;white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere}.post-body pre code{background:none;padding:0;white-space:inherit;word-break:inherit;overflow-wrap:inherit}.post-body blockquote{border-left:4px solid var(--accent-primary);padding-left:var(--spacing-lg);margin:var(--spacing-lg) 0;color:var(--text-secondary);font-style:italic}.post-body img,.post-body video,.post-body iframe{max-width:100%!important;height:auto!important;display:block;margin:1.5rem auto;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.post-body table{display:block;width:100%;overflow-x:auto;border-collapse:collapse;margin-bottom:var(--spacing-lg)}.post-body a{color:var(--accent-primary);text-decoration:underline;overflow-wrap:anywhere;word-break:break-all}.post-body a:hover{color:var(--accent-hover)}.post-updated{margin-top:var(--spacing-2xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.post-updated p{margin:0;font-size:.875rem}.post-detail-footer{display:none}.desktop-only{display:flex}.mobile-only{display:none}@media(max-width:768px){.post-detail-container{padding:var(--spacing-md)}.desktop-only{display:none}.mobile-only{display:flex}.post-detail-footer{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xl);padding:var(--spacing-lg);flex-wrap:wrap}.post-detail-footer .btn{flex:1;min-width:120px;justify-content:center}.post-content{padding:var(--spacing-md)}.post-title-detail{font-size:1.75rem;word-break:break-word}.post-body{font-size:.9375rem}.post-body .code-toolbar{max-width:300px!important;width:300px!important;overflow-x:hidden!important;margin:0 auto}.share-buttons{justify-content:flex-end;gap:var(--spacing-sm)}.share-btn{width:36px;height:36px;font-size:1rem}.details{margin-top:60px!important}}.mobile-back-btn{position:fixed;top:1rem;left:1rem;width:2.5rem;height:2.5rem;display:none;align-items:center;justify-content:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:50%;color:var(--text-primary);font-size:1.25rem;box-shadow:var(--shadow-md);z-index:1000;transition:all var(--transition-fast);text-decoration:none}.mobile-back-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color);transform:translate(-2px)}.mobile-back-btn:active{transform:translate(0) scale(.95)}@media(max-width:768px){.mobile-back-btn{display:flex}}@media(max-width:768px){.post-mobile-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.5rem;margin-bottom:-1.5rem;padding:0 .5rem;z-index:10;position:relative}.post-mobile-actions .btn{padding:.5rem 1rem;font-size:.875rem;border-radius:20px;box-shadow:var(--shadow-sm)}}.post-body pre{position:relative}.code-copy-btn{position:absolute;top:.5rem;right:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#e2e8f0;padding:.25rem .5rem;font-size:.75rem;cursor:pointer;transition:all .2s;opacity:0;display:flex;align-items:center;gap:.25rem}.post-body pre:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{background:#fff3}.code-copy-btn.copied{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.post-body-wrapper{display:block;width:100%}.post-content-main{width:100%;max-width:100%}.post-form-container{max-width:2000px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg)}.post-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);gap:var(--spacing-md)}.post-form{padding:var(--spacing-2xl)}.form-group{margin-bottom:var(--spacing-xl)}.form-group label{display:block;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:.875rem;font-weight:500}.input-error{border-color:var(--error)!important}.error-text{display:block;margin-top:var(--spacing-xs);color:var(--error);font-size:.8125rem}.form-group select{cursor:pointer}.form-actions{display:flex;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.editor-hint{margin-top:var(--spacing-sm);font-size:.8125rem;color:var(--text-secondary);display:flex;align-items:center;gap:var(--spacing-xs)}.jodit-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.jodit-wrapper.editor-error{border-color:var(--error)}.jodit-wrapper .jodit-toolbar__box{background-color:var(--bg-secondary)!important;border-bottom:1px solid var(--border-color)!important;padding:var(--spacing-sm)!important}.jodit-wrapper .jodit-toolbar-button{background-color:var(--bg-tertiary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important;margin:2px!important;transition:all var(--transition-fast)!important}.jodit-wrapper .jodit-toolbar-button:hover{background-color:var(--bg-elevated)!important;border-color:var(--accent-primary)!important}.jodit-wrapper .jodit-toolbar-button_active,.jodit-wrapper .jodit-toolbar-button_active:hover{background-color:var(--accent-primary)!important;border-color:var(--accent-primary)!important}.jodit-wrapper .jodit-toolbar-button svg{fill:var(--text-primary)!important}.jodit-wrapper .jodit-toolbar-button_active svg{fill:var(--text-bright)!important}.jodit-wrapper .jodit-wysiwyg{background-color:var(--bg-tertiary)!important;color:var(--text-primary)!important;min-height:400px!important;padding:var(--spacing-md)!important;font-size:1rem!important;line-height:1.6!important}.jodit-wrapper .jodit-placeholder{color:var(--text-secondary)!important}.jodit-popup__content{background-color:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-md)!important}.jodit-popup__content .jodit-toolbar-button{background-color:transparent!important;border:none!important}.jodit-popup__content .jodit-toolbar-button:hover{background-color:var(--bg-elevated)!important}.jodit-color-picker{background-color:var(--bg-secondary)!important;border:1px solid var(--border-color)!important}.jodit-color-picker__native{background-color:var(--bg-tertiary)!important;border:1px solid var(--border-color)!important}.jodit-source__mirror{background-color:var(--bg-tertiary)!important;color:var(--text-primary)!important;font-family:Consolas,Monaco,Courier New,monospace!important;font-size:.875rem!important;border:none!important}.jodit-wysiwyg h1,.jodit-wysiwyg h2,.jodit-wysiwyg h3,.jodit-wysiwyg h4,.jodit-wysiwyg h5,.jodit-wysiwyg h6{color:var(--text-primary)!important;font-weight:600!important;margin-top:1em!important;margin-bottom:.5em!important}.jodit-wysiwyg blockquote{border-left:4px solid var(--accent-primary)!important;padding-left:var(--spacing-md)!important;margin:var(--spacing-md) 0!important;color:var(--text-secondary)!important}.jodit-wysiwyg code,.jodit-wysiwyg pre{background-color:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important;padding:2px 4px!important;font-family:Consolas,Monaco,Courier New,monospace!important}.jodit-wysiwyg pre{padding:var(--spacing-sm)!important;margin:var(--spacing-md) 0!important;overflow-x:auto!important}.jodit-wysiwyg img{max-width:100%!important;height:auto!important;display:block!important;margin:1rem auto!important;border-radius:var(--radius-sm)!important}.jodit-wysiwyg a{color:var(--accent-primary)!important;text-decoration:underline!important}.jodit-wysiwyg a:hover{color:var(--accent-hover)!important}.jodit-wysiwyg table{border-collapse:collapse!important;width:100%!important;margin:var(--spacing-md) 0!important}.jodit-wysiwyg table td,.jodit-wysiwyg table th{border:1px solid var(--border-color)!important;padding:var(--spacing-sm)!important}.jodit-wysiwyg table th{background-color:var(--bg-secondary)!important;font-weight:600!important}.jodit-status-bar{display:none!important}.jodit-ui-group{background-color:transparent!important}.jodit-ui-button{color:var(--text-primary)!important}.jodit-ui-input{background-color:var(--bg-tertiary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-sm)!important}.jodit-ui-input:focus{border-color:var(--accent-primary)!important;outline:none!important}@media(max-width:768px){.post-form-header{flex-direction:column;align-items:flex-start}.post-form{padding:var(--spacing-xl)}.form-actions{flex-direction:column}.form-actions .btn{width:100%;justify-content:center}.jodit-wrapper .jodit-toolbar__box{flex-wrap:wrap!important}.jodit-wrapper .jodit-wysiwyg{min-height:300px!important}}.quill-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.quill-wrapper.editor-error{border-color:var(--error)}.quill-wrapper .ql-toolbar{background-color:var(--bg-secondary);border:none;border-bottom:1px solid var(--border-color);padding:var(--spacing-sm)}.quill-wrapper .ql-container{background-color:var(--bg-tertiary);border:none;font-size:1rem}.quill-wrapper .ql-editor{color:var(--text-primary);min-height:400px;padding:var(--spacing-md)}.quill-wrapper .ql-editor.ql-blank:before{color:var(--text-secondary);font-style:normal}.quill-wrapper .ql-editor pre.ql-syntax{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--spacing-md);overflow-x:auto;font-family:var(--font-mono);white-space:pre-wrap}.not-found-container{display:flex;align-items:center;justify-content:center;min-height:80vh;text-align:center;padding:var(--spacing-xl);background-color:var(--bg-primary)}.not-found-content{max-width:600px;width:100%;display:flex;flex-direction:column;align-items:center;animation:fadeIn .3s ease-out}.vscode-icon{font-size:5rem;color:var(--text-secondary);margin-bottom:var(--spacing-lg);opacity:.5}.vscode-title{font-size:1.1rem;font-weight:400;color:var(--text-primary);margin-bottom:var(--spacing-md);line-height:1.5}.vscode-message{font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.vscode-actions{display:flex;gap:var(--spacing-md)}.not-found-content .btn-primary{background-color:var(--accent-primary);color:#fff;border-radius:2px;padding:6px 14px;font-size:13px;font-weight:400}.not-found-content .btn-primary:hover{background-color:var(--accent-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.projects-container{max-width:1200px;margin:0 auto;padding:var(--spacing-xl)}.projects-header{text-align:center;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.projects-icon-wrapper{font-size:3rem;color:var(--accent-primary);margin-bottom:var(--spacing-md);display:inline-flex;padding:var(--spacing-lg);background:var(--bg-secondary);border-radius:50%;box-shadow:var(--shadow-md)}.projects-header h1{font-size:2.5rem;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--spacing-xl)}.project-card{display:flex;flex-direction:column;overflow:hidden;height:100%;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.project-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);border-color:var(--accent-primary)}.project-image{position:relative;width:100%;padding-top:56.25%;background-color:var(--bg-tertiary);overflow:hidden}.project-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card:hover .project-image img{transform:scale(1.05)}.project-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;gap:var(--spacing-md)}.project-link-btn{display:flex;align-items:center;justify-content:center;width:50px;height:50px;background:#fff;color:#1e293b;border-radius:50%;font-size:1.5rem;transition:transform var(--transition-fast)}.project-link-btn:hover{transform:scale(1.1);background:var(--accent-primary);color:#fff}.project-content{padding:var(--spacing-lg);display:flex;flex-direction:column;flex-grow:1}.project-meta{margin-bottom:var(--spacing-sm)}.project-category-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--accent-primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.project-title{font-size:1.5rem;margin-bottom:var(--spacing-md);color:var(--text-primary)}.project-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:var(--spacing-lg);flex-grow:1}.project-tech-stack{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:auto}.tech-badge{padding:.25rem .6rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;font-size:.75rem;color:var(--text-secondary);font-family:var(--font-mono)}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}.projects-header h1{font-size:2rem}}.app{display:flex;min-height:100vh}.main-content{flex:1;margin:0 0 0 280px;padding:0px var(--spacing-xl) var(--spacing-xl) var(--spacing-xl);transition:margin-left var(--transition-base)}body.sidebar-collapsed .main-content{margin-left:0}.page-container{max-width:1200px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg)}@media(max-width:768px){.main-content{margin-left:0;padding:0}}.jodit-ui-separator{border-right:none!important}.jodit-color-panel,.jodit-color-gray{display:none!important}:root{--jd-color-panel: none !important;--jd-color-gray: none !important}.jodit-container:not(.jodit_inline){background-color:none!important}
