/* ═══════════════════════════════════════════════════════
   ServiceRabbit – Location / Distance Styles
   ═══════════════════════════════════════════════════════ */

/* ── Location Bar (Task Browse) ── */
.loc-bar{
    background:var(--tr-purple-ultra,#f5f3ff);
    border:1.5px solid var(--tr-purple-soft,#ede9fe);
    border-radius:var(--tr-radius,0.75rem);
    padding:.65rem 1rem;
}
.loc-status{
    display:inline-flex;align-items:center;gap:.4rem;
}
.loc-detect-btn{
    font-size:.78rem;font-weight:600;
    transition:var(--tr-transition);
}
.loc-radius-select{
    width:auto;min-width:80px;font-size:.78rem;font-weight:600;
    border-radius:var(--tr-radius-full,50rem);
    border-color:var(--tr-purple-soft,#ede9fe);
    padding:.25rem .75rem .25rem .5rem;
}

/* ── Spin animation for detecting ── */
@keyframes locSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.spin-icon{animation:locSpin .8s linear infinite}

/* ── Location Picker (Create/Edit Task) ── */
.loc-picker{
    background:var(--tr-gray-50,#f9fafb);
    border:1.5px dashed var(--tr-gray-300,#d1d5db);
    border-radius:var(--tr-radius,0.75rem);
    padding:1.25rem;
}
.loc-detected-badge{
    display:inline-flex;align-items:center;
    background:var(--tr-green-soft,#d1fae5);
    border:1px solid rgba(16,185,129,.2);
    border-radius:var(--tr-radius-full,50rem);
    padding:.3rem .85rem;
    font-size:.78rem;font-weight:500;
    color:var(--tr-green,#10b981);
}

/* ── Distance Badge on Task Cards ── */
.task-distance-badge{
    display:inline-flex;align-items:center;gap:.3rem;
    background:var(--tr-purple-ultra,#f5f3ff);
    border:1px solid var(--tr-purple-soft,#ede9fe);
    border-radius:var(--tr-radius-full,50rem);
    padding:.2rem .6rem;
    font-size:.7rem;font-weight:600;
    color:var(--tr-purple,#7c3aed);
}
.task-distance-badge i{font-size:.65rem}
.task-distance-badge.remote{
    background:rgba(59,130,246,.08);
    border-color:rgba(59,130,246,.15);
    color:#3b82f6;
}

/* ── Location badge in Bid Cards ── */
.bid-distance-tag{
    display:inline-flex;align-items:center;gap:.25rem;
    font-size:.68rem;font-weight:600;
    padding:.15rem .5rem;
    border-radius:var(--tr-radius-full,50rem);
}
.bid-distance-tag.near{
    background:var(--tr-green-soft,#d1fae5);
    color:#047857;
}
.bid-distance-tag.far{
    background:#fef3c7;
    color:#92400e;
}

/* ── Profile Location Section ── */
.profile-loc-section{
    background:var(--tr-purple-ultra,#f5f3ff);
    border:1.5px solid var(--tr-purple-soft,#ede9fe);
    border-radius:var(--tr-radius,0.75rem);
    padding:1rem 1.25rem;
}
.profile-loc-status{
    display:inline-flex;align-items:center;gap:.4rem;
    font-size:.82rem;font-weight:500;
}
.profile-loc-coords{
    font-size:.72rem;color:var(--tr-gray-500,#6b7280);font-family:monospace;
}


/* ══════════════════════════════════════════════════════
   DISTANCE CARDS — Rich Design (Task Show Page)
   Matches ts-budget / ts-tile design language
   ══════════════════════════════════════════════════════ */

.ts-dist-card{
    border-radius:var(--tr-radius-xl,1.25rem)!important;
    overflow:hidden;
}

/* ── Card Header Bands ── */
.ts-dist-header{
    padding:1.15rem 1.25rem;
    position:relative;
    overflow:hidden;
}

.ts-dist-header-green{
    background:linear-gradient(135deg,#059669 0%,#10b981 50%,#34d399 100%);
}
.ts-dist-header-red{
    background:linear-gradient(135deg,#b91c1c 0%,#ef4444 50%,#f87171 100%);
}
.ts-dist-header-purple{
    background:var(--tr-gradient-banner,linear-gradient(135deg,#4c1d95 0%,#6d28d9 50%,#7c3aed 100%));
}
.ts-dist-header-blue{
    background:linear-gradient(135deg,#1d4ed8 0%,#3b82f6 50%,#60a5fa 100%);
}

/* ── Decorative Orbs ── */
.ts-dist-orb{
    position:absolute;
    border-radius:50%;
    pointer-events:none;
}
.ts-dist-orb-1{
    width:180px;height:180px;
    top:-60px;right:-40px;
    background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%);
}
.ts-dist-orb-2{
    width:120px;height:120px;
    bottom:-35px;left:-25px;
    background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);
}

/* ── Header Icon Circle ── */
.ts-dist-icon-circle{
    width:42px;height:42px;
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;
    flex-shrink:0;
    backdrop-filter:blur(4px);
}
.ts-dist-icon-green{
    background:rgba(255,255,255,.2);color:#fff;
    border:1.5px solid rgba(255,255,255,.15);
}
.ts-dist-icon-red{
    background:rgba(255,255,255,.2);color:#fff;
    border:1.5px solid rgba(255,255,255,.15);
}
.ts-dist-icon-purple{
    background:rgba(255,255,255,.15);color:#fff;
    border:1.5px solid rgba(255,255,255,.12);
}
.ts-dist-icon-blue{
    background:rgba(255,255,255,.2);color:#fff;
    border:1.5px solid rgba(255,255,255,.15);
}

/* ── Header Text ── */
.ts-dist-title{
    font-size:.95rem;font-weight:700;color:#fff;
    line-height:1.3;letter-spacing:-.01em;
}
.ts-dist-subtitle{
    font-size:.72rem;font-weight:500;
    color:rgba(255,255,255,.7);
    margin-top:1px;
}

/* ── Stat Row ── */
.ts-dist-stat{
    display:flex;align-items:center;gap:.65rem;
    flex:1;
}
.ts-dist-stat-icon{
    width:38px;height:38px;
    border-radius:var(--tr-radius-sm,.5rem);
    display:flex;align-items:center;justify-content:center;
    font-size:.95rem;flex-shrink:0;
}
.ts-dist-stat-label{
    font-size:.62rem;font-weight:600;
    text-transform:uppercase;letter-spacing:.07em;
    color:var(--tr-gray-400,#9ca3af);
    margin-bottom:1px;
}
.ts-dist-stat-value{
    font-size:.92rem;font-weight:700;
    color:var(--tr-dark,#1e1b4b);
    line-height:1.2;
}
.ts-dist-stat-sep{
    width:1px;height:32px;
    background:var(--tr-gray-200,#e5e7eb);
    flex-shrink:0;
}

/* ── Progress Bar ── */
.ts-dist-progress-wrap{
    padding:.1rem 0;
}
.ts-dist-progress-label{
    font-size:.66rem;font-weight:600;
    color:var(--tr-gray-500,#6b7280);
    text-transform:uppercase;letter-spacing:.04em;
}
.ts-dist-progress-pct{
    font-size:.66rem;font-weight:700;
    color:var(--tr-gray-500,#6b7280);
}
.ts-dist-progress{
    height:6px;
    background:var(--tr-gray-100,#f3f4f6);
    border-radius:99px;
    overflow:hidden;
}
.ts-dist-progress-bar{
    height:100%;
    border-radius:99px;
    transition:width .6s cubic-bezier(.4,0,.2,1);
}
.ts-dist-progress-green{
    background:linear-gradient(90deg,#10b981,#34d399);
}
.ts-dist-progress-red{
    background:linear-gradient(90deg,#ef4444,#f87171);
}

/* ── Detect Location Card — No Location State ── */
.ts-dist-detect-body{
    display:flex;align-items:center;gap:1.25rem;
}
.ts-dist-detect-icon-wrap{
    position:relative;
    width:64px;height:64px;
    flex-shrink:0;
}
.ts-dist-detect-pin{
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    font-size:1.5rem;
    color:var(--tr-purple,#7c3aed);
    z-index:2;
}
.ts-dist-detect-pulse{
    position:absolute;inset:0;
    border-radius:50%;
    background:var(--tr-purple-ultra,#f5f3ff);
    border:2px solid var(--tr-purple-soft,#ede9fe);
    animation:distPulse 2s ease-in-out infinite;
}
@keyframes distPulse{
    0%,100%{transform:scale(1);opacity:1}
    50%{transform:scale(1.15);opacity:.6}
}
.ts-dist-detect-text{
    flex:1;
}
.ts-dist-detect-text p{
    font-size:.82rem;color:var(--tr-gray-600,#4b5563);
    line-height:1.6;margin:0;
}
.ts-dist-detect-features{
    margin-top:.5rem;
}
.ts-dist-detect-features span{
    display:inline-flex;align-items:center;gap:.3rem;
    font-size:.68rem;font-weight:600;
    color:var(--tr-gray-500,#6b7280);
    background:var(--tr-gray-50,#f9fafb);
    border:1px solid var(--tr-gray-200,#e5e7eb);
    border-radius:var(--tr-radius-full,50rem);
    padding:.25rem .65rem;
}
.ts-dist-detect-features span i{
    font-size:.7rem;color:var(--tr-purple,#7c3aed);
}
.ts-dist-detect-btn{
    font-weight:600;font-size:.88rem;
    transition:var(--tr-transition);
}
.ts-dist-detect-btn:hover{
    transform:translateY(-2px);
    box-shadow:var(--tr-shadow-purple,0 10px 30px -5px rgba(124,58,237,.25));
}

/* ── Spin icon for detect button ── */
.ts-dist-spin{
    animation:locSpin .8s linear infinite;
}

/* ── Responsive ── */
@media(max-width:575.98px){
    .ts-dist-detect-body{
        flex-direction:column;text-align:center;
    }
    .ts-dist-stat{
        flex-direction:column;text-align:center;gap:.35rem;
    }
    .ts-dist-stat-sep{
        width:100%;height:1px;
    }
    .ts-dist-header{
        padding:.85rem 1rem;
    }
}