*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;margin:0;padding:0}#root{width:100%;height:100%;min-height:100vh}:root{--primary: #6366f1;--primary-dark: #4f46e5;--secondary: #64748b;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--surface: #1e293b;--surface-hover: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #334155;--border-light: #475569;--sidebar-width: 260px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 4px 6px -1px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4);--radius-sm: 6px;--radius: 8px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}*::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}html,body,#root{width:100%;height:100%;min-height:100vh;overflow-x:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}.layout{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:transform .3s ease}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.sidebar-header h1{font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--primary),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius);transition:all .2s ease}.nav-item:hover{background:var(--surface-hover);color:var(--text-primary)}.nav-item.active{background:var(--primary);color:#fff}.logout-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;margin:1rem;color:var(--danger);background:transparent;border:1px solid var(--danger);border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:var(--danger);color:#fff}.main-content{margin-left:var(--sidebar-width);flex:1;padding:2rem;min-height:100vh}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:200;padding:.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);cursor:pointer}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:4rem 1rem 1rem}.mobile-menu-btn{display:flex}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:50}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.5rem;background:linear-gradient(135deg,var(--primary),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.login-header p{color:var(--text-secondary);font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:1rem;transition:all .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}input::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.icon-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.icon-btn.danger:hover{background:#ef444433;color:var(--danger)}.page-header{margin-bottom:2rem}.page-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.page-header p{color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius)}.stat-info h3{font-size:1.5rem;font-weight:700}.stat-info p{color:var(--text-secondary);font-size:.875rem}.dashboard-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.section-card h2{font-size:1.125rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.empty-state{text-align:center;color:var(--text-muted);padding:2rem}.quick-actions{display:flex;flex-wrap:wrap;gap:.75rem}.action-btn{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);text-decoration:none;font-size:.875rem;transition:all .2s ease}.action-btn:hover{background:var(--primary);border-color:var(--primary)}.toolbar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:.75rem;flex:1;min-width:200px;max-width:400px;padding:0 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.search-box svg{color:var(--text-muted)}.search-box input{flex:1;padding:.75rem 0;background:transparent;border:none}.search-box input:focus{box-shadow:none}.table-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}.data-table{width:100%;min-width:600px;border-collapse:collapse}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.data-table th{background:var(--bg-tertiary);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.data-table tbody tr:hover{background:var(--surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.empty-row{text-align:center!important;color:var(--text-muted);padding:2rem!important}.actions{white-space:nowrap}.actions .icon-btn{display:inline-flex;align-items:center;justify-content:center}.thumbnail{width:50px;height:50px;object-fit:cover;border-radius:var(--radius-sm);cursor:pointer}.user-id{font-family:monospace;font-size:.875rem;color:var(--text-muted)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:9999px;text-transform:capitalize}.badge-google{background:#ea433533;color:#ea4335}.badge-apple{background:#fff3;color:#fff}.badge-email{background:#6366f133;color:var(--primary)}.badge-pending{background:#f59e0b33;color:var(--warning)}.badge-processing{background:#3b82f633;color:var(--info)}.badge-completed{background:#10b98133;color:var(--success)}.badge-failed{background:#ef444433;color:var(--danger)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:95%;max-width:500px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);position:relative;margin:auto}.modal-lg{max-width:800px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h2{font-size:1.25rem}.close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1}.close-btn:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;overscroll-behavior:contain}.detail-row{display:flex;padding:.5rem 0;border-bottom:1px solid var(--border)}.detail-row label{width:120px;font-weight:500;color:var(--text-secondary)}.detail-row span{flex:1;word-break:break-all}.modal-body h3{margin-top:1.5rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);font-size:1rem}.scan-detail-grid{display:grid;grid-template-columns:250px 1fr;gap:1.5rem}@media(max-width:600px){.scan-detail-grid{grid-template-columns:1fr}}.scan-image img{width:100%;border-radius:var(--radius)}.predictions-list{display:flex;flex-direction:column;gap:.75rem}.prediction-card{background:var(--bg-tertiary);border-radius:var(--radius);padding:.75rem}.prediction-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.confidence{color:var(--success);font-size:.875rem}.nutrition-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem;font-size:.875rem;color:var(--text-secondary)}.nutrition-grid span{font-weight:500}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem}.pagination span{color:var(--text-secondary)}.error-message{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.success-message{background:#10b9811a;border:1px solid var(--success);color:var(--success);padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.loading{text-align:center;padding:3rem;color:var(--text-muted)}code{background:var(--bg-tertiary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-family:Fira Code,monospace;font-size:.875rem}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:24px;border:1px solid var(--border)}.slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:var(--text-secondary);transition:.3s;border-radius:50%}input:checked+.slider{background-color:var(--success);border-color:var(--success)}input:checked+.slider:before{transform:translate(20px);background-color:#fff}.clickable-row{cursor:pointer;transition:background .2s ease}.clickable-row:hover{background:var(--surface-hover)!important}.clickable-row td{height:60px}.delete-modal{max-width:400px;text-align:center}.delete-modal-content{padding:2rem}.delete-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 1.5rem;background:#ef44441a;border-radius:50%;color:var(--danger)}.delete-modal h2{margin-bottom:.5rem;font-size:1.5rem}.delete-modal>.delete-modal-content>p{color:var(--text-secondary);margin-bottom:1rem}.user-info-preview{background:var(--bg-tertiary);padding:1rem;border-radius:var(--radius);margin-bottom:1rem;display:flex;flex-direction:column;gap:.25rem}.user-info-preview strong{font-size:1rem}.user-info-preview span{color:var(--text-muted);font-size:.875rem}.warning-text{color:var(--danger)!important;font-size:.875rem;margin-bottom:1.5rem!important}.modal-actions{display:flex;gap:1rem;justify-content:center}.modal-actions .btn{flex:1;max-width:150px}.provider-cell{text-align:center;vertical-align:middle}.provider-cell .provider-icon{vertical-align:middle}.provider-icon{width:24px;height:24px;object-fit:contain;display:inline-block;vertical-align:middle}.provider-icon.apple{color:#fff}.provider-icon.email{color:var(--primary)}.provider-cell{text-align:center}.provider-in-modal{display:flex;align-items:center}.subscription-modal{max-width:400px;text-align:center}.subscription-modal-content{padding:2rem}.subscription-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 1.5rem;background:#6366f11a;border-radius:50%;color:var(--primary)}.subscription-icon .premium-icon{font-size:2.5rem;color:var(--warning)}.subscription-modal h2{margin-bottom:.5rem;font-size:1.5rem}.subscription-modal>.subscription-modal-content>p{color:var(--text-secondary);margin-bottom:1rem}.subscription-note{color:var(--text-muted)!important;font-size:.875rem;margin-bottom:1.5rem!important;font-style:italic}.user-detail-modal .modal-body{padding:0}.user-profile-header{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border)}.user-avatar{width:80px;height:80px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{font-size:2rem;font-weight:700;color:#fff}.user-profile-info h3{font-size:1.25rem;margin-bottom:.25rem}.user-profile-info p{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.user-badges{display:flex;align-items:center;gap:.5rem}.provider-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--surface);border-radius:50%}.detail-section{padding:1.5rem;border-bottom:1px solid var(--border)}.detail-section:last-child{border-bottom:none}.detail-section h4{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media(max-width:600px){.detail-grid{grid-template-columns:1fr}.user-profile-header{flex-direction:column;text-align:center}}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.detail-item span{font-size:.9375rem;color:var(--text-primary)}.detail-item .mono{font-family:Fira Code,monospace;font-size:.75rem;color:var(--text-secondary);word-break:break-all}.capitalize{text-transform:capitalize}.source-icon{display:flex;align-items:center}.source-icon-img{width:20px;height:20px}.source-icon-img.instagram{color:#e4405f}.source-icon-img.facebook{color:#1877f2}.source-icon-img.youtube{color:red}.source-icon-img.twitter{color:#1da1f2}.source-icon-img.tiktok{font-size:.75rem;font-weight:700;color:#000;background:linear-gradient(135deg,#25f4ee,#fe2c55);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.source-icon-img.friend{color:var(--success)}.source-icon-img.other{color:var(--text-secondary)}.progress-photos{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.progress-photos>label{display:block;font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.photo-grid{display:flex;gap:1rem;flex-wrap:wrap}.photo-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.photo-item img{width:100px;height:140px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-tertiary)}.photo-item span{font-size:.75rem;color:var(--text-muted)}.badge-warning{background:#f59e0b1a;color:var(--warning)}.avatar-cell{width:60px;padding-right:0!important}.table-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.table-avatar img{width:100%;height:100%;object-fit:cover}.table-avatar span{font-size:.875rem;font-weight:600;color:#fff}.badge-monthly{background:#3b82f61a;color:#3b82f6}.badge-yearly{background:#a855f71a;color:#a855f7}.plan-selection{margin:1.5rem 0;text-align:left}.plan-selection>label{display:block;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.plan-options{display:flex;gap:1rem;margin-bottom:1rem}.plan-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.plan-option:hover{border-color:var(--primary)}.plan-option.selected{border-color:var(--primary);background:#6366f11a}.plan-option .plan-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.plan-option .plan-duration{font-size:.75rem;color:var(--text-muted)}.plan-dates{display:flex;gap:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius)}.date-info{display:flex;flex-direction:column;gap:.25rem}.date-info label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.date-info span{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.nutrition-summary{display:flex;gap:1rem;margin-bottom:1rem}.nutrition-summary-box{margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius)}.nutrition-summary-box h4{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.nutrition-summary-box .nutrition-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:0}.nutrition-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius)}.nutrition-item .value{font-size:1.25rem;font-weight:700;color:var(--primary)}.nutrition-item .label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.error-box{margin-top:1rem;padding:1rem;background:#ef44441a;border:1px solid var(--danger);border-radius:var(--radius);color:var(--danger)}.mono{font-family:Fira Code,monospace;font-size:.75rem}.chart-card{min-height:300px}.chart-loading,.chart-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted)}.bar-chart{display:flex;flex-direction:column;gap:.75rem;padding:1rem 0}.bar-item{display:flex;align-items:center;gap:1rem}.bar-label{width:60px;font-size:.875rem;color:var(--text-secondary);text-align:right}.bar-container{flex:1;height:28px;background:var(--bg-tertiary);border-radius:var(--radius);overflow:hidden}.bar-fill{height:100%;border-radius:var(--radius);transition:width .5s ease;min-width:4px}.bar-value{width:40px;font-size:.875rem;font-weight:600;color:var(--text-primary)}.vertical-bar-chart{padding:1rem 0;height:220px}.bars-container{display:flex;justify-content:space-around;align-items:flex-end;height:100%;gap:1rem}.vertical-bar-item{display:flex;flex-direction:column;align-items:center;height:100%;flex:1}.vertical-bar-value{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.vertical-bar-track{flex:1;width:100%;max-width:50px;background:var(--bg-tertiary);border-radius:var(--radius);display:flex;align-items:flex-end;overflow:hidden}.vertical-bar-fill{width:100%;border-radius:var(--radius);transition:height .5s ease;min-height:4px}.vertical-bar-label{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;text-align:center}.pie-chart-container{display:flex;align-items:center;gap:2rem;padding:1rem 0}.pie-chart-wrapper{position:relative}.pie-chart{width:180px;height:180px;flex-shrink:0}.pie-center-value{font-size:14px;font-weight:700;fill:var(--text-primary)}.pie-center-label{font-size:6px;fill:var(--text-muted);text-transform:uppercase}.pie-legend{display:flex;flex-direction:column;gap:1rem}.legend-item{display:flex;align-items:center;gap:.75rem}.legend-color{width:16px;height:16px;border-radius:4px;flex-shrink:0}.legend-info{display:flex;flex-direction:column;min-width:80px}.legend-label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.legend-percent{font-size:.75rem;color:var(--text-muted)}.legend-count{font-size:1rem;font-weight:700;color:var(--text-primary);margin-left:auto}.legend-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}@media(max-width:1024px){.data-table th,.data-table td{padding:.75rem}}@media(max-width:768px){.main-content{width:100%;overflow-x:hidden}.table-container{width:100%;max-width:calc(100vw - 2rem);margin-bottom:1rem;display:block;overflow-x:auto}.data-table{min-width:800px}.page-header h1{font-size:1.5rem}.data-table th,.data-table td{padding:.75rem .5rem;font-size:.875rem;white-space:nowrap}.data-table th{font-size:.7rem}.table-avatar{width:32px;height:32px}.table-avatar span{font-size:.75rem}.avatar-cell{width:40px}.badge{padding:.15rem .5rem;font-size:.7rem}.btn{padding:.75rem 1rem;font-size:.875rem;width:100%;justify-content:center}.icon-btn{width:32px;height:32px}.toolbar{flex-direction:column;align-items:stretch;gap:.75rem;width:100%}.search-box{width:100%;min-width:0}.stats-grid{grid-template-columns:1fr}.stat-card{padding:1rem}}
