/* ===== 레이아웃 ===== */
#root{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;
  min-height:100vh;display:flex;flex-direction:column;padding:0 0 84px;}
.topbar{padding:30px 22px 14px;text-align:center;position:relative;}
.theme-toggle{position:absolute;top:26px;right:20px;background:none;border:.5px solid var(--gold-dim);
  color:var(--gold-lt);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:15px;line-height:1;
  transition:border-color .2s;}
.theme-toggle:hover{border-color:var(--gold-lt);}
.brand .kicker{font-family:var(--latin);font-size:24px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold-lt);}
.brand-sub{font-size:13px;color:var(--ivory-dim);letter-spacing:.04em;margin-top:5px;}
#app{flex:1;padding:8px 22px 20px;}

/* 화면 공통 헤더 */
.screen-head{text-align:center;margin:6px 0 24px;}
.screen-head .s-kicker{font-family:var(--latin);font-size:13px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold-lt);}
.screen-head h1{font-weight:500;font-size:23px;margin:8px 0 4px;color:var(--ivory);}
.screen-head .s-sub{font-size:14px;color:var(--ivory-dim);line-height:1.6;}
.screen-head .s-meta{margin-top:14px;font-family:var(--latin);font-size:15px;
  letter-spacing:.2em;color:var(--gold-lt);}
.rule{width:80px;height:1px;margin:16px auto 0;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);}

/* ===== 탭바 ===== */
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--maxw);z-index:20;display:flex;
  background:var(--bar-bg);border-top:1px solid var(--gold-dim);backdrop-filter:blur(8px);}
.tabbar button{flex:1;background:none;border:none;color:var(--ivory-dim);
  font-family:var(--serif);font-size:12px;padding:12px 0 14px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:4px;transition:.2s;}
.tabbar button .tglyph{font-size:18px;line-height:1;}
.tabbar button.active{color:var(--gold-lt);background:#b8945f12;box-shadow:inset 0 2px 0 var(--gold-lt);}

/* ===== 도판 / 카드 ===== */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:18px;}
.plate{position:relative;min-height:240px;border:.5px solid var(--gold-dim);
  border-radius:var(--r-md);background:var(--ink2);cursor:pointer;overflow:hidden;
  transition:border-color .3s,transform .2s;display:flex;flex-direction:column;align-items:center;
  padding:28px 10px 18px;}
.plate:hover{border-color:var(--gold-lt);transform:translateY(-2px);}
.plate .corner{position:absolute;width:6px;height:6px;border:.5px solid var(--gold-dim);opacity:.6;}
.c1{top:5px;left:5px;border-right:0;border-bottom:0;}
.c2{top:5px;right:5px;border-left:0;border-bottom:0;}
.c3{bottom:5px;left:5px;border-right:0;border-top:0;}
.c4{bottom:5px;right:5px;border-left:0;border-top:0;}
.plate .pnum{position:absolute;top:9px;width:100%;text-align:center;
  font-family:var(--latin);font-size:11px;letter-spacing:.2em;color:var(--gold-dim);}
.aperture{width:62%;aspect-ratio:1;border-radius:50%;margin-top:4px;position:relative;
  border:.5px solid var(--gold-dim);}
.aperture::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:.5px solid #b8945f44;}
.glyph{font-size:30px;color:var(--gold-dim);line-height:1;}
.locked .aperture{display:flex;align-items:center;justify-content:center;background:#0c0d18;}
.plate .name{font-family:var(--latin);font-style:italic;font-size:17px;color:var(--ivory);
  margin-top:12px;text-align:center;padding:0 6px;}
.plate .meaning{font-size:11px;letter-spacing:.12em;color:var(--gold-dim);margin-top:3px;}
.plate .given{font-size:12.5px;color:var(--ivory);margin-top:8px;text-align:center;padding:0 8px;line-height:1.45;}
.plate .count-pip{position:absolute;top:8px;right:10px;font-family:var(--latin);font-size:12px;color:var(--gold-lt);}
.sealed-name{margin-top:14px;width:64%;height:11px;border-radius:2px;
  background:repeating-linear-gradient(45deg,#1b1c2a,#1b1c2a 4px,#15161f 4px,#15161f 8px);
  border:.5px solid #2a2b3a;}
.quest{font-size:11px;color:var(--ivory-dim);line-height:1.5;text-align:center;
  padding:10px 12px 0;margin-top:auto;margin-bottom:14px;}
.quest .lead{color:var(--gold);font-family:var(--latin);font-style:italic;
  font-size:13px;letter-spacing:.1em;display:block;margin-bottom:4px;}
.seal-badge{position:absolute;bottom:46px;font-family:var(--latin);font-size:10px;
  letter-spacing:.25em;color:var(--seal);border:.5px solid var(--seal);border-radius:2px;
  padding:1px 7px;text-transform:uppercase;}

/* ===== 모달 ===== */
.scrim{position:fixed;inset:0;z-index:40;background:#05060caa;backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;padding:20px;}
.scrim.on{display:flex;}
.modal{width:min(420px,94vw);background:var(--ink2);border:1px solid var(--gold);
  border-radius:var(--r-md);padding:30px 28px;position:relative;max-height:92vh;overflow:auto;}
.modal .mnum{font-family:var(--latin);font-size:12.5px;letter-spacing:.16em;color:var(--gold-dim);
  text-align:center;text-transform:uppercase;}
.modal h2{font-family:var(--latin);font-style:italic;font-weight:500;font-size:24px;
  text-align:center;color:var(--ivory);margin:6px 0 2px;}
.modal .mmean{text-align:center;font-size:12px;letter-spacing:.12em;color:var(--gold-lt);margin-bottom:4px;}
.modal .mglyph{text-align:center;font-size:40px;color:var(--gold-lt);margin:6px 0;}
.task{font-size:14px;line-height:1.7;text-align:center;color:var(--ivory);margin:6px 0 18px;}
.task .lead{display:block;font-family:var(--latin);font-style:italic;font-size:15px;
  color:var(--gold);letter-spacing:.08em;margin-bottom:6px;}
textarea{width:100%;min-height:108px;background:var(--ink);border:1px solid var(--gold-dim);
  border-radius:var(--r-sm);color:var(--ivory);font-family:var(--serif);font-size:15px;
  line-height:1.7;padding:13px;resize:vertical;outline:none;}
textarea:focus{border-color:var(--gold);}
input.nameInput{width:100%;background:var(--ink);border:1px solid var(--gold-dim);
  border-radius:var(--r-sm);color:var(--ivory);font-family:var(--serif);font-size:15px;
  padding:12px;text-align:center;outline:none;margin-top:4px;}
input.nameInput:focus{border-color:var(--gold);}
.btn{width:100%;margin-top:14px;background:var(--btn-bg);border:1px solid var(--btn-bg);
  color:var(--btn-fg);font-family:var(--serif);font-weight:500;font-size:15px;letter-spacing:.01em;
  padding:13px;border-radius:var(--r-md);cursor:pointer;transition:.18s;}
.btn:hover:not(:disabled){filter:brightness(1.07);}
.btn:active:not(:disabled){transform:scale(.99);}
.btn:disabled{opacity:.4;cursor:default;}
.btn.skip{margin-top:8px;background:transparent;border:.5px solid var(--gold-dim);
  color:var(--ivory-dim);font-weight:400;}
.btn.skip:hover{filter:none;border-color:var(--gold-lt);color:var(--gold-lt);}
.note{font-size:12px;line-height:1.6;color:var(--gold-lt);background:#b8945f12;
  border-left:2px solid var(--gold);padding:10px 12px;border-radius:0 var(--r-sm) var(--r-sm) 0;margin:14px 0 4px;}
.reveal-msg{text-align:center;font-size:13px;line-height:1.7;color:var(--ivory);margin:14px 0;}
.back-entry{font-size:13.5px;line-height:1.8;color:var(--ivory);background:var(--ink);
  border:.5px solid var(--gold-dim);border-radius:var(--r-sm);padding:14px;margin:6px 0;white-space:pre-wrap;}
.func{font-size:12.5px;line-height:1.7;color:var(--gold-lt);font-style:italic;text-align:center;margin:12px 4px 0;}
.mdate{text-align:center;font-family:var(--latin);font-size:12px;letter-spacing:.2em;color:var(--gold-dim);margin-top:14px;}
.fadein{animation:fi .9s ease both;}
@keyframes fi{from{opacity:0;transform:scale(.92);}to{opacity:1;transform:none;}}
.x{position:absolute;top:12px;right:16px;color:var(--ivory-dim);cursor:pointer;
  font-size:20px;line-height:1;background:none;border:none;}
.back{position:absolute;top:10px;left:16px;color:var(--ivory-dim);cursor:pointer;
  font-size:26px;line-height:1;background:none;border:none;}
.back:hover{color:var(--gold-lt);}

/* ===== 토스트 / 뱃지 ===== */
.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%) translateY(20px);
  z-index:60;background:var(--ink3);border:1px solid var(--gold);border-radius:var(--r-md);
  padding:12px 20px;color:var(--gold-lt);font-size:13px;letter-spacing:.05em;
  opacity:0;pointer-events:none;transition:.4s;text-align:center;max-width:90vw;}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0);}
.seal{display:flex;flex-direction:column;align-items:center;gap:8px;}
.seal .medal{width:54px;height:54px;border-radius:50%;border:1px solid var(--gold);
  background:var(--ink2);display:flex;align-items:center;justify-content:center;
  font-size:24px;color:var(--gold-lt);}
.seal .medal.locked{border-color:#2a2b3a;color:#2a2b3a;background:#0c0d18;}
.seal .seal-name{font-family:var(--latin);font-size:12px;letter-spacing:.12em;color:var(--gold);text-align:center;}
.seal .seal-name.locked{color:var(--gold-dim);}

/* ===== 진화 단계 pill ===== */
.stage-pill{display:inline-block;font-family:var(--latin);font-size:12px;letter-spacing:.08em;
  color:var(--gold-lt);border:.5px solid var(--gold-dim);border-radius:999px;padding:3px 12px;}

/* ===== 프리셋 칩(가이드 선택지) ===== */
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px;}
.chip{background:var(--ink);border:.5px solid var(--gold-dim);color:var(--ivory);
  font-family:var(--serif);font-size:14px;line-height:1.3;padding:11px 15px;border-radius:var(--r-md);
  cursor:pointer;transition:border-color .2s,background .2s;}
.chip:hover{border-color:var(--gold-lt);background:#b8945f18;}
.chip-free{color:var(--gold-lt);border-style:dashed;}

/* ===== 감정 온도 게이지 ===== */
.emo-wrap{margin:10px 0 4px;}
.emo-gauge{-webkit-appearance:none;appearance:none;width:100%;height:10px;border-radius:5px;outline:none;
  background:linear-gradient(90deg,#3a5a8a,#5b8bd8,#cfd8e6,#e9dcc3,#e8a85a,#d8554e);cursor:pointer;}
.emo-gauge::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,#fff,#ffe9c2 45%,#b8945f);border:1px solid rgba(255,255,255,.6);
  cursor:pointer;box-shadow:0 0 10px rgba(255,206,122,.6);}
.emo-gauge::-moz-range-thumb{width:24px;height:24px;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,#fff,#ffe9c2 45%,#b8945f);border:1px solid #b8945f;cursor:pointer;}
.emo-word{text-align:center;font-family:var(--latin);font-style:italic;font-size:22px;color:var(--ivory);margin-top:14px;}
.emo-temp{text-align:center;font-size:12px;color:var(--gold-lt);letter-spacing:.12em;margin-top:2px;}

/* ===== 감정 사분면 ===== */
.emo-pad{position:relative;width:100%;max-width:240px;aspect-ratio:1;margin:12px auto 0;border-radius:var(--r-md);
  border:.5px solid var(--gold-dim);cursor:crosshair;touch-action:none;
  background:
    radial-gradient(circle at 0% 0%, rgba(216,85,78,.5), transparent 68%),
    radial-gradient(circle at 100% 0%, rgba(232,168,86,.5), transparent 68%),
    radial-gradient(circle at 0% 100%, rgba(91,139,216,.5), transparent 68%),
    radial-gradient(circle at 100% 100%, rgba(63,191,168,.5), transparent 68%),
    #0c0d18;}
.emo-pad .lab{position:absolute;font-size:11px;color:#e9dcc3;opacity:.85;pointer-events:none;}
.emo-pad .lab.tl{top:8px;left:10px;} .emo-pad .lab.tr{top:8px;right:10px;}
.emo-pad .lab.bl{bottom:8px;left:10px;} .emo-pad .lab.br{bottom:8px;right:10px;}
.emo-thumb{position:absolute;width:24px;height:24px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;
  background:radial-gradient(circle at 50% 45%,#fff,#ffe9c2 45%,#b8945f);border:1px solid rgba(255,255,255,.7);
  box-shadow:0 0 10px rgba(255,206,122,.6);}

/* ===== 빈 상태 ===== */
.empty{text-align:center;color:var(--ivory-dim);font-size:14px;line-height:1.85;padding:40px 20px;}
.muted{color:var(--ivory-dim);} .center{text-align:center;}
