/* ============================================
   BLOOM hair salon — 美容室
   Theme: Pastel Feminine / Soft Rounded
   Completely different from #1-5
   ============================================ */
:root{
  --pri:#2d2d2d;--pri2:#444;
  --rose:#c2185b;--rose-light:#fce4ec;--rose-soft:#f8bbd0;
  --blush:#fff0f3;--cream:#fffaf5;
  --txt:#777;--heading:#2d2d2d;
  --bg:#fffbfc;--bg2:#fdf2f4;
  --ff:'Zen Kaku Gothic New','Noto Sans JP',sans-serif;
  --fe:'DM Sans','Inter',sans-serif;
  --r:20px;--r2:999px;--r3:50%;
  --hh:70px;
  /* base.css overrides */
  --color-primary:#c2185b;--color-accent:#c2185b;--color-text:#777;--color-heading:#2d2d2d;
  --color-bg:#fffbfc;--color-bg-alt:#fdf2f4;
  --color-header-bg:rgba(255,251,252,.95);
  --color-footer-bg:#2d2d2d;--color-footer-text:rgba(255,255,255,.4);
  --font-heading:'Zen Kaku Gothic New','Noto Sans JP',sans-serif;
  --font-body:'Noto Sans JP',sans-serif;
  --font-en:'DM Sans','Inter',sans-serif;
  --header-height:70px;--radius:20px;--radius-lg:24px;
}

/* Loading — soft pink */
.loading-screen{background:var(--rose)}
.loading-logo{font-family:var(--fe);color:#fff;font-size:1.8rem;font-weight:700;letter-spacing:.1em}

/* Header — clean, rounded CTA */
.header .logo{font-family:var(--fe);font-size:1.1rem;font-weight:700;color:var(--heading);letter-spacing:.02em}
.header.scrolled .logo{color:var(--heading)}
.header .nav-link{font-size:.78rem;font-weight:500;color:var(--txt)}
.header .nav-link::after{background:var(--rose);height:2px;border-radius:1px}
.header .hamburger span{background:var(--heading)}

/* Pill button */
.btn-rose{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.8rem;background:var(--rose);color:#fff;border-radius:var(--r2);font-size:.8rem;font-weight:600;font-family:var(--ff);transition:all .3s;border:none;cursor:pointer}
.btn-rose:hover{opacity:1;background:#ad1457;transform:translateY(-2px);box-shadow:0 8px 24px rgba(194,24,91,.2)}
.btn-soft{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.8rem;background:var(--rose-light);color:var(--rose);border-radius:var(--r2);font-size:.8rem;font-weight:600;font-family:var(--ff);transition:all .3s;border:none;cursor:pointer}
.btn-soft:hover{background:var(--rose-soft);transform:translateY(-1px)}

/* === HERO — Asymmetric blob + text === */
.hero-bloom{min-height:100vh;display:flex;align-items:center;padding-top:var(--hh);background:var(--bg);position:relative;overflow:hidden}
.hero-bloom::before{content:'';position:absolute;top:-15%;right:-10%;width:55vw;height:130%;background:var(--blush);border-radius:0 0 0 40%;z-index:0}
.hero-bloom-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;position:relative;z-index:1}
.hero-bloom-text .eyebrow{font-family:var(--fe);font-size:.65rem;font-weight:600;letter-spacing:.15em;color:var(--rose);margin-bottom:1.25rem;text-transform:uppercase}
.hero-bloom-text h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700;color:var(--heading);line-height:1.5;margin-bottom:1.25rem}
.hero-bloom-text h1 span{color:var(--rose)}
.hero-bloom-text p{font-size:.9rem;line-height:2;margin-bottom:2rem}
.hero-bloom-text .btns{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-bloom-img{position:relative}
.hero-bloom-img img{width:85%;margin-left:auto;border-radius:40% 40% 40% 0;aspect-ratio:3/4;object-fit:cover;box-shadow:0 30px 80px rgba(194,24,91,.1)}
.hero-bloom-float{position:absolute;bottom:10%;left:0;background:#fff;border-radius:var(--r);padding:1rem 1.5rem;box-shadow:0 8px 30px rgba(0,0,0,.06);display:flex;align-items:center;gap:.75rem}
.hero-bloom-float-icon{width:40px;height:40px;background:var(--rose-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem}
.hero-bloom-float strong{font-size:1.2rem;font-weight:700;color:var(--rose);display:block;font-family:var(--fe)}
.hero-bloom-float span{font-size:.6rem;color:var(--txt)}
@media(max-width:768px){
  .hero-bloom-grid{grid-template-columns:1fr;gap:2rem}
  .hero-bloom::before{width:100%;height:40%;top:auto;bottom:0;border-radius:40% 40% 0 0}
  .hero-bloom-img img{width:70%;margin:0 auto;border-radius:30%}
  .hero-bloom-float{position:static;margin-top:1rem}
  .hero-bloom{min-height:auto;padding-bottom:3rem}
}

/* === MENU CARDS — Rounded, soft shadow === */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}
.menu-card{background:#fff;border-radius:var(--r);overflow:hidden;transition:all .4s;box-shadow:0 2px 12px rgba(0,0,0,.03)}
.menu-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(194,24,91,.08)}
.menu-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .6s}
.menu-card:hover img{transform:scale(1.04)}
.menu-card-body{padding:1.25rem 1.5rem 1.5rem}
.menu-card-tag{display:inline-block;font-size:.55rem;font-weight:600;padding:.2rem .7rem;border-radius:var(--r2);background:var(--rose-light);color:var(--rose);margin-bottom:.5rem}
.menu-card h3{font-size:.95rem;font-weight:700;color:var(--heading);margin-bottom:.3rem}
.menu-card p{font-size:.72rem;line-height:1.7}
.menu-card .price{font-family:var(--fe);font-size:.85rem;color:var(--rose);font-weight:600;margin-top:.5rem;display:block}
@media(max-width:768px){.menu-grid{grid-template-columns:1fr}}

/* === STYLIST — Circle photos === */
.stylist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2.5rem}
.stylist{text-align:center}
.stylist img{width:160px;height:160px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;border:4px solid var(--rose-light);transition:border-color .3s}
.stylist:hover img{border-color:var(--rose)}
.stylist h3{font-size:.9rem;font-weight:700;color:var(--heading)}
.stylist .role{font-size:.65rem;color:var(--rose);margin-top:.15rem}
.stylist p{font-size:.7rem;line-height:1.7;margin-top:.5rem;max-width:250px;margin-left:auto;margin-right:auto}
@media(max-width:640px){.stylist-grid{grid-template-columns:1fr;max-width:280px;margin-left:auto;margin-right:auto}}

/* === INSTAGRAM-LIKE GALLERY === */
.insta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:2rem}
.insta-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;transition:transform .4s,filter .4s;filter:brightness(.95)}
.insta-grid img:hover{transform:scale(1.03);filter:brightness(1)}
@media(max-width:768px){.insta-grid{grid-template-columns:repeat(2,1fr)}}

/* === CTA — Soft rose bg === */
.cta-bloom{background:var(--rose);color:#fff;text-align:center;padding:clamp(4rem,8vw,6rem) 0;border-radius:var(--r);margin:0 clamp(1rem,3vw,2rem)}
.cta-bloom h2{font-size:clamp(1.3rem,3vw,1.8rem);font-weight:700;margin-bottom:.5rem}
.cta-bloom p{font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:1.5rem}
.cta-bloom .btn-w{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 2rem;background:#fff;color:var(--rose);border-radius:var(--r2);font-size:.8rem;font-weight:700;transition:all .3s}
.cta-bloom .btn-w:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1);opacity:1}

/* === PAGE HEADER — Soft gradient === */
.page-header{background:linear-gradient(135deg,var(--blush),var(--bg2));padding:calc(var(--hh) + 3rem) 0 3rem}
.page-header .section-label{color:var(--rose)}
.page-header .section-label::before{background:var(--rose)}
.page-header h1{font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:700;color:var(--heading)}
.page-header .page-subtitle{font-family:var(--fe);font-size:.7rem;color:var(--txt);letter-spacing:.1em;margin-top:.3rem}
.breadcrumb a{color:var(--rose)}

/* === FOOTER === */
.footer{background:var(--heading)}
.footer-logo{font-family:var(--fe);font-weight:700}

/* Forms — rounded */
.form-input,.form-textarea,.form-select{border-radius:12px;background:#fff;border:1.5px solid rgba(0,0,0,.06)}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(194,24,91,.08)}

/* SCALE Badge */
.scale-badge{background:var(--heading);border-radius:var(--r2)}
.scale-badge-dot{background:var(--rose)}

/* Misc */
.section-label{color:var(--rose)}
.section-label::before{background:var(--rose)}
