/* ==========================================================================
 * coreapks 设计系统 / Design tokens + component shim
 * 说明：site.css 是纯 Tailwind 工具类构建（不含 DaisyUI）。本文件补齐模板用到的
 *      DaisyUI 组件类(btn/card/badge)，并提供统一配色 token 与语义工具类。
 * 加载顺序：必须在 site.css 之前引入，让 Tailwind 工具类仍能覆盖具体属性。
 * 调色板：Trust Indigo (#4F46E5) + Sky (#0EA5E9) + Signal Amber (#F59E0B)
 *        中性 Slate，干净浅底，让广告创意成为页面最抢眼的彩色元素。
 * ========================================================================== */

:root {
  --c-primary: #4F46E5;          /* indigo-600  主色：CTA / 链接 / 品牌 */
  --c-primary-focus: #4338CA;    /* indigo-700  主色 hover/active */
  --c-primary-content: #FFFFFF;
  --c-secondary: #0EA5E9;        /* sky-500     次级/上下文内链 */
  --c-accent: #F59E0B;           /* amber-500   仅评分星 + deal 徽标 */
  --c-neutral: #1E293B;          /* slate-800   页脚/深色块 */
  --c-neutral-content: #CBD5E1;  /* slate-300 */
  --c-brand-dark: #312E81;       /* indigo-900  hero / 页头深色面 */
  --c-base-100: #FFFFFF;         /* 主表面/卡片 */
  --c-base-200: #F6F7FB;         /* 分段交替底 */
  --c-base-300: #E8EAF1;         /* 边框/分隔/广告位预留底 */
  --c-base-content: #0F172A;     /* slate-900 正文 */
  --c-muted: #64748B;            /* slate-500 次要文字 */
  --c-success: #16A34A;          /* green-600 安全/已验证 */
  --c-error: #DC2626;            /* red-600   折扣/危险 */
  --radius-btn: 0.625rem;
  --radius-card: 1rem;
}

/* ---------- 语义配色工具类（site.css / Tailwind 默认无同名类，无冲突） ---------- */
.bg-base-100 { background-color: var(--c-base-100); }
.bg-base-200 { background-color: var(--c-base-200); }
.bg-base-300 { background-color: var(--c-base-300); }
.border-base-300 { border-color: var(--c-base-300); }
.text-base-content { color: var(--c-base-content); }
.text-muted { color: var(--c-muted); }
.text-primary { color: var(--c-primary); }
.bg-primary { background-color: var(--c-primary); }
.text-secondary { color: var(--c-secondary); }
.bg-secondary { background-color: var(--c-secondary); }
.text-accent { color: var(--c-accent); }
.bg-accent { background-color: var(--c-accent); }
.text-success { color: var(--c-success); }
.bg-neutral { background-color: var(--c-neutral); }
.text-neutral-content { color: var(--c-neutral-content); }
.bg-brand-dark { background-color: var(--c-brand-dark); }

/* ---------- 按钮 shim ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  height: 2.75rem;
  min-height: 2.75rem;
  padding-inline: 1.25rem;
  border: 1px solid transparent;
  border-radius: var(--radius-btn);
  font-weight: 700;
  font-size: 1.0625rem;
  line-height: 1;
  text-align: center;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  transition: background-color .2s, color .2s, border-color .2s, box-shadow .2s, transform .05s;
}
.btn:active { transform: translateY(1px); }
.btn-sm { height: 2.25rem; min-height: 2.25rem; padding-inline: 1rem; font-size: 0.9375rem; border-radius: 0.5rem; }
.btn-lg { height: 3.5rem; padding-inline: 2rem; font-size: 1.1875rem; }
.btn-block { width: 100%; }
.btn-ghost { background-color: transparent; border-color: transparent; }
.btn-ghost:hover { background-color: rgba(15, 23, 42, .06); }
.btn-outline { background-color: transparent; border-color: currentColor; }
.btn-primary { background-color: var(--c-primary); color: var(--c-primary-content); border-color: var(--c-primary); }
.btn-primary:hover { background-color: var(--c-primary-focus); border-color: var(--c-primary-focus); }

/* ---------- 卡片 shim ---------- */
.card { position: relative; display: flex; flex-direction: column; border-radius: var(--radius-card); }
.card-body { display: flex; flex-direction: column; padding: 1.5rem; gap: 0.25rem; }
.card-title { font-weight: 700; font-size: 1.125rem; }

/* ---------- 徽标 shim ---------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.625rem;
  border: 1px solid transparent;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.2;
}
.badge-outline { background-color: transparent; border-color: currentColor; }
.badge-primary { background-color: var(--c-primary); color: var(--c-primary-content); }
.badge-accent { color: var(--c-accent); border-color: var(--c-accent); background-color: rgba(245, 158, 11, .08); }
.badge-error { color: var(--c-error); border-color: var(--c-error); background-color: rgba(220, 38, 38, .06); }
.badge-ghost { background-color: var(--c-base-200); color: var(--c-base-content); }

/* ---------- 广告位预留高度（防 CLS） ---------- */
.ad-slot { display: block; width: 100%; margin-inline: auto; }
.ad-slot--leader { min-height: 100px; }
.ad-slot--inline { min-height: 250px; }
.ad-slot--feed   { min-height: 290px; }
@media (min-width: 768px) {
  .ad-slot--leader { min-height: 90px; }
  .ad-slot--inline { min-height: 280px; }
  .ad-slot--feed   { min-height: 280px; }
}

/* ---------- 设计点缀（首页 / 分类页重设计） ---------- */
.text-gradient {
  background: linear-gradient(90deg, #818CF8 0%, #38BDF8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* hero 极光底 + 细网格 */
.hero-aurora {
  background:
    radial-gradient(55% 75% at 12% 8%, rgba(99,102,241,.60) 0%, transparent 60%),
    radial-gradient(45% 65% at 92% 18%, rgba(56,189,248,.38) 0%, transparent 55%),
    radial-gradient(75% 95% at 65% 125%, rgba(139,92,246,.50) 0%, transparent 60%),
    #1e1b4b;
  /* 顶部内边距由本类（我们自有、永不被 purge）承载，保证清掉 absolute 导航条，
     防止 hero/分类页左上角 logo 与首行文案重叠。site.css 里的 pt-24/pt-28 已被 purge 失效。 */
  padding-top: 6rem;        /* 96px：清掉 h-16(64px) 导航 + 余量 */
  padding-bottom: 3.5rem;
}
@media (min-width: 768px) {
  .hero-aurora { padding-top: 7rem; padding-bottom: 5rem; } /* 112px：清掉 md 导航(72px) */
}
.hero-grid::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 46px 46px;
  -webkit-mask-image: radial-gradient(circle at 50% -10%, #000 35%, transparent 75%);
  mask-image: radial-gradient(circle at 50% -10%, #000 35%, transparent 75%);
  pointer-events: none;
}

/* 卡片悬浮抬升 */
.lift-card { transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.lift-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px -12px rgba(79,70,229,.28); }

/* 导航 pill */
.nav-pill {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .5rem 1.05rem; border-radius: 9999px;
  font-weight: 700; font-size: .95rem; letter-spacing: .01em;
  transition: background-color .2s, color .2s;
}

/* section kicker 小标题 */
.kicker {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .75rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  color: var(--c-primary);
}
.kicker::before { content: ""; width: 1.6rem; height: 2px; border-radius: 2px; background: linear-gradient(90deg, var(--c-primary), var(--c-secondary)); }

/* 品牌 logo 标记 */
.brand-mark {
  width: 2.5rem; height: 2.5rem; border-radius: .8rem;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: 1.25rem; line-height: 1; flex-shrink: 0;
}
.brand-mark--light { background: linear-gradient(135deg, #4F46E5, #7C3AED); color: #fff; box-shadow: 0 6px 16px -4px rgba(79,70,229,.5); }
.brand-mark--dark { background: #fff; color: #4338CA; box-shadow: 0 0 0 1px rgba(255,255,255,.3), 0 6px 16px -4px rgba(0,0,0,.45); }

/* 可访问性：尊重 reduce-motion */
@media (prefers-reduced-motion: reduce) {
  .btn, .lift-card { transition: none; }
  .lift-card:hover { transform: none; }
}

/* ==========================================================================
 * Purge 补丁（site.css 缺失类的等价定义 = Tailwind 默认值）
 * site.css 是按【旧模板】扫描 purge 的 Tailwind 构建；重设计新引入、旧模板没用过的
 * 工具类未被编译进去（失效/inert）。下列选择器在 site.css 中【完全不存在】→ 纯新增、
 * 零冲突，不会影响任何现有正常页面。经全模板审计(112 项，剔除 SVG/CSS 属性噪音)补齐。
 * 根治办法见计划备注（用 Tailwind 独立 CLI 按当前模板重建 site.css）。
 * ========================================================================== */
/* ---- 字重（旧模板只用到 bold/semibold，extrabold/black 被 purge）---- */
.font-extrabold { font-weight: 800; }
.font-black     { font-weight: 900; }
/* ---- 文字色 ---- */
.text-indigo-50  { color: #eef2ff; }
.text-indigo-100 { color: #e0e7ff; }
.text-indigo-200 { color: #c7d2fe; }
.text-indigo-700 { color: #4338ca; }
.text-indigo-100\/70 { color: rgba(224,231,255,.70); }
.text-indigo-100\/80 { color: rgba(224,231,255,.80); }
.text-white\/90  { color: rgba(255,255,255,.90); }
.text-amber-300  { color: #fcd34d; }
.text-amber-400  { color: #fbbf24; }
.text-amber-600  { color: #d97706; }
.text-emerald-400{ color: #34d399; }
.text-emerald-600{ color: #059669; }
.text-sky-600    { color: #0284c7; }
.text-sky-900    { color: #0c4a6e; }
.text-rose-600   { color: #e11d48; }
.text-violet-600 { color: #7c3aed; }
/* ---- 背景色 ---- */
.bg-indigo-600 { background-color: #4f46e5; }
.bg-amber-100  { background-color: #fef3c7; }
.bg-amber-500  { background-color: #f59e0b; }
.bg-emerald-100{ background-color: #d1fae5; }
.bg-emerald-500{ background-color: #10b981; }
.bg-rose-500   { background-color: #f43f5e; }
.bg-violet-100 { background-color: #ede9fe; }
.bg-slate-100  { background-color: #f1f5f9; }
.bg-slate-200  { background-color: #e2e8f0; }
.bg-white\/\[0\.07\] { background-color: rgba(255,255,255,.07); }
/* ---- 边框色（配合已有 .border 宽度类）---- */
.border-indigo-100 { border-color: #e0e7ff; }
.border-amber-100  { border-color: #fef3c7; }
.border-amber-400  { border-color: #fbbf24; }
.border-emerald-100{ border-color: #d1fae5; }
.border-sky-500    { border-color: #0ea5e9; }
.border-violet-100 { border-color: #ede9fe; }
.border-slate-100  { border-color: #f1f5f9; }
.border-white\/15  { border-color: rgba(255,255,255,.15); }
.border-white\/40  { border-color: rgba(255,255,255,.40); }
/* ---- 渐变（hero 光晕 + explore_types 图标块）---- */
.bg-gradient-to-tr { background-image: linear-gradient(to top right, var(--tw-gradient-stops)); }
.bg-gradient-to-br { background-image: linear-gradient(to bottom right, var(--tw-gradient-stops)); }
.from-indigo-500 { --tw-gradient-from:#6366f1; --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.from-indigo-600 { --tw-gradient-from:#4f46e5; --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.from-sky-500    { --tw-gradient-from:#0ea5e9; --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.from-rose-500   { --tw-gradient-from:#f43f5e; --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.from-amber-500  { --tw-gradient-from:#f59e0b; --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.from-violet-500 { --tw-gradient-from:#8b5cf6; --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.from-indigo-500\/20 { --tw-gradient-from:rgba(99,102,241,.20); --tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to,transparent); }
.to-indigo-500  { --tw-gradient-to:#6366f1; }
.to-sky-500     { --tw-gradient-to:#0ea5e9; }
.to-rose-500    { --tw-gradient-to:#f43f5e; }
.to-amber-400   { --tw-gradient-to:#fbbf24; }
.to-emerald-500 { --tw-gradient-to:#10b981; }
.to-violet-500  { --tw-gradient-to:#8b5cf6; }
.to-teal-500    { --tw-gradient-to:#14b8a6; }
.to-sky-400\/10 { --tw-gradient-to:rgba(56,189,248,.10); }
/* ---- 特效：模糊 / ring / 彩色阴影 ---- */
.backdrop-blur-sm { -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); }
.blur-2xl { filter: blur(40px); }
.ring-1 { box-shadow: 0 0 0 1px var(--tw-ring-color, rgba(0,0,0,.05)); }
.ring-inset { box-shadow: inset 0 0 0 1px var(--tw-ring-color, rgba(0,0,0,.05)); }
.ring-black\/5 { --tw-ring-color: rgba(0,0,0,.05); }
.shadow-indigo-950\/40 { box-shadow: 0 10px 15px -3px rgba(30,27,75,.40), 0 4px 6px -4px rgba(30,27,75,.40); }
/* ---- 间距 / 圆角 ---- */
.mt-12 { margin-top: 3rem; }
.mb-5  { margin-bottom: 1.25rem; }
.pb-14 { padding-bottom: 3.5rem; }
.pb-16 { padding-bottom: 4rem; }
.pt-1  { padding-top: 0.25rem; }
.pl-0  { padding-left: 0; }
.pr-0  { padding-right: 0; }
.pr-6  { padding-right: 1.5rem; }
.p-5   { padding: 1.25rem; }
.px-2\.5 { padding-left: 0.625rem; padding-right: 0.625rem; }
.px-3\.5 { padding-left: 0.875rem; padding-right: 0.875rem; }
.px-5  { padding-left: 1.25rem; padding-right: 1.25rem; }
.py-1\.5 { padding-top: 0.375rem; padding-bottom: 0.375rem; }
.py-14 { padding-top: 3.5rem; padding-bottom: 3.5rem; }
.gap-0\.5 { gap: 0.125rem; }
.gap-x-6 { column-gap: 1.5rem; }
.gap-y-2 { row-gap: 0.5rem; }
.space-y-3 > :not([hidden]) ~ :not([hidden]) { margin-top: 0.75rem; }
.rounded-b-\[2\.5rem\] { border-bottom-left-radius: 2.5rem; border-bottom-right-radius: 2.5rem; }
/* ---- 尺寸 / 定位 / 行高（任意值）---- */
.min-w-\[150px\] { min-width: 150px; }
.max-w-\[44vw\]  { max-width: 44vw; }
.-inset-6 { top: -1.5rem; right: -1.5rem; bottom: -1.5rem; left: -1.5rem; }
.leading-\[1\.05\] { line-height: 1.05; }
/* ---- hover 态 ---- */
.hover\:bg-indigo-50:hover  { background-color: #eef2ff; }
.hover\:bg-sky-50:hover     { background-color: #f0f9ff; }
.hover\:bg-slate-100:hover  { background-color: #f1f5f9; }
.hover\:bg-white\/15:hover  { background-color: rgba(255,255,255,.15); }
.hover\:bg-white\/20:hover  { background-color: rgba(255,255,255,.20); }
.hover\:border-indigo-200:hover { border-color: #c7d2fe; }
.hover\:border-white\/25:hover  { border-color: rgba(255,255,255,.25); }
.hover\:text-indigo-600:hover { color: #4f46e5; }
.hover\:text-indigo-700:hover { color: #4338ca; }
.hover\:text-sky-600:hover    { color: #0284c7; }
/* ---- 横滑容器隐藏滚动条 ---- */
.scrollbar-hide { -ms-overflow-style: none; scrollbar-width: none; }
.scrollbar-hide::-webkit-scrollbar { display: none; }
/* ---- 响应式（md）---- */
@media (min-width: 768px) {
  .md\:text-xl  { font-size: 1.25rem; line-height: 1.75rem; }
  .md\:text-3xl { font-size: 1.875rem; line-height: 2.25rem; }
  .md\:p-5  { padding: 1.25rem; }
  .md\:py-16 { padding-top: 4rem; padding-bottom: 4rem; }
  .md\:py-20 { padding-top: 5rem; padding-bottom: 5rem; }
  .md\:mb-12 { margin-bottom: 3rem; }
  .md\:gap-5 { gap: 1.25rem; }
  .md\:max-w-\[34vw\] { max-width: 34vw; }
}
