/* ========== Salon Scheduler Front CSS ========== */

/* --- Therapist Grid --- */
.salon-therapist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:24px}
@media(max-width:480px){.salon-therapist-grid{grid-template-columns:repeat(2,1fr);gap:14px}}

/* --- Card --- */
.salon-therapist-card{display:block;background:var(--color_bg,#fff);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:10px;overflow:hidden;transition:box-shadow .2s,transform .2s;text-decoration:none;color:inherit}
.salon-therapist-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.15);transform:translateY(-3px);text-decoration:none;color:inherit}

/* --- Card Photo --- */
.salon-card-photo{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,rgba(200,169,110,.15),rgba(200,169,110,.05));position:relative;overflow:hidden}
.salon-card-photo img{width:100%;height:100%;object-fit:cover}
.salon-card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:48px;opacity:.3;color:var(--primary,#c8a96e)}

/* --- Badges --- */
.salon-badge-working{position:absolute;top:10px;left:10px;background:var(--primary,#c8a96e);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:3px;letter-spacing:1px}
.salon-badge-full{position:absolute;top:10px;left:10px;background:#e94560;color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:3px}
.salon-card-full{color:#e94560!important;font-weight:700}

/* --- Card Info --- */
.salon-card-info{padding:14px 16px;text-align:center}
.salon-card-name{font-size:15px;font-weight:700;color:var(--tx,#e8e6e1);margin-bottom:4px}
.salon-card-age{font-size:.85em;font-weight:400;opacity:.6;margin-left:2px}
.salon-card-time{font-size:13px;color:var(--dim,#888);letter-spacing:.5px}
.salon-card-spec{font-size:12px;color:var(--dim,#999);margin-bottom:2px}
.salon-card-off{color:var(--dim,#ccc)!important}

/* --- Tab Nav (日付タブ) --- */
.salon-tab-nav{display:flex;gap:0;justify-content:center;margin-bottom:28px;border-bottom:1px solid var(--bd,rgba(255,255,255,.1))}
.salon-tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:12px 20px;font-size:14px;font-weight:400;color:var(--dim,#888);cursor:pointer;white-space:nowrap;transition:all .2s;font-family:inherit;line-height:1.3;letter-spacing:.5px}
.salon-tab-btn:hover{color:var(--tx,#e8e6e1)}
.salon-tab-btn.active{color:var(--primary,#c8a96e);border-bottom-color:var(--primary,#c8a96e);font-weight:700}
.salon-today-mark{display:block;font-size:9px;letter-spacing:1px;margin-top:2px;color:var(--primary,#c8a96e)}
.salon-tab-content{display:none}.salon-tab-content.active{display:block}

/* --- Today Section --- */
.salon-today .salon-section-title{display:none}
.salon-empty{text-align:center;padding:40px 20px;color:var(--dim,#888);font-size:14px}

/* --- Weekly Section --- */
.salon-weekly .salon-section-title{display:none}

/* --- News --- */
.salon-news .salon-section-title{display:none}
.salon-news-list{list-style:none;padding:0;margin:0}
.salon-news-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--bd,rgba(255,255,255,.08));text-decoration:none;color:inherit;transition:opacity .2s;align-items:baseline}
.salon-news-item:hover{opacity:.7}
.salon-news-date{font-size:12px;color:var(--dim,#888);white-space:nowrap;letter-spacing:1px;min-width:80px}
.salon-news-cat{font-size:10px;padding:2px 8px;border-radius:3px;font-weight:700;white-space:nowrap}
.salon-news-title{font-size:14px;color:var(--tx,#e8e6e1)}
.salon-news-body{font-size:13px;color:var(--dim,#888);line-height:1.6;margin-top:8px}
.salon-news-toggle{background:none;border:none;color:var(--primary,#c8a96e);font-size:12px;cursor:pointer;padding:0;margin-top:4px}

/* --- Therapist Detail --- */
.salon-profile{max-width:800px;margin:0 auto}
.salon-profile-header{display:flex;gap:32px;margin-bottom:32px;flex-wrap:wrap}
.salon-profile-photo{width:280px;flex-shrink:0;aspect-ratio:3/4;border-radius:8px;overflow:hidden;background:var(--sf,rgba(255,255,255,.03))}
.salon-profile-photo img{width:100%;height:100%;object-fit:cover}
.salon-profile-info{flex:1;min-width:200px}
.salon-profile-name{font-size:24px;font-weight:700;color:var(--tx,#e8e6e1);margin-bottom:8px}
.salon-profile-spec{font-size:13px;color:var(--dim,#888);margin-bottom:16px}
.salon-profile-table{width:100%;font-size:13px;border-collapse:collapse}
.salon-profile-table th{text-align:left;padding:8px 12px;color:var(--dim,#888);font-weight:400;width:80px;border-bottom:1px solid var(--bd,rgba(255,255,255,.08))}
.salon-profile-table td{padding:8px 12px;color:var(--tx,#e8e6e1);border-bottom:1px solid var(--bd,rgba(255,255,255,.08))}
.salon-profile-text{line-height:1.8;color:var(--tx2,#b8b6b1);font-size:14px}
.salon-profile-schedule{margin-top:24px}
.salon-profile-schedule h3{font-size:16px;color:var(--tx,#e8e6e1);margin-bottom:12px}
@media(max-width:600px){
  .salon-profile-header{flex-direction:column}
  .salon-profile-photo{width:100%;max-width:320px;margin:0 auto}
}

/* Therapist list section */
.salon-therapist-list-section .salon-section-title{display:none}

/* --- Tab JS --- */
