/*! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.bottom-0{bottom:0}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-10{z-index:10}.z-50{z-index:50}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-10{margin-bottom:2.5rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.flex{display:flex}.grid{display:grid}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-24{height:6rem}.h-32{height:8rem}.h-40{height:10rem}.h-full{height:100%}.min-h-\[160px\]{min-height:160px}.min-h-screen{min-height:100vh}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-24{width:6rem}.w-28{width:7rem}.w-3{width:.75rem}.w-full{width:100%}.min-w-\[120px\]{min-width:120px}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-translate-y-6{--tw-translate-y:-1.5rem}.-translate-y-6,.translate-x-6{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-6{--tw-translate-x:1.5rem}.snap-x{scroll-snap-type:x var(--tw-scroll-snap-strictness)}.snap-start{scroll-snap-align:start}.scroll-mt-24{scroll-margin-top:6rem}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-24>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(6rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(6rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.scroll-smooth{scroll-behavior:smooth}.rounded-2xl{border-radius:1rem}.rounded-\[2rem\]{border-radius:2rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[\#B59410\]{--tw-border-opacity:1;border-color:rgb(181 148 16/var(--tw-border-opacity))}.border-\[\#BD1E33\]{--tw-border-opacity:1;border-color:rgb(189 30 51/var(--tw-border-opacity))}.border-\[\#E91E63\]{--tw-border-opacity:1;border-color:rgb(233 30 99/var(--tw-border-opacity))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity))}.border-slate-100{--tw-border-opacity:1;border-color:rgb(241 245 249/var(--tw-border-opacity))}.border-slate-200{--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity))}.border-slate-300{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity))}.border-white\/5{border-color:#ffffff0d}.\!bg-transparent{background-color:initial!important}.bg-\[\#B59410\]{--tw-bg-opacity:1;background-color:rgb(181 148 16/var(--tw-bg-opacity))}.bg-\[\#BD1E33\]{--tw-bg-opacity:1;background-color:rgb(189 30 51/var(--tw-bg-opacity))}.bg-\[\#E91E63\]{--tw-bg-opacity:1;background-color:rgb(233 30 99/var(--tw-bg-opacity))}.bg-emerald-50{--tw-bg-opacity:1;background-color:rgb(236 253 245/var(--tw-bg-opacity))}.bg-rose-50{--tw-bg-opacity:1;background-color:rgb(255 241 242/var(--tw-bg-opacity))}.bg-slate-100{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity))}.bg-slate-900{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.bg-white\/40{background-color:#fff6}.bg-white\/50{background-color:#ffffff80}.bg-white\/80{background-color:#fffc}.bg-white\/90{background-color:#ffffffe6}.bg-\[url\(\'img\/haikei\.png\'\)\]{background-image:url(img/haikei.png)}.bg-cover{background-size:cover}.bg-fixed{background-attachment:fixed}.bg-no-repeat{background-repeat:no-repeat}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-24{padding-bottom:6rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pt-2{padding-top:.5rem}.pt-24{padding-top:6rem}.pt-6{padding-top:1.5rem}.text-center{text-align:center}.font-sans{font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[7px\]{font-size:7px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-black{font-weight:900}.font-bold{font-weight:700}.font-normal{font-weight:400}.uppercase{text-transform:uppercase}.italic{font-style:italic}.not-italic{font-style:normal}.leading-loose{line-height:2}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-\[0\.4em\]{letter-spacing:.4em}.tracking-tighter{letter-spacing:-.05em}.tracking-widest{letter-spacing:.1em}.text-\[\#B59410\]{--tw-text-opacity:1;color:rgb(181 148 16/var(--tw-text-opacity))}.text-\[\#BD1E33\]{--tw-text-opacity:1;color:rgb(189 30 51/var(--tw-text-opacity))}.text-\[\#E91E63\]{--tw-text-opacity:1;color:rgb(233 30 99/var(--tw-text-opacity))}.text-emerald-600{--tw-text-opacity:1;color:rgb(5 150 105/var(--tw-text-opacity))}.text-rose-600{--tw-text-opacity:1;color:rgb(225 29 72/var(--tw-text-opacity))}.text-slate-400{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.opacity-10{opacity:.1}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-slate-200\/50{--tw-shadow-color:#e2e8f080;--tw-shadow:var(--tw-shadow-colored)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px)}.backdrop-blur-sm,.backdrop-blur-xl{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-xl{--tw-backdrop-blur:blur(24px)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.hover\:-translate-y-1:hover{--tw-translate-y:-0.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity))}.hover\:bg-slate-700:hover{--tw-bg-opacity:1;background-color:rgb(51 65 85/var(--tw-bg-opacity))}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-md:hover,.hover\:shadow-xl:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}@media (min-width:640px){.sm\:flex-none{flex:none}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:text-7xl{font-size:4.5rem;line-height:1}}@media (min-width:768px){.md\:mb-16{margin-bottom:4rem}.md\:mb-4{margin-bottom:1rem}.md\:mb-6{margin-bottom:1.5rem}.md\:mb-8{margin-bottom:2rem}.md\:ml-2{margin-left:.5rem}.md\:h-12{height:3rem}.md\:h-16{height:4rem}.md\:h-32{height:8rem}.md\:h-40{height:10rem}.md\:h-44{height:11rem}.md\:w-32{width:8rem}.md\:w-auto{width:auto}.md\:flex-row{flex-direction:row}.md\:gap-3{gap:.75rem}.md\:gap-4{gap:1rem}.md\:gap-6{gap:1.5rem}.md\:space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem*var(--tw-space-y-reverse))}.md\:rounded-2xl{border-radius:1rem}.md\:rounded-\[3rem\]{border-radius:3rem}.md\:p-4{padding:1rem}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}.md\:pb-12{padding-bottom:3rem}.md\:pb-32{padding-bottom:8rem}.md\:pt-32{padding-top:8rem}.md\:pt-4{padding-top:1rem}.md\:text-left{text-align:left}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-8xl{font-size:6rem;line-height:1}.md\:text-\[10px\]{font-size:10px}.md\:text-\[8px\]{font-size:8px}.md\:text-\[9px\]{font-size:9px}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xs{font-size:.75rem;line-height:1rem}}@media (min-width:1024px){.lg\:col-span-12{grid-column:span 12/span 12}.lg\:col-span-5{grid-column:span 5/span 5}.lg\:col-span-7{grid-column:span 7/span 7}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}}

/* ==============================================================
   ▼ 1. 店舗情報などの大枠（骨組み）のデザイン ▼
   ==============================================================
   ここでは、各店舗情報を囲む白い箱や、特徴などをまとめるカードの
   レイアウト（余白やサイズ）を設定しています。
*/
.top-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 1.5rem;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.18);
  filter: drop-shadow(0 20px 60px rgba(15, 23, 42, 0.25));
}
.hero-title {
  text-shadow: 0 4px 6px rgba(15, 23, 42, 0.1), 0 1px 3px rgba(15, 23, 42, 0.06);
}
/*AI section*/
.ai-diagnostic-box {
display: flex; 
flex-direction: column; 
justify-content: center; 
min-height: 160px;
padding: 2rem 1rem;
}
/* Store Section Wrapper */
.store-wrapper {
  display: grid;
  gap: 1rem;
  background-color: rgba(255, 255, 255, 0.4);
  padding: 1rem;
  border-radius: 2rem;
}
@media (min-width: 768px) {
  .store-wrapper {
    gap: 1.5rem;
    padding: 2rem;
  }
}
@media (min-width: 1024px) {
  .store-wrapper {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }
}

/* Glass Card Overview */
.glass-card {
  background-color: rgba(255, 255, 255, 1);
  padding: 1.5rem;
  border-radius: 1rem;
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(241, 245, 249);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
@media (min-width: 768px) {
  .glass-card {
    padding: 2rem;
  }
}

/* Feature/Condition Card */
.feature-card {
  background-color: rgba(255, 255, 255, 1);
  padding: 1.25rem;
  border-radius: 1rem;
  border: 1px solid rgb(241, 245, 249);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
@media (min-width: 768px) {
  .feature-card {
    padding: 1.5rem;
  }
}

/* Strength Block */
.strength-card {
  padding: 1.5rem;
  border-radius: 1rem;
  border-width: 2px;
  background-color: rgba(255, 255, 255, 1);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
}
@media (min-width: 768px) {
  .strength-card {
    padding: 2rem;
  }
}

/* Cast Image Card (Honten) */
.cast-img-card {
  width: 7rem;
  height: 10rem;
  border-radius: 0.75rem;
  overflow: hidden;
  margin-bottom: 0.5rem;
  position: relative;
  border: 1px solid rgb(241, 245, 249);
  background-color: rgb(241, 245, 249);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
@media (min-width: 768px) {
  .cast-img-card {
    width: 8rem;
    height: 11rem;
  }
}

/* Cast List Card (Alpha, Vampire) */
.cast-list-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.75rem;
  background-color: rgba(255, 255, 255, 1);
  border-radius: 0.75rem;
  border: 1px solid rgb(241, 245, 249);
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  position: relative;
  overflow: hidden;
}

/* Contact Container */
.contact-container {
  margin-top: 0.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgb(226, 232, 240);
}
@media (min-width: 1024px) {
  .contact-container {
    grid-column: span 12 / span 12;
  }
}

/* LINE Submit Button */
.btn-line {
  width: 100%;
  padding: 1rem 2rem;
  border-radius: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  font-size: 0.875rem;
  font-weight: 900;
  color: white;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
}
@media (min-width: 768px) {
  .btn-line {
    width: auto;
    border-radius: 1rem;
  }
}
.btn-line:hover {
  transform: translateY(-0.25rem);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
}


/* ==============================================================
   ▼ 2. ページ全体のレイアウトと背景設定 ▼
   ==============================================================
   背景画像(haikei.png)の指定や、ヘッダー（ナビゲーション）の固定、
   一番上の「Next Stage」と書かれたメイン部分の余白などを設定します。
*/

.body-theme {
  height: 100%;
  background-image: url('img/haikei.png');
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;
  margin: 0;
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

.main-layout {
  min-height: 100vh;
  background-color: transparent !important;
  color: rgb(15, 23, 42);
}

.header-nav {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 50;
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgb(243, 244, 246);
}

.header-container {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1rem;
  height: 3.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (min-width: 768px) {
  .header-container {
    padding: 0 1.5rem;
    height: 4rem;
  }
}

.hero-section {
  padding-top: 6rem;
  padding-bottom: 2rem;
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (min-width: 768px) {
  .hero-section {
    padding-top: 8rem;
    padding-bottom: 3rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

.hero-title {
  font-size: 3rem;
  line-height: 1;
  font-weight: 900;
  font-style: italic;
  letter-spacing: -0.05em;
  margin-bottom: 1rem;
  color: rgb(15, 23, 42);
  text-transform: uppercase;
}
@media (min-width: 640px) {
  .hero-title {
    font-size: 4.5rem;
  }
}
@media (min-width: 768px) {
  .hero-title {
    font-size: 6rem;
    margin-bottom: 1.5rem;
  }
}

.hero-subtitle {
  font-size: 0.75rem;
  line-height: 2;
  color: rgb(100, 116, 139);
  font-weight: 700;
  margin-bottom: 1.5rem;
  letter-spacing: 0.1em;
  padding: 0 0.5rem;
}
@media (min-width: 768px) {
  .hero-subtitle {
    font-size: 1rem;
    line-height: 1.5rem;
    margin-bottom: 2rem;
  }
}

.store-nav-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  padding: 0 1rem;
  margin-bottom: 4rem;
  max-width: 56rem;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 768px) {
  .store-nav-container {
    gap: 0.75rem;
  }
}

.store-nav-btn {
  position: relative;
  padding: 1rem 1.5rem;
  border-radius: 0.75rem;
  border-width: 2px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  flex: 1 1 0%;
  min-width: 120px;
  background-color: white;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
@media (min-width: 640px) {
  .store-nav-btn {
    flex: none;
  }
}
.store-nav-btn:hover {
  background-color: rgb(248, 250, 252);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
}

.footer-layout {
  padding-top: 3rem;
  padding-bottom: 3rem;
  text-align: center;
  color: rgb(148, 163, 184);
  background-color: rgb(15, 23, 42);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.store-title {
  font-size: 1.875rem;
  line-height: 2.25rem;
  font-weight: 900;
  letter-spacing: -0.05em;
  color: rgb(15, 23, 42);
}
@media (min-width: 768px) {
  .store-title {
    font-size: 3rem;
    line-height: 1;
  }
}

.store-title-wrapper {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}


/* ==============================================================
   ▼ 3. 各パーツごとの細かいデザイン ▼
   ==============================================================
   ボタンの形、ドロップダウンメニューの動き、文字の大きさ、
   LINEボタンの影など、個別の部品のデザインを設定します。
*/

.header-title {
  font-size: 1.25rem;
  line-height: 1.75rem;
  font-weight: 900;
  font-style: italic;
  letter-spacing: -0.05em;
  color: rgb(15, 23, 42);
}
@media (min-width: 768px) { .header-title { font-size: 1.5rem; line-height: 2rem; } }

.header-subtitle {
  font-size: 10px;
  font-weight: 400;
  color: rgb(148, 163, 184);
  margin-left: 0.25rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-style: normal;
}
@media (min-width: 768px) { .header-subtitle { margin-left: 0.5rem; } }

.header-contact-btn {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.1em;
  background-color: rgb(15, 23, 42);
  color: white;
  padding: 0.5rem 1rem;
  border-radius: 9999px;
  text-transform: uppercase;
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (min-width: 768px) { .header-contact-btn { padding: 0.5rem 1.5rem; } }
.header-contact-btn:hover { background-color: rgb(51, 65, 85); }



.dropdown-item {
  display: block;
  padding: 0.75rem 1rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: rgb(15, 23, 42);
  position: relative;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border-bottom: 1px solid rgb(241, 245, 249);
}
.dropdown-item:hover { background-color: rgb(248, 250, 252); }
.dropdown-item.no-border { border-bottom: none; }

.hero-container { max-width: 64rem; margin: 0 auto; text-align: center; }

.ai-diagnostic-box {
  max-width: 42rem;
  margin: 0 auto 2.5rem auto;
  padding: 2rem;
  background-color: rgba(255, 255, 255, 0.5);
  border: 2px dashed rgb(203, 213, 225);
  border-radius: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
}
@media (min-width: 768px) {
  .ai-diagnostic-box { margin-bottom: 4rem; border-radius: 3rem; }
}

.diagnostic-title {
  font-size: 0.875rem;
  font-weight: 700;
  color: rgb(148, 163, 184);
  margin-bottom: 0.5rem;
}
@media (min-width: 768px) { .diagnostic-title { font-size: 1rem; line-height: 1.5rem; } }

.diagnostic-subtitle { font-size: 0.75rem; color: rgb(148, 163, 184); }

.store-nav-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  position: relative;
  z-index: 10;
}
.store-nav-dot { width: 0.625rem; height: 0.625rem; border-radius: 9999px; }
.store-nav-text {
  font-size: 0.875rem; font-weight: 900; letter-spacing: -0.05em; color: rgb(15, 23, 42); line-height: 1.25rem;
}

.store-title-dot { width: 0.75rem; height: 2.5rem; border-radius: 9999px; }
@media (min-width: 768px) { .store-title-dot { height: 3rem; } }

.store-left-col { margin-top: 1rem; margin-bottom: 1rem; min-width: 0; }
@media (min-width: 768px) { .store-left-col { margin-top: 1.5rem; margin-bottom: 1.5rem; } }
@media (min-width: 1024px) { .store-left-col { grid-column: span 7 / span 7; margin: 0; } }

.store-right-col { margin-top: 1rem; margin-bottom: 1rem; min-width: 0; }
@media (min-width: 768px) { .store-right-col { margin-top: 1.5rem; margin-bottom: 1.5rem; } }
@media (min-width: 1024px) { .store-right-col { grid-column: span 5 / span 5; margin: 0; } }

.bg-icon-svg {
  position: absolute; top: 0; right: 0; width: 6rem; height: 6rem; opacity: 0.1; transform: translate(1.5rem, -1.5rem);
}
@media (min-width: 768px) { .bg-icon-svg { width: 8rem; height: 8rem; } }

.content-z { position: relative; z-index: 10; }

.card-overline {
  font-size: 8px; font-weight: 900; letter-spacing: 0.4em; margin-bottom: 0.5rem; text-transform: uppercase;
}
@media (min-width: 768px) { .card-overline { font-size: 10px; margin-bottom: 1rem; } }

.card-title {
  font-size: 1.5rem; line-height: 1.25; font-weight: 900; margin-bottom: 0.5rem; color: rgb(15, 23, 42);
}
@media (min-width: 768px) { .card-title { font-size: 1.875rem; margin-bottom: 1rem; } }

.card-desc {
  font-size: 10px; font-weight: 700; color: rgb(100, 116, 139); letter-spacing: 0.1em; line-height: 1.625;
}
@media (min-width: 768px) { .card-desc { font-size: 0.875rem; } }

.feature-grid { display: grid; gap: 1rem; }
@media (min-width: 640px) { .feature-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

.feature-header { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1rem; }
@media (min-width: 768px) { .feature-header { gap: 0.75rem; margin-bottom: 1.5rem; } }

.feature-icon { padding: 0.375rem; border-radius: 0.5rem; }
.feature-icon.bg-emerald { background-color: rgb(236, 253, 245); color: rgb(5, 150, 105); }
.feature-icon.bg-rose { background-color: rgb(255, 241, 242); color: rgb(225, 29, 72); }

.feature-label {
  font-size: 10px; font-weight: 900; letter-spacing: 0.1em; color: rgb(148, 163, 184); text-transform: uppercase;
}
@media (min-width: 768px) { .feature-label { font-size: 0.75rem; } }

.feature-text { font-size: 0.75rem; font-weight: 700; line-height: 1.625; color: inherit; }
.feature-text-muted { font-size: 0.75rem; font-weight: 700; line-height: 1.625; color: rgb(148, 163, 184); }
@media (min-width: 768px) { .feature-text, .feature-text-muted { font-size: 0.875rem; } }

.edu-title {
  font-size: 0.75rem; font-weight: 900; color: rgb(15, 23, 42); margin-bottom: 0.75rem; border-left-width: 4px; padding-left: 0.75rem;
}
@media (min-width: 768px) { .edu-title { font-size: 0.875rem; } }

.edu-list {
  display: flex; flex-direction: column; gap: 0.75rem;
}

.edu-badge {
  font-size: 10px; font-weight: 700; background-color: rgb(241, 245, 249); padding: 0.25rem 0.5rem; border-radius: 0.25rem; color: rgb(71, 85, 105); margin-right: 0.5rem;
}
.edu-desc { font-size: 0.75rem; color: rgb(51, 65, 85); font-weight: 700; }
@media (min-width: 768px) { .edu-desc { font-size: 0.875rem; } }

.strength-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
@media (min-width: 768px) { .strength-header { gap: 1rem; margin-bottom: 1.5rem; } }

.strength-label {
  font-size: 8px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.1em; color: rgb(148, 163, 184);
}
@media (min-width: 768px) { .strength-label { font-size: 10px; } }

.strength-list {
  font-size: 0.875rem; font-weight: 700; line-height: 1.625; color: rgb(15, 23, 42); display: flex; flex-direction: column; gap: 0.5rem; list-style: none;
}
@media (min-width: 768px) { .strength-list { font-size: 1rem; } }

.strength-item { display: flex; align-items: flex-start; gap: 0.5rem; }
.strength-bullet { margin-top: 0.25rem; flex-shrink: 0; }

.cast-section { padding-top: 0.5rem; }
@media (min-width: 768px) { .cast-section { padding-top: 1rem; } }

.cast-section-title {
  font-size: 8px; font-weight: 900; color: rgb(148, 163, 184); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 1rem; padding: 0 0.5rem;
}
@media (min-width: 768px) { .cast-section-title { font-size: 10px; } }

.cast-scroll-container {
  display: flex;
  gap: 0.75rem;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  padding: 0 0.5rem 0.75rem 0.5rem; /* スクロールバーとコンテンツの間の余白を確保 */
  scrollbar-width: thin;
  scrollbar-color: #cbd5e1 transparent;
}

/* ▽ スタイリッシュなカスタムスクロールバーの設定 (Webkit系) ▽ */
.cast-scroll-container::-webkit-scrollbar {
  height: 6px; /* スクロールバーの細さ */
}
.cast-scroll-container::-webkit-scrollbar-track {
  background: rgba(241, 245, 249, 0.6); /* うっすらとしたトラック背景 */
  border-radius: 9999px;
}
.cast-scroll-container::-webkit-scrollbar-thumb {
  background-color: #cbd5e1; /* つまみの色 */
  border-radius: 9999px;
}
.cast-scroll-container::-webkit-scrollbar-thumb:hover {
  background-color: #94a3b8; /* ホバー時に少し濃くする */
}
/* △ カスタムスクロールバー ここまで △ */
.cast-item-wrapper { flex-shrink: 0; width: 7rem; scroll-snap-align: start; }
@media (min-width: 768px) { .cast-item-wrapper { width: 8rem; } }

.cast-img { width: 100%; height: 100%; object-fit: cover; transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
.cast-img-label-container {
  position: absolute; bottom: 0; left: 0; width: 100%; padding: 0.375rem;
  background-color: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  border-top: 1px solid rgb(241, 245, 249);
  color: rgb(15, 23, 42);
}
.cast-img-label { font-size: 7px; font-weight: 900; color: rgb(148, 163, 184); letter-spacing: -0.05em; text-transform: uppercase; }
@media (min-width: 768px) { .cast-img-label { font-size: 8px; } }

.cast-name { font-size: 9px; font-weight: 900; color: rgb(15, 23, 42); margin-top: 0.25rem; }
@media (min-width: 768px) { .cast-name { font-size: 10px; } }

.cast-subname { font-size: 7px; color: rgb(100, 116, 139); font-weight: 700; line-height: 1.25; margin-top: 0.25rem; }
@media (min-width: 768px) { .cast-subname { font-size: 8px; } }

.cast-list-container { display: flex; flex-direction: column; gap: 0.75rem; padding: 0 0.5rem; }


.cast-list-avatar { width: 3rem; height: 3rem; border-radius: 9999px; background-color: rgb(226, 232, 240); flex-shrink: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.cast-list-name-wrap { display: flex; align-items: baseline; gap: 0.5rem; }
.cast-list-name { font-size: 0.875rem; font-weight: 900; color: rgb(15, 23, 42); }
.cast-list-badge { font-size: 10px; font-weight: 700; padding: 0.125rem 0.375rem; border-radius: 0.125rem; color: white; }
.cast-list-desc { font-size: 10px; color: rgb(100, 116, 139); font-weight: 700; margin-top: 0.25rem; }


@media (min-width: 768px) {  }
.contact-text-wrap { text-align: center; }
.contact-title { font-size: 1.25rem; font-weight: 900; font-style: italic; letter-spacing: -0.05em; color: rgb(15, 23, 42); text-transform: uppercase; }
@media (min-width: 768px) { .contact-title { font-size: 1.5rem; } }

.contact-subtitle { font-size: 10px; color: rgb(100, 116, 139); font-weight: 700; letter-spacing: 0.1em; margin-top: 0.25rem; }
@media (min-width: 768px) { .contact-subtitle { font-size: 0.75rem; } }

.footer-text { font-size: 8px; font-weight: 900; letter-spacing: 0.4em; text-transform: uppercase; }
@media (min-width: 768px) { .footer-text { font-size: 9px; } }



/* ==============================================================
   ▼ 4. 各店舗のテーマカラー（色）の設定 ▼
   ==============================================================
   ここで店舗ごとの色を一括管理しています。枠線、ボタン、文字色などで使われます。
   店舗の色を変更したい場合は、ここの #から始まるカラーコード を書き換えてください。
*/

/* --- 本店のテーマカラー（ゴールド） --- */
.bg-honten { background-color: #B59410; }
.border-honten { border-color: #B59410; }
.text-honten { color: #B59410; }

/* --- アルファのテーマカラー（ピンク） --- */
.bg-alpha { background-color: #E91E63; }
.border-alpha { border-color: #E91E63; }
.text-alpha { color: #E91E63; }

/* --- VAMPIREのテーマカラー（赤） --- */
.bg-vampire { background-color: #BD1E33; }
.border-vampire { border-color: #BD1E33; }
.text-vampire { color: #BD1E33; }

.bg-growth { background-color: #10b981; }
.bg-friendly { background-color: #f59e0b; }

.vertical-accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0.25rem;
}

.dropdown-label {
  padding-left: 0.5rem;
}

.scroll-offset-store {
  scroll-margin-top: 6rem;
}

.scroll-offset-contact {
  scroll-margin-top: 7rem;
}

/* ==============================================================
   ▼ 5. 店舗一覧エリアのレイアウト ▼
   ==============================================================
   店舗同士の間の縦の余白（間隔）などを設定します。
*/

.store-list-container {
  max-width: 72rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 6rem;
}
.store-list-container > * + * {
  margin-top: 6rem;
}
@media (min-width: 768px) {
  .store-list-container {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    padding-bottom: 8rem;
  }
}


/* ==============================================================
   ▼ 6. アニメーション（動き）と配置の微調整 ▼
   ==============================================================
   マウスを乗せたときの画像拡大や、ボタンが少し浮かび上がる動き、
   ドロップダウンメニューがフワッと表示される動きなどを設定します。
*/

/* Margin between cards in left and right column */
.store-left-col > * + *, .store-right-col > * + * {
  margin-top: 1rem;
}
@media (min-width: 768px) {
  .store-left-col > * + *, .store-right-col > * + * {
    margin-top: 1.5rem;
  }
}

/* Contact inner vertical centering */
.contact-inner { 
  display: flex; 
  flex-direction: column; 
  align-items: center; 
  justify-content: center; 
  gap: 1.5rem; 
  padding: 2rem 1rem; 
  text-align: center;
}

/* Dropdown Javascript functionality styles */
.dropdown-menu {
  position: absolute;
  right: 0;
  top: 100%;
  margin-top: 0.5rem;
  background-color: white;
  border-radius: 0.75rem;
  border: 1px solid rgb(241, 245, 249);
  overflow: hidden;
  min-width: 140px;
  z-index: 50;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  visibility: hidden;
  opacity: 0;
  transform: translateY(-0.5rem);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.dropdown-menu.open {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
}

/* Hover effect on dropdown items */
.dropdown-item .dropdown-label {
  display: inline-block;
  transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.dropdown-item:hover .dropdown-label {
  transform: translateX(4px);
}

/* Hover effect on Cast Images */
.cast-img-card .cast-img {
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.cast-img-card:hover .cast-img {
  transform: scale(1.05);
}

/* Slight scale on LINE buttons */
.btn-line {
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-line:hover {
  transform: translateY(-0.25rem) scale(1.02);
}

/* ユーティリティークラス追記 */
.hidden {
  display: none !important;
}

/* ==============================================================
   ▼ 7. キャスト一覧の無限スクロール制御 ▼
   ==============================================================
   キャストが4人以上になった時に、自動で左に流れる設定です。
*/
.hide-scrollbar-explicit {
  scrollbar-width: none !important;
}
.hide-scrollbar-explicit::-webkit-scrollbar {
  display: none !important;
}

.carousel-mode {
  padding-bottom: 0 !important;
  overflow: hidden !important;
  display: block !important;
}
.carousel-mode::-webkit-scrollbar {
  display: none !important;
}

.marquee-track {
  display: flex;
  gap: 0.75rem;
  width: max-content;
}

/* アニメーション中は flex-shrink を無効化して幅が潰れないようにする */
.marquee-content {
  display: flex;
  gap: 0.75rem;
  flex-shrink: 0;
  /* スクロールの速度を変更したい場合は、下の 15s（15秒） の数字を変えてください */
  animation: scrollMarquee 15s linear infinite;
  will-change: transform;
}

/* マイナス100%分(自身の幅分)とギャップ分移動することで、完全に一周する */
@keyframes scrollMarquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-100% - 0.75rem));
  }
}
