/* =========================================================
   文件：assets/css/components.css
   作用：
   1. 定义全站可复用组件样式
   2. 在 common.css 基础上补充导航、按钮、卡片、页脚等具体外观
   3. 为首页、地区页、详情页、关于页提供统一组件基础

   说明：
   - 本文件只定义“组件级样式”
   - 不负责某个具体页面的专属布局
   - 页面级差异放到 pages.css 中处理
   ========================================================= */


/* =========================================================
   一、顶部导航栏组件
   作用：
   - 提供官网统一页头
   - 用于展示品牌、主导航、联系入口等
   ========================================================= */

/* 整体站点头部容器 */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: rgba(246, 248, 251, 0.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-border);
}

/* 导航内部布局容器 */
.site-header__inner {
    min-height: 72px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
}

/* 左侧品牌区域 */
.site-brand {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    color: var(--color-text);
    text-decoration: none;
}

/* 鼠标悬停时保持品牌区域稳定，不做明显跳动 */
.site-brand:hover {
    color: var(--color-text);
}

/* Logo 外层 */
.site-brand__logo {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

/* Logo 图片 */
.site-brand__logo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 品牌文字区 */
.site-brand__text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

/* 品牌主标题 */
.site-brand__name {
    font-size: var(--font-size-base);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-text);
}

/* 品牌辅助说明 */
.site-brand__tagline {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    line-height: 1.2;
}

/* 导航菜单 */
.site-nav {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

/* 导航单项链接 */
.site-nav__link {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 var(--space-4);
    border-radius: 999px;
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    font-weight: 500;
    transition:
        background-color var(--transition-fast),
        color var(--transition-fast);
}

/* 导航 hover 态 */
.site-nav__link:hover {
    background-color: var(--color-surface);
    color: var(--color-text);
}

/* 当前页面激活态 */
.site-nav__link.is-active {
    background-color: var(--color-surface);
    color: var(--color-primary);
    box-shadow: var(--shadow-sm);
}

/* 头部右侧操作区 */
.site-header__actions {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex-shrink: 0;
}


/* =========================================================
   二、Hero / 页面横幅组件
   作用：
   - 用于首页首屏、地区详情页顶部横幅等
   - 强化摄影类官网的视觉完整度
   ========================================================= */

/* 通用 Hero 容器 */
.hero {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-xl);
    background:
        linear-gradient(135deg, rgba(29, 78, 216, 0.08), rgba(255, 255, 255, 0.88)),
        var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

/* Hero 内部内容区 */
.hero__content {
    position: relative;
    z-index: 1;
    padding: var(--space-12);
}

/* Hero 小标题 / 标签 */
.hero__eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 var(--space-3);
    margin-bottom: var(--space-4);
    border-radius: 999px;
    background-color: rgba(29, 78, 216, 0.08);
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
}

/* Hero 主标题 */
.hero__title {
    margin-bottom: var(--space-4);
    max-width: 760px;
    color: var(--color-text);
    font-size: clamp(32px, 4vw, 48px);
    line-height: 1.15;
}

/* Hero 副标题 */
.hero__subtitle {
    margin-bottom: 0;
    max-width: 760px;
    color: var(--color-text-secondary);
    font-size: var(--font-size-lg);
    line-height: var(--line-height-relaxed);
}

/* Hero 背景图层 */
.hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: 0.16;
}

/* Hero 背景图片 */
.hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Hero 操作按钮区 */
.hero__actions {
    margin-top: var(--space-8);
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
}


/* =========================================================
   三、按钮组件
   作用：
   - 用于导航右侧操作、Hero CTA、卡片跳转入口等
   ========================================================= */

/* 按钮基础类 */
.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    min-height: 44px;
    padding: 0 var(--space-5);
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: var(--font-size-sm);
    font-weight: 600;
    text-decoration: none;
    transition:
        transform var(--transition-fast),
        background-color var(--transition-fast),
        border-color var(--transition-fast),
        color var(--transition-fast),
        box-shadow var(--transition-fast);
    cursor: pointer;
}

/* 按钮 hover 轻微上浮 */
.button:hover {
    transform: translateY(-1px);
}

/* 主按钮 */
.button--primary {
    background-color: var(--color-primary);
    color: #ffffff;
    box-shadow: var(--shadow-sm);
}

.button--primary:hover {
    background-color: var(--color-primary-hover);
    color: #ffffff;
}

/* 次按钮 */
.button--secondary {
    background-color: var(--color-surface);
    color: var(--color-text);
    border-color: var(--color-border);
}

.button--secondary:hover {
    background-color: var(--color-surface-secondary);
    color: var(--color-text);
}

/* 幽灵按钮 */
.button--ghost {
    background-color: transparent;
    color: var(--color-text-secondary);
    border-color: var(--color-border);
}

.button--ghost:hover {
    background-color: var(--color-surface);
    color: var(--color-text);
}

/* 小尺寸按钮 */
.button--sm {
    min-height: 36px;
    padding: 0 var(--space-4);
    font-size: var(--font-size-sm);
}

/* 大尺寸按钮 */
.button--lg {
    min-height: 48px;
    padding: 0 var(--space-6);
    font-size: var(--font-size-base);
}


/* =========================================================
   四、标签组件
   作用：
   - 用于地区特色标签、图片标签、主题标签等
   ========================================================= */

/* 标签组容器 */
.tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

/* 通用标签 */
.tag {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 var(--space-3);
    border-radius: 999px;
    background-color: var(--color-surface-secondary);
    color: var(--color-text-secondary);
    font-size: var(--font-size-xs);
    font-weight: 600;
    line-height: 1;
    border: 1px solid transparent;
}

/* 主色标签 */
.tag--primary {
    background-color: rgba(29, 78, 216, 0.08);
    color: var(--color-primary);
}

/* 描边标签 */
.tag--outline {
    background-color: transparent;
    color: var(--color-text-secondary);
    border-color: var(--color-border);
}


/* =========================================================
   五、卡片图片区域基础
   作用：
   - 供地区卡片、图片卡片复用
   ========================================================= */

/* 通用卡片媒体容器 */
.card-media {
    position: relative;
    overflow: hidden;
    background-color: var(--color-surface-secondary);
}

/* 通用卡片图片 */
.card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

/* 悬停时图片轻微放大，增强质感 */
.surface-card-hover:hover .card-media img {
    transform: scale(1.03);
}


/* =========================================================
   六、地区卡片组件
   作用：
   - 用于首页热门地区、地区列表页
   ========================================================= */

/* 地区卡片整体 */
.region-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
}

/* 地区卡片封面 */
.region-card__media {
    aspect-ratio: 16 / 10;
    border-bottom: 1px solid var(--color-border);
}

/* 地区卡片主体 */
.region-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: var(--space-5);
}

/* 地区卡片标题行 */
.region-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-3);
}

/* 地区名称 */
.region-card__title {
    margin: 0;
    color: var(--color-text);
    font-size: var(--font-size-xl);
    line-height: 1.25;
}

/* 图片数量徽标 */
.region-card__count {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 var(--space-3);
    border-radius: 999px;
    background-color: var(--color-surface-secondary);
    color: var(--color-text-muted);
    font-size: var(--font-size-xs);
    font-weight: 600;
}

/* 地区简介 */
.region-card__description {
    margin-bottom: var(--space-4);
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}

/* 地区地点列表区域 */
.region-card__locations {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: auto;
    margin-bottom: var(--space-5);
}

/* 地区卡片底部操作区 */
.region-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-border);
}

/* 地区卡片底部辅助文字 */
.region-card__meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* 地区详情入口 */
.region-card__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
}


/* =========================================================
   七、图片卡片组件
   作用：
   - 用于首页精选图片、地区详情页图片网格
   ========================================================= */

/* 图片卡片整体 */
.photo-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
}

/* 图片封面区域 */
.photo-card__media {
    aspect-ratio: 4 / 3;
    border-bottom: 1px solid var(--color-border);
}

/* 图片主体内容 */
.photo-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    padding: var(--space-5);
}

/* 图片标题 */
.photo-card__title {
    margin-bottom: var(--space-2);
    color: var(--color-text);
    font-size: var(--font-size-lg);
    line-height: 1.35;
}

/* 图片地点 */
.photo-card__location {
    margin-bottom: var(--space-4);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* 图片说明 */
.photo-card__description {
    margin-bottom: var(--space-4);
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-base);
}

/* 图片标签区域 */
.photo-card__tags {
    margin-top: auto;
    margin-bottom: var(--space-5);
}

/* 图片底部区域 */
.photo-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-border);
}

/* 图片主题说明 */
.photo-card__theme {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* 图片详情入口 */
.photo-card__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-primary);
    font-size: var(--font-size-sm);
    font-weight: 600;
}


/* =========================================================
   八、横向精选图片条目（可选）
   作用：
   - 可用于 about 页或首页下半区展示更紧凑的图片信息
   ========================================================= */
.photo-row {
    display: flex;
    gap: var(--space-4);
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    background-color: var(--color-surface);
}

.photo-row__media {
    width: 160px;
    min-width: 160px;
    aspect-ratio: 4 / 3;
    border-radius: var(--radius-md);
    overflow: hidden;
}

.photo-row__body {
    display: flex;
    flex: 1;
    flex-direction: column;
}

.photo-row__title {
    margin-bottom: var(--space-2);
    font-size: var(--font-size-lg);
}

.photo-row__meta {
    margin-bottom: var(--space-3);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.photo-row__description {
    margin-bottom: var(--space-4);
    font-size: var(--font-size-sm);
}

.photo-row__footer {
    margin-top: auto;
}


/* =========================================================
   九、信息列表组件
   作用：
   - 用于关于页“服务内容”“备案信息”“联系方式”等模块
   ========================================================= */

/* 信息列表外层 */
.info-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

/* 单行信息项 */
.info-list__item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-4) 0;
    border-bottom: 1px solid var(--color-border);
}

/* 左侧标签 */
.info-list__label {
    min-width: 120px;
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
    font-weight: 600;
}

/* 右侧内容 */
.info-list__value {
    flex: 1;
    color: var(--color-text);
    font-size: var(--font-size-sm);
    text-align: right;
}

/* 可左对齐版本 */
.info-list--stacked .info-list__item {
    flex-direction: column;
}

.info-list--stacked .info-list__label,
.info-list--stacked .info-list__value {
    min-width: 0;
    text-align: left;
}


/* =========================================================
   十、特色要点列表
   作用：
   - 用于首页介绍区、关于页“平台特点”“服务说明”
   ========================================================= */

/* 要点列表 */
.feature-list {
    display: grid;
    gap: var(--space-4);
}

/* 单个要点项 */
.feature-list__item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
}

/* 要点图标圆点 */
.feature-list__icon {
    width: 12px;
    height: 12px;
    margin-top: 8px;
    border-radius: 999px;
    background-color: var(--color-primary);
    flex-shrink: 0;
}

/* 要点标题 */
.feature-list__title {
    margin-bottom: var(--space-2);
    color: var(--color-text);
    font-size: var(--font-size-base);
}

/* 要点描述 */
.feature-list__description {
    margin-bottom: 0;
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}


/* =========================================================
   十一、页脚组件
   作用：
   - 展示站点说明、备案信息、联系邮箱、底部导航
   - 公安备案场景下是必须重点打磨的区域
   ========================================================= */

/* 站点页脚整体 */
.site-footer {
    margin-top: var(--space-16);
    border-top: 1px solid var(--color-border);
    background-color: var(--color-surface);
}

/* 页脚内部主区域 */
.site-footer__main {
    padding-top: var(--space-10);
    padding-bottom: var(--space-10);
}

/* 页脚网格布局 */
.site-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: var(--space-8);
}

/* 页脚品牌说明区 */
.site-footer__brand {
    max-width: 460px;
}

/* 页脚品牌标题 */
.site-footer__title {
    margin-bottom: var(--space-3);
    color: var(--color-text);
    font-size: var(--font-size-lg);
}

/* 页脚品牌说明 */
.site-footer__description {
    margin-bottom: var(--space-4);
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}

/* 页脚区块标题 */
.site-footer__heading {
    margin-bottom: var(--space-4);
    color: var(--color-text);
    font-size: var(--font-size-base);
}

/* 页脚导航列表 */
.site-footer__nav {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* 页脚链接 */
.site-footer__nav a {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}

.site-footer__nav a:hover {
    color: var(--color-primary);
}

/* 页脚备案信息列表 */
.site-footer__records {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

/* 单条备案信息 */
.site-footer__record-item {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-base);
}

/* 页脚最底部版权区 */
.site-footer__bottom {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-4);
    padding-bottom: var(--space-4);
}

/* 页脚底部内容布局 */
.site-footer__bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}

/* 版权文字 */
.site-footer__copyright {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

/* 页脚底部附加链接 */
.site-footer__bottom-links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
}

.site-footer__bottom-links a {
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}


/* =========================================================
   十二、空状态组件
   作用：
   - 用于某地区暂无图片、数据加载失败、内容缺失等场景
   ========================================================= */
.empty-state {
    padding: var(--space-10);
    text-align: center;
    border: 1px dashed var(--color-border-strong);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
}

.empty-state__title {
    margin-bottom: var(--space-3);
    color: var(--color-text);
    font-size: var(--font-size-lg);
}

.empty-state__description {
    margin-bottom: 0;
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
}


/* =========================================================
   十三、面包屑组件
   作用：
   - 用于地区详情页、图片详情页顶部导航提示
   ========================================================= */
.breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-6);
}

.breadcrumb__item {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.breadcrumb__item a {
    color: var(--color-text-secondary);
}

.breadcrumb__item a:hover {
    color: var(--color-primary);
}

.breadcrumb__separator {
    color: var(--color-text-muted);
}


/* =========================================================
   十四、统计条组件
   作用：
   - 用于地区详情页展示“图片数 / 推荐地点 / 主题类型”等摘要信息
   ========================================================= */
.stat-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
}

.stat-bar__item {
    padding: var(--space-5);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.stat-bar__label {
    margin-bottom: var(--space-2);
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}

.stat-bar__value {
    color: var(--color-text);
    font-size: var(--font-size-xl);
    font-weight: 700;
    line-height: 1.2;
}


/* =========================================================
   十五、内容区块面板组件
   作用：
   - 用于关于页、地区说明区、补充信息区
   ========================================================= */
.content-panel {
    padding: var(--space-6);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-sm);
}

.content-panel__title {
    margin-bottom: var(--space-4);
    color: var(--color-text);
    font-size: var(--font-size-lg);
}

.content-panel__description:last-child,
.content-panel p:last-child {
    margin-bottom: 0;
}


/* =========================================================
   十六、响应式适配
   作用：
   - 让组件在平板和手机端仍然保持良好结构
   ========================================================= */

/* 平板和中等屏幕 */
@media (max-width: 1024px) {
    .site-header__inner {
        min-height: 68px;
    }

    .hero__content {
        padding: var(--space-10);
    }

    .site-footer__grid {
        grid-template-columns: 1fr 1fr;
    }

    .site-footer__brand {
        max-width: none;
        grid-column: 1 / -1;
    }

    .stat-bar {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* 手机和窄屏 */
@media (max-width: 768px) {
    .site-header {
        position: static;
    }

    .site-header__inner {
        min-height: auto;
        padding-top: var(--space-4);
        padding-bottom: var(--space-4);
        flex-direction: column;
        align-items: flex-start;
    }

    .site-nav {
        width: 100%;
    }

    .site-header__actions {
        width: 100%;
        flex-wrap: wrap;
    }

    .hero__content {
        padding: var(--space-8);
    }

    .hero__subtitle {
        font-size: var(--font-size-base);
    }

    .hero__actions {
        margin-top: var(--space-6);
        gap: var(--space-3);
    }

    .button {
        width: 100%;
    }

    .region-card__header,
    .photo-card__footer,
    .region-card__footer,
    .info-list__item,
    .site-footer__bottom-inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .site-footer__grid {
        grid-template-columns: 1fr;
    }

    .photo-row {
        flex-direction: column;
    }

    .photo-row__media {
        width: 100%;
        min-width: 0;
    }

    .stat-bar {
        grid-template-columns: 1fr;
    }
}

/* 超小屏 */
@media (max-width: 480px) {
    .site-brand__logo {
        width: 36px;
        height: 36px;
    }

    .hero__content {
        padding: var(--space-6);
    }

    .region-card__body,
    .photo-card__body,
    .content-panel {
        padding: var(--space-5);
    }

    .site-footer__main {
        padding-top: var(--space-8);
        padding-bottom: var(--space-8);
    }
}