:root{
  --bg:#f8fafc;
  --card:#ffffff;
  --text:#1e293b;
  --muted:#64748b;
  --line:#e2e8f0;
  --primary:#6366f1;
  --primary2:#ec4899;
  --shadow:0 10px 30px -10px rgba(0,0,0,.08);
  --radius:16px;
  --bar-bg:rgba(255,255,255,.8);
  --soft:#f1f5f9;
  --soft2:#e2e8f0;
  --table-head:#f8fafc;
  --tip-bg:#0f172a;
  --tip-text:#f8fafc;
}
html[data-theme="dark"]{
  --bg:#0f172a;
  --card:#1e293b;
  --text:#f1f5f9;
  --muted:#94a3b8;
  --line:rgba(255,255,255,.08);
  --shadow:0 10px 30px -10px rgba(0,0,0,.4);
  --bar-bg:rgba(15,23,42,.8);
  --soft:rgba(255,255,255,.05);
  --soft2:rgba(255,255,255,.1);
  --table-head:rgba(255,255,255,.03);
  --tip-bg:#f8fafc;
  --tip-text:#0f172a;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
pre{max-width:100%;overflow:auto;-webkit-overflow-scrolling:touch}
body.is-modal-open{overflow:hidden}
.wrap{display:flex;min-height:100vh}
.sidebar{
  position:sticky;top:0;height:100vh;width:240px;background:#2f3437;color:#fff;display:flex;flex-direction:column;
  padding:12px;gap:10px;transition:width .28s cubic-bezier(.2,.8,.2,1)
}
.side-mask{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
  z-index:55
}
.wrap.sidebar-open .side-mask{opacity:1;pointer-events:auto}
.side-head{display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:6px 6px}
.side-brand{display:flex;align-items:center;gap:12px;min-width:0;min-height:56px}
.brand-logo{
  width:46px;height:46px;border-radius:14px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.20);
  display:flex;align-items:center;justify-content:center;font-weight:700;flex:none;
  box-shadow:0 10px 22px rgba(0,0,0,.20)
}
.brand-logo img{width:100%;height:100%;object-fit:cover;border-radius:14px;display:block}
.brand-text{display:flex;align-items:center;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:230px;opacity:1;transform:translateX(0);transition:max-width .22s ease,opacity .18s ease,transform .18s ease}
.brand-text img{height:34px;width:auto;display:block}

[data-app="front"] .topbar .top-left > img,
[data-app="front"] .topbar .top-title{display:none!important}
.side-nav{display:flex;flex-direction:column;gap:0;overflow:auto;overscroll-behavior:contain;padding-right:0;scrollbar-width:none;-ms-overflow-style:none}
.side-nav::-webkit-scrollbar{width:0;height:0}
.side-group{display:flex;flex-direction:column;gap:0}
.side-item{
  height:44px;border-radius:10px;display:flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.86);background:transparent;border:0;padding:0 12px;cursor:pointer;
  transition:background .18s ease,color .18s ease
}
.side-item.active{color:#fff;font-weight:700}
.side-item:hover{
  background:linear-gradient(90deg,rgba(255,90,95,.24),rgba(255,90,95,0));
  color:#fff
}
.side-item.active{
  background:linear-gradient(90deg,rgba(255,90,95,.30),rgba(255,90,95,0));
  box-shadow:inset 3px 0 0 rgba(255,90,95,.92)
}
.side-ico{width:28px;display:flex;align-items:center;justify-content:center;flex:none}
.side-tag{
  width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.86);
  box-shadow:0 8px 18px rgba(0,0,0,.18)
}
.side-item:hover .side-tag,
.side-item.active .side-tag{
  background:rgba(255,90,95,.14);
  border-color:rgba(255,90,95,.22);
  color:rgba(255,90,95,.98)
}
.side-tag img{width:100%;height:100%;object-fit:cover;border-radius:8px;display:block}
.side-tag svg{display:block;width:100%;height:100%}
.side-tag i{display:block;font-size:16px;line-height:1}
.theme-swap .icon-dark{display:none}
[data-theme="dark"] .theme-swap .icon-light{display:none}
[data-theme="dark"] .theme-swap .icon-dark{display:block}
.side-txt{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;opacity:1;transform:translateX(0);transition:max-width .22s ease,opacity .18s ease,transform .18s ease}
.side-arrow{margin-left:auto;width:22px;height:22px;border-radius:999px;display:flex;align-items:center;justify-content:center;opacity:.60;transition:background .18s ease,opacity .18s ease}
.side-arrow:before{content:"";width:6px;height:6px;border-right:2px solid rgba(255,255,255,.62);border-bottom:2px solid rgba(255,255,255,.62);transform:rotate(-45deg);transition:transform .18s ease,border-color .18s ease}
.side-parent:hover .side-arrow{background:rgba(255,255,255,.06);opacity:.78}
.side-parent:hover .side-arrow:before{border-color:rgba(255,255,255,.78)}
.side-parent.is-open .side-arrow:before{transform:rotate(45deg)}
.side-divider{height:1px;max-height:1px;background:rgba(255,255,255,.10);margin:6px 0;opacity:1;transition:opacity .18s ease,max-height .22s ease,margin .22s ease}
.side-sub{
  margin:0;padding:0 12px 0 40px;border-left:0;
  max-height:0;
  overflow:hidden;opacity:0;transform:translateY(-6px);transform-origin:top;
  transition:max-height .26s cubic-bezier(.2,.8,.2,1),opacity .20s ease,margin .22s ease,transform .26s cubic-bezier(.2,.8,.2,1)
}
.side-sub.is-open{margin:4px 0 10px 0;opacity:1;transform:translateY(0);max-height:999px}
.side-sub.is-open.is-closing{margin:0;opacity:0;transform:translateY(-6px);transform-origin:bottom}
.side-sub-inner{overflow:hidden;display:flex;flex-direction:column;gap:4px}
.side-sub-item{
  height:34px;border-radius:10px;display:flex;align-items:center;gap:8px;
  color:rgba(255,255,255,.72);padding:0 4px;border:0;background:transparent;
  transition:color .18s ease,background .18s ease,box-shadow .18s ease
}
.side-sub-item:hover{
  color:#fff;
  background:rgba(255,90,95,.18)
}
.side-sub-item.active{
  color:#fff;
  font-weight:700;
  background:rgba(255,90,95,.22)
}
.side-sub-item.active{box-shadow:inset 2px 0 0 rgba(255,90,95,.92)}
.side-sub{scroll-margin-top:72px}
.side-sub-dot{display:none}
.side-sub-txt{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-spacer{flex:1}
.wrap.sidebar-collapsed .sidebar{width:76px}
.wrap.sidebar-collapsed .brand-logo{width:44px;height:44px;border-radius:14px}
.wrap.sidebar-collapsed .brand-logo img{border-radius:14px}
.wrap.sidebar-collapsed .brand-text{max-width:0;opacity:0;transform:translateX(-6px)}
.wrap.sidebar-collapsed .side-nav{padding-right:0}
.wrap.sidebar-collapsed .side-txt{max-width:0;opacity:0;transform:translateX(-6px)}
.wrap.sidebar-collapsed .side-arrow{display:none}
.wrap.sidebar-collapsed .side-divider{max-height:0;opacity:0;margin:0}
.wrap.sidebar-collapsed .side-sub{max-height:0 !important;opacity:0;margin:0;padding:0;border-left-color:transparent}
.side-flyout{
  position:fixed;left:0;top:0;z-index:90;
  background:#2f3437;color:#fff;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  box-shadow:0 22px 70px rgba(0,0,0,.42);
  padding:10px;
  min-width:200px;
  opacity:0;
  transform:translate3d(-6px,0,0) scale(.985);
  transition:opacity .14s ease,transform .14s ease;
  pointer-events:none;
  will-change:transform,opacity
}
.side-flyout.is-show{opacity:1;transform:translate3d(0,0,0) scale(1);pointer-events:auto}
.side-flyout:after{
  content:"";
  position:absolute;left:-7px;top:calc(var(--arrow-top,22px) - 7px);
  border:7px solid transparent;border-right-color:rgba(255,255,255,.10)
}
.side-flyout:before{
  content:"";
  position:absolute;left:-6px;top:calc(var(--arrow-top,22px) - 6px);
  border:6px solid transparent;border-right-color:#2f3437
}
.side-flyout.is-tip{min-width:auto;padding:10px 12px}
.side-flyout-tip{font-size:12px;font-weight:900;letter-spacing:.2px;white-space:nowrap}
.side-flyout-hd{
  font-size:12px;font-weight:900;letter-spacing:.2px;
  color:rgba(255,255,255,.92);
  padding:2px 6px 8px 6px;
  max-width:260px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.side-flyout-bd{
  display:flex;flex-direction:column;gap:4px;
  max-height:min(320px,calc(100vh - 16px));
  overflow:auto;
  padding-right:2px
}
.side-flyout .side-sub-item{height:34px;padding:0 10px;border-radius:10px}
.wrap.sidebar-collapsed .side-item.is-fly-active{
  background:linear-gradient(90deg,rgba(255,90,95,.24),rgba(255,90,95,0));
  color:#fff
}
.main{flex:1;min-width:0;min-height:100vh;display:flex;flex-direction:column}
.main-body{flex:1;min-width:0}
.topbar{
  height:56px;display:flex;align-items:center;justify-content:flex-start;gap:12px;padding:0 18px;border-bottom:1px solid var(--line);background:var(--bar-bg);backdrop-filter:blur(10px);position:sticky;top:0;z-index:20
}
.is-home .topbar,
.is-hero .topbar{
  background:transparent;
  border-bottom-color:transparent;
  backdrop-filter:none;
  margin-bottom:-56px
}
.is-home.is-top-solid .topbar,
.is-hero.is-top-solid .topbar{
  background:var(--bar-bg);
  backdrop-filter:blur(10px)
}
.is-home.is-top-solid .topbar:after,
.is-hero.is-top-solid .topbar:after{
  content:"";
  position:absolute;left:0;right:0;bottom:0;
  height:2px;
  background:linear-gradient(90deg,rgba(255,90,95,.95),rgba(124,77,255,.90));
  pointer-events:none
}
.is-home .burger{width:24px;height:24px}
.is-home .burger span{height:3px;border-radius:3px}
.is-home .top-actions .btn,
.is-hero .top-actions .btn{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.16);
  color:rgba(255,255,255,.92);
  box-shadow:0 10px 26px rgba(0,0,0,.22)
}
.is-home.is-top-solid .top-actions .btn,
.is-hero.is-top-solid .top-actions .btn{
  background:var(--card);
  border-color:var(--line);
  color:var(--text);
  box-shadow:0 10px 24px rgba(0,0,0,.06)
}
.is-home .top-actions .btn:hover,
.is-hero .top-actions .btn:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.22);
  color:#fff
}
.is-home.is-top-solid .top-actions .btn:hover,
.is-hero.is-top-solid .top-actions .btn:hover{
  background:rgba(255,90,95,.06);
  border-color:rgba(255,90,95,.35);
  color:var(--text)
}
.is-home .top-capsule,
.is-hero .top-capsule{
  color:rgba(255,255,255,.92);
  background:transparent
}
.is-home.is-top-solid .top-capsule,
.is-hero.is-top-solid .top-capsule{
  color:var(--text)
}
.is-home .top-capsule:hover,
.is-hero .top-capsule:hover{
  background:rgba(255,255,255,.10);
  color:#fff;
  text-decoration:none
}
.is-home.is-top-solid .top-capsule:hover,
.is-hero.is-top-solid .top-capsule:hover{
  background:rgba(255,90,95,.06);
  color:var(--text)
}
.is-home .top-toggle,
.is-hero .top-toggle{color:rgba(255,255,255,.92)}
.is-home.is-top-solid .top-toggle,
.is-hero.is-top-solid .top-toggle{color:var(--text)}
.is-home .top-toggle:hover,
.is-hero .top-toggle:hover{color:#fff}
.is-home.is-top-solid .top-toggle:hover,
.is-hero.is-top-solid .top-toggle:hover{color:var(--primary)}
.top-left{display:flex;align-items:center;gap:12px;min-width:0}
.top-capsules{
  display:flex;
  align-items:center;
  gap:0;
  min-width:0;
  height:56px;
  box-sizing:border-box;
  padding:0;
  overflow-x:auto;
  overflow-y:hidden;
  max-width:520px;
  -ms-overflow-style:none;
  scrollbar-width:none
}
.top-capsules::-webkit-scrollbar{width:0;height:0}
.top-capsule{
  height:38px;
  padding:0 10px;
  border-radius:0;
  border:0;
  background:transparent;
  color:var(--text);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  max-width:280px;
  position:relative;
  transition:background .16s ease,color .16s ease,transform .16s ease
}
.top-capsules .top-capsule{padding:0 12px}
.top-capsules .top-capsule:not(:first-child){
  border-left:1px solid var(--line)
}
.top-capsule:after{
  content:"";
  position:absolute;left:12px;right:12px;bottom:7px;height:2px;
  background:linear-gradient(90deg,rgba(255,90,95,.95),rgba(124,77,255,.90));
  transform:scaleX(0);
  transform-origin:left;
  opacity:.0;
  transition:transform .16s ease,opacity .16s ease
}
.top-capsule:hover{background:rgba(255,90,95,.06);color:var(--text)}
.top-capsule:hover:after{transform:scaleX(1);opacity:1}
.top-capsule:active{transform:translateY(0)}
.top-capsule:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.18)}
.top-capsule-ico{width:18px;height:18px;border-radius:6px;flex:none}
img.top-capsule-ico{display:block}
span.top-capsule-ico{display:flex;align-items:center;justify-content:center}
.top-capsule-ico-light,.top-capsule-ico-dark{width:18px;height:18px;display:block}
.top-capsule-ico svg{width:18px;height:18px;display:block}
.top-capsule-ico-light{display:none}
.is-home:not(.is-top-solid) .top-capsule-ico-light,
.is-hero:not(.is-top-solid) .top-capsule-ico-light{display:block}
.is-home:not(.is-top-solid) .top-capsule-ico-dark,
.is-hero:not(.is-top-solid) .top-capsule-ico-dark{display:none}
.top-capsule-txt{font-size:13px;font-weight:900;letter-spacing:.1px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-capsule-arr{
  font-size:14px;
  font-weight:1000;
  opacity:.55;
  transform:translateX(-2px);
  transition:opacity .18s ease,transform .18s ease;
  margin-left:-2px
}
.top-capsule:hover .top-capsule-arr{opacity:.85;transform:translateX(0)}
.top-toggle{
  border:0;background:transparent;color:inherit;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  width:44px;height:44px;
  padding:0;margin:0;border-radius:14px;
  transition:transform .16s ease,color .18s ease,background .18s ease
}
.top-toggle:hover{color:var(--primary);background:rgba(255,90,95,.06)}
.top-toggle:active{transform:scale(.96)}
.burger{
  width:24px;height:24px;
  display:flex;flex-direction:column;
  align-items:flex-start;justify-content:center;
  gap:5px
}
.burger span{
  height:3px;border-radius:3px;background:currentColor;display:block;
  will-change:width;
  transition-property:width;
  transition-duration:720ms;
  transition-timing-function:cubic-bezier(.2,.85,.2,1)
}
.burger .b1{width:22px;transition-delay:0ms}
.burger .b2{width:16px;transition-delay:150ms}
.burger .b3{width:11px;transition-delay:300ms}
.wrap.sidebar-collapsed .top-toggle .burger span{width:22px}

@media (prefers-reduced-motion: reduce){
  .burger span{transition:none}
  .top-toggle{transition:none}
}

.top-weather{position:relative;display:flex;align-items:center}
.top-weather-btn{
  height:36px;display:inline-flex;align-items:center;gap:6px;
  padding:0 12px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);color:var(--text);cursor:pointer;
  white-space:nowrap;max-width:240px;overflow:hidden;
  transition:transform .12s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease
}
.top-weather-loc{font-weight:900;font-size:13px;flex:none;letter-spacing:.1px}
.top-weather-sep{opacity:.65;flex:none}
.top-weather-brief{font-size:13px;color:var(--text);opacity:.72;font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis}
.top-weather-btn:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.35);box-shadow:0 10px 24px rgba(0,0,0,.06)}
.top-weather-btn:active{transform:translateY(0)}
.is-home .top-weather-btn,
.is-hero .top-weather-btn{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.16);
  color:rgba(255,255,255,.92);
  box-shadow:0 10px 26px rgba(0,0,0,.22)
}
.is-home.is-top-solid .top-weather-btn,
.is-hero.is-top-solid .top-weather-btn{
  background:var(--card);
  border-color:var(--line);
  color:var(--text);
  box-shadow:0 10px 24px rgba(0,0,0,.06)
}
.is-home .top-weather-brief,
.is-hero .top-weather-brief{color:rgba(255,255,255,.92);opacity:.88}
.is-home.is-top-solid .top-weather-brief,
.is-hero.is-top-solid .top-weather-brief{color:var(--text);opacity:.72}
.is-home .top-weather-btn:hover,
.is-hero .top-weather-btn:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.22);
  color:#fff
}
.is-home.is-top-solid .top-weather-btn:hover,
.is-hero.is-top-solid .top-weather-btn:hover{
  background:var(--card);
  border-color:rgba(255,90,95,.35);
  color:var(--text)
}

.top-music{position:relative;display:none;align-items:center}
.top-music.is-on{display:flex}
.top-music-btn{
  height:36px;display:flex;align-items:center;gap:8px;
  padding:0 10px 0 6px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);color:var(--text);cursor:pointer;
  white-space:nowrap;max-width:280px;overflow:hidden;
  transition:transform .12s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease
}
.top-music-btn:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.35);box-shadow:0 10px 24px rgba(0,0,0,.06)}
.top-music-btn:active{transform:translateY(0)}
.top-music-cover{width:26px;height:26px;border-radius:999px;flex:none;object-fit:cover;background:var(--line);animation:miniRecordSpin 5.2s linear infinite;animation-play-state:paused}
.top-music.is-playing .top-music-cover{animation-play-state:running}
.top-music-meta{display:flex;flex-direction:column;min-width:0;line-height:1.05}
.top-music-name{font-weight:900;font-size:12px;min-width:0;overflow:hidden;text-overflow:ellipsis}
.top-music-singer{font-size:11px;opacity:.68;font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis}
.top-music-ctl{display:flex;align-items:center;justify-content:center;flex:none;margin-left:6px;opacity:.85}
.top-music-ico{display:none}
.top-music.is-playing .top-music-ico.is-pause{display:block}
.top-music:not(.is-playing) .top-music-ico.is-play{display:block}
.is-home .top-music-btn,
.is-hero .top-music-btn{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.16);
  color:rgba(255,255,255,.92);
  box-shadow:0 10px 26px rgba(0,0,0,.22)
}
.is-home.is-top-solid .top-music-btn,
.is-hero.is-top-solid .top-music-btn{
  background:var(--card);
  border-color:var(--line);
  color:var(--text);
  box-shadow:0 10px 24px rgba(0,0,0,.06)
}
.is-home .top-music-btn:hover,
.is-hero .top-music-btn:hover{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.22);
  color:#fff
}
.is-home.is-top-solid .top-music-btn:hover,
.is-hero.is-top-solid .top-music-btn:hover{
  background:var(--card);
  border-color:rgba(255,90,95,.35);
  color:var(--text)
}
@media (max-width:860px){
  .top-music-btn{max-width:180px}
  .top-music-singer{display:none}
  .top-capsule{max-width:180px}
}

.weather-pop{
  position:absolute;left:0;top:calc(100% + 10px);
  min-width:300px;width:max-content;max-width:min(400px,calc(100vw - 28px));
  padding:0;
  border-radius:24px;
  opacity:0;pointer-events:none;
  transform:translate3d(0,-6px,0);
  transition:opacity .16s ease,transform .16s ease;
  z-index:40
}
.top-weather:hover .weather-pop,
.top-weather:focus-within .weather-pop{opacity:1;pointer-events:auto;transform:translate3d(0,0,0)}

.weather-pop-inner{
  padding:20px 24px;
  border-radius:24px;
  background:linear-gradient(135deg, #60A5FA 0%, #2563EB 100%);
  color:#fff;
  box-shadow:0 24px 60px -12px rgba(37,99,235,0.35), 0 0 0 1px rgba(255,255,255,0.1) inset;
  position:relative;
  overflow:hidden;
}

/* Decoration */
.weather-fx{position:absolute;inset:0;overflow:hidden;border-radius:24px;pointer-events:none;z-index:0}
.weather-pop-inner .weather-fx{position:absolute;z-index:0}

/* Clouds */
.fx-cloud{
  position:absolute;background:#fff;border-radius:50%;opacity:0.55;
  filter:blur(6px);
  will-change:transform;
}
.fx-cloud::after{
  content:"";position:absolute;background:inherit;border-radius:inherit;
  width:80%;height:80%;top:-40%;right:-20%;
}
.fx-cloud::before{
  content:"";position:absolute;background:inherit;border-radius:inherit;
  width:60%;height:60%;top:-20%;left:-30%;
}
.fx-cloud-1{width:100px;height:40px;top:20px;right:-20px;animation:floatCloud 20s linear infinite}
.fx-cloud-2{width:80px;height:35px;top:60px;right:40px;opacity:0.2;animation:floatCloud 25s linear infinite reverse}

@keyframes floatCloud{
  0%{transform:translateX(0)}
  50%{transform:translateX(-40px)}
  100%{transform:translateX(0)}
}

/* Rain */
.fx-rain{display:none;position:absolute;inset:0}
.fx-rain i{
  position:absolute;background:rgba(255,255,255,0.5);width:2px;height:18px;
  top:-24px;transform:rotate(12deg);border-radius:2px;
  animation:rainDrop 0.85s linear infinite;
}
.fx-rain i:nth-child(1){left:6%;animation-duration:0.74s;animation-delay:0.1s}
.fx-rain i:nth-child(2){left:14%;animation-duration:0.92s;animation-delay:0.25s}
.fx-rain i:nth-child(3){left:22%;animation-duration:0.78s;animation-delay:0.02s}
.fx-rain i:nth-child(4){left:30%;animation-duration:0.86s;animation-delay:0.18s}
.fx-rain i:nth-child(5){left:38%;animation-duration:0.72s;animation-delay:0.34s}
.fx-rain i:nth-child(6){left:46%;animation-duration:0.98s;animation-delay:0.08s}
.fx-rain i:nth-child(7){left:54%;animation-duration:0.80s;animation-delay:0.29s}
.fx-rain i:nth-child(8){left:62%;animation-duration:0.90s;animation-delay:0.14s}
.fx-rain i:nth-child(9){left:70%;animation-duration:0.76s;animation-delay:0.22s}
.fx-rain i:nth-child(10){left:78%;animation-duration:0.88s;animation-delay:0.05s}
.fx-rain i:nth-child(11){left:86%;animation-duration:0.70s;animation-delay:0.31s}
.fx-rain i:nth-child(12){left:94%;animation-duration:0.94s;animation-delay:0.12s}

@keyframes rainDrop{
  0%{transform:translateY(0);opacity:0}
  10%{opacity:1}
  100%{transform:translateY(200px);opacity:0}
}

/* Snow */
.fx-snow{display:none;position:absolute;inset:0}
.fx-snow i{
  position:absolute;top:-14px;width:5px;height:5px;border-radius:50%;
  background:rgba(255,255,255,0.85);
  box-shadow:0 0 10px rgba(255,255,255,0.18);
  animation:snowFall 4.8s linear infinite;
}
.fx-snow i:nth-child(1){left:8%;width:4px;height:4px;opacity:.65;animation-duration:5.2s;animation-delay:0.1s}
.fx-snow i:nth-child(2){left:16%;width:6px;height:6px;opacity:.75;animation-duration:4.6s;animation-delay:0.9s}
.fx-snow i:nth-child(3){left:24%;width:4px;height:4px;opacity:.55;animation-duration:5.6s;animation-delay:0.4s}
.fx-snow i:nth-child(4){left:32%;width:5px;height:5px;opacity:.70;animation-duration:4.9s;animation-delay:1.3s}
.fx-snow i:nth-child(5){left:40%;width:3px;height:3px;opacity:.50;animation-duration:6.2s;animation-delay:0.6s}
.fx-snow i:nth-child(6){left:48%;width:6px;height:6px;opacity:.80;animation-duration:4.4s;animation-delay:1.7s}
.fx-snow i:nth-child(7){left:56%;width:4px;height:4px;opacity:.60;animation-duration:5.8s;animation-delay:0.2s}
.fx-snow i:nth-child(8){left:64%;width:5px;height:5px;opacity:.72;animation-duration:5.0s;animation-delay:1.1s}
.fx-snow i:nth-child(9){left:72%;width:3px;height:3px;opacity:.48;animation-duration:6.4s;animation-delay:0.8s}
.fx-snow i:nth-child(10){left:80%;width:6px;height:6px;opacity:.82;animation-duration:4.3s;animation-delay:1.9s}
.fx-snow i:nth-child(11){left:88%;width:4px;height:4px;opacity:.58;animation-duration:5.9s;animation-delay:0.3s}
.fx-snow i:nth-child(12){left:96%;width:5px;height:5px;opacity:.74;animation-duration:4.7s;animation-delay:1.5s}

@keyframes snowFall{
  0%{transform:translate3d(0,0,0);opacity:0}
  10%{opacity:1}
  100%{transform:translate3d(22px,220px,0);opacity:0}
}

/* Weather States */
.weather-pop-inner[data-weather-type="sunny"]{
  background:linear-gradient(135deg, #60A5FA 0%, #3B82F6 100%);
}
.weather-pop-inner[data-weather-type="cloudy"] .fx-cloud{opacity:0.6}
.weather-pop-inner[data-weather-type="rain"]{
  background:linear-gradient(135deg, #475569 0%, #334155 100%);
}
.weather-pop-inner[data-weather-type="rain"] .fx-cloud{background:#94a3b8;opacity:0.3}
.weather-pop-inner[data-weather-type="rain"] .fx-rain{display:block}
.weather-pop-inner[data-weather-type="snow"]{
  background:linear-gradient(135deg, #94a3b8 0%, #64748b 100%);
}
.weather-pop-inner[data-weather-type="snow"] .fx-snow{display:block}

html[data-theme="dark"] .weather-pop-inner[data-weather-type="sunny"]{
  background:linear-gradient(135deg, #1e3a8a 0%, #172554 100%);
}
html[data-theme="dark"] .weather-pop-inner[data-weather-type="rain"]{
  background:linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
}

.weather-pop-inner::before{
  content:"";position:absolute;top:-60px;right:-60px;width:180px;height:180px;
  background:radial-gradient(circle, rgba(255,255,255,0.15) 0%, rgba(255,255,255,0) 70%);
  border-radius:50%;pointer-events:none;
}

.weather-pop-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;position:relative;z-index:1}
.weather-pop-city{font-size:17px;font-weight:700;letter-spacing:0.5px;text-shadow:0 1px 2px rgba(0,0,0,0.1)}
.weather-pop-upd{font-size:12px;opacity:0.8;font-weight:500}

.weather-pop-main{display:flex;align-items:baseline;gap:12px;margin-bottom:20px;position:relative;z-index:1}
.weather-pop-temp{font-size:52px;font-weight:850;line-height:1;letter-spacing:-2px;text-shadow:0 2px 8px rgba(0,0,0,0.1)}
.weather-pop-now{font-size:18px;font-weight:600;opacity:0.95}

.weather-pop-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;position:relative;z-index:1}
.weather-item{
  background:rgba(255,255,255,0.12);
  padding:10px 14px;
  border-radius:14px;
  display:flex;flex-direction:column;gap:3px;
  backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,0.1);
}
.weather-label{font-size:11px;opacity:0.8;font-weight:600}
.weather-val{font-size:14px;font-weight:700}

.home-sections{margin-top:14px}
.is-home .home-sections{margin-top:-42px;position:relative;z-index:6;background:var(--bg)}
.is-hero .home-sections{margin-top:-42px;position:relative;z-index:6;background:var(--bg)}
.home-mod{background:transparent;border:0;box-shadow:none;margin-top:14px;scroll-margin-top:72px}
.home-mod-hd{display:flex;flex-direction:column;align-items:stretch;gap:8px;padding:10px 2px;border-bottom:0}
.home-mod-hd-top{display:flex;align-items:center;gap:12px}
.home-mod-title{display:flex;align-items:center;gap:10px;min-width:0}
.home-mod-name{font-weight:900;white-space:nowrap}
.home-mark{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:none;color:var(--text);opacity:.92}
.home-mark img{width:100%;height:100%;display:block}
.home-mark svg{display:block;width:100%;height:100%}
.sec-mark{width:14px;height:16px;display:inline-block;flex:none;background:linear-gradient(135deg,rgba(255,90,95,.95),rgba(124,77,255,.95));clip-path:polygon(0 0,100% 0,100% 100%,50% 76%,0 100%);border-radius:4px;filter:drop-shadow(0 8px 14px rgba(17,24,39,.10));position:relative}
.sec-mark:after{content:"";position:absolute;inset:1px;border-radius:3px;background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,0));clip-path:polygon(0 0,100% 0,100% 100%,50% 76%,0 100%);opacity:.95}
.home-mod-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}
.home-pill{height:28px;display:inline-flex;align-items:center;padding:0 12px;border-radius:999px;border:1px solid rgba(17,24,39,.10);background:rgba(17,24,39,.02);color:var(--muted);font-size:12px;transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}
.home-pill:hover{background:var(--card);border-color:rgba(255,90,95,.35);color:var(--text);box-shadow:0 10px 22px rgba(0,0,0,.06)}
.home-subtabs{display:inline-flex;flex-wrap:wrap;gap:6px;align-items:center;padding:4px;border-radius:999px;background:rgba(17,24,39,.06);border:1px solid rgba(17,24,39,.06);width:fit-content;max-width:100%;position:relative}
.home-subtabs-indicator{position:absolute;left:0;top:4px;height:28px;width:0;border-radius:999px;background:var(--primary);transform:translate3d(0,0,0);transition:opacity .14s ease;opacity:0;pointer-events:none}
.home-subtabs.is-ready .home-subtabs-indicator{opacity:1}
.home-subtab{height:28px;display:inline-flex;align-items:center;padding:0 12px;border-radius:999px;color:rgba(17,24,39,.82);font-size:12px;font-weight:700;white-space:nowrap;transition:background .18s ease,color .18s ease;position:relative;z-index:1}
.home-subtab:hover{color:rgba(17,24,39,.96)}
.home-subtab.is-active{background:var(--primary);color:#fff}
.home-subtabs.is-ready .home-subtab.is-active{background:transparent;color:rgba(17,24,39,.82)}
.home-subtabs.is-ready .home-subtab.is-current{color:#fff}
.home-subtabs.is-ready .home-subtab.is-hover:not(.is-current){color:rgba(17,24,39,.96)}
.home-mod-more{margin-left:auto;color:var(--muted);font-size:12px;white-space:nowrap}
.home-mod-more:hover{color:var(--text)}
.home-mod-actions{margin-left:auto;display:flex;gap:10px;align-items:center}
.home-mod-actions .home-mod-more{margin-left:0}
.home-mod-bd{padding:0 2px 12px 2px}
.site-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;position:relative}
.site-grid[hidden]{display:none !important}
.site-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.site-card{
  display:flex;align-items:center;gap:10px;height:62px;padding:0 12px;border-radius:6px;
  border:1px solid var(--line);background:var(--card);position:relative;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
  min-width:0;max-width:100%
}
.site-card:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.06)}
.site-ico{
  width:30px;height:30px;border-radius:999px;background:var(--soft);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none
}
.site-ico img{width:100%;height:100%;object-fit:cover}
.site-ico > span{font-size:16px;line-height:1;transform:translateY(-.5px)}
.site-meta{min-width:0;display:flex;flex:1;flex-direction:column;gap:2px}
.site-name{display:block;min-width:0;max-width:100%;font-weight:800;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .18s ease}
.site-card:hover .site-name{color:var(--primary)}
.site-desc{display:block;min-width:0;max-width:100%;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.site-go{
  margin-left:auto;width:22px;height:22px;border-radius:999px;border:1px solid transparent;background:transparent;
  display:flex;align-items:center;justify-content:center;position:relative;flex:none;
  transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease
}
.site-go:before{
  content:"";width:6px;height:6px;border-right:2px solid rgba(17,24,39,.38);border-bottom:2px solid rgba(17,24,39,.38);
  transform:rotate(-45deg);transition:border-color .18s ease
}
.site-card:hover .site-go{
  background:rgba(17,24,39,.04);border-color:rgba(17,24,39,.10);box-shadow:0 10px 20px rgba(0,0,0,.10);
  transform:translateX(2px)
}
.site-card:hover .site-go:before{border-color:rgba(17,24,39,.62)}
.site-grid.post-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:16px}
.site-grid.post-grid.recommend-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:12px}
.recommend-grid .site-card.post-card{border-radius:12px}
.recommend-grid .site-card.post-card .post-cover{aspect-ratio:16/9}
.recommend-grid .site-card.post-card .post-meta{padding:8px 10px 10px 10px}
.recommend-grid .site-card.post-card .site-name{font-size:12px;line-height:1.35}
.recommend-grid .site-card.post-card .site-desc{font-size:11px}
.recommend-grid .post-summary{display:none}
.site-card.post-card{border-color:rgba(17,24,39,.10);box-shadow:0 10px 22px rgba(0,0,0,.06)}
.site-card.post-card:hover{box-shadow:0 16px 40px rgba(0,0,0,.10)}
.site-card.post-card{position:relative;flex-direction:column;align-items:stretch;gap:0;height:auto;padding:0;border-radius:14px;overflow:hidden}
.site-card.post-card .post-cover{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;background:var(--soft);transform:scale(1);transition:transform .28s ease}
.site-card.post-card:hover .post-cover{transform:scale(1.02)}
.site-card.post-card .post-meta{min-width:0;display:flex;flex-direction:column;padding:10px 12px 12px 12px}
.site-card.post-card .site-name{font-size:14px;line-height:1.35}
.site-card.post-card .site-desc{margin-top:5px;color:var(--muted);font-size:11px;line-height:1.4}
.site-card.post-card .post-summary{
  margin-top:7px;color:var(--muted);font-size:11px;line-height:1.6;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}

/* Recommend Badge Redesign - Ribbon Style */
.site-recommend-badge {
  position: absolute;
  z-index: 6;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  pointer-events: none;
  overflow: hidden;
}

/* Shine Effect */
.site-recommend-badge::after {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,0.4) 50%, rgba(255,255,255,0) 100%);
  transform: skewX(-25deg);
  animation: shine 3s infinite;
  z-index: 3;
}

@keyframes shine {
  0% { left: -100%; }
  20% { left: 200%; }
  100% { left: 200%; }
}

/* Standard Card (Row) - Ribbon Style */
.site-card:not(.link-cover-card):not(.post-card) {
  overflow: hidden; /* Ensure ribbon doesn't overflow card */
}

.site-card:not(.link-cover-card):not(.post-card) .site-recommend-badge {
  top: -4px;
  right: -4px;
  width: 80px;
  height: 80px;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

/* The Ribbon Strip */
.site-card:not(.link-cover-card):not(.post-card) .site-recommend-badge::before {
  content: "推荐";
  position: absolute;
  top: 14px;
  right: -26px;
  width: 100px;
  height: 22px;
  background: linear-gradient(90deg, #ff4d4f, #f5222d);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 22px;
  text-align: center;
  transform: rotate(45deg);
  box-shadow: 0 2px 4px rgba(0,0,0,0.15);
  z-index: 2;
  letter-spacing: 1px;
}

/* Hide SVG in Standard Ribbon Mode */
.site-card:not(.link-cover-card):not(.post-card) .site-recommend-badge svg {
  display: none;
}

/* Cover & Post Cards - Floating Pill Style */
/* Cover & Post Cards - Integrated Corner Style */
.site-card.link-cover-card .site-recommend-badge,
.site-card.post-card .site-recommend-badge {
  top: 0;
  right: 0;
  width: auto;
  height: auto;
  padding: 5px 12px 6px 14px;
  background: linear-gradient(135deg, #FF6B6B 0%, #FF8E53 100%);
  color: #fff;
  box-shadow: 0 4px 12px rgba(255, 107, 107, 0.3);
  backdrop-filter: blur(4px);
  border: none;
  z-index: 6;
}

.site-card.link-cover-card .site-recommend-badge {
  border-radius: 0 12px 0 12px;
}

.site-card.post-card .site-recommend-badge {
  border-radius: 0 14px 0 12px;
}

/* Use Text for Cover Cards too */
.site-card.link-cover-card .site-recommend-badge::before,
.site-card.post-card .site-recommend-badge::before {
  content: "推荐";
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
}

.site-card.link-cover-card .site-recommend-badge svg,
.site-card.post-card .site-recommend-badge svg {
  display: none;
}

/* Hover Effects */
.site-card:hover .site-recommend-badge {
  transform: scale(1.05);
}

/* Mini Card Badge Adaptation - Small Tag */
.site-card.mini-site-card .site-recommend-badge {
  width: auto;
  height: 18px;
  padding: 0 6px;
  top: 0;
  right: 0;
  border-radius: 0 14px 0 6px;
  background: linear-gradient(90deg, #ff4d4f, #f5222d);
  box-shadow: none;
}

.site-card.mini-site-card .site-recommend-badge::before {
  content: "推荐";
  transform: none;
  position: static;
  width: auto;
  height: auto;
  background: none;
  box-shadow: none;
  font-size: 10px;
  line-height: 18px;
  font-weight: 600;
  letter-spacing: 0;
}

.site-card.mini-site-card .site-recommend-badge svg {
  display: none;
}

/* Mobile Adaptation */
@media (max-width: 768px) {
  /* Standard Card Mobile - Smaller Ribbon */
  .site-card:not(.link-cover-card):not(.post-card) .site-recommend-badge {
    width: 60px;
    height: 60px;
  }
  .site-card:not(.link-cover-card):not(.post-card) .site-recommend-badge::before {
    top: 8px;
    right: -22px;
    width: 80px;
    height: 18px;
    font-size: 10px;
    line-height: 18px;
  }
  
  /* Cover Card Mobile */
  .site-card.link-cover-card .site-recommend-badge,
  .site-card.post-card .site-recommend-badge {
    height: auto;
    padding: 3px 8px 4px 10px;
    top: 0;
    right: 0;
  }
  .site-card.link-cover-card .site-recommend-badge::before,
  .site-card.post-card .site-recommend-badge::before {
    font-size: 10px;
  }
}

@media (min-width: 1400px){
  .site-grid.post-grid{grid-template-columns:repeat(5,minmax(0,1fr)) !important;gap:16px}
  body.is-hero .site-grid.link-cover-grid { grid-template-columns: repeat(5, minmax(0, 1fr)) !important; }
}
/* Link Cover Card & Grid */
.site-grid.link-cover-grid { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; gap: 16px; }

@media (max-width: 1200px) {
  .site-grid.link-cover-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 14px; }
}
@media (max-width: 760px) {
  .site-grid.link-cover-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 10px; }
}

.site-card.link-cover-card {
  position: relative;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  height: auto;
  padding: 0;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(17, 24, 39, 0.08);
  background: var(--card);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
  transition: transform 0.2s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.2s ease, border-color 0.2s ease;
}
.site-card.link-cover-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.12);
  border-color: rgba(17, 24, 39, 0.12);
  z-index: 2;
}
.site-card.link-cover-card .lcc-cover {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  background: var(--soft);
  overflow: hidden;
  border-bottom: 1px solid rgba(0,0,0,0.03);
}
.site-card.link-cover-card .lcc-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.site-card.link-cover-card:hover .lcc-cover img {
  transform: scale(1.06);
}
.site-card.link-cover-card .lcc-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 14px;
}
.site-card.link-cover-card .lcc-title {
  font-size: 14px;
  line-height: 1.4;
  font-weight: 800;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 0.2s ease;
}
.site-card.link-cover-card:hover .lcc-title {
  color: var(--primary);
}
.site-card.link-cover-card .lcc-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.site-card.link-cover-card .lcc-meta-left {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.site-card.link-cover-card .lcc-avatar {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--soft);
  flex: 0 0 auto;
  border: 1px solid rgba(17, 24, 39, 0.08);
}
.site-card.link-cover-card .lcc-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.site-card.link-cover-card .lcc-sub {
  min-width: 0;
  font-size: 12px;
  line-height: 1.3;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.site-card.link-cover-card .lcc-count {
  font-size: 11px;
  line-height: 1;
  color: var(--muted);
  font-weight: 700;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: var(--soft);
  padding: 3px 6px;
  border-radius: 6px;
}
.site-card.link-cover-card .lcc-count::before {
  content: "";
  width: 10px;
  height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'%3E%3C/path%3E%3Ccircle cx='12' cy='12' r='3'%3E%3C/circle%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.7;
}
.link-cover-grid .site-tip-float{white-space:pre-line;text-align:left;font-size:12px;line-height:1.55;padding:12px 12px;border-radius:12px}
.link-cover-grid .site-tip-float::first-line{font-weight:900;font-size:13px}
.post-top-badge{
  position:absolute;top:0;right:0;z-index:2;
  padding:5px 12px 6px 14px; /* Asymmetric padding for visual balance */
  background:linear-gradient(135deg, #FF6B6B 0%, #FF8E53 100%);
  color:#fff;font-size:12px;font-weight:800;letter-spacing:1px;
  border-radius:0 14px 0 12px; /* Matches card radius */
  box-shadow:0 4px 12px rgba(255, 107, 107, 0.3);
  backdrop-filter:blur(4px);
  transform:translateZ(0)
}
.post-top-badge.is-hero{right:0;top:0}
.post-hero-cover-wrap{position:relative;display:inline-block;flex:none}
.post-hero{margin-top:16px;display:flex;gap:18px;align-items:flex-start}
.post-hero-cover{width:320px;max-width:100%;aspect-ratio:16/9;object-fit:cover;display:block;border-radius:16px;border:1px solid rgba(0,0,0,.06);background:var(--soft);flex:none}
.post-hero-main{min-width:0;flex:1}
.post-hero-title{font-size:28px;font-weight:950;line-height:1.3;margin-top:2px}
.post-hero-meta{margin-top:6px;font-size:12px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.post-hero-summary{margin-top:10px;line-height:1.8}
.post-detail-card .card-bd{padding:22px 22px 24px 22px}
.post-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;position:relative;z-index:30}
.post-actions .btn{height:30px}
.post-actions .btn.btn-ico{height:34px;width:34px}
.post-actions [data-copy-link]{margin-left:auto}
.post-content{margin-top:18px;padding-top:14px;border-top:1px solid var(--line);font-size:16px;line-height:1.9;word-break:break-word;overflow-wrap:anywhere}
.post-detail-card .post-content{max-width:920px;margin-left:auto;margin-right:auto}
.post-content > :first-child{margin-top:0}
.post-content h1,.post-content h2,.post-content h3{margin:18px 0 10px 0;line-height:1.35}
.post-content h1{font-size:22px}
.post-content h2{font-size:18px}
.post-content h3{font-size:16px}
.post-content p{margin:10px 0}
.post-content table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.post-content th,.post-content td{white-space:normal;word-break:break-word}
.post-content iframe,.post-content embed,.post-content object{max-width:100%}
.post-content img,.post-content video{max-width:100%;height:auto;display:block;border-radius:12px;border:1px solid rgba(0,0,0,.06)}
.post-content img{margin:12px 0}
.post-content a{color:var(--primary);text-decoration:none}
.post-content a.is-clicked{color:rgba(99,102,241,.52);text-decoration:underline;text-decoration-style:dotted;text-decoration-thickness:from-font}
@supports (color:color-mix(in srgb, #000 0%, #fff)){
  .post-content a.is-clicked{color:color-mix(in srgb,var(--primary) 32%,var(--muted));text-decoration-color:color-mix(in srgb,var(--primary) 28%,transparent)}
}
.post-content a:visited{color:rgba(99,102,241,.62)}
@supports (color:color-mix(in srgb, #000 0%, #fff)){
  .post-content a:visited{color:color-mix(in srgb,var(--primary) 55%,var(--muted))}
}
.post-content a:hover{text-decoration:underline}
.post-content blockquote{margin:12px 0;padding:10px 12px;border-left:3px solid var(--primary);background:var(--soft);border-radius:10px}
.post-content pre{margin:12px 0;padding:12px 12px;border-radius:12px;background:#0b1220;color:#e5e7eb;overflow:auto}
.post-content code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.95em}
.media-viewer{position:fixed;inset:0;z-index:99999;display:none}
.media-viewer.is-open{display:block}
.media-viewer-mask{position:absolute;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(2px)}
.media-viewer-panel{position:absolute;left:14px;right:14px;top:14px;bottom:14px;border-radius:16px;border:1px solid var(--line);background:var(--card);overflow:hidden;display:flex;flex-direction:column}
.media-viewer-panel-simple{border:0;background:transparent;overflow:visible}
.media-viewer.is-simple{cursor:zoom-out}
.media-viewer.is-simple .media-viewer-mask{opacity:0;transition:opacity .26s ease}
.media-viewer.is-simple.is-open .media-viewer-mask{opacity:1}
.media-viewer.is-simple.is-closing .media-viewer-mask{opacity:0}
.media-viewer.is-simple .media-viewer-body{padding:0;overflow:visible}
.media-viewer.is-simple .media-viewer-img{border-radius:12px;box-shadow:0 18px 60px rgba(0,0,0,.35);max-width:none;max-height:none}
.media-viewer-toolbar{position:absolute;left:50%;top:10px;transform:translateX(-50%);z-index:4;display:flex;align-items:center;overflow:hidden;border-radius:2px;border:1px solid rgba(255,255,255,.22);background:rgba(17,24,39,.55);backdrop-filter:blur(2px)}
.media-viewer-toolbtn{width:44px;height:32px;display:flex;align-items:center;justify-content:center;border:0;background:transparent;color:#fff;cursor:pointer}
.media-viewer-toolbtn+.media-viewer-toolbtn{border-left:1px solid rgba(255,255,255,.18)}
.media-viewer-toolbtn:active{transform:translateY(1px)}
.media-viewer-top{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 10px;border-bottom:1px solid var(--line)}
.media-viewer-actions{display:flex;align-items:center;gap:8px}
.media-viewer-body{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:10px;overflow:hidden}
.media-viewer-img{max-width:100%;max-height:100%;transform-origin:center;touch-action:none;user-select:none}
@media (max-width: 640px){
  .post-hero{flex-direction:column}
  .post-hero-cover{width:100%}
  .admin-post-panel-row{grid-template-columns:1fr}
  .admin-post-side-sticky{position:static}
}
.site-tip{display:none}
.site-tip-float{
  position:absolute;left:0;top:0;z-index:20;
  background:rgba(17,24,39,.94);color:#fff;font-size:12px;line-height:1.5;
  padding:10px 12px;border-radius:10px;box-shadow:0 14px 30px rgba(0,0,0,.18);
  box-sizing:border-box;
  text-align:center;
  overflow-wrap:anywhere;
  word-break:break-word;
  opacity:0;pointer-events:none;
  transition:opacity .14s ease;
  transform:translate3d(0,0,0);
  will-change:transform,opacity
}
@media (hover: none), (pointer: coarse){
  .site-tip-float{display:none !important}
}
@media (max-width: 980px){
  .site-tip-float{display:none !important}
}
.post-grid .site-tip-float{white-space:pre-line;text-align:left;font-size:12px;line-height:1.55;padding:12px 12px;border-radius:12px}
.post-grid .site-tip-float::first-line{font-weight:900;font-size:13px}

@media (max-width: 980px){
  html,body{overflow-x:hidden}
  .btn.btn-ico[data-tip]:before,
  .btn.btn-ico[data-tip]:after,
  .ld-pill[data-tip]:before,
  .ld-pill[data-tip]:after,
  .ld-ico-chip[data-tip]:after{display:none !important}
  .weather-pop{display:none !important}
  .side-flyout{display:none !important}
  .top-actions .top-quote{display:none !important}
  .top-actions > .btn:not(.btn-ico){display:none !important}
}

@media (max-width: 640px){
  .top-capsules,
  .top-capsule{display:none !important}
}

@media (max-width:1200px){
  .site-grid.post-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important;gap:14px}
  .site-grid.post-grid.recommend-grid{grid-template-columns:repeat(3,minmax(0,1fr)) !important;gap:12px}
  .site-grid.link-cover-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:12px}
}
@media (max-width:860px){
  .site-grid.post-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:12px}
  .site-grid.post-grid.recommend-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:10px}
  .site-grid.link-cover-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;gap:10px}
}
@media (max-width:520px){
  .site-grid.post-grid{grid-template-columns:1fr !important;gap:12px}
}

.post-meta-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--soft);border:1px solid var(--line);font-size:12px}
.post-meta-pill .k{color:var(--muted);font-weight:800}
.post-meta-pill .v{color:var(--text);font-weight:900}
.admin-post-card .card-hd{align-items:flex-start}
.admin-post-hd-left{display:flex;flex-direction:column;gap:3px;min-width:0}
.admin-post-hd-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.admin-post-sub{font-size:12px;line-height:1.5}
.admin-post-grid{margin-top:0;align-items:start}
.admin-post-section{padding:12px;border:1px solid var(--line);border-radius:14px;background:var(--card)}
.admin-post-section + .admin-post-section{margin-top:14px}
.admin-post-section-hd{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-bottom:10px}
.admin-post-section-title{font-weight:900}
.admin-post-section-sub{font-size:12px}
.admin-site-grid{margin-top:0;align-items:start}
.admin-site-section{padding:12px;border:1px solid var(--line);border-radius:14px;background:var(--card)}
.admin-site-section + .admin-site-section{margin-top:14px}
.admin-site-section-hd{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-bottom:10px}
.admin-site-section-title{font-weight:900}
.admin-site-section-sub{font-size:12px}
.admin-site-row2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.admin-site-actions{margin-top:12px;display:flex;justify-content:flex-end}
.admin-site-textarea{height:140px;padding:10px;resize:vertical}
.admin-site-tabs{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:6px;border:1px solid var(--line);border-radius:14px;background:var(--soft);margin-top:0;margin-bottom:14px}
.admin-site-tab{appearance:none;border:1px solid transparent;background:transparent;color:var(--muted);padding:8px 12px;border-radius:12px;font-weight:900;cursor:pointer;line-height:1}
.admin-site-tab:hover{border-color:rgba(255,90,95,.24);background:rgba(255,90,95,.06);color:var(--text);transform:translateY(-1px)}
.admin-site-tab:active{transform:translateY(0)}
.admin-site-tab:focus{outline:0}
.admin-site-tab:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.18)}
.admin-site-tab.is-active{background:var(--card);border-color:var(--line);color:var(--text);box-shadow:0 10px 22px rgba(0,0,0,.06)}
.admin-site-panel[hidden]{display:none}
.admin-post-title-input{font-size:18px;font-weight:900;letter-spacing:.2px;padding:12px 12px}
.admin-post-side-sticky{position:sticky;top:84px;display:flex;flex-direction:column;gap:14px}
.admin-post-panel{padding:12px;border-radius:14px;border:1px solid var(--line);background:var(--soft)}
.admin-post-panel-title{font-weight:900;margin-bottom:10px}
.admin-post-panel .form-row{margin:10px 0}
.admin-post-panel-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.admin-post-save{width:100%;height:38px;margin-top:10px}
.admin-post-hint{margin-top:10px;font-size:12px;line-height:1.7}
.admin-post-cover-drop{margin-top:10px;position:relative}
.admin-post-cover-drop .input{position:absolute;inset:0;opacity:0;cursor:pointer}
.admin-post-cover-drop-ui{height:38px;border-radius:12px;border:1px dashed rgba(255,90,95,.35);background:rgba(255,90,95,.06);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;font-weight:900}
.admin-post-cover-preview{margin-top:10px}
.admin-post-cover-preview img{width:100%;max-height:220px;object-fit:cover;border-radius:12px;border:1px solid rgba(0,0,0,.06);display:block}
.post-editor-sep{width:1px;height:22px;background:var(--line);align-self:center;opacity:.8}
.post-editor{border:1px solid var(--line);border-radius:14px;background:var(--card);overflow:hidden}
.post-editor-top{display:flex;flex-direction:column;gap:10px;padding:10px;border-bottom:1px solid var(--line);background:linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,0))}
.post-editor-top .kvs{gap:8px;flex-wrap:wrap}
.post-editor-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap}
.post-editor-actions{align-items:center}
.post-editor-actions .btn.btn-ico{width:32px;height:32px;padding:0;border-radius:10px}
.post-editor-fontsize{height:32px;padding:0 10px;border-radius:10px;min-width:0}
.post-editor-fontsize:focus{outline:0;box-shadow:0 0 0 4px rgba(124,77,255,.18)}
.post-editor-color{position:relative}
.post-editor-color[open] > summary.btn.btn-ico{border-color:rgba(255,90,95,.24);background:rgba(255,90,95,.06)}
.post-editor-color > summary{list-style:none}
.post-editor-color > summary::-webkit-details-marker{display:none}
.post-editor-color-panel{
  position:absolute;right:0;top:calc(100% + 8px);
  width:260px;
  padding:10px;border-radius:14px;border:1px solid var(--line);background:var(--card);
  box-shadow:0 18px 44px rgba(0,0,0,.12);
  z-index:3
}
.post-editor-color-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.post-editor-color-row + .post-editor-color-row{margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.post-editor-color-swatch{
  width:22px;height:22px;border-radius:8px;
  border:1px solid rgba(0,0,0,.10);
  background:var(--c, transparent);
  cursor:pointer;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10)
}
.post-editor-color-swatch:hover{transform:translateY(-1px)}
.post-editor-color-swatch:active{transform:translateY(0)}
.post-editor-color-input{height:34px;border-radius:12px;padding:0 6px;flex:none;width:52px}
.post-editor-cmenu-color{padding:8px 10px 10px 10px;border-top:1px solid var(--line)}
.post-editor-cmenu-color-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.post-editor-cmenu-color-row + .post-editor-cmenu-color-row{margin-top:10px}
.post-editor-cmenu-color-input{height:34px;border-radius:12px;padding:0 6px;flex:none;width:52px}
.post-editor-more[open] > summary.btn.btn-ico{border-color:rgba(255,90,95,.24);background:rgba(255,90,95,.06)}
.post-editor-more{position:relative}
.post-editor-more[open] > summary{border-color:rgba(255,90,95,.24);background:rgba(255,90,95,.06)}
.post-editor-more > summary{list-style:none}
.post-editor-more > summary::-webkit-details-marker{display:none}
.post-editor-more-panel{
  position:absolute;right:0;top:calc(100% + 8px);
  width:min(520px,calc(100vw - 60px));
  padding:10px;border-radius:14px;border:1px solid var(--line);background:var(--card);
  box-shadow:0 18px 44px rgba(0,0,0,.12);
  z-index:3
}
.post-editor-cmenu{
  position:fixed;left:0;top:0;z-index:10010;
  display:none;
  width:280px;
  padding:6px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:0 22px 60px rgba(0,0,0,.18)
}
.post-editor-cmenu.is-open{display:block}
.post-editor-cmenu-list{display:flex;flex-direction:column;gap:2px}
.post-editor-cmenu-item{
  width:100%;
  height:34px;
  border:0;
  background:transparent;
  color:var(--text);
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 10px;
  border-radius:10px;
  cursor:pointer;
  font:inherit;
  text-align:left
}
.post-editor-cmenu-item:hover{background:var(--soft)}
.post-editor-cmenu-item:active{background:rgba(0,0,0,.06)}
.post-editor-cmenu-item:disabled{opacity:.45;cursor:not-allowed}
.post-editor-cmenu-ico{
  width:22px;height:22px;border-radius:8px;
  background:var(--soft);
  border:1px solid rgba(0,0,0,.06);
  color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:950;
  flex:none
}
.post-editor-cmenu-text{min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-editor-cmenu-kbd{color:var(--muted);font-size:12px;font-weight:800;flex:none}
.post-editor-cmenu-sep{height:1px;background:var(--line);opacity:.9;margin:6px 6px}
.post-editor-cmenu-link{padding:8px 10px 10px 10px;border-top:1px solid var(--line)}
.post-editor-cmenu-link-row{display:flex;gap:8px;align-items:center}
.post-editor-cmenu-link-input{height:34px;border-radius:12px}
.post-editor-cmenu-link-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
.post-editor-cmenu-foot{margin:6px 10px 4px 10px;font-size:12px;line-height:1.4}
.post-editor-more-row{display:flex;gap:10px;align-items:flex-start}
.post-editor-more-row + .post-editor-more-row{margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.post-editor-more-label{width:44px;flex:none;padding-top:6px}
.post-editor-more-actions{flex:1}
.post-editor-more .post-editor-size{flex:1;justify-content:flex-end}
.post-editor-more .post-editor-size input[type=range]{width:240px}
.post-editor-size{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.post-editor-size input[type=range]{width:200px}
.post-editor-body{display:grid;grid-template-columns:1fr 1fr;gap:0}
.post-editor-pane{min-width:0}
.post-editor .input.post-editor-wysiwyg{border:0;border-radius:0;padding:12px;min-height:260px;overflow:auto;white-space:normal;line-height:1.85}
.post-editor .input.post-editor-wysiwyg img.is-selected{outline:3px solid rgba(255,90,95,.35);outline-offset:2px}
.post-editor .input.post-editor-wysiwyg video.is-selected{outline:3px solid rgba(255,90,95,.35);outline-offset:2px}
.post-editor .input.post-editor-source{border:0;border-radius:0;padding:12px;resize:none;min-height:260px;line-height:1.6;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}
.post-editor-preview{width:100%;border:0;background:var(--card);min-height:260px}
.post-editor-body[data-mode="split"] .is-source{display:none}
.post-editor-body[data-mode="edit"]{grid-template-columns:1fr}
.post-editor-body[data-mode="edit"] .is-source,.post-editor-body[data-mode="edit"] .is-preview{display:none}
.post-editor-body[data-mode="source"] .is-edit{display:none}
.post-editor-body[data-mode="preview"]{grid-template-columns:1fr}
.post-editor-body[data-mode="preview"] .is-edit,.post-editor-body[data-mode="preview"] .is-source{display:none}
body.is-editor-fullscreen{overflow:hidden}
.post-editor.is-fullscreen{position:fixed;left:14px;right:14px;top:14px;bottom:14px;z-index:9999;box-shadow:0 24px 70px rgba(0,0,0,.22)}
.post-editor.is-fullscreen .post-editor-top{position:sticky;top:0;z-index:2}
.post-editor.is-fullscreen .post-editor-preview{height:100%}
.site-tip-float:after{content:"";position:absolute;left:50%;bottom:100%;transform:translateX(-50%);border:6px solid transparent;border-bottom-color:rgba(17,24,39,.94)}
.site-tip-float.is-show{opacity:1}
.mini-card{max-width:1060px;margin:18px auto;border-radius:18px}
.mini-hd-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.mini-add{display:grid;grid-template-columns:1fr 1.2fr auto;gap:10px;margin-bottom:12px}
.mini-note{padding:10px 12px;border-radius:14px;background:var(--soft);border:1px solid var(--line);margin-bottom:12px}
.mini-grid{gap:12px}
.mini-site-card{height:58px;border-radius:14px}
.mini-card-wrap{position:relative}
.mini-del{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:26px;height:26px;border-radius:999px;border:1px solid transparent;
  background:rgba(0,0,0,0);color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;line-height:1;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease
}
.mini-del:hover{background:var(--soft);border-color:var(--line);color:var(--text)}
.mini-del:active{transform:translateY(-50%) scale(.96)}
.mini-empty{margin-top:14px}
.is-mini .topbar,.is-mini .sidebar,.is-mini .footer,.is-mini .fab{display:none !important}
.is-mini .wrap{min-height:100vh}
.is-mini .main{margin-left:0;width:100%}
.is-mini .main-body{padding:0;min-height:100vh}
.mini-page{
  --mini-bg:none;
  --mini-bg-blur:0px;
  --mini-bg-extra-blur:0px;
  --mini-solid-bg:#0b1220;
  --mini-head-shift:64px;
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:22px 18px
}
.mini-page.is-panel-open{--mini-bg-extra-blur:6px}
.mini-page:before{
  content:"";
  position:fixed;inset:0;
  background:linear-gradient(180deg, rgba(2,6,18,.38), rgba(2,6,18,.22) 35%, rgba(2,6,18,.62));
  z-index:1
}
.mini-bg{
  position:fixed;inset:-26px;
  background-image:var(--mini-bg);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:blur(calc(var(--mini-bg-blur,0px) + var(--mini-bg-extra-blur,0px))) saturate(1.06) contrast(1.02);
  transition:filter .44s cubic-bezier(.2,.9,.2,1);
  z-index:0
}

/* Auth Page Redesign & Glassmorphism */
body.is-auth {
  background: radial-gradient(circle at 10% 20%, #f8fafc 0%, #e2e8f0 90%);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  overflow-x: hidden;
}

html[data-theme="dark"] body.is-auth {
  background: radial-gradient(circle at 90% 10%, #1e293b 0%, #0f172a 90%);
}

.auth-wrap {
  width: 100%;
  padding: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 1; /* Ensure above bg-shapes */
}

.auth-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 100%;
  max-width: 900px;
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 24px;
  box-shadow: 
    0 4px 6px -1px rgba(0, 0, 0, 0.05), 
    0 20px 40px -6px rgba(0, 0, 0, 0.08),
    inset 0 0 0 1px rgba(255, 255, 255, 0.4);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

html[data-theme="dark"] .auth-card {
  background: rgba(30, 35, 40, 0.65);
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow: 
    0 4px 6px -1px rgba(0, 0, 0, 0.2), 
    0 20px 40px -6px rgba(0, 0, 0, 0.4),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}

.auth-left {
  background: rgba(255, 255, 255, 0.4);
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}

html[data-theme="dark"] .auth-left {
  background: rgba(0, 0, 0, 0.2);
}

.auth-left-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.auth-mark-title {
  font-size: 24px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 4px;
}

.auth-mark-sub {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.auth-slogan-title {
  font-size: 32px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.2;
}

.auth-slogan-sub {
  font-size: 16px;
  color: var(--muted);
  margin-bottom: 24px;
}

.auth-left-rich {
  margin-top: auto;
  padding-top: 24px;
}

.auth-left-kicker {
  font-size: 14px;
  color: var(--text);
  margin-bottom: 8px;
}

.auth-left-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
}

.auth-features {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.auth-feature {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--text);
  font-weight: 500;
}

.auth-feature-ico {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  font-weight: bold;
}

.auth-right {
  padding: 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}

.auth-panel-title {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -1px;
  background: linear-gradient(135deg, var(--text) 0%, var(--muted) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 8px;
  line-height: 1.2;
}

html[data-theme="dark"] .auth-panel-title {
  background: linear-gradient(135deg, #fff 0%, #94a3b8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.auth-panel-sub {
  font-size: 15px;
  color: var(--muted);
  margin-bottom: 40px;
  line-height: 1.6;
}

.auth-form-label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: color 0.2s;
}

.field:focus-within .auth-form-label {
  color: var(--primary);
}

.auth-input {
  position: relative;
  display: flex;
  align-items: center;
}

.auth-input-ico {
  position: absolute;
  left: 16px;
  color: var(--muted);
  pointer-events: none;
  display: flex;
  transition: color 0.2s, transform 0.2s;
}

.auth-input .input {
  width: 100%;
  height: 52px;
  padding: 0 16px 0 48px;
  border-radius: 16px;
  border: 1px solid transparent;
  background: var(--soft);
  transition: all 0.2s cubic-bezier(0.2, 0.8, 0.2, 1);
  font-size: 15px;
  color: var(--text);
  font-weight: 500;
}

.auth-input .input::placeholder {
  color: var(--muted);
  opacity: 0.6;
  font-weight: 400;
  font-size: 14px;
}

html[data-theme="dark"] .auth-input .input {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.05);
}

.auth-input .input:hover {
  background: rgba(0, 0, 0, 0.04);
}

html[data-theme="dark"] .auth-input .input:hover {
  background: rgba(255, 255, 255, 0.08);
}

.auth-input .input:focus {
  background: var(--card);
  border-color: var(--primary);
  box-shadow: 0 4px 20px rgba(99, 102, 241, 0.15);
  transform: translateY(-1px);
}

.auth-input:focus-within .auth-input-ico {
  color: var(--primary);
  transform: scale(1.1);
}

.field-msg {
  min-height: 0;
  font-size: 12px;
  font-weight: 600;
  color: #ef4444;
  margin-top: 6px;
  opacity: 0;
  transform: translateY(-4px);
  transition: all 0.2s;
}

.field-msg:not(:empty) {
  opacity: 1;
  transform: translateY(0);
}

.field-msg:not(:empty)::before {
  content: "!";
  display: inline-flex;
  width: 14px;
  height: 14px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #ef4444;
  color: #fff;
  font-size: 10px;
  margin-right: 6px;
}

.btn.auth-submit {
  width: 100%;
  height: 52px;
  border-radius: 16px;
  font-size: 16px;
  font-weight: 700;
  margin-top: 32px;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  border: none;
  color: #fff;
  box-shadow: 0 10px 24px -4px rgba(99, 102, 241, 0.4);
  transition: transform 0.2s, box-shadow 0.2s;
  cursor: pointer;
  letter-spacing: 0.5px;
}

.btn.auth-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px -6px rgba(99, 102, 241, 0.5);
}

.btn.auth-submit:active {
  transform: translateY(0);
}

.auth-links {
  margin-top: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.auth-hint {
  margin-top: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 14px;
  color: var(--muted);
}

.auth-hint-link {
  background: transparent;
  border: none;
  padding: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--primary);
  cursor: pointer;
  transition: color 0.2s;
}

.auth-hint-link:hover {
  color: var(--primary2);
  text-decoration: underline;
  text-underline-offset: 4px;
}

.auth-hint-dot {
  color: var(--line);
  font-size: 12px;
}

.auth-copyright {
  margin-top: auto;
  text-align: center;
  font-size: 12px;
  color: var(--muted);
  opacity: 0.7;
  padding-top: 20px;
}

@media (max-width: 768px) {
  .auth-card {
    grid-template-columns: 1fr;
    max-width: 420px;
  }
  .auth-left {
    display: none;
  }
  .auth-right {
    padding: 30px 24px;
  }
}
.mini-page.is-solid .mini-bg{
  background-image:none;
  background-color:var(--mini-solid-bg);
  transform:none;
  filter:none
}
.mini-page.is-solid:before{background:var(--mini-solid-bg)}
.mini-page.is-solid .mini-bg:after{display:none}
.mini-bg:after{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(60% 45% at 50% 38%, rgba(255,255,255,.08), rgba(255,255,255,0));
}
.mini-settings-btn{
  position:fixed;
  top:18px;right:18px;
  top:calc(18px + env(safe-area-inset-top));
  right:calc(18px + env(safe-area-inset-right));
  width:42px;height:42px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(2,6,18,.34);
  color:rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  z-index:30;
  backdrop-filter:blur(10px);
  transition:transform .18s ease,background .18s ease,border-color .18s ease
}
.mini-settings-btn:hover{transform:translateY(-1px);background:rgba(2,6,18,.42);border-color:rgba(255,255,255,.30)}
.mini-settings-btn:active{transform:translateY(0)}
html[data-theme="dark"] .mini-settings-btn{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.16);
  color:rgba(255,255,255,.92)
}
html[data-theme="dark"] .mini-settings-btn:hover{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.24)
}
.mini-weather{
  position:fixed;
  top:18px;
  right:68px;
  top:calc(18px + env(safe-area-inset-top));
  right:calc(68px + env(safe-area-inset-right));
  z-index:30
}
.mini-page .mini-weather .top-weather-btn{
  height:42px;
  background:rgba(2,6,18,.34);
  border-color:rgba(255,255,255,.22);
  color:rgba(255,255,255,.92);
  backdrop-filter:blur(10px)
}
.mini-page .mini-weather .top-weather-brief{color:rgba(255,255,255,.92);opacity:.88}
.mini-page .mini-weather .weather-pop{left:auto;right:0}
html[data-theme="dark"] .mini-page .mini-weather .top-weather-btn{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.16)
}
@media (max-width:520px){
  .mini-weather{right:64px}
  .mini-page .mini-weather .top-weather-btn{max-width:180px}
}
.mini-home-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  right:calc(18px + env(safe-area-inset-right));
  bottom:calc(18px + env(safe-area-inset-bottom));
  z-index:30;
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end
}
.mini-corner-player{
  position:fixed;
  left:18px;
  bottom:18px;
  left:calc(18px + env(safe-area-inset-left));
  bottom:calc(18px + env(safe-area-inset-bottom));
  z-index:35;
  display:none;
  opacity:0;
  transform:translateY(6px) scale(.98);
  transition:opacity .18s ease,transform .22s cubic-bezier(.2,.9,.2,1)
}
.mini-corner-player.is-on{display:block;opacity:1;transform:translateY(0) scale(1)}
.mini-corner-info{
  position:absolute;
  left:84px;
  bottom:10px;
  max-width:min(260px,calc(100vw - 120px));
  padding:8px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.78);
  box-shadow:0 18px 44px rgba(0,0,0,.14);
  backdrop-filter:blur(10px);
  color:rgba(2,6,18,.88);
  font-weight:900;
  font-size:12px;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  opacity:0;
  transform:translateX(-4px);
  pointer-events:none;
  transition:opacity .16s ease,transform .22s cubic-bezier(.2,.9,.2,1)
}
.mini-corner-info[aria-hidden="true"]{display:none}
.mini-corner-player:hover .mini-corner-info,
.mini-corner-player:focus-within .mini-corner-info{opacity:1;transform:translateX(0)}
.mini-corner-info-txt{display:block}
html[data-theme="dark"] .mini-corner-info{
  border-color:rgba(255,255,255,.12);
  background:rgba(2,6,18,.72);
  box-shadow:0 18px 44px rgba(0,0,0,.28);
  color:rgba(255,255,255,.88)
}
.mini-corner-player-btn{
  width:72px;height:72px;
  border-radius:999px;
  border:2px solid transparent;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.68), rgba(255,255,255,0) 55%) padding-box,
    linear-gradient(135deg, rgba(124,77,255,.92), rgba(255,255,255,.46), rgba(124,77,255,.78)) border-box;
  backdrop-filter:blur(10px);
  box-shadow:0 18px 44px rgba(0,0,0,.18);
  padding:0;
  overflow:hidden;
  cursor:pointer;
  position:relative;
  display:block
}
.mini-corner-player-btn:before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:
    radial-gradient(circle at 50% 50%, rgba(2,6,18,.10), rgba(2,6,18,0) 58%),
    repeating-radial-gradient(circle at 50% 50%, rgba(255,255,255,.12) 0 1px, rgba(255,255,255,0) 1px 5px);
  opacity:.35;
  z-index:2;
  pointer-events:none
}
.mini-corner-player-btn:after{
  content:"♪";
  position:absolute;
  right:6px;
  bottom:6px;
  width:22px;
  height:22px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:900;
  background:rgba(124,77,255,.92);
  color:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
  z-index:6;
  pointer-events:none
}
.mini-corner-player.is-playing .mini-corner-player-btn:after{animation:miniCornerBadge 1.1s ease-in-out infinite}
.mini-corner-player-btn:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(124,77,255,.22),0 18px 44px rgba(0,0,0,.22)}
.mini-corner-player-cover{
  width:100%;
  height:100%;
  object-fit:cover;
  background:var(--soft);
  display:block;
  filter:saturate(1.05) contrast(1.03);
  animation:miniCornerSpin 8s linear infinite;
  animation-play-state:paused;
  position:relative;
  z-index:1
}
.mini-corner-player.is-playing .mini-corner-player-cover{animation-play-state:running}
.mini-corner-player-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(2,6,18,.22);
  color:#fff;
  opacity:.18;
  transition:opacity .16s ease,background .16s ease;
  z-index:5
}
.mini-corner-player-btn:hover .mini-corner-player-overlay{opacity:1}
.mini-corner-player.is-paused .mini-corner-player-overlay,
.mini-corner-player.is-idle .mini-corner-player-overlay{opacity:.92}
.mini-corner-player-ico.is-pause{display:none}
.mini-corner-player.is-playing .mini-corner-player-ico.is-play{display:none}
.mini-corner-player.is-playing .mini-corner-player-ico.is-pause{display:block}
@keyframes miniCornerSpin{from{transform:rotate(0deg) scale(1.02)}to{transform:rotate(360deg) scale(1.02)}}
@keyframes miniCornerBadge{0%,100%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.1);filter:brightness(1.06)}}
.mini-center{
  position:relative;
  z-index:2;
  width:min(980px,100%);
  text-align:center;
  padding-top:calc(50vh - var(--mini-head-shift,0px) + (var(--mini-head-h,220px) / 2) + 8px)
}
.mini-head{
  position:fixed;
  left:50%;
  top:calc(50% - var(--mini-head-shift,0px));
  transform:translate(-50%,-50%) translateY(var(--mini-head-dy,0px)) scale(var(--mini-head-scale,1));
  opacity:var(--mini-head-alpha,1);
  z-index:3;
  width:min(980px,calc(100% - 36px));
  transition:opacity .18s ease,transform .22s cubic-bezier(.2,.9,.2,1);
  will-change:transform,opacity
}
.mini-page.is-mini-head-hidden .mini-head{pointer-events:none}
.mini-title{font-weight:900;color:#fff;font-size:28px;letter-spacing:.4px}
.mini-sub{margin-top:6px;color:rgba(255,255,255,.72);font-size:13px;font-weight:700}
.mini-search-wrap{margin-top:18px}
.mini-search{
  max-width:760px;
  margin:0 auto;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.78);
  box-shadow:0 28px 80px rgba(0,0,0,.32);
  backdrop-filter:blur(10px)
}
.mini-enginebar{
  max-width:760px;
  margin:8px auto 0 auto;
  justify-content:center;
  gap:8px
}
.mini-music{
  max-width:760px;
  margin:8px auto 0 auto;
  padding:14px 14px 12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.72);
  box-shadow:0 22px 56px rgba(0,0,0,.18);
  backdrop-filter:blur(10px);
  text-align:left;
  position:relative;
  z-index:2
}
.mini-page[data-mini-logged="0"] .site-grid.mini-shortcuts{margin-top:18px}
.mini-music.is-hidden{display:none}
.mini-music:before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(124,77,255,.26), rgba(0,0,0,0), rgba(255,255,255,.22));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none
}
.mini-music.is-sheet-open{
  border-bottom-left-radius:0;
  border-bottom-right-radius:0
}
.mini-music-hd{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mini-music-kicker{font-weight:900;color:rgba(2,6,18,.92)}
.mini-music-search{margin-left:auto;display:flex;align-items:center;gap:8px;flex:1;min-width:240px}
.mini-music-inputwrap{position:relative;flex:1;min-width:0}
.mini-music-input{width:100%;min-width:0;height:34px;border-radius:12px}
.mini-music-recent{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 8px);
  padding:6px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.26);
  background:rgba(255,255,255,.96);
  box-shadow:0 22px 56px rgba(0,0,0,.18);
  backdrop-filter:blur(14px);
  display:none;
  z-index:30
}
.mini-music-recent.is-open{display:block;animation:miniMusicRecentIn .16s ease-out both}
@keyframes miniMusicRecentIn{from{opacity:0;transform:translateY(-4px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}
.mini-music-recent-item{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  user-select:none;
  border:1px solid transparent;
  background:transparent;
  color:rgba(2,6,18,.86);
  font-weight:900;
  font-size:12px;
  line-height:1.1;
  transition:background .14s ease,border-color .14s ease,transform .14s ease
}
.mini-music-recent-item:hover{background:rgba(124,77,255,.10);border-color:rgba(124,77,255,.16)}
.mini-music-recent-item:active{transform:scale(.99)}
.mini-music-recent-ico{
  width:18px;
  height:18px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(2,6,18,.06);
  color:rgba(2,6,18,.66);
  flex:0 0 auto
}
.mini-music-recent-text{min-width:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-music-recent-tip{flex:0 0 auto;color:rgba(2,6,18,.42);font-size:11px;font-weight:900}
.mini-music-btn{height:34px;border-radius:12px;white-space:nowrap}
.mini-music-player{margin-top:10px;display:none}
.mini-music-player.is-on{display:block;animation:miniMusicPlayerIn .26s cubic-bezier(.2,.9,.2,1) both}
@keyframes miniMusicPlayerIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes miniRecordSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.mini-music-now{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.26);
  background:rgba(255,255,255,.82);
  box-shadow:0 18px 44px rgba(0,0,0,.10);
  backdrop-filter:blur(12px)
}
.mini-music-now[data-mini-music-toggle]{cursor:pointer}
.mini-music-coverwrap{position:relative;width:42px;height:42px;flex:0 0 auto}
.mini-music-cover{width:42px;height:42px;border-radius:999px;object-fit:cover;background:var(--soft);display:block;animation:miniRecordSpin 5.2s linear infinite;animation-play-state:paused}
.mini-music-player.is-playing .mini-music-cover{animation-play-state:running}
.mini-music-coverbtn{
  position:absolute;
  inset:0;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(2,6,18,.22);
  backdrop-filter:blur(6px);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  opacity:0;
  transform:scale(.98);
  transition:opacity .16s ease,transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease
}
.mini-music-coverico.is-pause{display:none}
.mini-music-player.is-playing .mini-music-coverico.is-play{display:none}
.mini-music-player.is-playing .mini-music-coverico.is-pause{display:block}
.mini-music-player.is-paused .mini-music-coverico.is-play{display:block}
.mini-music-player.is-paused .mini-music-coverico.is-pause{display:none}
.mini-music-player.is-on .mini-music-coverwrap:hover .mini-music-coverbtn{opacity:1;transform:scale(1)}
.mini-music-player.is-paused .mini-music-coverbtn{opacity:1;transform:scale(1)}
.mini-music-coverbtn:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(124,77,255,.22),0 14px 34px rgba(0,0,0,.18)}
.mini-music-coverbtn:hover{background:rgba(2,6,18,.28);border-color:rgba(255,255,255,.28)}
.mini-music-coverbtn:active{transform:scale(.985)}
.mini-music-meta{min-width:0;flex:1}
.mini-music-title{display:flex;align-items:center;gap:8px;min-width:0}
.mini-music-name{font-weight:900;color:var(--text);line-height:1.2}
.mini-music-name{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-music-eq{display:none;gap:3px;align-items:flex-end;opacity:.72}
.mini-music-eq span{width:3px;height:6px;border-radius:999px;background:rgba(124,77,255,.90);transform-origin:50% 100%}
.mini-music-player.is-playing .mini-music-eq{display:inline-flex}
.mini-music-player.is-playing .mini-music-eq span{animation:miniEq 1s ease-in-out infinite}
.mini-music-player.is-playing .mini-music-eq span:nth-child(2){animation-delay:.12s}
.mini-music-player.is-playing .mini-music-eq span:nth-child(3){animation-delay:.24s}
.mini-music-player.is-playing .mini-music-eq span:nth-child(4){animation-delay:.36s}
@keyframes miniEq{0%,100%{transform:scaleY(.65)}50%{transform:scaleY(1.6)}}
.mini-music-singer{margin-top:2px;font-size:12px;color:var(--muted);font-weight:700;line-height:1.2}
.mini-music-ctl{
  width:34px;height:34px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  background:rgba(2,6,18,.04);
  color:rgba(2,6,18,.80);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  flex:0 0 auto;
  transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease
}
.mini-music-ctl:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(124,77,255,.18),0 14px 34px rgba(124,77,255,.14)}
.mini-music-ctl:hover{background:rgba(124,77,255,.08);border-color:rgba(124,77,255,.18);box-shadow:0 14px 34px rgba(124,77,255,.14);transform:translateY(-1px)}
.mini-music-ctl:active{transform:translateY(0)}
.mini-music-ico.is-pause,.mini-music-ico.is-mute{display:none}
.mini-music-play.is-playing .mini-music-ico.is-play{display:none}
.mini-music-play.is-playing .mini-music-ico.is-pause{display:block}
.mini-music-mute.is-muted .mini-music-ico.is-vol{display:none}
.mini-music-mute.is-muted .mini-music-ico.is-mute{display:block}
.mini-music.is-sheet-open .mini-music-sheetbtn svg{transform:rotate(180deg)}
.mini-music-sheetbtn svg{transition:transform .22s cubic-bezier(.2,.9,.2,1)}
.mini-music-play.is-playing{background:rgba(124,77,255,.14);border-color:rgba(124,77,255,.22);color:rgba(124,77,255,.92)}
.mini-music-play.is-playing:before{
  content:"";
  position:absolute;
  inset:-3px;
  border-radius:14px;
  background:radial-gradient(closest-side, rgba(124,77,255,.22), rgba(124,77,255,0));
  opacity:.75;
  animation:miniPulse 1.6s ease-in-out infinite;
  pointer-events:none
}
@keyframes miniPulse{0%,100%{transform:scale(.98);opacity:.55}50%{transform:scale(1.06);opacity:.88}}
.mini-music-play{position:relative}
.mini-music-popwrap{position:relative;flex:0 0 auto}
.mini-music-pill{
  height:34px;
  padding:0 10px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  background:rgba(2,6,18,.04);
  color:rgba(2,6,18,.82);
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  font-weight:900;
  user-select:none;
  transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease
}

@media (prefers-reduced-motion: reduce){
  .top-music-cover,
  .mini-music-cover{animation:none}
}
.mini-music-pill:hover{background:rgba(124,77,255,.08);border-color:rgba(124,77,255,.18);box-shadow:0 14px 34px rgba(124,77,255,.14);transform:translateY(-1px)}
.mini-music-pill:active{transform:translateY(0)}
.mini-music-pill:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(124,77,255,.18),0 14px 34px rgba(124,77,255,.14)}
.mini-music-lyricbtn{width:34px;justify-content:center;padding:0}
.mini-music-lyricbtn:not(.is-on){opacity:.45}
.mini-music-modebtn{width:34px;justify-content:center;padding:0}
.mini-music-modebtn .mini-music-modetxt{display:none}
.mini-music-modebtn .mini-music-modeico{display:none}
.mini-music-modebtn[data-mode="order"] .mini-music-modeico.is-order{display:block}
.mini-music-modebtn[data-mode="shuffle"] .mini-music-modeico.is-shuffle{display:block}
.mini-music-modebtn[data-mode="single"] .mini-music-modeico.is-single{display:block}
.mini-music-modebtn[data-mode="list"] .mini-music-modeico.is-list{display:block}
.mini-music-pop{
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  z-index:20;
  min-width:168px;
  padding:8px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.94);
  box-shadow:0 24px 66px rgba(0,0,0,.18);
  backdrop-filter:blur(14px);
  opacity:0;
  transform:translateY(8px) scale(.99);
  pointer-events:none;
  transition:opacity .16s ease,transform .18s cubic-bezier(.2,.9,.2,1)
}
.mini-music-pop[aria-hidden="false"]{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.mini-music-modepop{
  left:50%;
  right:auto;
  z-index:80;
  transform:translate(-50%,8px) scale(.99)
}
.mini-music-modepop[aria-hidden="false"]{transform:translate(-50%,0) scale(1)}
.mini-music.is-mode-open .mini-music-lyrics,
.mini-music.is-mode-open .mini-music-progressrow{pointer-events:none}
.mini-music-popitem{
  width:100%;
  appearance:none;
  -webkit-appearance:none;
  border:0;
  background:transparent;
  padding:8px 10px;
  border-radius:12px;
  display:flex;
  align-items:center;
  gap:10px;
  font:inherit;
  color:var(--text);
  cursor:pointer;
  font-weight:900
}
.mini-music-popitem:hover{background:rgba(124,77,255,.10)}
.mini-music-popitem.is-active{background:rgba(124,77,255,.14);color:rgba(124,77,255,.92)}
.mini-music-volpop{
  min-width:auto;
  width:72px;
  height:210px;
  padding:14px 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  left:50%;
  right:auto;
  z-index:80;
  transform:translate(-50%,8px) scale(.99)
}
.mini-music-volval{
  position:absolute;
  top:10px;
  left:50%;
  transform:translateX(-50%);
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.06);
  background:rgba(2,6,18,.04);
  font-size:11px;
  font-weight:900;
  color:rgba(2,6,18,.72);
  line-height:1;
  pointer-events:none;
  user-select:none
}
.mini-music-volpop[aria-hidden="false"]{transform:translate(-50%,0) scale(1)}
.mini-music-volpop .mini-music-range.mini-music-volrange{
  width:180px;
  height:32px;
  transform:rotate(-90deg);
  transform-origin:50% 50%;
  display:block
}
.mini-music-progressrow{
  margin-top:8px;
  padding:0 2px;
  display:flex;
  align-items:center;
  gap:10px
}
.mini-music-time{font-size:11px;font-weight:900;color:rgba(2,6,18,.58);width:44px;text-align:center;flex:0 0 auto}
.mini-music-progress-range{height:20px}
.mini-music-progress-range::-webkit-slider-runnable-track{height:4px}
.mini-music-progress-range::-moz-range-track{height:4px}
.mini-music-progress-range::-webkit-slider-thumb{width:14px;height:14px;margin-top:-5px}
.mini-music-progress-range::-moz-range-thumb{width:14px;height:14px}
.mini-page [data-mini-music-progress]{--track-on:var(--mini-music-progress-color, rgba(124,77,255,.92))}
.mini-page [data-mini-music-volrange]{--track-on:var(--mini-music-volume-color, rgba(124,77,255,.92))}
.mini-music-range{
  --p:0%;
  --track-on:rgba(124,77,255,.92);
  --track-off:rgba(2,6,18,.10);
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height:32px;
  background:transparent;
  outline:0
}
.mini-music-range::-webkit-slider-runnable-track{
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--track-on) 0 var(--p), var(--track-off) var(--p) 100%);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)
}
.mini-music-range::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:18px;
  height:18px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  border:1px solid rgba(0,0,0,.10);
  margin-top:-5px
}
.mini-music-progressline .mini-music-range::-webkit-slider-thumb{opacity:0;transform:scale(.86);transition:opacity .16s ease,transform .16s ease}
.mini-music-progressline:hover .mini-music-range::-webkit-slider-thumb,
.mini-music-progressline:focus-within .mini-music-range::-webkit-slider-thumb{opacity:1;transform:scale(1)}
.mini-music-range:focus-visible::-webkit-slider-thumb{
  box-shadow:0 0 0 4px rgba(124,77,255,.22), 0 10px 24px rgba(0,0,0,.18)
}
.mini-music-range::-moz-range-track{
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--track-on) 0 var(--p), var(--track-off) var(--p) 100%);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)
}
.mini-music-range::-moz-range-thumb{
  width:18px;
  height:18px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  box-shadow:0 10px 24px rgba(0,0,0,.18)
}
.mini-music-modeico{flex:0 0 auto}
.mini-music-modetxt{font-size:12px;letter-spacing:.2px;white-space:nowrap}
.mini-music-audio{display:none!important}
.mini-music-lyrics{
  margin-top:8px;
  margin-bottom:6px;
  padding:0;
  border-radius:0;
  border:0;
  background:transparent;
  cursor:default;
  user-select:none;
  text-align:center;
  position:relative;
  z-index:1;
  max-height:0;
  opacity:0;
  transform:translateY(-6px);
  overflow:hidden;
  pointer-events:none;
  transition:max-height 1.2s cubic-bezier(.18,.92,.18,1),opacity .72s ease,transform 1.2s cubic-bezier(.18,.92,.18,1)
}
.mini-music-lyrics.is-on{
  max-height:260px;
  opacity:1;
  transform:translateY(0);
  pointer-events:auto
}
.mini-music-lyricbar{display:flex;flex-direction:column;gap:6px;overflow:visible;align-items:center;justify-content:center;min-height:84px;padding:6px 0}
.mini-music-lyricbar.is-anim .mini-music-lyricline.is-cur{animation:miniLyricSlide .62s cubic-bezier(.22,.98,.2,1) both}
.mini-music-lyricline{width:100%;min-height:20px;font-weight:900;color:rgba(2,6,18,.56);font-size:11px;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.62;transform:scale(.96)}
.mini-music-lyricline.is-cur{color:var(--mini-music-lyric-cur, rgba(124,77,255,.92));font-size:14px;min-height:22px}
.mini-music-lyricline.is-prev,.mini-music-lyricline.is-next{opacity:.52;transform:scale(.94)}
.mini-music-lyricline.is-cur{opacity:1;transform:scale(1);text-align:center}
@keyframes miniLyricSlide{from{opacity:.78;transform:translateY(6px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
.mini-music-sheet{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% - 1px);
  z-index:12;
  display:none
}
.mini-music-sheet.is-open{display:block}
.mini-music-sheet-mask{
  position:fixed;
  inset:0;
  background:rgba(2,6,18,.18);
  backdrop-filter:blur(2px);
  z-index:0
}
.mini-music-sheet-panel{
  position:relative;
  z-index:1;
  left:auto;
  bottom:auto;
  transform:none;
  width:100%;
  max-height:min(55vh,520px);
  border-radius:0 0 18px 18px;
  border:1px solid rgba(255,255,255,.22);
  border-top:0;
  background:rgba(255,255,255,.96);
  box-shadow:0 26px 72px rgba(0,0,0,.18);
  backdrop-filter:blur(14px);
  overflow:hidden;
  display:flex;
  flex-direction:column
}
.mini-music-sheet-hd{
  padding:12px 12px 10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:1px solid rgba(0,0,0,.06)
}
.mini-music-sheet-title{font-weight:900;color:var(--text)}
.mini-music-sheet-close{
  margin-left:auto;
  width:34px;height:34px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft);
  cursor:pointer;
  font-size:18px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center
}
.mini-music-list{
  padding:12px;
  display:grid;
  gap:8px;
  overflow:auto
}
.mini-music-empty{margin-top:10px;color:var(--muted);font-weight:900;font-size:12px}
.mini-music-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.88);
  cursor:pointer;
  user-select:none;
  transition:background .16s ease,transform .16s ease,box-shadow .16s ease,border-color .16s ease
}
.mini-music-item.is-enter{animation:miniMusicIn .38s cubic-bezier(.2,.9,.2,1) both}
.mini-music-item:hover{background:rgba(255,255,255,.96);box-shadow:0 18px 44px rgba(0,0,0,.10);transform:translateY(-1px)}
.mini-music-item:active{transform:translateY(0)}
.mini-music-item.is-playing{border-color:rgba(124,77,255,.55);box-shadow:0 18px 44px rgba(124,77,255,.18)}
.mini-music-item-cover{width:34px;height:34px;border-radius:12px;object-fit:cover;background:var(--soft);flex:0 0 auto}
.mini-music-item-meta{min-width:0;flex:1}
.mini-music-item-name{font-weight:900;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-music-item-singer{margin-top:2px;font-size:12px;color:var(--muted);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-music-item-act{flex:0 0 auto;color:var(--muted);font-weight:900;font-size:12px}
.mini-music-item-act{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.06);
  background:rgba(2,6,18,.04)
}
.mini-music-item.is-playing .mini-music-item-act{
  background:rgba(124,77,255,.14);
  border-color:rgba(124,77,255,.22);
  color:rgba(124,77,255,.92)
}
@keyframes miniMusicIn{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes miniLyricTick{from{opacity:.2;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.mini-shortcut{margin-top:16px;position:relative;z-index:1}
.mini-shortcut.is-hidden{display:none}
.mini-shortcut-head{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}
.mini-shortcut-tabs{display:inline-flex;gap:6px;align-items:center;padding:4px;border-radius:999px;background:rgba(2,6,18,.18);border:1px solid rgba(255,255,255,.16);backdrop-filter:blur(10px)}
.mini-shortcut-tab{height:32px;padding:0 12px;border-radius:999px;border:0;background:transparent;color:rgba(255,255,255,.78);font-weight:900;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}
.mini-shortcut-tab:hover{background:rgba(255,255,255,.10)}
.mini-shortcut-tab:active{transform:scale(.98)}
.mini-shortcut-tab.is-active{background:rgba(255,255,255,.18);color:#fff}
.mini-shortcut-size{height:34px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.72);backdrop-filter:blur(10px);padding:0 10px;font-weight:900}
.mini-shortcut-filters{margin-top:10px;display:flex;justify-content:center;flex-wrap:wrap;gap:8px}
.mini-shortcut-chip{height:30px;padding:0 10px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(2,6,18,.18);color:rgba(255,255,255,.78);font-weight:900;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}
.mini-shortcut-chip:hover{background:rgba(255,255,255,.10)}
.mini-shortcut-chip:active{transform:scale(.98)}
.mini-shortcut-chip.is-active{background:rgba(255,255,255,.18);color:#fff}
.mini-shortcut-pager{margin-top:12px;display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;color:rgba(255,255,255,.78);font-size:12px;font-weight:900}
.mini-shortcut-pagebtn{height:32px;padding:0 12px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:rgba(2,6,18,.18);color:rgba(255,255,255,.84);font-weight:900;cursor:pointer;transition:background .18s ease,transform .18s ease,opacity .18s ease}
.mini-shortcut-pagebtn:hover{background:rgba(255,255,255,.10)}
.mini-shortcut-pagebtn:active{transform:scale(.98)}
.mini-shortcut-pagebtn:disabled{opacity:.45;cursor:not-allowed}
.mini-shortcut-pageinfo{min-width:120px;text-align:center}
.mini-shortcut-empty{margin-top:14px;color:rgba(255,255,255,.72);font-weight:900;font-size:13px}
.mini-shortcuts{margin-top:18px;gap:12px}
.mini-site-card{
  height:58px;
  border-radius:16px;
  border-color:rgba(255,255,255,.20);
  background:rgba(255,255,255,.72);
  box-shadow:0 22px 56px rgba(0,0,0,.18);
  backdrop-filter:blur(10px)
}
.mini-site-card:hover{box-shadow:0 28px 78px rgba(0,0,0,.22)}
.mini-panel{
  position:fixed;inset:0;
  z-index:40;
  pointer-events:none;
}
.mini-panel.is-open{pointer-events:auto}
.mini-panel-mask{
  position:absolute;inset:0;
  background:rgba(2,6,18,.42);
  opacity:0;
  backdrop-filter:blur(0px);
  transition:opacity .26s ease,backdrop-filter .44s cubic-bezier(.2,.9,.2,1)
}
.mini-panel.is-open .mini-panel-mask{opacity:1;backdrop-filter:blur(8px)}
.mini-panel-drawer{
  position:absolute;right:0;top:0;height:100%;
  width:min(380px,92vw);
  background:var(--card);
  border-left:1px solid var(--line);
  opacity:0;
  transform:translateX(104%) scale(.98);
  transform-origin:100% 50%;
  transition:opacity .28s ease,transform .44s cubic-bezier(.2,.9,.2,1);
  display:flex;
  flex-direction:column
}
.mini-panel.is-open .mini-panel-drawer{opacity:1;transform:translateX(0) scale(1)}
.mini-panel-hd{
  padding:14px 14px 12px 14px;
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px
}
.mini-panel-title{font-weight:900}
.mini-panel-close{
  margin-left:auto;
  width:34px;height:34px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;
  line-height:1
}
html[data-theme="dark"] .mini-panel-close{
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.90)
}
html[data-theme="dark"] .mini-panel-close:hover{
  border-color:rgba(255,255,255,.22);
  background:rgba(255,255,255,.10)
}
.mini-panel-bd{padding:14px;overflow:auto}
.mini-panel-bd{padding-bottom:calc(14px + env(safe-area-inset-bottom))}
.mini-panel-bd.is-guest{
  display:flex;
  flex-direction:column;
  overflow:hidden
}
.mini-panel-guest{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column
}
.mini-panel-guest-top,
.mini-panel-guest-bottom{
  flex:1;
  min-height:0;
  display:flex;
  align-items:center;
  justify-content:center
}
.mini-panel-guest-bottom{padding-top:10px}
.mini-auth-simple{
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--soft);
  padding:18px 14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  text-align:center
}
.mini-auth-simple-ico{
  width:58px;height:58px;
  border-radius:18px;
  border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(255,90,95,.18),rgba(124,77,255,.14));
  box-shadow:0 16px 40px rgba(0,0,0,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text)
}
.mini-auth-simple-title{margin-top:2px;font-weight:950;letter-spacing:.2px}
.mini-auth-simple-sub{color:var(--muted);font-size:12px;font-weight:800;max-width:260px}
.mini-auth-simple-btn{margin-top:4px;max-width:240px;width:100%;height:40px;border-radius:12px}
.mini-panel-preview-wrap{
  position:relative;
  margin-top:12px
}
.mini-panel-guest-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px;
  z-index:2;
  pointer-events:none
}
.mini-panel-guest-overlay .mini-auth-simple{pointer-events:auto}
html[data-theme="dark"] .mini-panel-guest-overlay .mini-auth-simple{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.22);
  box-shadow:0 18px 46px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.10) inset
}
.mini-panel-preview{
  margin-top:0;
  position:relative;
  border-radius:18px;
  overflow:hidden;
  opacity:.32;
  filter:blur(1.4px) saturate(.92) contrast(1.0);
  pointer-events:none;
}
.mini-auth-hint{
  position:relative;
  border:1px solid transparent;
  border-radius:18px;
  background:
    linear-gradient(var(--card),var(--card)) padding-box,
    linear-gradient(135deg,rgba(255,90,95,.42),rgba(124,77,255,.32),rgba(255,255,255,.18)) border-box;
  padding:14px 14px;
  display:flex;
  flex-direction:column;
  gap:12px;
  box-shadow:0 18px 46px rgba(0,0,0,.10);
  overflow:hidden
}
.mini-auth-hint:before{
  content:"";
  position:absolute;inset:-1px;
  background:
    radial-gradient(520px 260px at 0% 0%,rgba(255,90,95,.18),rgba(255,90,95,0) 60%),
    radial-gradient(520px 260px at 100% 100%,rgba(124,77,255,.16),rgba(124,77,255,0) 60%);
  opacity:.9;
  pointer-events:none
}
.mini-auth-hint>*{position:relative}
.mini-auth-kicker{
  display:inline-flex;
  align-items:center;
  height:22px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--muted);
  font-size:11px;
  font-weight:900;
  letter-spacing:.4px;
  width:max-content
}
.mini-auth-top{display:flex;gap:12px;align-items:center}
.mini-auth-ico{
  width:38px;height:38px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  background:rgba(255,255,255,.62);
  color:var(--text)
}
.mini-auth-title{font-weight:900;letter-spacing:.2px}
.mini-auth-sub{margin-top:3px;color:var(--muted);font-size:12px;font-weight:700}
.mini-auth-foot{display:flex;flex-direction:column;gap:8px}
.mini-auth-btn{width:100%;height:40px;border-radius:12px;box-shadow:0 14px 34px rgba(255,90,95,.18)}
.mini-auth-btn:hover{box-shadow:0 18px 44px rgba(255,90,95,.22)}
.mini-auth-note{font-size:11px;color:var(--muted);font-weight:800;text-align:center;letter-spacing:.2px}
.mini-panel-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mini-panel-actions .btn{height:40px;border-radius:12px}
.mini-panel-actions .btn.primary{grid-column:1/-1}
.mini-panel-sec{margin-top:10px;padding-top:8px;border-top:1px solid var(--line)}
.mini-panel-sec:first-of-type{margin-top:8px;padding-top:0;border-top:0}
.mini-panel-sec-title{
  font-weight:900;
  margin-bottom:6px;
  font-size:12px;
  letter-spacing:.12px;
  display:inline-flex;
  align-items:center;
  gap:8px
}
.mini-panel-sec-title:before{
  content:"";
  width:9px;height:9px;
  border-radius:4px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  box-shadow:0 10px 22px rgba(0,0,0,.12);
  backdrop-filter:blur(10px);
  opacity:.82
}
[data-mini-sec-key="text"] .mini-panel-sec-title:before{
  background:linear-gradient(135deg,rgba(255,90,95,.40),rgba(255,90,95,.10));
  border-color:rgba(255,90,95,.20)
}
[data-mini-sec-key="bookmarks"] .mini-panel-sec-title:before{
  background:linear-gradient(135deg,rgba(112,226,255,.34),rgba(112,226,255,.10));
  border-color:rgba(112,226,255,.18)
}
[data-mini-sec-key="blur"] .mini-panel-sec-title:before{
  background:linear-gradient(135deg,rgba(200,170,255,.34),rgba(200,170,255,.10));
  border-color:rgba(200,170,255,.18)
}
[data-mini-sec-key="bg"] .mini-panel-sec-title:before{
  background:linear-gradient(135deg,rgba(255,225,120,.32),rgba(255,225,120,.10));
  border-color:rgba(255,225,120,.18)
}
.mini-panel-sec-toggle{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:1px 0;
  border:0;
  background:transparent;
  color:inherit;
  cursor:pointer;
  font:inherit;
  text-align:left
}
.mini-panel-sec-toggle:focus-visible{outline:2px solid rgba(255,90,95,.35);outline-offset:3px;border-radius:12px}
.mini-panel-sec-toggle .mini-panel-sec-title{margin-bottom:0}
.mini-panel-sec-caret{
  width:22px;height:22px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.42);
  box-shadow:0 10px 24px rgba(0,0,0,.10);
  backdrop-filter:blur(10px);
  display:flex;
  align-items:center;
  justify-content:center;
  flex:none;
  transition:transform .22s cubic-bezier(.2,.9,.2,1),background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease
}
.mini-panel-sec-caret svg{display:none}
.mini-panel-sec-caret:before{
  content:"";
  width:6px;height:6px;
  border-right:1.6px solid currentColor;
  border-bottom:1.6px solid currentColor;
  opacity:.78;
  transform:translateY(-.5px) rotate(45deg);
}
.mini-panel-sec-toggle:hover .mini-panel-sec-caret{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,90,95,.18);
  color:rgba(255,90,95,.75);
  box-shadow:0 14px 34px rgba(0,0,0,.14)
}
.mini-panel-sec.is-open .mini-panel-sec-caret{transform:rotate(180deg)}
.mini-panel-sec-body{
  display:grid;
  grid-template-rows:0fr;
  opacity:0;
  transition:grid-template-rows .22s cubic-bezier(.2,.9,.2,1),opacity .16s ease;
}
.mini-panel-sec-body-inner{overflow:hidden;padding-top:6px}
.mini-panel-sec.is-open .mini-panel-sec-body{grid-template-rows:1fr;opacity:1}
.mini-opt-row{display:flex;align-items:center;justify-content:space-between;margin-top:6px}
.mini-opt-row:first-of-type{margin-top:0}
.mini-title.is-hidden,.mini-sub.is-hidden{display:none}
.mini-text-row{display:flex;align-items:center;gap:6px;margin-top:6px}
.mini-text-row:first-of-type{margin-top:0}
.mini-text-input{flex:1;min-width:0;height:30px}
.mini-check{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;font-weight:900;user-select:none;white-space:nowrap}
.mini-check input{width:16px;height:16px;accent-color:var(--primary)}
.mini-text-actions{margin-top:6px;display:flex;justify-content:flex-end}
.mini-music-set{display:flex;flex-direction:column;gap:8px}
[data-mini-sec-key="music"] .mini-panel-sec-body-inner{padding-top:6px}
.mini-music-card{
  border:1px solid var(--line);
  border-radius:14px;
  background:
    linear-gradient(var(--card),var(--card)) padding-box,
    linear-gradient(135deg,rgba(124,77,255,.16),rgba(255,255,255,.10)) border-box;
  box-shadow:0 10px 24px rgba(0,0,0,.05);
  padding:8px 8px
}
.mini-music-card-hd{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.mini-music-card-title{font-weight:950;font-size:12px;letter-spacing:.10px}
.mini-music-card-meta{
  margin-left:auto;
  height:22px;
  display:inline-flex;
  align-items:center;
  padding:0 8px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft);
  font-size:11px;
  font-weight:950;
  color:var(--text)
}
.mini-music-card-tip{margin-left:auto;color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.12px}
.mini-music-switches{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.mini-music-switch{
  border:1px solid var(--line);
  background:var(--soft);
  border-radius:14px;
  padding:8px 8px;
  justify-content:flex-start
}
.mini-music-switch input{margin-top:0}
.mini-music-volume input[type="range"]{width:100%}
.mini-music-colors{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
.mini-music-color{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 6px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.55)
}
html[data-theme="dark"] .mini-music-color{background:rgba(255,255,255,.04)}
.mini-music-color-title{
  width:100%;
  text-align:center;
  font-size:11px;
  font-weight:950;
  letter-spacing:.12px;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis
}
.mini-music-color-sub{display:none}
.mini-music-color-input{
  width:20px;
  min-width:20px;
  height:20px;
  padding:0;
  border-radius:7px;
  border:1px solid rgba(0,0,0,.14);
  background:transparent;
  cursor:pointer
}
html[data-theme="dark"] .mini-music-color-input{border-color:rgba(255,255,255,.16)}
.mini-music-color-input::-webkit-color-swatch-wrapper{padding:0}
.mini-music-color-input::-webkit-color-swatch{border:0;border-radius:6px}
.mini-music-actions{margin-top:6px;display:flex;justify-content:flex-end;gap:8px}
.mini-music-actions .btn{height:34px;border-radius:12px}
.mini-blur-row{display:flex;align-items:center;gap:10px}
.mini-blur-row input[type="range"]{flex:1}
.mini-blur-val{min-width:58px;text-align:right;font-weight:900;color:var(--text)}
.mini-blur-tip{margin-top:6px}
.mini-bg-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.mini-bg-pager{
  margin-top:10px;
  display:flex;
  justify-content:center
}
.mini-bg-pager-box{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft)
}
.mini-bg-pagebtn{
  width:34px;
  height:34px;
  padding:0;
  border-radius:999px;
  border:0;
  background:transparent;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  cursor:pointer
}
.mini-bg-pagebtn:hover,.mini-bg-pagebtn:focus-visible{outline:0;background:var(--card)}
.mini-bg-pagebtn:disabled{opacity:.5;cursor:not-allowed}
.mini-bg-pageinfo{min-width:110px;text-align:center;font-weight:900;letter-spacing:.2px;color:var(--muted)}
.mini-bg-pagejump{display:flex;align-items:center;gap:6px;padding-left:8px;margin-left:4px;border-left:1px solid var(--line)}
.mini-bg-pageinput{width:76px;height:34px;border-radius:999px}
.mini-bg-pageinput{appearance:textfield;-moz-appearance:textfield}
.mini-bg-pageinput::-webkit-outer-spin-button,.mini-bg-pageinput::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.mini-bg-pagego{height:34px;border-radius:999px}
.mini-bg-cell{position:relative}
.mini-bg-item.is-placeholder{cursor:default;background:var(--card);opacity:.42}
.mini-bg-item.is-placeholder:hover,.mini-bg-item.is-placeholder:focus-visible{background:var(--card)}
.mini-bg-item{
  position:relative;
  border:2px solid transparent;
  border-radius:14px;
  background:var(--soft);
  cursor:pointer;
  overflow:hidden;
  padding:0;
  aspect-ratio:4/3
}
.mini-bg-label{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(2,6,18,.40);
  color:rgba(255,255,255,.94);
  font-size:12px;
  font-weight:900;
  letter-spacing:.2px;
  white-space:nowrap;
  backdrop-filter:blur(10px);
  pointer-events:none;
  user-select:none
}
html:not([data-theme="dark"]) .mini-bg-label{
  border-color:rgba(2,6,18,.12);
  background:rgba(255,255,255,.80);
  color:rgba(2,6,18,.92)
}
.mini-bg-item img{width:100%;height:100%;object-fit:cover;display:block}
.mini-bg-item.is-active{border-color:var(--primary)}
.mini-bg-dl{
  position:absolute;
  right:10px;
  bottom:10px;
  height:32px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(2,6,18,.40);
  color:rgba(255,255,255,.94);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  cursor:pointer;
  backdrop-filter:blur(10px);
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .16s ease,transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease
}
.mini-bg-cell:hover .mini-bg-dl,.mini-bg-cell:focus-within .mini-bg-dl{opacity:1;pointer-events:auto;transform:translateY(0)}
.mini-bg-dl:hover{background:rgba(2,6,18,.52);border-color:rgba(255,255,255,.28);box-shadow:0 12px 30px rgba(0,0,0,.16)}
.mini-bg-dl:active{transform:translateY(1px)}
.mini-bg-dl svg{width:16px;height:16px}
.mini-bg-dl-txt{font-size:12px;font-weight:900;letter-spacing:.2px}
@media (hover:none){
  .mini-bg-dl{opacity:1;pointer-events:auto;transform:none}
}
html:not([data-theme="dark"]) .mini-bg-dl{
  border-color:rgba(2,6,18,.12);
  background:rgba(255,255,255,.80);
  color:rgba(2,6,18,.92);
}
html:not([data-theme="dark"]) .mini-bg-dl:hover{
  border-color:rgba(2,6,18,.16);
  background:rgba(255,255,255,.92);
  box-shadow:0 12px 30px rgba(2,6,18,.10);
}
html[data-theme="dark"] .mini-page:before{background:linear-gradient(180deg, rgba(2,6,18,.46), rgba(2,6,18,.24) 40%, rgba(2,6,18,.72))}
html[data-theme="dark"] .mini-search{background:rgba(2,6,18,.46);border-color:rgba(255,255,255,.12)}
html[data-theme="dark"] .mini-music{background:rgba(2,6,18,.46);border-color:rgba(255,255,255,.12)}
html[data-theme="dark"] .mini-music:before{background:linear-gradient(135deg, rgba(124,77,255,.34), rgba(0,0,0,0), rgba(255,255,255,.10))}
html[data-theme="dark"] .mini-music-kicker{color:rgba(255,255,255,.92)}
html[data-theme="dark"] .mini-music-recent{background:rgba(2,6,18,.92);border-color:rgba(255,255,255,.12);box-shadow:0 24px 66px rgba(0,0,0,.34)}
html[data-theme="dark"] .mini-music-recent-item{color:rgba(255,255,255,.88)}
html[data-theme="dark"] .mini-music-recent-item:hover{background:rgba(124,77,255,.18);border-color:rgba(124,77,255,.18)}
html[data-theme="dark"] .mini-music-recent-ico{background:rgba(255,255,255,.08);color:rgba(255,255,255,.66)}
html[data-theme="dark"] .mini-music-recent-tip{color:rgba(255,255,255,.46)}
html[data-theme="dark"] .mini-music-now{background:rgba(2,6,18,.46);border-color:rgba(255,255,255,.12);box-shadow:0 18px 44px rgba(0,0,0,.24)}
html[data-theme="dark"] .mini-music-ctl{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.10);color:rgba(255,255,255,.84)}
html[data-theme="dark"] .mini-music-ctl:hover{background:rgba(124,77,255,.16);border-color:rgba(124,77,255,.28);box-shadow:0 14px 34px rgba(124,77,255,.18)}
html[data-theme="dark"] .mini-music-pill{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.10);color:rgba(255,255,255,.86)}
html[data-theme="dark"] .mini-music-pill:hover{background:rgba(124,77,255,.16);border-color:rgba(124,77,255,.28);box-shadow:0 14px 34px rgba(124,77,255,.18)}
html[data-theme="dark"] .mini-music-time{color:rgba(255,255,255,.56)}
html[data-theme="dark"] .mini-music-pop{background:rgba(2,6,18,.92);border-color:rgba(255,255,255,.12);box-shadow:0 24px 66px rgba(0,0,0,.34)}
html[data-theme="dark"] .mini-music-popitem{color:rgba(255,255,255,.88)}
html[data-theme="dark"] .mini-music-popitem:hover{background:rgba(124,77,255,.18)}
html[data-theme="dark"] .mini-music-popitem.is-active{background:rgba(124,77,255,.22);color:rgba(208,194,255,.98)}
html[data-theme="dark"] .mini-music-coverbtn{border-color:rgba(255,255,255,.14);background:rgba(2,6,18,.36)}
html[data-theme="dark"] .mini-music-coverbtn:hover{background:rgba(2,6,18,.46);border-color:rgba(255,255,255,.22)}
html[data-theme="dark"] .mini-music-volval{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.14);color:rgba(255,255,255,.86)}
html[data-theme="dark"] .mini-music-range{--track-off:rgba(255,255,255,.14)}
html[data-theme="dark"] .mini-music-range::-webkit-slider-thumb{background:rgba(255,255,255,.96);border-color:rgba(255,255,255,.14)}
html[data-theme="dark"] .mini-music-range::-moz-range-thumb{background:rgba(255,255,255,.96);border-color:rgba(255,255,255,.14)}
html[data-theme="dark"] .mini-music-eq span{background:rgba(208,194,255,.96)}
html[data-theme="dark"] .mini-music-item{background:rgba(2,6,18,.42);border-color:rgba(255,255,255,.12)}
html[data-theme="dark"] .mini-music-item:hover{background:rgba(2,6,18,.54)}
html[data-theme="dark"] .mini-music-item-act{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.10);color:rgba(255,255,255,.64)}
html[data-theme="dark"] .mini-music-item.is-playing .mini-music-item-act{background:rgba(124,77,255,.18);border-color:rgba(124,77,255,.28);color:rgba(208,194,255,.96)}
html[data-theme="dark"] .mini-music-lyrics{background:transparent;border-color:transparent}
html[data-theme="dark"] .mini-music-lyricline{color:rgba(255,255,255,.62)}
html[data-theme="dark"] .mini-music-lyricline.is-cur{color:var(--mini-music-lyric-cur, rgba(124,77,255,.92))}
html[data-theme="dark"] .mini-music-sheet-mask{background:rgba(2,6,18,.44);backdrop-filter:blur(4px)}
html[data-theme="dark"] .mini-music-sheet-panel{background:rgba(2,6,18,.90);border-color:rgba(255,255,255,.12)}
html[data-theme="dark"] .mini-music-sheet-hd{border-bottom-color:rgba(255,255,255,.10)}
html[data-theme="dark"] .mini-site-card{background:rgba(2,6,18,.42);border-color:rgba(255,255,255,.12)}
@media (max-width:860px){
  .mini-title{font-size:24px}
  .mini-search{border-radius:16px}
  .site-grid.cols-4.mini-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:860px){
  .mini-add{grid-template-columns:1fr;gap:10px}
  .site-grid.cols-4.mini-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
.top-title{font-weight:700}
.top-actions{display:flex;align-items:center;gap:10px;margin-left:auto;justify-content:flex-end;min-width:0}
.top-quote{
  margin-right:0;
  max-width:min(720px,60vw);
  color:var(--muted);
  font-size:13px;
  font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  user-select:none
}
.is-home .top-quote,.is-hero .top-quote{color:rgba(255,255,255,.82)}
.is-home.is-top-solid .top-quote,
.is-hero.is-top-solid .top-quote{color:var(--muted)}
@media (max-width:1024px){
  .top-actions .top-quote{display:none !important}
}
.top-actions .btn{display:inline-flex;align-items:center;justify-content:center}
.btn{
  height:34px;padding:0 12px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--text);cursor:pointer;white-space:nowrap;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;text-decoration:none
}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.danger{
  background:rgba(239,68,68,.10);
  border-color:rgba(239,68,68,.28);
  color:#ef4444
}
.btn.danger:hover{
  background:rgba(239,68,68,.14);
  border-color:rgba(239,68,68,.42)
}
.btn.danger:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(239,68,68,.18)}
.btn.danger:active{transform:translateY(1px)}
.btn.btn-ico{width:34px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px}
.btn.btn-ico svg{display:block}
[data-app="front"] .top-actions .btn.btn-ico{width:38px;height:38px}
[data-app="front"] .top-actions .btn.btn-ico svg{width:20px;height:20px}
[data-app="front"] .top-actions .btn.btn-ico svg [stroke]{stroke-width:2.8}
.btn.btn-ico[data-tip]{position:relative}
.btn.btn-ico .user-entry-dot{
  position:absolute;right:6px;bottom:6px;
  width:8px;height:8px;border-radius:999px;
  background:#ef4444;
  display:none
}
.btn.btn-ico.has-unread .user-entry-dot{display:block}
.btn.btn-ico[data-tip]:before{
  content:attr(data-tip);
  position:absolute;left:50%;top:calc(100% + 10px);
  transform:translate(-50%,-6px);
  padding:7px 10px;border-radius:10px;
  background:var(--tip-bg);color:var(--tip-text);
  font-size:12px;font-weight:800;letter-spacing:.2px;
  white-space:nowrap;
  z-index:80;
  opacity:0;pointer-events:none;
  box-shadow:0 16px 40px rgba(0,0,0,.22);
  transition:opacity .08s ease,transform .08s ease
}
.btn.btn-ico[data-tip]:after{
  content:"";
  position:absolute;left:50%;top:calc(100% + 4px);
  transform:translate(-50%,-6px);
  border:6px solid transparent;border-bottom-color:var(--tip-bg);
  z-index:80;
  opacity:0;pointer-events:none;
  transition:opacity .08s ease,transform .08s ease
}
.btn.btn-ico[data-tip]:hover:before,.btn.btn-ico[data-tip]:hover:after,.btn.btn-ico[data-tip]:focus-visible:before,.btn.btn-ico[data-tip]:focus-visible:after{opacity:1;transform:translate(-50%,0)}
.search-modal{position:fixed;inset:0;z-index:80;display:none}
.search-modal.is-open{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:calc(16px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))
}
.search-modal-mask{position:absolute;inset:0;background:rgba(0,0,0,.42);backdrop-filter:blur(4px)}
.search-modal-panel{
  position:relative;margin:0;width:min(980px,100%);
  max-height:min(78vh,720px);
  background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:0 22px 70px rgba(0,0,0,.28);
  overflow:hidden;
  opacity:0;
  transform:translate3d(0,12px,0) scale(.985);
  transition:opacity .18s ease,transform .18s ease
}
.search-modal.is-open .search-modal-panel{opacity:1;transform:translate3d(0,0,0) scale(1)}
.search-modal-enginebar{padding:12px 12px 0 12px;background:var(--bar-bg);backdrop-filter:blur(10px)}
.search-modal-enginebar .enginebar{margin-top:0}
.search-modal-row{display:flex;align-items:center;gap:10px;padding:12px 12px;border-bottom:1px solid var(--line);background:var(--bar-bg);backdrop-filter:blur(10px)}
.search-modal-search{flex:1;width:100%;max-width:none;box-shadow:none}
.search-modal-close{flex:none}
.search-modal-bd{padding:12px 12px 14px 12px;overflow:auto;max-height:calc(min(78vh,720px) - 110px)}
.search-modal-adbar{margin-top:0;margin-bottom:12px}
.search-modal-empty{display:none;padding:14px 6px}

.adpop-modal{position:fixed;inset:0;z-index:90;display:none}
.adpop-modal.is-open{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:calc(16px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))
}
.adpop-mask{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px)}
.adpop-panel{
  position:relative;margin:0;width:min(720px,100%);
  background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 28px 90px rgba(0,0,0,.36);
  overflow:hidden;
  opacity:0;
  transform:translate3d(0,12px,0) scale(.985);
  transition:opacity .18s ease,transform .18s ease
}
.adpop-modal[data-fab-ad-pop] .adpop-panel{width:min(520px,100%)}
.adpop-modal.is-open .adpop-panel{opacity:1;transform:translate3d(0,0,0) scale(1)}
.adpop-close{
  position:absolute;right:12px;top:12px;z-index:2;
  width:34px;height:34px;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.06);
  color:var(--text);font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;
  cursor:pointer
}
html[data-theme="dark"] .adpop-close{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.adpop-bd{padding:12px}
.adpop-link{display:block;color:inherit;text-decoration:none}
.adpop-img{width:100%;height:auto;display:block;border-radius:14px}
.adpop-modal[data-fab-ad-pop] .adpop-img{max-width:min(480px,100%);margin:0 auto}
.adpop-title{padding:34px 18px 24px 18px;font-size:18px;font-weight:900;letter-spacing:.2px;text-align:center}
.adpop-html{padding:18px 16px}
.adpop-html table{display:block;max-width:100%;overflow:auto;-webkit-overflow-scrolling:touch}
.adpop-html iframe{max-width:100%}
.home-popup{padding:6px 2px 0 2px}
.home-popup-header{padding:10px 10px 0 10px;display:flex;align-items:center;gap:12px}
.home-popup-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(47,128,237,.14);color:#2f80ed}
.home-popup-icon svg{width:32px;height:32px;display:block}
.home-popup-title-wrap{flex:1;min-width:0}
.home-popup-main-title{font-size:20px;font-weight:900;letter-spacing:.2px;line-height:1.25;margin:0;color:var(--text)}
.home-popup-sub-title{font-size:13px;line-height:1.5;margin:0;color:var(--muted)}
.home-popup-content{padding:12px 10px 6px 10px;font-size:15px;line-height:1.8;color:var(--text)}
.home-popup-section{margin:0 0 14px 0}
.home-popup-section:last-child{margin-bottom:0}
.home-popup-section-title{font-weight:900;color:var(--text);margin:0 0 8px 0;font-size:16px}
.home-popup-text{margin:0 0 8px 0;color:var(--muted)}
.home-popup-text:last-child{margin-bottom:0}
.home-popup-list{padding-left:20px;margin:0}
.home-popup-list li{margin:0 0 6px 0}
.home-popup-list li:last-child{margin-bottom:0}
.home-popup-footer{padding:0 10px 12px 10px;display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}
.home-popup-btn{padding:8px 18px;border-radius:10px;border:1px solid var(--line);background:var(--soft);color:var(--muted);font-size:14px;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}
.home-popup-btn:hover{background:var(--soft2);color:var(--text)}
.home-popup-btn:active{transform:translateY(1px)}
.home-popup-btn.primary{border-color:transparent;background:#2f80ed;color:#fff}
.home-popup-btn.primary:hover{background:#2563eb;color:#fff}

.cookie-modal{position:fixed;inset:0;z-index:95;display:none}
.cookie-modal.is-open{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:16px;
  padding-left:calc(16px + env(safe-area-inset-left));
  padding-right:calc(16px + env(safe-area-inset-right));
  padding-top:calc(16px + env(safe-area-inset-top));
  padding-bottom:calc(16px + env(safe-area-inset-bottom))
}
.cookie-mask{position:absolute;inset:0;background:rgba(0,0,0,.42);backdrop-filter:blur(4px)}
.cookie-panel{
  position:relative;
  width:min(760px,100%);
  background:var(--card);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 28px 90px rgba(0,0,0,.36);
  overflow:hidden;
  opacity:0;
  transform:translate3d(0,12px,0) scale(.985);
  transition:opacity .18s ease,transform .18s ease
}
.cookie-modal.is-open .cookie-panel{opacity:1;transform:translate3d(0,0,0) scale(1)}
.cookie-hd{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);background:var(--bar-bg);backdrop-filter:blur(10px)}
.cookie-title{font-size:14px;font-weight:900;letter-spacing:.2px;color:var(--text)}
.cookie-close{
  width:34px;height:34px;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.06);
  color:var(--text);font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex:none
}
html[data-theme="dark"] .cookie-close{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.cookie-bd{padding:12px 14px 10px 14px}
.cookie-desc{font-size:12px;line-height:1.8;color:var(--muted);font-weight:700}
.cookie-kvs{margin-top:10px;display:grid;grid-template-columns:1fr;gap:10px}
.cookie-kv{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border:1px solid var(--line);background:var(--soft);border-radius:14px}
.cookie-k{font-size:12px;font-weight:900;color:var(--text)}
.cookie-v{font-size:12px;color:var(--muted);font-weight:700;line-height:1.7}
.cookie-more{margin-top:10px}
.cookie-more-link{font-size:12px;font-weight:800;color:var(--primary)}
.cookie-more-link:hover{text-decoration:underline}
.cookie-ft{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;padding:12px 14px;border-top:1px solid var(--line);background:var(--bar-bg);backdrop-filter:blur(10px)}
@media (max-width: 640px){
  .cookie-modal.is-open{
    padding:10px;
    padding-left:calc(10px + env(safe-area-inset-left));
    padding-right:calc(10px + env(safe-area-inset-right));
    padding-top:calc(10px + env(safe-area-inset-top));
    padding-bottom:calc(10px + env(safe-area-inset-bottom))
  }
  .cookie-panel{border-radius:16px}
  .cookie-ft{justify-content:stretch}
  .cookie-ft .btn{flex:1}
}


.lock-modal-wrap {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  visibility: hidden;
}
.lock-modal-wrap.is-open {
  visibility: visible;
}
.lock-modal-mask {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity .3s;
}
.lock-modal-wrap.is-open .lock-modal-mask {
  opacity: 1;
}
.lock-modal-panel {
  position: relative;
  width: min(360px, 100%);
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: 0 40px 80px rgba(0,0,0,0.2), 0 10px 30px rgba(0,0,0,0.1);
  padding: 32px 24px 24px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  opacity: 0;
  transform: scale(0.9) translateY(10px);
  transition: opacity .3s cubic-bezier(0.19, 1, 0.22, 1), transform .3s cubic-bezier(0.19, 1, 0.22, 1);
}
.lock-modal-wrap.is-open .lock-modal-panel {
  opacity: 1;
  transform: scale(1) translateY(0);
}
.lock-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid transparent;
  background: transparent;
  color: var(--muted);
  font-size: 22px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
}
.lock-modal-close:hover {
  background: var(--soft);
  color: var(--text);
}
.lock-modal-icon {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--primary), rgba(124,77,255,0.8));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  box-shadow: 0 12px 24px rgba(124,77,255,0.3);
}
.lock-modal-title {
  font-size: 18px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 6px;
  line-height: 1.4;
}
.lock-modal-desc {
  font-size: 13px;
  color: var(--muted);
  font-weight: 500;
  margin-bottom: 24px;
  line-height: 1.6;
}
.lock-modal-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.lock-modal-input-wrap {
  position: relative;
}
.lock-modal-input {
  width: 100%;
  height: 48px;
  border-radius: 14px;
  border: 2px solid var(--line);
  background: var(--bg);
  padding: 0 44px 0 16px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  color: var(--text);
  transition: all .2s;
  outline: none;
}
.lock-modal-eye{
  position:absolute;
  top:50%;
  right:12px;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border-radius:10px;
  border:1px solid transparent;
  background:transparent;
  color:var(--muted);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:all .2s
}
.lock-modal-eye:hover{background:var(--soft);color:var(--text)}
.lock-eye-off{display:none}
.lock-modal-show-pass .lock-eye-on{display:none}
.lock-modal-show-pass .lock-eye-off{display:block}
.lock-modal-input:focus {
  border-color: var(--primary);
  background: var(--card);
  box-shadow: 0 0 0 4px rgba(124,77,255,0.1);
}
.lock-modal-submit {
  width: 100%;
  height: 48px;
  border-radius: 14px;
  background: var(--text);
  color: var(--bg);
  font-size: 15px;
  font-weight: 800;
  border: none;
  cursor: pointer;
  transition: transform .1s, opacity .2s;
}
html[data-theme="dark"] .lock-modal-submit {
  background: #fff;
  color: #000;
}
.lock-modal-submit:hover {
  opacity: 0.9;
}
.lock-modal-submit:active {
  transform: scale(0.98);
}
.lock-modal-hint {
  margin-top: 16px;
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
}
.lock-modal-hint a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 800;
}
.lock-modal-hint a:hover {
  text-decoration: underline;
}

/* New Banner Styles */
.lock-banner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 20px;
  background: var(--card);
  border: 1px dashed var(--line);
  border-radius: 24px;
  gap: 20px;
  margin: 20px 0;
  overflow: hidden;
  transition: border-color .3s;
}
.lock-banner:hover {
  border-color: var(--primary);
}
.lock-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(124,77,255,0.04), transparent 70%);
  pointer-events: none;
}
.lock-icon {
  width: 72px;
  height: 72px;
  border-radius: 20px;
  background: var(--soft);
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0;
  margin-bottom: 4px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.03);
}
.lock-icon svg {
  width: 36px;
  height: 36px;
  opacity: 0.9;
}
.lock-banner-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 480px;
  margin: 0 auto;
  z-index: 1;
}
.lock-banner-title {
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 0.5px;
  color: var(--text);
}
.lock-banner-desc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--muted);
  font-weight: 500;
}
.lock-banner-actions {
  z-index: 1;
  margin-top: 8px;
}
.lock-banner-actions .btn {
  min-width: 160px;
  height: 48px;
  border-radius: 14px;
  font-size: 15px;
  font-weight: 800;
  box-shadow: 0 8px 20px rgba(124,77,255,0.25);
  transition: transform .2s, box-shadow .2s;
}
.lock-banner-actions .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(124,77,255,0.35);
}

.lock-banner.lock-banner-grid {
  grid-column: 1 / -1;
  padding: 26px 16px;
  margin: 0;
  border-radius: 18px;
  gap: 14px;
}
.lock-banner.lock-banner-grid .lock-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
}
.lock-banner.lock-banner-grid .lock-icon svg {
  width: 28px;
  height: 28px;
}
.lock-banner.lock-banner-grid .lock-banner-title {
  font-size: 16px;
}
.lock-banner.lock-banner-grid .lock-banner-desc {
  font-size: 13px;
}
.lock-banner.lock-banner-grid .lock-banner-actions .btn {
  min-width: 150px;
  height: 42px;
  border-radius: 12px;
  font-size: 14px;
  box-shadow: 0 8px 18px rgba(124,77,255,0.22);
}
.lock-banner.lock-banner-grid .lock-banner-actions .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(124,77,255,0.30);
}

.search-page{background:linear-gradient(180deg, rgba(124,77,255,.10), transparent 60%);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:16px 16px 18px 16px}
.search-page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.search-page-title{display:flex;align-items:baseline;gap:10px}
.search-page-h1{font-size:16px;font-weight:900;letter-spacing:.2px}
.search-page-meta{font-size:12px;color:var(--muted);font-weight:800}
.search-page-bar{flex:1;min-width:min(520px,100%);max-width:860px}
html[data-theme="dark"] .search-page{background:linear-gradient(180deg, rgba(124,77,255,.14), rgba(2,6,18,.35) 55%, rgba(2,6,18,.0) 100%);border-color:rgba(255,255,255,.10);box-shadow:0 26px 80px rgba(0,0,0,.45)}
@media (max-width: 640px){
  .search-page{padding:14px}
  .search-page-bar{min-width:100%}
}
.container{max-width:1180px;margin:0 auto;padding:18px}
.container.is-wide{max-width:1320px}
.admin-container{max-width:none}
.container.home-container{max-width:none;padding:0}
.hero-wrap{padding:0}
.hero{
  border-radius:16px;overflow:hidden;background:#0b1020;color:#fff;position:relative;box-shadow:var(--shadow)
}
.hero.hero-ice{
  background:
    radial-gradient(1080px 600px at 76% 0%, rgba(92,64,255,.18), transparent 64%),
    radial-gradient(1080px 620px at 18% -10%, rgba(160,78,255,.16), transparent 68%),
    radial-gradient(980px 560px at 52% -18%, rgba(120,70,255,.12), transparent 72%),
    linear-gradient(180deg, #020612 0%, #04102a 55%, #04163a 100%)
}
.hero.hero-ice:before{
  background:linear-gradient(180deg, rgba(255,255,255,.06), transparent 62%)
}
.is-home .hero{border-radius:0}
.is-hero .hero{border-radius:0}
.hero:before{
  content:"";position:absolute;inset:0;background:
    radial-gradient(1200px 360px at 60% 0%, rgba(124,77,255,.45), transparent 60%),
    radial-gradient(900px 320px at 20% 0%, rgba(255,90,95,.38), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 55%);
  pointer-events:none
}
.stars{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;transform:translateZ(0);will-change:transform
}
.stars:before{
  content:"";position:absolute;inset:-60px;opacity:.32;
  background-image:
    radial-gradient(rgba(255,255,255,.55) 1px, transparent 1px),
    radial-gradient(rgba(255,255,255,.32) 1px, transparent 1px),
    radial-gradient(rgba(170,140,255,.18) 2px, transparent 2px);
  background-size:140px 140px, 220px 220px, 520px 520px;
  background-position:0 0, 60px 80px, 20px 120px;
  transform:translate3d(0,0,0);
  will-change:transform;
  animation:stars-drift 90s linear infinite alternate
}
.stars .star{
  position:absolute;left:0;top:0;border-radius:999px;
  background:rgba(255,255,255,.92);
  box-shadow:0 0 10px rgba(160,180,255,.22),0 0 2px rgba(255,255,255,.35);
  transform:translate3d(0,0,0);
  will-change:transform,opacity;
  animation:star-drift var(--dur,120s) linear infinite alternate
}
@keyframes stars-drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-240px,160px,0)}}
@keyframes star-drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(var(--dx,0px),var(--dy,0px),0)}}
}
.mountain{
  position:absolute;left:0;right:0;bottom:-1px;height:86px;
  background:linear-gradient(180deg,rgba(255,255,255,.0),rgba(255,255,255,.92));
  clip-path:polygon(0 50%,8% 38%,14% 54%,23% 30%,33% 52%,45% 24%,57% 54%,68% 32%,78% 56%,90% 36%,100% 52%,100% 100%,0 100%);
  opacity:.92
}
.hero-ice .mountain{display:none}
.ice-layers{position:absolute;left:0;right:0;bottom:14px;height:260px;pointer-events:none}
.ice-layer{
  position:absolute;left:0;right:0;bottom:14px;height:260px;
  background-repeat:repeat-x;background-position:0 100%;
  opacity:1;transform:translateZ(0);will-change:transform,opacity,background-position
}
.ice-back{background-image:url("/static/img/冰山图片3.webp");z-index:1;filter:blur(.2px);background-size:2600px 100%;animation:ice-rise .68s cubic-bezier(.2,.8,.2,1) 0s both,ice-move-2600 70s linear .68s infinite}
.ice-mid{background-image:url("/static/img/冰山图片2.webp");z-index:2;background-size:3200px 100%;animation:ice-rise .74s cubic-bezier(.2,.8,.2,1) .06s both,ice-move-3200 150s linear .80s infinite}
.ice-front{background-image:url("/static/img/冰山图片1.webp");z-index:3;background-size:2400px 100%;animation:ice-rise .82s cubic-bezier(.2,.8,.2,1) .12s both,ice-move-2400 85s linear .94s infinite}
@keyframes ice-move-2600{from{background-position:0 100%}to{background-position:-2600px 100%}}
@keyframes ice-move-3200{from{background-position:0 100%}to{background-position:-3200px 100%}}
@keyframes ice-move-2400{from{background-position:0 100%}to{background-position:-2400px 100%}}
@keyframes ice-rise{from{opacity:0;transform:translate3d(0,32px,0) scale(.90)}to{opacity:1;transform:translate3d(0,0,0) scale(1)}}
@media (prefers-reduced-motion:reduce){
  .ice-layer{animation:none}
  .stars:before{animation:none}
  .stars .star{animation:none}
}
.hero-inner{position:relative;padding:26px 22px 140px}
.hero.hero-ice .hero-inner{
  min-height:clamp(340px,48vh,520px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(70px,7vw,110px) 0 170px
}
.hero.hero-ice .hero-inner>*{padding-left:clamp(18px,5vw,74px);padding-right:clamp(18px,5vw,74px)}
.hero-row{display:flex;align-items:center;gap:14px;justify-content:center;margin-top:14px}
.search{
  width:min(820px,100%);height:50px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);
  display:flex;align-items:center;padding:0 10px;gap:10px;box-shadow:0 14px 40px rgba(0,0,0,.22)
}
.hero.hero-ice .search{height:54px;padding:0 12px}
.engine-cur{
  height:34px;padding:0 12px;border-radius:999px;border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.18);color:rgba(255,255,255,.92);font-size:13px;display:flex;align-items:center;flex:none
}
.is-home .engine-cur{height:38px}
.search input{
  flex:1;height:44px;border:0;outline:0;background:transparent;color:#fff;font-size:14px
}
.is-home .search input{font-size:15px}
.search input::placeholder{color:rgba(255,255,255,.65)}
.search .go{
  width:auto;height:auto;border-radius:0;border:0;background:transparent;color:rgba(255,255,255,.92);
  cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0 2px
}
.search .go svg{display:block}
.is-home .search .go{width:auto;height:auto}
.search .go:hover{color:#fff}
.tabbar{display:flex;gap:10px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.is-home .tabbar{margin-top:14px}
.tab{padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.92);background:rgba(255,255,255,.06)}
.noticebar{display:flex;justify-content:center;margin-top:8px}
.is-home .noticebar{margin-top:10px}
.notice-inner{
  width:min(720px,100%);display:flex;align-items:center;gap:8px;
  height:34px;padding:0 10px;border-radius:10px;
  background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)
}
.notice-ico{color:rgba(255,255,255,.92);display:flex;align-items:center;flex:none}
.notice-viewport{flex:1;min-width:0;height:20px;overflow:hidden;position:relative}
.notice-track{will-change:transform}
.notice-item{height:20px;display:flex;align-items:center}
.notice-text{display:flex;align-items:center;gap:6px;min-width:0;color:rgba(255,255,255,.88);font-size:12px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none}
.notice-text:hover{color:#fff}
.notice-badge{opacity:.9}
.enginebar{
  display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:10px;
  padding:0;background:transparent;border:0;
  position:relative
}
.enginebar.enginebar-top{margin-top:14px}
.hero-inner .enginebar.enginebar-top{margin-bottom:2px}
.is-home .enginebar{margin-top:14px}
.engine{
  height:28px;padding:0 6px;border-radius:0;border:0;background:transparent;
  color:rgba(255,255,255,.70);cursor:pointer;font-size:13px;position:relative
}
.engine:hover{color:rgba(255,255,255,.90)}
.engine.active{color:#fff}
.enginebar[data-enginebar-anim="1"] .engine.active:after{opacity:0}
.engine.active:after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;border-radius:999px;
  background:rgba(255,255,255,.92)
}
.enginebar-indicator{
  position:absolute;
  left:0;top:0;
  height:3px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  opacity:0;
  transform:translate3d(0,0,0);
  will-change:transform,width,opacity
}
.enginebar[data-enginebar-ready="1"] .enginebar-indicator{
  opacity:1;
  transition:
    transform .38s cubic-bezier(.2,.9,.2,1) .08s,
    width .38s cubic-bezier(.2,.9,.2,1) .08s,
    opacity .2s ease .08s
}
.search.is-light{background:var(--card);border-color:var(--line);box-shadow:none}
.search.is-light input{color:var(--text)}
.search.is-light input::placeholder{color:var(--muted)}
.search.is-light .go{background:transparent;color:var(--text)}
.search.is-light .go:hover{color:var(--primary)}
.search.is-light .engine-cur{background:var(--soft);border-color:var(--line);color:var(--text)}
.enginebar.is-light .engine{color:var(--muted)}
.enginebar.is-light .engine:hover{color:var(--text)}
.enginebar.is-light .engine.active{color:var(--text)}
.enginebar.is-light .engine.active:after{background:var(--primary)}
.enginebar.is-light .enginebar-indicator{background:var(--primary)}
.search-adbar{display:flex;justify-content:center;margin-top:10px}
.search-adbar-inner{
  width:min(820px,100%);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap
}
.search-ad{
  display:inline-flex;
  align-items:center;
  gap:5px;
  color:rgba(255,255,255,.92);
  text-decoration:none;
  font-size:13px;
  font-weight:700;
  letter-spacing:.1px
}
.search-ad:hover{color:#fff}
.search-ad-ico{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex:none}
.search-ad-ico svg{width:18px;height:18px;display:block}
.search-ad-ico-img{width:18px;height:18px;border-radius:6px;flex:none;display:block}
.search-ad-txt{white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}
.search-page .search-ad,.search-modal .search-ad{color:var(--text)}
.search-page .search-ad:hover,.search-modal .search-ad:hover{color:var(--primary)}
html[data-theme="dark"] .search-page .search-ad:hover,html[data-theme="dark"] .search-modal .search-ad:hover{color:#fff}
.search-page-tools{flex:1;min-width:min(520px,100%);max-width:860px;display:flex;flex-direction:column;align-items:stretch}
.search-page-tools .enginebar{margin-top:0}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:14px}
.dashboard-grid{align-items:stretch}
.dashboard-grid>.col-8,.dashboard-grid>.col-4,.dashboard-grid>.col-6,.dashboard-grid>.col-12{display:flex;min-height:0}
.dashboard-grid>.col-8>.card,.dashboard-grid>.col-4>.card,.dashboard-grid>.col-6>.card,.dashboard-grid>.col-12>.card{flex:1;display:flex;flex-direction:column;min-height:0}
.dashboard-grid .card-bd{flex:1;min-height:0}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)
}
.card-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--line)}
.card-title{font-weight:700;display:flex;align-items:center;gap:8px}
.card-hd-actions{gap:12px}
.card-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.card-hd-actions .btn{height:28px}
.badge{font-size:12px;color:var(--muted)}
.card-bd{padding:10px 12px}
.links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.links.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.links.cols-1{grid-template-columns:1fr}
.link{
  border:1px solid var(--line);border-radius:12px;padding:10px 10px;display:flex;gap:10px;align-items:flex-start;background:var(--card);
  min-width:0;max-width:100%
}
.link:hover{border-color:rgba(255,90,95,.35);box-shadow:0 10px 24px rgba(255,90,95,.12)}
.link-logo{
  width:36px;height:36px;border-radius:10px;background:var(--soft);display:flex;align-items:center;justify-content:center;flex:none;overflow:hidden
}
.link-logo img{width:100%;height:100%;object-fit:cover}
.link-main{min-width:0;max-width:100%}
.link-name{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.link-desc{margin-top:2px;color:var(--muted);font-size:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pill{display:inline-flex;align-items:center;gap:6px;margin-top:6px;font-size:12px;color:var(--muted)}
.pill b{color:var(--text)}
.col-8{grid-column:span 8}
.col-4{grid-column:span 4}
.col-3{grid-column:span 3}
.col-6{grid-column:span 6}
.col-12{grid-column:span 12}
.section{margin-top:14px}
.kvs{display:flex;gap:8px;flex-wrap:wrap}
.kv{padding:6px 10px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--muted);font:inherit}
button.kv{appearance:none;-webkit-appearance:none;cursor:pointer}
button.kv:focus{outline:0}
button.kv:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.fb-page>.col-4,.fb-page>.col-8,.fb-page>.col-12{display:flex;min-height:0}
.fb-page>.col-4>.card,.fb-page>.col-8>.card,.fb-page>.col-12>.card{flex:1;display:flex;flex-direction:column;min-height:0}
.fb-page .card-bd{flex:1;min-height:0}
.fb-filter{display:flex;flex-direction:column;gap:10px}
.fb-filter-row2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.fb-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.fb-sep{height:1px;background:var(--line);margin:12px 0}
.fb-bars{display:flex;flex-direction:column;gap:10px}
.fb-bar-row{display:grid;grid-template-columns:90px 1fr 56px;gap:10px;align-items:center}
.fb-bar-label{font-size:12px;font-weight:900;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fb-bar-track{height:10px;border-radius:999px;background:var(--soft);border:1px solid var(--line);overflow:hidden}
.fb-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,rgba(255,90,95,.92),rgba(124,77,255,.72))}
.fb-bar-num{text-align:right;font-weight:900;font-size:12px;color:var(--text)}
.fb-panel-split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}
.fb-tag{display:inline-flex;align-items:center;justify-content:center;height:22px;padding:0 10px;border-radius:999px;border:1px solid var(--line);background:var(--soft);font-size:12px;font-weight:800;color:var(--text);white-space:nowrap}
.fb-trend-grid{height:190px}
.fb-trend-grid .trend-col-bars{height:140px}
.link-detail .ld-hero{align-items:stretch}
.ld-crumbs{flex-wrap:wrap;gap:6px;font-size:13px}
.ld-crumb{color:var(--muted);text-decoration:none}
.ld-crumb:hover{color:var(--text)}
.ld-crumb-sep{color:var(--muted);opacity:.6}
.ld-crumb-cur{color:var(--text);font-weight:800}
.ld-head{display:flex;gap:12px;align-items:flex-start}
.ld-logo{
  width:54px;height:54px;border-radius:14px;background:var(--soft);border:1px solid var(--line);
  overflow:hidden;flex:none;display:flex;align-items:center;justify-content:center
}
.ld-logo img{width:100%;height:100%;object-fit:cover;display:block}
.ld-main{min-width:0;flex:1}
.ld-title{font-size:18px;line-height:1.2}
.ld-desc{margin-top:4px}
.ld-meta-row{margin-top:10px}
.ld-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.btn.btn-ico{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center}
.ld-fav{color:var(--muted)}
.ld-fav.is-active{color:var(--primary);border-color:rgba(255,90,95,.40);background:rgba(255,90,95,.08)}
.ld-eye{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--muted);
  padding:0 10px;height:34px;
  border-radius:10px;border:1px solid var(--line);background:var(--card)
}
.ld-eye svg{display:block}
.ld-eye span{font-weight:800;color:var(--text);font-size:12px}
.ld-tags{margin-top:10px}
.ld-toc{display:flex;flex-direction:column;gap:8px}
.ld-toc-item{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  height:34px;padding:0 10px;border-radius:10px;border:1px solid var(--line);
  background:var(--card);color:var(--muted);text-decoration:none
}
.ld-toc-item:hover{color:var(--text);border-color:rgba(255,90,95,.35)}
.ld-toc-item.is-active{color:var(--text);border-color:rgba(255,90,95,.55);box-shadow:0 10px 24px rgba(255,90,95,.10)}
.ld-chart{height:160px;display:grid;grid-template-columns:repeat(14,minmax(0,1fr));gap:6px;align-items:end}
.ld-chart-col{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}
.ld-chart-bar{
  width:100%;
  border-radius:10px;
  background:linear-gradient(180deg,rgba(255,90,95,.60),rgba(124,77,255,.35));
  box-shadow:0 10px 24px rgba(0,0,0,.06);
  transition:transform .18s ease,filter .18s ease
}
.ld-chart-col:hover .ld-chart-bar{transform:translateY(-2px);filter:saturate(1.08)}
.ld-chart-x{font-size:11px;color:var(--muted);white-space:nowrap;transform:scale(.94)}
.ld-ad img{width:100%;height:auto;border-radius:12px;border:1px solid var(--line);display:block}
.ld-ad-text{display:block;text-decoration:none;color:inherit;border:1px solid var(--line);border-radius:12px;padding:10px;background:var(--card)}
.ld-ad-text:hover{border-color:rgba(255,90,95,.35);box-shadow:0 10px 24px rgba(0,0,0,.06)}
.ld-ad-title{font-weight:800}
.ld-ad-sub{margin-top:4px;font-size:12px}
.ld-ad-empty{padding:10px;border-radius:12px;background:var(--soft);border:1px dashed var(--line)}
.ld-ad-empty-title{font-weight:800}
.ld-feedback-tip{font-size:12px}
.link-detail .ld-hero{display:none}
.link-detail .ld-top{display:grid;grid-template-columns:260px 1fr;gap:38px;align-items:start;margin-top:14px}
.ld-ico-card{
  width:240px;
  border-radius:20px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.38));
  box-shadow:0 18px 44px rgba(0,0,0,.10);
  padding:12px;
  position:relative;
  overflow:hidden
}
html[data-theme="dark"] .ld-ico-card{
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  box-shadow:0 22px 54px rgba(0,0,0,.50)
}
.ld-ico-corner{
  position:absolute;
  right:12px;
  top:12px;
  height:20px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(2,132,199,.92);
  color:#fff;
  font-size:12px;
  font-weight:900;
  display:flex;
  align-items:center;
  box-shadow:0 10px 24px rgba(2,132,199,.18)
}
html[data-theme="dark"] .ld-ico-corner{background:rgba(14,165,233,.88);box-shadow:0 14px 34px rgba(0,0,0,.38)}
.ld-ico-img{width:100%;height:220px;border-radius:16px;border:1px solid rgba(17,24,39,.08);background:transparent;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;z-index:1}
html[data-theme="dark"] .ld-ico-img{border-color:rgba(255,255,255,.10)}
.ld-ico-img:before{
  content:"";
  position:absolute;
  inset:-40px;
  background:
    radial-gradient(closest-side at 50% 40%, rgba(17,24,39,.10), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,.66), rgba(255,255,255,.36));
  filter:blur(14px);
  transform:scale(1.08);
  opacity:.95;
  pointer-events:none
}
html[data-theme="dark"] .ld-ico-img:before{
  background:
    radial-gradient(closest-side at 50% 40%, rgba(255,255,255,.14), transparent 64%),
    linear-gradient(180deg, rgba(17,24,39,.28), rgba(17,24,39,.14));
  opacity:.92
}
.ld-ico-img:after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:16px;
  background:rgba(255,255,255,.18);
  backdrop-filter:blur(10px) saturate(1.06);
  -webkit-backdrop-filter:blur(10px) saturate(1.06);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72), inset 0 -12px 26px rgba(17,24,39,.10);
  pointer-events:none
}
html[data-theme="dark"] .ld-ico-img:after{background:rgba(17,24,39,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.10), inset 0 -10px 26px rgba(0,0,0,.55)}
.ld-ico-img img{width:56%;height:56%;object-fit:contain;display:block;filter:drop-shadow(0 12px 18px rgba(0,0,0,.20));position:relative;z-index:2}
.ld-ico-bottom{position:absolute;left:0;right:0;bottom:34px;display:flex;justify-content:center;gap:14px;padding:0 12px;z-index:3}
.ld-ico-chip{
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.72);
  box-shadow:0 12px 26px rgba(0,0,0,.14);
  backdrop-filter:blur(14px) saturate(1.12);
  -webkit-backdrop-filter:blur(14px) saturate(1.12);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  color:rgba(17,24,39,.72);
  text-decoration:none;
  transform:translateY(0) scale(1);
  position:relative;
  transition:transform .16s cubic-bezier(.2,.85,.25,1.25),box-shadow .16s ease,background-color .16s ease,border-color .16s ease
}
.ld-ico-chip{cursor:pointer}
.ld-ico-chip:hover{transform:translateY(-4px) scale(1.06);box-shadow:0 18px 34px rgba(0,0,0,.18)}
.ld-ico-chip:active{transform:translateY(-1px) scale(.97);box-shadow:0 12px 26px rgba(0,0,0,.14)}
.ld-ico-chip-view:hover,.ld-ico-chip-view:active{transform:translateY(0) scale(1);box-shadow:0 12px 26px rgba(0,0,0,.14)}
.ld-ico-chip[data-tip]:after{
  content:attr(data-tip);
  position:absolute;
  left:50%;
  bottom:100%;
  transform:translate(-50%,-10px) scale(.98);
  opacity:0;
  pointer-events:none;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.88);
  color:rgba(17,24,39,.86);
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
  box-shadow:0 12px 26px rgba(0,0,0,.14);
  backdrop-filter:blur(12px) saturate(1.12);
  -webkit-backdrop-filter:blur(12px) saturate(1.12);
  transition:opacity .14s ease,transform .14s cubic-bezier(.2,.85,.25,1.25)
}
html[data-theme="dark"] .ld-ico-chip[data-tip]:after{
  border-color:rgba(255,255,255,.14);
  background:rgba(17,24,39,.72);
  color:rgba(255,255,255,.92);
  box-shadow:0 18px 40px rgba(0,0,0,.62)
}
.ld-ico-chip:hover[data-tip]:after{opacity:1;transform:translate(-50%,-14px) scale(1)}
.ld-ico-chip svg{display:block;opacity:.92}
.ld-ico-chip-num{font-size:12px;font-weight:900;line-height:1}
.ld-ico-chip.is-active{color:rgba(255,90,95,1);border-color:rgba(255,90,95,.35);background:rgba(255,90,95,.12)}
.ld-ico-chip-view{cursor:default}
html[data-theme="dark"] .ld-ico-chip{
  border-color:rgba(255,255,255,.14);
  background:rgba(17,24,39,.36);
  box-shadow:0 16px 38px rgba(0,0,0,.58);
  color:rgba(255,255,255,.82)
}
@media (prefers-reduced-motion: reduce){
  .ld-ico-chip{transition:none}
  .ld-ico-chip:hover,.ld-ico-chip:active{transform:none}
  .ld-rel-item{transition:none}
  .ld-rel-item:hover,.ld-rel-item:active{transform:none}
}
.ld-top-info{min-width:0;padding-top:6px;padding-right:320px;position:relative}
.ld-top-right{position:absolute;right:0;top:0;width:300px}
.ld-ad-top{border-radius:14px;border:1px solid var(--line);background:var(--card);overflow:hidden}
.ld-ad-top-img img{width:100%;height:auto;display:block}
.ld-ad-top-text{display:block;text-decoration:none;color:inherit;padding:10px 10px}
.ld-ad-top-text:hover{background:rgba(255,90,95,.06)}
.ld-ad-top-title{font-weight:900}
.ld-ad-top-sub{margin-top:4px;font-size:12px}
.ld-ad-top-empty{padding:10px 10px;background:var(--soft)}
.ld-ad-top-empty-title{font-weight:900}
.ld-top-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ld-crumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ld-crumb-link{color:var(--muted);text-decoration:none;font-weight:900}
.ld-crumb-link:hover{color:var(--text)}
.ld-crumb-sep{opacity:.55}
.ld-badge{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid var(--line);background:var(--card);color:var(--muted)}
.ld-badge-red{border-color:rgba(255,90,95,.35);background:rgba(255,90,95,.10);color:rgba(255,90,95,1)}
.ld-badge-soft{background:rgba(17,24,39,.04)}
html[data-theme="dark"] .ld-badge-soft{background:rgba(255,255,255,.06)}
.ld-h1{margin-top:10px;font-size:28px;line-height:1.15;font-weight:900;letter-spacing:.2px}
.ld-top-desc{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.8;max-width:720px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.ld-top-actions{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.ld-pill{height:38px;display:inline-flex;align-items:center;gap:10px;padding:0 14px;border-radius:10px;border:1px solid var(--line);background:var(--soft);color:var(--text);text-decoration:none;font-weight:800}
.ld-pill:hover{border-color:rgba(255,90,95,.35);box-shadow:0 10px 24px rgba(0,0,0,.06)}
.ld-pill[data-tip]{position:relative}
.ld-pill[data-tip]:before{
  content:attr(data-tip);
  position:absolute;left:50%;top:calc(100% + 10px);
  transform:translate(-50%,-6px);
  padding:7px 10px;border-radius:10px;
  background:var(--tip-bg);color:var(--tip-text);
  font-size:12px;font-weight:800;letter-spacing:.2px;
  white-space:nowrap;
  z-index:80;
  opacity:0;pointer-events:none;
  box-shadow:0 16px 40px rgba(0,0,0,.22);
  transition:opacity .14s ease,transform .14s ease
}
.ld-pill[data-tip]:after{
  content:"";
  position:absolute;left:50%;top:calc(100% + 4px);
  transform:translate(-50%,-6px);
  border:6px solid transparent;border-bottom-color:var(--tip-bg);
  z-index:80;
  opacity:0;pointer-events:none;
  transition:opacity .08s ease,transform .08s ease
}
.ld-pill[data-tip]:hover:before,.ld-pill[data-tip]:hover:after,.ld-pill[data-tip]:focus-visible:before,.ld-pill[data-tip]:focus-visible:after{opacity:1;transform:translate(-50%,0)}
.ld-pill-arr{opacity:.65;font-weight:900;margin-left:2px}
.ld-pill-red{width:38px;min-width:38px;padding:0;justify-content:center;background:rgba(255,90,95,1);border-color:rgba(255,90,95,.60);color:#fff}
.ld-pill-red:hover{box-shadow:0 12px 28px rgba(255,90,95,.24)}
.ld-qr-drop{margin-top:10px;border-radius:14px;border:1px solid var(--line);background:#22c55e;color:#fff;overflow:hidden;max-height:0;opacity:0;transform:translateY(-6px);transition:max-height .26s ease,opacity .22s ease,transform .22s ease}
.ld-qr-drop.is-open{max-height:220px;opacity:1;transform:translateY(0)}
.ld-qr-drop-inner{display:flex;align-items:center;gap:12px;padding:10px 10px}
.ld-qr-drop-img{width:132px;height:132px;border-radius:14px;background:#fff;display:block;object-fit:cover;padding:6px}
.ld-qr-drop-title{font-weight:900;font-size:14px;letter-spacing:.2px}
.ld-qr-drop-search{margin-top:8px;display:flex;align-items:center;gap:10px;background:#fff;color:#111827;border-radius:12px;padding:8px 10px;font-weight:900;min-width:0}
.ld-qr-drop-search svg{color:#22c55e}
.ld-qr-drop-kw{white-space:nowrap;overflow:hidden;max-width:100%;text-overflow:ellipsis;min-width:0;flex:1}
.ld-qr-drop-tip{margin-top:10px;font-size:12px;opacity:.92;line-height:1.6}
.ld-tags2{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px}
.ld-tags2-label{color:var(--muted);font-size:12px;font-weight:900}
.ld-tag{display:inline-flex;align-items:center;padding:0;color:var(--muted);text-decoration:none;font-size:12px;font-weight:800;line-height:1.8;border-bottom:1px dashed transparent}
a.ld-tag:hover{color:var(--text);border-bottom-color:rgba(255,90,95,.45)}
a.ld-tag:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20);border-radius:6px}
.ld-desc-line{margin-top:14px;color:var(--muted);font-size:13px;line-height:1.8;max-width:900px;overflow-wrap:anywhere}
.ld-rich-card{border-top:0}
.ld-rich-card .card-hd{border-bottom:0;padding-bottom:0}
.ld-rich-card .card-bd{padding-top:0}
.ld-claim{margin-top:14px}
.ld-claim-title{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  height:34px;
  margin:0 0 10px 0;
  color:var(--text);
  font-weight:900;
  letter-spacing:.2px
}
.ld-claim-title:before{
  content:"";
  position:absolute;
  left:0;right:0;top:50%;
  height:1px;
  background:var(--line)
}
.ld-claim-title span{
  position:relative;
  padding:0 14px;
  background:var(--bg);
  font-size:14px
}
.ld-claim-box{
  width:100%;
  border:1px solid var(--line);
  background:var(--card);
  border-radius:var(--radius);
  padding:12px 14px;
  line-height:1.8
}
.ld-claim-text{color:var(--muted);font-size:12px;font-weight:700}
.ld-claim-foot{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid var(--line);
  display:flex;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
  font-size:12px;
  font-weight:800;
  color:var(--muted)
}
.ld-claim-foot-right{overflow-wrap:anywhere}
.ld-stats-cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:10px}
.ld-stat{border:1px solid var(--line);border-radius:14px;background:var(--soft);padding:10px 10px}
.ld-stat-k{font-size:12px;color:var(--muted);font-weight:900}
.ld-stat-v{margin-top:6px;font-size:20px;font-weight:900;letter-spacing:.2px}
.ld-stat-sub{font-size:12px;color:var(--muted);font-weight:900;margin-left:6px}
.ld-stat-wide{grid-column:span 2}
.ld-delta{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:26px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:900;border:1px solid var(--line);background:var(--card)}
.ld-delta.up{border-color:rgba(16,185,129,.40);color:#10b981;background:rgba(16,185,129,.10)}
.ld-delta.down{border-color:rgba(239,68,68,.40);color:#ef4444;background:rgba(239,68,68,.10)}
.ld-delta.flat{border-color:rgba(148,163,184,.40);color:var(--muted);background:rgba(148,163,184,.10)}
.ld-chart-svg-wrap{
  border-radius:16px;
  border:1px solid rgba(17,24,39,.10);
  background:
    radial-gradient(900px 360px at 15% 0%, rgba(157,101,201,.16), rgba(157,101,201,0) 62%),
    linear-gradient(180deg, rgba(248,250,252,1), rgba(241,245,249,1));
  overflow:hidden;
  position:relative;
  padding:18px 18px 16px 18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.70), 0 18px 44px rgba(17,24,39,.12);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif
}
html[data-theme="dark"] .ld-chart-svg-wrap{
  border-color:rgba(255,255,255,.10);
  background:
    radial-gradient(900px 360px at 15% 0%, rgba(157,101,201,.22), rgba(157,101,201,0) 62%),
    linear-gradient(180deg, rgba(24,28,34,1), rgba(10,12,16,1))
}
.ld-chart-legend{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 0 10px 0;color:rgba(17,24,39,.72);font-size:12px;font-weight:800;letter-spacing:.2px}
html[data-theme="dark"] .ld-chart-legend{color:rgba(255,255,255,.80)}
.ld-chart-legend-item{appearance:none;-webkit-appearance:none;border:0;background:transparent;padding:6px 8px;border-radius:10px;display:inline-flex;align-items:center;gap:8px;color:inherit;font:inherit;cursor:pointer;transition:background .16s ease,opacity .16s ease,transform .16s ease}
.ld-chart-legend-item:hover{background:rgba(17,24,39,.04);transform:translateY(-1px)}
html[data-theme="dark"] .ld-chart-legend-item:hover{background:rgba(255,255,255,.06)}
.ld-chart-legend-item:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.ld-chart-legend-item[aria-pressed="false"]{opacity:.45}
.ld-chart-legend-swatch{display:inline-block;flex:none}
.ld-chart-legend-swatch.is-bar{width:18px;height:10px;border-radius:3px;background:linear-gradient(180deg, rgba(157,101,201,1), rgba(184,146,217,1));box-shadow:0 8px 18px rgba(157,101,201,.22)}
.ld-chart-legend-swatch.is-line{width:18px;height:3px;border-radius:999px;background:linear-gradient(90deg, rgba(157,101,201,1), rgba(184,146,217,1));box-shadow:0 8px 18px rgba(157,101,201,.22)}
.ld-chart-svg{width:100%;height:260px;display:block}

.ld-y-panel{fill:rgba(255,255,255,.62);stroke:rgba(17,24,39,.10);stroke-width:1}
html[data-theme="dark"] .ld-y-panel{fill:rgba(0,0,0,.22);stroke:rgba(255,255,255,.10)}
.ld-grid{stroke:rgba(17,24,39,.22);stroke-width:1;stroke-dasharray:6 6;stroke-linecap:round}
html[data-theme="dark"] .ld-grid{stroke:rgba(255,255,255,.16)}

.ld-y{font-size:12px;font-weight:600;fill:rgba(17,24,39,.72);paint-order:stroke;stroke:rgba(255,255,255,.92);stroke-width:3;stroke-linejoin:round}
.ld-x{font-size:12px;font-weight:600;fill:rgba(17,24,39,.55);paint-order:stroke;stroke:rgba(255,255,255,.86);stroke-width:3;stroke-linejoin:round}
html[data-theme="dark"] .ld-y{fill:rgba(248,249,250,.86);stroke:rgba(0,0,0,.55)}
html[data-theme="dark"] .ld-x{fill:rgba(248,249,250,.62);stroke:rgba(0,0,0,.55)}

.ld-line-area{opacity:1;fill:rgba(157,101,201,.14)}
html[data-theme="dark"] .ld-line-area{fill:rgba(184,146,217,.14)}
.ld-bar{
  fill:url(#ldBarGrad);
  opacity:.82;
  stroke:rgba(17,24,39,.10);
  stroke-width:1;
  transition:opacity .16s ease,filter .16s ease,transform .16s ease,stroke-width .16s ease;
  transform-box:fill-box;
  transform-origin:center bottom
}
html[data-theme="dark"] .ld-bar{stroke:rgba(255,255,255,.10)}
.ld-bar:hover{opacity:1;filter:drop-shadow(0 18px 30px rgba(157,101,201,.22));transform:translateY(-2px);stroke-width:1.4}
.ld-bar.is-peak{fill:url(#ldBarGradPeak);opacity:1;stroke:rgba(17,24,39,.18);stroke-width:1.6}
html[data-theme="dark"] .ld-bar.is-peak{stroke:rgba(255,255,255,.22)}

.ld-line{
  stroke:url(#ldLineGrad);
  stroke-width:2.8;
  stroke-linecap:round;
  stroke-linejoin:round;
  filter:drop-shadow(0 14px 26px rgba(157,101,201,.18))
}
html[data-theme="dark"] .ld-line{filter:drop-shadow(0 18px 30px rgba(0,0,0,.55))}

.ld-pt{cursor:pointer;transform-box:fill-box;transform-origin:center;transition:transform .16s ease}
.ld-pt:hover{transform:translateY(-1px) scale(1.10)}
.ld-pt-ring{fill:rgba(255,255,255,.92);stroke:rgba(17,24,39,.26);stroke-width:2}
html[data-theme="dark"] .ld-pt-ring{fill:rgba(15,23,42,.92);stroke:rgba(255,255,255,.72)}
.ld-pt-dot{fill:rgba(157,101,201,.96)}
html[data-theme="dark"] .ld-pt-dot{fill:rgba(184,146,217,.96)}
.ld-pt.is-peak .ld-pt-ring{stroke:rgba(255,255,255,.92)}
.ld-pt.is-peak .ld-pt-dot{fill:rgba(123,76,191,1)}

.ld-chart-svg-wrap.is-hide-bar .ld-bar{display:none !important}
.ld-chart-svg-wrap.is-hide-line .ld-line,.ld-chart-svg-wrap.is-hide-line .ld-line-area,.ld-chart-svg-wrap.is-hide-line .ld-pt{display:none !important}

.ld-chart-svg.ld-anim .ld-bar{opacity:0;transform:scaleY(.12)}
.ld-chart-svg.ld-anim .ld-line{opacity:0}
.ld-chart-svg.ld-anim .ld-line-area{opacity:0}
.ld-chart-svg.ld-anim.is-ready .ld-line-area{animation:ldAreaIn .45s ease forwards;animation-delay:var(--area-delay,80ms)}
.ld-chart-svg.ld-anim.is-ready .ld-bar{animation:ldBarGrow .70s cubic-bezier(.22,1,.36,1) forwards;animation-delay:var(--d,0ms)}
.ld-chart-svg.ld-anim.is-ready .ld-line{opacity:1;animation:ldLineDraw 1s cubic-bezier(.22,1,.36,1) forwards;animation-delay:var(--line-delay,120ms)}

@keyframes ldAreaIn{from{opacity:0}to{opacity:1}}
@keyframes ldBarGrow{to{opacity:.92;transform:scaleY(1)}}
@keyframes ldLineDraw{to{stroke-dashoffset:0}}
.ld-chart-tip{
  position:absolute;
  left:0;
  top:0;
  transform:translate(-9999px,-9999px);
  opacity:0;
  pointer-events:none;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(15,23,42,.70);
  color:rgba(255,255,255,.90);
  box-shadow:0 22px 60px rgba(0,0,0,.45);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  transition:opacity .12s ease
}
html[data-theme="dark"] .ld-chart-tip{
  border-color:rgba(255,255,255,.12);
  background:rgba(15,23,42,.72);
  color:rgba(248,249,250,.92);
  box-shadow:0 22px 50px rgba(0,0,0,.60)
}
.ld-chart-tip.is-open{opacity:1}
.ld-chart-tip-d{font-size:12px;font-weight:400;opacity:.92}
.ld-chart-tip-v{margin-top:4px;font-size:14px;font-weight:600}
.ld-rel-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.ld-rel-item{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 12px;
  display:flex;
  align-items:center;
  gap:12px;
  background:var(--card);
  text-decoration:none;
  color:inherit;
  min-height:68px;
  transform:translateZ(0);
  will-change:transform,box-shadow;
  transition:transform .22s cubic-bezier(.2,.9,.2,1),box-shadow .22s ease,border-color .18s ease
}
.ld-rel-item:hover,.ld-rel-item:focus-visible{border-color:rgba(255,90,95,.35);box-shadow:0 16px 44px rgba(0,0,0,.10);transform:translate3d(0,-4px,0)}
.ld-rel-item:active{transform:translate3d(0,-1px,0)}
.ld-rel-ico{width:38px;height:38px;border-radius:12px;background:var(--soft);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none}
.ld-rel-ico img{width:100%;height:100%;object-fit:cover;display:block}
.ld-rel-fallback{font-weight:900;color:#9ca3af}
.ld-rel-meta{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.ld-rel-name{font-weight:900;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ld-rel-desc{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ld-rel-go{font-size:20px;color:var(--muted);opacity:.7;flex:none}
@media (max-width:1100px){.link-detail .ld-top{grid-template-columns:240px 1fr;gap:22px}.ld-ico-card{width:240px}.ld-ico-img{height:220px}.ld-top-info{padding-right:280px}.ld-top-right{width:260px}}
@media (max-width:960px){
  .link-detail .ld-top{grid-template-columns:220px 1fr;gap:16px}
  .ld-top-ico{display:flex;justify-content:flex-start}
  .ld-ico-card{width:220px;flex:none}
  .ld-ico-img{height:200px}
  .ld-top-info{padding-right:0;position:static;display:flex;flex-direction:column;gap:10px}
  .ld-top-badges{order:10}
  .ld-h1{order:20;font-size:24px}
  .ld-top-desc{order:30;max-width:none;-webkit-line-clamp:3}
  .ld-top-actions{order:40}
  .ld-top-right{position:static;width:100%;margin:0;order:45}
  .ld-qr-drop{order:46}
  .ld-tags2{order:50}
  .ld-ad-top{max-height:220px}
  .ld-ad-top-img{display:block;aspect-ratio:21/9;background:var(--soft);max-height:160px;overflow:hidden}
  .ld-ad-top-img img{width:100%;height:100%;object-fit:cover}
  .ld-stats-cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ld-stat-wide{grid-column:span 2}
}
@media (max-width:560px){
  .link-detail .ld-top{grid-template-columns:1fr;gap:14px}
  .ld-top-ico{display:flex;justify-content:center}
  .ld-ico-card{width:100%;max-width:420px}
  .ld-ico-img{height:220px}
  .ld-ico-img img{width:clamp(104px,26vw,128px);height:clamp(104px,26vw,128px)}
  .ld-top-info{gap:12px}
  .ld-top-right{order:45}
  .ld-ad-top-img{max-height:240px}
  .ld-qr-drop.is-open{max-height:520px}
  .ld-qr-drop-inner{flex-direction:column;align-items:flex-start}
  .ld-qr-drop-right{width:100%}
  .ld-qr-drop-img{width:150px;height:150px}
  .ld-chart-svg-wrap{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:14px 12px 12px 12px}
  .ld-chart-svg{height:240px;min-width:760px}
  .ld-rel-grid{grid-template-columns:1fr}
  .ld-stats-cards{grid-template-columns:1fr}
  .ld-stat-wide{grid-column:span 1}
}
@media (min-width:561px) and (max-width:960px){
  .link-detail .ld-desc-line{margin-left:calc(220px + 16px);max-width:none}
}
.overview{display:flex;flex-direction:column;gap:14px}
.overview-traffic{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.metric{
  border:1px solid var(--line);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.70),rgba(255,255,255,.30));
  padding:12px 12px 10px 12px;
  position:relative;
  overflow:hidden;
  min-height:148px;
  transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease,background .18s ease
}
html[data-theme="dark"] .metric{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02))
}
.metric:hover{
  border-color:rgba(255,90,95,.35);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.06)
}
html[data-theme="dark"] .metric:hover{
  border-color:rgba(255,90,95,.58);
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  box-shadow:0 16px 34px rgba(0,0,0,.45)
}
.metric-hd{display:flex;align-items:center;justify-content:space-between;gap:10px}
.metric-label{font-size:12px;color:var(--muted);font-weight:800}
.metric-chip{
  height:24px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(17,24,39,.03);
  color:var(--muted);
  font-size:12px;
  display:inline-flex;
  align-items:center;
  white-space:nowrap
}
html[data-theme="dark"] .metric-chip{
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.06)
}
.metric-val{margin-top:8px;font-size:26px;font-weight:900;letter-spacing:.3px}
.metric-sub{margin-top:2px;font-size:12px;color:var(--muted)}
.metric-spark{position:absolute;left:0;right:0;bottom:0;height:54px;opacity:.95;pointer-events:none}
.metric-spark svg{width:100%;height:100%}
.metric-spark .spark-area{fill:rgba(255,90,95,.14)}
.metric-spark .spark-line{stroke:rgba(255,90,95,.92);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.metric.metric-view .spark-area{fill:rgba(124,77,255,.14)}
.metric.metric-view .spark-line{stroke:rgba(124,77,255,.92)}
.metric.metric-click .spark-area{fill:rgba(255,90,95,.14)}
.metric.metric-click .spark-line{stroke:rgba(255,90,95,.92)}
.overview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.ov-tile{
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 10px;
  background:var(--card);
  min-height:86px;
  transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease,background .18s ease
}
html[data-theme="dark"] .ov-tile{
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,0) 60%),rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.12)
}
.ov-tile:hover{
  border-color:rgba(255,90,95,.40);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.06);
  background:linear-gradient(90deg,rgba(255,90,95,.06),transparent)
}
html[data-theme="dark"] .ov-tile:hover{
  border-color:rgba(255,90,95,.62);
  background:linear-gradient(90deg,rgba(255,90,95,.14),transparent),linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,0) 60%),rgba(255,255,255,.04);
  box-shadow:0 16px 34px rgba(0,0,0,.42)
}
.ov-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.ov-label{font-size:12px;color:var(--muted);font-weight:800}
.ov-value{font-size:18px;font-weight:900}
.ov-sub{margin-top:6px;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trend-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:10px;
  align-items:end;
  height:220px;
  border-radius:12px;
  border:1px solid var(--line);
  background:rgba(17,24,39,.02);
  padding:10px 10px 8px 10px
}
html[data-theme="dark"] .trend-grid{background:rgba(255,255,255,.03)}
.trend-grid:empty{display:none}
.trend-col{
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  position:relative
}
.trend-col-bars{
  height:170px;
  width:100%;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:8px
}
.trend-vbar{
  width:18px;
  border-radius:999px;
  min-height:4px;
  position:relative
}
.trend-vbar.view{background:linear-gradient(to top,rgba(124,77,255,.92),rgba(124,77,255,.22))}
.trend-vbar.click{background:linear-gradient(to top,rgba(255,90,95,.92),rgba(255,90,95,.20))}
.trend-vnum{
  position:absolute;
  left:50%;
  top:-18px;
  transform:translateX(-50%);
  font-size:11px;
  color:var(--muted);
  opacity:0;
  transition:opacity .14s ease
}
.trend-col:hover .trend-vnum{opacity:1}
.trend-x{font-size:12px;font-weight:800;color:var(--muted)}
.trend-legend{margin-top:12px;display:flex;gap:14px;align-items:center;color:var(--muted);font-size:12px}
.trend-legend-item{display:inline-flex;align-items:center;gap:8px}
.trend-dot{width:10px;height:10px;border-radius:999px;display:inline-block}
.trend-dot.view{background:rgba(124,77,255,.92)}
.trend-dot.click{background:rgba(255,90,95,.92)}
.dashboard-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:4px
}
.dash-card{
  border-radius:12px;
  border:1px solid var(--line);
  padding:10px 10px;
  background:var(--card);
  display:flex;
  flex-direction:column;
  gap:4px;
  min-height:82px
}
.dash-label{
  font-size:12px;
  color:var(--muted)
}
.dash-value{
  font-size:20px;
  font-weight:900;
  letter-spacing:.2px
}
.dash-sub{
  display:flex;
  justify-content:space-between;
  gap:6px;
  font-size:11px;
  color:var(--muted)
}
.dash-chart{
  margin-top:18px;
  border-radius:12px;
  border:1px solid var(--line);
  padding:10px 10px
}
.dash-chart-hd{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:8px
}
.dash-chart-title{
  font-weight:700
}
.dash-chart-meta{
  font-size:12px;
  color:var(--muted)
}
.dash-chart-body{
  display:flex;
  align-items:flex-end;
  gap:8px;
  height:140px
}
.dash-bar{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  gap:4px;
  font-size:11px
}
.dash-bar-inner{
  width:100%;
  max-width:20px;
  border-radius:999px;
  background:linear-gradient(to top,rgba(255,90,95,.95),rgba(124,77,255,.90));
  position:relative;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding-bottom:4px;
  min-height:4px
}
.dash-bar-count{
  color:#fff;
  font-size:10px;
  line-height:1;
  transform:translateY(1px)
}
.dash-bar-day{
  color:var(--muted)
}
.quick-links{
  display:flex;
  flex-direction:column;
  gap:8px
}
.quick-item{
  border-radius:10px;
  border:1px solid var(--line);
  padding:8px 10px;
  display:flex;
  align-items:center;
  gap:8px;
  background:var(--card);
  min-height:54px;
  transition:background .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease
}
.quick-item:hover{
  border-color:rgba(255,90,95,.40);
  background:linear-gradient(90deg,rgba(255,90,95,.06),transparent);
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.06)
}
html[data-theme="dark"] .quick-item:hover{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.03);
  box-shadow:none
}
.quick-main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:2px
}
.quick-name{
  font-weight:700;
  font-size:13px
}
.quick-sub{
  font-size:12px;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis
}
.quick-go{
  margin-left:auto;
  font-size:14px;
  color:var(--muted)
}
.todo-list{display:flex;flex-direction:column;gap:10px}
.todo-group{border-radius:10px;border:1px solid var(--line);padding:8px 10px}
.todo-group-title{font-size:12px;font-weight:700;margin-bottom:6px}
.todo-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.todo-item{display:flex;align-items:center;gap:8px}
.todo-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.todo-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.todo-sub{font-size:11px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap}
.todo-action{font-size:12px;color:var(--primary)}
.todo-action:hover{text-decoration:underline}
.todo-empty{font-size:12px;color:var(--muted)}
.footer{padding:10px 0;color:var(--muted);border-top:1px solid var(--line);background:transparent;--footer-max:1180px;--footer-pad-left:18px;--footer-pad-right:18px}
.footer-inner{max-width:var(--footer-max);margin:0 auto;padding-left:var(--footer-pad-left);padding-right:var(--footer-pad-right)}
.footer-panel{
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:none;
  padding:10px 12px 8px 12px
}
html[data-theme="dark"] .footer-panel{box-shadow:none}
.footer-main{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px}
.footer-left{min-width:0;display:flex;flex-direction:column;gap:8px}
.footer-brand{
  display:flex;align-items:center;gap:10px;
  min-width:0;
  padding:4px 6px;
  border-radius:12px;
  transition:background .18s ease
}
.footer-brand:hover{background:rgba(255,90,95,.06)}
.footer-brand-ico{
  width:34px;height:34px;border-radius:12px;flex:none;
  border:1px solid var(--line);
  background:var(--soft);
  overflow:hidden;display:flex;align-items:center;justify-content:center
}
.footer-brand-ico img{width:100%;height:100%;object-fit:cover;display:block}
.footer-brand-text{min-width:0;display:flex;flex-direction:column;gap:2px}
.footer-brand-name{font-size:14px;font-weight:900;letter-spacing:.2px;color:var(--text);line-height:1}
.footer-brand-sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.footer-legal{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding-left:6px}
.footer-legal-link{
  font-size:12px;
  color:var(--muted);
  font-weight:800;
  opacity:.92;
  transition:color .18s ease,opacity .18s ease;
  background:transparent;
  border:0;
  padding:0;
  cursor:pointer
}
.footer-legal-link:hover{color:var(--text);opacity:1}
.footer-friends-wrap{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding-left:6px}
.footer-friends-label{
  font-size:11px;
  font-weight:900;
  letter-spacing:.2px;
  color:var(--muted);
  padding:2px 6px;
  border-radius:8px;
  background:var(--soft);
  border:1px solid var(--line)
}
.footer-friends{display:flex;flex-wrap:wrap;gap:0}
.footer-friend{font-size:12px;color:var(--muted);font-weight:700;opacity:.92;transition:color .18s ease,opacity .18s ease}
.footer-friend:not(:last-child)::after{content:"·";margin:0 10px;color:var(--muted);opacity:.55}
.footer-friend:hover{color:var(--text);opacity:1}
.home-friends-panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 12px}
.home-friends-wrap{padding-left:0}
.footer-right{display:flex;gap:12px;align-items:center;justify-content:flex-end}
.footer-qr{display:flex;gap:10px;align-items:flex-start}
.footer-qr-item{display:flex;flex-direction:column;align-items:center;gap:7px}
.footer-qr-btn{
  position:relative;
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none;
  font:inherit;
  color:inherit;
  border:1px solid transparent;
  background:
    linear-gradient(var(--card),var(--card)) padding-box,
    linear-gradient(135deg,rgba(255,90,95,.22),rgba(124,77,255,.14)) border-box;
  border-radius:16px;
  padding:6px;
  z-index:2;
  box-shadow:0 14px 34px rgba(0,0,0,.06);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease
}
.footer-qr-btn:hover,.footer-qr-btn:focus-visible{transform:translateY(-1px);box-shadow:0 18px 46px rgba(0,0,0,.10);z-index:60}
.footer-qr-btn:active{transform:scale(.985)}
.footer-qr-thumb{
  display:block;
  border-radius:12px;
  overflow:hidden;
  background:var(--soft);
  border:1px solid rgba(17,24,39,.06)
}
html[data-theme="dark"] .footer-qr-thumb{border-color:rgba(255,255,255,.10)}
.footer-qr-code{width:64px;height:64px;display:block;transform:translateZ(0);will-change:transform}
.footer-qr-btn.is-qrover .footer-qr-code{transform:translateZ(0) scale(1.02)}
.footer-qr-badge{
  position:absolute;
  left:10px;
  top:10px;
  padding:4px 8px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,90,95,.92), rgba(124,77,255,.86));
  color:#fff;
  font-size:11px;
  font-weight:950;
  letter-spacing:.2px;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 12px 26px rgba(0,0,0,.16);
  backdrop-filter:blur(6px);
  pointer-events:none
}
.footer-qr-label{
  font-size:11px;
  font-weight:900;
  letter-spacing:.2px;
  color:var(--muted);
  max-width:86px;
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis
}
.footer-qr-btn[data-tip]:before,
.footer-qr-btn[data-tip]:after{display:none}
.qr-pop{position:fixed;z-index:9999;pointer-events:none}
.qr-pop.is-open{pointer-events:auto}
.qr-pop[data-mode="popover"]{left:0;top:0;transform:translate3d(var(--x,0px),var(--y,0px),0)}
.qr-pop[data-mode="popover"] .qr-pop-mask{display:none}
.qr-pop[data-mode="popover"] .qr-pop-panel{
  opacity:0;
  transform:translate3d(-50%,calc(-100% - 10px),0) scale(.92);
  transform-origin:50% 100%;
  transition:opacity .28s ease,transform .44s cubic-bezier(.2,.9,.2,1)
}
.qr-pop[data-mode="popover"][data-place="bottom"] .qr-pop-panel{
  transform:translate3d(-50%,10px,0) scale(.92);
  transform-origin:50% 0%;
}
.qr-pop[data-mode="popover"].is-open .qr-pop-panel{opacity:1;transform:translate3d(-50%,calc(-100% - 10px),0) scale(1)}
.qr-pop[data-mode="popover"][data-place="bottom"].is-open .qr-pop-panel{transform:translate3d(-50%,10px,0) scale(1)}
.qr-pop[data-mode="modal"]{
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:calc(16px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))
}
.qr-pop[data-mode="modal"] .qr-pop-mask{
  position:absolute;inset:0;
  background:rgba(0,0,0,.42);
  opacity:0;
  transition:opacity .26s ease
}
.qr-pop[data-mode="modal"] .qr-pop-panel{
  position:relative;
  opacity:0;
  transform:translate3d(0,8px,0) scale(.96);
  transition:opacity .28s ease,transform .44s cubic-bezier(.2,.9,.2,1)
}
.qr-pop[data-mode="modal"].is-open{pointer-events:auto}
.qr-pop[data-mode="modal"].is-open .qr-pop-mask{opacity:1}
.qr-pop[data-mode="modal"].is-open .qr-pop-panel{opacity:1;transform:translate3d(0,0,0) scale(1)}
.qr-pop-panel{
  width:min(360px,calc(100vw - 28px));
  border-radius:20px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.84);
  backdrop-filter:blur(12px);
  box-shadow:0 22px 70px rgba(0,0,0,.20);
  padding:14px 14px 12px 14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px
}
html[data-theme="dark"] .qr-pop-panel{background:rgba(0,0,0,.24);box-shadow:0 26px 86px rgba(0,0,0,.55)}
.qr-pop-hd{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:2px 2px 10px 2px}
.qr-pop-title{font-size:14px;font-weight:950;letter-spacing:.2px;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.qr-pop-close{
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none;
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--muted);
  width:34px;height:34px;
  border-radius:12px;
  font:inherit;
  font-size:18px;
  font-weight:900;
  line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .18s ease,border-color .18s ease,background .18s ease,color .18s ease
}
.qr-pop-close:hover,.qr-pop-close:focus-visible{border-color:rgba(255,90,95,.35);color:var(--text)}
.qr-pop-close:active{transform:scale(.985)}
.qr-pop-body{display:flex;gap:12px;align-items:center;padding:0 2px 10px 2px}
.qr-pop-frame{
  flex:none;
  border-radius:16px;
  background:#fff;
  padding:10px;
  border:1px solid rgba(17,24,39,.06);
  box-shadow:0 14px 40px rgba(0,0,0,.10)
}
html[data-theme="dark"] .qr-pop-frame{border-color:rgba(255,255,255,.10);background:rgba(0,0,0,.22);box-shadow:none}
.qr-pop-txt{
  max-width:320px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.2px;
  color:var(--text);
  opacity:.82;
  text-align:center;
  overflow-wrap:anywhere;
  line-height:1.45
}
.qr-pop-img{
  width:152px;height:152px;
  max-width:min(76vw,360px);
  max-height:min(76vh,360px);
  display:block;
  object-fit:contain;
  border-radius:12px;
  background:#fff;
  touch-action:none;
  transform:translateZ(0);
  will-change:transform,opacity;
  opacity:1;
  transition:opacity .22s ease
}
html[data-theme="dark"] .qr-pop-img{background:#fff}
.qr-pop-meta{min-width:0;flex:1;display:flex;flex-direction:column;gap:6px}
.qr-pop-sub{font-size:12px;font-weight:900;color:var(--muted);line-height:1.4}
.qr-pop-raw{
  font-size:12px;
  font-weight:900;
  color:var(--text);
  opacity:.84;
  overflow-wrap:anywhere;
  line-height:1.4;
  max-height:3.8em;
  overflow:hidden
}
.qr-pop-actions{display:flex;gap:8px;flex-wrap:wrap;padding:0 2px 2px 2px}
.qr-pop-act{
  height:32px;
  padding:0 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--text);
  font-weight:900;
  letter-spacing:.1px;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:transform .14s ease,border-color .18s ease,background .18s ease,color .18s ease
}
.qr-pop-act:hover,.qr-pop-act:focus-visible{border-color:rgba(255,90,95,.35)}
.qr-pop-act:active{transform:scale(.985)}
.qr-pop-act.primary{
  border-color:transparent;
  background:linear-gradient(135deg, rgba(255,90,95,.92), rgba(124,77,255,.86));
  color:#fff
}
.fb-pop{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;pointer-events:none}
.fb-pop-mask{position:absolute;inset:0;background:rgba(0,0,0,.42);opacity:0;transition:opacity .26s ease}
.fb-pop-panel{
  position:relative;
  width:min(640px,92vw);
  background:#fff;
  border-radius:18px;
  box-shadow:0 20px 70px rgba(0,0,0,.26);
  opacity:0;
  transform:translate3d(var(--fb-dx,0px),calc(var(--fb-dy,0px) + 12px),0) scale(.22);
  transition:opacity .28s ease,transform .44s cubic-bezier(.2,.9,.2,1);
  padding:18px 18px 16px 18px
}
html[data-theme="dark"] .fb-pop-panel{background:var(--card)}
.fb-pop.is-open{pointer-events:auto}
.fb-pop.is-open .fb-pop-mask{opacity:1}
.fb-pop.is-open .fb-pop-panel{opacity:1;transform:translate3d(0,0,0) scale(1)}
.fb-pop-hd{display:flex;align-items:center;justify-content:space-between;gap:12px}
.fb-pop-title{font-size:18px;font-weight:900;letter-spacing:.2px}
.fb-pop-close{
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none;
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--muted);
  width:34px;height:34px;
  border-radius:12px;
  font:inherit;
  font-size:18px;
  font-weight:900;
  line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .18s ease,border-color .18s ease,background .18s ease,color .18s ease
}
.fb-pop-close:hover,.fb-pop-close:focus-visible{border-color:rgba(255,90,95,.35);color:var(--text)}
.fb-pop-close:active{transform:scale(.985)}
.fb-pop-note{
  display:flex;align-items:flex-start;gap:10px;
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(56,189,248,.26);
  background:rgba(56,189,248,.10)
}
html[data-theme="dark"] .fb-pop-note{border-color:rgba(56,189,248,.18);background:rgba(56,189,248,.08)}
.fb-pop-note-ico{
  width:18px;height:18px;
  border-radius:999px;
  background:rgba(56,189,248,.20);
  color:rgba(2,132,199,1);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;flex:0 0 auto;
  margin-top:1px
}
html[data-theme="dark"] .fb-pop-note-ico{background:rgba(56,189,248,.18);color:rgba(56,189,248,1)}
.fb-pop-note-txt{font-size:13px;font-weight:800;letter-spacing:.2px;color:var(--text);line-height:1.6}
.fb-form{margin-top:12px}
.fb-opts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
@media (max-width: 520px){.fb-opts{grid-template-columns:1fr}}
.fb-opt{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--soft);
  cursor:pointer;
  font-weight:900;
  letter-spacing:.2px;
  user-select:none
}
.fb-opt input{margin:0}
.fb-text{
  width:100%;
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:var(--card);
  color:var(--text);
  font:inherit;
  resize:vertical;
  display:none
}
.fb-pop.is-other .fb-text{display:block}
.fb-actions{display:flex;justify-content:center;margin-top:14px}
.fb-submit{
  cursor:pointer;
  -webkit-appearance:none;
  appearance:none;
  border:1px solid rgba(255,90,95,.60);
  background:rgba(255,90,95,1);
  color:#fff;
  height:42px;
  padding:0 26px;
  border-radius:12px;
  font:inherit;
  font-weight:900;
  letter-spacing:.2px;
  transition:transform .18s ease,box-shadow .18s ease
}
.fb-submit:hover{box-shadow:0 12px 28px rgba(255,90,95,.24)}
.fb-submit:active{transform:scale(.985)}
.fb-submit[data-loading="1"]{opacity:.78;pointer-events:none}
.footer-stats{min-width:220px;opacity:.9}
.footer-stats-title{font-size:11px;font-weight:800;letter-spacing:.2px;color:var(--muted);margin:0}
.footer-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}
.footer-stats-inline{display:flex;align-items:center;gap:12px;flex-wrap:nowrap;white-space:nowrap}
.footer-stats-inline .footer-stat{padding:0;gap:6px}
.footer-stats-inline .footer-stat-label{font-size:11px}
.footer-stats-inline .footer-stat-num{font-size:12px}
.footer-stat{
  display:flex;align-items:baseline;justify-content:space-between;gap:6px;
  padding:2px 0
}
.footer-stat-label{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.2px}
.footer-stat-num{font-size:12px;font-weight:800;letter-spacing:.2px;line-height:1.1;color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap}
.footer-stat-val{font-variant-numeric:tabular-nums;color:var(--text);opacity:.9}
.footer-stat-unit{margin-left:3px;font-size:11px;font-weight:700;letter-spacing:.2px;color:var(--muted)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:8px;margin-top:8px;border-top:1px solid var(--line);font-size:12px}
.footer-bottom-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.footer-bottom-right{display:flex;align-items:center}
.footer-dot{opacity:.55}
@media (max-width: 1024px){
  .footer-main{grid-template-columns:1fr}
  .footer-right{justify-content:flex-start;flex-wrap:wrap}
  .footer-stats{min-width:0;flex:1}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .footer-bottom-right{width:100%}
  .footer-stats-inline{flex-wrap:wrap}
}
@media (max-width: 640px){
  .footer{--footer-pad-left:14px;--footer-pad-right:14px}
  .footer-panel{padding:10px 10px 8px 10px}
  .footer-qr-code{width:56px;height:56px}
  .footer-stats-grid{grid-template-columns:1fr}
}
@media (min-width: 1200px){
  .is-home .footer{--footer-max:calc(100% - 280px);--footer-pad-left:0;--footer-pad-right:0}
}
@media (prefers-reduced-motion: reduce){
  .footer-brand,.footer-friend,.footer-qr-btn,.footer-qr-code,.qr-pop-panel,.qr-pop-mask,.fb-pop-panel,.fb-pop-mask{transition:none!important}
}
.need-login{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:26px 12px}
.need-login-ill{position:relative;width:240px;height:140px;margin:6px auto 2px}
.need-login-card{
  position:absolute;
  width:112px;height:78px;
  border-radius:16px;
  border:1px solid rgba(59,130,246,.20);
  background:
    radial-gradient(140px 80px at 20% 0%, rgba(59,130,246,.14), transparent 62%),
    radial-gradient(160px 80px at 90% 10%, rgba(99,102,241,.10), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.03)),
    var(--card);
  box-shadow:0 22px 46px rgba(0,0,0,.12)
}
.need-login-card.c1{left:14px;top:30px;transform:rotate(-10deg)}
.need-login-card.c2{left:64px;top:12px;transform:rotate(0deg)}
.need-login-card.c3{right:14px;top:30px;transform:rotate(10deg)}
.need-login-avatar{
  position:absolute;
  left:50%;top:74px;
  transform:translate(-50%,-50%);
  width:66px;height:66px;border-radius:999px;
  border:1px solid rgba(59,130,246,.28);
  background:
    radial-gradient(30px 30px at 30% 28%, rgba(255,255,255,.26), transparent 58%),
    radial-gradient(40px 40px at 72% 26%, rgba(59,130,246,.18), transparent 66%),
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.02)),
    var(--card);
  box-shadow:0 26px 56px rgba(0,0,0,.14)
}
.need-login-avatar:before{
  content:"";
  position:absolute;
  left:50%;top:22px;
  transform:translate(-50%,-50%);
  width:22px;height:22px;border-radius:999px;
  background:rgba(59,130,246,.22)
}
.need-login-avatar:after{
  content:"";
  position:absolute;
  left:50%;top:48px;
  transform:translate(-50%,-50%);
  width:38px;height:22px;border-radius:999px;
  background:rgba(59,130,246,.14)
}
.need-login-title{font-size:18px;font-weight:800}
.need-login-sub{font-size:13px;max-width:420px}
.need-login-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;align-items:center;margin-top:4px}
.need-login-actions .btn{display:flex;align-items:center;justify-content:center;height:44px;line-height:1}
.auth-wrap{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:18px}
.auth-card{
  width:min(980px,100%);
  height:clamp(500px,62vh,690px);
  max-height:calc(100vh - 20px);
  display:grid;grid-template-columns:1.25fr .75fr;
  background:var(--card);border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)
}
.auth-admin-card{
  width:min(900px,100%);
  height:clamp(420px,52vh,560px)
}
.auth-admin-card .auth-right{justify-content:center;position:relative}
.auth-admin-card .auth-right-top{margin-bottom:14px}
.auth-admin-card .auth-panel-title{font-size:18px}
.auth-admin-card .auth-panel-sub{margin-top:4px}
.auth-admin-card .auth-right .section{margin-top:14px;max-width:380px}
.auth-admin-card .auth-right .field{margin-top:12px}
.auth-admin-card .auth-right .auth-links{justify-content:flex-start}
.auth-admin-card .auth-right .auth-link{padding:0;height:34px}
.auth-admin-card .auth-copyright{
  margin-top:0;
  padding-top:0;
  position:absolute;
  right:20px;
  bottom:16px
}
.auth-admin-card .auth-left-rich{max-width:520px}
.auth-admin-card .auth-slogan-title{font-size:30px}
.auth{--auth-pink:#ff4081}
.auth-left{
  padding:0;
  background:#0b1220;
  color:#fff;
  position:relative;
  overflow:hidden
}
.auth-pattern{
  position:absolute;
  inset:0;
  background-image:radial-gradient(rgba(255,255,255,.1) 1px, transparent 1px);
  background-size:24px 24px;
  mask-image:linear-gradient(to bottom, #000 0%, transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, #000 0%, transparent 100%);
  pointer-events:none;
  z-index:0
}
.glass-card{
  margin:20px;
  height:calc(100% - 40px);
  background:rgba(255,255,255,.03);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  padding:36px;
  box-shadow:0 25px 50px -12px rgba(0,0,0,.5), inset 0 0 0 1px rgba(255,255,255,.05);
  position:relative;
  z-index:1
}
.auth-left-inner{
  height:calc(100% - 40px);
  display:grid;
  grid-template-rows:auto 1fr auto;
  gap:20px
}
.auth-left-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.auth-left-mid{display:grid;gap:10px}
.auth-left-bottom{display:grid;grid-template-columns:1fr;gap:14px;align-content:end}
.auth-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.auth-title-actions{display:flex;align-items:center;gap:10px}
.auth-home{
  width:38px;height:38px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(17,24,39,.10);
  background:
    radial-gradient(18px 18px at 30% 30%, rgba(255,90,95,.12), transparent 65%),
    radial-gradient(18px 18px at 70% 30%, rgba(124,77,255,.12), transparent 65%),
    rgba(255,255,255,.64);
  color:rgba(17,24,39,.78);
  box-shadow:0 12px 26px rgba(0,0,0,.10);
  transition:transform .2s ease,background .2s ease,opacity .2s ease
}
.auth-home:hover{opacity:.92}
.auth-home:active{transform:translateY(1px)}
.auth-home:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20)}
html[data-theme="dark"] .auth-home{
  border-color:rgba(255,255,255,.12);
  background:#000;
  color:#fff;
  box-shadow:0 14px 34px rgba(0,0,0,.40)
}
html[data-theme="dark"] .auth-home:active{transform:scale(.95)}
.auth-left-rich{margin-top:18px;max-width:420px}
.auth-left-kicker{font-weight:900;letter-spacing:.2px;opacity:.98}
.auth-left-desc{margin-top:10px;opacity:.92;line-height:1.65}
.auth-features{display:grid;gap:10px}
.auth-feature{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18)}
.auth-feature-ico{width:18px;height:18px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.22);font-weight:900;line-height:1;flex:none}
.auth-left-panel{padding:12px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.20)}
.auth-left-panel-title{font-weight:900;letter-spacing:.2px}
.auth-left-panel-sub{margin-top:6px;opacity:.92}
.auth-mini-grid{margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.auth-mini{padding:10px;border-radius:12px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.auth-mini-num{font-weight:900}
.auth-mini-label{opacity:.92}
.auth-right{
  padding:20px;
  background:
    radial-gradient(820px 520px at 110% 10%, rgba(255,90,95,.10), transparent 60%),
    radial-gradient(820px 520px at -10% 0%, rgba(124,77,255,.08), transparent 62%),
    linear-gradient(180deg,rgba(255,255,255,.72),rgba(255,255,255,.48));
  backdrop-filter:blur(16px);
  border-left:1px solid rgba(17,24,39,.10);
  display:flex;flex-direction:column;min-height:0
}
.auth-copyright{margin-top:auto;padding-top:10px;display:flex;justify-content:flex-end;color:var(--muted);font-size:11px}
html[data-theme="dark"] .auth-right{
  background:
    radial-gradient(820px 520px at 110% 10%, rgba(255,90,95,.12), transparent 60%),
    radial-gradient(820px 520px at -10% 0%, rgba(124,77,255,.10), transparent 62%),
    linear-gradient(180deg,rgba(23,26,32,.78),rgba(23,26,32,.48));
  border-left-color:rgba(255,255,255,.10)
}
body.is-auth{
  background:
    radial-gradient(920px 620px at 2% 4%, rgba(99,102,241,.14), transparent 62%),
    radial-gradient(920px 620px at 98% 18%, rgba(236,72,153,.12), transparent 64%),
    linear-gradient(180deg,#f8fafc 0%,#eef2ff 56%,#f1f5f9 100%)
}
html[data-theme="dark"] body.is-auth{
  background:
    radial-gradient(920px 620px at 2% 4%, rgba(99,102,241,.16), transparent 62%),
    radial-gradient(920px 620px at 98% 18%, rgba(236,72,153,.14), transparent 64%),
    linear-gradient(180deg,#0b1220 0%,#0f172a 56%,#070c18 100%)
}
body.is-auth .auth-wrap{
  min-height:100vh;
  padding:clamp(14px,3vh,34px) 18px;
  flex-direction:column;
  gap:14px
}
body.is-auth .auth-card{grid-template-columns:.82fr 1.18fr}
body.is-auth .auth-left{padding:22px}
body.is-auth .auth-right{padding:24px}
.auth-mark{display:flex;align-items:center;justify-content:space-between;gap:12px}
.auth-mark-title{font-size:18px;font-weight:900;letter-spacing:.4px}
.auth-mark-sub{font-size:12px;opacity:.9;font-weight:800}
.auth-slogan{margin-top:14px}
.auth-slogan-title{font-size:28px;font-weight:900;letter-spacing:.2px;line-height:1.15}
.auth-slogan-sub{margin-top:10px;opacity:.9}
.auth-foot{
  width:min(980px,100%);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;border-radius:14px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.40);
  backdrop-filter:blur(12px);
  color:var(--muted)
}
html[data-theme="dark"] .auth-foot{
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.06)
}
.auth-foot strong{color:var(--text)}
.auth-foot a{color:var(--text);font-weight:900}
.auth-foot a:hover{opacity:.9}
.auth-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.auth-tabs{
  flex:1 1 320px;
  display:flex;align-items:center;gap:6px;padding:4px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.40);
  box-shadow:0 14px 34px rgba(0,0,0,.10);
  backdrop-filter:blur(12px)
}
html[data-theme="dark"] .auth-tabs{
  border-color:rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  box-shadow:0 18px 44px rgba(0,0,0,.40)
}
.auth-tab{
  flex:1;
  height:44px;min-width:0;padding:0 14px;border-radius:999px;border:1px solid transparent;
  background:transparent;color:rgba(107,114,128,.92);font-weight:900;cursor:pointer;
  transition:background .42s ease,color .42s ease,transform .42s ease,box-shadow .42s ease,border-color .42s ease
}
.auth-tab.is-active{
  background:linear-gradient(135deg,rgba(255,90,95,.16),rgba(124,77,255,.14));
  color:var(--text);
  border-color:rgba(255,90,95,.18);
  box-shadow:0 12px 26px rgba(0,0,0,.12)
}
.auth-tab:active{transform:translateY(1px)}
.auth-tab:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.auth-right-top{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-bottom:10px}
.auth-hint{
  margin-top:8px;display:flex;align-items:center;justify-content:center;gap:6px;
  color:var(--muted);font-size:12px;height:34px;border-radius:12px;
  background:rgba(255,255,255,.7);border:1px solid rgba(17,24,39,.10);
  box-shadow:0 10px 24px rgba(0,0,0,.08)
}
html[data-theme="dark"] .auth-hint{
  background:rgba(23,26,32,.70);
  border-color:rgba(255,255,255,.10);
  box-shadow:0 14px 34px rgba(0,0,0,.40)
}
.auth-hint-link{
  border:0;background:transparent;color:var(--primary);font-weight:900;cursor:pointer;
  padding:0 2px;border-radius:8px;transition:color .2s ease,transform .2s ease
}
.auth-hint-link:hover{color:#ff3d44;transform:translateY(-1px)}
.auth-hint-link:active{transform:translateY(0)}
.auth-hint-link:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.auth-hint-dot{opacity:.55}
.auth-panels{margin-top:10px;position:relative;flex:1;min-height:0}
.auth-panel{
  position:absolute;inset:0;z-index:0;
  opacity:0;transform:translateY(12px) scale(.995);
  pointer-events:none;
  transition:opacity .42s ease,transform .42s ease;
  overflow-y:auto;
  overflow-x:hidden;
  padding-bottom:14px
}
.auth[data-auth-mode="login"] [data-auth-panel="login"],
.auth[data-auth-mode="register"] [data-auth-panel="register"],
.auth[data-auth-mode="forgot"] [data-auth-panel="forgot"],
.auth[data-auth-mode="reset"] [data-auth-panel="reset"]{
  opacity:1;transform:translateY(0) scale(1);pointer-events:auto;z-index:1
}
.auth-panel-title{font-size:17px;font-weight:900;letter-spacing:.2px}
.auth-panel-sub{margin-top:3px;color:var(--muted)}
.field{margin-top:8px}
.field-label{font-size:12px;color:var(--muted);font-weight:800;margin-bottom:5px}
.auth-form-label{display:block;font-size:12px;color:var(--muted);font-weight:800;margin-bottom:5px}
.auth-input{position:relative}
.auth-input-ico{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  color:var(--muted);opacity:.88;pointer-events:none
}
.auth-input .input{padding-left:38px}
.auth .input.is-inline-error::placeholder{color:#ef4444;opacity:1}
.auth .input.is-inline-error{caret-color:var(--text)}
.auth-code-row{display:flex;align-items:center;gap:8px}
.auth-code-row .auth-input{flex:1}
.auth-strength{margin-top:4px}
.auth-strength-row{display:flex;align-items:center;gap:8px}
.auth-strength-label{font-size:12px;color:var(--muted)}
.auth-strength-bars{display:flex;gap:6px}
.auth-strength-bar{width:52px;height:4px;border-radius:999px;background:rgba(107,114,128,.22)}
.auth-strength-tip{margin-top:2px;font-size:12px;color:var(--muted);opacity:.9}
.field-msg{min-height:0;margin-top:0;font-size:12px;color:var(--muted);opacity:0;transform:translateY(-2px);transition:opacity .32s ease,transform .32s ease}
.field.is-error .field-msg{opacity:1;transform:translateY(0);color:#ef4444}
.field.is-ok .field-msg{opacity:1;transform:translateY(0);color:#10b981}
.field.is-error .field-msg,
.field.is-ok .field-msg{margin-top:3px;min-height:14px}
.field.is-error:not(.is-active) .input{border-color:rgba(239,68,68,.55);box-shadow:0 0 0 4px rgba(239,68,68,.10)}
.field.is-ok:not(.is-active) .input{border-color:rgba(16,185,129,.55);box-shadow:0 0 0 4px rgba(16,185,129,.10)}
.auth [data-auth-panel="login"] .field.is-error:not(.is-active) .input,
.auth [data-auth-panel="login"] .field.is-ok:not(.is-active) .input{border-color:rgba(17,24,39,.14);box-shadow:none}
html[data-theme="dark"] .auth [data-auth-panel="login"] .field.is-error:not(.is-active) .input,
html[data-theme="dark"] .auth [data-auth-panel="login"] .field.is-ok:not(.is-active) .input{border-color:rgba(255,255,255,.14);box-shadow:none}
.auth .input{
  height:42px;
  background:rgba(255,255,255,.55);
  border-color:rgba(17,24,39,.14);
  color:var(--text)
}
html[data-theme="dark"] .auth .input{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.22);
  box-shadow:0 1px 0 rgba(255,255,255,.06) inset
}
.auth-input-row{display:flex;align-items:center;gap:8px}
.auth-input-row .input{flex:1}
.auth-code-btn{
  height:42px;padding:0 12px;border-radius:12px;border:1px solid var(--line);
  background:rgba(99,102,241,.06);
  border-color:rgba(99,102,241,.30);
  color:var(--primary);
  font-weight:900;cursor:pointer;white-space:nowrap
}
.auth-code-btn:hover{border-color:rgba(99,102,241,.45);background:rgba(99,102,241,.10);box-shadow:0 10px 24px rgba(0,0,0,.08)}
.auth-code-btn:active{transform:translateY(1px)}
.auth-code-btn:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(99,102,241,.18),0 10px 24px rgba(0,0,0,.08)}
.auth-code-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}
.auth .input:focus{border-color:rgba(99,102,241,.55);box-shadow:0 0 0 4px rgba(99,102,241,.18)}
.auth .field.is-active .input{
  border-color:rgba(99,102,241,.55);
  box-shadow:0 0 0 4px rgba(99,102,241,.18)
}
.auth .field.is-active .auth-input-ico{color:var(--primary)}
.auth-submit{margin-top:10px;width:100%;height:42px;border-radius:14px}

.auth-checks{margin-top:10px;display:grid;gap:8px}
.auth-checks .field{margin-top:0}
.auth-check{
  display:flex;align-items:flex-start;gap:10px;
  color:var(--muted);font-size:12px;line-height:1.3
}
.auth-check input[type="checkbox"]{
  width:16px;height:16px;margin-top:1px;flex:none;
  accent-color:var(--primary);
}
.auth-check a{color:var(--primary);text-decoration:none;font-weight:900}
.auth-check a:hover{text-decoration:underline}
.auth-links{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.auth-link{
  height:44px;padding:0 12px;border:0;border-radius:12px;
  background:transparent;color:var(--muted);font-weight:900;cursor:pointer;
  transition:background .3s ease,color .3s ease
}
.auth-link:hover{background:var(--soft);color:var(--text)}
.auth-link:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.auth-steps{display:flex;align-items:center;gap:10px;margin-top:16px}
.auth-step{display:flex;align-items:center;gap:10px}
.auth-step-dot{
  width:10px;height:10px;border-radius:999px;
  background:rgba(107,114,128,.35);
  box-shadow:0 0 0 4px rgba(107,114,128,.12);
  transition:background .38s ease,box-shadow .38s ease,transform .38s cubic-bezier(.34,1.56,.64,1)
}
.auth-step-txt{font-size:12px;font-weight:900;color:var(--muted);transition:color .38s ease}
.auth-step-line{flex:1;height:2px;border-radius:999px;background:rgba(107,114,128,.25);transition:background .38s ease}
.auth[data-forgot-step="2"] .auth-step-line{background:rgba(99,102,241,.35)}
.auth[data-forgot-step="1"] [data-step="1"] .auth-step-dot,
.auth[data-forgot-step="2"] [data-step="2"] .auth-step-dot{
  background:var(--primary);
  box-shadow:0 0 0 4px rgba(99,102,241,.18);
  transform:scale(1.2)
}
.auth[data-forgot-step="1"] [data-step="1"] .auth-step-txt,
.auth[data-forgot-step="2"] [data-step="2"] .auth-step-txt{color:var(--text)}

.auth-step-desc{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  font-size:12px;
  line-height:1.55;
  color:var(--muted);
  background:rgba(255,255,255,.55);
  border:1px solid rgba(17,24,39,.08)
}
html[data-theme="dark"] .auth-step-desc{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12)
}

.auth-step-panels{margin-top:12px;position:relative;min-height:240px}
.auth-step-panel{
  position:absolute;inset:0;
  opacity:0;transform:translateX(10px);
  pointer-events:none;
  transition:opacity .42s ease,transform .42s ease
}
.auth[data-forgot-step="1"] [data-forgot-panel="1"],
.auth[data-forgot-step="2"] [data-forgot-panel="2"]{opacity:1;transform:translateX(0);pointer-events:auto}

.auth-forgot-note{
  margin-top:10px;
  padding:12px 12px;
  border-radius:16px;
  background:rgba(99,102,241,.06);
  border:1px solid rgba(99,102,241,.18)
}
html[data-theme="dark"] .auth-forgot-note{
  background:rgba(99,102,241,.10);
  border-color:rgba(99,102,241,.22)
}
.auth-forgot-note-title{font-size:12px;font-weight:900;color:var(--text)}
.auth-forgot-note-sub{margin-top:4px;font-size:12px;color:var(--muted);line-height:1.5}

.auth-done{
  margin-top:12px;padding:20px;border-radius:18px;
  border:1px solid rgba(16,185,129,.25);
  background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(16,185,129,.02));
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:12px
}
.auth-done-ico{
  width:48px;height:48px;border-radius:999px;
  background:rgba(16,185,129,.14);
  color:#10b981;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;
  box-shadow:0 8px 20px rgba(16,185,129,.15)
}
.auth-done-title{font-size:18px;font-weight:900;letter-spacing:.2px;color:var(--text)}
.auth-done-sub{color:var(--muted);font-size:13px;line-height:1.6}
.auth-done-steps{margin-top:2px;width:100%;display:grid;gap:8px}
.auth-done-step{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;border-radius:14px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(16,185,129,.16);
  text-align:left
}
html[data-theme="dark"] .auth-done-step{
  background:rgba(255,255,255,.06);
  border-color:rgba(16,185,129,.18)
}
.auth-done-step-no{
  width:20px;height:20px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(16,185,129,.14);
  color:#10b981;
  font-size:12px;
  font-weight:900;
  flex:none;
  margin-top:1px
}
.auth-done-step-txt{font-size:12px;color:var(--muted);line-height:1.4;font-weight:800}
html[data-theme="dark"] .auth-done{
  background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(16,185,129,.04));
  border-color:rgba(16,185,129,.20)
}
.auth-theme{
  height:40px;display:inline-flex;align-items:center;gap:10px;padding:0 14px;
  border-radius:999px;border:1px solid rgba(17,24,39,.12);
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.7));
  color:var(--text);cursor:pointer;min-width:112px;justify-content:center;
  box-shadow:0 10px 22px rgba(0,0,0,.08);
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease,background .22s ease,color .22s ease
}
.auth-theme.is-ico{
  width:38px;min-width:0;
  padding:0;border-radius:999px;
  gap:0
}
html[data-theme="dark"] .auth-theme{
  border-color:rgba(255,255,255,.12);
  background:linear-gradient(180deg,rgba(23,26,32,.88),rgba(23,26,32,.62));
  box-shadow:0 14px 34px rgba(0,0,0,.40)
}
html[data-theme="dark"] .auth-theme.is-ico{
  background:#000;
  color:#fff
}
html[data-theme="dark"] .auth-theme.is-ico:active{transform:scale(.95)}
.auth-theme:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.30);box-shadow:0 14px 30px rgba(0,0,0,.12)}
.auth-theme:active{transform:translateY(0)}
.auth-theme:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.20),0 14px 30px rgba(0,0,0,.12)}
.auth-theme .theme-ico{display:block}
.auth-theme .i-sun{display:none}
html[data-theme="dark"] .auth-theme .i-moon{display:none}
html[data-theme="dark"] .auth-theme .i-sun{display:block}
.auth-theme-txt{font-size:12px;font-weight:800;letter-spacing:.2px}

.has-tip{position:relative}
.has-tip:after{
  content:attr(data-tip);
  position:absolute;
  right:0;
  top:calc(100% + 10px);
  padding:7px 10px;
  border-radius:10px;
  background:rgba(15,18,30,.86);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
  opacity:0;
  transform:translateY(-4px);
  pointer-events:none;
  box-shadow:0 18px 50px rgba(0,0,0,.42);
  transition:opacity .16s ease,transform .16s ease
}
.has-tip:before{
  content:"";
  position:absolute;
  right:12px;
  top:calc(100% + 4px);
  width:8px;height:8px;
  background:rgba(15,18,30,.86);
  border-left:1px solid rgba(255,255,255,.14);
  border-top:1px solid rgba(255,255,255,.14);
  transform:rotate(45deg);
  opacity:0;
  pointer-events:none;
  transition:opacity .16s ease
}
.has-tip:hover:after,.has-tip:focus-visible:after{opacity:1;transform:translateY(0)}
.has-tip:hover:before,.has-tip:focus-visible:before{opacity:1}
.form-row{margin:12px 0}
.field-hint{margin-top:4px;font-size:12px;color:var(--muted)}
.cat-icon-row{display:flex;gap:10px;align-items:center}
.cat-icon-preview{
  width:32px;height:32px;border-radius:10px;border:1px solid var(--line);background:var(--soft);
  display:flex;align-items:center;justify-content:center;font-size:18px;flex:none
}
.cat-icon-preview img{width:100%;height:100%;object-fit:cover;border-radius:10px;display:block}
.cat-icon-preview svg{display:block;width:100%;height:100%}
.cat-icon-preview i{font-size:18px;line-height:1}
.cat-icon-main{flex:1;display:flex;flex-direction:column;gap:6px}
.cat-icon-mode{display:flex;gap:10px;flex-wrap:wrap}
.cat-radio{display:flex;gap:6px;align-items:center;font-size:12px;color:var(--muted);user-select:none}
.cat-radio input{accent-color:var(--primary)}
.cat-icon-pane{display:flex;flex-direction:column;gap:8px}
.cat-icon-inline{display:flex;gap:6px;align-items:center}
.cat-icon-inline .input{flex:1}
.cat-icon-actions{display:flex;gap:6px;flex-wrap:wrap}
.cat-icon-picker{
  margin-top:10px;padding:10px;border-radius:12px;border:1px solid var(--line);background:var(--soft)
}
.cat-icon-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.cat-icon-count{font-size:12px;color:var(--muted)}
.cat-icon-grid{
  display:grid;
  grid-template-columns:repeat(10,minmax(0,1fr));
  gap:4px
}
.cat-icon-item{
  height:28px;border-radius:8px;border:1px solid var(--line);background:var(--card);
  display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;
  transition:background .16s ease,border-color .16s ease,transform .12s ease
}
.cat-icon-item i{font-size:16px;line-height:1}
.cat-icon-item:hover{
  background:rgba(255,90,95,.08);
  border-color:rgba(255,90,95,.35);
  transform:translateY(-1px)
}
.input{
  width:100%;height:40px;border-radius:12px;border:1px solid var(--line);padding:0 12px;outline:0;
  background:var(--card);color:var(--text);
  transition:border-color .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease
}
.input::placeholder{color:var(--muted)}
.input:focus{border-color:rgba(255,90,95,.45);box-shadow:0 0 0 4px rgba(255,90,95,.16)}
.input:focus-visible{outline:0}
html[data-theme="dark"] .input{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.14);
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset
}
html[data-theme="dark"] .input:focus{border-color:rgba(255,90,95,.50);box-shadow:0 0 0 4px rgba(255,90,95,.20)}
html[data-theme="dark"] select.input{color:var(--text)}
html[data-theme="dark"] select.input option{background:#171a20;color:var(--text)}
.pass-field{position:relative}
.pass-field .input{padding-right:46px}
.pass-eye{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:34px;height:34px;border-radius:12px;
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--text);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,opacity .18s ease
}
.pass-eye:hover{border-color:rgba(255,90,95,.35);transform:translateY(-50%) translateY(-1px);box-shadow:0 10px 20px rgba(0,0,0,.06)}
.pass-eye:active{transform:translateY(-50%)}
.pass-eye:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
html[data-theme="dark"] .pass-eye{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);box-shadow:0 1px 0 rgba(255,255,255,.04) inset}
html[data-theme="dark"] .pass-eye:hover{border-color:rgba(255,90,95,.55);box-shadow:0 14px 28px rgba(0,0,0,.45)}
.smtp-panels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.smtp-panel{border:1px solid var(--line);border-radius:12px;padding:10px 10px;background:rgba(255,255,255,.30)}
html[data-theme="dark"] .smtp-panel{background:rgba(255,255,255,.03)}
.smtp-panel-title{font-size:12px;font-weight:800;color:var(--muted);margin-bottom:4px}
.smtp-panel .form-row{margin:10px 0}
.smtp-panel textarea.input{height:140px;padding:10px;resize:vertical}
.smtp-hint{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.6}
.qr-admin-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.qr-admin-item{border:1px solid var(--line);border-radius:12px;padding:10px 10px;background:rgba(255,255,255,.30)}
html[data-theme="dark"] .qr-admin-item{background:rgba(255,255,255,.03)}
.qr-admin-preview{margin-top:0;border-radius:12px;border:1px dashed var(--line);background:var(--soft);padding:10px;display:flex;align-items:center;justify-content:center}
html[data-theme="dark"] .qr-admin-preview{background:rgba(255,255,255,.04)}
.qr-admin-img{width:140px;height:140px;object-fit:cover;border-radius:10px;background:rgba(0,0,0,.06)}
.qr-admin-actions{display:flex;gap:10px;align-items:center;margin-top:10px;flex-wrap:wrap}
.qr-admin-meta{margin-top:8px;font-size:12px;line-height:1.5}
.music-admin-top{margin-bottom:12px;display:flex;flex-direction:column;gap:8px}
.music-admin-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.music-admin-label{font-weight:900;letter-spacing:.2px}
.music-admin-tip{margin-top:-2px}
.music-admin-fieldset{border:0;padding:0;margin:0}
.music-admin-fieldset.is-disabled{opacity:.58}
.music-admin-providers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px;margin-top:8px}
.music-admin-provider{display:flex;align-items:center;gap:8px}
.music-admin-provider input{width:14px;height:14px}
.music-admin-tune .form-row{margin-top:10px}
.music-admin-actions{margin-top:12px;display:flex;justify-content:flex-end}
.admin-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.admin-switch input{position:absolute;opacity:0;pointer-events:none}
.admin-switch-ui{
  width:46px;height:26px;border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft);
  position:relative;
  transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease
}
.admin-switch-ui:before{
  content:"";
  position:absolute;left:3px;top:3px;
  width:20px;height:20px;border-radius:999px;
  background:var(--card);
  box-shadow:0 10px 22px rgba(0,0,0,.10);
  transition:transform .18s ease,background .18s ease,box-shadow .18s ease
}
.admin-switch input:checked + .admin-switch-ui{background:rgba(255,90,95,.18);border-color:rgba(255,90,95,.35)}
.admin-switch input:checked + .admin-switch-ui:before{transform:translateX(20px);background:var(--primary);box-shadow:0 12px 26px rgba(255,90,95,.18)}
.admin-switch-text{font-size:12px;color:var(--muted);font-weight:800}
.admin-switch:focus-within .admin-switch-ui{box-shadow:0 0 0 4px rgba(255,90,95,.16)}
.admin-switch:hover .admin-switch-ui{border-color:rgba(255,90,95,.25)}
.mini-bg-admin-upload{margin-bottom:12px}
.mini-bg-drop{
  display:flex;
  gap:12px;
  align-items:stretch;
  border:1px dashed var(--line);
  border-radius:14px;
  background:var(--soft);
  padding:12px;
  cursor:pointer;
  transition:border-color .18s ease,box-shadow .18s ease,background .18s ease
}
html[data-theme="dark"] .mini-bg-drop{background:rgba(255,255,255,.04)}
.mini-bg-drop:hover{border-color:rgba(255,90,95,.30)}
.mini-bg-drop.is-drag{border-color:rgba(255,90,95,.55);box-shadow:0 0 0 4px rgba(255,90,95,.12)}
.mini-bg-drop-main{flex:1;min-width:0}
.mini-bg-drop-title{font-weight:900}
.mini-bg-drop-sub{margin-top:4px;font-size:12px;line-height:1.6}
.mini-bg-drop-actions{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.mini-bg-drop-meta{margin-top:8px;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-bg-drop-preview{width:140px;flex:none;display:flex;align-items:center;justify-content:center}
.mini-bg-drop-img{width:140px;height:90px;object-fit:cover;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.06)}
.mini-bg-admin-head{margin:14px 0 10px;display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.mini-bg-admin-title{font-weight:900}
.mini-bg-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.mini-bg-card{
  position:relative;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--card);
  overflow:hidden;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease
}
html[data-theme="dark"] .mini-bg-card{box-shadow:0 16px 42px rgba(0,0,0,.42)}
.mini-bg-card:hover{transform:translateY(-2px);border-color:rgba(255,90,95,.22);box-shadow:0 18px 44px rgba(0,0,0,.10)}
.mini-bg-card.is-saved{border-color:rgba(16,185,129,.50);box-shadow:0 0 0 4px rgba(16,185,129,.14),0 18px 44px rgba(0,0,0,.10)}
.mini-bg-thumb{aspect-ratio:4/3;background:var(--soft);position:relative}
.mini-bg-img{width:100%;height:100%;object-fit:cover;display:block}
.mini-bg-overlay{
  position:absolute;inset:0;
  padding:10px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:10px;
  background:linear-gradient(180deg, rgba(2,6,18,.46) 0%, rgba(2,6,18,.06) 52%, rgba(2,6,18,.56) 100%);
  opacity:0;
  pointer-events:none;
  transition:opacity .16s ease
}
.mini-bg-card:hover .mini-bg-overlay,.mini-bg-card:focus-within .mini-bg-overlay{opacity:1;pointer-events:auto}
.mini-bg-badges{display:flex;align-items:center;justify-content:space-between;gap:8px}
.mini-bg-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(2,6,18,.46);
  color:rgba(255,255,255,.92);
  font-size:12px;font-weight:900
}
.mini-bg-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(2,6,18,.46);
  color:rgba(255,255,255,.92);
  font-size:12px;font-weight:900;
  user-select:none
}
.mini-bg-pill input{width:14px;height:14px}
.mini-bg-ops{display:flex;gap:10px;justify-content:flex-end}
.mini-bg-op.btn.btn-ico{
  width:34px;height:34px;
  border-color:rgba(255,255,255,.16);
  background:rgba(2,6,18,.36);
  color:rgba(255,255,255,.92)
}
.mini-bg-op.btn.btn-ico:hover{border-color:rgba(255,255,255,.26);background:rgba(2,6,18,.50)}
.mini-bg-op.btn.btn-ico svg{width:18px;height:18px}
@media (max-width:980px){.mini-bg-admin-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}
@media (max-width:640px){
  .mini-bg-drop{flex-direction:column}
  .mini-bg-drop-preview{width:100%}
  .mini-bg-drop-img{width:100%;height:160px}
  .mini-bg-admin-grid{grid-template-columns:1fr}
  .mini-bg-overlay{opacity:1;pointer-events:auto}
}
@media (hover:none){.mini-bg-overlay{opacity:1;pointer-events:auto}}
.muted{color:var(--muted);overflow-wrap:anywhere}
.toast{
  position:fixed;
  left:50%;
  top:16px;
  transform:translate3d(-50%,-8px,0);
  z-index:10080;
  display:none;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease,transform .2s ease;
  background:rgba(255,255,255,.88);
  color:rgba(17,24,39,.86);
  border:1px solid rgba(17,24,39,.10);
  border-radius:16px;
  box-shadow:0 18px 50px rgba(0,0,0,.12);
  backdrop-filter:blur(14px);
  max-width:min(calc(100vw - 28px),520px);
  overflow-wrap:anywhere
}
.toast.is-show{opacity:1;transform:translate3d(-50%,0,0);pointer-events:auto}
html[data-theme="dark"] .toast{
  background:rgba(0,0,0,.72);
  color:#fff;
  border-color:rgba(255,255,255,.14);
  box-shadow:0 22px 70px rgba(0,0,0,.55)
}
.toast-inner{display:flex;align-items:center;gap:10px;padding:10px 12px}
.toast-ico{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex:none}
.toast-txt{font-size:13px;font-weight:900;letter-spacing:.2px;line-height:1.35}
.toast-success{border-color:rgba(16,185,129,.25)}
.toast-success .toast-ico{color:#10b981}
.toast-error{border-color:rgba(239,68,68,.25)}
.toast-error .toast-ico{color:#ef4444}
.toast-loading .toast-ico{color:rgba(107,114,128,.90)}
html[data-theme="dark"] .toast-loading .toast-ico{color:rgba(255,255,255,.86)}
.toast-spinner{
  width:16px;height:16px;border-radius:999px;
  border:2px solid currentColor;border-right-color:transparent;
  animation:toast-spin .7s linear infinite
}
@keyframes toast-spin{to{transform:rotate(360deg)}}
.admin-layout{display:flex;gap:14px}
.admin-nav{width:220px}
.admin-nav a{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:var(--card);margin-bottom:10px}
.tree{display:flex;flex-direction:column;gap:8px}
.tree.tree-compact{gap:6px}
.tree.tree-list{
  --indent:16px;
  gap:0;
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--card);
  overflow:hidden
}
.tree.tree-list.tree-compact{--indent:14px;gap:0}
.tree.tree-list .tree-item{
  position:relative;
  display:flex;align-items:center;gap:10px;
  padding:10px 12px 10px calc(12px + (var(--level,0) * var(--indent)));
  border:0;border-bottom:1px solid var(--line);
  border-radius:0;background:transparent;
  overflow:hidden;
  max-height:60px;
  transition:background .18s ease,color .18s ease,opacity .18s ease,transform .18s ease,max-height .18s ease,padding .18s ease
}
.tree.tree-list.tree-compact .tree-item{padding:8px 12px 8px calc(12px + (var(--level,0) * var(--indent)))}
.tree.tree-list.tree-compact .tree-item{max-height:52px}
.tree.tree-list .tree-item:last-child{border-bottom:0}
.tree.tree-list .tree-item:hover{background:var(--soft)}
.tree.tree-list .tree-item.active{
  background:linear-gradient(90deg, rgba(255,90,95,.12), rgba(255,90,95,0) 42%);
  box-shadow:inset 3px 0 0 rgba(255,90,95,.45)
}
.tree.tree-list .tree-item.is-open{
  background:linear-gradient(90deg, rgba(255,90,95,.06), rgba(255,90,95,0) 42%)
}
.tree.tree-list .tree-item.is-hidden{
  opacity:0;
  transform:translate3d(0,-2px,0);
  max-height:0;
  padding-top:0;
  padding-bottom:0;
  border-bottom:0;
  pointer-events:none
}
.tree.tree-list .tree-item.is-drop-target{
  background:linear-gradient(90deg, rgba(59,130,246,.14), rgba(59,130,246,0) 46%);
  box-shadow:inset 3px 0 0 rgba(59,130,246,.70)
}
.tree.tree-list .tree-item.is-drop-target.is-drop-deny{
  background:linear-gradient(90deg, rgba(239,68,68,.14), rgba(239,68,68,0) 46%);
  box-shadow:inset 3px 0 0 rgba(239,68,68,.70)
}
html[data-theme="dark"] .tree.tree-list .tree-item:hover{background:rgba(255,255,255,.06)}
html[data-theme="dark"] .tree.tree-list .tree-item.active{
  background:linear-gradient(90deg, rgba(255,90,95,.22), rgba(255,90,95,0) 46%);
  box-shadow:inset 3px 0 0 rgba(255,90,95,.70)
}
html[data-theme="dark"] .tree.tree-list .tree-item.is-open{
  background:linear-gradient(90deg, rgba(255,90,95,.14), rgba(255,90,95,0) 50%);
  box-shadow:inset 3px 0 0 rgba(255,90,95,.32)
}
.table tr.is-selected td{background:rgba(255,90,95,.08)}
html[data-theme="dark"] .table tr.is-selected td{background:rgba(255,90,95,.14)}
.table tr.is-moving{opacity:.72}
.table tr.is-removing{opacity:0;transition:opacity .18s ease}
.dnd-drag-image{
  min-width:150px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.14);
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 40px rgba(0,0,0,.16);
  color:rgba(17,24,39,.86);
  backdrop-filter:blur(14px)
}
html[data-theme="dark"] .dnd-drag-image{
  border-color:rgba(255,255,255,.14);
  background:rgba(0,0,0,.72);
  color:#fff;
  box-shadow:0 22px 70px rgba(0,0,0,.55)
}
.dnd-title{font-size:13px;font-weight:900;letter-spacing:.2px;line-height:1.2}
.dnd-sub{margin-top:4px;font-size:12px;color:rgba(107,114,128,.90);font-weight:700}
html[data-theme="dark"] .dnd-sub{color:rgba(255,255,255,.78)}
.dnd-sample{margin-top:6px;font-size:12px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tree.tree-list .tree-item.is-disabled{opacity:.65}
.tree.tree-list .tree-item:before{
  content:"";
  position:absolute;
  left:calc(12px + (var(--level,0) * var(--indent)) - 8px);
  top:0;bottom:0;
  width:1px;
  background:rgba(17,24,39,.10)
}
html[data-theme="dark"] .tree.tree-list .tree-item:before{background:rgba(255,255,255,.22)}
.tree.tree-list .tree-item.is-root:before{display:none}
.tree.tree-list .tree-item:after{
  content:"";
  position:absolute;
  left:calc(12px + (var(--level,0) * var(--indent)) - 8px);
  top:50%;
  width:10px;height:1px;
  background:rgba(17,24,39,.10)
}
html[data-theme="dark"] .tree.tree-list .tree-item:after{background:rgba(255,255,255,.22)}
.tree.tree-list .tree-item.is-root:after{display:none}
.tree-toggle{
  width:26px;height:26px;border-radius:10px;border:1px solid transparent;background:transparent;
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);flex:none;
  transition:background .18s ease,border-color .18s ease,color .18s ease,transform .18s ease
}
.tree-toggle:hover{background:var(--soft);border-color:var(--line);color:var(--text)}
.tree-toggle:active{transform:translateY(1px)}
.tree-toggle:before{
  content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(-45deg);transition:transform .18s ease
}
.tree-item.is-open .tree-toggle:before{transform:rotate(45deg)}
.tree-item.is-open .tree-toggle{color:var(--text)}
.tree-item.active .tree-toggle{color:var(--text)}
.tree-toggle.tree-toggle-placeholder{border-color:transparent;background:transparent}
.tree-toggle.tree-toggle-placeholder:before{display:none}
.tree-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:4px}
.tree-title{display:flex;align-items:center;gap:8px;min-width:0}
.tree-ico{
  width:26px;height:26px;border-radius:10px;border:1px solid var(--line);background:var(--soft);
  display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none;
  color:var(--text);font-size:14px
}
.tree-ico img{width:100%;height:100%;object-fit:cover;display:block}
.tree-ico svg{display:block;width:100%;height:100%}
.tree-ico i{font-size:14px;line-height:1}
.tree-name{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tree-slug{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tree-sub{display:flex;gap:8px;flex-wrap:wrap}
.tree-pill{font-size:12px;color:var(--muted);padding:3px 8px;border-radius:999px;border:1px solid var(--line);background:var(--soft)}
.tree-actions{display:flex;align-items:center;gap:8px;flex:none}
.tree-link{display:flex;align-items:center;gap:8px;min-width:0;text-decoration:none;color:inherit}
.tree-link:hover .tree-name{color:var(--primary)}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid var(--line);padding:10px 8px;text-align:left}
.table th{color:var(--muted);font-weight:600;background:var(--table-head)}
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px;flex-wrap:wrap}
.toolbar .input{height:34px}
.pagination:not(ul){display:flex;align-items:center;justify-content:center;padding:12px}
ul.pagination{display:flex;gap:8px;align-items:center;justify-content:center;list-style:none;margin:0;padding:0}
ul.pagination>li{display:flex}
ul.pagination>li>a,ul.pagination>li>span{
  min-width:34px;height:34px;padding:0 12px;border-radius:12px;
  border:1px solid var(--line);background:var(--card);color:var(--text);
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;text-decoration:none;
  transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease
}
ul.pagination>li>a:hover{
  border-color:rgba(255,90,95,.42);
  background:var(--soft);
  box-shadow:0 10px 24px rgba(0,0,0,.06);
  transform:translateY(-1px)
}
ul.pagination>li.active>span{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
  box-shadow:0 12px 28px rgba(0,0,0,.10)
}
ul.pagination>li.disabled>span{
  background:var(--soft);
  color:var(--muted);
  opacity:.6
}
ul.pagination>li.disabled>a,ul.pagination>li.disabled>span{cursor:not-allowed;pointer-events:none}
.hot-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.hot-card{
  display:flex;align-items:center;gap:10px;height:44px;padding:0 12px;border-radius:12px;
  border:1px solid var(--line);background:var(--card);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease
}
.hot-card:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.35);box-shadow:0 10px 24px rgba(0,0,0,.06)}
.hot-ico{width:26px;height:26px;border-radius:999px;background:var(--soft);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none}
.hot-ico img{width:100%;height:100%;object-fit:cover}
.hot-ico > span{font-size:14px;line-height:1;transform:translateY(-.5px)}
.hot-name{min-width:0;font-weight:800;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.side-rec-grid{display:grid;grid-template-columns:1fr;gap:12px}
.side-rec-card{position:relative;display:flex;align-items:center;gap:12px;padding:10px;border-radius:12px;border:1px solid var(--line);background:var(--card);text-decoration:none;color:inherit;transition:all .25s cubic-bezier(0.25, 0.8, 0.25, 1)}
.side-rec-card:hover{transform:translateY(-2px);border-color:rgba(255,90,95,.3);box-shadow:0 8px 24px rgba(0,0,0,.06), 0 2px 8px rgba(255,90,95,0.04);z-index:1}
.side-rec-card:focus-visible{outline:2px solid rgba(255,90,95,.45);outline-offset:2px}
.side-rec-cover{width:48px;height:48px;border-radius:10px;overflow:hidden;background:var(--soft);flex:none;display:block;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);position:relative}
.side-rec-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.side-rec-card:hover .side-rec-cover img{transform:scale(1.08)}
.side-rec-meta{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.side-rec-top{display:flex;align-items:center;justify-content:space-between;gap:6px;min-width:0}
.side-rec-left{display:flex;align-items:center;gap:6px;min-width:0}
.side-rec-tag{
  height:16px;padding:0 4px;border-radius:4px;
  background:linear-gradient(135deg, #ff5a5f 0%, #ff8a90 100%);
  color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;flex:none;line-height:1;
  box-shadow:0 2px 5px rgba(255,90,95,0.2)
}
.side-rec-name{min-width:0;font-weight:700;font-size:14px;line-height:1.3;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-rec-stats{font-size:10px;line-height:1;color:var(--muted);white-space:nowrap;background:transparent;padding:0;flex:none;opacity:0.8}
.side-rec-desc{font-size:12px;line-height:1.4;color:var(--muted);opacity:.75;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.side-rec-go{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:0;transform:translateX(-5px);transition:all .25s ease;background:rgba(255,90,95,0.1);font-size:14px;font-weight:bold;position:absolute;right:10px}
.side-rec-card:hover .side-rec-go{opacity:1;transform:translateX(0)}

.side-post-list{display:flex;flex-direction:column;gap:12px}
.side-post-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:12px;border:1px solid var(--line);background:var(--card);text-decoration:none;color:inherit;transition:all .25s cubic-bezier(0.25, 0.8, 0.25, 1)}
.side-post-item:hover{transform:translateY(-2px);border-color:rgba(255,90,95,.3);box-shadow:0 8px 24px rgba(0,0,0,.06), 0 2px 8px rgba(255,90,95,0.04);z-index:1}
.side-post-item:focus-visible{outline:2px solid rgba(255,90,95,.45);outline-offset:2px}
.side-post-cover{width:48px;height:48px;border-radius:10px;overflow:hidden;background:var(--soft);flex:none;display:block;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);position:relative}
.side-post-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.side-post-item:hover .side-post-cover img{transform:scale(1.08)}
.side-post-meta{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.side-post-top{display:flex;align-items:center;justify-content:space-between;gap:6px;min-width:0}
.side-post-title{min-width:0;font-weight:700;font-size:14px;line-height:1.3;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-post-views{font-size:10px;line-height:1;color:var(--muted);white-space:nowrap;background:transparent;padding:0;flex:none;opacity:0.8}
.side-post-sub{font-size:12px;line-height:1.4;color:var(--muted);opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-post-go{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:0;transform:translateX(-5px);transition:all .25s ease;background:rgba(255,90,95,0.1);font-size:14px;font-weight:bold;position:absolute;right:10px}
.side-post-item:hover .side-post-go{opacity:1;transform:translateX(0)}
@media (min-width: 981px){
  .home-sections .grid.section>.col-8{grid-column:span 9}
  .home-sections .grid.section>.col-4{grid-column:span 3}
}
@media (min-width: 1200px){
  body.is-hero .category-side{position:sticky;top:84px}
}
html[data-theme="dark"] .home-subtabs{background:rgba(0,0,0,.28);border-color:rgba(255,255,255,.10);box-shadow:0 0 0 1px rgba(0,0,0,.22) inset}
html[data-theme="dark"] .home-subtab{color:rgba(255,255,255,.78)}
html[data-theme="dark"] .home-subtab:hover{color:#fff}
html[data-theme="dark"] .home-subtabs.is-ready .home-subtab.is-active{color:rgba(255,255,255,.78)}
html[data-theme="dark"] .home-subtabs.is-ready .home-subtab.is-current{color:rgba(255,255,255,.78)}
html[data-theme="dark"] .home-subtabs.is-ready .home-subtab.is-hover{color:#fff}
html[data-theme="dark"] .site-go:before{border-color:rgba(255,255,255,.62)}
html[data-theme="dark"] .site-card:hover .site-go{
  background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);box-shadow:0 12px 26px rgba(0,0,0,.45)
}
html[data-theme="dark"] .site-card:hover .site-go:before{border-color:rgba(255,255,255,.78)}
html[data-theme="dark"] .home-mod{background:transparent}
html[data-theme="dark"] .card{background:var(--card)}
html[data-theme="dark"] .site-card{background:var(--card);border-color:var(--line)}
html[data-theme="dark"] .site-card:hover{box-shadow:0 12px 28px rgba(0,0,0,.32);transform:translateY(-1px)}
html[data-theme="dark"] .site-ico{background:rgba(255,255,255,.08);box-shadow:none}
.user-home{min-height:60vh}
.user-hero{position:relative;padding:18px 0 22px 0;overflow:hidden}
.user-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(1200px 420px at 12% 8%,rgba(255,66,140,.78),rgba(255,66,140,0) 56%),
    radial-gradient(900px 420px at 82% 18%,rgba(255,153,60,.78),rgba(255,153,60,0) 52%),
    radial-gradient(820px 520px at 55% 28%,rgba(124,77,255,.62),rgba(124,77,255,0) 60%),
    linear-gradient(90deg,rgba(17,24,39,.90),rgba(17,24,39,.10));
  transform:translate3d(0,0,0)
}
.user-hero-inner{position:relative}
.user-hero-card{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 14px;border-radius:16px;
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.14);
  color:rgba(255,255,255,.94);
  box-shadow:0 18px 44px rgba(0,0,0,.22);
  backdrop-filter:blur(12px)
}
.user-hero-avatar{
  width:72px;height:72px;border-radius:18px;
  border:2px solid rgba(255,255,255,.82);
  background:rgba(255,255,255,.12);
  box-shadow:0 18px 44px rgba(0,0,0,.22);
  overflow:hidden;flex:none
}
.user-hero-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.user-hero-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:5px}
.user-hero-name{display:flex;align-items:center;gap:10px;min-width:0}
.user-hero-name-txt{font-size:18px;font-weight:900;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.user-hero-pill{
  height:20px;padding:0 8px;border-radius:999px;
  border:1px solid rgba(255,255,255,.26);
  background:rgba(255,255,255,.12);
  color:rgba(255,255,255,.88);
  display:inline-flex;align-items:center;justify-content:center;flex:none;
  font-size:12px;font-weight:900;letter-spacing:.2px
}
.user-hero-meta{display:flex;align-items:center;gap:8px;min-width:0;color:rgba(255,255,255,.78);font-size:12px;font-weight:800}
.user-hero-email{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60ch}
.user-hero-bio{color:rgba(255,255,255,.80);font-size:13px;line-height:1.6;max-width:90ch;overflow-wrap:anywhere}
.user-hero-actions{display:flex;align-items:center;gap:10px;flex:none}
.user-hero-actions .btn{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.18);
  color:rgba(255,255,255,.92);
  box-shadow:0 14px 30px rgba(0,0,0,.18)
}
.user-hero-actions .btn:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.24);color:#fff}
.user-home-back{display:none}
.user-shell{margin-top:-14px}
.user-grid{margin-top:0}
.user-home .btn{display:inline-flex;align-items:center;justify-content:center;line-height:1}
.user-nav{display:flex;flex-direction:column;gap:8px}
.user-nav-item{
  height:42px;border-radius:12px;border:1px solid var(--line);background:var(--card);
  display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px;
  color:var(--text);cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease,color .18s ease
}
.user-nav-item:hover{border-color:rgba(255,90,95,.28);box-shadow:0 10px 22px rgba(0,0,0,.06);transform:translateY(-1px)}
.user-nav-item:active{transform:translateY(0)}
.user-nav-item:focus{outline:0}
.user-nav-item:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.20),0 10px 22px rgba(0,0,0,.06)}
.user-nav-item.is-active{
  border-color:rgba(255,90,95,.30);
  background:linear-gradient(135deg,rgba(255,90,95,.10),rgba(124,77,255,.08));
  box-shadow:0 14px 30px rgba(0,0,0,.08)
}
.user-nav-txt{font-weight:900}
.user-nav-badge{
  width:8px;height:8px;min-width:8px;border-radius:999px;padding:0;
  background:#ef4444;
  display:none;
  font-size:0;line-height:0
}
.user-nav-badge[aria-hidden="false"]{display:inline-block}
.user-nav-foot{margin-top:12px;display:flex;justify-content:stretch}
.user-nav-foot .btn{width:100%}
.user-quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.user-quick{
  text-align:left;
  border:1px solid var(--line);background:var(--card);border-radius:14px;padding:10px 10px;
  color:var(--text);
  cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease
}
.user-quick:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.28);box-shadow:0 10px 22px rgba(0,0,0,.06)}
.user-quick:active{transform:translateY(0)}
.user-quick:focus{outline:0}
.user-quick:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.20),0 10px 22px rgba(0,0,0,.06)}
.user-quick-name{font-weight:900;color:var(--text)}
.user-quick-sub{margin-top:3px;color:var(--muted);font-size:12px}
.user-panel{display:none}
.user-panel.is-active{display:block}
.user-profile-grid{display:grid;grid-template-columns:240px 1fr;gap:14px;align-items:start}
.user-profile-avatar{
  width:90px;height:90px;border-radius:22px;overflow:hidden;border:1px solid var(--line);
  background:var(--soft);box-shadow:0 18px 36px rgba(0,0,0,.08)
}
.user-profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.user-profile-kvs{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.user-kv{border:1px solid var(--line);background:var(--card);border-radius:14px;padding:10px 10px}
.user-k{font-size:12px;color:var(--muted);font-weight:900}
.user-v{margin-top:4px;font-weight:800;overflow-wrap:anywhere}
.user-form-grid{display:flex;flex-direction:column;gap:10px}
.user-form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}
.user-textarea{resize:vertical;min-height:150px;padding:10px 12px;line-height:1.6}
.user-chips{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.user-chip{
  height:30px;padding:0 10px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);color:var(--muted);font-weight:900;font-size:12px;cursor:pointer;
  transition:transform .18s ease,border-color .18s ease,background .18s ease,color .18s ease
}
.user-chip:hover{color:var(--text);border-color:rgba(255,90,95,.26);transform:translateY(-1px)}
.user-chip:active{transform:translateY(0)}
.user-chip:focus{outline:0}
.user-chip:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.user-chip.is-active{color:var(--text);background:var(--soft);border-color:rgba(255,90,95,.22)}
.user-msg{display:flex;flex-direction:column;gap:12px}
.user-msg-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding:10px 10px;border-radius:16px;border:1px solid var(--line);
  background:rgba(255,255,255,.70);
  backdrop-filter:blur(10px)
}
html[data-theme="dark"] .user-msg-toolbar{background:rgba(0,0,0,.22)}
.user-msg-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.user-msg-actions .btn{height:32px;border-radius:12px}
.user-msg-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.user-msg-item{
  position:relative;
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px 14px;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.08);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(10px);
  box-shadow:0 12px 36px rgba(0,0,0,.06);
  transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease,background .18s ease
}
.user-msg-item:before{
  content:"";
  position:absolute;left:0;top:10px;bottom:10px;
  width:3px;border-radius:999px;
  background:rgba(107,114,128,.22)
}
.user-msg-item.is-unread:before{background:rgba(255,90,95,.86)}
html[data-theme="dark"] .user-msg-item{
  border-color:rgba(255,255,255,.10);
  background:rgba(0,0,0,.26);
  box-shadow:0 18px 50px rgba(0,0,0,.42)
}
.user-msg-item:hover{border-color:rgba(255,90,95,.22);box-shadow:0 18px 56px rgba(0,0,0,.10);transform:translateY(-1px)}
.user-msg-item:active{transform:translateY(0)}
.user-msg-dot{
  width:9px;height:9px;border-radius:999px;margin-top:6px;flex:none;
  background:rgba(107,114,128,.30)
}
.user-msg-item.is-unread .user-msg-dot{background:rgba(255,90,95,.92)}
.user-msg-main{min-width:0;flex:1}
.user-msg-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.user-msg-title{font-weight:900;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px}
.user-msg-time{color:var(--muted);font-size:12px;font-weight:800;white-space:nowrap}
.user-msg-desc{
  margin-top:6px;
  color:var(--muted);
  font-size:12px;
  line-height:1.6;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:2;
  overflow:hidden
}
.user-msg-meta{margin-top:8px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.user-tag{
  height:22px;padding:0 10px;border-radius:999px;border:1px solid rgba(17,24,39,.10);
  background:rgba(17,24,39,.04);
  display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;color:rgba(17,24,39,.78)
}
html[data-theme="dark"] .user-tag{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:rgba(255,255,255,.78)}
.user-link{
  border:0;
  background:transparent;
  color:var(--primary);
  font-weight:900;
  cursor:pointer;
  padding:0 2px;
  text-decoration:none
}
.user-link:hover{text-decoration:underline}
.user-empty{display:none !important}
.user-links-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.user-links-left,.user-links-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.user-links-grid .link-desc{word-break:break-all;overflow-wrap:anywhere}
.user-link-card{position:relative}
.user-bulk-check{display:none;position:absolute;left:12px;top:50%;transform:translateY(-50%);z-index:6;background:rgba(0,0,0,.35);backdrop-filter:blur(6px);padding:5px;border-radius:10px}
html[data-theme="dark"] .user-bulk-check{background:rgba(255,255,255,.10)}
.user-bulk-check input{width:16px;height:16px;margin:0}
[data-link-manager][data-bulk="1"] .user-bulk-check{display:inline-flex;align-items:center;justify-content:center}
[data-link-manager][data-bulk="1"] .user-links-grid .user-link-card{padding-left:46px}
.user-file{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}
.user-file-btn{position:relative;overflow:hidden}
[data-user-home] [data-avatar-upload].input{height:auto;padding:6px 12px;font-size:0;line-height:0;color:transparent}
[data-user-home] [data-avatar-upload].input::file-selector-button{
  width:100%;height:28px;margin:0;border:0;border-radius:10px;
  background:var(--soft);color:var(--text);font-weight:900;cursor:pointer;text-align:center;font-size:14px;line-height:28px;
  transition:transform .18s ease,background .18s ease,color .18s ease
}
[data-user-home] [data-avatar-upload].input:active::file-selector-button{transform:translateY(1px)}
[data-user-home] [data-avatar-upload].input::-webkit-file-upload-button{
  width:100%;height:28px;margin:0;border:0;border-radius:10px;
  background:var(--soft);color:var(--text);font-weight:900;cursor:pointer;text-align:center;font-size:14px;line-height:28px;
  transition:transform .18s ease,background .18s ease,color .18s ease
}
[data-user-home] [data-avatar-upload].input:active::-webkit-file-upload-button{transform:translateY(1px)}
.user-search{width:min(360px,72vw)}
.user-star{font-weight:900;color:#9ca3af}
.user-link-actions{gap:8px}
.user-favs-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.user-favs-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.user-view-toggle{
  height:34px;border-radius:12px;border:1px solid var(--line);background:var(--card);
  display:inline-flex;align-items:center;overflow:hidden
}
.user-view-btn{
  height:34px;padding:0 12px;border:0;background:transparent;color:var(--muted);
  font-weight:900;cursor:pointer;transition:background .18s ease,color .18s ease
}
.user-view-btn:hover{color:var(--text)}
.user-view-btn:focus{outline:0}
.user-view-btn:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.20) inset}
.user-view-btn.is-active{background:var(--soft);color:var(--text)}
.user-fav-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.user-fav-list.is-list{grid-template-columns:1fr}
.user-fav-item{
  display:flex;gap:10px;align-items:center;padding:12px 12px;border-radius:14px;
  border:1px solid var(--line);background:var(--card);text-decoration:none;color:inherit;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease
}
.user-fav-item:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.24);box-shadow:0 12px 26px rgba(0,0,0,.06)}
.user-fav-item:active{transform:translateY(0)}
.user-fav-ico{
  width:40px;height:40px;border-radius:14px;border:1px solid var(--line);background:var(--soft);
  display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--muted);flex:none
}
.user-fav-ico img{width:20px;height:20px;object-fit:contain;border-radius:8px;display:block}
.user-fav-main{min-width:0;flex:1}
.user-fav-name{font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-fav-url{margin-top:2px;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-fav-meta{margin-top:6px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.user-muted{color:var(--muted);font-size:12px;font-weight:800}
.user-security-split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.user-security-split.is-single{grid-template-columns:1fr}
.user-subtitle{font-weight:900;margin-bottom:6px}
.user-switch{
  display:flex;align-items:flex-start;gap:10px;padding:10px 10px;border-radius:14px;border:1px solid var(--line);background:var(--card);
  cursor:pointer;margin-top:10px
}
.user-switch input{position:absolute;opacity:0;pointer-events:none}
.user-switch-ui{
  width:44px;height:26px;border-radius:999px;border:1px solid var(--line);background:var(--soft);flex:none;
  position:relative;transition:background .18s ease,border-color .18s ease
}
.user-switch-ui:before{
  content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;border-radius:999px;
  background:var(--card);border:1px solid rgba(17,24,39,.10);transition:transform .18s ease
}
.user-switch input:checked + .user-switch-ui{background:rgba(255,90,95,.16);border-color:rgba(255,90,95,.30)}
.user-switch input:checked + .user-switch-ui:before{transform:translateX(18px)}
.user-switch-txt{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.user-switch-title{font-weight:900}
.user-switch-sub{color:var(--muted);font-size:12px;line-height:1.6}
.user-sec-sessions{margin-top:14px}
.user-sec-title{font-weight:900;margin-bottom:8px}
.user-sec-items{display:flex;flex-direction:column;gap:10px}
.user-sec-item{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:12px 12px;border-radius:14px;border:1px solid var(--line);background:var(--card)
}
.user-sec-item .btn{align-self:center}
.user-sec-ico{
  width:40px;height:40px;border-radius:14px;border:1px solid var(--line);
  background:var(--soft);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);
  flex:none
}
.user-sec-ico svg{display:block}
.user-sec-ico.is-mobile{
  background:linear-gradient(135deg,rgba(255,90,95,.12),rgba(124,77,255,.08));
  border-color:rgba(255,90,95,.20);
  color:rgba(255,90,95,.92)
}
.user-sec-ico.is-pc{
  background:linear-gradient(135deg,rgba(17,24,39,.06),rgba(124,77,255,.08));
  border-color:rgba(17,24,39,.10);
  color:rgba(17,24,39,.72)
}
html[data-theme="dark"] .user-sec-ico.is-pc{
  border-color:rgba(255,255,255,.14);
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(124,77,255,.10));
  color:rgba(255,255,255,.82)
}
.user-sec-env{margin-top:4px}
.user-sec-main{min-width:0;flex:1}
.user-sec-name{font-weight:900}
.user-sec-sub{margin-top:3px;color:var(--muted);font-size:12px}
.user-modal{position:fixed;inset:0;z-index:90;display:none;align-items:center;justify-content:center;padding:16px}
.user-modal.is-open{display:flex}
.user-modal-mask{position:absolute;inset:0;background:rgba(0,0,0,.42);backdrop-filter:blur(4px)}
.user-modal-panel{
  position:relative;z-index:1;width:min(760px,92vw);max-height:min(84vh,820px);
  border-radius:16px;border:1px solid var(--line);background:var(--card);box-shadow:0 24px 66px rgba(0,0,0,.22);
  overflow:hidden;opacity:0;transform:translate3d(0,8px,0) scale(.995);
  transition:opacity .18s ease,transform .18s ease
}
.user-modal.is-open .user-modal-panel{opacity:1;transform:translate3d(0,0,0) scale(1)}
.user-modal-hd{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line)}
.user-modal-title{font-weight:900}
.user-modal-close{
  width:34px;height:34px;border-radius:999px;border:1px solid var(--line);background:var(--soft);
  cursor:pointer;font-size:18px;line-height:1;color:var(--text)
}
.user-modal-close:hover{border-color:rgba(255,90,95,.26)}
.user-modal-close:focus{outline:0}
.user-modal-close:focus-visible{box-shadow:0 0 0 4px rgba(255,90,95,.20)}
.user-modal-bd{padding:12px 14px;overflow:auto;max-height:calc(min(84vh,820px) - 58px)}
@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))){
  .user-hero-card{background:rgba(17,24,39,.78);border-color:rgba(255,255,255,.18)}
  .user-modal-mask{backdrop-filter:none}
}
.fab{
  position:fixed;right:20px;bottom:20px;z-index:60;
  right:calc(20px + env(safe-area-inset-right));
  bottom:calc(20px + env(safe-area-inset-bottom));
  display:flex;flex-direction:column;gap:10px
}
.fab-btn{
  position:relative;
  width:40px;height:40px;border-radius:999px;
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--text);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,opacity .18s ease
}
.fab-ad-ico{
  width:20px;height:20px;
  object-fit:contain;
  display:block;
  border-radius:8px
}
.fab-ad-svg{
  width:20px;height:20px;
  display:flex;align-items:center;justify-content:center
}
.fab-ad-svg svg{
  width:20px;height:20px;
  display:block
}
.fab-btn:hover{transform:translateY(-1px);box-shadow:0 18px 44px rgba(0,0,0,.16);border-color:rgba(17,24,39,.12)}
html[data-theme="dark"] .fab-btn:hover{border-color:rgba(255,255,255,.14)}
.fab-btn:active{transform:translateY(0)}
.fab-btn:focus-visible{outline:0;box-shadow:0 0 0 4px rgba(255,90,95,.18),0 18px 44px rgba(0,0,0,.16)}
.fab-btn:before{
  content:attr(data-tip);
  position:absolute;right:calc(100% + 12px);top:50%;
  transform:translate(-6px,-50%);
  padding:7px 10px;border-radius:10px;
  background:var(--tip-bg);color:var(--tip-text);
  font-size:12px;font-weight:800;letter-spacing:.2px;
  white-space:nowrap;
  opacity:0;pointer-events:none;
  box-shadow:0 16px 40px rgba(0,0,0,.22);
  transition:opacity .14s ease,transform .14s ease
}
.fab-btn:after{
  content:"";
  position:absolute;right:calc(100% + 4px);top:50%;
  transform:translate(-6px,-50%);
  border:6px solid transparent;border-left-color:var(--tip-bg);
  opacity:0;pointer-events:none;
  transition:opacity .14s ease,transform .14s ease
}
.fab-btn:hover:before,.fab-btn:hover:after,.fab-btn:focus-visible:before,.fab-btn:focus-visible:after{opacity:1;transform:translate(0,-50%)}
.backtop-fab.is-hidden{opacity:0;transform:translateY(6px);pointer-events:none}
.theme-fab .theme-ico{display:block}
.theme-fab .i-sun{display:none}
html[data-theme="dark"] .theme-fab .i-moon{display:none}
html[data-theme="dark"] .theme-fab .i-sun{display:block}

@media (prefers-reduced-motion: no-preference){
  html.is-theme-anim *,html.is-theme-anim *:before,html.is-theme-anim *:after{
    transition:background-color .32s ease,color .32s ease,border-color .32s ease,box-shadow .32s ease,fill .32s ease,stroke .32s ease
  }
  html.is-nav-anim body{opacity:0;transition:opacity .18s ease}
  html.is-theme-anim body:before{
    content:"";
    position:fixed;inset:0;z-index:999;
    pointer-events:none;
    background:
      radial-gradient(720px 360px at 84% 86%,rgba(255,90,95,.18),rgba(255,90,95,0) 60%),
      radial-gradient(620px 320px at 86% 84%,rgba(124,77,255,.14),rgba(124,77,255,0) 58%);
    opacity:0;
    animation:theme-flash .46s ease both
  }
  .theme-fab.is-anim{animation:theme-btn .46s cubic-bezier(.2,.9,.2,1) both}
}
@keyframes theme-flash{
  0%{opacity:0}
  20%{opacity:1}
  100%{opacity:0}
}
@keyframes theme-btn{
  0%{transform:translateY(0) scale(1)}
  45%{transform:translateY(-2px) scale(1.06)}
  100%{transform:translateY(0) scale(1)}
}
.admin-user-edit{display:flex;flex-direction:column;gap:14px}
.aue-summary{padding:2px 2px 0 2px}
.aue-summary-left{display:flex;align-items:center;gap:12px;min-width:0}
.aue-avatar{
  width:46px;height:46px;border-radius:14px;border:1px solid var(--line);background:var(--soft);
  overflow:hidden;flex:none;box-shadow:0 16px 36px rgba(0,0,0,.10)
}
.aue-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.aue-summary-main{min-width:0;flex:1}
.aue-name-row{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}
.aue-name{font-weight:900;letter-spacing:.2px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aue-id{font-size:12px;font-weight:900;letter-spacing:.2px}
.aue-flags{margin-top:6px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.aue-dot{opacity:.55}
.aue-pill{
  height:20px;padding:0 8px;border-radius:999px;
  border:1px solid rgba(255,90,95,.24);
  background:rgba(255,90,95,.10);
  color:var(--text);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;letter-spacing:.2px
}
.aue-pill.is-off{border-color:rgba(107,114,128,.30);background:rgba(107,114,128,.12)}
.aue-sub{margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aue-meta{margin-top:8px}
.aue-panel{border:1px solid var(--line);border-radius:14px;background:var(--card);box-shadow:var(--shadow);overflow:hidden}
.aue-panel-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--line)}
.aue-panel-title{font-weight:900}
.aue-panel-tag{font-size:12px;font-weight:900;letter-spacing:.2px}
.aue-panel-bd{padding:10px 12px}
.aue-rows{display:flex;flex-direction:column;gap:10px}
.aue-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:center}
.aue-label{font-size:12px;font-weight:900;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aue-field{min-width:0}
.aue-ro{background:var(--soft)}
.aue-textarea{min-height:110px;padding:10px 12px;resize:vertical;line-height:1.6}
.aue-avatar-row{display:flex;gap:10px;align-items:center}
.aue-avatar-sm{
  width:34px;height:34px;border-radius:12px;border:1px solid var(--line);background:var(--soft);
  overflow:hidden;flex:none
}
.aue-avatar-sm img{width:100%;height:100%;object-fit:cover;display:block}
.aue-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:12px}
.admin-user-list{margin-top:0}
.admin-user-row{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 12px;border-radius:14px;
  border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease
}
.admin-user-row:hover{transform:translateY(-1px);border-color:rgba(255,90,95,.26);box-shadow:0 16px 40px rgba(0,0,0,.10)}
.admin-user-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.admin-user-ava{
  width:44px;height:44px;border-radius:14px;border:1px solid var(--line);background:var(--soft);
  overflow:hidden;flex:none
}
.admin-user-ava img{width:100%;height:100%;object-fit:cover;display:block}
.admin-user-main{min-width:0;flex:1}
.admin-user-top{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}
.admin-user-name{font-weight:900;letter-spacing:.2px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:44ch}
.admin-user-id{font-size:12px;font-weight:900;letter-spacing:.2px}
.admin-user-flags{margin-top:5px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.admin-user-pill{
  height:20px;padding:0 8px;border-radius:999px;
  border:1px solid rgba(255,90,95,.24);
  background:rgba(255,90,95,.10);
  color:var(--text);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;letter-spacing:.2px
}
.admin-user-pill.is-off{border-color:rgba(107,114,128,.30);background:rgba(107,114,128,.12)}
.admin-user-sub{margin-top:3px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.admin-user-k{font-size:12px;font-weight:900;color:var(--muted)}
.admin-user-v{font-size:12px;font-weight:800;color:var(--text);min-width:0}
.admin-user-dot{opacity:.55}
.admin-user-email{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52ch}
.admin-user-nick{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52ch}
.admin-user-desc{
  margin-top:6px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  max-width:92ch;
  line-height:1.55
}
.admin-user-right{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;flex:none}
.admin-user-kvs{min-width:0}
.admin-user-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:clamp(220px,24vw,360px)}
.admin-user-meta-item{
  border:1px solid var(--line);
  background:var(--soft);
  border-radius:12px;
  padding:8px 10px;
  min-width:0
}
.admin-user-meta-k{display:block;font-size:11px;font-weight:900;color:var(--muted);letter-spacing:.2px}
.admin-user-meta-v{display:block;margin-top:2px;font-size:12px;font-weight:900;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-user-actions{display:flex;gap:8px;align-items:center;flex:none}
@media (hover:none){
  .theme-fab:before,.theme-fab:after{display:none}
}
@media (max-width:980px){
  .aue-row{grid-template-columns:1fr}
  .aue-label{white-space:normal}
  .admin-user-row{flex-direction:column;align-items:stretch}
  .admin-user-right{width:100%;grid-template-columns:1fr;gap:10px}
  .admin-user-actions{justify-content:flex-end}
  .admin-user-meta{width:100%}
  .card-hd-actions{flex-direction:column;align-items:flex-start}
  .card-hd-actions .card-actions{width:100%;justify-content:flex-start}
  .links:not(.user-links-grid){grid-template-columns:1fr}
  .links.cols-3{grid-template-columns:1fr}
  .col-8,.col-4{grid-column:span 12}
  .col-3{grid-column:span 6}
  .user-hero-card{flex-direction:column;align-items:flex-start}
  .user-hero-actions{width:100%}
  .user-hero-actions .btn{flex:1}
  .user-hero-actions .user-home-back{display:inline-flex;flex:none;width:44px;padding:0}
  .user-shell{margin-top:-10px}
  .user-nav{flex-direction:row;gap:10px;overflow:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:2px}
  .user-nav::-webkit-scrollbar{width:0;height:0}
  .user-nav-item{flex:none;white-space:nowrap}
  .user-nav-foot{display:none}
  .user-profile-grid{grid-template-columns:1fr}
  .user-fav-list{grid-template-columns:1fr}
  .user-security-split{grid-template-columns:1fr}
  .overview-traffic{grid-template-columns:1fr}
  .overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .smtp-panels{grid-template-columns:1fr}
  .qr-admin-grid{grid-template-columns:1fr}
  .sidebar{display:none}
  [data-app="front"] .sidebar{
    display:flex;
    position:fixed;
    left:0;
    top:0;
    height:100vh;
    z-index:60;
    transform:translate3d(-105%,0,0);
    transition:transform .22s cubic-bezier(.2,.8,.2,1);
    box-shadow:0 22px 70px rgba(0,0,0,.42)
  }
  [data-app="front"].sidebar-open .sidebar{transform:translate3d(0,0,0)}
  [data-app="front"].sidebar-collapsed .sidebar{width:240px}
  .container{padding:14px}
  .hero-wrap{padding:14px}
  .auth-card{grid-template-columns:1fr}
  .auth-right{border-left:0}
  body.is-auth .auth-wrap{gap:12px}
  body.is-auth .auth[data-auth] .auth-panels{position:static;flex:none;min-height:auto}
  body.is-auth .auth[data-auth] .auth-panel{
    position:static;
    inset:auto;
    opacity:1;
    transform:none;
    pointer-events:auto;
    overflow:visible;
    padding-bottom:0;
    display:none
  }
  body.is-auth .auth[data-auth][data-auth-mode="login"] [data-auth-panel="login"],
  body.is-auth .auth[data-auth][data-auth-mode="register"] [data-auth-panel="register"],
  body.is-auth .auth[data-auth][data-auth-mode="forgot"] [data-auth-panel="forgot"],
  body.is-auth .auth[data-auth][data-auth-mode="reset"] [data-auth-panel="reset"]{display:block}
  body.is-auth .auth-card{height:auto;max-height:none}
  body.is-auth .auth-left{padding:18px}
  body.is-auth .auth-left-bottom{display:none}
  body.is-auth .auth-left-panel{display:none}
  body.is-auth .auth-mini-grid{grid-template-columns:1fr}
  body.is-auth .auth-slogan-title{font-size:22px}
  body.is-auth .auth-right{padding:16px}
  .hot-grid{grid-template-columns:1fr}
  .fb-panel-split{grid-template-columns:1fr}
}
@media (max-width:1200px){
  .site-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
  .site-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (min-width:1400px){
  .site-grid{grid-template-columns:repeat(7,minmax(0,1fr))}
}
@media (min-width:1200px){
  .home-sections{padding:0 140px}
}
@media (max-width:1020px){
  .site-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .site-grid.cols-4{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:860px){
  .site-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:520px){
  .container{padding:12px}
  .site-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .site-grid{gap:10px}
  .site-card{height:58px;padding:0 10px;gap:8px}
  .site-ico{width:28px;height:28px}
  .site-name{font-size:12px}
  .site-desc{font-size:11px}
  .site-go{width:18px;height:18px}
  .user-links-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .user-links-grid .link{padding:8px 8px;gap:8px}
  .user-links-grid .link-logo{width:32px;height:32px;border-radius:10px}
  .user-links-grid .link-name{font-size:12px}
  .user-links-grid .link-desc{font-size:11px;-webkit-line-clamp:1}
  .user-links-grid .user-link-actions{flex-wrap:wrap}
  .overview-grid{grid-template-columns:1fr}
  .dashboard-grid{grid-template-columns:1fr}
  .is-home .home-sections,
  .is-hero .home-sections{margin-top:14px}
  .home-mod-hd-top{flex-wrap:wrap}
  .home-mod-more{margin-left:0}
  .home-mod-actions{margin-left:0}
  .topbar{padding:0 12px;gap:10px}
  [data-app="front"] .top-quote{display:none}
  .hero.hero-ice .hero-inner{min-height:320px;padding:54px 0 120px}
  .hero-row{gap:10px}
  .enginebar{gap:10px}
  .card-hd{flex-wrap:wrap}
  ul.pagination{flex-wrap:wrap;gap:6px}
  ul.pagination>li>a,ul.pagination>li>span{min-width:32px;height:32px;padding:0 10px;border-radius:10px}
  .search-page-head{align-items:stretch}
  .search-page-title{width:100%;justify-content:space-between}
  .search-page-bar{max-width:100%}
  [data-app="front"] .input{font-size:16px}
  [data-app="front"] .search input{font-size:16px}
  .friend-search .input{max-width:none !important;width:100%}
  .form-actions{width:100%;justify-content:stretch !important}
  .form-actions .btn{flex:1;min-width:0}
  .post-hero-title{font-size:20px}
  .post-content{font-size:14px}
  .post-content table{display:block;max-width:100%;overflow:auto;-webkit-overflow-scrolling:touch}
  .col-3{grid-column:span 12}
  .col-6{grid-column:span 12}
  .user-hero{padding:14px 0 18px 0}
  .user-hero-avatar{width:64px;height:64px;border-radius:16px}
  .user-hero-name{font-size:16px}
  .user-links-left,.user-links-right,.user-favs-right{width:100%}
  .user-links-left .btn,.user-links-left .user-file-btn{flex:1;min-width:0}
  .user-search{width:100%}
  .user-link-actions{flex-wrap:wrap}
  .user-form-actions{width:100%}
  .user-form-actions .btn{flex:1;min-width:0}
  .user-modal{padding:12px}
  .user-modal-panel{width:96vw;max-height:88vh;border-radius:14px}
  .user-modal-bd{max-height:calc(88vh - 58px)}
  .user-quick-grid{grid-template-columns:1fr}
  .fb-filter-row2{grid-template-columns:1fr}
  .fb-bar-row{grid-template-columns:1fr 1fr 50px}
  .fb-panel-split{grid-template-columns:1fr}
  body.is-auth .auth-wrap{gap:12px}
  body.is-auth .auth[data-auth] .auth-panels{position:static;flex:none;min-height:auto}
  body.is-auth .auth[data-auth] .auth-panel{
    position:static;
    inset:auto;
    opacity:1;
    transform:none;
    pointer-events:auto;
    overflow:visible;
    padding-bottom:0;
    display:none
  }
  body.is-auth .auth[data-auth][data-auth-mode="login"] [data-auth-panel="login"],
  body.is-auth .auth[data-auth][data-auth-mode="register"] [data-auth-panel="register"],
  body.is-auth .auth[data-auth][data-auth-mode="forgot"] [data-auth-panel="forgot"],
  body.is-auth .auth[data-auth][data-auth-mode="reset"] [data-auth-panel="reset"]{display:block}
  body.is-auth .auth-card{height:auto;max-height:none}
  body.is-auth .auth-left{padding:18px}
  body.is-auth .auth-left-bottom{display:none}
  body.is-auth .auth-left-panel{display:none}
  body.is-auth .auth-mini-grid{grid-template-columns:1fr}
  body.is-auth .auth-slogan-title{font-size:22px}
  body.is-auth .auth-right{padding:16px}
  .auth-foot{flex-direction:column;align-items:flex-start}
  .admin-user-meta{grid-template-columns:1fr}
}
@media (prefers-reduced-motion: reduce){
  .auth-panel,.auth-step-panel,.auth-tab,.auth-theme,.auth-link,.field-msg{transition:none}
}

/* Admin Glassmorphism */
.wrap[data-layout]:not([data-app="front"]) .sidebar{
  background:#2f3437!important;
  border-right:1px solid rgba(255,255,255,.08);
}
html[data-theme="dark"] .wrap[data-layout]:not([data-app="front"]) .sidebar{
  background:rgba(47,52,55,.72)!important;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-right:1px solid rgba(255,255,255,.06);
}

.wrap[data-layout]:not([data-app="front"]) .topbar{
  background:var(--bar-bg)!important;
}
html[data-theme="dark"] .wrap[data-layout]:not([data-app="front"]) .topbar{
  background:rgba(30,35,40,.7)!important;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.05);
}

body.is-auth{
  background:#f8fafc;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow-x:hidden
}
html[data-theme="dark"] body.is-auth{
  background:#0b1220
}

body.is-auth .auth-wrap{
  width:100%;
  padding:clamp(14px,3vh,34px) 18px;
  display:flex;
  align-items:center;
  justify-content:center
}

body.is-auth .auth-card{
  width:min(1024px,100%);
  height:clamp(520px,66vh,720px);
  max-height:calc(100vh - 24px);
  display:grid;
  grid-template-columns:1.55fr 3.45fr;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.78);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  box-shadow:0 26px 70px rgba(2,6,23,.16)
}
html[data-theme="dark"] body.is-auth .auth-card{
  border-color:rgba(255,255,255,.10);
  background:rgba(15,23,42,.62);
  box-shadow:0 34px 90px rgba(0,0,0,.55)
}

body.is-auth .auth-left{
  padding:0;
  color:#fff;
  position:relative;
  overflow:hidden;
  background:#0b1220
}
body.is-auth .auth-left:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:none;
  opacity:0;
  mix-blend-mode:normal;
  pointer-events:none
}
body.is-auth .auth-left:after{
  content:"";
  position:absolute;
  inset:-20%;
  background:none;
  opacity:0;
  filter:none;
  pointer-events:none
}

body.is-auth .auth-pattern{display:none}

body.is-auth .auth-left-inner{
  height:100%;
  padding:44px 44px 36px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:18px;
  position:relative;
  z-index:1
}
body.is-auth .auth-left-inner.glass-card{
  margin:0;
  height:100%;
  background:transparent;
  border:0;
  border-radius:0;
  padding:44px 44px 36px;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none
}

body.is-auth .auth-left-center{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:14px
}
body.is-auth .auth-left-glyph{
  width:120px;height:120px;
  display:flex;align-items:center;justify-content:center;
  border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10)
}
body.is-auth .auth-left-title{
  font-size:22px;
  font-weight:900;
  letter-spacing:.2px;
  color:#fff
}
body.is-auth .auth-left-sub{
  font-size:13px;
  color:rgba(255,255,255,.72);
  font-weight:700
}
body.is-auth .auth-left-mini{
  margin-top:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap
}
body.is-auth .auth-left-dot{
  width:6px;height:6px;border-radius:999px;
  background:rgba(255,255,255,.22)
}
body.is-auth .auth-left-chip{
  height:28px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.78);
  font-size:12px;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center
}

body.is-auth .auth-hint-dot{
  opacity:1;
  color:rgba(2,6,23,.42)
}
html[data-theme="dark"] body.is-auth .auth-hint-dot{
  color:rgba(255,255,255,.46)
}

body.is-auth .auth-left .auth-mark-title,
body.is-auth .auth-left .auth-slogan-title,
body.is-auth .auth-left .auth-slogan-sub{display:none}
body.is-auth .auth-left-bottom{
  opacity:.72
}

body.is-auth .auth-right {
  padding: 40px;
  position: relative;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-left: 1px solid rgba(255, 255, 255, 0.6);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 0;
}

html[data-theme="dark"] body.is-auth .auth-right {
  background: rgba(15, 23, 42, 0.6);
  border-left-color: rgba(255, 255, 255, 0.08);
}

body.is-auth .auth-card:not(.auth-admin-card) .auth-right{
  align-items:center;
  padding:44px 46px
}
body.is-auth .auth-user-center{
  width:min(460px,100%);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:16px;
  min-height:0;
  flex:1;
  margin:0 auto
}
body.is-auth .auth-card:not(.auth-admin-card) .auth-panels{
  width:100%;
  margin-top:0;
  flex:1;
  min-height:0
}
body.is-auth .auth-card:not(.auth-admin-card) .auth-panel-title{
  font-size:28px;
  font-weight:900;
  letter-spacing:-.6px;
  text-align:center
}
body.is-auth .auth-card:not(.auth-admin-card) .auth-copyright{
  text-align:center
}

body.is-auth .auth-admin-card .auth-right{
  align-items:center;
  padding:44px 46px
}
body.is-auth .auth-admin-center{
  width:min(420px,100%);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:14px
}
body.is-auth .auth-admin-card .auth-admin-head{
  text-align:center
}
body.is-auth .auth-admin-card .auth-panel-title{
  font-size:28px;
  font-weight:900;
  letter-spacing:-.6px
}
body.is-auth .auth-admin-card .auth-panel-sub{
  margin-top:8px;
  font-size:13px;
  color:var(--muted);
  opacity:.86
}
body.is-auth .auth-admin-card .section{
  margin-top:0;
  width:100%;
  max-width:none
}
body.is-auth .auth-admin-card .auth-links{
  justify-content:center
}
body.is-auth .auth-admin-card .auth-link{
  color:var(--muted);
  font-weight:800
}
body.is-auth .auth-admin-card .auth-copyright{
  position:static;
  margin-top:12px;
  padding-top:0
}

body.is-auth .auth-right-top {
  position: absolute;
  top: 20px;
  right: 20px;
  display: flex;
  gap: 12px;
  z-index: 10;
}

body.is-auth .auth-home,
body.is-auth .auth-theme {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted);
  transition: all 0.2s cubic-bezier(0.2, 0.8, 0.2, 1);
  cursor: pointer;
}

body.is-auth .auth-home:hover,
body.is-auth .auth-theme:hover {
  background: var(--soft);
  color: var(--text);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

html[data-theme="dark"] body.is-auth .auth-home:hover,
html[data-theme="dark"] body.is-auth .auth-theme:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

body.is-auth .auth-panel-title {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -1px;
  background: linear-gradient(135deg, var(--text) 0%, var(--muted) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 4px;
  line-height: 1.2;
}

html[data-theme="dark"] body.is-auth .auth-panel-title {
  background: linear-gradient(135deg, #fff 0%, #94a3b8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

body.is-auth .auth-panel-sub {
  font-size: 15px;
  color: var(--muted);
  margin-bottom: 16px;
  line-height: 1.6;
}

body.is-auth .field {
  margin-bottom: 10px;
}

body.is-auth .auth-form-label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

body.is-auth .auth-input {
  position: relative;
}

body.is-auth .auth-input-ico {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  transition: all 0.2s;
  pointer-events: none;
  z-index: 2;
}

body.is-auth .auth-input:focus-within .auth-input-ico {
  color: var(--primary);
  transform: translateY(-50%) scale(1.1);
}

body.is-auth .auth .input {
  height: 42px;
  padding: 0 18px 0 50px;
  border-radius: 12px;
  background: var(--soft);
  border: 1px solid transparent;
  color: var(--text);
  font-size: 15px;
  font-weight: 500;
  width: 100%;
  transition: all 0.2s cubic-bezier(0.2, 0.8, 0.2, 1);
}

html[data-theme="dark"] body.is-auth .auth .input {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.05);
}

body.is-auth .auth .input:hover {
  background: rgba(0, 0, 0, 0.04);
}

html[data-theme="dark"] body.is-auth .auth .input:hover {
  background: rgba(255, 255, 255, 0.08);
}

body.is-auth .auth .input:focus {
  background: var(--card);
  border-color: var(--primary);
  box-shadow: 0 4px 20px rgba(99, 102, 241, 0.15);
  transform: translateY(-1px);
}

html[data-theme="dark"] body.is-auth .auth .input:focus {
  background: rgba(15, 23, 42, 0.8);
  box-shadow: 0 4px 20px rgba(99, 102, 241, 0.25);
}

body.is-auth .field-msg {
  min-height: 16px;
  font-size: 12px;
  font-weight: 600;
  color: #ef4444;
  margin-top: 2px;
  opacity: 0;
  transform: translateY(-5px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  gap: 6px;
}

body.is-auth .field-msg:not(:empty) {
  opacity: 1;
  transform: translateY(0);
}

body.is-auth .field-msg:not(:empty)::before {
  content: "!";
  display: flex;
  width: 16px;
  height: 16px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #ef4444;
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  flex-shrink: 0;
}

body.is-auth .auth-checks {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

body.is-auth .auth-checks .field {
  margin-bottom: 0;
}

body.is-auth .auth-check {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
  font-size: 13px;
  color: var(--muted);
}

body.is-auth .auth-check input[type="checkbox"] {
  appearance: none;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--line);
  border-radius: 5px;
  background: var(--soft);
  cursor: pointer;
  position: relative;
  transition: all 0.2s;
  flex-shrink: 0;
}

body.is-auth .auth-check input[type="checkbox"]:checked {
  background: var(--primary);
  border-color: var(--primary);
}

body.is-auth .auth-check input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

body.is-auth .auth-check a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s;
}

body.is-auth .auth-check a:hover {
  color: var(--primary2);
  text-decoration: underline;
}

body.is-auth .auth-submit {
  height: 42px;
  border-radius: 12px;
  background: #0f172a;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.15);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.5px;
  margin-top: 16px;
  color: #fff;
  border: none;
  cursor: pointer;
  transition: all 0.2s;
  width: 100%;
}

body.is-auth .auth-submit:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -6px rgba(15, 23, 42, 0.3);
  filter: brightness(1.1);
}

html[data-theme="dark"] body.is-auth .auth-submit {
  background: #3b82f6;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.25);
}

html[data-theme="dark"] body.is-auth .auth-submit:hover {
  background: #2563eb;
  box-shadow: 0 8px 20px -6px rgba(37, 99, 235, 0.4);
}

body.is-auth .auth-submit:active {
  transform: translateY(0);
}

body.is-auth .auth-hint {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 14px;
  color: var(--muted);
}

body.is-auth .auth-hint-link {
  background: transparent;
  border: none;
  padding: 0;
  font-size: 14px;
  font-weight: 700;
  color: var(--primary);
  cursor: pointer;
  transition: color 0.2s;
}

body.is-auth .auth-hint-link:hover {
  color: var(--primary2);
  text-decoration: underline;
}

body.is-auth .auth-copyright {
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  opacity: 0.7;
  padding-top: 16px;
  margin-top: auto;
}

@media (max-width: 860px) {
  body.is-auth .auth-card {
    height: auto;
    max-height: none;
    grid-template-columns: 1fr;
    max-width: 460px;
    margin: 20px;
  }
  body.is-auth .auth-left {
    display: none;
  }
  body.is-auth .auth-right {
    border-left: 0;
    padding: 40px 32px;
    border-radius: 24px;
    background: var(--card);
  }
  body.is-auth .auth-right-top {
    top: 20px;
    right: 20px;
  }
  body.is-auth .auth-panel{padding-bottom:72px}
  body.is-auth .auth-hint{position:relative;z-index:2}
  body.is-auth .auth-copyright{justify-content:center;padding-top:10px;margin-top:12px;pointer-events:none}
}

/* Admin Card Glassmorphism */
.admin-container .card {
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 20px 40px -6px rgba(0, 0, 0, 0.08);
}

html[data-theme="dark"] .admin-container .card {
  background: rgba(42, 47, 51, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

/* Auth Links (Admin Login) */
body.is-auth .auth-links {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  gap: 16px;
}

body.is-auth .auth-link {
  color: var(--muted);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
  opacity: 0.8;
}

body.is-auth .auth-link:hover {
  color: var(--primary);
  opacity: 1;
  text-decoration: underline;
  text-underline-offset: 4px;
}

/* Auth Strength (Register) */
body.is-auth .auth-strength {
  margin-top: 12px;
  margin-bottom: 4px;
}

body.is-auth .auth-strength-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

body.is-auth .auth-strength-label {
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
}

body.is-auth .auth-strength-bars {
  display: flex;
  gap: 4px;
  flex: 1;
  max-width: 140px;
}

body.is-auth .auth-strength-bar {
  flex: 1;
  height: 4px;
  border-radius: 2px;
  background: var(--line);
  transition: background 0.3s ease;
}

body.is-auth .auth-strength-tip {
  font-size: 12px;
  color: var(--muted);
  opacity: 0.7;
  line-height: 1.4;
  margin-top: 4px;
}

/* Auth Code Button (Register) */
body.is-auth .auth-code-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

body.is-auth .auth-code-row .auth-input {
  flex: 1;
  min-width: 0;
}

body.is-auth .auth-code-btn {
  height: 48px;
  padding: 0 20px;
  border-radius: 14px;
  background: var(--card);
  border: 1px solid var(--line);
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

body.is-auth .auth-code-btn:hover:not(:disabled) {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(99, 102, 241, 0.25);
}

body.is-auth .auth-code-btn:active:not(:disabled) {
  transform: translateY(0);
}

body.is-auth .auth-code-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background: var(--bg);
}

/* Auth Validation States */
body.is-auth .field.is-error .input {
  border-color: #ef4444;
  background: rgba(239, 68, 68, 0.05);
  box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.1);
}

body.is-auth .field.is-error .auth-input-ico {
  color: #ef4444;
}

body.is-auth .field.is-ok .input {
  border-color: #10b981;
  background: rgba(16, 185, 129, 0.05);
}

body.is-auth .field.is-ok .auth-input-ico {
  color: #10b981;
}

/* Fix register form spacing and layout */
body.is-auth [data-register] .field {
  margin-top: 0;
  margin-bottom: 0;
}
body.is-auth [data-register] .auth-form-label {
  margin-bottom: 2px;
}
body.is-auth [data-register] .auth-checks {
  margin-top: 4px;
}
body.is-auth [data-register] .auth-submit {
  margin-top: 6px;
  height: 38px;
}
body.is-auth [data-register] .auth-hint {
  margin-top: 6px;
  height: 32px;
  min-height: 32px;
}
body.is-auth [data-register] .auth-copyright {
  padding-top: 6px;
  margin-top: 0;
}

/* Compact password strength */
body.is-auth [data-register] .auth-strength {
  margin-top: 2px;
}
body.is-auth [data-register] .auth-strength-row {
  gap: 4px;
}
body.is-auth [data-register] .auth-strength-label {
  font-size: 11px;
}
body.is-auth [data-register] .auth-strength-tip {
  margin-top: 0;
  font-size: 11px;
  opacity: 0.7;
  line-height: 1.2;
}

/* Dark mode auth button color match */
html[data-theme="dark"] body.is-auth .btn.primary {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}
