@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Noto+Serif+KR:wght@300;400;500;600&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--rose:#c9607a;--rose-deep:#a84060;--rose-lt:#f5dde5;--rose-pale:#fdf0f4;--cream:#fdf8f4;--white:#fff;--ink:#2a2028;--ink-light:#5a4a52;--ink-muted:#8a7a82;--dusty:#b09098;--border:#e8d8de;--gold:#c8a97a;--sans:"Noto Serif KR","Apple SD Gothic Neo",sans-serif;--serif:"Playfair Display","Noto Serif KR",serif}body{background:#fdf8f4;background:var(--cream);color:#2a2028;color:var(--ink);font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);overflow-x:hidden}.app-root,body{min-height:100vh}.app-root{overflow:hidden;position:relative}.deco-circle{border-radius:50%;pointer-events:none;position:fixed;z-index:0}.deco-1{background:radial-gradient(circle,#f5dde5 0,#0000 70%);height:480px;opacity:.55;right:-120px;top:-160px;width:480px}.deco-2{background:radial-gradient(circle,#e8f0fb 0,#0000 70%);bottom:-100px;height:360px;left:-80px;opacity:.5;width:360px}.deco-3{background:radial-gradient(circle,#fef0e8 0,#0000 70%);height:200px;left:50%;opacity:.4;top:45%;width:200px}.envelopes-bg{inset:0;overflow:hidden;pointer-events:none;position:fixed;z-index:0}.heart-float{animation:heartFloat 8s ease-in-out infinite alternate;animation:heartFloat var(--dur,8s) ease-in-out infinite alternate;opacity:.15;position:absolute;transform-origin:center}@keyframes heartFloat{0%{transform:translateY(0) rotate(0deg);transform:translateY(0) rotate(var(--rot,0deg))}to{transform:translateY(-28px) rotate(6deg);transform:translateY(-28px) rotate(calc(var(--rot, 0deg) + 6deg))}}.intro-overlay{align-items:center;background:linear-gradient(155deg,#fef9f5,#faedf3 40%,#f5eafa);display:flex;inset:0;justify-content:center;overflow:hidden;position:fixed;z-index:100}.intro-glow{animation:glowPulse 5s ease-in-out infinite alternate;border-radius:50%;filter:blur(80px);pointer-events:none;position:absolute}.intro-glow-1{animation-delay:0s;background:radial-gradient(circle,#fcd5e3 0,#0000 70%);height:520px;opacity:.55;right:-100px;top:-80px;width:520px}.intro-glow-2{animation-delay:1.8s;background:radial-gradient(circle,#e8d8f8 0,#0000 70%);bottom:-60px;height:400px;left:-80px;opacity:.5;width:400px}.intro-glow-3{animation-delay:3.2s;background:radial-gradient(circle,#fff0d0 0,#0000 70%);height:300px;left:50%;opacity:.35;top:50%;transform:translate(-50%,-50%);width:300px}@keyframes glowPulse{0%{opacity:.5;opacity:var(--base-op,.5);transform:scale(1)}to{opacity:.7;opacity:calc(var(--base-op, .5)*1.4);transform:scale(1.18)}}.intro-particles-layer{inset:0;overflow:hidden;pointer-events:none;position:absolute}.intro-particle{animation:particleFall 1.8s cubic-bezier(.25,.1,.35,1) forwards;animation:particleFall var(--fall-dur,1.8s) cubic-bezier(.25,.1,.35,1) forwards;animation-delay:0s;animation-delay:var(--fall-delay,0s);pointer-events:none;position:absolute;top:-90px;will-change:transform,opacity}@keyframes particleFall{0%{opacity:0;transform:translateY(0) translateX(0) rotate(-8deg)}8%{opacity:1}30%{transform:translateY(28vh) translateX(12px) rotate(6deg);transform:translateY(28vh) translateX(calc(var(--sway, 30px)*.4)) rotate(calc(var(--wobble, 6deg)))}60%{transform:translateY(62vh) translateX(30px) rotate(-4.2deg);transform:translateY(62vh) translateX(var(--sway,30px)) rotate(calc(var(--wobble, 6deg)*-.7))}88%{opacity:.92}to{opacity:.85;transform:translateY(106vh) translateX(18px) rotate(2.4deg);transform:translateY(106vh) translateX(calc(var(--sway, 30px)*.6)) rotate(calc(var(--wobble, 6deg)*.4))}}.intro-piled{animation:piledAppear .5s cubic-bezier(.22,1,.36,1) both;animation-delay:0s;animation-delay:var(--appear-delay,0s);pointer-events:none;position:absolute;transform:rotate(0deg);transform:rotate(var(--rot,0deg));transform-origin:bottom center}@keyframes piledAppear{0%{opacity:0;transform:rotate(0deg) scale(.6) translateY(12px);transform:rotate(var(--rot,0deg)) scale(.6) translateY(12px)}60%{transform:rotate(0deg) scale(1.07) translateY(-4px);transform:rotate(var(--rot,0deg)) scale(1.07) translateY(-4px)}to{opacity:1;transform:rotate(0deg) scale(1) translateY(0);transform:rotate(var(--rot,0deg)) scale(1) translateY(0)}}.intro-text-wrap{animation:textReveal .9s cubic-bezier(.22,1,.36,1) both;animation-delay:.3s;padding:2.5rem 2rem;position:relative;text-align:center;z-index:2}@keyframes textReveal{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}.intro-eyebrow{align-items:center;animation:fadeIn .7s ease both;animation-delay:.5s;color:#b09098;color:var(--dusty);display:flex;font-size:12px;gap:8px;justify-content:center;letter-spacing:.3em;margin-bottom:18px;opacity:0;text-transform:uppercase}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.intro-title{color:#2a2028;color:var(--ink);font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:clamp(42px,9vw,72px);font-weight:400;letter-spacing:-.01em;line-height:1.15;margin-bottom:14px}.intro-title-line{animation:slideUp .8s cubic-bezier(.22,1,.36,1) both;display:inline;opacity:0}.intro-title-line.delay-1{animation-delay:.65s}.intro-title-line:first-child{animation-delay:.45s}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.intro-sub{animation:fadeIn .7s ease both;animation-delay:.85s;color:#8a7a82;color:var(--ink-muted);font-size:16px;font-style:italic;letter-spacing:.04em;margin-bottom:28px;opacity:0}.intro-deco-line{animation:fadeIn .7s ease both;animation-delay:1s;background:linear-gradient(90deg,#0000,#c9607a,#0000);background:linear-gradient(90deg,#0000,var(--rose),#0000);height:1.5px;margin:0 auto 28px;opacity:0;width:48px}.intro-enter-btn{align-items:center;animation:fadeIn .7s ease both;animation-delay:1.1s;background:linear-gradient(135deg,#c9607a,#a84060);background:linear-gradient(135deg,var(--rose),var(--rose-deep));border:none;border-radius:99px;box-shadow:0 6px 28px #c9607a52,0 2px 8px #c9607a2e;color:#fff;cursor:pointer;display:inline-flex;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:15px;gap:10px;letter-spacing:.05em;opacity:0;overflow:hidden;padding:15px 36px;position:relative;transition:all .25s cubic-bezier(.22,1,.36,1)}.intro-enter-btn:before{background:linear-gradient(135deg,#ffffff26,#0000);content:"";inset:0;opacity:0;position:absolute;transition:opacity .25s}.intro-enter-btn:hover{box-shadow:0 12px 40px #c9607a66;transform:translateY(-3px) scale(1.03)}.intro-enter-btn:hover:before{opacity:1}.intro-enter-btn:active{transform:translateY(-1px) scale(1.01)}.btn-icon{animation:iconBounce 2s ease infinite;animation-delay:1.5s;font-size:18px}.btn-arrow{font-size:16px;transition:transform .2s}.intro-enter-btn:hover .btn-arrow{transform:translateX(4px)}@keyframes iconBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}}.app-inner{margin:0 auto;max-width:640px;padding:2rem 1.25rem 4rem;position:relative;z-index:1}.site-header{margin-bottom:2rem;text-align:center}.header-eyebrow{color:#b09098;color:var(--dusty);font-size:11px;letter-spacing:.22em;margin-bottom:8px;text-transform:uppercase}.header-title{color:#2a2028;color:var(--ink);font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:clamp(28px,6vw,44px);font-weight:400}.header-sub{color:#8a7a82;color:var(--ink-muted);font-size:14px;font-style:italic;margin-top:6px}.user-bar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:1rem}.user-nick{color:#5a4a52;color:var(--ink-light);font-size:13px;font-weight:500}.user-code{background:#f5ebe0;border-radius:99px;color:#b09098;color:var(--dusty);font-size:12px;padding:3px 10px}.logout-btn{background:none;border:1px solid #eed8ce;border-radius:99px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;font-size:12px;padding:3px 12px;transition:all .15s}.logout-btn:hover{border-color:#c9607a;border-color:var(--rose);color:#c9607a;color:var(--rose)}.tab-nav{flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:1.8rem}.tab-nav,.tab-pill{align-items:center;display:flex}.tab-pill{background:#fff;background:var(--white);border:1.5px solid #eed8ce;border-radius:99px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;gap:6px;padding:9px 20px;transition:all .18s}.tab-pill:hover{color:#c9607a;color:var(--rose)}.tab-pill.active,.tab-pill:hover{border-color:#c9607a;border-color:var(--rose)}.tab-pill.active{background:#c9607a;background:var(--rose);color:#fff}.tab-divider{color:#e8d8de;color:var(--border);font-size:12px}.content-area{background:#fff;background:var(--white);border:1px solid #eed8ce;border-radius:20px;box-shadow:0 4px 32px #d4637a0d;min-height:400px;padding:1.8rem 1.5rem}.form-group,.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:1rem}.form-label,label{color:#5a4a52;color:var(--ink-light);font-size:12px;font-weight:500;letter-spacing:.04em}.form-input,input{background:#fdf8f4;background:var(--cream);border:1.5px solid #eed8ce;border-radius:12px;color:#2a2028;color:var(--ink);font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;outline:none;padding:11px 14px;transition:border-color .15s;width:100%}.form-input:focus,input:focus{border-color:#c9607a;border-color:var(--rose)}.form-textarea{background:#fdf8f4;background:var(--cream);border:1.5px solid #eed8ce;border-radius:12px;color:#2a2028;color:var(--ink);font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;line-height:1.7;outline:none;padding:12px 14px;resize:vertical;transition:border-color .15s;width:100%}.form-textarea:focus{border-color:#c9607a;border-color:var(--rose)}.submit-btn{background:linear-gradient(135deg,#c9607a,#a84060);background:linear-gradient(135deg,var(--rose),var(--rose-deep));border:none;border-radius:99px;box-shadow:0 4px 16px #c9607a38;color:#fff;cursor:pointer;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:15px;letter-spacing:.03em;padding:14px;transition:all .18s;width:100%}.submit-btn:hover:not(:disabled){box-shadow:0 6px 24px #c9607a54;transform:translateY(-1px)}.submit-btn:disabled{cursor:not-allowed;opacity:.45}.error-msg{color:#c9607a}.error-msg,.success-msg{font-size:13px;margin-top:6px}.success-msg{color:#4d7a18}.letter-form-wrap{display:flex;flex-direction:column;gap:0}.form-eyebrow{color:#b09098;color:var(--dusty);font-size:11px;letter-spacing:.2em;margin-bottom:1.6rem;text-align:center;text-transform:uppercase}.form-row{display:flex;gap:12px;margin-bottom:1rem}.form-row .form-group{flex:1 1;margin-bottom:0}.form-select{appearance:none;background:#fdf8f4;background:var(--cream);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath fill='%23b09098' d='m1 1 5 5 5-5'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:1.5px solid #eed8ce;border-radius:12px;color:#2a2028;color:var(--ink);cursor:pointer;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;outline:none;padding:11px 36px 11px 14px;transition:border-color .15s;width:100%}.form-select:focus{border-color:#c9607a;border-color:var(--rose)}.form-hint-warn{background:#fff8f0;border:1px solid #f0c898;border-radius:10px;color:#c97a30;font-size:13px;padding:10px 14px;text-align:center}.theme-grid{display:flex;flex-wrap:wrap;gap:8px}.theme-chip{background:#0000;border:1.5px solid #eed8ce;border-radius:99px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:13px;padding:7px 14px;transition:all .15s}.theme-chip:hover{border-color:#c9607a;border-color:var(--rose);color:#c9607a;color:var(--rose)}.theme-chip.active{font-weight:500}.lbox-stage{overflow:visible;position:relative;width:100%}.lbox-heart-falling{animation:lboxFall 1.4s cubic-bezier(.3,0,.7,1) forwards;animation:lboxFall var(--fall-dur,1.4s) cubic-bezier(.3,0,.7,1) forwards;pointer-events:none;position:absolute;top:-160px}@keyframes lboxFall{0%{opacity:0;transform:translateX(0) rotate(-6deg)}10%{opacity:1}50%{transform:translateX(20px) rotate(4deg);transform:translateX(var(--sway,20px)) rotate(4deg)}to{opacity:.95;transform:translateX(6px) translateY(520px) rotate(-3deg);transform:translateX(calc(var(--sway, 20px)*.3)) translateY(520px) rotate(-3deg)}}.lbox-heart-piled{cursor:pointer;position:absolute;transform:rotate(0deg);transform:rotate(var(--pile-rot,0deg));transition:transform .18s}.lbox-heart-piled:hover{transform:rotate(0deg) scale(1.07) translateY(-4px);transform:rotate(var(--pile-rot,0deg)) scale(1.07) translateY(-4px);z-index:10}.heart-delete-btn{align-items:center;background:#f0e0e4;border:none;border-radius:50%;color:#c9607a;color:var(--rose);cursor:pointer;display:none;font-size:11px;height:22px;justify-content:center;position:absolute;right:-6px;top:-6px;width:22px;z-index:3}.lbox-heart-piled:hover .heart-delete-btn{display:flex}.heart-hover-label{background:#ffffffeb;border:1px solid #eed8ce;border-radius:99px;bottom:-24px;color:#5a4a52;color:var(--ink-light);font-size:11px;left:50%;opacity:0;padding:2px 10px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s;white-space:nowrap}.lbox-heart-piled:hover .heart-hover-label{opacity:1}.mailbox-tabs{border:1.5px solid #eed8ce;border-radius:12px;display:flex;gap:0;margin-bottom:1rem;overflow:hidden}.mbtab{background:#0000;border:none;color:#8a7a82;color:var(--ink-muted);cursor:pointer;flex:1 1;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;padding:11px;transition:all .15s}.mbtab.active{background:#c9607a;background:var(--rose);color:#fff;font-weight:500}.filter-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.2rem}.filter-chip{background:#0000;border:1px solid #eed8ce;border-radius:99px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:12px;padding:5px 13px;transition:all .15s}.filter-chip:hover{color:#c9607a;color:var(--rose)}.filter-chip.active,.filter-chip:hover{border-color:#c9607a;border-color:var(--rose)}.filter-chip.active{background:#c9607a;background:var(--rose);color:#fff}.sent-badge{background:#378add;border-radius:99px;color:#fff;font-size:10px;padding:2px 7px;position:absolute;right:-6px;top:-6px;z-index:2}.loading{font-size:14px;font-style:italic}.empty,.loading{color:#8a7a82;color:var(--ink-muted);padding:3rem 0;text-align:center}.empty{font-size:15px;line-height:2}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#2a202859;display:flex;inset:0;justify-content:center;padding:1.5rem;position:fixed;z-index:200}.modal{animation:modalIn .22s ease;background:#fff;background:var(--white);border-radius:20px;box-shadow:0 16px 64px #2a202840;max-width:420px;padding:2rem 1.8rem;width:100%}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-direction{color:#8a7a82;color:var(--ink-muted);font-size:12px;margin-bottom:6px;text-align:center}.modal-from{color:#5a4a52;color:var(--ink-light);font-size:14px;margin-bottom:4px;text-align:center}.modal-title{color:#2a2028;color:var(--ink);font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:22px;margin-bottom:6px;text-align:center}.modal-date{color:#b09098;color:var(--dusty);font-size:12px;margin-bottom:1.2rem;text-align:center}.modal-body{background:#fdf8f4;background:var(--cream);border:1px solid #f0e8e4;border-radius:12px;color:#2a2028;color:var(--ink);font-size:14px;line-height:1.9;margin-bottom:1.4rem;padding:1.2rem;white-space:pre-wrap}.modal-close{background:#0000;border:1.5px solid #eed8ce;border-radius:99px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;padding:11px;transition:all .15s;width:100%}.modal-close:hover{border-color:#c9607a;border-color:var(--rose);color:#c9607a;color:var(--rose)}.login-wrap{align-items:center;background:linear-gradient(160deg,#fdf6ef,#fae8ee);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-card{background:#fff;background:var(--white);border:1px solid #eed8ce;border-radius:22px;box-shadow:0 8px 48px #d4637a14;max-width:400px;padding:2.5rem 2rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-title{color:#2a2028;color:var(--ink);font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:32px;font-weight:400}.login-tabs{border:1px solid #eed8ce;border-radius:10px;display:flex;margin-bottom:1.5rem;overflow:hidden}.ltab{background:#0000;border:none;color:#8a7a82;color:var(--ink-muted);cursor:pointer;flex:1 1;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;padding:10px;transition:all .15s}.ltab.active{background:#c9607a;background:var(--rose);color:#fff;font-weight:500}.friends-page{display:flex;flex-direction:column;gap:1.2rem}.my-code-card{background:linear-gradient(135deg,#fdf0f3,#fce8ef);border:1px solid #eed8ce;border-radius:16px;padding:1.4rem;text-align:center}.my-code-label{color:#b09098;color:var(--dusty);font-size:11px;letter-spacing:.12em;margin-bottom:8px;text-transform:uppercase}.my-code-value{color:#c9607a;color:var(--rose);font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:36px;font-weight:400;letter-spacing:.18em;margin-bottom:6px}.my-code-sub{color:#8a7a82;color:var(--ink-muted);font-size:12px;margin-bottom:12px}.copy-btn{background:#0000;border:1px solid #c9607a;border:1px solid var(--rose);border-radius:99px;color:#c9607a;color:var(--rose);cursor:pointer;font-size:13px;padding:7px 20px;transition:all .15s}.copy-btn:hover{background:#c9607a;background:var(--rose);color:#fff}.section-title{border-top:1px solid #f0e8e4;color:#5a4a52;color:var(--ink-light);font-size:13px;font-weight:500;letter-spacing:.06em;padding-top:.5rem}.badge-count{background:#c9607a;background:var(--rose);border-radius:99px;color:#fff;font-size:11px;margin-left:6px;padding:1px 7px}.add-friend-form{display:flex;flex-direction:column;gap:10px}.code-input{background:#fdf8f4;background:var(--cream);border:1px solid #eed8ce;border-radius:12px;font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:18px;letter-spacing:.25em;outline:none;padding:12px 16px;text-align:center;transition:border-color .15s;width:100%}.code-input:focus{border-color:#c9607a;border-color:var(--rose)}.relation-select-row{display:flex;gap:8px}.relation-btn{background:#0000;border:1px solid #eed8ce;border-radius:10px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;flex:1 1;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:13px;padding:9px;transition:all .15s}.relation-btn:hover{border-color:#c9607a;border-color:var(--rose)}.pending-empty{background:#fdf8f4;background:var(--cream);border:1px dashed #eed8ce;border-radius:12px;color:#8a7a82;color:var(--ink-muted);font-size:13px;padding:10px 16px;text-align:center}.pending-list{display:flex;flex-direction:column;gap:8px}.pending-card{background:#fdf8f4;background:var(--cream);border:1px solid #eed8ce;border-radius:12px;justify-content:space-between;padding:12px 16px}.pending-card,.pending-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.pending-code{color:#8a7a82;color:var(--ink-muted);font-size:11px;letter-spacing:.1em}.accept-btn{background:#c9607a;background:var(--rose);border:none;border-radius:99px;color:#fff;cursor:pointer;font-size:13px;padding:6px 16px}.friends-list{display:flex;flex-direction:column;gap:10px}.friend-card{align-items:center;background:#fdf8f4;background:var(--cream);border:1px solid #eed8ce;border-radius:14px;cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:all .18s}.friend-card:hover{border-color:#c9607a;border-color:var(--rose);box-shadow:0 4px 16px #d4637a1a;transform:translateY(-1px)}.friend-avatar{align-items:center;background:linear-gradient(135deg,#c9607a,#a84060);background:linear-gradient(135deg,var(--rose),var(--rose-deep));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:18px;height:40px;justify-content:center;width:40px}.friend-info{flex:1 1}.friend-name{color:#2a2028;color:var(--ink);font-size:15px;font-weight:500}.friend-code-small{color:#8a7a82;color:var(--ink-muted);font-size:11px;letter-spacing:.1em;margin-top:2px}.relation-tag{border-radius:99px;font-size:12px;font-weight:500;padding:3px 10px}.chat-arrow{font-size:18px}.chat-page{display:flex;flex-direction:column;height:60vh}.chat-header{align-items:center;border-bottom:1px solid #f0e8e4;display:flex;gap:12px;margin-bottom:1rem;padding-bottom:1rem}.back-btn{background:none;border:1px solid #eed8ce;border-radius:99px;color:#8a7a82;color:var(--ink-muted);cursor:pointer;font-size:14px;padding:6px 12px;transition:all .15s}.back-btn:hover{border-color:#c9607a;border-color:var(--rose);color:#c9607a;color:var(--rose)}.chat-avatar{align-items:center;background:linear-gradient(135deg,#c9607a,#a84060);background:linear-gradient(135deg,var(--rose),var(--rose-deep));border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-family:Playfair Display,"Noto Serif KR",serif;font-family:var(--serif);font-size:16px;height:36px;justify-content:center;width:36px}.chat-name{color:#2a2028;color:var(--ink);font-size:15px;font-weight:500}.chat-status{color:#8a7a82;color:var(--ink-muted);font-size:11px}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:.5rem 0 1rem}.chat-empty{color:#8a7a82;color:var(--ink-muted);font-size:14px;font-style:italic;padding:2rem 0;text-align:center}.chat-bubble-wrap{align-items:flex-end;display:flex;gap:8px}.chat-bubble-wrap.me{flex-direction:row-reverse}.bubble-avatar{align-items:center;background:#f0e8e4;border-radius:50%;display:flex;flex-shrink:0;font-size:13px;height:28px;justify-content:center;width:28px}.chat-bubble{border-radius:18px;font-size:14px;line-height:1.5;max-width:260px;padding:10px 14px;word-break:break-word}.bubble-me{background:#f7c0d0;border-bottom-right-radius:4px;color:#7a1535}.bubble-other{background:#fdf8f4;background:var(--cream);border:1px solid #eed8ce;border-bottom-left-radius:4px;color:#2a2028;color:var(--ink)}.bubble-time{color:#8a7a82;color:var(--ink-muted);font-size:10px;margin-top:3px;text-align:right}.chat-bubble-wrap.other .bubble-time{text-align:left}.chat-input-bar{border-top:1px solid #f0e8e4;display:flex;gap:8px;padding-top:1rem}.chat-input{background:#fdf8f4;background:var(--cream);border:1px solid #eed8ce;border-radius:12px;flex:1 1;font-family:"Noto Serif KR",Apple SD Gothic Neo,sans-serif;font-family:var(--sans);font-size:14px;outline:none;padding:10px 14px;resize:none;transition:border-color .15s}.chat-input:focus{border-color:#c9607a;border-color:var(--rose)}.chat-input:disabled{opacity:.5}.chat-send-btn{background:#c9607a;background:var(--rose);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:opacity .15s}.chat-send-btn:disabled{cursor:not-allowed;opacity:.4}.site-footer{color:#b09098;color:var(--dusty);font-size:12px;font-style:italic;margin-top:2rem;text-align:center}
/*# sourceMappingURL=main.2f1051b8.css.map*/