
.ftf-search{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.ftf-search input,.ftf-search select{padding:12px 14px;border:1px solid #e5e7eb;border-radius:12px;width:100%;max-width:520px}
.ftf-search .ftf-cuisine,.ftf-search .ftf-price{max-width:260px}
.ftf-cards .ftf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.ftf-card{position:relative;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.06)}
.ftf-card img{width:100%;height:200px;object-fit:cover}
.ftf-body{padding:14px 16px 16px}
.ftf-badge{position:absolute;left:14px;top:14px;padding:6px 10px;border-radius:999px;font-size:12px;color:#fff}
.ftf-badge.open{background:#16a34a}.ftf-badge.closed{background:#ef4444}
.ftf-heart{position:absolute;right:14px;top:14px;border:none;background:#fff;width:36px;height:36px;border-radius:999px;box-shadow:0 6px 16px rgba(0,0,0,.12);cursor:pointer;font-size:18px;line-height:36px;display:flex;align-items:center;justify-content:center}
.ftf-heart::before{content:"\2665"; color:#6b7280;}
.ftf-heart.on::before{color:#e11d48;}
.ftf-card h4{margin:6px 0 8px;font-size:20px}
.ftf-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.chip{background:#f3f4f6;border-radius:999px;padding:4px 8px;font-size:12px}
.chip.muted{background:#eef2ff}
.chip.rating{background:transparent}
.ftf-star{color:#d1d5db;font-size:14px}.ftf-star.on{color:#f59e0b}
.ftf-address{color:#6b7280;margin-top:6px}
.ftf-hours{color:#6b7280;margin-top:4px}
.button{padding:10px 14px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;margin-top:10px;cursor:pointer}
.button-primary{background:#2563eb;color:#fff;border-color:#2563eb}
.ftf-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:9999}
.ftf-modal-content{background:#fff;width:min(1000px,92vw);border-radius:18px;overflow:hidden;transform:translateY(20px);animation:ftf-in .18s ease forwards;position:relative}
@keyframes ftf-in{to{transform:translateY(0);opacity:1;}}
.ftf-modal .ftf-close{position:absolute;right:16px;top:10px;cursor:pointer;font-size:24px}
.ftf-detail{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;padding:32px;max-height:80vh;overflow-y:auto}
.ftf-detail-left{display:flex;flex-direction:column;gap:20px}
.ftf-truck-image-container{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.12)}
.ftf-truck-image-container img{width:100%;height:300px;object-fit:cover;display:block}
.ftf-truck-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(0,0,0,0.1) 0%,transparent 30%,transparent 70%,rgba(0,0,0,0.3) 100%);display:flex;justify-content:space-between;align-items:flex-start;padding:16px}
.ftf-status-badge{background:#ef4444;color:#fff;padding:8px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.ftf-status-badge.open{background:#16a34a}
.ftf-favorite-btn{background:rgba(255,255,255,0.9);border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s ease;backdrop-filter:blur(10px)}
.ftf-favorite-btn:hover{background:rgba(255,255,255,1);transform:scale(1.05)}
.ftf-favorite-btn.on svg{color:#e11d48;fill:currentColor}
.ftf-favorite-btn svg{color:#6b7280;transition:all 0.2s ease}
.ftf-truck-info{display:flex;flex-direction:column;gap:16px}
.ftf-truck-title{font-size:28px;font-weight:700;color:#1f2937;margin:0;line-height:1.2}
.ftf-truck-meta{display:flex;align-items:center;gap:12px;font-size:16px;color:#6b7280}
.ftf-cuisine{font-weight:600;color:#374151}
.ftf-price-level{font-weight:700;color:#059669;font-size:18px}
.ftf-rating-section{display:flex;align-items:center;gap:12px}
.ftf-stars-display{display:flex;gap:2px}
.ftf-stars-display .ftf-star{font-size:20px;color:#d1d5db}
.ftf-stars-display .ftf-star.on{color:#f59e0b}
.ftf-rating-text{display:flex;align-items:center;gap:8px}
.ftf-rating-avg{font-size:18px;font-weight:700;color:#1f2937}
.ftf-rating-count{font-size:14px;color:#6b7280}
.ftf-contact-info{display:flex;flex-direction:column;gap:12px}
.ftf-contact-item{display:flex;align-items:center;gap:12px;font-size:14px;color:#374151}
.ftf-contact-item a{color:#2563eb;text-decoration:none;font-weight:500}
.ftf-contact-item a:hover{text-decoration:underline}
.ftf-icon{color:#6b7280;flex-shrink:0}
.ftf-detail-right{display:flex;flex-direction:column;gap:24px}
.ftf-reviews-section{display:flex;flex-direction:column;gap:20px}
.ftf-reviews-title{font-size:24px;font-weight:700;color:#1f2937;margin:0;padding-bottom:16px;border-bottom:2px solid #e5e7eb}
.ftf-reviews-list{display:flex;flex-direction:column;gap:16px;max-height:300px;overflow-y:auto;padding-right:8px}
.ftf-review-item{background:#f9fafb;border-radius:12px;padding:16px;border-left:4px solid #e5e7eb}
.ftf-review-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.ftf-review-stars{display:flex;gap:2px}
.ftf-review-stars .ftf-star{font-size:14px;color:#d1d5db}
.ftf-review-stars .ftf-star.on{color:#f59e0b}
.ftf-review-author{font-weight:600;color:#374151;font-size:14px}
.ftf-review-date{color:#6b7280;font-size:12px;margin-left:auto}
.ftf-review-content{color:#4b5563;font-size:14px;line-height:1.5}
.ftf-review-form-section{background:#f8fafc;border-radius:12px;padding:20px;border:1px solid #e2e8f0}
.ftf-review-form-title{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 16px 0}
.ftf-form-group{margin-bottom:16px}
.ftf-form-input,.ftf-form-textarea{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color 0.2s ease;background:#fff}
.ftf-form-input:focus,.ftf-form-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,0.1)}
.ftf-form-textarea{resize:vertical;min-height:80px}
.ftf-rating-label{display:block;font-weight:600;color:#374151;margin-bottom:8px;font-size:14px}
.ftf-rating-value{display:inline-block;margin-left:12px;font-size:14px;color:#6b7280;font-weight:500}
.ftf-stars-input{display:flex;gap:6px;cursor:pointer;padding:8px 0}
.ftf-stars-input .ftf-star{font-size:28px;color:#d1d5db;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);cursor:pointer;user-select:none;position:relative;display:inline-block;line-height:1}
.ftf-stars-input .ftf-star:hover{transform:scale(1.2);color:#fbbf24}
.ftf-stars-input .ftf-star.on{color:#f59e0b;transform:scale(1.1)}
.ftf-stars-input .ftf-star.clicked{animation:starClick 0.4s ease-out}
@keyframes starClick{
  0%{transform:scale(1)}
  50%{transform:scale(1.4);color:#fbbf24}
  100%{transform:scale(1.1)}
}
.ftf-submit-btn{background:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all 0.2s ease;font-size:14px}
.ftf-submit-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,0.3)}
.ftf-submit-btn:active{transform:translateY(0)}
/* Custom scrollbar for reviews */
.ftf-reviews-list::-webkit-scrollbar{width:6px}
.ftf-reviews-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}
.ftf-reviews-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
.ftf-reviews-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}
/* Responsive design */
@media (max-width: 768px) {
  .ftf-detail{grid-template-columns:1fr;gap:24px;padding:20px}
  .ftf-truck-image-container img{height:250px}
  .ftf-truck-title{font-size:24px}
  .ftf-reviews-list{max-height:250px}
  .ftf-modal-content{width:95vw;margin:20px}
}
/* Enhanced star rating animations */
.ftf-stars-input .ftf-star{position:relative;overflow:visible}
.ftf-stars-input .ftf-star::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(251,191,36,0.3);border-radius:50%;transform:translate(-50%,-50%);transition:all 0.3s ease;pointer-events:none}
.ftf-stars-input .ftf-star:hover::after{width:40px;height:40px}
.ftf-stars-input .ftf-star.on::after{width:30px;height:30px;background:rgba(245,158,11,0.2)}
/* Loading states */
.ftf-submit-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}
.ftf-submit-btn:disabled:hover{transform:none;box-shadow:none}
.form-control,.form-select{padding:10px;border:1px solid #ced4da;border-radius:8px;width:100%}
.btn{display:inline-block;padding:10px 14px;border-radius:10px;border:1px solid transparent;cursor:pointer}
.btn-primary{background:#0d6efd;color:#fff}
.mb-3{margin-bottom:1rem}.mt-2{margin-top:.5rem}.w-100{width:100%}.row{display:flex;gap:10px}.col{flex:1}
.ftf-upload-preview.show .ftf-upload-progress{height:6px;background:#0d6efd;width:0;animation:ftf-progress 1.2s ease forwards}
@keyframes ftf-progress{from{width:0}to{width:100%}}

.ftf-rating-row{display:flex;align-items:center;gap:8px;margin-top:2px}
.ftf-rating-row .ftf-stars .ftf-star{font-size:16px}
.ftf-rating-num{margin-left:auto;font-size:13px;display:flex;gap:6px;align-items:center}
.ftf-rating-num .muted{color:#6b7280}
/* Toast */
.ftf-toast{position:fixed;left:50%;top:24px;transform:translateX(-50%) translateY(-20px);opacity:0;border-radius:12px;padding:10px 14px;background:#0ea5e9;color:#fff;display:flex;gap:10px;align-items:center;box-shadow:0 12px 30px rgba(0,0,0,.18);z-index:10000;transition:.25s ease}
.ftf-toast.success{background:#16a34a}
.ftf-toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.ftf-toast-icon{width:22px;height:22px;border-radius:999px;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}

/* Modals for Register & Favorites */
.ftf-register-modal.ftf-modal, .ftf-fav-modal.ftf-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:9999}
.ftf-register-content{width:min(640px,92vw);border-radius:18px;overflow:hidden;background:#fff;position:relative}
.ftf-fav-content{width:min(1000px,94vw);border-radius:18px;overflow:hidden;background:#fff;position:relative}
.ftf-modal .ftf-close{position:absolute;right:16px;top:12px;cursor:pointer;font-size:22px}
.ftf-fav-list.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}

/* Ensure rating stars render correctly in list cards */
.ftf-stars{display:flex;gap:2px}
.ftf-stars .ftf-star{font-size:16px;color:#d1d5db}
.ftf-stars .ftf-star.on{color:#f59e0b}


/* --- Distance badge (mi) --- */
.ftf-card .ftf-distance{
  position:absolute; right:16px; top:56px;
  background:#fff; color:#6b7280; border-radius:10px;
  padding:4px 8px; font-size:13px; box-shadow:0 6px 18px rgba(0,0,0,.08);
  display:none;
}
.ftf-card .ftf-distance.show{ display:inline-block; }
