/* TherapistSelection Component Styles */
:root{
  --brand-primary: var(--primary);
  --brand-secondary:#F5F5F5;
}

.btn[disabled]{opacity:.55;cursor:not-allowed;filter:saturate(.8)}
.btn-secondary{background:var(--brand-secondary);color:#111827;border:1px solid #d1d5db}

.ts-modal{position:fixed;inset:0;display:none;z-index:1000}
.ts-modal.is-open{display:block}
.ts-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);opacity:0;animation:ts-fade .3s ease-in-out forwards}
.ts-dialog{position:relative;width:min(92vw,980px);max-height:85vh;margin:6vh auto;background:#fff;border-radius:16px;box-shadow:0 16px 48px rgba(0,0,0,.2);padding:20px;transform:translateY(8px) scale(.98);animation:ts-pop .3s ease-in-out forwards;overflow-y:auto;-webkit-overflow-scrolling:touch}
@keyframes ts-fade{to{opacity:1}}
@keyframes ts-pop{to{transform:none}}
.ts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.ts-title{font-size:1.4rem;font-weight:800;color:var(--primary)}
.ts-close{background:#111827;color:#fff;border:none;border-radius:999px;width:34px;height:34px;font-weight:800}
.ts-close:focus{outline:2px solid rgba(17,24,39,.35);outline-offset:2px}
.ts-attrib{font-size:.75rem;color:#6b7280;margin:6px 0 10px}
.ts-toolbar{display:flex;gap:8px;align-items:center;margin:8px 0 12px}
.ts-search{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:0.95rem}

.ts-list{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ts-row{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,0.06);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.ts-row:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.10)}
.ts-row[aria-selected="true"]{border-color:var(--brand-primary);box-shadow:0 10px 30px rgba(31,95,67,.18)}
.ts-media{width:100%;height:160px;object-fit:cover}
.ts-name{font-weight:800;color:#374151;padding:10px 12px}
.ts-tags{padding:0 12px 10px;display:flex;gap:6px;flex-wrap:wrap}
.ts-tag{background:#eef2f7;color:#1f2937;border:1px solid #d1d5db;border-radius:999px;padding:4px 8px;font-size:.8rem}
.ts-rating{padding:0 12px 10px;color:#374151;font-weight:700}
.ts-actions{display:flex;justify-content:flex-end;padding:8px 12px}
.ts-select{background:var(--brand-primary);color:#fff;border:1px solid rgba(31,95,67,.3);border-radius:10px;padding:8px 12px;font-weight:700}
.ts-filter{padding:8px 12px;border:1px solid #d1d5db;border-radius:999px;background:#fff;color:#374151;font-weight:600}
.ts-check{display:inline-flex;align-items:center;gap:6px;color:var(--brand-primary);font-weight:700;margin-top:6px}
.ts-skeleton{width:100%;height:160px;background:#e5e7eb;margin:0;animation:ts-pulse 1.1s ease-in-out infinite}
@keyframes ts-pulse{0%{opacity:.6}50%{opacity:1}100%{opacity:.6}}

@media (max-width:680px){
  .ts-dialog{margin:10vh 12px;padding:16px;max-height:80vh}
  .ts-list{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:480px){
  .ts-list{grid-template-columns:1fr}
}

.ts-pager{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:12px}
.ts-page-btn{background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:999px;padding:8px 12px;font-weight:700}
.ts-page-info{color:#6b7280;font-weight:700}

.ts-confirm{position:fixed;inset:0;z-index:1100}
.ts-confirm-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);animation:ts-fade .25s ease-in-out forwards}
.ts-confirm-dialog{position:relative;width:min(92vw,420px);margin:10vh auto;background:#fff;border-radius:16px;box-shadow:0 16px 48px rgba(0,0,0,.2);padding:18px;transform:translateY(6px) scale(.98);animation:ts-pop .25s ease-in-out forwards}
.ts-confirm-title{font-size:1.2rem;color:#111827;font-weight:800;margin:0 0 8px}
.ts-confirm-media{width:100%;height:180px;border-radius:12px;object-fit:cover;margin:6px 0 12px}
.ts-confirm-actions{display:flex;justify-content:flex-end;gap:8px}
.ts-ok{background:var(--brand-primary);color:#fff;border:1px solid rgba(31,95,67,.3);border-radius:10px;padding:8px 12px;font-weight:700;cursor:pointer}
.ts-cancel{background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:10px;padding:8px 12px;font-weight:700;cursor:pointer}

@media (prefers-reduced-motion: reduce){
  .ts-backdrop{animation:none}
  .ts-dialog{animation:none}
}
