*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color:#6b9d87;--primary-hover:#5a8572;--bg-main:#fff;--bg-sidebar:#fafbf9;--bg-page:#e5e5e5;--border-color:#e0e0e0;--border-dark:#d0d0d0;--text-primary:#333;--text-secondary:#666;--text-muted:#999;--sidebar-width:240px;--rightbar-width:280px;--topbar-height:60px;--footer-height:48px;--max-width:1200px;--font-family:"Noto Sans SC","Source Han Sans SC","Source Han Sans CN",-apple-system,BlinkMacSystemFont,"Segoe UI","Microsoft YaHei",sans-serif}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes skeleton-wave{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background-color:#f0f0f0;border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-wave{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-wave 1.5s ease-in-out infinite}html{overflow-y:scroll;scrollbar-gutter:stable;margin:0;padding:0;height:100%}@supports not (scrollbar-gutter:stable){html{overflow-y:scroll}}body{font-family:var(--font-family);font-size:14px;line-height:1.5;color:var(--text-primary);background-color:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%;margin:0;padding:0;position:static}a{text-decoration:none;color:inherit}.main-layout-wrapper{min-height:100vh;width:100%;overflow-x:hidden;position:relative}.page-wrapper{width:var(--max-width);max-width:100%;margin:0 auto;box-shadow:0 2px 8px rgba(0,0,0,.08);position:relative;min-height:100vh}.page-wrapper,.top-bar{background:var(--bg-main);box-sizing:border-box}.top-bar{height:var(--topbar-height);min-height:var(--topbar-height);border-bottom:1px solid var(--border-color);display:flex;padding:0 24px;position:fixed;top:0;z-index:999;left:50%;margin-left:calc(var(--max-width) / 2 * -1 + var(--sidebar-width));width:calc(var(--max-width) - var(--sidebar-width));gap:12px;box-shadow:0 1px 4px rgba(0,0,0,.05)}.mobile-menu-btn,.top-bar{align-items:center;flex-shrink:0}.mobile-menu-btn{display:none;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;color:var(--text-primary);padding:0}.mobile-menu-btn svg{width:24px;height:24px}.sidebar-overlay{display:none}.top-bar-center,form.top-bar-center{flex:1 1;display:flex;align-items:center;justify-content:center;max-width:400px;margin:0 auto}.search-category{border:1px solid var(--border-dark);border-right:1px solid #e8e8e8;background:var(--bg-main);cursor:pointer}.search-category,.search-input{height:34px;padding:0 12px;font-size:13px;outline:none;font-family:var(--font-family)}.search-input{flex:1 1;border:1px solid var(--border-dark);border-left:none;border-right:none}.search-btn{height:34px;width:42px;border:1px solid var(--border-dark);border-left:none;background:var(--bg-main);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:background .2s}.search-btn:hover{background:#f5f5f5}.top-bar-center:focus-within .search-btn,.top-bar-center:focus-within .search-category,.top-bar-center:focus-within .search-input{border-color:var(--primary-color)}.top-bar-center:focus-within .search-category{border-right-color:#e8e8e8}.top-bar-center:focus-within .search-input{border-left:none;border-right:none}.top-bar-center:focus-within .search-btn{border-left:none}.top-bar-right{flex-shrink:0;min-width:200px;display:flex;align-items:center;justify-content:flex-end;gap:12px}.login-link{color:var(--primary-color);font-size:13px;padding:8px 16px;transition:color .2s;min-width:60px;text-align:center;display:inline-block}.login-link:hover{color:var(--primary-hover)}.welcome-text{font-size:13px;color:var(--text-primary);display:inline-block;white-space:nowrap}.welcome-text .username{color:var(--primary-color);font-weight:500;margin-right:4px}.logout-btn{font-size:12px;color:var(--text-secondary);background:var(--bg-main);border:1px solid var(--border-color);border-radius:4px;padding:6px 12px;cursor:pointer;transition:all .2s;white-space:nowrap;display:inline-block;font-family:var(--font-family)}.logout-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.main-container{display:flex;min-height:100vh;position:relative;width:100%;box-sizing:border-box;margin-top:var(--topbar-height)}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);position:fixed;left:50%;margin-left:calc(var(--max-width) / 2 * -1);top:0!important;bottom:0;overflow-y:auto;flex-shrink:0;z-index:200;scrollbar-width:none;-ms-overflow-style:none;margin-top:0!important;padding-top:0!important;will-change:auto}.sidebar::-webkit-scrollbar{display:none}.site-header{height:50px;display:flex;align-items:center;justify-content:center;margin-top:0;padding-top:0}.site-title{font-size:17px;font-weight:500;color:var(--primary-color);margin:0}.site-title-transition{transition:opacity .15s ease-in-out;opacity:1;will-change:opacity}.user-profile{padding:16px 0 20px;text-align:center;border-bottom:1px solid var(--border-color)}.avatar{width:84px;height:84px;border-radius:50%;margin:0 auto 12px;background:var(--bg-main);box-shadow:0 2px 8px rgba(107,157,135,.15);overflow:hidden;position:relative;flex-shrink:0}.avatar img,.avatar svg{width:100%;height:100%;display:block}.avatar img{max-width:100%;max-height:100%;object-fit:cover;object-position:center;border-radius:50%}.username{font-size:15px;font-weight:500;color:var(--text-primary)}.nav-menu{padding:16px 0}.nav-item{display:flex;align-items:center;height:46px;margin:0 16px;padding:0 16px;color:var(--text-secondary);transition:all .25s ease;border-radius:6px;position:relative}.nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--primary-color);border-radius:0 2px 2px 0;transition:height .25s ease}.nav-item:hover{background:rgba(107,157,135,.06);color:var(--primary-color)}.nav-item:hover .nav-icon{transform:scale(1.05)}.nav-item:hover .nav-arrow{opacity:1;transform:translateX(0)}.nav-item.active{background:rgba(107,157,135,.1);color:var(--primary-hover);font-weight:500}.nav-item.active:before{height:20px}.nav-item.active .nav-icon svg{transform:scale(1.1)}.nav-item.active .nav-arrow{opacity:1;transform:translateX(0)}.nav-icon{margin-right:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.nav-icon,.nav-icon svg{width:20px;height:20px;transition:all .25s ease}.nav-icon svg{fill:var(--text-secondary);stroke:var(--text-secondary)}.nav-item.active .nav-icon svg,.nav-item:hover .nav-icon svg{fill:var(--primary-color);stroke:var(--primary-color)}.nav-item.active .nav-icon svg{fill:var(--primary-hover);stroke:var(--primary-hover)}.nav-text{font-size:14px;flex:1 1;letter-spacing:.3px}.nav-arrow{font-size:14px;opacity:0;transform:translateX(-4px);transition:all .25s ease;color:var(--primary-color)}.content-wrapper{flex:1 1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-width:0}.content-area,.content-wrapper{background:var(--bg-main);width:100%;box-sizing:border-box}.content-area{flex:1 1;padding:24px;min-height:calc(100vh - var(--topbar-height) - var(--footer-height));will-change:auto}.content-area.three-column{padding:0}.content-main{display:flex;gap:24px;padding:24px;width:100%}.content-main,.middle-content{box-sizing:border-box;min-width:0}.middle-content{flex:1 1}.right-sidebar{width:var(--rightbar-width);flex-shrink:0;box-sizing:border-box;align-self:flex-start}.footer{height:var(--footer-height);background:var(--bg-sidebar);border-top:1px solid var(--border-color);justify-content:center;margin-top:auto;padding:0 24px}.footer,.footer-content{display:flex;align-items:center}.footer-content{font-size:12px;color:var(--text-secondary);gap:8px}.footer-content a{color:var(--primary-color);transition:color .2s}.footer-content a:hover{color:var(--primary-hover)}.sidebar-widget{background:var(--bg-main);border:1px solid var(--border-color);margin-bottom:24px;padding:0}.widget-title{font-size:15px;font-weight:500;color:var(--text-primary);padding:14px 16px;margin:0;border-bottom:1px solid var(--border-color);background:var(--bg-sidebar)}.sidebar-widget>:not(.widget-title):not(.weather-header):not(.author-section):not(.home-stats-grid):not(.activity-columns):not(.weather-detail-grid):not(.calendar-info):not(.stats-list){padding:16px}.sidebar-widget>.activity-columns,.sidebar-widget>.home-stats-grid,.sidebar-widget>.weather-detail-grid{padding:0;width:100%}.sidebar-widget>.photo-info-content{padding:0}.author-widget{margin-bottom:20px}.author-widget .author-section{padding:16px}.author-main{display:grid;grid-template-columns:50% 1fr;grid-gap:16px;gap:16px;margin-bottom:16px;align-items:stretch}.author-photo{display:flex;width:100%;height:160px;border:1px solid var(--border-color);overflow:hidden;background:#f0f0f0;position:relative}.author-photo img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;object-position:center;display:block}.author-info-table{min-height:160px;display:flex;flex-direction:column;justify-content:flex-start}.author-info-table .info-row{display:flex;align-items:center;font-size:13px;padding:4px 0;border-bottom:1px solid #f5f5f5}.author-info-table .info-row:first-child{padding-top:0}.author-info-table .info-row:last-child{border-bottom:none}.author-info-table .info-label{color:var(--text-muted);width:84px;flex-shrink:0}.author-info-table .info-value{color:var(--text-primary);font-weight:500;flex:1 1}.author-bio{padding-top:16px;border-top:1px solid #e8e8e8;font-size:13px;line-height:1.8;display:flex;flex-direction:column;gap:8px}.bio-label{color:var(--text-muted);font-size:12px;font-weight:500}.bio-content{color:var(--text-secondary);line-height:1.8}.home-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:0;gap:0;background:transparent;border:none;width:100%}.home-stat-item{background:var(--bg-main);padding:22px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;border-right:1px solid var(--border-color);min-width:0}.home-stat-item:last-child{border-right:none}.home-stat-item .stat-icon{width:28px;height:28px;color:var(--primary-color)}.home-stat-value{font-size:18px;font-weight:600;color:var(--primary-color)}.home-stat-label{font-size:12px;color:var(--text-muted)}.activity-columns{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:0;gap:0;background:transparent;border:none;width:100%}.activity-column{display:flex;flex-direction:column;background:var(--bg-main);padding:18px;border-right:1px solid var(--border-color);min-width:0}.activity-column:last-child{border-right:none}.activity-column-header{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-secondary);font-weight:500;padding-bottom:10px;border-bottom:1px solid #f0f0f0;margin-bottom:8px}.activity-icon{width:16px;height:16px;color:var(--primary-color);flex-shrink:0}.activity-list{display:flex;flex-direction:column;gap:0;font-size:12px}.activity-item{color:var(--text-secondary);padding:6px 8px;border-bottom:1px solid #f5f5f5;transition:color .2s}.activity-item:hover{color:var(--primary-color)}.activity-item:last-child{border-bottom:none}.weather-header{padding:12px 16px;background:var(--bg-sidebar);border:none;margin-bottom:0}.weather-location-name{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-secondary);margin-bottom:8px}.location-pin{width:14px;height:14px;color:var(--primary-color)}.weather-main-display{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:6px}.weather-icon-svg{width:32px;height:32px;color:var(--primary-color)}.weather-temp{font-size:22px;font-weight:600;color:var(--primary-color)}.weather-desc{font-size:14px;color:var(--text-secondary)}.weather-update-info{font-size:11px;color:var(--text-muted);text-align:center}.weather-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:0;gap:0;background:transparent;border-top:none;width:100%}.weather-detail-item{background:var(--bg-main);padding:10px 16px;display:flex;justify-content:space-between;align-items:center;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);min-width:0}.weather-detail-item:first-child,.weather-detail-item:nth-child(2){border-top:1px solid var(--border-color)}.weather-detail-item:nth-child(2n){border-right:none}.weather-detail-item:nth-last-child(-n+2){border-bottom:none}.weather-detail-item .detail-label{font-size:12px;color:var(--text-muted)}.weather-detail-item .detail-value{font-size:12px;color:var(--text-primary);font-weight:500}.calendar-info{padding:8px 16px}.calendar-row{display:flex;justify-content:flex-start;align-items:center;padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:13px;gap:12px}.calendar-row:first-child{padding-top:0}.calendar-row:last-child{border-bottom:none;padding-bottom:0}.calendar-label{color:var(--text-muted);flex-shrink:0;min-width:50px}.calendar-value-split{display:flex;align-items:center;gap:16px;color:var(--text-primary)}.calendar-highlight{color:var(--primary-color);font-weight:500}.calendar-progress-wrap{display:flex;flex-direction:row;align-items:center;gap:12px;flex:1 1}.progress-info{display:flex;justify-content:space-between;align-items:center;font-size:13px}.progress-weeks{color:var(--text-primary);font-size:13px;flex-shrink:0}.progress-percent{color:var(--primary-color);font-weight:500;font-size:13px;white-space:nowrap;flex-shrink:0}.progress-bar{flex:1 1;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden;min-width:0}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),#5a8572);border-radius:3px;transition:width .3s ease}.mini-progress-bar{flex:1 1;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.mini-progress-fill{height:100%;background:var(--primary-color);transition:width .3s}.progress-weeks{font-size:12px;color:var(--text-secondary);white-space:nowrap}.stats-list{padding:8px 16px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.stat-row:first-child{padding-top:0}.stat-row:last-child{border-bottom:none;padding-bottom:0}.stat-label{font-size:13px;color:var(--text-secondary);flex-shrink:0;width:80px}.stat-value{font-size:12px;font-weight:500;color:var(--text-muted)}.stat-value[data-unit=articles]:after{content:" 篇"}.stat-value[data-unit=categories]:after{content:" 个"}.stat-value[data-unit=views]:after{content:" 次"}.stat-value[data-unit=monthly]:after{content:" 篇"}.stat-highlight{color:var(--primary-color);font-weight:600}@media screen and (max-width:1200px){.page-wrapper{width:100%;max-width:100%;box-shadow:none}.sidebar{left:0;margin-left:0;transform:translateX(-100%);transition:transform .3s ease}.sidebar.mobile-open{transform:translateX(0)}.mobile-menu-btn{display:flex}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:998}.sidebar-overlay.active{display:block}.top-bar{left:0;width:100%}.content-wrapper,.top-bar{margin-left:0}.content-main{flex-direction:column}.right-sidebar{width:100%}.top-bar-center{max-width:300px}}@media screen and (max-width:767px){body{background-color:#fff}.sidebar{left:0;margin-left:0;transform:translateX(-100%);z-index:999;transition:transform .3s ease;box-shadow:2px 0 8px rgba(0,0,0,.1)}.sidebar.mobile-open{transform:translateX(0)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:998}.sidebar-overlay.active{display:block}.mobile-menu-btn{display:flex}.top-bar{margin-left:0;padding:0 12px;height:56px;gap:8px;justify-content:space-between}.top-bar-center{display:none;flex:0 1}.top-bar-right{min-width:auto;justify-content:flex-end;margin-left:auto}.content-wrapper{margin-left:0;width:100%}.content-area{padding:0}.content-main{padding:16px;gap:16px}.sidebar-widget{margin-bottom:16px}.author-main{display:flex;flex-direction:column}.author-info-table{min-height:0}.author-photo{display:block;flex:0 0 auto;width:100%;height:160px}.author-photo img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;object-position:center}.home-stats-grid{grid-template-columns:repeat(2,1fr)}.activity-columns{grid-template-columns:1fr}.activity-column{border-right:none;border-bottom:1px solid var(--border-color)}.activity-column:last-child{border-bottom:none}.weather-detail-grid{grid-template-columns:repeat(2,1fr)}.weather-detail-item{border-right:1px solid var(--border-color)}.weather-detail-item:nth-child(2n){border-right:none}.weather-detail-item:nth-last-child(-n+2){border-bottom:none}.calendar-progress-wrap{flex-direction:column;gap:8px;align-items:stretch}.mini-progress-bar{order:2}.progress-weeks{order:1}}.toc-widget{position:relative}.toc-widget.sticky{position:fixed;top:80px;width:280px;z-index:100}.toc{display:flex;flex-direction:column;padding:8px}.toc-item{display:block;width:100%;padding:8px 12px;font-size:13px;color:#666;text-decoration:none;transition:all .2s;border-left:2px solid transparent;position:relative}.toc-item:hover{background:rgba(107,157,135,.05)}.toc-item.active,.toc-item:hover{color:#6b9d87;border-left-color:#6b9d87}.toc-item.active{background:rgba(107,157,135,.08);font-weight:500}.toc-parent{display:flex;justify-content:space-between;align-items:center}.toc-text{flex:1 1}.toc-toggle{font-size:10px;transition:transform .2s;color:#999;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toc-parent.collapsed .toc-toggle{transform:rotate(-90deg)}.toc-children{max-height:500px;overflow:hidden;transition:max-height .3s ease}.toc-children.collapsed{max-height:0}.toc-sub{padding-left:24px;font-size:12px}.category-section{margin-bottom:20px;position:relative}.category-tabs{display:flex;border:1px solid var(--border-color)}.category-tab{flex:1 1;padding:10px 0;font-size:14px;color:var(--text-secondary);cursor:pointer;transition:all .2s;background:var(--bg-main);border-right:1px solid var(--border-color);text-align:center;text-decoration:none}.category-tab:last-child{border-right:none}.category-tab:hover{color:var(--primary-color);background:rgba(107,157,135,.04)}.category-tab.active{color:#fff;background:var(--primary-color);font-weight:500}.subcategory-dropdown{position:absolute;top:100%;background:var(--bg-main);border:1px solid var(--border-color);border-top:none;box-shadow:0 4px 12px rgba(0,0,0,.08);z-index:10;display:flex;flex-direction:column;min-width:160px}.subcategory-item{padding:12px 20px;font-size:13px;color:var(--text-secondary);transition:all .2s;border-bottom:1px solid #f0f0f0;text-decoration:none}.subcategory-item:last-child{border-bottom:none}.subcategory-item:hover{background:rgba(107,157,135,.05);color:var(--primary-color)}.subcategory-item.active{background:rgba(107,157,135,.1);color:var(--primary-color);font-weight:500}.blog-list{display:flex;flex-direction:column;gap:16px}.blog-item{padding:18px 20px 12px;border:1px solid var(--border-color);background:var(--bg-main);transition:all .2s}.blog-item:hover{box-shadow:0 2px 8px rgba(0,0,0,.06);border-color:var(--border-dark)}.blog-item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}.blog-item-header .blog-title{flex:1 1;margin:0}.permission-badge-container{flex-shrink:0;display:flex}.permission-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;font-size:12px;border:1px solid;border-radius:4px;background:hsla(0,0%,100%,.8);font-weight:500}.permission-icon,.permission-label{font-size:12px;line-height:1}.blog-title{font-size:18px;font-weight:500;margin:0 0 12px}.blog-title a{color:var(--text-primary);transition:color .2s;text-decoration:none}.blog-title a:hover{color:var(--primary-color)}.blog-meta{display:flex;gap:16px;margin-bottom:12px;font-size:13px;color:var(--text-muted)}.meta-item{display:flex;align-items:center;gap:4px}.meta-item .icon{width:14px;height:14px;flex-shrink:0}.blog-excerpt{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0 0 8px;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.blog-tags{display:flex;gap:8px;flex-wrap:wrap}.tag{padding:3px 8px;font-size:12px;background:rgba(107,157,135,.08);color:var(--primary-color);transition:all .2s;border-radius:0;line-height:1.4}.tag:hover{background:rgba(107,157,135,.15)}.disk-table-container{overflow-x:auto;margin-bottom:24px;border:1px solid var(--border-color);background:var(--bg-main)}.disk-table{width:100%;border-collapse:collapse;table-layout:fixed}.disk-table thead{background:var(--bg-sidebar);border-bottom:2px solid var(--border-color)}.disk-table th{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.disk-table .col-name{width:40%;max-width:0}.disk-table .col-type{width:14%;max-width:0}.disk-table .col-permission{width:16%;max-width:0}.disk-table .col-size{width:15%;max-width:0}.disk-table .col-time{width:20%;max-width:0}.disk-table-row{border-bottom:1px solid var(--border-color);transition:background .2s}.disk-table-row:hover{background:var(--bg-sidebar)}.disk-table-row:last-child{border-bottom:none}.disk-table-row td{padding:12px 16px;font-size:14px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.disk-file-name{display:flex;align-items:center;gap:12px;min-width:0}.disk-file-icon{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.disk-file-icon .file-icon{width:24px;height:24px}.disk-file-link{color:var(--text-primary);text-decoration:none;transition:color .2s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1;min-width:0;display:inline-block}.disk-file-link:hover{color:var(--primary-color)}.disk-permission-cell{display:flex;align-items:center}.disk-permission-cell .permission-pill{margin:0}.disk-file-type{color:var(--text-secondary);font-size:13px}.disk-file-size,.disk-file-time{color:var(--text-muted);font-size:13px}.disk-empty{padding:60px 20px;text-align:center}.disk-detail-header,.disk-empty{border:1px solid var(--border-color);background:var(--bg-main)}.disk-detail-header{display:flex;align-items:flex-start;gap:20px;padding:24px;margin-bottom:24px}.disk-detail-icon{flex-shrink:0;width:64px;height:64px;display:flex;align-items:center;justify-content:center;color:var(--primary-color)}.disk-detail-icon .file-icon{width:56px;height:56px}.disk-detail-info{flex:1 1;min-width:0}.disk-detail-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 12px;word-break:break-all}.disk-detail-meta{display:flex;gap:20px;font-size:13px;color:var(--text-muted);flex-wrap:wrap}.disk-detail-meta .meta-item{display:flex;align-items:center;gap:6px}.disk-detail-meta .icon{width:14px;height:14px;flex-shrink:0}.disk-detail-actions{display:flex;gap:12px;flex-shrink:0}.disk-back-btn,.disk-download-btn{padding:8px 16px;font-size:14px;border:1px solid var(--border-color);background:var(--bg-main);color:var(--text-primary);cursor:pointer;transition:all .2s;text-decoration:none;display:flex;align-items:center;gap:6px;border-radius:0}.disk-download-btn{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.disk-download-btn:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.disk-back-btn:hover{background:var(--bg-sidebar);border-color:var(--border-dark)}.disk-back-btn .icon,.disk-download-btn .icon{width:16px;height:16px}.disk-preview-container{border:1px solid var(--border-color);background:var(--bg-main);margin-bottom:24px;min-height:400px}.preview-image-container{width:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:#f5f5f5;min-height:400px}.preview-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:4px;box-shadow:0 2px 12px rgba(0,0,0,.1)}.preview-video-container{width:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:#000;min-height:400px}.preview-video{max-width:100%;max-height:70vh;width:100%;height:auto}.preview-audio-container{width:100%;display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--bg-sidebar);min-height:200px}.preview-audio{width:100%;max-width:600px}.preview-pdf-container{width:100%;height:70vh;min-height:600px;background:#525252;position:relative}.preview-pdf{width:100%;height:100%;border:none}.preview-text-container{width:100%;height:70vh;min-height:400px}.preview-text{width:100%;height:100%;border:none;background:var(--bg-main)}.preview-office-container{width:100%;height:70vh;min-height:600px;background:var(--bg-main);position:relative}.preview-office{width:100%;height:100%;border:none}.preview-office-hint{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:rgba(107,157,135,.1);border-top:1px solid var(--border-color);font-size:12px;color:var(--text-secondary);text-align:center}.preview-not-available{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;background:var(--bg-sidebar);min-height:400px;text-align:center}.preview-message{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.preview-hint{font-size:14px;color:var(--text-muted)}.disk-action-btn{padding:10px 16px;font-size:14px;border:1px solid var(--border-color);background:var(--bg-main);color:var(--text-primary);cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:0}.disk-action-btn:hover{background:var(--bg-sidebar);border-color:var(--primary-color);color:var(--primary-color)}.disk-action-btn.disk-download-btn{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.disk-action-btn.disk-download-btn:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}.preview-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:10000;overflow-y:auto;padding:20px;box-sizing:border-box;animation:fadeIn .2s ease-in-out;min-height:100vh}.preview-modal-content{background:var(--bg-main);border-radius:8px;width:95%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,.3);animation:modalSlideIn .3s ease-out}.preview-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.preview-modal-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:16px}.preview-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary);background:none;border:none;cursor:pointer;border-radius:4px;transition:all .2s;flex-shrink:0}.preview-modal-close:hover{background:var(--bg-sidebar);color:var(--text-primary)}.preview-modal-body{flex:1 1;overflow:auto;min-height:0}.preview-modal-body .preview-audio-container,.preview-modal-body .preview-image-container,.preview-modal-body .preview-not-available,.preview-modal-body .preview-office-container,.preview-modal-body .preview-pdf-container,.preview-modal-body .preview-text-container,.preview-modal-body .preview-video-container{height:100%;min-height:500px}.preview-modal-body .preview-office-container,.preview-modal-body .preview-pdf-container,.preview-modal-body .preview-text-container{height:calc(90vh - 160px);min-height:500px}.preview-modal-body .preview-image-container,.preview-modal-body .preview-video-container{padding:40px;min-height:500px}.preview-modal-body .preview-audio-container{padding:60px 40px;min-height:300px}.preview-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color);flex-shrink:0}.preview-modal-footer .disk-action-btn{padding:8px 16px;font-size:14px}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:32px;padding-top:20px;border-top:1px solid var(--border-color)}.page-btn,.page-num{padding:6px 12px;font-size:13px;color:var(--text-secondary);border:1px solid var(--border-color);background:var(--bg-main);cursor:pointer;transition:all .2s;text-decoration:none;border-radius:0}.page-btn:hover:not(.disabled),.page-num:hover{background:#f5f5f5;border-color:var(--border-dark)}.page-num.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.page-btn.disabled,.page-btn:disabled{color:#ccc;cursor:not-allowed;background:#f9f9f9;opacity:.6}.page-btn:disabled:hover{background:#f9f9f9;border-color:var(--border-color)}.album-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px;margin-bottom:32px}.album-card{background:var(--bg-main);border:1px solid var(--border-color);transition:all .3s;cursor:pointer;overflow:hidden;text-decoration:none;display:block;color:inherit}.album-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px);border-color:var(--primary-color)}.album-cover{width:100%;height:150px;overflow:hidden;background:#f5f5f5;position:relative}.album-cover-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.album-card:hover .album-cover-img{transform:scale(1.05)}.album-placeholder{width:100%;height:100%;display:block}.album-card:hover .album-placeholder{transform:scale(1.05);transition:transform .3s}.album-info{padding:16px;display:flex;flex-direction:column;gap:6px}.album-info-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.album-title{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album-card .album-meta{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-muted)}.album-card .album-meta-primary{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.album-card .album-meta-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:rgba(107,157,135,.1);color:var(--text-secondary);border-radius:999px;font-size:12px;line-height:1.2}.album-card .album-meta .icon{font-size:12px;line-height:1}.album-card .album-meta-primary .permission-pill{background:rgba(107,157,135,.1);color:#2f6f52;gap:4px}.album-card .album-meta-primary .permission-pill.encrypted{background:rgba(250,173,20,.18);color:#d48806}.album-card .album-meta-primary .permission-pill.private{background:rgba(244,88,88,.18);color:#d4380d}.permission-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:500;line-height:1}.permission-pill .icon{font-size:12px}.permission-pill.public{background:rgba(107,157,135,.15);color:#2f6f52}.permission-pill.encrypted{background:rgba(250,173,20,.18);color:#d48806}.permission-pill.private{background:rgba(244,88,88,.18);color:#d4380d}.popular-list{padding:0 0 0 16px}.popular-item{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0;transition:background .2s;text-decoration:none;color:inherit}.popular-item:hover{background:rgba(107,157,135,.05)}.popular-item:last-child{border-bottom:none}.popular-rank{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;font-size:11px;font-weight:600;flex-shrink:0;margin-left:0}.popular-item:nth-child(2) .popular-rank{background:#7ea990}.popular-item:nth-child(3) .popular-rank{background:#91b59e}.popular-item:nth-child(n+4) .popular-rank{background:#a8c4b4}.popular-title{flex:1 1;margin-left:12px;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.popular-count{font-size:12px;color:var(--text-muted);margin-left:8px}.popular-count:after{content:" 次浏览"}.category-stats-list{padding:8px}.category-stat-item{display:flex;align-items:flex-start;gap:12px;padding:10px 8px;transition:background .2s;text-decoration:none;color:inherit}.category-stat-item:hover{background:rgba(107,157,135,.05)}.category-stat-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--text-muted);border:1px solid var(--border-color)}.category-stat-icon.top{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.category-stat-name{flex:1 1;font-size:13px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.category-stat-item:hover .category-stat-name{color:var(--primary-color)}.category-stat-count{font-size:12px;color:var(--text-muted);margin-left:auto;flex-shrink:0}.category-stat-count:after{content:" 个"}@media (max-width:1200px){.album-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.album-grid{grid-template-columns:1fr;gap:16px}.album-cover{height:200px}}.breadcrumb-nav{padding:16px 0;margin-bottom:20px}.breadcrumb-link{color:var(--text-secondary)}.breadcrumb-link:hover{color:var(--primary-color)}.breadcrumb-separator{color:var(--text-muted)}.breadcrumb-current{color:var(--text-primary)}.album-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.album-detail-title{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.album-description{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0 0 16px}.album-description p{margin:0}.album-meta{display:flex;gap:20px;font-size:13px;color:var(--text-secondary);flex-wrap:wrap}.album-meta .meta-item{display:flex;align-items:center;gap:6px}.album-meta .meta-item svg{color:var(--primary-color);flex-shrink:0}.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px;margin-bottom:32px}.album-empty-state{margin-top:32px;padding:64px 24px;text-align:center;background:var(--bg-main);border:1px dashed var(--border-color);border-radius:12px;color:var(--text-secondary)}.album-empty-icon{font-size:56px;margin-bottom:16px;color:var(--primary-color);opacity:.45}.album-empty-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.album-empty-description{font-size:14px;line-height:1.7;color:var(--text-secondary)}.album-empty-action{display:inline-flex;align-items:center;justify-content:center;margin-top:24px;padding:10px 20px;background:var(--primary-color);color:#fff;border-radius:999px;text-decoration:none;font-size:14px;transition:background .2s,transform .2s}.album-empty-action:hover{background:var(--primary-hover);transform:translateY(-2px)}.album-detail-actions{margin-top:40px;padding-top:20px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}.album-action-link{color:var(--primary-color);text-decoration:none;font-size:14px;transition:color .2s}.album-action-link:hover{color:var(--primary-hover)}.photo-item{overflow:hidden;cursor:pointer;border:2px solid var(--border-color);border-radius:8px;transition:all .3s;background:var(--bg-main);display:flex;flex-direction:column}.photo-item:hover{border-color:var(--primary-color);transform:translateY(-4px);box-shadow:0 8px 16px rgba(0,0,0,.1)}.photo-item.selected{border-color:var(--primary-color);box-shadow:0 4px 12px rgba(107,157,135,.3)}.photo-thumbnail{aspect-ratio:4/3;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center;position:relative;width:100%}.photo-thumbnail img{width:100%;height:100%;object-fit:cover}.photo-thumbnail svg{width:100%;height:100%;display:block}.photo-caption{padding:12px;background:var(--bg-main);border-top:1px solid #f0f0f0}.photo-location{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-primary);margin-bottom:4px}.photo-location svg{color:var(--primary-color);flex-shrink:0}.photo-date{font-size:12px;color:var(--text-muted)}.related-photos{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;padding:8px}.related-photo-item{cursor:pointer;aspect-ratio:1;overflow:hidden;border-radius:4px;transition:transform .2s}.related-photo-item:hover{transform:scale(1.05)}.related-photo-thumb{display:flex;align-items:center;justify-content:center}.related-photo-thumb,.related-photo-thumb svg{width:100%;height:100%}.photo-info-content{display:flex;flex-direction:column;background:var(--bg-main)}.photo-info-hint{padding:16px;font-size:13px;line-height:1.6;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.photo-detail-info{padding:12px 16px 0}.photo-detail-info .detail-row:first-child{padding-top:0}.photo-info-empty{padding:32px 16px;text-align:center;color:var(--text-muted);font-size:13px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0;font-size:13px;line-height:1.5}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-secondary);font-weight:500;white-space:nowrap;flex-shrink:0}.detail-value{color:var(--text-primary);text-align:right;flex:1 1;margin-left:12px}.detail-description{flex-direction:column;align-items:stretch;padding:12px 0}.detail-description .detail-label{margin-bottom:6px}.detail-description .detail-value{text-align:left;margin-left:0;color:var(--text-secondary);line-height:1.8}.view-large-btn{width:calc(100% - 32px);padding:10px;margin:16px;background:var(--primary-color);color:#fff;border:none;font-size:14px;cursor:pointer;transition:background .2s;border-radius:4px}.view-large-btn:hover{background:var(--primary-hover)}.image-viewer{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.95);z-index:9999}.image-viewer,.image-viewer #viewerImage{display:flex;align-items:center;justify-content:center}.image-viewer #viewerImage{margin-right:380px;max-width:calc(100% - 380px - 100px);position:relative;padding-bottom:0;overflow:hidden;cursor:zoom-in}.image-viewer #viewerImage img{max-width:100%;max-height:calc(80vh - 140px);object-fit:contain;transition:transform .25s ease}.image-viewer #viewerImage.zoomed{cursor:zoom-out}.image-viewer #viewerImage.zoomed img{transform:scale(1.5)}.viewer-close{position:absolute;top:20px;right:420px;font-size:40px;color:#fff;background:none;border:none;cursor:pointer;z-index:10002;width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:all .2s}.viewer-close:hover{background:hsla(0,0%,100%,.1);border-radius:50%}.viewer-next,.viewer-prev{background:hsla(0,0%,100%,.14);color:#fff;border:none;cursor:pointer;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:34px;transition:background .2s,transform .2s}.viewer-next:hover,.viewer-prev:hover{background:hsla(0,0%,100%,.25);transform:translateY(-2px)}.viewer-controls{position:fixed;bottom:40px;left:calc((100% - 380px) / 2);transform:translateX(-50%);display:flex;align-items:center;justify-content:center;gap:20px;background:rgba(0,0,0,.68);padding:14px 22px;border-radius:999px;box-shadow:0 6px 24px rgba(0,0,0,.35);z-index:10002;cursor:default}.viewer-controls-divider{width:1px;height:30px;background:hsla(0,0%,100%,.25)}.viewer-controls-status{font-size:14px;color:#fff;letter-spacing:.35px}.viewer-controls button{font-size:30px;width:48px;height:48px;border-radius:50%;border:none;background:hsla(0,0%,100%,.18);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}.viewer-controls button:hover{background:hsla(0,0%,100%,.32);transform:translateY(-2px)}.viewer-info{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:#fff;font-size:16px;text-align:center;background:rgba(0,0,0,.5);padding:12px 24px;border-radius:4px}.viewer-info>div:first-child{margin-bottom:8px;font-weight:500}.viewer-info>div:last-child{font-size:14px;color:#ccc}.viewer-details{position:fixed;top:0;right:0;width:380px;height:100%;background:rgba(0,0,0,.92);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:80px 30px 30px;overflow-y:auto;overflow-x:hidden;border-left:1px solid hsla(0,0%,100%,.1);z-index:10001;scrollbar-width:none;-ms-overflow-style:none}.viewer-details::-webkit-scrollbar{display:none}.viewer-details-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid hsla(0,0%,100%,.15)}.viewer-title{font-size:18px;font-weight:600;color:#fff;letter-spacing:.5px;margin-bottom:8px}.viewer-counter{font-size:13px;color:#aaa;background:hsla(0,0%,100%,.1);padding:6px 14px;border-radius:16px;font-weight:500;display:inline-block}.viewer-details-content{display:flex;flex-direction:column;gap:20px;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.viewer-details-content::-webkit-scrollbar{display:none}.viewer-details .comment-section{margin-top:32px;padding-top:24px;border-top:1px solid hsla(0,0%,100%,.15)}.viewer-details .comment-list{max-height:400px;overflow-y:auto;overflow-x:hidden;margin-bottom:20px;padding-right:8px;scrollbar-width:none;-ms-overflow-style:none}.viewer-details .comment-list::-webkit-scrollbar{display:none}.viewer-details .comment-item{border-bottom:1px solid hsla(0,0%,100%,.1);padding-bottom:16px;margin-bottom:16px}.viewer-details .comment-item:last-child{border-bottom:none;padding-bottom:0}.viewer-details .comment-author{color:#fff}.viewer-details .comment-text{color:hsla(0,0%,100%,.9)}.viewer-details .comment-meta{color:hsla(0,0%,100%,.6)}.viewer-details .comment-action-btn{color:hsla(0,0%,100%,.7)}.viewer-details .comment-like-btn,.viewer-details .comment-reply-toggle{color:#6b9d87}.viewer-details .comment-form{background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;padding:16px}.viewer-details .form-title{color:#fff}.viewer-details .form-input,.viewer-details .form-textarea{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);color:#fff;border-radius:6px}.viewer-details .form-input:focus,.viewer-details .form-textarea:focus{background:hsla(0,0%,100%,.15);border-color:hsla(0,0%,100%,.3);outline:none}.viewer-details .form-input::placeholder,.viewer-details .form-textarea::placeholder{color:hsla(0,0%,100%,.5);opacity:1}.viewer-detail-item{display:flex;flex-direction:row;align-items:flex-start;gap:12px}.viewer-detail-item svg{flex-shrink:0;opacity:.8;color:var(--primary-color);margin-top:2px}.viewer-detail-item .detail-label{color:#999;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:8px;white-space:nowrap;min-width:80px}.viewer-detail-item .detail-value{color:#fff;font-size:14px;line-height:1.6;flex:1 1}.viewer-detail-description{flex-direction:column}.viewer-detail-description .detail-label{margin-bottom:6px}.viewer-detail-description .detail-value{line-height:1.8;color:#e0e0e0}.photo-info-widget{position:-webkit-sticky;position:sticky;top:80px}.photo-info-tip{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:13px}@media (max-width:1024px){.photo-grid{grid-template-columns:repeat(3,1fr);gap:12px}.viewer-details{width:320px;padding:70px 20px 20px}.image-viewer #viewerImage{margin-right:320px;max-width:calc(100% - 320px - 80px)}.image-viewer #viewerImage img{max-height:calc(75vh - 130px)}.viewer-controls{left:50%}.viewer-close,.viewer-next{right:360px}}@media (max-width:768px){.photo-grid{grid-template-columns:repeat(2,1fr);gap:10px}.viewer-details{position:absolute;bottom:0;top:auto;left:0;right:0;width:100%;height:auto;max-height:45vh;padding:20px;border-left:none;border-top:1px solid hsla(0,0%,100%,.1)}.viewer-details-content{gap:16px}.viewer-detail-item{gap:6px}.viewer-detail-item .detail-label{font-size:11px}.viewer-detail-item .detail-value{font-size:13px}.viewer-title{font-size:16px}.viewer-counter{font-size:12px;padding:4px 10px}.image-viewer #viewerImage{margin-right:0;max-width:90vw}.image-viewer #viewerImage,.image-viewer #viewerImage img{max-height:calc(65vh - 110px)}.viewer-close,.viewer-next{right:30px}.viewer-controls{left:50%;bottom:28px}}.page-ellipsis{color:var(--text-muted);padding:0 4px}.hot-list{padding:8px}.hot-item{display:flex;align-items:flex-start;gap:12px;padding:10px 8px;transition:background .2s;text-decoration:none;color:inherit}.hot-item:hover{background:rgba(107,157,135,.05)}.hot-rank{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;color:var(--text-muted);border:1px solid var(--border-color)}.hot-rank.top{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.hot-title{flex:1 1;font-size:13px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hot-item:hover .hot-title{color:var(--primary-color)}.tag-cloud{padding:16px;display:flex;flex-wrap:wrap;gap:10px}.cloud-tag{padding:4px 12px;background:rgba(107,157,135,.08);color:var(--primary-color);transition:all .2s;text-decoration:none;border-radius:0}.cloud-tag:hover{background:rgba(107,157,135,.15);transform:translateY(-1px)}.breadcrumb-nav{padding:12px 0 8px;margin-bottom:8px;font-size:13px;color:var(--text-secondary)}.breadcrumb-link{color:var(--primary-color);transition:color .2s;text-decoration:none}.breadcrumb-link:hover{color:var(--primary-hover)}.breadcrumb-separator{margin:0 8px;color:#ccc}.breadcrumb-current{color:var(--text-muted)}.article,.article-header{background:var(--bg-main)}.article-header{padding:24px;border:1px solid rgba(107,157,135,.2);border-radius:0;margin-bottom:24px;box-shadow:0 1px 3px rgba(107,157,135,.08)}.article-title{font-size:28px;font-weight:600;color:var(--text-primary);line-height:1.4;margin:0 0 16px;padding-bottom:16px;border-bottom:1px solid rgba(107,157,135,.2)}.article-meta{display:flex;gap:20px;font-size:13px;color:var(--text-muted);flex-wrap:wrap;margin-bottom:0}.article-meta .meta-item{display:flex;align-items:center;gap:4px}.article-meta .icon{width:14px;height:14px;flex-shrink:0}.article-content{padding:22px 24px 20px;border:1px solid rgba(107,157,135,.2);border-radius:0;background:var(--bg-main);font-size:15px;line-height:1.8;color:var(--text-primary);margin-bottom:8px;box-shadow:0 1px 3px rgba(107,157,135,.08)}.article-content h1{font-size:24px;font-weight:600;margin:32px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--border-color);color:var(--text-primary)}.article-content h1:first-child{margin-top:0}.article-content h2{font-size:22px;font-weight:600;margin:32px 0 16px;padding-bottom:0;color:var(--text-primary)}.article-content h2:first-child{margin-top:0}.article-content h3{font-size:18px;font-weight:600;margin:24px 0 12px;color:var(--text-primary)}.article-content p{margin:12px 0;text-align:justify}.article-content ol,.article-content ul{margin:12px 0;padding-left:24px}.article-content li{margin:8px 0}.article-content strong{font-weight:600;color:var(--text-primary)}.article-content code{padding:2px 6px;background:rgba(107,157,135,.08);color:var(--primary-color);font-family:Consolas,Monaco,monospace;font-size:14px}.article-content blockquote{margin:16px 0;padding:12px 16px;border-left:3px solid var(--primary-color);background:var(--bg-sidebar);color:var(--text-secondary)}.article-tags{display:flex;gap:8px;padding:8px 0 12px;border-top:none;margin:0}.article-tags .tag{padding:2px 6px!important;font-size:10px!important;line-height:1.3!important;font-weight:400!important;background:rgba(107,157,135,.08)!important}.article-navigation{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;margin-top:12px;padding-top:12px;margin-bottom:12px;border-top:1px solid var(--border-color)}.nav-next,.nav-prev{padding:14px 16px;border:1px solid rgba(107,157,135,.2);background:var(--bg-main);cursor:pointer;transition:all .3s;position:relative;text-decoration:none;display:block;color:inherit}.nav-next:hover,.nav-prev:hover{border-color:var(--primary-color);background:rgba(107,157,135,.04);transform:translateY(-2px);box-shadow:0 4px 12px rgba(107,157,135,.15)}.nav-prev{text-align:left}.nav-next{text-align:right}.nav-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;display:flex;align-items:center;gap:4px}.nav-prev .nav-label{justify-content:flex-start}.nav-next .nav-label{justify-content:flex-end}.nav-prev .nav-label:before{content:"←";font-size:14px}.nav-next .nav-label:after{content:"→";font-size:14px}.nav-next .nav-title{text-align:right}.nav-title{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4}.nav-next:hover .nav-title,.nav-prev:hover .nav-title{color:var(--primary-color)}.nav-next.disabled,.nav-prev.disabled{cursor:not-allowed;opacity:.5}.nav-next.disabled:hover,.nav-prev.disabled:hover{transform:none;border-color:rgba(107,157,135,.2);background:var(--bg-main);box-shadow:none}.related-list{padding:8px 16px}.related-item{display:block;padding:8px 0;transition:background .2s;text-decoration:none;color:inherit;border-bottom:1px solid #f0f0f0}.related-item:first-child{padding-top:0}.related-item:last-child{border-bottom:none;padding-bottom:0}.related-item:hover{background:transparent}.related-title{display:block;font-size:13px;color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.related-item:hover .related-title{color:var(--primary-color)}.comment-section{margin-top:12px;padding-top:28px;border-top:2px solid var(--border-color)}.comment-title{font-size:20px;font-weight:600;margin:0 0 24px;color:var(--text-primary)}.comment-count{font-size:16px;color:var(--text-muted);font-weight:400}.comment-list{display:flex;flex-direction:column;gap:18px;margin-bottom:32px}.comment-item{display:grid;grid-template-columns:42px 1fr 110px;grid-gap:12px;gap:12px;padding-bottom:20px;border-bottom:1px solid rgba(15,23,42,.08)}.comment-item.comment-root{background:transparent}.comment-item.comment-reply{background:rgba(107,157,135,.06);border-radius:8px;padding:16px;grid-template-columns:38px 1fr 90px;border-bottom:none;margin-bottom:14px}.comment-item:last-child{border-bottom:none;padding-bottom:0}.comment-avatar{width:42px;height:42px;border-radius:50%;background:rgba(107,157,135,.15);border:1px solid rgba(107,157,135,.3);display:flex;align-items:center;justify-content:center;color:var(--primary-color);font-size:18px}.comment-avatar svg{width:100%;height:100%;display:block}.comment-content{min-width:0}.comment-header{display:grid;grid-template-columns:minmax(0,max-content) minmax(0,max-content) auto;align-items:baseline;grid-gap:8px;gap:8px;margin-bottom:4px}.comment-author{font-size:14px;font-weight:600;color:var(--text-primary)}.comment-website{font-size:12px;color:var(--primary-color);text-decoration:none;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-website:hover{text-decoration:underline}.comment-time{font-size:12px;color:var(--text-muted);justify-self:end}.comment-badge{padding:2px 8px;font-size:11px;border-radius:999px;background:var(--primary-color);color:#fff;letter-spacing:.5px}.comment-text{font-size:14px;color:var(--text-secondary);line-height:1.7;margin:2px 0 8px;word-break:break-word}.comment-actions{display:flex;align-items:center;gap:16px;font-size:12px;color:var(--text-muted)}.comment-action-btn{display:inline-flex;align-items:center;gap:6px;font-size:inherit;color:inherit;padding:0;background:none;border:none;cursor:pointer;transition:color .2s ease,transform .2s ease}.comment-action-btn:hover{color:var(--primary-color);transform:translateY(-1px)}.comment-action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.comment-action-btn.comment-like-btn{color:var(--primary-color);font-weight:500}.comment-action-btn.comment-like-btn:hover{color:#2e7d32}.comment-reply-toggle{color:var(--primary-color);font-weight:500}.comment-reply-toggle:hover{color:#2e7d32}.comment-meta{display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;font-size:12px;color:var(--text-muted);line-height:1.6;gap:8px}.comment-meta span{display:block;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.comment-replies{grid-column:2/span 2;margin-left:24px;padding-left:16px;border-left:1px solid rgba(107,157,135,.25);display:flex;flex-direction:column;gap:16px}.comment-replies .comment-item:last-child{margin-bottom:0}.comment-replies .comment-item{border-bottom:none;padding-bottom:0}.comment-form{padding:24px;background:var(--bg-sidebar);border:1px solid var(--border-color)}.form-title{font-size:16px;font-weight:500;margin:0 0 16px;color:var(--text-primary)}.form-row{display:flex;gap:12px;margin-bottom:12px}.form-row .form-group{flex:1 1;margin-bottom:0}.form-group{margin-bottom:12px}.form-input,.form-textarea{width:100%;padding:12px 16px;font-size:14px;border:1px solid var(--border-color);background:var(--bg-main);color:var(--text-primary);transition:border-color .2s;font-family:var(--font-family);border-radius:0}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color)}.form-textarea{resize:vertical;min-height:120px}.form-actions{margin-top:16px}.submit-btn{padding:12px 24px;font-size:14px;color:#fff;background:var(--primary-color);border:none;cursor:pointer;transition:all .2s;border-radius:0}.submit-btn:hover{background:var(--primary-hover)}.navigation-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px;margin-bottom:32px}.navigation-card{background:var(--bg-main);border:1px solid var(--border-color);transition:box-shadow .3s,border-color .3s,transform .3s;cursor:pointer;overflow:hidden;text-decoration:none;display:flex;flex-direction:column;color:inherit;padding:18px;min-height:90px;box-sizing:border-box;contain:layout style}.navigation-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.1);border-color:var(--primary-color);transform:translateY(-2px)}.navigation-card-top{display:flex;flex-direction:row;align-items:flex-start;gap:16px;flex:1 1}.nav-card-icon{width:60px;height:60px;min-width:60px;display:flex;align-items:center;justify-content:center;background:rgba(107,157,135,.08);border-radius:8px;font-size:30px;flex-shrink:0;overflow:hidden;position:relative}.nav-card-icon img.favicon-image{width:100%;height:100%;object-fit:contain;position:absolute;top:0;left:0;opacity:0;transition:opacity .2s ease-in-out;aspect-ratio:1;background-color:transparent;contain:layout style paint}.nav-card-icon .icon-placeholder{font-size:30px;display:block;z-index:1;position:relative}.nav-card-icon .favicon-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;opacity:.5;z-index:2}.nav-card-icon .fallback-icon{font-size:30px}.nav-card-info{flex:1 1;display:flex;flex-direction:column;gap:8px;min-width:0;justify-content:flex-start}.nav-card-name{font-size:16px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:1;-webkit-line-clamp:1;-webkit-box-orient:vertical;line-height:1.5;margin:0 0 2px}.navigation-card:hover .nav-card-name{color:var(--primary-color)}.nav-card-desc{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.7;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:0 0 auto;min-height:2.4em;word-break:break-word}.nav-card-url{font-size:12px;color:var(--text-muted);margin-top:10px;padding-top:10px;border-top:1px solid rgba(107,157,135,.1);width:100%;text-align:center;display:flex;align-items:center;justify-content:center;gap:6px;flex-shrink:0;overflow:hidden;word-break:break-all;white-space:normal;line-height:1.5}.nav-card-url:before{content:"";display:inline-block;width:12px;height:12px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%23999' d='M8.636 3.5a.5.5 0 0 0-.5-.5H1.5A1.5 1.5 0 0 0 0 4.5v10A1.5 1.5 0 0 0 1.5 16h10a1.5 1.5 0 0 0 1.5-1.5V7.864a.5.5 0 0 0-1 0V14.5a.5.5 0 0 1-.5.5h-10a.5.5 0 0 1-.5-.5v-10a.5.5 0 0 1 .5-.5h6.636a.5.5 0 0 0 .5-.5z'/%3E%3Cpath fill='%23999' d='M16 .5a.5.5 0 0 0-.5-.5h-5a.5.5 0 0 0 0 1h3.793L6.146 9.146a.5.5 0 1 0 .708.708L15 1.707V5.5a.5.5 0 0 0 1 0v-5z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;opacity:.6;flex-shrink:0}@media (max-width:1200px){.navigation-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.navigation-grid{grid-template-columns:1fr;gap:16px}.navigation-card{padding:14px;min-height:85px}.navigation-card-top{gap:12px}.nav-card-icon{width:52px;height:52px;min-width:52px;font-size:26px}.nav-card-icon .fallback-icon{font-size:26px}.nav-card-info{gap:6px}.nav-card-desc{font-size:13px;line-height:1.6;line-clamp:2;-webkit-line-clamp:2;min-height:2.1em}.nav-card-url{margin-top:8px;padding-top:8px;font-size:11px}}.password-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;overflow-y:auto;padding:20px;box-sizing:border-box;min-height:100vh}.password-modal-content{background:var(--bg-main);border-radius:8px;width:90%;max-width:400px;box-shadow:0 4px 20px rgba(0,0,0,.3)}.password-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color)}.password-modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.password-modal-close{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-modal-close:hover{color:var(--text-primary)}.password-modal-body{padding:20px}.password-input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--bg-main);color:var(--text-primary);transition:border-color .2s}.password-input:focus{outline:none;border-color:var(--primary-color)}.password-error{margin-top:12px;color:#e74c3c;font-size:13px}.password-modal-footer{display:flex;gap:12px;padding:20px;border-top:1px solid var(--border-color);justify-content:flex-end}.password-btn-cancel,.password-btn-submit{padding:10px 20px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s;border:none}.password-btn-cancel{background:var(--bg-sidebar);color:var(--text-primary)}.password-btn-cancel:hover{background:var(--border-color)}.password-btn-submit{background:var(--primary-color);color:#fff}.password-btn-submit:hover{background:var(--primary-hover)}.page-title{font-size:28px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.page-description{font-size:14px;color:var(--text-muted);margin:0 0 32px}.archive-timeline{position:relative;padding-left:40px}.archive-timeline:before{content:"";position:absolute;left:32px;top:0;bottom:0;width:2px;background:var(--border-color)}.archive-year-group{margin-bottom:48px;position:relative}.archive-year-group:last-child{margin-bottom:0}.archive-year-header{display:flex;align-items:baseline;gap:8px;margin-bottom:20px;position:relative;padding-left:20px}.archive-year-header:before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;background:var(--primary-color);border:3px solid var(--bg-main);box-shadow:0 0 0 2px var(--primary-color);z-index:1}.archive-year{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.archive-year-count{font-size:14px;color:var(--text-muted);font-weight:400}.archive-items{display:flex;flex-direction:column;gap:12px;padding-left:20px}.archive-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--bg-main);border:1px solid var(--border-color);border-radius:8px;text-decoration:none;color:inherit;transition:all .2s;position:relative}.archive-item:before{content:"";position:absolute;left:-32px;top:24px;width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:background .2s}.archive-item:hover{border-color:var(--primary-color);box-shadow:0 2px 8px rgba(107,157,135,.1);transform:translateX(4px)}.archive-item:hover:before{background:var(--primary-color)}.archive-item-icon{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:rgba(107,157,135,.08);border-radius:6px;color:var(--primary-color);flex-shrink:0}.archive-item-content{flex:1 1;min-width:0}.archive-item-header{display:flex;align-items:center;gap:12px;margin-bottom:6px}.archive-item-type{font-size:12px;color:var(--primary-color);background:rgba(107,157,135,.1);padding:2px 8px;border-radius:4px;font-weight:500}.archive-item-date{font-size:13px;color:var(--text-muted)}.archive-item-title{font-size:16px;font-weight:500;color:var(--text-primary);margin:0 0 6px;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical}.archive-item:hover .archive-item-title{color:var(--primary-color)}.archive-item-category{font-size:12px;color:var(--text-muted);display:inline-block}.archive-item-arrow{width:24px;height:24px;min-width:24px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .2s;flex-shrink:0}.archive-item:hover .archive-item-arrow{color:var(--primary-color);transform:translateX(4px)}.year-nav-list{display:flex;flex-direction:column;gap:6px}.year-nav-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:transparent;border:1px solid var(--border-color);border-radius:6px;font-size:14px;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left}.year-nav-item:hover{background:rgba(107,157,135,.05)}.year-nav-item.active,.year-nav-item:hover{border-color:var(--primary-color);color:var(--primary-color)}.year-nav-item.active{background:rgba(107,157,135,.1);font-weight:500}.year-nav-count{font-size:12px;color:var(--text-muted);margin-left:auto}.year-nav-item.active .year-nav-count{color:var(--primary-color)}.latest-list{display:flex;flex-direction:column;gap:0}.latest-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-color);text-decoration:none;color:inherit;transition:all .2s}.latest-item:last-child{border-bottom:none}.latest-item:hover{padding-left:4px}.latest-item-icon{width:20px;height:20px;min-width:20px;display:flex;align-items:center;justify-content:center;color:var(--primary-color);margin-top:2px;flex-shrink:0}.latest-item-title{flex:1 1;font-size:13px;color:var(--text-primary);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-width:0}.latest-item:hover .latest-item-title{color:var(--primary-color)}.latest-item-date{font-size:12px;color:var(--text-muted);margin-left:auto;flex-shrink:0;white-space:nowrap}@media (max-width:768px){.archive-timeline{padding-left:30px}.archive-year-header:before{left:-22px;width:12px;height:12px}.archive-item:before{left:-18px;width:6px;height:6px}.archive-item{padding:12px}.archive-item-icon{width:32px;height:32px;min-width:32px}.year-nav-item{padding:8px 10px;font-size:13px}.latest-item-date{display:none}}