:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{width:100%;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;pointer-events:auto;-webkit-user-select:none;user-select:none}.photographer-preview-modal{background:#fff!important;color:#333!important;border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 40px #0003;pointer-events:auto;-webkit-user-select:text;user-select:text}.modal-header{padding:24px;border-bottom:1px solid #e0e0e0;position:relative}.photographer-header{display:flex;gap:20px;align-items:flex-start}.photographer-avatar-large{width:80px;height:80px;border-radius:50%;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center;flex-shrink:0}.photographer-avatar-large img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-large{font-size:32px;font-weight:700;color:#666}.photographer-info h2{margin:0 0 8px;font-size:28px;font-weight:700;color:#333}.photo-count{margin:0 0 16px;font-size:16px;color:#666}.close-button{position:absolute;top:16px;right:16px;background:none;border:none;font-size:32px;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-button:hover{background:#f5f5f5;color:#333}.modal-body{padding:24px;background:#fff!important;color:#333!important}.bio-section{margin-bottom:32px}.bio{font-size:16px;line-height:1.6;color:#333!important;margin:0 0 16px}.explanation{font-size:14px;color:#666!important;font-style:italic;margin:0;padding:12px;background:#f8f9fa;border-radius:8px;border-left:4px solid #1976d2}.matching-tags{margin-top:12px}.tags-label{font-size:14px;color:#666;font-weight:500;display:block;margin-bottom:8px}.tags-list{display:flex;flex-wrap:wrap;gap:8px}.tag-chip{background:#e3f2fd;color:#1976d2;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:500}.photos-preview h3{margin:0 0 20px;font-size:20px;font-weight:600;color:#333}.loading-photos{text-align:center;padding:40px;color:#666}.photos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.photo-preview{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s ease}.photo-preview:hover{transform:scale(1.05)}.photo-preview img{width:100%;height:100%;object-fit:cover}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0f0f0;color:#666;font-size:12px;border-radius:4px}.photo-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:12px 8px 8px;color:#fff}.photo-title{font-size:12px;font-weight:500;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-photos{text-align:center;color:#666;font-style:italic;padding:20px}.modal-footer{padding:24px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end}.add-button{background:#1976d2;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:140px}.add-button:hover:not(:disabled){background:#1565c0}.add-button:disabled{opacity:.6;cursor:not-allowed}.view-button{background:transparent;color:#1976d2;border:2px solid #1976d2;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.view-button:hover{background:#1976d2;color:#fff}@media (max-width: 768px){.modal-overlay{padding:10px}.photographer-preview-modal{max-height:95vh}.photographer-header{flex-direction:column;align-items:center;text-align:center}.modal-header,.modal-body,.modal-footer{padding:16px}.photos-grid{grid-template-columns:repeat(2,1fr)}.modal-footer{flex-direction:column}.add-button,.view-button{width:100%}}.recommendation-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:transform .2s ease,box-shadow .2s ease;border:1px solid #e0e0e0}.recommendation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.photographer-info{display:flex;align-items:center;gap:12px}.photographer-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center}.photographer-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:20px;font-weight:700;color:#666}.photographer-details h3{margin:0;font-size:18px;font-weight:600;color:#333}.photo-count{margin:4px 0 0;font-size:14px;color:#666}.similarity-score{font-size:16px;font-weight:700;padding:4px 8px;background:#0000000d;border-radius:6px}.recommendation-body{margin-bottom:20px}.photographer-bio{font-size:14px;color:#555;line-height:1.4;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.matching-tags{margin-bottom:12px}.tags-label{font-size:12px;color:#666;font-weight:500;display:block;margin-bottom:6px}.tags-list{display:flex;flex-wrap:wrap;gap:6px}.tag-chip{background:#e3f2fd;color:#1976d2;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.more-tags{background:#f5f5f5;color:#666}.explanation{font-size:13px;color:#666;font-style:italic;margin:0;line-height:1.4}.recommendation-footer{display:flex;justify-content:center}.explore-button{background:#1976d2;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;width:100%}.explore-button:hover{background:#1565c0}.explore-button:active{transform:translateY(1px)}.recommendations-page{max-width:1200px;margin:0 auto;padding:20px}.recommendations-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.header-content h1{margin:0 0 8px;font-size:32px;font-weight:700;color:#333}.subtitle{margin:0;font-size:16px;color:#666;max-width:600px;line-height:1.5}.refresh-button{background:#1976d2;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px}.refresh-button:hover:not(:disabled){background:#1565c0}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.refresh-button.refreshing{position:relative}.refresh-button.refreshing:after{content:"";position:absolute;width:16px;height:16px;margin:auto;border:2px solid transparent;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;top:0;left:0;bottom:0;right:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#1976d2;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.error-container h2{margin:0 0 12px;font-size:24px;color:#d32f2f}.error-container p{margin:0 0 24px;font-size:16px;color:#666}.retry-button{background:#d32f2f;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.retry-button:hover{background:#c62828}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;text-align:center;padding:40px}.empty-icon{font-size:64px;margin-bottom:24px;opacity:.6}.empty-state h2{margin:0 0 16px;font-size:28px;color:#333}.empty-state p{margin:0;font-size:16px;color:#666;max-width:500px;line-height:1.6}.recommendations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-bottom:40px}.recommendations-footer{text-align:center;padding:24px;border-top:1px solid #e0e0e0}.footer-text{margin:0;font-size:14px;color:#666}@media (max-width: 768px){.recommendations-page{padding:16px}.recommendations-header{flex-direction:column;gap:16px;align-items:stretch}.header-content h1{font-size:24px}.recommendations-grid{grid-template-columns:1fr;gap:16px}.refresh-button{align-self:flex-start}}
