/* Pretendard, 한글 글리프 영역으로만 스코프.
   모든 화면의 한글 텍스트는 Pretendard로 렌더되고,
   영문은 다음 폴백(Fraunces / Noto Serif KR Latin / JetBrains Mono)으로 떨어져
   기존 영문 톤(로고 italic 세리프, 본문 클래식 세리프, 모노 라벨) 그대로 유지. */
@font-face {
  font-family: 'PretendardKR';
  src: local('Pretendard Variable'), local('Pretendard'),
       url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/packages/pretendard/dist/web/variable/woff2/PretendardVariable.woff2') format('woff2-variations'),
       url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/packages/pretendard/dist/web/static/woff2/Pretendard-Regular.woff2') format('woff2');
  font-weight: 100 900;
  font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}

:root {
  /* ── DRIPBOOK brand tokens (v01) ── */
  --ink:#1A1612;
  --bone:#F2ECE0;
  --paper:#F8F4EC;
  --coffee:#6F4A2E;
  --ash:#8A8178;
  --mist:#D9D1C2;
  --white:#FFFCF6;

  /* Semantic (kept for process chips — muted editorial tones) */
  --washed:#3E6B86;
  --natural:#A8602E;
  --anaerobic-natural:#6B4E86;
  --anaerobic-washed:#5A6B86;
  --teal:#4A7A64;
  --red:#A8443A;

  --border:rgba(26,22,18,0.12);
  --border2:rgba(26,22,18,0.06);
  --radius:8px;
  --radius-sm:4px;
  --radius-lg:12px;
  --shadow:0 1px 2px rgba(26,22,18,.04);
  --shadow-lg:0 12px 32px -16px rgba(26,22,18,.18);
  --transition:all .2s cubic-bezier(.4,0,.2,1);

  /* 한글은 모두 Pretendard (PretendardKR이 unicode-range로 한글만 잡고
     영문은 폴백으로 떨어져 기존 영문 폰트 그대로 유지). */
  --f-sans:'PretendardKR', 'Noto Serif KR', -apple-system, BlinkMacSystemFont, 'Segoe UI', serif;
  --f-serif-en:'Fraunces', 'Noto Serif KR', serif;
  --f-serif-kr:'PretendardKR', 'Noto Serif KR', sans-serif;
  --f-mono:'JetBrains Mono', ui-monospace, monospace;
  /* 숫자 표시 전용: 깔끔한 sans (Pretendard 라틴 글리프). 라벨은 --f-mono 유지. */
  --f-num:'Pretendard', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html,body {
  height:100%; height:100dvh;
  overflow:hidden;
  overscroll-behavior:none;
}
body {
  background:var(--bone); color:var(--ink);
  font-family:var(--f-sans); font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  position:fixed; inset:0;  /* 모바일 주소창 노출/숨김 시 점프 방지 */
}

/* ─── Screen System ─── */
.screen {
  display:none;
  position:absolute; inset:0;       /* 정확히 viewport 채움 */
  height:100%; height:100dvh;
  flex-direction:column;
  overflow:hidden;                  /* 스크린 자체 스크롤 금지, 자식이 처리 */
  padding-top:env(safe-area-inset-top, 0);
  padding-bottom:env(safe-area-inset-bottom, 0);
}
.screen.active { display:flex; }

/* ─── Shared Nav Header ─── */
.nav-header {
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; gap:.6rem;
  padding:0 1.1rem; height:56px; flex-shrink:0;
  background:rgba(242,236,224,.92); backdrop-filter:blur(20px) saturate(1.2);
  border-bottom:0.8px solid var(--border);
}
.back-btn {
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  background:transparent; border:0.8px solid var(--border); color:var(--ink);
  border-radius:var(--radius-sm); font-size:1rem; cursor:pointer; flex-shrink:0; transition:var(--transition);
}
.back-btn:hover { border-color:var(--ink); background:var(--paper); }
.nav-title {
  font-family:var(--f-mono); font-size:.62rem; letter-spacing:.25em; font-weight:500;
  text-transform:uppercase; color:var(--ash); flex:1;
}
.nav-logo {
  font-family:var(--f-serif-en); font-style:italic; font-weight:600;
  font-size:1.4rem; letter-spacing:.02em; color:var(--ink); flex:1;
}
.nav-right { display:flex; align-items:center; gap:.5rem; }
.user-label {
  font-family:var(--f-mono); font-size:.56rem; color:var(--ash);
  letter-spacing:.08em;
  max-width:120px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.logout-btn {
  font-family:var(--f-mono); font-size:.54rem; letter-spacing:.18em; text-transform:uppercase;
  background:transparent; color:var(--ash); border:0.8px solid var(--border);
  padding:.45rem .7rem; border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
}
.logout-btn:hover { border-color:var(--ink); color:var(--ink); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   1. LOADING
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenLoading {
  align-items:center; justify-content:center;
  background:var(--bone);
}
.load-mark { width:112px; height:112px; margin-bottom:1.8rem; animation:markFade .9s ease both; }
@keyframes markFade { from{opacity:0; transform:translateY(12px)} to{opacity:1; transform:translateY(0)} }
.load-logo {
  font-family:var(--f-serif-en); font-style:italic; font-weight:600;
  font-size:3.4rem; letter-spacing:.01em; color:var(--ink);
  animation:fadeUp .8s ease both;
}
.load-logo-kr {
  font-family:var(--f-serif-kr); font-weight:500;
  font-size:1.1rem; letter-spacing:.28em; color:var(--coffee);
  margin-top:.4rem;
  animation:fadeUp .8s .1s ease both;
}
.by-bublica { display:flex; align-items:center; justify-content:center; gap:.4rem; margin-top:1.2rem; animation:fadeUp .8s .15s ease both; }
.by-bublica-text {
  font-family:var(--f-mono); font-size:.5rem; letter-spacing:.18em;
  color:var(--ash); text-transform:uppercase;
}
.by-bublica svg { height:14px; width:auto; }
.by-bublica-login { margin-bottom:.2rem; }
.by-bublica-login .by-bublica-text { font-size:.48rem; }
.by-bublica-login svg { height:12px; }
.load-tagline {
  font-family:var(--f-mono); font-weight:500;
  font-size:.58rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ash);
  margin-top:.8rem; margin-bottom:2.6rem;
  animation:fadeUp .8s .2s ease both;
}
.load-bar-wrap {
  width:140px; height:1.5px; background:var(--mist);
  position:relative; overflow:hidden;
  animation:fadeUp .8s .3s ease both;
}
.load-bar-fill {
  position:absolute; top:0; left:0; height:100%;
  background:var(--ink);
  animation:loadFill 1.9s ease forwards;
}
@keyframes loadFill { 0%{width:0%} 60%{width:75%} 100%{width:100%} }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   2. LOGIN
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenLogin {
  align-items:center; justify-content:center; padding:2rem 1.5rem;
  background:var(--bone);
  overflow-y:auto;  /* 짧은 화면 fallback */
}
.login-wrap { width:100%; max-width:360px; }
.login-mark { width:72px; height:72px; display:block; margin:0 auto .9rem; }
.login-logo {
  font-family:var(--f-serif-en); font-style:italic; font-weight:600;
  font-size:2.4rem; letter-spacing:.01em; color:var(--ink);
  text-align:center; margin-bottom:.2rem;
}
.login-logo-kr {
  font-family:var(--f-serif-kr); font-weight:500;
  font-size:.9rem; letter-spacing:.24em; color:var(--coffee);
  text-align:center;
}
.login-tagline {
  font-family:var(--f-mono); font-size:.54rem; letter-spacing:.24em;
  text-transform:uppercase; color:var(--ash);
  text-align:center; margin-top:.6rem; margin-bottom:2.4rem;
}
.login-mode-label {
  font-family:var(--f-mono); font-size:.58rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--coffee);
  margin-bottom:1.2rem; display:flex; align-items:center; gap:.5rem;
  font-weight:500;
}
.login-mode-label::before { content:''; display:block; width:1rem; height:0.8px; background:var(--coffee); }
.field-group { margin-bottom:1rem; }
.field-group label {
  font-family:var(--f-mono); font-size:.54rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ash);
  display:block; margin-bottom:.45rem; font-weight:500;
}
.field-group input {
  width:100%; background:var(--white); border:0.8px solid var(--border); color:var(--ink);
  font-family:var(--f-sans); font-size:.95rem; padding:.85rem 1rem;
  outline:none; transition:var(--transition); -webkit-appearance:none;
  border-radius:var(--radius-sm);
}
.field-group input:focus { border-color:var(--ink); }
.field-group input::placeholder { color:var(--ash); opacity:.6; }
.auth-remember {
  display:flex; align-items:center; gap:.55rem;
  margin:.4rem 0 .9rem;
  cursor:pointer; user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.auth-remember input { position:absolute; opacity:0; pointer-events:none; }
.auth-remember-mark {
  width:16px; height:16px; flex-shrink:0;
  border:0.8px solid var(--border); border-radius:3px;
  background:var(--white); position:relative;
  transition:var(--transition);
}
.auth-remember input:focus-visible + .auth-remember-mark {
  outline:2px solid var(--coffee); outline-offset:2px;
}
.auth-remember input:checked + .auth-remember-mark {
  background:var(--ink); border-color:var(--ink);
}
.auth-remember input:checked + .auth-remember-mark::after {
  content:''; position:absolute;
  left:4.5px; top:1px;
  width:4px; height:8px;
  border:solid var(--bone);
  border-width:0 1.5px 1.5px 0;
  transform:rotate(45deg);
}
.auth-remember-text {
  font-family:var(--f-sans); font-size:.78rem; font-weight:500;
  color:var(--coffee); letter-spacing:.005em;
}
.auth-error {
  font-family:var(--f-sans); font-size:.72rem; color:var(--red);
  min-height:1.2rem; margin-bottom:.6rem;
}
.auth-submit {
  width:100%; font-family:var(--f-sans); font-size:.88rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  background:var(--ink); color:var(--bone);
  border:none; padding:1rem; border-radius:var(--radius-sm);
  cursor:pointer; transition:var(--transition); margin-bottom:.6rem;
}
.auth-submit:hover { background:#000; }
.auth-submit:active { transform:translateY(1px); }
.auth-toggle {
  width:100%; font-family:var(--f-mono); font-size:.54rem; letter-spacing:.18em;
  text-transform:uppercase;
  background:transparent; color:var(--ash); border:0.8px solid var(--border);
  padding:.8rem; border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
  font-weight:500;
}
.auth-toggle:hover { border-color:var(--ink); color:var(--ink); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   3. SCAN
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenScan { background:var(--bone); }
.scan-body {
  flex:1 1 0; min-height:0;
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; padding:2rem 1.5rem; gap:1.4rem;
}
.scan-mark { width:84px; height:84px; opacity:.9; }
.scan-hero-title {
  font-family:var(--f-serif-kr); font-weight:600; font-size:1.4rem;
  color:var(--ink); text-align:center; line-height:1.3; letter-spacing:.01em;
}
.scan-hero-sub {
  font-family:var(--f-mono); font-size:.56rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ash);
  text-align:center; margin-top:-.4rem;
}
.scan-btn-primary {
  position:relative; width:100%; max-width:340px;
  background:var(--ink); color:var(--bone); border:none;
  border-radius:var(--radius-sm);
  padding:1.1rem 1rem;
  display:flex; flex-direction:column; align-items:center; gap:.3rem;
  cursor:pointer; transition:var(--transition);
}
.scan-btn-primary:hover { background:#000; transform:translateY(-1px); }
.scan-btn-primary input[type=file] {
  position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%;
}
.sbp-icon { display:none; }
.sbp-label {
  font-family:var(--f-sans); font-weight:600; font-size:.95rem;
  letter-spacing:.08em; color:var(--bone); pointer-events:none;
}
.sbp-sub {
  font-family:var(--f-mono); font-size:.48rem; letter-spacing:.2em;
  text-transform:uppercase; color:rgba(242,236,224,.6); pointer-events:none;
}

/* scan states */
.scan-progress-area { display:none; width:100%; max-width:340px; }
.scan-progress-area.show { display:block; }
.scan-preview-img {
  width:100%; aspect-ratio:4/3; object-fit:cover;
  border:0.8px solid var(--border); border-bottom:none; display:block;
}
.scan-anim-box {
  padding:1.1rem 1rem 1.2rem; background:var(--white);
  border:0.8px solid var(--border); border-top:none; text-align:center;
}
.scanning-bar {
  position:relative;
  width:100%; max-width:220px; height:3px;
  margin:.2rem auto .75rem;
  background:var(--mist);
  border-radius:2px;
  overflow:hidden;
}
.scanning-bar-fill {
  position:absolute; top:0; left:-40%;
  width:40%; height:100%;
  background:var(--ink);
  border-radius:2px;
  animation:scanLoadingSweep 1.5s cubic-bezier(.45,0,.55,1) infinite;
}
@keyframes scanLoadingSweep {
  0%   { left:-40%; }
  100% { left:100%; }
}
.scanning-label {
  font-family:var(--f-sans); font-size:.86rem; font-weight:500;
  color:var(--coffee); letter-spacing:.005em;
}
.scan-result-box {
  display:none; width:100%; max-width:340px;
  background:var(--white); border:0.8px solid var(--ink);
  padding:1.25rem 1.2rem;
}
.scan-result-box.show { display:block; }
.sr-badge {
  font-family:var(--f-mono); font-size:.5rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--coffee); margin-bottom:.6rem; font-weight:500;
}
.sr-name {
  font-family:var(--f-serif-kr); font-size:1.05rem; font-weight:600;
  color:var(--ink); margin-bottom:.8rem; line-height:1.35;
}
.sr-rows { display:flex; flex-direction:column; gap:.35rem; margin-bottom:1rem; }
.sr-row {
  display:flex; justify-content:space-between; align-items:baseline;
  padding-bottom:.35rem; border-bottom:0.5px solid var(--border2);
}
.sr-row:last-child { border-bottom:none; }
.sr-key {
  font-family:var(--f-mono); font-size:.5rem; color:var(--ash);
  letter-spacing:.18em; text-transform:uppercase; font-weight:500;
}
.sr-val {
  font-family:var(--f-sans); font-size:.82rem; color:var(--ink); font-weight:500;
}
.sr-continue {
  width:100%; font-family:var(--f-sans); font-size:.82rem; font-weight:600;
  letter-spacing:.08em;
  background:var(--ink); color:var(--bone); border:none; padding:.9rem;
  border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
}
.sr-continue:hover:not(:disabled) { background:#000; }
.sr-continue:disabled { opacity:.3; cursor:not-allowed; }
.sr-rescan {
  display:block; margin:.55rem auto 0; padding:.4rem .75rem;
  background:transparent; color:var(--ash);
  font-family:var(--f-mono); font-size:.55rem; letter-spacing:.18em;
  text-transform:uppercase; font-weight:500;
  border:0.6px solid var(--border); border-radius:var(--radius-sm);
  cursor:pointer; transition:var(--transition);
}
.sr-rescan:hover { color:var(--ink); border-color:var(--ink); }

.sr-conf {
  display:inline-block; font-family:var(--f-mono); font-size:.46rem; letter-spacing:.12em;
  padding:.15rem .4rem; text-transform:uppercase;
  margin-left:.3rem; vertical-align:middle; font-weight:500;
  border-radius:2px;
}
.sr-conf-ai  { background:rgba(111,74,46,.1); color:var(--coffee); }
.sr-conf-low { background:rgba(168,96,46,.12); color:var(--natural); }

.sr-blend-badge {
  display:inline-block;
  font-family:var(--f-mono); font-size:.5rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  padding:.18rem .45rem;
  margin-left:.35rem; vertical-align:middle;
  background:var(--ink); color:var(--bone);
  border-radius:2px;
}

.sr-roast-confirm {
  display:none; margin-bottom:1rem; padding:.9rem;
  background:var(--paper); border:0.5px dashed var(--border);
}
.sr-roast-q {
  font-family:var(--f-serif-kr); font-size:.88rem; font-weight:600;
  color:var(--ink); margin-bottom:.3rem;
}
.sr-roast-hint {
  font-family:var(--f-sans); font-size:.7rem; color:var(--ash);
  margin-bottom:.65rem; line-height:1.55;
}
.sr-roast-pills { display:grid; grid-template-columns:1fr 1fr 1fr; gap:.4rem; }
.sr-roast-pill {
  font-family:var(--f-sans); font-size:.82rem; font-weight:500;
  padding:.55rem .3rem; background:var(--white); border:0.8px solid var(--border);
  border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition); color:var(--ink);
}
.sr-roast-pill:hover { border-color:var(--ink); }
.sr-roast-pill.selected { border-color:var(--ink); background:var(--ink); color:var(--bone); }
.scan-error-box { display:none; width:100%; max-width:340px; text-align:center; }
.scan-error-box.show { display:flex; flex-direction:column; align-items:center; gap:.8rem; }
.scan-error-msg {
  font-family:var(--f-sans); font-size:.82rem; color:var(--red);
  line-height:1.7;
}
.scan-retry-btn {
  font-family:var(--f-mono); font-size:.54rem; letter-spacing:.18em; text-transform:uppercase;
  background:transparent; color:var(--ink); border:0.8px solid var(--border);
  padding:.6rem 1.2rem; border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
  font-weight:500;
}
.scan-retry-btn:hover { border-color:var(--ink); background:var(--paper); }
.manual-link {
  background:transparent; border:none;
  font-family:var(--f-mono); font-size:.56rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ash); cursor:pointer;
  padding:.5rem; text-decoration:none; transition:var(--transition); margin-top:.4rem;
  border-bottom:0.8px solid var(--border); font-weight:500;
}
.manual-link:hover { color:var(--ink); border-bottom-color:var(--ink); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   4. ROAST
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenRoast { background:var(--bone); }
.select-body {
  flex:1 1 0; min-height:0;
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding:1.4rem 1.2rem;
}
.screen-section-label {
  font-family:var(--f-mono); font-weight:500;
  font-size:.58rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ash); margin-bottom:1.2rem;
  display:flex; align-items:center; gap:.6rem;
}
.screen-section-label::before { content:''; display:block; width:1.2rem; height:0.8px; background:var(--ash); }

/* ─── Bean name input (manual flow, optional) ─── */
#screenBeanName .select-body {
  display:flex; flex-direction:column; gap:1.2rem;
  padding-top:1.5rem;
}
.bean-name-intro {
  display:flex; flex-direction:column; gap:.65rem;
}
.bean-name-h {
  margin:0;
  font-family:var(--f-serif-kr); font-weight:600; font-size:1.35rem;
  color:var(--ink); letter-spacing:-.005em; line-height:1.35;
}
.bean-name-p {
  margin:0;
  font-family:var(--f-sans); font-size:.85rem; line-height:1.6;
  color:var(--ash); word-break:keep-all;
}
.bean-name-hint {
  display:block; margin-top:.4rem;
  font-family:var(--f-mono); font-size:.68rem;
  letter-spacing:.04em; color:var(--coffee);
}
.bean-name-input-wrap {
  display:flex; flex-direction:column;
}
.bean-input-label {
  display:block;
  font-family:var(--f-mono); font-size:.62rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--coffee);
  margin-top:.95rem;
  margin-bottom:.4rem;
}
.bean-input-label:first-child { margin-top:0; }

#screenBeanName[data-mode="single"] .bean-info-blend  { display:none; }
#screenBeanName[data-mode="blend"]  .bean-info-single { display:none; }
.bean-name-input {
  width:100%;
  background:var(--white); border:0.8px solid var(--border);
  padding:1.05rem 1.1rem;
  font-family:var(--f-serif-kr); font-size:1rem; font-weight:500;
  color:var(--ink); letter-spacing:.005em;
  border-radius:var(--radius-sm);
  outline:none; transition:var(--transition);
}
.bean-name-input:focus { border-color:var(--ink); }
.bean-name-input::placeholder { color:var(--ash); font-weight:400; }

.bean-name-actions {
  display:flex; flex-direction:column; gap:.6rem;
  padding:1rem 1.2rem 1.6rem;
  border-top:0.5px solid var(--border);
  background:var(--bone);
  flex-shrink:0;
}
.bean-name-next {
  width:100%;
  background:var(--ink); color:var(--bone); border:none;
  padding:1rem;
  font-family:var(--f-sans); font-size:.92rem; font-weight:600;
  letter-spacing:.04em;
  border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
}
.bean-name-next:hover { background:#000; }
.bean-name-skip {
  width:100%;
  background:transparent; color:var(--ash); border:none;
  padding:.7rem;
  font-family:var(--f-mono); font-size:.6rem; font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  cursor:pointer; transition:var(--transition);
}
.bean-name-skip:hover { color:var(--ink); }

/* ─── Bean type select (manual flow) ─── */
.bean-type-list { display:flex; flex-direction:column; gap:.6rem; }
.bean-type-card {
  background:var(--white); border:0.8px solid var(--border); border-radius:var(--radius-sm);
  padding:1.15rem 1.1rem; cursor:pointer; transition:var(--transition);
  display:flex; align-items:flex-start; gap:.9rem;
  min-height:84px;
}
.bean-type-card:hover { border-color:var(--ink); }
.bean-type-card.selected { border-color:var(--ink); background:var(--paper); }
.bean-type-icon {
  flex-shrink:0; margin-top:.5rem;
  width:42px; min-width:42px; height:14px;
  display:inline-flex; align-items:center; justify-content:flex-start;
  gap:5px;
}
.bean-type-icon::before {
  content:''; width:11px; height:11px; border-radius:50%;
  background:var(--coffee); display:block; flex-shrink:0;
}
/* 싱글 한 점을 블렌드 두 점 시각 중심(컨테이너 기준 x≈13.5px)에 맞추기 위해 8px 좌측 오프셋 */
.bean-type-card[data-type="single"] .bean-type-icon::before {
  margin-left:8px;
}
.bean-type-card[data-type="blend"] .bean-type-icon::after {
  content:''; width:11px; height:11px; border-radius:50%;
  background:var(--coffee); display:block; flex-shrink:0;
  opacity:.55;
}
.bean-type-name {
  font-family:var(--f-serif-kr); font-size:1.02rem; font-weight:600;
  color:var(--ink); margin-bottom:.25rem; letter-spacing:.01em;
}
.bean-type-desc {
  font-family:var(--f-sans); font-size:.78rem;
  color:var(--ash); line-height:1.55; word-break:keep-all;
}

.roast-list { display:flex; flex-direction:column; gap:.6rem; }
.roast-card {
  background:var(--white); border:0.8px solid var(--border); border-radius:var(--radius-sm);
  padding:1.15rem 1.1rem; cursor:pointer; transition:var(--transition);
  display:flex; align-items:flex-start; gap:.9rem;
  min-height:84px;
}
.roast-card:hover { border-color:var(--ink); }
.roast-card.sel-light,
.roast-card.sel-medium,
.roast-card.sel-dark { border-color:var(--ink); background:var(--paper); }
.roast-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; margin-top:.35rem; }
.roast-dot.light  { background:#D4A574; }
.roast-dot.medium { background:#A97148; }
.roast-dot.dark   { background:#4A2E1E; }
.roast-card-name {
  font-family:var(--f-serif-kr); font-size:1.02rem; font-weight:600;
  color:var(--ink); margin-bottom:.25rem; letter-spacing:.01em;
}
.roast-card-desc {
  font-family:var(--f-sans); font-size:.76rem; color:var(--ash);
  line-height:1.55;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   5. PROCESS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenProcess { background:var(--bone); }
/* 드리퍼 카드(.method-card)와 동일한 사이즈·톤 — 2-col grid + 큰 카드 + 가운데 정렬.
   selected는 ink 배경 인버트가 아니라 보더 강조만 (가공방식·로스팅은 의미값 강조형). */
.proc-list {
  display:grid; grid-template-columns:1fr 1fr; gap:.8rem;
  align-content:start;
}
.proc-card {
  background:var(--paper); border:1px solid var(--mist); border-radius:14px;
  padding:2rem 1rem 1.4rem; cursor:pointer; transition:var(--transition);
  text-align:center; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:.85rem;
  min-height:175px; color:var(--ink);
}
.proc-card:hover { border-color:var(--ink); }
.proc-card:active { transform:translateY(1px); }
.proc-card.sel-washed,
.proc-card.sel-natural,
.proc-card.sel-anaerobic_natural,
.proc-card.sel-anaerobic_washed,
.proc-card.sel-none {
  border-color:var(--ink); background:var(--white);
}
/* 없음/기타 — 5번째 카드, 그리드에서 가운데 정렬 */
.proc-card-fallback {
  grid-column:1 / -1;
  justify-self:center;
  width:60%;
  border-style:dashed;
}
.proc-dot {
  width:32px; height:32px; border-radius:50%; flex-shrink:0;
  box-sizing:border-box;
}
.proc-dot.washed            { background:var(--washed); }
.proc-dot.natural           { background:var(--natural); }
.proc-dot.anaerobic-natural { background:var(--anaerobic-natural); }
.proc-dot.anaerobic-washed  { background:var(--anaerobic-washed); }
.proc-dot.none              { background:transparent; border:2px dashed var(--mist); }
.proc-card-name {
  font-family:var(--f-sans); font-size:1.05rem; font-weight:600;
  color:var(--ink); letter-spacing:.005em;
}
.proc-card-meta {
  font-family:var(--f-mono); font-size:.5rem; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ash);
  word-break:keep-all;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   6. METHOD
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenMethod { background:var(--bone); }
.method-ctx {
  background:var(--paper); border-bottom:0.8px solid var(--border);
  padding:.85rem 1.2rem;
  font-family:var(--f-mono); font-size:.56rem;
  color:var(--ash); letter-spacing:.12em; text-transform:uppercase;
  line-height:1.7; font-weight:500;
}
.method-ctx strong {
  font-family:var(--f-serif-kr); font-weight:600; font-size:.8rem;
  color:var(--ink); text-transform:none; letter-spacing:0;
}
#screenMethod .select-body { display:flex; flex-direction:column; }
.method-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:.8rem;
  align-content:start;
}
.method-card {
  background:var(--paper); border:1px solid var(--mist); border-radius:14px;
  padding:2rem 1rem 1.4rem; cursor:pointer; transition:var(--transition);
  text-align:center; display:flex; flex-direction:column;
  align-items:center; justify-content:flex-start; gap:.85rem;
  min-height:0; color:var(--ink);
}
.method-card:hover { border-color:var(--ink); }
.method-card:active { transform:translateY(1px); }
.method-card.selected {
  background:var(--ink); border-color:var(--ink); color:var(--bone);
}
/* fallback(기타/없음) — 5번째 카드, 그리드에서 가운데 정렬 */
.method-card-fallback {
  grid-column:1 / -1;
  justify-self:center;
  width:60%;
  border-style:dashed;
}
.method-card-icon {
  color:inherit; display:inline-flex; align-items:center; justify-content:center;
  width:4rem; height:4rem; transition:var(--transition);
}
.method-card-icon svg { width:2.6rem; height:2.6rem; display:block; }
.method-card:hover .method-card-icon { color:var(--coffee); }
.method-card.selected .method-card-icon,
.method-card.selected:hover .method-card-icon { color:var(--bone); }
.method-card-name {
  font-family:var(--f-sans); font-size:1.05rem; font-weight:600;
  color:inherit; letter-spacing:.005em;
}
.method-card-meta {
  font-family:var(--f-mono); font-size:.5rem; font-weight:500;
  letter-spacing:.24em; text-transform:uppercase; color:var(--ash);
}
.method-card.selected .method-card-meta { color:var(--mist); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   7. RECIPE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
#screenRecipe { background:var(--bone); }
.recipe-body {
  flex:1 1 0; min-height:0;
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding:1.4rem 1.2rem 1.6rem;
  display:flex; flex-direction:column; gap:1.3rem;
}

/* ─── Recipe Card (editorial dial-row) ─── */
.recipe-card {
  background:var(--paper);
  border:0.8px solid var(--border);
  border-radius:16px;
  padding:1.4rem 1.35rem 1.1rem;
  display:flex; flex-direction:column; gap:1rem;
  box-shadow:var(--shadow);
}
.recipe-card.hidden { display:none; }

/* Hot/Ice segmented */
.rc-hotice {
  align-self:flex-start; display:inline-flex;
  background:var(--white); border:0.8px solid var(--border);
  padding:2px; gap:0;
}
.rc-hi-btn {
  font-family:var(--f-mono); font-size:.55rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase;
  background:transparent; color:var(--ash); border:none;
  padding:.5rem 1rem; cursor:pointer; transition:var(--transition);
}
.rc-hi-btn:hover { color:var(--ink); }
.rc-hi-btn.active { background:var(--ink); color:var(--bone); }

/* Card head row */
.rc-card-head {
  display:flex; justify-content:space-between; align-items:baseline;
  font-family:var(--f-mono); font-size:.62rem; font-weight:500;
  letter-spacing:.3em; text-transform:uppercase; color:var(--ash);
  padding-bottom:.9rem;
  border-bottom:0.8px solid var(--border);
}

/* Title block */
.rc-card-title {
  display:flex; flex-direction:column; gap:.32rem;
  padding:.55rem .8rem .55rem;
  margin:0 -.4rem;
  border-radius:var(--radius-sm);
  background:linear-gradient(180deg, rgba(111,74,46,.08) 0%, rgba(111,74,46,.025) 100%);
  border-left:2px solid rgba(111,74,46,.35);
}
.rc-card-kr {
  font-family:var(--f-serif-kr); font-weight:600;
  font-size:1.8rem; color:var(--ink); letter-spacing:-.005em;
  line-height:1.22;
}
.rc-card-en {
  font-family:var(--f-serif-en); font-style:italic; font-weight:500;
  font-size:.98rem; color:var(--ash); letter-spacing:.01em;
}
.rc-card-ice-note {
  margin-top:.35rem;
  font-family:var(--f-mono); font-size:.52rem; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase; color:var(--washed);
}

/* Dial rows */
.rc-dials {
  display:flex; flex-direction:column;
}
.rc-dial {
  display:flex; justify-content:space-between; align-items:baseline;
  padding:1rem 0;
  border-top:0.5px solid var(--border);
}
.rc-dial:first-child { border-top:none; padding-top:.6rem; }
.rc-dial-left {
  display:flex; flex-direction:column; gap:.2rem; min-width:0;
}
.rc-dial-kr {
  font-family:var(--f-sans); font-weight:500; font-size:.95rem;
  color:var(--ink); letter-spacing:.005em;
}
.rc-dial-en {
  font-family:var(--f-mono); font-size:.52rem; font-weight:500;
  color:var(--ash); letter-spacing:.28em; text-transform:uppercase;
}
.rc-dial-en.brand { letter-spacing:.22em; }
.rc-dial-right {
  display:flex; align-items:baseline; gap:.22rem; flex-shrink:0;
  justify-content:flex-end;
}
.rc-dial-val {
  font-family:var(--f-num); font-weight:600; font-size:1.65rem;
  color:var(--ink); letter-spacing:0; line-height:1;
  font-variant-numeric:tabular-nums;
  text-align:right;
  min-width:3.2ch;
}
.rc-dial-val.rc-dial-ratio {
  font-size:1.4rem; letter-spacing:.01em; min-width:auto;
}
.rc-dial-unit {
  font-family:var(--f-num); font-size:.78rem; font-weight:500;
  color:var(--ash); letter-spacing:0;
}

/* Grind disclaimer note (placed under dials) */
.rc-grind-note {
  margin:0;
  padding:.85rem 0 1rem;
  border-top:0.5px solid var(--border);
  font-family:var(--f-sans);
  font-size:.78rem;
  font-weight:400;
  line-height:1.55;
  color:var(--ash);
  letter-spacing:.005em;
  word-break:keep-all;
}

/* Variant picker (other recipes) */
.rc-variants {
  display:flex; flex-direction:column;
  border-top:0.5px solid var(--border);
  padding-top:.5rem;
}
.rc-variants[hidden] { display:none; }

.rc-variants-toggle {
  display:flex; align-items:center; gap:.6rem;
  background:transparent; border:none;
  padding:.65rem 0; cursor:pointer; transition:var(--transition);
  text-align:left;
}
.rc-variants-toggle:hover .rc-variants-label { color:var(--coffee); }
.rc-variants-toggle:hover .rc-variants-arrow { color:var(--ink); }
.rc-variants-label {
  font-family:var(--f-sans); font-weight:500; font-size:.9rem;
  color:var(--ink); transition:var(--transition);
}
.rc-variants-count {
  font-family:var(--f-mono); font-size:.54rem; font-weight:500;
  letter-spacing:.24em; text-transform:uppercase; color:var(--ash);
  margin-left:auto;
}
.rc-variants-arrow {
  font-family:var(--f-mono); font-size:.62rem; color:var(--ash);
  transition:transform .25s cubic-bezier(.4,0,.2,1);
  margin-left:.15rem;
}
.rc-variants-toggle.open .rc-variants-arrow { transform:rotate(180deg); color:var(--ink); }
.rc-variants-toggle.open .rc-variants-label { color:var(--ink); }

.rc-variants-list {
  display:flex; flex-direction:column; gap:.4rem;
  margin-top:.55rem; margin-bottom:.3rem;
  animation:grinderFadeIn .22s cubic-bezier(.4,0,.2,1);
}
.rc-variants-list[hidden] { display:none; }

.rc-var-item {
  background:var(--white); border:0.8px solid var(--border);
  padding:.8rem 1rem;
  display:flex; flex-direction:column; gap:.28rem;
  cursor:pointer; transition:var(--transition);
}
.rc-var-item:hover { border-color:var(--ink); background:var(--paper); }
.rc-var-item:active { transform:translateY(1px); }
.rc-var-item.active {
  background:var(--ink); border-color:var(--ink); cursor:default;
}
.rc-var-item.active:active { transform:none; }
.rc-var-name {
  font-family:var(--f-serif-kr); font-weight:600; font-size:.95rem;
  color:var(--ink); line-height:1.3; letter-spacing:.005em;
}
.rc-var-source {
  font-family:var(--f-mono); font-size:.5rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ash); font-weight:500;
}
.rc-var-badge {
  align-self:flex-start;
  font-family:var(--f-mono); font-size:.46rem; font-weight:600;
  letter-spacing:.26em; text-transform:uppercase;
  color:var(--coffee);
}
.rc-var-badge.featured {
  background:var(--coffee); color:var(--bone);
  padding:.22rem .5rem;
}
.rc-var-item.active .rc-var-name,
.rc-var-item.active .rc-var-source,
.rc-var-item.active .rc-var-badge { color:var(--bone); }
.rc-var-item.active .rc-var-source { opacity:.75; }
.rc-var-item.active .rc-var-badge.featured {
  background:var(--bone); color:var(--ink);
}

/* Brew start button */
.rc-brew-start {
  width:100%;
  font-family:var(--f-sans); font-size:.95rem; font-weight:600;
  letter-spacing:.18em;
  background:var(--ink); color:var(--bone); border:none;
  padding:1.1rem; cursor:pointer; transition:var(--transition);
  margin-top:.4rem;
}
.rc-brew-start:hover { background:#000; }
.rc-brew-start:active { transform:translateY(1px); }

/* ─── Timeline (pour steps) ─── */
.recipe-timeline-wrap {
  background:var(--white); border:0.8px solid var(--border);
  padding:1.2rem 1.1rem;
  display:flex; flex-direction:column; gap:1rem;
}
.recipe-timeline-wrap.hidden { display:none; }
.timeline-head {
  display:flex; justify-content:space-between; align-items:baseline;
}
.timeline-title {
  font-family:var(--f-mono); font-size:.56rem; letter-spacing:.28em;
  text-transform:uppercase; color:var(--ash); font-weight:500;
}
.timeline-total {
  font-family:var(--f-mono); font-size:.54rem; color:var(--ash);
  letter-spacing:.1em;
}
.timeline-total strong {
  font-family:var(--f-num); color:var(--ink); font-weight:600;
  font-variant-numeric:tabular-nums;
}

.timeline-steps {
  position:relative; display:flex; justify-content:space-between;
  align-items:flex-start; padding:.1rem .25rem 0;
}
.timeline-steps::before {
  content:''; position:absolute; left:.25rem; right:.25rem;
  top:11px; height:1px; background:var(--border); z-index:0;
}
.step-col {
  position:relative; z-index:1; display:flex; flex-direction:column;
  align-items:center; gap:.4rem; flex:1; min-width:0;
  cursor:pointer;
}
.step-node {
  width:22px; height:22px; border-radius:50%;
  background:var(--bone); border:1.2px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-mono); font-size:.54rem; font-weight:600;
  color:var(--ash); transition:var(--transition);
}
.step-node.active {
  background:var(--ink); border-color:var(--ink); color:var(--bone);
}
.step-node.done {
  background:var(--coffee); border-color:var(--coffee); color:var(--bone);
}
.step-label {
  font-family:var(--f-mono); font-size:.48rem; font-weight:500;
  color:var(--ash); letter-spacing:.1em; text-transform:uppercase;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  max-width:76px; text-align:center;
}
.step-col.active .step-label { color:var(--ink); }

.step-card {
  background:var(--paper);
  border:0.8px solid var(--border);
  padding:1.05rem 1.1rem; display:grid;
  grid-template-columns:2.6em 1fr; gap:.95rem; align-items:center;
}
.step-card-num {
  font-family:var(--f-num); font-weight:600; font-size:2rem;
  color:var(--ink); line-height:1; letter-spacing:0;
  font-variant-numeric:tabular-nums;
  text-align:right;
}
.step-card-num-unit {
  font-family:var(--f-mono); font-size:.48rem; color:var(--ash);
  letter-spacing:.2em; text-transform:uppercase; margin-left:.2rem; font-weight:500;
}
.step-card-body { display:flex; flex-direction:column; gap:.35rem; min-width:0; }
.step-card-name {
  font-family:var(--f-serif-kr); font-weight:600; font-size:1rem;
  color:var(--ink); line-height:1.3; letter-spacing:.01em;
}
.step-card-instr {
  font-family:var(--f-sans); font-size:.8rem;
  color:var(--ash); line-height:1.55;
}
.step-countdown {
  display:flex; align-items:baseline; gap:.45rem;
  font-family:var(--f-mono); font-size:.5rem;
  color:var(--ash); letter-spacing:.2em; text-transform:uppercase; font-weight:500;
}
.step-countdown-val {
  font-family:var(--f-num); font-weight:600; font-size:1.1rem;
  color:var(--coffee); letter-spacing:0;
  font-variant-numeric:tabular-nums;
}

.pour-start-btn {
  width:100%; font-family:var(--f-sans); font-size:.85rem; font-weight:600;
  letter-spacing:.14em;
  background:var(--ink); color:var(--bone); border:none; padding:1rem;
  border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
}
.ctrl-icon {
  width:1em; height:1em;
  display:inline-block; flex-shrink:0;
  vertical-align:-0.12em;
}
.pour-start-btn:hover { background:#000; }
.pour-start-btn.running {
  background:var(--coffee);
}
.pour-start-btn.running:hover { background:#5a3c26; }

.pour-ctrl-row {
  display:grid;
  grid-template-columns:1fr auto;
  gap:.6rem;
  align-items:stretch;
}
.pour-ctrl-row .pour-start-btn { width:100%; }
.pour-skip-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  background:var(--paper); color:var(--ink);
  border:0.5px solid var(--ink);
  padding:.95rem 1.05rem;
  font-family:var(--f-mono); font-size:.6rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  border-radius:var(--radius-sm);
  cursor:pointer; transition:var(--transition);
}
.pour-skip-btn:hover:not(:disabled) {
  background:var(--ink); color:var(--bone);
}
.pour-skip-btn:hover:not(:disabled) .ctrl-icon { transform:translateX(2px); }
.pour-skip-btn:disabled {
  opacity:.4; cursor:default;
  border-color:var(--border); color:var(--ash);
}
.pour-skip-btn .ctrl-icon {
  width:.95em; height:.95em;
  transition:transform .2s cubic-bezier(.4,0,.2,1);
}

.timeline-back-btn {
  width:100%;
  font-family:var(--f-mono); font-size:.58rem; font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  background:transparent; color:var(--ash); border:0.5px solid var(--border);
  padding:.85rem; cursor:pointer; transition:var(--transition);
}
.timeline-back-btn:hover { border-color:var(--ink); color:var(--ink); }

/* ─── Completed step card ─── */
.step-card-complete {
  background:var(--paper);
  border:0.8px solid var(--coffee);
  border-radius:var(--radius-sm);
}
.step-card-complete .step-card-num {
  color:var(--coffee); font-size:2.4rem;
}
.step-card-complete .step-card-name {
  color:var(--coffee);
}

/* ─── Persistent feedback CTA (recipe body 하단 상시 노출) ─── */
.recipe-feedback-cta {
  width:100%;
  display:inline-flex; align-items:center; justify-content:center; gap:.65rem;
  background:transparent; color:var(--coffee);
  border:0.8px solid var(--coffee);
  padding:.95rem 1rem;
  font-family:var(--f-sans); font-size:.85rem; font-weight:600;
  letter-spacing:.02em;
  border-radius:var(--radius-sm); cursor:pointer; transition:var(--transition);
  margin-top:.4rem;
}
.recipe-feedback-cta:hover {
  background:var(--coffee); color:var(--bone);
}
.recipe-feedback-icon {
  width:1.05rem; height:1.05rem; flex-shrink:0;
}
.recipe-feedback-label { flex-shrink:0; }
.recipe-feedback-arr {
  font-family:var(--f-mono); font-size:1rem; font-weight:500;
  transition:transform .2s cubic-bezier(.4,0,.2,1);
  margin-left:.15rem;
}
.recipe-feedback-cta:hover .recipe-feedback-arr { transform:translateX(3px); }

/* ─── Grind Convert Trigger (under grind dial value) ─── */
.rc-dial-right-grind {
  display:flex; flex-direction:column; align-items:flex-end; gap:.45rem;
}
.rc-grind-value-row {
  display:flex; align-items:baseline; gap:.7rem;
  justify-content:space-between;
  width:100%;
}
.rc-grind-num {
  display:inline-flex; align-items:baseline; gap:.25rem;
  flex-shrink:0;
}
.rc-grind-size-tag {
  display:inline-block;
  padding:.22rem .55rem;
  background:var(--coffee); color:var(--bone);
  font-family:var(--f-serif-kr); font-weight:600; font-size:.72rem;
  letter-spacing:.02em;
  border-radius:2px;
  white-space:nowrap;
  cursor:help;
}
.rc-grind-convert-btn {
  display:inline-flex; align-items:center; gap:.35rem;
  background:transparent; border:0.5px solid var(--border);
  padding:.35rem .65rem;
  font-family:var(--f-mono); font-size:.52rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ash); cursor:pointer;
  transition:var(--transition);
}
.rc-grind-convert-btn:hover {
  border-color:var(--ink); color:var(--ink); background:var(--paper);
}
.rc-grind-convert-arrow {
  font-family:var(--f-mono); font-size:.65rem;
  transition:transform .2s cubic-bezier(.4,0,.2,1);
}
.rc-grind-convert-btn:hover .rc-grind-convert-arrow {
  transform:translate(2px, -2px);
}

/* ─── Grinder Conversion Modal ─── */
body.no-scroll { overflow:hidden; }
.gcv-modal {
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  padding:1.2rem;
}
.gcv-modal[hidden] { display:none; }
.gcv-modal-backdrop {
  position:absolute; inset:0;
  background:rgba(26, 22, 18, 0.55);
  backdrop-filter:blur(3px);
  animation:gcvFade .2s ease;
}
.gcv-modal-panel {
  position:relative;
  width:100%; max-width:640px; max-height:88vh;
  background:var(--bone);
  border:0.8px solid var(--ink);
  display:flex; flex-direction:column;
  animation:gcvPop .22s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
@keyframes gcvFade { from { opacity:0; } to { opacity:1; } }
@keyframes gcvPop {
  from { opacity:0; transform:translateY(8px) scale(.985); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.gcv-modal-head {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:1rem;
  padding:1.15rem 1.2rem 1rem;
  border-bottom:0.5px solid var(--border);
  background:var(--paper);
}
.gcv-modal-titles { display:flex; flex-direction:column; gap:.3rem; min-width:0; }
.gcv-title {
  margin:0;
  font-family:var(--f-serif-kr); font-weight:600; font-size:1.02rem;
  color:var(--ink); letter-spacing:.005em;
}
.gcv-sub {
  margin:0;
  font-family:var(--f-sans); font-size:.72rem; line-height:1.5;
  color:var(--ash); word-break:keep-all;
}
.gcv-modal-close {
  flex-shrink:0;
  background:transparent; border:0.5px solid var(--border);
  width:2rem; height:2rem;
  font-family:var(--f-sans); font-size:1.25rem; line-height:1;
  color:var(--ash); cursor:pointer;
  transition:var(--transition);
}
.gcv-modal-close:hover { border-color:var(--ink); color:var(--ink); background:var(--bone); }

.gcv-scroll {
  flex:1;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  background:var(--bone);
}
.gcv-table {
  border-collapse:collapse; width:max-content; min-width:100%;
  font-family:var(--f-mono); font-size:.72rem;
  color:var(--ink);
}
.gcv-table th, .gcv-table td {
  padding:.55rem .7rem;
  text-align:center;
  border-bottom:0.5px solid var(--border);
  white-space:nowrap;
  letter-spacing:.01em;
}
.gcv-table th {
  font-weight:600;
  font-size:.58rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ash);
  background:var(--paper);
  position:sticky; top:0; z-index:1;
}
.gcv-table td.gcv-anchor,
.gcv-table th.gcv-anchor {
  font-weight:600;
  color:var(--coffee);
  border-right:0.5px solid var(--ink);
  position:sticky; left:0;
  z-index:1;
}
.gcv-table td.gcv-anchor {
  background:#F1E9DA;
  box-shadow:1px 0 0 var(--border);
}
.gcv-table th.gcv-anchor {
  z-index:3;
  background:var(--paper);
  box-shadow:1px 0 0 var(--border);
}
.gcv-table tr.gcv-row-active td {
  background:var(--ink);
  color:var(--bone);
  font-weight:600;
}
.gcv-table tr.gcv-row-active td.gcv-anchor {
  background:var(--coffee);
  color:var(--bone);
  z-index:2;
  box-shadow:1px 0 0 var(--ink);
}
.gcv-foot {
  margin:0;
  padding:.85rem 1.2rem 1rem;
  border-top:0.5px solid var(--border);
  background:var(--paper);
  font-family:var(--f-mono); font-size:.6rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--coffee);
}
.gcv-foot-warn { color:var(--ash); }

/* ─── Correction Badge (recipe card) ─── */
.rc-correction-badge,
.rc-origin-note {
  display:flex; align-items:center; gap:.55rem;
  margin-top:.85rem;
  padding:.55rem .8rem;
  background:rgba(111, 74, 46, 0.08);
  border:0.5px solid rgba(111, 74, 46, 0.3);
  border-radius:4px;
}
.rc-correction-badge[hidden],
.rc-origin-note[hidden] { display:none; }
.rc-origin-note {
  background:rgba(180, 65, 65, 0.07);
  border-color:rgba(180, 65, 65, 0.28);
}
.rcb-icon { font-size:.9rem; flex-shrink:0; }
.rcb-text {
  flex:1; min-width:0;
  font-family:var(--f-mono); font-size:.6rem; font-weight:500;
  letter-spacing:.06em; color:var(--coffee);
  word-break:keep-all;
}
.rcb-toggle {
  flex-shrink:0;
  background:transparent; border:0.5px solid var(--coffee);
  padding:.25rem .55rem;
  font-family:var(--f-mono); font-size:.5rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--coffee); cursor:pointer;
  transition:var(--transition);
}
.rcb-toggle:hover { background:var(--coffee); color:var(--bone); }

/* ─── Review Card (post-extraction) ─── */
.review-card {
  background:var(--paper);
  border:0.8px solid var(--ink);
  padding:1.5rem 1.4rem 1.3rem;
  display:flex; flex-direction:column; gap:1rem;
  animation:reviewSlide .35s cubic-bezier(.4,0,.2,1);
}
@keyframes reviewSlide {
  from { opacity:0; transform:translateY(12px); }
  to   { opacity:1; transform:translateY(0); }
}
.review-head { display:flex; flex-direction:column; gap:.4rem; }
.review-eyebrow {
  font-family:var(--f-mono); font-size:.55rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase; color:var(--coffee);
}
.review-title {
  margin:0;
  font-family:var(--f-serif-kr); font-weight:600; font-size:1.5rem;
  color:var(--ink); letter-spacing:-.005em;
}
.review-sub {
  font-family:var(--f-sans); font-size:.85rem; line-height:1.45;
  color:var(--ink); word-break:keep-all;
}
.review-ctx {
  font-family:var(--f-mono); font-size:.58rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--ash);
}
.review-promise {
  margin:0;
  padding:.85rem 1rem;
  background:rgba(111, 74, 46, 0.08);
  border-left:2px solid var(--coffee);
  font-family:var(--f-sans); font-size:.82rem; line-height:1.55;
  color:var(--ink); word-break:keep-all;
}
.review-promise strong {
  color:var(--coffee); font-weight:600;
}

.review-stars {
  display:flex; gap:.3rem; align-self:flex-start;
}
.rstar {
  background:transparent; border:none;
  font-size:1.95rem; line-height:1;
  color:var(--mist); cursor:pointer;
  transition:transform .15s, color .15s;
  padding:.15rem;
}
.rstar:hover { transform:scale(1.08); }
.rstar.on { color:var(--coffee); }

.review-tags {
  display:flex; flex-wrap:wrap; gap:.4rem;
}
.rtag {
  background:var(--bone); border:0.5px solid var(--border);
  padding:.5rem .85rem;
  font-family:var(--f-sans); font-size:.78rem; font-weight:500;
  color:var(--ink); cursor:pointer;
  transition:var(--transition);
  border-radius:4px;
}
.rtag:hover { border-color:var(--ink); }
.rtag.selected {
  background:var(--ink); color:var(--bone); border-color:var(--ink);
}

.review-hint {
  margin:0;
  font-family:var(--f-sans); font-size:.7rem; line-height:1.5;
  color:var(--ash); word-break:keep-all;
}

.review-actions { display:flex; flex-direction:column; gap:.5rem; margin-top:.3rem; }
.review-save {
  width:100%;
  background:var(--ink); color:var(--bone); border:none;
  padding:1rem;
  font-family:var(--f-sans); font-size:.85rem; font-weight:600;
  letter-spacing:.14em;
  border-radius:var(--radius-sm); cursor:pointer;
  transition:var(--transition);
}
.review-save:hover:not(:disabled) { background:#000; }
.review-save:disabled { opacity:.35; cursor:default; }
.review-skip {
  width:100%;
  background:transparent; color:var(--ash); border:none;
  padding:.75rem;
  font-family:var(--f-mono); font-size:.6rem; font-weight:500;
  letter-spacing:.28em; text-transform:uppercase;
  cursor:pointer; transition:var(--transition);
}
.review-skip:hover { color:var(--ink); }

/* ─── Toast ─── */
.toast {
  display:none; position:fixed; bottom:1.8rem; left:50%;
  transform:translateX(-50%);
  background:var(--ink); border:none; font-family:var(--f-sans);
  font-size:.82rem; padding:.75rem 1.2rem; color:var(--bone);
  z-index:999; white-space:nowrap; max-width:90vw; letter-spacing:.02em;
}
.toast.show { display:block; animation:fadeUp .3s ease; }

@media (max-width: 380px) {
  .recipe-card { padding:1.2rem 1.15rem 1rem; }
  .rc-card-kr { font-size:1.5rem; }
  .rc-card-en { font-size:.9rem; }
  .rc-dial-val { font-size:1.4rem; }
  .rc-dial-val.rc-dial-ratio { font-size:1.2rem; }
  .step-label { font-size:.44rem; max-width:56px; }
  .gcv-modal { padding:.7rem; }
  .gcv-modal-head { padding:1rem 1rem .85rem; }
  .gcv-table { font-size:.64rem; }
  .gcv-table th, .gcv-table td { padding:.45rem .55rem; }
  .gcv-table th { font-size:.52rem; }
  .gcv-grind-convert-btn { font-size:.5rem; }
  .gcv-foot { padding:.75rem 1rem .9rem; font-size:.55rem; }
}

/* 짧은 화면 (iPhone SE, 작은 안드로이드) — 핵심 영역 컴팩트화 */
@media (max-height: 700px) {
  .nav-header { height:48px; }
  .select-body { padding:1rem 1.1rem; }
  .recipe-body { padding:1rem 1.1rem 1.2rem; gap:1rem; }
  .recipe-card { padding:1.2rem 1.2rem .95rem; }
  .rc-card-kr { font-size:1.5rem; }
  .rc-dials { gap:.05rem; }
  .rc-dial { padding:.55rem 0; }
  .rc-dial-val { font-size:1.5rem; }
  .rc-grind-note { padding:.65rem 0 .75rem; font-size:.72rem; }
  .recipe-feedback-cta { padding:.8rem .9rem; font-size:.8rem; }

  .roast-card, .bean-type-card { padding:.9rem 1rem; min-height:72px; }
  .roast-card-name, .bean-type-name { font-size:.96rem; }
  .roast-card-desc, .bean-type-desc { font-size:.74rem; line-height:1.45; }
  .proc-card { padding:1.4rem .8rem 1rem; gap:.55rem; min-height:140px; }
  .proc-card-name { font-size:.96rem; }
  .proc-card-meta { font-size:.46rem; }
  .proc-dot { width:26px; height:26px; }

  .method-grid { gap:.65rem; }
  .method-card { padding:1.4rem .8rem 1rem; gap:.6rem; }
  .method-card-icon { width:3rem; height:3rem; }
  .method-card-icon svg { width:2.1rem; height:2.1rem; }

  .scan-body { padding:1.2rem 1.5rem; gap:1rem; }
  .scan-mark { width:64px; height:64px; }

  .bean-name-actions { padding:.8rem 1.2rem 1.2rem; }
  .bean-name-h { font-size:1.2rem; }
  .bean-name-p { font-size:.78rem; }
}

/* 매우 짧은 화면 — login 등 한층 더 압축 */
@media (max-height: 600px) {
  .login-mark { width:54px; height:54px; margin-bottom:.6rem; }
  .login-logo { font-size:1.9rem; }
  .login-tagline { margin-bottom:1.4rem; }
  .field-group { margin-bottom:.7rem; }
  .field-group input { padding:.7rem .9rem; }
}
