mirror of
https://github.com/jxxghp/MoviePilot-Frontend.git
synced 2026-06-16 21:20:45 +08:00
931 lines
25 KiB
SCSS
931 lines
25 KiB
SCSS
/* stylelint-disable no-duplicate-selectors */
|
||
/* stylelint-disable scss/at-rule-no-unknown */
|
||
/* stylelint-disable no-descending-specificity */
|
||
// 公共样式 - 所有主题都需要
|
||
@tailwind base;
|
||
@tailwind components;
|
||
@tailwind utilities;
|
||
|
||
html.v-overlay-scroll-blocked {
|
||
position: static;
|
||
}
|
||
|
||
html.v-overlay-scroll-blocked body {
|
||
position: fixed;
|
||
overflow: hidden;
|
||
inset: 0;
|
||
inset-block-start: var(--v-body-scroll-y);
|
||
}
|
||
|
||
@mixin hide-scrollbar {
|
||
-ms-overflow-style: none;
|
||
scrollbar-width: none;
|
||
|
||
&::-webkit-scrollbar {
|
||
display: none;
|
||
}
|
||
}
|
||
|
||
@media (width <= 768px) {
|
||
html,body {
|
||
@include hide-scrollbar;
|
||
}
|
||
}
|
||
|
||
// 全局卡片外观 token:圆角和阴影在主题定制器中即时切换。
|
||
html {
|
||
--app-theme-surface-radius: 8px;
|
||
--app-surface-radius: var(--app-theme-surface-radius);
|
||
--app-field-radius: var(--app-theme-surface-radius);
|
||
--app-surface-border-opacity: 0.06;
|
||
--app-surface-border: 1px solid rgba(var(--v-theme-on-surface), var(--app-surface-border-opacity));
|
||
--app-shadow-rgb: 15, 23, 42;
|
||
--app-card-rest-shadow: none;
|
||
--app-card-hover-shadow: none;
|
||
--app-fab-shadow: none;
|
||
--app-fab-shadow-strong: none;
|
||
--app-fab-shadow-hover: none;
|
||
--app-fab-shadow-strong-hover: none;
|
||
--app-fab-shadow-active: none;
|
||
--app-overlay-shadow: none;
|
||
--app-surface-shadow: none;
|
||
--app-surface-hover-shadow: none;
|
||
}
|
||
|
||
html[data-theme-skin='bordered'] {
|
||
--app-surface-border-opacity: 0.1;
|
||
}
|
||
|
||
html[data-theme-radius='small'] {
|
||
--app-theme-surface-radius: 4px;
|
||
}
|
||
|
||
html[data-theme-radius='large'] {
|
||
--app-theme-surface-radius: 12px;
|
||
}
|
||
|
||
html[data-theme-radius='extra'] {
|
||
--app-theme-surface-radius: 16px;
|
||
}
|
||
|
||
html[data-theme-radius='huge'] {
|
||
--app-theme-surface-radius: 24px;
|
||
}
|
||
|
||
html[data-theme='dark'],
|
||
html[data-theme='purple'],
|
||
html[data-theme='transparent'] {
|
||
--app-shadow-rgb: 0, 0, 0;
|
||
}
|
||
|
||
html[data-theme-shadow='low'] {
|
||
--app-card-rest-shadow: 0 10px 24px rgba(var(--app-shadow-rgb), 0.06), 0 2px 8px rgba(var(--app-shadow-rgb), 0.04);
|
||
--app-card-hover-shadow: 0 14px 30px rgba(var(--app-shadow-rgb), 0.08), 0 4px 12px rgba(var(--app-shadow-rgb), 0.05);
|
||
--app-fab-shadow: 0 16px 34px rgba(var(--app-shadow-rgb), 0.16), 0 6px 16px rgba(var(--app-shadow-rgb), 0.1);
|
||
--app-fab-shadow-strong: 0 20px 40px rgba(var(--app-shadow-rgb), 0.2), 0 8px 18px rgba(var(--app-shadow-rgb), 0.12);
|
||
--app-fab-shadow-hover: 0 22px 42px rgba(var(--app-shadow-rgb), 0.22), 0 8px 18px rgba(var(--app-shadow-rgb), 0.12);
|
||
--app-fab-shadow-strong-hover: 0 26px 46px rgba(var(--app-shadow-rgb), 0.24), 0 10px 22px rgba(var(--app-shadow-rgb), 0.14);
|
||
--app-fab-shadow-active: 0 10px 22px rgba(var(--app-shadow-rgb), 0.16), 0 3px 8px rgba(var(--app-shadow-rgb), 0.1);
|
||
--app-overlay-shadow: 0 18px 42px rgba(var(--app-shadow-rgb), 0.14), 0 6px 18px rgba(var(--app-shadow-rgb), 0.08);
|
||
--app-surface-shadow: 0 10px 24px rgba(var(--app-shadow-rgb), 0.07), 0 2px 8px rgba(var(--app-shadow-rgb), 0.05);
|
||
--app-surface-hover-shadow: 0 14px 30px rgba(var(--app-shadow-rgb), 0.09), 0 4px 12px rgba(var(--app-shadow-rgb), 0.06);
|
||
}
|
||
|
||
html[data-theme-shadow='medium'] {
|
||
--app-card-rest-shadow: 0 14px 32px rgba(var(--app-shadow-rgb), 0.09), 0 4px 12px rgba(var(--app-shadow-rgb), 0.06);
|
||
--app-card-hover-shadow: 0 18px 40px rgba(var(--app-shadow-rgb), 0.11), 0 6px 16px rgba(var(--app-shadow-rgb), 0.07);
|
||
--app-fab-shadow: 0 18px 40px rgba(var(--app-shadow-rgb), 0.2), 0 7px 18px rgba(var(--app-shadow-rgb), 0.12);
|
||
--app-fab-shadow-strong: 0 24px 48px rgba(var(--app-shadow-rgb), 0.24), 0 10px 24px rgba(var(--app-shadow-rgb), 0.14);
|
||
--app-fab-shadow-hover: 0 24px 46px rgba(var(--app-shadow-rgb), 0.24), 0 10px 22px rgba(var(--app-shadow-rgb), 0.14);
|
||
--app-fab-shadow-strong-hover: 0 30px 54px rgba(var(--app-shadow-rgb), 0.28), 0 12px 28px rgba(var(--app-shadow-rgb), 0.16);
|
||
--app-fab-shadow-active: 0 12px 26px rgba(var(--app-shadow-rgb), 0.18), 0 4px 10px rgba(var(--app-shadow-rgb), 0.12);
|
||
--app-overlay-shadow: 0 24px 56px rgba(var(--app-shadow-rgb), 0.18), 0 10px 24px rgba(var(--app-shadow-rgb), 0.1);
|
||
--app-surface-shadow: 0 14px 32px rgba(var(--app-shadow-rgb), 0.1), 0 4px 12px rgba(var(--app-shadow-rgb), 0.07);
|
||
--app-surface-hover-shadow: 0 18px 40px rgba(var(--app-shadow-rgb), 0.12), 0 6px 16px rgba(var(--app-shadow-rgb), 0.08);
|
||
}
|
||
|
||
html[data-theme-shadow='high'] {
|
||
--app-card-rest-shadow: 0 18px 40px rgba(var(--app-shadow-rgb), 0.12), 0 6px 18px rgba(var(--app-shadow-rgb), 0.08);
|
||
--app-card-hover-shadow: 0 22px 50px rgba(var(--app-shadow-rgb), 0.15), 0 8px 22px rgba(var(--app-shadow-rgb), 0.1);
|
||
--app-fab-shadow: 0 22px 48px rgba(var(--app-shadow-rgb), 0.24), 0 10px 24px rgba(var(--app-shadow-rgb), 0.14);
|
||
--app-fab-shadow-strong: 0 28px 58px rgba(var(--app-shadow-rgb), 0.3), 0 12px 30px rgba(var(--app-shadow-rgb), 0.18);
|
||
--app-fab-shadow-hover: 0 28px 56px rgba(var(--app-shadow-rgb), 0.28), 0 12px 28px rgba(var(--app-shadow-rgb), 0.17);
|
||
--app-fab-shadow-strong-hover: 0 34px 64px rgba(var(--app-shadow-rgb), 0.34), 0 14px 32px rgba(var(--app-shadow-rgb), 0.2);
|
||
--app-fab-shadow-active: 0 14px 30px rgba(var(--app-shadow-rgb), 0.22), 0 5px 12px rgba(var(--app-shadow-rgb), 0.14);
|
||
--app-overlay-shadow: 0 30px 70px rgba(var(--app-shadow-rgb), 0.22), 0 14px 30px rgba(var(--app-shadow-rgb), 0.12);
|
||
--app-surface-shadow: 0 18px 40px rgba(var(--app-shadow-rgb), 0.13), 0 6px 18px rgba(var(--app-shadow-rgb), 0.09);
|
||
--app-surface-hover-shadow: 0 22px 50px rgba(var(--app-shadow-rgb), 0.16), 0 8px 22px rgba(var(--app-shadow-rgb), 0.11);
|
||
}
|
||
|
||
// 进度条样式
|
||
#nprogress .bar {
|
||
background: rgb(var(--v-theme-primary)) !important;
|
||
inset-block-start: env(safe-area-inset-top) !important;
|
||
}
|
||
|
||
#nprogress .peg {
|
||
box-shadow: 0 0 10px rgb(var(--v-theme-primary)), 0 0 5px rgb(var(--v-theme-primary)) !important;
|
||
inline-size: 5px;
|
||
transform: rotate(0deg) translate(0, 0);
|
||
}
|
||
|
||
// 卡片高度匹配
|
||
.match-height.v-row {
|
||
.v-card {
|
||
block-size: 100%;
|
||
}
|
||
}
|
||
|
||
// 统一系统内主要 surface 的边框、圆角和阴影,局部组件通过变量覆盖。
|
||
.app-surface,
|
||
.v-card,
|
||
.v-sheet,
|
||
.v-list,
|
||
.v-expansion-panel {
|
||
border: var(--app-surface-border);
|
||
border-radius: var(--app-surface-radius) !important;
|
||
box-shadow: var(--app-surface-shadow) !important;
|
||
transition: border-color 0.2s ease, border-radius 0.2s ease, box-shadow 0.2s ease;
|
||
}
|
||
|
||
// 底部导航卡片原本就是胶囊形态,不参与主题圆角切换。
|
||
.footer-nav-card.v-card {
|
||
--app-surface-radius: 9999px;
|
||
}
|
||
|
||
@media (hover: hover) {
|
||
.app-surface:hover,
|
||
.v-card:hover,
|
||
.v-sheet:hover,
|
||
.v-list:hover,
|
||
.v-expansion-panel:hover {
|
||
box-shadow: var(--app-surface-hover-shadow) !important;
|
||
}
|
||
}
|
||
|
||
// 局部需要退出全局 surface 风格时使用这些工具类,避免再用 !important 抢优先级。
|
||
.app-surface-borderless {
|
||
--app-surface-border: 0 solid transparent;
|
||
}
|
||
|
||
.app-surface-flat,
|
||
.app-surface-flat:hover {
|
||
--app-surface-hover-shadow: none;
|
||
--app-surface-shadow: none;
|
||
}
|
||
|
||
.app-surface-square {
|
||
--app-surface-radius: 0;
|
||
}
|
||
|
||
.app-surface-shape {
|
||
border-radius: var(--app-surface-radius);
|
||
}
|
||
|
||
// 统一文本输入、下拉框、文本域等有框表单控件的圆角,显式 rounded 控件保留特殊形态。
|
||
.v-field:not(.v-field--variant-plain, .v-field--variant-underlined, .v-field--rounded, [class^='rounded-'], [class*=' rounded-']) {
|
||
border-radius: var(--app-field-radius);
|
||
transition: border-radius 0.2s ease, box-shadow 0.2s ease;
|
||
}
|
||
|
||
.v-btn:not(.v-btn--variant-plain, .v-btn--variant-text) {
|
||
box-shadow: var(--app-surface-shadow) !important;
|
||
transition: box-shadow 0.2s ease;
|
||
}
|
||
|
||
.v-btn:not(.v-btn--rounded, [class^='rounded-'], [class*=' rounded-']) {
|
||
border-radius: var(--app-surface-radius);
|
||
transition: border-radius 0.2s ease;
|
||
}
|
||
|
||
// 只给外层 surface 加边框和阴影,卡片内部的列表、表格等子组件保持平面,避免层级噪声。
|
||
.v-card .v-list:not(.app-surface),
|
||
.v-card .v-sheet:not(.app-surface),
|
||
.v-card .v-table:not(.app-surface),
|
||
.v-card .v-expansion-panel:not(.app-surface),
|
||
.v-card .v-window:not(.app-surface),
|
||
.v-card .v-toolbar:not(.app-surface),
|
||
.v-card .v-navigation-drawer:not(.app-surface),
|
||
.v-card .v-stepper:not(.app-surface),
|
||
.v-card .v-alert:not(.app-surface),
|
||
.v-card .v-avatar,
|
||
.v-card .v-chip {
|
||
--app-surface-hover-shadow: none;
|
||
--app-surface-shadow: none;
|
||
}
|
||
|
||
// 弹窗内容里的嵌套卡片默认保持平面;弹窗自身仍由 overlay 规则控制阴影和圆角。
|
||
.v-dialog > .v-overlay__content > .v-card :where(.v-card, .v-sheet, .v-list, .v-table, .v-expansion-panel):not(.app-card-colorful),
|
||
.v-dialog > .v-overlay__content > .v-sheet :where(.v-card, .v-sheet, .v-list, .v-table, .v-expansion-panel):not(.app-card-colorful) {
|
||
--app-surface-hover-shadow: none;
|
||
--app-surface-shadow: none;
|
||
}
|
||
|
||
// 主题定制器的 bordered 皮肤:保持原布局密度,只给非 Vuetify 外壳增加清晰边界。
|
||
html[data-theme-skin='bordered'] {
|
||
.layout-vertical-nav {
|
||
border: var(--app-surface-border);
|
||
}
|
||
|
||
.navbar-content-container {
|
||
border-block-end: var(--app-surface-border);
|
||
}
|
||
|
||
.layout-vertical-nav {
|
||
border-block: 0;
|
||
border-inline-start: 0;
|
||
}
|
||
}
|
||
|
||
// 应用类信息卡片:固定右侧媒体槽位,避免图片被左侧文字挤压变形。
|
||
.app-card-shell {
|
||
position: relative;
|
||
block-size: 100%;
|
||
}
|
||
|
||
// 设置项强调卡片:复用通知模板入口的弱强调条、轻渐变与悬浮反馈。
|
||
.app-card-colorful {
|
||
overflow: hidden;
|
||
background:
|
||
linear-gradient(
|
||
135deg,
|
||
rgba(var(--app-card-accent-rgb), var(--app-card-accent-start-opacity)),
|
||
rgba(var(--app-card-accent-end-rgb), var(--app-card-accent-end-opacity)) 46%,
|
||
rgba(var(--v-theme-surface), 0) 76%
|
||
),
|
||
rgba(var(--v-theme-surface), var(--app-card-surface-opacity));
|
||
box-shadow: var(--app-card-rest-shadow);
|
||
color: rgb(var(--v-theme-on-surface));
|
||
|
||
--app-card-accent-rgb: var(--v-theme-primary);
|
||
--app-card-accent-end-rgb: var(--app-card-accent-rgb);
|
||
--app-card-accent-start-opacity: 0.025;
|
||
--app-card-accent-end-opacity: 0.012;
|
||
--app-card-border-opacity: 0.08;
|
||
--app-card-hover-border-opacity: 0.16;
|
||
--app-card-stripe-opacity: 0.22;
|
||
--app-card-surface-opacity: 0.92;
|
||
--app-surface-border: 1px solid rgba(var(--app-card-accent-rgb), var(--app-card-border-opacity));
|
||
--app-surface-hover-shadow: var(--app-card-hover-shadow);
|
||
--app-surface-shadow: var(--app-card-rest-shadow);
|
||
|
||
transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
|
||
}
|
||
|
||
.app-card-colorful::before {
|
||
position: absolute;
|
||
background: rgb(var(--app-card-accent-rgb));
|
||
block-size: 100%;
|
||
content: "";
|
||
inline-size: 0.125rem;
|
||
inset-block: 0;
|
||
inset-inline-start: 0;
|
||
opacity: var(--app-card-stripe-opacity);
|
||
pointer-events: none;
|
||
}
|
||
|
||
.app-card-colorful:hover {
|
||
--app-surface-border: 1px solid rgba(var(--app-card-accent-rgb), var(--app-card-hover-border-opacity));
|
||
}
|
||
|
||
.app-card-colorful:focus-visible {
|
||
outline: 2px solid rgba(var(--app-card-accent-rgb), 0.7);
|
||
outline-offset: 3px;
|
||
}
|
||
|
||
.app-card-color-probe {
|
||
position: absolute;
|
||
block-size: 3rem;
|
||
inline-size: 3rem;
|
||
inset-block-start: 0;
|
||
inset-inline-start: 0;
|
||
opacity: 0;
|
||
pointer-events: none;
|
||
}
|
||
|
||
html[data-theme="transparent"] .app-card-colorful,
|
||
.v-theme--transparent .app-card-colorful {
|
||
backdrop-filter: blur(var(--transparent-blur, 10px));
|
||
|
||
--app-card-accent-start-opacity: 0.018;
|
||
--app-card-accent-end-opacity: 0.01;
|
||
--app-card-border-opacity: 0;
|
||
--app-card-hover-border-opacity: 0;
|
||
--app-card-stripe-opacity: 0.16;
|
||
--app-card-surface-opacity: var(--transparent-opacity-light, 0.2);
|
||
--app-surface-border: 0 solid transparent;
|
||
}
|
||
|
||
// 保证卡片右上角的浮动操作区始终高于可点击的卡片内容层,避免误触发详情打开。
|
||
.app-card-top-action {
|
||
z-index: 2;
|
||
}
|
||
|
||
.app-card-summary {
|
||
position: relative;
|
||
display: flex;
|
||
overflow: hidden;
|
||
align-items: stretch;
|
||
justify-content: flex-start;
|
||
block-size: 7.5rem;
|
||
min-block-size: 7.5rem;
|
||
}
|
||
|
||
.app-card-summary__content {
|
||
position: relative;
|
||
z-index: 1;
|
||
display: flex;
|
||
flex: 1 1 auto;
|
||
flex-direction: column;
|
||
justify-content: center;
|
||
min-inline-size: 0;
|
||
padding-block: 0.25rem 0.5rem;
|
||
row-gap: 0.25rem;
|
||
}
|
||
|
||
.app-card-summary__title-row {
|
||
display: flex;
|
||
align-items: flex-start;
|
||
column-gap: 0.25rem;
|
||
min-inline-size: 0;
|
||
}
|
||
|
||
.app-card-summary__title-row > .v-badge {
|
||
flex-shrink: 0;
|
||
align-self: center;
|
||
}
|
||
|
||
.app-card-summary__subtitle,
|
||
.app-card-summary__meta-item {
|
||
overflow: hidden;
|
||
min-inline-size: 0;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
}
|
||
|
||
.app-card-summary__title {
|
||
display: -webkit-box;
|
||
overflow: hidden;
|
||
flex: 0 0 auto;
|
||
-webkit-box-orient: vertical;
|
||
-webkit-line-clamp: 2;
|
||
line-clamp: 2;
|
||
line-height: 1.35;
|
||
max-block-size: calc(1.35em * 2);
|
||
min-inline-size: 0;
|
||
text-overflow: ellipsis;
|
||
white-space: normal;
|
||
word-break: break-word;
|
||
}
|
||
|
||
.app-card-summary__title-row .app-card-summary__title {
|
||
flex: 1 1 auto;
|
||
}
|
||
|
||
.app-card-summary__meta {
|
||
display: flex;
|
||
overflow: hidden;
|
||
align-items: center;
|
||
column-gap: 0.5rem;
|
||
min-block-size: 1.5rem;
|
||
min-inline-size: 0;
|
||
}
|
||
|
||
.app-card-summary--single-action .app-card-summary__content {
|
||
padding-inline-end: 3.75rem;
|
||
}
|
||
|
||
.app-card-summary--double-action .app-card-summary__content {
|
||
padding-inline-end: 5rem;
|
||
}
|
||
|
||
.app-card-summary--title-subtitle {
|
||
padding-block: 0.75rem !important;
|
||
}
|
||
|
||
.app-card-summary--title-subtitle .app-card-summary__content {
|
||
justify-content: space-between;
|
||
block-size: 100%;
|
||
padding-block: 0;
|
||
}
|
||
|
||
.app-card-summary--title-subtitle .app-card-summary__title {
|
||
flex: 0 1 auto;
|
||
}
|
||
|
||
.app-card-summary--title-subtitle .app-card-summary__subtitle {
|
||
flex-shrink: 0;
|
||
}
|
||
|
||
.app-card-summary__media {
|
||
position: absolute;
|
||
z-index: 0;
|
||
display: flex;
|
||
align-items: flex-end;
|
||
justify-content: flex-end;
|
||
inset-block-end: 0.75rem;
|
||
inset-inline-end: 1rem;
|
||
pointer-events: none;
|
||
}
|
||
|
||
.app-card-summary--single-action .app-card-summary__media,
|
||
.app-card-summary--double-action .app-card-summary__media {
|
||
inset-inline-end: 1rem;
|
||
}
|
||
|
||
.app-card-summary__image {
|
||
flex-shrink: 0;
|
||
block-size: 3.5rem;
|
||
inline-size: 3.5rem;
|
||
max-block-size: 3.5rem;
|
||
max-inline-size: 3.5rem;
|
||
min-block-size: 3.5rem;
|
||
min-inline-size: 3.5rem;
|
||
}
|
||
|
||
.app-card-summary__image .v-img__img {
|
||
object-fit: contain;
|
||
}
|
||
|
||
// Toast通知样式
|
||
.Vue-Toastification__container {
|
||
z-index: 2500;
|
||
margin-block: env(safe-area-inset-top) env(safe-area-inset-bottom);
|
||
}
|
||
|
||
@media only screen and (width <= 600px){
|
||
.Vue-Toastification__container {
|
||
inline-size: 100vw;
|
||
padding-block: 4.5rem;
|
||
padding-inline: 1rem;
|
||
}
|
||
|
||
.Vue-Toastification__toast {
|
||
border-radius: 8px;
|
||
}
|
||
}
|
||
|
||
// 对话框样式
|
||
.v-dialog > .v-overlay__content > .v-card > .v-card-item {
|
||
padding: 16px;
|
||
}
|
||
|
||
// 路由过渡动画
|
||
.fade-slide-leave-active,
|
||
.fade-slide-enter-active {
|
||
transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
|
||
}
|
||
|
||
.fade-slide-enter-from {
|
||
opacity: 0;
|
||
transform: translateX(20px);
|
||
}
|
||
|
||
.fade-slide-leave-to {
|
||
opacity: 0;
|
||
transform: translateX(20px);
|
||
}
|
||
|
||
// 网格布局样式
|
||
.grid-info-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
|
||
padding-block-end: 1rem;
|
||
}
|
||
|
||
.grid-site-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
|
||
padding-block-end: 1rem;
|
||
}
|
||
|
||
.grid-media-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(9rem, 1fr));
|
||
}
|
||
|
||
.grid-backdrop-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
|
||
}
|
||
|
||
.grid-torrent-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
|
||
}
|
||
|
||
.grid-plugin-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
|
||
}
|
||
|
||
.grid-downloading-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
|
||
}
|
||
|
||
.grid-directory-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(min(100%, 24rem), 1fr));
|
||
}
|
||
|
||
.grid-filterrule-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
|
||
}
|
||
|
||
.grid-customrule-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr));
|
||
}
|
||
|
||
.grid-subscribe-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
|
||
}
|
||
|
||
.grid-user-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
|
||
}
|
||
|
||
.grid-app-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
|
||
}
|
||
|
||
.grid-workflow-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
|
||
}
|
||
|
||
.grid-workflow-share-card {
|
||
grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
|
||
}
|
||
|
||
// 文本样式
|
||
.text-moviepilot {
|
||
background-clip: text;
|
||
background-image: linear-gradient(to bottom right,var(--tw-gradient-stops));
|
||
color: transparent;
|
||
|
||
--tw-gradient-from: #818cf8;
|
||
--tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to);
|
||
--tw-gradient-to: #c084fc;
|
||
}
|
||
|
||
.text-shadow {
|
||
text-shadow: 1px 1px #777;
|
||
}
|
||
|
||
// 滑块标题样式
|
||
.slider-header {
|
||
position: relative;
|
||
display: flex;
|
||
}
|
||
|
||
.slider-title {
|
||
display: inline-flex;
|
||
align-items: center;
|
||
font-size: 1.25rem;
|
||
font-weight: 700;
|
||
line-height: 1.75rem;
|
||
}
|
||
|
||
@media (width >= 640px){
|
||
.slider-title {
|
||
overflow: hidden;
|
||
font-size: 1.5rem;
|
||
line-height: 2.25rem;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
}
|
||
}
|
||
|
||
// 滚动条样式
|
||
::-webkit-scrollbar {
|
||
block-size: 4px;
|
||
inline-size: 4px;
|
||
opacity: 0;
|
||
transition: opacity 0.3s;
|
||
}
|
||
|
||
::-webkit-scrollbar-thumb {
|
||
border-radius: 2px;
|
||
background: rgb(var(--v-theme-perfect-scrollbar-thumb));
|
||
box-shadow: inset 0 0 10px rgba(0,0,0,20%);
|
||
|
||
@media(hover){
|
||
&:hover{
|
||
background: #a1a1a1;
|
||
}
|
||
}
|
||
}
|
||
|
||
*:hover::-webkit-scrollbar {
|
||
opacity: 1;
|
||
}
|
||
|
||
*:active::-webkit-scrollbar {
|
||
opacity: 1;
|
||
}
|
||
|
||
// 组件样式
|
||
.v-alert--variant-elevated, .v-alert--variant-flat {
|
||
border-radius: var(--app-surface-radius);
|
||
background: rgb(var(--v-table-header-background));
|
||
color: rgba(var(--v-theme-on-surface), var(--v-high-emphasis-opacity));
|
||
}
|
||
|
||
.Vue-Toastification__toast {
|
||
border-radius: var(--app-surface-radius);
|
||
box-shadow: var(--app-overlay-shadow);
|
||
}
|
||
|
||
.backdrop-blur {
|
||
--tw-backdrop-blur: blur(8px)!important;
|
||
|
||
backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)!important;
|
||
}
|
||
|
||
.v-toolbar{
|
||
background: rgb(var(--v-table-header-background));
|
||
}
|
||
|
||
.v-divider {
|
||
border-color: rgba(var(--v-theme-on-background), var(--v-selected-opacity));
|
||
opacity:0.75;
|
||
}
|
||
|
||
:root {
|
||
--theme-customizer-fab-offset: 420px;
|
||
}
|
||
|
||
// 紧凑型悬浮操作按钮
|
||
.compact-fab-stack {
|
||
position: fixed;
|
||
z-index: 1100;
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: flex-end;
|
||
gap: 0.75rem;
|
||
inset-block-end: max(1rem, calc(env(safe-area-inset-bottom) + 1rem));
|
||
inset-inline-end: max(1rem, calc(env(safe-area-inset-right) + 1rem));
|
||
pointer-events: none;
|
||
transition: inset-inline-end 0.2s ease;
|
||
}
|
||
|
||
.compact-fab-stack > * {
|
||
pointer-events: auto;
|
||
}
|
||
|
||
.compact-fab-stack--history {
|
||
inset-block-end: max(4.5rem, calc(env(safe-area-inset-bottom) + 4.5rem));
|
||
}
|
||
|
||
.compact-fab.v-fab {
|
||
display: inline-flex;
|
||
overflow: visible;
|
||
flex: none;
|
||
min-inline-size: 0 !important;
|
||
pointer-events: auto;
|
||
}
|
||
|
||
.compact-fab .v-fab__container {
|
||
position: static;
|
||
display: inline-flex;
|
||
overflow: visible;
|
||
margin: 0 !important;
|
||
}
|
||
|
||
.compact-fab .v-btn {
|
||
border: 1px solid rgba(var(--v-theme-on-surface), 0.08);
|
||
backdrop-filter: blur(14px);
|
||
box-shadow: var(--app-fab-shadow);
|
||
opacity: 0.98;
|
||
transition:
|
||
transform 0.18s ease,
|
||
box-shadow 0.18s ease,
|
||
filter 0.18s ease,
|
||
opacity 0.18s ease;
|
||
}
|
||
|
||
.compact-fab--primary .v-btn {
|
||
block-size: 3rem !important;
|
||
box-shadow: var(--app-fab-shadow-strong);
|
||
inline-size: 3rem !important;
|
||
}
|
||
|
||
.compact-fab--secondary .v-btn {
|
||
block-size: 3rem !important;
|
||
inline-size: 3rem !important;
|
||
}
|
||
|
||
.compact-fab--primary .v-icon {
|
||
font-size: 1.75rem !important;
|
||
}
|
||
|
||
.compact-fab--secondary .v-icon {
|
||
font-size: 1.75rem !important;
|
||
}
|
||
|
||
@media (hover: hover) {
|
||
.compact-fab .v-btn:hover {
|
||
box-shadow: var(--app-fab-shadow-hover);
|
||
filter: saturate(1.03);
|
||
transform: translateY(-2px);
|
||
}
|
||
|
||
.compact-fab--primary .v-btn:hover {
|
||
box-shadow: var(--app-fab-shadow-strong-hover);
|
||
}
|
||
}
|
||
|
||
.compact-fab .v-btn:active {
|
||
box-shadow: var(--app-fab-shadow-active);
|
||
transform: translateY(0) scale(0.98);
|
||
}
|
||
|
||
@media (width <= 768px) {
|
||
.compact-fab-stack {
|
||
gap: 0.625rem;
|
||
inset-block-end: max(0.875rem, calc(env(safe-area-inset-bottom) + 0.875rem));
|
||
inset-inline-end: max(0.875rem, calc(env(safe-area-inset-right) + 0.875rem));
|
||
}
|
||
|
||
.compact-fab-stack--history {
|
||
inset-block-end: max(4rem, calc(env(safe-area-inset-bottom) + 4rem));
|
||
}
|
||
|
||
.compact-fab--primary .v-btn {
|
||
block-size: 3.5rem !important;
|
||
inline-size: 3.5rem !important;
|
||
}
|
||
|
||
.compact-fab--secondary .v-btn {
|
||
block-size: 3rem !important;
|
||
inline-size: 3rem !important;
|
||
}
|
||
}
|
||
|
||
@media (width >= 601px) {
|
||
html[data-theme-customizer-open='true'] .compact-fab-stack {
|
||
inset-inline-end: calc(var(--theme-customizer-fab-offset) + max(1rem, calc(env(safe-area-inset-right) + 1rem)));
|
||
}
|
||
|
||
html[data-theme-customizer-open='true'] .global-action-buttons {
|
||
inset-inline-end: calc(var(--theme-customizer-fab-offset) + 2rem);
|
||
}
|
||
}
|
||
|
||
@media (width >= 601px) and (width <= 768px) {
|
||
html[data-theme-customizer-open='true'] .compact-fab-stack {
|
||
inset-inline-end: calc(
|
||
var(--theme-customizer-fab-offset) + max(0.875rem, calc(env(safe-area-inset-right) + 0.875rem))
|
||
);
|
||
}
|
||
}
|
||
|
||
.apexcharts-title-text {
|
||
color: rgba(var(--v-theme-on-surface), var(--v-high-emphasis-opacity)) !important;
|
||
}
|
||
|
||
.v-tabs:not(.v-tabs-pill).v-tabs--horizontal {
|
||
border-block-end: 1px solid rgba(var(--v-border-color), var(--v-border-opacity));
|
||
}
|
||
|
||
.v-fab__container {
|
||
padding-block-end: env(safe-area-inset-bottom);
|
||
}
|
||
|
||
.card-cover-blurred::before {
|
||
position: absolute;
|
||
backdrop-filter: blur(2px);
|
||
background: rgba(29, 39, 59, 48%);
|
||
content: '';
|
||
inset: 0;
|
||
}
|
||
|
||
// 弹出层样式
|
||
.v-overlay__content .v-list{
|
||
overflow: hidden;
|
||
border-radius: var(--app-surface-radius);
|
||
backdrop-filter: blur(6px);
|
||
background-color: rgb(var(--v-theme-surface), 0.9);
|
||
box-shadow: none;
|
||
padding-inline: 0.5rem !important;
|
||
}
|
||
|
||
.v-overlay__content .v-card:not(.bg-primary){
|
||
border-radius: var(--app-surface-radius);
|
||
backdrop-filter: blur(8px);
|
||
background-color: rgb(var(--v-theme-surface), 0.95);
|
||
box-shadow: none;
|
||
|
||
.v-list, .v-table {
|
||
backdrop-filter: none;
|
||
background-color: transparent;
|
||
box-shadow: none;
|
||
}
|
||
}
|
||
|
||
.v-menu {
|
||
.v-list-item:hover {
|
||
background-color: rgba(var(--v-theme-on-surface), 0.04);
|
||
}
|
||
}
|
||
|
||
.v-btn.v-btn--icon {
|
||
transition: opacity 0.15s ease;
|
||
}
|
||
|
||
.v-btn.v-btn--icon:hover {
|
||
opacity: 0.85;
|
||
}
|
||
|
||
.v-overlay__content {
|
||
background: transparent;
|
||
box-shadow: none;
|
||
margin-block: env(safe-area-inset-top) env(safe-area-inset-bottom);
|
||
transition: opacity 0.2s ease, box-shadow 0.2s ease;
|
||
}
|
||
|
||
.v-menu > .v-overlay__content {
|
||
overflow: visible;
|
||
}
|
||
|
||
.v-dialog--fullscreen > .v-overlay__content > .v-card {
|
||
padding-block-end: calc(env(safe-area-inset-top) + env(safe-area-inset-bottom));
|
||
}
|
||
|
||
.v-dialog--fullscreen > .v-overlay__content {
|
||
border-radius: 0 !important;
|
||
box-shadow: none !important;
|
||
}
|
||
|
||
.v-dialog > .v-overlay__content {
|
||
margin-block: env(safe-area-inset-top) env(safe-area-inset-bottom);
|
||
}
|
||
|
||
.v-bottom-sheet > .v-bottom-sheet__content.v-overlay__content > .v-card {
|
||
padding-block-end: env(safe-area-inset-bottom);
|
||
}
|
||
|
||
.v-dialog > .v-overlay__content > .v-card,
|
||
.v-dialog > .v-overlay__content > .v-sheet,
|
||
.v-dialog > .v-overlay__content > form > .v-card,
|
||
.v-dialog > .v-overlay__content > form > .v-sheet,
|
||
.v-bottom-sheet > .v-bottom-sheet__content.v-overlay__content > .v-card,
|
||
.v-menu > .v-overlay__content > .v-card,
|
||
.v-menu > .v-overlay__content > .v-list {
|
||
box-shadow: var(--app-overlay-shadow) !important;
|
||
}
|
||
|
||
.v-dialog--fullscreen > .v-overlay__content > .v-card,
|
||
.v-dialog--fullscreen > .v-overlay__content > .v-sheet,
|
||
.v-dialog--fullscreen > .v-overlay__content > form > .v-card,
|
||
.v-dialog--fullscreen > .v-overlay__content > form > .v-sheet {
|
||
box-shadow: none !important;
|
||
}
|
||
|
||
// 小屏全屏弹窗仍贴底铺满,但顶部两个角跟随主题定制器圆角。
|
||
@media (width <= 600px) {
|
||
.v-dialog--fullscreen > .v-overlay__content {
|
||
overflow: hidden;
|
||
border-end-end-radius: 0 !important;
|
||
border-end-start-radius: 0 !important;
|
||
border-start-end-radius: var(--app-theme-surface-radius) !important;
|
||
border-start-start-radius: var(--app-theme-surface-radius) !important;
|
||
}
|
||
|
||
.v-dialog--fullscreen > .v-overlay__content > .v-card,
|
||
.v-dialog--fullscreen > .v-overlay__content > .v-sheet,
|
||
.v-dialog--fullscreen > .v-overlay__content > form > .v-card,
|
||
.v-dialog--fullscreen > .v-overlay__content > form > .v-sheet {
|
||
border-end-end-radius: 0 !important;
|
||
border-end-start-radius: 0 !important;
|
||
border-start-end-radius: var(--app-theme-surface-radius) !important;
|
||
border-start-start-radius: var(--app-theme-surface-radius) !important;
|
||
}
|
||
}
|
||
|
||
.settings-icon-button {
|
||
flex-shrink: 0;
|
||
border-radius: 0.95rem;
|
||
block-size: 2.75rem;
|
||
inline-size: 2.75rem;
|
||
margin-inline-start: 0.25rem;
|
||
min-inline-size: 2.75rem;
|
||
}
|
||
|
||
.settings-icon-button .v-icon {
|
||
font-size: 1.35rem;
|
||
}
|
||
|
||
@media (width <= 768px) {
|
||
.settings-icon-button {
|
||
border-radius: 0.825rem;
|
||
block-size: 2.5rem;
|
||
inline-size: 2.5rem;
|
||
min-inline-size: 2.5rem;
|
||
}
|
||
|
||
.settings-icon-button .v-icon {
|
||
font-size: 1.25rem;
|
||
}
|
||
}
|
||
|
||
.v-infinite-scroll__side {
|
||
padding: 0;
|
||
}
|
||
|
||
.v-menu .v-overlay__content {
|
||
box-shadow: none;
|
||
}
|