promptmanager / src /styles /iosStyles.css
samlax12's picture
Upload 55 files
e85fa50 verified
/* iOS风格全局样式 */
:root {
/* iOS 风格颜色 */
--ios-blue: #007AFF;
--ios-green: #4CD964;
--ios-red: #FF3B30;
--ios-orange: #FF9500;
--ios-yellow: #FFCC00;
--ios-purple: #5856D6;
--ios-pink: #FF2D55;
--ios-teal: #5AC8FA;
--ios-indigo: #5E5CE6;
/* 系统灰色 */
--ios-gray: #8E8E93;
--ios-gray2: #AEAEB2;
--ios-gray3: #C7C7CC;
--ios-gray4: #D1D1D6;
--ios-gray5: #E5E5EA;
--ios-gray6: #F2F2F7;
/* 背景色 */
--ios-background: #F2F2F7;
--ios-card-background: #FFFFFF;
/* 字体大小 */
--ios-font-small: 13px;
--ios-font-medium: 15px;
--ios-font-large: 17px;
--ios-font-xlarge: 20px;
--ios-font-xxlarge: 22px;
--ios-font-title: 28px;
/* 圆角 */
--ios-radius-small: 6px;
--ios-radius-medium: 10px;
--ios-radius-large: 14px;
/* 内边距 */
--ios-padding-small: 8px;
--ios-padding-medium: 16px;
--ios-padding-large: 24px;
/* 动画 */
--ios-transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
/* 全局样式重置 */
* {
margin: 0;
padding: 0;
box-sizing: border-box;
-webkit-tap-highlight-color: transparent;
font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'SF Pro Text', 'Helvetica Neue', Arial, sans-serif;
}
body {
background-color: var(--ios-background);
color: #000000;
padding-bottom: env(safe-area-inset-bottom);
}
/* iOS风格容器 */
.ios-container {
max-width: 1200px;
margin: 0 auto;
padding: var(--ios-padding-medium);
}
/* iOS风格页面标题 */
.ios-page-title {
font-size: var(--ios-font-title);
font-weight: 700;
margin-bottom: var(--ios-padding-medium);
}
/* iOS风格卡片 */
.ios-card {
background-color: var(--ios-card-background);
border-radius: var(--ios-radius-medium);
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
overflow: hidden;
margin-bottom: var(--ios-padding-medium);
transition: var(--ios-transition);
}
.ios-card:hover {
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
transform: translateY(-2px);
}
/* iOS风格按钮 */
.ios-button {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 44px;
padding: 0 var(--ios-padding-medium);
border-radius: 22px;
font-size: var(--ios-font-medium);
font-weight: 600;
text-align: center;
transition: var(--ios-transition);
cursor: pointer;
user-select: none;
border: none;
outline: none;
}
.ios-button-primary {
background-color: var(--ios-blue);
color: white;
}
.ios-button-primary:hover {
background-color: #0071EB;
}
.ios-button-secondary {
background-color: var(--ios-gray5);
color: #000000;
}
.ios-button-secondary:hover {
background-color: var(--ios-gray4);
}
.ios-button-danger {
background-color: var(--ios-red);
color: white;
}
.ios-button-danger:hover {
background-color: #FF2D30;
}
/* iOS风格输入框 */
.ios-input {
width: 100%;
height: 44px;
padding: 0 var(--ios-padding-medium);
font-size: var(--ios-font-medium);
background-color: var(--ios-gray6);
border-radius: var(--ios-radius-medium);
border: none;
transition: var(--ios-transition);
}
.ios-input:focus {
background-color: white;
box-shadow: 0 0 0 2px var(--ios-blue);
outline: none;
}
/* iOS风格文本域 */
.ios-textarea {
width: 100%;
min-height: 100px;
padding: var(--ios-padding-medium);
font-size: var(--ios-font-medium);
background-color: var(--ios-gray6);
border-radius: var(--ios-radius-medium);
border: none;
resize: vertical;
transition: var(--ios-transition);
}
.ios-textarea:focus {
background-color: white;
box-shadow: 0 0 0 2px var(--ios-blue);
outline: none;
}
/* iOS风格标签 */
.ios-tag {
display: inline-flex;
align-items: center;
height: 24px;
padding: 0 10px;
font-size: var(--ios-font-small);
font-weight: 500;
border-radius: 12px;
margin-right: 8px;
margin-bottom: 8px;
}
/* iOS风格导航栏 */
.ios-navbar {
display: flex;
align-items: center;
height: 44px;
padding: 0 var(--ios-padding-medium);
background-color: rgba(255, 255, 255, 0.8);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
position: sticky;
top: 0;
z-index: 100;
border-bottom: 1px solid var(--ios-gray5);
}
.ios-navbar-title {
font-size: var(--ios-font-large);
font-weight: 600;
flex: 1;
text-align: center;
}
.ios-navbar-button {
font-size: var(--ios-font-medium);
font-weight: 500;
color: var(--ios-blue);
background: none;
border: none;
cursor: pointer;
padding: 0 10px;
height: 100%;
display: flex;
align-items: center;
}
/* iOS风格底部工具栏 */
.ios-toolbar {
display: flex;
align-items: center;
justify-content: space-around;
height: 50px;
background-color: rgba(255, 255, 255, 0.8);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
position: fixed;
bottom: 0;
left: 0;
right: 0;
border-top: 1px solid var(--ios-gray5);
padding-bottom: env(safe-area-inset-bottom);
z-index: 100;
}
.ios-toolbar-item {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
height: 100%;
font-size: 10px;
color: var(--ios-gray);
}
.ios-toolbar-item.active {
color: var(--ios-blue);
}
/* iOS风格列表 */
.ios-list {
background-color: white;
border-radius: var(--ios-radius-medium);
overflow: hidden;
}
.ios-list-item {
display: flex;
align-items: center;
min-height: 44px;
padding: 0 var(--ios-padding-medium);
border-bottom: 1px solid var(--ios-gray5);
}
.ios-list-item:last-child {
border-bottom: none;
}
.ios-list-item-content {
flex: 1;
}
.ios-list-item-title {
font-size: var(--ios-font-medium);
font-weight: 400;
}
.ios-list-item-subtitle {
font-size: var(--ios-font-small);
color: var(--ios-gray);
margin-top: 2px;
}
.ios-list-item-chevron {
color: var(--ios-gray3);
margin-left: var(--ios-padding-small);
}
/* iOS风格分割线 */
.ios-divider {
height: 1px;
background-color: var(--ios-gray5);
margin: var(--ios-padding-medium) 0;
}
/* iOS风格开关 */
.ios-switch {
position: relative;
display: inline-block;
width: 51px;
height: 31px;
}
.ios-switch input {
opacity: 0;
width: 0;
height: 0;
}
.ios-switch-slider {
position: absolute;
cursor: pointer;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: var(--ios-gray4);
border-radius: 34px;
transition: var(--ios-transition);
}
.ios-switch-slider:before {
position: absolute;
content: "";
height: 27px;
width: 27px;
left: 2px;
bottom: 2px;
background-color: white;
border-radius: 50%;
transition: var(--ios-transition);
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}
.ios-switch input:checked + .ios-switch-slider {
background-color: var(--ios-green);
}
.ios-switch input:checked + .ios-switch-slider:before {
transform: translateX(20px);
}
/* iOS风格模态框 */
.ios-modal-backdrop {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: rgba(0, 0, 0, 0.5);
display: flex;
align-items: center;
justify-content: center;
z-index: 1000;
opacity: 0;
pointer-events: none;
transition: var(--ios-transition);
}
.ios-modal-backdrop.open {
opacity: 1;
pointer-events: auto;
}
.ios-modal {
width: 90%;
max-width: 500px;
background-color: white;
border-radius: var(--ios-radius-large);
overflow: hidden;
transform: scale(0.9);
transition: var(--ios-transition);
}
.ios-modal-backdrop.open .ios-modal {
transform: scale(1);
}
.ios-modal-header {
padding: var(--ios-padding-medium);
text-align: center;
border-bottom: 1px solid var(--ios-gray5);
}
.ios-modal-title {
font-size: var(--ios-font-large);
font-weight: 600;
}
.ios-modal-body {
padding: var(--ios-padding-medium);
max-height: 50vh;
overflow-y: auto;
}
.ios-modal-footer {
display: flex;
border-top: 1px solid var(--ios-gray5);
}
.ios-modal-button {
flex: 1;
height: 44px;
border: none;
background: none;
font-size: var(--ios-font-medium);
font-weight: 500;
cursor: pointer;
transition: var(--ios-transition);
}
.ios-modal-button:not(:last-child) {
border-right: 1px solid var(--ios-gray5);
}
.ios-modal-button-primary {
color: var(--ios-blue);
}
.ios-modal-button-primary:hover {
background-color: rgba(0, 122, 255, 0.1);
}
.ios-modal-button-danger {
color: var(--ios-red);
}
.ios-modal-button-danger:hover {
background-color: rgba(255, 59, 48, 0.1);
}
/* iOS风格加载指示器 */
.ios-loader {
display: inline-block;
width: 20px;
height: 20px;
border: 2px solid rgba(0, 122, 255, 0.3);
border-radius: 50%;
border-top-color: var(--ios-blue);
animation: ios-spin 1s linear infinite;
}
@keyframes ios-spin {
to {
transform: rotate(360deg);
}
}
/* iOS风格空状态 */
.ios-empty-state {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
min-height: 200px;
padding: var(--ios-padding-large);
text-align: center;
}
.ios-empty-state-icon {
font-size: 48px;
color: var(--ios-gray3);
margin-bottom: var(--ios-padding-medium);
}
.ios-empty-state-title {
font-size: var(--ios-font-large);
font-weight: 600;
margin-bottom: 8px;
}
.ios-empty-state-text {
font-size: var(--ios-font-medium);
color: var(--ios-gray);
max-width: 250px;
}