.footer-shell{display:grid;gap:14px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}.footer-main{display:flex;justify-content:flex-start}.footer-brand-block{display:grid;gap:10px;justify-items:start}.footer-brand-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.footer-brand{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#ffffff05;border:1px solid rgba(255,255,255,.08);color:#f5f1ebad;font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.footer-brand-row p,.footer-info-item,.footer-links a,.footer-copy{margin:0;color:#f5f1eb80;line-height:1.5;font-size:.8rem}.footer-info{display:grid;gap:4px;justify-items:start}.footer-links{display:flex;flex-wrap:wrap;gap:14px}.footer-links a{text-decoration:none}.footer-links a:hover{color:#f5f1ebb8}.footer-bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px 18px}.footer-copy{color:#f5f1eb57;font-size:.76rem}@media(max-width:768px){.footer-bottom{flex-direction:column;align-items:flex-start}.footer-links{gap:10px}}.hero{padding:26px 0 8px}.hero-mark{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:34px;color:var(--text-secondary)}.hero-mark span{font-size:.9rem;font-weight:700;letter-spacing:.32em}.hero-shell{display:grid;grid-template-columns:minmax(0,1fr);gap:clamp(2rem,4vw,3rem);align-items:start;justify-items:center;width:min(100%,980px);margin:0 auto}.hero-copy{display:grid;gap:22px;max-width:48rem;margin:0 auto 14px;width:100%;justify-items:center;text-align:center}.hero-brand-badge{display:inline-flex;align-items:center;justify-content:center}.hero-brand-badge img{display:block;width:76px;height:76px;object-fit:contain;border-radius:18px}.hero-title{margin:0;max-width:16ch;font-size:clamp(1.9rem,4.3vw,3.4rem);color:var(--text-primary);line-height:1.02}.hero-title-line{display:block}.hero-title-line-accent{display:inline-block;padding-inline:.08em;background:linear-gradient(90deg,#ffb59f,#ff8f86 28%,#ff7f74 54%,#ffd3bf);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-title-line+.hero-title-line{margin-top:.42em}.hero-description{margin:0;max-width:34rem;color:var(--text-secondary);font-size:clamp(1rem,1.55vw,1.2rem);line-height:1.9}.hero-actions{display:flex;padding-top:8px;justify-content:center}.hero-frame{position:relative;overflow:hidden;min-height:min(50vh,452px);margin-top:14px;width:100%;border-radius:32px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at top left,rgba(255,77,77,.12),transparent 28%),linear-gradient(180deg,#23252afa,#181a1ef0)}.hero-artwork{position:absolute;inset:0;overflow:hidden;background:var(--bg-page)}.hero-chat-preview{display:flex;flex-direction:column;height:100%}.hero-chat-preview.is-input-pinned{height:100%}.hero-chat-header{display:flex;align-items:center;justify-content:space-between;min-height:56px;padding:12px 16px 10px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.hero-chat-header-left{display:flex;align-items:center;gap:12px;min-width:0}.hero-chat-bubble-avatar img{width:100%;height:100%;object-fit:cover;display:block}.hero-chat-header-info{display:flex;flex-direction:column;min-width:0}.hero-chat-header-info strong{margin:0;font-size:16px;font-family:Pretendard Variable,Pretendard,SUIT,Apple SD Gothic Neo,sans-serif}.hero-chat-header-meta{font-size:.82em;color:#ffffff85;font-weight:500}.hero-chat-header-status{font-size:12px;color:#4ade80}.hero-chat-header-right{display:flex;align-items:center;gap:10px}.hero-chat-header-btn{width:36px;height:36px;padding:0;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:transparent;color:#fff9;display:inline-flex;align-items:center;justify-content:center;font-size:15px;line-height:1}.hero-chat-messages{flex:1;min-height:0;overflow:hidden;padding:18px 18px 24px;display:flex;flex-direction:column;gap:8px;justify-content:flex-start}.hero-chat-disclaimer{margin-bottom:8px;margin-inline:auto 0;width:min(336px,calc(100% - 40px));padding:10px 12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a}.hero-chat-disclaimer strong{display:block;margin-bottom:4px;font-size:12px;font-weight:700;color:#ffffffe0}.hero-chat-disclaimer p{margin:0;font-size:12px;line-height:1.5;color:#ffffff94}.hero-chat-bubble-wrap{display:flex;align-items:flex-end;gap:8px;animation:bubbleIn .25s ease}.hero-chat-bubble-wrap.user{justify-content:flex-end}.hero-chat-narration-wrap{display:flex;justify-content:flex-start;padding-left:40px;margin:2px 0 6px;animation:bubbleIn .25s ease}.hero-chat-narration{max-width:min(560px,calc(100% - 40px));margin:0;color:#ffffff9e;font-size:15px;line-height:1.78;font-style:italic;letter-spacing:.01em;white-space:pre-wrap}.hero-chat-bubble-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0}.hero-chat-bubble{max-width:75%;padding:10px 14px;border-radius:16px;font-size:15px;line-height:1.5;word-break:break-word}.hero-chat-bubble.assistant{background:#ffffff14;color:#fff;border-bottom-left-radius:4px}.hero-chat-bubble-speaker{display:inline-block;margin-right:6px;color:#ffffff7a;font-size:.92em;font-weight:600}.hero-chat-bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.45}30%{transform:translateY(-3px);opacity:1}}@media(prefers-reduced-motion:reduce){.hero-chat-bubble-wrap,.hero-chat-narration-wrap,.typing-dot{animation:none}}@media(max-width:980px){.hero-frame{min-height:372px}}@media(max-width:768px){.hero{padding-top:18px}.hero-shell,.hero-copy{width:100%}.hero-mark{flex-direction:column;align-items:flex-start;margin-bottom:18px}.hero-title{font-size:clamp(1.7rem,8vw,2.4rem);max-width:none}.hero-brand-badge img{width:64px;height:64px;border-radius:16px}.hero-actions .btn{width:100%}.hero-frame{min-height:304px;border-radius:26px}.hero-chat-header{padding-inline:14px}.hero-chat-messages{padding:16px 14px 20px}.hero-chat-narration-wrap{padding-left:38px}.hero-chat-narration{font-size:14px;line-height:1.72}.hero-chat-bubble{max-width:82%;font-size:14px}}.hero-unlock-sheet-overlay{position:absolute;inset:0;z-index:3;display:flex;align-items:flex-end;justify-content:center;padding-top:0;background:linear-gradient(180deg,#080a0e00,#080a0e2e 34%,#080a0e85);animation:heroUnlockFadeIn .24s ease}.hero-unlock-sheet{width:100%;background:var(--bg-page);border-radius:20px 20px 0 0;padding:18px 24px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 -24px 48px #0000003d;animation:heroUnlockSlideUp .3s ease}.hero-unlock-sheet-header{position:relative;width:100%;display:flex;justify-content:center;margin-bottom:18px}.hero-unlock-sheet-handle{width:36px;height:4px;border-radius:999px;background:#ffffff26}.hero-unlock-sheet-close{position:absolute;top:-2px;right:0;padding:0;border:none;background:transparent;color:#ffffffb3;font-size:28px;line-height:1;cursor:default}.hero-unlock-sheet-icon{position:relative;width:88px;height:88px;margin-bottom:20px;border-radius:50%;overflow:visible;background:color-mix(in srgb,var(--accent) 10%,white 90%);isolation:isolate;box-shadow:0 0 0 1px #ffffff14,0 0 32px color-mix(in srgb,var(--accent) 32%,transparent),0 0 60px color-mix(in srgb,var(--accent-strong) 18%,transparent)}.hero-unlock-sheet-icon:before,.hero-unlock-sheet-icon:after{content:"";position:absolute;inset:-18px;border-radius:50%;z-index:-2;pointer-events:none;opacity:0;transform:scale(.68);animation:heroUnlockWave 2.8s cubic-bezier(.16,.84,.32,1) infinite}.hero-unlock-sheet-icon:before{background:radial-gradient(circle,color-mix(in srgb,var(--accent) 44%,white 56%) 0%,color-mix(in srgb,var(--accent) 30%,transparent) 18%,color-mix(in srgb,var(--accent) 16%,transparent) 34%,transparent 66%)}.hero-unlock-sheet-icon:after{inset:-34px;z-index:-3;background:radial-gradient(circle,color-mix(in srgb,var(--accent-strong) 34%,white 66%) 0%,color-mix(in srgb,var(--accent) 20%,transparent) 20%,color-mix(in srgb,var(--accent) 10%,transparent) 42%,transparent 74%);animation-delay:.9s}.hero-unlock-sheet-icon img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.hero-unlock-sheet-title{margin:0;font-size:22px;line-height:1.28;font-weight:800;color:#fffffff5}.hero-unlock-sheet-description{margin:14px 0 0;font-size:16px;line-height:1.5;color:#ffffffc2}@keyframes heroUnlockFadeIn{0%{opacity:0}to{opacity:1}}@keyframes heroUnlockSlideUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes heroUnlockWave{0%{opacity:0;transform:scale(.68)}14%{opacity:.88}52%{opacity:.24}to{opacity:0;transform:scale(2.25)}}@media(max-width:768px){.hero-unlock-sheet{padding-left:18px;padding-right:18px}.hero-unlock-sheet-title{font-size:20px}}@media(prefers-reduced-motion:reduce){.hero-unlock-sheet-overlay,.hero-unlock-sheet{animation:none}.hero-unlock-sheet-icon:before,.hero-unlock-sheet-icon:after{animation:none;opacity:.22;transform:scale(1)}}.selection-board-shell{display:grid;width:min(100%,980px);margin:0 auto;gap:20px}.selection-board-head{display:grid;justify-items:center;text-align:center;gap:12px}.selection-board-kicker{margin:0;color:#ff6e6eb8;font-size:.76rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.selection-board-description{max-width:620px;letter-spacing:-.02em}.selection-board-grid{position:relative;width:100%;justify-self:center;overflow:visible}.selection-board-cursor{position:absolute;top:0;left:0;z-index:3;width:18px;height:24px;opacity:0;pointer-events:none;transform:translate(var(--cursor-x, 0),var(--cursor-y, 0));transition:transform .56s cubic-bezier(.22,1,.36,1),opacity .18s ease}.selection-board-cursor:before{content:"";position:absolute;inset:0;clip-path:polygon(0 0,0 100%,34% 76%,57% 100%,72% 92%,49% 68%,100% 68%);background:linear-gradient(180deg,#fffdfa,#ffd8cb);border:1px solid rgba(17,17,17,.38);border-radius:2px;box-shadow:0 8px 18px #00000057}.selection-board-cursor.is-visible{opacity:1}.selection-board-cursor.is-pressed{transition-duration:.18s;transform:translate(var(--cursor-x, 0),var(--cursor-y, 0)) scale(.92)}.selection-board-row{display:block}.selection-board-options{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:14px 18px;min-height:62px;padding:11px 18px}.selection-board-option{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 12px;border-radius:999px;appearance:none;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#ffffffb8;font-size:.88rem;font-weight:700;letter-spacing:-.02em;cursor:default;transition:color .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .22s ease}.selection-board-option.is-selected{padding-inline:16px;background:linear-gradient(180deg,#ff626238,#ff4d4d24);border-color:#ff6e6e66;color:#fff;box-shadow:0 10px 18px #ff4d4d29,inset 0 1px #ffffff1f}.selection-board-option.is-demo-active{animation:selection-board-flash .32s ease}@keyframes selection-board-flash{0%{transform:scale(.96);box-shadow:0 0 #ff7a7a00,inset 0 1px #ffffff1f}45%{transform:scale(1.04);box-shadow:0 0 0 6px #ff7a7a24,0 10px 18px #ff4d4d3d,inset 0 1px #ffffff2e}to{transform:scale(1);box-shadow:0 10px 18px #ff4d4d29,inset 0 1px #ffffff1f}}@media(prefers-reduced-motion:reduce){.selection-board-cursor{display:none}.selection-board-option{transition:none}.selection-board-option.is-demo-active{animation:none}}@media(max-width:768px){.selection-board-shell{width:100%;gap:16px}.selection-board-head{gap:8px}.selection-board-options{gap:8px 10px;min-height:56px;padding:9px 14px}.selection-board-option{min-height:34px;padding:0 10px;font-size:.8rem}.selection-board-option.is-selected{padding-inline:14px}}.landing-rhythm-shell{display:grid;width:min(100%,980px);margin:0 auto;gap:40px;justify-items:center}.landing-rhythm-head{display:grid;gap:18px;justify-items:center;text-align:center}.landing-rhythm-kicker{margin:0;color:#ff6e6eb8;font-size:.76rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.landing-carousel-wrap{width:100%;position:relative}.landing-carousel-track{display:flex;overflow:hidden;scroll-behavior:smooth}.landing-carousel-track>.landing-character-card{min-width:100%;flex-shrink:0}.landing-carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:16px}.landing-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:#fff3;padding:0;cursor:pointer;transition:background .2s,transform .2s}.landing-carousel-dot.active{background:var(--accent);transform:scale(1.3)}.landing-character-card{width:100%;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:#111214eb;box-shadow:0 14px 26px #00000047}.landing-character-media{position:relative;aspect-ratio:.72;overflow:hidden;background:#ffffff08}.landing-character-media:after{content:"";position:absolute;inset:auto 0 0;height:48%;background:linear-gradient(180deg,transparent 0%,rgba(11,12,14,.16) 24%,rgba(11,12,14,.92) 100%);pointer-events:none}.landing-character-media img{width:100%;height:100%;object-fit:cover;display:block}.landing-character-overlay{position:absolute;inset:12px 12px auto;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.landing-character-label{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;background:#0e0f119e;border:1px solid rgba(255,77,77,.12);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.landing-character-metric{display:grid;gap:4px;padding:9px 11px;border-radius:14px;background:#0e0f119e;border:1px solid rgba(255,255,255,.08);text-align:right}.landing-character-metric span{color:#ffffff94;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}.landing-character-metric strong{color:#fffaf7;font-size:.88rem;line-height:1}.landing-character-body{margin-top:-94px;position:relative;z-index:1;padding:0 16px 18px;border-radius:0;display:grid;gap:10px}.landing-character-body h3,.landing-character-body p{margin:0}.landing-character-body h3{font-size:clamp(1.16rem,1.6vw,1.36rem);line-height:1.14;color:#fffaf7;text-shadow:0 6px 16px rgba(0,0,0,.28)}.landing-character-tags{display:flex;flex-wrap:wrap;gap:10px}.landing-character-body p{color:var(--text-secondary);font-size:.94rem;line-height:1.6}.landing-character-tags span{display:inline-flex;align-items:center;min-height:30px;padding:0 10px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,77,77,.12);color:var(--text-secondary);font-size:.76rem}@media(max-width:768px){.landing-rhythm-shell{width:100%;gap:30px}.landing-rhythm-head{width:90%}.landing-character-body{margin-top:-84px;padding:0 14px 16px}}.landing-taste-showcase-shell{display:grid;width:min(100%,1120px);margin:0 auto;gap:34px}.landing-taste-showcase-head{display:grid;justify-items:center;text-align:center;gap:12px}.landing-taste-showcase-kicker{margin:0;color:#ff6e6eb8;font-size:.76rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.landing-taste-showcase-head .section-copy{max-width:680px}.landing-taste-showcase-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.landing-taste-tile{position:relative;overflow:hidden;min-height:420px;border-radius:28px;border:1px solid rgba(255,255,255,.08);background:#101113f0;box-shadow:var(--shadow-card);isolation:isolate}.landing-taste-tile:after{content:"";position:absolute;inset:auto 0 0;height:64%;background:linear-gradient(180deg,transparent 0%,rgba(11,12,14,.28) 34%,rgba(11,12,14,.96) 100%);pointer-events:none;z-index:1}.landing-taste-tile-media{position:absolute;inset:0}.landing-taste-tile-media img{width:100%;height:100%;display:block;object-fit:cover;transform:scale(1.02)}.landing-taste-tile-overlay{position:relative;z-index:2;display:grid;align-content:end;gap:12px;min-height:420px;padding:22px 20px 20px}.landing-taste-tile-overlay h3,.landing-taste-tile-overlay p{margin:0}.landing-taste-tile-overlay h3{color:#fff8f5;font-size:clamp(1.16rem,1.7vw,1.44rem);line-height:1.16;letter-spacing:-.04em}.landing-taste-tile-overlay p{color:#fff5efd1;font-size:.94rem;line-height:1.5}.landing-taste-tile-soft:before,.landing-taste-tile-ember:before,.landing-taste-tile-shadow:before,.landing-taste-tile-wine:before,.landing-taste-tile-rose:before,.landing-taste-tile-smoke:before{content:"";position:absolute;inset:0;z-index:1;mix-blend-mode:screen;opacity:.88;pointer-events:none}.landing-taste-tile-soft:before{background:linear-gradient(180deg,#ffb8a40f,#ff84742e)}.landing-taste-tile-ember:before{background:linear-gradient(180deg,#ff73590a,#ff522e3d)}.landing-taste-tile-shadow:before{background:linear-gradient(180deg,#78689605,#28141457)}.landing-taste-tile-wine:before{background:linear-gradient(180deg,#7d203005,#7014204d)}.landing-taste-tile-rose:before{background:linear-gradient(180deg,#ffa0a00a,#ff5b5b38)}.landing-taste-tile-smoke:before{background:linear-gradient(180deg,#ffb87c05,#4e2a1847)}@media(max-width:920px){.landing-taste-showcase-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.landing-taste-showcase-shell{width:100%;gap:24px}.landing-taste-showcase-grid{gap:14px}.landing-taste-tile{min-height:320px;border-radius:22px}.landing-taste-tile-overlay{min-height:320px;padding:18px 16px 16px;gap:10px}.landing-taste-tile-overlay p{font-size:.88rem}}@media(max-width:560px){.landing-taste-showcase-grid{grid-template-columns:minmax(0,1fr)}}.landing-cta-card{display:grid;gap:18px;padding:30px 28px;border-radius:var(--radius-lg);background:radial-gradient(circle at top left,rgba(255,77,77,.12),transparent 26%),linear-gradient(180deg,#1d1f23f5,#121315f5);border:var(--card-border);box-shadow:var(--shadow-card);justify-items:center;text-align:center}.landing-cta-kicker{color:#ff6e6eb8;font-size:.76rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.landing-cta .btn{width:fit-content}@media(max-width:768px){.landing-cta .container{width:100%}.landing-cta-card{width:90%;margin:0 auto;padding:24px 20px}.landing-cta .btn{width:100%}}.bottom-tab-bar{position:fixed;left:0;right:0;bottom:0;z-index:300;width:100%;padding-bottom:var(--safe-area-bottom);background:#141416fa;pointer-events:none}.bottom-tab-bar-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:8px 12px 10px;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -8px 24px #0000003d;pointer-events:auto}@media(min-width:768px){.bottom-tab-bar-inner{width:min(1280px,calc(100% - 64px));margin:0 auto;padding-left:24px;padding-right:24px}}.bottom-tab-link{min-height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-radius:0;color:#ffffff85;text-decoration:none;transition:color .18s ease,transform .18s ease}.bottom-tab-link:hover{color:#ffffffbd}.bottom-tab-link.is-active{color:var(--accent)}.bottom-tab-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center}.bottom-tab-icon svg{width:22px;height:22px;fill:currentColor;stroke:none;stroke-linecap:round;stroke-linejoin:round}.bottom-tab-label{font-size:10px;font-weight:700;letter-spacing:-.02em}.bottom-tab-link.is-active .bottom-tab-label{color:var(--accent)}.onboarding{min-height:var(--page-height);display:flex;flex-direction:column;background:var(--bg-page);color:var(--text-primary);padding:0 20px;transition:background .4s ease}.onboarding.phase-appearance{background:linear-gradient(180deg,rgba(99,102,241,.06) 0%,var(--bg-page) 40%)}.onboarding.phase-character{background:linear-gradient(180deg,rgba(168,85,247,.06) 0%,var(--bg-page) 40%)}.onboarding.phase-relation{background:linear-gradient(180deg,rgba(232,89,110,.06) 0%,var(--bg-page) 40%)}.onboarding.phase-preference{background:linear-gradient(180deg,rgba(245,158,11,.06) 0%,var(--bg-page) 40%)}.onboarding.phase-profile{background:linear-gradient(180deg,rgba(34,197,94,.06) 0%,var(--bg-page) 40%)}.onboarding-progress{width:100%;height:3px;background:#ffffff1a;position:fixed;top:var(--safe-area-top);left:0;z-index:10}.onboarding-progress-bar{height:100%;background:var(--accent);transition:width .3s ease}.onboarding-meta{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:40px;margin-top:56px;max-width:400px;margin-left:auto;margin-right:auto;width:100%}.onboarding-phase-label{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);opacity:.8;text-align:center}.onboarding-counter{font-size:13px;color:#ffffff59;text-align:right}.onboarding-content{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:400px;margin:0 auto;width:100%;padding-bottom:calc(80px + var(--safe-area-bottom))}.onboarding-content-image-select{max-width:560px}.onboarding-question{font-size:22px;font-weight:600;line-height:1.5;margin-bottom:32px;text-align:center}.onboarding-options{display:flex;flex-direction:column;gap:12px}.onboarding-option{padding:16px 20px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:left;display:flex;flex-direction:column;gap:6px}.onboarding-option:hover{background:#ffffff14;border-color:var(--accent)}.onboarding-option:active{transform:scale(.98)}.onboarding-option.is-selected{background:#e8596e1f;border-color:var(--accent)}.onboarding-option-label{font-size:16px;font-weight:500}.onboarding-option-sub{font-size:13px;color:#fff6;line-height:1.5}.onboarding-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.onboarding-grid-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.onboarding-grid-item:hover{background:#ffffff14;border-color:var(--accent)}.onboarding-grid-item:active{transform:scale(.96)}.onboarding-grid-item.is-selected{background:#e8596e1f;border-color:var(--accent)}.onboarding-grid-icon{font-size:24px}.onboarding-grid-label{font-size:13px;font-weight:500;text-align:center}.onboarding-preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:24px}.onboarding-type-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:24px}.onboarding-type-chip{padding:12px 18px;border:1px solid rgba(255,255,255,.15);border-radius:999px;background:#ffffff0a;color:#ffffffc7;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.onboarding-type-chip:hover{background:#ffffff14;border-color:#ffffff47}.onboarding-type-chip.is-selected{background:#e8596e2e;border-color:var(--accent);color:var(--text-primary)}.onboarding-preset-card{padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:left;display:flex;flex-direction:column;gap:4px}.onboarding-preset-card:hover{background:#ffffff14;border-color:var(--accent)}.onboarding-preset-card:active{transform:scale(.97)}.onboarding-preset-card.is-selected{background:#e8596e1f;border-color:var(--accent)}.onboarding-preset-label{font-size:16px;font-weight:600}.onboarding-preset-sub{font-size:12px;color:#fff6;line-height:1.4}.onboarding-axes-title{font-size:15px;font-weight:600;color:#fff9;margin-bottom:16px;text-align:center}.onboarding-chip-large{padding:12px 18px;border:1px solid rgba(255,255,255,.15);border-radius:12px;background:#ffffff0a;color:#ffffffb3;font-size:15px;cursor:pointer;transition:all .2s ease}.onboarding-chip-large:hover{background:#ffffff14;border-color:#ffffff4d}.onboarding-chip-large.is-selected{background:#e8596e33;border-color:var(--accent);color:var(--text-primary)}.onboarding-custom-age,.onboarding-custom-input{margin-top:16px;display:flex;flex-direction:column;gap:12px}.onboarding-custom-age-input{padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:var(--text-primary);font-size:16px;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}.onboarding-custom-age-input:focus{border-color:var(--accent)}.onboarding-custom-age-input::placeholder{color:#ffffff40}.onboarding-custom-age-error{font-size:13px;color:#ff6b6b;margin:-4px 0 0}.onboarding-next-btn:disabled{opacity:.4;cursor:not-allowed}.onboarding-axes{display:flex;flex-direction:column;gap:24px;margin-bottom:24px}.onboarding-axis{display:flex;flex-direction:column;gap:8px}.onboarding-axis-header{display:flex;justify-content:space-between}.onboarding-axis-low,.onboarding-axis-high{font-size:13px;color:#ffffff80}.onboarding-axis-slider{width:100%;height:6px;-webkit-appearance:none;appearance:none;border-radius:3px;background:#ffffff26;outline:none;cursor:pointer}.onboarding-axis-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid rgba(255,255,255,.2)}.onboarding-axis-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid rgba(255,255,255,.2)}.onboarding-axis-ticks{display:flex;justify-content:space-between;padding:0 2px}.onboarding-axis-tick{font-size:11px;color:#ffffff40;width:20px;text-align:center}.onboarding-axis-tick.is-active{color:var(--accent);font-weight:600}.onboarding-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:32px}.onboarding-chip-groups{display:flex;flex-direction:column;gap:18px}.onboarding-chip-group .onboarding-axes-title{margin-bottom:10px;font-size:13px;text-align:left}.onboarding-chip-group .onboarding-chips{justify-content:flex-start;margin-bottom:0}.onboarding-chip{padding:10px 16px;border:1px solid rgba(255,255,255,.15);border-radius:20px;background:#ffffff0a;color:#ffffffb3;font-size:14px;cursor:pointer;transition:all .2s ease}.onboarding-chip:hover{background:#ffffff14;border-color:#ffffff4d}.onboarding-chip.is-selected{background:#e8596e33;border-color:var(--accent);color:var(--text-primary)}.onboarding-next-btn{width:100%;padding:16px;border:none;border-radius:14px;background:var(--accent);color:#fff;font-size:17px;font-weight:600;cursor:pointer;transition:opacity .2s;margin-top:32px}.onboarding-next-btn:hover{opacity:.9}.onboarding-textarea{padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:var(--text-primary);font-size:15px;outline:none;transition:border-color .2s;resize:vertical;font-family:inherit}.onboarding-textarea:focus{border-color:var(--accent)}.onboarding-textarea::placeholder{color:#ffffff40}.onboarding-back{background:none;border:none;color:#fff6;font-size:13px;cursor:pointer;padding:4px 0;text-align:left}.onboarding-back:hover{color:#ffffffb3}.onboarding-profile-sub{font-size:14px;color:#ffffff59;text-align:center;margin-bottom:24px}.onboarding-profile-form{display:flex;flex-direction:column;gap:20px;max-width:400px;margin:0 auto;width:100%}.onboarding-profile-field{display:flex;flex-direction:column;gap:8px}.onboarding-profile-field span{font-size:13px;font-weight:600;color:#ffffff80}.onboarding-profile-field input{padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:var(--text-primary);font-size:16px;outline:none;transition:border-color .2s}.onboarding-profile-field input:focus{border-color:var(--accent)}.onboarding-profile-field input::placeholder{color:#ffffff40}.onboarding-profile-gender-group{display:flex;gap:10px}.onboarding-profile-gender{flex:1;padding:12px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:#ffffff0a;color:#fff9;font-size:15px;cursor:pointer;transition:all .2s;text-align:center}.onboarding-profile-gender.is-selected{background:#e8596e1f;border-color:var(--accent);color:var(--text-primary)}.onboarding-profile-error{font-size:14px;color:#e8596e;text-align:center}.onboarding-profile-submit{width:100%;padding:16px;border:none;border-radius:14px;background:var(--accent);color:#fff;font-size:17px;font-weight:600;cursor:pointer;transition:opacity .2s;margin-top:8px}.onboarding-profile-submit:hover{opacity:.9}.onboarding-generating{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.onboarding-generating-frame{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:14px}.onboarding-generating-kicker{display:none}.onboarding-generating-orb{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,var(--accent) 0%,transparent 70%);animation:pulse-orb 2s ease-in-out infinite}@keyframes pulse-orb{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:1}}.onboarding-generating-text{font-size:20px;font-weight:600;color:var(--text-primary);margin:0;text-align:center}.onboarding-generating-sub{font-size:14px;color:#fff6;text-align:center;margin:0}.onboarding-generating-progress{width:100%;margin-top:12px}.onboarding-generating-progress-rail{position:relative;height:10px;border-radius:999px;overflow:hidden;background:#ffffff1f}.onboarding-generating-progress-fill{position:relative;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent) 0%,var(--accent) 72%,rgba(232,89,110,.82) 100%);transition:width .38s cubic-bezier(.22,1,.36,1);will-change:width}.onboarding-generating-progress-glow{position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);pointer-events:none}.onboarding-generating-progress-meta{display:flex;justify-content:space-between;align-items:center;margin-top:12px;font-size:11px;letter-spacing:.8px;color:#ffffff6b}.onboarding-generating-progress-meta strong{font-size:14px;color:#ffffffe0}.onboarding:has(.onboarding-image-gallery) .onboarding-content{justify-content:flex-start;padding-bottom:calc(160px + var(--safe-area-bottom))}.onboarding-image-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:4px}.onboarding-image-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.onboarding-image-confirm{position:fixed;bottom:calc(74px + var(--safe-area-bottom));left:0;right:0;padding:16px 20px;background:linear-gradient(to top,var(--bg-page) 60%,transparent);z-index:100}.onboarding-image-confirm .onboarding-next-btn{max-width:400px;margin:0 auto;display:block}.onboarding-image-card{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;gap:0;border:2px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;background:#ffffff0a;cursor:pointer;transition:all .2s ease;padding:0;aspect-ratio:1 / 1}.onboarding-image-card img{width:100%;flex:1;object-fit:cover;display:block}.onboarding-image-card .onboarding-grid-label{padding:10px 12px 12px;font-size:14px}.onboarding-image-card:hover{border-color:#ffffff4d;transform:scale(1.02)}.onboarding-image-card.is-selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}@media(max-width:360px){.onboarding-grid{grid-template-columns:repeat(3,1fr)}.onboarding-image-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.onboarding{padding:0 32px}.onboarding-meta{max-width:720px;margin-top:72px}.onboarding-content{max-width:720px;padding-bottom:calc(112px + var(--safe-area-bottom))}.onboarding-content-image-select{max-width:960px}.onboarding-question{font-size:30px;margin-bottom:36px}.onboarding-image-confirm .onboarding-next-btn{max-width:520px}}.character-select-page{position:relative;min-height:100dvh;padding:32px 18px 56px;background:radial-gradient(circle at top,rgba(255,77,77,.16),transparent 34%),linear-gradient(180deg,rgba(255,77,77,.05) 0%,var(--bg-page) 34%,var(--bg-page) 100%);color:var(--text-primary)}.character-select-loading{position:fixed;inset:0;z-index:40;display:grid;place-items:center;background:#090a0d70;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.character-select-shell{width:min(100%,720px);margin:0 auto;display:grid;gap:28px}.character-select-header{display:grid;gap:10px;text-align:center}.character-select-kicker{margin:0;font-size:12px;letter-spacing:.24em;color:var(--accent);opacity:.78}.character-select-header h1{margin:0;font-size:clamp(32px,6vw,54px)}.character-select-copy{margin:0;color:var(--text-secondary);line-height:1.5}.character-select-list{display:grid;gap:16px}.character-select-card{border:1px solid rgba(255,77,77,.14);border-radius:24px;background:linear-gradient(180deg,#23252afa,#191b1ff5);box-shadow:var(--shadow-card);overflow:hidden;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.character-select-card[data-expanded=true]{border-color:#ff4d4d47;box-shadow:0 22px 44px #00000052,0 0 0 1px #ff4d4d14}.character-select-card-summary{width:100%;padding:18px;border:0;background:transparent;color:inherit;display:grid;grid-template-columns:minmax(96px,132px) minmax(0,1fr);gap:16px;align-items:center;text-align:left;cursor:pointer}.character-select-card-summary:focus-visible{outline:2px solid rgba(255,77,77,.5);outline-offset:-2px}.character-select-card-photo{width:100%;aspect-ratio:.82;border-radius:18px;overflow:hidden;background:#ffffff0d;border:1px solid rgba(255,77,77,.1)}.character-select-card-photo img{width:100%;height:100%;object-fit:cover}.character-select-card-copy{display:grid;gap:6px;min-width:0;color:var(--text-primary)}.character-select-card-copy strong{font-size:clamp(18px,4.6vw,24px);line-height:1.2}.character-select-card-copy span{font-size:clamp(13px,3.4vw,15px);line-height:1.45}.character-select-card-copy small{color:var(--text-secondary);font-size:clamp(11px,2.9vw,13px);line-height:1.5}.character-select-card-detail{display:grid;gap:16px;padding:0 18px 18px;animation:character-select-expand .18s ease}.character-select-card-block{display:grid;gap:6px;padding-top:14px;border-top:1px solid rgba(255,77,77,.1)}.character-select-card-block span{display:inline-block;font-size:11px;letter-spacing:.18em;color:var(--accent);opacity:.72}.character-select-card-block p{margin:0;font-size:14px;line-height:1.6;color:var(--text-primary)}.character-select-start{width:100%;min-height:56px;padding:16px 18px;border:0;border-radius:18px;background:var(--accent-gradient);color:#fff8f5;box-shadow:0 14px 24px #ff4d4d38;font-size:17px;font-weight:700;cursor:pointer}.character-select-card-start{margin-top:4px}.character-select-start:disabled{opacity:.6;cursor:default}.character-select-spinner{display:inline-block;width:52px;height:52px;border-radius:999px;border:4px solid rgba(255,248,245,.2);border-top-color:#fff8f5;animation:character-select-spin .8s linear infinite;box-shadow:0 0 0 1px #ff4d4d1f}.character-select-error{margin:0;color:#ffb4c7;text-align:center}.character-select-empty{width:min(100%,520px);margin:12vh auto 0;padding:32px 24px;text-align:center;border-radius:24px;border:1px solid rgba(255,77,77,.14);background:#1c1e22e6}@keyframes character-select-spin{to{transform:rotate(360deg)}}@keyframes character-select-expand{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:720px){.character-select-page{padding-inline:12px}.character-select-card-summary{grid-template-columns:104px minmax(0,1fr);padding:16px;gap:14px}.character-select-card-detail{padding:0 16px 16px}}.login{min-height:var(--page-height);display:flex;background:var(--bg-page);color:var(--text-primary)}.login-panel{width:100%;color:var(--text-primary)}.login-panel-page{min-height:var(--page-height);display:flex;background:var(--bg-page)}.login-panel-sheet{position:relative;background:var(--bg-page);border-radius:20px 20px 0 0;padding:12px 20px calc(24px + var(--safe-area-bottom))}.login-content{width:100%;display:flex;flex-direction:column;justify-content:space-between;padding:80px 20px 0;padding-bottom:calc(var(--bottom-tab-space) + 32px)}.login-panel-sheet .login-content{padding:16px 0 0}.login-sheet-header{position:relative;display:flex;justify-content:center;margin-bottom:8px}.login-sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff26}.login-sheet-close{position:absolute;top:-2px;right:0;border:none;background:transparent;color:#ffffffb3;font-size:28px;line-height:1;cursor:pointer}.login-top{text-align:center}.login-logo{width:72px;height:72px;border-radius:18px;margin-bottom:12px}.login-brand{display:block;font-size:22px;font-weight:800;letter-spacing:.08em;margin-bottom:20px}.login-title{padding:10% 0;font-size:26px;font-weight:700;line-height:1.4;letter-spacing:-.02em}.login-subtitle{font-size:16px;color:#fff9;margin-top:-4px;font-weight:500}.login-subtitle-name{color:var(--accent);font-weight:700}.login-bottom{display:flex;flex-direction:column;gap:16px}.login-buttons{display:flex;flex-direction:column;gap:12px}.login-agreement{text-align:center;font-size:12px;color:#ffffff59;line-height:1.5;margin:0}.login-agreement a{color:#ffffff80;text-decoration:underline}.login-btn{display:flex;align-items:center;width:100%;height:52px;border:none;border-radius:12px;padding:0 12px;cursor:pointer;transition:opacity .15s;-webkit-tap-highlight-color:transparent}.login-btn:disabled{cursor:not-allowed}.login-btn:active:not(:disabled){opacity:.8}.login-btn-icon{width:20px;height:20px;flex-shrink:0}.login-btn-label{flex:1;text-align:center;font-size:16px;font-weight:600;line-height:24px;margin-left:-20px}.login-btn-kakao{background:#fee500;color:#0d0d0d}.login-btn-google{background:#fff;color:#0d0d0d;border:1px solid #cbd5e1}.login-btn-apple{background:#000;color:#fff}.login-toast{position:fixed;top:calc(var(--safe-area-top) + 16px);left:50%;transform:translate(-50%) translateY(-20px);background:#ff3b30eb;color:#fff;font-size:14px;font-weight:500;padding:12px 20px;border-radius:12px;z-index:100;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;max-width:calc(100% - 40px);text-align:center}.login-toast-visible{opacity:1;transform:translate(-50%) translateY(0)}@media(min-width:768px){.login-content{max-width:560px;margin:0 auto;padding-top:96px;padding-bottom:calc(var(--bottom-tab-space) + 48px)}}.profile-overlay{position:fixed;inset:0;background:#0000008a;z-index:320;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.profile-sheet{width:100%;max-width:480px;max-height:76vh;overflow-y:auto;background:var(--bg-page);border-radius:20px 20px 0 0;padding:20px 20px calc(20px + var(--safe-area-bottom));display:flex;flex-direction:column;align-items:stretch;gap:16px;animation:slideUp .3s ease}.profile-sheet-header{position:relative;display:flex;justify-content:center;margin-bottom:8px}.profile-sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff26}.profile-sheet-close{position:absolute;top:-2px;right:0;border:none;background:transparent;color:#ffffffb3;font-size:28px;line-height:1;cursor:pointer;padding:0}.profile-hero{display:grid;grid-template-columns:160px minmax(0,1fr);gap:18px;align-items:start}.profile-photo{width:160px;height:160px;border-radius:10px;overflow:hidden;background:#ffffff0d}.profile-photo img{width:100%;height:100%;object-fit:cover}.profile-hero-copy{min-width:0}.profile-name{font-size:22px;font-weight:700;line-height:1.2;margin:0 0 6px;text-align:left}.profile-tagline{font-size:14px;line-height:1.5;color:#ffffff80;margin:0 0 10px;text-align:left}.profile-meta-line{font-size:13px;line-height:1.5;color:#ffffff75;margin:0;text-align:left}.profile-traits{display:flex;flex-wrap:wrap;gap:8px}.profile-trait{padding:7px 11px;border-radius:20px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);font-size:13px;color:#ffffffc7}.profile-section{display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.profile-section-label{display:block;font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;text-align:left}.profile-desc,.profile-relation{font-size:14px;line-height:1.6;color:#ffffff9e;text-align:left;margin:0}.profile-sheet-close:active{opacity:.8}@media(max-width:380px){.profile-sheet{padding-left:16px;padding-right:16px}.profile-hero{grid-template-columns:120px minmax(0,1fr);gap:14px}.profile-photo{width:120px;height:120px;border-radius:18px}}.relationship-stage-overlay{position:fixed;inset:0;z-index:320;display:flex;align-items:flex-end;justify-content:center;background:#0000008a;animation:fadeIn .2s ease}.relationship-stage-sheet{width:100%;max-width:480px;background:var(--bg-page);border-radius:20px 20px 0 0;padding:18px 24px calc(24px + var(--safe-area-bottom));display:flex;flex-direction:column;align-items:center;text-align:center;animation:slideUp .3s ease}.relationship-stage-sheet-header{position:relative;width:100%;display:flex;justify-content:center;margin-bottom:18px}.relationship-stage-sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff26}.relationship-stage-sheet-close{position:absolute;top:-2px;right:0;border:none;background:transparent;color:#ffffffb3;font-size:28px;line-height:1;cursor:pointer;padding:0}.relationship-stage-sheet-icon{width:88px;height:88px;border-radius:50%;overflow:hidden;margin-bottom:20px;background:color-mix(in srgb,var(--accent) 10%,white 90%)}.relationship-stage-sheet-icon img{width:100%;height:100%;object-fit:cover;display:block}.relationship-stage-sheet-title{margin:0;font-size:22px;line-height:1.28;font-weight:800;color:#fffffff5}.relationship-stage-sheet-description{margin:14px 0 0;font-size:16px;line-height:1.5;color:#ffffffc2}.relationship-stage-sheet-cta{width:100%;margin-top:28px;border:none;border-radius:18px;background:var(--accent-gradient);color:#fff;font-size:18px;font-weight:700;line-height:1;padding:22px 18px;cursor:pointer}.relationship-stage-sheet-cta:active,.relationship-stage-sheet-close:active{opacity:.86}@media(max-width:380px){.relationship-stage-sheet{padding-left:18px;padding-right:18px}.relationship-stage-sheet-title{font-size:20px}}.chat-page{position:relative;height:var(--page-height);overflow:hidden;display:flex;flex-direction:column;background:var(--bg-page);color:var(--text-primary)}.chat-header{display:flex;align-items:center;justify-content:space-between;min-height:56px;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.chat-header-left{display:flex;align-items:center;gap:12px}.chat-header-content{display:flex;flex-direction:column;gap:6px}.chat-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden}.chat-avatar img{width:100%;height:100%;object-fit:cover}.chat-header-info{display:flex;flex-direction:column}.chat-header-info strong{font-size:16px}.chat-affection-mood{width:min(144px,42vw);display:inline-flex;align-items:center;gap:6px}.chat-affection-mood-meta{display:inline-flex;flex:0 0 auto;align-items:center;gap:2px}.chat-affection-mood-track{position:relative;flex:1;height:6px;overflow:hidden;border-radius:999px;background:linear-gradient(180deg,#ffffff24,#ffffff0a),color-mix(in srgb,var(--accent) 12%,rgba(255,255,255,.04))}.chat-affection-mood-fill{height:100%;border-radius:inherit;opacity:.96;transition:width .22s ease,background-color .22s ease,box-shadow .22s ease,opacity .22s ease}.chat-affection-threshold-marker{position:absolute;top:50%;z-index:1;width:1px;height:10px;border-radius:999px;background:#8e8e8e9e;box-shadow:0 0 4px #ffffff2e;transform:translate(-50%,-50%);pointer-events:none}.chat-affection-mood-icon{display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;height:6px;font-size:10px;line-height:1;opacity:.5}.chat-affection-score-badge{display:inline-flex;flex:0 0 auto;align-items:center;color:#ffffff8f;font-size:10px;font-weight:600;line-height:1;letter-spacing:.01em}.chat-affection-mood--base .chat-affection-mood-fill{background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 36%,white 64%),color-mix(in srgb,var(--accent) 52%,white 48%));box-shadow:0 0 8px color-mix(in srgb,var(--accent) 22%,transparent)}.chat-affection-mood--close .chat-affection-mood-fill{background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 82%,white 18%),color-mix(in srgb,var(--accent-strong) 74%,white 26%));box-shadow:0 0 12px color-mix(in srgb,var(--accent) 30%,transparent)}.chat-affection-mood--deep .chat-affection-mood-fill{background:var(--accent-gradient);box-shadow:0 0 14px color-mix(in srgb,var(--accent) 38%,transparent);animation:chatMoodPulse 2.8s ease-in-out infinite}.chat-header-status{font-size:12px;color:#ffd666e6;font-weight:600}.chat-header-right{display:flex;align-items:center;gap:10px}.chat-header-balance{font-size:13px;font-weight:600;color:#ffffff80;cursor:pointer}.chat-header-rooms-btn,.chat-header-mypage{width:36px;height:36px;padding:0;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:transparent;color:#fff9;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.chat-header-rooms-btn:hover,.chat-header-mypage:hover{background:#ffffff0f}.chat-header-rooms-icon,.chat-header-mypage-icon{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}@keyframes chatMoodPulse{0%,to{opacity:.9}50%{opacity:1}}.chat-messages{flex:1;min-height:0;overflow-y:auto;padding:16px;padding-bottom:calc(196px + var(--safe-area-bottom));display:flex;flex-direction:column;gap:16px}.chat-disclaimer{margin-bottom:8px;margin-inline:auto;width:min(328px,calc(100% - 32px));padding:10px 12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a}.chat-disclaimer strong{display:block;margin-bottom:4px;font-size:12px;font-weight:700;color:#ffffffe0}.chat-disclaimer p{text-align:center;margin:0;font-size:12px;line-height:1.5;color:#ffffff94}.chat-disclaimer p+p{margin-top:2px}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.chat-empty p{color:#ffffff4d;font-size:15px}.chat-retry-btn{padding:10px 24px;border:1px solid rgba(255,255,255,.15);border-radius:10px;background:#ffffff0f;color:#fff9;font-size:14px;cursor:pointer}.chat-bubble-wrap{display:flex;align-items:flex-end;gap:8px;animation:bubbleIn .25s ease}.chat-message-block{display:flex;flex-direction:column;gap:8px;width:100%;animation:bubbleIn .25s ease}.chat-message-block.assistant.has-visual .chat-bubble-wrap{width:100%}.chat-bubble-stack{display:flex;flex-direction:column;align-items:flex-start;gap:8px;max-width:75%}.chat-bubble-wrap.assistant .chat-bubble-stack{align-items:flex-start;width:min(75%,560px)}.chat-bubble-wrap.user{justify-content:flex-end}.chat-narration-wrap{display:flex;justify-content:flex-start;padding-left:20px;animation:bubbleIn .25s ease}.chat-narration{max-width:min(560px,calc(100% - 20px));margin:0;color:#ffffff9e;font-size:15px;line-height:1.8;font-style:italic;letter-spacing:.01em;white-space:pre-wrap}.chat-bubble-avatar{width:32px;height:32px;padding:0;border:none;background:transparent;border-radius:50%;overflow:hidden;flex-shrink:0;cursor:pointer}.chat-bubble-avatar img{width:100%;height:100%;object-fit:cover}.chat-bubble{max-width:100%;padding:10px 14px;border-radius:16px;font-size:15px;line-height:1.5;word-break:break-word}.chat-dialogue-visual{display:block;width:100%;max-width:min(calc(100% - 80px),560px);margin:0 auto;aspect-ratio:1 / 1;object-fit:cover;border-radius:16px;background:#ffffff0f;box-shadow:inset 0 0 0 1px #ffffff0d}.chat-bubble.assistant{background:#ffffff14;border-bottom-left-radius:4px}.chat-bubble.assistant.narration{background:#ffffff14}.chat-bubble.assistant.dialogue{margin:5px 0;background:#ffffff1a;color:#fff;border-bottom-left-radius:4px;box-shadow:inset 0 0 0 1px #ffffff0d}.chat-bubble-speaker{display:inline-block;margin-right:6px;color:#ffffff7a;font-size:.92em;font-weight:600}.chat-bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-bubble-user-action{color:#ffffffc2;font-style:italic}.typing-bubble{display:flex;gap:4px;padding:12px 16px}.typing-dot{width:8px;height:8px;border-radius:50%;background:#ffffff4d;animation:typingBounce 1.2s infinite}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}.coin-sheet-overlay{position:fixed;inset:0;background:#0000008a;z-index:320;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.coin-sheet{width:100%;max-width:480px;background:var(--bg-page);border-radius:20px 20px 0 0;padding:18px 24px calc(24px + var(--safe-area-bottom));display:flex;flex-direction:column;align-items:center;text-align:center;animation:slideUp .3s ease}.coin-sheet-header{position:relative;width:100%;display:flex;justify-content:center;margin-bottom:18px}.coin-sheet-handle{width:36px;height:4px;border-radius:2px;background:#ffffff26}.coin-sheet-close{position:absolute;top:-2px;right:0;padding:0;border:none;background:transparent;color:#ffffffb3;font-size:28px;line-height:1;cursor:pointer}.coin-sheet-icon{width:88px;height:88px;margin-bottom:20px;padding:18px}.coin-sheet-title{margin:0;font-size:22px;line-height:1.28;font-weight:800;color:#fffffff5}.coin-sheet-desc{margin:14px 0 0;font-size:16px;line-height:1.5;color:#ffffffc2}.coin-sheet-btn{width:100%;border:none;border-radius:18px;margin-top:28px;padding:22px 18px;background:var(--accent-gradient);color:#fff;font-size:18px;font-weight:700;line-height:1;cursor:pointer}.coin-sheet-btn:active,.coin-sheet-close:active{opacity:.86}.chat-input-area{position:absolute;left:12px;right:12px;bottom:calc(12px + var(--safe-area-bottom));z-index:4;padding:10px 14px;border-radius:14px;backdrop-filter:blur(5px) saturate(180%);-webkit-backdrop-filter:blur(5px) saturate(180%);overflow:hidden}.chat-input-area:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none}.chat-input-area:after{content:"";position:absolute;inset:1px;border-radius:13px;border:1px solid rgba(255,255,255,.18);pointer-events:none}.chat-input-tools{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;margin-top:10px}.chat-input-tool-btn{min-width:60px;height:34px;padding:0 13px;border:1px solid rgba(255,255,255,.34);border-radius:999px;background:transparent;color:#ffffffe6;font-size:14px;font-weight:600;line-height:1;display:inline-flex;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:transform .16s ease,background-color .16s ease,border-color .16s ease,box-shadow .16s ease}.chat-input-tool-btn:hover{transform:translateY(-1px);border-color:#ffffff7a;background:linear-gradient(180deg,#ffffff21,#ffffff09),#ffffff05}.chat-input-tool-btn:active{transform:translateY(0)}.chat-input-tool-btn:disabled{opacity:.45;cursor:default}.chat-input-tool-icon{width:15px;height:13px;flex-shrink:0;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.chat-input-wrap{position:relative;z-index:1;display:flex;gap:8px;align-items:flex-end}.chat-input{flex:1;border:0px;background:transparent;color:#fff;font-size:15px;line-height:160%;outline:none;resize:none;min-height:2.15em;max-height:5.4em;overflow-y:hidden;field-sizing:content}.chat-input::placeholder{color:#ffffff80}.chat-send-btn{width:38px;height:34px;min-width:38px;padding:0;border:1px solid color-mix(in srgb,var(--accent) 58%,rgba(255,255,255,.22));border-radius:999px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 82%,white 18%),color-mix(in srgb,var(--accent-strong) 88%,black 12%));color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .16s ease,filter .16s ease,opacity .16s ease}.chat-send-btn-emoji{font-size:16px;line-height:1;transform:translate(1px)}.chat-send-btn:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.04)}.chat-send-btn:active:not(:disabled){transform:translateY(0)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}@media(max-width:480px){.chat-input-area{left:10px;right:10px;bottom:calc(10px + var(--safe-area-bottom));padding:8px 12px;border-radius:12px}.chat-input-wrap{gap:6px}.chat-input{border-radius:18px}.chat-send-btn{width:38px;height:34px;min-width:38px;border-radius:999px}.chat-send-btn-emoji{font-size:16px}}.login-sheet-overlay{position:fixed;inset:0;background:#0009;z-index:320;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.login-sheet{width:100%;max-width:480px;animation:slideUp .3s ease}.chat-header-left{cursor:pointer}.room-list-overlay{position:fixed;inset:0;background:#0009;z-index:320;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.room-list-sheet{width:100%;max-width:480px;max-height:70vh;background:var(--bg-page);border-radius:20px 20px 0 0;padding:20px 20px calc(20px + var(--safe-area-bottom));display:flex;flex-direction:column;gap:16px;animation:slideUp .3s ease}.room-list-header{display:flex;justify-content:space-between;align-items:center}.room-list-header h3{font-size:18px;font-weight:700}.room-list-close{background:none;border:none;color:#ffffff80;font-size:24px;cursor:pointer}.room-list-items{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1}.room-list-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff0a;cursor:pointer;text-align:left;color:var(--text-primary);transition:background .2s}.room-list-item:hover{background:#ffffff14}.room-list-item.is-current{border-color:var(--accent);background:#e8596e14}.room-list-item-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0}.room-list-item-avatar img{width:100%;height:100%;object-fit:cover}.room-list-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.room-list-item-info strong{font-size:15px}.room-list-item-info span{font-size:12px;color:#fff6}.room-list-item-badge{font-size:11px;padding:3px 8px;border-radius:10px;background:var(--accent);color:#fff;font-weight:600}.room-list-new{width:100%;padding:14px;border:1px dashed rgba(255,255,255,.2);border-radius:12px;background:none;color:#ffffff80;font-size:15px;cursor:pointer;transition:all .2s}.room-list-new:hover{border-color:var(--accent);color:var(--accent)}@media(min-width:768px){.chat-header,.chat-messages{width:min(1100px,calc(100% - 64px));margin:0 auto}.chat-header{padding-left:0;padding-right:0}.chat-messages{padding-left:0;padding-right:0;padding-bottom:calc(216px + var(--safe-area-bottom))}.chat-input-area{left:50%;right:auto;width:min(1100px,calc(100% - 64px));transform:translate(-50%)}.login-sheet,.room-list-sheet{max-width:720px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes bubbleIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.chat-lobby{min-height:calc(var(--app-height) - var(--bottom-tab-space));display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-page);color:var(--text-primary)}.chat-lobby-panel{width:100%;max-width:360px;padding:28px 24px;border-radius:24px;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at top right,rgba(255,77,77,.14),transparent 28%),linear-gradient(180deg,#1f2125fa,#151619f5);box-shadow:var(--shadow-card);text-align:center}.chat-lobby-eyebrow{margin:0 0 10px;font-size:12px;font-weight:700;letter-spacing:.08em;color:#ffffff6b;text-transform:uppercase}.chat-lobby-title{margin:0;font-size:28px;line-height:1.2;letter-spacing:-.04em}.chat-lobby-copy{margin:14px 0 0;font-size:15px;line-height:1.65;color:#ffffff9e}.chat-lobby-cta{width:100%;margin-top:24px;min-height:52px;border:none;border-radius:16px;background:var(--accent-gradient);color:#fff;font-size:15px;font-weight:700;cursor:pointer}@media(min-width:768px){.chat-lobby{padding:40px 24px}.chat-lobby-panel{max-width:560px;padding:40px 36px}}.page-header{position:relative;display:flex;align-items:center;justify-content:space-between;min-height:56px;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.page-header-left,.page-header-right{position:relative;z-index:1;display:flex;align-items:center}.page-header-left{justify-content:flex-start}.page-header-right{justify-content:flex-end}.page-header-title{position:absolute;left:0;right:0;text-align:center;font-size:17px;font-weight:700;margin:0;pointer-events:none}.page-header-btn{background:none;border:none;color:var(--text-primary);font-size:15px;cursor:pointer;padding:8px 4px;-webkit-tap-highlight-color:transparent}.page-header-btn:active{opacity:.6}.mypage{min-height:calc(var(--app-height) - var(--bottom-tab-space));background:radial-gradient(circle at top right,rgba(255,77,77,.08),transparent 22%),linear-gradient(180deg,rgba(255,255,255,.01),transparent 18%),var(--bg-page);color:var(--text-primary)}.mypage-loading{display:flex;align-items:center;justify-content:center;min-height:calc(var(--app-height) - var(--bottom-tab-space));color:var(--text-muted)}.mypage-content{max-width:480px;margin:0 auto;padding:14px 16px calc(24px + var(--safe-area-bottom))}.mypage-profile-card{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 0 14px;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.06);color:inherit;text-align:left;cursor:pointer}.mypage-profile-name{display:block;font-size:20px;font-weight:700;margin-bottom:4px}.mypage-profile-meta{margin:0;font-size:14px;color:var(--text-secondary)}.mypage-chevron{color:var(--text-muted);font-size:24px;line-height:1}.mypage-balance-card{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;padding:14px;border-radius:14px;background:radial-gradient(circle at top right,rgba(255,77,77,.12),transparent 26%),linear-gradient(180deg,#23252afa,#191b1ff0);box-shadow:var(--shadow-card)}.mypage-balance-copy{display:flex;align-items:center;gap:8px}.mypage-balance-label{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px}.mypage-coin-icon{width:18px;height:18px}.mypage-balance-value{font-size:22px;line-height:1;letter-spacing:-.04em}.mypage-balance-btn{min-width:82px;min-height:40px;padding:0 14px;border:none;border-radius:12px;background:var(--accent-gradient);color:#fff;font-size:14px;font-weight:700;cursor:pointer}.mypage-balance-btn:hover{opacity:.92}.mypage-menu{margin-top:14px}.mypage-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:44px;padding:0;border:none;border-bottom:1px solid rgba(255,255,255,.06);background:none;color:var(--text-primary);font-size:15px;cursor:pointer}.mypage-menu-left{display:inline-flex;align-items:center;gap:8px}.mypage-menu-left small{color:var(--text-muted);font-size:12px;letter-spacing:.08em}.mypage-menu-item-danger,.mypage-menu-item-danger .mypage-chevron{color:#ff625f}.mypage-menu-item-toggle{cursor:default}.mypage-menu-item-toggle.disabled{opacity:.68}.mypage-safety-switch{position:relative;width:46px;height:27px;padding:0;border:none;border-radius:999px;background:#ffffff1f;cursor:pointer;transition:background .16s ease}.mypage-safety-switch.active{background:#ff4d4de6}.mypage-safety-switch:disabled{cursor:not-allowed}.mypage-safety-thumb{position:absolute;top:2.5px;left:2.5px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .16s ease}.mypage-safety-switch.active .mypage-safety-thumb{transform:translate(19px)}.mypage-safety-note,.mypage-safety-error{margin:8px 0 0;font-size:13px;line-height:1.6}.mypage-safety-note{color:var(--text-muted)}.mypage-safety-error{color:#ff8f8f}.mypage-version{margin:20px 0 0;text-align:center;color:var(--text-muted);font-size:13px}@media(min-width:768px){.mypage{padding:0 32px}.mypage-content{width:clamp(480px,68vw,920px);max-width:none;padding:32px 0 calc(112px + var(--safe-area-bottom))}}.mypage-modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#04060a9e}.mypage-modal{width:calc(100% - 40px);max-width:320px;padding:24px;border-radius:18px;background:linear-gradient(180deg,#23252afa,#191b1ff5);border:var(--card-border)}.mypage-modal-title{margin:0 0 8px;font-size:18px;font-weight:700}.mypage-modal-desc{margin:0 0 20px;color:var(--text-secondary);font-size:14px;line-height:1.6}.mypage-modal-actions{display:flex;gap:10px}.mypage-modal-btn{flex:1;min-height:44px;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer}.mypage-modal-btn.cancel{background:#ffffff14;color:#fff}.mypage-modal-btn.confirm{background:var(--accent-gradient);color:#fff}.mypage-modal-btn.confirm.danger{background:#ff625f}.mypage-modal-btn:disabled{opacity:.5;cursor:not-allowed}.mypage-edit{min-height:var(--page-height);background:radial-gradient(circle at top right,rgba(255,77,77,.08),transparent 22%),linear-gradient(180deg,rgba(255,255,255,.01),transparent 18%),var(--bg-page);color:var(--text-primary)}.mypage-edit-content{max-width:480px;margin:0 auto;padding:20px 16px calc(40px + var(--safe-area-bottom))}.mypage-edit-loading{color:var(--text-muted)}.mypage-edit-form{display:grid;gap:18px;padding:4px 0 0}.mypage-edit-field{display:grid;gap:10px}.mypage-edit-field span{font-size:14px;color:var(--text-secondary)}.mypage-edit-field input{display:block;width:100%;max-width:100%;min-width:0;min-height:52px;padding:0 14px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:linear-gradient(180deg,#23252af5,#191b1ff0);color:var(--text-primary);font-size:16px}.mypage-edit-birthdate-row{display:grid;grid-template-columns:minmax(0,1.5fr) auto minmax(0,1fr) auto minmax(0,1fr);gap:10px;align-items:center}.mypage-edit-birthdate-input{text-align:center}.mypage-edit-birthdate-separator{color:var(--text-muted);font-size:16px;line-height:1}@media(max-width:420px){.mypage-edit-birthdate-row{gap:8px}.mypage-edit-birthdate-input{padding-left:10px;padding-right:10px;font-size:15px}}.mypage-edit-field input::placeholder{color:var(--text-muted)}.mypage-edit-gender-group{display:flex;gap:8px}.mypage-edit-gender{flex:1;min-height:48px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:linear-gradient(180deg,#23252af5,#191b1ff0);color:var(--text-secondary);font-size:15px;font-weight:600;cursor:pointer}.mypage-edit-gender.selected{border-color:#ff4d4d57;background:#ff4d4d1f;color:#fff}.mypage-edit-note{margin:-4px 0 0;color:var(--text-muted);font-size:13px;line-height:1.6}.mypage-edit-error{margin:0;color:#ff8f8f;font-size:14px}.mypage-edit-submit{margin:20% 0;min-height:54px;border:none;border-radius:16px;background:var(--accent-gradient);color:#fff;font-size:16px;font-weight:700;cursor:pointer}.mypage-edit-submit:disabled{opacity:.45;cursor:not-allowed}@media(min-width:768px){.mypage-edit-content{max-width:720px;padding:32px 24px calc(56px + var(--safe-area-bottom))}.mypage-edit-form{gap:22px}}.checkout{min-height:var(--page-height);background:var(--bg-page);color:var(--text-primary)}.checkout-content{padding:20px 20px calc(40px + var(--safe-area-bottom))}.checkout-products{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.checkout-product{position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:flex-start;padding:15px 20px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff0a;color:var(--text-primary);cursor:pointer;transition:border-color .15s}.checkout-product.selected{border-color:var(--accent);background:#e8596e14}.checkout-product-copy{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:0}.checkout-product-tokens{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:18px;font-weight:700}.checkout-product-meta{margin-left:28px;color:#ffffff75;font-size:12px;font-weight:600;line-height:1.2;letter-spacing:-.01em}.checkout-product-ribbon{position:absolute;top:5px;left:-25px;display:inline-flex;align-items:center;justify-content:center;width:78px;height:18px;transform:rotate(-40deg);background:color-mix(in srgb,var(--accent) 88%,white 12%);color:#fff;font-family:Pretendard Variable,Pretendard,SUIT,Apple SD Gothic Neo,sans-serif;font-size:10px;font-weight:700;letter-spacing:-.01em;box-shadow:0 6px 14px #e8596e33;pointer-events:none;text-rendering:geometricPrecision}.checkout-product-ribbon:after{content:"";position:absolute;inset:-2px;background:linear-gradient(105deg,#fff0 34%,#ffffff29 44%,#ffffffb8,#ffffff29 56%,#fff0 66%);transform:translate(-180%);animation:checkoutRibbonSweep 3.1s ease-in-out infinite}.checkout-product-bonus-chip{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 12px;border-radius:999px;background:color-mix(in srgb,var(--accent) 18%,transparent);color:color-mix(in srgb,var(--accent) 80%,white 20%);font-size:13px;font-weight:700;letter-spacing:-.01em;line-height:1}.checkout-token-icon{width:18px;height:18px;object-fit:contain}.checkout-product-price{font-size:16px;color:#fff9;line-height:1.3;padding-top:2px;flex-shrink:0}.checkout-widget-area{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.checkout-refund-notice{display:grid;gap:10px;padding:14px 16px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#ffffff08}.checkout-refund-title{margin:0;font-size:14px;font-weight:600;color:#ffffffe0}.checkout-refund-list{margin:0;padding-left:18px;color:#ffffff9e;font-size:13px;line-height:1.65}.checkout-refund-link{width:fit-content;color:#ffffffc7;font-size:13px;text-decoration:underline;text-underline-offset:3px}.checkout-error{text-align:center;color:var(--accent);font-size:14px;margin:0}.checkout-pay-btn{width:100%;height:52px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer}.checkout-pay-btn:disabled{opacity:.4;cursor:not-allowed}.checkout-result{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:var(--page-height);padding:40px 20px;text-align:center}.checkout-result h2{font-size:22px;font-weight:700;margin:16px 0 8px}.checkout-result-icon{width:64px;height:64px;border-radius:50%;background:#4ade8026;color:#4ade80;font-size:32px;display:flex;align-items:center;justify-content:center}.checkout-result-icon.error{background:#e8596e26;color:var(--accent)}.checkout-result-detail{font-size:15px;color:#fff9;margin:0 0 8px}.checkout-result-code{font-size:13px;color:#ffffff4d;margin:0 0 24px}.checkout-result-btn{width:100%;max-width:300px;height:52px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;margin-top:24px}.checkout-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes checkoutRibbonSweep{0%,62%,to{transform:translate(-180%)}82%{transform:translate(180%)}}@keyframes spin{to{transform:rotate(360deg)}}.support-page{min-height:var(--page-height);background:radial-gradient(circle at top left,rgba(255,77,77,.12),transparent 24%),linear-gradient(180deg,rgba(255,255,255,.01),transparent 16%),var(--bg-page)}.support-content{max-width:480px;margin:0 auto;padding:20px 16px calc(40px + var(--safe-area-bottom))}.support-loading{min-height:40vh;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.support-form{display:grid;gap:18px}.support-copy{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.6}.support-field{display:grid;gap:8px}.support-field span{font-size:14px;font-weight:700;color:var(--text-primary)}.support-field input,.support-field textarea{width:100%;border:var(--card-border);border-radius:16px;background:var(--bg-panel-strong);color:var(--text-primary);padding:14px 16px;font:inherit;resize:vertical}.support-field textarea{min-height:180px;line-height:1.6}.support-field input::placeholder,.support-field textarea::placeholder{color:var(--text-muted)}.support-error,.support-success{margin:0;font-size:14px}.support-error{color:#ff8f8f}.support-success{color:#9ee6ad}.support-submit{min-height:52px;border:none;border-radius:16px;background:var(--accent-gradient);color:#fff;font-size:16px;font-weight:700;cursor:pointer}.support-submit:disabled{opacity:.7;cursor:not-allowed}@media(min-width:768px){.support-content{max-width:760px;padding:32px 24px calc(56px + var(--safe-area-bottom))}}.withdraw-page{min-height:var(--page-height);background:radial-gradient(circle at top right,rgba(255,77,77,.14),transparent 26%),linear-gradient(180deg,rgba(255,255,255,.01),transparent 16%),var(--bg-page)}.withdraw-content{max-width:480px;margin:0 auto;padding:20px 16px calc(40px + var(--safe-area-bottom))}.withdraw-form{display:grid;gap:18px}.withdraw-copy,.withdraw-warning,.withdraw-error{margin:0;font-size:14px;line-height:1.6}.withdraw-copy{color:var(--text-secondary)}.withdraw-warning{padding:14px 16px;border-radius:16px;border:1px solid rgba(255,98,95,.18);background:#ff625f14;color:#ffb1ae}.withdraw-error{color:#ff8f8f}.withdraw-field{display:grid;gap:8px}.withdraw-field span{font-size:14px;font-weight:700;color:var(--text-primary)}.withdraw-field textarea{width:100%;min-height:180px;padding:14px 16px;border:var(--card-border);border-radius:16px;background:var(--bg-panel-strong);color:var(--text-primary);font:inherit;line-height:1.6;resize:vertical}.withdraw-field textarea::placeholder{color:var(--text-muted)}.withdraw-submit{min-height:52px;border:none;border-radius:16px;background:linear-gradient(135deg,#ff625f,#ff7c66);color:#fff;font-size:16px;font-weight:700;cursor:pointer}.withdraw-submit:disabled{opacity:.7;cursor:not-allowed}@media(min-width:768px){.withdraw-content{max-width:760px;padding:32px 24px calc(56px + var(--safe-area-bottom))}}.admin{min-height:var(--page-height);background:var(--bg-page);color:var(--text-primary);padding:20px;max-width:800px;margin:0 auto}.admin-login{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:20px}.admin-login h1{font-size:24px}.admin-login form{display:flex;gap:10px}.admin-login input{padding:10px 16px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0f;color:#fff;font-size:16px}.admin-login button{padding:10px 20px;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer}.admin-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.admin-header h1{font-size:20px;flex:1}.admin-header button{padding:8px 16px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:none;color:#ffffffb3;cursor:pointer}.admin-back{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:14px}.admin-loading{color:#fff6;text-align:center}.admin-rooms{display:flex;flex-direction:column;gap:8px}.admin-room-row{display:flex;align-items:center;gap:10px}.admin-room-row input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.admin-room-card{flex:1;display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#ffffff0a;cursor:pointer;text-align:left;color:var(--text-primary)}.admin-room-card:hover{background:#ffffff14}.admin-room-card strong{min-width:80px}.admin-room-card span{font-size:13px;color:#ffffff80}.admin-room-date{margin-left:auto}.admin-content{display:flex;flex-direction:column;gap:24px}.admin-section{border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:16px;background:#ffffff05}.admin-section h2{font-size:15px;font-weight:700;color:var(--accent);margin-bottom:12px}.admin-section pre{font-size:12px;line-height:1.6;color:#ffffffb3;white-space:pre-wrap;word-break:break-all;margin:0}.admin-quiz{display:flex;flex-direction:column;gap:6px}.admin-quiz-row{display:flex;gap:12px}.admin-quiz-key{font-size:12px;color:#fff6;min-width:100px}.admin-quiz-val{font-size:14px;color:#ffffffd9}.admin-ai>div{margin-bottom:12px;font-size:14px;line-height:1.7;color:#ffffffb3}.admin-ai strong{color:#ffffff80;font-size:12px;display:block;margin-bottom:4px}.admin-persona{background:#ffffff0a;padding:12px;border-radius:8px;font-size:13px!important}.admin-prompt{background:#ffffff0a;padding:12px;border-radius:8px;max-height:400px;overflow-y:auto}.admin-messages{display:flex;flex-direction:column;gap:10px}.admin-msg{display:flex;gap:8px;font-size:14px;line-height:1.6;padding:10px 12px;border:1px solid rgba(255,255,255,.06);border-radius:10px;background:#ffffff05}.admin-msg-role{font-size:11px;font-weight:600;min-width:50px;flex-shrink:0;padding-top:2px}.admin-msg-user .admin-msg-role{color:#4fc3f7}.admin-msg-assistant .admin-msg-role{color:var(--accent)}.admin-msg-body{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.admin-msg-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:11px;color:#ffffff59}.admin-msg-text{display:block;color:#ffffffbf;white-space:pre-wrap;word-break:break-word}.policy-page{min-height:var(--app-height);background:radial-gradient(circle at 12% 12%,rgba(255,77,77,.12),transparent 18%),radial-gradient(circle at 85% 10%,rgba(255,77,77,.07),transparent 22%),linear-gradient(180deg,#121315,#101113);color:var(--text-primary)}.policy-shell{width:min(920px,calc(100% - 32px));margin:0 auto;padding:32px 0 72px}.policy-header{display:grid;gap:10px;margin-bottom:28px}.policy-title,.policy-content h2{font-family:Pretendard Variable,Pretendard,SUIT,Apple SD Gothic Neo,sans-serif;letter-spacing:-.03em}.policy-title{margin:0;font-size:clamp(2rem,4vw,2.8rem)}.policy-date{margin:0;color:var(--text-secondary)}.policy-content{display:grid;gap:18px;padding:28px;border-radius:24px;background:#ffffff08;border:1px solid rgba(255,255,255,.07);box-shadow:var(--shadow-card)}.policy-content section{display:grid;gap:10px}.policy-content h2,.policy-content p,.policy-content ul{margin:0}.policy-content h2{font-size:1.08rem}.policy-content p,.policy-content li{color:var(--text-secondary);line-height:1.8}.policy-content strong,.policy-content a{color:var(--text-primary)}.policy-content ul{padding-left:20px}@media(max-width:768px){.policy-shell{width:calc(100% - 24px);padding:20px 0 56px}.policy-content{padding:20px 16px}}html,body,#root{margin:0;padding:0}body{font-family:Pretendard Variable,Pretendard,SUIT,Apple SD Gothic Neo,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit}button,input,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--app-height: 100vh;--bottom-tab-height: 74px;--bottom-tab-space: calc(var(--bottom-tab-height) + var(--safe-area-bottom));--page-height: calc(var(--app-height) - var(--safe-area-top) - var(--bottom-tab-space));--bg-page: #121315;--bg-soft: rgba(18, 19, 21, .96);--bg-panel: rgba(28, 30, 34, .9);--bg-panel-strong: rgba(35, 37, 42, .98);--text-primary: #f5f1eb;--text-secondary: rgba(245, 241, 235, .72);--text-muted: rgba(245, 241, 235, .48);--line-soft: rgba(255, 77, 77, .16);--accent: #ff4d4d;--accent-strong: #ff4d4d;--cream: #f5f1eb;--wine: #ff4d4d;--rose: #ff4d4d;--plum: #0f1012;--mint: #1d2125;--hero-gradient: radial-gradient(circle at top left, rgba(255, 77, 77, .14), transparent 26%), linear-gradient(135deg, #17181b 0%, #131417 58%, #101113 100%);--card-gradient: linear-gradient(180deg, rgba(35, 37, 42, .96) 0%, rgba(25, 27, 31, .92) 100%);--accent-gradient: linear-gradient(135deg, #ff4d4d 0%, #ff6f6f 100%);--section-spacing: clamp(3rem, 6vw, 5rem);--landing-stack-gap: clamp(4.5rem, 9vw, 7rem);--radius-pill: 999px;--radius-lg: 26px;--radius-md: 20px;--shadow-soft: 0 18px 40px rgba(0, 0, 0, .28), 0 6px 16px rgba(0, 0, 0, .18);--shadow-card: 0 16px 32px rgba(0, 0, 0, .24), 0 4px 10px rgba(0, 0, 0, .18), inset 0 1px 0 rgba(255, 255, 255, .04);--card-border: 1px solid rgba(255, 77, 77, .14);--card-padding: 24px;--mobile-gutter: 16px}@supports (height: 100dvh){:root{--app-height: 100dvh}}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body,*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}body{line-height:1.5;color:var(--text-primary);overflow-x:hidden;background:var(--bg-page);min-height:var(--app-height)}html,body,#root,.App,.app-shell,.app-main{overscroll-behavior-x:none;overscroll-behavior-y:none}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;background:radial-gradient(circle at 12% 12%,rgba(255,77,77,.14),transparent 18%),radial-gradient(circle at 85% 10%,rgba(255,77,77,.08),transparent 20%),radial-gradient(circle at 60% 85%,rgba(255,255,255,.04),transparent 24%),linear-gradient(180deg,rgba(255,255,255,.03),transparent 22%),radial-gradient(circle at top right,rgba(255,77,77,.06),transparent 24%),var(--bg-page)}#root,.App,.app-shell{width:100%;min-height:var(--app-height)}.App,.app-shell{position:relative;isolation:isolate}.app-shell{padding-bottom:var(--bottom-tab-space)}.app-main{min-height:var(--page-height)}html.chat-page-scroll-locked,body.chat-page-scroll-locked,#root.chat-page-scroll-locked,.app-shell.chat-page-scroll-locked{height:var(--app-height);overflow:hidden}.app-main.chat-page-scroll-locked{height:var(--page-height);min-height:var(--page-height);overflow:hidden}.landing-stack{display:grid;align-content:start;gap:var(--landing-stack-gap);padding-bottom:28px}.landing-stack>*{margin:0}.landing-stack .section-title{font-size:clamp(1.9rem,3.1vw,2.7rem);line-height:1.08;letter-spacing:-.035em}.landing-stack .section-copy{max-width:34rem;font-size:clamp(1rem,1.55vw,1.18rem);line-height:1.75}.container{width:min(1180px,calc(100% - 40px));margin:0 auto}.section{padding:var(--section-spacing) 0;position:relative}@media(min-width:768px){.app-main{width:min(1280px,calc(100% - 64px));margin:0 auto}}.card{background:var(--card-gradient);border:var(--card-border);border-radius:var(--radius-lg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:var(--shadow-card)}.card-tight{border-radius:var(--radius-md)}.card-soft{background:linear-gradient(180deg,#23252afa,#191b1ff0)}.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius-pill);background:#ffffff0a;border:1px solid rgba(255,77,77,.16);color:var(--accent-strong);font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.section-title,.hero-title{font-family:Pretendard Variable,Pretendard,SUIT,Apple SD Gothic Neo,sans-serif;letter-spacing:-.04em;line-height:.96}.section-title{font-size:clamp(2.6rem,5vw,4.4rem);margin:0}.section-copy{margin:0;font-size:clamp(1rem,1.4vw,1.18rem);color:var(--text-secondary);line-height:1.75}.section-head{display:grid;gap:18px;margin-bottom:36px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:0 24px;border-radius:var(--radius-pill);border:1px solid transparent;text-decoration:none;font-size:.98rem;font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}.btn:hover{transform:translateY(-2px)}.btn:focus-visible,a:focus-visible{outline:2px solid rgba(255,77,77,.92);outline-offset:3px}.btn-primary{color:#fff8f5;background:var(--accent-gradient);box-shadow:0 14px 24px #ff4d4d38}.btn-secondary{color:var(--accent-strong);background:#ffffff0a;border-color:#ff4d4d29}.accent-text{color:var(--rose)}@media(max-width:768px){.App>.hero,.App>.selection-board,.App>.landing-rhythm{margin-bottom:0}.landing-stack{gap:72px;padding-bottom:24px}.landing-stack .section-title{font-size:clamp(1.55rem,6vw,2.1rem)}.landing-stack .section-copy{font-size:.95rem;line-height:1.6}.container{width:calc(100% - (var(--mobile-gutter) * 2))}.section{padding:72px 0}}
