/*
Theme Name: 僕の彼女
Author: 僕の彼女
Description: 僕の彼女 - Yokohama men's relaxation salon theme. Pop/candy design with color-theme switch. Custom post types: news / therapist / schedule.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: tug-excellent
*/

:root{
  --pink-deep:#ff4d8d;
  --pink:#ff7eb6;
  --pink-soft:#ffd6e6;
  --pink-pale:#fff6fa;
  --accent:#ff5a7a;
  --gold:#ffce5e;
  --text:#3a2630;
  --text-soft:#9a7d8a;
  --line:#f1e3ea;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(255,77,141,.10);
  --shadow-sm:0 4px 14px rgba(58,38,48,.06);
  --radius:18px;
  --maxw:1100px;
  --page-bg:#ffffff;
  --grad-bar:linear-gradient(90deg,var(--pink-deep),#ff6aa5,var(--pink-deep));
  --grad-nav:linear-gradient(90deg,#ff5a93,#ff8ab9);
  --grad-cta:linear-gradient(160deg,#ff7eb6,#ff4d8d);
  --hero-overlay:linear-gradient(180deg,rgba(255,242,247,.28),rgba(255,232,242,.52));
  --hero-img:url(images/hero-bg.jpg);
  --room1:url(images/room1.jpg);
  --room2:url(images/room2.jpg);
  --room3:url(images/room3.jpg);
  --kw1:linear-gradient(135deg,#ff9ec0,#ff4d8d);
  --kw2:linear-gradient(135deg,#ffcf7a,#ff9a3c);
  --kw3:linear-gradient(135deg,#8fcdff,#5a8cff);
  --card-bg:#ffffff;
  --footer-bg:#332530;
  --pattern-op:.10;
}

/* ===== 配色テーマ（プレビュー切替用） ===== */
/* 淡い系：ラベンダー寄りの優しいパステル */
:root[data-theme="pale"]{
  --pink-deep:#d98bb8;--pink:#ecb6d6;--pink-soft:#f1e2ee;--pink-pale:#f5f2fb;
  --accent:#a98fd0;--gold:#ecd7a8;--text:#5e4f59;--text-soft:#ab9da6;--line:#efe9f2;
  --grad-bar:linear-gradient(90deg,#e2a6c8,#f0c6dc,#e2a6c8);
  --grad-nav:linear-gradient(90deg,#e7add0,#cfc0e6);
  --grad-cta:linear-gradient(160deg,#ffd8e8,#dcc6ec);
  --hero-overlay:linear-gradient(180deg,rgba(244,240,251,.58),rgba(252,243,249,.70));
  --kw1:linear-gradient(135deg,#f2bcd6,#dd95bd);--kw2:linear-gradient(135deg,#efd9b6,#e3c79e);--kw3:linear-gradient(135deg,#c9bce8,#a98fd0);
}
/* 赤系：はっきりした情熱の赤 */
:root[data-theme="red"]{
  --pink-deep:#cf1f37;--pink:#ff4d5e;--pink-soft:#ffccd0;--pink-pale:#fdecee;
  --accent:#a3122a;--gold:#e8b24e;--text:#3a2228;--text-soft:#9c7a80;--line:#f3dde0;
  --grad-bar:linear-gradient(90deg,#c81d35,#ff3d50,#c81d35);
  --grad-nav:linear-gradient(90deg,#c81d35,#ff4f5f);
  --grad-cta:linear-gradient(160deg,#ff4356,#b3142a);
  --hero-overlay:linear-gradient(180deg,rgba(207,31,55,.44),rgba(120,12,28,.56));
  --kw1:linear-gradient(135deg,#ff5a68,#cf1f37);--kw2:linear-gradient(135deg,#ffcf7a,#ef8f3c);--kw3:linear-gradient(135deg,#ff8a96,#d11f38);
}
/* ギャル系：派手＆高彩度（マゼンタ×パープル×シアン） */
:root[data-theme="gal"]{
  --pink-deep:#ff1f9c;--pink:#ff5cc0;--pink-soft:#ffc0ea;--pink-pale:#fbe6fb;
  --accent:#8a2be2;--gold:#ffd23f;--text:#2a1430;--text-soft:#8a6a92;--line:#efd6ef;
  --grad-bar:linear-gradient(90deg,#ff1f9c,#9b3cff,#1fd0ff);
  --grad-nav:linear-gradient(90deg,#ff1f9c,#9b3cff);
  --grad-cta:linear-gradient(160deg,#ff45bb,#8a2be2);
  --hero-overlay:linear-gradient(180deg,rgba(255,31,156,.42),rgba(120,40,210,.54));
  --kw1:linear-gradient(135deg,#ff5cc0,#ff1f9c);--kw2:linear-gradient(135deg,#a86bff,#7a2dff);--kw3:linear-gradient(135deg,#4fe0ff,#1fa9ff);
}
/* 高級感系：黒×金（ダークモード） */
:root[data-theme="luxury"]{
  --page-bg:#0f0d12;--card-bg:#1b1822;--footer-bg:#080709;--pattern-op:.04;
  --pink-deep:#d4af37;--pink:#e6c869;--pink-soft:#3a301c;--pink-pale:#16131c;
  --accent:#e8c66a;--gold:#d4af37;--text:#f2ecdd;--text-soft:#b3a282;--line:#332c3a;
  --grad-bar:linear-gradient(90deg,#15121b,#2a2233,#15121b);
  --grad-nav:linear-gradient(90deg,#14111a,#221c2b);
  --grad-cta:linear-gradient(160deg,#1d1826,#0d0b10);
  --hero-overlay:linear-gradient(180deg,rgba(10,9,12,.42),rgba(10,9,12,.66));
  --hero-img:url(images/hero-bg-luxury.jpg);
  --room1:url(images/room1-lux.jpg);
  --room2:url(images/room2-lux.jpg);
  --room3:url(images/room3-lux.jpg);
  --kw1:linear-gradient(135deg,#e6c869,#b8923f);--kw2:linear-gradient(135deg,#cdb06a,#9c7d34);--kw3:linear-gradient(135deg,#d4af37,#8a6e2a);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:118px;word-break:auto-phrase;}
body{
  font-family:"Zen Maru Gothic",sans-serif;
  color:var(--text);
  background:var(--page-bg);
  line-height:1.85;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px;}

/* ===== 虹色ロゴ(控えめ) ===== */
.logo-mark{
  width:var(--s,42px);height:var(--s,42px);border-radius:50%;
  background:conic-gradient(#ff6b8a,#ffa64d,#ffd84d,#5fd98a,#5fc6ff,#9a8cff,#df84ff,#ff6b8a);
  display:inline-grid;place-items:center;flex:none;
}
.logo-mark::after{content:"";width:60%;height:60%;border-radius:50%;background:#fff;}

/* ===== 固定トップバー ===== */
.topbar{position:fixed;top:0;left:0;width:100%;z-index:1000;}

/* キャンペーンバー */
.campaign-bar{
  background:var(--grad-bar);
  background-size:200% 100%;
  color:#fff;text-align:center;font-weight:800;
  padding:7px 12px;font-size:.84rem;letter-spacing:.02em;
  animation:bar-shine 7s linear infinite;
}
@keyframes bar-shine{0%{background-position:0 0;}100%{background-position:200% 0;}}
.campaign-bar b{font-weight:900;}

/* ナビ */
.nav{background:var(--grad-nav);box-shadow:0 4px 14px rgba(255,77,141,.22);}
.nav-inner{display:flex;align-items:center;gap:18px;height:60px;}
.nav-brand{display:flex;align-items:center;gap:9px;font-weight:900;font-size:1.1rem;letter-spacing:.02em;color:#fff;}
.nav-links{display:flex;gap:15px;margin-left:8px;}
.nav-links a{position:relative;display:flex;flex-direction:column;align-items:center;line-height:1.05;padding:3px 0;transition:opacity .2s;color:#fff;}
.nav-links a .jp{font-weight:900;font-size:.86rem;letter-spacing:.02em;white-space:nowrap;}
.nav-links a .en{font-weight:700;font-size:.55rem;opacity:.8;letter-spacing:.12em;margin-top:3px;}
.nav-links a:hover{opacity:.82;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:#fff;transition:width .25s;}
.nav-links a:hover::after{width:100%;}
.nav-contact{margin-left:auto;display:flex;align-items:center;gap:14px;}
.nav-hours{font-size:.76rem;color:rgba(255,255,255,.92);font-weight:700;line-height:1.3;text-align:right;}
.nav-hours b{color:#fff;font-weight:900;display:block;font-size:.82rem;}
.nav-tel{display:flex;align-items:center;gap:5px;font-weight:900;color:#fff;font-size:1.02rem;white-space:nowrap;}
.nav-line{background:#fff;color:#06c755;padding:8px 16px;border-radius:999px;font-weight:900;font-size:.82rem;white-space:nowrap;box-shadow:0 3px 10px rgba(0,0,0,.12);transition:transform .2s;}
.nav-line:hover{transform:translateY(-2px);}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;font-size:1.5rem;color:#fff;line-height:1;}

/* ===== ヒーロー スライドショー(ポップ/キャンディ) ===== */
.hero{position:relative;}
.hero-slider{position:relative;overflow:hidden;}
.hero-track{display:flex;transition:transform .6s ease;will-change:transform;}
.hero-slide{flex:0 0 100%;min-width:100%;position:relative;overflow:hidden;display:grid;place-items:center;padding:116px 20px 56px;text-align:center;}
.hero-slide.s1{
  background:var(--hero-overlay), var(--hero-img) center/cover no-repeat;
}
.hero-slide.s2{background:linear-gradient(135deg,var(--pink-pale),var(--pink-soft));}
.hero-slide.s3{background:linear-gradient(160deg,var(--pink-pale),var(--pink-soft));}
.hero-stripes{display:none;}
.hero-inner{position:relative;z-index:2;}
.hero-promo{max-width:780px;width:100%;border-radius:18px;box-shadow:var(--shadow);}
.slide-promo{position:relative;z-index:2;max-width:560px;width:100%;background:var(--card-bg);border:2px solid var(--pink-soft);border-radius:24px;padding:clamp(30px,5vw,42px) clamp(22px,5vw,34px);box-shadow:var(--shadow);}
.slide-badge{display:inline-block;background:var(--gold);color:#2e2620;font-weight:900;font-size:.88rem;padding:6px 20px;border-radius:999px;margin-bottom:16px;}
.slide-h{font-size:clamp(1.9rem,5.4vw,3rem);font-weight:900;line-height:1.4;}
.slide-h .accent{color:var(--pink-deep);}
.slide-p{font-weight:700;color:var(--text-soft);margin:14px 0 26px;font-size:clamp(.94rem,2.3vw,1.1rem);}
.slide-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
/* スライダー操作UI */
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;background:rgba(255,255,255,.85);color:var(--pink-deep);font-size:1.6rem;line-height:1;display:grid;place-items:center;box-shadow:0 3px 10px rgba(0,0,0,.15);transition:background .2s;}
.hero-arrow:hover{background:#fff;}
.hero-arrow.prev{left:12px;}
.hero-arrow.next{right:12px;}
.hero-dots{position:absolute;left:0;right:0;bottom:14px;z-index:6;display:flex;gap:8px;justify-content:center;}
.hero-dot{width:11px;height:11px;padding:0;border-radius:50%;border:2px solid #fff;background:rgba(255,255,255,.55);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:background .2s;}
.hero-dot.active{background:var(--pink-deep);}
.hero-badge{position:relative;width:300px;max-width:80vw;aspect-ratio:1;margin:0 auto 20px;background:#fff;border-radius:50%;display:grid;place-content:center;justify-items:center;gap:8px;box-shadow:0 12px 34px rgba(255,77,141,.22);outline:3px dotted var(--pink-soft);outline-offset:9px;}
.hero-badge .logo-mark{--s:86px;}
.hero-badge .bname{font-weight:900;font-size:1.5rem;letter-spacing:.05em;color:var(--text);}
.hero-ribbon{background:var(--pink-deep);color:#fff;font-family:"Pacifico",cursive;font-size:.9rem;padding:3px 24px;border-radius:6px;margin-top:2px;}
.hero-eyebrow{display:inline-block;font-weight:900;font-size:clamp(.78rem,2.7vw,.96rem);letter-spacing:.1em;color:var(--pink-deep);background:rgba(255,255,255,.82);padding:6px 18px;border-radius:999px;margin-bottom:16px;box-shadow:0 3px 12px rgba(255,77,141,.18);}
.hero-logo-img{display:block;width:clamp(290px,82vw,500px);height:auto;margin:0 auto 16px;border-radius:20px;box-shadow:0 12px 34px rgba(255,77,141,.28);}
.hero-logo-text{font-family:"Hachi Maru Pop","Zen Maru Gothic",cursive;font-weight:700;font-size:clamp(2rem,6.5vw,3rem);line-height:1.15;color:var(--pink-deep);text-shadow:0 2px 0 #fff,0 5px 14px rgba(255,77,141,.3);padding:0 6px;}
.footer-logo-text{display:block;font-family:"Hachi Maru Pop","Zen Maru Gothic",cursive;font-size:1.9rem;color:#fff;margin:0 auto 10px;}
.footer-logo-img{display:block;width:200px;max-width:60vw;height:auto;margin:0 auto 10px;border-radius:12px;}
.hero h1{font-size:clamp(2rem,6.6vw,3.5rem);font-weight:900;line-height:1.45;text-shadow:0 2px 0 #fff;}
.hero h1 .accent{color:var(--pink-deep);}
.hero .sub{font-size:clamp(.96rem,2.3vw,1.15rem);margin-top:12px;font-weight:700;color:var(--text-soft);}
.keywords{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px;}
.kw{display:inline-grid;place-items:center;width:96px;height:96px;border-radius:50%;color:#fff;font-weight:900;font-size:1.04rem;box-shadow:var(--shadow);}
.kw.k1{background:var(--kw1);}
.kw.k2{background:var(--kw2);}
.kw.k3{background:var(--kw3);}
.feature-icons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px;}
.feature-icons .fi{background:var(--card-bg);border:2px solid var(--pink-soft);border-radius:999px;padding:8px 18px;font-weight:800;font-size:.86rem;color:var(--pink-deep);display:flex;align-items:center;gap:7px;box-shadow:var(--shadow-sm);}
/* コミック吹き出しバッジ */
.pop-badge{position:absolute;z-index:3;background:#fff;border:3px solid var(--pink-deep);border-radius:18px;padding:12px 18px;font-weight:900;color:var(--pink-deep);font-size:.92rem;line-height:1.35;box-shadow:0 8px 18px rgba(0,0,0,.12);text-align:center;}
.pop-badge .big{display:block;font-size:1.4rem;color:var(--accent);}
.pop-badge::before{content:"";position:absolute;bottom:-19px;left:22px;border:9px solid transparent;border-top-color:var(--pink-deep);}
.pop-badge::after{content:"";position:absolute;bottom:-14px;left:25px;border:7px solid transparent;border-top-color:#fff;}
.pop-badge.left{top:120px;left:3%;transform:rotate(-6deg);}
.pop-badge.right{top:150px;right:3%;transform:rotate(6deg);}

/* ===== セクション共通 ===== */
.section{padding:64px 0;}
.section.alt{background:var(--pink-pale);position:relative;}
.section.alt::before{content:"";position:absolute;inset:0;background:url(images/candy-pattern.jpg) repeat;background-size:300px;opacity:var(--pattern-op);pointer-events:none;}
.section .container{position:relative;z-index:1;}
.section-head{text-align:center;margin-bottom:40px;}
.section-head .en{font-family:"Pacifico",cursive;font-size:2.1rem;color:var(--pink-deep);display:block;line-height:1;}
.section-head .ja{font-weight:700;color:var(--text-soft);font-size:.92rem;letter-spacing:.22em;margin-top:10px;display:block;}
.section-head .deco-line{width:50px;height:3px;border-radius:2px;background:var(--pink-soft);margin:14px auto 0;}

/* ===== セラピストカード(出勤/一覧 共通) ===== */
.thera-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.thera-note{text-align:center;color:var(--text-soft);font-weight:700;margin-bottom:26px;font-size:.9rem;}
.tcard{background:var(--card-bg);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .25s,box-shadow .25s;}
.tcard:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.tphoto{aspect-ratio:3/4;position:relative;display:grid;place-items:center;background-size:cover;background-position:center;}
.tphoto .ph-name{font-size:2rem;font-weight:900;color:#fff;text-shadow:0 2px 10px rgba(58,38,48,.28);}
.tphoto::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(58,38,48,.16));}
.tag{position:absolute;top:9px;left:9px;z-index:2;font-size:.68rem;font-weight:900;padding:3px 10px;border-radius:999px;}
.tag.new{background:var(--gold);color:#2e2620;}
.tag.pickup{background:var(--pink-deep);color:#fff;left:auto;right:9px;}
.shop-badge{position:absolute;bottom:9px;right:9px;z-index:2;background:rgba(255,255,255,.94);color:var(--pink-deep);font-size:.7rem;font-weight:900;padding:3px 10px;border-radius:999px;}
.tbody{padding:13px 14px;text-align:center;}
.tbody .tname{font-weight:900;font-size:1.08rem;}
.tbody .tname small{font-weight:700;color:var(--text-soft);font-size:.74rem;margin-left:4px;}
.tbody .ttime{margin-top:5px;font-size:.88rem;font-weight:800;color:var(--pink-deep);}
.tbody .tshop{margin-top:5px;font-size:.84rem;font-weight:700;color:var(--text-soft);}
.tname-row{display:flex;align-items:center;justify-content:center;gap:6px;}
.tname-row .tname{font-weight:900;font-size:1.05rem;}
.tspecs{margin-top:3px;font-weight:800;font-size:.84rem;color:var(--text);letter-spacing:.02em;}
.sns{width:21px;height:21px;border-radius:50%;display:inline-grid;place-items:center;color:#fff;font-size:.62rem;font-weight:900;text-decoration:none;flex:none;}
.sns.x{background:#000;}
.sns.ig{background:linear-gradient(45deg,#f09433,#dc2743,#bc1888);}
.sns.tt{background:#111;}
.sns.ln{background:#06c755;}
/* パステル(上品)アバター */
.av1{background:linear-gradient(135deg,#ffd9e8,#ff9ec3);}
.av2{background:linear-gradient(135deg,#ffe3d0,#ffbb9c);}
.av3{background:linear-gradient(135deg,#dcedff,#a9caff);}
.av4{background:linear-gradient(135deg,#e9ddff,#c3acff);}
.av5{background:linear-gradient(135deg,#d6f5e6,#9fe0c6);}
.av6{background:linear-gradient(135deg,#fff0cc,#ffd98f);}
.av7{background:linear-gradient(135deg,#ffd9e2,#ffaabf);}

/* ===== Special Campaign ===== */
.promo-banner{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:28px;display:block;}
.campaign-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.campaign-card{background:var(--card-bg);border-radius:var(--radius);padding:26px 20px;text-align:center;box-shadow:var(--shadow-sm);border:1.5px solid var(--pink-soft);}
.campaign-card .label{font-weight:700;color:var(--text-soft);font-size:.88rem;}
.campaign-card .big{font-size:1.55rem;font-weight:900;color:var(--pink-deep);margin:6px 0;}

/* ===== News ===== */
.news-list{max-width:760px;margin:0 auto;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line);}
.news-item{display:flex;gap:16px;padding:17px 24px;border-bottom:1px solid var(--line);align-items:baseline;flex-wrap:wrap;}
.news-item:last-child{border-bottom:none;}
.news-item .date{color:var(--pink-deep);font-weight:900;font-size:.86rem;flex:none;width:92px;}
.news-item .cat{background:var(--pink-soft);color:var(--pink-deep);font-size:.7rem;font-weight:900;padding:2px 10px;border-radius:999px;flex:none;}
.news-item .txt{font-weight:700;flex:1;min-width:180px;}

/* ===== System ===== */
.system-table{max-width:760px;margin:0 auto;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line);}
.system-row{display:flex;justify-content:space-between;align-items:center;padding:19px 28px;border-bottom:1px solid var(--line);gap:12px;}
.system-row:last-child{border-bottom:none;}
.system-row .item{font-weight:700;}
.system-row .price{font-weight:900;font-size:1.2rem;color:var(--pink-deep);white-space:nowrap;}
.system-row.free .price{color:#27ae60;}
.system-row.highlight{background:linear-gradient(135deg,var(--pink-pale),var(--pink-soft));}
.system-cat{padding:11px 28px;background:var(--pink-pale);font-weight:900;font-size:.82rem;color:var(--text-soft);letter-spacing:.08em;border-bottom:1px solid var(--line);}
.system-note{text-align:center;color:var(--text-soft);font-size:.84rem;margin-top:16px;font-weight:700;line-height:1.8;}

/* ===== Recruit ===== */
.recruit{
  background:linear-gradient(135deg,var(--pink-pale),var(--pink-soft));text-align:center;border-radius:var(--radius);
  max-width:var(--maxw);margin:60px auto;padding:50px 24px;box-shadow:var(--shadow-sm);border:1px solid var(--pink-soft);
}
.recruit h2{font-family:"Pacifico",cursive;font-size:2.3rem;color:var(--pink-deep);}
.recruit p{font-weight:700;margin:12px 0 24px;font-size:1.05rem;color:var(--text);}

/* ===== SNS ===== */
.sns-section{padding:46px 0;}
.sns-banner{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);max-width:var(--maxw);margin:0 auto;}

/* ===== Access ===== */
.access-contact{text-align:center;margin-bottom:32px;}
.access-contact .tel{font-size:1.35rem;font-weight:900;}
.access-contact .tel a{color:var(--pink-deep);}
.access-contact .hours{color:var(--text-soft);font-weight:700;margin-top:4px;}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.access-card{background:var(--card-bg);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);}
.access-card .head{background:var(--pink-deep);color:#fff;padding:14px 22px;font-weight:900;font-size:1.08rem;}
.access-card .head small{display:block;font-size:.76rem;font-weight:700;opacity:.9;}
.access-card iframe{display:block;width:100%;height:240px;border:0;}
.access-card .body{padding:18px 22px;}
.access-card .body p{margin:4px 0;font-weight:700;}
.access-card .body .zip{color:var(--text-soft);font-size:.86rem;}
.access-card .route{display:inline-block;margin-top:12px;background:var(--pink-deep);color:#fff;padding:9px 24px;border-radius:999px;font-weight:900;font-size:.88rem;transition:transform .2s;}
.access-card .route:hover{transform:translateY(-2px);}

/* ===== 外部リンクバナー枠(下部): 掲載ポータル/求人 公式バナー ===== */
.ext-banners{background:var(--pink-pale);padding:40px 16px;}
.ext-head{text-align:center;font-weight:900;color:var(--text-soft);font-size:.82rem;letter-spacing:.2em;margin-bottom:20px;}
.ext-inner{max-width:640px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.ext-banner{display:flex;flex-direction:column;align-items:center;gap:11px;background:var(--card-bg);border:1.5px solid var(--pink-soft);border-radius:14px;padding:18px 16px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;}
.ext-banner:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.ext-banner .ext-cap{font-weight:900;font-size:.82rem;color:var(--pink-deep);text-align:center;}
.ext-banner img{width:200px;max-width:100%;height:auto;border-radius:4px;border:1px solid var(--line);}

/* ===== CTA ===== */
.cta{text-align:center;padding:74px 20px;background:var(--grad-cta);color:#fff;}
.cta h2{font-size:clamp(1.7rem,4.6vw,2.5rem);font-weight:900;text-shadow:0 3px 10px rgba(0,0,0,.12);}
.cta p{font-weight:700;margin:12px 0 28px;font-size:1.05rem;}
.cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 38px;border-radius:999px;font-weight:900;font-size:1.05rem;box-shadow:0 8px 22px rgba(0,0,0,.18);transition:transform .2s,box-shadow .2s;}
.btn:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.26);}
.btn-tel{background:#fff;color:var(--pink-deep);}
.btn-line{background:#06c755;color:#fff;}

/* ===== Footer ===== */
.footer{background:var(--footer-bg);color:#fff;text-align:center;padding:44px 20px 88px;}
.footer .logo-mark{--s:48px;margin:0 auto 12px;}
.footer-logo{display:block;width:190px;max-width:62%;height:auto;margin:0 auto 12px;}
.footer .fbrand{font-weight:900;font-size:1.25rem;letter-spacing:.03em;}
.footer .fnav{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:16px 0;font-size:.88rem;font-weight:700;}
.footer .fnav a{opacity:.85;transition:opacity .2s;}
.footer .fnav a:hover{opacity:1;}
.footer .copy{opacity:.6;font-size:.78rem;margin-top:14px;}
.footer .disclaimer{opacity:.5;font-size:.72rem;margin-top:10px;line-height:1.6;}

/* ===== 浮遊予約ボタン(スマホ) ===== */
.float-cta{position:fixed;bottom:0;left:0;width:100%;z-index:900;display:none;grid-template-columns:1fr 1fr;box-shadow:0 -4px 16px rgba(0,0,0,.15);}
.float-cta a{padding:14px;text-align:center;font-weight:900;font-size:1rem;color:#fff;}
.float-cta .f-tel{background:var(--pink-deep);}
.float-cta .f-line{background:#06c755;}

/* ===== フェードイン ===== */
.fade{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s;}
.fade.in{opacity:1;transform:none;}

/* ===== 配色プレビュー切替UI（確認用・本番では削除） ===== */
.theme-switch{position:fixed;z-index:1200;left:50%;transform:translateX(-50%);bottom:14px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center;background:rgba(33,24,30,.9);backdrop-filter:blur(6px);padding:8px 12px;border-radius:999px;box-shadow:0 6px 20px rgba(0,0,0,.28);max-width:94vw;}
.theme-switch .ts-label{color:#fff;font-weight:800;font-size:.78rem;margin-right:2px;white-space:nowrap;}
.theme-switch button{border:none;cursor:pointer;font-weight:800;font-size:.8rem;padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.18);color:#fff;transition:background .2s,transform .2s;}
.theme-switch button:hover{transform:translateY(-1px);background:rgba(255,255,255,.32);}
.theme-switch button.active{background:#fff;color:#21181e;}
@media(max-width:600px){
  .theme-switch{bottom:58px;padding:6px 8px;gap:4px;}
  .theme-switch .ts-label{display:none;}
  .theme-switch button{font-size:.74rem;padding:5px 9px;}
}

/* ===== レスポンシブ ===== */
@media(max-width:1024px){
  .nav-links{display:none;}
  .nav-hours{display:none;}
  .nav-toggle{display:block;}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;width:100%;background:#ff6aa5;padding:16px 24px;gap:14px;box-shadow:0 8px 18px rgba(0,0,0,.12);}
  .nav-inner{gap:10px;}
}
@media(max-width:900px){
  .pop-badge{display:none;}
  .thera-grid{grid-template-columns:repeat(2,1fr);}
  .campaign-grid{grid-template-columns:1fr;}
  .access-grid{grid-template-columns:1fr;}
  .ext-inner{grid-template-columns:1fr;max-width:320px;}
}
@media(max-width:600px){
  .float-cta{display:grid;}
  .nav-brand{font-size:1rem;}
  .nav-tel span{display:none;}
  .access-card iframe{height:210px;}
  .hero-slide{padding:136px 18px 46px;}
  .hero-arrow{display:none;}
}

/* ===== Recruit page (求人募集) ===== */
.rhero{position:relative;padding:128px 20px 70px;text-align:center;overflow:hidden;background:var(--hero-overlay),var(--hero-img) center/cover no-repeat;}
.rhero .en{font-family:"Pacifico",cursive;font-size:clamp(2.4rem,7vw,3.6rem);color:var(--pink-deep);line-height:1;text-shadow:0 2px 0 #fff;}
.rhero .ja{display:block;font-weight:900;font-size:clamp(1.2rem,3.4vw,1.7rem);margin-top:10px;}
.rhero .lead{margin-top:16px;font-weight:700;color:var(--text);max-width:640px;margin-left:auto;margin-right:auto;}
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.reason{background:var(--card-bg);border:1.5px solid var(--pink-soft);border-radius:var(--radius);padding:26px 20px;text-align:center;box-shadow:var(--shadow-sm);}
.reason .ico{font-size:2.2rem;line-height:1;}
.reason h3{font-weight:900;font-size:1.12rem;color:var(--pink-deep);margin:10px 0 6px;}
.reason p{font-weight:700;color:var(--text-soft);font-size:.9rem;}
.req-table{max-width:820px;margin:0 auto;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line);}
.req-row{display:flex;border-bottom:1px solid var(--line);}
.req-row:last-child{border-bottom:none;}
.req-row .th{flex:0 0 168px;background:var(--pink-pale);color:var(--pink-deep);font-weight:900;padding:16px 18px;font-size:.92rem;}
.req-row .td{flex:1;padding:16px 18px;font-weight:700;}
.req-row .td .note{display:block;color:var(--text-soft);font-size:.82rem;font-weight:700;margin-top:4px;}
.perks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:7px 18px;margin:0;padding:0;}
.perks li{position:relative;padding-left:20px;font-weight:700;font-size:.9rem;line-height:1.5;}
.perks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--pink-deep);font-weight:900;}
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.flow .step{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line);padding:22px 16px;text-align:center;position:relative;}
.flow .num{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--pink-deep);color:#fff;font-weight:900;margin-bottom:10px;}
.flow .step h4{font-weight:900;font-size:1rem;margin-bottom:4px;}
.flow .step p{font-weight:700;color:var(--text-soft);font-size:.84rem;}
.qa{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.qa .item{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line);padding:18px 22px;}
.qa .q{font-weight:900;color:var(--pink-deep);}
.qa .a{font-weight:700;margin-top:6px;}
.tencho-msg{max-width:720px;margin:0 auto;background:var(--card-bg);border:1.5px solid var(--pink-soft);border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow-sm);}
.tencho-msg .greet{font-weight:900;color:var(--pink-deep);font-size:1.06rem;margin-bottom:14px;}
.tencho-msg p{font-weight:700;line-height:2;margin:0 0 14px;}
.tencho-msg p:last-of-type{margin-bottom:0;}
.tencho-sign{text-align:right;margin-top:20px;font-weight:900;color:var(--pink-deep);}
.rcta{text-align:center;padding:72px 20px;background:var(--grad-cta);color:#fff;}
.rcta h2{font-size:clamp(1.6rem,4.6vw,2.4rem);font-weight:900;text-shadow:0 3px 10px rgba(0,0,0,.12);}
.rcta p{font-weight:700;margin:12px 0 28px;font-size:1.05rem;}
@media(max-width:900px){
  .reasons{grid-template-columns:repeat(2,1fr);}
  .flow{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .rhero{padding:136px 18px 52px;}
  .reasons{grid-template-columns:1fr;}
  .req-row{flex-direction:column;}
  .req-row .th{flex-basis:auto;}
  .perks{grid-template-columns:1fr;gap:8px;}
}

/* ===== セラピスト詳細ページ ===== */
.staff-back{max-width:var(--maxw);margin:0 auto;padding:132px 20px 0;}
@media(min-width:601px){.staff-back{padding-top:104px;}}
.staff-back a{color:var(--pink-deep);font-weight:800;font-size:.9rem;}
.profile{display:grid;grid-template-columns:380px 1fr;gap:34px;max-width:var(--maxw);margin:18px auto 0;padding:0 20px;}
.p-gallery{display:flex;flex-direction:column;gap:10px;}
.p-main{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/4;display:grid;place-items:center;background:linear-gradient(135deg,#ffd9e8,#ff9ec3);}
.p-main img{width:100%;height:100%;object-fit:cover;}
.p-main .ph{color:#fff;font-size:2.6rem;font-weight:900;text-shadow:0 2px 10px rgba(58,38,48,.28);}
.p-main .tag{position:absolute;top:12px;left:12px;background:var(--gold);color:#2e2620;font-size:.74rem;font-weight:900;padding:3px 12px;border-radius:999px;z-index:2;}
.p-thumbs{display:flex;gap:8px;flex-wrap:wrap;}
.p-thumb{width:60px;height:76px;border-radius:10px;border:2px solid transparent;cursor:pointer;padding:0;overflow:hidden;background:none;}
.p-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.p-thumb.active{border-color:var(--pink-deep);}
/* プロフィール動画 */
.p-main .p-video{width:100%;height:100%;}
.p-main .p-video-el{width:100%;height:100%;object-fit:cover;background:#000;display:block;}
.p-main .p-video-embed{position:absolute;inset:0;}
.p-main .p-video-embed iframe{width:100%;height:100%;border:0;display:block;}
.p-thumb-video{background:#15121b;display:grid;place-items:center;}
.p-thumb-video .vplay{color:#d4af37;font-size:1.15rem;}
.p-name{font-size:2rem;font-weight:900;}
.p-name small{font-size:.9rem;color:var(--text-soft);font-weight:700;margin-left:8px;}
.p-shop{display:inline-block;margin-top:6px;background:var(--pink-soft);color:var(--pink-deep);font-weight:900;font-size:.8rem;padding:3px 12px;border-radius:999px;}
.p-specs{margin:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;display:grid;grid-template-columns:repeat(2,1fr);gap:8px 18px;}
.p-specs div{font-weight:700;}
.p-specs span{color:var(--text-soft);font-weight:800;margin-right:8px;display:inline-block;min-width:72px;}
.p-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.p-tags .t{background:var(--card-bg);border:1.5px solid var(--pink-soft);color:var(--pink-deep);font-weight:800;font-size:.82rem;padding:6px 14px;border-radius:999px;}
.p-sns{display:flex;gap:10px;align-items:center;margin-bottom:8px;}
.p-sns .lbl{font-weight:800;color:var(--text-soft);font-size:.84rem;}
.p-sns a{width:34px;height:34px;border-radius:50%;display:inline-grid;place-items:center;color:#fff;font-weight:900;font-size:.78rem;}
.p-sns a.x{background:#000;}
.p-sns a.ig{background:linear-gradient(45deg,#f09433,#dc2743,#bc1888);}
.p-sns a.tt{background:#111;}
.p-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px;}
.detail-sec{max-width:var(--maxw);margin:34px auto 0;padding:0 20px;}
.detail-sec h2{font-weight:900;font-size:1.4rem;border-left:6px solid var(--pink-deep);padding-left:12px;margin-bottom:16px;}
.detail-sec p{margin-bottom:14px;font-weight:700;}
.hitokoto-box{background:var(--pink-pale);border:2px solid var(--pink-soft);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow-sm);}
.blog-list{display:flex;flex-direction:column;gap:14px;}
.blog-card{display:flex;gap:14px;background:var(--card-bg);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.blog-thumb{flex:0 0 96px;width:96px;align-self:stretch;min-height:96px;object-fit:cover;background:linear-gradient(135deg,#ffe3ef,#ffc4dd);}
.blog-body{padding:12px 14px;}
.blog-date{color:var(--pink-deep);font-weight:900;font-size:.8rem;}
.blog-title{font-weight:900;font-size:1.02rem;margin:3px 0 5px;}
.blog-ex{font-weight:700;color:var(--text-soft);font-size:.9rem;}
.blog-more{display:inline-block;margin-top:14px;background:var(--pink-deep);color:#fff;font-weight:900;padding:9px 22px;border-radius:999px;font-size:.9rem;}
.sched-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;background:var(--pink-pale);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:12px;}
.sday{text-align:center;}
.sdate{font-weight:900;font-size:.86rem;}
.sdate small{display:block;font-weight:700;font-size:.72rem;color:var(--text-soft);}
.sdate.sun{color:#e0314b;}
.sdate.sat{color:#2f7fd6;}
.stime{margin-top:10px;font-weight:800;font-size:.78rem;color:var(--pink-deep);border-top:1px solid var(--line);padding-top:10px;min-height:30px;}
.stime.off{color:var(--text-soft);}
.sched-cta{display:flex;gap:12px;justify-content:center;margin-top:8px;flex-wrap:wrap;}
@media(max-width:760px){.profile{grid-template-columns:1fr;gap:20px;}.p-gallery{max-width:340px;margin:0 auto;width:100%;}}
@media(max-width:600px){.sched-grid{gap:3px;padding:8px;}.sdate{font-size:.66rem;}.sdate small{font-size:.6rem;}.stime{font-size:.6rem;padding-top:6px;margin-top:6px;}.blog-thumb{flex-basis:80px;width:80px;}}

/* ===== コンセプトページ ===== */
.c-hero{padding:128px 20px 60px;text-align:center;background:linear-gradient(180deg,var(--pink-pale),#ffe6f1);}
.c-hero .en{font-family:"Pacifico",cursive;font-size:clamp(2.4rem,7vw,3.4rem);color:var(--pink-deep);line-height:1;}
.c-hero .ja{display:block;font-weight:900;font-size:1.1rem;letter-spacing:.2em;margin-top:10px;color:var(--text-soft);}
.c-lead{max-width:760px;margin:50px auto;padding:0 20px;text-align:center;}
.c-lead h2{font-size:clamp(1.4rem,4vw,2rem);font-weight:900;line-height:1.7;}
.c-lead h2 .accent{color:var(--pink-deep);}
.c-lead p{margin-top:18px;font-weight:700;}
.room-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.room{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);}
.room .ph{aspect-ratio:4/3;overflow:hidden;background-color:#ffd6e6;background-size:cover;background-position:center;background-repeat:no-repeat;}
.room.r1 .ph{background-image:var(--room1);}
.room.r2 .ph{background-image:var(--room2);}
.room.r3 .ph{background-image:var(--room3);}
.room .cap{padding:12px 14px;font-weight:700;text-align:center;}
.kodawari{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:680px;margin:0 auto;}
.kodawari .k{background:var(--card-bg);border:1.5px solid var(--pink-soft);border-radius:var(--radius);padding:20px 10px;text-align:center;box-shadow:var(--shadow-sm);}
.kodawari .k .ico{font-size:1.9rem;}
.kodawari .k .t{font-weight:900;font-size:.9rem;margin-top:8px;color:var(--pink-deep);}
@media(max-width:760px){.room-grid{grid-template-columns:1fr;}.kodawari{grid-template-columns:repeat(2,1fr);}}
/* ===== HP予約フォーム（お客様向け・テーマ変数で配色追従） ===== */
.tug-resform{background:var(--card-bg);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);}
.tug-resform .rf-row{margin-bottom:14px;}
.tug-resform label{display:block;font-weight:800;margin-bottom:5px;font-size:.92rem;}
.tug-resform .req{color:var(--accent);font-size:.74rem;margin-left:6px;}
.tug-resform input,.tug-resform select,.tug-resform textarea{width:100%;font-size:16px;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:var(--page-bg);color:var(--text);font-family:inherit;}
.tug-resform .rf-note{color:var(--text-soft);font-size:.82rem;margin:6px 0 14px;}
.tug-resform .rf-submit{width:100%;border:0;border-radius:999px;padding:15px;font-weight:900;font-size:1.05rem;background:var(--grad-cta);color:#fff;box-shadow:var(--shadow);cursor:pointer;}
.tug-resform-done{background:var(--card-bg);border:1px solid var(--line);border-radius:var(--radius);padding:32px 22px;text-align:center;box-shadow:var(--shadow-sm);}
.tug-resform-done h3{color:var(--accent);margin-bottom:10px;font-size:1.2rem;}
.tug-resform-done p{font-weight:700;color:var(--text-soft);}
