/* ============================================================
   のびのび訪問施術院 — Design System
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Shippori+Mincho:wght@500;600;700;800&family=Zen+Maru+Gothic:wght@500;700;900&display=swap');

:root{
  /* Color */
  --gold:        #F2B417;
  --gold-deep:   #E5A50C;
  --gold-soft:   #FBE6A8;
  --gold-pale:   #FCF1CF;
  --gold-wash:   #FDF7E6;

  --ink:         #353A41;   /* headings */
  --ink-soft:    #5C616A;   /* body */
  --muted:       #8E9097;   /* captions */
  --navy:        #2B3340;   /* uniform / strong */

  --cream:       #FBF6EC;   /* page background */
  --cream-2:     #FCF8F0;   /* alt card */
  --white:       #FFFFFF;
  --line:        #EFE7D6;   /* hairline */
  --line-soft:   #F2ECE0;

  --shadow-sm: 0 4px 16px rgba(168,140,60,.08);
  --shadow:    0 12px 34px rgba(168,140,60,.10);
  --shadow-lg: 0 22px 60px rgba(168,140,60,.14);

  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-pill: 999px;

  --maxw: 1180px;

  --font-sans: "Noto Sans JP", system-ui, sans-serif;
  --font-serif: "Shippori Mincho", "Noto Serif JP", serif;
  --font-round: "Zen Maru Gothic", "Noto Sans JP", sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; }
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ink-soft);
  background:var(--cream);
  line-height:1.9;
  font-size:16.5px;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  width:100%;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; color:var(--ink); line-height:1.45; font-weight:700; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding:74px 0; }
.center{ text-align:center; }
.gold{ color:var(--gold-deep); }

/* ---------- Section heading ---------- */
.shead{ text-align:center; margin-bottom:46px; }
.shead .en{
  display:block; font-family:var(--font-round); font-weight:700;
  letter-spacing:.32em; color:var(--gold-deep); font-size:.78rem;
  margin-bottom:12px; padding-left:.32em;
}
.shead h2{
  font-family:var(--font-serif); font-size:2.2rem; font-weight:700;
  letter-spacing:.05em; position:relative; display:inline-block;
}
.shead h2::after{
  content:""; display:block; width:50px; height:3px; background:var(--gold);
  border-radius:3px; margin:16px auto 0;
}
.shead p{ margin:1.2em auto 0; max-width:640px; color:var(--ink-soft); font-size:1.02rem; }
.title-mark{ position:relative; display:inline-block; }
.title-mark::after{ display:none; }

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:60; background:rgba(255,255,255,.94);
  backdrop-filter:blur(8px); border-bottom:1px solid var(--line-soft);
}
.nav{
  max-width:1320px; margin:0 auto; padding:0 26px;
  display:flex; align-items:center; gap:26px; height:78px;
}
.brand{ display:flex; align-items:center; gap:13px; flex-shrink:0; }
.brand .logo{ width:42px; height:42px; flex-shrink:0; }
.brand .logo-img{ height:56px; width:auto; display:block; }
.brand .bname{
  font-family:var(--font-round); font-weight:700; color:var(--ink);
  font-size:1.22rem; letter-spacing:.04em; line-height:1.1;
}
.nav-links{ display:flex; align-items:center; gap:5px; margin-left:auto; }
.nav-links a{
  font-weight:500; color:var(--ink); font-size:1rem; padding:9px 14px;
  border-radius:var(--r-pill); transition:.2s; letter-spacing:.04em;
}
.nav-links a:hover{ color:var(--gold-deep); background:var(--gold-wash); }
.nav-links a.active{ color:var(--gold-deep); }

.btn-cta{
  position:relative; overflow:hidden;
  display:inline-flex; align-items:center; gap:12px; flex-shrink:0;
  background:linear-gradient(135deg, #F7C03A 0%, var(--gold) 50%, var(--gold-deep) 100%);
  color:#fff; font-weight:700; font-size:.95rem;
  padding:13px 16px 13px 22px; border-radius:var(--r-pill);
  box-shadow:0 8px 20px rgba(242,180,23,.4); border:none; transition:transform .22s, box-shadow .22s;
  letter-spacing:.05em;
}
.btn-cta::before{
  content:""; position:absolute; top:0; left:-130%; width:60%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.5), transparent);
  transform:skewX(-20deg); transition:none;
}
.btn-cta:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(242,180,23,.5); }
.btn-cta:hover::before{ animation:shine .85s ease; }
.btn-cta .arw{ position:relative; width:24px; height:24px; border-radius:50%; background:rgba(255,255,255,.3);
  display:grid; place-items:center; transition:transform .22s; }
.btn-cta:hover .arw{ transform:translateX(3px); }
.btn-cta .arw svg{ width:13px; height:13px; }

@keyframes shine{ to{ left:140%; } }

.hamburger{ display:none; width:46px; height:46px; border:1px solid var(--line);
  border-radius:12px; background:#fff; flex-direction:column; gap:5px;
  align-items:center; justify-content:center; }
.hamburger span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.25s; }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  position:relative; overflow:hidden;
  display:inline-flex; align-items:center; gap:14px; font-weight:700;
  padding:17px 22px 17px 30px; border-radius:var(--r-pill); font-size:1.02rem;
  transition:transform .22s, box-shadow .22s; border:none; letter-spacing:.06em;
}
.btn .arw{ position:relative; width:28px; height:28px; border-radius:50%; display:grid; place-items:center; transition:transform .22s; }
.btn .arw svg{ width:14px; height:14px; }
.btn:hover .arw{ transform:translateX(3px); }
.btn-gold{ background:linear-gradient(135deg, #F7C03A 0%, var(--gold) 50%, var(--gold-deep) 100%);
  color:#fff; box-shadow:0 12px 26px rgba(242,180,23,.4); }
.btn-gold::before{
  content:""; position:absolute; top:0; left:-130%; width:55%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.5), transparent);
  transform:skewX(-20deg);
}
.btn-gold .arw{ background:rgba(255,255,255,.28); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(242,180,23,.5); }
.btn-gold:hover::before{ animation:shine .85s ease; }
.btn-ghost{ background:#fff; color:var(--ink); border:1.6px solid var(--gold); }
.btn-ghost .arw{ background:var(--gold); }
.btn-ghost .arw svg{ color:#fff; }
.btn-ghost:hover{ background:var(--gold-wash); transform:translateY(-2px); box-shadow:0 12px 26px rgba(242,180,23,.2); }
.arw svg{ stroke:currentColor; }

/* ============================================================
   Page hero (sub pages)
   ============================================================ */
.page-hero{
  position:relative; background:var(--gold-wash);
  padding:58px 0 70px; overflow:hidden; border-bottom:1px solid var(--line-soft);
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(120% 80% at 85% -10%, rgba(242,180,23,.14), transparent 60%);
}
.page-hero .wrap{ position:relative; }
.crumb{ font-size:.82rem; color:var(--muted); margin-bottom:18px; letter-spacing:.06em; }
.crumb a:hover{ color:var(--gold-deep); }
.page-hero .en{
  display:block; font-family:var(--font-round); font-weight:700; letter-spacing:.3em;
  color:var(--gold-deep); font-size:.78rem; margin-bottom:10px;
}
.page-hero h1{
  font-family:var(--font-serif); font-size:2.7rem; font-weight:700; letter-spacing:.06em;
}
.page-hero p{ margin:16px 0 0; max-width:680px; }

/* ============================================================
   Cards / generic
   ============================================================ */
.card{ background:#fff; border-radius:var(--r); box-shadow:var(--shadow-sm); border:1px solid var(--line-soft); }
.tag{
  display:inline-flex; align-items:center; gap:7px; background:var(--gold);
  color:#fff; font-weight:700; font-size:.8rem; padding:6px 16px; border-radius:var(--r-pill);
  letter-spacing:.06em;
}
.tag-soft{ background:var(--gold-pale); color:var(--gold-deep); }

/* icon circle */
.ic{ display:grid; place-items:center; border-radius:50%; overflow:hidden; flex-shrink:0; }
.ic svg{ width:56%; height:56%; stroke:var(--gold-deep); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.ic-line svg{ stroke:var(--navy); stroke-width:1.5; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ background:#fff; border-top:1px solid var(--line); padding:56px 0 30px; }
.foot-top{ display:flex; flex-wrap:wrap; gap:40px; justify-content:space-between; }
.foot-brand{ max-width:340px; }
.foot-brand .brand{ margin-bottom:16px; }
.foot-brand p{ font-size:.9rem; color:var(--muted); }
.foot-cols{ display:flex; gap:64px; flex-wrap:wrap; }
.foot-cols h4{ font-size:.82rem; color:var(--gold-deep); letter-spacing:.14em; margin-bottom:16px; font-family:var(--font-round); }
.foot-cols ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.foot-cols a{ font-size:.92rem; color:var(--ink-soft); }
.foot-cols a:hover{ color:var(--gold-deep); }
.foot-bottom{ margin-top:44px; padding-top:22px; border-top:1px solid var(--line-soft);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.8rem; color:var(--muted); }

/* ============================================================
   Image placeholder
   ============================================================ */
.ph{
  position:relative; background:
    repeating-linear-gradient(135deg, #F6EEDD 0 14px, #FBF6EC 14px 28px);
  display:grid; place-items:center; color:var(--gold-deep); overflow:hidden;
}
.ph span{
  font-family:"SFMono-Regular",ui-monospace,monospace; font-size:.74rem;
  letter-spacing:.08em; background:rgba(255,255,255,.78); padding:5px 12px;
  border-radius:999px; border:1px solid var(--line);
}

/* ============================================================
   Full-width page banner (sub pages)
   ============================================================ */
.page-banner{ background:#FFFDF8; line-height:0; }
.page-banner img{ display:block; width:100%; height:auto; }
.crumb-bar{ background:var(--cream-2); border-bottom:1px solid var(--line-soft); }
.crumb-bar .wrap{ padding-top:13px; padding-bottom:13px; }
.crumb-bar .crumb{ margin:0; font-size:.82rem; color:var(--muted); letter-spacing:.05em; }
.crumb-bar .crumb a:hover{ color:var(--gold-deep); }

/* ============================================================
   Photo frames (design flair)
   ============================================================ */
.media{ position:relative; border-radius:24px; overflow:hidden; box-shadow:var(--shadow);
  aspect-ratio:4/3; background:#F2ECE0; }
.media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.media--tall{ aspect-ratio:3/4; }
.media--wide{ aspect-ratio:16/9; }
.media--organic{ border-radius:120px 26px 26px 26px; }
.media--organic-r{ border-radius:26px 120px 26px 120px; }
.media--pill{ border-radius:200px; }

/* gold offset accent behind a framed photo */
.framed{ position:relative; }
.framed::before{ content:""; position:absolute; inset:0; border-radius:26px;
  border:2px solid var(--gold); transform:translate(18px,18px); z-index:0; pointer-events:none; }
.framed > .media{ position:relative; z-index:1; }
.framed.framed--soft::before{ border:none; background:var(--gold-soft); }

/* floating mini badge on a photo */
.media .float-badge{ display:none; }

/* ============================================================
   Wave divider
   ============================================================ */
.wave{ display:block; width:100%; height:auto; }

/* ============================================================
   Reveal animation
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1080px){
  .nav-links{ display:none; }
  .hamburger{ display:flex; }
  .nav{ height:70px; gap:14px; padding:0 18px; }
  .btn-cta{ padding:11px 14px 11px 18px; font-size:.9rem; }
  .btn-cta .arw{ width:22px; height:22px; }
}
@media (max-width:680px){
  .nav{ height:62px; padding:0 16px; }
  .brand .logo-img{ height:42px; }
  /* CTA lives in the drawer on phones — keep the bar clean */
  .nav > .btn-cta{ display:none; }
  .hamburger{ width:44px; height:44px; }
}
@media (max-width:720px){
  .section{ padding:48px 0; }
  .wrap{ padding:0 18px; }
  .shead{ margin-bottom:34px; }
  .shead h2{ font-size:1.5rem; }
  .shead p{ font-size:.96rem; }
  .page-banner img{ min-height:120px; object-fit:cover; }
  .crumb-bar .wrap{ padding-top:11px; padding-bottom:11px; }
  .crumb{ font-size:.76rem; }
  .btn{ font-size:.96rem; padding:15px 20px 15px 26px; }
  .tag{ font-size:.76rem; padding:5px 14px; }
  .site-footer{ padding:44px 0 26px; }
  .foot-top{ flex-direction:column; gap:30px; }
  .foot-cols{ gap:40px; }
  .foot-bottom{ flex-direction:column; gap:6px; text-align:center; }
}
@media (max-width:480px){
  .shead .en{ font-size:.72rem; letter-spacing:.24em; }
  .shead h2{ font-size:1.38rem; }
}

/* ============================================================
   Mobile drawer
   ============================================================ */
.drawer{
  position:fixed; inset:0; z-index:80; background:rgba(43,51,64,.45);
  opacity:0; visibility:hidden; transition:.3s; backdrop-filter:blur(2px);
}
.drawer.open{ opacity:1; visibility:visible; }
.drawer-panel{
  position:absolute; top:0; right:0; height:100%; width:min(86vw,330px);
  background:var(--cream); box-shadow:-10px 0 40px rgba(0,0,0,.16); padding:20px 22px 28px;
  transform:translateX(100%); transition:transform .34s cubic-bezier(.4,0,.2,1); overflow-y:auto;
  display:flex; flex-direction:column;
}
.drawer.open .drawer-panel{ transform:none; }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.drawer-head .logo-img{ height:42px; width:auto; }
.drawer-panel .close{ width:42px; height:42px; flex-shrink:0;
  border-radius:50%; border:1px solid var(--line); background:#fff; font-size:1.4rem; color:var(--ink);
  display:grid; place-items:center; line-height:1; }
.drawer-panel nav{ margin-top:18px; display:grid; gap:8px; }
.drawer-panel nav a{ display:flex; align-items:center; justify-content:space-between;
  padding:15px 18px; border-radius:14px; background:#fff; border:1px solid var(--line-soft);
  font-weight:700; color:var(--ink); font-size:1rem; transition:.18s; }
.drawer-panel nav a::after{ content:"›"; color:var(--gold); font-size:1.3rem; font-weight:400; }
.drawer-panel nav a:hover,.drawer-panel nav a.active{ background:var(--gold-wash); border-color:var(--gold-soft); color:var(--gold-deep); }
.drawer-cta{ margin-top:auto; padding-top:22px; display:grid; gap:10px; }
.drawer-call{ display:flex; align-items:center; justify-content:center; gap:10px; padding:14px;
  border-radius:14px; background:#fff; border:1.5px solid var(--gold-soft); color:var(--ink); font-weight:700; }
.drawer-call svg{ width:20px; height:20px; stroke:var(--gold-deep); fill:none; stroke-width:1.7; }
.drawer-call b{ font-family:var(--font-serif); font-size:1.2rem; color:var(--gold-deep); letter-spacing:.02em; }
.drawer-panel .btn-cta{ width:100%; justify-content:center; padding:15px; font-size:1rem; }

/* ============================================================
   Floating follow menu button (mobile)
   ============================================================ */
.menu-fab{
  position:fixed; right:14px; top:14px; bottom:auto; z-index:70; display:none;
  align-items:center; gap:8px; padding:11px 18px 11px 14px;
  background:linear-gradient(135deg, #F7C03A, var(--gold-deep));
  color:#fff; border:none; border-radius:var(--r-pill);
  box-shadow:0 10px 26px rgba(229,165,12,.5); cursor:pointer;
  opacity:0; transform:translateY(-24px) scale(.9); pointer-events:none;
  transition:opacity .3s, transform .3s;
}
.menu-fab.show{ opacity:1; transform:none; pointer-events:auto; }
.menu-fab .fab-bars{ display:flex; flex-direction:column; gap:4px; width:20px; }
.menu-fab .fab-bars i{ display:block; height:2px; background:#fff; border-radius:2px; }
.menu-fab .fab-bars i:nth-child(2){ width:75%; }
.menu-fab .fab-label{ font-weight:700; font-size:.9rem; letter-spacing:.05em; }
@media (max-width:1080px){ .menu-fab{ display:flex; } .site-header{ position:relative; } }
