:root{--primary-color: #6366f1;--secondary-color: #8b5cf6;--quadrant-high-positive: #f59e0b;--quadrant-high-negative: #ef4444;--quadrant-low-positive: #14b8a6;--quadrant-low-negative: #6366f1;--bg-gradient: linear-gradient(135deg, #fef3c7 0%, #fce7f3 25%, #e0e7ff 50%, #d1fae5 75%, #fef3c7 100%);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color:#333;background:var(--bg-gradient);background-attachment:fixed;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body,#root{min-height:100vh}::selection{background:#6366f14d}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f180}.tooltip-wrapper{position:relative;display:inline-block}.emotion-tooltip{text-align:center}.tooltip-coords{font-size:.75rem;color:#666;margin-top:2px}.tooltip-content{padding:8px 12px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a,0 2px 4px #0000000d;white-space:nowrap;z-index:1000;font-size:.85rem;font-weight:500;pointer-events:none}.tooltip-portal{position:fixed;transform:translate(-50%,-100%)}.tooltip-dimmed strong{color:#999}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#fff}.emotion-dot{position:absolute;width:20px;height:20px;border-radius:50%;transform:translate(-50%,-50%);cursor:pointer;z-index:2;transition:transform .2s ease,background-color .2s ease,box-shadow .2s ease;box-shadow:0 4px 8px #00000026,0 2px 4px #0000001a,inset 0 2px 4px #ffffff4d}.emotion-dot:hover{transform:translate(-50%,-50%) scale(1.4);z-index:100;box-shadow:0 6px 16px #0003,0 3px 6px #00000026,inset 0 2px 4px #fff6}.emotion-dot.dimmed{z-index:1;box-shadow:0 2px 4px #0000001a,0 1px 2px #0000000d,inset 0 1px 2px #fff3}.emotion-dot.selected{transform:translate(-50%,-50%) scale(1.3);z-index:99;box-shadow:0 0 0 3px #fff,0 0 0 5px currentColor,0 6px 16px #0003}.emotion-dot .tooltip-wrapper{display:block;width:100%;height:100%}.dot-inner{width:100%;height:100%;border-radius:50%;border:1px solid rgba(0,0,0,.2)}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.15);opacity:.85}}.emotion-dot.highlighted{animation:pulse 2s ease-in-out infinite}.emotion-dot.highlighted:hover{animation:none}.emotion-grid-container{display:flex;justify-content:center;align-items:center;padding:40px 20px;flex:1}.emotion-grid{position:relative;width:min(80vw,700px);height:min(80vw,700px);background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000001a,0 8px 24px #00000014,inset 0 2px 4px #fffc}.grid-background{position:absolute;inset:0;width:100%;height:100%;border-radius:24px;overflow:hidden;border:2px solid #666666}.axis-labels{position:absolute;inset:0;pointer-events:none}.axis-label{position:absolute;font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.05em}.axis-label.top{top:12px;left:50%;transform:translate(-50%)}.axis-label.bottom{bottom:12px;left:50%;transform:translate(-50%)}.axis-label.left{left:2px;top:50%;transform:translateY(-50%) rotate(-90deg)}.axis-label.right{right:2px;top:50%;transform:translateY(-50%) rotate(90deg)}.quadrant-labels{position:absolute;inset:0;pointer-events:none}.quadrant-label{position:absolute;font-size:.7rem;font-weight:500;color:#0000004d;text-transform:uppercase;letter-spacing:.03em}.quadrant-label.top-left{top:20px;left:20px}.quadrant-label.top-right{top:20px;right:20px}.quadrant-label.bottom-left{bottom:20px;left:20px}.quadrant-label.bottom-right{bottom:20px;right:20px}.dots-container{position:absolute;inset:40px}.category-filter{display:flex;flex-wrap:wrap;gap:8px;padding:16px;justify-content:center;max-width:1000px;margin:0 auto}.category-button{padding:2px 10px;border:none;border-radius:20px;background:#fff;color:#444;font-size:.85rem;font-weight:500;cursor:pointer;transition:transform .2s ease;box-shadow:0 2px 8px #00000014,0 1px 2px #0000000a,inset 0 1px 2px #fffc}.category-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f,0 2px 4px #00000014,inset 0 1px 2px #fffc}.category-button.active{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;box-shadow:0 4px 12px #6366f14d,0 2px 4px #6366f133,inset 0 1px 2px #fff3}.category-button.see-more{background:transparent;color:var(--primary-color);font-weight:600;box-shadow:none;border:1px dashed var(--primary-color)}.category-button.see-more:hover{background:#6366f11a;box-shadow:none}@media(max-width:768px){.category-filter{padding:12px 8px;gap:6px}.category-button{font-size:.75rem;padding:2px 8px}}.emotion-button{display:inline-block;color:#333;border:none;border-radius:16px;padding:6px 12px;font-size:.85rem;cursor:pointer;transition:filter .2s ease,transform .2s ease;text-transform:capitalize;text-decoration:none;white-space:nowrap}.emotion-button:hover{filter:brightness(.95);transform:translateY(-1px)}.emotion-button.disabled{opacity:.5;cursor:not-allowed;background:#e5e5e5;box-shadow:0 2px 0 1px #00000026}.emotion-button.disabled:hover{filter:none;transform:none}.emotion-sidebar{background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026,0 4px 12px #0000001a;padding:20px 24px;display:flex;align-items:center;gap:24px;position:relative;max-width:90vw;overflow:hidden}.sidebar-close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:1.25rem;color:#999;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s ease}.sidebar-close:hover{color:#333}.sidebar-title{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.sidebar-header{font-size:1.25rem;font-weight:700;margin:0;text-transform:capitalize;white-space:nowrap}.sidebar-coords{font-size:.75rem;color:#666}.sidebar-category{display:inline-block;color:#333;border:none;border-radius:20px;padding:6px 16px;font-size:.85rem;font-weight:500;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;white-space:nowrap}.sidebar-category:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.sidebar-section{display:flex;align-items:center;gap:12px;min-width:0;flex-shrink:1}.sidebar-section h3{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#666;margin:0;white-space:nowrap}.sidebar-related{display:flex;flex-wrap:wrap;gap:8px;padding-right:24px}@media(max-width:768px){.emotion-sidebar{flex-direction:column;align-items:flex-start;gap:12px;max-width:none;width:100%;border-radius:0 0 16px 16px;padding:12px 16px 16px}.sidebar-close{top:4px;right:4px}.sidebar-title{padding-right:32px}.sidebar-header{font-size:1.1rem}.sidebar-section{flex-direction:column;align-items:flex-start;gap:8px;width:100%}.sidebar-related{padding-right:0}}.category-drawer{background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026,0 4px 12px #0000001a;padding:20px 24px;display:flex;align-items:center;gap:24px;position:relative;max-width:90vw}.drawer-close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:1.25rem;color:#999;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s ease}.drawer-close:hover{color:#333}.drawer-title{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.drawer-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#999}.drawer-header{font-size:1.25rem;font-weight:700;margin:0;text-transform:capitalize;white-space:nowrap}.drawer-emotions{display:flex;flex-wrap:wrap;gap:8px;padding-right:24px}@media(max-width:768px){.category-drawer{flex-direction:column;align-items:flex-start;gap:12px;max-width:none;width:100%;border-radius:0 0 16px 16px;padding:12px 16px 16px}.drawer-close{top:4px;right:4px}.drawer-title{padding-right:32px}.drawer-header{font-size:1.1rem}.drawer-emotions{padding-right:0}}.home{min-height:100vh;display:flex;flex-direction:column}.home-header{text-align:center;padding:32px 20px 16px}.home-header h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.home-header p{color:#666;margin:8px 0 0;font-size:1rem}.drawer-container{position:fixed;top:0;left:50%;transform:translate(-50%) translateY(-100%);z-index:1000;padding:16px;opacity:0;pointer-events:none;transition:transform .3s ease,opacity .3s ease}.drawer-container.open{transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto}@media(max-width:768px){.home-header{padding:16px 16px 8px}.home-header h1{font-size:1.75rem}.home-header p{font-size:.875rem}.drawer-container{left:0;right:0;transform:translate(0) translateY(-100%);padding:0}.drawer-container.open{transform:translate(0) translateY(0)}}.emotion-detail{min-height:100vh;padding:24px;display:flex;flex-direction:column;align-items:center}.back-button{align-self:flex-start;padding:10px 20px;border:none;border-radius:16px;background:#fff;color:var(--primary-color);font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s ease;box-shadow:0 2px 8px #00000014,0 1px 2px #0000000a,inset 0 1px 2px #fffc;margin-bottom:24px}.back-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f,0 2px 4px #00000014}.detail-card{width:100%;max-width:600px;background:#fff;border-radius:24px;padding:32px;box-shadow:0 20px 60px #0000001a,0 8px 24px #00000014,inset 0 2px 4px #fffc}.emotion-name{font-size:2.5rem;font-weight:700;text-transform:capitalize;margin:0 0 16px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.coordinates{display:flex;gap:24px;margin-bottom:16px}.coord{display:flex;flex-direction:column}.coord-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:.05em}.coord-value{font-size:1.5rem;font-weight:600;color:#333}.category-badge{display:inline-block;padding:6px 14px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;border-radius:20px;font-size:.85rem;font-weight:500;margin-bottom:24px}.detail-section{margin-top:24px;padding-top:24px;border-top:1px solid rgba(0,0,0,.08)}.detail-section h2{font-size:1rem;font-weight:600;color:#444;margin:0 0 12px;text-transform:uppercase;letter-spacing:.03em}.emotion-links{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.emotion-links .tooltip-wrapper{display:flex}.emotion-link{padding:8px 16px;background:#6366f11a;color:var(--primary-color);border-radius:16px;text-decoration:none;font-size:.9rem;font-weight:500;text-transform:capitalize;transition:all .2s ease}.emotion-link:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}.emotion-link.disabled{background:#0000000d;color:#999;cursor:default}.flip-description{font-size:.85rem;color:#666;margin:0 0 12px}.flip-result{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#6366f114;border-radius:16px;text-decoration:none;transition:all .2s ease}.flip-result:hover{background:#6366f126;transform:translate(4px)}.flip-emotion{font-size:1.1rem;font-weight:600;color:var(--primary-color);text-transform:capitalize}.flip-coords{font-size:.8rem;color:#666}.notes-section{margin-top:32px}.notes-textarea{width:100%;min-height:120px;padding:16px;border:2px solid rgba(99,102,241,.2);border-radius:16px;font-family:inherit;font-size:.95rem;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.notes-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a}.notes-textarea::placeholder{color:#aaa}
