/* ============================================================
   style.css — Two of Us (redesigned)
   ============================================================ */
:root{
  --bg:#efe9df; --panel:#fbf8f2; --ink:#332f28; --dim:#9a9082;
  --accent:#8a7458; --accent2:#c2b39a; --line:#e4dccd;
  --radius:14px; --shadow:0 2px 10px rgba(60,50,35,.07);
  --font-display:'Gowun Batang',serif;
  --font-body:'IBM Plex Sans KR',sans-serif;
  --maxw:1080px;
  --bg-image:none; --bg-size:cover; --bg-blur:0px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background-image:var(--bg-image);background-size:var(--bg-size);background-position:center;filter:blur(var(--bg-blur));opacity:.5;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,textarea,select{font-family:inherit;color:inherit;}
img{display:block;max-width:100%;}
.serif{font-family:var(--font-display);}

/* ---------- LOCK SCREEN ---------- */
#lock{position:fixed;inset:0;z-index:1000;cursor:pointer;display:flex;align-items:flex-end;justify-content:center;background:#1a1712;transition:opacity .6s ease;}
#lock.unlocking{opacity:0;pointer-events:none;}
/* 배경 이미지 레이어 */
#lockBg{position:absolute;inset:0;background-size:cover;background-position:center;transition:filter .6s ease,transform .6s ease;}
#lock.dimmed #lockBg{filter:brightness(.25) blur(18px);transform:scale(1.04);}
/* 배경 없을 때 그라디언트 */
#lockBg:not([style*="url"]){background:linear-gradient(135deg,#1a1712 0%,#2c2520 50%,#1a1712 100%);}
/* 힌트 텍스트 */
.lock-hint{position:relative;z-index:2;text-align:center;color:#f3ede1;padding-bottom:12vh;text-shadow:0 2px 20px rgba(0,0,0,.8);transition:opacity .4s;}
#lock.dimmed .lock-hint{opacity:0;}
.lock-hint .lock-title{font-family:var(--font-display);font-size:clamp(2rem,6vw,3.4rem);font-weight:700;letter-spacing:.02em;}
.lock-hint .lock-sub{margin-top:8px;font-size:.95rem;opacity:.85;letter-spacing:.18em;}
.lock-hint .lock-tap{margin-top:30px;font-size:.82rem;opacity:.6;letter-spacing:.2em;animation:breathe 2.6s ease-in-out infinite;}
@keyframes breathe{0%,100%{opacity:.3;}50%{opacity:.75;}}
#lockForm{position:absolute;z-index:3;left:50%;bottom:-40%;transform:translateX(-50%);width:min(360px,90vw);background:rgba(251,248,242,.96);backdrop-filter:blur(8px);border-radius:18px;padding:30px 26px;box-shadow:0 20px 60px rgba(0,0,0,.45);transition:bottom .45s cubic-bezier(.2,.8,.2,1);text-align:center;}
#lock.dimmed #lockForm{bottom:30%;}
#lockForm .lf-portrait{width:74px;height:74px;border-radius:50%;margin:0 auto 14px;background-size:cover;background-position:center;background-color:var(--accent2);border:3px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.2);}
#lockForm h2{font-family:var(--font-display);font-size:1.2rem;margin-bottom:4px;}
#lockForm p.note{font-size:.82rem;color:var(--dim);margin-bottom:18px;}
#lockForm input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:16px;text-align:center;}
#lockForm input:focus{outline:none;border-color:var(--accent);}
#lockForm button{width:100%;margin-top:14px;padding:12px;border-radius:10px;background:var(--accent);color:#fff;font-weight:600;font-size:.97rem;}
#lockForm .err{min-height:1.1em;margin-top:10px;font-size:.84rem;color:#b4524a;}
#lockForm .lf-cancel{margin-top:10px;font-size:.8rem;color:var(--dim);background:none;}

/* ---------- APP SHELL ---------- */
#app{display:none;min-height:100vh;}
#app.show{display:block;}
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;padding:13px 18px;background:color-mix(in srgb,var(--bg) 84%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.hamburger{font-size:1.4rem;line-height:1;padding:6px 9px;border-radius:9px;transition:background .15s;}
.hamburger:hover{background:color-mix(in srgb,var(--accent) 9%,transparent);}
.topbar .where{font-family:var(--font-display);font-weight:700;font-size:1.05rem;flex:1;letter-spacing:.01em;}
.topbar .t-btn{font-size:.85rem;color:var(--dim);padding:7px 11px;border-radius:8px;transition:color .15s,background .15s;}
.topbar .t-btn:hover{color:var(--ink);background:color-mix(in srgb,var(--accent) 8%,transparent);}
.topbar .t-btn.on{color:var(--accent);font-weight:600;}

#drawerScrim{position:fixed;inset:0;z-index:49;background:rgba(20,16,12,.34);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .25s;}
#drawerScrim.show{opacity:1;pointer-events:auto;}
#drawer{position:fixed;top:0;left:0;bottom:0;z-index:50;width:min(290px,82vw);background:var(--panel);border-right:1px solid var(--line);box-shadow:0 0 50px rgba(0,0,0,.16);transform:translateX(-100%);transition:transform .28s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;padding:22px 0;overflow-y:auto;}
#drawer.open{transform:translateX(0);}
.drawer-head{padding:6px 24px 18px;border-bottom:1px solid var(--line);margin-bottom:10px;}
.drawer-head .dh-title{font-family:var(--font-display);font-weight:700;font-size:1.3rem;}
.drawer-head .dh-sub{font-size:.8rem;color:var(--dim);margin-top:3px;letter-spacing:.12em;}
.nav-item{display:flex;align-items:center;gap:13px;padding:13px 24px;font-size:.98rem;color:var(--dim);transition:color .15s,background .15s;position:relative;text-align:left;width:100%;}
.nav-item .ni-icon{width:22px;text-align:center;font-size:1.05rem;flex:none;}
.nav-item:hover{color:var(--ink);background:color-mix(in srgb,var(--accent) 5%,transparent);}
.nav-item.active{color:var(--ink);font-weight:600;background:color-mix(in srgb,var(--accent) 9%,transparent);}
.nav-item.active::before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;background:var(--accent);border-radius:0 3px 3px 0;}
.drawer-foot{margin-top:auto;padding:16px 24px 4px;border-top:1px solid var(--line);}
.drawer-foot button{font-size:.84rem;color:var(--dim);padding:6px 0;display:block;}

main{max-width:var(--maxw);margin:0 auto;padding:34px 22px 110px;}
.page{display:none;animation:rise .3s ease both;}
.page.active{display:block;}
@keyframes rise{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.page-title{font-family:var(--font-display);font-weight:700;font-size:1.7rem;margin-bottom:6px;}
.page-lead{color:var(--dim);font-size:.92rem;margin-bottom:26px;}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);}
.card + .card{margin-top:20px;}
.placeholder-note{border:1px dashed var(--line);border-radius:var(--radius);padding:40px 26px;text-align:center;color:var(--dim);background:color-mix(in srgb,var(--accent) 3%,transparent);font-size:.9rem;line-height:1.8;}
.placeholder-note b{color:var(--ink);font-weight:600;display:block;margin-bottom:6px;font-family:var(--font-display);font-size:1.05rem;}
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border:1px solid var(--line);border-radius:10px;background:var(--panel);font-size:.9rem;transition:border-color .15s,background .15s;}
.btn:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--line));}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.edit-only{display:none;}
body.editing .edit-only{display:inline-flex;}
body.editing .edit-only.block{display:block;}

/* ---------- HOUSE ---------- */
.house-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.house-stage-wrap{position:relative;width:100%;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:color-mix(in srgb,var(--accent) 6%,var(--panel));box-shadow:var(--shadow);}
.house-stage{position:relative;width:100%;aspect-ratio:16/10;background-size:cover;background-position:center;user-select:none;}
.house-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--dim);text-align:center;padding:20px;}
body.house-place .house-stage{cursor:crosshair;}

/* ---------- 분위기(시간대/날씨) 오버레이 ---------- */
.house-stage::after{content:"";position:absolute;inset:0;z-index:5;pointer-events:none;mix-blend-mode:multiply;opacity:0;transition:background 2s ease,opacity 2s ease;}
.house-stage.amb-morning::after{background:linear-gradient(180deg,rgba(255,228,180,.35),rgba(255,200,150,.12));opacity:1;}
.house-stage.amb-day::after{background:rgba(255,250,235,.05);opacity:1;}
.house-stage.amb-evening::after{background:linear-gradient(180deg,rgba(255,150,90,.30),rgba(120,70,110,.30));opacity:1;}
.house-stage.amb-night::after{background:linear-gradient(180deg,rgba(20,30,70,.45),rgba(10,12,35,.55));opacity:1;}
.house-stage.amb-cloudy::after{background:rgba(120,125,135,.28);opacity:1;}
.house-stage.amb-rain::after{background:rgba(60,80,110,.32);opacity:1;}
.house-stage.amb-snow::after{background:rgba(210,225,245,.22);opacity:1;}

/* 날씨 효과는 사용자가 날씨별 배경 이미지로 직접 처리 (CSS 파티클 없음) */
.house-svg{position:absolute;inset:0;width:100%;height:100%;z-index:3;pointer-events:none;}
.house-svg .floor-poly{fill:color-mix(in srgb,var(--accent) 14%,transparent);stroke:var(--accent);stroke-width:1.5;stroke-dasharray:5 4;opacity:0;transition:opacity .2s;}
body.editing .house-svg .floor-poly{opacity:.5;}
.house-svg .room-poly{fill:color-mix(in srgb,#5f9ec0 16%,transparent);stroke:#5f9ec0;stroke-width:1.5;opacity:0;transition:opacity .2s;}
body.editing .house-svg .room-poly{opacity:.45;}
.house-svg .draft-poly{fill:color-mix(in srgb,var(--accent) 20%,transparent);stroke:var(--accent);stroke-width:2;}
.house-svg .draft-pt{fill:#fff;stroke:var(--accent);stroke-width:2;}
.room-label{position:absolute;transform:translate(-50%,-50%);z-index:4;font-size:.74rem;color:#fff;background:rgba(60,50,35,.6);padding:2px 8px;border-radius:10px;pointer-events:none;opacity:0;transition:opacity .2s;}
body.editing .room-label{opacity:1;}

/* dot character */
.dot-char{position:absolute;transform:translate(-50%,-100%);z-index:8;cursor:pointer;will-change:left,top;}
.dot-char .dot-sprite{width:var(--dot-size,68px);height:var(--dot-size,68px);background-size:contain;background-repeat:no-repeat;background-position:center bottom;image-rendering:pixelated;}
.dot-char .dot-ph{width:54px;height:54px;border-radius:50%;background:color-mix(in srgb,var(--accent) 30%,var(--panel));border:2px solid #fff;box-shadow:0 3px 8px rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--ink);}

/* doors */
.door{position:absolute;transform:translate(-50%,-50%);z-index:6;cursor:pointer;width:var(--door-size,56px);height:var(--door-size,56px);display:flex;align-items:center;justify-content:center;}
.door img{width:100%;height:100%;object-fit:contain;}
.door .door-ph{width:28px;height:44px;border-radius:3px;border:2px solid var(--accent);background:color-mix(in srgb,var(--accent) 22%,var(--panel));transition:transform .3s,background .3s;transform-origin:left center;}
.door.open .door-ph{transform:perspective(60px) rotateY(-58deg);background:color-mix(in srgb,var(--accent) 8%,var(--panel));}
.door .door-del{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;background:#b4524a;color:#fff;font-size:.7rem;display:none;align-items:center;justify-content:center;z-index:2;}
body.editing .door:hover .door-del{display:flex;}
body.editing .door{cursor:grab;}
body.editing .door.dragging,body.editing .hotspot.dragging,body.editing .dot-char.dragging{cursor:grabbing;z-index:20;}
body.house-place .dot-char,body.house-place .door,body.house-place .room-label,body.house-place .hotspot{pointer-events:none;}

/* hotspot — 보기 모드에선 투명한 클릭 영역, 편집 모드에선 표시 */
.hotspot{position:absolute;transform:translate(-50%,-50%);z-index:6;width:40px;height:40px;display:flex;align-items:center;justify-content:center;}
.hotspot .hs-dot{width:18px;height:18px;border-radius:50%;background:color-mix(in srgb,#c9a96a 70%,transparent);border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.3);opacity:0;transition:opacity .2s;}
body.editing .hotspot{cursor:grab;}
body.editing .hotspot .hs-dot{opacity:1;}
.hotspot .hs-del{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;background:#b4524a;color:#fff;font-size:.7rem;display:none;align-items:center;justify-content:center;z-index:2;}
body.editing .hotspot:hover .hs-del{display:flex;}
body.editing .dot-char{cursor:grab;}

/* speech bubble */
.speech{position:absolute;transform:translate(-50%,calc(-100% - 6px));z-index:12;background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:8px 13px;font-size:.86rem;width:max-content;max-width:200px;box-shadow:var(--shadow);pointer-events:none;opacity:0;transition:opacity .2s;white-space:normal;word-break:keep-all;overflow-wrap:break-word;line-height:1.4;text-align:center;}
.speech.show{opacity:1;}
.speech::after{content:"";position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:var(--panel);border-bottom:0;}
/* 캐릭터에 붙는 말풍선: 캐릭터(발끝 기준) 위 중앙에 떠서 함께 움직임 */
.dot-char .char-speech{left:50%;top:-8px;bottom:auto;}
.dot-char:not(.dragging){cursor:pointer;}
.dot-char.dragging{cursor:grabbing;z-index:20;}
/* 쓰다듬기/붙이기 이모지 */
.char-emoji{position:absolute;left:50%;top:-18px;transform:translateX(-50%);z-index:15;font-size:1.4rem;pointer-events:none;animation:emojiFloat 1.4s ease-out forwards;}
@keyframes emojiFloat{
  0%{opacity:0;transform:translate(-50%,4px) scale(.6);}
  20%{opacity:1;transform:translate(-50%,-6px) scale(1.1);}
  100%{opacity:0;transform:translate(-50%,-40px) scale(1);}
}

.draw-banner{display:none;align-items:center;gap:12px;padding:11px 15px;border-radius:10px;margin-bottom:12px;background:color-mix(in srgb,var(--accent) 12%,var(--panel));border:1px solid var(--accent);font-size:.88rem;}
body.house-draw .draw-banner{display:flex;}
.draw-banner .db-spacer{flex:1;}

/* house editor — 아코디언 기반 */
.house-editor{margin-top:18px;display:flex;flex-direction:column;gap:0;}

/* 탭 바 */
.he-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;position:sticky;top:54px;z-index:30;background:var(--bg);padding:8px 0;}
.he-tab-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line);border-radius:20px;background:var(--panel);font-size:.9rem;color:var(--dim);transition:all .15s;white-space:nowrap;}
.he-tab-btn:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--line));color:var(--ink);}
.he-tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;}
.he-tab-badge{font-size:.7rem;padding:1px 7px;border-radius:10px;background:color-mix(in srgb,var(--ink) 10%,transparent);color:inherit;}
.he-tab-btn.active .he-tab-badge{background:rgba(255,255,255,.25);}

/* 탭 모드: 선택 안 된 섹션은 숨기고, 열린 섹션 제목(summary)도 숨김 */
.he-acc{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);overflow:hidden;}
.he-acc:not([open]){display:none;}
.he-acc>summary{display:none;}
.he-badge{font-family:var(--font-body);font-weight:500;font-size:.74rem;color:var(--dim);background:color-mix(in srgb,var(--accent) 10%,transparent);padding:2px 9px;border-radius:20px;}
.he-body{padding:18px;}
.he-hint{font-size:.82rem;color:var(--dim);margin:0 0 10px;line-height:1.6;}
.he-hint.inline{display:inline;margin:0;}
.he-hint .warn{color:#b4524a;}
.he-sub{font-size:.84rem;color:var(--dim);margin:16px 0 8px;font-weight:600;}
.he-btns{display:flex;gap:7px;flex-wrap:wrap;}

/* 카드(방/문/핫스팟/상호작용 항목) */
.he-card{border:1px solid var(--line);border-radius:11px;padding:12px 14px;background:var(--bg);}
.he-card + .he-card{margin-top:8px;}
.he-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.he-card-head b{font-size:.92rem;}

/* 라벨+컨트롤 한 줄 필드 */
.he-field{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.he-field>label{flex:none;width:74px;font-size:.82rem;color:var(--dim);}
.he-field>input[type=text],.he-field>input:not([type]),.he-field>input[type=range],.he-field>select{flex:1;min-width:0;}
.he-field input:not([type=range]),.he-field select{padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--panel);font-size:.9rem;}
.he-field input[type=range]{accent-color:var(--accent);}

.he-list{display:flex;flex-direction:column;gap:6px;}
.he-line{display:flex;gap:6px;align-items:center;}
.he-line input{flex:1;min-width:0;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:.9rem;}

/* 삭제(×) 버튼 통일 */
.x-btn{flex:none;width:24px;height:24px;border-radius:7px;background:color-mix(in srgb,#b4524a 12%,transparent);color:#b4524a;font-size:.9rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.x-btn:hover{background:color-mix(in srgb,#b4524a 24%,transparent);}
.x-btn.sm{width:18px;height:18px;font-size:.7rem;border-radius:50%;}
.btn.danger{color:#b4524a;border-color:color-mix(in srgb,#b4524a 30%,var(--line));}
.btn.danger:hover{background:color-mix(in srgb,#b4524a 8%,transparent);}

/* 이미지 선택 picker */
.he-imgrow{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start;}
.he-pick{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;width:64px;height:64px;border:1.5px dashed var(--line);border-radius:10px;background:var(--bg);font-size:.7rem;color:var(--dim);overflow:hidden;transition:border-color .15s,background .15s;}
.he-pick:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent);}
.he-pick .plus{font-size:1.2rem;color:var(--accent);line-height:1;}
.he-pick.filled{border-style:solid;padding:0;position:relative;}
.he-pick.filled img{width:100%;height:100%;object-fit:contain;}
.he-pick.filled span{position:absolute;bottom:0;left:0;right:0;background:rgba(20,16,12,.55);color:#fff;font-size:.62rem;padding:2px 0;}
.he-frame{position:relative;display:inline-block;width:64px;height:64px;}
.he-frame img{width:100%;height:100%;object-fit:contain;border:1px solid var(--line);border-radius:10px;background:var(--bg);}
.he-frame .x-btn{position:absolute;top:-6px;right:-6px;background:#b4524a;color:#fff;}
.he-action{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;}
.he-action-name{flex:none;width:70px;font-size:.84rem;color:var(--dim);padding-top:6px;}
.he-val{flex:none;min-width:38px;text-align:right;font-size:.82rem;color:var(--accent);font-variant-numeric:tabular-nums;}
.he-check{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer;margin-bottom:4px;}
.he-check input{width:16px;height:16px;accent-color:var(--accent);}

/* ---------- DECO PANEL ---------- */
#deco{position:fixed;top:0;right:0;bottom:0;z-index:60;width:min(340px,90vw);background:var(--panel);border-left:1px solid var(--line);box-shadow:0 0 50px rgba(0,0,0,.16);transform:translateX(100%);transition:transform .28s cubic-bezier(.2,.8,.2,1);overflow-y:auto;padding:24px;}
#deco.open{transform:translateX(0);}
#decoScrim{position:fixed;inset:0;z-index:59;background:rgba(20,16,12,.3);opacity:0;pointer-events:none;transition:opacity .25s;}
#decoScrim.show{opacity:1;pointer-events:auto;}
#deco h3{font-family:var(--font-display);font-size:1.2rem;margin-bottom:4px;}
#deco .deco-sub{font-size:.8rem;color:var(--dim);margin-bottom:20px;}
.deco-group{margin-bottom:22px;}
.deco-group .dg-label{font-size:.8rem;color:var(--dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;}
.swatches{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.swatch{aspect-ratio:1;border-radius:10px;border:2px solid transparent;cursor:pointer;position:relative;overflow:hidden;}
.swatch span{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;font-size:.62rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);padding-bottom:4px;}
.deco-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;}
.deco-row label{font-size:.88rem;}
.deco-row input[type=color]{width:42px;height:30px;border:1px solid var(--line);border-radius:7px;background:none;cursor:pointer;}
.deco-row input[type=range]{flex:1;}
.font-opt{display:flex;gap:8px;flex-wrap:wrap;}
.font-opt button{padding:8px 12px;border:1px solid var(--line);border-radius:9px;font-size:.86rem;}
.font-opt button.sel{border-color:var(--accent);color:var(--accent);font-weight:600;}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:200;background:var(--ink);color:var(--bg);padding:11px 20px;border-radius:30px;font-size:.88rem;opacity:0;pointer-events:none;transition:.3s;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

@media(max-width:640px){
  main{padding:24px 16px 100px;}
  .page-title{font-size:1.45rem;}
  .card{padding:20px;}
  input,textarea,select{font-size:16px;}
}
@media(prefers-reduced-motion:reduce){.page{animation:none;}}

/* ---------- profile page ---------- */
.pf-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.pf-tab{padding:7px 16px;border:1px solid var(--line);border-radius:999px;background:var(--panel);font-size:.86rem;color:var(--dim);transition:border-color .15s,background .15s,color .15s;}
.pf-tab:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--line));color:var(--ink);}
.pf-tab.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;}
.pf-tab.add{border-style:dashed;color:var(--accent);}
.pf-tabedit{display:flex;gap:8px;align-items:center;margin-bottom:18px;}
.pf-tabedit input{flex:1;min-width:0;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:var(--panel);font-size:.92rem;}
.btn.danger{border-color:color-mix(in srgb,#b4524a 40%,var(--line));color:#b4524a;}
.btn.danger:hover{background:color-mix(in srgb,#b4524a 10%,transparent);border-color:#b4524a;}

.pf-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));align-items:start;}
.pf-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px 22px;box-shadow:var(--shadow);overflow:hidden;}
.pf-card::before{content:"";position:absolute;left:0;right:0;top:0;height:62px;background:linear-gradient(color-mix(in srgb,var(--accent) 16%,transparent),color-mix(in srgb,var(--accent) 4%,transparent));}
.pf-portrait{position:relative;width:116px;height:116px;border-radius:50%;margin:6px auto 12px;background:var(--line) center/cover no-repeat;border:4px solid var(--panel);box-shadow:0 4px 16px rgba(0,0,0,.14),0 0 0 1px var(--line);display:flex;align-items:center;justify-content:center;}
.pf-portrait span{opacity:.5;font-size:.82rem;color:var(--ink);}
.pf-portrait.editable{cursor:pointer;transition:box-shadow .15s;}
.pf-portrait.editable:hover{box-shadow:0 4px 16px rgba(0,0,0,.18),0 0 0 2px var(--accent);}
.pf-name{position:relative;text-align:center;font-size:1.3rem;font-weight:700;margin-bottom:3px;}
.pf-tag{text-align:center;color:var(--accent);font-size:.9rem;font-style:italic;margin-bottom:14px;}
.pf-say{position:relative;margin:0 0 16px;padding:11px 15px;background:color-mix(in srgb,var(--accent) 9%,var(--panel));border:1px solid color-mix(in srgb,var(--accent) 22%,var(--line));border-radius:14px;font-size:.9rem;line-height:1.5;color:var(--ink);}
.pf-say::after{content:"";position:absolute;bottom:-8px;width:0;height:0;border:8px solid transparent;border-top-color:color-mix(in srgb,var(--accent) 9%,var(--panel));border-bottom:0;}
.pf-card.left .pf-say::after{right:28px;}
.pf-card.right .pf-say::after{left:28px;}
.pf-fields{display:grid;grid-template-columns:auto 1fr;gap:7px 14px;margin:0;}
.pf-fields dt{color:var(--dim);font-size:.84rem;white-space:nowrap;}
.pf-fields dd{margin:0;font-size:.9rem;}

/* ---------- 날씨 버튼 (house view) ---------- */
.amb-btn{position:absolute;top:12px;right:12px;z-index:14;width:42px;height:42px;border-radius:50%;font-size:1.2rem;line-height:1;background:color-mix(in srgb,var(--panel) 90%,transparent);backdrop-filter:blur(6px);border:1px solid var(--line);box-shadow:var(--shadow);transition:transform .15s,background .15s;}
.amb-btn:hover{transform:scale(1.08);background:var(--panel);}

/* ---------- 정보 모달 (캐릭터 상태 / 날씨) ---------- */
.info-modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;background:rgba(20,16,12,.5);backdrop-filter:blur(3px);padding:24px;}
.info-modal.show{display:flex;animation:fadeIn .2s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.im-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px 28px;width:min(320px,90vw);box-shadow:0 20px 60px rgba(0,0,0,.35);text-align:center;animation:rise .25s ease both;}
.im-x{position:absolute;top:12px;right:14px;width:28px;height:28px;border-radius:50%;color:var(--dim);font-size:1.1rem;line-height:1;transition:background .15s;}
.im-x:hover{background:color-mix(in srgb,var(--accent) 10%,transparent);color:var(--ink);}
.im-face{width:96px;height:96px;margin:0 auto 12px;border-radius:50%;background-size:contain;background-repeat:no-repeat;background-position:center bottom;background-color:color-mix(in srgb,var(--accent) 14%,var(--panel));border:2px solid var(--line);image-rendering:pixelated;}
.im-name{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin-bottom:16px;}
.im-bars{display:flex;flex-direction:column;gap:10px;}
.im-bar{display:flex;align-items:center;gap:10px;}
.im-lab{flex:none;width:34px;font-size:.82rem;color:var(--dim);text-align:left;}
.im-track{flex:1;height:9px;border-radius:5px;background:color-mix(in srgb,var(--accent) 12%,var(--line));overflow:hidden;}
.im-fill{height:100%;border-radius:5px;transition:width .5s ease;}
.im-val{flex:none;width:28px;text-align:right;font-size:.8rem;color:var(--dim);font-variant-numeric:tabular-nums;}
/* 날씨 모달 */
.im-card.amb .im-weather-icon{font-size:3.4rem;line-height:1;margin-bottom:6px;}
.im-card.amb .im-weather-name{font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-bottom:18px;}
.im-rows{display:flex;flex-direction:column;gap:10px;}
.im-row{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;padding:8px 12px;background:var(--bg);border-radius:10px;}
.im-row span{color:var(--dim);}
.im-row b{font-weight:600;}

/* gauge effect input row */
.he-field.gauge-eff{flex-wrap:wrap;}
.he-field.gauge-eff input[type=number]{padding:6px 8px;border:1px solid var(--line);border-radius:7px;background:var(--bg);font-size:.86rem;}

/* ---------- 로그인 / 커플 / 초대 모달 ---------- */
#lockForm,#coupleForm,#inviteForm{
  position:absolute;z-index:3;left:50%;bottom:-40%;
  transform:translateX(-50%);
  width:min(360px,90vw);
  background:rgba(251,248,242,.96);
  backdrop-filter:blur(8px);
  border-radius:18px;padding:30px 26px;
  box-shadow:0 20px 60px rgba(0,0,0,.45);
  transition:bottom .45s cubic-bezier(.2,.8,.2,1);
  text-align:center;display:none;
}
#lock.dimmed #lockForm,
#lock.dimmed #coupleForm,
#lock.dimmed #inviteForm{ bottom:30%; }
#lockForm input[type=email],
#lockForm input[type=password]{
  width:100%;padding:12px 14px;margin-top:10px;
  border:1px solid var(--line);border-radius:10px;
  background:#fff;font-size:16px;text-align:center;
}
#lockForm input:focus,#coupleForm input:focus{ outline:none;border-color:var(--accent); }
#lockForm button[type=submit],
#createCoupleBtn{ width:100%;margin-top:14px;padding:12px;border-radius:10px;background:var(--accent);color:#fff;font-weight:600;font-size:.97rem; }
.auth-switch{ margin-top:12px;font-size:.84rem;color:var(--dim); }
.auth-switch a{ color:var(--accent);text-decoration:none;font-weight:600; }
#coupleForm h2,#inviteForm h2{ font-family:var(--font-display);font-size:1.2rem;margin-bottom:4px; }
#coupleForm .note,#inviteForm .note{ font-size:.82rem;color:var(--dim);margin-bottom:18px; }
.couple-or{ font-size:.8rem;color:var(--dim);margin:14px 0 10px;position:relative; }
.couple-or::before,.couple-or::after{ content:'';position:absolute;top:50%;width:38%;height:1px;background:var(--line); }
.couple-or::before{left:0;} .couple-or::after{right:0;}
#joinCode{ width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:20px;text-align:center;letter-spacing:.3em;font-weight:700; }
.invite-code{ font-size:2.2rem;font-weight:700;font-family:var(--font-display);letter-spacing:.25em;color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);border-radius:12px;padding:14px 20px;margin:10px 0; }

/* ============================================================
   gauge HUD
   ============================================================ */
.gauge-hud{position:absolute;top:10px;right:10px;z-index:14;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.gh-char{background:color-mix(in srgb,var(--panel) 88%,transparent);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:10px;padding:8px 10px;min-width:124px;box-shadow:var(--shadow);}
.gh-name{font-size:.74rem;font-weight:600;color:var(--ink);margin-bottom:5px;}
.gh-bar{display:flex;align-items:center;gap:6px;margin-bottom:3px;}
.gh-bar:last-child{margin-bottom:0;}
.gh-lab{font-size:.66rem;color:var(--dim);width:24px;flex:none;}
.gh-track{flex:1;height:6px;border-radius:3px;background:color-mix(in srgb,var(--accent) 12%,var(--line));overflow:hidden;}
.gh-fill{height:100%;border-radius:3px;transition:width .5s ease;}
.gh-bar.mood   .gh-fill{background:#e0915f;}
.gh-bar.energy .gh-fill{background:#6f9e6a;}
.gh-bar.aff    .gh-fill{background:#c96f8c;}
.he-field.gauge-eff{flex-wrap:wrap;}
.he-field.gauge-eff input[type=number]{padding:6px 8px;border:1px solid var(--line);border-radius:7px;background:var(--bg);font-size:.86rem;}

/* ============================================================
   타임라인 — 세로 중앙선 좌우 교대형
   ============================================================ */
:root{
  --tl-a: var(--accent);
  --tl-b: color-mix(in srgb,var(--accent) 55%,#4ab8e8);
  --tl-both: color-mix(in srgb,var(--accent) 40%,var(--ink));
  --tl-alt: #9b6ee8;
  --tl-oc: #4ac98a;
  --tl-note: #9a9082;
}
.tl-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;}
.tl-tab{padding:6px 14px;border:1px solid var(--line);border-radius:20px;background:var(--panel);font-size:.84rem;color:var(--dim);transition:all .14s;}
.tl-tab:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--line));color:var(--ink);}
.tl-tab.on{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;}
.tl-add-bar{margin-bottom:20px;}
.tl-empty{text-align:center;padding:56px 0;color:var(--dim);}

/* 범례 */
.tl-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:18px;}
.tl-legend-item{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--dim);}
.tl-legend-dot{width:10px;height:10px;border-radius:50%;flex:none;}

/* 세로 타임라인 컨테이너 */
.tl-vertical{
  position:relative;
  padding:24px 0 40px;
}

/* 중앙 세로선 */
.tl-vline{
  position:absolute;
  left:50%; top:0; bottom:0;
  width:2px;
  background:var(--line);
  transform:translateX(-50%);
  border-radius:1px;
}

/* 각 이벤트 행 */
.tl-vitem{
  position:relative;
  display:flex;
  align-items:flex-start;
  margin-bottom:40px;
  min-height:32px;
}

/* 좌측 카드: 카드가 왼쪽, 점이 오른쪽 중앙 */
.tl-vitem-left{
  flex-direction:row;
  justify-content:flex-end;
  padding-right:calc(50% + 28px);
}
/* 우측 카드: 점이 왼쪽 중앙, 카드가 오른쪽 */
.tl-vitem-right{
  flex-direction:row;
  padding-left:calc(50% + 28px);
}

/* 중앙 점 */
.tl-vdot{
  position:absolute;
  left:50%; top:18px;
  width:14px; height:14px;
  border-radius:50%;
  transform:translateX(-50%);
  z-index:2;
  flex:none;
  transition:transform .15s;
}
.tl-vitem:hover .tl-vdot{transform:translateX(-50%) scale(1.25);}

/* 카드 */
.tl-vcard{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px 16px;
  box-shadow:var(--shadow);
  max-width:320px;
  width:100%;
  border-top:3px solid var(--card-col,var(--accent));
  animation:tlVIn .28s ease both;
  position:relative;
}
@keyframes tlVIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* 연결선: 카드에서 중앙 점까지 */
.tl-vitem-left .tl-vcard::after{
  content:'';position:absolute;
  top:22px; right:-28px;
  width:28px; height:1px;
  background:var(--line);
}
.tl-vitem-right .tl-vcard::before{
  content:'';position:absolute;
  top:22px; left:-28px;
  width:28px; height:1px;
  background:var(--line);
}

.tl-vcard-img{
  width:100%; height:100px;
  border-radius:8px;
  background-size:cover; background-position:center;
  margin-bottom:10px;
}
.tl-vcard-date{
  font-size:.76rem; font-weight:700;
  color:var(--card-col,var(--accent));
  letter-spacing:.04em;
  margin-bottom:5px;
  text-transform:uppercase;
}
.tl-vcard-label{
  font-family:var(--font-display);
  font-weight:700; font-size:.98rem;
  color:var(--ink); margin-bottom:5px;
  word-break:keep-all;
}
.tl-vcard-body{
  font-size:.82rem; line-height:1.65; color:var(--dim);
  word-break:keep-all; overflow-wrap:break-word;
  white-space:pre-wrap;
}
.tl-vcard-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;}
.tl-tag{padding:2px 7px;border-radius:20px;font-size:.72rem;background:color-mix(in srgb,var(--ink) 7%,transparent);color:var(--dim);}
.tl-vcard-au{
  display:inline-block;margin-top:7px;
  font-size:.72rem;color:var(--tl-alt);
  background:color-mix(in srgb,var(--tl-alt) 10%,transparent);
  padding:2px 8px;border-radius:20px;
}
.tl-vcard-edit-toggle{
  display:inline-block; margin-top:10px;
  font-size:.75rem; color:var(--dim);
  cursor:pointer; padding:3px 8px;
  border:1px solid var(--line); border-radius:7px;
  transition:border-color .13s, color .13s;
}
.tl-vcard-edit-toggle:hover{border-color:var(--accent);color:var(--accent);}

/* 편집 패널 */
.tl-edit-panel{
  margin-top:32px; padding-top:22px;
  border-top:1px solid var(--line);
  display:flex; flex-direction:column; gap:10px;
}
.tl-edit-panel-title{
  font-size:.78rem; font-weight:700; color:var(--dim);
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:4px;
}
.tl-edit-card{
  background:var(--panel); border:1px solid var(--line);
  border-radius:var(--radius); padding:14px 16px;
  display:flex; flex-direction:column; gap:6px;
}
.tl-edit-row{display:flex;gap:7px;align-items:center;flex-wrap:wrap;}
.tl-inp{padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:.88rem;color:var(--ink);}
.tl-inp:focus{outline:none;border-color:var(--accent);}
.tl-sel{padding:7px 8px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:.85rem;color:var(--ink);}
.tl-ta{width:100%;min-height:60px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:.88rem;color:var(--ink);resize:vertical;font-family:var(--font-body);line-height:1.6;}
.tl-ta:focus{outline:none;border-color:var(--accent);}
.tl-imgrow{display:flex;gap:7px;flex-wrap:wrap;}

/* 모바일: 단일 컬럼 */
@media(max-width:600px){
  .tl-vline{left:22px;}
  .tl-vitem-left,.tl-vitem-right{
    padding-left:50px; padding-right:0;
    flex-direction:row;
    justify-content:flex-start;
  }
  .tl-vdot{left:22px;}
  .tl-vitem-left .tl-vcard::after{display:none;}
  .tl-vitem-right .tl-vcard::before{display:none;}
  .tl-vcard{max-width:100%;}
}

/* ============================================================
   갤러리
   ============================================================ */
.gl-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.gl-tab{padding:6px 14px;border:1px solid var(--line);border-radius:999px;background:var(--panel);font-size:.83rem;color:var(--dim);cursor:pointer;transition:all .15s;}
.gl-tab:hover{border-color:var(--accent);color:var(--ink);}
.gl-tab.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;}
.gl-tab.add{border-style:dashed;color:var(--accent);}
.gl-album-bar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap;}
.gl-albname{flex:1;min-width:120px;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:.9rem;color:var(--ink);}
.gl-empty{text-align:center;padding:48px 0;color:var(--dim);}
.gl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;}
.gl-cell{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:1;background:var(--line);}
.gl-thumb{width:100%;height:100%;background:center/cover no-repeat;cursor:pointer;transition:transform .2s;}
.gl-thumb:hover{transform:scale(1.04);}
.gl-del{position:absolute;top:5px;right:5px;opacity:0;transition:opacity .15s;}
.gl-cell:hover .gl-del{opacity:1;}

/* ============================================================
   TRPG 백업
   ============================================================ */
.trpg-add{margin-bottom:16px;}
.trpg-empty{text-align:center;padding:48px 0;color:var(--dim);}
.trpg-list{display:flex;flex-direction:column;gap:10px;}
.trpg-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.trpg-head{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;user-select:none;}
.trpg-head:hover{background:color-mix(in srgb,var(--accent) 6%,var(--panel));}
.trpg-title{font-weight:600;flex:1;}
.trpg-meta{display:flex;gap:8px;font-size:.8rem;color:var(--dim);}
.trpg-chevron{color:var(--dim);font-size:.8rem;}
.trpg-body{padding:0 16px 16px;}
.trpg-fields{display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;margin-bottom:10px;}
@media(max-width:540px){.trpg-fields{grid-template-columns:1fr;}}
.trpg-ta{width:100%;min-height:80px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--bg);font-size:.88rem;color:var(--ink);resize:vertical;font-family:var(--font-body);line-height:1.6;margin-bottom:6px;box-sizing:border-box;}
.trpg-ta.tall{min-height:200px;}
.trpg-info{margin-bottom:10px;font-size:.88rem;color:var(--dim);}
.trpg-summary{padding:10px 14px;background:color-mix(in srgb,var(--accent) 7%,var(--bg));border-left:3px solid var(--accent);border-radius:0 8px 8px 0;font-size:.9rem;line-height:1.6;margin-bottom:10px;white-space:pre-wrap;}
.trpg-log-wrap{margin-top:8px;}
.trpg-log-wrap summary{font-size:.85rem;color:var(--dim);cursor:pointer;padding:4px 0;}
.trpg-log{background:color-mix(in srgb,var(--ink) 4%,var(--bg));padding:12px;border-radius:8px;font-size:.8rem;line-height:1.7;white-space:pre-wrap;word-break:break-all;max-height:400px;overflow-y:auto;margin:8px 0 0;}

/* ============================================================
   롤플레잉 — SNS 게시글형 UI
   ============================================================ */

/* 목록 뷰 */
.rp-list-view { display:flex; flex-direction:column; gap:0; }
.rp-list-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.rp-thread-list { border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--panel); }
.rp-thread-item {
  display:flex; align-items:flex-start; gap:12px;
  padding:15px 18px; cursor:pointer; transition:background .13s;
  position:relative; border-bottom:1px solid var(--line);
}
.rp-thread-item:last-child { border-bottom:none; }
.rp-thread-item:hover { background:color-mix(in srgb,var(--accent) 4%,var(--panel)); }
.rp-thread-avatar {
  flex:none; width:42px; height:42px; border-radius:50%;
  background:color-mix(in srgb,var(--accent) 18%,var(--panel));
  border:2px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:1.05rem;
  color:var(--accent); overflow:hidden; background-size:cover; background-position:center;
}
.rp-thread-body { flex:1; min-width:0; }
.rp-thread-name { font-weight:600; font-size:.92rem; margin-bottom:3px; }
.rp-thread-preview { font-size:.84rem; color:var(--dim); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:5px; }
.rp-thread-preview b { color:var(--ink); font-weight:600; }
.rp-thread-footer { display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.rp-thread-date { font-size:.75rem; color:var(--dim); }
.rp-thread-count { font-size:.75rem; color:var(--accent); font-weight:600; padding:1px 7px; background:color-mix(in srgb,var(--accent) 10%,transparent); border-radius:20px; }
.rp-tag { padding:2px 7px; border-radius:20px; font-size:.73rem; background:color-mix(in srgb,var(--ink) 8%,transparent); color:var(--dim); }
.rp-thread-del-btn {
  position:absolute; top:10px; right:12px;
  width:24px; height:24px; border-radius:50%;
  font-size:.78rem; color:var(--dim);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .13s, background .13s;
}
.rp-thread-item:hover .rp-thread-del-btn { opacity:1; }
.rp-thread-del-btn:hover { background:color-mix(in srgb,#b4524a 14%,transparent); color:#b4524a; }
.rp-empty-state { text-align:center; padding:56px 20px; color:var(--dim); font-size:.9rem; }

/* 상세 뷰 */
.rp-detail-view { display:flex; flex-direction:column; }
.rp-detail-header {
  display:flex; align-items:center; gap:12px;
  padding-bottom:14px; border-bottom:1px solid var(--line); margin-bottom:0;
  position:sticky; top:54px; z-index:20;
  background:color-mix(in srgb,var(--bg) 94%,transparent);
  backdrop-filter:blur(10px);
}
.rp-back-btn {
  display:flex; align-items:center; gap:5px; padding:7px 13px;
  border:1px solid var(--line); border-radius:9px; background:var(--panel);
  font-size:.85rem; color:var(--dim); transition:border-color .13s, color .13s;
}
.rp-back-btn:hover { border-color:var(--accent); color:var(--ink); }
.rp-detail-title-text { font-family:var(--font-display); font-weight:700; font-size:1rem; }
.rp-meta-edit-bar {
  display:flex; flex-direction:column; gap:6px;
  padding:12px 0 14px; border-bottom:1px solid var(--line); margin-bottom:0;
}
.rp-meta-input {
  padding:8px 11px; border:1px solid var(--line); border-radius:9px;
  background:var(--bg); color:var(--ink); font-size:.88rem;
}
.rp-meta-input:focus { outline:none; border-color:var(--accent); }
.rp-detail-tags { display:flex; flex-wrap:wrap; gap:5px; padding:10px 0 12px; border-bottom:1px solid var(--line); }

/* 피드 */
.rp-feed { display:flex; flex-direction:column; padding-bottom:200px; }

/* 게시글 카드 */
.rp-post {
  display:flex; gap:12px;
  padding:16px 0; border-bottom:1px solid var(--line);
  animation:rpIn .2s ease both;
}
@keyframes rpIn { from{opacity:0;transform:translateY(5px);} to{opacity:1;transform:none;} }
.rp-post-reply {
  padding-left:16px; background:none;
  border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent);
}
.rp-post-avatar {
  flex:none; width:40px; height:40px; border-radius:50%;
  background:color-mix(in srgb,var(--accent) 18%,var(--panel));
  border:2px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:1rem;
  color:var(--accent); overflow:hidden; background-size:cover; background-position:center;
}
.rp-post-body { flex:1; min-width:0; }
.rp-post-meta { display:flex; align-items:baseline; gap:6px; margin-bottom:5px; flex-wrap:wrap; }
.rp-post-who { font-weight:700; font-size:.92rem; }
.rp-post-time { font-size:.78rem; color:var(--dim); margin-left:auto; }
.rp-post-content {
  font-size:.92rem; line-height:1.75; color:var(--ink);
  word-break:keep-all; overflow-wrap:break-word; white-space:pre-wrap;
}

/* 액션 바 */
.rp-post-actions {
  display:flex; align-items:center; gap:0; margin-top:10px;
  opacity:0; transition:opacity .14s;
}
.rp-post:hover .rp-post-actions,
body.editing .rp-post-actions { opacity:1; }
.rp-act-btn {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 10px; border-radius:8px;
  font-size:.78rem; color:var(--dim); background:none;
  transition:background .12s, color .12s;
}
.rp-act-btn:hover { background:color-mix(in srgb,var(--accent) 9%,transparent); color:var(--accent); }
.rp-act-btn.active { color:var(--accent); }
.rp-act-btn.del:hover { background:color-mix(in srgb,#b4524a 9%,transparent); color:#b4524a; }
.rp-act-icon { font-size:.85rem; line-height:1; }

/* 답글 영역 */
.rp-replies { border-left:2px solid var(--line); margin-left:20px; }
.rp-reply-label { font-size:.78rem; color:var(--dim); padding:8px 0 0 16px; }
.rp-replies .rp-post { padding-left:16px; }

/* 답글 입력창 (인라인) */
.rp-reply-compose {
  display:flex; align-items:flex-start; gap:10px;
  margin-left:20px; padding:12px 0 12px 16px;
  border-left:2px solid var(--accent);
}
.rp-compose-avatar-sm {
  flex:none; width:32px; height:32px; border-radius:50%;
  background:color-mix(in srgb,var(--accent) 18%,var(--panel));
  border:2px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-size:.82rem; font-weight:700; color:var(--accent);
  overflow:hidden; background-size:cover; background-position:center;
}
.rp-compose-field { flex:1; min-width:0; }
.rp-compose-ta {
  width:100%; min-height:40px; max-height:160px;
  padding:9px 13px; border:1px solid var(--line); border-radius:12px;
  background:var(--bg); font-size:.9rem; color:var(--ink);
  resize:none; font-family:var(--font-body); line-height:1.6;
  transition:border-color .13s, min-height .15s;
}
.rp-compose-ta:focus { outline:none; border-color:var(--accent); }
.rp-compose-ta::placeholder { color:var(--dim); }
.rp-compose-btns { display:flex; flex-direction:column; gap:5px; padding-top:2px; }
.rp-compose-who-btn {
  padding:5px 10px; border:1px solid var(--line); border-radius:8px;
  background:var(--panel); font-size:.78rem; color:var(--dim);
  transition:border-color .12s, color .12s; white-space:nowrap;
}
.rp-compose-who-btn:hover { border-color:var(--accent); color:var(--accent); }
.rp-compose-send-btn {
  padding:7px 14px; border-radius:10px;
  background:var(--accent); color:#fff; font-weight:600; font-size:.85rem;
  transition:background .12s; white-space:nowrap;
}
.rp-compose-send-btn:hover { background:color-mix(in srgb,var(--accent) 82%,#000); }
.rp-compose-send-btn.sm { padding:5px 10px; font-size:.8rem; }
.rp-compose-cancel-btn {
  padding:5px 10px; border:1px solid var(--line); border-radius:8px;
  background:none; font-size:.78rem; color:var(--dim);
  transition:border-color .12s;
}
.rp-compose-cancel-btn:hover { border-color:var(--dim); }

/* 편집 인라인 */
.rp-post-edit-wrap { display:flex; flex-direction:column; gap:7px; }
.rp-post-edit-sel {
  padding:5px 8px; border:1px solid var(--line); border-radius:8px;
  background:var(--bg); font-size:.84rem; color:var(--ink); align-self:flex-start;
}
.rp-post-edit-ta {
  width:100%; min-height:68px; padding:9px 12px;
  border:1px solid var(--line); border-radius:10px;
  background:var(--bg); font-size:.92rem; color:var(--ink);
  resize:vertical; font-family:var(--font-body); line-height:1.7;
}
.rp-post-edit-ta:focus { outline:none; border-color:var(--accent); }
.rp-post-edit-btns { display:flex; gap:6px; }

/* 하단 고정 입력창 */
.rp-compose-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:30;
  background:color-mix(in srgb,var(--panel) 96%,transparent);
  backdrop-filter:blur(14px); border-top:1px solid var(--line);
  padding:10px 18px 14px;
}
.rp-compose-inner {
  max-width:var(--maxw); margin:0 auto;
  display:flex; align-items:flex-end; gap:10px;
}
.rp-compose-avatar {
  flex:none; width:36px; height:36px; border-radius:50%;
  background:color-mix(in srgb,var(--accent) 18%,var(--panel));
  border:2px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:700; color:var(--accent);
  overflow:hidden; background-size:cover; background-position:center;
}
.rp-compose-right { display:flex; flex-direction:column; gap:5px; align-items:flex-end; flex:none; }
.rp-compose-hint { max-width:var(--maxw); margin:4px auto 0; padding:0 18px; font-size:.72rem; color:var(--dim); text-align:right; }

/* ---------- 타임라인 날짜 배지 + 드래그 ---------- */
.tl-vcard-date{ display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-bottom:6px; }
.tl-date-y{
  font-size:.82rem; font-weight:800;
  color:var(--card-col,var(--accent));
  letter-spacing:.03em;
}
.tl-date-md{
  font-size:.78rem; font-weight:600;
  color:color-mix(in srgb,var(--card-col,var(--accent)) 75%,var(--ink));
}
.tl-date-unknown{ font-size:.74rem; color:var(--dim); font-style:italic; }

.tl-img-draggable{ cursor:grab; position:relative; user-select:none; }
.tl-img-draggable:active{ cursor:grabbing; }
.tl-img-hint{
  position:absolute; bottom:6px; left:50%; transform:translateX(-50%);
  background:rgba(20,16,12,.55); color:#fff; font-size:.68rem;
  padding:3px 10px; border-radius:20px; white-space:nowrap;
  opacity:0; transition:opacity .2s; pointer-events:none;
}
.tl-img-draggable:hover .tl-img-hint{ opacity:1; }
.tl-drag-hint{ font-size:.78rem; color:var(--dim); margin:0 0 10px; text-align:center; }
.tl-drag-handle{
  font-size:1.1rem; color:var(--dim); cursor:grab;
  line-height:1; margin-bottom:6px; text-align:center;
  opacity:.5; transition:opacity .15s;
}
.tl-vcard:hover .tl-drag-handle{ opacity:1; }
.tl-vitem.tl-dragging{ opacity:.4; }
.tl-vitem.tl-drag-over .tl-vcard{
  outline:2px dashed var(--accent);
  outline-offset:3px;
  background:color-mix(in srgb,var(--accent) 6%,var(--panel));
}

/* 인라인 편집 폼 */
.tl-vcard-wrap{
  display:flex; flex-direction:column; gap:0;
  max-width:320px; width:100%;
}
.tl-inline-edit{
  background:var(--bg);
  border:1px solid var(--line);
  border-top:none;
  border-radius:0 0 var(--radius) var(--radius);
  padding:14px 16px;
  display:flex; flex-direction:column; gap:8px;
}
.tl-date-row{ display:flex; gap:6px; }
.tl-date-inp{ flex:1; min-width:0; }
.tl-date-inp.sm{ flex:.5; }
.tl-edit-row2{ display:flex; gap:6px; }
.tl-vcard-edit{
  margin-top:10px; font-size:.78rem; color:var(--accent);
  cursor:pointer; text-align:right; padding:2px 0;
  font-weight:600; letter-spacing:.02em;
}
.tl-vcard-edit:hover{ text-decoration:underline; }
/* 카드가 편집 중일 때 하단 모서리 각지게 */
.tl-vcard-wrap:has(.tl-inline-edit[style*="block"]) .tl-vcard{
  border-radius:var(--radius) var(--radius) 0 0;
}

/* 잠금화면 배경 미리보기 */
.lock-bg-preview{
  width:80px; height:50px; border-radius:8px;
  background-size:cover; background-position:center;
  border:1px solid var(--line); flex:none; cursor:pointer;
}

/* ============================================================
   RP 채팅형 레이아웃
   ============================================================ */
.rp-chat-view{display:flex;flex-direction:column;height:calc(100vh - 54px - 80px);min-height:0;}
.rp-chat-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:54px;z-index:20;}
.rp-back-btn{font-size:1.2rem;padding:4px 8px;border-radius:8px;color:var(--dim);transition:background .15s;}
.rp-back-btn:hover{background:color-mix(in srgb,var(--accent) 8%,transparent);}
.rp-chat-header-info{flex:1;min-width:0;}
.rp-chat-title{font-family:var(--font-display);font-weight:700;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rp-chat-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px;}
.rp-header-edit-btn{padding:6px 10px;border-radius:8px;color:var(--dim);font-size:1rem;transition:background .15s;}
.rp-header-edit-btn:hover{background:color-mix(in srgb,var(--accent) 8%,transparent);}

/* 메시지 영역 */
.rp-chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px;}
.rp-chat-empty{text-align:center;color:var(--dim);font-size:.88rem;margin:40px 0;}

/* 날짜 구분선 */
.rp-date-sep{display:flex;align-items:center;gap:10px;margin:16px 0 8px;color:var(--dim);font-size:.75rem;}
.rp-date-sep::before,.rp-date-sep::after{content:'';flex:1;height:1px;background:var(--line);}

/* 메시지 행 */
.rp-msg-row{display:flex;align-items:flex-end;gap:8px;max-width:80%;margin-bottom:2px;}
.rp-msg-mine{align-self:flex-end;flex-direction:row-reverse;}
.rp-msg-theirs{align-self:flex-start;}

/* 아바타 */
.rp-msg-avatar{
  flex:none;width:34px;height:34px;border-radius:50%;
  background:color-mix(in srgb,var(--accent) 22%,var(--panel));
  background-size:cover;background-position:center;
  border:2px solid var(--line);font-size:.8rem;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:var(--ink);
}
.rp-msg-avatar.mine{visibility:visible;}

/* 말풍선 */
.rp-msg-content{display:flex;flex-direction:column;gap:3px;max-width:100%;}
.rp-msg-name{font-size:.74rem;color:var(--dim);margin-left:4px;}
.rp-bubble{
  padding:10px 14px;border-radius:18px;
  font-size:.92rem;line-height:1.6;word-break:keep-all;overflow-wrap:break-word;
  max-width:100%;white-space:pre-wrap;
}
.rp-bubble-theirs{
  background:var(--panel);border:1px solid var(--line);
  border-bottom-left-radius:6px;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
}
.rp-bubble-mine{
  background:var(--accent);color:#fff;
  border-bottom-right-radius:6px;
}
.rp-msg-meta{display:flex;align-items:center;gap:6px;padding:0 4px;}
.rp-msg-mine .rp-msg-meta{justify-content:flex-end;}
.rp-msg-time{font-size:.7rem;color:var(--dim);}
.rp-msg-act{font-size:.72rem;color:var(--dim);padding:2px 6px;border-radius:6px;transition:background .15s;}
.rp-msg-act:hover{background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--ink);}
.rp-msg-act.del:hover{background:color-mix(in srgb,#b4524a 10%,transparent);color:#b4524a;}

/* 인라인 편집 */
.rp-msg-edit{display:flex;flex-direction:column;gap:6px;min-width:200px;}

/* 입력창 */
.rp-compose-bar{position:sticky;bottom:0;z-index:20;background:var(--panel);border-top:1px solid var(--line);padding:10px 14px;}
.rp-compose-inner{display:flex;align-items:flex-end;gap:10px;}
.rp-compose-avatar-btn{flex:none;padding:0;border-radius:50%;transition:transform .15s;}
.rp-compose-avatar-btn:hover{transform:scale(1.08);}
.rp-compose-avatar{
  width:36px;height:36px;border-radius:50%;
  background:color-mix(in srgb,var(--accent) 22%,var(--panel));
  background-size:cover;background-position:center;
  border:2px solid var(--line);font-size:.8rem;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:var(--ink);
}
.rp-compose-ta{flex:1;padding:10px 14px;border:1px solid var(--line);border-radius:20px;background:var(--bg);font-size:.92rem;resize:none;max-height:160px;line-height:1.5;}
.rp-compose-ta:focus{outline:none;border-color:var(--accent);}
.rp-compose-send-btn{flex:none;padding:10px 18px;border-radius:20px;background:var(--accent);color:#fff;font-weight:600;font-size:.9rem;transition:opacity .15s;}
.rp-compose-send-btn:hover{opacity:.85;}
.rp-compose-send-btn.sm{padding:7px 14px;font-size:.82rem;}
.rp-compose-hint{font-size:.72rem;color:var(--dim);text-align:right;margin-top:4px;}
.im-weather-source{font-size:.72rem;color:var(--dim);margin:-6px 0 12px;letter-spacing:.02em;}

/* ============================================================
   RP SNS 피드형 카드
   ============================================================ */
.rp-feed-view{ display:flex; flex-direction:column; }
.rp-feed{
  padding:12px 16px;
  display:flex; flex-direction:column; gap:2px;
}
.rp-empty-feed{ text-align:center;color:var(--dim);font-size:.88rem;padding:40px 0; }

/* 게시글 카드 */
.rp-post-card{
  display:flex; gap:12px; align-items:flex-start;
  padding:14px 16px;
  background:color-mix(in srgb,var(--panel) 92%,transparent);
  backdrop-filter:blur(6px);
  border-radius:var(--radius);
  margin-bottom:6px;
  border:1px solid color-mix(in srgb,var(--line) 60%,transparent);
  box-shadow:0 1px 4px rgba(0,0,0,.06);
  transition:background .15s;
}
.rp-post-card:hover{ background:var(--panel); }

/* 아바타 */
.rp-post-card-avatar{
  flex:none; width:42px; height:42px; border-radius:50%;
  background:color-mix(in srgb,var(--accent) 20%,var(--panel));
  background-size:cover; background-position:center;
  border:2px solid var(--line);
  font-size:.88rem; font-weight:700; color:var(--ink);
  display:flex; align-items:center; justify-content:center;
}

/* 본문 */
.rp-post-card-body{ flex:1; min-width:0; }
.rp-post-card-top{
  display:flex; align-items:center; gap:8px;
  margin-bottom:6px; flex-wrap:wrap;
}
.rp-post-card-name{
  font-weight:700; font-size:.92rem;
  color:var(--ink); font-family:var(--font-display);
}
.rp-post-card-time{ font-size:.76rem; color:var(--dim); }
.rp-post-card-text{
  font-size:.92rem; line-height:1.7;
  color:var(--ink); word-break:keep-all;
  overflow-wrap:break-word; white-space:pre-wrap;
}

/* 내 캐릭터 선택 */
.rp-mychar-bar{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;}
.rp-mychar-label{font-size:.82rem;color:var(--dim);flex:none;font-weight:600;}
.rp-mychar-btns{display:flex;gap:8px;}
.rp-mychar-btn{display:flex;align-items:center;gap:8px;padding:7px 14px;border:1.5px solid var(--line);border-radius:20px;font-size:.88rem;color:var(--dim);background:var(--bg);transition:all .15s;}
.rp-mychar-btn:hover{border-color:var(--accent);color:var(--ink);}
.rp-mychar-btn.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--panel));color:var(--ink);font-weight:600;}
.rp-mychar-avatar{width:24px;height:24px;border-radius:50%;background:color-mix(in srgb,var(--accent) 20%,var(--panel));background-size:cover;background-position:center;font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex:none;}
.rp-mychar-check{color:var(--accent);font-size:.8rem;}

/* ============================================================
   집 레이어(층/마당) 시스템
   ============================================================ */
/* 스테이지 위 레이어 전환 탭 */
.layer-tabs{
  display:flex; gap:6px; padding:8px 12px;
  background:color-mix(in srgb,var(--panel) 90%,transparent);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
  flex-wrap:wrap;
}
.layer-tab{
  padding:6px 16px; border-radius:20px; font-size:.84rem;
  border:1px solid var(--line); background:var(--panel);
  color:var(--dim); transition:all .15s;
}
.layer-tab.active{
  background:var(--accent); color:#fff;
  border-color:var(--accent); font-weight:600;
}
.layer-tab:hover:not(.active){
  border-color:color-mix(in srgb,var(--accent) 30%,var(--line));
  color:var(--ink);
}

/* 에디터 레이어 관리 바 */
.he-layer-bar{
  border:1px solid var(--line); border-radius:var(--radius);
  padding:12px 14px; margin-bottom:10px;
  background:var(--panel); display:flex;
  flex-direction:column; gap:8px;
}
.he-layer-label{ font-size:.78rem; color:var(--dim); font-weight:600; }
.he-layer-btns{ display:flex; gap:6px; flex-wrap:wrap; align-items:center; }
.he-layer-btn{
  padding:6px 14px; border-radius:16px; font-size:.84rem;
  border:1px solid var(--line); background:var(--bg);
  color:var(--dim); transition:all .15s; position:relative;
}
.he-layer-btn.active{
  background:color-mix(in srgb,var(--accent) 12%,var(--panel));
  border-color:var(--accent); color:var(--ink); font-weight:600;
}
.he-layer-del{
  margin-left:6px; color:var(--dim); font-size:.75rem;
  vertical-align:middle; padding:1px 3px; border-radius:50%;
}
.he-layer-del:hover{ color:#b4524a; }
.he-layer-add{
  padding:6px 12px; border-radius:16px; font-size:.84rem;
  border:1.5px dashed var(--line); color:var(--dim);
  background:transparent; transition:all .15s;
}
.he-layer-add:hover{ border-color:var(--accent); color:var(--accent); }
.he-layer-name-row{ display:flex; }
.he-layer-name-inp{
  flex:1; padding:8px 12px; border:1px solid var(--line);
  border-radius:8px; background:var(--bg); font-size:.9rem;
}
.he-layer-bg{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.btn.danger.sm{ padding:6px 12px; font-size:.8rem; }

/* ============================================================
   계단 / 층 연결 오브젝트
   ============================================================ */
.stair-obj{
  position:absolute; transform:translate(-50%,-50%);
  z-index:9; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; gap:2px;
}
.stair-icon{
  font-size:1.6rem; line-height:1;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));
  transition:transform .15s;
}
.stair-obj:hover .stair-icon{ transform:scale(1.15); }
.stair-img{
  width:48px; height:48px; object-fit:contain;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));
}
.stair-label{
  font-size:.68rem; font-weight:700;
  background:rgba(20,16,12,.65); color:#fff;
  padding:2px 8px; border-radius:10px;
  white-space:nowrap; backdrop-filter:blur(2px);
}
.stair-del{
  position:absolute; top:-8px; right:-8px;
  width:18px; height:18px; border-radius:50%;
  background:#b4524a; color:#fff; font-size:.7rem;
  display:none; align-items:center; justify-content:center;
}
.stair-obj:hover .stair-del{ display:flex; }

/* 층 전환 페이드 애니메이션 */
.house-stage.layer-fade{ opacity:0; transition:opacity .2s ease; }
.house-stage.layer-fade-in{ animation:layerIn .35s ease forwards; }
@keyframes layerIn{
  from{ opacity:0; transform:scale(.97); }
  to{ opacity:1; transform:scale(1); }
}
