﻿/* V6.4 separated theme system + dock drawers */
:root{--theme-color:#4f46e5;--theme-color-2:#06b6d4;--glass-blur:18px;--surface:rgba(255,255,255,.74);--surface-strong:rgba(255,255,255,.9);--surface-soft:rgba(248,250,252,.66);--text:#111827;--muted:#64748b;--line:rgba(226,232,240,.86);--shadow:0 16px 48px rgba(15,23,42,.08);--pill-bg:rgba(255,255,255,.48);--pill-text:#334155;--badge-bg:rgba(15,23,42,.08);--badge-text:#334155;--page-grad:radial-gradient(circle at 18% -10%,color-mix(in srgb,var(--theme-color-2,#06b6d4) 18%,transparent),transparent 34%),linear-gradient(180deg,#f8fafc,#eef2f7)}
*{-webkit-tap-highlight-color:transparent}.app-card,.dock-btn,.icon-btn,button,a{-webkit-tap-highlight-color:transparent;outline:none}
html[data-theme=dark]{--surface:rgba(31,41,55,.62);--surface-strong:rgba(31,41,55,.82);--surface-soft:rgba(15,23,42,.5);--text:#e5e7eb;--muted:#9ca3af;--line:rgba(148,163,184,.22);--shadow:0 18px 56px rgba(0,0,0,.28);--pill-bg:rgba(15,23,42,.44);--pill-text:#cbd5e1;--badge-bg:rgba(255,255,255,.09);--badge-text:#e5e7eb;--page-grad:radial-gradient(circle at 18% -10%,color-mix(in srgb,var(--theme-color-2,#06b6d4) 22%,transparent),transparent 36%),linear-gradient(180deg,#111827,#0f172a)}
body,.store-page{color:var(--text)}.store-page{background-image:var(--page-grad),var(--site-bg)!important}.topbar{background:var(--surface)!important;border-bottom:1px solid var(--line);backdrop-filter:blur(var(--glass-blur,18px));box-shadow:var(--shadow)}.store-header,.hero-copy,.app-card,.player-panel,.audio-drawer,.detail-panel,.site-notice,.view-state span,.card,.metric-card,.dash-panel,.category-admin-card,.admin-modal-panel,.admin-preview-panel,.login-card{background:var(--surface)!important;border-color:var(--line)!important;color:var(--text)!important;box-shadow:var(--shadow)!important;backdrop-filter:blur(var(--glass-blur,18px))}.store-search,.store-search input,.input,select,textarea{background:var(--surface-soft)!important;border-color:var(--line)!important;color:var(--text)!important}.store-search input::placeholder,.input::placeholder,textarea::placeholder{color:var(--muted)}.muted,.app-subtitle,.app-mobile-line,.section-head p,.store-footer,.metric-card span,.dash-row span,.dash-row small,.status-item span,.media-controls span,.audio-mini span,.front-status{color:var(--muted)!important}.app-meta span,.badge{background:var(--badge-bg)!important;color:var(--badge-text)!important}.download-btn,.detail-primary,.store-search button,.cat-pill.active,.theme-toggle,.media-controls button,.video-controls button{background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important;color:#fff!important}.play-btn{background:linear-gradient(135deg,var(--theme-color-2,var(--theme-color)),var(--theme-color))!important;color:#fff!important}.brand-mark,.mini-cover{background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important}.trend-bars,.file-card,.mini-card,.category-preview,.detail-preview,.detail-fields div{background:var(--surface-soft)!important;border-color:var(--line)!important;color:var(--text)!important}.status-item,.dash-row,.file-card-actions{border-color:var(--line)!important}.player-mask,.detail-mask,.admin-modal-mask,.admin-preview-mask{background:rgba(2,6,23,.58)!important}
.cat-pill{flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;min-width:max-content;background:var(--pill-bg)!important;color:var(--pill-text)!important;border:1px solid color-mix(in srgb,var(--cat-color,var(--theme-color)) 22%,var(--line))!important;box-shadow:none!important;backdrop-filter:blur(var(--glass-blur,18px))}.cat-pill>span{display:inline-flex;align-items:center;gap:8px;line-height:1}.cat-pill.active{border-color:transparent!important;box-shadow:0 12px 28px color-mix(in srgb,var(--theme-color) 28%,transparent)!important}.cat-pill b{background:color-mix(in srgb,var(--cat-color,var(--theme-color)) 18%,var(--badge-bg))!important;color:var(--badge-text)!important}.cat-pill.active b{background:rgba(255,255,255,.22)!important;color:#fff!important}.cat-icon{width:22px;height:22px;flex:0 0 22px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;border-radius:6px;background:rgba(255,255,255,.08)}.cat-icon img{width:100%;height:100%;object-fit:contain}.cat-icon .cat-icon-fallback{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;font-style:normal;font-size:12px;font-weight:950;line-height:1}.theme-toggle{border:0;box-shadow:0 8px 22px color-mix(in srgb,var(--theme-color) 18%,transparent)!important}.admin-theme-toggle{order:2}.nav .menu{order:3}
.card-cat-icon{width:18px!important;height:18px!important;flex:0 0 18px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;border-radius:5px;padding:0!important;background:rgba(255,255,255,.08)!important}.card-cat-icon img{width:100%;height:100%;object-fit:contain}.card-cat-icon .cat-icon-fallback{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;font-style:normal;font-size:10px;font-weight:950;line-height:1}.app-card{cursor:pointer;transition:transform .16s ease,background .16s ease,box-shadow .18s ease}.app-card:active{transform:scale(.985);background:rgba(255,255,255,.06)!important}.app-card:focus-visible{outline:3px solid color-mix(in srgb,var(--theme-color) 46%,transparent);outline-offset:3px}.app-card.is-focused{outline:3px solid color-mix(in srgb,var(--theme-color) 46%,transparent);outline-offset:3px}.card-actions{display:none!important}.app-mobile-line{display:none}
@media(max-width:620px){.cat-pill{padding:11px 13px}.admin-theme-toggle{position:absolute;right:14px;top:14px}.nav{position:relative}}

.app-shell{width:100%;box-sizing:border-box}.app-shell .store-header{width:100%;box-sizing:border-box;border-radius:24px;margin-left:0;margin-right:0}
.brand-mark{width:60px!important;height:60px!important;padding:4px!important;border-radius:16px!important;background:rgba(255,255,255,.06)!important;box-shadow:none!important;color:var(--text)!important;overflow:hidden;box-sizing:border-box}.brand-mark img{width:100%;height:100%;object-fit:contain;display:block}
@media(max-width:860px){.app-shell{padding:calc(env(safe-area-inset-top) + 12px) 16px 0}.app-shell .store-header{width:100%;box-sizing:border-box;border-radius:24px;margin:0 0 12px}.app-shell .store-header.search-hidden{transform:translateY(calc(-100% - 12px))}}

@media(max-width:700px){html,body{touch-action:manipulation;overscroll-behavior-y:contain}.app-grid{gap:8px}.app-card,.store-app-card,.card-style-compact .app-card,.card-style-gallery .app-card{min-height:0;height:auto;max-height:80px;grid-template-columns:44px minmax(0,1fr)!important;gap:8px;padding:8px 9px!important;border-radius:16px!important;align-items:center;text-align:left;overflow:hidden}.app-icon-wrap,.app-icon,.store-app-card .app-icon-wrap,.store-app-card .app-icon,.card-style-compact .app-icon-wrap,.card-style-compact .app-icon{width:44px!important;height:44px!important;border-radius:13px!important}.app-title{font-size:14px!important;line-height:1.18;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-subtitle{display:none!important}.app-meta{display:none!important}.app-mobile-line{display:flex;align-items:center;gap:5px;min-width:0;margin-top:5px;font-size:12px!important;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-mobile-line span{min-width:0;overflow:hidden;text-overflow:ellipsis}.app-mobile-line span+span:before{content:"路";margin-right:5px;color:var(--muted)}.app-mobile-line .card-cat-icon+span:before{content:none;margin:0}.app-mobile-line .card-cat-icon{width:15px!important;height:15px!important;flex-basis:15px!important;border-radius:4px}.card-style-gallery .app-card{display:grid!important}}
@media(max-width:700px){.resource-detail{align-items:flex-end;padding:0 12px env(safe-area-inset-bottom)}.detail-panel{width:100%;max-height:min(86vh,var(--vvh,86vh));border-radius:24px 24px 0 0}.detail-head{padding:16px 16px 12px}.detail-head b{font-size:18px}.detail-head span{font-size:12px}.detail-body{padding:14px 14px 104px}.detail-desc{padding:14px;max-height:190px}.detail-preview{min-height:170px;border-radius:16px}.detail-fields{grid-template-columns:1fr 1fr}.detail-actions{display:flex;justify-content:space-between;gap:8px;padding:12px 14px calc(12px + env(safe-area-inset-bottom))}.detail-actions button,.detail-actions a{min-width:0;min-height:44px;padding:0 14px;font-size:13px}.detail-actions .detail-primary{min-width:120px}.rich-content{font-size:13px}.detail-music-card.music-card{padding:14px 10px}.detail-music-card .cover-ring{width:118px;height:118px;border-radius:30px}}

.mobile-dock{position:fixed;left:16px;right:16px;bottom:calc(14px + env(safe-area-inset-bottom));z-index:190;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:8px;border-radius:28px;background:var(--surface);border:1px solid var(--line);box-shadow:0 18px 54px rgba(2,6,23,.2);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.mobile-dock button{position:relative;height:44px;border:0;border-radius:22px;background:var(--surface-soft);color:var(--text);font-weight:950;display:grid;place-items:center}.mobile-dock svg,.dock-btn svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.mobile-dock button.active{background:color-mix(in srgb,var(--theme-color) 16%,transparent);color:var(--theme-color)}.mobile-dock button:active{transform:scale(.98)}.dock-badge{position:absolute;right:4px;top:3px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;line-height:18px;box-shadow:0 0 0 2px var(--surface)}.bottom-sheet{position:fixed;inset:0;z-index:240}.bottom-sheet[hidden]{display:none}.sheet-mask{position:absolute;inset:0;background:rgba(2,6,23,.42);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.sheet-panel{position:absolute;left:16px;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));max-height:min(70vh,560px);overflow:auto;border-radius:28px;background:var(--surface);border:1px solid var(--line);box-shadow:0 28px 90px rgba(2,6,23,.28);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:16px}.sheet-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.sheet-head b{font-size:18px}.sheet-head button{width:40px;height:40px;border:0;border-radius:999px;background:var(--surface-soft);color:var(--text);font-size:20px;font-weight:950}.sheet-pills{display:flex;flex-wrap:wrap;gap:8px}.sheet-pills .cat-pill{appearance:none}.theme-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.theme-options button{height:46px;border:1px solid var(--line);border-radius:22px;background:var(--surface-soft);color:var(--text);font-weight:950}.theme-options button.active{border-color:transparent;background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)));color:#fff;box-shadow:0 12px 28px color-mix(in srgb,var(--theme-color) 24%,transparent)}.theme-options button:active{transform:scale(.98)}.notice-list{display:grid;gap:8px}.notice-item{width:100%;display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;text-align:left;border:1px solid var(--line);border-radius:16px;background:var(--surface-soft);color:var(--text);padding:10px}.notice-item i{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.08);font-style:normal;font-weight:950}.notice-item b,.notice-item small{display:block}.notice-item small,.notice-item em{color:var(--muted);font-style:normal;font-size:12px}.notice-item.unread{border-color:color-mix(in srgb,var(--theme-color) 42%,var(--line))}.sheet-open{overflow:hidden}.store-page .app-shell{padding-bottom:calc(112px + env(safe-area-inset-bottom))}
.resource-detail{position:fixed;inset:0;z-index:230;display:flex;align-items:center;justify-content:center;padding:18px}.resource-detail[hidden]{display:none}.detail-mask{position:absolute;inset:0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.detail-panel{position:relative;width:min(720px,100%);max-height:82vh;display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;border:1px solid var(--line);border-radius:26px}.detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 20px 14px;border-bottom:1px solid var(--line)}.detail-head span{display:block;color:var(--muted);font-size:13px;font-weight:850;margin-top:5px}.detail-head b{display:block;max-width:590px;font-size:20px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-head button{width:40px;height:40px;border:0;border-radius:999px;background:var(--surface-soft);color:var(--text);font-size:22px;font-weight:950}.detail-body{overflow:auto;padding:16px 20px 104px;display:grid;gap:14px}.detail-desc{background:var(--surface-soft);border:1px solid var(--line);border-radius:16px;padding:16px;max-height:220px;overflow:auto}.detail-preview[hidden]{display:none}.detail-preview{min-height:220px;border:1px solid var(--line);border-radius:18px;display:grid;place-items:center;overflow:hidden}.detail-image{width:100%;max-height:48vh;object-fit:contain}.detail-frame{width:100%;height:min(52vh,520px);border:0;background:#fff}.detail-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-fields div{border:1px solid var(--line);border-radius:14px;padding:10px 12px;min-width:0}.detail-fields span{display:block;color:var(--muted);font-size:11px;font-weight:900}.detail-fields b{display:block;margin-top:3px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rich-content{font-size:14px;line-height:1.6;color:var(--text)}.rich-content p{margin:0 0 10px}.rich-content p:last-child{margin-bottom:0}.rich-content ul,.rich-content ol{margin:0 0 10px;padding-left:22px}.rich-content a{color:var(--theme-color);font-weight:900}.rich-content img{max-width:100%;height:auto;border-radius:14px}.rich-content code{background:var(--badge-bg);border-radius:6px;padding:2px 5px}.rich-content pre{max-width:100%;overflow:auto;background:rgba(2,6,23,.88);color:#e5e7eb;border-radius:14px;padding:12px}.detail-actions{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-between;gap:10px;padding:14px 20px calc(14px + env(safe-area-inset-bottom));background:linear-gradient(180deg,transparent,var(--surface) 22%);border-top:1px solid var(--line)}.detail-actions button,.detail-actions a{min-height:44px;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--text);padding:0 20px;font-weight:950;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.detail-actions .detail-primary{border-color:transparent;min-width:128px}.detail-music-card{width:100%;box-sizing:border-box}.detail-music-card .music-head{grid-template-columns:1fr auto 44px}.detail-video{width:100%;padding:0}.detail-video .media-player{border-radius:18px}
.video-controls button{width:40px;height:40px;border-radius:50%;border:1px solid rgba(15,23,42,.08)!important;background:rgba(15,23,42,.08)!important;color:var(--text)!important;display:inline-flex;align-items:center;justify-content:center;padding:0}.video-controls button:hover,.video-controls button:active{background:rgba(15,23,42,.14)!important}.video-controls [data-media-toggle]{background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important;color:#fff!important;border-color:transparent!important}.video-controls button svg{width:20px;height:20px;display:block;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.video-controls svg .play-fill{fill:currentColor!important;stroke:none!important}html[data-theme=dark] .video-controls button{background:rgba(255,255,255,.10)!important;color:#fff!important;border-color:rgba(255,255,255,.14)!important}html[data-theme=dark] .video-controls button:hover,html[data-theme=dark] .video-controls button:active{background:rgba(255,255,255,.16)!important}html[data-theme=dark] .video-controls [data-media-toggle]{background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important;color:#fff!important;border-color:transparent!important}
.player-close{display:grid!important;place-items:center!important;background:rgba(15,23,42,.08)!important;color:var(--text)!important;border:1px solid rgba(15,23,42,.08)!important}.player-close:hover,.player-close:active{background:rgba(15,23,42,.14)!important}.player-close svg{width:20px;height:20px;display:block;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}html[data-theme=dark] .player-close{background:rgba(255,255,255,.08)!important;color:#fff!important;border-color:rgba(255,255,255,.12)!important}html[data-theme=dark] .player-close:hover,html[data-theme=dark] .player-close:active{background:rgba(255,255,255,.16)!important}
@media(max-width:700px){.resource-detail{align-items:flex-end;padding:0 12px calc(12px + env(safe-area-inset-bottom))}.detail-panel{width:100%;max-height:min(84vh,var(--vvh,84vh));border-radius:26px}.detail-head{padding:16px 16px 10px}.detail-head b{font-size:18px}.detail-body{padding:14px 14px 104px}.detail-preview{min-height:136px;border-radius:20px}.detail-cover{width:86px;height:86px;border-radius:22px}.detail-fields{grid-template-columns:1fr 1fr}.detail-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:12px 14px calc(12px + env(safe-area-inset-bottom))}.detail-actions button,.detail-actions a{min-width:0;min-height:44px;padding:0 10px;font-size:13px}.detail-actions .detail-primary{min-width:0}.rich-content{font-size:13px}.detail-music-card.music-card{padding:14px 10px}.detail-music-card .cover-ring{width:118px;height:118px;border-radius:30px}}
@media(max-width:700px){.resource-detail{align-items:flex-end;padding:0 12px env(safe-area-inset-bottom)}.detail-panel{width:100%;max-height:min(86vh,var(--vvh,86vh));border-radius:24px 24px 0 0}.detail-head{padding:16px 16px 12px}.detail-head b{font-size:18px}.detail-head span{font-size:12px}.detail-body{padding:14px 14px 104px}.detail-desc{padding:14px;max-height:190px}.detail-preview[hidden]{display:none}.detail-preview{min-height:170px;border-radius:16px}.detail-fields{grid-template-columns:1fr 1fr}.detail-actions{display:flex;justify-content:space-between;gap:8px;padding:12px 14px calc(12px + env(safe-area-inset-bottom))}.detail-actions button,.detail-actions a{min-width:0;min-height:44px;padding:0 14px;font-size:13px}.detail-actions .detail-primary{min-width:120px}.rich-content{font-size:13px}}
@media(min-width:760px){.mobile-dock{left:50%;right:auto;width:420px;max-width:460px;transform:translateX(-50%)}.sheet-panel{left:50%;right:auto;width:min(520px,calc(100vw - 32px));transform:translateX(-50%)}}

@media(min-width:861px){
  .store-page .app-shell{max-width:1180px;margin:0 auto;padding:24px 24px 140px}
  .app-shell .store-header{position:sticky;top:12px;padding:14px 18px;margin:0 0 16px;border-radius:24px}
  .store-brand b{font-size:17px}
  .store-search{max-width:500px;padding:4px;border-radius:18px}
  .store-search input{padding:11px 13px;border-radius:14px}
  .store-search button{padding:10px 13px;border-radius:13px;font-size:13px}
  .store-hero.compact-hero{grid-template-columns:1fr;gap:10px;margin-bottom:16px}
  .compact-hero .hero-copy{min-height:128px;padding:26px;border-radius:24px}
  .compact-hero .hero-copy h1{font-size:36px;line-height:1.05;margin-bottom:7px}
  .compact-hero .hero-copy p{line-height:1.45;max-width:820px}
  .compact-hero .hero-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .compact-hero .hero-stats div{min-height:66px;padding:14px 16px;border-radius:18px}
  .compact-hero .hero-stats b{font-size:24px;line-height:1.05}
  .compact-hero .hero-stats span{font-size:12px}
  .app-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
  .mobile-dock{bottom:28px;width:420px;max-width:460px;height:56px;padding:8px;border-radius:999px}
  .mobile-dock button{height:40px;border-radius:999px;font-size:14px}
  .sheet-panel{bottom:96px;width:460px;max-height:480px;border-radius:24px}
}
@media(min-width:900px){
  .app-card:not(.is-hidden),.store-app-card:not(.is-hidden),.card-style-compact .app-card:not(.is-hidden),.card-style-gallery .app-card:not(.is-hidden){
    display:flex!important;
    align-items:flex-start;
    gap:14px;
    min-height:0!important;
    height:auto!important;
    padding:16px!important;
    border-radius:22px;
  }
  .app-icon-wrap,.app-icon,.store-app-card .app-icon-wrap,.store-app-card .app-icon,.card-style-compact .app-icon-wrap,.card-style-compact .app-icon,.card-style-gallery .app-icon-wrap,.card-style-gallery .app-icon{
    width:64px!important;
    height:64px!important;
    flex:0 0 64px;
    border-radius:18px;
  }
  .app-info{flex:1;min-width:0}
  .app-title{font-size:17px;line-height:1.24;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .app-subtitle{display:block;font-size:13px;line-height:1.35;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:1}
  .app-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
  .app-meta span{font-size:11px;padding:4px 8px}
}
#infoSheet .sheet-panel{overflow:hidden!important;display:flex;flex-direction:column;max-height:70vh}.notification-list,.notice-list{max-height:60vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;display:grid;gap:10px;padding-right:0}.notification-list::-webkit-scrollbar,.notice-list::-webkit-scrollbar{display:none}.notice-item{width:100%;display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:10px;align-items:center;text-align:left;border:0!important;border-radius:16px!important;background:rgba(255,255,255,.08)!important;color:var(--text);padding:12px 14px!important;box-shadow:none!important}.notice-item i{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.10);font-style:normal;font-weight:950}.notice-item span{min-width:0}.notice-item b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notice-item small{display:block;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notice-item small,.notice-item em{color:var(--muted)!important;font-style:normal;font-size:12px}.notice-item.unread{background:color-mix(in srgb,var(--theme-color) 12%,rgba(255,255,255,.08))!important}.sheet-head{position:relative}.sheet-head button{flex:0 0 auto}@media(max-width:700px){#infoSheet .sheet-panel{max-height:70vh;border-radius:24px 24px 0 0!important}}
.lucide-icon{width:18px;height:18px;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;color:currentColor}.mobile-dock svg,.dock-btn svg{width:20px!important;height:20px!important;fill:none!important;stroke:currentColor!important;stroke-width:1.8!important;stroke-linecap:round;stroke-linejoin:round}.notice-item i .lucide-icon,.card-cat-icon .lucide-icon{width:14px;height:14px}.detail-actions .lucide-icon,.video-controls .lucide-icon,.player-close .lucide-icon,.sheet-head .lucide-icon{width:18px;height:18px}.detail-actions button,.detail-actions a{gap:8px}.icon-play polygon{fill:none;stroke:currentColor}
.icon-btn,.dock-btn,.player-btn,.action-btn,button,.btn,.cat-pill,.detail-actions a,a[data-download]{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative;z-index:2}.notice-item{display:grid}.icon-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),.dock-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),.player-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),.action-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),button :where(svg,path,polygon,rect,circle,line,polyline,i,span,b,small,em,img),.btn :where(svg,path,polygon,rect,circle,line,polyline,i,span,b,small,em,img),.cat-pill :where(svg,path,polygon,rect,circle,line,polyline,i,span,b,img),.detail-actions a :where(svg,path,polygon,rect,circle,line,polyline,i,span),a[data-download] :where(svg,path,polygon,rect,circle,line,polyline,i,span),.notice-item :where(svg,path,polygon,rect,circle,line,polyline,i,span,b,small,em){pointer-events:none}.lucide-icon,.lucide-icon *{pointer-events:none}.hero-copy:after,.progress-wrap:before,.progress-wrap:after,.progress-wrap [data-buffered],.progress-wrap [data-played],.mini-progress,.mini-progress span,.app-card mark{pointer-events:none}.player-mask,.detail-mask,.sheet-mask,.admin-modal-mask,.admin-preview-mask{pointer-events:auto}
*::before,*::after{pointer-events:none}.mobile-dock .dock-btn,.audio-drawer .icon-btn,.audio-drawer .circle-btn,.audio-mini .audio-mini-play,.audio-mini .audio-toggle,.audio-mini .mini-close,.player-close,.media-toggle-btn,.media-icon-btn,.detail-actions button,.detail-actions a,.sheet-head button,.theme-options button{display:inline-flex!important;align-items:center!important;justify-content:center!important;cursor:pointer;position:relative;z-index:2}.circle-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),.media-toggle-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),.media-icon-btn :where(svg,path,polygon,rect,circle,line,polyline,i,span),.player-close :where(svg,path,polygon,rect,circle,line,polyline,i,span),.audio-mini-play :where(svg,path,polygon,rect,circle,line,polyline,i,span),.audio-toggle :where(svg,path,polygon,rect,circle,line,polyline,i,span),.mini-close :where(svg,path,polygon,rect,circle,line,polyline,i,span),.sheet-head button :where(svg,path,polygon,rect,circle,line,polyline,i,span),.theme-options button :where(svg,path,polygon,rect,circle,line,polyline,i,span){pointer-events:none}
.is-hidden{display:none!important}.detail-actions{justify-content:flex-end!important;align-items:center!important;gap:10px!important}.detail-actions button,.detail-actions a{flex:0 0 auto!important}.detail-actions .detail-primary{border-color:transparent;min-width:128px}@media(max-width:700px){.detail-actions{display:flex!important;justify-content:flex-end!important;gap:10px!important}.detail-actions button,.detail-actions a{flex:1 1 0!important;min-width:0!important}.detail-actions .detail-primary{flex:1 1 0!important;min-width:0!important}}
.detail-actions{position:sticky!important;left:auto!important;right:auto!important;bottom:0!important;display:flex!important;justify-content:flex-end!important;align-items:center!important;padding:14px 20px calc(14px + env(safe-area-inset-bottom))!important;background:linear-gradient(180deg,transparent,var(--surface) 24%)!important;border-top:1px solid var(--line)!important}.detail-action-group{display:inline-flex;align-items:center;justify-content:flex-end;gap:12px;max-width:100%}.detail-action-group button,.detail-action-group a{flex:0 0 auto!important;min-width:0}.detail-action-group .detail-primary{min-width:128px}.detail-action-group button{min-width:112px}@media(max-width:700px){.detail-actions{justify-content:flex-end!important;padding:12px 14px calc(12px + env(safe-area-inset-bottom))!important}.detail-action-group{width:100%;display:flex;gap:10px}.detail-action-group button,.detail-action-group a{flex:1 1 0!important;min-width:0!important}.detail-action-group .detail-primary{min-width:0!important}}
.app-card.is-hidden,.store-app-card.is-hidden,.card-style-compact .app-card.is-hidden,.card-style-gallery .app-card.is-hidden{display:none!important}
.player-panel{position:relative!important}.player-close{position:absolute!important;top:16px!important;right:16px!important;z-index:20!important}.player-title{padding-right:56px!important}.legacy-video-shell{position:relative!important;width:100%!important;background:#000;border-radius:20px;overflow:hidden}.media-player{display:block;width:100%!important;background:#000!important;border-radius:20px!important}.video-controls{position:absolute!important;left:16px!important;right:16px!important;bottom:16px!important;z-index:10!important;width:auto!important}
.bottom-sheet .sheet-pills{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.bottom-sheet .sheet-pills .cat-pill{width:100%;min-width:0!important;justify-content:space-between!important;box-sizing:border-box}.bottom-sheet .sheet-pills .cat-pill>span{min-width:0;overflow:hidden}.bottom-sheet .sheet-pills .cat-pill span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bottom-sheet .sheet-pills .cat-pill b{flex:0 0 auto}@media(min-width:760px){.bottom-sheet .sheet-panel{width:min(440px,calc(100vw - 32px))!important}}@media(max-width:700px){.bottom-sheet .sheet-panel{left:16px!important;right:16px!important;width:auto!important}.bottom-sheet .sheet-pills{grid-template-columns:repeat(2,minmax(0,1fr))}}
.admin-page{background:var(--page-grad);color:var(--text);min-height:100vh}.admin-shell{width:min(1440px,100%);margin:0 auto;display:grid;grid-template-columns:252px minmax(0,1fr);gap:20px;padding:20px}.admin-sidebar{position:sticky;top:20px;height:calc(100vh - 40px);display:flex;flex-direction:column;gap:16px;padding:16px;border:1px solid var(--line);border-radius:28px;background:var(--surface);box-shadow:var(--shadow);backdrop-filter:blur(var(--glass-blur,18px))}.admin-brand{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:950}.admin-brand span{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)));color:#fff}.admin-menu{display:grid;gap:6px}.admin-menu a,.admin-side-foot a{display:flex;align-items:center;min-height:42px;padding:0 12px;border-radius:16px;color:var(--muted);text-decoration:none;font-weight:850}.admin-menu a.active,.admin-menu a:hover{background:color-mix(in srgb,var(--theme-color) 14%,transparent);color:var(--theme-color)}.admin-side-foot{margin-top:auto;display:grid;gap:6px}.admin-main{min-width:0;padding-bottom:42px}.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;padding:16px 18px;border:1px solid var(--line);border-radius:26px;background:var(--surface);box-shadow:var(--shadow);backdrop-filter:blur(var(--glass-blur,18px))}.admin-topbar h1{margin:4px 0 0;font-size:24px}.admin-kicker{font-size:12px;font-weight:950;color:var(--muted);letter-spacing:0}.admin-module{display:grid;gap:16px}.admin-page-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.admin-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.admin-toolbar .input,.admin-toolbar select{min-height:42px}.admin-api-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.admin-stat-card{padding:16px;border:1px solid var(--line);border-radius:20px;background:var(--surface);box-shadow:var(--shadow)}.admin-stat-card span{display:block;color:var(--muted);font-size:12px;font-weight:850}.admin-stat-card b{display:block;margin-top:8px;font-size:28px}.admin-two-col{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:16px}.admin-tree{display:grid;gap:8px;max-height:70vh;overflow:auto;scrollbar-width:none}.admin-tree::-webkit-scrollbar{display:none}.admin-tree-item{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;border:0;border-radius:16px;background:var(--surface-soft);color:var(--text);text-align:left;justify-content:flex-start}.admin-tree-item.active{background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)));color:#fff}.admin-tree-indent{flex:0 0 auto;color:var(--muted)}.admin-tree-item.active .admin-tree-indent{color:rgba(255,255,255,.8)}.admin-tree-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-tree-badge{margin-left:auto;padding:3px 8px;border-radius:999px;background:rgba(255,255,255,.12);font-size:12px}.admin-form-card{display:grid;gap:14px}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.admin-form-grid .span-2{grid-column:1/-1}.admin-cascade{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.admin-resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.admin-resource-card{display:grid;gap:12px;padding:14px;border:1px solid var(--line);border-radius:20px;background:var(--surface);box-shadow:var(--shadow)}.admin-resource-main{display:flex;align-items:flex-start;gap:12px;min-width:0}.admin-resource-info{min-width:0;display:grid;gap:5px}.admin-resource-info .app-title{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-resource-info .app-subtitle{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-card-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.admin-modal-panel{max-width:760px}.admin-drawer{position:fixed;inset:0;z-index:260}.admin-drawer[hidden]{display:none}.admin-drawer-mask{position:absolute;inset:0;background:rgba(2,6,23,.48);backdrop-filter:blur(8px)}.admin-drawer-panel{position:absolute;right:18px;top:18px;bottom:18px;width:min(720px,calc(100vw - 36px));overflow:auto;padding:18px;border:1px solid var(--line);border-radius:28px;background:var(--surface);box-shadow:0 28px 90px rgba(2,6,23,.28)}.admin-list{display:grid;gap:10px}.admin-light-card{padding:14px;border-radius:18px;background:var(--surface-soft);border:1px solid var(--line)}.admin-placeholder{min-height:260px;display:grid;place-items:center;text-align:center}.admin-placeholder b{font-size:22px}.admin-toast{position:fixed;right:24px;bottom:24px;z-index:400;padding:12px 16px;border-radius:16px;background:var(--text);color:var(--bg);box-shadow:var(--shadow);font-weight:850}.admin-toast.err{background:#ef4444;color:#fff}.file-browser-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.file-card.is-published{opacity:.65}.file-card .checkline{margin:0}.settings-section{display:grid;gap:12px}.settings-section h3{margin:0}.mini-table{display:grid;gap:8px}.mini-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:14px;background:var(--surface-soft)}@media(max-width:1100px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{position:relative;top:auto;height:auto}.admin-menu{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-side-foot{display:flex}.admin-api-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-resource-grid,.file-browser-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-two-col{grid-template-columns:1fr}}@media(max-width:700px){.admin-shell{padding:12px}.admin-topbar,.admin-page-head{align-items:flex-start;flex-direction:column}.admin-menu{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-api-grid,.admin-resource-grid,.file-browser-grid,.admin-form-grid,.admin-cascade{grid-template-columns:1fr}.admin-drawer-panel{left:12px;right:12px;top:auto;bottom:12px;width:auto;max-height:86vh;border-radius:28px 28px 20px 20px}.admin-card-actions{justify-content:flex-start}}
.category-layer-list{display:grid;gap:14px}.category-layer{display:grid;gap:9px}.category-layer[hidden]{display:none}.category-layer h4{margin:0;color:var(--muted);font-size:12px;font-weight:950}.category-layer .sheet-pills{margin:0}
a[data-download].is-loading,.detail-actions a.is-loading{opacity:.72;pointer-events:none}
a[data-download].is-loading::after,.detail-actions a.is-loading::after{content:"";width:12px;height:12px;margin-left:8px;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;animation:download-spin .7s linear infinite}
@keyframes download-spin{to{transform:rotate(360deg)}}
.admin-drawer{display:flex;align-items:center;justify-content:center;padding:18px}.admin-drawer[hidden]{display:none!important}.admin-drawer-mask{position:absolute;inset:0;background:rgba(2,6,23,.48);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.admin-drawer-panel{position:relative!important;left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;width:min(760px,94vw)!important;max-width:760px!important;max-height:86vh!important;overflow:hidden!important;display:grid!important;grid-template-rows:auto minmax(0,1fr) auto;padding:0!important;border-radius:28px!important}.admin-drawer-panel .modal-head{padding:18px 18px 12px;border-bottom:1px solid var(--line)}.admin-drawer-scroll{overflow:auto;padding:16px 18px;display:grid;gap:14px}.admin-drawer-panel .modal-actions{position:sticky;bottom:0;padding:14px 18px;background:var(--surface);border-top:1px solid var(--line)}.admin-drawer-panel .code,.admin-drawer-panel .mini-card,.admin-drawer-panel input,.admin-drawer-panel textarea,.admin-resource-info .app-subtitle{word-break:break-all;overflow-wrap:anywhere}.admin-drawer-panel .admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:700px){.admin-drawer{padding:12px}.admin-drawer-panel{width:94vw!important}.admin-drawer-panel .admin-form-grid{grid-template-columns:1fr}.admin-drawer-panel .admin-form-grid .span-2{grid-column:auto}}

.search-modal{
  position:fixed;
  inset:0;
  z-index:300;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:72px 14px 18px;
}
.search-modal[hidden]{
  display:none!important;
}
.search-modal-mask{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.36);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.search-panel{
  position:relative;
  z-index:1;
  width:min(680px,100%);
  max-height:min(76vh,680px);
  overflow:hidden;
  border-radius:28px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 28px 90px rgba(15,23,42,.24);
  backdrop-filter:blur(18px) saturate(1.12);
  -webkit-backdrop-filter:blur(18px) saturate(1.12);
}
.search-command-head{
  display:grid;
  grid-template-columns:28px 1fr 42px;
  gap:10px;
  align-items:center;
  padding:12px;
  border-bottom:1px solid rgba(148,163,184,.22);
}
.search-command-head svg{
  width:22px;
  height:22px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  color:var(--muted);
}
.search-command-head input{
  width:100%;
  min-width:0;
  height:44px;
  border:0;
  outline:none;
  background:rgba(255,255,255,.62);
  border-radius:16px;
  padding:0 12px;
  font-size:15px;
  color:var(--text);
}
.search-command-head button{
  width:42px;
  height:42px;
  border:0;
  border-radius:14px;
  background:rgba(255,255,255,.55);
  color:var(--text);
}
.search-results{
  max-height:calc(76vh - 116px);
  overflow-y:auto;
  padding:10px;
}
.search-result{
  display:grid;
  grid-template-columns:48px 1fr auto;
  gap:10px;
  align-items:center;
  padding:10px;
  border-radius:18px;
  background:rgba(255,255,255,.42);
  border:1px solid rgba(255,255,255,.45);
}
.search-result+.search-result{
  margin-top:8px;
}
.search-result-cover{
  width:48px;
  height:48px;
  border-radius:14px;
  overflow:hidden;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.5);
  color:var(--muted);
  font-size:11px;
  font-weight:950;
}
.search-result-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.search-result-main{
  min-width:0;
}
.search-result-main b{
  display:block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.search-result-main span{
  display:block;
  font-size:12px;
  color:rgba(15,23,42,.58);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.search-result-actions{
  display:flex;
  gap:6px;
}
.search-result-actions .icon-btn{
  width:36px;
  height:36px;
  padding:0;
  border-radius:12px;
}
.search-result.active{
  border-color:color-mix(in srgb,var(--theme-color) 42%,rgba(255,255,255,.45));
  background:color-mix(in srgb,var(--theme-color) 10%,rgba(255,255,255,.42));
}
.search-command-tools{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  padding:0 12px 10px;
  color:var(--muted);
  font-size:12px;
  font-weight:850;
}
.search-command-tools button{
  border:0;
  border-radius:999px;
  padding:7px 10px;
  background:rgba(255,255,255,.55);
  color:var(--theme-color);
  font-weight:950;
}
.search-command-tools kbd{
  margin-left:auto;
  border-radius:8px;
  padding:3px 7px;
  background:rgba(15,23,42,.08);
  color:var(--muted);
  font:inherit;
}
.search-empty{
  padding:28px 12px;
  text-align:center;
  color:var(--muted);
}
.search-empty b{
  display:block;
  color:var(--text);
}
.search-result-group{
  padding:2px 4px 10px;
  color:var(--muted);
  font-size:12px;
  font-weight:950;
}
.subcat-filters{
  margin:10px 0 16px;
  display:grid;
  gap:10px;
}
.subcat-filters[hidden]{
  display:none!important;
}
.subcat-row{
  display:grid;
  grid-template-columns:none;
  align-items:initial;
  gap:8px;
}
.subcat-row>span{
  font-size:12px;
  font-weight:900;
  color:rgba(15,23,42,.55);
}
.subcat-pills{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding-bottom:2px;
  scrollbar-width:none;
}
.subcat-pills::-webkit-scrollbar{
  display:none;
}
.subcat-pill{
  flex:0 0 auto;
}
html[data-theme=dark] .search-panel{
  background:rgba(15,23,42,.78);
  border-color:rgba(148,163,184,.24);
}
html[data-theme=dark] .search-command-head input,
html[data-theme=dark] .search-command-head button,
html[data-theme=dark] .search-command-tools button,
html[data-theme=dark] .search-result,
html[data-theme=dark] .search-result-cover{
  background:rgba(30,41,59,.62);
  border-color:rgba(148,163,184,.18);
}
html[data-theme=dark] .search-result-main span,
html[data-theme=dark] .subcat-row>span{
  color:rgba(226,232,240,.62);
}
@media(max-width:700px){
  .search-modal{
    align-items:flex-start;
    padding:max(18px,env(safe-area-inset-top)) 10px calc(90px + env(safe-area-inset-bottom));
  }
  .search-panel{
    width:100%;
    max-height:calc(100dvh - 120px);
    border-radius:24px;
  }
  .search-results{
    max-height:calc(100dvh - 230px);
  }
  .search-command-tools{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    padding:0 12px 10px;
    font-size:12px;
  }
  .search-command-tools kbd{
    display:none;
  }
  .search-result{
    grid-template-columns:42px 1fr 84px;
  }
  .search-result-cover{
    width:42px;
    height:42px;
    border-radius:13px;
  }
}

/* V8.2.7-inspired lightweight glass system */
:root{
  --glass-bg:rgba(255,255,255,.64);
  --glass-bg-strong:rgba(255,255,255,.82);
  --glass-bg-soft:rgba(255,255,255,.34);
  --glass-border:rgba(255,255,255,.52);
  --glass-blur:16px;
  --glass-shadow:0 22px 70px rgba(15,23,42,.13),inset 0 1px 0 rgba(255,255,255,.42);
  --page-gradient:
    radial-gradient(circle at 14% 10%,color-mix(in srgb,var(--theme-color) 24%,transparent),transparent 34%),
    radial-gradient(circle at 88% 18%,color-mix(in srgb,var(--theme-color-2) 22%,transparent),transparent 30%),
    radial-gradient(circle at 52% 100%,rgba(125,211,252,.20),transparent 36%),
    linear-gradient(135deg,#f8fafc,#eef2ff 45%,#ecfeff);
  --surface:var(--glass-bg);
  --surface-strong:var(--glass-bg-strong);
  --surface-soft:var(--glass-bg-soft);
  --line:var(--glass-border);
  --shadow:var(--glass-shadow);
  --page-grad:var(--page-gradient);
}
html[data-theme=dark]{
  --glass-bg:rgba(15,23,42,.58);
  --glass-bg-strong:rgba(15,23,42,.74);
  --glass-bg-soft:rgba(30,41,59,.38);
  --glass-border:rgba(148,163,184,.22);
  --glass-shadow:0 24px 80px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.07);
  --page-gradient:
    radial-gradient(circle at 14% 10%,color-mix(in srgb,var(--theme-color) 28%,transparent),transparent 34%),
    radial-gradient(circle at 88% 18%,color-mix(in srgb,var(--theme-color-2) 24%,transparent),transparent 31%),
    radial-gradient(circle at 48% 100%,rgba(14,165,233,.12),transparent 36%),
    linear-gradient(135deg,#101827,#172033 48%,#0f2530);
}
body,.store-page,.admin-page{background:var(--page-gradient)!important;color:var(--text)}
.store-page{background-image:var(--page-gradient),var(--site-bg,linear-gradient(transparent,transparent))!important;background-attachment:fixed}
.card,.app-card,.store-header,.mobile-dock,.bottom-sheet .sheet-panel,.detail-panel,.admin-sidebar,.admin-topbar,.admin-stat-card,.admin-resource-card,.admin-form-card,.admin-drawer-panel,.file-card,.settings-section,.player-panel,.audio-drawer,.admin-modal-panel,.admin-preview-panel{
  background:var(--glass-bg)!important;
  border:1px solid var(--glass-border)!important;
  box-shadow:var(--glass-shadow)!important;
  backdrop-filter:blur(var(--glass-blur)) saturate(1.12)!important;
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.12)!important;
}
.store-search,.store-search input,.input,select,textarea,.mini-card,.admin-light-card,.detail-desc,.detail-preview,.detail-fields div{
  background:var(--glass-bg-soft)!important;
  border-color:var(--glass-border)!important;
}
.cat-pill,.app-meta span,.badge,.dock-btn,.mobile-dock button,.theme-options button,.notice-item,.btn,.icon-btn,.circle-btn,.player-btn,.action-btn,.detail-actions button,.detail-actions a{
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}
.cat-pill{background:color-mix(in srgb,var(--cat-color,var(--theme-color)) 10%,var(--glass-bg-soft))!important}
.sheet-mask,.detail-mask,.player-mask,.admin-drawer-mask,.admin-modal-mask,.admin-preview-mask{background:rgba(15,23,42,.42)!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important}
.mobile-dock{z-index:190!important}.bottom-sheet{z-index:240!important}.resource-detail,.player-modal,.audio-drawer{z-index:260!important}.admin-modal,.admin-preview-modal,.admin-drawer{z-index:300!important}.toast,.admin-toast{z-index:420!important}
.category-layer-list{max-height:56vh;overflow-y:auto;scrollbar-width:none;padding-right:2px}.category-layer-list::-webkit-scrollbar{display:none}
.dev-badge{margin-left:auto;padding:2px 7px;border-radius:999px;background:color-mix(in srgb,var(--theme-color) 12%,transparent);color:var(--theme-color);font-size:11px;font-weight:950}
.admin-drawer{display:block!important;padding:0!important}
.admin-drawer-panel{
  position:absolute!important;
  left:50%!important;
  top:50%!important;
  right:auto!important;
  bottom:auto!important;
  transform:translate(-50%,-50%)!important;
  width:min(760px,94vw)!important;
  max-height:86vh!important;
  overflow:hidden!important;
  overflow-x:hidden!important;
  border-radius:28px!important;
}
.admin-drawer-scroll{overflow:auto;overflow-x:hidden;max-width:100%}
.admin-drawer-panel .modal-actions{display:flex;justify-content:flex-end;gap:10px;position:sticky;bottom:0;background:var(--glass-bg-strong)!important}
.admin-drawer-panel .code,.admin-drawer-panel .mini-card,.admin-drawer-panel input,.admin-drawer-panel textarea,.admin-drawer-panel a{word-break:break-all;overflow-wrap:anywhere;max-width:100%}
.admin-modal-panel{max-height:86vh;overflow:auto;overflow-x:hidden}
@media(max-width:700px){
  :root{--glass-blur:10px}
  .admin-drawer-panel{width:94vw!important;max-height:88vh!important;border-radius:24px!important}
  .category-layer-list{max-height:60vh}
}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
  :root{--glass-blur:0px}
}

/* Admin polish: clipped menu pills, glass feedback, and softer forms */
.admin-sidebar{overflow:hidden!important}
.admin-menu{min-width:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;padding:1px}
.admin-menu::-webkit-scrollbar{display:none}
.admin-menu a{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  gap:10px;
  border:1px solid transparent;
}
.admin-menu a.active{
  background:linear-gradient(135deg,color-mix(in srgb,var(--theme-color) 16%,transparent),color-mix(in srgb,var(--theme-color-2,var(--theme-color)) 10%,transparent))!important;
  border-color:color-mix(in srgb,var(--theme-color) 22%,transparent)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18)!important;
}
.admin-menu a span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.dev-badge{
  flex:0 0 auto;
  white-space:nowrap;
  max-width:72px;
  overflow:hidden;
  text-overflow:ellipsis;
}
.admin-page .input,
.admin-page input:not([type="checkbox"]):not([type="radio"]),
.admin-page select,
.admin-page textarea{
  background:rgba(255,255,255,.48)!important;
  border:1px solid rgba(255,255,255,.55)!important;
  color:var(--text)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16);
  overflow-wrap:anywhere;
  max-width:100%;
}
html[data-theme=dark] .admin-page .input,
html[data-theme=dark] .admin-page input:not([type="checkbox"]):not([type="radio"]),
html[data-theme=dark] .admin-page select,
html[data-theme=dark] .admin-page textarea{
  background:rgba(15,23,42,.36)!important;
  border-color:rgba(148,163,184,.24)!important;
}
.settings-section{gap:16px!important;padding:2px 0 6px}
.settings-section + .settings-section{margin-top:14px;padding-top:18px;border-top:1px solid var(--glass-border)}
.settings-section .code,.settings-section input{word-break:break-all;overflow-wrap:anywhere}
.admin-theme-toggle{background:color-mix(in srgb,var(--theme-color) 12%,var(--glass-bg-soft))!important;color:var(--theme-color)!important;box-shadow:none!important}
.admin-toast{
  position:fixed;
  right:24px;
  bottom:24px;
  max-width:min(420px,calc(100vw - 32px));
  padding:12px 16px;
  border-radius:18px;
  background:var(--glass-bg-strong)!important;
  color:var(--text)!important;
  border:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow);
  backdrop-filter:blur(14px) saturate(1.12);
  -webkit-backdrop-filter:blur(14px) saturate(1.12);
  font-weight:850;
}
.admin-toast.err{
  background:color-mix(in srgb,#ef4444 22%,var(--glass-bg-strong))!important;
  color:#fff!important;
  border-color:color-mix(in srgb,#ef4444 34%,transparent);
}
.admin-confirm{
  position:fixed;
  inset:0;
  z-index:430;
  display:grid;
  place-items:center;
  padding:18px;
}
.admin-confirm-mask{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.admin-confirm-panel{
  position:relative;
  width:min(420px,calc(100vw - 32px));
  display:grid;
  gap:12px;
  padding:20px;
  border-radius:24px;
  background:var(--glass-bg-strong);
  border:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow);
  color:var(--text);
  backdrop-filter:blur(var(--glass-blur)) saturate(1.12);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(1.12);
}
.admin-confirm-panel b{font-size:18px}
.admin-confirm-panel p{margin:0;color:var(--muted);line-height:1.65}
.admin-confirm-panel .modal-actions{justify-content:flex-end}
.btn.is-loading,.button.is-loading,button.is-loading{
  opacity:.72;
  pointer-events:none;
}

/* Front store glass shop layout */
html body.store-page{
  min-height:100vh;
  background:
    radial-gradient(circle at 14% 10%,rgba(99,102,241,.18),transparent 34%),
    radial-gradient(circle at 88% 18%,rgba(34,211,238,.18),transparent 30%),
    linear-gradient(135deg,#f8fafc,#eef2ff 45%,#ecfeff)!important;
  background-attachment:fixed!important;
}
html[data-theme=dark] body.store-page{
  background:
    radial-gradient(circle at 14% 10%,color-mix(in srgb,var(--theme-color) 26%,transparent),transparent 34%),
    radial-gradient(circle at 88% 18%,color-mix(in srgb,var(--theme-color-2,var(--theme-color)) 22%,transparent),transparent 30%),
    linear-gradient(135deg,#111827,#172033 48%,#0f2a34)!important;
}
.store-page .app-shell,
.store-page .store-shell,
.store-page .store-main,
.store-page .store-content{
  background:transparent!important;
  background-image:none!important;
}
.store-page .app-shell,
.store-page .store-shell{
  width:min(1120px,calc(100% - 32px))!important;
  max-width:1120px!important;
  margin:0 auto!important;
  padding:22px 0 calc(96px + env(safe-area-inset-bottom))!important;
  box-sizing:border-box;
}
.store-page .store-header{
  width:100%!important;
  margin:0 0 16px!important;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 16px!important;
  border-radius:26px!important;
  background:rgba(255,255,255,.55)!important;
  border:1px solid rgba(255,255,255,.58)!important;
  box-shadow:0 18px 58px rgba(15,23,42,.09)!important;
  backdrop-filter:blur(14px) saturate(1.08)!important;
  -webkit-backdrop-filter:blur(14px) saturate(1.08)!important;
}
html[data-theme=dark] .store-page .store-header{
  background:rgba(15,23,42,.58)!important;
  border-color:rgba(148,163,184,.22)!important;
}
.store-page .store-brand{
  min-width:0;
  flex:1 1 auto;
}
.store-page .store-brand>span:last-child{
  min-width:0;
}
.store-page .store-search{
  flex:0 1 520px;
  max-width:520px!important;
  min-width:280px;
  box-shadow:none!important;
}
.store-main-panel{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:18px;
  padding:18px;
  border-radius:32px;
  background:rgba(255,255,255,.45);
  border:1px solid rgba(255,255,255,.48);
  box-shadow:0 24px 80px rgba(15,23,42,.10);
  backdrop-filter:blur(14px) saturate(1.08);
  -webkit-backdrop-filter:blur(14px) saturate(1.08);
}
.store-main-panel:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 8%,color-mix(in srgb,var(--theme-color) 12%,transparent),transparent 32%),
    radial-gradient(circle at 82% 0%,color-mix(in srgb,var(--theme-color-2,var(--theme-color)) 10%,transparent),transparent 34%);
  pointer-events:none;
}
.store-main-panel>*{
  position:relative;
  z-index:1;
}
html[data-theme=dark] .store-main-panel{
  background:rgba(15,23,42,.46);
  border-color:rgba(148,163,184,.18);
}
.store-page .store-hero.compact-hero{
  margin:0!important;
  display:grid;
  gap:14px;
}
.store-page .hero-copy{
  position:relative;
  overflow:hidden;
  min-height:150px!important;
  padding:28px!important;
  border-radius:26px!important;
  background:rgba(255,255,255,.55)!important;
  border:1px solid rgba(255,255,255,.58)!important;
  box-shadow:0 16px 52px rgba(15,23,42,.08)!important;
}
.store-page .hero-copy:after{
  content:"";
  position:absolute;
  right:-12%;
  top:-58%;
  width:320px;
  height:320px;
  border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--theme-color-2,var(--theme-color)) 18%,transparent),transparent 68%);
  pointer-events:none;
}
.store-page .hero-copy h1{
  font-size:clamp(30px,4vw,44px)!important;
  line-height:1.06!important;
}
.store-page .hero-copy p{
  max-width:760px;
}
.store-page .hero-stats{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:12px!important;
}
.store-page .hero-stats>div{
  border-radius:22px!important;
  padding:16px!important;
  background:linear-gradient(135deg,rgba(255,255,255,.52),rgba(255,255,255,.32))!important;
  border:1px solid rgba(255,255,255,.48)!important;
  color:var(--text)!important;
  box-shadow:0 12px 34px rgba(15,23,42,.08)!important;
}
html[data-theme=dark] .store-page .hero-copy,
html[data-theme=dark] .store-page .hero-stats>div{
  background:linear-gradient(135deg,rgba(30,41,59,.58),rgba(15,23,42,.42))!important;
  border-color:rgba(148,163,184,.18)!important;
}
.store-page .hero-stats b{
  font-size:34px!important;
  line-height:1!important;
}
.store-page .hero-stats span{
  margin-top:6px;
  color:var(--muted)!important;
  font-size:12px;
  font-weight:900;
}
.store-page .resource-section{
  margin:0!important;
  display:grid;
  gap:14px;
}
.subcat-filters{
  display:grid;
  gap:10px;
  margin-top:-2px;
}
.subcat-filters[hidden],
.subcat-row[hidden]{
  display:none!important;
}
.subcat-row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:10px;
}
.subcat-row>span{
  color:var(--muted);
  font-size:12px;
  font-weight:950;
  white-space:nowrap;
}
.subcat-pills{
  display:flex;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  padding:2px 2px 5px;
  scrollbar-width:none;
}
.subcat-pills::-webkit-scrollbar{
  display:none;
}
.subcat-pill{
  flex:0 0 auto;
  min-width:max-content;
}
.store-page .site-notice,
.store-page .app-card,
.store-page .store-empty,
.store-page .view-state span{
  background:rgba(255,255,255,.55)!important;
  border-color:rgba(255,255,255,.52)!important;
  box-shadow:0 14px 44px rgba(15,23,42,.08)!important;
}
html[data-theme=dark] .store-page .site-notice,
html[data-theme=dark] .store-page .app-card,
html[data-theme=dark] .store-page .store-empty,
html[data-theme=dark] .store-page .view-state span{
  background:rgba(15,23,42,.52)!important;
  border-color:rgba(148,163,184,.18)!important;
}
.store-page .app-grid{
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr))!important;
  gap:16px!important;
}
@media(min-width:861px){
  .store-page .app-card:not(.is-hidden),
  .store-page .store-app-card:not(.is-hidden),
  .store-page.card-style-compact .app-card:not(.is-hidden),
  .store-page.card-style-gallery .app-card:not(.is-hidden){
    min-height:132px!important;
    height:auto!important;
    padding:16px!important;
    display:flex!important;
    align-items:flex-start!important;
    gap:14px!important;
    border-radius:24px!important;
  }
  .store-page .app-icon-wrap,
  .store-page .app-icon{
    width:66px!important;
    height:66px!important;
    flex:0 0 66px!important;
    border-radius:18px!important;
  }
  .store-page .app-info{
    min-width:0;
    flex:1 1 auto;
    display:grid;
    gap:7px;
  }
  .store-page .app-title{
    font-size:16px!important;
  }
  .store-page .app-subtitle{
    font-size:13px!important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
}
.store-page .mobile-dock{
  background:rgba(255,255,255,.58)!important;
  border-color:rgba(255,255,255,.55)!important;
  box-shadow:0 18px 56px rgba(15,23,42,.14)!important;
  backdrop-filter:blur(14px) saturate(1.08)!important;
  -webkit-backdrop-filter:blur(14px) saturate(1.08)!important;
}
html[data-theme=dark] .store-page .mobile-dock{
  background:rgba(15,23,42,.66)!important;
  border-color:rgba(148,163,184,.2)!important;
}
.store-page .mobile-dock button.active{
  background:color-mix(in srgb,var(--theme-color) 16%,transparent)!important;
  color:var(--theme-color)!important;
}
.store-page .store-footer{
  margin:14px 0 0!important;
  padding-bottom:0!important;
}
@media(max-width:700px){
  html body.store-page{
    background-attachment:scroll!important;
  }
  .store-page .app-shell,
  .store-page .store-shell{
    width:calc(100% - 20px)!important;
    padding:calc(env(safe-area-inset-top) + 10px) 0 calc(88px + env(safe-area-inset-bottom))!important;
  }
  .store-page .store-header{
    gap:10px;
    padding:11px!important;
    border-radius:24px!important;
  }
  .store-page .store-search{
    min-width:0;
    flex:1 1 auto;
  }
  .store-main-panel{
    gap:12px;
    padding:10px;
    border-radius:24px;
    backdrop-filter:blur(10px) saturate(1.04);
    -webkit-backdrop-filter:blur(10px) saturate(1.04);
  }
  .store-page .hero-copy{
    min-height:0!important;
    padding:18px!important;
    border-radius:22px!important;
  }
  .store-page .hero-stats{
    display:none!important;
  }
  .subcat-row{
    grid-template-columns:1fr;
    gap:6px;
  }
  .subcat-row>span{
    padding-left:2px;
  }
  .store-page .app-grid{
    grid-template-columns:repeat(auto-fit,minmax(170px,1fr))!important;
    gap:8px!important;
  }
}

/* Category hierarchy and mobile detail title fixes */
.subcat-filters{
  gap:12px!important;
}
.subcat-row{
  grid-template-columns:1fr!important;
  align-items:stretch!important;
  gap:8px!important;
}
.subcat-row>span,
.subcat-label{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  font-size:12px!important;
  font-weight:950!important;
  color:var(--muted)!important;
}
.subcat-row>span:before,
.subcat-label:before{
  content:"";
  width:7px;
  height:7px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)));
}
.subcat-pills{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  padding:2px 2px 6px!important;
  scrollbar-width:none!important;
}
.subcat-pills::-webkit-scrollbar{
  display:none!important;
}
.subcat-pill{
  flex:0 0 auto!important;
  min-width:max-content!important;
}
.subcat-pill.active,
.subcat-all.active{
  background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 10px 26px color-mix(in srgb,var(--theme-color) 24%,transparent)!important;
}
.detail-head{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:12px!important;
  align-items:start!important;
}
.detail-head>div{
  min-width:0!important;
}
.detail-head b,
.detail-title,
.resource-detail-title{
  max-width:100%!important;
  min-width:0!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  white-space:normal!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  word-break:break-word!important;
  overflow-wrap:anywhere!important;
  line-height:1.25!important;
}
.app-title,
.resource-card-title{
  max-width:100%!important;
  min-width:0!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  white-space:normal!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  word-break:break-word!important;
  overflow-wrap:anywhere!important;
  line-height:1.22!important;
}
@media(max-width:700px){
  .detail-head b{
    font-size:17px!important;
  }
  .store-page .app-title{
    font-size:14px!important;
  }
}

/* Unified pills and player icon buttons */
html,
body{
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
.pill-group,
.sheet-pills,
.subcat-pills{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  overflow-x:auto!important;
  overflow-y:visible!important;
  scrollbar-width:none!important;
  flex-wrap:nowrap!important;
}
.pill-group::-webkit-scrollbar,
.sheet-pills::-webkit-scrollbar,
.subcat-pills::-webkit-scrollbar{
  display:none!important;
}
.pill,
.cat-pill,
.theme-options button{
  position:relative!important;
  height:42px!important;
  min-height:42px!important;
  padding:0 18px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1!important;
  white-space:nowrap!important;
  border:1px solid rgba(120,140,255,.18)!important;
  background:rgba(255,255,255,.55)!important;
  color:var(--text)!important;
  box-shadow:none!important;
  flex:0 0 auto!important;
  min-width:0!important;
  overflow:visible!important;
  isolation:isolate!important;
  backface-visibility:hidden!important;
  transition:background .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease!important;
}
.pill:active,
.cat-pill:active,
.theme-options button:active{
  transform:none!important;
}
.pill.active,
.cat-pill.active,
.theme-options button.active{
  background:linear-gradient(135deg,var(--theme-color,#5b5cff),var(--theme-color-2,#2ec5ff))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 4px 18px color-mix(in srgb,var(--theme-color,#5b5cff) 25%,transparent)!important;
}
.pill>span,
.cat-pill>span{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  min-width:0!important;
  line-height:1!important;
}
.pill-badge,
.cat-pill b,
.dock-badge{
  min-width:22px!important;
  height:22px!important;
  padding:0 6px!important;
  border-radius:999px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:12px!important;
  font-weight:800!important;
  line-height:1!important;
  background:rgba(0,0,0,.08)!important;
  color:currentColor!important;
  box-sizing:border-box!important;
}
.pill.active .pill-badge,
.cat-pill.active b{
  background:rgba(255,255,255,.22)!important;
  color:#fff!important;
}
.icon-btn,
.circle-btn,
.detail-actions button,
.detail-actions a,
.music-actions button,
.music-actions a,
.player-toolbar .icon-btn,
.video-controls button,
.audio-mini .audio-mini-play,
.audio-mini .audio-toggle,
.audio-mini .mini-close{
  width:46px!important;
  height:46px!important;
  min-width:46px!important;
  min-height:46px!important;
  padding:0!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 46px!important;
  background:rgba(255,255,255,.55)!important;
  color:var(--text)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  box-shadow:none!important;
  text-decoration:none!important;
  line-height:1!important;
  font-size:0!important;
  cursor:pointer!important;
  isolation:isolate!important;
  backface-visibility:hidden!important;
  transition:background .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease!important;
}
.icon-btn:hover,
.circle-btn:hover,
.detail-actions button:hover,
.detail-actions a:hover,
.music-actions button:hover,
.music-actions a:hover,
.video-controls button:hover{
  background:rgba(255,255,255,.72)!important;
}
.icon-btn:active,
.circle-btn:active,
.detail-actions button:active,
.detail-actions a:active,
.music-actions button:active,
.music-actions a:active,
.video-controls button:active,
.audio-mini .audio-mini-play:active,
.audio-mini .audio-toggle:active,
.audio-mini .mini-close:active{
  transform:none!important;
}
.icon-btn.primary,
.circle-btn.primary,
.detail-primary,
.music-actions .play-circle,
.video-controls [data-media-toggle],
.audio-mini .audio-mini-play{
  background:linear-gradient(135deg,var(--theme-color,#5b5cff),var(--theme-color-2,#2ec5ff))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 4px 18px color-mix(in srgb,var(--theme-color,#5b5cff) 25%,transparent)!important;
}
.icon-btn svg,
.circle-btn svg,
.detail-actions svg,
.music-actions svg,
.player-toolbar svg,
.video-controls svg,
.audio-mini svg{
  width:20px!important;
  height:20px!important;
  display:block!important;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
  pointer-events:none!important;
}
.icon-btn i,
.circle-btn i{
  font-size:20px!important;
  line-height:1!important;
  pointer-events:none!important;
}
.detail-action-group,
.music-actions,
.player-actions-desktop{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:12px!important;
}
.detail-actions{
  justify-content:flex-end!important;
}
.player-panel,
.audio-drawer,
.music-card,
.music-actions,
.video-controls{
  filter:none!important;
  will-change:auto!important;
}
html[data-theme=dark] .pill,
html[data-theme=dark] .cat-pill,
html[data-theme=dark] .theme-options button,
html[data-theme=dark] .icon-btn,
html[data-theme=dark] .circle-btn,
html[data-theme=dark] .detail-actions button,
html[data-theme=dark] .detail-actions a,
html[data-theme=dark] .music-actions button,
html[data-theme=dark] .music-actions a,
html[data-theme=dark] .video-controls button,
html[data-theme=dark] .audio-mini .audio-toggle,
html[data-theme=dark] .audio-mini .mini-close{
  background:rgba(255,255,255,.10)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.14)!important;
}
@media(max-width:700px){
  .music-actions,
  .player-actions-mobile{
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:12px!important;
  }
  .detail-action-group{
    justify-content:flex-end!important;
    gap:12px!important;
  }
  .pill,
  .cat-pill,
  .theme-options button{
    height:40px!important;
    min-height:40px!important;
    padding:0 16px!important;
    font-size:13px!important;
  }
}
.detail-action-group .icon-btn,
.detail-action-group .detail-primary,
.detail-actions .icon-btn,
.detail-actions .detail-primary{
  width:46px!important;
  min-width:46px!important;
  max-width:46px!important;
  height:46px!important;
  min-height:46px!important;
  flex:0 0 46px!important;
}
@media(max-width:700px){
  .detail-action-group .icon-btn,
  .detail-action-group .detail-primary,
  .detail-actions .icon-btn,
  .detail-actions .detail-primary{
    flex:0 0 46px!important;
    width:46px!important;
    min-width:46px!important;
    max-width:46px!important;
  }
}

/* Final clean UI pass: stable pills, visible icon hovers, single range progress */
.pill,
.cat-pill,
.subcat-pill,
.theme-options button{
  position:relative!important;
  height:42px!important;
  min-height:42px!important;
  padding:0 18px!important;
  border:0!important;
  border-radius:999px!important;
  background:transparent!important;
  color:var(--text,#111827)!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1!important;
  white-space:nowrap!important;
  flex:0 0 auto!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  overflow:visible!important;
  isolation:isolate!important;
  backface-visibility:hidden!important;
  transform:none!important;
  filter:none!important;
  -webkit-font-smoothing:antialiased;
}
.pill::before,
.cat-pill::before,
.subcat-pill::before,
.theme-options button::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(120,140,255,.18);
  pointer-events:none;
  box-shadow:none;
}
.pill.active,
.cat-pill.active,
.subcat-pill.active,
.theme-options button.active{
  color:#fff!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
}
.pill.active::before,
.cat-pill.active::before,
.subcat-pill.active::before,
.theme-options button.active::before{
  background:linear-gradient(135deg,var(--theme-color,#5b5cff),var(--theme-color-2,#18c6e8));
  border-color:transparent;
  box-shadow:0 8px 22px color-mix(in srgb,var(--theme-color,#5b5cff) 24%,transparent);
}
.pill *,
.cat-pill *,
.subcat-pill *,
.theme-options button *,
.pill::before,
.cat-pill::before,
.subcat-pill::before,
.theme-options button::before{
  pointer-events:none!important;
}
.pill>span,
.cat-pill>span,
.subcat-pill>span{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  min-width:0!important;
  line-height:1!important;
}
.pill-badge,
.cat-pill b{
  min-width:22px!important;
  height:22px!important;
  padding:0 7px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:12px!important;
  font-weight:800!important;
  line-height:1!important;
  background:rgba(255,255,255,.28)!important;
  color:inherit!important;
  box-sizing:border-box!important;
}
.pill:not(.active) .pill-badge,
.cat-pill:not(.active) b{
  background:rgba(91,92,255,.12)!important;
  color:var(--theme-color,#4f46e5)!important;
}
html[data-theme=dark] .pill::before,
html[data-theme=dark] .cat-pill::before,
html[data-theme=dark] .subcat-pill::before,
html[data-theme=dark] .theme-options button::before{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.14);
}
.player-progress{
  width:100%;
  margin:14px 0 10px;
}
.video-controls .player-progress{
  flex:1 1 auto;
  min-width:80px;
  margin:0 8px;
}
.player-range{
  width:100%;
  height:6px;
  appearance:none;
  -webkit-appearance:none;
  display:block;
  background:linear-gradient(to right,var(--theme-color,#5b5cff) 0%,var(--theme-color-2,#18c6a7) var(--progress,0%),rgba(120,135,160,.22) var(--progress,0%),rgba(120,135,160,.22) 100%);
  border:0;
  border-radius:999px;
  outline:none;
  cursor:pointer;
}
.player-range::-webkit-slider-thumb{
  appearance:none;
  -webkit-appearance:none;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#fff;
  border:3px solid var(--theme-color,#5b5cff);
  box-shadow:0 4px 12px color-mix(in srgb,var(--theme-color,#5b5cff) 28%,transparent);
  cursor:pointer;
}
.player-range::-moz-range-thumb{
  width:16px;
  height:16px;
  border-radius:50%;
  background:#fff;
  border:3px solid var(--theme-color,#5b5cff);
  box-shadow:0 4px 12px color-mix(in srgb,var(--theme-color,#5b5cff) 28%,transparent);
  cursor:pointer;
}
.progress-wrap::before,
.progress-wrap::after,
.progress-wrap [data-buffered],
.progress-wrap [data-played]{
  display:none!important;
}
.icon-btn.primary,
.icon-btn.primary i,
.icon-btn.primary svg,
.detail-primary,
.detail-primary svg,
.circle-btn.primary,
.circle-btn.primary svg,
a[data-download].primary,
a[data-download].primary svg{
  color:#fff!important;
  stroke:currentColor!important;
  opacity:1!important;
}
.icon-btn.primary:hover,
.detail-primary:hover,
.circle-btn.primary:hover,
a[data-download].primary:hover{
  color:#fff!important;
  background:linear-gradient(135deg,var(--theme-color,#5457ff),var(--theme-color-2,#12b8e8))!important;
  box-shadow:0 10px 26px color-mix(in srgb,var(--theme-color,#2c82ff) 28%,transparent)!important;
  opacity:1!important;
}
.icon-btn.primary:hover i,
.icon-btn.primary:hover svg,
.detail-primary:hover svg,
.circle-btn.primary:hover svg,
a[data-download].primary:hover svg{
  color:#fff!important;
  stroke:currentColor!important;
  opacity:1!important;
}

/* UI button rendering base: outer owns geometry, .ui-btn-bg owns paint */
.ui-btn,
.ui-btn *,
.ui-btn::before,
.ui-btn::after{
  box-sizing:border-box!important;
}
.ui-btn::before,
.ui-btn::after,
.ui-btn-bg::before,
.ui-btn-bg::after{
  content:none!important;
}
.ui-btn{
  position:relative!important;
  border:0!important;
  outline:0!important;
  padding:0!important;
  margin:0!important;
  background:transparent!important;
  background-image:none!important;
  box-shadow:none!important;
  overflow:visible!important;
  transform:none!important;
  filter:none!important;
  mask:none!important;
  -webkit-mask:none!important;
  clip-path:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  -webkit-tap-highlight-color:transparent!important;
  appearance:none!important;
  -webkit-appearance:none!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  isolation:isolate!important;
  cursor:pointer!important;
  flex-shrink:0!important;
  text-decoration:none!important;
  line-height:1!important;
}
.ui-btn-bg{
  position:absolute!important;
  inset:0!important;
  border-radius:inherit!important;
  z-index:-1!important;
  pointer-events:none!important;
  box-sizing:border-box!important;
  transform:none!important;
  filter:none!important;
  mask:none!important;
  -webkit-mask:none!important;
  clip-path:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}
.ui-btn-circle{
  width:46px!important;
  height:46px!important;
  min-width:46px!important;
  min-height:46px!important;
  flex:0 0 46px!important;
  border-radius:50%!important;
}
.ui-btn-pill{
  height:42px!important;
  min-height:42px!important;
  min-width:64px!important;
  padding:0 18px!important;
  border-radius:999px!important;
  gap:8px!important;
}
.ui-btn-text,
.ui-btn-icon,
.ui-btn-badge{
  position:relative!important;
  z-index:1!important;
  pointer-events:none!important;
}
.ui-btn-icon{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  line-height:1!important;
}
.ui-btn-icon i,
.ui-btn-icon svg{
  font-size:20px!important;
  width:20px!important;
  height:20px!important;
  display:block!important;
  color:currentColor!important;
  stroke:currentColor!important;
  opacity:1!important;
}
.ui-btn:not(.ui-btn-primary){
  color:#111827!important;
}
.ui-btn:not(.ui-btn-primary) .ui-btn-bg{
  background:rgba(255,255,255,.72)!important;
  border:1px solid rgba(120,140,255,.18)!important;
  box-shadow:0 8px 22px rgba(15,23,42,.06)!important;
}
.ui-btn-primary,
.ui-btn.ui-btn-primary,
.ui-btn.ui-btn-primary.active{
  color:#fff!important;
  background:transparent!important;
  background-image:none!important;
  border:0!important;
  box-shadow:none!important;
}
.ui-btn-primary .ui-btn-bg,
.ui-btn-primary.active .ui-btn-bg,
.ui-btn.active .ui-btn-bg{
  background:linear-gradient(135deg,#5b5cff 0%,#18bde8 100%)!important;
  border:0!important;
  box-shadow:0 10px 24px rgba(37,99,235,.26)!important;
}
.ui-btn:hover{
  transform:none!important;
  filter:none!important;
  background:transparent!important;
  background-image:none!important;
}
.ui-btn-primary:hover,
.ui-btn-primary:hover .ui-btn-icon,
.ui-btn-primary:hover svg{
  color:#fff!important;
  opacity:1!important;
  stroke:currentColor!important;
}
.ui-btn-primary:hover .ui-btn-bg{
  background:linear-gradient(135deg,#5457ff 0%,#12b8e8 100%)!important;
  box-shadow:0 12px 28px rgba(37,99,235,.30)!important;
}
.ui-btn:not(.ui-btn-primary):hover .ui-btn-bg{
  background:rgba(255,255,255,.82)!important;
  border-color:rgba(120,140,255,.24)!important;
}
.ui-btn-badge{
  min-width:22px!important;
  height:22px!important;
  padding:0 7px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  line-height:1!important;
  font-size:12px!important;
  font-weight:800!important;
  background:rgba(255,255,255,.28)!important;
  color:inherit!important;
}
.ui-btn:not(.ui-btn-primary) .ui-btn-badge{
  background:rgba(91,92,255,.12)!important;
  color:#4f46e5!important;
}
.ui-btn-pill .ui-btn-text{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  min-width:0!important;
  font-size:14px!important;
  font-weight:800!important;
  line-height:1!important;
  white-space:nowrap!important;
}
.player-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:12px!important;
}
.player-actions .ui-btn{
  flex:0 0 auto!important;
}
.player-panel > .player-close.ui-btn{
  position:absolute!important;
  top:16px!important;
  right:16px!important;
  z-index:20!important;
}
.pill-group{
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  overflow-x:auto!important;
  scrollbar-width:none!important;
}
.pill-group::-webkit-scrollbar{
  display:none!important;
}
html[data-theme=dark] .ui-btn:not(.ui-btn-primary){
  color:#fff!important;
}
html[data-theme=dark] .ui-btn:not(.ui-btn-primary) .ui-btn-bg{
  background:rgba(255,255,255,.10)!important;
  border-color:rgba(255,255,255,.14)!important;
  box-shadow:0 8px 22px rgba(0,0,0,.12)!important;
}
html[data-theme=dark] .ui-btn:not(.ui-btn-primary):hover .ui-btn-bg{
  background:rgba(255,255,255,.16)!important;
  border-color:rgba(255,255,255,.20)!important;
}

/* Final Dock-style buttons/tabs: simple paint, no gradients on the button body */
.pill,
.pill.active,
.pill-badge,
.icon-btn,
.icon-btn.primary,
.ui-btn,
.ui-btn-bg,
.ui-btn-primary,
.download-btn,
.play-btn,
.action-btn,
.player-action-btn,
.category-pill,
.sub-pill{
  background:transparent!important;
  background-image:none!important;
  border:0!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  filter:none!important;
  transform:none!important;
  mask:none!important;
  -webkit-mask:none!important;
  clip-path:none!important;
  overflow:visible!important;
}
.dock-actions{
  display:flex!important;
  flex-direction:row!important;
  align-items:center!important;
  justify-content:center!important;
  flex-wrap:nowrap!important;
  gap:8px!important;
  width:fit-content!important;
  max-width:100%!important;
  margin:0 auto!important;
  padding:8px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.62)!important;
  border:1px solid rgba(255,255,255,.45)!important;
  box-shadow:0 14px 40px rgba(15,23,42,.12),inset 0 1px 0 rgba(255,255,255,.65)!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}
.player-actions,
.player-actions-mobile,
.audio-actions,
.music-actions{
  display:flex!important;
  flex-direction:row!important;
  align-items:center!important;
  justify-content:center!important;
  flex-wrap:nowrap!important;
}
.player-actions .dock-actions,
.player-actions-mobile .dock-actions,
.audio-actions .dock-actions,
.music-actions .dock-actions{
  flex-direction:row!important;
  flex-wrap:nowrap!important;
}
.dock-btn{
  width:42px!important;
  height:42px!important;
  min-width:42px!important;
  min-height:42px!important;
  flex:0 0 42px!important;
  border:0!important;
  outline:0!important;
  padding:0!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:transparent!important;
  background-image:none!important;
  color:#1f2937!important;
  cursor:pointer!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  filter:none!important;
  transform:none!important;
  overflow:visible!important;
  transition:background .2s ease,color .2s ease,box-shadow .2s ease!important;
}
.dock-btn-icon,
.dock-btn i,
.dock-btn svg{
  font-size:20px!important;
  width:20px!important;
  height:20px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  color:currentColor!important;
  stroke:currentColor!important;
  opacity:1!important;
  pointer-events:none!important;
}
.dock-btn:hover{
  background:rgba(255,255,255,.86)!important;
  color:#2563eb!important;
  box-shadow:inset 0 0 0 1px rgba(37,99,235,.12)!important;
}
.dock-btn.active,
.dock-btn.primary,
.dock-btn.detail-primary,
.dock-btn[data-download]{
  background:#2563eb!important;
  color:#fff!important;
  box-shadow:0 8px 18px rgba(37,99,235,.28)!important;
}
.dock-btn.active:hover,
.dock-btn.primary:hover,
.dock-btn.detail-primary:hover,
.dock-btn[data-download]:hover{
  background:#1d4ed8!important;
  color:#fff!important;
}
.dock-tabs,
.sheet-pills,
.subcat-pills{
  display:flex!important;
  align-items:center!important;
  gap:6px!important;
  width:fit-content!important;
  max-width:100%!important;
  padding:6px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.62)!important;
  border:1px solid rgba(255,255,255,.45)!important;
  box-shadow:0 10px 30px rgba(15,23,42,.08),inset 0 1px 0 rgba(255,255,255,.65)!important;
  overflow-x:auto!important;
  overflow-y:visible!important;
  scrollbar-width:none!important;
  flex-wrap:nowrap!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}
.dock-tabs::-webkit-scrollbar,
.sheet-pills::-webkit-scrollbar,
.subcat-pills::-webkit-scrollbar{
  display:none!important;
}
.dock-tab{
  height:36px!important;
  min-height:36px!important;
  min-width:0!important;
  padding:0 14px!important;
  border:0!important;
  outline:0!important;
  border-radius:999px!important;
  background:transparent!important;
  background-image:none!important;
  color:#1f2937!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1!important;
  white-space:nowrap!important;
  cursor:pointer!important;
  flex:0 0 auto!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  filter:none!important;
  transform:none!important;
  overflow:visible!important;
  transition:background .2s ease,color .2s ease,box-shadow .2s ease!important;
}
.dock-tab > span{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  min-width:0!important;
  pointer-events:none!important;
}
.dock-tab:hover{
  background:rgba(255,255,255,.86)!important;
  color:#2563eb!important;
}
.dock-tab.active{
  background:#2563eb!important;
  color:#fff!important;
  box-shadow:0 6px 16px rgba(37,99,235,.25)!important;
}
.dock-tab em{
  min-width:20px!important;
  height:20px!important;
  padding:0 6px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-style:normal!important;
  font-size:12px!important;
  font-weight:800!important;
  line-height:1!important;
  background:rgba(37,99,235,.12)!important;
  color:#2563eb!important;
  pointer-events:none!important;
}
.dock-tab.active em{
  background:rgba(255,255,255,.24)!important;
  color:#fff!important;
}
.player-panel > .player-close.dock-btn{
  position:absolute!important;
  top:16px!important;
  right:16px!important;
  z-index:20!important;
}
html[data-theme=dark] .dock-actions,
html[data-theme=dark] .dock-tabs,
html[data-theme=dark] .sheet-pills,
html[data-theme=dark] .subcat-pills{
  background:rgba(15,23,42,.62)!important;
  border-color:rgba(255,255,255,.12)!important;
  box-shadow:0 14px 40px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.10)!important;
}
html[data-theme=dark] .dock-btn,
html[data-theme=dark] .dock-tab{
  color:#e5e7eb!important;
}
html[data-theme=dark] .dock-btn:hover,
html[data-theme=dark] .dock-tab:hover{
  background:rgba(255,255,255,.12)!important;
  color:#93c5fd!important;
}
html[data-theme=dark] .dock-btn.active,
html[data-theme=dark] .dock-btn.primary,
html[data-theme=dark] .dock-btn.detail-primary,
html[data-theme=dark] .dock-btn[data-download],
html[data-theme=dark] .dock-tab.active{
  background:#2563eb!important;
  color:#fff!important;
}
@media(max-width:480px){
  .dock-actions{
    gap:6px!important;
    padding:7px!important;
  }
  .dock-btn{
    width:40px!important;
    height:40px!important;
    min-width:40px!important;
    min-height:40px!important;
    flex-basis:40px!important;
  }
}
@media(max-width:360px){
  .dock-actions{
    gap:4px!important;
    padding:6px!important;
  }
  .dock-btn{
    width:38px!important;
    height:38px!important;
    min-width:38px!important;
    min-height:38px!important;
    flex-basis:38px!important;
  }
}

/* Focused fixes: equal Dock, clean category tabs, fullscreen video shell */
.mobile-dock{
  position:fixed!important;
  left:50%!important;
  right:auto!important;
  bottom:calc(18px + env(safe-area-inset-bottom))!important;
  transform:translateX(-50%)!important;
  z-index:190!important;
  width:min(420px,calc(100vw - 32px))!important;
  max-width:min(420px,calc(100vw - 32px))!important;
  height:58px!important;
  display:grid!important;
  grid-template-columns:repeat(4,1fr)!important;
  align-items:center!important;
  gap:0!important;
  padding:7px 10px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.72)!important;
  border:1px solid rgba(255,255,255,.55)!important;
  box-shadow:0 18px 54px rgba(2,6,23,.16)!important;
  backdrop-filter:blur(18px)!important;
  -webkit-backdrop-filter:blur(18px)!important;
}
.mobile-dock .dock-btn{
  width:100%!important;
  height:44px!important;
  min-width:0!important;
  min-height:44px!important;
  flex:0 1 auto!important;
  flex-basis:auto!important;
  border:0!important;
  border-radius:999px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:transparent!important;
  color:var(--text)!important;
  position:relative!important;
  padding:0!important;
  box-shadow:none!important;
}
.mobile-dock .dock-btn svg{
  width:21px!important;
  height:21px!important;
  display:block!important;
  flex:0 0 auto!important;
}
.mobile-dock .dock-btn.active{
  background:rgba(91,92,255,.14)!important;
  color:var(--theme-color)!important;
  box-shadow:0 8px 20px rgba(91,92,255,.18)!important;
}
.dock-badge{
  position:absolute!important;
  top:5px!important;
  right:calc(50% - 21px)!important;
  min-width:16px!important;
  max-width:30px!important;
  height:16px!important;
  padding:0 5px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:#ef4444!important;
  color:#fff!important;
  font-size:10px!important;
  font-weight:900!important;
  line-height:1!important;
  box-shadow:0 0 0 2px rgba(255,255,255,.88),0 4px 10px rgba(239,68,68,.25)!important;
  pointer-events:none!important;
  z-index:3!important;
  white-space:nowrap!important;
}
.dock-badge[hidden]{
  display:none!important;
}
.mobile-dock .dock-btn.has-unread svg{
  animation:bellShake 1.8s ease-in-out infinite;
  transform-origin:50% 20%;
}
@keyframes bellShake{
  0%,70%,100%{transform:rotate(0deg)}
  75%{transform:rotate(8deg)}
  80%{transform:rotate(-8deg)}
  85%{transform:rotate(5deg)}
  90%{transform:rotate(-5deg)}
}
.sheet-pills,
.subcat-pills{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  width:100%!important;
  max-width:100%!important;
  padding:6px!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.52)!important;
  border:1px solid rgba(255,255,255,.48)!important;
  overflow-x:auto!important;
  overflow-y:hidden!important;
  scrollbar-width:none!important;
  flex-wrap:nowrap!important;
  box-sizing:border-box!important;
}
.sheet-pills::-webkit-scrollbar,
.subcat-pills::-webkit-scrollbar{
  display:none!important;
}
.sheet-pills .dock-tab,
.subcat-pills .dock-tab{
  height:36px!important;
  padding:0 13px!important;
  border:0!important;
  border-radius:999px!important;
  background:transparent!important;
  background-image:none!important;
  color:var(--text)!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:7px!important;
  font-size:13px!important;
  font-weight:850!important;
  white-space:nowrap!important;
  flex:0 0 auto!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
  transform:none!important;
  overflow:visible!important;
}
.sheet-pills .dock-tab.active,
.subcat-pills .dock-tab.active{
  background:var(--theme-color)!important;
  color:#fff!important;
  box-shadow:0 8px 18px rgba(37,99,235,.22)!important;
}
.dock-tab em,
.dock-tab b{
  min-width:20px!important;
  height:20px!important;
  padding:0 6px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:11px!important;
  font-weight:900!important;
  font-style:normal!important;
  background:rgba(37,99,235,.12)!important;
  color:var(--theme-color)!important;
}
.dock-tab.active em,
.dock-tab.active b{
  background:rgba(255,255,255,.25)!important;
  color:#fff!important;
}
#categorySheet .sheet-panel{
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  max-height:min(70vh,560px)!important;
  border-radius:28px!important;
}
#categorySheet .sheet-head,
#categorySheet .sheet-pills{
  flex:0 0 auto!important;
}
@media(max-width:700px){
  #categorySheet .sheet-panel{
    left:12px!important;
    right:12px!important;
    bottom:calc(88px + env(safe-area-inset-bottom))!important;
    width:auto!important;
    max-height:58vh!important;
    border-radius:24px!important;
  }
  .sheet-pills,
  .subcat-pills{
    flex-wrap:nowrap!important;
  }
}

/* ── 详情弹窗封面（响应式布局） ── */
.detail-main{
  display:flex;
  flex-direction:column;
  gap:14px;
  overflow:hidden;
}
.detail-cover-wrap{
  width:100%;
  max-height:280px;
  overflow:hidden;
  border-radius:14px;
  position:relative;
  flex-shrink:0;
  background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2));
}
.detail-cover-img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .4s ease;
  border-radius:inherit;
}
.cover-audio .detail-cover-img{
  aspect-ratio:1/1;
  object-fit:contain;
}
.cover-video .detail-cover-img{
  aspect-ratio:16/9;
  object-fit:cover;
}
.cover-image .detail-cover-img{
  aspect-ratio:auto;
  object-fit:contain;
  max-height:260px;
}
.cover-fallback{
  aspect-ratio:16/9;
  min-height:160px;
}
.detail-cover-fallback{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:100%;
  height:100%;
  position:absolute;
  top:0;
  left:0;
}
.detail-cover-fallback-icon{
  width:48px;
  height:48px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  position:relative;
}
.detail-cover-fallback-icon::after{
  content:'';
  position:absolute;
  inset:14px;
  border:2.5px solid rgba(255,255,255,.28);
  border-radius:3px;
}
.detail-cover-fallback span{
  font-size:14px;
  font-weight:700;
  color:rgba(255,255,255,.4);
  letter-spacing:.06em;
  text-transform:uppercase;
}
.detail-cover-wrap:hover .detail-cover-img{
  transform:scale(1.04);
}
.detail-cover-img[src=""],
.detail-cover-img:not([src]){
  display:none!important;
}

/* PC 端：封面左 + 信息右 */
@media(min-width:700px){
  .detail-main{
    flex-direction:row;
    gap:18px;
  }
  .detail-cover-wrap{
    width:220px;
    max-height:260px;
    border-radius:14px;
  }
  .cover-video .detail-cover-wrap{
    width:280px;
  }
  .cover-audio .detail-cover-wrap{
    width:200px;
  }
  .detail-body{
    flex:1;
    min-width:0;
    overflow-y:auto;
    max-height:60vh;
  }
  .cover-audio .detail-cover-img{
    aspect-ratio:1/1;
    max-width:100%;
    border-radius:inherit;
  }
  .cover-video .detail-cover-img{
    aspect-ratio:16/9;
  }
  .cover-image .detail-cover-img{
    max-height:240px;
  }
}

/* 大屏进一步优化 */
@media(min-width:900px){
  .detail-cover-wrap{
    width:260px;
    max-height:300px;
  }
  .cover-video .detail-cover-wrap{
    width:340px;
  }
}

/* ── Cloudreve 文件浏览器 m3u8 高亮 ── */
.file-m3u8{
  color:var(--theme-color-2,#06b6d4)!important;
  font-weight:700;
}

/* ════════════════════════════════════════════
   V7 — 资源详情弹窗重构
   ════════════════════════════════════════════ */
.resource-detail{
  position:fixed;
  inset:0;
  z-index:260;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
}
.resource-detail[hidden]{
  display:none!important;
}
.detail-mask{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.42)!important;
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
}
.detail-panel{
  position:relative;
  width:min(860px,100%);
  max-height:min(86vh,820px);
  overflow:hidden;
  display:grid;
  grid-template-rows:auto minmax(0,1fr) auto;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.58);
  background:rgba(255,255,255,.76)!important;
  box-shadow:0 30px 90px rgba(15,23,42,.18)!important;
  backdrop-filter:blur(24px) saturate(160%)!important;
  -webkit-backdrop-filter:blur(24px) saturate(160%)!important;
}
html[data-theme=dark] .detail-panel{
  background:rgba(15,23,42,.78)!important;
  border-color:rgba(148,163,184,.22)!important;
}
.detail-head{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:14px!important;
  align-items:start!important;
  padding:18px 20px 14px!important;
  border-bottom:1px solid var(--line)!important;
}
.detail-head-main{
  min-width:0;
}
.detail-eyebrow{
  display:inline-flex!important;
  width:max-content;
  margin-bottom:6px;
  padding:4px 9px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)));
  color:#fff!important;
  font-size:11px!important;
  font-weight:900!important;
}
.detail-head b{
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  overflow:hidden!important;
  white-space:normal!important;
  line-height:1.22!important;
  font-size:21px!important;
  font-weight:900!important;
}
.detail-head span#detailKind{
  display:block!important;
  margin-top:6px!important;
  color:var(--muted)!important;
  font-size:12px!important;
  font-weight:800!important;
}
.detail-main{
  min-height:0;
  overflow:auto!important;
  display:grid!important;
  grid-template-columns:260px minmax(0,1fr);
  gap:18px;
  padding:18px 20px 96px;
}
.detail-visual{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.detail-cover-wrap{
  width:100%!important;
  max-height:none!important;
  aspect-ratio:1/1;
  border-radius:24px!important;
  overflow:hidden;
  position:relative;
  background:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.45), transparent 36%),
    linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important;
  box-shadow:0 20px 50px rgba(15,23,42,.14);
}
.detail-kind-video .detail-cover-wrap{
  aspect-ratio:16/9;
}
.detail-cover-img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block;
}
.detail-kind-audio .detail-cover-img{
  object-fit:cover!important;
}
.detail-cover-fallback{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.detail-quick-stats{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.detail-stat-card{
  min-width:0;
  padding:12px;
  border-radius:18px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(255,255,255,.7);
  box-shadow:0 12px 28px rgba(15,23,42,.06);
}
html[data-theme=dark] .detail-stat-card{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.12);
}
.detail-stat-card span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
}
.detail-stat-card b{
  display:block;
  margin-top:5px;
  font-size:17px;
  line-height:1.1;
  font-weight:950;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.detail-body{
  min-width:0;
  overflow:visible!important;
  padding:0!important;
  display:flex!important;
  flex-direction:column;
  gap:14px;
}
.detail-section{
  min-width:0;
  border-radius:22px;
  padding:14px;
  background:rgba(255,255,255,.5);
  border:1px solid rgba(255,255,255,.68);
}
html[data-theme=dark] .detail-section{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.12);
}
.detail-section-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.detail-section-title b{
  font-size:14px;
  font-weight:950;
}
.detail-section-title span{
  color:var(--muted);
  font-size:11px;
  font-weight:850;
}
.detail-desc{
  max-height:180px!important;
  overflow:auto!important;
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
}
.detail-fields{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px!important;
}
.detail-fields div{
  min-width:0;
  padding:10px 12px!important;
  border-radius:16px!important;
  background:rgba(255,255,255,.48)!important;
  border:1px solid rgba(255,255,255,.62)!important;
}
html[data-theme=dark] .detail-fields div{
  background:rgba(255,255,255,.06)!important;
  border-color:rgba(255,255,255,.1)!important;
}
.detail-fields span{
  display:block;
  color:var(--muted);
  font-size:11px;
  font-weight:900;
}
.detail-fields b{
  display:block;
  margin-top:4px;
  font-size:13px;
  line-height:1.25;
  font-weight:900;
  white-space:normal!important;
  overflow:hidden;
  text-overflow:ellipsis;
  word-break:break-word;
}
.detail-actions{
  position:absolute!important;
  left:0!important;
  right:0!important;
  bottom:0!important;
  padding:14px 20px calc(14px + env(safe-area-inset-bottom))!important;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.88) 24%)!important;
  border-top:1px solid var(--line)!important;
}
html[data-theme=dark] .detail-actions{
  background:linear-gradient(180deg,transparent,rgba(15,23,42,.92) 24%)!important;
}
.detail-action-group{
  display:flex!important;
  justify-content:flex-end!important;
  align-items:center!important;
  gap:10px!important;
}
.detail-action-btn{
  min-width:112px!important;
  height:44px!important;
  padding:0 16px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  border:1px solid rgba(255,255,255,.62)!important;
  background:rgba(255,255,255,.64)!important;
  color:var(--text)!important;
  text-decoration:none!important;
  font-size:13px!important;
  font-weight:950!important;
}
.detail-download-btn{
  background:linear-gradient(135deg,var(--theme-color),var(--theme-color-2,var(--theme-color)))!important;
  color:#fff!important;
  border-color:transparent!important;
}
.detail-action-btn svg{
  width:18px!important;
  height:18px!important;
}
@media(max-width:700px){
  .resource-detail{
    align-items:flex-end;
    padding:0 10px calc(10px + env(safe-area-inset-bottom));
  }
  .detail-panel{
    width:100%;
    max-height:min(88vh,var(--vvh,88vh));
    border-radius:26px 26px 0 0;
  }
  .detail-head{
    padding:16px 16px 12px!important;
  }
  .detail-head b{
    font-size:18px!important;
  }
  .detail-main{
    grid-template-columns:1fr;
    gap:14px;
    padding:14px 14px 104px;
  }
  .detail-cover-wrap{
    aspect-ratio:16/9;
    border-radius:22px!important;
  }
  .detail-kind-audio .detail-cover-wrap{
    aspect-ratio:1/1;
    width:min(210px,70vw)!important;
    margin:0 auto;
  }
  .detail-quick-stats{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .detail-fields{
    grid-template-columns:1fr 1fr!important;
  }
  .detail-action-group{
    width:100%;
  }
  .detail-action-btn{
    flex:1 1 0!important;
    min-width:0!important;
  }
}

