@import"https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500&family=Noto+Sans+JP:wght@300;400&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{font-family:Zen Kaku Gothic New,Noto Sans JP,sans-serif}.app{min-height:var(--app-height, 100dvh);background:#f5f0eb;background-image:radial-gradient(ellipse at 20% 50%,rgba(220,205,190,.4) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(235,220,200,.3) 0%,transparent 50%);display:flex;flex-direction:column;align-items:center;padding:0 16px}.screen{width:100%;max-width:960px;min-height:var(--app-height, 100dvh);display:flex;flex-direction:column;animation:fadeUp .4s ease;background:#fffcf857;border-left:1px solid rgba(220,200,180,.45);border-right:1px solid rgba(220,200,180,.45)}.welcome-screen{max-width:480px;justify-content:center;align-items:center;padding:48px 32px;text-align:center;gap:0;background:transparent;border:0}.welcome-icon{width:64px;height:64px;background:#b48c641f;border-radius:20px;border:1px solid rgba(180,140,100,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.welcome-title{font-size:22px;font-weight:400;color:#5a3e28;letter-spacing:.12em;margin-bottom:10px}.welcome-sub{font-size:13px;color:#9a7a60;font-weight:400;line-height:1.8;margin-bottom:48px}.welcome-enter{padding:14px 48px;background:linear-gradient(135deg,#c49a6c,#a8784a);border:none;border-radius:14px;color:#fff;font-size:15px;font-family:inherit;font-weight:400;letter-spacing:.08em;cursor:pointer;box-shadow:0 4px 16px #a8784a40;transition:transform .1s,opacity .2s}.welcome-enter:active{transform:scale(.97);opacity:.9}.welcome-note{font-size:11px;color:#c4a888;margin-top:20px;line-height:1.8;font-weight:400}.loading-dots{font-size:13px;color:#9a7a60;margin-top:8px}.loading-dots:after{content:"";animation:dots 6s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"・"}50%{content:"・・"}75%{content:"・・・"}to{content:""}}.auth-screen{max-width:480px;justify-content:center;padding:32px 24px;background:transparent;border:0}.auth-logo{text-align:center;margin-bottom:36px}.auth-logo h1{font-size:18px;font-weight:400;color:#5a3e28;letter-spacing:.1em}.auth-logo p{font-size:11px;color:#9a7a60;margin-top:5px;font-weight:400}.auth-card{background:#fffcf8e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:28px 24px;border:1px solid rgba(220,200,180,.5);box-shadow:0 4px 24px #a0785014}.auth-tabs{display:flex;background:#b48c6414;border-radius:10px;padding:3px;margin-bottom:24px}.auth-tab{flex:1;padding:8px;border:none;background:transparent;border-radius:8px;font-size:13px;color:#9a7a60;cursor:pointer;font-family:inherit;transition:all .2s}.auth-tab.active{background:#fff;color:#5a3e28;box-shadow:0 1px 6px #a078501f}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;color:#9a7a60;margin-bottom:5px;letter-spacing:.08em}.form-input{width:100%;padding:11px 13px;border:1px solid rgba(180,140,100,.2);border-radius:10px;font-size:14px;color:#5a3e28;background:#fffcf8e6;font-family:inherit;font-weight:400;outline:none;transition:border-color .2s}.form-input:focus{border-color:#b48c6473}.form-input::placeholder{color:#c4a888}textarea.form-input{resize:none;height:68px;line-height:1.6}.btn-primary{width:100%;padding:13px;background:linear-gradient(135deg,#c49a6c,#a8784a);border:none;border-radius:12px;color:#fff;font-size:14px;font-family:inherit;font-weight:400;letter-spacing:.05em;cursor:pointer;margin-top:6px;transition:opacity .2s,transform .1s}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary:not(:disabled):active{transform:scale(.98);opacity:.9}.auth-note{text-align:center;font-size:11px;color:#b89878;margin-top:18px;line-height:1.8;font-weight:400}.auth-error{color:#c47a6c;font-size:12px;margin-bottom:8px}.auth-hint{font-size:11px;color:#b89878;line-height:1.7;margin-bottom:12px}.btn-secondary{width:100%;padding:11px;background:transparent;border:1px solid rgba(180,140,100,.3);border-radius:12px;color:#a8784a;font-size:14px;cursor:pointer;transition:opacity .2s}.btn-secondary:active{opacity:.7}.btn-text{width:100%;padding:10px;background:transparent;border:none;color:#b89878;font-size:12px;cursor:pointer;margin-top:4px;text-decoration:underline}.btn-text:active{opacity:.6}.pw-field{position:relative;display:flex;align-items:center}.pw-field .form-input{flex:1;padding-right:52px}.pw-toggle{position:absolute;right:10px;background:none;border:none;color:#b89878;cursor:pointer;padding:4px;display:flex;align-items:center}.pw-toggle:active{opacity:.6}.room-header{padding:18px 20px 14px;display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid rgba(180,140,100,.12);background:#fffcf899;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.room-header>div:last-child{flex-wrap:wrap;justify-content:flex-end}.room-header h2{font-size:16px;font-weight:400;color:#5a3e28;letter-spacing:.05em}.room-header p{font-size:11px;color:#a88868;margin-top:2px;font-weight:400}.online-badge{display:flex;align-items:center;gap:5px;font-size:11px;color:#9a7a60;font-weight:400}.online-dot{width:6px;height:6px;background:#a8c49a;border-radius:50%;animation:pulse 2.5s infinite}.bottom-nav{display:flex;border-top:1px solid rgba(180,140,100,.12);background:#fffcf8cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;bottom:0}.nav-btn{flex:1;padding:12px 4px 14px;border:none;background:transparent;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:3px;transition:opacity .2s}.nav-btn:active{opacity:.7}.nav-icon{font-size:18px}.nav-label{font-size:10px;color:#a88868;font-weight:400;letter-spacing:.05em}.nav-btn.active .nav-label{color:#a8784a;font-weight:400}.nav-btn.active .nav-icon{filter:saturate(1.5)}.stamp-area{padding:14px 20px;border-bottom:1px solid rgba(180,140,100,.08);background:#fffcf866}.stamp-label{font-size:10px;color:#b89878;letter-spacing:.1em;margin-bottom:9px;font-weight:400}.stamps{display:flex;gap:7px;flex-wrap:wrap}.stamp{flex:0 1 auto;padding:6px 13px;border-radius:20px;border:1px solid rgba(180,140,100,.22);background:#fffcf8b3;font-size:12px;color:#7a5a40;cursor:pointer;font-family:inherit;font-weight:400;transition:all .2s;letter-spacing:.03em;white-space:nowrap}.stamp.selected{background:#c49a6c2e;border-color:#b48c6473;color:#5a3e28}.user-list{flex:1;padding:14px 20px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;align-content:start}.section-label{font-size:10px;color:#b89878;letter-spacing:.12em;margin-bottom:10px;font-weight:400}.user-list .section-label{grid-column:1 / -1;margin-bottom:0}.user-card{display:flex;align-items:center;padding:13px 15px;background:#fffcf8bf;border-radius:14px;border:1px solid rgba(220,200,180,.5);box-shadow:0 1px 8px #a078500f;transition:all .2s;min-width:0}.user-avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#e8d4bc,#d4b898);display:flex;align-items:center;justify-content:center;font-size:18px;margin-right:11px;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:14px;color:#5a3e28;font-weight:400;margin-bottom:2px}.user-intro{font-size:11px;color:#9a7a60;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-stamp-tag{display:inline-block;margin-top:4px;font-size:10px;color:#a8784a;background:#c49a6c1f;border:1px solid rgba(180,140,100,.2);border-radius:6px;padding:2px 8px;font-weight:400}.user-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.status-badge{font-size:10px;padding:3px 8px;border-radius:6px;font-weight:400;letter-spacing:.03em}.status-waiting{background:#a8c49a26;color:#5a8a5a;border:1px solid rgba(168,196,154,.3)}.status-chatting{background:#b4a0821f;color:#9a7a50;border:1px solid rgba(180,160,130,.25)}.knock-btn{padding:5px 11px;background:#c49a6c1f;border:1px solid rgba(180,140,100,.25);border-radius:8px;font-size:11px;color:#7a5a40;cursor:pointer;font-family:inherit;font-weight:400;transition:all .2s}.knock-btn:active{background:#c49a6c40}.room-log{padding:10px 20px 16px;border-top:1px solid rgba(180,140,100,.08);background:#fffcf84d;max-height:220px;overflow-y:auto}.log-label{font-size:10px;color:#c4a888;letter-spacing:.1em;margin-bottom:7px;font-weight:400}.log-item{font-size:12px;color:#9a7a60;font-weight:400;padding:5px 0;border-bottom:1px solid rgba(180,140,100,.07);line-height:1.5}.log-item:last-child{border-bottom:none}.log-time{font-size:10px;color:#c4a888;margin-right:7px}.empty-room{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px;text-align:center}.empty-room p{font-size:14px;color:#9a7a60;font-weight:400;line-height:1.9;margin-bottom:28px}.ai-chat-btn{padding:12px 32px;background:linear-gradient(135deg,#c49a6c,#a8784a);border:none;border-radius:12px;color:#fff;font-size:14px;font-family:inherit;font-weight:400;letter-spacing:.05em;cursor:pointer}.chat-screen{height:var(--app-height, 100dvh);min-height:unset;overflow:hidden;transform:translateY(var(--visual-viewport-offset-top, 0))}.chat-header{padding:14px 18px;display:flex;align-items:center;gap:11px;border-bottom:1px solid rgba(180,140,100,.12);background:#fffcf899;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:5}.back-btn{width:32px;height:32px;border:none;background:#b48c641a;border-radius:8px;color:#7a5a40;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}.chat-header-info h3{font-size:15px;font-weight:400;color:#5a3e28}.chat-header-info p{font-size:11px;color:#a88868;font-weight:400;margin-top:1px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.chat-header-stamp{background:#b48c641f;border-radius:6px;padding:1px 6px;font-size:10px;color:#8a6848}.chat-notice{margin:10px 14px;padding:9px 13px;background:#b48c6412;border-radius:10px;font-size:11px;color:#a88868;text-align:center;font-weight:400;line-height:1.7}.messages{flex:1 1 auto;min-height:0;padding:8px 14px 14px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:9px}.message{max-width:80%;animation:fadeUp .3s ease}.message.mine{align-self:flex-end}.message.theirs{align-self:flex-start}.message-bubble{padding:10px 13px;border-radius:16px;font-size:14px;line-height:1.6;font-weight:400;letter-spacing:.02em;white-space:pre-wrap;word-break:break-word}.message.mine .message-bubble{background:linear-gradient(135deg,#c49a6c,#a8784a);color:#fff;border-bottom-right-radius:4px}.message.theirs .message-bubble{background:#fffcf8eb;color:#5a3e28;border:1px solid rgba(220,200,180,.5);border-bottom-left-radius:4px;box-shadow:0 1px 6px #a0785014}.message-time{font-size:10px;color:#c4a888;margin-top:3px;font-weight:400;text-align:right}.message.theirs .message-time{text-align:left}.typing{align-self:flex-start}.typing-bubble{background:#fffcf8eb;border:1px solid rgba(220,200,180,.5);border-radius:16px 16px 16px 4px;padding:10px 16px;display:flex;gap:4px;align-items:center}.typing-dot{width:6px;height:6px;background:#c4a888;border-radius:50%;animation:typingDot 1.2s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.chat-input-area{flex:0 0 auto;width:100%;box-sizing:border-box;padding:12px 12px max(12px,env(safe-area-inset-bottom));border-top:1px solid rgba(180,140,100,.1);background:#fffcf899;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;gap:12px;align-items:center}.chat-input{flex:1;min-width:0;width:0;padding:10px 13px;border:1px solid rgba(180,140,100,.2);border-radius:12px;font-size:16px;color:#5a3e28;background:#fffcf8e6;font-family:inherit;font-weight:400;outline:none;resize:none;line-height:1.5;max-height:100px}.send-btn{flex:0 0 40px;width:40px;height:40px;background:linear-gradient(135deg,#c49a6c,#a8784a);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:active{opacity:.8}.end-chat-area{padding:0 14px 6px;text-align:center}.end-chat-btn{background:none;border:none;font-size:12px;color:#b89878;cursor:pointer;font-family:inherit;font-weight:400;letter-spacing:.05em;text-decoration:underline;text-underline-offset:3px}.wave-screen{flex:1;overflow-y:auto;padding:20px;width:100%;max-width:760px;margin:0 auto}.wave-header{margin-bottom:20px}.wave-header h3{font-size:16px;font-weight:400;color:#5a3e28;margin-bottom:4px}.wave-header p{font-size:12px;color:#9a7a60;font-weight:400;line-height:1.6}.wave-chart{background:#fffcf8cc;border-radius:16px;border:1px solid rgba(220,200,180,.5);padding:20px 16px;margin-bottom:20px}.wave-chart-title{font-size:11px;color:#b89878;letter-spacing:.1em;margin-bottom:4px}.wave-chart-sub{font-size:10px;color:#c4a888;font-weight:400;margin-bottom:14px}.wave-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.wave-scroll::-webkit-scrollbar{height:3px}.wave-scroll::-webkit-scrollbar-track{background:#b48c640f;border-radius:2px}.wave-scroll::-webkit-scrollbar-thumb{background:#b48c6433;border-radius:2px}.wave-bars{display:flex;align-items:flex-end;gap:4px;height:80px;margin-bottom:6px}.wave-bar-wrap{display:flex;align-items:flex-end;flex-shrink:0;width:18px}.wave-bar{width:100%;border-radius:3px 3px 0 0;transition:height .4s ease;min-height:3px}.wave-bar.good{background:linear-gradient(to top,#a8c49a,#c8dfc0)}.wave-bar.mid{background:linear-gradient(to top,#c4a888,#ddc4a0)}.wave-bar.bad{background:linear-gradient(to top,#c49a7a,#ddb898)}.wave-bar.empty{background:#b48c641a}.wave-day{font-size:9px;color:#c4a888}.wave-today-stamp{background:#fffcf8cc;border-radius:16px;border:1px solid rgba(220,200,180,.5);padding:18px 16px;margin-bottom:20px}.wave-today-title{font-size:11px;color:#b89878;letter-spacing:.1em;margin-bottom:12px}.wave-stamps{display:flex;gap:7px;flex-wrap:wrap}.wave-stamp{flex:0 1 auto;padding:8px 14px;border-radius:20px;border:1px solid rgba(180,140,100,.22);background:#fffcf8b3;font-size:12px;color:#7a5a40;cursor:pointer;font-family:inherit;font-weight:400;transition:all .2s;white-space:nowrap}.wave-stamp.selected{background:#c49a6c33;border-color:#b48c6480;color:#5a3e28}.wave-log{background:#fffcf8cc;border-radius:16px;border:1px solid rgba(220,200,180,.5);padding:18px 16px}.wave-log-title{font-size:11px;color:#b89878;letter-spacing:.1em;margin-bottom:12px}.wave-log-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(180,140,100,.07)}.wave-log-item:last-child{border-bottom:none}.wave-log-date{font-size:11px;color:#b89878;font-weight:400;width:48px;flex-shrink:0}.wave-log-tag{font-size:11px;color:#a8784a;background:#c49a6c1f;border:1px solid rgba(180,140,100,.2);border-radius:6px;padding:2px 9px;font-weight:400}.hourly-chart{background:#fffcf8cc;border-radius:16px;border:1px solid rgba(220,200,180,.5);padding:18px 16px;margin-bottom:20px}.hourly-title{font-size:11px;color:#b89878;letter-spacing:.1em;margin-bottom:4px}.hourly-sub{font-size:10px;color:#c4a888;font-weight:400;margin-bottom:14px}.hourly-bars{display:flex;align-items:flex-end;gap:2px;height:56px;margin-bottom:6px}.hourly-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.hourly-bar{width:100%;border-radius:2px 2px 0 0;min-height:2px;transition:height .4s ease}.hourly-bar.active-hour{background:linear-gradient(to top,#c49a6c,#ddb888)}.hourly-bar.inactive-hour{background:#b48c641f}.hourly-labels{display:flex;justify-content:space-between;padding:0 2px}.hourly-label{font-size:9px;color:#c4a888}.history-screen{flex:1;overflow-y:auto;padding:20px;width:100%;max-width:760px;margin:0 auto}.history-header{margin-bottom:18px}.history-header h3{font-size:16px;font-weight:400;color:#5a3e28;margin-bottom:4px}.history-header p{font-size:12px;color:#9a7a60;font-weight:400}.history-card{background:#fffcf8cc;border-radius:14px;border:1px solid rgba(220,200,180,.5);padding:15px 16px;margin-bottom:10px;transition:all .2s;box-shadow:0 1px 6px #a078500f}.history-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;cursor:pointer}.history-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#e8d4bc,#d4b898);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.history-name{font-size:14px;color:#5a3e28;font-weight:400}.history-date{font-size:11px;color:#b89878;margin-left:auto;font-weight:400}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#50321e40;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:100;animation:fadeUp .2s ease}.modal{background:#fffcf8;border-radius:20px;padding:28px 24px;width:100%;max-width:320px;text-align:center;box-shadow:0 8px 40px #7850281f;border:1px solid rgba(220,200,180,.5)}.modal h3{font-size:17px;font-weight:400;color:#5a3e28;margin-bottom:8px;letter-spacing:.05em}.modal p{font-size:13px;color:#9a7a60;font-weight:400;line-height:1.7;margin-bottom:18px}.modal-input{width:100%;padding:10px 13px;border:1px solid rgba(180,140,100,.2);border-radius:10px;font-size:13px;color:#5a3e28;background:#f5f0ebcc;font-family:inherit;font-weight:400;outline:none;margin-bottom:14px}.modal-input::placeholder{color:#c4a888}.modal-actions{display:flex;gap:8px}.btn-secondary{flex:1;padding:11px;background:#b48c6414;border:1px solid rgba(180,140,100,.18);border-radius:10px;font-size:13px;color:#9a7a60;cursor:pointer;font-family:inherit;font-weight:400}.btn-modal-primary{flex:1;padding:11px;background:linear-gradient(135deg,#c49a6c,#a8784a);border:none;border-radius:10px;font-size:13px;color:#fff;cursor:pointer;font-family:inherit;font-weight:400}@media (max-width: 560px){.app{padding:0}.screen{max-width:none;border:0;background:transparent}.room-header{align-items:flex-start;padding:14px 14px 12px}.room-header h2{font-size:15px}.stamp-area,.user-list,.room-log{padding-left:14px;padding-right:14px}.stamps,.wave-stamps{gap:6px}.stamp,.wave-stamp{flex:1 1 calc(50% - 6px);padding-left:8px;padding-right:8px;text-align:center}.user-list{display:block}.user-card{margin-bottom:8px;align-items:flex-start}.user-right{max-width:96px}.knock-btn,.status-badge{white-space:nowrap}.wave-screen,.history-screen{padding:16px 14px;max-width:none}.history-card-top{align-items:flex-start}.history-date{margin-left:4px;flex-shrink:0}.message{max-width:88%}.modal-overlay{padding:16px}}@media (min-width: 760px){.room-log{margin-top:auto}.bottom-nav{align-self:center;width:100%}.message{max-width:68%}}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}
