:root{--text:#64748b;--text-h:#0f172a;--bg:#f8fafc;--bg-card:#fff;--border:#e2e8f0;--accent:#3b82f6;--accent-hover:#2563eb;--accent-bg:#3b82f61a;--star:#fbbf24;--star-empty:#cbd5e1;--success:#10b981;--success-bg:#10b9811a;--error:#ef4444;--error-bg:#ef44441a;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/1.5 var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--text:#94a3b8;--text-h:#f1f5f9;--bg:#0f172a;--bg-card:#1e293b;--border:#334155;--accent:#60a5fa;--accent-hover:#3b82f6;--accent-bg:#60a5fa26;--star:#fbbf24;--star-empty:#475569;--success:#34d399;--success-bg:#34d39926;--error:#f87171;--error-bg:#f8717126;--shadow:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #0003}}*,:before,:after{box-sizing:border-box}body{min-height:100vh;margin:0}#root{min-height:100vh}h1,h2{color:var(--text-h);margin:0;font-weight:600}h1{letter-spacing:-.02em;font-size:1.75rem}h2{font-size:1.25rem}p{margin:0}.btn{cursor:pointer;border:none;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:inherit;font-size:.9375rem;font-weight:500;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--secondary{background:var(--bg-card);color:var(--text-h);border:1px solid var(--border)}.btn--secondary:hover:not(:disabled){background:var(--bg);border-color:var(--text)}.btn--full{width:100%}.btn-text{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.875rem;font-weight:500}.btn-text:hover{text-decoration:underline}.form-input{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-h);border-radius:.5rem;padding:.75rem 1rem;font-family:inherit;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.form-input::placeholder{color:var(--text)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);outline:none}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-field{flex-direction:column;gap:.5rem;display:flex}.form-field label{color:var(--text-h);font-size:.875rem;font-weight:500}.message{border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.message--error{background:var(--error-bg);color:var(--error)}.message--success{background:var(--success-bg);color:var(--success)}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--bg-card);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border);border-radius:1rem;padding:2rem}.login-header{text-align:center;margin-bottom:2rem}.login-icon{width:3rem;height:3rem;color:var(--accent);margin-bottom:1rem}.login-header h1{margin-bottom:.5rem}.login-header p{color:var(--text)}.login-form{flex-direction:column;gap:1.25rem;display:flex}.dashboard{flex-direction:column;min-height:100vh;display:flex}.dashboard__header{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex;position:sticky;top:0}.dashboard__user{align-items:center;gap:1rem;display:flex}.user-email{color:var(--text);font-size:.875rem}.dashboard__main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem}.add-property-form{margin-bottom:2rem}.form-group{gap:.75rem;display:flex}.form-group .form-input{flex:1}.add-property-form .message{margin-top:.75rem}.loading{color:var(--text);flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:2.5rem;height:2.5rem;margin-bottom:1rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.empty-icon{width:4rem;height:4rem;color:var(--text);opacity:.5;margin-bottom:1rem}.empty-state h2{margin-bottom:.5rem}.empty-state p{color:var(--text)}.properties-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.5rem;display:grid}.property-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:.75rem;transition:box-shadow .15s;overflow:hidden}.property-card:hover{box-shadow:var(--shadow-lg)}.property-card__image-link{aspect-ratio:16/10;width:100%;display:block;overflow:hidden}.property-card__image{object-fit:cover;width:100%;height:100%;transition:transform .2s}.property-card__image-link:hover .property-card__image{transform:scale(1.03)}.property-card__header{border-bottom:1px solid var(--border);flex-direction:column;gap:.25rem;margin-bottom:1rem;padding:1.25rem 1.25rem 1rem;display:flex}.property-card__title{color:var(--text-h);margin:0 0 .375rem;font-size:1.0625rem;font-weight:600;line-height:1.35}.property-card__url{color:var(--accent);word-break:break-all;align-items:center;gap:.5rem;font-weight:500;text-decoration:none;display:inline-flex}.property-card__url:hover{text-decoration:underline}.external-icon{flex-shrink:0;width:1rem;height:1rem}.property-card__date{color:var(--text);font-size:.8125rem}.property-card__ratings{flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:0 1.25rem;display:flex}.property-card__my-rating,.property-card__avg-rating{align-items:center;gap:.75rem;display:flex}.rating-label{color:var(--text-h);min-width:85px;font-size:.875rem;font-weight:500}.avg-score{color:var(--star);font-size:1.125rem;font-weight:600}.rating-count{color:var(--text);font-size:.8125rem}.star-rating{gap:.25rem;display:inline-flex}.star-rating--small{gap:.125rem}.star-rating--readonly{pointer-events:none}.star{cursor:pointer;color:var(--star-empty);background:0 0;border:none;padding:0;transition:transform .1s,color .1s}.star svg{width:1.5rem;height:1.5rem;display:block}.star-rating--small .star svg{width:1rem;height:1rem}.star--filled{color:var(--star)}.star:not(:disabled):hover{transform:scale(1.1)}.star:disabled{cursor:default}.property-card__toggle{color:var(--text);cursor:pointer;background:0 0;border:none;align-items:center;gap:.25rem;margin-bottom:1rem;margin-left:1.25rem;padding:0;font-family:inherit;font-size:.8125rem;display:inline-flex}.property-card__toggle:hover{color:var(--text-h)}.chevron{width:1rem;height:1rem;transition:transform .2s}.chevron--up{transform:rotate(180deg)}.property-card__other-ratings{background:var(--bg);border-radius:.5rem;flex-direction:column;gap:.75rem;margin:0 1.25rem 1rem;padding:.75rem;display:flex}.other-rating{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.other-rating__user{color:var(--text-h);min-width:120px;font-size:.8125rem;font-weight:500}.other-rating__notes{width:100%;color:var(--text);border-left:2px solid var(--border);margin-top:.25rem;padding-left:.5rem;font-size:.8125rem}.property-card__viewing{flex-direction:column;gap:.625rem;padding:0 1.25rem 1rem;display:flex}.viewing-status{align-items:center;display:flex}.viewing-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.625rem;display:inline-flex}.viewing-toggle--readonly{cursor:default}.viewing-toggle input{opacity:0;width:0;height:0;position:absolute}.viewing-toggle__slider{background:var(--border);border-radius:1rem;width:2.5rem;height:1.375rem;transition:background .2s;position:relative}.viewing-toggle__slider:after{content:"";background:#fff;border-radius:50%;width:1.125rem;height:1.125rem;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.viewing-toggle input:checked+.viewing-toggle__slider{background:var(--success)}.viewing-toggle input:checked+.viewing-toggle__slider:after{transform:translate(1.125rem)}.viewing-toggle--readonly .viewing-toggle__slider{opacity:.7}.viewing-toggle__label{color:var(--text-h);font-size:.875rem;font-weight:500}.viewing-date{align-items:center;gap:.5rem;padding-left:.25rem;display:flex}.viewing-date__label{color:var(--text);font-size:.8125rem}.viewing-date__input{background:var(--bg);border:1px solid var(--border);color:var(--text-h);border-radius:.375rem;padding:.375rem .5rem;font-family:inherit;font-size:.8125rem}.viewing-date__input:focus{border-color:var(--accent);outline:none}.viewing-date__value{color:var(--text-h);font-size:.8125rem;font-weight:500}.property-card__notes{border-top:1px solid var(--border);padding:1rem 1.25rem 1.25rem}.notes-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.notes-editor{flex-direction:column;gap:.75rem;display:flex}.notes-editor textarea{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text-h);resize:vertical;border-radius:.5rem;min-height:80px;padding:.75rem;font-family:inherit;font-size:.875rem}.notes-editor textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);outline:none}.notes-actions{justify-content:flex-end;gap:.5rem;display:flex}.notes-actions .btn{padding:.5rem 1rem;font-size:.875rem}.property-card__my-notes{color:var(--text);font-size:.875rem;line-height:1.5}@media (width<=640px){.dashboard__header{text-align:center;flex-direction:column;gap:1rem}.dashboard__user{justify-content:space-between;width:100%}.form-group{flex-direction:column}.properties-grid{grid-template-columns:1fr}.property-card__my-rating,.property-card__avg-rating{flex-wrap:wrap}.rating-label{width:100%;min-width:auto}}
