/* 重置默认样式 */
* {
    margin: 0; /* 清除默认外边距 */
    padding: 0; /* 清除默认内边距 */
    box-sizing: border-box; /* 使用边框盒模型 */
}

/* 基础样式设置 */
body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; /* 使用系统字体 */
    background: linear-gradient(135deg, #2c3e50 0%, #34495e 100%); /* 深色渐变背景 */
    height: 100vh; /* 全屏高度 */
    overflow: hidden; /* 隐藏滚动条 */
    user-select: none; /* 禁止文本选择 */
    -webkit-user-select: none; /* Safari禁止文本选择 */
    -webkit-touch-callout: none; /* 禁用iOS长按菜单 */
}

/* 主应用容器 */
.app-container {
    display: flex; /* 使用弹性布局 */
    flex-direction: column; /* 垂直排列 */
    height: 100vh; /* 全屏高度 */
    background: #ffffff; /* 白色背景 */
    border-radius: 12px 12px 0 0; /* 顶部圆角 */
    box-shadow: 0 -8px 25px rgba(0, 0, 0, 0.15); /* 阴影效果 */
    margin-top: 10px; /* 顶部间距 */
}

/* 顶部工具栏样式 - 紧凑单行布局 */
.toolbar {
    display: flex; /* 弹性布局 */
    justify-content: space-between; /* 两端对齐 */
    align-items: center; /* 垂直居中 */
    padding: 8px 15px; /* 减少内边距 */
    background: #f8f9fa; /* 浅灰背景 */
    border-bottom: 1px solid #e9ecef; /* 底部边框 */
    border-radius: 12px 12px 0 0; /* 顶部圆角 */
    min-height: 50px; /* 最小高度 */
    flex-wrap: nowrap; /* 不换行 */
}

/* 工具组容器 */
.tool-group {
    display: flex; /* 弹性布局 */
    align-items: center; /* 垂直居中 */
    gap: 6px; /* 减少元素间距 */
}

/* 工具按钮基础样式 - 更小尺寸 */
.tool-btn {
    width: 36px; /* 减小按钮宽度 */
    height: 36px; /* 减小按钮高度 */
    border: none; /* 无边框 */
    border-radius: 8px; /* 圆角 */
    background: #ffffff; /* 白色背景 */
    color: #6c757d; /* 灰色图标 */
    cursor: pointer; /* 鼠标指针 */
    transition: all 0.2s ease; /* 快速过渡动画 */
    display: flex; /* 弹性布局 */
    align-items: center; /* 垂直居中 */
    justify-content: center; /* 水平居中 */
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1); /* 减小阴影 */
}

/* 工具按钮SVG图标样式 */
.tool-btn svg {
    width: 16px; /* 减小图标宽度 */
    height: 16px; /* 减小图标高度 */
}

/* 工具按钮悬停效果 */
.tool-btn:hover {
    transform: translateY(-1px); /* 减小向上移动距离 */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15); /* 增强阴影 */
}

/* 激活状态的工具按钮 */
.tool-btn.active {
    background: #007bff; /* 蓝色背景 */
    color: #ffffff; /* 白色图标 */
    box-shadow: 0 2px 8px rgba(0, 123, 255, 0.3); /* 蓝色阴影 */
}

/* 清空按钮特殊样式 */
.clear-btn {
    background: #dc3545; /* 红色背景 */
    color: #ffffff; /* 白色图标 */
}

/* 清空按钮悬停效果 */
.clear-btn:hover {
    background: #c82333; /* 深红色背景 */
}

/* 画笔粗细控制容器 - 紧凑布局 */
.brush-size-container {
    display: flex; /* 弹性布局 */
    align-items: center; /* 垂直居中 */
    gap: 4px; /* 减少元素间距 */
    background: #ffffff; /* 白色背景 */
    padding: 4px 8px; /* 减少内边距 */
    border-radius: 15px; /* 圆角 */
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1); /* 减小阴影 */
}

/* 画笔粗细标签 */
.brush-size-label {
    font-size: 10px; /* 减小字体大小 */
    color: #6c757d; /* 灰色文字 */
    font-weight: 500; /* 字体粗细 */
    white-space: nowrap; /* 不换行 */
}

/* 画笔粗细滑块 */
.brush-size-slider {
    width: 50px; /* 减小滑块宽度 */
    height: 3px; /* 减小滑块高度 */
    border-radius: 2px; /* 圆角 */
    background: #e9ecef; /* 背景色 */
    outline: none; /* 无轮廓 */
    -webkit-appearance: none; /* 移除默认样式 */
}

/* 滑块滑块样式 */
.brush-size-slider::-webkit-slider-thumb {
    -webkit-appearance: none; /* 移除默认样式 */
    width: 12px; /* 减小滑块宽度 */
    height: 12px; /* 减小滑块高度 */
    border-radius: 50%; /* 圆形 */
    background: #007bff; /* 蓝色背景 */
    cursor: pointer; /* 鼠标指针 */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2); /* 减小阴影 */
}

/* 画笔粗细数值显示 */
.brush-size-value {
    font-size: 10px; /* 减小字体大小 */
    color: #007bff; /* 蓝色文字 */
    font-weight: 600; /* 字体粗细 */
    min-width: 15px; /* 减小最小宽度 */
    text-align: center; /* 居中对齐 */
}

/* 移除原有颜色选择器，改为工具栏内的紧凑颜色选择 */
.color-palette {
    display: flex; /* 弹性布局 */
    align-items: center; /* 垂直居中 */
    gap: 4px; /* 减少元素间距 */
    background: #ffffff; /* 白色背景 */
    padding: 4px 8px; /* 减少内边距 */
    border-radius: 15px; /* 圆角 */
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1); /* 减小阴影 */
    overflow-x: auto; /* 水平滚动 */
    -webkit-overflow-scrolling: touch; /* iOS平滑滚动 */
    max-width: 200px; /* 限制最大宽度 */
}

/* 颜色按钮样式 - 更小尺寸 */
.color-btn {
    width: 20px; /* 减小按钮宽度 */
    height: 20px; /* 减小按钮高度 */
    border: 1px solid #ffffff; /* 白色边框 */
    border-radius: 50%; /* 圆形 */
    cursor: pointer; /* 鼠标指针 */
    transition: all 0.2s ease; /* 快速过渡动画 */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15); /* 减小阴影 */
    flex-shrink: 0; /* 不缩放 */
}

/* 颜色按钮悬停效果 */
.color-btn:hover {
    transform: scale(1.1); /* 放大 */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2); /* 增强阴影 */
}

/* 激活状态的颜色按钮 */
.color-btn.active {
    border-color: #007bff; /* 蓝色边框 */
    border-width: 2px; /* 加粗边框 */
    transform: scale(1.1); /* 放大 */
}

/* 强制浅色模式 - 确保默认显示白色背景和灰色网格 */
.canvas-container {
    flex: 1; /* 占据剩余空间 */
    position: relative; /* 相对定位 */
    background: #ffffff !important; /* 强制白色背景 */
    overflow: hidden; /* 隐藏溢出 */
    /* 只显示大网格 - 每20px，使用较浅的灰色 */
    background-image: 
        linear-gradient(rgba(128, 128, 128, 0.2) 1px, transparent 1px),
        linear-gradient(90deg, rgba(128, 128, 128, 0.2) 1px, transparent 1px) !important;
    background-size: 
        20px 20px, 20px 20px !important;  /* 只有大网格 */
    background-position: 0 0, 0 0 !important; /* 网格位置 */
}

#drawingCanvas {
    width: 100%; /* 全宽 */
    height: 100%; /* 全高 */
    display: block; /* 块级元素 */
    cursor: crosshair; /* 十字光标 */
    touch-action: none; /* 禁用触摸默认行为 */
    background: transparent !important; /* 完全透明，显示底层的白色背景和灰色网格 */
}

/* 橡皮擦模式下的光标 */
.canvas-container.eraser-mode #drawingCanvas {
    cursor: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20"><circle cx="10" cy="10" r="8" fill="none" stroke="red" stroke-width="2"/></svg>') 10 10, auto; /* 自定义橡皮擦光标 */
}

/* 底部状态栏 - 更紧凑 */
.status-bar {
    background: rgba(255, 255, 255, 0.95); /* 半透明白色背景 */
    backdrop-filter: blur(10px); /* 背景模糊效果 */
    padding: 8px 16px; /* 内边距 */
    font-size: 14px; /* 字体大小 */
    color: #666; /* 文字颜色 */
    border-top: 1px solid rgba(0, 0, 0, 0.1); /* 顶部边框 */
    display: flex; /* 弹性布局 */
    justify-content: space-between; /* 两端对齐 */
    align-items: center; /* 垂直居中 */
}

/* 存储信息样式 */
.storage-info {
    font-size: 12px; /* 较小字体 */
    color: #999; /* 较淡颜色 */
    background: rgba(0, 0, 0, 0.05); /* 淡背景 */
    padding: 2px 8px; /* 内边距 */
    border-radius: 12px; /* 圆角 */
}

/* 状态文字样式 */
.status-text {
    font-size: 12px; /* 减小字体大小 */
    color: #6c757d; /* 灰色文字 */
    font-weight: 500; /* 字体粗细 */
}

/* 移动端适配 */
@media (max-width: 768px) {
    /* 小屏幕下的应用容器 */
    .app-container {
        margin-top: 0; /* 移除顶部间距 */
        border-radius: 0; /* 移除圆角 */
        height: 100vh; /* 全屏高度 */
    }
    
    /* 小屏幕下的工具栏 */
    .toolbar {
        padding: 6px 10px; /* 进一步减少内边距 */
        border-radius: 0; /* 移除圆角 */
        min-height: 45px; /* 减小最小高度 */
    }
    
    /* 小屏幕下的工具按钮 */
    .tool-btn {
        width: 32px; /* 进一步减小按钮尺寸 */
        height: 32px; /* 进一步减小按钮尺寸 */
    }
    
    /* 小屏幕下的画笔粗细滑块 */
    .brush-size-slider {
        width: 40px; /* 进一步减小滑块宽度 */
    }
    
    /* 小屏幕下的颜色按钮 */
    .color-btn {
        width: 18px; /* 进一步减小按钮尺寸 */
        height: 18px; /* 进一步减小按钮尺寸 */
    }
    
    /* 小屏幕下的颜色选择器 */
    .color-palette {
        padding: 3px 6px; /* 进一步减少内边距 */
        gap: 3px; /* 进一步减少间距 */
        max-width: 150px; /* 减小最大宽度 */
    }
    
    /* 小屏幕下的画布网格 */
    .canvas-container {
        background-size: 
            15px 15px, 15px 15px !important;  /* 只有大网格，适配小屏幕 */
    }
    
    /* 小屏幕下的撤销/重做按钮 */
    .action-btn {
        width: 42px; /* 减小按钮尺寸 */
        height: 42px; /* 减小按钮尺寸 */
    }
    
    .action-btn svg {
        width: 20px; /* 减小图标尺寸 */
        height: 20px; /* 减小图标尺寸 */
    }
    
    .undo-btn, .redo-btn {
        bottom: 15px; /* 减小距离底部的间距 */
    }
    
    .undo-btn {
        left: 15px; /* 减小距离左侧的间距 */
    }
    
    .redo-btn {
        right: 15px; /* 减小距离右侧的间距 */
    }
}

/* 超小屏幕适配 */
@media (max-width: 480px) {
    /* 工具栏在超小屏幕下保持单行 */
    .toolbar {
        gap: 4px; /* 减少间距 */
        padding: 5px 8px; /* 进一步减少内边距 */
    }
    
    /* 工具组间距调整 */
    .tool-group {
        gap: 3px; /* 进一步减少间距 */
    }
    
    /* 画笔粗细容器在超小屏幕下的调整 */
    .brush-size-container {
        padding: 3px 6px; /* 进一步减少内边距 */
    }
    
    /* 超小屏幕下的画布网格 */
    .canvas-container {
        background-size: 
            12px 12px, 12px 12px !important;  /* 只有大网格，适配超小屏幕 */
    }
}

/* 加载动画 */
@keyframes fadeIn {
    from {
        opacity: 0; /* 起始透明度 */
        transform: translateY(20px); /* 起始位置 */
    }
    to {
        opacity: 1; /* 结束透明度 */
        transform: translateY(0); /* 结束位置 */
    }
}

/* 应用加载动画 */
.app-container {
    animation: fadeIn 0.5s ease-out; /* 淡入动画 */
}

/* 触摸反馈效果 */
.tool-btn:active,
.color-btn:active {
    transform: scale(0.95); /* 按下时缩小 */
    transition: transform 0.1s ease; /* 快速过渡 */
}

/* 禁用文本选择和拖拽 */
.toolbar,
.color-palette,
.status-bar {
    -webkit-user-select: none; /* Safari */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* IE/Edge */
    user-select: none; /* 标准 */
}

/* 确保在iOS Safari中正确显示 */
@supports (-webkit-touch-callout: none) {
    .app-container {
        height: 100vh; /* iOS Safari全屏高度 */
        height: -webkit-fill-available; /* iOS Safari填充可用高度 */
    }
}

/* 撤销/重做按钮基础样式 */
.action-btn {
    position: absolute; /* 绝对定位 */
    width: 48px; /* 按钮宽度 */
    height: 48px; /* 按钮高度 */
    border: none; /* 无边框 */
    border-radius: 50%; /* 圆形按钮 */
    background: rgba(255, 255, 255, 0.9); /* 半透明白色背景 */
    color: #6c757d; /* 灰色图标 */
    cursor: pointer; /* 鼠标指针 */
    transition: all 0.3s ease; /* 过渡动画 */
    display: flex; /* 弹性布局 */
    align-items: center; /* 垂直居中 */
    justify-content: center; /* 水平居中 */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15); /* 阴影效果 */
    backdrop-filter: blur(10px); /* 背景模糊效果 */
    z-index: 10; /* 层级 */
}

/* 撤销按钮 - 左下角定位 */
.undo-btn {
    bottom: 20px; /* 距离底部20px */
    left: 20px; /* 距离左侧20px */
}

/* 重做按钮 - 右下角定位 */
.redo-btn {
    bottom: 20px; /* 距离底部20px */
    right: 20px; /* 距离右侧20px */
}

/* 按钮图标样式 */
.action-btn svg {
    width: 24px; /* 图标宽度 */
    height: 24px; /* 图标高度 */
}

/* 按钮悬停效果 */
.action-btn:hover {
    background: rgba(255, 255, 255, 1); /* 完全不透明的白色背景 */
    color: #007bff; /* 蓝色图标 */
    transform: translateY(-2px); /* 向上移动 */
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2); /* 增强阴影 */
}

/* 按钮激活效果 */
.action-btn:active {
    transform: translateY(0); /* 恢复位置 */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15); /* 减小阴影 */
}

/* 禁用状态的按钮 */
.action-btn:disabled {
    opacity: 0.5; /* 半透明 */
    cursor: not-allowed; /* 禁用光标 */
    transform: none; /* 无变换 */
}

/* 禁用状态的按钮悬停效果 */
.action-btn:disabled:hover {
    background: rgba(255, 255, 255, 0.9); /* 保持原背景 */
    color: #6c757d; /* 保持原颜色 */
    transform: none; /* 无变换 */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15); /* 保持原阴影 */
} 