@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400;600;700&family=Nunito:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:Nunito,sans-serif;color:#3a3028;background:#f0e6d8;-webkit-font-smoothing:antialiased}.welcome-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,#fdf6ee,#f0e6d8,#e8ddd0)}.welcome-inner{text-align:center;max-width:680px;width:100%}.welcome-title{font-family:Caveat,cursive;font-size:clamp(2.4rem,5vw,3.6rem);color:#3a3028;margin-bottom:8px;font-weight:700;letter-spacing:-.5px}.welcome-subtitle{color:#6b5e50;font-size:1.05rem;margin-bottom:40px;line-height:1.6}.welcome-disclaimer{color:#8b7e6e;font-size:.85rem;margin-bottom:24px;font-style:italic}.type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;width:100%}.type-card{background:#fffcf7;border:2px solid #E0D5C5;border-radius:16px;padding:24px 20px;cursor:pointer;text-align:left;transition:all .25s ease;display:flex;flex-direction:column;gap:8px;font-family:Nunito,sans-serif}.type-card:hover{border-color:#b8a990;transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.type-icon{font-size:1.8rem}.type-label{font-weight:700;color:#3a3028;font-size:1.05rem}.type-desc{color:#8b7e6e;font-size:.88rem;line-height:1.4}.welcome-import{margin-top:32px;border-top:1px solid #E0D5C5;padding-top:20px}.import-label{color:#8b7e6e;font-size:.85rem;cursor:pointer;display:inline-flex;align-items:center;gap:8px;text-decoration:underline}.app-layout{height:100vh;display:flex;flex-direction:column;background:#f0e6d8}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#fffcf7;border-bottom:1px solid #E0D5C5;flex-shrink:0}.toolbar-left{display:flex;align-items:center;gap:10px}.toolbar-title{font-family:Caveat,cursive;font-size:1.4rem;font-weight:700;color:#3a3028}.toolbar-badge{font-size:.72rem;background:#f0e6d8;color:#6b5e50;padding:3px 10px;border-radius:20px;font-weight:600}.toolbar-right{position:relative}.toolbar-menu-btn{background:none;border:1px solid #E0D5C5;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:.85rem;color:#3a3028;font-family:Nunito,sans-serif}.toolbar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.toolbar-dropdown{position:absolute;right:0;top:110%;background:#fffcf7;border:1px solid #E0D5C5;border-radius:12px;padding:8px;box-shadow:0 8px 24px #0000001a;z-index:100;min-width:200px}.toolbar-dropdown-item{display:block;width:100%;text-align:left;padding:8px 12px;background:none;border:none;cursor:pointer;border-radius:8px;font-size:.88rem;color:#3a3028;font-family:Nunito,sans-serif}.toolbar-dropdown-item:hover{background:#f0e6d8}.mobile-tabs{display:none;border-bottom:1px solid #E0D5C5;background:#fffcf7}.mobile-tab{flex:1;padding:10px;border:none;cursor:pointer;background:transparent;color:#8b7e6e;font-weight:400;font-size:.88rem;border-bottom:2px solid transparent;font-family:Nunito,sans-serif}.mobile-tab--active{background:#f0e6d8;color:#3a3028;font-weight:700;border-bottom-color:#3a3028}@media(max-width:767px){.mobile-tabs{display:flex}.panel--hidden-mobile{display:none!important}}.main-content{flex:1;display:flex;overflow:hidden;min-height:0}.panel-chat{width:40%;min-width:320px;max-width:480px;display:flex;flex-direction:column;border-right:1px solid #E0D5C5;background:#f7f1e8}@media(max-width:767px){.panel-chat{width:100%;min-width:0;max-width:none;border-right:none}}.panel-board{flex:1;position:relative;padding:12px;display:flex;flex-direction:column}@media(max-width:767px){.panel-board{width:100%}}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-bubble{max-width:85%;padding:10px 14px;border-radius:16px;font-size:.92rem;line-height:1.55;white-space:pre-wrap}.chat-bubble--user{align-self:flex-end;background:#3a3028;color:#fff;border-bottom-right-radius:4px}.chat-bubble--assistant{align-self:flex-start;background:#fffcf7;color:#3a3028;border:1px solid #E0D5C5;border-bottom-left-radius:4px}.chat-bubble--system{align-self:flex-start;background:transparent;padding:4px 14px}.chat-system-text{color:#8b7e6e;font-size:.82rem}.chat-bubble--loading{align-self:flex-start;padding:10px 18px;border-radius:16px;background:#fffcf7;border:1px solid #E0D5C5;color:#8b7e6e;font-size:.9rem;display:flex;gap:4px;align-items:center}.dot{animation:pulse 1.2s infinite}.dot-2{animation-delay:.2s}.dot-3{animation-delay:.4s}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.chat-input-bar{padding:12px 16px;border-top:1px solid #E0D5C5;background:#fffcf7;display:flex;gap:8px}.chat-input{flex:1;padding:10px 14px;border-radius:12px;border:1px solid #E0D5C5;background:#fff;outline:none;font-size:.92rem;font-family:Nunito,sans-serif;color:#3a3028}.chat-input:focus{border-color:#b8a990}.chat-send{padding:10px 20px;border-radius:12px;border:none;background:#3a3028;color:#fff;cursor:pointer;font-size:.92rem;font-weight:600;font-family:Nunito,sans-serif}.chat-send:disabled{background:#ccc;cursor:default}.whiteboard-container{width:100%;height:100%;background:#fff8f0;border-radius:12px;overflow:hidden}.whiteboard-svg{width:100%;height:100%;touch-action:none;-webkit-user-select:none;user-select:none}.legend{position:absolute;top:20px;left:20px;background:#fffcf7ee;border-radius:10px;padding:8px 12px;font-size:.7rem;border:1px solid #E0D5C5;color:#6b5e50;z-index:5;max-width:160px}.legend-title{font-size:.75rem}.legend-items{margin-top:4px;display:flex;flex-direction:column;gap:3px}.legend-item{display:flex;align-items:center;gap:6px}.person-detail{position:absolute;bottom:12px;left:12px;right:12px;background:#fffcf7;border-radius:12px;padding:12px 16px;border:1px solid #E0D5C5;box-shadow:0 4px 16px #00000014;z-index:10}.person-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;color:#3a3028}.person-detail-close{background:none;border:none;cursor:pointer;font-size:1.1rem;color:#8b7e6e}.emotion-chips{display:flex;gap:6px;flex-wrap:wrap}.emotion-chip{padding:4px 10px;border-radius:20px;border:1px solid #E0D5C5;background:#fff;font-size:.78rem;cursor:pointer;font-weight:400;font-family:Nunito,sans-serif}.emotion-chip--active{font-weight:700;border-width:2px}.wb-person-appear{animation:wb-scale-in .6s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes wb-scale-in{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.wb-person-pulse{animation:wb-pulse-scale .8s ease-out}@keyframes wb-pulse-scale{0%{transform:scale(1)}30%{transform:scale(1.18)}60%{transform:scale(.95)}to{transform:scale(1)}}.wb-person-emotion{animation:wb-emotion-flash .7s ease-out}@keyframes wb-emotion-flash{0%{opacity:1}25%{opacity:.5;transform:scale(1.12)}50%{opacity:1;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.wb-ripple{animation:wb-ripple-expand 1s ease-out forwards}@keyframes wb-ripple-expand{0%{r:2.5;opacity:.8;stroke-width:.6}to{r:10;opacity:0;stroke-width:.1}}.wb-fade-out{animation:wb-fade-out .5s ease-out forwards}@keyframes wb-fade-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.5)}}.wb-line-draw{animation:wb-draw-line .8s ease-out forwards}@keyframes wb-draw-line{0%{stroke-dashoffset:200;opacity:.3}to{stroke-dashoffset:0;opacity:.7}}.wb-line-glow{animation:wb-glow-fade 1.2s ease-out forwards}@keyframes wb-glow-fade{0%{opacity:.5;stroke-width:1.5}to{opacity:0;stroke-width:.1}}.wb-text-appear{animation:wb-text-in .6s ease-out .3s both}@keyframes wb-text-in{0%{opacity:0}to{opacity:1}}
