*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1565c0;--primary-dark: #0d47a1;--primary-light: #e3f2fd;--accent: #d32f2f;--accent-light: #ffebee;--teal: #00897b;--teal-light: #e0f2f1;--bg: #ffffff;--bg-secondary: #f5f7fa;--bg-card: #ffffff;--text: #1a1a2e;--text-secondary: #5f6c7b;--text-muted: #a0aab4;--border: #e2e8f0;--success: #2e7d32;--warning: #f57f17;--danger: #c62828;--shadow: 0 2px 12px rgba(21, 101, 192, .08);--shadow-lg: 0 8px 32px rgba(21, 101, 192, .12);--radius: 10px;--radius-lg: 14px;--font: "Montserrat", system-ui, -apple-system, sans-serif;--nav-height: 64px;--sidebar-width: 260px;--sidebar-collapsed: 64px;--max-width: 1200px;--transition: .2s ease;--gradient-primary: linear-gradient(135deg, #1565c0 0%, #0d47a1 100%);--gradient-accent: linear-gradient(135deg, #d32f2f 0%, #b71c1c 100%);--gradient-hero: linear-gradient(135deg, #e3f2fd 0%, #e0f2f1 50%, #fff 100%)}[data-theme=dark]{--primary: #42a5f5;--primary-dark: #1e88e5;--primary-light: #0d2137;--accent: #ef5350;--accent-light: #2a1515;--teal: #4db6ac;--teal-light: #0d2320;--bg: #0a0e17;--bg-secondary: #111827;--bg-card: #1a2235;--text: #e8edf5;--text-secondary: #94a3b8;--text-muted: #475569;--border: #1e293b;--shadow: 0 2px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--gradient-hero: linear-gradient(135deg, #0d2137 0%, #0d2320 50%, #0a0e17 100%)}body:not(.admin-page) img{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}body:not(.admin-page) .post-content,body:not(.admin-page) .tutorial-pager__content,body:not(.admin-page) .about-section,body:not(.admin-page) .hero,body:not(.admin-page) .expertise-card,body:not(.admin-page) .project-card{-webkit-user-select:none;user-select:none}body:not(.admin-page) pre,body:not(.admin-page) code{-webkit-user-select:text;user-select:text}body:not(.admin-page) .post-content img,body:not(.admin-page) .tutorial-pager__content img,body:not(.admin-page) .about-hero__photo img,body:not(.admin-page) .card__image,body:not(.admin-page) .post-page__featured-image,body:not(.admin-page) .hero img{position:relative;pointer-events:none}body:not(.admin-page) .post-content,body:not(.admin-page) .tutorial-pager__content,body:not(.admin-page) .about-hero__photo,body:not(.admin-page) .hero__content{position:relative}body:not(.admin-page) .img-shield{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2;background:transparent;cursor:default}body:not(.admin-page) .post-content img,body:not(.admin-page) .tutorial-pager__content img,body:not(.admin-page) .card__image{position:relative}body:not(.admin-page) .img-protected{position:relative;display:inline-block}body:not(.admin-page) .img-protected:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;z-index:5;background:transparent;pointer-events:auto;cursor:default}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font);font-weight:400;line-height:1.6;color:var(--text);background-color:var(--bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-dark)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{font-family:var(--font);cursor:pointer;border:none;background:none;font-size:inherit}input,textarea,select{font-family:var(--font);font-size:inherit}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;color:var(--text)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{margin-bottom:1rem}::selection{background-color:var(--primary);color:#fff}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .4s ease forwards}.public-layout{min-height:100vh;display:flex;flex-direction:column}.public-layout__content{flex:1;padding-top:var(--nav-height)}.navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-height);border-bottom:3px solid;border-image:linear-gradient(90deg,#d32f2f,#1565c0,#00897b) 1;z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .navbar{background:#0a0e17f2}[data-theme=light] .navbar,:root:not([data-theme]) .navbar{background:#fffffff2}.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.navbar__logo{font-size:1.35rem;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:.5rem;text-decoration:none;flex-shrink:0}.navbar__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.navbar__logo:hover{color:var(--primary-dark)}.navbar__logo-img{height:36px;width:auto;object-fit:contain}.navbar__links{display:flex;align-items:center;gap:.25rem}.navbar__link{padding:.5rem 1rem;color:var(--text-secondary);font-weight:500;font-size:.95rem;border-radius:var(--radius);transition:all var(--transition);text-decoration:none}.navbar__link:hover,.navbar__link--active{color:var(--primary);background:var(--primary-light)}.navbar__hamburger{display:none;padding:.5rem;color:var(--text);background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:var(--radius)}.navbar__hamburger:hover{background:var(--primary-light);color:var(--primary)}.navbar__mobile-menu{display:none;position:fixed;top:var(--nav-height);left:0;right:0;z-index:999;padding:1rem 1.5rem;flex-direction:column;gap:.25rem;animation:fadeIn .15s ease;overflow-y:auto;border-top:3px solid;border-image:linear-gradient(90deg,#d32f2f,#1565c0,#00897b) 1;box-shadow:0 8px 32px #0003}[data-theme=dark] .navbar__mobile-menu{background:#0a0e17}[data-theme=light] .navbar__mobile-menu,:root:not([data-theme]) .navbar__mobile-menu{background:#fff}.navbar__mobile-menu--open{display:flex}.navbar__mobile-link{padding:.85rem 1rem;font-weight:600;font-size:1.05rem;border-radius:var(--radius);text-decoration:none;display:block}[data-theme=dark] .navbar__mobile-link{color:#e8edf5}[data-theme=light] .navbar__mobile-link,:root:not([data-theme]) .navbar__mobile-link{color:#1a1a2e}.navbar__mobile-link:hover,.navbar__mobile-link--active{color:var(--primary)!important;background:var(--primary-light)}@media (max-width: 768px){.navbar__links{display:none}.navbar__hamburger{display:flex;width:40px;height:40px;align-items:center;justify-content:center}.navbar__logo{font-size:1rem;flex-shrink:1;min-width:0;overflow:hidden}.navbar__logo-img{height:28px;flex-shrink:0}.navbar__actions{gap:.25rem}}.footer{background:var(--bg-secondary);border-top:3px solid;border-image:linear-gradient(90deg,#00897b,#1565c0,#d32f2f) 1;padding:3rem 0 2rem;margin-top:auto}.footer__inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;margin-bottom:2rem}.footer__brand h3{font-size:1.2rem;color:var(--primary);margin-bottom:.5rem}.footer__brand p{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.footer__heading{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.75rem}.footer__link-list{display:flex;flex-direction:column;gap:.4rem}.footer__link-list a{color:var(--text-secondary);font-size:.9rem;text-decoration:none}.footer__link-list a:hover{color:var(--primary)}.footer__bottom{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;font-size:.85rem;color:var(--text-muted)}.footer__bottom a{color:var(--text-secondary)}.footer__bottom a:hover{color:var(--primary)}@media (max-width: 768px){.footer__grid{grid-template-columns:1fr;gap:1.5rem}.footer__bottom{flex-direction:column;text-align:center}}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition)}.admin-sidebar__header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.admin-sidebar__logo{font-size:1.1rem;font-weight:700;color:var(--primary);text-decoration:none;display:flex;align-items:center;gap:.5rem}.admin-sidebar__logo:hover{color:var(--primary-dark)}.admin-sidebar__close{display:none;color:var(--text-secondary);padding:.25rem}.admin-sidebar__nav{flex:1;padding:1rem .75rem;overflow-y:auto;display:flex;flex-direction:column;gap:.15rem}.admin-sidebar__link{display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;color:var(--text-secondary);font-size:.9rem;font-weight:500;border-radius:var(--radius);transition:all var(--transition);text-decoration:none}.admin-sidebar__link:hover{color:var(--text);background:var(--border)}.admin-sidebar__link--active{color:var(--primary);background:var(--primary-light);font-weight:600}.admin-sidebar__link svg{width:20px;height:20px;flex-shrink:0}.admin-sidebar__footer{padding:1rem 1.5rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted)}.admin-topbar{display:flex;align-items:center;justify-content:space-between;height:var(--nav-height);padding:0 1.5rem;background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.admin-topbar__left{display:flex;align-items:center;gap:1rem}.admin-topbar__hamburger{display:none;padding:.5rem;color:var(--text)}.admin-topbar__breadcrumb{font-size:.95rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.admin-topbar__breadcrumb span{color:var(--text);font-weight:600}.admin-topbar__right{display:flex;align-items:center;gap:1rem}.admin-topbar__user{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text)}.admin-topbar__avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem}.admin-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.admin-main{flex:1;padding:2rem 1.5rem;max-width:1400px;width:100%}.admin-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media (max-width: 1024px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar--open{transform:translate(0)}.admin-sidebar__close{display:flex}.admin-content{margin-left:0}.admin-topbar__hamburger{display:flex}.admin-overlay--visible{display:block}}.page-header{margin-bottom:2rem}.page-header__title{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.page-header__subtitle{color:var(--text-secondary);font-size:.95rem}.page-header__actions{display:flex;gap:.75rem;margin-top:1rem}.dashboard-welcome{background:linear-gradient(135deg,#1565c0,#00897b);border-radius:16px;padding:2rem 2.5rem;margin-bottom:1.5rem;color:#fff;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between}.dashboard-welcome__content{position:relative;z-index:1}.dashboard-welcome__greeting{font-size:1.65rem;font-weight:700;margin:0 0 .35rem;color:#fff}.dashboard-welcome__subtitle{font-size:1rem;opacity:.9;margin:0 0 .75rem;font-weight:400}.dashboard-welcome__meta{display:flex;align-items:center;gap:.4rem;font-size:.85rem;opacity:.8}.dashboard-welcome__decoration{opacity:.12;flex-shrink:0}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1rem;margin-bottom:1.5rem}.dashboard-stat{border-radius:14px;padding:1.25rem 1.35rem;color:#fff;display:flex;flex-direction:column;gap:.5rem;box-shadow:0 4px 14px #0000001f;transition:transform .2s ease,box-shadow .2s ease;cursor:default}.dashboard-stat:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000002e}.dashboard-stat__icon{opacity:.85}.dashboard-stat__value{font-size:2rem;font-weight:700;line-height:1}.dashboard-stat__label{font-size:.82rem;font-weight:500;opacity:.9;text-transform:uppercase;letter-spacing:.4px}.dashboard-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;margin-bottom:1.5rem}.dashboard-action{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;text-decoration:none;color:var(--text);transition:all .2s ease;cursor:pointer}.dashboard-action:hover{border-color:var(--action-color, var(--primary));box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.dashboard-action__icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--action-color, var(--primary)) 12%,transparent);color:var(--action-color, var(--primary));transition:background .2s ease}.dashboard-action:hover .dashboard-action__icon{background:color-mix(in srgb,var(--action-color, var(--primary)) 20%,transparent)}.dashboard-action__label{font-weight:600;font-size:.88rem}.dashboard-panels{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:.5rem}.dashboard-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.5rem}.dashboard-panel__title{font-size:1.05rem;font-weight:700;margin:0 0 1rem}.dashboard-table__row--alt{background:var(--bg-offset, rgba(0, 0, 0, .02))}[data-theme=dark] .dashboard-table__row--alt{background:#ffffff06}.dashboard-table__link{font-weight:500;color:var(--text);text-decoration:none;transition:color .15s ease}.dashboard-table__link:hover{color:var(--primary)}.dashboard-table__meta{color:var(--text-secondary);font-size:.85rem}.dashboard-chart{display:flex;flex-direction:column;gap:.85rem}.dashboard-chart__row{display:grid;grid-template-columns:140px 1fr 40px;align-items:center;gap:.75rem}.dashboard-chart__title{font-size:.82rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-chart__track{height:22px;background:var(--bg-offset, rgba(0, 0, 0, .04));border-radius:6px;overflow:hidden}[data-theme=dark] .dashboard-chart__track{background:#ffffff0f}.dashboard-chart__bar{height:100%;background:linear-gradient(90deg,#1565c0,#00897b);border-radius:6px;transition:width .5s ease;min-width:4px}.dashboard-chart__count{font-size:.82rem;font-weight:600;color:var(--text-secondary);text-align:right}@media (max-width: 900px){.dashboard-panels{grid-template-columns:1fr}}@media (max-width: 640px){.dashboard-welcome{padding:1.5rem;flex-direction:column;text-align:center}.dashboard-welcome__decoration{display:none}.dashboard-welcome__greeting{font-size:1.3rem}.dashboard-stats,.dashboard-actions{grid-template-columns:repeat(2,1fr)}.dashboard-chart__row{grid-template-columns:100px 1fr 36px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:var(--radius);transition:all var(--transition);border:1px solid transparent;cursor:pointer;white-space:nowrap;text-decoration:none;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:18px;height:18px}a.btn,a.btn:hover,a.btn:visited{text-decoration:none}.btn--primary,.btn--primary:hover,.btn--primary:visited,.btn--primary:active,a.btn--primary,a.btn--primary:hover,a.btn--primary:visited{color:#fff!important}.btn--primary{background:var(--gradient-primary);border-color:var(--primary)}.btn--primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 4px 12px #1565c04d}.btn--danger,.btn--danger:hover,a.btn--danger,a.btn--danger:hover{color:#fff!important}.btn--secondary{background:var(--bg-secondary);color:var(--text);border-color:var(--border)}.btn--secondary:hover:not(:disabled){background:var(--border)}.btn--danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn--danger:hover:not(:disabled){background:#c82333}.btn--ghost{background:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--bg-secondary);color:var(--text)}.btn--sm{padding:.35rem .75rem;font-size:.82rem}.btn--sm svg{width:15px;height:15px}.btn--lg{padding:.8rem 1.75rem;font-size:1rem}.btn--icon{padding:.5rem;width:36px;height:36px}.btn--full{width:100%}.btn__spinner{animation:spin .6s linear infinite}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:.35rem}.form-input{width:100%;padding:.6rem .85rem;font-size:.95rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition);outline:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0073aa26}.form-input--error{border-color:var(--danger)}.form-input--error:focus{box-shadow:0 0 0 3px #dc354526}.form-input--has-toggle{padding-right:2.5rem}.form-input__eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.form-input__eye:hover{color:var(--text);background:var(--bg-secondary)}.form-textarea{min-height:100px;resize:vertical}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236c757d' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem}.form-error{font-size:.8rem;color:var(--danger);margin-top:.25rem}.form-hint{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--transition),transform var(--transition)}.card:hover{box-shadow:var(--shadow)}.card--clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card__image{width:100%;aspect-ratio:16 / 9;object-fit:cover;background:var(--bg-secondary)}.card__image-placeholder{width:100%;aspect-ratio:16 / 9;background:linear-gradient(135deg,var(--primary-light),var(--bg-secondary));display:flex;align-items:center;justify-content:center;color:var(--primary)}.card__body{padding:1.25rem}.card__title{font-size:1.1rem;font-weight:700;margin-bottom:.5rem;line-height:1.4}.card__title a{color:var(--text);text-decoration:none}.card__title a:hover{color:var(--primary)}.card__excerpt{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card__meta{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--text-muted);flex-wrap:wrap}.card__meta-item{display:flex;align-items:center;gap:.3rem}.card__meta-item svg{width:14px;height:14px}.card__footer{padding:.85rem 1.25rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card__tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;font-size:.75rem;font-weight:600;border-radius:100px;line-height:1.4}.badge--primary{background:var(--primary-light);color:var(--primary)}.badge--accent{background:#fff3e6;color:var(--accent)}[data-theme=dark] .badge--accent{background:#2d1a0a}.badge--success{background:#e6f9ee;color:var(--success)}[data-theme=dark] .badge--success{background:#0d2818}.badge--warning{background:#fff8e1;color:#856404}[data-theme=dark] .badge--warning{background:#2d2300;color:var(--warning)}.badge--danger{background:#fde8e8;color:var(--danger)}[data-theme=dark] .badge--danger{background:#2d0a0a}.badge--outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .15s ease}.modal{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal--lg{max-width:700px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal__title{font-size:1.15rem;font-weight:700}.modal__close{padding:.25rem;color:var(--text-muted);transition:color var(--transition)}.modal__close:hover{color:var(--text)}.modal__body{padding:1.5rem}.modal__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border)}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--border) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}.skeleton--text{height:1rem;margin-bottom:.5rem}.skeleton--title{height:1.5rem;width:60%;margin-bottom:.75rem}.skeleton--image{aspect-ratio:16 / 9;border-radius:var(--radius) var(--radius) 0 0}.skeleton--avatar{width:44px;height:44px;border-radius:50%}.skeleton--card{height:300px;border-radius:var(--radius-lg)}.pagination{display:flex;align-items:center;justify-content:center;gap:.35rem;margin-top:2rem}.pagination__btn{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);font-size:.85rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border);transition:all var(--transition);cursor:pointer;padding:0 .5rem}.pagination__btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text)}.pagination__btn--active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination__btn--active:hover{background:var(--primary-dark)}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pagination__btn svg{width:16px;height:16px}.theme-toggle{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:transparent;border:1px solid transparent;transition:all var(--transition);cursor:pointer}.theme-toggle:hover{background:var(--bg-secondary);color:var(--text);border-color:var(--border)}.post-content{font-size:1.05rem;line-height:1.8;color:var(--text)}.post-content h1{font-size:2rem;margin:2rem 0 1rem}.post-content h2{font-size:1.6rem;margin:1.75rem 0 .85rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.post-content h3{font-size:1.3rem;margin:1.5rem 0 .75rem}.post-content p{margin-bottom:1.25rem}.post-content a{color:var(--primary);text-decoration:underline;text-decoration-color:#0073aa4d;text-underline-offset:2px}.post-content a:hover{text-decoration-color:var(--primary)}.post-content img{border-radius:var(--radius);margin:1.5rem auto;box-shadow:var(--shadow)}.post-content blockquote{border-left:4px solid var(--primary);padding:1rem 1.25rem;margin:1.5rem 0;background:var(--bg-secondary);border-radius:0 var(--radius) var(--radius) 0;color:var(--text-secondary);font-style:italic}.post-content blockquote p:last-child{margin-bottom:0}.post-content ul,.post-content ol{margin:1rem 0;padding-left:1.75rem}.post-content ul{list-style:disc}.post-content ol{list-style:decimal}.post-content li{margin-bottom:.4rem}.post-content pre{background:#1e1e2e;color:#cdd6f4;padding:1.25rem;border-radius:var(--radius);overflow-x:auto;margin:1.5rem 0;font-family:Fira Code,JetBrains Mono,monospace;font-size:.9rem;line-height:1.5}.post-content code{font-family:Fira Code,JetBrains Mono,monospace;font-size:.88em}.post-content :not(pre)>code{background:var(--bg-secondary);border:1px solid var(--border);padding:.15rem .4rem;border-radius:4px;color:var(--accent)}.post-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.post-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}.post-content th,.post-content td{border:1px solid var(--border);padding:.6rem .85rem;text-align:left}.post-content th{background:var(--bg-secondary);font-weight:600}.editor-wrapper{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg)}.editor-toolbar{display:flex;align-items:center;gap:.15rem;padding:.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-wrap:wrap}.editor-toolbar__divider{width:1px;height:24px;background:var(--border);margin:0 .25rem}.editor-toolbar__btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--text-secondary);transition:all var(--transition);cursor:pointer;background:transparent;border:none}.editor-toolbar__btn:hover{background:var(--border);color:var(--text)}.editor-toolbar__btn--active{background:var(--primary-light);color:var(--primary)}.editor-toolbar__btn svg{width:18px;height:18px}.tiptap-editor{padding:2rem 2.5rem;min-height:500px;max-width:800px;margin:0 auto;outline:none;font-size:1.05rem;line-height:1.8;color:var(--text)}.tiptap-editor:focus{outline:none}.tiptap-editor p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-muted);pointer-events:none;height:0}.tiptap-editor h1{font-size:2rem;margin:1rem 0 .5rem}.tiptap-editor h2{font-size:1.6rem;margin:.85rem 0 .45rem}.tiptap-editor h3{font-size:1.3rem;margin:.75rem 0 .4rem}.tiptap-editor p{margin-bottom:.75rem}.tiptap-editor ul{list-style:disc;padding-left:1.5rem;margin:.5rem 0}.tiptap-editor ol{list-style:decimal;padding-left:1.5rem;margin:.5rem 0}.tiptap-editor blockquote{border-left:3px solid var(--primary);padding-left:1rem;margin:.75rem 0;color:var(--text-secondary)}.tiptap-editor pre{background:#1e1e2e;color:#cdd6f4;padding:1rem;border-radius:var(--radius);font-family:monospace;font-size:.9rem;margin:.75rem 0;overflow-x:auto}.tiptap-editor img{max-width:100%;margin:.75rem 0;cursor:pointer}.post-content img,.tutorial-pager__content img{max-width:100%;display:block;margin:1.5rem auto;border-radius:var(--radius-lg);background:#fff;padding:.5rem;box-shadow:var(--shadow)}[data-theme=dark] .post-content img,[data-theme=dark] .tutorial-pager__content img{background:#f8f9fa;box-shadow:0 2px 12px #0006}.tiptap-editor a{color:var(--primary);text-decoration:underline}.tiptap-editor hr{border:none;border-top:1px solid var(--border);margin:1rem 0}.tiptap-editor .page-break-marker{border:none;border-top:2px dashed var(--primary);margin:2rem 0;position:relative;height:0;cursor:pointer}.tiptap-editor .page-break-marker:after{content:"Page Break";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--bg-card);color:var(--primary);padding:0 .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.tiptap-editor .page-break-marker.ProseMirror-selectednode{border-color:var(--danger)}.tiptap-editor .page-break-marker.ProseMirror-selectednode:after{color:var(--danger);content:"Page Break (selected - press Delete to remove)"}.tiptap-editor code{background:var(--bg-secondary);padding:.1rem .3rem;border-radius:4px;font-family:monospace;font-size:.88em}.editor-inline-popup{position:absolute;top:100%;left:0;z-index:50;display:flex;align-items:center;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:4px;margin-top:4px;min-width:300px}.editor-inline-popup__input{flex:1;border:none;background:var(--bg-secondary);color:var(--text);padding:6px 10px;border-radius:4px;font-size:.85rem;outline:none;min-width:0}.editor-inline-popup__input:focus{background:var(--bg);box-shadow:0 0 0 2px var(--primary)}.editor-inline-popup__action,.editor-inline-popup__close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;flex-shrink:0}.editor-inline-popup__action:hover{background:var(--primary-light);color:var(--primary)}.editor-inline-popup__close:hover{background:var(--border);color:var(--danger)}.editor-drop-area{position:relative}.editor-drop-area--active{outline:2px dashed var(--primary);outline-offset:-2px;border-radius:var(--radius)}.editor-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0073aa14;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--primary);font-weight:600;font-size:.95rem;pointer-events:none;border-radius:var(--radius);z-index:10}.editor-uploading{position:absolute;bottom:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem 1rem;font-size:.85rem;color:var(--primary);box-shadow:var(--shadow);z-index:10}.ctx-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.ctx-menu{position:fixed;z-index:1000;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;max-width:260px;padding:4px;animation:fadeIn .1s ease}.ctx-menu__item{display:flex;align-items:center;gap:10px;width:100%;padding:7px 10px;border:none;background:transparent;color:var(--text);font-size:.85rem;cursor:pointer;border-radius:6px;text-align:left}.ctx-menu__item span{flex:1}.ctx-menu__item kbd{font-size:.7rem;color:var(--text-muted);background:var(--bg-secondary);padding:1px 5px;border-radius:3px;border:1px solid var(--border)}.ctx-menu__item:hover{background:var(--primary-light);color:var(--primary)}.ctx-menu__item--active{color:var(--primary);font-weight:600}.ctx-menu__item--sub:after{content:""}.ctx-menu__back{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;border:none;background:transparent;color:var(--text-muted);font-size:.8rem;cursor:pointer;border-radius:6px}.ctx-menu__back:hover{background:var(--bg-secondary);color:var(--text)}.ctx-menu__sep{height:1px;background:var(--border);margin:3px 6px}.ctx-menu__input-row{display:flex;align-items:center;gap:4px;padding:4px 6px}.ctx-menu__input{flex:1;border:none;background:var(--bg-secondary);color:var(--text);padding:6px 8px;border-radius:4px;font-size:.85rem;outline:none;min-width:0}.ctx-menu__input:focus{box-shadow:0 0 0 2px var(--primary)}.ctx-menu__input-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:var(--primary);color:#fff;border-radius:4px;cursor:pointer;flex-shrink:0}.ctx-menu__input-btn:hover{background:var(--primary-dark)}.tiptap-editor img[data-shape=rounded],.post-content img[data-shape=rounded]{border-radius:12px}.tiptap-editor img[data-shape=circular],.post-content img[data-shape=circular]{border-radius:50%}.tiptap-editor img[data-border=thin],.post-content img[data-border=thin]{border:1px solid var(--border)}.tiptap-editor img[data-border=thick],.post-content img[data-border=thick]{border:3px solid var(--primary)}.tiptap-editor img[data-size=small],.post-content img[data-size=small]{width:25%}.tiptap-editor img[data-size=medium],.post-content img[data-size=medium]{width:50%}.tiptap-editor img[data-size=large],.post-content img[data-size=large]{width:75%}.tiptap-editor img[data-size=full],.post-content img[data-size=full]{width:100%}.tiptap-editor img[data-align=left],.post-content img[data-align=left]{float:left;margin-right:1rem;margin-bottom:.5rem}.tiptap-editor img[data-align=right],.post-content img[data-align=right]{float:right;margin-left:1rem;margin-bottom:.5rem}.tiptap-editor img[data-align=center],.post-content img[data-align=center]{display:block;margin-left:auto;margin-right:auto}.image-toolbar{display:flex;align-items:center;gap:2px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:4px;position:absolute;z-index:50;transform:translate(-50%)}.image-toolbar__group{display:flex;align-items:center;gap:1px}.image-toolbar__sep{width:1px;height:20px;background:var(--border);margin:0 4px}.image-toolbar__btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;font-size:.7rem;font-weight:600}.image-toolbar__btn:hover{background:var(--border);color:var(--text)}.image-toolbar__btn--active{background:var(--primary-light);color:var(--primary)}.hero{padding:5rem 0 4rem;background:var(--gradient-hero)}[data-theme=dark] .hero{background:var(--gradient-hero)}.hero__inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;gap:3rem}.hero__content{flex:1}.hero__badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;font-size:.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:1.25rem}.hero__title{font-size:3rem;font-weight:700;line-height:1.15;margin-bottom:1rem}.hero__title-accent{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__subtitle{font-size:1.15rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1.75rem;max-width:560px}.hero__actions{display:flex;gap:.75rem;flex-wrap:wrap}@media (max-width: 768px){.hero{padding:2.5rem 0 2rem}.hero__inner{flex-direction:column;text-align:center}.hero__title{font-size:1.6rem}.hero__subtitle{font-size:.95rem;margin-left:auto;margin-right:auto}.hero__actions{justify-content:center;flex-direction:column;align-items:center}.hero__actions .btn{width:100%;max-width:280px}}.section{padding:4rem 0}.section--alt{background:var(--bg-secondary)}.section__header{text-align:center;margin-bottom:2.5rem}.section__title{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.section__subtitle{color:var(--text-secondary);font-size:1rem;max-width:600px;margin:0 auto}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}@media (max-width: 768px){.posts-grid{grid-template-columns:1fr}}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(340px,100%),1fr));gap:1.5rem}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr}}.expertise-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem}.expertise-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:all var(--transition)}.expertise-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.expertise-card__icon{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.expertise-card__icon svg{width:28px;height:28px}.expertise-card__title{font-size:1rem;font-weight:700;margin-bottom:.4rem}.expertise-card__desc{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.post-page{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.post-page__featured-image{width:100%;aspect-ratio:2 / 1;object-fit:cover;border-radius:var(--radius-lg);margin-bottom:2rem}.post-page__header{margin-bottom:2rem}.post-page__category{margin-bottom:.75rem}.post-page__title{font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.post-page__meta{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;color:var(--text-secondary);font-size:.9rem}.post-page__meta-item{display:flex;align-items:center;gap:.35rem}.post-page__meta-item svg{width:16px;height:16px}.post-page__tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.post-page__share{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.post-page__share-label{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.post-page__share-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:var(--bg-secondary);color:var(--text-secondary);transition:all var(--transition);cursor:pointer;border:1px solid var(--border)}.post-page__share-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.related-posts{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}.related-posts__title{font-size:1.25rem;font-weight:700;margin-bottom:1.25rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-secondary)}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem}.auth-card__header{text-align:center;margin-bottom:2rem}.auth-card__logo{font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:.5rem}.auth-card__subtitle{color:var(--text-secondary);font-size:.9rem}.auth-card__error{background:#fde8e8;color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius);font-size:.85rem;margin-bottom:1rem}[data-theme=dark] .auth-card__error{background:#2d0a0a}.data-table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:.75rem 1rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border)}.data-table td{padding:.85rem 1rem;font-size:.9rem;border-bottom:1px solid var(--border);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-secondary)}.data-table__actions{display:flex;gap:.35rem}.data-table__empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.data-table__empty svg{width:48px;height:48px;margin:0 auto 1rem;opacity:.5}@media (max-width: 768px){.data-table-wrapper{overflow-x:auto}.data-table{min-width:600px}}.post-editor{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.post-editor__main{display:flex;flex-direction:column;gap:1rem}.post-editor__title-input{width:100%;padding:.75rem 0;font-size:1.75rem;font-weight:700;border:none;background:transparent;color:var(--text);outline:none;border-bottom:2px solid var(--border);transition:border-color var(--transition)}.post-editor__title-input:focus{border-bottom-color:var(--primary)}.post-editor__title-input::placeholder{color:var(--text-muted)}.post-editor__sidebar{display:flex;flex-direction:column;gap:1rem}.post-editor__panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.post-editor__panel-header{padding:.85rem 1rem;font-weight:600;font-size:.9rem;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.post-editor__panel-body{padding:1rem}.post-editor__actions{display:flex;gap:.75rem}@media (max-width: 1024px){.post-editor{grid-template-columns:1fr}}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.media-item{position:relative;aspect-ratio:1;border-radius:var(--radius);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:all var(--transition)}.media-item:hover{border-color:var(--primary)}.media-item--selected{border-color:var(--primary);box-shadow:0 0 0 3px #0073aa33}.media-item img{width:100%;height:100%;object-fit:cover}.media-item__overlay{position:absolute;bottom:0;left:0;right:0;padding:.5rem;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:.75rem;opacity:0;transition:opacity var(--transition)}.media-item:hover .media-item__overlay{opacity:1}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg-secondary)}.dropzone:hover,.dropzone--active{border-color:var(--primary);background:var(--primary-light)}.dropzone__icon{color:var(--text-muted);margin-bottom:1rem}.dropzone__icon svg{width:48px;height:48px}.dropzone__text{font-size:.95rem;color:var(--text-secondary);margin-bottom:.25rem}.dropzone__hint{font-size:.8rem;color:var(--text-muted)}.category-tag-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media (max-width: 768px){.category-tag-layout{grid-template-columns:1fr}}.category-tag-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.category-tag-list{display:flex;flex-direction:column;gap:.5rem}.category-tag-item{display:flex;align-items:center;justify-content:space-between;padding:.65rem .85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.category-tag-item__name{font-weight:500;font-size:.9rem}.category-tag-item__count{font-size:.8rem;color:var(--text-muted)}.settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.5rem}.settings-tab{padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;transition:all var(--transition);cursor:pointer;background:transparent}.settings-tab:hover{color:var(--text)}.settings-tab--active{color:var(--primary);border-bottom-color:var(--primary)}.settings-section{max-width:640px}.about-hero{display:flex;align-items:center;gap:2.5rem;margin-bottom:3rem}.about-hero__photo{width:180px;height:180px;border-radius:50%;object-fit:cover;border:4px solid var(--primary);flex-shrink:0;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--primary)}.about-hero__photo svg{width:80px;height:80px}.about-hero__info h1{font-size:2rem;margin-bottom:.35rem}.about-hero__info p{color:var(--text-secondary);font-size:1.05rem}@media (max-width: 768px){.about-hero{flex-direction:column;text-align:center}}.about-section{margin-bottom:2.5rem}.about-section__title{font-size:1.3rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary);display:inline-block}.timeline{position:relative;padding-left:2rem}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--border)}.timeline__item{position:relative;padding-bottom:1.5rem}.timeline__item:before{content:"";position:absolute;left:-2rem;top:.35rem;width:12px;height:12px;border-radius:50%;background:var(--primary);border:2px solid var(--bg);margin-left:-5px}.timeline__year{font-size:.8rem;font-weight:600;color:var(--primary);margin-bottom:.2rem}.timeline__title{font-size:1rem;font-weight:600;margin-bottom:.15rem}.timeline__desc{font-size:.9rem;color:var(--text-secondary)}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill-chip{padding:.4rem .85rem;background:var(--primary-light);color:var(--primary);border-radius:100px;font-size:.82rem;font-weight:500}.accordion{display:flex;flex-direction:column;gap:.5rem}.accordion__item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.accordion__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;font-size:.95rem;font-weight:600;color:var(--text);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition);border:none}.accordion__trigger:hover{background:var(--border)}.accordion__trigger svg{width:18px;height:18px;transition:transform var(--transition);color:var(--text-muted)}.accordion__trigger--open svg{transform:rotate(180deg)}.accordion__content{padding:1rem;font-size:.9rem;color:var(--text-secondary);line-height:1.6}.blog-filters{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.blog-filters__search{flex:1;min-width:200px;position:relative}.blog-filters__search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);width:18px;height:18px}.blog-filters__search input{width:100%;padding:.6rem .85rem .6rem 2.5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;outline:none;transition:border-color var(--transition)}.blog-filters__search input:focus{border-color:var(--primary)}.blog-filters__select{padding:.6rem 2.25rem .6rem .85rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236c757d' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;cursor:pointer}.blog-filters__view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.blog-filters__view-btn{padding:.5rem .65rem;color:var(--text-muted);background:var(--bg);border:none;cursor:pointer;transition:all var(--transition)}.blog-filters__view-btn:hover{color:var(--text)}.blog-filters__view-btn--active{background:var(--primary);color:#fff}.blog-filters__view-btn svg{width:18px;height:18px}.posts-list{display:flex;flex-direction:column;gap:1rem}.post-list-item{display:flex;gap:1.25rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition)}.post-list-item:hover{box-shadow:var(--shadow)}.post-list-item__image{width:200px;aspect-ratio:16 / 9;object-fit:cover;border-radius:var(--radius);flex-shrink:0;background:var(--bg-secondary)}.post-list-item__content{flex:1;display:flex;flex-direction:column}@media (max-width: 640px){.post-list-item{flex-direction:column}.post-list-item__image{width:100%}}.not-found{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}.not-found__code{font-size:8rem;font-weight:700;color:var(--primary);line-height:1;margin-bottom:.5rem}.not-found__title{font-size:1.5rem;margin-bottom:.5rem}.not-found__desc{color:var(--text-secondary);margin-bottom:1.5rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state svg{width:64px;height:64px;margin:0 auto 1rem;opacity:.5}.empty-state__title{font-size:1.1rem;font-weight:600;color:var(--text-secondary);margin-bottom:.35rem}.empty-state__desc{font-size:.9rem;margin-bottom:1.25rem}.tags-input{display:flex;flex-wrap:wrap;gap:.35rem;padding:.4rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);min-height:40px;cursor:text}.tags-input:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #0073aa26}.tags-input__tag{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:var(--primary-light);color:var(--primary);border-radius:4px;font-size:.8rem;font-weight:500}.tags-input__tag-remove{cursor:pointer;display:flex;padding:0;background:none;border:none;color:var(--primary);opacity:.7}.tags-input__tag-remove:hover{opacity:1}.tags-input__field{flex:1;min-width:80px;border:none;outline:none;background:transparent;font-size:.85rem;color:var(--text);padding:.15rem .25rem}.reading-time{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--text-muted)}.reading-time svg{width:14px;height:14px}.user-list__item{display:flex;align-items:center;gap:.75rem}.user-list__avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.featured-image-picker{border:2px dashed var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color var(--transition)}.featured-image-picker:hover{border-color:var(--primary)}.featured-image-picker__placeholder{padding:2rem;text-align:center;color:var(--text-muted);font-size:.85rem}.featured-image-picker__placeholder svg{width:32px;height:32px;margin:0 auto .5rem}.featured-image-picker__preview{position:relative}.featured-image-picker__preview img{width:100%;aspect-ratio:16 / 9;object-fit:cover}.featured-image-picker__remove{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none}.admin-list-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.admin-list-header__search{position:relative;min-width:250px}.admin-list-header__search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.admin-list-header__search-icon svg{width:16px;height:16px}.admin-list-header__search input{width:100%;padding:.55rem .85rem .55rem 2.25rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:.88rem;outline:none}.admin-list-header__search input:focus{border-color:var(--primary)}.project-card__tech{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.75rem}.project-card__links{display:flex;gap:.5rem}.autosave-indicator{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-muted)}.autosave-indicator--saving{color:var(--warning)}.autosave-indicator--saved{color:var(--success)}.tutorial-pager{margin:1.5rem 0}.tutorial-pager__progress{height:3px;background:var(--border);border-radius:2px;margin-bottom:2rem;overflow:hidden}.tutorial-pager__progress-bar{height:100%;background:var(--primary);border-radius:2px;transition:width .3s ease}.tutorial-pager__content{min-height:300px;animation:fadeIn .3s ease}.tutorial-pager__nav{display:flex;align-items:center;justify-content:space-between;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.tutorial-pager__indicator{color:var(--text-secondary);font-size:.9rem;font-weight:500}.tutorial-pager__finish{text-align:center;padding:1.5rem;margin-top:1.5rem;background:var(--primary-light);border-radius:var(--radius-lg);color:var(--primary);font-weight:600;font-size:1.05rem}.tutorial-pager__dots{display:flex;justify-content:center;gap:6px;margin-top:1rem}.tutorial-pager__dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--border);cursor:pointer;padding:0;transition:all .2s ease}.tutorial-pager__dot:hover{background:var(--text-muted)}.tutorial-pager__dot--active{background:var(--primary);transform:scale(1.3)}.toast-message{font-family:var(--font);font-size:.9rem}
