/* ════════════════════════════════════════════════════════════════════════
   journey-onboarding.css — first-run THE UNFOLD flow (port of
   design-mockups/onboarding/onb-polished3.html into the real app).

   Scoped under #kjOnb (a full-screen overlay inside the .kj root). The mockup's
   phone bezel (.screen / .stage / .phone) is dropped — #reel fills the viewport.
   c-kit tokens the mockup relied on are redeclared LOCALLY on #kjOnb so this is
   self-contained (and consistent with css/journey.css's c-kit values).

   Beats: 0 opener (word-snow) · 1 bloom (glyphs→pictures) · 2 unfold (one word,
   a whole world) · 3 picker (starter decks → Begin). "Build your own" hands off
   to the real composer (js/journey-composer.js), so the mockup's inline
   constructor CSS is intentionally omitted.

   和の感性 floor: gold appears AT MOST ONCE (the "A whole world." payoff).
   Selection is moss; romaji rides under every Japanese token.
   ════════════════════════════════════════════════════════════════════════ */

#kjOnb{
  /* c-kit tokens (local, self-contained) */
  --font-jp:'Klee One','Noto Sans JP',serif;
  --font-ui:'Inter','Noto Sans JP',sans-serif;
  --bg:#F0EDE8; --paper:#FAFAF7; --ink:#2C2C2C; --stone:#57534e; --faint:#6E6860;
  --accent:#3D5A80; --gold:#C9A96E; --moss:#6B7F5C;
  --divider:rgba(44,40,32,.12); --image-base:#cdc4b4;
  --radius:10px; --radius-lg:16px; --radius-xl:22px; --radius-full:999px;
  --shadow-rest:0 1px 2px rgba(20,16,10,.05), 0 6px 18px rgba(20,16,10,.06);
  --shadow-card:0 2px 6px rgba(20,16,10,.07), 0 14px 34px rgba(18,16,10,.11);
  --ease:cubic-bezier(.16,1,.3,1);
  --side:18px;

  position:fixed; inset:0; z-index:120; background:#14100a; color:var(--ink); font-family:var(--font-ui);
  opacity:0; pointer-events:none; transition:opacity .4s var(--ease);
  -webkit-font-smoothing:antialiased;
}
#kjOnb.on{opacity:1; pointer-events:auto;}
/* Defensive (mirrors #kjStudy): off = fully inert. On iOS Safari an opacity:0
   composited overlay still hit-tests — pointer-events:none on the root alone is
   NOT honored reliably during/after the opacity transition, so the leftover
   full-screen layer traps every tap on the dashboard beneath until reload. Force
   the whole subtree inert; journey-onboarding.js close() also removes the node
   post-fade so nothing survives to hit-test. */
#kjOnb:not(.on), #kjOnb:not(.on) *{pointer-events:none !important;}

/* the onboarding owns the whole screen — one dark room, the watercolor IS the surface */
#kjOnb #reel{position:absolute; inset:0; overflow:hidden; background:#14100a; font-family:var(--font-ui);}

/* ── the shared dark room every beat lives inside ── */
#kjOnb .room{position:absolute; inset:0; overflow:hidden;}
#kjOnb .room::before{content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:radial-gradient(125% 92% at 50% 6%, rgba(64,50,30,.5) 0%, rgba(20,16,10,0) 62%);}

/* ════ THE CASCADE (beat 0 ambient) — a quiet snowfall of words ════ */
#kjOnb .flow{position:absolute; inset:0; z-index:2; overflow:hidden; pointer-events:none;
  transition:opacity 1.1s var(--ease), filter 1.1s var(--ease);}
#kjOnb .flow::before{content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to bottom, rgba(20,16,10,.55) 0%, rgba(20,16,10,0) 16%, rgba(20,16,10,0) 84%, rgba(20,16,10,.62) 100%);}
#kjOnb .flow .w{position:absolute; top:0; left:0; white-space:nowrap; color:rgba(178,170,156,.5);
  font-weight:400; letter-spacing:.3px; line-height:1; text-shadow:0 1px 8px rgba(8,5,3,.45);
  will-change:transform,opacity; transform:translate3d(0,-14vh,0);
  animation-name:kjo-fall; animation-timing-function:linear; animation-iteration-count:infinite;}
#kjOnb .flow .w.jp{font-family:var(--font-jp); font-weight:500; color:rgba(186,178,164,.56);}
#kjOnb .flow .w.kana{font-family:var(--font-jp); font-weight:400; color:rgba(170,162,148,.46);}
#kjOnb .flow .w.rom{font-family:var(--font-ui); font-weight:500; color:rgba(160,153,140,.5); letter-spacing:.5px;}
#kjOnb .flow .w.en{font-family:var(--font-ui); font-weight:400; color:rgba(166,159,146,.5); letter-spacing:.2px;}
@keyframes kjo-fall{
  0%   {transform:translate3d(0,-14vh,0); opacity:0;}
  10%  {opacity:1;}
  86%  {opacity:1;}
  100% {transform:translate3d(0,101vh,0); opacity:0;}
}
#kjOnb .flow.slowing .w{animation-timing-function:cubic-bezier(.33,0,.15,1) !important;}
#kjOnb .flow.gone{opacity:0; filter:blur(3px);}
#kjOnb .flow.gone .w{animation-play-state:paused;}
#kjOnb .wall.under-flow{opacity:.18; filter:saturate(0) brightness(.9);
  transition:opacity 1.1s var(--ease), filter 1.1s var(--ease);}

/* ════ THE BLOOM STAGE — one grid, two beats (list → bloom) ════ */
#kjOnb .wall{position:absolute; inset:0; z-index:1; display:grid; gap:5px; padding:5px;
  grid-template-columns:repeat(4,1fr); grid-template-rows:repeat(6,1fr);
  grid-auto-flow:row dense; align-content:stretch;
  transition:opacity .9s var(--ease), transform 1.05s var(--ease), filter 1.05s var(--ease);}
#kjOnb .cell{position:relative; border-radius:9px; overflow:hidden; background:#1d1710;
  box-shadow:inset 0 0 0 1px rgba(120,108,90,.10);
  opacity:0; transform:translateY(14px); will-change:transform,opacity;}
#kjOnb .cell.big{grid-column:span 2; grid-row:span 2;}
#kjOnb .cell .dead{position:absolute; inset:0; z-index:2; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-jp); font-weight:400; color:rgba(176,168,154,.40); letter-spacing:.5px;
  font-size:18px; line-height:1; text-align:center; padding:4px;
  transition:opacity .55s var(--ease), transform .7s var(--ease), color .55s var(--ease);}
#kjOnb .cell.big .dead{font-size:30px;}
#kjOnb .cell .pic{position:absolute; inset:0; z-index:1; background-size:cover; background-position:center;
  filter:saturate(.5) brightness(.5) blur(2px); opacity:0;
  transform:scale(1.08); transition:opacity .8s var(--ease), filter 1s var(--ease), transform 1.1s var(--ease);}
#kjOnb .cell .shade{position:absolute; left:0; right:0; bottom:0; z-index:2; height:60%; pointer-events:none;
  opacity:0; transition:opacity .7s var(--ease);
  background:linear-gradient(to top, rgba(11,7,3,.88) 0%, rgba(11,7,3,.34) 54%, rgba(11,7,3,0) 100%);}
#kjOnb .cell .lab{position:absolute; left:7px; right:7px; bottom:6px; z-index:3; color:#fdfaf3;
  font-family:var(--font-ui); opacity:0; transform:translateY(4px);
  transition:opacity .6s var(--ease), transform .6s var(--ease);}
#kjOnb .cell .lab .lj{display:block; font-family:var(--font-jp); font-size:11.5px; font-weight:600; line-height:1.1;
  letter-spacing:.02em; color:#fdfaf3; text-shadow:0 1px 3px rgba(0,0,0,.85);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
#kjOnb .cell .lab .le{display:block; font-size:9.5px; font-weight:500; line-height:1.12; letter-spacing:.1px; margin-top:1px;
  color:rgba(243,234,217,.82); text-shadow:0 1px 3px rgba(0,0,0,.8);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
#kjOnb .cell.big .lab .lj{font-size:15px;} #kjOnb .cell.big .lab .le{font-size:11px;}
#kjOnb .cell.big .lab{bottom:9px; left:10px; right:10px;}
#kjOnb .wall.listed .cell{opacity:1; transform:none; transition:opacity .5s var(--ease), transform .55s var(--ease);}
#kjOnb .wall.bloom .cell .dead{opacity:0; transform:translateY(-7px) scale(.82); color:rgba(253,250,243,.7);}
#kjOnb .wall.bloom .cell .pic{opacity:1; filter:saturate(.98) brightness(.94) blur(0); transform:scale(1);}
#kjOnb .wall.bloom .cell .shade{opacity:1;}
#kjOnb .wall.bloom .cell .lab{opacity:1; transform:none;}

/* ── the claim band: razor copy in its OWN protected zone. ── */
#kjOnb .claim{position:absolute; left:0; right:0; bottom:0; z-index:6; pointer-events:none;
  padding:92px 24px calc(72px + env(safe-area-inset-bottom,0px));
  background:linear-gradient(to top, #0d0904 0%, #0d0904 40%, rgba(13,9,4,.88) 60%, rgba(13,9,4,.42) 82%, rgba(13,9,4,0) 100%);
  opacity:0; transform:translateY(10px); transition:opacity .6s var(--ease), transform .6s var(--ease);}
#kjOnb .claim.show{opacity:1; transform:none;}
#kjOnb .claim.solid{background:linear-gradient(to top, #0d0904 0%, #0d0904 62%, rgba(13,9,4,.94) 80%, rgba(13,9,4,0) 100%);}
#kjOnb .claim .eyebrow{font-size:10px; font-weight:700; letter-spacing:2.4px; text-transform:uppercase;
  color:rgba(253,250,243,.5); display:inline-flex; align-items:center; gap:9px; margin-bottom:14px;}
#kjOnb .claim .eyebrow::before{content:""; width:16px; height:1.5px; border-radius:2px; background:rgba(253,250,243,.42);}
#kjOnb .claim h1.en{font-family:var(--font-ui); font-size:30px; font-weight:600; line-height:1.18; color:#f6f1e6;
  letter-spacing:-.014em; text-shadow:0 2px 18px rgba(0,0,0,.6); max-width:300px; text-wrap:balance;}
#kjOnb .claim .en-lead{font-family:var(--font-ui); font-size:29px; font-weight:600; line-height:1.2;
  color:#f6f1e6; letter-spacing:-.014em; text-shadow:0 2px 18px rgba(0,0,0,.6); max-width:320px; text-wrap:balance;}
#kjOnb .claim .en-lead.big{font-size:31px;}
#kjOnb .claim .jp-echo{font-family:var(--font-jp); font-size:21px; font-weight:600; font-feature-settings:'palt' 1;
  line-height:1.45; color:rgba(251,247,238,.84); letter-spacing:.01em; margin-top:14px; max-width:320px;
  text-shadow:0 2px 14px rgba(8,5,3,.55);}
#kjOnb .claim .jp-echo ruby{ruby-position:over; ruby-align:space-around;}
#kjOnb .claim .jp-echo rt{font-family:var(--font-jp); font-size:.42em; font-weight:400; line-height:1; letter-spacing:.04em;
  color:rgba(251,247,238,.64);}
#kjOnb .claim .rm{font-size:13px; font-weight:500; color:rgba(253,250,243,.6); letter-spacing:.4px; margin-top:8px;}

/* ════ PERSISTENT TAP CUE ════ */
#kjOnb .tapcue{position:absolute; left:50%; transform:translateX(-50%);
  bottom:calc(env(safe-area-inset-bottom,0px) + 34px); z-index:20; pointer-events:none;
  display:inline-flex; flex-direction:column; align-items:center; gap:7px;
  opacity:0; transition:opacity .5s var(--ease);}
#kjOnb .tapcue.show{opacity:1;}
#kjOnb .tapcue .chev{width:17px; height:17px; border-radius:50%; border:1.5px solid rgba(253,250,243,.78);
  position:relative; animation:kjo-tapBreathe 2.4s var(--ease) infinite;}
#kjOnb .tapcue .chev::after{content:""; position:absolute; left:50%; top:46%; width:6px; height:6px;
  border-right:1.5px solid rgba(253,250,243,.9); border-bottom:1.5px solid rgba(253,250,243,.9);
  transform:translate(-50%,-60%) rotate(45deg);}
@keyframes kjo-tapBreathe{0%,100%{box-shadow:0 0 0 0 rgba(253,250,243,0);} 50%{box-shadow:0 0 0 5px rgba(253,250,243,.14);}}

/* ════ PROGRESS RAIL — four stops ════ */
#kjOnb .rail{position:absolute; left:50%; transform:translateX(-50%); bottom:calc(env(safe-area-inset-bottom,0px) + 15px);
  z-index:19; display:flex; gap:7px; transition:opacity .4s var(--ease);}
#kjOnb .rail.hide{opacity:0; pointer-events:none;}
#kjOnb .rail i{width:6px; height:6px; border-radius:50%; background:rgba(253,250,243,.26); transition:width .4s var(--ease), background .4s var(--ease);}
#kjOnb .rail i.on{width:17px; border-radius:3px; background:rgba(253,250,243,.82);}

/* ════ THE FOLD — the showcase tile pulls FORWARD into the scene ════ */
#kjOnb .flyer{position:absolute; z-index:14; border-radius:11px; overflow:hidden; background:var(--image-base);
  box-shadow:0 18px 50px rgba(8,5,3,.55); opacity:0; pointer-events:none;
  transition:left 1.1s cubic-bezier(.33,0,.2,1), top 1.1s cubic-bezier(.33,0,.2,1),
             width 1.1s cubic-bezier(.33,0,.2,1), height 1.1s cubic-bezier(.33,0,.2,1),
             border-radius .9s var(--ease), box-shadow .9s var(--ease), opacity .45s var(--ease);}
#kjOnb .flyer .fpic{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(.96) brightness(.92);}

/* ════ THE UNFOLD ════ */
#kjOnb .unfold{position:absolute; inset:0; z-index:12; display:flex; flex-direction:column; background:#14100a;
  opacity:0; pointer-events:none; transition:opacity .6s var(--ease);}
#kjOnb .unfold.live{opacity:1; pointer-events:auto;}
#kjOnb .uscene{position:absolute; inset:0; z-index:0;}
#kjOnb .uscene .uphoto{position:absolute; inset:0; background-size:cover; background-position:center;
  filter:brightness(.84) saturate(1.02); transform:scale(1.02);
  animation:kjo-u-kb 26s var(--ease) infinite alternate;}
@keyframes kjo-u-kb{0%{transform:scale(1.02);} 100%{transform:scale(1.1);}}
#kjOnb .uscene .uscrim{position:absolute; inset:0;
  background:linear-gradient(to top, rgba(13,9,4,.97) 0%, rgba(13,9,4,.9) 26%, rgba(13,9,4,.62) 48%, rgba(13,9,4,.2) 72%, rgba(13,9,4,.04) 100%);}
#kjOnb .uscene .uphoto.reduced{animation:none; transform:none;}
@keyframes kjo-audioPulse{0%{transform:scale(1); opacity:.65;} 100%{transform:scale(2); opacity:0;}}

#kjOnb .ustack{position:relative; z-index:10; flex:1; min-height:0; overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch; display:flex; flex-direction:column; justify-content:flex-end;}
#kjOnb .ustack::-webkit-scrollbar{display:none;}
#kjOnb .ustack .uspacer{flex:1 0 30vh; min-height:120px;}
#kjOnb .ustack .ubody{position:relative; padding:0 24px calc(env(safe-area-inset-bottom,0px) + 124px);}

#kjOnb .ulayer{display:none; opacity:0; transform:translateY(16px);
  transition:opacity .55s var(--ease), transform .55s var(--ease); will-change:opacity,transform;}
#kjOnb .ulayer.armed{display:block;}
#kjOnb .ulayer.in{opacity:1; transform:none;}

#kjOnb .usec{display:inline-flex; align-items:center; gap:9px; margin-bottom:11px;}
#kjOnb .usec::before{content:""; width:15px; height:1.5px; border-radius:2px; background:rgba(253,250,243,.4);}
#kjOnb .usec .sj{font-family:var(--font-jp); font-size:13px; font-weight:600; color:rgba(253,250,243,.86); letter-spacing:.06em; text-shadow:0 1px 6px rgba(8,5,3,.6);}
#kjOnb .usec .se{font-family:var(--font-ui); font-size:9.5px; font-weight:700; letter-spacing:1.8px; text-transform:uppercase; color:rgba(253,250,243,.62); text-shadow:0 1px 6px rgba(8,5,3,.6);}
#kjOnb .ulayer .usec{opacity:0; transform:translateY(8px); transition:opacity .45s var(--ease), transform .45s var(--ease);}
#kjOnb .ulayer .ustory .stxt, #kjOnb .ulayer .usent .ex{opacity:0; transform:translateY(10px);
  transition:opacity .5s var(--ease) .08s, transform .5s var(--ease) .08s;}
#kjOnb .ulayer.in .usec{opacity:1; transform:none;}
#kjOnb .ulayer.in .ustory .stxt, #kjOnb .ulayer.in .usent .ex{opacity:1; transform:none;}

/* LAYER 0 · word identity */
#kjOnb .uword{margin-bottom:6px;}
#kjOnb .uword .wjp{font-family:var(--font-jp); font-size:56px; font-weight:600; line-height:1; color:#fdfaf3;
  font-feature-settings:'palt' 1; text-shadow:0 2px 16px rgba(8,5,3,.7);}
#kjOnb .uword .wread{display:flex; align-items:center; gap:11px; margin-top:11px;}
#kjOnb .uword .wread .wk{font-family:var(--font-jp); font-size:19px; font-weight:600; color:rgba(251,247,238,.88); letter-spacing:.02em; text-shadow:0 1px 8px rgba(8,5,3,.6);}
#kjOnb .uword .wread .wr{font-family:var(--font-ui); font-size:16px; font-weight:500; color:rgba(250,244,233,.84); letter-spacing:.4px;}
#kjOnb .uword .wread .uaud{position:relative; flex:0 0 auto; width:34px; height:34px; margin-left:2px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center; cursor:pointer;
  background:rgba(20,15,10,.62); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.28), 0 2px 8px rgba(8,5,3,.55); -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .2s var(--ease);}
#kjOnb .uword .wread .uaud:active{transform:scale(.9);}
#kjOnb .uword .wread .uaud svg{width:15px; height:15px; fill:#fdfaf3;}
#kjOnb .uword .wread .uaud.hint::before{content:""; position:absolute; inset:0; border-radius:50%; pointer-events:none;
  animation:kjo-tapBreathe 2.2s var(--ease) 2;}
#kjOnb .uword .wread .uaud.playing::after{content:""; position:absolute; inset:-1px; border-radius:50%;
  border:1.5px solid rgba(253,250,243,.7); pointer-events:none; animation:kjo-audioPulse .72s var(--ease) forwards;}
#kjOnb .uword .wen{font-family:var(--font-ui); font-size:17px; font-weight:500; color:#f3ead9; margin-top:9px; letter-spacing:.005em; text-shadow:0 1px 8px rgba(8,5,3,.55);}

#kjOnb .ulayer.div{margin-top:18px; padding-top:18px; border-top:1px solid rgba(253,250,243,.13);}

/* LAYER 1 · story */
#kjOnb .ustory .stxt{font-family:var(--font-ui); font-size:14.5px; font-weight:500; line-height:1.62; color:rgba(248,242,231,.92);
  letter-spacing:.005em; text-shadow:0 1px 7px rgba(8,5,3,.5); max-width:330px;}
#kjOnb .ustory .stxt b{font-family:var(--font-jp); font-weight:600; color:#fdfaf3;}

/* LAYER 2 · sentence */
#kjOnb .usent .ex .ejp{font-family:var(--font-jp); font-size:21px; font-weight:600; line-height:1.85; color:#fdfaf3;
  font-feature-settings:'palt' 1; text-shadow:0 1px 9px rgba(8,5,3,.6);}
#kjOnb .usent .ex .ejp ruby{ruby-position:over; ruby-align:center;}
#kjOnb .usent .ex .ejp rt{font-family:var(--font-jp); font-size:.42em; font-weight:400; color:rgba(251,247,238,.66); letter-spacing:.02em;}
#kjOnb .usent .ex .erm{font-family:var(--font-ui); font-size:12.5px; font-weight:500; color:rgba(248,241,230,.66); letter-spacing:.3px; margin-top:8px;}
#kjOnb .usent .ex .een{font-family:var(--font-ui); font-size:13.5px; font-weight:500; color:rgba(243,234,217,.86); margin-top:6px; line-height:1.4;}

/* LAYER 3 · family */
#kjOnb .ufam .fam{display:flex; justify-content:center; gap:16px; margin-top:2px; flex-wrap:wrap; align-items:flex-start;}
#kjOnb .ufam .fc{position:relative; display:flex; flex-direction:column; align-items:stretch; text-align:center;
  flex:0 1 132px; max-width:148px;
  opacity:0; transform:translateY(10px); transition:opacity .5s var(--ease) .08s, transform .5s var(--ease) .08s;}
#kjOnb .ufam.in .fc{opacity:1; transform:none;}
#kjOnb .ufam .fc:nth-child(2){transition-delay:.17s;}
#kjOnb .ufam .fc .frel{display:inline-flex; align-self:center; align-items:baseline; gap:7px; margin-bottom:9px;}
#kjOnb .ufam .fc .frel .frj{font-family:var(--font-jp); font-size:12px; font-weight:600; color:rgba(253,250,243,.86); line-height:1; letter-spacing:.04em; text-shadow:0 1px 6px rgba(8,5,3,.6);}
#kjOnb .ufam .fc .frel .frr{font-family:var(--font-ui); font-size:9px; font-weight:600; color:rgba(253,250,243,.6); letter-spacing:.2px; line-height:1;}
#kjOnb .ufam .fc .frel .fre{font-family:var(--font-ui); font-size:8.5px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; color:rgba(253,250,243,.56); line-height:1;}
#kjOnb .ufam .fc .ph{position:relative; width:100%; aspect-ratio:1/1; border-radius:13px; overflow:hidden;
  background-size:cover; background-position:center; background-color:var(--image-base);
  box-shadow:0 4px 14px rgba(8,5,3,.46), inset 0 0 0 1px rgba(255,255,255,.07);}
#kjOnb .ufam .fc .ph::after{content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(11,7,3,.34) 0%, rgba(11,7,3,0) 55%);}
#kjOnb .ufam .fc .fjp{font-family:var(--font-jp); font-size:14px; font-weight:600; color:#fdfaf3; margin-top:8px; line-height:1.15;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap; text-shadow:0 1px 5px rgba(8,5,3,.6);}
#kjOnb .ufam .fc .frm{font-family:var(--font-ui); font-size:10px; font-weight:500; color:rgba(248,241,230,.64); margin-top:2px; letter-spacing:.2px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
#kjOnb .ufam .fc .fen{font-family:var(--font-ui); font-size:10.5px; font-weight:500; color:rgba(243,234,217,.78); margin-top:2px; line-height:1.25;}

/* THE PAYOFF — gold lives in EXACTLY ONE element */
#kjOnb .upay{position:relative; margin-top:24px; padding-top:22px; border-top:1px solid rgba(253,250,243,.13);}
#kjOnb .upay::before{content:""; position:absolute; left:-24px; right:-24px; top:-6px; bottom:-30px; z-index:-1; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 60%, rgba(13,9,4,.6) 0%, rgba(13,9,4,.3) 55%, rgba(13,9,4,0) 100%);}
#kjOnb .upay .ph1{font-family:var(--font-ui); font-size:26px; font-weight:700; line-height:1.2; color:#f7f2e7;
  letter-spacing:-.012em; text-shadow:0 2px 16px rgba(8,5,3,.6); text-wrap:balance;}
#kjOnb .upay .ph1 .gold{color:#D8B97A; letter-spacing:.004em; text-shadow:0 1px 12px rgba(8,5,3,.7);}
#kjOnb .upay .ph2{font-family:var(--font-ui); font-size:14px; font-weight:500; color:rgba(243,234,217,.74); margin-top:9px; letter-spacing:.01em;}
#kjOnb .ulayer.upay{transform:translateY(22px) scale(.985); transition:opacity .7s var(--ease), transform .7s var(--ease);}
#kjOnb .ulayer.upay.in{transform:none;}

/* (BEAT 3 — the old starter-deck picker .close{...} was removed in the tiered
   graft. The TIERED-picker rules are appended at the END of this file, namespaced
   to #kjoTflow / #kjoTwall so they never touch the beats 0-2 .wall/.flow.) */

/* ════ reduced-motion: still TAP-GATED; the metaphor is a two-state SNAP ════ */
@media (prefers-reduced-motion: reduce){
  #kjOnb .flow{display:none !important;}
  #kjOnb .cell{opacity:1 !important; transform:none !important;}
  #kjOnb .cell .dead{transition:none !important;}
  #kjOnb .cell .pic{transition:none !important;}
  #kjOnb .wall.bloom .cell .dead{display:none !important;}
  #kjOnb .wall.bloom .cell .pic{opacity:1 !important; filter:saturate(.98) brightness(.94) !important; transform:none !important;}
  #kjOnb .cell .shade, #kjOnb .cell .lab{transition:none !important;}
  #kjOnb .wall, #kjOnb .claim, #kjOnb .rail, #kjOnb .tapcue, #kjOnb .unfold, #kjOnb .uscene .uphoto, #kjOnb .ulayer, #kjOnb .flyer, #kjOnb .uaud{transition-duration:.001s !important; animation:none !important;}
  #kjOnb .ulayer.armed{opacity:1; transform:none;}
  #kjOnb .ulayer.upay{transform:none;}
  #kjOnb .uword .wread .uaud.hint::before{animation:none !important;}
  #kjOnb .tapcue .chev{animation:none !important;}
}

/* ════════════════════════════════════════════════════════════════════════
   BEAT 3 — the TIERED-door picker (grafted from onb-tiered-flow.html).
   Appended after beats 0-2; namespaced to #kjoTflow (router stage) and
   #kjoTwall (topic wall) so it never clobbers the bloom .wall / snow .flow.
   The master #kjOnb base/overlay/token block above is NOT redeclared; the
   tiered-only tokens it needs (--image-base dark, --radius-md/-sm, the
   tiered ease) are scoped to #kjoTflow + the seal below.
   和の感性 floor: gold only on the おすすめ tag + the 道 seal. Selection = moss.
   ════════════════════════════════════════════════════════════════════════ */

/* tiered-only tokens, scoped so they never touch beats 0-2 */
#kjOnb #kjoTflow, #kjOnb .seal-veil{
  --ease:cubic-bezier(.22,1,.36,1);
  --image-base:#1c150d; --radius-md:12px; --radius-sm:9px; --radius-lg:16px;
}

/* ── the router stage: every screen is absolutely stacked, slid by class ── */
/* tiered router stage — hidden until the unfold payoff tap reveals it (toClose adds .live) */
#kjOnb #kjoTflow{position:absolute; inset:0; z-index:18; overflow:hidden; background:#0d0904; font-family:var(--font-ui);
  opacity:0; pointer-events:none; transition:opacity .7s var(--ease);}
#kjOnb #kjoTflow.live{opacity:1; pointer-events:auto;}
#kjOnb .scr{position:absolute; inset:0; display:flex; flex-direction:column; background:#0d0904;
  transform:translateX(100%); opacity:0; pointer-events:none;
  transition:transform .4s var(--ease), opacity .4s var(--ease);}
#kjOnb .scr.active{transform:none; opacity:1; pointer-events:auto;}
#kjOnb .scr.behind{transform:translateX(-14%) scale(.96); opacity:.0;}
#kjOnb #scr-doors{transform:translateX(0); opacity:1; pointer-events:auto;}
#kjOnb #scr-doors.behind{transform:translateX(-14%) scale(.96); opacity:0; pointer-events:none;}

#kjOnb .cbg{position:absolute; inset:0; background-size:cover; background-position:center;
  filter:brightness(.3) saturate(.88); animation:kjo-cb-kb 32s var(--ease) infinite alternate;}
@keyframes kjo-cb-kb{0%{transform:scale(1.04);} 100%{transform:scale(1.12);}}
#kjOnb .cscrim{position:absolute; inset:0; background:linear-gradient(to top,
  rgba(13,9,4,.97) 0%, rgba(13,9,4,.93) 32%, rgba(13,9,4,.86) 66%, rgba(13,9,4,.82) 100%);}
#kjOnb .cbody{position:relative; z-index:2; display:flex; flex-direction:column; height:100%; min-height:0;}

#kjOnb .skip{position:absolute; top:calc(env(safe-area-inset-top,0px) + 14px); right:16px; z-index:30;
  font-family:var(--font-ui); font-size:12.5px; font-weight:600; color:rgba(238,231,219,.55);
  padding:6px 12px; border-radius:var(--radius-full); cursor:pointer;
  -webkit-user-select:none; user-select:none;
  background:rgba(20,15,10,.32); -webkit-backdrop-filter:blur(5px); backdrop-filter:blur(5px);
  box-shadow:inset 0 0 0 1px rgba(255,253,248,.12);}

#kjOnb .back{flex:0 0 auto; width:38px; height:38px; border-radius:var(--radius-full);
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  color:rgba(243,234,217,.82); background:rgba(20,15,10,.4);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  box-shadow:inset 0 0 0 1px rgba(255,253,248,.16);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .15s var(--ease), background .2s var(--ease);}
#kjOnb .back:active{transform:scale(.92);}
#kjOnb .back svg{width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round;}

#kjOnb .cbrand{display:flex; align-items:center; gap:7px; min-width:0;}
#kjOnb .cbrand .hanko{width:22px; height:22px; border-radius:50%; object-fit:cover; flex:0 0 auto;
  box-shadow:0 2px 7px rgba(8,5,3,.4);}
#kjOnb .cbrand .bk{font-family:var(--font-jp); font-size:13px; font-weight:600; color:rgba(253,250,243,.9); letter-spacing:.03em; white-space:nowrap;}
#kjOnb .cbrand .bkrm{font-family:var(--font-ui); font-size:10px; font-weight:500; color:rgba(243,234,217,.55); letter-spacing:.3px;}

#kjOnb .chl{font-family:var(--font-ui); font-size:22px; font-weight:600; line-height:1.18; color:#f7f2e7;
  letter-spacing:-.012em; text-shadow:0 2px 16px rgba(0,0,0,.55);}
#kjOnb .chl .cjp{font-family:var(--font-jp); font-size:14px; font-weight:600; color:rgba(238,231,219,.7); margin-left:9px;}
#kjOnb .chl .cjp .crm{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.5); margin-left:5px; letter-spacing:.2px;}
#kjOnb .chl .csub{display:block; margin-top:6px; font-size:12.5px; font-weight:500; color:rgba(238,231,219,.62);
  letter-spacing:.1px; text-shadow:none;}

#kjOnb .cscroll{flex:1 1 auto; min-height:0; overflow-y:auto; -webkit-overflow-scrolling:touch;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, #000 10px, #000 calc(100% - 10px), transparent 100%);
          mask-image:linear-gradient(to bottom, transparent 0, #000 10px, #000 calc(100% - 10px), transparent 100%);}
#kjOnb .cscroll::-webkit-scrollbar{display:none;}

#kjOnb .cfoot{flex:0 0 auto; position:relative; z-index:3;
  padding:12px 20px calc(env(safe-area-inset-bottom,0px) + 16px);
  background:linear-gradient(to top, #0d0904 0%, #0d0904 62%, rgba(13,9,4,0) 100%);}
#kjOnb .cta{width:100%; display:flex; align-items:center; justify-content:center; gap:11px;
  padding:16px; border-radius:var(--radius-full); background:transparent; color:rgba(243,234,217,.5);
  box-shadow:inset 0 0 0 1.5px rgba(243,234,217,.22); -webkit-user-select:none; user-select:none;
  pointer-events:none; transition:background .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease), transform .15s var(--ease);}
#kjOnb .cta.on{background:var(--accent); color:#fff; box-shadow:0 6px 18px rgba(61,90,128,.42); pointer-events:auto;}
#kjOnb .cta:active{transform:scale(.97);}
#kjOnb .cta b{font-family:var(--font-jp); font-size:17px; font-weight:600;}
#kjOnb .cta .crm{font-family:var(--font-ui); font-size:12px; font-weight:500; opacity:.82; letter-spacing:.3px;}
#kjOnb .cta .cen,#kjOnb .cta .cwords{font-family:var(--font-ui); font-size:12px; font-weight:500; opacity:.74; letter-spacing:.3px; font-variant-numeric:tabular-nums;}
#kjOnb .cta .ar{font-size:17px; line-height:1; margin-left:1px;}

/* ════════════════════════════════ SCREEN 0 — door picker ═══════════════════ */
#kjOnb #scr-doors .cbg{filter:brightness(.34) saturate(.9); animation-duration:30s;}
#kjOnb #scr-doors .cbody{padding:calc(env(safe-area-inset-top,0px) + 24px) 0 0;}
#kjOnb .chead{flex:0 0 auto; padding:0 22px 12px;}
#kjOnb .dbrand{display:flex; flex-wrap:wrap; align-items:center; gap:6px 9px; margin-bottom:13px;}
#kjOnb .dbrand .hanko{width:26px; height:26px; border-radius:50%; object-fit:cover; flex:0 0 auto; box-shadow:0 2px 8px rgba(8,5,3,.4);}
#kjOnb .dbrand .bk{font-family:var(--font-jp); font-size:14px; font-weight:600; color:rgba(253,250,243,.92); letter-spacing:.04em; white-space:nowrap;}
#kjOnb .dbrand .bkrm{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(243,234,217,.6); letter-spacing:.3px;}
#kjOnb .dbrand .btag{flex:1 0 100%; margin-top:1px; font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(243,234,217,.62); letter-spacing:.1px;}
#kjOnb #scr-doors .chl{font-size:23px; max-width:300px; text-wrap:balance;}
#kjOnb #scr-doors .chl .csub{font-size:12.5px; margin-top:5px;}
#kjOnb #scr-doors .cscroll{padding:6px 22px 26px;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, #000 9px, #000 calc(100% - 9px), transparent 100%);
          mask-image:linear-gradient(to bottom, transparent 0, #000 9px, #000 calc(100% - 9px), transparent 100%);}

#kjOnb .dbrand, #kjOnb #scr-doors .chl{opacity:0; transform:translateY(14px);
  transition:opacity .5s var(--ease), transform .55s var(--ease);}
#kjOnb #kjoTflow.assemble .dbrand{opacity:1; transform:none; transition-delay:.04s;}
#kjOnb #kjoTflow.assemble #scr-doors .chl{opacity:1; transform:none; transition-delay:.1s;}
#kjOnb .door{opacity:0; transform:translateY(16px); transition:opacity .5s var(--ease), transform .55s var(--ease);}
#kjOnb #kjoTflow.assemble .door{opacity:1; transform:none;}

#kjOnb .tier-lead{display:flex; flex-direction:column; gap:12px; margin-bottom:18px;}
#kjOnb .hero{position:relative; border-radius:var(--radius-lg); overflow:hidden; cursor:pointer;
  aspect-ratio:16/8.4; background-color:var(--image-base);
  box-shadow:0 7px 22px rgba(8,5,3,.5), inset 0 0 0 1px rgba(255,255,255,.06);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);}
#kjOnb .hero:active{transform:scale(.985);}
#kjOnb .hero .hpic{position:absolute; inset:0; background-size:cover; background-position:center;
  filter:saturate(1.02) brightness(.98); transition:filter .25s var(--ease);}
#kjOnb .hero.recommend .hpic{animation:kjo-hero-kb 24s var(--ease) infinite alternate;}
@keyframes kjo-hero-kb{0%{transform:scale(1.03);} 100%{transform:scale(1.1);}}
#kjOnb .hero .htint{position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(11,7,3,.94) 0%, rgba(11,7,3,.72) 34%, rgba(11,7,3,.3) 64%, rgba(11,7,3,.06) 100%);}
#kjOnb .hero .hbody{position:absolute; left:18px; right:16px; bottom:16px; z-index:2; max-width:74%;}
#kjOnb .hero .hkick{display:inline-flex; align-items:center; gap:7px; margin-bottom:9px;
  font-family:var(--font-ui); font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#e7d9b6;}
#kjOnb .hero .hseal{display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-jp); font-size:11px; font-weight:600; letter-spacing:.05em; color:#f0e3c4;
  padding:3px 10px 3px 9px; border-radius:var(--radius-full);
  background:rgba(20,15,8,.36); box-shadow:inset 0 0 0 1px rgba(201,169,110,.7);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);}
#kjOnb .hero .hseal .srm{font-family:var(--font-ui); font-size:9.5px; font-weight:500; letter-spacing:.04em; color:rgba(240,227,196,.78);}
#kjOnb .hero .hseal::before{content:""; width:6px; height:6px; border-radius:50%; background:var(--gold); box-shadow:0 0 6px rgba(201,169,110,.65);}
#kjOnb .hero .hen{font-family:var(--font-ui); font-size:21px; font-weight:700; line-height:1.1; color:#fdfaf3;
  letter-spacing:-.01em; text-shadow:0 1px 3px rgba(0,0,0,.9), 0 0 14px rgba(0,0,0,.5);}
#kjOnb .hero .hjp{font-family:var(--font-jp); font-size:14px; font-weight:600; color:rgba(251,247,238,.94);
  margin-top:6px; line-height:1.1; text-shadow:0 1px 5px rgba(8,5,3,.95);}
#kjOnb .hero .hjp .hrm{font-family:var(--font-ui); font-size:10.5px; font-weight:500; color:rgba(243,234,217,.82); margin-left:7px; letter-spacing:.2px;}
#kjOnb .hero .hsub{font-family:var(--font-ui); font-size:12px; font-weight:500; color:rgba(243,234,217,.82);
  margin-top:8px; line-height:1.3; text-shadow:0 1px 4px rgba(8,5,3,.9); max-width:240px;}

#kjOnb .door.sel{box-shadow:0 9px 26px rgba(8,5,3,.55), 0 0 0 3px var(--moss), 0 0 0 4.5px rgba(11,7,3,.6) !important;}
#kjOnb .dcheck{position:absolute; top:11px; right:11px; z-index:4; width:26px; height:26px; border-radius:50%;
  background:var(--moss); display:flex; align-items:center; justify-content:center;
  opacity:0; transform:scale(.6); transition:opacity .22s var(--ease), transform .22s var(--ease);
  box-shadow:0 2px 7px rgba(8,5,3,.5), 0 0 0 1.5px rgba(253,250,243,.92);}
#kjOnb .dcheck svg{width:14px; height:14px; fill:none; stroke:#fff; stroke-width:2.6; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .door.sel .dcheck{opacity:1; transform:scale(1);}
#kjOnb .dinto{position:absolute; top:50%; right:13px; z-index:4; transform:translateY(-50%);
  width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:rgba(253,250,243,.78); background:rgba(20,15,10,.4);
  -webkit-backdrop-filter:blur(5px); backdrop-filter:blur(5px);
  box-shadow:inset 0 0 0 1px rgba(255,253,248,.24);}
#kjOnb .dinto svg{width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round;}

#kjOnb .tier-seam{display:flex; align-items:center; gap:11px; margin:2px 2px 14px;}
#kjOnb .tier-seam .line{flex:1 1 auto; height:1px; background:rgba(243,234,217,.15);}
#kjOnb .tier-seam .lab{flex:0 0 auto; font-family:var(--font-ui); font-size:10.5px; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase; color:rgba(238,231,219,.5);}

#kjOnb .tier-explore{display:flex; flex-direction:column; gap:10px;}
#kjOnb .row{position:relative; display:flex; align-items:center; cursor:pointer;
  border-radius:var(--radius-lg); overflow:hidden; background-color:#16110a;
  min-height:78px; box-shadow:0 4px 14px rgba(8,5,3,.4), inset 0 0 0 1px rgba(255,255,255,.05);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .22s var(--ease), box-shadow .22s var(--ease);}
#kjOnb .row:active{transform:scale(.985);}
#kjOnb .row .rthumb{position:relative; flex:0 0 auto; width:96px; align-self:stretch; overflow:hidden; background-color:var(--image-base);}
#kjOnb .row .rthumb .rpic{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(.98) brightness(.82);}
#kjOnb .row .rthumb::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(22,17,10,0) 40%, rgba(22,17,10,.96) 100%);}
#kjOnb .row .rmosaic{position:absolute; inset:0; display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:1.5px; background:rgba(11,7,3,.5);}
#kjOnb .row .rmosaic .mq{background-size:cover; background-position:center; filter:saturate(.95) brightness(.8);}
#kjOnb .row .rbody{flex:1 1 auto; min-width:0; padding:12px 44px 12px 15px;}
#kjOnb .row .ren{font-family:var(--font-ui); font-size:15px; font-weight:700; line-height:1.12; color:#fdfaf3; letter-spacing:-.005em;}
#kjOnb .row .rjp{font-family:var(--font-jp); font-size:12px; font-weight:600; color:rgba(251,247,238,.88); margin-top:3px; line-height:1.1;}
#kjOnb .row .rjp .rrm{font-family:var(--font-ui); font-size:9.5px; font-weight:500; color:rgba(243,234,217,.74); margin-left:6px; letter-spacing:.2px;}
#kjOnb .row .rsub{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.62); margin-top:5px; line-height:1.25;}
#kjOnb .row .rmark{position:absolute; top:8px; left:8px; z-index:3; width:26px; height:26px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; pointer-events:none;
  background:rgba(20,15,10,.44); -webkit-backdrop-filter:blur(5px); backdrop-filter:blur(5px);
  box-shadow:inset 0 0 0 1px rgba(255,253,248,.3), 0 1px 5px rgba(8,5,3,.4);}
#kjOnb .row .rmark span{font-family:var(--font-jp); font-size:14px; font-weight:600; color:#fdfaf3; line-height:1; text-shadow:0 1px 3px rgba(8,5,3,.6);}
#kjOnb .row.sel{box-shadow:0 7px 20px rgba(8,5,3,.5), 0 0 0 3px var(--moss), 0 0 0 4.5px rgba(11,7,3,.6) !important;}
#kjOnb .row .dcheck{top:50%; transform:translateY(-50%) scale(.6); right:12px;}
#kjOnb .row.sel .dcheck{transform:translateY(-50%) scale(1);}
#kjOnb .row .dinto{right:12px;}

#kjOnb .cnote{text-align:center; font-family:var(--font-ui); font-size:11.5px; font-weight:500;
  color:rgba(238,231,219,.56); margin-top:13px; letter-spacing:.1px;}

/* ════════════════ shared substep header bar (back + brand) ════════════════ */
#kjOnb .subhead{flex:0 0 auto; padding:calc(env(safe-area-inset-top,0px) + 16px) 20px 10px;}
#kjOnb .cbar{display:flex; align-items:center; gap:10px; margin-bottom:13px;}
#kjOnb .subhead .chl{font-size:22px; max-width:300px; padding-right:8px;}
#kjOnb .subhead .chl .cjp{white-space:nowrap; display:inline-block;}

/* ════════════════ TEXTBOOK · book picker ════════════════ */
#kjOnb #scr-book .cscroll{padding:8px 20px 24px;}
#kjOnb .bkgrid{display:flex; flex-direction:column; gap:12px;}
#kjOnb .bcard{position:relative; display:flex; align-items:stretch; cursor:pointer; min-height:96px;
  border-radius:var(--radius-lg); overflow:hidden; background-color:#16110a;
  box-shadow:0 5px 16px rgba(8,5,3,.44), inset 0 0 0 1px rgba(255,255,255,.05);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .22s var(--ease), box-shadow .22s var(--ease);}
#kjOnb .bcard:active{transform:scale(.985);}
#kjOnb .bcard .bcpic{position:relative; flex:0 0 auto; width:108px; align-self:stretch; overflow:hidden; background-color:var(--image-base);}
#kjOnb .bcard .bcpic .bcimg{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(1) brightness(.86);}
#kjOnb .bcard .bcpic::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(22,17,10,0) 46%, rgba(22,17,10,.95) 100%);}
#kjOnb .bcard .bcbody{flex:1 1 auto; min-width:0; padding:15px 46px 15px 16px; display:flex; flex-direction:column; justify-content:center;}
#kjOnb .bcard .bcen{font-family:var(--font-ui); font-size:17px; font-weight:700; color:#fdfaf3; line-height:1.1; letter-spacing:-.01em;}
#kjOnb .bcard .bcjp{font-family:var(--font-jp); font-size:12.5px; font-weight:600; color:rgba(251,247,238,.86); margin-top:4px; line-height:1.1;}
#kjOnb .bcard .bcjp .bcrm{font-family:var(--font-ui); font-size:10px; font-weight:500; color:rgba(243,234,217,.66); margin-left:6px; letter-spacing:.2px;}
#kjOnb .bcard .bcmeta{font-family:var(--font-ui); font-size:11.5px; font-weight:500; color:rgba(238,231,219,.6); margin-top:7px; letter-spacing:.1px;}
#kjOnb .bcard .bcmeta .bcdot{display:inline-block; width:3px; height:3px; border-radius:50%; background:rgba(238,231,219,.4); margin:0 6px; vertical-align:middle;}

/* ════════════════ TEXTBOOK · lessons ════════════════ */
#kjOnb #scr-lessons .cscroll{padding:8px 20px 24px;}
#kjOnb #scr-spoken .cscroll{padding:8px 20px 24px;}
#kjOnb .lnote{font-family:var(--font-ui); font-size:11.5px; font-weight:500; color:rgba(238,231,219,.58);
  margin:0 2px 12px; line-height:1.35;}
#kjOnb .lgrid{display:flex; flex-direction:column; gap:9px;}
#kjOnb .lcard{position:relative; display:flex; align-items:center; cursor:pointer; min-height:74px;
  border-radius:var(--radius-lg); overflow:hidden; background-color:#16110a;
  box-shadow:0 4px 13px rgba(8,5,3,.4), inset 0 0 0 1px rgba(255,255,255,.05);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);}
#kjOnb .lcard:active{transform:scale(.985);}
#kjOnb .lcard .lpic{position:relative; flex:0 0 auto; width:86px; align-self:stretch; overflow:hidden; background-color:var(--image-base);}
#kjOnb .lcard .lpic .lpimg{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(.98) brightness(.84);}
#kjOnb .lcard .lpic::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(22,17,10,0) 36%, rgba(22,17,10,.94) 100%);}
#kjOnb .lcard .lbody{flex:1 1 auto; min-width:0; padding:11px 46px 11px 14px;}
#kjOnb .lcard .lnum{font-family:var(--font-ui); font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(238,231,219,.55);}
#kjOnb .lcard .lname{font-family:var(--font-ui); font-size:14.5px; font-weight:700; color:#fdfaf3; line-height:1.14; margin-top:3px; letter-spacing:-.005em;}
#kjOnb .lcard .lct{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.58); margin-top:5px; letter-spacing:.1px;}
#kjOnb .lcard.sel{box-shadow:0 7px 20px rgba(8,5,3,.5), 0 0 0 3px var(--moss), 0 0 0 4.5px rgba(11,7,3,.6) !important;}
#kjOnb .lcard .dcheck{top:50%; transform:translateY(-50%) scale(.6); right:12px;}
#kjOnb .lcard.sel .dcheck{transform:translateY(-50%) scale(1);}

/* ════════════════ PICK A TOPIC · the wall ════════════════ */
#kjOnb #scr-topic .cscroll{padding:8px 20px 20px;}
#kjOnb .feat{position:relative; border-radius:var(--radius-lg); overflow:hidden; cursor:pointer;
  aspect-ratio:16/8; margin-bottom:14px; background-color:var(--image-base);
  box-shadow:0 7px 22px rgba(8,5,3,.5), inset 0 0 0 1px rgba(255,255,255,.06);
  -webkit-user-select:none; user-select:none;}
#kjOnb .feat:active{transform:scale(.99);}
#kjOnb .feat .fpic{position:absolute; inset:0; background-size:cover; background-position:center;
  filter:saturate(1.02) brightness(.96); animation:kjo-hero-kb 26s var(--ease) infinite alternate;}
#kjOnb .feat .ftint{position:absolute; inset:0; background:linear-gradient(105deg,
  rgba(11,7,3,.9) 0%, rgba(11,7,3,.6) 38%, rgba(11,7,3,.2) 70%, rgba(11,7,3,.04) 100%);}
#kjOnb .feat .fbody{position:absolute; left:16px; right:14px; bottom:14px; z-index:2;}
#kjOnb .feat .fkick{font-family:var(--font-ui); font-size:9.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(238,231,219,.55);}
#kjOnb .feat .fen{font-family:var(--font-ui); font-size:19px; font-weight:700; color:#fdfaf3; line-height:1.08; margin-top:6px; letter-spacing:-.01em; text-shadow:0 1px 3px rgba(0,0,0,.85);}
#kjOnb .feat .fjp{font-family:var(--font-jp); font-size:12.5px; font-weight:600; color:rgba(251,247,238,.9); margin-top:4px; text-shadow:0 1px 4px rgba(8,5,3,.9);}
#kjOnb .feat .fjp .frm{font-family:var(--font-ui); font-size:9.5px; font-weight:500; color:rgba(243,234,217,.74); margin-left:6px; letter-spacing:.2px;}
#kjOnb .feat.sel{box-shadow:0 7px 22px rgba(8,5,3,.5), 0 0 0 3px var(--moss), 0 0 0 4.5px rgba(11,7,3,.55) !important;}
#kjOnb .feat .fcheck{position:absolute; top:9px; left:9px; z-index:4; width:24px; height:24px; border-radius:50%;
  background:var(--moss); display:flex; align-items:center; justify-content:center;
  opacity:0; transform:scale(.5); transition:opacity .2s var(--ease), transform .2s var(--ease);
  box-shadow:0 2px 7px rgba(8,5,3,.5), 0 0 0 1.5px rgba(253,250,243,.92);}
#kjOnb .feat .fcheck svg{width:13px; height:13px; fill:none; stroke:#fff; stroke-width:2.7; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .feat.sel .fcheck{opacity:1; transform:scale(1);}

#kjOnb #kjoTwall{display:grid; grid-template-columns:1fr 1fr; gap:11px;}
#kjOnb .world{position:relative; opacity:0; transform:translateY(14px); transition:opacity .5s var(--ease), transform .55s var(--ease);}
#kjOnb #scr-topic.tin .world{opacity:1; transform:none;}
#kjOnb .wcard{position:relative; border-radius:var(--radius-lg); overflow:hidden; cursor:pointer;
  aspect-ratio:1/1; background-color:var(--image-base);
  box-shadow:0 5px 16px rgba(8,5,3,.46), inset 0 0 0 1px rgba(255,255,255,.05);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none;
  transition:transform .22s var(--ease), box-shadow .22s var(--ease);}
#kjOnb .wcard:active{transform:scale(.975);}
#kjOnb .wcard .wpic{position:absolute; inset:0; background-size:cover; background-position:center;
  filter:saturate(1) brightness(.92); transition:filter .25s var(--ease);}
#kjOnb .wcard .wtint{position:absolute; inset:0; background:linear-gradient(to top, rgba(11,7,3,.92) 0%, rgba(11,7,3,.6) 28%, rgba(11,7,3,.14) 56%, rgba(11,7,3,0) 80%);}
#kjOnb .wcard .wbody{position:absolute; left:12px; right:12px; bottom:11px; z-index:2;}
#kjOnb .wcard .wen{font-family:var(--font-ui); font-size:14px; font-weight:700; line-height:1.12; color:#fdfaf3; letter-spacing:-.006em; text-shadow:0 1px 3px rgba(0,0,0,.85);}
#kjOnb .wcard .wjp{font-family:var(--font-jp); font-size:12px; font-weight:600; color:rgba(251,247,238,.9); margin-top:3px; line-height:1.1; text-shadow:0 1px 4px rgba(8,5,3,.9);}
#kjOnb .wcard .wjp .wrm{font-family:var(--font-ui); font-size:9px; font-weight:500; color:rgba(243,234,217,.74); margin-left:5px; letter-spacing:.2px;}
#kjOnb .wcard .wcount{display:block; margin-top:5px; font-family:var(--font-ui); font-size:10.5px; font-weight:600; color:rgba(238,231,219,.66); letter-spacing:.2px; text-shadow:0 1px 3px rgba(8,5,3,.85);}
#kjOnb .world.sel .wcard{box-shadow:0 8px 22px rgba(8,5,3,.52), 0 0 0 3px var(--moss), 0 0 0 4.5px rgba(11,7,3,.55) !important;}
#kjOnb .world.sel .wcard .wpic{filter:saturate(1.05) brightness(.98);}
#kjOnb .world.partial .wcard{box-shadow:0 8px 22px rgba(8,5,3,.52), 0 0 0 3px var(--moss), 0 0 0 4.5px rgba(11,7,3,.55) !important;}
#kjOnb .wcheck{position:absolute; top:9px; left:9px; z-index:4; width:24px; height:24px; border-radius:50%;
  background:var(--moss); display:flex; align-items:center; justify-content:center;
  opacity:0; transform:scale(.5); transition:opacity .2s var(--ease), transform .2s var(--ease);
  box-shadow:0 2px 7px rgba(8,5,3,.5), 0 0 0 1.5px rgba(253,250,243,.92);}
#kjOnb .wcheck svg{width:13px; height:13px; fill:none; stroke:#fff; stroke-width:2.7; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .world.sel .wcheck, #kjOnb .world.partial .wcheck{opacity:1; transform:scale(1);}
#kjOnb .wpeek{position:absolute; bottom:9px; right:9px; z-index:5; display:flex; align-items:center; gap:5px;
  padding:5px 9px 5px 10px; border-radius:var(--radius-full); cursor:pointer;
  font-family:var(--font-ui); font-size:9.5px; font-weight:600; letter-spacing:.02em; color:rgba(253,250,243,.9);
  background:rgba(18,13,8,.5); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  box-shadow:inset 0 0 0 1px rgba(255,253,248,.22); transition:transform .15s var(--ease), background .2s var(--ease);}
#kjOnb .wpeek:active{transform:scale(.93);}
#kjOnb .wpeek svg{width:11px; height:11px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round;}

#kjOnb #scr-topic .cfoot{padding:10px 18px calc(env(safe-area-inset-bottom,0px) + 16px);}
#kjOnb .tray{display:flex; align-items:center; gap:8px; overflow-x:auto; padding:2px 2px 10px; min-height:38px;}
#kjOnb .tray::-webkit-scrollbar{display:none;}
#kjOnb .tray .tempty{font-family:var(--font-ui); font-size:12px; font-weight:500; color:rgba(238,231,219,.52); white-space:nowrap; padding:8px 2px;}
#kjOnb .tchip{flex:0 0 auto; display:inline-flex; align-items:center; gap:7px; padding:6px 8px 6px 7px;
  border-radius:var(--radius-full); background:rgba(107,127,92,.16); box-shadow:inset 0 0 0 1.5px var(--moss);
  animation:kjo-tpop .26s var(--ease) both;}
#kjOnb .tchip.part{background:rgba(107,127,92,0); box-shadow:inset 0 0 0 1.5px rgba(107,127,92,.5);}
@keyframes kjo-tpop{0%{opacity:0; transform:scale(.8) translateY(4px);} 100%{opacity:1; transform:none;}}
#kjOnb .tchip .tcpic{width:24px; height:24px; border-radius:50%; overflow:hidden; flex:0 0 auto; background-size:cover; background-position:center; box-shadow:inset 0 0 0 1px rgba(255,255,255,.1);}
#kjOnb .tchip .tclab{font-family:var(--font-ui); font-size:11.5px; font-weight:600; color:rgba(251,247,238,.92); white-space:nowrap;}
#kjOnb .tchip .tclab .tcpart{font-weight:500; color:rgba(238,231,219,.6); margin-left:3px; font-size:10px;}
#kjOnb .tchip .tcx{flex:0 0 auto; width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; color:rgba(243,234,217,.8); background:rgba(20,15,10,.5);}
#kjOnb .tchip .tcx svg{width:10px; height:10px; fill:none; stroke:currentColor; stroke-width:2.6; stroke-linecap:round;}
#kjOnb .tally{display:flex; align-items:baseline; justify-content:center; gap:8px; margin-bottom:11px; min-height:18px;
  font-family:var(--font-ui); font-size:13px; font-weight:600; color:rgba(243,234,217,.6); letter-spacing:.1px; transition:color .3s var(--ease);}
#kjOnb .tally.live{color:rgba(247,242,231,.92);}
#kjOnb .tally .tnum{font-weight:700; color:#f7f2e7; font-variant-numeric:tabular-nums;}
#kjOnb .tally .tdot{width:3px; height:3px; border-radius:50%; background:rgba(238,231,219,.4); align-self:center;}
#kjOnb .tally .tw{color:rgba(238,231,219,.66); font-weight:500;}

#kjOnb .sheet-scrim{position:absolute; inset:0; z-index:40; background:rgba(8,5,3,.5);
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease);
  -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px);}
#kjOnb .sheet-scrim.open{opacity:1; pointer-events:auto;}
#kjOnb .sheet{position:absolute; left:0; right:0; bottom:0; z-index:41; max-height:80%;
  display:flex; flex-direction:column; background:#15100a;
  border-radius:22px 22px 0 0; box-shadow:0 -10px 40px rgba(8,5,3,.6);
  transform:translateY(101%); transition:transform .34s var(--ease);
  padding-bottom:calc(env(safe-area-inset-bottom,0px) + 4px);}
#kjOnb .sheet.open{transform:translateY(0);}
#kjOnb .sheet .grab{flex:0 0 auto; width:38px; height:4px; border-radius:2px; margin:9px auto 4px; background:rgba(243,234,217,.24);}
#kjOnb .shead{flex:0 0 auto; display:flex; align-items:flex-start; gap:12px; padding:6px 18px 10px;}
#kjOnb .shead .shpic{flex:0 0 auto; width:52px; height:52px; border-radius:var(--radius-md); overflow:hidden;
  background-size:cover; background-position:center; background-color:var(--image-base); box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);}
#kjOnb .shead .shtxt{flex:1 1 auto; min-width:0; padding-top:1px;}
#kjOnb .shead .shen{font-family:var(--font-ui); font-size:16px; font-weight:700; color:#fdfaf3; line-height:1.12; letter-spacing:-.005em;}
#kjOnb .shead .shjp{font-family:var(--font-jp); font-size:12.5px; font-weight:600; color:rgba(238,231,219,.72); margin-top:3px;}
#kjOnb .shead .shjp .shrm{font-family:var(--font-ui); font-size:10px; font-weight:500; color:rgba(238,231,219,.5); margin-left:5px; letter-spacing:.2px;}
#kjOnb .shead .shsub{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.56); margin-top:5px; line-height:1.3;}
#kjOnb .shead .shclose{flex:0 0 auto; width:30px; height:30px; border-radius:50%; cursor:pointer;
  display:flex; align-items:center; justify-content:center; color:rgba(243,234,217,.7);
  background:rgba(255,253,248,.07); box-shadow:inset 0 0 0 1px rgba(255,253,248,.1);}
#kjOnb .shclose svg{width:14px; height:14px; fill:none; stroke:currentColor; stroke-width:2.3; stroke-linecap:round;}
#kjOnb .speek{display:flex; gap:7px; padding:0 18px 12px;}
#kjOnb .speek .spk{flex:0 0 auto; width:52px; height:52px; border-radius:11px; overflow:hidden; position:relative;
  background-color:var(--image-base); box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);}
#kjOnb .speek .spk .spki{position:absolute; inset:0; background-size:cover; background-position:center;}
#kjOnb .speek .spkmore{flex:0 0 auto; width:52px; height:52px; border-radius:11px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-ui); font-size:12px; font-weight:700; color:rgba(243,234,217,.7);
  background:rgba(255,253,248,.05); box-shadow:inset 0 0 0 1px rgba(255,253,248,.1);}
#kjOnb .sall{margin:0 18px 8px; display:flex; align-items:center; gap:11px; cursor:pointer;
  padding:11px 13px; border-radius:var(--radius-md); background:rgba(255,253,248,.04);
  box-shadow:inset 0 0 0 1px rgba(255,253,248,.08); -webkit-user-select:none; user-select:none; transition:box-shadow .2s var(--ease);}
#kjOnb .sall.on{box-shadow:inset 0 0 0 1.5px var(--moss);}
#kjOnb .sall .sabox{flex:0 0 auto; width:22px; height:22px; border-radius:6px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,253,248,.06); box-shadow:inset 0 0 0 1.5px rgba(255,253,248,.22); transition:background .2s var(--ease), box-shadow .2s var(--ease);}
#kjOnb .sall.on .sabox{background:var(--moss); box-shadow:none;}
#kjOnb .sall .sabox svg{width:13px; height:13px; fill:none; stroke:#fff; stroke-width:2.7; stroke-linecap:round; stroke-linejoin:round; opacity:0; transition:opacity .15s var(--ease);}
#kjOnb .sall.on .sabox svg{opacity:1;}
#kjOnb .sall .satxt{flex:1 1 auto; min-width:0;}
#kjOnb .sall .saen{font-family:var(--font-ui); font-size:13px; font-weight:600; color:#fdfaf3;}
#kjOnb .sall .sact{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.56); margin-top:1px;}
#kjOnb .ssub{font-family:var(--font-ui); font-size:10px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(238,231,219,.42); padding:6px 18px 8px;}
#kjOnb .schips{flex:1 1 auto; min-height:0; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:0 18px 16px; display:flex; flex-wrap:wrap; gap:8px;}
#kjOnb .schips::-webkit-scrollbar{display:none;}
#kjOnb .chip2{display:inline-flex; align-items:center; gap:8px; cursor:pointer; padding:9px 13px 9px 11px; border-radius:var(--radius-full);
  background:rgba(255,253,248,.05); box-shadow:inset 0 0 0 1px rgba(255,253,248,.1);
  -webkit-user-select:none; user-select:none; transition:box-shadow .18s var(--ease), background .18s var(--ease);}
#kjOnb .chip2.on{background:rgba(107,127,92,.16); box-shadow:inset 0 0 0 1.5px var(--moss);}
#kjOnb .chip2 .cdot{width:7px; height:7px; border-radius:50%; background:rgba(238,231,219,.3); flex:0 0 auto; transition:background .18s var(--ease);}
#kjOnb .chip2.on .cdot{background:var(--moss);}
#kjOnb .chip2 .clab{font-family:var(--font-ui); font-size:12.5px; font-weight:600; color:rgba(251,247,238,.9); line-height:1;}
#kjOnb .chip2 .cnum{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.5); line-height:1;}
#kjOnb .sheet .sfoot2{flex:0 0 auto; padding:10px 18px calc(env(safe-area-inset-bottom,0px) + 14px); border-top:1px solid rgba(255,253,248,.07);}
#kjOnb .sheet .sdone{width:100%; display:flex; align-items:center; justify-content:center; gap:9px; padding:13px; border-radius:var(--radius-full); cursor:pointer;
  font-family:var(--font-ui); font-size:14px; font-weight:600; color:#fdfaf3;
  background:rgba(255,253,248,.07); box-shadow:inset 0 0 0 1px rgba(255,253,248,.16);
  -webkit-user-select:none; user-select:none; transition:transform .15s var(--ease);}
#kjOnb .sheet .sdone.has{background:var(--moss); box-shadow:none; color:#fff;}
#kjOnb .sheet .sdone:active{transform:scale(.98);}

/* ════════════════ BUILD YOUR OWN · the composer ════════════════ */
#kjOnb .shoji{position:absolute; inset:0; z-index:7; background:#0d0904; pointer-events:none;
  opacity:1; transition:opacity .5s var(--ease);}
#kjOnb #scr-byo.shoji-on .shoji{opacity:0;}
#kjOnb .csheet{position:relative; z-index:5; flex:1 1 auto; min-height:0; margin-top:6px; display:flex; flex-direction:column;
  background:#1a140c; border-radius:24px 24px 0 0;
  box-shadow:0 -10px 34px rgba(8,5,3,.6), inset 0 1px 0 rgba(255,253,248,.06); overflow:hidden;}
#kjOnb .csheet .grab{flex:0 0 auto; display:flex; justify-content:center; padding:9px 0 4px;}
#kjOnb .csheet .grab span{width:38px; height:4px; border-radius:2px; background:rgba(243,234,217,.22);}
#kjOnb .sbody{flex:1 1 auto; min-height:0; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:6px 20px 22px;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, #000 10px, #000 calc(100% - 10px), transparent 100%);
          mask-image:linear-gradient(to bottom, transparent 0, #000 10px, #000 calc(100% - 10px), transparent 100%);}
#kjOnb .sbody::-webkit-scrollbar{display:none;}

#kjOnb .count{position:relative; border-radius:var(--radius-lg); overflow:hidden; margin:4px 0 18px; aspect-ratio:16/8.2;
  background-color:var(--image-base); box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);}
#kjOnb .count .cpic{position:absolute; inset:0; background-size:cover; background-position:center;
  filter:saturate(1) brightness(.96); transition:opacity .4s var(--ease); animation:kjo-count-kb 26s var(--ease) infinite alternate;}
@keyframes kjo-count-kb{0%{transform:scale(1.03);} 100%{transform:scale(1.1);}}
#kjOnb .count .ctint{position:absolute; inset:0; background:linear-gradient(105deg, rgba(11,7,3,.93) 0%, rgba(11,7,3,.78) 38%, rgba(11,7,3,.4) 70%, rgba(11,7,3,.12) 100%);}
#kjOnb .count .cbody2{position:absolute; left:18px; right:16px; bottom:15px; z-index:2;}
#kjOnb .count .clab{font-family:var(--font-ui); font-size:10.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(238,231,219,.55); display:flex; align-items:baseline; gap:8px; flex-wrap:wrap;}
#kjOnb .count .cnum{display:flex; align-items:baseline; gap:9px; margin-top:3px;}
#kjOnb .count .cn{font-family:var(--font-ui); font-size:52px; font-weight:700; line-height:.96; color:#fdfaf3; letter-spacing:-.025em; text-shadow:0 2px 12px rgba(0,0,0,.5); font-variant-numeric:tabular-nums;}
#kjOnb .count .cu{font-family:var(--font-ui); font-size:13px; font-weight:600; color:rgba(243,234,217,.74); letter-spacing:.2px; padding-bottom:6px;}
#kjOnb .count .cn.tick{animation:kjo-numtick .42s var(--ease);}
@keyframes kjo-numtick{0%{transform:translateY(4px); opacity:.4;} 100%{transform:none; opacity:1;}}
#kjOnb .count .cwater{position:relative; margin-top:11px; height:4px; border-radius:2px; background:rgba(243,234,217,.13); overflow:hidden;}
#kjOnb .count .cwater i{position:absolute; left:0; top:0; bottom:0; border-radius:2px; background:var(--accent); width:0%; transition:width .5s var(--ease);}
#kjOnb .count.narrow .cpic{filter:brightness(.5) saturate(.55) grayscale(.3);}
#kjOnb .count .cledger{margin-top:9px; font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.7); line-height:1.35; text-shadow:0 1px 3px rgba(8,5,3,.7);}

#kjOnb .sect-h{display:flex; align-items:baseline; gap:9px; margin:2px 2px 9px;}
#kjOnb .sect-h b{font-family:var(--font-ui); font-size:13px; font-weight:700; color:#fdfaf3; letter-spacing:-.005em;}
#kjOnb .sect-h .sjp{font-family:var(--font-jp); font-size:11px; font-weight:600; color:rgba(243,234,217,.6);}
#kjOnb .sect-h .sjp .srm{font-family:var(--font-ui); font-size:9px; font-weight:500; color:rgba(243,234,217,.5); margin-left:5px; letter-spacing:.2px;}
#kjOnb .sect-note{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.54); margin:-4px 2px 11px; line-height:1.3;}

#kjOnb .bases{display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-bottom:10px;}
#kjOnb .base{position:relative; border-radius:var(--radius-md); overflow:hidden; cursor:pointer; aspect-ratio:1/1.05;
  background-color:var(--image-base); box-shadow:0 3px 11px rgba(8,5,3,.4), inset 0 0 0 1px rgba(255,255,255,.05);
  -webkit-user-select:none; user-select:none; -webkit-touch-callout:none; transition:transform .2s var(--ease), box-shadow .2s var(--ease);}
#kjOnb .base:active{transform:scale(.97);}
#kjOnb .base .bpic{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(.92) brightness(.62); transition:filter .25s var(--ease);}
#kjOnb .base .btint{position:absolute; inset:0; background:linear-gradient(to top, rgba(11,7,3,.92) 0%, rgba(11,7,3,.5) 48%, rgba(11,7,3,.18) 100%);}
#kjOnb .base .bbody{position:absolute; left:10px; right:9px; bottom:9px; z-index:2;}
#kjOnb .base .ben{font-family:var(--font-ui); font-size:13px; font-weight:700; color:#fdfaf3; line-height:1.08; letter-spacing:-.01em; text-shadow:0 1px 3px rgba(0,0,0,.8);}
#kjOnb .base .bjp{display:block; font-family:var(--font-jp); font-size:11px; font-weight:600; color:rgba(251,247,238,.86); margin-top:3px; line-height:1;}
#kjOnb .base .brm{display:block; font-family:var(--font-ui); font-size:9px; font-weight:500; color:rgba(243,234,217,.66); margin-top:2px; letter-spacing:.2px;}
#kjOnb .base .bwhy{display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; font-family:var(--font-ui); font-size:9px; font-weight:500; color:rgba(243,234,217,.58); margin-top:4px; line-height:1.25; text-shadow:0 1px 3px rgba(0,0,0,.8);}
#kjOnb .base.sel{box-shadow:0 6px 16px rgba(8,5,3,.5), 0 0 0 2.5px var(--moss), 0 0 0 4px rgba(11,7,3,.55) !important;}
#kjOnb .base.sel .bpic{filter:saturate(1) brightness(.72);}
#kjOnb .base .bck{position:absolute; top:8px; right:8px; z-index:3; width:22px; height:22px; border-radius:50%;
  background:var(--moss); display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.6);
  transition:opacity .2s var(--ease), transform .2s var(--ease); box-shadow:0 1px 5px rgba(8,5,3,.5), 0 0 0 1.5px rgba(253,250,243,.9);}
#kjOnb .base .bck svg{width:12px; height:12px; fill:none; stroke:#fff; stroke-width:2.8; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .base.sel .bck{opacity:1; transform:scale(1);}

#kjOnb .facets{display:flex; flex-direction:column; gap:10px;}
#kjOnb .facet{border-radius:var(--radius-md); overflow:hidden; background:#1d160d; box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);}
#kjOnb .fhd{display:flex; align-items:center; gap:11px; padding:14px 14px; cursor:pointer; -webkit-user-select:none; user-select:none; transition:background .2s var(--ease);}
#kjOnb .facet.open .fhd{background:rgba(255,253,248,.03);}
#kjOnb .fhd:active{background:rgba(255,253,248,.04);}
#kjOnb .fname{flex:0 0 auto; min-width:0;}
#kjOnb .fname .fn-en{font-family:var(--font-ui); font-size:14px; font-weight:700; color:#fdfaf3; line-height:1.1; letter-spacing:-.005em;}
#kjOnb .fname .fn-jp{font-family:var(--font-jp); font-size:10.5px; font-weight:600; color:rgba(243,234,217,.56); margin-left:7px; line-height:1;}
#kjOnb .fname .fn-jp .fn-rm{font-family:var(--font-ui); font-size:8.5px; font-weight:500; color:rgba(243,234,217,.46); margin-left:4px; letter-spacing:.2px;}
#kjOnb .fsum{flex:1 1 auto; min-width:0; text-align:right; font-family:var(--font-ui); font-size:12px; font-weight:500; color:rgba(238,231,219,.5); line-height:1.25; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
#kjOnb .fsum.on{color:#a9c39b; font-weight:600;}
#kjOnb .fchev{flex:0 0 auto; width:24px; height:24px; display:flex; align-items:center; justify-content:center; color:rgba(243,234,217,.5); transition:transform .25s var(--ease);}
#kjOnb .facet.open .fchev{transform:rotate(90deg);}
#kjOnb .fchev svg{width:17px; height:17px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .fclear{flex:0 0 auto; width:24px; height:24px; border-radius:50%; display:none; align-items:center; justify-content:center; cursor:pointer; margin-right:-2px;
  color:rgba(238,231,219,.62); background:rgba(20,15,10,.5); box-shadow:inset 0 0 0 1px rgba(255,253,248,.12);}
#kjOnb .facet.has .fclear{display:flex;}
#kjOnb .fclear svg{width:12px; height:12px; fill:none; stroke:currentColor; stroke-width:2.4; stroke-linecap:round;}
#kjOnb .fbody{display:none; padding:0 13px 14px;}
#kjOnb .facet.open .fbody{display:block;}

#kjOnb .tgrid{display:grid; grid-template-columns:repeat(3,1fr); gap:8px;}
#kjOnb .tcell{position:relative; border-radius:var(--radius-sm); overflow:hidden; cursor:pointer; background:none; border:0; padding:0; text-align:left; -webkit-user-select:none; user-select:none;}
#kjOnb .tcell .tart{position:relative; aspect-ratio:1/.82; border-radius:var(--radius-sm); overflow:hidden; background-size:cover; background-position:center; background-color:var(--image-base); box-shadow:inset 0 0 0 1px rgba(255,255,255,.05); transition:box-shadow .2s var(--ease);}
#kjOnb .tcell .tart::after{content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(11,7,3,.72) 0%, rgba(11,7,3,.1) 60%);}
#kjOnb .tcell.on .tart{box-shadow:0 0 0 2.5px var(--moss), 0 0 0 4px rgba(22,17,10,.7);}
#kjOnb .tcell .tck{position:absolute; top:5px; right:5px; z-index:2; width:20px; height:20px; border-radius:50%; background:var(--moss); display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.5); transition:opacity .18s var(--ease), transform .18s var(--ease); box-shadow:0 1px 4px rgba(8,5,3,.5);}
#kjOnb .tcell .tck svg{width:11px; height:11px; fill:none; stroke:#fff; stroke-width:3; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .tcell.on .tck{opacity:1; transform:scale(1);}
#kjOnb .tcap{padding:5px 2px 1px;}
#kjOnb .tcap .tl{font-family:var(--font-ui); font-size:10.5px; font-weight:600; color:rgba(253,250,243,.92); line-height:1.15; letter-spacing:-.005em;}
#kjOnb .tcap .tj{font-family:var(--font-jp); font-size:9.5px; font-weight:500; color:rgba(243,234,217,.56); margin-top:1px; line-height:1.1; display:flex; align-items:baseline; gap:4px; flex-wrap:wrap;}
#kjOnb .tcap .tj .trm{font-family:var(--font-ui); font-size:8.5px; font-weight:500; color:rgba(243,234,217,.46); letter-spacing:.2px;}
#kjOnb .tcap .tc{display:block; margin-top:2px; font-family:var(--font-ui); font-size:9px; font-weight:600; color:rgba(243,234,217,.42); letter-spacing:.2px;}
#kjOnb .tmore{margin-top:10px; width:100%; padding:9px; border-radius:var(--radius-full); cursor:pointer; background:rgba(255,253,248,.04); color:rgba(243,234,217,.66); border:0; font-family:var(--font-ui); font-size:11.5px; font-weight:600; letter-spacing:.2px; box-shadow:inset 0 0 0 1px rgba(255,253,248,.1); -webkit-user-select:none; user-select:none;}
#kjOnb .tmore:active{background:rgba(255,253,248,.07);}

#kjOnb .chips{display:flex; flex-direction:column; gap:8px;}
#kjOnb .fchip{display:flex; align-items:center; gap:11px; padding:12px 13px; cursor:pointer; border-radius:var(--radius-sm); background:rgba(255,253,248,.025); border:0; text-align:left; box-shadow:inset 0 0 0 1px rgba(255,253,248,.07); -webkit-user-select:none; user-select:none; transition:box-shadow .18s var(--ease), background .18s var(--ease);}
#kjOnb .fchip:active{background:rgba(255,253,248,.05);}
#kjOnb .fchip.on{background:rgba(107,127,92,.16); box-shadow:inset 0 0 0 1.5px var(--moss);}
#kjOnb .fchip .cbox{flex:0 0 auto; width:20px; height:20px; border-radius:6px; box-shadow:inset 0 0 0 1.5px rgba(243,234,217,.3); display:flex; align-items:center; justify-content:center; transition:background .18s var(--ease), box-shadow .18s var(--ease);}
#kjOnb .fchip.on .cbox{background:var(--moss); box-shadow:none;}
#kjOnb .fchip .cbox svg{width:12px; height:12px; fill:none; stroke:#fff; stroke-width:3; stroke-linecap:round; stroke-linejoin:round; opacity:0; transition:opacity .15s var(--ease);}
#kjOnb .fchip.on .cbox svg{opacity:1;}
#kjOnb .fchip .clbl{flex:1 1 auto; min-width:0;}
#kjOnb .fchip .clbl .ce{font-family:var(--font-ui); font-size:13.5px; font-weight:600; color:#fdfaf3; line-height:1.1;}
#kjOnb .fchip .clbl .cs{display:block; font-family:var(--font-ui); font-size:10.5px; font-weight:500; color:rgba(238,231,219,.54); margin-top:2px;}
#kjOnb .fchip .ccount{flex:0 0 auto; font-family:var(--font-ui); font-size:12px; font-weight:700; color:rgba(243,234,217,.62); font-variant-numeric:tabular-nums;}

#kjOnb .bklist{display:flex; flex-direction:column; gap:8px;}
#kjOnb .bkblock{border-radius:var(--radius-sm); overflow:hidden; background:rgba(255,253,248,.022); box-shadow:inset 0 0 0 1px rgba(255,253,248,.07);}
#kjOnb .bkrow{display:flex; align-items:center; gap:10px; padding:11px 12px; cursor:pointer; -webkit-user-select:none; user-select:none;}
#kjOnb .bkck{flex:0 0 auto; width:20px; height:20px; border-radius:6px; cursor:pointer; box-shadow:inset 0 0 0 1.5px rgba(243,234,217,.3); display:flex; align-items:center; justify-content:center; background:none; border:0; transition:background .18s var(--ease), box-shadow .18s var(--ease);}
#kjOnb .bkrow.on .bkck{background:var(--moss); box-shadow:none;}
#kjOnb .bkck svg{width:12px; height:12px; fill:none; stroke:#fff; stroke-width:3; stroke-linecap:round; stroke-linejoin:round; opacity:0; transition:opacity .15s var(--ease);}
#kjOnb .bkrow.on .bkck svg{opacity:1;}
#kjOnb .bknm{flex:1 1 auto; min-width:0; background:none; border:0; text-align:left; cursor:pointer; padding:0;}
#kjOnb .bknm .be{font-family:var(--font-ui); font-size:13px; font-weight:600; color:#fdfaf3; line-height:1.1;}
#kjOnb .bknm .bj{display:block; font-family:var(--font-jp); font-size:9.5px; font-weight:500; color:rgba(243,234,217,.52); margin-top:2px;}
#kjOnb .bknm .bj .bjrm{font-family:var(--font-ui); font-size:8.5px; font-weight:500; color:rgba(243,234,217,.46); margin-left:5px; letter-spacing:.2px;}
#kjOnb .bkct{flex:0 0 auto; font-family:var(--font-ui); font-size:11.5px; font-weight:700; color:rgba(243,234,217,.6); font-variant-numeric:tabular-nums;}
#kjOnb .bkexp{flex:0 0 auto; width:24px; height:24px; display:flex; align-items:center; justify-content:center; color:rgba(243,234,217,.5); background:none; border:0; cursor:pointer; transition:transform .22s var(--ease);}
#kjOnb .bkblock.exp .bkexp{transform:rotate(90deg);}
#kjOnb .bkexp svg{width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round;}
#kjOnb .bklessons{display:none; padding:0 12px 11px; flex-direction:column; gap:5px;}
#kjOnb .bkblock.exp .bklessons{display:flex;}
#kjOnb .lchip{display:flex; align-items:center; gap:9px; padding:9px 11px; cursor:pointer; border-radius:var(--radius-sm); background:rgba(255,253,248,.03); border:0; text-align:left; box-shadow:inset 0 0 0 1px rgba(255,253,248,.06); -webkit-user-select:none; user-select:none;}
#kjOnb .lchip.on{background:rgba(107,127,92,.16); box-shadow:inset 0 0 0 1.5px var(--moss);}
#kjOnb .lchip .lck{flex:0 0 auto; width:16px; height:16px; border-radius:5px; box-shadow:inset 0 0 0 1.4px rgba(243,234,217,.3); display:flex; align-items:center; justify-content:center;}
#kjOnb .lchip.on .lck{background:var(--moss); box-shadow:none;}
#kjOnb .lchip .lck svg{width:10px; height:10px; fill:none; stroke:#fff; stroke-width:3; stroke-linecap:round; stroke-linejoin:round; opacity:0;}
#kjOnb .lchip.on .lck svg{opacity:1;}
#kjOnb .lchip .ll{flex:1 1 auto; min-width:0;}
#kjOnb .lchip .ll .ln{font-family:var(--font-ui); font-size:11.5px; font-weight:600; color:rgba(253,250,243,.9); line-height:1.1;}
#kjOnb .lchip .ll .lnn{display:block; font-family:var(--font-ui); font-size:9.5px; font-weight:500; color:rgba(238,231,219,.5); margin-top:2px;}
#kjOnb .lchip .lct{flex:0 0 auto; font-family:var(--font-ui); font-size:10px; font-weight:600; color:rgba(243,234,217,.46); font-variant-numeric:tabular-nums;}

#kjOnb .fhint{margin-top:10px; font-family:var(--font-ui); font-size:10.5px; font-weight:500; color:rgba(238,231,219,.46); line-height:1.35; letter-spacing:.1px;}
#kjOnb .cross{margin:16px 2px 2px; padding:11px 13px; border-radius:var(--radius-sm); background:rgba(255,253,248,.025); box-shadow:inset 0 0 0 1px rgba(255,253,248,.06); font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,231,219,.6); line-height:1.4;}
#kjOnb .cross b{color:#a9c39b; font-weight:700;}
#kjOnb .cross .ar{color:rgba(243,234,217,.4); margin:0 4px;}
#kjOnb .guard{margin:14px 2px 2px; padding:14px; border-radius:var(--radius-sm); background:rgba(180,120,90,.1); box-shadow:inset 0 0 0 1px rgba(201,140,110,.3);}
#kjOnb .guard .gt{font-family:var(--font-ui); font-size:12.5px; font-weight:700; color:#e8c4ac;}
#kjOnb .guard .gb{font-family:var(--font-ui); font-size:11px; font-weight:500; color:rgba(238,224,217,.72); margin-top:5px; line-height:1.4;}

#kjOnb .sfoot{flex:0 0 auto; position:relative; z-index:6; padding:13px 18px calc(env(safe-area-inset-bottom,0px) + 16px);
  background:linear-gradient(to top, #1a140c 0%, #1a140c 70%, rgba(26,20,12,0) 100%);}

/* ════════════════ the HANDOFF seal — the ONE scarce gold moment ════════════════ */
#kjOnb .seal-veil{position:absolute; inset:0; z-index:60; display:flex; align-items:center; justify-content:center;
  background:#0d0904; opacity:0; pointer-events:none; transition:opacity .45s var(--ease); overflow:hidden;}
#kjOnb .seal-veil.open{opacity:1; pointer-events:auto;}
#kjOnb .seal-bg{position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(.4) saturate(.95);
  animation:kjo-hero-kb 30s var(--ease) infinite alternate;}
#kjOnb .seal-scrim{position:absolute; inset:0; background:radial-gradient(120% 90% at 50% 42%, rgba(13,9,4,.78) 0%, rgba(11,7,3,.93) 72%);}
#kjOnb .seal-card{position:relative; z-index:2; text-align:center; padding:0 34px; transform:translateY(14px) scale(.97); opacity:0;
  transition:transform .55s var(--ease), opacity .55s var(--ease);}
#kjOnb .seal-veil.open .seal-card{transform:none; opacity:1; transition-delay:.12s;}
#kjOnb .seal-ring{width:100px; height:100px; margin:0 auto 22px; border-radius:50%; position:relative; display:flex; align-items:center; justify-content:center;
  box-shadow:inset 0 0 0 2px rgba(201,169,110,.7), 0 0 30px rgba(201,169,110,.22);
  background:radial-gradient(circle at 38% 32%, rgba(201,169,110,.14), rgba(201,169,110,.03));}
#kjOnb .seal-ring::before{content:""; position:absolute; inset:7px; border-radius:50%; box-shadow:inset 0 0 0 1px rgba(201,169,110,.3);}
#kjOnb .seal-ring .skanji{font-family:var(--font-jp); font-size:40px; font-weight:600; color:#e8d4a4; text-shadow:0 0 18px rgba(201,169,110,.4); line-height:1;}
#kjOnb .seal-card .sttl{font-family:var(--font-ui); font-size:21px; font-weight:700; color:#f7f2e7; letter-spacing:-.01em;}
#kjOnb .seal-card .stjp{font-family:var(--font-jp); font-size:14px; font-weight:600; color:rgba(240,227,196,.84); margin-top:7px;}
#kjOnb .seal-card .stjp .strm{font-family:var(--font-ui); font-size:10.5px; font-weight:500; color:rgba(240,227,196,.62); margin-left:6px; letter-spacing:.2px;}
#kjOnb .seal-card .stwhat{font-family:var(--font-ui); font-size:13px; font-weight:500; color:rgba(238,231,219,.74); margin-top:14px; line-height:1.5; max-width:290px;}
#kjOnb .seal-card .stwhat b{color:#e8d4a4; font-weight:700;}
#kjOnb .seal-card .stbless{font-family:var(--font-jp); font-size:12.5px; font-weight:600; color:rgba(240,227,196,.7); margin-top:16px;}
#kjOnb .seal-card .stbless .strm{font-family:var(--font-ui); font-size:10px; font-weight:500; color:rgba(240,227,196,.5); margin-left:6px;}
#kjOnb .seal-enter{margin-top:24px; display:inline-flex; align-items:center; gap:10px; cursor:pointer; padding:15px 30px; border-radius:var(--radius-full);
  background:var(--accent); color:#fff; box-shadow:0 6px 18px rgba(61,90,128,.4); -webkit-user-select:none; user-select:none; transition:transform .15s var(--ease);}
#kjOnb .seal-enter:active{transform:scale(.97);}
#kjOnb .seal-enter b{font-family:var(--font-jp); font-size:16px; font-weight:600;}
#kjOnb .seal-enter .erm{font-family:var(--font-ui); font-size:12px; font-weight:500; opacity:.82; letter-spacing:.3px;}
#kjOnb .seal-enter .ar{font-size:16px; line-height:1;}

@media (prefers-reduced-motion: reduce){
  #kjOnb .cbg, #kjOnb .hero.recommend .hpic, #kjOnb .feat .fpic, #kjOnb .count .cpic, #kjOnb .wcard .wpic, #kjOnb .seal-bg{animation:none !important;}
  #kjOnb .scr, #kjOnb .door, #kjOnb .dbrand, #kjOnb .chl, #kjOnb .cta, #kjOnb .dcheck, #kjOnb .world, #kjOnb .wcheck, #kjOnb .sheet, #kjOnb .sheet-scrim,
  #kjOnb .seal-veil, #kjOnb .seal-card, #kjOnb .count .cn, #kjOnb .shoji{transition-duration:.001s !important;}
}
@media (max-height:680px){
  #kjOnb .speek .spk, #kjOnb .speek .spkmore{width:46px; height:46px;}
}
