*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;min-height:100vh;margin:0}#root{width:100%;min-height:100vh}:root{--blue-600: #2563eb;--blue-500: #3b82f6;--blue-100: #dbeafe;--blue-50: #eff6ff;--gray-900: #111111;--gray-700: #333333;--gray-500: #555555;--gray-400: #777777;--gray-300: #999999;--gray-200: #cccccc;--gray-100: #e5e5e5;--gray-50: #f7f8fa;--white: #ffffff;--border: #e2e5ea;--danger: #dc2626;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--shadow-sm: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.03);--shadow-md: 0 4px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--shadow-lg: 0 8px 24px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04)}body{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Inter,sans-serif;background:var(--gray-50);color:var(--gray-900);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--white);border-bottom:1px solid var(--border);padding:0 2.5rem;height:auto;min-height:56px;display:flex;align-items:center;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb}.header .container{width:100%;padding:0}.header-content{display:flex;align-items:center;justify-content:space-between;gap:2rem;width:100%;padding:.75rem 0}.header h1{font-size:.95rem;font-weight:700;color:var(--gray-900);white-space:nowrap;letter-spacing:-.01em;margin:0}.header p{font-size:.8rem;color:var(--gray-400);border-left:1px solid var(--border);padding-left:1rem;white-space:nowrap;margin:.25rem 0 0}.header-user{display:flex;align-items:center;gap:1rem;white-space:nowrap}.user-name{font-size:.875rem;font-weight:500;color:var(--gray-700)}.logout-btn{font-size:.8rem;padding:.5rem 1rem;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--gray-700);cursor:pointer;transition:all .2s ease;font-weight:500}.logout-btn:hover{background:var(--gray-200);border-color:var(--gray-300)}.logout-btn:active{transform:scale(.98)}.container{width:100%;padding:0}.main-content{flex:1;padding:2rem 2.5rem;display:flex;flex-direction:column;gap:1.75rem}.search-section{margin:0}.user-selector{background:var(--white);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease}.user-selector:hover{box-shadow:var(--shadow-md)}.user-selector form{display:flex;gap:.75rem;align-items:flex-end}.form-group{flex:1;display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.75rem;font-weight:600;color:var(--gray-500)}.input{padding:.6rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;background:var(--gray-50);color:var(--gray-900);transition:all .2s ease}.input:hover{border-color:var(--gray-300);background:var(--white)}.input:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px #2563eb1f;background:var(--white)}.input::placeholder{color:var(--gray-300)}.button{padding:.6rem 1.5rem;border:none;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s ease}.button-primary{background:var(--blue-600);color:var(--white);box-shadow:0 1px 3px #2563eb40}.button-primary:hover{background:var(--blue-500);box-shadow:0 3px 8px #2563eb4d;transform:translateY(-1px)}.button-primary:active{transform:translateY(0);box-shadow:0 1px 2px #2563eb33}.button-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.state-container{padding:2rem;text-align:center}.loading{display:flex;flex-direction:column;align-items:center;gap:.75rem}.spinner{width:2rem;height:2rem;border:2.5px solid var(--gray-100);border-top-color:var(--blue-600);border-radius:50%;animation:spin .8s cubic-bezier(.45,.05,.55,.95) infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading p{font-size:.85rem;color:var(--gray-400)}.error{background:#fef2f2;color:var(--danger);padding:.85rem 1.15rem;border-radius:var(--radius-md);border:1px solid #fecaca;font-size:.85rem}.metrics-section{margin:0;margin-bottom:1.75rem}.content-grid{display:grid;grid-template-columns:450px 1fr;gap:1.5rem;align-items:start}.member-center{display:flex;flex-direction:column;justify-self:stretch}.summary-right{display:none}.metrics-container{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.metric-card{background:var(--white);padding:1.5rem 1.75rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .25s ease}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--blue-100)}.metric-card.wide{grid-column:1 / -1}.metric-card h3{font-size:.7rem;color:var(--gray-400);margin-bottom:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.metric-value{font-size:1.75rem;font-weight:700;color:var(--gray-900);line-height:1.2;word-break:break-all;letter-spacing:-.02em}.event-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.5rem}.event-list li{display:flex;justify-content:space-between;align-items:center;padding:.6rem .85rem;background:var(--gray-50);border-radius:var(--radius-sm);border:1px solid var(--gray-100);transition:all .15s ease}.event-list li:hover{background:var(--blue-50);border-color:var(--blue-100)}.event-name{font-weight:500;font-size:.825rem;color:var(--gray-900)}.event-count{background:var(--blue-600);color:var(--white);padding:.2rem .6rem;border-radius:2rem;font-size:.7rem;font-weight:600;min-width:1.5rem;text-align:center}.timeline-section{margin:0;padding:0;width:450px}.event-timeline{background:var(--white);padding:1.75rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;width:100%}.event-timeline h2{margin:0;padding:0;font-size:1.25rem;font-weight:600;color:var(--gray-900);display:block}.session-summary{display:flex;gap:.5rem;margin-bottom:1.25rem}.event-timeline.empty{text-align:center;padding:2rem;color:var(--gray-400);font-size:.85rem}.session-group{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:1rem;overflow:hidden;transition:box-shadow .2s ease}.session-group:hover{box-shadow:var(--shadow-md)}.session-group:last-child{margin-bottom:0}.session-header{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;background:var(--blue-50);border-bottom:1px solid var(--blue-100)}.session-label{font-size:.75rem;font-weight:700;color:var(--blue-600);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.session-meta{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--gray-500);font-variant-numeric:tabular-nums}.session-meta span:not(.session-duration):before{content:"·";margin-right:.5rem;color:var(--gray-300)}.session-duration{background:var(--blue-600);color:var(--white);padding:.1rem .5rem;border-radius:2rem;font-weight:600;font-size:.65rem}.session-footer{padding:.5rem 1rem;background:var(--gray-50);border-top:1px solid var(--border);font-size:.7rem;color:var(--gray-400);text-align:center}.timeline-delta-row{display:flex;align-items:center;justify-content:center;width:4.5rem;min-width:4.5rem;padding:.1rem 0}.delta-label{font-size:.625rem;font-weight:600;color:var(--gray-400);white-space:nowrap;font-variant-numeric:tabular-nums;padding:.05rem .4rem;background:var(--white);border-radius:2rem;border:1px solid var(--gray-100);position:relative;z-index:3}.step-marker{display:none}.timeline-item:has(.step-marker.start) .timeline-step:before{background:#16a34a;box-shadow:0 0 0 3px #bbf7d0}.timeline-item:has(.step-marker.end) .timeline-step:before{background:var(--gray-400);box-shadow:0 0 0 3px var(--gray-100)}.timeline{display:flex;flex-direction:column;padding:.5rem .75rem;position:relative}.timeline:before{content:"";position:absolute;top:1.35rem;bottom:1.35rem;left:calc(3rem - 1.5px);width:3px;background:var(--blue-200, #bfdbfe);border-radius:2px;z-index:0}.timeline-item{display:flex;align-items:stretch;position:relative;cursor:pointer}.timeline-item.clickable{cursor:pointer}.timeline-item.clickable:hover .timeline-content{background:var(--blue-50);border-color:var(--blue-500);box-shadow:0 0 0 2px #2563eb1a}.timeline-step{width:4.5rem;min-width:4.5rem;display:flex;flex-direction:column;align-items:center;position:relative;padding-top:.85rem;font-size:0;color:transparent}.timeline-step:before{content:"";width:.625rem;height:.625rem;border-radius:50%;background:var(--blue-600);z-index:2;flex-shrink:0;box-shadow:0 0 0 3px var(--blue-100)}.timeline-step:after{display:none}.timeline-item:last-child .timeline-step:after{display:none}.timeline-content{flex:1;padding:.75rem 1rem;margin:.2rem 0;border-radius:var(--radius-sm);transition:all .2s ease;border:1px solid transparent}.timeline-content:hover{background:var(--blue-50);border-color:var(--blue-100)}.timeline-row{display:flex;align-items:baseline;gap:.5rem}.timeline-event-name{font-size:.85rem;color:var(--gray-900);font-weight:600}.timeline-time{font-size:.7rem;color:var(--gray-400);font-weight:400;font-variant-numeric:tabular-nums;white-space:nowrap;margin-left:.5rem;flex-shrink:0}.timeline-details{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.25rem}.badge{display:inline-block;padding:.15rem .55rem;border-radius:2rem;font-size:.65rem;color:var(--blue-600);background:var(--blue-50);font-weight:500;border:1px solid var(--blue-100);transition:all .15s ease}.badge:hover{background:var(--blue-100)}.footer{background:var(--white);border-top:1px solid var(--border);padding:1.25rem 2.5rem;color:var(--gray-400);font-size:.75rem;text-align:center;margin-top:auto}@media(max-width:1024px){.metrics-container{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.header{padding:0 1.25rem}.header-content{flex-wrap:wrap;gap:.75rem}.main-content{padding:1.25rem}.footer{padding:1rem 1.25rem}.metric-card:hover,.timeline-content:hover{transform:none}.header h1{font-size:.85rem}.header p{display:none}.header-user{gap:.5rem}.user-name{display:none}.user-selector form{flex-direction:column}.button{width:100%}.metrics-container{grid-template-columns:repeat(2,1fr)}.event-list{grid-template-columns:1fr}}@media(max-width:480px){.header{padding:0 1rem}.header-content{flex-direction:column;align-items:flex-start}.header-user,.logout-btn{width:100%}.main-content{padding:1rem;gap:1rem}.metrics-container{grid-template-columns:1fr}.metric-value{font-size:1.25rem}}.event-detail-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.event-detail-modal{background:#1a1a1a;border:1px solid #333;border-radius:8px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #000000b3}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #333;background:#0d0d0d;position:sticky;top:0;z-index:10}.modal-header h2{margin:0;font-size:1.5rem;color:#fff}.modal-close{background:none;border:none;color:#999;font-size:2rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#fff}.modal-content{padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section h3{margin:0 0 1rem;font-size:.95rem;color:#0ea5e9;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #333;padding-bottom:.5rem}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem 0;font-size:.9rem;border-bottom:1px solid #222}.detail-row:last-child{border-bottom:none}.detail-label{color:#999;min-width:140px;font-weight:500}.detail-value{color:#fff;word-break:break-word;text-align:right;flex:1;font-family:Monaco,Menlo,monospace;font-size:.85rem}.params-table{background:#0d0d0d;border:1px solid #333;border-radius:4px;overflow:hidden}.param-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #222;font-size:.85rem}.param-row:last-child{border-bottom:none}.param-key{color:#0ea5e9;min-width:150px;font-family:Monaco,Menlo,monospace;font-weight:500;flex-shrink:0}.param-value{color:#ddd;word-break:break-word;text-align:left;flex:1;font-family:Monaco,Menlo,monospace}.event-detail-modal::-webkit-scrollbar{width:8px}.event-detail-modal::-webkit-scrollbar-track{background:#0d0d0d}.event-detail-modal::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.event-detail-modal::-webkit-scrollbar-thumb:hover{background:#555}.member-card{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:1.75rem;box-shadow:0 1px 3px #0000000d;transition:all .2s ease;display:flex;flex-direction:column}.member-card:hover{box-shadow:0 4px 12px #00000014}.member-header{display:flex;align-items:flex-start;gap:1rem;padding:0 0 1rem;border-bottom:1px solid #f3f4f6}.member-name{flex:1}.member-name h2{margin:0;font-size:1.25rem;font-weight:600;color:#111}.member-pf{margin:0;font-size:.75rem;color:#2563eb;font-weight:500}.member-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem 1rem}.member-item{display:flex;flex-direction:column}.member-item.full-width{grid-column:1 / -1}.member-item label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.member-item p{margin:0;font-size:.95rem;color:#374151;line-height:1.4}.visits-count{font-size:1.75rem;font-weight:600;color:#2563eb}.status-badge{display:inline-block;background:#dbeafe;color:#1e40af;padding:.25rem .75rem;border-radius:.5rem;font-size:.85rem;font-weight:500;width:fit-content}@media(max-width:768px){.member-card{padding:1rem;margin-bottom:1.5rem}.member-header{flex-direction:column;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem}.member-name h2{font-size:1.25rem}.member-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.member-item.full-width{grid-column:1 / -1}}@media(max-width:480px){.member-card{padding:.875rem;margin-bottom:1rem}.member-grid{grid-template-columns:1fr;gap:.75rem}.member-name h2{font-size:1.1rem}.visits-count{font-size:1.5rem}}.member-section{margin-top:2rem;padding-top:1.5rem;border-top:2px solid #f3f4f6}.member-section h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#111;letter-spacing:-.5px}.member-section h4{margin:1rem 0 .5rem;font-size:.95rem;font-weight:600;color:#374151}.conversation-stats,.gym-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;border:1px solid #e5e7eb}.stat-item,.info-item{display:flex;flex-direction:column;gap:.25rem}.stat-label,.info-label{font-size:.8rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.stat-value,.info-value{font-size:1rem;color:#111;font-weight:500}.conversation-timeline,.conversations-list{margin-top:1rem}.conversations-list h4,.conversation-timeline h4{margin:1rem 0 .75rem;font-size:.95rem;font-weight:600;color:#374151}.conversation-item{margin-bottom:1rem;border:1px solid #d1d5db;border-radius:.5rem;overflow:hidden}.conversation-json{background:#f3f4f6;border:none;border-radius:0;padding:1rem;font-size:.75rem;overflow-x:auto;color:#374151;line-height:1.4;max-height:350px;overflow-y:auto;font-family:Monaco,Menlo,Ubuntu Mono,Courier New,monospace;margin:0}.member-data-preview{background:#f3f4f6;border:1px solid #d1d5db;border-radius:.5rem;padding:1rem;font-size:.75rem;overflow-x:auto;color:#374151;line-height:1.4;max-height:400px;overflow-y:auto;font-family:Monaco,Menlo,Ubuntu Mono,Courier New,monospace}.no-data{color:#9ca3af;font-size:.95rem;text-align:center;padding:1rem}.insight-loading{padding:1rem 0;color:#6b7280;font-size:.875rem}.insight-text{margin:0;font-size:.95rem;line-height:1.6;color:#374151;background:#f9fafb;padding:1rem;border-radius:.5rem;border-left:3px solid #2563eb}.insight-empty{margin:0;color:#9ca3af;font-size:.875rem;font-style:italic}.login-form{background:#fff;border:1px solid #e5e7eb;border-radius:1rem;padding:2rem;max-width:400px;margin:2rem auto;box-shadow:0 4px 12px #0000000f}.login-header{margin-bottom:1.5rem;text-align:center}.login-header h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#111}.login-header p{margin:0;font-size:.9rem;color:#6b7280}.login-error{background:#fee;color:#991b1b;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem;border:1px solid #fecaca}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#111;margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.95rem;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.login-button{width:100%;padding:.875rem;background:#2563eb;color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.login-button:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.login-button:disabled{background:#9ca3af;cursor:not-allowed}.login-button:active:not(:disabled){transform:scale(.98)}@media(max-width:480px){.login-form{padding:1.5rem;margin:1rem}.login-header h2{font-size:1.25rem}}
