/* Charles 菜品换背景 —— 移动端优先
   设计取舍（Brainstorm→Critique）：原配色 cream + serif + terracotta 正是「通用 AI 默认」
   套路之一，故改为两家店真正的共同基因——「酒」：以 OKLCH 单基色推导的 wine/bordeaux 作强调，
   底色换成更克制的瓷白（非烘焙奶油色），衬线只保留在 Revel 字标里。强调只花在一处（主按钮+加载）。 */

:root{
  color-scheme: light dark;

  /* ---- 单基色推导的 wine 强调 + Radix 式 3 档语义 token（light-dark 双模） ---- */
  --bg:          light-dark(oklch(0.984 0.006 60),  oklch(0.175 0.012 35));
  --bg-subtle:   light-dark(oklch(0.965 0.008 60),  oklch(0.205 0.012 35));
  --card:        light-dark(oklch(1 0 0),           oklch(0.225 0.013 35));
  --surface-2:   light-dark(oklch(0.972 0.007 60),  oklch(0.255 0.013 35));
  --line:        light-dark(oklch(0.905 0.010 60),  oklch(0.320 0.013 35));
  --line-strong: light-dark(oklch(0.835 0.013 60),  oklch(0.400 0.013 35));
  --ink:         light-dark(oklch(0.265 0.020 40),  oklch(0.955 0.008 60)); /* 主文字 */
  --muted:       light-dark(oklch(0.500 0.020 40),  oklch(0.720 0.015 55)); /* 次文字 */
  --accent:      light-dark(oklch(0.430 0.165 16),  oklch(0.700 0.140 16)); /* wine fill (step9) */
  --accent-hover:light-dark(oklch(0.370 0.165 16),  oklch(0.760 0.130 16)); /* step10 */
  --accent-quiet:light-dark(oklch(0.962 0.022 16),  oklch(0.270 0.055 16)); /* 浅色底 step3 */
  --accent-text: light-dark(oklch(0.985 0.010 60),  oklch(0.150 0.020 35)); /* 强调底上的文字 */
  --accent-soft: var(--accent-quiet);                                       /* 旧名别名 */
  --gold:        light-dark(oklch(0.560 0.095 80),  oklch(0.740 0.095 80));
  --ok:          light-dark(oklch(0.500 0.110 150), oklch(0.700 0.120 150));
  --focus:       light-dark(oklch(0.430 0.165 16),  oklch(0.720 0.150 16));

  /* ---- easing by intent（Emil Kowalski）：入场=ease-out；屏内移动=ease-in-out；UI 永不 ease-in ---- */
  --ease-out:  cubic-bezier(0.16,1,0.3,1);
  --ease-move: cubic-bezier(0.22,1,0.36,1);

  --radius:16px;
  --shadow:0 6px 24px light-dark(oklch(0.45 0.04 50 / .12), oklch(0 0 0 / .45));
  --font:-apple-system,BlinkMacSystemFont,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",system-ui,sans-serif;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
/* 抽屉/弹层打开时锁背景滚动（:has()，修「背景仍可滚」这个真 bug） */
body:has(.modal.show){overflow:hidden}

/* 中文排版（djhh）：标题/正文避免孤字、平衡换行 */
h1,h2,h3,p,label,.hint,.chip,button{word-break:keep-all;overflow-wrap:break-word}
h1,h2,h3{text-wrap:balance;margin:0}
p{text-wrap:pretty}
.num{white-space:nowrap;font-variant-numeric:tabular-nums}

/* 可访问性：视觉隐藏但仍可聚焦（给真实表单控件用） */
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
/* 键盘焦点环（仅键盘可见） */
:focus-visible{outline:2.5px solid var(--focus);outline-offset:2px;border-radius:6px}
.chip:has(input:focus-visible),.drop:has(input:focus-visible){outline:2.5px solid var(--focus);outline-offset:2px}
*:focus:not(:focus-visible){outline:none}

.wrap{max-width:560px;margin:0 auto;padding:0 16px 120px;container-type:inline-size}

/* 顶栏 */
header{
  position:sticky;top:0;z-index:20;
  background:color-mix(in oklch, var(--bg) 85%, transparent);
  backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line);
}
.bar{max-width:560px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px}
.brand .dot{width:26px;height:26px;border-radius:8px;background:var(--accent);display:grid;place-items:center}
.brand .dot svg{width:16px;height:16px}
.balance{font-size:13px;color:var(--muted);text-align:right;line-height:1.3}
.balance b{color:var(--ink);font-size:15px}
.balance a{color:var(--accent);text-decoration:none;font-size:12px}
.balance a:focus-visible{text-decoration:underline}

/* 卡片 / 区块 */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-top:16px}
.step{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.step .n{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--accent-text);font-size:13px;font-weight:700;display:grid;place-items:center;flex:0 0 auto}
.step h2{font-size:16px}
.hint{font-size:12.5px;color:var(--muted);margin:6px 0 0}

/* 入场：滚动驱动揭示（已在视口内的卡片直接到终态，不闪；下方卡片滚动时浮入） */
@media (prefers-reduced-motion: no-preference){
  @supports (animation-timeline: view()){
    .card{animation:reveal both;animation-timeline:view();animation-range:entry 2% entry 30%}
    @keyframes reveal{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
  }
}

/* 上传区 */
.drop{
  border:1.5px dashed var(--line-strong);border-radius:14px;background:var(--bg-subtle);
  min-height:160px;display:grid;place-items:center;text-align:center;cursor:pointer;
  position:relative;overflow:hidden;transition:border-color .2s var(--ease-move),background .2s var(--ease-move);
}
.drop:hover{border-color:var(--accent)}
.drop .ph{color:var(--muted);font-size:14px;padding:24px}
.drop .ph .big{font-size:30px;margin-bottom:6px}
.drop img{width:100%;height:100%;max-height:340px;object-fit:contain;display:block}
.drop .change{position:absolute;right:10px;bottom:10px;background:oklch(0 0 0 / .6);color:#fff;font-size:12px;padding:6px 12px;border-radius:20px}

/* 选项网格 */
.grid{display:grid;gap:10px}
.bgs{grid-template-columns:repeat(3,1fr)}
.ratios{grid-template-columns:repeat(5,1fr)}
.logos{grid-template-columns:repeat(4,1fr)}
.lgsw{width:100%;height:34px;background-size:contain;background-repeat:no-repeat;background-position:center}
.lgsw-icon{display:grid;place-items:center;color:var(--muted);font-size:20px}
/* chip = 包住真实 radio 的 label（原生键盘方向键 + a11y） */
.chip{
  position:relative;
  border:1.5px solid var(--line);background:var(--card);border-radius:12px;padding:10px 6px;
  display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;
  font-size:12.5px;color:var(--ink);transition:border-color .15s var(--ease-move),background .15s var(--ease-move),color .15s var(--ease-move);text-align:center;
}
.chip:active{transform:scale(.97)}
.chip:has(input:checked){border-color:var(--accent);background:var(--accent-quiet);color:var(--accent);font-weight:600}
.chip .sw{width:100%;height:38px;border-radius:8px;border:1px solid oklch(0 0 0 / .05)}
/* 背景预设缩略 */
.sw-default{background:linear-gradient(160deg,#efe7da,#d9c3a3)}
.sw-warm{background:linear-gradient(160deg,#6b4a2f,#caa15f)}
.sw-wood{background:linear-gradient(160deg,#e8d8be,#bd9b6a)}
.sw-stone{background:linear-gradient(160deg,#3a3a3c,#6a6a6e)}
.sw-fresh{background:linear-gradient(160deg,#cdd6cb,#a9b6ad)}
.sw-custom{background:repeating-linear-gradient(45deg,var(--surface-2),var(--surface-2) 8px,var(--line) 8px,var(--line) 16px);display:grid;place-items:center;color:var(--muted);font-size:20px}
/* 比例缩略 */
.rt{display:grid;place-items:center;height:38px}
.rt i{display:block;background:var(--line-strong);border-radius:3px}
.chip:has(input:checked) .rt i{background:var(--accent)}

/* 宽容器（平板及以上）放大间距 */
@container (min-width:520px){
  .card{padding:22px}
  .grid{gap:12px}
}

/* 开关 */
.switch{display:flex;align-items:center;justify-content:space-between;gap:10px}
.toggle{position:relative;width:48px;height:28px;flex:0 0 auto}
.toggle input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.toggle .sl{position:absolute;inset:0;background:var(--line-strong);border-radius:20px;transition:background .2s var(--ease-move);pointer-events:none}
.toggle .sl:before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s var(--ease-move);box-shadow:0 1px 3px oklch(0 0 0 / .25)}
.toggle input:checked + .sl{background:var(--accent)}
.toggle input:checked + .sl:before{transform:translateX(20px)}
.toggle input:focus-visible + .sl{outline:2.5px solid var(--focus);outline-offset:2px}
.collapse{overflow:hidden;max-height:0;transition:max-height .28s var(--ease-move);opacity:.4}
.collapse.open{max-height:460px;opacity:1;margin-top:14px}
.corners{grid-template-columns:repeat(4,1fr)}

/* 生成按钮（吸底） */
.cta{
  position:fixed;left:0;right:0;bottom:0;z-index:30;
  background:linear-gradient(180deg,color-mix(in oklch,var(--bg),transparent),var(--bg) 28%);
  padding:14px 16px calc(14px + env(safe-area-inset-bottom));
}
.cta .inner{max-width:560px;margin:0 auto}
.btn{
  width:100%;border:0;border-radius:14px;padding:16px;font-size:16px;font-weight:700;
  background:var(--accent);color:var(--accent-text);cursor:pointer;font-family:var(--font);
  box-shadow:0 8px 20px color-mix(in oklch,var(--accent) 35%,transparent);transition:transform .1s var(--ease-move),background .2s var(--ease-move);
}
.btn:hover{background:var(--accent-hover)}
.btn:active{transform:translateY(1px)}
.btn:disabled{background:var(--line-strong);color:var(--bg);box-shadow:none;cursor:not-allowed}
.btn small{font-weight:500;opacity:.9}

/* 结果弹层 */
.modal{position:fixed;inset:0;z-index:50;background:oklch(0.18 0.02 40 / .72);display:none;align-items:center;justify-content:center;padding:18px}
.modal.show{display:flex}
.sheet{position:relative;background:var(--card);border-radius:18px;max-width:520px;width:100%;max-height:92vh;overflow:auto;padding:20px 18px}
.sheet h3{font-size:17px;margin-bottom:12px;text-align:center}
.close{position:absolute;top:10px;right:10px;width:34px;height:34px;border:0;border-radius:50%;background:var(--bg-subtle);color:var(--muted);font-size:20px;line-height:1;cursor:pointer;display:grid;place-items:center}
.close:hover{background:var(--line);color:var(--ink)}
.result-img{width:100%;border-radius:12px;display:block;background:var(--surface-2)}
.row{display:flex;gap:10px;margin-top:14px}
.row .btn{flex:1}
.btn.ghost{background:var(--card);color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:var(--bg-subtle)}

/* 加载 */
.loading{display:none;flex-direction:column;align-items:center;gap:16px;padding:30px 10px 8px;text-align:center}
.loading.show{display:flex}
.load-msg{font-size:14px;color:var(--muted)}

.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:11px 18px;border-radius:24px;font-size:13.5px;z-index:60;opacity:0;transition:opacity .25s var(--ease-out);pointer-events:none;max-width:90vw;text-align:center}
.toast.show{opacity:1}
.foot{text-align:center;color:var(--muted);font-size:12px;margin-top:22px;line-height:1.7}

/* View Transitions：弹层开合 / 加载→结果 用 ease-out 交叉过渡 */
@media (prefers-reduced-motion: no-preference){
  ::view-transition-old(root),::view-transition-new(root){animation-duration:.32s;animation-timing-function:var(--ease-out)}
}
