:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{overflow-x:clip}@supports not (overflow: clip){html{overflow-x:hidden}}html[data-theme=light]{--sidebar-width: 220px;--bg: #f0f2f5;--surface: #ffffff;--surface-hover: #f8fafc;--text: #333333;--text-sub: #666666;--border: #e5e7eb;--shadow: 0 10px 25px rgba(0, 0, 0, .08);--shadow-hover: 0 14px 35px rgba(0, 0, 0, .12);--primary: #3b82f6;--primary-soft: rgba(59, 130, 246, .12);--backdrop: rgba(15, 23, 42, .5)}html[data-theme=dark]{--sidebar-width: 220px;--bg: #111827;--surface: #1f2937;--surface-hover: #243244;--text: #f3f4f6;--text-sub: #9ca3af;--border: #374151;--shadow: 0 10px 25px rgba(0, 0, 0, .35);--shadow-hover: 0 14px 35px rgba(0, 0, 0, .45);--primary: #3b82f6;--primary-soft: rgba(59, 130, 246, .22);--backdrop: rgba(0, 0, 0, .55)}body{margin:0;min-width:320px;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}*{box-sizing:border-box}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;min-height:100svh;display:flex;background:var(--bg)}.app-shell--with-sidebar{padding-left:var(--sidebar-width)}.app-shell--sidebar-hidden{padding-left:0}.sidebar{width:var(--sidebar-width);flex:0 0 var(--sidebar-width);padding:16px 14px 10px;border-right:1px solid var(--border);background:color-mix(in srgb,var(--surface) 90%,transparent);position:fixed;left:0;top:0;height:100vh;height:100svh;display:flex;flex-direction:column;overflow:hidden;border-radius:0;z-index:25;will-change:transform;transition:transform .18s ease}.sidebar-header{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:10px;margin-bottom:14px;text-align:left}.sidebar-avatar{width:54px;height:54px;flex:0 0 54px;border-radius:999px;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);box-shadow:var(--shadow);background:color-mix(in srgb,var(--surface) 92%,transparent);object-fit:cover}.sidebar-brand{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0;flex:1}.sidebar-title{font-weight:900;letter-spacing:.2px;font-size:18px;line-height:1.1;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-subtitle{font-size:12px;color:var(--text-sub)}.sidebar-list{display:flex;flex-direction:column;gap:10px;flex:1;overflow:auto;padding-bottom:10px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.sidebar-group{display:flex;flex-direction:column;gap:4px}.sidebar-group-title{padding:6px 10px 2px;font-size:11px;letter-spacing:.6px;color:var(--text-sub)}.sidebar-bottom{display:flex;flex-direction:column;gap:10px;padding-top:10px}.sidebar-footer{padding-top:10px;border-top:1px solid color-mix(in srgb,var(--border) 70%,transparent);font-size:12px;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:clip}@media(max-width:980px){.sidebar-footer-commit{display:none}}.sidebar-footer a{color:inherit}.sidebar-footer a:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px;border-radius:6px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:10px;border:1px solid transparent;color:var(--text);background:transparent;cursor:pointer;text-align:left;font-size:13px;line-height:1.2}.sidebar-hide-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--border) 70%,transparent);background:color-mix(in srgb,var(--surface) 94%,transparent);color:var(--text-sub);cursor:pointer}.sidebar-hide-btn svg{width:18px;height:18px}.sidebar-hide-btn:hover{border-color:color-mix(in srgb,var(--primary) 22%,var(--border));background:var(--surface-hover);color:var(--text)}.sidebar-hide-btn:active{transform:translateY(1px)}.sidebar-hide-btn:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px}.sidebar-item:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px}.sidebar-item:hover{background:var(--primary-soft)}.sidebar-item:active{transform:translateY(1px)}.sidebar-item.is-active{background:var(--primary-soft);border-color:color-mix(in srgb,var(--primary) 35%,var(--border))}.category-icon{width:18px;flex:0 0 18px;display:inline-flex;align-items:center;justify-content:center;opacity:.9}.main{flex:1;min-width:0}.admin-auth{display:grid;place-items:center;padding:24px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 72%,transparent),transparent)}.admin-auth-inner{width:min(440px,100%);display:flex;flex-direction:column;gap:14px}.admin-auth-header{text-align:center}.admin-auth-title{margin:0;font-size:18px;font-weight:900;letter-spacing:.2px}.admin-auth-sub{margin:8px 0 0;color:var(--text-sub)}.admin-auth-card{width:100%}.admin-password-row{position:relative;display:flex;align-items:stretch}.admin-password-row>input{flex:1;padding-right:44px}.admin-password-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:12px;border:1px solid color-mix(in srgb,var(--border) 75%,transparent);background:color-mix(in srgb,var(--surface) 92%,transparent);cursor:pointer}.admin-password-toggle:hover{background:var(--surface-hover);border-color:color-mix(in srgb,var(--primary) 18%,var(--border))}.admin-password-toggle:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px}.banner{padding:26px 22px 18px;background:linear-gradient(180deg,color-mix(in srgb,var(--surface) 82%,transparent),transparent);border-bottom:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.banner-row{display:flex;align-items:stretch;gap:16px;justify-content:space-between}.banner-left{display:flex;flex-direction:column;gap:12px;align-items:flex-start;flex:1;min-width:280px}.banner-title{font-size:22px;font-weight:800;margin:0}.banner-tools{display:flex;gap:8px;align-items:stretch;justify-content:flex-end;align-self:stretch}.banner-time{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1.1;padding:10px 16px;min-width:240px;border-radius:16px;border:1px solid color-mix(in srgb,var(--border) 75%,transparent);background:color-mix(in srgb,var(--surface) 92%,transparent)}.banner-time-main{font-size:30px;font-weight:900;letter-spacing:.2px}.banner-time-sub{font-size:16px;color:var(--text-sub);margin-top:6px}.icon-btn{height:36px;padding:0 10px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}.icon-btn:hover{border-color:color-mix(in srgb,var(--primary) 40%,var(--border));background:var(--surface-hover)}.icon-btn:active{transform:translateY(1px)}.icon-btn:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px}.search{margin-top:0;position:relative;width:min(520px,100%)}.search-input{width:100%;border-radius:999px;border:1px solid var(--border);padding:12px 14px 12px 44px;background:var(--surface);color:var(--text);outline:none}.search-input:focus{border-color:color-mix(in srgb,var(--primary) 55%,var(--border));box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 25%,transparent)}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-sub)}.content{position:relative;padding:18px 22px 90px}.content:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.1;background-image:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--text) 18%,transparent) 1px,transparent 1px),radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--primary) 12%,transparent) 1px,transparent 1px);background-size:18px 18px,42px 42px;background-position:0 0,9px 13px}.section-block+.section-block{margin-top:18px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--border) 65%,transparent)}.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin:0 0 16px}.section-title h2{margin:0;font-size:16px;font-weight:800;color:color-mix(in srgb,var(--text) 82%,var(--text-sub));display:flex;align-items:center;gap:8px}.section-title h2:before{content:"";width:4px;height:14px;border-radius:999px;background:color-mix(in srgb,var(--primary) 75%,var(--border));flex:0 0 4px}.section-title span{color:var(--text-sub);font-size:12px}.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.card{display:flex;gap:12px;padding:14px;border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:var(--surface-hover)}.card:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:3px}.card:active{transform:translateY(0)}.card-icon{width:38px;height:38px;border-radius:10px;border:1px solid color-mix(in srgb,var(--border) 80%,transparent);background:color-mix(in srgb,var(--surface) 88%,transparent);display:grid;place-items:center;overflow:hidden;flex:0 0 38px}.card-icon img{width:24px;height:24px;object-fit:contain}.card-body{min-width:0;display:flex;flex-direction:column;gap:4px}.card-title{font-weight:800;font-size:14px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-desc{margin:0;font-size:12px;color:var(--text-sub);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{margin:0;font-size:12px;color:var(--text-sub)}.fab{position:fixed;right:max(18px,env(safe-area-inset-right));bottom:max(18px,env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:10px;z-index:20}.fab-btn{width:46px;height:46px;border-radius:999px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);cursor:pointer;display:grid;place-items:center;color:var(--text);position:relative;transition:transform .12s ease,border-color .12s ease,background .12s ease}.fab-btn:hover{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:var(--surface-hover)}.fab-btn.is-active{border-color:color-mix(in srgb,var(--primary) 80%,var(--border));background:radial-gradient(circle at 50% 45%,color-mix(in srgb,var(--primary) 24%,transparent),color-mix(in srgb,var(--primary) 8%,var(--surface)) 58%,var(--surface));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--primary) 35%,transparent),inset 0 0 18px color-mix(in srgb,var(--primary) 28%,transparent),0 0 0 2px color-mix(in srgb,var(--primary) 32%,transparent),var(--shadow)}.fab-btn:active{transform:translateY(1px)}.fab-btn:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:3px}.fab-btn svg{width:20px;height:20px}.fab-btn[data-tooltip]:after{content:attr(data-tooltip);position:absolute;right:56px;top:50%;transform:translateY(-50%) translate(6px);opacity:0;pointer-events:none;white-space:nowrap;font-size:12px;padding:8px 10px;border-radius:12px;border:1px solid color-mix(in srgb,var(--border) 75%,transparent);background:color-mix(in srgb,var(--surface) 92%,transparent);color:var(--text);box-shadow:var(--shadow);transition:opacity .12s ease,transform .12s ease}.fab-btn[data-tooltip]:before{content:"";position:absolute;right:48px;top:50%;transform:translateY(-50%) translate(6px);opacity:0;pointer-events:none;width:10px;height:10px;background:color-mix(in srgb,var(--surface) 92%,transparent);border-right:1px solid color-mix(in srgb,var(--border) 75%,transparent);border-bottom:1px solid color-mix(in srgb,var(--border) 75%,transparent);rotate:-45deg;transition:opacity .12s ease,transform .12s ease}.fab-btn[data-tooltip]:hover:after,.fab-btn[data-tooltip]:focus-visible:after,.fab-btn[data-tooltip]:hover:before,.fab-btn[data-tooltip]:focus-visible:before{opacity:1;transform:translateY(-50%) translate(0)}.fab-btn-wrap{position:relative;width:46px;height:46px;overflow:visible}.fab-progress{position:absolute;width:46px;height:46px;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2}.fab-btn-wrap>.fab-btn{position:relative;z-index:1}.modal-backdrop{position:fixed;inset:0;background:var(--backdrop);z-index:30;display:grid;place-items:center;padding:18px}.modal{width:min(720px,100%);border-radius:16px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-hover);overflow:hidden}.modal-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:14px;font-weight:800}.modal-body{padding:16px;display:grid;gap:10px}.form-row{display:grid;gap:6px}.form-row label{font-size:12px;color:var(--text-sub)}.form-row input,.form-row select,.form-row textarea{border-radius:12px;border:1px solid var(--border);padding:10px 12px;background:var(--surface);color:var(--text);outline:none}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:color-mix(in srgb,var(--primary) 55%,var(--border));box-shadow:0 0 0 4px color-mix(in srgb,var(--primary) 25%,transparent)}.form-row textarea{min-height:160px;resize:vertical}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 16px 16px;border-top:1px solid var(--border)}.btn{border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:10px 12px;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}.btn:hover{background:var(--surface-hover);border-color:color-mix(in srgb,var(--primary) 18%,var(--border))}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px}.btn-primary{background:var(--primary);border-color:color-mix(in srgb,var(--primary) 60%,var(--border));color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed}.mobile-topbar{display:none;align-items:center;gap:10px}.mobile-menu-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:grid;place-items:center}.mobile-menu-btn:focus-visible{outline:3px solid color-mix(in srgb,var(--primary) 45%,transparent);outline-offset:2px}.sidebar-overlay{display:none}@media(prefers-reduced-motion:reduce){.card,.sidebar,.fab-btn,.btn,.icon-btn{transition:none}}@media(min-width:861px){.app-shell--sidebar-hidden .sidebar{transform:translate(calc(-1 * var(--sidebar-width) - 20px))}}@media(max-width:860px){.app-shell--with-sidebar{padding-left:0}.banner-row{flex-wrap:wrap}.banner-left{width:100%}.banner-time{min-width:0}.sidebar-avatar,.banner-time{display:none}.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:40;transform:translate(-105%);transition:transform .18s ease}.sidebar.is-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:var(--backdrop);border-radius:0;z-index:35}.mobile-topbar{display:flex}.banner-row{flex-direction:column;align-items:stretch}.banner-row>.banner-title{display:none}.banner-tools{justify-content:space-between}}
