/* Flat Hunting */

/* Board kanban — reuses .kanban, .kanban-col, .kh, .k-cards from components.css */
.flat-card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:var(--sp-md);cursor:pointer;transition:all 0.15s;position:relative;overflow:hidden}.flat-card:hover{border-color:var(--border-hover);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.flat-card::before{content:'';position:absolute;left:0;top:0;right:0;height:3px;background:var(--accent)}
.flat-card-photo{width:100%;height:80px;border-radius:6px;object-fit:cover;margin-bottom:var(--sp-md);background:var(--surface);display:block}
.flat-card-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:var(--sp-sm)}
.flat-card-meta{display:flex;gap:var(--sp-sm);flex-wrap:wrap;margin-bottom:var(--sp-sm)}
.flat-card-price{font-size:12px;font-weight:600;color:var(--accent)}
.flat-card-details{font-size:10.5px;color:var(--text);display:flex;gap:var(--sp-sm);align-items:center}
.flat-card-score{display:flex;gap:var(--sp-xs);margin-top:var(--sp-sm)}
.flat-score-dot{width:6px;height:6px;border-radius:var(--radius-full);background:var(--border)}.flat-score-dot.filled{background:var(--accent)}
.flat-barrio-tag{padding:var(--sp-xs) var(--sp-sm);border-radius:4px;font-size:9.5px;font-weight:600;background:var(--accent-faint);color:var(--accent)}

/* Flat kanban status colors */
.kh-tovisit{color:var(--sand-500)}.kh-tovisit .kh-count{background:var(--sand-50);color:var(--sand-500)}
.kh-visited{color:var(--jean-500)}.kh-visited .kh-count{background:var(--jean-50);color:var(--jean-500)}
.kh-thinking{color:var(--jean-400)}.kh-thinking .kh-count{background:var(--jean-100);color:var(--jean-400)}
.kh-favorite{color:var(--burgundy-500)}.kh-favorite .kh-count{background:var(--burgundy-50);color:var(--burgundy-500)}
.kh-offermade{color:var(--sage-500)}.kh-offermade .kh-count{background:var(--sage-50);color:var(--sage-500)}
.kh-flatdropped{color:var(--beige-600)}.kh-flatdropped .kh-count{background:var(--beige-200);color:var(--beige-600)}
.kh-sold{color:var(--clay-500)}.kh-sold .kh-count{background:var(--clay-50);color:var(--clay-500)}

/* Visit form */
.visit-select{margin-bottom:var(--sp-lg)}
.visit-select select{width:100%;padding:var(--sp-md);border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;outline:none;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%237A7468' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--sp-md) center;padding-right:36px}
.visit-progress{height:4px;border-radius:2px;background:var(--border);margin-bottom:var(--sp-lg);overflow:hidden;position:sticky;top:88px;z-index:10}
.visit-progress-fill{height:100%;border-radius:2px;background:var(--accent);transition:width 0.3s ease}
.visit-progress-text{font-size:11px;color:var(--text);margin-bottom:var(--sp-md);font-weight:500;position:sticky;top:92px;z-index:10;background:var(--bg);padding:var(--sp-sm) 0}
.visit-category{margin-bottom:var(--sp-lg)}
.visit-cat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-md) 0;cursor:pointer;border-bottom:1px solid var(--border)}
.visit-cat-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent-dim)}
.visit-cat-count{font-size:10.5px;color:var(--text-secondary);font-weight:500}
.visit-cat-chevron{color:var(--text-secondary);transition:transform 0.2s;font-size:14px}
.visit-cat-header.open .visit-cat-chevron{transform:rotate(180deg)}
.visit-questions{display:none;padding-top:var(--sp-md)}.visit-cat-header.open+.visit-questions{display:block}
.visit-q{padding:var(--sp-md) 0;border-bottom:1px solid var(--border)}
.visit-q:last-child{border-bottom:none}
.visit-q-text{font-size:13.5px;color:var(--text);font-weight:500;line-height:1.4;margin-bottom:var(--sp-xs)}
.visit-q-en{font-size:11.5px;color:var(--text-secondary);font-weight:400;line-height:1.4;margin-bottom:var(--sp-md)}
.visit-q-hint{font-size:10px;color:var(--red);font-weight:500;margin-bottom:var(--sp-sm);display:flex;align-items:center;gap:var(--sp-sm)}
.visit-yn{display:flex;gap:var(--sp-sm)}
.visit-yn-btn{padding:var(--sp-sm) var(--sp-lg);border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s;flex:1;text-align:center}
.visit-yn-btn.yes{border-color:var(--green-border);background:var(--green-bg);color:var(--green)}
.visit-yn-btn.no{border-color:var(--red-border);background:var(--red-bg);color:var(--red)}
.visit-text-input{width:100%;padding:var(--sp-md);border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;font-family:inherit;outline:none;resize:none;min-height:36px}.visit-text-input:focus{border-color:var(--accent-dim)}
.visit-empty{text-align:center;padding:var(--sp-2xl) var(--sp-lg);color:var(--text-tertiary)}.visit-empty p{font-size:13px;font-weight:400}

/* Score modal */
.score-slider-row{margin-bottom:var(--sp-lg)}
.score-slider-label{font-size:12px;font-weight:600;color:var(--text);margin-bottom:var(--sp-sm);display:flex;justify-content:space-between}
.score-slider-val{font-weight:700;color:var(--accent)}
.score-slider{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:var(--border);outline:none}
.score-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:var(--radius-full);background:var(--accent);cursor:pointer;border:2px solid var(--bg);box-shadow:0 1px 4px rgba(0,0,0,0.15)}
.score-total{text-align:center;padding:var(--sp-lg);background:var(--accent-faint);border-radius:var(--sp-md);margin-bottom:var(--sp-md)}
.score-total-val{font-family:'Fraunces',serif;font-size:32px;font-weight:600;color:var(--accent)}
.score-total-label{font-size:11px;color:var(--text);margin-top:var(--sp-xs)}

/* Compare view */
.compare-select{display:flex;gap:var(--sp-sm);flex-wrap:wrap;margin-bottom:var(--sp-lg)}
.compare-chip{padding:var(--sp-sm) var(--sp-md);border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all 0.15s}.compare-chip.active{border-color:var(--accent);background:var(--accent-faint);color:var(--accent)}
.compare-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}
.compare-table{width:100%;border-collapse:collapse;font-size:12px}
.compare-table th{position:sticky;top:0;background:var(--surface);padding:var(--sp-md);font-weight:600;color:var(--text);border-bottom:2px solid var(--border);text-align:left;white-space:nowrap;min-width:120px}
.compare-table td{padding:var(--sp-md);border-bottom:1px solid var(--border);color:var(--text);vertical-align:top}
.compare-table tr:hover td{background:var(--surface)}
.compare-row-label{font-weight:600;color:var(--text);white-space:nowrap;min-width:100px;background:var(--surface-2);position:sticky;left:0}
.compare-score{font-weight:700;color:var(--accent)}
.compare-empty{text-align:center;padding:var(--sp-2xl) var(--sp-lg);color:var(--text-tertiary)}.compare-empty p{font-size:13px;font-weight:400}

/* Edit modal details sections */
.flat-details{margin-top:var(--sp-md)}
.flat-details summary{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--accent-dim);cursor:pointer;padding:var(--sp-md) 0;border-bottom:1px solid var(--border)}
.flat-details[open] summary{border-bottom:none;margin-bottom:var(--sp-sm)}
.flat-details .flat-fields{display:flex;flex-direction:column;gap:var(--sp-xs);padding-bottom:var(--sp-md)}
