.albums{--albums-gap:1rem;--albums-col-count:1;max-width:var(--container-width);margin:0 auto;padding:var(--spacing-md);animation:fadeIn var(--transition-normal)}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.albums__header{text-align:left;margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-sm)}.albums__title{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text-main);display:flex;align-items:center;gap:var(--spacing-sm)}.albums__subtitle{color:var(--color-text-secondary);font-size:1rem;margin-bottom:var(--spacing-sm)}.albums__stats{display:inline-flex;gap:var(--spacing-lg);font-size:.875rem;color:var(--color-text-muted)}.albums__grid{column-count:var(--albums-col-count);column-gap:var(--albums-gap);width:100%;margin:0 auto}.albums__item{break-inside:avoid;margin-bottom:var(--albums-gap);transform:translateZ(0)}.albums__card{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-surface);border:1px solid var(--color-border);box-shadow:none;transition:all var(--transition-normal);cursor:zoom-in}.albums__card:hover{transform:translateY(-5px);box-shadow:0 10px 25px -5px var(--color-shadow);border-color:var(--color-primary)}.albums__image-wrapper{position:relative;width:100%}.albums__image{display:block;width:100%;height:auto;transition:transform var(--transition-normal),opacity var(--transition-normal);opacity:0}.albums__image.is-loaded{opacity:1}.albums__card:hover .albums__image{transform:scale(1.05)}.albums__overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);opacity:0;transition:opacity var(--transition-fast);display:flex;flex-direction:column;justify-content:space-between;padding:var(--spacing-md);pointer-events:none}.albums__card:hover .albums__overlay{opacity:1;pointer-events:auto}.albums__actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.albums__action-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.9);border:none;color:#333;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition-fast),background var(--transition-fast)}.albums__action-btn:hover{background:#fff;transform:scale(1.1)}.albums__info{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);transform:translateY(10px);transition:transform var(--transition-fast)}.albums__card:hover .albums__info{transform:translateY(0)}.albums__desc{font-size:.95rem;margin-bottom:var(--spacing-xs);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.albums__meta{display:flex;flex-direction:column;gap:4px;font-size:.8rem;opacity:.9}.albums__meta-row{display:flex;justify-content:space-between}.albums__loading{display:flex;justify-content:center;padding:var(--spacing-xl) 0;width:100%}.albums__spinner{width:40px;height:40px;border:3px solid var(--color-bg-surface-alt);border-top-color:var(--color-primary);border-radius:50%;animation:albums-spin 1s linear infinite}.albums__no-more{text-align:center;padding:var(--spacing-xl) 0;color:var(--color-text-muted)}@keyframes albums-spin{to{transform:rotate(360deg)}}@media (min-width:640px){.albums{--albums-col-count:2}}@media (min-width:1024px){.albums{--albums-col-count:3}}@media (min-width:1280px){.albums{--albums-col-count:4}}.article-read{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border)}.article-header{text-align:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.article-title{font-size:2rem;font-weight:800;color:var(--color-text-main);margin-bottom:var(--spacing-md);line-height:1.3}.article-meta{font-size:.9rem;color:var(--color-text-muted);display:flex;justify-content:center;gap:var(--spacing-lg)}.article-content{font-size:1.1rem;line-height:1.8;color:var(--color-text-main)}.article-content h1,.article-content h2,.article-content h3{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md);font-weight:700;color:var(--color-text-main)}.article-content p{margin-bottom:var(--spacing-md)}.article-content img{border-radius:var(--radius-md);margin:var(--spacing-lg) 0;box-shadow:0 4px 6px var(--color-shadow)}.article-intro{position:relative;margin:var(--spacing-xl) 0;padding:1.5rem 1.5rem 1.5rem 4.5rem;background-color:var(--color-bg-surface-alt);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:1.05rem;line-height:1.75;border:none}.article-intro::before{content:'\f10d';font-family:"Font Awesome 6 Free","Font Awesome 5 Free",FontAwesome;font-weight:900;position:absolute;left:1.25rem;top:1.25rem;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background-color:var(--color-bg-surface);color:var(--color-primary);border-radius:50%;font-size:1rem;box-shadow:0 2px 5px rgba(0,0,0,.05)}@media (max-width:768px){.article-intro{padding:1.25rem 1.25rem 1.25rem 1.25rem;margin:var(--spacing-lg) 0;display:flex;flex-direction:column;gap:.75rem}.article-intro::before{position:static;width:2rem;height:2rem;font-size:.9rem}}.article-intro p{margin-bottom:.75em}.article-intro p:last-child{margin-bottom:0}.article-intro p{margin-bottom:1em}.article-intro p:last-child{margin-bottom:0}.article-content pre{background-color:#1e293b;color:#e2e8f0;padding:var(--spacing-md);border-radius:var(--radius-md);overflow-x:auto;margin:var(--spacing-lg) 0}.article-content code{font-family:monospace;background-color:var(--color-bg-surface-alt);padding:.2em .4em;border-radius:var(--radius-sm);font-size:.9em}.article-content pre code{background-color:transparent;padding:0}.article-card{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.05);transition:all .3s cubic-bezier(.4, 0, .2, 1);display:flex;flex-direction:column;border:1px solid transparent;position:relative;height:auto}@media (prefers-color-scheme:dark){.article-card{border-color:var(--color-border);box-shadow:none;background-color:var(--color-bg-surface)}}.article-card:hover{transform:translateY(-5px);box-shadow:0 15px 30px rgba(0,0,0,.1);border-color:var(--color-primary)}.article-card__cover{width:100%;aspect-ratio:16/9;overflow:hidden;position:relative;cursor:pointer}.article-card__cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.4, 0, .2, 1);display:block}.article-card__cover img.lazy:not(.loaded){object-fit:scale-down;padding:2rem;background-color:var(--color-bg-surface-alt)}.article-card:hover .article-card__cover img{transform:scale(1.08)}.article-card__content{padding:1.5rem;display:flex;flex-direction:column;flex:1;position:relative}.article-card__meta{display:flex;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.article-card__meta span{display:inline-flex;align-items:center;gap:.4rem}.article-card__meta i{font-size:.9em;opacity:.7}.article-card__title{font-size:1.4rem;font-weight:700;margin:0 0 .75rem 0;line-height:1.4;letter-spacing:-.01em;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.article-card__title a{color:var(--color-text-main);text-decoration:none;transition:color .2s ease;background-image:linear-gradient(var(--color-primary),var(--color-primary));background-size:0 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .3s,color .3s}.article-card__title a:hover{color:var(--color-primary);background-size:100% 2px}.article-card__excerpt{font-size:1rem;color:var(--color-text-secondary);line-height:1.625;margin-bottom:1.5rem;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-wrap:break-word;word-break:break-word;opacity:.9}.article-card__excerpt>*{display:inline;margin:0;padding:0}.article-card__excerpt audio,.article-card__excerpt blockquote,.article-card__excerpt code,.article-card__excerpt img,.article-card__excerpt pre,.article-card__excerpt table,.article-card__excerpt video{display:none}.article-card__footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px dashed var(--color-border)}.article-card__tags{display:flex;flex-wrap:wrap;gap:.5rem}.article__tag{display:inline-flex;align-items:center;padding:.25rem .75rem;background-color:var(--color-bg-surface-alt);border-radius:99px;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:all .2s ease}.article__tag:hover{background-color:var(--color-primary);color:#fff;transform:translateY(-1px)}.article-card__stats{display:flex;align-items:center;gap:1rem;font-size:.85rem;color:var(--color-text-muted)}.stat-item{display:flex;align-items:center;gap:.4rem}@media (min-width:768px){.article-card{flex-direction:row;height:auto;min-height:220px;align-items:stretch}.article-card__cover{width:38%;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.article-card__cover img{position:static;width:100%;height:100%;object-fit:cover}.article-card__content{width:62%;padding:1.5rem 1.75rem;display:flex;flex-direction:column}.article-card__title{font-size:1.5rem}}@media (max-width:768px){.article-read{padding:var(--spacing-md);border-radius:var(--radius-md)}.article-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.article-title{font-size:1.5rem;margin-bottom:var(--spacing-sm)}.article-meta{flex-direction:row;flex-wrap:nowrap;gap:var(--spacing-md);font-size:.9rem;justify-content:center}.article-meta__item{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;flex-shrink:0}@media (max-width:420px){.article-meta__item:nth-child(4){display:none}}.article-content{font-size:1rem;line-height:1.6}.article-content h1,.article-content h2,.article-content h3{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.article-intro{margin:var(--spacing-lg) 0;padding:var(--spacing-md)}.article-content pre{margin:var(--spacing-md) 0;padding:var(--spacing-sm)}.article-card__content{padding:1.25rem}.article-card__title{font-size:1.25rem}.article-card__excerpt{font-size:.95rem;margin-bottom:1rem;line-height:1.5}}.bookmark{padding:var(--spacing-md,1rem);max-width:1400px;margin:0 auto}.bookmark__search{position:relative;margin-bottom:var(--spacing-lg,2rem);display:flex;justify-content:center}.bookmark__search-wrapper{display:flex;width:100%;max-width:600px;position:relative}.bookmark__search-input{width:100%;padding:12px 20px;padding-right:50px;border-radius:8px;border:2px solid var(--color-border,#e0e0e0);background-color:var(--color-bg-card,#fff);color:var(--color-text-primary,#333);font-size:1rem;transition:all .3s ease;outline:0}.bookmark__search-input:focus{border-color:var(--color-primary,#007bff);box-shadow:0 4px 12px rgba(0,0,0,.1)}.bookmark__search-btn{position:absolute;right:5px;top:50%;transform:translateY(-50%);background:0 0;border:none;color:var(--color-text-secondary,#666);cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.bookmark__search-btn:hover{color:var(--color-primary,#007bff);background-color:var(--color-bg-hover,#f5f5f5)}.bookmark__search-results{position:absolute;top:100%;left:50%;transform:translateX(-50%);width:100%;max-width:600px;background:var(--color-bg-card,#fff);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);margin-top:8px;z-index:100;overflow:hidden;display:none}.bookmark__search-list{list-style:none;padding:0;margin:0;max-height:300px;overflow-y:auto}.bookmark__search-item{padding:12px 20px;cursor:pointer;border-bottom:1px solid var(--color-border-light,#f0f0f0);transition:background-color .2s}.bookmark__search-item:last-child{border-bottom:none}.bookmark__search-item--active,.bookmark__search-item:hover{background-color:var(--color-bg-hover,#f5f5f5)}.bookmark__categories{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:var(--spacing-lg,2rem)}.bookmark__actions{display:flex;justify-content:flex-end;margin-bottom:1rem}@media (max-width:600px){.bookmark__categories{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;padding-bottom:5px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.bookmark__categories::-webkit-scrollbar{display:none}.bookmark__category{flex-shrink:0;white-space:nowrap}.bookmark__actions{display:block;margin-bottom:20px}.bookmark__btn{width:100%;justify-content:center;padding:12px 24px;font-size:1rem;font-weight:600;border-radius:8px}}.bookmark__btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;border:none;text-decoration:none}.bookmark__btn--primary{background-color:var(--color-primary,#007bff);color:#fff}.bookmark__btn--primary:hover{background-color:var(--color-primary-dark,#0056b3);box-shadow:0 4px 12px rgba(0,123,255,.3);color:#fff}.bookmark__category{padding:6px 16px;border-radius:20px;background-color:var(--color-bg-secondary,#f0f2f5);color:var(--color-text-secondary,#666);text-decoration:none;font-size:.9rem;transition:all .2s;border:1px solid transparent}.bookmark__category:hover{background-color:var(--color-bg-hover,#e4e6eb);color:var(--color-text-primary,#333)}.bookmark__category--active{background-color:var(--color-primary,#007bff);color:#fff;box-shadow:0 4px 10px rgba(0,123,255,.3)}.bookmark__category--active:hover{background-color:var(--color-primary-dark,#0056b3);color:#fff}.bookmark__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-auto-rows:1px;gap:20px;align-items:start}.bookmark-card{background-color:var(--color-bg-card,#fff);border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.05);overflow:hidden;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;position:relative;border:1px solid var(--color-border-light,rgba(0,0,0,.05))}.bookmark-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.1)}.bookmark-card__link{text-decoration:none;color:inherit;display:flex;flex-direction:column;flex-grow:1}.bookmark-card__preview{width:100%;min-height:100px;object-fit:cover;background-color:var(--color-bg-secondary,#f5f5f5)}.bookmark-card__content{padding:16px;display:flex;align-items:flex-start;gap:12px}.bookmark-card__icon{width:24px;height:24px;border-radius:4px;object-fit:contain;flex-shrink:0}.bookmark-card__title{font-size:1rem;font-weight:600;color:var(--color-text-primary,#333);margin:0;line-height:1.4;word-break:break-word}.bookmark-card__footer{padding:12px 16px;border-top:1px solid var(--color-border-light,#f0f0f0);display:flex;justify-content:space-between;align-items:center;background-color:var(--color-bg-card-footer,#fafafa);margin-top:auto}.bookmark-card__tags{display:flex;flex-wrap:wrap;gap:6px}.bookmark-card__tag{font-size:.75rem;color:var(--color-text-secondary,#666);background-color:var(--color-tag-bg,#eee);padding:2px 8px;border-radius:4px}.bookmark-card__edit{color:var(--color-text-secondary,#999);transition:color .2s;padding:4px}.bookmark-card__edit:hover{color:var(--color-primary,#007bff)}.bookmark-form{max-width:800px;margin:40px auto;background:var(--color-bg-card,#fff);padding:40px;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,.08)}.bookmark-form__header{margin-bottom:30px;text-align:center}.bookmark-form__title{font-size:1.8rem;color:var(--color-text-primary,#333);margin-bottom:10px}.bookmark-form__group{margin-bottom:24px}.bookmark-form__label{display:block;margin-bottom:8px;font-weight:500;color:var(--color-text-primary,#333)}.bookmark-form__input{width:100%;padding:12px 16px;border-radius:8px;border:1px solid var(--color-border,#ddd);background-color:var(--color-bg-input,#fff);color:var(--color-text-primary,#333);font-size:1rem;transition:border-color .2s}.bookmark-form__input:focus{border-color:var(--color-primary,#007bff);outline:0}.bookmark-form__categories{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.bookmark-form__checkbox-wrapper{position:relative}.bookmark-form__checkbox{display:none}.bookmark-form__checkbox-label{display:inline-block;padding:8px 16px;border-radius:20px;border:1px solid var(--color-border,#ddd);color:var(--color-text-secondary,#666);cursor:pointer;transition:all .2s;user-select:none}.bookmark-form__checkbox:checked+.bookmark-form__checkbox-label{background-color:var(--color-primary,#007bff);color:#fff;border-color:var(--color-primary,#007bff)}.bookmark-form__actions{display:flex;gap:16px;margin-top:40px}.bookmark-form__cancel,.bookmark-form__delete,.bookmark-form__submit{padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;border:none;transition:all .2s;font-size:1rem}.bookmark-form__submit{background-color:var(--color-primary,#007bff);color:#fff;flex:2}.bookmark-form__submit:hover{background-color:var(--color-primary-dark,#0056b3)}.bookmark-form__cancel{background-color:transparent;border:1px solid var(--color-border,#ddd);color:var(--color-text-secondary,#666);flex:1;text-decoration:none;display:flex;align-items:center;justify-content:center}.bookmark-form__cancel:hover{background-color:var(--color-bg-hover,#f5f5f5)}.bookmark-form__delete{background-color:#dc3545;color:#fff;flex:1}.bookmark-form__delete:hover{background-color:#c82333}@media (prefers-color-scheme:dark){:root{--color-bg-body:#121212;--color-bg-card:#1e1e1e;--color-bg-card-footer:#252525;--color-bg-secondary:#2c2c2c;--color-bg-hover:#333333;--color-bg-input:#2c2c2c;--color-text-primary:#e0e0e0;--color-text-secondary:#a0a0a0;--color-border:#404040;--color-border-light:#333333;--color-tag-bg:#333333;--color-primary:#3d8bfd;--color-primary-dark:#1a73e8}}[data-theme=dark]{--color-bg-body:#121212;--color-bg-card:#1e1e1e;--color-bg-card-footer:#252525;--color-bg-secondary:#2c2c2c;--color-bg-hover:#333333;--color-bg-input:#2c2c2c;--color-text-primary:#e0e0e0;--color-text-secondary:#a0a0a0;--color-border:#404040;--color-border-light:#333333;--color-tag-bg:#333333;--color-primary:#3d8bfd;--color-primary-dark:#1a73e8}.bson-tool{max-width:800px;margin:40px auto;padding:var(--spacing-xl);background-color:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:0 4px 6px var(--color-shadow);transition:background-color var(--transition-normal)}.bson-tool__header{margin-bottom:var(--spacing-lg);text-align:center;border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-md)}.bson-tool__title{font-size:1.75rem;font-weight:700;color:var(--color-text-main);margin:0}.bson-tool__section{margin-bottom:var(--spacing-xl)}.bson-tool__upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;background-color:var(--color-bg-surface-alt);transition:all var(--transition-normal);position:relative;overflow:hidden;min-height:200px}.bson-tool__upload-area:hover{border-color:var(--color-primary);background-color:rgba(37,99,235,.05)}.bson-tool__file-input{position:absolute;width:100%;height:100%;top:0;left:0;opacity:0;cursor:pointer;z-index:10}.bson-tool__upload-content{pointer-events:none;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);z-index:5}.bson-tool__upload-icon{font-size:3rem;color:var(--color-primary);margin-bottom:var(--spacing-sm)}.bson-tool__upload-text{font-size:1.1rem;font-weight:500;color:var(--color-text-main)}.bson-tool__upload-hint{font-size:.9rem;color:var(--color-text-muted)}.bson-tool__file-info{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-surface-alt);border-radius:var(--radius-md);font-family:monospace;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);border:1px solid var(--color-border)}.bson-tool__input-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.bson-tool__label{font-size:.95rem;font-weight:600;color:var(--color-text-secondary)}.bson-tool__input{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface);color:var(--color-text-main);font-size:1rem;transition:border-color var(--transition-fast)}.bson-tool__input:focus{outline:0;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.bson-tool__result-card{margin-top:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-surface-alt);border-radius:var(--radius-md);border:1px solid var(--color-border);animation:fadeIn var(--transition-normal)}.bson-tool__result-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0;border-bottom:1px dashed var(--color-border)}.bson-tool__result-row:last-child{border-bottom:none}.bson-tool__result-label{color:var(--color-text-secondary);font-size:.9rem}.bson-tool__result-value{color:var(--color-status-connected);font-family:monospace;font-weight:600}.bson-tool__error{color:var(--color-status-error);margin-top:var(--spacing-sm);font-size:.9rem;padding:var(--spacing-sm);background-color:rgba(239,68,68,.1);border-radius:var(--radius-sm)}.bson-tool__code-container{margin-top:var(--spacing-md);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);background-color:#1e293b}.bson-tool__code-container pre{margin:0;padding:var(--spacing-md);max-height:500px;overflow-y:auto;color:#e2e8f0}@keyframes fadeIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@media (max-width:600px){.bson-tool{padding:var(--spacing-md);margin:20px auto}.bson-tool__result-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.canvas-chat{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;width:100dvw;height:100vh;height:100dvh;height:calc(var(--vh,1vh) * 100);min-height:-webkit-fill-available;background-color:rgba(0,0,0,.85);z-index:2000;display:none;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.canvas-chat--visible{display:flex;opacity:1}.canvas-chat__container{position:relative;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.3);overflow:hidden;max-width:95vw;max-width:95dvw;max-height:90vh;max-height:90dvh;max-height:calc(var(--vh,1vh) * 90);display:flex;flex-direction:column;width:100%;height:100%}@media (max-width:640px){.canvas-chat__container{max-width:100vw;max-width:100dvw;max-height:100vh;max-height:100dvh;max-height:calc(var(--vh,1vh) * 100);border-radius:0;margin-top:env(safe-area-inset-top,0);margin-bottom:env(safe-area-inset-bottom,0)}}@media (prefers-color-scheme:dark){.canvas-chat__container{background-color:#1e1e1e;border:1px solid #333}}.canvas-chat__header{padding:10px 15px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}@media (prefers-color-scheme:dark){.canvas-chat__header{background-color:#2d2d2d;border-bottom-color:#444}}.canvas-chat__title{margin:0;font-size:16px;font-weight:600;color:#333}@media (prefers-color-scheme:dark){.canvas-chat__title{color:#ddd}}.canvas-chat__status{font-size:12px;color:#666;margin-left:10px}@media (prefers-color-scheme:dark){.canvas-chat__status{color:#aaa}}.canvas-chat__close{background:0 0;border:none;font-size:20px;cursor:pointer;color:#666;padding:0;line-height:1;transition:color .2s}.canvas-chat__close:hover{color:#d32f2f}@media (prefers-color-scheme:dark){.canvas-chat__close{color:#aaa}.canvas-chat__close:hover{color:#ff5252}}.canvas-chat__body{position:relative;background-color:#fff;cursor:crosshair;overflow:hidden}@media (prefers-color-scheme:dark){.canvas-chat__body{background-color:#121212}}.canvas-chat__canvas{display:block;touch-action:none}.canvas-chat__toolbar{padding:10px;background-color:#f5f5f5;border-top:1px solid #e0e0e0;display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center}@media (prefers-color-scheme:dark){.canvas-chat__toolbar{background-color:#2d2d2d;border-top-color:#444}}.canvas-chat__tool-btn{width:30px;height:30px;border:1px solid #ddd;border-radius:4px;background-color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#333}@media (prefers-color-scheme:dark){.canvas-chat__tool-btn{background-color:#333;border-color:#555;color:#ddd}}.canvas-chat__tool-btn:hover{background-color:#e0e0e0}.canvas-chat__tool-btn--active{background-color:#2196f3;color:#fff;border-color:#1976d2}@media (prefers-color-scheme:dark){.canvas-chat__tool-btn:hover{background-color:#444}.canvas-chat__tool-btn--active{background-color:#1565c0;border-color:#0d47a1}}.canvas-chat__color-picker{width:30px;height:30px;padding:0;border:none;border-radius:4px;cursor:pointer;background:0 0}.canvas-chat__size-slider{width:100px;cursor:pointer}.group-chat__commands{position:absolute;bottom:100%;left:0;width:100%;background-color:#fff;border-top:1px solid #ddd;border-bottom:1px solid #ddd;box-shadow:0 -2px 10px rgba(0,0,0,.1);display:none;z-index:10}@media (prefers-color-scheme:dark){.group-chat__commands{background-color:#2d2d2d;border-color:#444}}.group-chat__commands--visible{display:block}.group-chat__command-item{padding:8px 12px;cursor:pointer;display:flex;justify-content:space-between;color:#333}@media (prefers-color-scheme:dark){.group-chat__command-item{color:#ddd}}.group-chat__command-item:hover{background-color:#f5f5f5}@media (prefers-color-scheme:dark){.group-chat__command-item:hover{background-color:#3e3e3e}}.group-chat__command-name{font-weight:700;color:#2196f3}.group-chat__command-desc{color:#888;font-size:12px}:root{--code-sidebar-width:320px;--code-header-height:56px;--code-tree-indent:20px;--code-line-color:var(--color-border);--code-line-style:dashed 1px}.code-explorer{display:flex;align-items:flex-start;position:relative;background-color:var(--color-bg-body);font-family:'Segoe UI',system-ui,-apple-system,sans-serif;color:var(--color-text-main);border-top:1px solid var(--color-border);min-height:600px}.code-explorer__sidebar{width:var(--code-sidebar-width);background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;z-index:10;position:sticky;top:var(--header-height,64px);height:calc(100vh - var(--header-height,64px));max-height:100vh;overflow:hidden}.code-explorer__resizer{position:absolute;top:0;right:-5px;width:10px;height:100%;cursor:col-resize;z-index:20;background:0 0;transition:background-color var(--transition-fast)}.code-explorer__resizer.is-resizing,.code-explorer__resizer:hover{background-color:rgba(37,99,235,.2)}.code-explorer__search{height:var(--code-header-height);padding:0 var(--spacing-md);border-bottom:1px solid var(--color-border);display:flex;align-items:center;background-color:var(--color-bg-surface);flex-shrink:0}.code-explorer__search input{flex:1;width:auto;padding:8px 12px;border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-bg-surface-alt);color:var(--color-text-main);outline:0;font-size:.9rem;transition:all var(--transition-fast)}.code-explorer__search input:focus{border-color:var(--color-primary);background-color:var(--color-bg-surface);box-shadow:0 0 0 2px rgba(37,99,235,.1)}.code-explorer__search .btn-search{background:0 0;border:none;cursor:pointer;color:var(--color-text-secondary);padding:8px;margin-left:4px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.code-explorer__search .btn-search:hover{background-color:var(--color-bg-surface-alt);color:var(--color-primary)}.code-explorer__tree{flex:1;overflow-y:auto;padding:var(--spacing-sm) 0;scrollbar-width:thin;scrollbar-color:var(--color-text-muted) transparent}.code-tree__node{position:relative;line-height:1.5}.code-tree__content{display:flex;align-items:center;padding:6px var(--spacing-sm) 6px 0;cursor:pointer;user-select:none;color:var(--color-text-secondary);transition:background-color var(--transition-fast);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-right:var(--spacing-xs);position:relative}.code-tree__content:hover{background-color:var(--color-bg-surface-alt);color:var(--color-text-main)}.code-tree__content.is-active{background-color:rgba(37,99,235,.1);color:var(--color-primary);font-weight:500}@media (prefers-color-scheme:dark){.code-tree__content.is-active{background-color:rgba(59,130,246,.15)}}.code-tree__toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:transform var(--transition-fast),color var(--transition-fast);flex-shrink:0;z-index:2}.code-tree__toggle:hover{color:var(--color-text-main)}.code-tree__node.is-expanded>.code-tree__content>.code-tree__toggle{transform:rotate(90deg)}.code-tree__toggle.is-hidden{visibility:hidden}.code-tree__icon{width:18px;height:18px;margin-right:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:2}.code-tree__icon img,.code-tree__icon svg{width:100%;height:100%;object-fit:contain}.code-tree__label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:inherit;text-decoration:none;font-size:.95rem}.code-tree__children{display:none;margin-left:11px;padding-left:11px;border-left:var(--code-line-style);border-left-color:var(--code-text-muted);border-left-color:rgba(148,163,184,.4)}.code-tree__node.is-expanded>.code-tree__children{display:block}.code-tree__children>.code-tree__node::before{content:"";position:absolute;top:18px;left:-12px;width:12px;height:1px;border-top:var(--code-line-style);border-top-color:rgba(148,163,184,.4)}.code-explorer__tree>.code-tree__node::before{display:none}.code-tree__children{border-left:none;margin-left:12px;padding-left:0}.code-tree__children>.code-tree__node{padding-left:12px}.code-tree__children>.code-tree__node::before{content:"";position:absolute;top:0;bottom:0;left:0;border-left:var(--code-line-style);border-color:rgba(148,163,184,.4);width:1px;height:auto}.code-tree__children>.code-tree__node::after{content:"";position:absolute;top:18px;left:0;width:12px;height:1px;border-top:var(--code-line-style);border-color:rgba(148,163,184,.4)}.code-tree__children>.code-tree__node:last-child::before{height:19px}.code-tree__node.is-loading>.code-tree__content{cursor:wait;opacity:.7}.code-tree__label mark{background-color:var(--color-mark-bg);color:var(--color-mark-text);border-radius:2px;padding:0 2px}.code-explorer__main{flex:1;display:flex;flex-direction:column;background-color:var(--color-bg-body);min-width:0}.code-explorer__breadcrumbs{height:var(--code-header-height);padding:0 var(--spacing-lg);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-surface);display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem;color:var(--color-text-secondary);white-space:nowrap;overflow-x:auto;scrollbar-width:none;position:sticky;top:var(--header-height,64px);z-index:5}.code-explorer__breadcrumbs a{color:var(--color-text-secondary);text-decoration:none;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.code-explorer__breadcrumbs a:hover{background-color:var(--color-bg-surface-alt);color:var(--color-primary)}.code-explorer__breadcrumbs span{color:var(--color-text-muted)}.code-explorer__content{padding:var(--spacing-lg);max-width:100%}.code-explorer__content .row{display:flex;align-items:center;padding:12px var(--spacing-md);border-bottom:1px solid var(--color-border);background-color:var(--color-bg-surface);transition:transform var(--transition-fast),box-shadow var(--transition-fast);margin-bottom:-1px}.code-explorer__content .row:first-child{border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md);border-top:1px solid var(--color-border)}.code-explorer__content .row:last-child{border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.code-explorer__content .row:hover{background-color:var(--color-bg-surface-alt);z-index:1;position:relative}.code-explorer__content .row .icon{width:32px;height:32px;margin-right:var(--spacing-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.code-explorer__content .row .icon img{width:100%;height:100%;object-fit:contain}.code-explorer__content .row .header{flex:2;min-width:0;font-weight:500;font-size:1rem}.code-explorer__content .row .header a{color:var(--color-text-main);text-decoration:none}.code-explorer__content .row .header a:hover{color:var(--color-primary);text-decoration:underline}.code-explorer__content .row .desc{flex:3;min-width:0;color:var(--color-text-muted);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 var(--spacing-md)}.code-explorer__content .row .time{flex:1;min-width:120px;text-align:right;color:var(--color-text-muted);font-size:.85rem}#codeView{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:'Fira Code',Consolas,Monaco,'Andale Mono',monospace}#codeView{position:relative}#codeView code{display:block!important;font-family:inherit!important}.line-highlight.line-highlight{margin-top:16px!important}.readme-main{background-color:var(--color-bg-surface);padding:var(--spacing-xl);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:0 1px 3px var(--color-shadow)}@media (max-width:768px){.code-explorer__sidebar{display:none}.code-explorer__content{padding:var(--spacing-sm)}.code-explorer__content .row{padding:12px 8px;gap:8px}.code-explorer__content .row .icon{width:24px;height:24px;margin-right:4px}.code-explorer__content .row .header{font-size:.95rem;flex:1}.code-explorer__content .row .desc{display:none}.code-explorer__content .row .time{display:none}}.comment-section{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border);margin-top:var(--spacing-xl)}.comment-section-skeleton{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border);margin-top:var(--spacing-xl);min-height:200px;display:flex;justify-content:center;align-items:center}.comment-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-bg-surface-alt)}.comment-section__title{font-size:1.5rem;font-weight:700;color:var(--color-text-main);display:flex;align-items:center;gap:var(--spacing-sm)}.comment-section__count{background-color:var(--color-primary);color:#fff;font-size:.8rem;padding:.2em .6em;border-radius:99px}.comment-section__refresh-btn{background:0 0;border:none;cursor:pointer;color:var(--color-text-muted);transition:color var(--transition-fast),transform var(--transition-fast);padding:var(--spacing-xs)}.comment-section__refresh-btn:hover{color:var(--color-primary);transform:rotate(180deg)}.comment-form{margin-bottom:var(--spacing-xl);background-color:var(--color-bg-surface-alt);padding:var(--spacing-lg);border-radius:var(--radius-md);transition:all var(--transition-normal)}.comment-form--reply{margin-top:var(--spacing-md);margin-bottom:var(--spacing-md);border-left:3px solid var(--color-primary);animation:slideIn .3s ease-out}@keyframes slideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.comment-form__header{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}@media (min-width:640px){.comment-form__header{grid-template-columns:repeat(3,1fr)}}.comment-form__group{display:flex;flex-direction:column}.comment-form__label{font-size:.85rem;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--color-text-secondary)}.comment-form__label span{color:#ef4444;margin-left:2px}.comment-form__input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface);color:var(--color-text-main);transition:border-color var(--transition-fast)}.comment-form__input:focus{border-color:var(--color-primary);outline:0}.comment-form__editor-wrapper{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface);overflow:hidden;transition:border-color var(--transition-fast)}.comment-form__editor-wrapper:focus-within{border-color:var(--color-primary)}.comment-form__editor{width:100%;min-height:120px;padding:var(--spacing-md);border:none;resize:vertical;background-color:transparent;color:var(--color-text-main);font-family:inherit;line-height:1.6}.comment-form__editor:focus{outline:0}.comment-form__footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px dashed var(--color-border)}.comment-form__actions{display:flex;gap:var(--spacing-md)}.comment-form__submit-actions{display:flex;align-items:center;gap:var(--spacing-md)}.comment-form__action-btn{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;display:flex;align-items:center}.comment-form__action-btn:hover{color:var(--color-primary)}.comment-form__submit-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.comment-form__submit-btn:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-2px)}.comment-form__submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.comment-form__cancel-btn{background:0 0;border:none;color:var(--color-text-muted);font-size:.9rem;cursor:pointer;transition:color var(--transition-fast)}.comment-form__cancel-btn:hover{color:#ef4444}.comment-list{display:flex;flex-direction:column;gap:var(--spacing-lg);position:relative;min-height:200px}.comment-list-loading{position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgba(255,255,255,.7);z-index:10;display:flex;justify-content:center;align-items:center;border-radius:var(--radius-md);backdrop-filter:blur(2px)}.comment-list.is-loading>:not(.comment-list-loading){opacity:.5;pointer-events:none}.comment-loading-spinner{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--color-primary);font-weight:600}@media (prefers-color-scheme:dark){.comment-list-loading{background-color:rgba(0,0,0,.6)}}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.comment-item{display:flex;gap:var(--spacing-md);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-bg-surface-alt);animation:fadeIn .5s ease-out}.comment-item:last-child{border-bottom:none;padding-bottom:0}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.comment-item__avatar{flex-shrink:0}.comment-avatar-img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--color-bg-surface-alt)}.comment-item__body{flex:1;min-width:0}.comment-item__header{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.comment-item__author{font-weight:700;color:var(--color-text-main);text-decoration:none}.comment-item__author:hover{color:var(--color-primary);text-decoration:underline}.comment-item__user-info{display:inline-flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.comment-item__tag{font-size:.75rem;padding:2px 8px;border-radius:12px;background-color:var(--color-bg-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border);font-weight:500;line-height:1}.comment-item__tag--admin{background-color:rgba(239,68,68,.1);color:#ef4444;border-color:rgba(239,68,68,.2)}.comment-item__date{font-size:.8rem;color:var(--color-text-muted)}.comment-item__content{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-sm);word-break:break-word}.comment-item__content img{max-width:100%;border-radius:var(--radius-md);margin:var(--spacing-sm) 0}.comment-item__content pre{background-color:var(--color-bg-surface-alt);padding:var(--spacing-sm);border-radius:var(--radius-sm);overflow-x:auto}.comment-item__actions{display:flex;gap:var(--spacing-md)}.comment-item__reply-btn{background:0 0;border:none;color:var(--color-text-muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:4px;transition:color var(--transition-fast)}.comment-item__reply-btn:hover{color:var(--color-primary)}.comment-replies{margin-top:var(--spacing-md);padding-left:var(--spacing-lg);border-left:2px solid var(--color-bg-surface-alt)}.comment-replies .comment-item{border-bottom:1px dashed var(--color-bg-surface-alt);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md)}.comment-replies .comment-item:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}.comment-replies .comment-avatar-img{width:32px;height:32px}.comment-load-more{text-align:center;margin-top:var(--spacing-lg)}.comment-load-more__btn{background-color:var(--color-bg-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.comment-load-more__btn:hover{background-color:var(--color-bg-surface);border-color:var(--color-primary);color:var(--color-primary)}.comment-empty{text-align:center;padding:var(--spacing-xl) 0;color:var(--color-text-muted)}.comment-empty svg{margin-bottom:var(--spacing-md);color:var(--color-text-muted);opacity:.5}@media (max-width:768px){.comment-section,.comment-section-skeleton{padding:var(--spacing-md);margin-top:var(--spacing-lg);border-radius:var(--radius-md)}.comment-replies{padding-left:var(--spacing-sm);margin-top:var(--spacing-sm);border-left-width:2px}.comment-item{gap:var(--spacing-sm);padding-bottom:var(--spacing-md)}.comment-avatar-img{width:36px;height:36px}}.friends-page{padding-bottom:var(--spacing-xl)}.friends-page__header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--color-bg-surface-alt);display:flex;align-items:center;gap:var(--spacing-sm)}.friends-page__title{font-size:1.75rem;font-weight:800;color:var(--color-text-main);display:flex;align-items:center;gap:var(--spacing-sm)}.friends-page__title i{color:var(--color-primary)}.friends-page__subtitle{margin-top:var(--spacing-xs);color:var(--color-text-muted);font-size:.9rem}.friends-page__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.friend-card{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);transition:all var(--transition-normal);overflow:hidden;position:relative;height:100%;--hover-hue:220;--hover-color:hsl(var(--hover-hue), 75%, 45%)}@media (prefers-color-scheme:dark){.friend-card{--hover-color:hsl(var(--hover-hue), 80%, 65%)}}.friend-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px var(--color-shadow);border-color:var(--hover-color)}.friend-card__link{display:flex;align-items:center;padding:var(--spacing-lg);text-decoration:none;height:100%}.friend-card__avatar{flex-shrink:0;width:64px;height:64px;margin-right:var(--spacing-md);position:relative}.friend-card__avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;border:2px solid var(--color-bg-surface-alt);transition:transform var(--transition-fast),border-color var(--transition-normal)}.friend-card:hover .friend-card__avatar img{transform:rotate(10deg);border-color:var(--hover-color)}.friend-card__info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.friend-card__name{font-size:1.1rem;font-weight:700;color:var(--color-text-main);margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition-fast)}.friend-card:hover .friend-card__name{color:var(--hover-color)}.friend-card__desc{font-size:.85rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.friend-card--skeleton .friend-card__avatar,.friend-card--skeleton .friend-card__desc,.friend-card--skeleton .friend-card__name{background-color:var(--color-bg-surface-alt);color:transparent}@media (max-width:640px){.friends-page__grid{grid-template-columns:1fr}.friend-card__link{padding:var(--spacing-md)}}.friends-page__comments{margin-top:var(--spacing-xl)}.group-chat{position:fixed;bottom:20px;right:20px;width:400px;max-width:calc(100vw - 40px);height:600px;max-height:calc(100vh - 40px);background-color:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:0 10px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--color-border);z-index:1000;opacity:0;transform:translateY(20px) scale(.95);visibility:hidden;transition:all var(--transition-normal)}.group-chat--visible{opacity:1;transform:translateY(0) scale(1);visibility:visible}.group-chat__header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background-color:var(--color-bg-surface-alt);flex-shrink:0}.group-chat__title{font-size:1.125rem;font-weight:600;color:var(--color-text-main);margin:0}.group-chat__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:0 0;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:1.25rem;line-height:1;padding:0}.group-chat__close:hover{color:var(--color-text-main);background-color:var(--color-bg-body)}.group-chat__messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:0}.group-chat__messages::-webkit-scrollbar{width:6px}.group-chat__messages::-webkit-scrollbar-track{background:0 0}.group-chat__messages::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.group-chat__messages::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.group-chat__load-more{text-align:center;padding:var(--spacing-sm);color:var(--color-text-muted);font-size:.875rem;cursor:pointer;transition:color var(--transition-fast)}.group-chat__load-more:hover{color:var(--color-text-secondary)}.group-chat__load-more--loading{cursor:default;opacity:.6}.group-chat__message{display:flex;gap:var(--spacing-sm);animation:message-slide-in var(--transition-fast) ease-out}@keyframes message-slide-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.group-chat__message--own{flex-direction:row-reverse}.group-chat__avatar{width:36px;height:36px;min-width:36px;border-radius:50%;object-fit:cover;flex-shrink:0;background-color:var(--color-bg-surface-alt)}.group-chat__message-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;align-items:flex-start}.group-chat__message--own .group-chat__message-content{align-items:flex-end}.group-chat__bubble{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);word-wrap:break-word;word-break:break-word;max-width:80%;line-height:1.5;white-space:pre-wrap}.group-chat__message--own .group-chat__bubble{background-color:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.group-chat__message:not(.group-chat__message--own) .group-chat__bubble{background-color:var(--color-bg-surface-alt);color:var(--color-text-main);border-bottom-left-radius:var(--radius-sm)}.group-chat__username{font-size:.75rem;color:var(--color-text-muted);font-weight:500}.group-chat__message--own .group-chat__username{text-align:right}.group-chat__timestamp{font-size:.6875rem;color:var(--color-text-muted);margin-top:2px}.group-chat__message--own .group-chat__timestamp{text-align:right}.group-chat__system-message{text-align:center;padding:var(--spacing-sm);color:var(--color-text-muted);font-size:.875rem;font-style:italic}.group-chat__input-area{position:relative;padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);background-color:var(--color-bg-surface-alt);flex-shrink:0}.group-chat__input{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface);color:var(--color-text-main);font-size:.875rem;font-family:inherit;resize:none;min-height:40px;max-height:120px;transition:border-color var(--transition-fast)}.group-chat__input:focus{outline:0;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(37,99,235,.1)}.group-chat__send-btn{padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color var(--transition-fast);white-space:nowrap;flex-shrink:0}.group-chat__send-btn:hover:not(:disabled){background-color:var(--color-primary-hover)}.group-chat__send-btn:disabled{opacity:.6;cursor:not-allowed}.group-chat__trigger{position:fixed;bottom:calc(var(--spacing-xl) + 48px + var(--spacing-md));right:var(--spacing-xl);width:48px;height:48px;border-radius:50%;background-color:var(--color-primary);color:#fff;border:none;box-shadow:0 4px 12px rgba(37,99,235,.3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all var(--transition-fast);z-index:999}.group-chat__trigger:hover{background-color:var(--color-primary-hover);transform:scale(1.1);box-shadow:0 6px 16px rgba(37,99,235,.4)}.group-chat--visible+.group-chat__trigger,.group-chat--visible~.group-chat__trigger{display:none}@media (prefers-color-scheme:dark){.group-chat{box-shadow:0 10px 25px -5px rgba(0,0,0,.3),0 8px 10px -6px rgba(0,0,0,.2)}.group-chat__trigger{box-shadow:0 4px 12px rgba(59,130,246,.4)}.group-chat__trigger:hover{box-shadow:0 6px 16px rgba(59,130,246,.5)}}@media (max-width:640px){.group-chat{bottom:0;right:0;left:0;top:0;width:100%;max-width:100%;height:100vh;height:100dvh;height:calc(var(--vh,1vh) * 100);min-height:-webkit-fill-available;max-height:100vh;max-height:100dvh;max-height:calc(var(--vh,1vh) * 100);border-radius:0;border-left:none;border-right:none;border-bottom:none;border-top:none;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.group-chat__header{padding-top:calc(var(--spacing-md) + env(safe-area-inset-top,0px))}.group-chat__input-area{padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px))}.group-chat__trigger{bottom:calc(var(--spacing-lg) + 40px + var(--spacing-md) + env(safe-area-inset-bottom,0px));right:var(--spacing-lg);width:40px;height:40px;font-size:1.25rem}.group-chat__bubble{max-width:85%}.group-chat__avatar{width:32px;height:32px;min-width:32px}}@media (min-width:641px) and (max-width:1024px){.group-chat{width:360px;height:500px}}@media (max-width:768px){.group-chat__trigger{width:40px;height:40px;font-size:1.25rem}}.hero{position:relative;height:500px;overflow:hidden;margin-bottom:var(--spacing-xl);background-color:var(--color-bg-surface-alt)}.hero__bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;filter:blur(4px);transform:scale(1.1);z-index:0;transition:opacity 1s ease-in-out}.hero__bg.active{opacity:1}.hero__bg:not(.active){opacity:0}.hero__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,rgba(0,0,0,.3),rgba(0,0,0,.6));z-index:1}@media (prefers-color-scheme:dark){.hero__overlay{background:linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,.8))}}.hero__content{position:relative;z-index:2;text-align:center;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3);height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.hero__title{font-size:3rem;font-weight:800;margin-bottom:var(--spacing-sm);letter-spacing:-.02em}.hero__subtitle{font-size:1.25rem;opacity:.9;margin-bottom:var(--spacing-lg);min-height:1.8rem}.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.btn--primary{background-color:var(--color-primary);color:#fff;border:none}.btn--primary:hover{background-color:var(--color-primary-hover);transform:translateY(-2px)}.page-layout{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl)}@media (min-width:992px){.page-layout{grid-template-columns:3fr 1fr}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-bg-surface-alt)}.section-title{font-size:1.5rem;font-weight:700;color:var(--color-text-main);position:relative}.section-title::after{content:'';position:absolute;bottom:-10px;left:0;width:60px;height:2px;background-color:var(--color-primary)}.section-more{font-size:.875rem;color:var(--color-text-muted)}.article-grid{display:flex;flex-direction:column;gap:var(--spacing-lg)}.avatar--lg{width:80px;height:80px;border-radius:50%;margin:0 auto;object-fit:cover;border:3px solid var(--color-bg-surface-alt)}.social-links{display:flex;justify-content:center;gap:var(--spacing-md)}.social-links a{font-size:1.25rem;color:var(--color-text-secondary)}.social-links a:hover{color:var(--color-primary)}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tag-cloud .tag--active{background-color:var(--color-primary);color:#fff}.daily-header{display:flex;justify-content:space-between;align-items:flex-start}.daily-date__day{display:block;font-size:1.5rem;font-weight:700;color:var(--color-text-main);line-height:1;margin-bottom:var(--spacing-xs)}.daily-date__sub{font-size:.875rem;color:var(--color-text-muted);display:flex;align-items:center;gap:var(--spacing-sm)}.tag--success{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.daily-weather{display:flex;align-items:center;gap:var(--spacing-sm);text-align:right}.daily-weather__icon{font-size:2rem;color:var(--color-primary)}.daily-weather__temp{font-weight:700;color:var(--color-text-main)}.daily-weather__location{font-size:.8rem;color:var(--color-text-muted)}@media (min-width:992px){.daily-header{flex-direction:column;gap:var(--spacing-md)}.daily-date{width:100%;padding-bottom:var(--spacing-sm);border-bottom:1px dashed var(--color-border)}.daily-weather{width:100%;text-align:left;justify-content:flex-start}.daily-weather__temp{font-size:1.1em}}.list-unstyled{list-style:none}.news-list__item{margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px dashed var(--color-bg-surface-alt)}.news-list__item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.news-list__link{display:block;font-size:.95rem;color:var(--color-text-secondary);line-height:1.4}.news-list__link:hover{color:var(--color-primary)}.history-list__item{margin-bottom:var(--spacing-sm);font-size:.9rem;color:var(--color-text-secondary);display:flex;gap:var(--spacing-sm)}.history-list__item::before{content:'•';color:var(--color-primary)}@media (max-width:768px){.hero{height:300px}.hero__title{font-size:2rem}.section-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-xs)}.section-title{font-size:1.25rem}.page-layout{gap:var(--spacing-lg)}}.solar-term{--term-bg-start:var(--color-primary);--term-bg-end:var(--color-primary-hover);display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;font-size:.75rem;font-weight:600;line-height:1.5;color:#fff;background:linear-gradient(135deg,var(--term-bg-start),var(--term-bg-end));border-radius:9999px;box-shadow:0 2px 4px var(--color-shadow);text-shadow:0 1px 1px rgba(0,0,0,.1);transition:all var(--transition-fast);cursor:default;user-select:none;vertical-align:middle}.solar-term:hover{transform:translateY(-1px);box-shadow:0 4px 6px rgba(0,0,0,.15);filter:brightness(1.1)}@media (prefers-color-scheme:dark){.solar-term{box-shadow:0 2px 4px rgba(0,0,0,.4)}.solar-term:hover{box-shadow:0 4px 8px rgba(0,0,0,.5)}}.markdown-body{font-size:1rem;line-height:1.8;color:var(--color-text-main);word-wrap:break-word}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4,.markdown-body h5,.markdown-body h6{margin-top:1.5em;margin-bottom:.8em;font-weight:700;line-height:1.3;color:var(--color-text-main)}.markdown-body h1{font-size:2em;padding-bottom:.3em;border-bottom:1px solid var(--color-border)}.markdown-body h2{font-size:1.75em;padding-bottom:.3em;border-bottom:1px solid var(--color-border)}.markdown-body h3{font-size:1.5em}.markdown-body h4{font-size:1.25em}.markdown-body h5{font-size:1em}.markdown-body h6{font-size:.875em;color:var(--color-text-muted)}.markdown-body blockquote,.markdown-body dl,.markdown-body ol,.markdown-body p,.markdown-body pre,.markdown-body table,.markdown-body ul{margin-top:0;margin-bottom:1em}.markdown-body strong{font-weight:700}.markdown-body em{font-style:italic}.markdown-body a{color:var(--color-primary);text-decoration:none;border-bottom:1px solid transparent;transition:all var(--transition-fast)}.markdown-body a:hover{color:var(--color-primary-hover);border-bottom-color:var(--color-primary-hover)}.markdown-body ol,.markdown-body ul{padding-left:2em}.markdown-body ul{list-style-type:disc}.markdown-body ol{list-style-type:decimal}.markdown-body li>p{margin-top:.5em}.markdown-body li+li{margin-top:.25em}.markdown-body blockquote{padding:.5em 1em;color:var(--color-text-secondary);background-color:var(--color-bg-surface-alt);border-left:.25em solid var(--color-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.markdown-body blockquote>:first-child{margin-top:0}.markdown-body blockquote>:last-child{margin-bottom:0}.markdown-body img{max-width:100%;height:auto;border-radius:var(--radius-md);box-shadow:0 4px 6px var(--color-shadow);display:block;margin:1.5em auto}.markdown-body code{padding:.2em .4em;margin:0;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:85%;background-color:var(--color-bg-surface-alt);border-radius:var(--radius-sm);color:var(--color-text-main)}.markdown-body pre{padding:1em;overflow:auto;font-size:85%;line-height:1.45;background-color:#1e293b;border-radius:var(--radius-md);color:#e2e8f0}.markdown-body pre code{display:inline;padding:0;margin:0;overflow:visible;line-height:inherit;word-wrap:normal;background-color:transparent;border:0;color:inherit}.markdown-body table{display:block;width:100%;width:max-content;max-width:100%;overflow:auto;border-spacing:0;border-collapse:collapse}.markdown-body table td,.markdown-body table th{padding:.5em 1em;border:1px solid var(--color-border)}.markdown-body table th{font-weight:600;background-color:var(--color-bg-surface-alt)}.markdown-body table tr{background-color:var(--color-bg-surface);border-top:1px solid var(--color-border)}.markdown-body table tr:nth-child(2n){background-color:var(--color-bg-body)}.markdown-body hr{height:.25em;padding:0;margin:2em 0;background-color:var(--color-border);border:0}.markdown-body details{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5em 1em}.markdown-body summary{cursor:pointer;font-weight:600;outline:0}.markdown-body details[open]{padding-bottom:1em}.markdown-body details[open] summary{margin-bottom:1em;border-bottom:1px solid var(--color-border);padding-bottom:.5em}@media (prefers-color-scheme:dark){.markdown-body pre{background-color:#0f172a;border:1px solid var(--color-border)}}:root{--mumble-spacing-xs:0.25rem;--mumble-spacing-sm:0.5rem;--mumble-spacing-md:1rem;--mumble-spacing-lg:1.5rem;--mumble-spacing-xl:2rem;--mumble-radius-sm:4px;--mumble-radius-md:8px;--mumble-radius-lg:12px;--mumble-radius-xl:16px;--mumble-transition-fast:0.2s ease;--mumble-transition-normal:0.3s ease;--mumble-color-primary:#2563eb;--mumble-color-primary-hover:#1d4ed8;--mumble-color-text-main:#1f2937;--mumble-color-text-secondary:#4b5563;--mumble-color-text-muted:#9ca3af;--mumble-color-bg-body:#f3f4f6;--mumble-color-bg-surface:#ffffff;--mumble-color-bg-surface-alt:#f9fafb;--mumble-color-border:#e5e7eb;--mumble-color-shadow:rgba(0, 0, 0, 0.05);--mumble-color-shadow-hover:rgba(0, 0, 0, 0.1)}@media (prefers-color-scheme:dark){:root{--mumble-color-text-main:#e5e7eb;--mumble-color-text-secondary:#d1d5db;--mumble-color-text-muted:#6b7280;--mumble-color-bg-body:#111827;--mumble-color-bg-surface:#1f2937;--mumble-color-bg-surface-alt:#374151;--mumble-color-border:#374151;--mumble-color-shadow:rgba(0, 0, 0, 0.3);--mumble-color-shadow-hover:rgba(0, 0, 0, 0.5)}}[data-theme=dark]{--mumble-color-text-main:#e5e7eb;--mumble-color-text-secondary:#d1d5db;--mumble-color-text-muted:#6b7280;--mumble-color-bg-body:#111827;--mumble-color-bg-surface:#1f2937;--mumble-color-bg-surface-alt:#374151;--mumble-color-border:#374151;--mumble-color-shadow:rgba(0, 0, 0, 0.3);--mumble-color-shadow-hover:rgba(0, 0, 0, 0.5)}@media (max-width:768px){:root{--mumble-spacing-md:0.75rem;--mumble-spacing-lg:1rem;--mumble-spacing-xl:1.25rem}}.mumble-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--mumble-spacing-xl);max-width:1200px;margin:var(--mumble-spacing-xl) auto;padding:0 var(--mumble-spacing-md);align-items:start}.mumble-layout__main{display:flex;flex-direction:column;gap:var(--mumble-spacing-lg);min-width:0}@media (max-width:900px){.mumble-layout{display:block;padding:0 var(--mumble-spacing-sm)}.mumble-layout__sidebar{display:none}}.mumble-card{background-color:var(--mumble-color-bg-surface);border-radius:var(--mumble-radius-lg);border:1px solid var(--mumble-color-border);padding:var(--mumble-spacing-lg);box-shadow:0 1px 2px var(--mumble-color-shadow);transition:transform var(--mumble-transition-fast),box-shadow var(--mumble-transition-fast);position:relative;overflow:hidden}@media (max-width:768px){.mumble-card{padding:var(--mumble-spacing-md);border-radius:var(--mumble-radius-md)}}.mumble-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px var(--mumble-color-shadow-hover);border-color:transparent}.mumble-card--detail:hover{transform:none;box-shadow:0 1px 2px var(--mumble-color-shadow)}.mumble-card__header{display:flex;align-items:center;gap:var(--mumble-spacing-md);margin-bottom:var(--mumble-spacing-md)}.mumble-card__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--mumble-color-bg-surface-alt);background-color:var(--mumble-color-bg-surface-alt)}@media (max-width:768px){.mumble-card__avatar{width:40px;height:40px}}.mumble-card__meta{display:flex;flex-direction:column;justify-content:center}.mumble-card__author{font-weight:700;font-size:1rem;color:var(--mumble-color-text-main);display:flex;align-items:center;gap:var(--mumble-spacing-sm)}.mumble-card__role{font-size:.75rem;padding:.1rem .5rem;border-radius:999px;background-color:var(--mumble-color-bg-surface-alt);color:var(--mumble-color-text-secondary);font-weight:500}.mumble-card__time{font-size:.85rem;color:var(--mumble-color-text-muted)}.mumble-card__content{color:var(--mumble-color-text-main);font-size:1rem;line-height:1.75;margin-bottom:var(--mumble-spacing-lg);position:relative;word-break:break-word}.mumble-card__content.is-collapsed{max-height:300px;overflow:hidden;mask-image:linear-gradient(to bottom,black 50%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 50%,transparent 100%)}.mumble-card__content img{max-width:100%;height:auto;border-radius:var(--mumble-radius-md);margin:var(--mumble-spacing-sm) 0;box-shadow:0 2px 4px var(--mumble-color-shadow);cursor:zoom-in;display:block}.mumble-card__content a{color:var(--mumble-color-primary);text-decoration:none;border-bottom:1px dashed var(--mumble-color-primary)}.mumble-card__read-more{display:none;text-align:center;margin-top:calc(var(--mumble-spacing-md) * -1);margin-bottom:var(--mumble-spacing-md);position:relative;z-index:10}.mumble-card__read-more.is-expanded{margin-top:var(--mumble-spacing-sm)}.mumble-card__read-more-btn{background-color:var(--mumble-color-bg-surface-alt);border:1px solid var(--mumble-color-border);color:var(--mumble-color-text-secondary);padding:var(--mumble-spacing-sm) var(--mumble-spacing-xl);border-radius:99px;font-size:.875rem;cursor:pointer;transition:all var(--mumble-transition-fast)}.mumble-card__read-more-btn:hover{background-color:var(--mumble-color-primary);color:#fff;border-color:var(--mumble-color-primary)}.mumble-card__footer{display:flex;align-items:center;gap:var(--mumble-spacing-lg);padding-top:var(--mumble-spacing-md);border-top:1px solid var(--mumble-color-bg-surface-alt)}.mumble-action{display:flex;align-items:center;gap:var(--mumble-spacing-sm);color:var(--mumble-color-text-muted);font-size:.9rem;cursor:pointer;background:0 0;border:none;padding:var(--mumble-spacing-xs) var(--mumble-spacing-sm);border-radius:var(--mumble-radius-md);transition:all var(--mumble-transition-fast);font-family:inherit;text-decoration:none}.mumble-action:hover{background-color:var(--mumble-color-bg-surface-alt);color:var(--mumble-color-primary)}.mumble-action--active{color:var(--mumble-color-primary);background-color:rgba(37,99,235,.1)}.mumble-comments{margin-top:var(--mumble-spacing-lg);padding-top:var(--mumble-spacing-lg);border-top:1px dashed var(--mumble-color-border);animation:mumbleFadeIn var(--mumble-transition-normal)}.mumble-comments.is-hidden{display:none}@keyframes mumbleFadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.comment-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--mumble-spacing-md)}.comment-section__title{font-size:1rem;font-weight:700;margin:0;color:var(--mumble-color-text-main)}.comment-section__refresh-btn{background:0 0;border:none;color:var(--mumble-color-text-muted);cursor:pointer;transition:color var(--mumble-transition-fast)}.comment-section__refresh-btn:hover{color:var(--mumble-color-primary)}.comment-form{background-color:var(--mumble-color-bg-surface-alt);padding:var(--mumble-spacing-md);border-radius:var(--mumble-radius-md);margin-bottom:var(--mumble-spacing-lg);border:1px solid var(--mumble-color-border)}.comment-form__header{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--mumble-spacing-md);margin-bottom:var(--mumble-spacing-md)}.comment-form__group{display:flex;flex-direction:column;gap:var(--mumble-spacing-xs)}.comment-form__label{font-size:.8rem;font-weight:600;color:var(--mumble-color-text-secondary)}.comment-form__editor,.comment-form__input{width:100%;padding:var(--mumble-spacing-sm) var(--mumble-spacing-md);border:1px solid var(--mumble-color-border);border-radius:var(--mumble-radius-sm);background-color:var(--mumble-color-bg-surface);color:var(--mumble-color-text-main);font-family:inherit;font-size:.95rem;transition:all var(--mumble-transition-fast);box-sizing:border-box}.comment-form__editor{min-height:100px;resize:vertical;display:block}.comment-form__editor:focus,.comment-form__input:focus{outline:0;border-color:var(--mumble-color-primary);box-shadow:0 0 0 3px rgba(37,99,235,.15)}.comment-form__footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--mumble-spacing-md)}.comment-form__actions{display:flex;gap:var(--mumble-spacing-sm)}.comment-form__action-btn{color:var(--mumble-color-text-muted);background:0 0;border:none;padding:var(--mumble-spacing-xs);border-radius:var(--mumble-radius-sm);cursor:pointer;transition:all var(--mumble-transition-fast);display:flex;align-items:center}.comment-form__action-btn:hover{color:var(--mumble-color-primary);background-color:rgba(37,99,235,.1)}.comment-form__submit-btn{background-color:var(--mumble-color-primary);color:#fff;border:none;padding:var(--mumble-spacing-sm) var(--mumble-spacing-lg);border-radius:var(--mumble-radius-sm);cursor:pointer;font-weight:600;display:flex;align-items:center;gap:var(--mumble-spacing-sm);transition:background-color var(--mumble-transition-fast)}.comment-form__submit-btn:hover{background-color:var(--mumble-color-primary-hover)}.comment-form__submit-btn:disabled{opacity:.7;cursor:not-allowed}.comment-list{display:flex;flex-direction:column;gap:var(--mumble-spacing-md)}.comment-item{display:flex;gap:var(--mumble-spacing-md);animation:mumbleFadeIn .5s ease}.comment-item__avatar{width:32px;height:32px;flex-shrink:0}.comment-item__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:1px solid var(--mumble-color-border)}.comment-item__body{flex:1;background-color:var(--mumble-color-bg-surface-alt);padding:var(--mumble-spacing-md);border-radius:var(--mumble-radius-md);border-top-left-radius:2px;min-width:0}.comment-item__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--mumble-spacing-xs);font-size:.85rem}.comment-item__date{color:var(--mumble-color-text-muted)}.comment-item__content{font-size:.95rem;color:var(--mumble-color-text-main);line-height:1.6;word-break:break-word}.comment-item__content img{max-width:100%;border-radius:var(--mumble-radius-sm);margin:var(--mumble-spacing-sm) 0}.comment-item__actions{margin-top:var(--mumble-spacing-sm);display:flex;gap:var(--mumble-spacing-md)}.comment-item__reply-btn{font-size:.8rem;color:var(--mumble-color-text-muted);background:0 0;border:none;padding:0;cursor:pointer;display:flex;align-items:center;gap:4px}.comment-item__reply-btn:hover{color:var(--mumble-color-primary)}.comment-replies{margin-top:var(--mumble-spacing-md);padding-left:var(--mumble-spacing-md);border-left:2px solid var(--mumble-color-border);display:flex;flex-direction:column;gap:var(--mumble-spacing-md)}.comment-load-more{text-align:center;margin-top:var(--mumble-spacing-lg)}.comment-load-more__btn{background-color:var(--mumble-color-bg-surface);border:1px solid var(--mumble-color-border);color:var(--mumble-color-text-secondary);padding:var(--mumble-spacing-sm) var(--mumble-spacing-xl);border-radius:99px;cursor:pointer;transition:all var(--mumble-transition-fast)}.comment-load-more__btn:hover{border-color:var(--mumble-color-primary);color:var(--mumble-color-primary)}.comment-empty{text-align:center;padding:var(--mumble-spacing-xl);color:var(--mumble-color-text-muted)}.history-widget{background-color:var(--mumble-color-bg-surface);border-radius:var(--mumble-radius-lg);border:1px solid var(--mumble-color-border);padding:var(--mumble-spacing-lg);position:sticky;top:var(--mumble-spacing-lg)}.history-widget__title{font-size:1.1rem;font-weight:700;color:var(--mumble-color-text-main);margin-top:0;margin-bottom:var(--mumble-spacing-md);padding-bottom:var(--mumble-spacing-sm);border-bottom:2px solid var(--mumble-color-bg-surface-alt)}.history-widget__list{display:flex;flex-direction:column;gap:var(--mumble-spacing-md)}.history-item{padding-bottom:var(--mumble-spacing-md);border-bottom:1px dashed var(--mumble-color-border);transition:transform var(--mumble-transition-fast)}.history-item:last-child{border-bottom:none;padding-bottom:0}.history-item:hover{transform:translateX(4px)}.history-item__content{font-size:.9rem;color:var(--mumble-color-text-secondary);margin-bottom:var(--mumble-spacing-xs);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.history-item__time{font-size:.75rem;color:var(--mumble-color-text-muted);text-align:right;display:block;font-style:italic}.not-found-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;padding:var(--spacing-xl);text-align:center;background-color:var(--color-bg-body);color:var(--color-text-main);overflow:hidden;position:relative}.not-found__glitch-wrapper{position:relative;margin-bottom:var(--spacing-xl)}.not-found__code{font-size:8rem;font-weight:900;line-height:1;color:var(--color-text-main);position:relative;z-index:1;text-shadow:2px 2px 0 var(--color-primary);animation:glitch-skew 1s infinite linear alternate-reverse}.not-found__code::after,.not-found__code::before{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;opacity:.8}.not-found__code::before{color:#ef4444;z-index:-1;animation:glitch-anim-1 2.5s infinite linear alternate-reverse}.not-found__code::after{color:#3b82f6;z-index:-2;animation:glitch-anim-2 3s infinite linear alternate-reverse}.not-found__title{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-md);color:var(--color-text-main)}.not-found__description{font-size:1.2rem;color:var(--color-text-secondary);max-width:600px;margin-bottom:var(--spacing-xl);line-height:1.6}.not-found__description-quote{font-style:italic;color:var(--color-text-muted);font-size:1rem;margin-top:var(--spacing-sm);display:block}.not-found__actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap;justify-content:center}.not-found__btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);text-decoration:none;gap:var(--spacing-sm)}.not-found__btn--primary{background-color:var(--color-primary);color:#fff;border:2px solid var(--color-primary);box-shadow:0 4px 6px rgba(37,99,235,.2)}.not-found__btn--primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 6px 12px rgba(37,99,235,.3)}.not-found__btn--secondary{background-color:transparent;color:var(--color-text-main);border:2px solid var(--color-border)}.not-found__btn--secondary:hover{border-color:var(--color-text-secondary);background-color:var(--color-bg-surface-alt);transform:translateY(-2px)}@keyframes glitch-skew{0%{transform:skew(0)}10%{transform:skew(2deg)}20%{transform:skew(-2deg)}30%{transform:skew(1deg)}40%{transform:skew(-1deg)}50%{transform:skew(0)}100%{transform:skew(0)}}@keyframes glitch-anim-1{0%{clip-path:polygon(0 2%,100% 2%,100% 5%,0 5%);transform:translate(-2px,0)}10%{clip-path:polygon(0 15%,100% 15%,100% 15%,0 15%);transform:translate(2px,0)}20%{clip-path:polygon(0 10%,100% 10%,100% 20%,0 20%);transform:translate(-2px,0)}30%{clip-path:polygon(0 1%,100% 1%,100% 2%,0 2%);transform:translate(2px,0)}40%{clip-path:polygon(0 33%,100% 33%,100% 33%,0 33%);transform:translate(0,0)}50%{clip-path:polygon(0 44%,100% 44%,100% 44%,0 44%);transform:translate(0,0)}60%{clip-path:polygon(0 50%,100% 50%,100% 20%,0 20%);transform:translate(0,0)}100%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);transform:translate(0,0)}}@keyframes glitch-anim-2{0%{clip-path:polygon(0 12%,100% 12%,100% 15%,0 15%);transform:translate(2px,0)}10%{clip-path:polygon(0 10%,100% 10%,100% 20%,0 20%);transform:translate(-2px,0)}20%{clip-path:polygon(0 1%,100% 1%,100% 2%,0 2%);transform:translate(2px,0)}30%{clip-path:polygon(0 33%,100% 33%,100% 33%,0 33%);transform:translate(-1px,0)}40%{clip-path:polygon(0 44%,100% 44%,100% 44%,0 44%);transform:translate(0,0)}50%{clip-path:polygon(0 50%,100% 50%,100% 20%,0 20%);transform:translate(1px,0)}60%{clip-path:polygon(0 70%,100% 70%,100% 70%,0 70%);transform:translate(-1px,0)}100%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);transform:translate(0,0)}}@media (max-width:768px){.not-found__code{font-size:5rem}.not-found__title{font-size:1.5rem}}.search-page{padding:var(--spacing-lg) 0;max-width:var(--container-width);margin:0 auto;width:100%}.search-page__layout{display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-xl);align-items:start}@media (max-width:992px){.search-page__layout{grid-template-columns:1fr}}.search-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.search-header__title{font-size:1.5rem;color:var(--color-text-main);font-weight:600}.search-header__keyword{color:var(--color-primary);font-style:italic}.search-header__meta{color:var(--color-text-muted);font-size:.9rem}.search-results{display:flex;flex-direction:column;gap:var(--spacing-lg)}.search-results--empty{text-align:center;padding:var(--spacing-xl);background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px dashed var(--color-border);color:var(--color-text-secondary)}.search-card{background:var(--color-bg-surface);border-radius:var(--radius-lg);overflow:hidden;display:grid;grid-template-columns:240px 1fr;gap:0;border:1px solid var(--color-border);transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal);position:relative;height:200px}.search-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px -10px var(--color-shadow);border-color:var(--color-primary);z-index:1}@media (max-width:768px){.search-card{grid-template-columns:1fr;height:auto}}.search-card__cover{position:relative;overflow:hidden;background-color:var(--color-bg-surface-alt);height:100%}.search-card__cover img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.search-card:hover .search-card__cover img{transform:scale(1.05)}.search-card__content{padding:var(--spacing-lg);display:flex;flex-direction:column;justify-content:space-between;min-width:0}.search-card__meta{display:flex;gap:var(--spacing-md);font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.search-card__meta-item{display:flex;align-items:center;gap:var(--spacing-xs)}.search-card__title{font-size:1.25rem;font-weight:700;margin-bottom:var(--spacing-sm);line-height:1.4;color:var(--color-text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-card__title a{color:inherit;text-decoration:none;background-image:linear-gradient(var(--color-primary),var(--color-primary));background-size:0 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size var(--transition-normal)}.search-card:hover .search-card__title a{background-size:100% 2px;color:var(--color-primary)}.search-card__excerpt{font-size:.95rem;color:var(--color-text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--spacing-md)}.search-card__excerpt mark,.search-card__title mark{background-color:var(--color-mark-bg);color:var(--color-mark-text);padding:0 2px;border-radius:2px}.search-card__footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;border-top:1px solid var(--color-bg-surface-alt);padding-top:var(--spacing-sm)}.search-card__tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.search-card__tag{font-size:.8rem;color:var(--color-text-muted);text-decoration:none;padding:2px 8px;background:var(--color-bg-surface-alt);border-radius:12px;transition:all var(--transition-fast)}.search-card__tag:hover{background:var(--color-primary);color:#fff}.search-card__stats{display:flex;gap:var(--spacing-md);font-size:.85rem;color:var(--color-text-muted)}.search-card--skeleton{pointer-events:none}.search-page__sidebar .widget{margin-bottom:var(--spacing-lg)}.steam-container{max-width:var(--container-width);margin:0 auto;padding:var(--spacing-md);animation:fadeIn var(--transition-normal)}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.steam-header{margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-sm)}.steam-header__title{font-size:1.5rem;font-weight:700;color:var(--color-text-main);display:flex;align-items:center;gap:var(--spacing-sm)}.steam-game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.steam-game-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal);display:flex;flex-direction:column;position:relative}.steam-game-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px -5px var(--color-shadow);border-color:var(--color-primary)}.steam-game-card__link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.steam-game-card__image-wrapper{position:relative;padding-top:46%;background:var(--color-bg-surface-alt);overflow:hidden}.steam-game-card__image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.steam-game-card:hover .steam-game-card__image{transform:scale(1.05)}.steam-game-card__content{padding:var(--spacing-md);flex-grow:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.steam-game-card__title{font-size:1.1rem;font-weight:600;color:var(--color-text-main);margin:0;line-height:1.4}.steam-game-card__meta{font-size:.875rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-xs);margin-top:auto}.steam-summary{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.steam-summary__stats{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-muted)}.steam-summary__progress-track{height:6px;background:var(--color-bg-surface-alt);border-radius:3px;overflow:hidden}.steam-summary__progress-bar{height:100%;background:var(--color-primary);border-radius:3px;width:0;transition:width 1s ease-out;position:relative;overflow:hidden}.steam-summary__progress-bar::after{content:"";position:absolute;top:0;left:0;bottom:0;width:100%;background:linear-gradient(90deg,rgba(255,255,255,0) 0,rgba(255,255,255,.4) 50%,rgba(255,255,255,0) 100%);transform:translateX(-100%);animation:shimmer 2s infinite linear}@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}.steam-summary__icons{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.steam-summary__icon{width:24px;height:24px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--color-border)}.steam-summary__icon img{width:100%;height:100%;object-fit:cover}.steam-detail-header{background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);display:flex;gap:var(--spacing-lg);align-items:flex-start}@media (max-width:900px){.steam-detail-header{flex-direction:column;align-items:center;text-align:center}.steam-detail-header__info{align-items:center}.steam-detail-header__meta{justify-content:center}}.steam-detail-header__cover{width:100%;max-width:460px;height:auto;aspect-ratio:460/215;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px var(--color-shadow);flex-shrink:0;background-color:#000}.steam-detail-header__info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.steam-detail-header__title{font-size:2rem;font-weight:800;color:var(--color-text-main);margin:0}.steam-detail-header__meta{display:flex;gap:var(--spacing-lg);color:var(--color-text-secondary);font-size:.9rem;flex-wrap:wrap;justify-content:center}@media (min-width:769px){.steam-detail-header__meta{justify-content:flex-start}}.steam-detail-header__meta-item{display:flex;align-items:center;gap:var(--spacing-xs)}.steam-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-md);background:var(--color-bg-surface-alt);padding:var(--spacing-md);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.steam-stat-box{text-align:center;display:flex;flex-direction:column}.steam-stat-box__value{font-size:1.5rem;font-weight:700;color:var(--color-text-main)}.steam-stat-box__label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.steam-group{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);overflow:hidden}.steam-group__header{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-surface-alt);cursor:pointer;display:flex;align-items:center;justify-content:space-between;user-select:none;transition:background-color var(--transition-fast)}.steam-group__header:hover{background-color:var(--color-border)}.steam-group__title{font-size:1.1rem;font-weight:600;color:var(--color-text-main);display:flex;align-items:center;gap:var(--spacing-sm);margin:0}.steam-group__icon{transition:transform var(--transition-normal)}.steam-group.steam-is-collapsed .steam-group__icon{transform:rotate(-90deg)}.steam-group .steam-group__content{display:block;padding:0}.steam-group.steam-is-collapsed .steam-group__content{display:none}.steam-achievement{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.steam-achievement:last-child{border-bottom:none}.steam-achievement:hover{background-color:var(--color-bg-surface-alt)}.steam-achievement__icon{width:64px;height:64px;flex-shrink:0;border-radius:var(--radius-md);overflow:hidden;background:var(--color-bg-surface-alt);border:1px solid var(--color-border)}.steam-achievement__icon img{width:100%;height:100%;object-fit:cover}.steam-achievement__info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.25rem}.steam-achievement__name{font-weight:600;color:var(--color-text-main);font-size:1rem}.steam-achievement__desc{color:var(--color-text-secondary);font-size:.875rem;line-height:1.4}.steam-achievement__status{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;min-width:100px;font-size:.875rem;color:var(--color-text-muted)}@media (max-width:768px){.steam-summary{margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);gap:var(--spacing-xs)}.steam-stats-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);padding:var(--spacing-sm);margin-top:var(--spacing-xs)}}@media (max-width:640px){.steam-achievement{flex-direction:column;align-items:flex-start}.steam-achievement__status{align-items:flex-start;margin-top:var(--spacing-sm);flex-direction:row;gap:var(--spacing-sm)}}.steam-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600}.steam-status-badge--unlocked{background-color:rgba(16,185,129,.1);color:#10b981}.steam-status-badge--locked{background-color:rgba(100,116,139,.1);color:#64748b}.steam-status-badge--hidden{background-color:rgba(99,102,241,.1);color:#6366f1}.steam-empty{text-align:center;padding:var(--spacing-xl);background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);color:var(--color-text-secondary)}.steam-empty__icon{font-size:3rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.steam-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-text-main);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:var(--spacing-md)}.steam-back-btn:hover{background:var(--color-bg-surface-alt);border-color:var(--color-text-muted)}.timeline-page{max-width:var(--container-width);margin:0 auto;padding:var(--spacing-xl) var(--spacing-md);min-height:calc(100vh - var(--header-height))}.timeline-page__header{text-align:center;margin-bottom:var(--spacing-xl);animation:fadeInDown var(--transition-normal) forwards}.timeline-page__title{font-size:2rem;font-weight:700;color:var(--color-text-main);margin-bottom:var(--spacing-sm)}.timeline-page__subtitle{color:var(--color-text-secondary);font-size:1.1rem}.timeline{position:relative;padding:var(--spacing-lg) 0}.timeline::before{content:'';position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--color-border);transform:translateX(-50%);z-index:0}.timeline__item{position:relative;margin-bottom:var(--spacing-xl);width:50%;padding:0 var(--spacing-xl);box-sizing:border-box;opacity:0;transform:translateY(20px);transition:opacity var(--transition-normal),transform var(--transition-normal)}.timeline__item.is-visible{opacity:1;transform:translateY(0)}.timeline__item:nth-child(odd){left:0;text-align:right}.timeline__item:nth-child(2n){left:50%;text-align:left}.timeline__marker{position:absolute;top:24px;width:16px;height:16px;background:var(--color-bg-surface);border:4px solid var(--color-primary);border-radius:50%;z-index:1;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.timeline__item:nth-child(odd) .timeline__marker{right:-8px}.timeline__item:nth-child(2n) .timeline__marker{left:-8px}.timeline__item:hover .timeline__marker{background:var(--color-primary);box-shadow:0 0 0 4px var(--color-bg-surface-alt)}.timeline__date{display:inline-block;margin-bottom:var(--spacing-sm);font-weight:600;color:var(--color-primary);font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-surface-alt);border-radius:var(--radius-sm)}.timeline__content{background:var(--color-bg-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px var(--color-shadow),0 2px 4px -1px var(--color-shadow);border:1px solid var(--color-border);position:relative;transition:transform var(--transition-fast),box-shadow var(--transition-fast);text-align:left}.timeline__item:hover .timeline__content{transform:translateY(-2px);box-shadow:0 10px 15px -3px var(--color-shadow),0 4px 6px -2px var(--color-shadow);border-color:var(--color-primary)}.timeline__content::after{content:'';position:absolute;top:24px;width:0;height:0;border-style:solid;z-index:1}.timeline__item:nth-child(odd) .timeline__content::after{right:-10px;border-width:10px 0 10px 10px;border-color:transparent transparent transparent var(--color-bg-surface)}.timeline__item:nth-child(odd) .timeline__content::before{content:'';position:absolute;top:24px;right:-11px;width:0;height:0;border-style:solid;border-width:10px 0 10px 10px;border-color:transparent transparent transparent var(--color-border);z-index:0}.timeline__item:nth-child(2n) .timeline__content::after{left:-10px;border-width:10px 10px 10px 0;border-color:transparent var(--color-bg-surface) transparent transparent}.timeline__item:nth-child(2n) .timeline__content::before{content:'';position:absolute;top:24px;left:-11px;width:0;height:0;border-style:solid;border-width:10px 10px 10px 0;border-color:transparent var(--color-border) transparent transparent;z-index:0}.timeline__item:nth-child(odd):hover .timeline__content::before{border-left-color:var(--color-primary)}.timeline__item:nth-child(2n):hover .timeline__content::before{border-right-color:var(--color-primary)}.timeline__title{margin-top:0;margin-bottom:var(--spacing-md);font-size:1.25rem;color:var(--color-text-main);font-weight:700}.timeline__body{color:var(--color-text-secondary);font-size:1rem;line-height:1.6}.timeline__more{display:inline-block;margin-top:var(--spacing-md);color:var(--color-primary);text-decoration:none;font-weight:500;font-size:.9rem;transition:color var(--transition-fast)}.timeline__more:hover{color:var(--color-primary-hover);text-decoration:underline}@keyframes fadeInDown{from{opacity:0;transform:translate3d(0,-20px,0)}to{opacity:1;transform:translate3d(0,0,0)}}@media (max-width:768px){.timeline::before{left:20px}.timeline__item{width:100%;padding-left:50px;padding-right:0;margin-bottom:var(--spacing-lg)}.timeline__item:nth-child(2n),.timeline__item:nth-child(odd){left:0;text-align:left}.timeline__item:nth-child(2n) .timeline__marker,.timeline__item:nth-child(odd) .timeline__marker{left:12px;right:auto}.timeline__item:nth-child(2n) .timeline__content::after,.timeline__item:nth-child(odd) .timeline__content::after{left:-10px;right:auto;border-width:10px 10px 10px 0;border-color:transparent var(--color-bg-surface) transparent transparent}.timeline__item:nth-child(2n) .timeline__content::before,.timeline__item:nth-child(odd) .timeline__content::before{left:-11px;right:auto;border-width:10px 10px 10px 0;border-color:transparent var(--color-border) transparent transparent}.timeline__item:nth-child(2n):hover .timeline__content::before,.timeline__item:nth-child(odd):hover .timeline__content::before{border-right-color:var(--color-primary);border-left-color:transparent}}.toc{position:fixed;top:100px;right:20px;width:250px;max-height:calc(100vh - 120px);overflow-y:auto;padding:var(--spacing-md);background-color:var(--color-bg-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:0 4px 6px var(--color-shadow);z-index:90;display:none;opacity:0;transform:translateX(20px);transition:opacity var(--transition-normal),transform var(--transition-normal)}.toc.is-visible{display:block;opacity:1;transform:translateX(0)}.toc-fab{display:none;position:fixed;top:calc(var(--header-height) + 1rem);right:1rem;width:3rem;height:3rem;border-radius:50%;background-color:var(--color-bg-surface);color:var(--color-text-main);border:1px solid var(--color-border);box-shadow:0 4px 12px var(--color-shadow);z-index:95;cursor:pointer;align-items:center;justify-content:center;transition:all var(--transition-normal)}.toc-fab:hover{transform:translateY(-2px);box-shadow:0 6px 16px var(--color-shadow);color:var(--color-primary)}.toc-fab:active{transform:translateY(0)}@media (max-width:1200px){.toc.is-visible~.toc-fab{display:flex}.toc{display:none!important;position:fixed;top:calc(var(--header-height) + 4.5rem);right:1rem;left:auto;width:250px;max-width:80vw;max-height:60vh;height:auto;margin:0;border-radius:var(--radius-md);border:1px solid var(--color-border);transform:none;background-color:var(--color-bg-surface);box-shadow:0 4px 20px var(--color-shadow);z-index:94}.toc.is-open-mobile{display:block!important;animation:tocFadeIn .2s ease forwards}}@keyframes tocFadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.toc-list{list-style:none;padding:0;margin:0}.toc-list .toc-list{padding-left:var(--spacing-md);margin-top:var(--spacing-xs)}.toc-link{display:block;color:var(--color-text-secondary);text-decoration:none;font-size:.9rem;padding:2px 0;transition:color var(--transition-fast);line-height:1.4}.toc-link:hover{color:var(--color-primary)}.is-active-link{color:var(--color-primary);font-weight:600}.is-collapsed{max-height:0;overflow:hidden}.toc::-webkit-scrollbar{width:4px}.toc::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:2px}.video-container{max-width:var(--container-width);margin:0 auto;padding:var(--spacing-lg)}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.video-card{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 6px -1px var(--color-shadow),0 2px 4px -1px var(--color-shadow);transition:transform var(--transition-fast),box-shadow var(--transition-fast);text-decoration:none;display:flex;flex-direction:column}.video-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px var(--color-shadow),0 4px 6px -2px var(--color-shadow)}.video-card__cover{position:relative;padding-top:56.25%;background-color:var(--color-bg-surface-alt);overflow:hidden}.video-card__image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.video-card:hover .video-card__image{transform:scale(1.05)}.video-card__info{padding:var(--spacing-md);flex-grow:1;display:flex;flex-direction:column}.video-card__title{font-size:1.1rem;font-weight:600;color:var(--color-text-main);margin-bottom:var(--spacing-xs);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.video-card__meta{margin-top:auto;display:flex;align-items:center;justify-content:space-between;font-size:.875rem;color:var(--color-text-secondary)}.video-card__stats{display:flex;gap:var(--spacing-sm)}.video-card__stat{display:flex;align-items:center;gap:4px}.video-watch{max-width:var(--container-width);margin:0 auto;padding:var(--spacing-lg)}.video-player-wrapper{width:100%;background-color:#000;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 10px 15px -3px rgba(0,0,0,.5);margin-bottom:var(--spacing-lg);position:relative;aspect-ratio:16/9}.video-player{width:100%;height:100%}.video-info{background-color:var(--color-bg-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 var(--color-shadow)}.video-info__header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.video-info__title{font-size:1.5rem;font-weight:700;color:var(--color-text-main);margin-bottom:var(--spacing-sm);line-height:1.3}.video-info__meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md);color:var(--color-text-secondary);font-size:.9rem}.video-info__meta-item{display:flex;align-items:center;gap:6px}.video-info__description{color:var(--color-text-secondary);line-height:1.6;font-size:1rem;white-space:pre-wrap}.video-comments{margin-top:var(--spacing-lg)}.icon{width:1em;height:1em;fill:currentColor}@media (max-width:768px){.video-container,.video-watch{padding:var(--spacing-md)}.video-grid{grid-template-columns:repeat(auto-fill,minmax(100%,1fr));gap:var(--spacing-md)}.video-info__title{font-size:1.25rem}}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid transparent}.alert--info{background-color:var(--color-bg-surface-alt);border-color:var(--color-border);color:var(--color-text-secondary)}.alert--info strong{color:var(--color-primary)}.back-to-top{position:fixed;bottom:var(--spacing-xl);right:var(--spacing-xl);width:48px;height:48px;background-color:var(--color-bg-surface);color:var(--color-text-main);border:1px solid var(--color-border);border-radius:50%;box-shadow:0 4px 12px var(--color-shadow);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:999;opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-normal)}.back-to-top:hover{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 6px 16px var(--color-shadow)}.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover.is-visible{transform:translateY(-4px)}.back-to-top i{font-size:1.25rem}@media (max-width:768px){.back-to-top{bottom:var(--spacing-lg);right:var(--spacing-lg);width:40px;height:40px}}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--transition-fast);backdrop-filter:blur(2px)}.dialog-overlay--visible{opacity:1;visibility:visible}.dialog{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:0 10px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);width:90%;max-width:400px;transform:scale(.95);opacity:0;transition:all var(--transition-normal);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--color-border)}.dialog-overlay--visible .dialog{transform:scale(1);opacity:1}.dialog__header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);font-weight:600;font-size:1.125rem;color:var(--color-text-main);display:flex;align-items:center;justify-content:space-between}.dialog__close{cursor:pointer;color:var(--color-text-muted);transition:color var(--transition-fast);background:0 0;border:none;font-size:1.25rem;padding:0;line-height:1}.dialog__close:hover{color:var(--color-text-main)}.dialog__body{padding:var(--spacing-lg);color:var(--color-text-secondary);font-size:1rem;line-height:1.6}.dialog__input-wrapper{margin-top:var(--spacing-md)}.dialog__input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg-body);color:var(--color-text-main);font-size:1rem;transition:border-color var(--transition-fast)}.dialog__input:focus{outline:0;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(37,99,235,.1)}.dialog__footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--spacing-sm);background-color:var(--color-bg-surface-alt)}.dialog__btn{padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent}.dialog__btn--primary{background-color:var(--color-primary);color:#fff}.dialog__btn--primary:hover{background-color:var(--color-primary-hover)}.dialog__btn--default{background-color:var(--color-bg-surface);border-color:var(--color-border);color:var(--color-text-secondary)}.dialog__btn--default:hover{background-color:var(--color-bg-body);color:var(--color-text-main)}.toast-container{position:fixed;top:20px;left:50%;transform:translateX(-50%);z-index:2000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background-color:var(--color-bg-surface);color:var(--color-text-main);padding:.75rem 1.25rem;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);display:flex;align-items:center;gap:.75rem;min-width:200px;max-width:90vw;animation:toast-enter .3s ease forwards;pointer-events:auto;border:1px solid var(--color-border)}.toast--info{border-left:4px solid var(--color-primary)}.toast--success{border-left:4px solid #10b981}.toast--warning{border-left:4px solid #f59e0b}.toast--error{border-left:4px solid #ef4444}.toast__icon{font-size:1.25rem}.toast--success .toast__icon{color:#10b981}.toast--warning .toast__icon{color:#f59e0b}.toast--error .toast__icon{color:#ef4444}.toast--info .toast__icon{color:var(--color-primary)}.toast.is-leaving{animation:toast-exit .3s ease forwards}@keyframes toast-enter{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-exit{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.dialog-tooltip{position:fixed;z-index:10000;padding:6px 10px;background:rgba(0,0,0,.85);color:#fff;border-radius:4px;font-size:13px;line-height:1.4;pointer-events:none;opacity:0;transition:opacity .2s ease,transform .2s ease;max-width:300px;word-wrap:break-word;box-shadow:0 4px 12px rgba(0,0,0,.15);backdrop-filter:blur(4px);transform:translateY(5px)}.dialog-tooltip.is-visible{opacity:1;transform:translateY(0)}.dialog-tooltip::after{content:'';position:absolute;width:0;height:0;border-style:solid;left:50%;transform:translateX(-50%)}.dialog-tooltip:not(.is-bottom)::after{bottom:-6px;border-width:6px 6px 0 6px;border-color:rgba(0,0,0,.85) transparent transparent transparent}.dialog-tooltip.is-bottom::after{top:-6px;border-width:0 6px 6px 6px;border-color:transparent transparent rgba(0,0,0,.85) transparent}@media (prefers-color-scheme:dark){.dialog-tooltip{background:rgba(60,60,60,.95);color:#f5f5f5;box-shadow:0 4px 12px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.1)}.dialog-tooltip:not(.is-bottom)::after{border-color:rgba(60,60,60,.95) transparent transparent transparent}.dialog-tooltip.is-bottom::after{border-color:transparent transparent rgba(60,60,60,.95) transparent}}@media (max-width:640px){.dialog{width:95%;margin:0 auto}.toast-container{width:100%;padding:0 1rem;top:auto;bottom:2rem;transform:none;left:0}.toast{width:100%;animation:toast-enter-mobile .3s ease forwards}.toast.is-leaving{animation:toast-exit-mobile .3s ease forwards}@keyframes toast-enter-mobile{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-exit-mobile{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}}.notification-box{position:fixed;right:20px;top:15px;width:350px;background-color:var(--color-bg-surface);border-radius:var(--radius-md);box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);border:1px solid var(--color-border);z-index:1500;opacity:0;transform:translateX(100%);transition:opacity var(--transition-normal),transform var(--transition-normal);overflow:hidden;box-sizing:border-box}.notification-box--enter{opacity:1;transform:translateX(0)}.notification-box--exit{opacity:0;transform:translateX(100%)}.notification-box--info{border-left:4px solid var(--color-primary)}.notification-box--success{border-left:4px solid #10b981}.notification-box--warning{border-left:4px solid #f59e0b}.notification-box--error{border-left:4px solid #ef4444}.notification-box__title{padding:var(--spacing-md) var(--spacing-lg);font-weight:600;font-size:1rem;color:var(--color-text-main);border-bottom:1px solid var(--color-border)}.notification-box__content-container{padding:var(--spacing-md) var(--spacing-lg)}.notification-box__content{color:var(--color-text-secondary);font-size:.875rem;line-height:1.6;word-wrap:break-word}.notification-box__progress{margin-top:var(--spacing-sm);height:26px;background-color:var(--color-bg-surface-alt);border-radius:var(--radius-md);overflow:hidden;position:relative;display:flex;align-items:center;gap:8px}.notification-box__progress-track{flex:1;height:100%;background-color:var(--color-bg-surface-alt);border-radius:var(--radius-md);overflow:hidden;position:relative}.notification-box__progress-bar{height:100%;background-color:var(--color-primary);border-radius:var(--radius-md);transition:width var(--transition-normal);position:absolute;top:0;left:0;min-width:0;width:0}.notification-box__progress-bar[style*="width: 0%"],.notification-box__progress-bar[style*="width:0%"]{display:none}.notification-box--success .notification-box__progress-bar{background-color:#10b981}.notification-box--warning .notification-box__progress-bar{background-color:#f59e0b}.notification-box--error .notification-box__progress-bar{background-color:#ef4444}.notification-box__progress-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:.8125rem;font-weight:600;white-space:nowrap;line-height:1;letter-spacing:.02em;z-index:1;pointer-events:none;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.notification-box__progress-bar[style*="display: none"]~.notification-box__progress-text,.notification-box__progress-bar[style*="display:none"]~.notification-box__progress-text{color:var(--color-text-secondary);text-shadow:none}.notification-box__progress-text--external{font-size:.8125rem;color:var(--color-text-secondary);font-weight:600;white-space:nowrap;line-height:1;letter-spacing:.02em;min-width:50px;text-align:right;flex-shrink:0}.notification-box__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:0 0;border:none;cursor:pointer;color:var(--color-text-muted);font-size:1.25rem;line-height:1;padding:0;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.notification-box__close:hover{color:var(--color-text-main);background-color:var(--color-bg-surface-alt)}.notification-box__close:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-color-scheme:dark){.notification-box{box-shadow:0 4px 6px -1px rgba(0,0,0,.3),0 2px 4px -1px rgba(0,0,0,.2)}}@media (max-width:640px){.notification-box{right:10px;left:10px;width:calc(100% - 20px);max-width:none}}@keyframes shake{0%{transform:translate(1px,1px) rotate(0)}10%{transform:translate(-1px,-2px) rotate(-1deg)}20%{transform:translate(-3px,0) rotate(1deg)}30%{transform:translate(3px,2px) rotate(0)}40%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,2px) rotate(-1deg)}60%{transform:translate(-3px,1px) rotate(0)}70%{transform:translate(3px,1px) rotate(-1deg)}80%{transform:translate(-1px,-1px) rotate(1deg)}90%{transform:translate(1px,2px) rotate(0)}100%{transform:translate(1px,-2px) rotate(-1deg)}}@keyframes broken-glass{0%{transform:scale(1);filter:none}5%{transform:scale(1.02)}100%{transform:scale(1);filter:sepia(.2) blur(.5px)}}@keyframes stone-throw{0%{transform:translate3d(60vw,-60vh,1000px) rotate(0) scale(.5);opacity:0}20%{opacity:1}100%{transform:translate3d(0,0,0) rotate(720deg) scale(1);opacity:1}}.easter-egg-stone{position:fixed;top:50%;left:50%;width:100px;height:100px;margin-left:-50px;margin-top:-50px;z-index:100000;font-size:80px;line-height:100px;text-align:center;pointer-events:none;animation:stone-throw .6s ease-in forwards;filter:drop-shadow(10px 10px 15px rgba(0,0,0,.5))}.easter-egg--shake .group-chat,.easter-egg--shake .group-chat__trigger,.easter-egg--shake .site-wrapper{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}.easter-egg--broken{position:relative;overflow-x:hidden}.easter-egg--broken .group-chat,.easter-egg--broken .group-chat__trigger,.easter-egg--broken .site-wrapper{filter:sepia(.1) contrast(1.1);transition:filter .2s}.easter-egg--broken::before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:99999;pointer-events:none;background-image:radial-gradient(circle at center,rgba(255,255,255,.15) 0,transparent 25%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' preserveAspectRatio='none'%3E%3Cdefs%3E%3Cfilter id='glow'%3E%3CfeGaussianBlur stdDeviation='0.3' result='coloredBlur'/%3E%3CfeMerge%3E%3CfeMergeNode in='coloredBlur'/%3E%3CfeMergeNode in='SourceGraphic'/%3E%3C/feMerge%3E%3C/filter%3E%3C/defs%3E%3Cg stroke='rgba(255, 255, 255, 0.7)' stroke-width='0.4' stroke-linecap='round' filter='url(%23glow)'%3E%3Cpath d='M50 50 L10 5'/%3E%3Cpath d='M50 50 L90 10'/%3E%3Cpath d='M50 50 L95 60'/%3E%3Cpath d='M50 50 L60 95'/%3E%3Cpath d='M50 50 L15 85'/%3E%3Cpath d='M50 50 L5 40'/%3E%3Cpath d='M30 25 L40 15'/%3E%3Cpath d='M70 20 L80 35'/%3E%3Cpath d='M65 85 L80 75'/%3E%3Cpath d='M20 60 L30 75'/%3E%3Cpath d='M40 40 L60 30' stroke-opacity='0.5'/%3E%3Cpath d='M45 55 L35 65' stroke-opacity='0.5'/%3E%3C/g%3E%3Ccircle cx='50' cy='50' r='15' fill='url(%23center-crack)' opacity='0.3'/%3E%3Cdefs%3E%3CradialGradient id='center-crack'%3E%3Cstop offset='0%25' stop-color='white'/%3E%3Cstop offset='100%25' stop-color='transparent'/%3E%3C/radialGradient%3E%3C/defs%3E%3C/svg%3E");background-size:cover;background-position:center;mix-blend-mode:screen}.easter-egg--broken::after{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;box-shadow:inset 0 0 150px rgba(0,0,0,.4);z-index:99998;pointer-events:none;backdrop-filter:blur(0.5px)}.home-video-section{margin-bottom:var(--spacing-xl);background-color:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;box-shadow:0 4px 6px var(--color-shadow);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.home-video-section:hover{box-shadow:0 10px 15px var(--color-shadow)}.home-video-section__header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background-color:var(--color-bg-surface-alt)}.home-video-section__title{font-size:1.1rem;font-weight:700;color:var(--color-text-main);display:flex;align-items:center;gap:var(--spacing-sm)}.home-video-section__title i{color:var(--color-primary)}.home-video-section__body{padding:var(--spacing-md)}.home-video-player{position:relative;width:100%;padding-bottom:56.25%;background-color:#000;border-radius:var(--radius-md);overflow:hidden;box-shadow:inset 0 0 20px rgba(0,0,0,.5)}.home-video-player:not(.is-web-fullscreen):not(.is-fullscreen)>*{position:absolute!important;top:0;left:0;width:100%!important;height:100%!important;object-fit:cover}@media (prefers-color-scheme:dark){.home-video-section{border-color:var(--color-border)}}@media (max-width:768px){.home-video-section__body{padding:var(--spacing-sm)}.home-video-section{border-radius:var(--radius-md)}}.app-startup{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#050505;background-image:linear-gradient(rgba(18,16,16,0) 50%,rgba(0,0,0,.25) 50%),linear-gradient(90deg,rgba(255,0,0,.06),rgba(0,255,0,.02),rgba(0,0,255,.06));background-size:100% 2px,3px 100%;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;font-family:'Fira Code',monospace;color:#e0e0e0;overflow:hidden}.app-startup::after{content:" ";display:block;position:absolute;top:0;left:0;bottom:0;right:0;background:rgba(18,16,16,.1);opacity:0;z-index:2;pointer-events:none;animation:flicker .15s infinite}.app-startup__content{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:60px;position:relative;z-index:3}.app-startup__brand{position:relative;width:100px;height:100px;margin-bottom:2rem;display:flex;align-items:center;justify-content:center}.app-startup__ring{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid transparent;border-top-color:#00f3ff;border-bottom-color:#bc13fe;box-shadow:0 0 15px rgba(0,243,255,.5),0 0 5px rgba(188,19,254,.5);animation:spin 2s linear infinite}.app-startup__ring::before{content:"";position:absolute;top:-5px;left:-5px;right:-5px;bottom:-5px;border-radius:50%;border:2px solid transparent;border-left-color:#00f3ff;border-right-color:#bc13fe;opacity:.5;animation:spin 3s linear infinite reverse}.app-startup__ring::after{content:"";position:absolute;top:10px;left:10px;right:10px;bottom:10px;border-radius:50%;border:1px dashed rgba(255,255,255,.3);animation:spin 10s linear infinite}.app-startup__core{width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:20px solid #fff;position:relative;animation:pulse-triangle 1s ease-in-out infinite;filter:drop-shadow(0 0 10px #00f3ff)}.app-startup__core::after{content:'';position:absolute;top:20px;left:-10px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-top:20px solid #fff}.app-startup__title{font-size:2.5rem;font-weight:900;text-transform:uppercase;letter-spacing:.2em;margin-bottom:.5rem;color:#fff;text-shadow:2px 2px 0 #bc13fe,-2px -2px 0 #00f3ff;position:relative;animation:glitch-text 3s infinite linear alternate-reverse}.app-startup__subtitle{font-size:1rem;color:#00f3ff;margin-bottom:2.5rem;text-transform:uppercase;letter-spacing:.3em;opacity:.8;text-shadow:0 0 5px rgba(0,243,255,.8)}.app-startup__progress{width:300px;height:12px;background-color:#1a1a1a;border:1px solid #333;padding:2px;position:relative;box-shadow:0 0 10px rgba(0,0,0,.5);clip-path:polygon(0 0,100% 0,100% 70%,95% 100%,0 100%)}.app-startup__bar{height:100%;width:var(--blazor-load-percentage,10%);background:repeating-linear-gradient(45deg,#bc13fe,#bc13fe 10px,#9d00e0 10px,#9d00e0 20px);box-shadow:0 0 10px #bc13fe;transition:width .1s ease-out;position:relative}.app-startup__bar::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shine 1.5s infinite}.app-startup__status{margin-top:1rem;font-size:.8rem;color:#00f3ff;text-transform:uppercase;letter-spacing:1px}.app-startup__status::before{content:"> SYSTEM LOADING: "}.app-startup__status::after{content:var(--blazor-load-percentage-text, "INITIALIZING...");font-weight:700}.app-startup__footer{position:absolute;bottom:2rem;width:100%;text-align:center;font-size:.75rem;color:#555;z-index:3}.app-startup__footer p{margin:0}.app-startup__footer a{color:#777;text-decoration:none;transition:color .2s;text-transform:uppercase}.app-startup__footer a:hover{color:#00f3ff;text-shadow:0 0 5px #00f3ff}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes pulse-triangle{0%{transform:scale(.8);opacity:.7}50%{transform:scale(1.1);opacity:1}100%{transform:scale(.8);opacity:.7}}@keyframes flicker{0%{opacity:.05}5%{opacity:.1}10%{opacity:.05}15%{opacity:.15}20%{opacity:.05}50%{opacity:.05}55%{opacity:.1}60%{opacity:.05}100%{opacity:.05}}@keyframes glitch-text{0%{transform:translate(0)}20%{transform:translate(-2px,2px)}40%{transform:translate(-2px,-2px)}60%{transform:translate(2px,2px)}80%{transform:translate(2px,-2px)}100%{transform:translate(0)}}@keyframes shine{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}@media (max-width:600px){.app-startup__title{font-size:2rem}.app-startup__progress{width:80%}}*,::after,::before{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";background-color:var(--color-bg-body);color:var(--color-text-main);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color var(--transition-normal),color var(--transition-normal);min-height:100vh;display:flex;flex-direction:column}.site-wrapper{display:flex;flex-direction:column;min-height:100vh}.site-main{flex:1;width:100%}a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}img{max-width:100%;height:auto;display:block}mark{background-color:var(--color-mark-bg);color:var(--color-mark-text);padding:.1em .2em;border-radius:var(--radius-sm)}.container{width:100%;max-width:var(--container-width);margin:var(--spacing-xl) auto 0;padding:0 var(--spacing-md)}.site-header{height:var(--header-height);background-color:rgba(255,255,255,.8);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;backdrop-filter:blur(10px)}@media (prefers-color-scheme:dark){.site-header{background-color:rgba(30,41,59,.8)}}.site-header__inner{height:100%;display:flex;align-items:center;justify-content:space-between}.site-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:700;font-size:1.25rem;color:var(--color-text-main)}.site-logo__img{height:32px;width:32px;border-radius:var(--radius-sm)}.site-footer{padding:var(--spacing-xl) 0;margin-top:var(--spacing-xl);background-color:var(--color-bg-surface);border-top:1px solid var(--color-border);text-align:center;color:var(--color-text-secondary);font-size:.875rem}.text-center{text-align:center}.mt-1{margin-top:var(--spacing-md)}.mt-2{margin-top:var(--spacing-lg)}.connection-status{display:inline-block;width:.5rem;height:.5rem;border-radius:50%;background-color:var(--color-status-disconnected);vertical-align:middle;margin-left:var(--spacing-sm);transition:background-color var(--transition-normal),box-shadow var(--transition-normal);cursor:help}.connection-status--connected{background-color:var(--color-status-connected);box-shadow:0 0 4px var(--color-status-connected-shadow)}.connection-status--disconnected{background-color:var(--color-status-error);animation:status-pulse 2s infinite}@keyframes status-pulse{0%{opacity:1}50%{opacity:.5}100%{opacity:1}}:root{--music-player-size:64px;--music-player-panel-width:360px;--music-player-theme:#ff4081;--music-player-bg:rgba(18, 18, 18, 0.96);--music-player-text:#fff;--music-player-text-secondary:rgba(255, 255, 255, 0.65)}@media (prefers-color-scheme:light){:root{--music-player-bg:rgba(255, 255, 255, 0.96);--music-player-text:#333;--music-player-text-secondary:rgba(0, 0, 0, 0.65)}}.music-player__mini{position:fixed;left:16px;bottom:16px;width:var(--music-player-size);height:var(--music-player-size);border-radius:50%;box-shadow:0 8px 24px rgba(0,0,0,.2);z-index:100;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--music-player-bg);transition:transform .18s ease}.music-player__mini:active{transform:scale(.98)}.music-player__mini-cover{width:100%;height:100%;border-radius:50%;display:block;position:absolute;inset:0;overflow:hidden;background-size:cover;background-position:center;background-repeat:no-repeat}.music-player__progress-ring{position:absolute;top:-8px;left:-8px;width:calc(100% + 16px);height:calc(100% + 16px);pointer-events:none;transform:rotate(-90deg);z-index:1}.music-player__progress-ring circle{transition:stroke-dashoffset .35s;transform-origin:50% 50%}.music-player__mini-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2}.music-player__mini-status{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;transition:background .18s;pointer-events:none}.music-player__panel{position:fixed;inset:0;pointer-events:none;z-index:100;box-sizing:border-box}.music-player__panel *{box-sizing:border-box}.music-player__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);opacity:0;transition:opacity .25s;pointer-events:none;display:none}.music-player__content{position:fixed;left:0;top:0;bottom:0;width:var(--music-player-panel-width);transform:translateX(-100%);transition:transform .28s cubic-bezier(.2, .9, .2, 1);pointer-events:auto;background:var(--music-player-bg);color:var(--music-player-text);display:flex;flex-direction:column;box-shadow:4px 0 24px rgba(0,0,0,.1);backdrop-filter:blur(10px);overflow-x:hidden}.music-player__panel--open .music-player__backdrop{opacity:1;pointer-events:auto}.music-player__panel--open .music-player__content{transform:translateX(0)}.music-player__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(128,128,128,.1)}.music-player__info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.music-player__title{font-size:16px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}.music-player__artist{font-size:12px;color:var(--music-player-text-secondary)}.music-player__close-btn{background:0 0;border:none;color:var(--music-player-text);font-size:20px;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.music-player__close-btn:hover{background:rgba(128,128,128,.1)}.music-player__main{padding:16px;flex:1;display:flex;flex-direction:column;align-items:center;gap:16px;overflow-y:auto;overflow-x:hidden;width:100%}.music-player__cover-wrap{display:flex;justify-content:center;align-items:center;margin-bottom:10px}.music-player__cover{width:180px;height:180px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.15);transition:transform .3s ease;background-size:cover;background-position:center;background-repeat:no-repeat}@keyframes music-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.music-player__cover--rotating{animation:music-spin 20s linear infinite;border-radius:50%}.music-player__controls{width:100%;max-width:100%;padding:0 8px}.music-player__progress{display:flex;align-items:center;gap:10px;margin-bottom:16px}.music-player__time{font-size:12px;color:var(--music-player-text-secondary);width:40px;text-align:center;font-feature-settings:"tnum"}.music-player__seek{flex:1;height:4px;border-radius:2px;background:rgba(128,128,128,.2);position:relative;cursor:pointer;appearance:none}.music-player__seek::-webkit-slider-thumb{appearance:none;width:12px;height:12px;border-radius:50%;background:var(--music-player-theme);cursor:pointer;transition:transform .1s}.music-player__seek::-webkit-slider-thumb:hover{transform:scale(1.2)}.music-player__btn-group{display:flex;gap:20px;justify-content:center;align-items:center;margin-bottom:16px}.music-player__btn{width:48px;height:48px;border-radius:50%;background:rgba(128,128,128,.1);border:0;color:var(--music-player-text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:20px}.music-player__btn--main{width:64px;height:64px;background:var(--music-player-theme);color:#fff;font-size:28px;box-shadow:0 4px 12px rgba(255,64,129,.3)}.music-player__btn:hover:not(.music-player__btn--main){background:rgba(128,128,128,.2)}.music-player__btn--main:hover{transform:scale(1.05)}.music-player__extra-controls{display:flex;gap:16px;align-items:center;justify-content:center}.music-player__text-btn{background:0 0;border:none;color:var(--music-player-text-secondary);font-size:18px;cursor:pointer;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s}.music-player__text-btn--active,.music-player__text-btn:hover{color:var(--music-player-theme);background:rgba(128,128,128,.05)}.music-player__list{max-height:0;overflow-y:auto;transition:max-height .3s ease;border-top:1px solid rgba(128,128,128,.1);background:rgba(0,0,0,.02)}.music-player__list--visible{max-height:40vh;padding:8px 0}.music-player__item{display:flex;align-items:center;justify-content:flex-start;padding:10px 16px;cursor:pointer;transition:background .2s,color .2s;border-left:3px solid transparent}.music-player__item:hover{background:rgba(128,128,128,.1)}.music-player__item--active{background:rgba(128,128,128,.1);border-left-color:var(--music-player-theme)}.music-player__item--active .music-player__item-index,.music-player__item--active .music-player__item-title{color:var(--music-player-theme);font-weight:600}.music-player__item-index{width:24px;text-align:center;margin-right:12px;font-size:14px;color:var(--music-player-text-secondary);font-feature-settings:"tnum"}.music-player__item-meta{display:flex;flex-direction:column;overflow:hidden;flex:1}.music-player__item-title{font-size:14px;color:var(--music-player-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}.music-player__item-artist{font-size:12px;color:var(--music-player-text-secondary)}.music-player__lyrics{text-align:center;height:180px;overflow:hidden;mask-image:linear-gradient(to bottom,transparent,black 15%,black 85%,transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,black 15%,black 85%,transparent);margin-top:10px;width:100%;user-select:none;cursor:default}.music-player__lyrics-inner{transition:transform .3s ease-out}.music-player__lyric-line{padding:6px 0;font-size:14px;color:var(--music-player-text-secondary);transition:all .3s;min-height:24px}.music-player__lyric-line--current{color:var(--music-player-theme);font-size:16px;font-weight:700;transform:scale(1.05)}.music-player__bg-lyrics{position:fixed;bottom:15px;left:50%;transform:translateX(-50%);width:100%;max-width:800px;text-align:center;pointer-events:none;z-index:98;opacity:0;transition:opacity .3s ease;user-select:none;cursor:default;height:100px;overflow:hidden}.music-player__bg-lyrics--visible{opacity:1}.music-player__bg-lyrics-inner{display:flex;flex-direction:column;width:100%;transition:transform .5s cubic-bezier(.25, 1, .5, 1);will-change:transform}.music-player__bg-lyrics .music-player__lyric-line{padding:8px 0;font-size:20px;color:var(--music-player-text-secondary);transition:all .5s;min-height:44px;line-height:1.4;text-shadow:0 2px 8px rgba(0,0,0,.5);opacity:.6;display:flex;justify-content:center;align-items:center}.music-player__bg-lyrics .music-player__lyric-line--current{color:var(--music-player-theme);font-size:24px;font-weight:700;opacity:1;text-shadow:0 4px 12px rgba(255,64,129,.6);transform:scale(1.05)}@media (max-width:768px){:root{--music-player-size:64px}.music-player__content{width:100%;left:0;right:0;top:0;bottom:0;transform:translateY(100%);border-radius:0}.music-player__backdrop{display:block}.music-player__panel--open .music-player__content{transform:translateY(0)}.music-player__cover{width:260px;height:260px;border-radius:50%;margin:20px 0}.music-player__lyrics{height:260px}.music-player__list--visible{position:absolute;top:56px;left:0;right:0;bottom:0;max-height:none;z-index:20;background:var(--music-player-bg);display:flex;flex-direction:column}.music-player__bg-lyrics{bottom:100px;max-width:90%;padding:0 20px;height:80px}.music-player__bg-lyrics .music-player__lyric-line{font-size:16px;padding:6px 0;min-height:24px}.music-player__bg-lyrics .music-player__lyric-line--current{font-size:20px}.music-player__list-close-mobile{display:none;justify-content:center;align-items:center;padding:12px;cursor:pointer;color:var(--music-player-text-secondary);border-bottom:1px solid rgba(128,128,128,.1);background:var(--music-player-bg);font-size:20px;transition:color .2s}.music-player__list-close-mobile:hover{color:var(--music-player-theme)}}@media (min-width:769px){.music-player__content{border-top-right-radius:12px;border-bottom-right-radius:12px}.music-player__main{flex:0 0 auto;overflow-y:visible}.music-player__list{flex:1;max-height:none;overflow-y:auto;display:block}#mp-list-toggle{display:none}}.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:100%;margin-top:0}.header-left{display:flex;align-items:center;flex:0 0 auto;z-index:110}.header-center{display:flex;align-items:center;justify-content:center;flex:1 1 auto}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:20px;flex:0 0 auto;z-index:110}.site-logo__text{font-family:'Segoe UI',sans-serif;font-weight:700;letter-spacing:-.5px;margin-left:8px}.nav-menu{display:flex;list-style:none;margin:0;padding:0;gap:32px}.nav-menu__item{position:relative;height:100%;display:flex;align-items:center}.nav-menu__link{display:flex;align-items:center;gap:6px;color:var(--color-text-secondary);font-weight:500;font-size:.95rem;padding:4px 0;position:relative;transition:color .2s ease}.nav-menu__link::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:2px;background-color:var(--color-primary);transform:scaleX(0);transform-origin:right;transition:transform .2s ease}.nav-menu__link:hover{color:var(--color-text-main)}.nav-menu__link:hover::after{transform:scaleX(1);transform-origin:left}.nav-menu__item--active .nav-menu__link{color:var(--color-primary);font-weight:600}.nav-menu__item--active .nav-menu__link::after{transform:scaleX(1);background-color:var(--color-primary)}.nav-menu__arrow{font-size:.75em;margin-left:4px;transition:transform .2s}.nav-menu__item--has-sub:hover .nav-menu__arrow{transform:rotate(180deg)}.nav-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:2px;box-shadow:0 4px 12px rgba(0,0,0,.08);min-width:160px;padding:8px 0;opacity:0;visibility:hidden;transition:all .15s cubic-bezier(.4, 0, .2, 1);z-index:100;margin-top:12px}.nav-dropdown::before{content:'';position:absolute;top:-12px;left:0;width:100%;height:12px}.nav-menu__item--has-sub:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.nav-dropdown__item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--color-text-secondary);font-size:.9rem;transition:background-color .1s,color .1s}.nav-dropdown__item.active,.nav-dropdown__item:hover{background-color:var(--color-bg-surface-alt);color:var(--color-primary)}.nav-dropdown__item i{width:16px;text-align:center;font-size:.9em}.nav-user{display:flex;align-items:center}.nav-user__avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--color-border);cursor:pointer;object-fit:cover;transition:border-color .2s}.nav-user__avatar:hover{border-color:var(--color-primary)}.nav-user__login-btn{background:0 0;color:var(--color-text-main);border:1px solid transparent;padding:4px;border-radius:50%;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.nav-user__login-btn:hover{color:var(--color-primary);background-color:var(--color-bg-surface-alt)}.nav-toggle{display:none;background:0 0;border:none;cursor:pointer;padding:4px;z-index:120}.nav-toggle__icon{display:block;width:24px;height:2px;background-color:var(--color-text-main);position:relative;transition:background-color .3s}.nav-toggle__icon::after,.nav-toggle__icon::before{content:'';position:absolute;width:100%;height:100%;background-color:var(--color-text-main);transition:transform .3s}.nav-toggle__icon::before{transform:translateY(-7px)}.nav-toggle__icon::after{transform:translateY(7px)}.nav-toggle--active .nav-toggle__icon{background-color:transparent}.nav-toggle--active .nav-toggle__icon::before{transform:translateY(0) rotate(45deg)}.nav-toggle--active .nav-toggle__icon::after{transform:translateY(0) rotate(-45deg)}@media (max-width:900px){.header-center{position:fixed;top:0;right:0;width:0;max-width:320px;height:100vh;background-color:rgba(255,255,255,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:calc(var(--header-height) + 2rem) 0 2rem;box-shadow:-10px 0 30px rgba(0,0,0,.1);transform:translateX(100%);visibility:hidden;transition:transform .4s cubic-bezier(.16, 1, .3, 1),width 0s .4s,visibility 0s .4s;z-index:100;display:block;overflow-y:auto}@media (prefers-color-scheme:dark){.header-center{background-color:rgba(30,30,30,.9)}}.nav-toggle{display:block}.nav-menu{flex-direction:column;gap:0;width:100%;padding:0 16px}.nav-menu__item{width:100%;display:block;height:auto;border-bottom:1px solid rgba(0,0,0,.05);opacity:0;transform:translateX(20px);transition:opacity .3s ease,transform .3s ease}.header-center.is-open .nav-menu__item{opacity:1;transform:translateX(0)}.header-center.is-open .nav-menu__item:first-child{transition-delay:0.1s}.header-center.is-open .nav-menu__item:nth-child(2){transition-delay:0.15s}.header-center.is-open .nav-menu__item:nth-child(3){transition-delay:0.2s}.header-center.is-open .nav-menu__item:nth-child(4){transition-delay:0.25s}.header-center.is-open .nav-menu__item:nth-child(5){transition-delay:0.3s}.header-center.is-open .nav-menu__item:nth-child(6){transition-delay:0.35s}.nav-menu__link{width:100%;padding:18px 12px;font-size:1.1rem;justify-content:space-between;color:var(--color-text-main);border-radius:8px}.nav-menu__link::after{display:none}.nav-menu__link:hover{background-color:rgba(0,0,0,.03)}.nav-menu__item--active .nav-menu__link{color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.05);font-weight:600}.nav-dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;margin:0;padding:0;border-radius:0;background-color:transparent;display:none;padding-left:12px}.nav-menu__item--expanded .nav-dropdown{display:block;animation:slideDown .3s ease}.nav-menu__item--has-sub:hover .nav-dropdown{transform:none}.nav-menu__item--expanded .nav-menu__arrow{transform:rotate(180deg)}.nav-dropdown__item{padding:14px 16px;border-left:2px solid rgba(0,0,0,.1);font-size:1rem;margin:4px 0;border-radius:0 8px 8px 0}.nav-dropdown__item.active{border-left-color:var(--color-primary);background-color:rgba(0,0,0,.03);color:var(--color-primary);font-weight:600}.header-center.is-open{transform:translateX(0);width:100%;visibility:visible;transition:transform .4s cubic-bezier(.16, 1, .3, 1),width 0s,visibility 0s}.mobile-menu-overlay{position:fixed;inset:0;background-color:rgba(0,0,0,.3);backdrop-filter:blur(2px);z-index:99;opacity:0;visibility:hidden;transition:opacity .3s}.mobile-menu-overlay.is-open{opacity:1;visibility:visible}}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xl)}.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--spacing-sm);border-radius:var(--radius-md);background-color:var(--color-bg-surface);color:var(--color-text-main);border:1px solid var(--color-border);font-size:.9rem;font-weight:500;transition:all var(--transition-fast);cursor:pointer;text-decoration:none}.pagination a:hover{background-color:var(--color-bg-surface-alt);color:var(--color-primary);border-color:var(--color-primary)}.pagination .pagination__item--active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);pointer-events:none}.pagination .pagination__item--disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-surface-alt)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-surface-alt)}::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:4px;border:2px solid var(--color-bg-surface-alt)}::-webkit-scrollbar-thumb:hover{background-color:#94a3b8}@media (prefers-color-scheme:dark){::-webkit-scrollbar-thumb{background-color:#475569;border-color:#1e293b}::-webkit-scrollbar-thumb:hover{background-color:#64748b}}.search-box{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border);box-shadow:0 1px 3px var(--color-shadow);transition:box-shadow var(--transition-normal)}.search-box:focus-within{box-shadow:0 4px 6px var(--color-shadow);border-color:var(--color-primary)}.search-box__form{display:flex;gap:var(--spacing-sm)}.search-box__input{flex:1;width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface-alt);color:var(--color-text-main);font-size:.95rem;transition:all var(--transition-fast);outline:0}.search-box__input:focus{background-color:var(--color-bg-surface);border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(59,130,246,.2)}.search-box__input::placeholder{color:var(--color-text-muted)}.search-box__button{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;transition:background-color var(--transition-fast),transform var(--transition-fast);display:flex;align-items:center;justify-content:center}.search-box__button:hover{background-color:var(--color-primary-hover);transform:translateY(-1px)}.search-box__button:active{transform:translateY(0)}@keyframes skeleton-loading{0%{background-position:100% 50%}100%{background-position:0 50%}}.skeleton{--skeleton-start:var(--color-bg-surface-alt, #f1f5f9);--skeleton-mid:var(--color-border, #e2e8f0);--skeleton-end:var(--color-bg-surface-alt, #f1f5f9);background:linear-gradient(90deg,var(--skeleton-start) 25%,var(--skeleton-mid) 37%,var(--skeleton-end) 63%);background-size:400% 100%;animation:skeleton-loading 1.4s ease infinite;border-radius:var(--radius-md,4px);cursor:default;pointer-events:none;user-select:none}@media (prefers-color-scheme:dark){.skeleton{--skeleton-start:var(--color-bg-surface-alt, #1e293b);--skeleton-mid:var(--color-border, #334155);--skeleton-end:var(--color-bg-surface-alt, #1e293b)}}.skeleton--circle{border-radius:50%}.skeleton--text{height:1em;margin-bottom:.5em;border-radius:var(--radius-sm,2px)}.skeleton--title{height:1.5em;margin-bottom:1rem;border-radius:var(--radius-sm,2px)}.skeleton--button{height:2.5rem;border-radius:var(--radius-md,4px)}.skeleton--block{display:block;width:100%;height:100%}.skeleton--w-10{width:10%}.skeleton--w-20{width:20%}.skeleton--w-25{width:25%}.skeleton--w-30{width:30%}.skeleton--w-40{width:40%}.skeleton--w-50{width:50%}.skeleton--w-60{width:60%}.skeleton--w-70{width:70%}.skeleton--w-75{width:75%}.skeleton--w-80{width:80%}.skeleton--w-90{width:90%}.skeleton--w-100{width:100%}.skeleton-wrapper{position:relative;overflow:hidden}.tooltip{position:relative;display:inline-block}.tooltip__content{position:fixed;inset:auto;border:none;margin:0;width:max-content;max-width:250px;background-color:var(--color-bg-surface);color:var(--color-text-main);text-align:center;border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem;box-shadow:0 4px 6px -1px var(--color-shadow),0 2px 4px -1px var(--color-shadow);border:1px solid var(--color-border);pointer-events:none;opacity:0;transition:opacity var(--transition-fast),display var(--transition-fast) allow-discrete,overlay var(--transition-fast) allow-discrete;overflow:hidden;white-space:normal;word-break:break-word}.tooltip__content:popover-open{opacity:1}.tooltip__content::before{content:"";position:absolute;width:8px;height:8px;background:var(--color-bg-surface);border:1px solid var(--color-border);transform:rotate(45deg);z-index:-1}.tooltip__content--top::before{bottom:-5px;left:50%;margin-left:-4px;border-top:none;border-left:none}.tooltip__content--bottom::before{top:-5px;left:50%;margin-left:-4px;border-bottom:none;border-right:none}.tooltip__content--left::before{top:50%;right:-5px;margin-top:-4px;border-bottom:none;border-left:none}.tooltip__content--right::before{top:50%;left:-5px;margin-top:-4px;border-top:none;border-right:none}:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-bg-body:#f8fafc;--color-bg-surface:#ffffff;--color-bg-surface-alt:#f1f5f9;--color-text-main:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-mark-bg:#fef08a;--color-mark-text:#854d0e;--color-border:#e2e8f0;--color-shadow:rgba(0, 0, 0, 0.05);--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--container-width:1200px;--header-height:64px;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:1rem;--transition-fast:150ms ease;--transition-normal:300ms ease;--color-status-connected:#22c55e;--color-status-connected-shadow:rgba(34, 197, 94, 0.4);--color-status-disconnected:#94a3b8;--color-status-error:#ef4444}@media (max-width:768px){:root{--spacing-md:0.75rem;--spacing-lg:1rem;--spacing-xl:1.25rem}}@media (prefers-color-scheme:dark){:root{--color-primary:#3b82f6;--color-primary-hover:#60a5fa;--color-bg-body:#0f172a;--color-bg-surface:#1e293b;--color-bg-surface-alt:#334155;--color-text-main:#f1f5f9;--color-text-secondary:#cbd5e1;--color-text-muted:#64748b;--color-mark-bg:rgba(234, 179, 8, 0.2);--color-mark-text:#fde047;--color-border:#334155;--color-shadow:rgba(0, 0, 0, 0.3)}}.widget{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border);box-shadow:0 1px 3px var(--color-shadow)}.card__header,.widget__header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border)}.card__title,.widget__title{font-size:1.1rem;font-weight:700;color:var(--color-text-main);margin:0}.widget__intro{font-size:.95rem;color:var(--color-text-secondary);line-height:1.6}.widget__intro p{margin-bottom:var(--spacing-sm);text-indent:2em}.widget__intro p:last-child{margin-bottom:0}.sidebar-list{list-style:none;padding:0;margin:0}.sidebar-list__item{margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px dashed var(--color-border)}.sidebar-list__item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.sidebar-list__link{display:block;color:var(--color-text-secondary);font-size:.95rem;line-height:1.5;transition:color var(--transition-fast),transform var(--transition-fast);text-decoration:none}.sidebar-list__link:hover{color:var(--color-primary);transform:translateX(4px)}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tag-cloud .tag{display:inline-block;padding:4px 10px;background-color:var(--color-bg-surface-alt);color:var(--color-text-secondary);font-size:.85rem;border-radius:var(--radius-sm);transition:all var(--transition-fast);text-decoration:none}.tag--active,.tag-cloud .tag:hover{background-color:var(--color-primary);color:#fff;transform:translateY(-2px)}