.hosts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.host-card{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:24px;
    transition:all 0.4s cubic-bezier(0.16,1,0.3,1);
    position:relative;overflow:hidden;display:flex;flex-direction:column;
}
.host-card::before{
    content:'';position:absolute;top:0;left:0;width:100%;height:3px;
    background:var(--grad);transform:scaleX(0);transform-origin:left;
    transition:transform 0.4s cubic-bezier(0.16,1,0.3,1);
}
.host-card .btn{margin-top:auto;width:100%}
.host-card .rent-btn{background:var(--grad);color:#fff;box-shadow:0 4px 20px var(--accent-glow);padding:12px}
.host-card .rent-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}

.host-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.host-name{font-weight:700;font-size:1rem;color:var(--text)}
.host-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:50px;font-size:0.7rem;font-weight:700}
.host-badge.online{background:rgba(16,185,129,0.1);color:var(--emerald)}
.host-badge.offline{background:rgba(100,116,139,0.1);color:var(--text-3)}
.host-badge .bdot{width:6px;height:6px;border-radius:50%;display:inline-block}
.host-badge.online .bdot{background:var(--emerald);box-shadow:0 0 6px var(--emerald-glow);animation:pulse 2s infinite}

.host-specs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.host-spec{padding:4px 10px;background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:6px;font-family:var(--font-mono);font-size:0.72rem;color:var(--text-2)}

.host-price-row{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.host-price{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;color:var(--emerald)}
.host-price-unit{font-size:0.75rem;color:var(--text-3);font-family:var(--font-mono)}
.host-price-extra{font-size:0.65rem;color:var(--text-3);font-family:var(--font-mono);margin-top:1px}
.host-loc{color:var(--text-3);font-size:0.78rem;margin-bottom:16px}

.host-util{margin-bottom:16px}
.host-util-label{display:flex;justify-content:space-between;font-size:0.7rem;color:var(--text-3);margin-bottom:6px}
.host-util-bar{height:5px;background:rgba(255,255,255,0.05);border-radius:3px;overflow:hidden}
.host-util-fill{height:100%;border-radius:3px;transition:width 0.8s ease;background:var(--grad)}

/* Host hover effects */
.host-card:hover{
    transform:translateY(-8px) scale(1.02);
    box-shadow:0 30px 80px rgba(0,0,0,0.7),0 0 60px rgba(168,85,247,0.15);
    border-color:rgba(168,85,247,0.4);
}
.host-card:hover::before{transform:scaleX(1)}
.host-card:hover .host-price{animation:pricePop 0.4s ease}

/* ===== Filter Pill Buttons ===== */
.filter-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: var(--text-2);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    font-family: Inter, sans-serif;
}
.filter-pill:hover {
    border-color: var(--accent);
    color: var(--text);
    background: rgba(168,85,247,0.06);
}
.filter-pill.has-filter {
    border-color: var(--accent);
    background: rgba(168,85,247,0.12);
    color: var(--accent);
}
.filter-pill .pill-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent);
    display: none;
}
.filter-pill.has-filter .pill-dot {
    display: block;
}

/* ===== Filter Panel (Popover) ===== */
.filter-panel-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 999;
    display: none;
    align-items: flex-start;
    justify-content: center;
    padding-top: 80px;
    animation: fadeIn 0.15s ease;
}
.filter-panel-backdrop.active {
    display: flex;
}
.filter-panel {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    width: 480px;
    max-width: 90vw;
    max-height: 70vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 40px 100px rgba(0,0,0,0.8);
    animation: panelSlideIn 0.25s cubic-bezier(0.16,1,0.3,1);
}
.filter-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.filter-panel-header h3 {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
}
.filter-panel-close {
    background: none;
    border: none;
    color: var(--text-3);
    font-size: 1.6rem;
    cursor: pointer;
    padding: 2px 8px;
    line-height: 1;
    border-radius: 6px;
    transition: all 0.2s;
}
.filter-panel-close:hover {
    background: rgba(255,255,255,0.05);
    color: var(--text);
}
.filter-panel-body {
    padding: 16px 20px;
    overflow-y: auto;
    flex: 1;
}
.filter-panel-footer {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    padding: 12px 20px;
    border-top: 1px solid var(--border);
    flex-shrink: 0;
}

/* Filter panel content sections */
.filter-panel-content {}
.filter-field {
    margin-bottom: 16px;
}
.filter-field:last-child {
    margin-bottom: 0;
}
.filter-field label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-2);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}
.filter-range-row {
    display: flex;
    gap: 8px;
    align-items: center;
}
.filter-range-row input {
    flex: 1;
    padding: 8px 10px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-size: 0.84rem;
    font-family: var(--font-mono);
    transition: border-color 0.2s;
}
.filter-range-row input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px rgba(168,85,247,0.12);
}
.filter-range-row span {
    color: var(--text-3);
    font-size: 0.85rem;
}

/* Toggle group buttons */
.toggle-group {
    display: flex;
    gap: 6px;
}
.toggle-opt {
    flex: 1;
    padding: 7px 12px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg-secondary);
    color: var(--text-2);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    font-family: Inter, sans-serif;
    text-align: center;
}
.toggle-opt:hover {
    border-color: var(--accent);
    color: var(--text);
}
.toggle-opt.active {
    background: rgba(168,85,247,0.12);
    border-color: var(--accent);
    color: var(--accent);
}

/* Animations */
@keyframes fadeIn {
    from { opacity: 0 }
    to { opacity: 1 }
}
@keyframes panelSlideIn {
    from { opacity: 0; transform: translateY(-12px) scale(0.97) }
    to { opacity: 1; transform: translateY(0) scale(1) }
}
