.site-footer{flex-shrink:0;text-align:center;padding:1rem 1.25rem;background:#fff;border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:.82rem;line-height:1.8}.site-footer a{color:var(--color-primary);text-decoration:none}.site-footer a:hover{text-decoration:underline}.cover-page{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column;font-size:142.5%}.cover-header{display:flex;justify-content:center;background:var(--color-bg);flex-shrink:0}.cover-header-inner{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1650px;padding:1.125rem 2.25rem;margin:0 auto}.cover-logo{display:flex;align-items:center;gap:.75rem;font-size:1.1em;font-weight:600;color:var(--color-text)}.cover-logo-img{height:57px;width:auto;object-fit:contain}.cover-logo-fallback{display:none;font-size:1.5em}.cover-logo-fallback.show{display:inline}.cover-btn-join{padding:.6rem 1.5rem;border:1px solid var(--color-text);border-radius:6px;color:var(--color-text);font-size:.9em;transition:background .2s,color .2s}.cover-btn-join:hover{background:var(--color-text);color:var(--color-bg)}.cover-main{flex:1;display:flex;align-items:stretch;gap:2.85rem;padding:1.4rem 2.25rem 2.85rem;max-width:1650px;margin:0 auto;width:100%}.cover-hero-image{flex:0 0 600px;aspect-ratio:4/3;background:var(--color-border);border-radius:8px;overflow:hidden;position:relative}.cover-hero-image img,.cover-hero-image video{width:100%;height:100%;object-fit:cover}.cover-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--color-matcha) 0%,var(--color-primary) 100%)}.cover-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;border-radius:50%;background:#fff6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.55);font-size:2rem;color:var(--color-text);line-height:1;box-shadow:0 2px 10px #0000001f;transition:transform .2s,background .2s}.cover-nav-btn:hover{transform:translateY(-50%) scale(1.05);background:#ffffff8c}.cover-prev{left:1rem}.cover-next{right:1rem}.cover-hero-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:flex-start}.cover-title-main{font-size:2.8em;font-weight:700;color:var(--color-primary-dark);margin-bottom:1.25rem;letter-spacing:.04em;line-height:1.3;display:flex;flex-direction:column;gap:.1em}.cover-title-line{display:block}.cover-desc-wrap{margin-bottom:1.5rem;padding:1rem 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.cover-desc-brief{font-size:.9em;line-height:1.75;color:var(--color-text-muted)}.cover-desc-brief p{margin:0 0 .5em}.cover-desc-brief p:last-of-type:not(.cover-desc-preview){margin-bottom:0}.cover-desc-preview{font-size:.92em;line-height:1.7;color:var(--color-text);margin-top:.6em!important;margin-bottom:0!important;opacity:.9}.cover-desc-toggle{margin-top:.75rem;padding:.35rem 0;font-size:.8em;color:var(--color-primary);background:none;border:none;border-bottom:1px solid transparent;cursor:pointer;transition:color .2s,border-color .2s}.cover-desc-toggle:hover{color:var(--color-primary-dark);border-bottom-color:var(--color-primary)}.cover-desc-full{margin-top:1rem;overflow-y:visible;max-height:none}.cover-desc{font-size:.85em;line-height:1.65;color:var(--color-text-muted);margin-bottom:.75rem}.cover-desc:last-child{margin-bottom:0}.cover-features{display:flex;gap:1.25rem;margin-bottom:1rem}.cover-feature-link{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:var(--color-primary-dark);transition:color .2s}.cover-feature-link:hover{color:var(--color-primary)}.cover-feature-icon{font-size:1rem}.cover-btn-cta{display:inline-block;padding:.9rem 2.25rem;background:var(--color-primary);color:#fff;border-radius:6px;font-size:1em;font-weight:500;transition:background .2s,transform .1s;align-self:flex-start}.cover-btn-cta:hover{background:var(--color-primary-dark);transform:translateY(-1px)}@media (max-width: 1200px){.cover-main{flex-direction:column;align-items:center}.cover-hero-image{flex:none;width:100%;max-width:600px}.cover-hero-content{width:100%}}@media (max-width: 768px){.cover-page{font-size:123.5%}.cover-title-main{font-size:2.2em}.cover-hero-image{max-width:100%}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:url(/img/bg.jpg) center center no-repeat;background-size:cover}.login-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-card-wrap{position:relative;z-index:1;margin:1rem}.login-card{background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:2rem 2.25rem 2.5rem;box-shadow:0 8px 32px #0003;width:500px;max-width:calc(100vw - 2rem);height:450px;display:flex;flex-direction:column;box-sizing:border-box}.login-tabs{display:flex;gap:.5rem;margin-bottom:1.75rem;border-bottom:1px solid rgba(0,0,0,.08)}.login-tab{padding:.5rem 0;font-size:1.05rem;color:#666}.login-tab.active{color:#333;font-weight:600}.login-hint{font-size:.9rem;color:#555;margin-bottom:1.25rem}.login-form .form-group{margin-bottom:1rem}.login-form .form-group label{display:block;font-size:.9rem;color:#444;margin-bottom:.35rem}.login-form .form-group input{width:100%;padding:.6rem .75rem;font-size:.95rem;border:1px solid #ddd;border-radius:8px;background:#fff}.login-form .form-group input:focus{outline:none;border-color:var(--color-primary)}.form-actions{margin-top:1.25rem}.btn-login{padding:.6rem 1.5rem;font-size:.95rem;font-weight:500;border:none;border-radius:8px;background:var(--color-primary);color:#fff}.btn-login:hover:not(:disabled){background:var(--color-primary-dark)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-links{margin-top:auto;padding-top:1.25rem;flex-shrink:0;font-size:.85rem;color:#555}.login-links a{color:var(--color-primary-dark)}.login-links a:hover{text-decoration:underline}.login-links p{margin-bottom:.4rem}.login-page>.site-footer{position:absolute;bottom:0;left:0;right:0;z-index:1;background:#ffffffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.fireworks-canvas{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:101}.fireworks-canvas--ambient{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.register-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:url(/img/bg.jpg) center center no-repeat;background-size:cover}.register-bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.register-card-wrap{position:relative;z-index:1;margin:1rem}.register-card{background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:2rem 2.25rem 2.5rem;box-shadow:0 8px 32px #0003;width:500px;max-width:calc(100vw - 2rem);height:640px;display:flex;flex-direction:column;box-sizing:border-box}.register-card-content{flex:1;min-height:0;overflow-y:auto}.register-tabs{display:flex;gap:.5rem;margin-bottom:1.75rem;border-bottom:1px solid rgba(0,0,0,.08)}.register-tab{padding:.5rem 0;font-size:1.05rem;color:#666}.register-tab.active{color:#333;font-weight:600}.register-hint{font-size:.9rem;color:#555;margin-bottom:1.25rem}.register-hint--sub{margin-top:-.65rem;margin-bottom:1rem;font-size:.82rem;color:#777;line-height:1.55}.register-form .form-group,.register-form .form-actions{margin-bottom:1rem}.register-form .form-group label{display:block;font-size:.9rem;color:#444;margin-bottom:.35rem}.register-form .form-group input{width:100%;padding:.6rem .75rem;font-size:.95rem;border:1px solid #ddd;border-radius:8px;background:#fff}.code-row{display:flex;gap:.5rem}.code-row input{flex:1}.btn-send-code{padding:.6rem 1rem;font-size:.85rem;border:1px solid var(--color-primary);border-radius:8px;background:transparent;color:var(--color-primary);white-space:nowrap}.btn-send-code:hover:not(:disabled){background:var(--color-primary);color:#fff}.btn-send-code:disabled{opacity:.6;cursor:not-allowed}.quiz-list{margin-bottom:1.5rem}.quiz-item{margin-bottom:1.25rem;padding:1rem;background:#f9f9f9;border-radius:8px}.quiz-question{font-weight:500;margin-bottom:.75rem}.quiz-options{display:flex;flex-direction:column;gap:.5rem}.quiz-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.attr-options{display:flex;gap:1rem}.attr-option{display:flex;align-items:center;gap:.5rem;cursor:pointer}.attr-options-with-avatar{display:flex;gap:1rem;flex-wrap:wrap}.attr-option-with-avatar{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;padding:.75rem;border:2px solid #eee;border-radius:12px;transition:border-color .2s,background .2s}.attr-option-with-avatar:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 100, 100, 100),.05)}.attr-option-with-avatar.active{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb, 100, 100, 100),.08)}.identity-avatar{width:64px;height:64px;object-fit:cover;border-radius:50%}.avatar-preview{display:flex;flex-direction:column;align-items:center}.avatar-preview-img{width:80px;height:80px;object-fit:cover;border-radius:50%;margin-top:.5rem}.register-card--step2 .register-card-content{overflow:visible;flex:0 1 auto}.register-card--step2 .register-hint{margin-bottom:.6rem}.register-card--step2 .register-hint--sub{margin-top:-.35rem;margin-bottom:.75rem;font-size:.8rem;line-height:1.45}.register-form-step2{width:100%;display:flex;flex-direction:column;align-items:center}.register-form-step2 .step2-avatar{display:block;width:96px;height:96px;object-fit:cover;border-radius:50%;border:3px solid rgba(255,255,255,.95);box-shadow:0 4px 16px #7ba87238;margin-bottom:1rem}.step2-form-fields{width:100%;display:flex;flex-direction:column;gap:.75rem;margin-bottom:.5rem}.step2-form-fields .form-group{margin-bottom:0}.register-form-step2 .form-actions{width:100%;margin-top:.75rem;margin-bottom:0}.account-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem}.account-modal{position:relative;z-index:102;background:#fff;border-radius:16px;padding:2rem;max-width:360px;width:100%;box-shadow:0 12px 48px #0000004d;text-align:center}.account-modal h3{margin:0 0 1rem;font-size:1.25rem}.account-modal-msg{margin:0 0 .5rem;color:#555;font-size:.95rem}.account-modal-value{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--color-primary);word-break:break-all}.account-modal-hint{margin:0 0 1.5rem;font-size:.85rem;color:#888}.form-error{color:#c44;font-size:.9rem;margin-bottom:.5rem}.form-actions{display:flex;gap:1rem;margin-top:1rem}.btn-prev{padding:.6rem 1.25rem;border:1px solid #ddd;border-radius:8px;background:#fff;color:#333}.btn-next,.btn-register{padding:.6rem 1.5rem;border:none;border-radius:8px;background:var(--color-primary);color:#fff;font-weight:500}.btn-next:hover,.btn-register:hover:not(:disabled){background:var(--color-primary-dark)}.btn-register:disabled{opacity:.7;cursor:not-allowed}.register-note{font-size:.8rem;color:#888;margin-top:.5rem}.register-links{margin-top:auto;padding-top:1.25rem;flex-shrink:0;font-size:.85rem;color:#555}.register-links a{color:var(--color-primary-dark)}.register-links p{margin-bottom:.4rem}.register-page>.site-footer{position:absolute;bottom:0;left:0;right:0;z-index:1;background:#ffffffd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.main-layout{min-height:100vh;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.main-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;gap:1rem;height:56px;min-width:0;padding:0 1.25rem;background:#fff;border-bottom:1px solid var(--color-border);box-shadow:0 1px 3px #0000000f}.menu-toggle{flex-shrink:0;display:none;align-items:center;justify-content:center;gap:.5rem;width:40px;height:40px;padding:0;background:#f5f5f5;border:none;border-radius:8px;font-size:1rem;color:var(--color-text);cursor:pointer;transition:background .15s,color .15s}.menu-toggle:hover,.menu-toggle--active{background:#7ba8722e;color:var(--color-primary-dark)}.menu-toggle svg{width:24px;height:24px}.main-logo{flex-shrink:0;display:flex;align-items:center;gap:.5rem;font-size:1.2rem;font-weight:600;color:var(--color-text)}.main-logo-img{height:36px;width:auto;object-fit:contain}.main-logo-fallback{display:none;font-size:1.5rem}.main-logo-fallback.show{display:inline}.header-right{margin-left:auto;display:flex;align-items:center;gap:1rem;min-width:0;flex:1;justify-content:flex-end}.header-search{display:flex;align-items:center;width:280px;padding:.4rem .75rem;background:#f5f5f5;border-radius:20px;border:1px solid transparent}.header-search:focus-within{background:#fff;border-color:var(--color-primary)}.header-search input{flex:1;border:none;background:none;font-size:.9rem}.header-search input:focus{outline:none}.header-search button{background:none;border:none;padding:.25rem;color:#666;cursor:pointer}.header-search button svg{width:18px;height:18px}.user-menu{display:flex;align-items:center;gap:.5rem}.user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;overflow:hidden;background:var(--color-border)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar-fallback{font-size:1.25rem}.user-name{font-size:.9rem;color:var(--color-text-muted)}.btn-logout{padding:.35rem .75rem;font-size:.8rem;border:1px solid var(--color-border);border-radius:4px;background:transparent;color:var(--color-text-muted);cursor:pointer}.btn-logout:hover{color:var(--color-text);border-color:var(--color-text)}.main-body{flex:1;min-height:0;display:flex;margin-top:56px;height:calc(100vh - 56px);height:calc(100dvh - 56px);max-height:calc(100vh - 56px);max-height:calc(100dvh - 56px);overflow:hidden;box-sizing:border-box}.sidebar{width:260px;flex-shrink:0;background:#fff;border-right:1px solid var(--color-border);padding:1rem 0;position:fixed;left:0;top:56px;bottom:0;overflow-y:auto;overflow-x:hidden;z-index:100;box-shadow:1px 0 4px #0000000a;transition:width .25s ease}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:0 1rem .75rem;gap:.5rem}.sidebar-title{flex:1;font-size:.85rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.sidebar-nav{display:flex;flex-direction:column}.sidebar-nav-link{position:relative;display:flex;align-items:center;gap:.6rem;padding:.7rem 1.25rem;color:var(--color-text);font-size:.95rem;transition:background .15s,color .15s;border-left:3px solid transparent}.sidebar-nav-link:hover{background:#f8f8f8}.sidebar-nav-link.active{background:#7ba8721f;color:var(--color-primary-dark);border-left-color:var(--color-primary)}.nav-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;opacity:.9}.nav-icon svg{width:20px;height:20px}.sidebar-overlay{display:none}.main-content{flex:1;min-width:0;min-height:0;margin-left:260px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;background:var(--color-bg);transition:margin-left .25s ease}@media (max-width: 768px){.menu-toggle{display:flex}.main-header{gap:.5rem;padding:0 .65rem}.main-logo-img{height:30px}.header-right{gap:.4rem}.header-search{flex:1 1 auto;width:auto;min-width:0;max-width:10.5rem;padding:.35rem .55rem}.header-search input{font-size:.8rem;min-width:0}.header-search input::placeholder{font-size:.75rem}.user-name{display:none}.user-menu{flex-shrink:0;gap:.35rem}.btn-logout{padding:.3rem .5rem;font-size:.75rem}.sidebar{position:fixed;left:0;top:56px;bottom:0;width:280px;max-width:85vw;transform:translate(-100%);transition:transform .25s ease;z-index:200;box-shadow:4px 0 16px #00000026}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.sidebar-overlay{display:block;position:fixed;right:0;bottom:0;left:0;top:56px;background:#0006;z-index:199;opacity:0;pointer-events:none;transition:opacity .25s}.sidebar-overlay.visible{opacity:1;pointer-events:auto}}@media (max-width: 400px){.header-search{max-width:7.5rem}.btn-logout{padding:.3rem .4rem;font-size:.7rem}}.admin-layout{min-height:100vh;height:100vh;height:100dvh;display:flex;overflow:hidden;background:#f3f5f7}.admin-sidebar{position:fixed;left:0;top:0;bottom:0;z-index:200;width:220px;background:#001529;color:#d2e0ef;padding:1rem .75rem;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.admin-brand{padding:.75rem;margin-bottom:.5rem;color:#fff;font-weight:600;border-bottom:1px solid rgba(255,255,255,.12)}.admin-menu{display:flex;flex-direction:column;gap:.25rem}.admin-menu a{padding:.6rem .75rem;border-radius:6px;color:#d2e0ef;font-size:.92rem}.admin-menu a:hover{background:#ffffff1f}.admin-menu a.active{background:#1677ff;color:#fff}.admin-main{flex:1;min-width:0;min-height:0;margin-left:220px;display:flex;flex-direction:column;height:100vh;height:100dvh;box-sizing:border-box}.admin-header{flex-shrink:0;height:56px;background:#fff;border-bottom:1px solid #e9edf3;display:flex;align-items:center;justify-content:space-between;padding:0 1rem}.admin-header-title{font-weight:600}.admin-header-right{display:flex;align-items:center;gap:.75rem}.admin-header-right button{border:1px solid #d9d9d9;background:#fff;border-radius:6px;padding:.3rem .7rem}.admin-content{flex:1;min-height:0;padding:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch}@media (max-width: 900px){.admin-sidebar{width:180px}.admin-main{margin-left:180px}}.home-page{position:relative;overflow:hidden;min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem}.home-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;background-repeat:no-repeat}.home-center{position:relative;z-index:1;width:100%;max-width:640px;display:flex;flex-direction:column;align-items:center}.home-title-img{display:block;width:min(100%,420px);height:auto;margin-bottom:1.5rem;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.12))}.home-search{display:flex;align-items:center;width:100%;max-width:560px;padding:.6rem 1rem .6rem 1.25rem;background:#fff;border-radius:28px;border:1px solid var(--color-border);box-shadow:0 2px 8px #00000014;transition:box-shadow .2s}.home-search:focus-within{box-shadow:0 4px 16px #0000001f;border-color:var(--color-primary)}.home-search input{flex:1;border:none;background:none;font-size:1rem;padding:.25rem .5rem}.home-search input:focus{outline:none}.home-search button{background:none;border:none;padding:.35rem;color:var(--color-text-muted);cursor:pointer}.home-search button:hover{color:var(--color-primary)}.home-search button svg{width:22px;height:22px}.home-section{margin-top:2rem;width:100%}.home-section-title{font-size:1rem;color:var(--color-text);margin-bottom:.75rem;padding-left:.25rem}.home-grid{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}.home-card{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#ffffffe6;border-radius:12px;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s}.home-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.home-card-img{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--color-border)}.home-card-img img{width:100%;height:100%;object-fit:cover}.home-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--color-matcha)}.home-card-title{margin-top:.6rem;font-size:.9rem;color:var(--color-text);text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-empty{grid-column:1 / -1;text-align:center;color:var(--color-text-muted);padding:1rem;font-size:.9rem}@media (max-width: 600px){.home-grid{grid-template-columns:repeat(2,1fr)}.home-title-img{width:min(100%,280px)}}.timeline-page{position:relative;height:100%;padding:1.5rem;background:url(/img/timeline.png) center center / 100% 100% no-repeat;color:var(--color-text);overflow-y:auto}.timeline-page .page-title{font-size:1.5rem;margin-bottom:1.5rem;color:var(--color-text)}.timeline-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.timeline-filters select{padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:8px;font-size:.9rem;background:#fff;color:var(--color-text)}.timeline-vt{max-width:720px;margin:0 auto}.timeline-vt__section+.timeline-vt__section{margin-top:2.5rem}.timeline-vt__year{font-size:1rem;font-weight:600;text-align:center;color:var(--color-text);margin-bottom:1.25rem;position:relative;z-index:1}.timeline-vt__track{position:relative;padding:0 .25rem}.timeline-vt__line{position:absolute;left:50%;top:0;bottom:0;width:1px;background:#3d3a352e;transform:translate(-50%);pointer-events:none}.timeline-vt__rows{position:relative;z-index:1}.timeline-vt__row{display:block;color:inherit;text-decoration:none;border-radius:8px;transition:background .2s ease}.timeline-vt__row:hover{background:#ffffff73}.timeline-vt__row-inner{display:grid;grid-template-columns:minmax(0,1fr) 36px minmax(0,1fr);align-items:flex-start;padding:1.1rem 0;gap:0 10px}.timeline-vt__gutter{min-height:1px}.timeline-vt__axis-cell{display:flex;justify-content:center;padding-top:.15rem}.timeline-vt__node{display:flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0}.timeline-vt__node-default{display:block;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#f0a0a0,#d86868);position:relative;box-shadow:0 0 0 2px #ffffffd9}.timeline-vt__node-default:after{content:"";position:absolute;left:50%;top:50%;width:2px;height:55%;background:#ffffffeb;border-radius:1px;transform:translate(-50%,-50%) rotate(42deg)}.timeline-vt__node-img{width:22px;height:22px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 2px #ffffffd9;border:1px solid rgba(61,58,53,.15)}.timeline-vt__body{min-width:0;padding-top:0}.timeline-vt__row--right .timeline-vt__body{text-align:left;padding-left:2px}.timeline-vt__row--left .timeline-vt__body{text-align:right;padding-right:2px}.timeline-vt__date{display:block;font-size:.8rem;color:var(--color-text-muted);margin-bottom:.35rem}.timeline-vt__date--left{margin-top:.45rem;margin-bottom:0}.timeline-vt__item-title{font-size:1rem;font-weight:600;color:var(--color-text);line-height:1.45;margin:0}.timeline-vt__intro{font-size:.85rem;color:var(--color-text-muted);line-height:1.55;margin:.35rem 0 0;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.timeline-page__empty{padding:3rem 1rem;text-align:center;color:var(--color-text-muted)}@media (max-width: 640px){.timeline-vt__track{padding-left:.25rem}.timeline-vt__line{left:18px;transform:none}.timeline-vt__row-inner{grid-template-columns:36px minmax(0,1fr);gap:0 14px}.timeline-vt__row--right .timeline-vt__gutter,.timeline-vt__row--left .timeline-vt__gutter{display:none}.timeline-vt__row--right .timeline-vt__axis-cell{grid-column:1;grid-row:1;justify-content:flex-start}.timeline-vt__row--right .timeline-vt__body{grid-column:2;grid-row:1;text-align:left;padding-left:0}.timeline-vt__row--left .timeline-vt__axis-cell{grid-column:1;grid-row:1;justify-content:flex-start}.timeline-vt__row--left .timeline-vt__body{grid-column:2;grid-row:1;text-align:left;padding-right:0}.timeline-vt__row--left .timeline-vt__date--left{margin-top:.35rem}}.timeline-detail{position:relative;min-height:calc(100vh - 56px);width:100%;padding:1.5rem 1.5rem 5rem;box-sizing:border-box;background:var(--color-bg);color:var(--color-text)}.timeline-detail--loading{padding:3rem;text-align:center}.timeline-detail__back{display:inline-block;margin-bottom:1rem;font-size:.9rem;color:var(--color-primary-dark)}.timeline-detail__back:hover{text-decoration:underline}.timeline-detail__header{margin-bottom:1.75rem}.timeline-detail__meta{display:flex;gap:.75rem;align-items:center;margin-bottom:.5rem}.timeline-detail__tag{padding:.2rem .55rem;font-size:.75rem;font-weight:600;background:var(--color-primary);color:#fff;border-radius:4px}.timeline-detail__date{font-size:.9rem;color:var(--color-text-muted)}.timeline-detail__title{font-size:1.45rem;font-weight:700;margin-bottom:.5rem;line-height:1.35}.timeline-detail__intro{font-size:.95rem;color:var(--color-text-muted);line-height:1.6}.timeline-detail__sections{display:flex;flex-direction:column;gap:2rem}.timeline-detail__section-title{font-size:1.05rem;font-weight:700;margin-bottom:.85rem;color:var(--color-text)}.timeline-detail__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.85rem 1rem}@media (min-width: 640px){.timeline-detail__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (min-width: 900px){.timeline-detail__grid{grid-template-columns:repeat(5,1fr)}}.timeline-detail__card{display:block;width:100%;padding:0;border:none;background:transparent;cursor:pointer;text-align:center;border-radius:10px;transition:transform .15s ease,box-shadow .15s ease}.timeline-detail__card:hover{transform:translateY(-2px)}.timeline-detail__card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.timeline-detail__thumb{position:relative;width:100%;aspect-ratio:16 / 10;border-radius:10px;overflow:hidden;background:#00000014;box-shadow:0 1px 4px #00000014}.timeline-detail__thumb-img,.timeline-detail__thumb-video{width:100%;height:100%;object-fit:cover;display:block}.timeline-detail__thumb--article{background:linear-gradient(145deg,#e8efe4,#d4e0cf);display:flex;align-items:center;justify-content:center}.timeline-detail__thumb--article-cover{position:relative;background:#e8e8e8}.timeline-detail__thumb--article-cover .timeline-detail__thumb-img{object-fit:cover}.timeline-detail__article-badge{position:absolute;right:6px;bottom:6px;padding:2px 7px;font-size:.62rem;font-weight:600;letter-spacing:.02em;color:#fff;background:#00000085;border-radius:4px;pointer-events:none}.timeline-detail__article-icon{width:36px;height:44px;border-radius:4px;background:#ffffffd9;box-shadow:0 2px 6px #00000014;border:1px solid rgba(123,168,114,.35);position:relative}.timeline-detail__article-icon:before{content:"";position:absolute;left:8px;right:8px;top:10px;height:4px;border-radius:1px;background:var(--color-primary);opacity:.5}.timeline-detail__article-icon:after{content:"";position:absolute;left:8px;right:14px;top:18px;height:3px;border-radius:1px;background:var(--color-text-muted);opacity:.35}.timeline-detail__play{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:44px;height:44px;border-radius:50%;background:#00000073;pointer-events:none}.timeline-detail__play:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-40%,-50%);border-style:solid;border-width:8px 0 8px 14px;border-color:transparent transparent transparent #fff}.timeline-detail__card-title{margin-top:.4rem;font-size:.78rem;line-height:1.35;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.timeline-detail__fallback{margin-top:.5rem}.timeline-detail__hero-img{width:100%;max-height:420px;object-fit:cover;border-radius:12px;margin-bottom:1rem}.timeline-detail__html{font-size:.95rem;line-height:1.75;background:#ffffff8c;padding:1rem 1.25rem;border-radius:12px}.timeline-detail__html img{max-width:100%;height:auto}.timeline-detail__empty{padding:2rem 1rem;text-align:center;color:var(--color-text-muted);background:#ffffff73;border-radius:12px}.timeline-detail__modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem}.timeline-detail__modal-inner{position:relative;width:100%;max-width:720px;max-height:90vh;overflow:auto;background:#fff;border-radius:12px;padding:1.25rem 1.25rem 1.5rem;box-shadow:0 8px 32px #0003}.timeline-detail__modal-close{position:absolute;top:.75rem;right:.75rem;padding:.35rem .65rem;font-size:.8rem;border:1px solid var(--color-border);border-radius:6px;background:#fff}.timeline-detail__modal-title{font-size:1.05rem;font-weight:600;margin:0 3.5rem .75rem 0;padding-right:.5rem}.timeline-detail__modal-video{width:100%;border-radius:8px;background:#000;max-height:min(70vh,520px)}.timeline-detail__article-body{white-space:pre-wrap;font-size:.95rem;line-height:1.75;color:var(--color-text)}.timeline-detail__fab{position:fixed;right:1rem;bottom:1.25rem;z-index:1500;display:flex;flex-direction:column;gap:.5rem}.timeline-detail__fab-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#ffffffeb;color:var(--color-text);font-size:.65rem;font-weight:700;box-shadow:0 2px 12px #0000001f;cursor:pointer}.timeline-detail__fab-btn:hover{background:#fff;color:var(--color-primary-dark)}.timeline-detail__toc{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1600;background:#00000040}.timeline-detail__toc-panel{position:absolute;right:0;top:0;bottom:0;width:min(280px,86vw);background:#fffffff7;box-shadow:-4px 0 20px #00000014;padding:1rem 1rem 5rem;overflow-y:auto}.timeline-detail__toc-h{font-size:.85rem;font-weight:600;margin-bottom:.75rem;color:var(--color-text-muted)}.timeline-detail__toc-panel ul{list-style:none;margin:0;padding:0}.timeline-detail__toc-panel li+li{margin-top:.35rem}.timeline-detail__toc-panel button{width:100%;text-align:left;padding:.5rem .65rem;font-size:.9rem;border:none;background:transparent;border-radius:8px;cursor:pointer;color:var(--color-text)}.timeline-detail__toc-panel button:hover{background:#7ba8721f}.songs-page{position:relative;height:100%;width:100%;padding:1.5rem;box-sizing:border-box;background:url(/img/songs.jpg) center center / 100% 100% no-repeat;color:var(--color-text);overflow-y:auto}.songs-bundles{display:flex;flex-direction:column;gap:2rem}.songs-bundle{width:100%;max-width:none}.songs-bundle__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;margin-bottom:.85rem}.songs-bundle__title{font-size:1.1rem;font-weight:700;margin:0;color:var(--color-text)}.songs-bundle__meta{font-size:.85rem;color:var(--color-text-muted)}.songs-bundle__link-album{margin-left:auto;font-size:.85rem;color:var(--color-primary-dark)}.songs-bundle__link-album:hover{text-decoration:underline}.songs-bundle__empty{font-size:.9rem;color:var(--color-text-muted);padding:.5rem 0}.songs-bundle__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:.85rem 1rem}@media (min-width: 640px){.songs-bundle__grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (min-width: 900px){.songs-bundle__grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.songs-tile{display:block;text-align:center;text-decoration:none;color:inherit;border-radius:10px;transition:transform .15s ease,box-shadow .15s ease}.songs-tile:hover{transform:translateY(-2px)}.songs-tile:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.songs-tile__thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;background:#ffffffa6;box-shadow:0 1px 4px #00000014}.songs-tile__thumb img{width:100%;height:100%;object-fit:cover;display:block}.songs-tile__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.25rem;background:var(--color-matcha)}.songs-tile__name{margin:.4rem 0 0;font-size:.8rem;line-height:1.35;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.songs-page .page-title{font-size:1.5rem;margin-bottom:1.25rem;color:var(--color-text)}.songs-page .empty-hint{padding:3rem 1rem;text-align:center;color:var(--color-text-muted)}.album-detail{position:relative;min-height:calc(100vh - 56px);width:100%;max-width:none;margin:0;padding:1.25rem 1.5rem 2.5rem;box-sizing:border-box;background:url(/img/songs.jpg) center center / 100% 100% no-repeat;color:var(--color-text)}.album-detail--state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;color:var(--color-text-muted)}.album-detail__toolbar{margin-bottom:1rem}.album-detail__back{display:inline-block;font-size:.9rem;color:var(--color-primary-dark);font-weight:500}.album-detail__back:hover{text-decoration:underline}.album-detail__hero{margin-bottom:2.25rem;width:100%}.album-detail__intro{min-width:0;padding-bottom:.25rem;max-width:52em}.album-detail__label{margin:0 0 .35rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);font-weight:600}.album-detail__title{margin:0 0 .5rem;font-size:clamp(1.35rem,3vw,2rem);font-weight:700;line-height:1.2;letter-spacing:.02em}.album-detail__meta{margin:0 0 .75rem;font-size:.9rem;color:var(--color-text-muted)}.album-detail__desc{margin:0 0 1rem;font-size:.95rem;line-height:1.65;color:var(--color-text-muted);max-width:52em}.album-detail__count{margin:0;font-size:.88rem;color:var(--color-primary-dark);font-weight:500}.album-detail__section{width:100%}.album-detail__section-title{margin:0 0 1rem;font-size:1.1rem;font-weight:700}.album-detail__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:.85rem 1rem;width:100%}@media (min-width: 640px){.album-detail__grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (min-width: 900px){.album-detail__grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (min-width: 1200px){.album-detail__grid{grid-template-columns:repeat(6,minmax(0,1fr))}}.album-detail__tile{display:block;text-align:center;text-decoration:none;color:inherit;border-radius:10px;transition:transform .15s ease,box-shadow .15s ease}.album-detail__tile:hover{transform:translateY(-2px)}.album-detail__tile:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.album-detail__tile-thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:#ffffffb8;box-shadow:0 1px 4px #00000014}.album-detail__tile-thumb img{width:100%;height:100%;object-fit:cover;display:block}.album-detail__tile-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.25rem;background:var(--color-matcha)}.album-detail__tile-dur{position:absolute;right:6px;bottom:6px;padding:.12rem .4rem;font-size:.68rem;font-variant-numeric:tabular-nums;color:#fff;background:#0000008c;border-radius:4px;line-height:1.2}.album-detail__tile-name{margin:.4rem 0 0;font-size:.8rem;line-height:1.35;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.album-detail__empty{margin:0;padding:1.5rem 0;font-size:.95rem;color:var(--color-text-muted)}.song-player{--sp-bg: var(--color-bg);--sp-panel: var(--color-bg-card);--sp-text: var(--color-text);--sp-muted: var(--color-text-muted);--sp-accent: var(--color-primary);--sp-accent-dim: var(--color-primary-dark);width:100%;min-height:calc(100vh - 56px);margin:0;padding:0 1.25rem 1rem;background:var(--sp-bg);color:var(--sp-text);display:flex;flex-direction:column;box-sizing:border-box}.song-player--state{align-items:center;justify-content:center;gap:1rem;text-align:center;color:var(--sp-muted)}.song-player__audio-el{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.song-player__header{flex-shrink:0;padding:.75rem 0 .25rem}.song-player__back{display:inline-block;font-size:.9rem;color:var(--sp-muted);transition:color .15s}.song-player__back:hover{color:var(--sp-text)}.song-player__stage{flex:1;display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.1fr);gap:clamp(1.5rem,4vw,3.5rem);align-items:center;padding:1rem 0 6.5rem;min-height:0}.song-player__viz{display:flex;justify-content:center;align-items:center}.song-vinyl{position:relative;width:min(42vw,380px);aspect-ratio:1;max-width:100%}.song-vinyl__tonearm{position:absolute;top:-2%;right:8%;width:38%;height:42%;background:linear-gradient(135deg,#d8dde6,#9aa3b0 45%,#c5cad3);border-radius:2px 2px 40%;transform-origin:92% 8%;transform:rotate(-28deg);box-shadow:0 2px 8px #00000059;z-index:2;transition:transform .45s ease;pointer-events:none}.song-vinyl__tonearm--on{transform:rotate(-6deg)}.song-vinyl__platter{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle at 35% 30%,#2a2e38,#12141a 55%,#0a0b0e);box-shadow:inset 0 0 0 1px #ffffff0a,0 12px 40px #00000073;display:flex;align-items:center;justify-content:center}.song-vinyl__grooves{position:absolute;top:6%;right:6%;bottom:6%;left:6%;border-radius:50%;background:repeating-radial-gradient(circle at 50% 50%,transparent 0,transparent 3px,rgba(255,255,255,.02) 3px,rgba(255,255,255,.02) 4px);pointer-events:none}.song-vinyl__disc{position:relative;width:62%;aspect-ratio:1;border-radius:50%;overflow:hidden;box-shadow:0 0 0 3px #1a1c22,0 0 0 10px #252830,inset 0 0 20px #0006;animation:song-vinyl-spin 26s linear infinite;animation-play-state:paused}.song-vinyl__disc--spinning{animation-play-state:running}@keyframes song-vinyl-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.song-vinyl__cover{width:100%;height:100%;object-fit:cover;display:block}.song-vinyl__cover--placeholder{display:flex;align-items:center;justify-content:center;font-size:clamp(2rem,8vw,3.5rem);background:linear-gradient(145deg,#2d323c,#1a1d24)}.song-player__side{min-height:0;display:flex;flex-direction:column;align-items:stretch}.song-player__title{font-size:clamp(1.35rem,2.5vw,1.85rem);font-weight:600;letter-spacing:.02em;margin-bottom:.35rem;line-height:1.25}.song-player__meta{margin-bottom:1rem;font-size:.9rem}.song-player__meta-link{color:var(--sp-accent);border-bottom:1px solid transparent;transition:border-color .15s}.song-player__meta-link:hover{border-bottom-color:var(--sp-accent)}.song-player__meta-muted{color:var(--sp-muted)}.song-player__lyrics-wrap{flex:1;min-height:200px;max-height:min(52vh,520px);overflow-y:auto;padding-right:.5rem;margin-right:-.25rem;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.song-player__lyrics-wrap::-webkit-scrollbar{width:6px}.song-player__lyrics-wrap::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.song-player__lyrics{white-space:pre-wrap;font-family:inherit;font-size:.95rem;line-height:2;color:var(--sp-muted);text-align:center;max-width:36em;margin:0 auto}.song-player__lyrics-empty{text-align:center;color:var(--sp-muted);padding:2rem 0;font-size:.95rem}.song-player__dock{position:sticky;bottom:0;margin:0 -1.25rem -1rem;padding:.75rem 1.25rem 1rem;background:linear-gradient(180deg,rgba(245,242,237,0) 0%,var(--sp-panel) 28%);border-top:1px solid var(--color-border);box-shadow:0 -4px 24px #3d3a350f;display:grid;grid-template-columns:minmax(0,220px) 1fr minmax(0,140px);gap:1rem;align-items:center;z-index:5}.song-player__dock-left{display:flex;align-items:center;gap:.65rem;min-width:0}.song-player__mini-cover{width:48px;height:48px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--color-border);display:flex;align-items:center;justify-content:center;font-size:1.25rem}.song-player__mini-cover img{width:100%;height:100%;object-fit:cover}.song-player__dock-titles{min-width:0;display:flex;flex-direction:column;gap:.15rem}.song-player__dock-name{font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-player__dock-sub{font-size:.75rem;color:var(--sp-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-player__dock-center{min-width:0;display:flex;flex-direction:column;gap:.35rem}.song-player__progress{cursor:pointer;padding:.35rem 0}.song-player__progress--disabled{cursor:not-allowed;opacity:.45}.song-player__progress-track{height:4px;border-radius:2px;background:var(--color-border);overflow:hidden}.song-player__progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--sp-accent-dim),var(--sp-accent));transition:width .08s linear}.song-player__times{display:flex;justify-content:space-between;font-size:.72rem;color:var(--sp-muted);font-variant-numeric:tabular-nums}.song-player__controls{display:flex;justify-content:center;align-items:center;padding-top:.15rem}.song-player__playbtn{width:52px;height:52px;border-radius:50%;border:none;background:var(--sp-accent);color:#fff;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .12s;box-shadow:0 4px 14px #7ba87259}.song-player__playbtn:hover:not(:disabled){background:var(--sp-accent-dim);transform:scale(1.04)}.song-player__playbtn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.song-player__dock-right{display:flex;justify-content:flex-end;align-items:center}.song-player__vol{display:flex;align-items:center;gap:.4rem;color:var(--sp-muted)}.song-player__vol input[type=range]{width:88px;accent-color:var(--sp-accent)}.song-player__no-audio{grid-column:1 / -1;text-align:center;font-size:.8rem;color:#c9a227;margin:0;padding-top:.25rem}@media (max-width: 900px){.song-player__stage{grid-template-columns:1fr;padding-bottom:7rem}.song-vinyl{width:min(72vw,300px)}.song-player__dock{grid-template-columns:1fr;gap:.65rem}.song-player__dock-left{max-width:100%}.song-player__dock-right{justify-content:center}.song-player__lyrics-wrap{max-height:40vh}}.materials-page{position:relative;height:100%;width:100%;padding:1.5rem;box-sizing:border-box;background:url(/img/materials.jpg) center center / 100% 100% no-repeat;color:var(--color-text);overflow-y:auto}.materials-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.materials-filters button{padding:.5rem 1.25rem;border:1px solid var(--color-border);border-radius:8px;background:#fff;font-size:.95rem}.materials-filters button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.materials-bundles{display:flex;flex-direction:column;gap:2rem}.materials-bundle{width:100%;max-width:none}.materials-bundle__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem 1rem;margin-bottom:.85rem}.materials-bundle__title{font-size:1.1rem;font-weight:700;margin:0;color:var(--color-text)}.materials-bundle__meta{font-size:.82rem;color:var(--color-text-muted)}.materials-bundle__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.85rem 1rem}@media (min-width: 640px){.materials-bundle__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (min-width: 900px){.materials-bundle__grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.materials-tile{display:block;text-align:center;text-decoration:none;color:inherit;border-radius:10px;transition:transform .15s ease,box-shadow .15s ease}.materials-tile:hover{transform:translateY(-2px)}.materials-tile:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.materials-tile__thumb{position:relative;aspect-ratio:16 / 10;border-radius:10px;overflow:hidden;background:#ffffffa6;box-shadow:0 1px 4px #00000014}.materials-tile__thumb img{width:100%;height:100%;object-fit:cover;display:block}.materials-tile__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.25rem;background:var(--color-matcha)}.materials-tile__tag{position:absolute;top:.45rem;left:.45rem;padding:.15rem .45rem;font-size:.65rem;font-weight:600;background:#0000008c;color:#fff;border-radius:4px}.materials-tile__name{margin:.4rem 0 0;font-size:.8rem;line-height:1.35;font-weight:500;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.materials-page .page-title{font-size:1.5rem;margin-bottom:1.25rem;color:var(--color-text)}.materials-page .empty-hint{padding:3rem 1rem;text-align:center;color:var(--color-text-muted)}.material-detail{padding:1.5rem;max-width:900px;margin:0 auto}.material-detail .detail-title{font-size:1.5rem;margin-bottom:.5rem}.material-detail .detail-tag{display:inline-block;padding:.2rem .5rem;font-size:.8rem;background:var(--color-primary);color:#fff;border-radius:4px;margin-bottom:1rem}.material-media{margin-bottom:1.5rem;border-radius:8px;overflow:hidden;background:#000}.material-media img,.material-media video{width:100%;display:block}.material-desc{font-size:.95rem;line-height:1.6;color:var(--color-text-muted)}.messages-page{padding:1.5rem;min-height:60vh}.messages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.view-switch{display:flex;gap:.5rem}.view-switch button{padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:8px;background:#fff;font-size:.9rem}.view-switch button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.star-view{display:flex;flex-direction:column;min-height:min(72vh,620px);border-radius:16px;overflow:hidden;background:linear-gradient(165deg,#152018,#1e2a22 38%,#243228);box-shadow:0 8px 32px #14231c59}.star-view__head{position:relative;z-index:20;flex-shrink:0;padding:1.1rem 1.35rem 1.15rem;background:linear-gradient(180deg,#0c1610eb,#121e18e0);border-bottom:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.star-view__brand{margin:0 0 .35rem;font-size:1.15rem;font-weight:700;letter-spacing:.08em;color:#fffffff5;text-shadow:0 1px 2px rgba(0,0,0,.35)}.star-view__stats{margin:0;font-size:.9rem;color:#ffffffc7;line-height:1.45}.star-view__stats strong{color:#c8e6b8;font-weight:700;font-size:1.05em}.star-view__stats-sub{display:block;margin-top:.25rem;font-size:.78rem;color:#ffffff80;font-weight:400}.star-view__sky{position:relative;flex:1;min-height:280px;isolation:isolate}.star-view__glow{position:absolute;inset:-20% -10% auto;height:55%;background:radial-gradient(ellipse 70% 80% at 50% 0%,rgba(123,168,114,.12),transparent 70%);pointer-events:none;z-index:0}.star-field{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.star-avatar{--tw-delay: 0s;--tw-dur: 2.2s;position:absolute;width:34px;height:34px;margin-left:-17px;margin-top:-17px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 2px #ffffff2e,0 4px 14px #00000059;animation:star-twinkle var(--tw-dur) ease-in-out infinite;animation-delay:var(--tw-delay);will-change:opacity,transform}.star-avatar img{width:100%;height:100%;object-fit:cover;display:block}@keyframes star-twinkle{0%,to{opacity:.45;transform:scale(.92)}50%{opacity:1;transform:scale(1.08)}}.bubble-view{width:100%;max-width:none;margin:0}.bubble-panel{display:flex;flex-direction:column;min-height:min(72vh,620px);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #14231c38;background:linear-gradient(165deg,#152018,#1e2a22 38%,#243228)}.bubble-panel__head{position:relative;z-index:20;flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:1.1rem 1.35rem 1.15rem;background:linear-gradient(180deg,#0c1610eb,#121e18e0);border-bottom:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bubble-panel__brand{margin:0;font-size:1.15rem;font-weight:700;letter-spacing:.08em;color:#fffffff5;text-shadow:0 1px 2px rgba(0,0,0,.35)}.bubble-panel__head .btn-add-message{padding:.45rem 1rem;border:1px solid rgba(255,255,255,.35);border-radius:8px;background:#ffffff1a;color:#fff;font-size:.88rem;font-weight:500;box-shadow:none}.bubble-panel__head .btn-add-message:hover{background:#ffffff2e;border-color:#ffffff80}.bubble-panel__body{flex:1;min-height:0;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.bubble-wall{--bubble-wall-min: 360px;position:relative;flex:1;width:100%;margin:0;padding:.65rem .75rem 1rem;box-sizing:border-box;min-height:max(var(--bubble-wall-min),calc(min(72vh,620px) - 5.75rem));background:url(/img/message.jpg) center / 100% 100% no-repeat;box-shadow:inset 0 1px #ffffff59;overflow-x:hidden;overflow-y:visible}.bubble-wall__empty{position:relative;z-index:2;margin:0;padding:3rem 1.5rem;text-align:center;color:var(--color-text-muted);font-size:.95rem}.bubble-card{position:absolute;width:min(280px,calc(100vw - 2.75rem));padding:.75rem .85rem .65rem;background:#fff;border-radius:10px;box-shadow:0 2px #ffffffe6 inset,0 6px 20px #3d3a351f,0 1px 3px #0000000f;border:1px solid rgba(0,0,0,.05);transform-origin:center center;transition:box-shadow .2s ease,transform .2s ease,z-index 0s}.bubble-card:hover{z-index:60!important;box-shadow:0 2px #fffffff2 inset,0 12px 32px #3d3a352e;transform:rotate(0) scale(1.02)!important}.bubble-card__head{display:flex;align-items:center;gap:.55rem;margin-bottom:.5rem}.bubble-card__avatar{flex-shrink:0;width:38px;height:38px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 2px #7ba87259}.bubble-card__avatar img{width:100%;height:100%;object-fit:cover;display:block}.bubble-card__meta{min-width:0;display:flex;flex-direction:column;gap:.1rem}.bubble-card__name{font-size:.88rem;font-weight:600;color:var(--color-primary-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bubble-card__time{font-size:.72rem;color:var(--color-text-muted)}.bubble-card__content{margin:0;font-size:.86rem;line-height:1.55;color:var(--color-text);word-break:break-word;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.bubble-card__content--expanded{display:block;-webkit-line-clamp:unset;overflow:visible;max-height:none}.bubble-card__expand{margin:.35rem 0 0;padding:0;border:none;background:none;font-size:.78rem;color:var(--color-primary);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.bubble-card__expand:hover{color:var(--color-primary-dark)}.bubble-card__foot{display:flex;justify-content:flex-end;margin-top:.45rem;padding-top:.35rem;border-top:1px solid var(--color-border)}.bubble-card__like{background:none;border:none;font-size:.82rem;color:var(--color-text-muted);padding:.15rem .25rem;cursor:pointer}.bubble-card__like:hover{color:var(--color-primary)}.message-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:#141c1673;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.message-modal{width:100%;max-width:420px;border-radius:14px;background:#fff;box-shadow:0 16px 48px #0000002e;overflow:hidden}.message-modal__head{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-card)}.message-modal__head h3{margin:0;font-size:1rem;font-weight:700;color:var(--color-text)}.message-modal__close{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border:none;border-radius:8px;background:transparent;color:var(--color-text-muted);font-size:1.35rem;line-height:1;cursor:pointer}.message-modal__close:hover{background:var(--color-border);color:var(--color-text)}.message-form--modal{padding:1rem 1rem 1.15rem}@media (max-width: 600px){.bubble-wall{min-height:auto!important;height:auto!important;padding-bottom:.75rem}.bubble-card{position:relative!important;left:0!important;top:auto!important;width:100%!important;max-width:none!important;margin-bottom:.65rem;transform:none!important}.bubble-card:hover{transform:scale(1.01)!important}}.message-form{display:flex;flex-direction:column;gap:.75rem}.message-form textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:8px;font-size:.95rem;resize:vertical}.message-form textarea:focus{outline:none;border-color:var(--color-primary)}.message-form button{padding:.6rem 1.25rem;border:none;border-radius:8px;background:var(--color-primary);color:#fff;font-size:.95rem}.message-form button:disabled{opacity:.6;cursor:not-allowed}.admin-view{max-width:700px}.admin-list{list-style:none}.admin-item{padding:1rem;background:#fff;border-radius:8px;margin-bottom:.75rem;box-shadow:0 1px 4px #0000000f}.admin-meta{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.5rem}.admin-nickname{font-weight:600;color:var(--color-text)}.admin-attr{margin-left:.25rem}.admin-time{margin-left:.75rem;font-size:.8rem}.admin-content{font-size:.95rem;line-height:1.5;margin-bottom:.5rem}.admin-actions{display:flex;gap:.5rem}.admin-actions button{padding:.35rem .75rem;font-size:.85rem;border:1px solid var(--color-border);border-radius:6px;background:#fff}.admin-actions button.btn-delete{border-color:#c44;color:#c44}.admin-actions button.btn-delete:hover{background:#c44;color:#fff}.messages-page .empty-hint{padding:2rem;text-align:center;color:var(--color-text-muted)}.search-page{padding:1.5rem}.search-hint{color:var(--color-text-muted);margin-top:.5rem}.search-loading{padding:2rem;text-align:center;color:var(--color-text-muted)}.search-results{margin-top:1.5rem}.result-section{margin-bottom:2rem}.result-section h2{font-size:1.1rem;margin-bottom:1rem;color:var(--color-text-muted)}.result-section ul{list-style:none}.result-section li{margin-bottom:.75rem}.result-section a{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:8px;transition:background .2s}.result-section a:hover{background:#f5f5f5}.result-section img{width:48px;height:48px;object-fit:cover;border-radius:4px}.search-page .empty-hint{padding:3rem;text-align:center;color:var(--color-text-muted)}.profile-page{padding:1.5rem;max-width:520px}.profile-lead{margin:0 0 1.25rem;font-size:.9rem;line-height:1.65;color:var(--color-text-muted)}.profile-lead strong{color:var(--color-text);font-weight:600}.profile-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem 1.35rem;display:flex;flex-direction:column;gap:1rem}.profile-field{display:flex;flex-direction:column;gap:.35rem}.profile-field label{font-size:.85rem;font-weight:600;color:var(--color-text)}.profile-field input{padding:.55rem .65rem;border:1px solid var(--color-border);border-radius:8px;font-size:.95rem}.profile-field input:focus{outline:none;border-color:var(--color-primary)}.profile-field--readonly input{background:var(--color-bg);color:var(--color-text-muted)}.profile-hint{font-size:.78rem;color:var(--color-text-muted)}.profile-msg{margin:0;font-size:.88rem}.profile-msg--ok{color:var(--color-primary-dark)}.profile-msg--err{color:#c45c5c}.profile-actions{margin-top:.25rem}.profile-save{padding:.55rem 1.35rem;border:none;border-radius:8px;background:var(--color-primary);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer}.profile-save:hover:not(:disabled){background:var(--color-primary-dark)}.profile-save:disabled{opacity:.65;cursor:not-allowed}.admin-page{background:#fff;border:1px solid #e9edf3;border-radius:10px;padding:1rem}.admin-page h1{font-size:1.1rem;margin-bottom:.75rem}.admin-page-desc{color:#666;font-size:.88rem;margin:-.35rem 0 .85rem}.admin-tag{display:inline-block;margin-left:.4rem;padding:.1rem .45rem;font-size:.72rem;border-radius:4px;vertical-align:middle}.admin-tag--ok{background:#e6f7e6;color:#2d7a2d}.quiz-admin-question{max-width:300px;line-height:1.4}.admin-toolbar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.admin-toolbar input,.admin-toolbar select,.admin-toolbar textarea{border:1px solid #d9d9d9;border-radius:6px;padding:.4rem .6rem;background:#fff}.admin-toolbar button{border:1px solid #d9d9d9;border-radius:6px;padding:.4rem .75rem;background:#fff}.admin-toolbar button.primary{background:#1677ff;color:#fff;border-color:#1677ff}.admin-page button.primary{background:#1677ff;color:#fff;border:1px solid #1677ff;border-radius:6px;padding:.4rem .85rem;font-size:.9rem;cursor:pointer}.admin-page button.primary:hover:not(:disabled){background:#0958d9;border-color:#0958d9}.admin-page button.primary:disabled{opacity:.6;cursor:not-allowed}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th,.admin-table td{border-bottom:1px solid #eef1f5;text-align:left;padding:.55rem .45rem;vertical-align:top}.admin-table th{background:#fafbfc;color:#415166}.admin-actions{display:flex;gap:.4rem;flex-wrap:wrap}.admin-empty{color:#7f8ea3;padding:1rem 0}.admin-kpis{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));margin-bottom:.9rem}.admin-kpi{border:1px solid #e8ecf3;background:#fafcff;border-radius:8px;padding:.8rem}.admin-kpi .label{font-size:.82rem;color:#6c7c93}.admin-kpi .value{margin-top:.4rem;font-size:1.25rem;font-weight:600}.thumb-40{width:40px;height:40px;object-fit:cover;border-radius:6px}.admin-chart-grid{display:grid;gap:.75rem;grid-template-columns:repeat(2,minmax(240px,1fr))}.admin-chart-card{border:1px solid #e8ecf3;border-radius:8px;background:#fff;padding:.4rem}.admin-chart-card-full{grid-column:1 / -1}@media (max-width: 900px){.admin-chart-grid{grid-template-columns:1fr}.admin-chart-card-full{grid-column:auto}}.form-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1300;background:#0006;display:flex;align-items:center;justify-content:center;padding:1rem}.form-modal{width:100%;max-width:560px;background:#fff;border-radius:10px;border:1px solid #e9edf3;box-shadow:0 8px 30px #00000029}.form-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid #edf1f6}.form-modal-header h3{margin:0;font-size:1rem}.form-modal-header button{border:1px solid #d9d9d9;border-radius:6px;background:#fff;padding:.28rem .65rem}.form-modal-body{padding:.9rem 1rem;display:grid;gap:.7rem}.form-modal-field{display:grid;gap:.35rem}.form-modal-field span{font-size:.85rem;color:#506279}.form-modal-field input,.form-modal-field textarea,.form-modal-field select{border:1px solid #d9d9d9;border-radius:6px;padding:.45rem .6rem;font-size:.9rem}.form-modal-field textarea{min-height:88px;resize:vertical}.form-modal-actions{display:flex;justify-content:flex-end;gap:.55rem;margin-top:.35rem}.form-modal-actions button{border:1px solid #d9d9d9;border-radius:6px;background:#fff;padding:.4rem .8rem}.form-modal-actions .primary{background:#1677ff;border-color:#1677ff;color:#fff}.upload-action{display:inline-flex;align-items:center}.upload-action input{display:none}.upload-action span{border:1px solid #d9d9d9;border-radius:6px;background:#fff;padding:.4rem .8rem;font-size:.9rem;cursor:pointer}.admin-pagination{margin-top:.8rem;display:flex;justify-content:flex-end;align-items:center;gap:.55rem}.admin-pagination button{border:1px solid #d9d9d9;border-radius:6px;background:#fff;padding:.35rem .75rem}.admin-pagination button:disabled{opacity:.5;cursor:not-allowed}.admin-pagination span{font-size:.88rem;color:#5b6b82}.carousel-admin-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.carousel-admin-head h1{margin:0;font-size:1.1rem}.carousel-edit-hint{margin:.35rem 0 0;font-size:.8rem;color:#888}.carousel-add-preview{border:1px dashed #d9d9d9;border-radius:8px;min-height:140px;display:flex;align-items:center;justify-content:center;background:#fafbfc;overflow:hidden}.carousel-add-preview img,.carousel-add-preview video{max-width:100%;max-height:220px;display:block;object-fit:contain}.carousel-add-preview__placeholder{margin:0;font-size:.88rem;color:#7f8ea3;padding:1rem;text-align:center}.timeline-manage-table{table-layout:fixed;width:100%}.timeline-manage-table th,.timeline-manage-table td{overflow:hidden;vertical-align:middle}.timeline-manage-table th:nth-child(1),.timeline-manage-table td:nth-child(1){width:52px}.timeline-manage-table th:nth-child(2),.timeline-manage-table td:nth-child(2){width:112px}.timeline-manage-table th:nth-child(3),.timeline-manage-table td:nth-child(3){width:72px}.timeline-manage-table th:nth-child(4),.timeline-manage-table td:nth-child(4){width:20%}.timeline-manage-table th:nth-child(5),.timeline-manage-table td:nth-child(5){width:34%;min-width:0}.timeline-manage-table th:nth-child(6),.timeline-manage-table td:nth-child(6){width:104px;overflow:visible;white-space:normal}.timeline-manage-table td.tm-cell-blocks{text-align:center;vertical-align:middle}.tm-blocks-link{display:inline-flex;align-items:center;justify-content:center;padding:.32rem .7rem;font-size:.78rem;font-weight:600;line-height:1.2;border-radius:6px;text-decoration:none;color:#fff!important;background:#1677ff;border:1px solid #1677ff;box-shadow:0 1px 2px #1677ff40;white-space:nowrap;transition:background .15s,border-color .15s,box-shadow .15s}.tm-blocks-link:hover{background:#4096ff;border-color:#4096ff;box-shadow:0 2px 6px #1677ff59}.tm-blocks-link:focus-visible{outline:2px solid #69b1ff;outline-offset:2px}.timeline-manage-table th:nth-child(7),.timeline-manage-table td:nth-child(7){width:148px;overflow:visible;white-space:normal}.timeline-manage-table .tm-ellipsis{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timeline-manage-table td:nth-child(7) .admin-actions{flex-wrap:wrap}.admin-page.timeline-blocks-page{width:auto;max-width:none;margin:-1rem;padding:1rem 1.25rem 1.5rem;box-sizing:border-box;border-radius:0;border-left:none;border-right:none}.blocks-back-line{margin:0 0 .35rem}.blocks-back-line a{color:#1677ff;font-size:.9rem}.blocks-back-line a:hover{text-decoration:underline}.blocks-page-top{margin-bottom:1rem;width:100%}.blocks-page-intro h1{margin:.2rem 0 .35rem;font-size:1.25rem}@media (min-width: 880px){.blocks-page-top{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem 1.5rem}.blocks-page-toolbar{flex:1;min-width:min(100%,420px);max-width:640px;margin-top:0!important;margin-bottom:0!important}}.blocks-sections-grid{display:grid;width:100%;grid-template-columns:repeat(auto-fit,minmax(min(100%,420px),1fr));gap:1rem 1.25rem;justify-items:stretch;align-items:stretch}.blocks-sections-grid>.blocks-card{width:100%;min-width:0}.timeline-blocks-sub{color:#5a6472;margin-bottom:.75rem;font-size:.9rem}.timeline-blocks-toolbar{display:flex;flex-wrap:wrap;gap:.65rem;align-items:stretch;margin-top:.75rem;margin-bottom:0}.timeline-blocks-toolbar .blocks-input-grow{flex:1;min-width:200px}.blocks-card{margin-top:0;width:100%;min-width:0;box-sizing:border-box;padding:1.15rem 1.25rem 1.35rem;border:1px solid #e4e9f0;border-radius:12px;background:#fafbfd;box-shadow:0 1px 2px #0f172a0a}.blocks-card-title{font-size:1.05rem;font-weight:600;margin:0 0 1rem;color:#1f2937;padding-bottom:.65rem;border-bottom:1px solid #e8ecf3}.blocks-row{display:flex;flex-wrap:wrap;gap:.65rem;align-items:flex-end;margin-bottom:1rem}.blocks-row-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.blocks-field{display:flex;flex-direction:column;gap:.3rem;min-width:0}.blocks-field--grow{flex:1;min-width:140px}.blocks-field label,.blocks-label{font-size:.78rem;font-weight:500;color:#64748b}.blocks-input,.blocks-textarea{border:1px solid #d1d9e6;border-radius:8px;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;background:#fff;color:#1e293b;transition:border-color .15s,box-shadow .15s}.blocks-input:focus,.blocks-textarea:focus{outline:none;border-color:#1677ff;box-shadow:0 0 0 2px #1677ff1f}.blocks-textarea{width:100%;min-height:120px;resize:vertical;line-height:1.55}.blocks-textarea--compact{min-height:100px}.blocks-field--mt{margin-top:.75rem}.blocks-field--mt-sm{margin-top:.5rem}.blocks-add-forms{display:grid;width:100%;grid-template-columns:1fr;gap:1rem 1.25rem;margin-top:.75rem;box-sizing:border-box}@media (min-width: 780px){.blocks-add-forms{grid-template-columns:repeat(2,minmax(0,1fr))}}.blocks-add-col{min-width:0}.blocks-add-col .blocks-section-h{margin-top:0;margin-bottom:.5rem}.blocks-input--narrow{width:88px}.blocks-btn{border:1px solid #d1d9e6;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-family:inherit;background:#fff;color:#334155;cursor:pointer;transition:background .15s,border-color .15s}.blocks-btn:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.blocks-btn:disabled{opacity:.55;cursor:not-allowed}.blocks-btn--primary{background:#1677ff;border-color:#1677ff;color:#fff}.blocks-btn--primary:hover:not(:disabled){background:#4096ff;border-color:#4096ff}.blocks-btn--danger{border-color:#ffa39e;color:#cf1322;background:#fff5f5}.blocks-btn--danger:hover:not(:disabled){background:#fff1f0;border-color:#ff7875}.blocks-btn--ghost{background:transparent}.blocks-section-h{font-size:.88rem;font-weight:600;color:#475569;margin:1.1rem 0 .65rem}.blocks-form-block{width:100%;box-sizing:border-box;padding:.85rem 1rem;margin-top:.65rem;border-radius:10px;background:#fff;border:1px solid #e8ecf3}.blocks-form-block+.blocks-form-block{margin-top:.85rem}.blocks-form-grid{display:grid;gap:.75rem}@media (min-width: 640px){.blocks-form-grid--2{grid-template-columns:1fr 1fr}}.blocks-file-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.blocks-file-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.45rem .9rem;font-size:.82rem;border-radius:8px;border:1px dashed #94a3b8;background:#f8fafc;color:#475569;cursor:pointer}.blocks-file-btn:hover{border-color:#1677ff;color:#1677ff;background:#f0f7ff}.blocks-file-btn input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.blocks-file-hint{font-size:.78rem;color:#94a3b8}.blocks-table-wrap{width:100%;overflow-x:auto;border:1px solid #e8ecf3;border-radius:10px;background:#fff;box-sizing:border-box}.blocks-table{width:100%;border-collapse:collapse;font-size:.875rem}.blocks-table th,.blocks-table td{padding:.55rem .65rem;text-align:left;border-bottom:1px solid #eef1f5;vertical-align:middle}.blocks-table th{background:#f8fafc;color:#64748b;font-weight:600;font-size:.8rem}.blocks-table tr:last-child td{border-bottom:none}.blocks-thumb{width:40px;height:40px;object-fit:cover;border-radius:6px;background:#e2e8f0}.blocks-table-actions{display:flex;flex-wrap:wrap;gap:.4rem}.blocks-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:1.5rem 1rem;overflow-y:auto}.blocks-modal{width:100%;max-width:520px;margin-top:2vh;padding:1.25rem 1.35rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 12px 40px #00000026}.blocks-modal h4{margin:0 0 1rem;font-size:1rem;color:#0f172a}.blocks-modal-footer{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;margin-top:1.15rem;padding-top:1rem;border-top:1px solid #eef1f5}.messages-audit__table{table-layout:fixed;width:100%}.messages-audit__col-id{width:4%}.messages-audit__col-user{width:10%}.messages-audit__col-attr{width:9%}.messages-audit__col-content{width:32%}.messages-audit__col-status{width:9%}.messages-audit__col-time{width:16%}.messages-audit__col-actions{width:20%}.messages-audit__table th,.messages-audit__table td{height:3rem;max-height:3rem;vertical-align:middle;overflow:hidden}.messages-audit__ellipsis,.messages-audit__content{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}.messages-audit__content{cursor:default}.messages-audit__table td:last-child{max-width:none;overflow:visible;white-space:normal}.messages-audit .admin-actions{align-items:center;flex-wrap:nowrap;white-space:nowrap}.messages-audit .admin-actions button{border-radius:6px;padding:.38rem .8rem;font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid transparent}.messages-audit .btn-pass{background:#1677ff;color:#fff;border-color:#1677ff}.messages-audit .btn-pass:hover:not(:disabled){background:#0958d9;border-color:#0958d9}.messages-audit .btn-pass:disabled{background:#adcfff;color:#f0f7ff;border-color:#adcfff;cursor:not-allowed;opacity:1}.messages-audit .btn-reject{background:#fa8c16;color:#fff;border-color:#fa8c16}.messages-audit .btn-reject:hover:not(:disabled){background:#d46b08;border-color:#d46b08}.messages-audit .btn-reject:disabled{background:#ffd8b8;color:#fff;border-color:#ffd8b8;cursor:not-allowed}.messages-audit .btn-del{background:#fff;color:#cf1322;border-color:#ffccc7}.messages-audit .btn-del:hover{background:#fff1f0;border-color:#ff7875}.messages-audit__status{display:inline-block;padding:.18rem .55rem;border-radius:4px;font-size:.8rem;font-weight:500;white-space:nowrap}.messages-audit__status--pending{background:#fff7e6;color:#d46b08;border:1px solid #ffd591}.messages-audit__status--approved{background:#f6ffed;color:#389e0d;border:1px solid #b7eb8f}.messages-audit__status--rejected{background:#fff1f0;color:#cf1322;border:1px solid #ffa39e}:root{--color-primary: #7ba872;--color-primary-dark: #6a9762;--color-primary-light: #9bc491;--color-bg: #f5f2ed;--color-bg-card: #fff;--color-text: #3d3a35;--color-text-muted: #5a564d;--color-border: #e8e4dc;--color-matcha: #a8c69f;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}
