/*
Theme Name: Rosewood Aroma
Theme URI: https://rosewood-aroma.com
Author: Rosewood Aroma
Description: オリジナルテーマ for Rosewood Aroma サロン
Version: 1.0
License: Private
Text Domain: rosewood-aroma
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Noto+Serif+JP:wght@200;300;400&family=Zen+Kaku+Gothic+New:wght@300;400&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --rosewood:#7d4e3e;--rosewood-light:#c4907e;--rosewood-pale:#fdf5f2;
  --sage:#6b7c5e;--sage-light:#b8c9a8;--sage-pale:#f3f6f0;
  --cream:#faf7f2;--cream2:#f2ede4;
  --ink:#1e1c18;--ink2:#4a4740;--ink3:#8a8780;
  --gold:#b8975a;--gold-light:#e8d8b0;
  --border:#e4ddd4;
  --ff-serif:'Cormorant Garamond',serif;
  --ff-jp:'Noto Serif JP',serif;
  --ff-body:'Zen Kaku Gothic New',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--ff-body);background:var(--cream);color:var(--ink);overflow-x:hidden}

/* ANNOUNCE BAR */
.announce-bar{
  background:var(--rosewood);color:white;
  padding:10px 2.5rem;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;letter-spacing:0.05em;line-height:1.7;
  text-align:center;position:relative;gap:8px;
}
.announce-bar a{
  color:white;font-weight:500;
  text-decoration:underline;white-space:nowrap;
  margin-left:8px;
}
.announce-bar a:hover{opacity:0.8;}
.announce-close{
  position:absolute;right:1rem;top:50%;transform:translateY(-50%);
  background:none;border:none;color:rgba(255,255,255,0.6);
  font-size:14px;cursor:pointer;padding:4px 8px;
  transition:color 0.2s;
}
.announce-close:hover{color:white;}
@media(max-width:768px){
  .announce-bar{padding:10px 2.5rem 10px 1rem;font-size:11px;}
}

/* LANG TOGGLE */
.lang-bar{background:var(--ink);padding:8px 2rem;display:flex;justify-content:flex-end;align-items:center;gap:16px}
.lang-btn{background:none;border:none;color:rgba(255,255,255,0.45);font-size:11px;letter-spacing:0.15em;cursor:pointer;padding:4px 8px;font-family:var(--ff-body);transition:color 0.2s}
.lang-btn.active{color:white;border-bottom:1px solid var(--gold)}
.lang-divider{color:rgba(255,255,255,0.2);font-size:10px}

/* NAV */
nav.ra-nav{background:rgba(250,247,242,0.97);border-bottom:1px solid var(--border);padding:0 2.5rem;display:flex;align-items:center;justify-content:space-between;height:68px;position:sticky;top:0;z-index:100}
.logo-wrap{display:flex;flex-direction:column;gap:2px}
.logo-en{font-family:var(--ff-serif);font-size:20px;font-weight:300;letter-spacing:0.18em;color:var(--ink);font-style:italic}
.logo-sub{font-size:9px;letter-spacing:0.3em;color:var(--sage);text-transform:uppercase}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-size:12px;letter-spacing:0.1em;color:var(--ink2);text-decoration:none;transition:color 0.2s;font-family:var(--ff-body)}
.nav-links a:hover{color:var(--rosewood)}
.nav-reserve{background:var(--rosewood);color:white;border:none;padding:10px 24px;font-size:11px;letter-spacing:0.15em;cursor:pointer;font-family:var(--ff-body);transition:background 0.2s;border-radius:1px}
.nav-reserve:hover{background:#6a3d2f}

/* HERO */
.hero{min-height:90vh;display:grid;grid-template-columns:1fr 1fr;position:relative}
.hero-left{background:var(--cream2);display:flex;flex-direction:column;justify-content:center;padding:6rem 4rem 6rem 5rem;position:relative;overflow:hidden}
.hero-left::before{content:'';position:absolute;top:-60px;left:-60px;width:300px;height:300px;border:1px solid var(--border);border-radius:50%;opacity:0.4}
.hero-left::after{content:'';position:absolute;bottom:-40px;right:40px;width:180px;height:180px;border:1px solid var(--gold-light);border-radius:50%;opacity:0.5}
.hero-tag{font-size:10px;letter-spacing:0.3em;color:var(--gold);text-transform:uppercase;margin-bottom:2rem;display:flex;align-items:center;gap:12px}
.hero-tag::before{content:'';width:28px;height:1px;background:var(--gold)}
.hero-h1{font-family:var(--ff-jp);font-size:44px;font-weight:200;line-height:1.6;letter-spacing:0.04em;color:var(--ink);margin-bottom:1.75rem}
.hero-h1-en{font-family:var(--ff-serif);font-size:40px;font-weight:300;line-height:1.4;letter-spacing:0.06em;color:var(--ink);margin-bottom:1.75rem;font-style:italic}
.hero-desc{font-size:13px;line-height:2;color:var(--ink2);max-width:360px;margin-bottom:3rem;font-weight:300}
.hero-actions{display:flex;align-items:center;gap:2rem}
.btn-primary{background:var(--rosewood);color:white;border:none;padding:15px 36px;font-size:12px;letter-spacing:0.15em;cursor:pointer;font-family:var(--ff-body);border-radius:1px;transition:background 0.2s}
.btn-primary:hover{background:#6a3d2f}
.btn-text{font-size:11px;letter-spacing:0.12em;color:var(--ink3);cursor:pointer;border-bottom:1px solid var(--border);padding-bottom:2px;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--ff-body);transition:color 0.2s}
.btn-text:hover{color:var(--rosewood);border-bottom-color:var(--rosewood)}
.hero-right{background:var(--sage-pale);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.hero-art{position:relative;width:340px;height:460px}
.oval-outer{position:absolute;inset:0;border:1px solid var(--sage-light);border-radius:170px}
.oval-inner{position:absolute;inset:28px;border:1px solid rgba(107,124,94,0.3);border-radius:142px}
.oval-center{position:absolute;inset:64px;background:white;border-radius:110px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px}
.oval-glyph{font-family:var(--ff-serif);font-size:52px;color:var(--sage);opacity:0.5;font-style:italic;line-height:1}
.oval-label{font-size:9px;letter-spacing:0.25em;color:var(--sage);text-transform:uppercase}
.float-badge{position:absolute;background:white;border:1px solid var(--border);padding:12px 16px;border-radius:2px;min-width:140px}
.float-badge.b1{top:48px;right:-20px}
.float-badge.b2{bottom:68px;left:-20px}
.badge-label{font-size:9px;letter-spacing:0.18em;color:var(--ink3);text-transform:uppercase;margin-bottom:4px}
.badge-val{font-size:13px;color:var(--ink);font-family:var(--ff-serif);font-style:italic}

/* CONCEPT */
.concept{padding:7rem 5rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.concept-text .eyebrow{font-size:10px;letter-spacing:0.3em;color:var(--gold);text-transform:uppercase;margin-bottom:1.5rem}
.concept-text h2{font-family:var(--ff-jp);font-size:30px;font-weight:300;letter-spacing:0.06em;line-height:1.7;margin-bottom:2rem;color:var(--ink)}
.concept-text h2.en{font-family:var(--ff-serif);font-size:32px;font-weight:300;font-style:italic;letter-spacing:0.04em;line-height:1.5}
.concept-text p{font-size:13px;line-height:2.2;color:var(--ink2);font-weight:300}
.concept-nums{display:flex;flex-direction:column;gap:2rem}
.concept-num{display:flex;align-items:baseline;gap:1rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.concept-num:last-child{border-bottom:none;padding-bottom:0}
.cn-number{font-family:var(--ff-serif);font-size:44px;font-weight:300;color:var(--rosewood-light);line-height:1;font-style:italic}
.cn-label{font-size:12px;color:var(--ink2);letter-spacing:0.06em}
.cn-sub{font-size:10px;color:var(--ink3);margin-top:2px;letter-spacing:0.08em}

/* MENU */
.menu-section{padding:6rem 3rem;background:var(--cream2)}
.sec-header{text-align:center;margin-bottom:4rem}
.sec-eyebrow{font-size:10px;letter-spacing:0.3em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem}
.sec-title{font-family:var(--ff-jp);font-size:28px;font-weight:300;letter-spacing:0.08em;color:var(--ink)}
.sec-title.en{font-family:var(--ff-serif);font-size:30px;font-weight:300;font-style:italic}
.sec-line{width:36px;height:1px;background:var(--gold-light);margin:1.25rem auto 0}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;max-width:900px;margin:0 auto;background:var(--border)}
.menu-item{background:var(--cream);padding:2.5rem;transition:background 0.3s;cursor:pointer;position:relative;overflow:hidden}
.menu-item::before{content:'';position:absolute;left:0;top:0;width:2px;height:0;background:var(--rosewood);transition:height 0.3s}
.menu-item:hover{background:var(--rosewood-pale)}
.menu-item:hover::before,.menu-item.selected::before{height:100%}
.menu-item.selected{background:var(--rosewood-pale)}
.mi-num{font-family:var(--ff-serif);font-size:12px;color:var(--rosewood-light);letter-spacing:0.15em;margin-bottom:1rem;font-style:italic}
.mi-name{font-family:var(--ff-jp);font-size:17px;font-weight:300;letter-spacing:0.06em;color:var(--ink);margin-bottom:0.5rem}
.mi-name-en{font-family:var(--ff-serif);font-size:15px;font-weight:300;font-style:italic;color:var(--ink2);margin-bottom:1rem}
.mi-desc{font-size:12px;line-height:1.9;color:var(--ink2);margin-bottom:1.25rem;font-weight:300}
.mi-meta{display:flex;align-items:baseline;justify-content:space-between}
.mi-time{font-size:10px;letter-spacing:0.12em;color:var(--sage);text-transform:uppercase}
.mi-price{font-family:var(--ff-serif);font-size:20px;color:var(--rosewood);font-style:italic}
.mi-price-sub{font-size:10px;color:var(--ink3);font-family:var(--ff-body);font-style:normal}
.menu-selected-indicator{background:var(--rosewood-pale);border:1px solid var(--rosewood-light);padding:12px 20px;max-width:900px;margin:16px auto 0;font-size:12px;color:var(--rosewood);letter-spacing:0.08em;display:none}
.menu-selected-indicator.show{display:block}

/* BOOKING */
.booking{padding:6rem 4rem;background:var(--cream)}
.booking-inner{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:4rem}
.cal-wrap{border:1px solid var(--border);background:white}
.cal-head{background:var(--cream2);padding:14px 1.25rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.cal-month-label{font-family:var(--ff-serif);font-size:16px;font-style:italic;color:var(--ink);letter-spacing:0.06em}
.cal-nav-btn{background:none;border:none;cursor:pointer;color:var(--sage);font-size:18px;padding:2px 8px;transition:color 0.2s}
.cal-nav-btn:hover{color:var(--rosewood)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);padding:8px}
.cal-dn{text-align:center;font-size:9px;letter-spacing:0.12em;color:var(--ink3);padding:6px 0;text-transform:uppercase}
.cal-d{text-align:center;padding:9px 2px;font-size:12px;cursor:pointer;color:var(--ink2);transition:all 0.15s;border-radius:1px;margin:1px}
.cal-d:hover:not(.dp):not(.dc){background:var(--rosewood-pale);color:var(--rosewood)}
.cal-d.sel{background:var(--rosewood);color:white}
.cal-d.tod{color:var(--rosewood);font-weight:500}
.cal-d.dp,.cal-d.dc{color:var(--border);cursor:default}
.cal-d.avail::after{content:'';display:block;width:3px;height:3px;background:var(--sage-light);border-radius:50%;margin:1px auto 0}
.cal-d.sel::after{background:rgba(255,255,255,0.4)}
.time-label{font-size:10px;letter-spacing:0.18em;color:var(--ink3);text-transform:uppercase;margin:1.5rem 0 0.75rem}
.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.t-slot{border:1px solid var(--border);padding:9px 4px;text-align:center;font-size:12px;cursor:pointer;color:var(--ink2);letter-spacing:0.06em;transition:all 0.15s;background:white}
.t-slot:hover:not(.tna){border-color:var(--rosewood);color:var(--rosewood)}
.t-slot.tsel{background:var(--rosewood);color:white;border-color:var(--rosewood)}
.t-slot.tna{color:var(--border);cursor:default;background:#faf9f8}
.summary-box{border:1px solid var(--border);margin-bottom:1.5rem;background:white}
.sb-head{background:var(--cream2);padding:12px 1.25rem;font-family:var(--ff-serif);font-size:14px;font-style:italic;color:var(--ink);border-bottom:1px solid var(--border);letter-spacing:0.06em}
.sb-body{padding:1.25rem}
.sb-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:12px}
.sb-row:last-child{border-bottom:none;padding-top:10px}
.sb-k{color:var(--ink3);letter-spacing:0.06em}
.sb-v{color:var(--ink);font-weight:400;text-align:right}
.sb-price{color:var(--rosewood);font-family:var(--ff-serif);font-size:17px;font-style:italic}
.fl{margin-bottom:1.1rem}
.fl-label{font-size:10px;letter-spacing:0.18em;color:var(--ink3);text-transform:uppercase;display:block;margin-bottom:6px}
.fl-input{width:100%;padding:11px 14px;border:1px solid var(--border);font-size:13px;color:var(--ink);background:white;outline:none;transition:border-color 0.2s;font-family:var(--ff-body);resize:none}
.fl-input:focus{border-color:var(--rosewood)}
.submit-btn{width:100%;background:var(--rosewood);color:white;border:none;padding:15px;font-size:12px;letter-spacing:0.18em;cursor:pointer;font-family:var(--ff-body);transition:background 0.2s;margin-top:0.25rem}
.submit-btn:hover{background:#6a3d2f}
.success-box{display:none;border:1px solid var(--sage-light);background:var(--sage-pale);padding:2rem;text-align:center;margin-top:1rem}
.success-box.show{display:block}
.suc-icon{width:36px;height:36px;border:1px solid var(--sage);border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center}
.suc-title{font-family:var(--ff-serif);font-size:18px;font-style:italic;color:var(--sage);margin-bottom:0.5rem}
.suc-desc{font-size:12px;color:var(--ink2);line-height:1.9}

/* CONTACT */
.contact-section{padding:6rem 4rem;background:var(--sage-pale)}
.contact-inner{max-width:560px;margin:0 auto}

/* FOOTER */
.ra-footer{background:var(--ink);padding:3.5rem 4rem;display:flex;justify-content:space-between;align-items:flex-start}
.foot-logo{font-family:var(--ff-serif);font-size:20px;color:white;font-style:italic;letter-spacing:0.12em;margin-bottom:8px}
.foot-sub{font-size:9px;letter-spacing:0.25em;color:rgba(255,255,255,0.35);text-transform:uppercase}
.foot-info{font-size:11px;color:rgba(255,255,255,0.4);line-height:2.2;letter-spacing:0.06em;text-align:right}

/* LANG SWITCH */
.ja-text,.en-text{display:none}
body.lang-ja .ja-text{display:block}
body.lang-en .en-text{display:block}
body.lang-ja .ja-inline{display:inline}
body.lang-en .ja-inline{display:none}
body.lang-en .en-inline{display:inline}
body.lang-ja .en-inline{display:none}
.ja-inline,.en-inline{display:none}

/* RESPONSIVE */
@media(max-width:768px){
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:4rem 1.75rem}
  .hero-h1{font-size:32px}
  .hero-h1-en{font-size:28px}
  .concept{grid-template-columns:1fr;padding:4rem 1.75rem;gap:2.5rem}
  .menu-section{padding:4rem 0}
  .menu-grid{grid-template-columns:1fr}
  .booking{padding:4rem 1.5rem}
  .booking-inner{grid-template-columns:1fr;gap:2rem}
  .contact-section{padding:4rem 1.5rem}
  nav.ra-nav{padding:0 1.5rem}
  nav.ra-nav .nav-links{display:none}
  .ra-footer{flex-direction:column;gap:2rem;padding:2.5rem 1.75rem}
  .foot-info{text-align:left}
  .lang-bar{padding:6px 1.5rem}
}
