code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f9fa;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding:0}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin:0}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}p{margin:0 0 1rem}a{color:#667eea;text-decoration:none;transition:color .2s ease}a:hover{color:#5a67d8}button{font-size:inherit}button,input,select,textarea{font-family:inherit}input:focus,select:focus,textarea:focus{outline:none}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}@media (max-width:768px){.main-content{padding:0}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.loading{align-items:center;color:#666;display:flex;justify-content:center;padding:2rem}.loading:after{animation:dots 1s steps(5) infinite;content:"..."}@keyframes dots{0%,20%{color:#0000;text-shadow:.25em 0 0 #0000,.5em 0 0 #0000}40%{color:#666;text-shadow:.25em 0 0 #0000,.5em 0 0 #0000}60%{text-shadow:.25em 0 0 #666,.5em 0 0 #0000}80%,to{text-shadow:.25em 0 0 #666,.5em 0 0 #666}}.error{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33}.error,.success{margin:1rem 0;padding:1rem}.success{background:#efe;border:1px solid #cfc;border-radius:8px;color:#363}.log-interaction{margin:0 auto;max-width:800px;padding:2rem}.log-header{margin-bottom:2rem;text-align:center}.log-header h2{color:#333;font-size:2.5rem;margin:0 0 .5rem}.log-header p{color:#666;font-size:1.1rem;margin:0}.interaction-form{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem}.form-section{border-bottom:1px solid #f0f0f0;margin-bottom:2rem;padding-bottom:1.5rem}.form-section:last-of-type{border-bottom:none}.form-section h3{color:#333;font-size:1.3rem;margin:0 0 1rem}.contact-selector{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.contact-option{align-items:center;background:#fff;border:2px solid #e1e1e1;border-radius:8px;color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1rem;text-decoration:none;transition:all .2s ease}.contact-option:hover{border-color:#667eea;transform:translateY(-1px)}.contact-option.selected{background:#f8f9ff;border-color:#667eea}.contact-option.add-new{border-style:dashed;color:#667eea}.contact-avatar-small{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1rem;font-weight:700;height:50px;justify-content:center;width:50px}.add-new .contact-avatar-small{background:#e1e1e1;color:#667eea;font-size:1.5rem}.emotion-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.emotion-option{background:#fff;border:2px solid #e1e1e1;border-radius:8px;cursor:pointer;font-weight:500;padding:.75rem 1rem;text-align:center;transition:all .2s ease}.emotion-option:hover{border-color:#667eea;transform:translateY(-1px)}.emotion-option.selected{box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.star-rating{display:flex;gap:.5rem;justify-content:center;margin:1rem 0}.star{background:none;border:none;cursor:pointer;font-size:2rem;opacity:.3;transition:all .2s ease}.star.filled{opacity:1;transform:scale(1.1)}.star:hover{transform:scale(1.2)}.rating-description{color:#666;font-style:italic;margin:.5rem 0 0;text-align:center}.interaction-types{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:.5rem}.type-option{background:#fff;border:2px solid #e1e1e1;border-radius:8px;cursor:pointer;font-weight:500;padding:.75rem;text-align:center;transition:all .2s ease}.type-option.selected,.type-option:hover{border-color:#667eea;transform:translateY(-1px)}.type-option.selected{background:#f8f9ff}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:#333;font-weight:600}.form-group input,.form-group textarea{border:2px solid #e1e1e1;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-group textarea{min-height:100px;resize:vertical}.form-actions{border-top:1px solid #f0f0f0;display:flex;gap:1rem;justify-content:center;margin-top:2rem;padding-top:1.5rem}.button{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:1rem;font-weight:600;padding:.75rem 2rem;text-decoration:none;transition:all .2s ease}.button.primary{background:#667eea;color:#fff}.button.primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px)}.button.primary:disabled{background:#ccc;cursor:not-allowed;transform:none}.button.secondary{background:#f7f7f7;border:1px solid #ddd;color:#555}.button.secondary:hover{background:#f0f0f0;transform:translateY(-1px)}@media (max-width:768px){.log-interaction{padding:1rem}.log-header h2{font-size:2rem}.interaction-form{padding:1.5rem}.contact-selector{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.emotion-grid,.form-row,.interaction-types{grid-template-columns:1fr}.form-actions{flex-direction:column}.star-rating{justify-content:center}.star{font-size:1.8rem}}.contact-detail{margin:0 auto;max-width:1000px;padding:2rem}.contact-header{margin-bottom:2rem}.back-link{align-items:center;color:#667eea;display:inline-flex;font-weight:500;gap:.5rem;margin-bottom:1rem;text-decoration:none;transition:color .2s ease}.back-link:hover{color:#5a67d8;text-decoration:none}.contact-profile{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;gap:1.5rem;padding:2rem}.contact-avatar-large{flex-shrink:0}.contact-avatar-large img{border-radius:50%;height:100px;object-fit:cover;width:100px}.avatar-placeholder-large{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:2rem;font-weight:700;height:100px;justify-content:center;width:100px}.contact-info h1{color:#333;font-size:2rem;margin:0 0 1rem}.contact-tag{border-radius:16px;font-size:.9rem;padding:.4rem .8rem}.contact-actions{flex-shrink:0}.action-button{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.action-button.primary{background:#667eea;color:#fff}.action-button.primary:hover{background:#5a67d8;transform:translateY(-1px)}.action-button.secondary{background:#f7f7f7;border:1px solid #ddd;color:#555}.action-button.secondary:hover{background:#f0f0f0;transform:translateY(-1px)}.contact-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:1.5rem;text-align:center}.stat-label{color:#666;font-size:.9rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.stat-value{color:#333;font-size:1.8rem;font-weight:700}.stat-value.large{font-size:2.5rem}.insights-section,.interactions-section{margin-bottom:2rem}.insights-section h3,.interactions-section h3{color:#333;font-size:1.5rem;margin-bottom:1rem}.insights-list{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:1.5rem}.insight-item{border-bottom:1px solid #f0f0f0;color:#555;line-height:1.6;padding:1rem 0}.insight-item:last-child{border-bottom:none;padding-bottom:0}.interactions-timeline{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:1.5rem}.interaction-timeline-item{border-bottom:1px solid #f0f0f0;display:flex;gap:1rem;padding:1rem 0}.interaction-timeline-item:last-child{border-bottom:none;padding-bottom:0}.interaction-marker{align-items:center;background:#f0f0f0;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;margin-top:.25rem;width:40px}.interaction-type{font-size:1.2rem}.interaction-content{flex:1 1}.interaction-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.interaction-emotion{color:#333;font-weight:600}.interaction-rating{color:#666}.interaction-date{color:#888;font-size:.9rem;margin-left:auto}.interaction-notes{color:#555;line-height:1.6}.contact-actions-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}@media (max-width:768px){.contact-detail{padding:1rem}.contact-profile{flex-direction:column;padding:1.5rem;text-align:center}.contact-info h1{font-size:1.6rem}.contact-stats{gap:1rem;grid-template-columns:1fr}.stat-value.large{font-size:2rem}.interaction-header{align-items:flex-start;flex-direction:column;gap:.5rem}.interaction-date{margin-left:0}.contact-actions-bottom{flex-direction:column}}.emotional-dashboard{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-header{margin-bottom:3rem;text-align:center}.dashboard-header h2{color:#333;font-size:2.5rem;margin:0 0 .5rem}.dashboard-subtitle{color:#666;font-size:1.1rem;margin:0}.metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.metric-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.metric-card:hover{box-shadow:0 8px 15px #00000026;transform:translateY(-2px)}.metric-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.metric-name{color:#333;font-size:1.1rem;font-weight:600}.metric-trend{font-size:1.2rem}.metric-value{display:flex;flex-direction:column;gap:.5rem}.metric-number{color:#333;font-size:2.5rem;font-weight:700}.metric-bar{background:#f0f0f0;border-radius:4px;height:8px;overflow:hidden;width:100%}.metric-fill{border-radius:4px;height:100%;transition:width .3s ease}.recent-section{margin-bottom:3rem}.recent-section h3{color:#333;font-size:1.5rem;margin-bottom:1rem}.interactions-list{display:flex;flex-direction:column;gap:1rem}.interaction-item{background:#fff;border-left:4px solid #667eea;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1rem}.interaction-info{align-items:center;display:flex;justify-content:space-between}.interaction-contact{display:flex;flex-direction:column;gap:.25rem}.interaction-contact strong{color:#333;font-size:1rem}.interaction-emotion{color:#666;font-size:.9rem}.interaction-meta{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.interaction-time{color:#888;font-size:.85rem}.interaction-rating{font-size:.9rem}.insights-section{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;padding:2rem}.insights-section h3{color:#333;font-size:1.5rem;margin-bottom:1rem}.insights-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.insights-card p{color:#555;line-height:1.6;margin:.75rem 0}.insights-card p:first-child{margin-top:0}.insights-card p:last-child{margin-bottom:0}@media (max-width:768px){.emotional-dashboard{padding:1rem}.dashboard-header h2{font-size:2rem}.metrics-grid{gap:1rem;grid-template-columns:1fr}.interaction-info{flex-direction:column;gap:.5rem}.interaction-info,.interaction-meta{align-items:flex-start}.insights-section{padding:1.5rem}}.contact-list{margin:0 auto;max-width:1200px;padding:2rem}.contact-list-header{margin-bottom:2rem}.contact-list-header h2{color:#333;font-size:2.5rem;margin:0 0 1rem}.contact-controls{display:flex;flex-wrap:wrap;gap:1rem}.search-input{border:2px solid #e1e1e1;border-radius:8px;flex:1 1;font-size:1rem;min-width:250px;padding:.75rem;transition:border-color .2s ease}.search-input:focus{border-color:#667eea;outline:none}.sort-select{background:#fff;border:2px solid #e1e1e1;border-radius:8px;cursor:pointer;font-size:1rem;padding:.75rem;transition:border-color .2s ease}.sort-select:focus{border-color:#667eea;outline:none}.contacts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.contact-card{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.contact-card,.contact-card:hover{color:inherit;text-decoration:none}.contact-card:hover{box-shadow:0 8px 15px #00000026;transform:translateY(-2px)}.contact-avatar{flex-shrink:0}.contact-avatar img{object-fit:cover}.avatar-placeholder,.contact-avatar img{border-radius:50%;height:60px;width:60px}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:1.2rem;font-weight:700;justify-content:center}.contact-info{flex:1 1;min-width:0}.contact-name{color:#333;font-size:1.3rem;font-weight:600;margin:0 0 .5rem}.contact-meta{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.interaction-count,.last-interaction{color:#666;font-size:.9rem}.contact-status{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.last-emotion{color:#555;font-size:.95rem}.relationship-score{text-align:right}.score-value{font-size:1.1rem;font-weight:700}.contact-tags{display:flex;flex-wrap:wrap;gap:.5rem}.contact-tag{background:#f0f0f0;border-radius:12px;color:#666;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.no-contacts{color:#666;grid-column:1/-1;padding:3rem;text-align:center}.no-contacts p{font-size:1.1rem;margin:0}@media (max-width:768px){.contact-list{padding:1rem}.contact-list-header h2{font-size:2rem}.contact-controls{flex-direction:column}.search-input{min-width:auto}.contacts-grid{gap:1rem;grid-template-columns:1fr}.contact-card{padding:1rem}.contact-name{font-size:1.1rem}.contact-status{align-items:flex-start;flex-direction:column;gap:.5rem}.relationship-score{text-align:left}}.navigation{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 2rem}.nav-logo{color:#fff;font-size:1.8rem;font-weight:700;margin:0;text-decoration:none}.nav-links{align-items:center;display:flex;gap:1.5rem}.nav-link{border-radius:20px;color:#ffffffe6;font-weight:500;padding:.5rem 1rem;position:relative;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#ffffff1a;color:#fff;transform:translateY(-1px)}.nav-link.active{background:#fff3;box-shadow:inset 0 2px 4px #0000001a;color:#fff}@media (max-width:768px){.nav-container{flex-wrap:wrap;padding:1rem}.nav-links{gap:1rem;justify-content:center;margin-top:.5rem;width:100%}.nav-link{font-size:.9rem;padding:.4rem .8rem}}
/*# sourceMappingURL=main.c400ebf5.css.map*/