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

/* --- 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}
.salon-therapist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
@media(max-width:480px){.salon-therapist-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* --- Card Photo --- */
.salon-card-photo{width:100%;aspect-ratio:2/3;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-area{font-size:10px;color:var(--primary,#c8a96e);margin-top:2px}
.salon-card-sns-overlay{position:absolute;bottom:8px;right:8px;z-index:2}
.salon-card-sns-overlay a{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;font-size:14px;text-decoration:none;transition:background .2s}
.salon-card-sns-overlay a:hover{background:var(--primary,#c8a96e)}
.salon-card-off{color:var(--dim,#ccc)!important}

/* --- Tab Nav (日付タブ) --- */
.salon-tab-nav{display:flex;gap:0;justify-content:flex-start;margin-bottom:28px;border-bottom:1px solid var(--bd,rgba(255,255,255,.1));overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}
.salon-tab-nav::-webkit-scrollbar{display:none}
.salon-tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:12px 16px;font-size:13px;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;flex-shrink:0}
.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,#d0cec8);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 --- */

/* --- NEW Badge --- */
/* NEW corner badge (v2: 中サイズ 50px 三角) */
.salon-badge-new{position:absolute;top:0;right:0;left:auto;width:0;height:0;border-style:solid;border-width:0 50px 50px 0;border-color:transparent #e94560 transparent transparent;z-index:3;background:none;padding:0;border-radius:0;font-size:0;letter-spacing:0}
.salon-badge-new::after{content:'NEW';position:absolute;top:8px;right:-44px;color:#fff;font-size:10px;font-weight:700;letter-spacing:1px;transform:rotate(45deg)}

/* ========== RECRUIT PAGE ========== */
.recruit-content{max-width:900px;margin:0 auto;padding:60px 24px 80px}
.recruit-section-title{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:24px;font-weight:400;letter-spacing:4px;color:var(--primary,#c8a96e);margin-bottom:8px}
.recruit-section-sub{font-size:11px;color:var(--dim,#908e88);letter-spacing:2px;margin-bottom:32px}
.recruit-section-divider{width:40px;height:1px;background:var(--primary,#c8a96e);margin:0 auto 40px;opacity:.5}
.recruit-table{width:100%;border-collapse:collapse;margin-bottom:60px}
.recruit-table th,.recruit-table td{padding:20px 24px;text-align:left;vertical-align:top;border-bottom:1px solid var(--bd,rgba(255,255,255,.08));font-size:14px}
.recruit-table th{width:160px;font-weight:500;color:var(--primary,#c8a96e);letter-spacing:1px;white-space:nowrap;background:var(--sf,rgba(255,255,255,.03))}
.recruit-table td{color:var(--tx2,#d0cec8);line-height:1.9}
.recruit-table td ul{list-style:none;padding:0;margin:0}
.recruit-table td ul li{padding:2px 0}
.recruit-table td ul li::before{content:'・';color:var(--primary,#c8a96e);margin-right:4px}
@media(max-width:600px){.recruit-table,.recruit-table tbody,.recruit-table tr,.recruit-table th,.recruit-table td{display:block;width:100%}.recruit-table th{padding:16px 20px 8px;border-bottom:none}.recruit-table td{padding:8px 20px 20px}}

.recruit-message{background:var(--bg2,#141419);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:8px;padding:40px 36px;margin-bottom:60px}
.recruit-message-title{font-size:16px;font-weight:500;color:var(--primary,#c8a96e);letter-spacing:1px;margin-bottom:16px}
.recruit-message-text{font-size:14px;color:var(--tx2,#d0cec8);line-height:2;white-space:pre-line}

.recruit-apply-section{text-align:center;margin-bottom:60px}
.recruit-apply-title{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:22px;font-weight:400;letter-spacing:3px;color:var(--primary,#c8a96e);margin-bottom:8px}
.recruit-apply-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.recruit-apply-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;border-radius:4px;text-decoration:none;font-size:14px;font-weight:500;letter-spacing:1px;transition:opacity .2s,transform .2s;min-width:200px;justify-content:center}
.recruit-apply-btn:hover{opacity:.85;transform:translateY(-2px)}
.recruit-apply-btn--line{background:#06c755;color:#fff}
.recruit-apply-btn--mail{background:var(--primary,#c8a96e);color:#0e0e12}
.recruit-apply-btn--tel{border:1px solid var(--bd,rgba(255,255,255,.08));color:var(--tx,#e8e6e1);background:transparent}

.recruit-form-section{background:var(--bg2,#141419);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:8px;padding:48px 40px}
.recruit-form-title{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:22px;font-weight:400;letter-spacing:3px;color:var(--primary,#c8a96e);text-align:center;margin-bottom:8px}
.recruit-form-sub{text-align:center;font-size:11px;color:var(--dim,#908e88);letter-spacing:1px;margin-bottom:36px}
.recruit-form-group{margin-bottom:24px}
.recruit-form-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--tx2,#d0cec8);letter-spacing:.5px;margin-bottom:8px}
.recruit-form-required{font-size:9px;background:#e94560;color:#fff;padding:2px 6px;border-radius:2px;letter-spacing:1px}
.recruit-form-input,.recruit-form-select,.recruit-form-textarea{width:100%;padding:12px 16px;background:var(--bg,#0e0e12);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:4px;color:var(--tx,#e8e6e1);font-family:inherit;font-size:14px;transition:border-color .2s}
.recruit-form-input:focus,.recruit-form-select:focus,.recruit-form-textarea:focus{outline:none;border-color:var(--primary,#c8a96e)}
.recruit-form-textarea{min-height:120px;resize:vertical}
.recruit-form-select{appearance:none;cursor:pointer}
.recruit-radio-group{display:flex;gap:20px;margin-top:4px}
.recruit-radio-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:var(--tx2,#d0cec8)}
.recruit-radio-label input[type="radio"]{accent-color:var(--primary,#c8a96e)}
.recruit-form-submit{display:block;width:100%;max-width:320px;margin:36px auto 0;padding:16px 24px;background:var(--primary,#c8a96e);color:#0e0e12;border:none;border-radius:4px;font-family:inherit;font-size:15px;font-weight:500;letter-spacing:2px;cursor:pointer;transition:opacity .2s,transform .2s}
.recruit-form-submit:hover{opacity:.85;transform:translateY(-2px)}
@media(max-width:600px){.recruit-form-section{padding:32px 20px}.recruit-apply-buttons{flex-direction:column;align-items:center}.recruit-apply-btn{width:100%;max-width:320px}}

/* ========== MENU / PRICE PAGE ========== */
.menu-content{max-width:900px;margin:0 auto;padding:60px 24px 80px}
.menu-section{margin-bottom:48px}
.menu-section-title{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:22px;font-weight:400;letter-spacing:3px;color:var(--primary,#c8a96e);margin-bottom:6px}
.menu-section-sub{font-size:11px;color:var(--dim,#908e88);letter-spacing:2px;margin-bottom:24px}
.menu-table{width:100%;border-collapse:collapse}
.menu-table tr{border-bottom:1px solid var(--bd,rgba(255,255,255,.08))}
.menu-table td{padding:16px 8px;font-size:14px}
.menu-table .menu-name{color:var(--tx,#e8e6e1)}
.menu-table .menu-time{color:var(--dim,#908e88);font-size:12px;text-align:center;width:80px}
.menu-table .menu-price{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:20px;font-weight:400;color:var(--primary,#c8a96e);text-align:right;white-space:nowrap;letter-spacing:1px}
.menu-table .menu-price small{font-size:11px;color:var(--dim,#908e88);font-family:var(--font-body,'Noto Sans JP',sans-serif)}
.menu-option-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.menu-option-grid{grid-template-columns:1fr}}
.menu-option-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg2,#141419);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:6px}
.menu-option-name{font-size:13px;color:var(--tx2,#d0cec8)}
.menu-option-price{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:18px;color:var(--primary,#c8a96e)}
.menu-note{margin-top:32px;font-size:12px;color:var(--dim,#908e88);line-height:2}

/* Terms section */
.salon-terms-section{background:var(--bg2,#141419);border-top:1px solid var(--bd,rgba(255,255,255,.08));border-bottom:1px solid var(--bd,rgba(255,255,255,.08));padding:80px 24px}
.salon-terms-inner{max-width:900px;margin:0 auto}
.terms-notice{font-size:15px;color:var(--tx,#e8e6e1);line-height:2.2;text-align:center;margin-bottom:40px}
.terms-heading{font-size:12px;color:var(--dim,#908e88);letter-spacing:2px;text-align:center;margin-bottom:28px;padding-bottom:16px;border-bottom:1px solid var(--bd,rgba(255,255,255,.08))}
.terms-list{list-style:none;padding:0;margin:0 auto 36px;max-width:640px}
.terms-list li{padding:12px 0 12px 28px;position:relative;font-size:14px;color:var(--tx2,#d0cec8);border-bottom:1px solid rgba(255,255,255,.04)}
.terms-list li::before{content:'✕';position:absolute;left:0;top:12px;color:#e94560;font-size:11px;font-weight:700}
.terms-footer{font-size:13px;color:var(--tx2,#d0cec8);line-height:2.2;text-align:center;padding-top:28px;border-top:1px solid var(--bd,rgba(255,255,255,.08))}
.terms-disclaimer{margin-top:28px;font-size:11px;color:var(--dim,#908e88);line-height:2;text-align:center}

/* ========== CONTACT PAGE ========== */
.contact-content{max-width:700px;margin:0 auto;padding:60px 24px 80px}
.contact-intro{text-align:center;font-size:14px;color:var(--tx2,#d0cec8);line-height:2;margin-bottom:48px}
.contact-form-section{background:var(--bg2,#141419);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:8px;padding:48px 40px}
.contact-form-title{font-family:var(--font-display,'Cormorant Garamond',serif);font-size:22px;font-weight:400;letter-spacing:3px;color:var(--primary,#c8a96e);text-align:center;margin-bottom:8px}
.contact-form-sub{text-align:center;font-size:11px;color:var(--dim,#908e88);letter-spacing:1px;margin-bottom:36px}
.contact-form-group{margin-bottom:24px}
.contact-form-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--tx2,#d0cec8);letter-spacing:.5px;margin-bottom:8px}
.contact-form-required{font-size:9px;background:#e94560;color:#fff;padding:2px 6px;border-radius:2px;letter-spacing:1px}
.contact-form-input,.contact-form-select,.contact-form-textarea{width:100%;padding:12px 16px;background:var(--bg,#0e0e12);border:1px solid var(--bd,rgba(255,255,255,.08));border-radius:4px;color:var(--tx,#e8e6e1);font-family:inherit;font-size:14px;transition:border-color .2s}
.contact-form-input:focus,.contact-form-select:focus,.contact-form-textarea:focus{outline:none;border-color:var(--primary,#c8a96e)}
.contact-form-textarea{min-height:160px;resize:vertical}
.contact-form-select{appearance:none;cursor:pointer}
.contact-radio-group{display:flex;gap:20px;margin-top:4px}
.contact-radio-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:var(--tx2,#d0cec8)}
.contact-radio-label input[type="radio"]{accent-color:var(--primary,#c8a96e)}
.contact-form-submit{display:block;width:100%;max-width:320px;margin:36px auto 0;padding:16px 24px;background:var(--primary,#c8a96e);color:#0e0e12;border:none;border-radius:4px;font-family:inherit;font-size:15px;font-weight:500;letter-spacing:2px;cursor:pointer;transition:opacity .2s,transform .2s}
.contact-form-submit:hover{opacity:.85;transform:translateY(-2px)}
.contact-other-methods{margin-top:48px;text-align:center}
.contact-other-title{font-size:13px;color:var(--dim,#908e88);letter-spacing:1px;margin-bottom:20px}
.contact-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.contact-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:4px;font-size:13px;font-weight:500;letter-spacing:1px;transition:opacity .2s,transform .2s;min-width:180px;justify-content:center;text-decoration:none}
.contact-btn:hover{opacity:.85;transform:translateY(-2px)}
.contact-btn--tel{border:1px solid var(--bd,rgba(255,255,255,.08));color:var(--tx,#e8e6e1)}
.contact-btn--line{background:#06c755;color:#fff}
@media(max-width:600px){.contact-form-section{padding:32px 20px}.contact-buttons{flex-direction:column;align-items:center}.contact-btn{width:100%;max-width:300px}}

/* --- Link HTML Tag --- */
.salon-link-html{display:block;max-width:100%;text-align:center}
.salon-link-html img{max-width:100%;height:auto;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.salon-link-html a{display:inline-block;transition:opacity .2s}
.salon-link-html a:hover{opacity:.8}
