/* /app/static/css/style.css */

/* --- 主题切换器 --- */
#theme-switcher {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	color: var(--pico-nav-link-color);
	transition: color 0.2s;
}
#theme-switcher:hover {
	color: var(--pico-primary);
}

/* --- 标签输入组件 --- */
.tag-input-container {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	padding: 5px;
	border: 1px solid var(--pico-form-element-border-color);
	border-radius: var(--pico-border-radius);
	background-color: var(--pico-form-element-background-color);
	transition: box-shadow 0.2s, border-color 0.2s;
	margin-bottom: var(--pico-form-element-spacing-vertical);
}
.tag-input-container:focus-within {
	border-color: var(--pico-primary);
	box-shadow: 0 0 0 1px var(--pico-primary);
}
.tag-item {
	display: inline-flex;
	align-items: center;
	background-color: var(--pico-primary);
	color: var(--pico-primary-inverse);
	border-radius: var(--pico-border-radius);
	padding: 0.2em 0.6em;
	margin: 3px;
	font-size: 0.9em;
	white-space: nowrap;
}
.tag-remove-btn {
	margin-left: 8px;
	cursor: pointer;
	width: 16px;
	height: 16px;
	background: none;
	border: none;
	color: var(--pico-primary-inverse);
	opacity: 0.7;
	transition: opacity 0.2s;
	font-weight: bold;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	line-height: 1;
}
.tag-remove-btn:hover {
	opacity: 1;
}
.tag-input-container input[type="text"] {
	flex-grow: 1;
	border: none !important;
	padding: 5px !important;
	outline: none !important;
	background: transparent !important;
	color: var(--pico-color) !important;
	min-width: 150px;
	box-shadow: none !important;
	margin-bottom: 0 !important;
}

/* --- 标签展示徽章 --- */
.tag-badge {
	display: inline-block;
	padding: 0.25em 0.6em;
	font-size: 0.8em;
	font-weight: 600;
	line-height: 1;
	text-align: center;
	white-space: nowrap;
	vertical-align: baseline;
	border-radius: var(--pico-border-radius);
	text-decoration: none;
	background-color: var(--pico-secondary-background);
	color: var(--pico-secondary-foreground);
	border: 1px solid var(--pico-secondary-border);
	transition: all 0.2s ease-in-out;
	margin: 0 0.2rem 0.2rem 0;
}
.tag-badge:hover {
	background-color: var(--pico-secondary-hover-background);
	color: var(--pico-secondary-hover-foreground);
	border-color: var(--pico-secondary-hover-border);
}


/* --- 过滤器激活状态 --- */
#tag-filters button.active, #company-filters button.active {
	background-color: var(--pico-primary);
	color: var(--pico-primary-inverse);
	border-color: var(--pico-primary);
}


/*
 * ===================================================================
 * 游戏列表视图切换核心样式 (View Mode Switching)
 * ===================================================================
 */

#game-list {
    transition: all 0.3s ease-in-out;
}

/* --- 通用基础样式 --- */
/* 为卡片容器的父链接设置，以确保悬浮效果作用于整个区域 */
.game-link-container {
    display: block; /* 确保链接占据块级空间 */
    text-decoration: none;
    transition: transform 0.2s, box-shadow 0.2s;
    border-radius: var(--pico-card-border-radius); /* 将圆角赋予外层链接，效果更统一 */
}
.game-link-container:hover {
    transform: translateY(-4px);
    box-shadow: var(--pico-card-box-shadow);
}

/* 卡片本身的基础样式，现在由父级链接控制悬浮动画 */
.game-card {
    display: flex;
    width: 100%;
    height: 100%;
    background-color: var(--pico-card-background-color);
    border: 1px solid var(--pico-card-border-color);
    border-radius: var(--pico-card-border-radius);
    overflow: hidden;
    transition: border-color 0.2s; /* 为紧凑模式的悬浮效果准备 */
}

/* 通用图片容器 */
.game-card-img-container {
    position: relative;
    background-color: var(--pico-muted-background-color);
    flex-shrink: 0; /* 防止图片在flex布局中被压缩 */
}
.game-card-img, .img-placeholder {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.img-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--pico-muted-color);
}

/* 通用内容区域 */
.game-card-body {
    display: flex;
    flex-direction: column;
    padding: var(--pico-card-body-padding);
    overflow: hidden;
}
.game-card-body strong {
    color: var(--pico-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis; /* 超长标题显示省略号 */
}
.game-card-body small {
    color: var(--pico-muted-color);
    margin-top: 0.25rem;
}


/* ----------------------------- */
/* 1. 卡片视图 (Card View) - 默认 */
/* ----------------------------- */
#game-list.view-cards {
    display: grid;
    /* 优化网格布局，使其在不同屏幕尺寸下更自然 */
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1.2rem;
}
#game-list.view-cards .game-card {
    flex-direction: column;
}
#game-list.view-cards .game-card-img-container {
    width: 100%;
    padding-top: 133.33%; /* 维持 3:4 宽高比 */
}
#game-list.view-cards .game-card-body {
    flex-grow: 1;
    justify-content: flex-start; /* 内容从顶部开始排列 */
}

/* ----------------------- */
/* 2. 列表视图 (List View) */
/* ----------------------- */
#game-list.view-list {
    display: flex;
    flex-direction: column;
    gap: 1rem; /* 使用 gap 替代 margin-bottom */
}
/* 列表视图下，悬浮时只加阴影，不位移，避免页面跳动 */
#game-list.view-list .game-link-container:hover {
    transform: none;
}
#game-list.view-list .game-card {
    flex-direction: row;
    align-items: center; /* 垂直居中对齐图片和文字 */
}
#game-list.view-list .game-card-img-container {
    padding-top: 0; /* 清除卡片视图的 padding-top */
    width: 90px;
    height: 120px;
}
#game-list.view-list .game-card-body {
    justify-content: center; /* 使文字部分在垂直方向上居中 */
}


/* --------------------------- */
/* 3. 紧凑视图 (Compact View) */
/* --------------------------- */
#game-list.view-compact {
    display: grid;
    /* 设置一个固定的4列网格，1fr代表每列占据可用空间的1份 */
    grid-template-columns: repeat(4, 1fr);
    /* 适当调整间距，使其既紧凑又有呼吸感 */
    gap: 1rem;
}

/* 在 Grid 布局中，不再需要为链接容器设置 auto 宽度 */
#game-list.view-compact .game-link-container {
    width: 100%; /* 链接将撑满整个网格单元 */
}

/* 悬浮效果保持不变，依然是稳定的边框高亮 */
#game-list.view-compact .game-link-container:hover {
    transform: none;
    box-shadow: none;
}
#game-list.view-compact .game-link-container:hover .game-card {
    border-color: var(--pico-primary-hover);
}

/* 卡片内部样式保持不变，依然是小缩略图+标题的核心模式 */
#game-list.view-compact .game-card {
    flex-direction: row;
    align-items: center;
    padding: 0.4rem 0.8rem;
    width: 100%; /* 卡片也撑满链接容器 */
}

/* 图片容器样式不变 */
#game-list.view-compact .game-card-img-container {
    display: block !important;
    width: 30px;
    height: 40px;
    margin-right: 0.75rem;
    border-radius: calc(var(--pico-border-radius) / 2);
    overflow: hidden;
}

/* 内容主体样式不变 */
#game-list.view-compact .game-card-body {
    padding: 0;
    justify-content: center;
}

/* 副标题依然隐藏 */
#game-list.view-compact .game-card-body small {
    display: none;
}