@charset "utf-8";
/*!
Theme Name: au2025_vol1
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: au2025_vol1
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

au2025_vol1 is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
	margin-top: 175px;
}
@media screen and (max-width: 768px) {
main {
	margin-top: 90px;
}

}
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
	color: #404040;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-size: 1rem;
	line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
}

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
	background: #fff;
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 1.5em 3em;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: 700;
}

dd {
	margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

img {
	height: auto;
	max-width: 100%;
}

figure {
	margin: 1em 0;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/* Links
--------------------------------------------- */
a {
	color: #4169e1;
}

a:visited {
	color: #800080;
}

a:hover,
a:focus,
a:active {
	color: #191970;
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 1px solid;
	border-color: #ccc #ccc #bbb;
	border-radius: 3px;
	background: #e6e6e6;
	color: rgba(0, 0, 0, 0.8);
	line-height: 1;
	padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #666;
	border: 1px solid #ccc;
	border-radius: 3px;
	padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
}

select {
	border: 1px solid #ccc;
}

textarea {
	width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.main-navigation {
	display: block;
	width: 100%;
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	display: block;
	left: auto;
}

.main-navigation ul ul a {
	width: 200px;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: auto;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	text-decoration: none;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

@media screen and (min-width: 37.5em) {

	.menu-toggle {
		display: none;
	}

	.main-navigation ul {
		display: flex;
	}
}

.site-main .comment-navigation,
.site-main
.posts-navigation,
.site-main
.post-navigation {
	margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
	display: block;
}

.post,
.page {
	margin: 0 0 1.5em;
}

.updated:not(.published) {
	display: none;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
	margin: 0 0 1.5em;
}

.widget select {
	max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
	display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

/* Galleries
--------------------------------------------- */
.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
	grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
	display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {

	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {

	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}
/*--------------------------------------------------------------
# Custom Layout (やっちゃん追加分)
--------------------------------------------------------------*/

/* Header */
/* 共通レイアウト */
#site-header {
  background: #fff;
  position: fixed;
  top: 0;
  z-index: 9999;
  background-color: #fff; /* 透明の場合は変えてOK */
  box-shadow: 0 2px 4px rgba(0,0,0,0.1); /* お好みで影を付けて浮かせる */
  width: 100%;
}

/* トップメッセージ */
.header-top {
  background: #00a3d9;
  padding: 3px;
}
.header-top .catch0 {
	font-size: 10px;
    margin: 0;
	color: #FFF;
}
/* ヘッダー内レイアウト */
.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px;
  position: relative;
}
.header-inner .header-Box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header-contact {
    margin-right: 24px;
    margin-left: 24px;
}

.header-contact .catch {
  font-size: clamp(9px, 1.1vw, 14px);
  margin: 5px 0 0;
}
.header-contact .service-hours {
  font-size: clamp(9px, 1.1vw, 14px);
  font-weight: bold;
  color: #07307B;
  line-height: 1;
  margin: 0;
}

/* アクションブロック */
.header-actions {
}
.header-actions .action-campaign {
  background: #00a3d9;
  padding: 10px;
  border-radius: 5px;
  text-align: center;
  font-size: clamp(10px, 1.1vw, 14px);
  color: #FFF;
}

.header-actions .action-campaign em {
  font-size: clamp(13px, 1.2vw, 18px);
  color: #f7fa07;
  font-weight: bold;
  font-style: normal;
  
}
.header-actions .action-mail {
    margin-bottom: 8px;
}
.action-mail a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background-color: #00c300; /* LINE公式カラー */
  color: #fff;
  border-radius: 8px;
  font-weight: bold;
  text-decoration: none;
  transition: background-color 0.3s;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
padding: 8px;
    font-size: clamp(12px, 1.1vw, 16px);
}

.action-mail a:hover {
  background-color: #00a800; /* 少し濃いグリーンに */
}

.action-mail img {
  width: 40px;
  height: auto;
}
.header-actions .action-campaign {
  background: linear-gradient(135deg, #d4af37, #b8860b); /* ゴールドグラデーション */
  padding: 14px 20px;
  border-radius: 12px;
  color: #fff;
  font-weight: bold;
  font-size: clamp(13px, 1.3vw, 16px);
  text-align: center;
  position: relative;
  overflow: hidden;
  letter-spacing: 0.5px;
}

/* クーポン風の切れ込み演出 */
.header-actions .action-campaign::before,
.header-actions .action-campaign::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 28px;
  background: #fff;
  border-radius: 50%;
  z-index: 2;
}

.header-actions .action-campaign::before {
  left: -7px;
}

.header-actions .action-campaign::after {
  right: -7px;
}

.discount {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
.header-logo {
	max-width: 220px;
}
/* トップメッセージ */
.header-top {
	min-height: 60px;
}
.header-top .catch0 {
	max-width: 86%;
}
}
/* ナビゲーション（PC） */
.nav-wrap {
  background: #00a3d9;
}

.nav-list {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
}
.nav-list li {
	position: relative;
}
.nav-list li a {
  display: block;
  padding: 16px 20px;
  color: #fff;
  text-decoration: none;
  font-size: clamp(12px, 1.1vw, 16px);
}

.nav-list li a:hover {
  background: #FFF;
}
.nav-list li:before {
        content: '';
        height: 1.2em;
        border-left: solid 1px #FFF;
        position: absolute;
        left: 0;
		top: 20px;
    }
/* SP表示用 */
.is-sp {
  display: none;
}

.H-tel a {
display: flex;
    align-items: center;
    gap: 5px;
    padding: 12px;
    border-radius: 8px;
    color: #fff;
    font-size: clamp(0.7rem, 1.1vw, 16px);
    font-weight: bold;
    text-decoration: none;
    transition: background 0.3s, transform 0.2s;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    background-color: #ff6f00;
}

.H-tel a:hover {
  background: #0277bd;
}

.H-tel img {
  width: 22px;
  height: auto;
}



@media screen and (max-width: 767px) {
  .is-pc {
    display: none;
  }

  .is-sp {
    display: block;
  }

  .menu-toggle {
    padding: 10px;
    cursor: pointer;
  }

  #mobile-menu {
    display: none;
    background: #004d40;
  }

  .mobile-menu-inner {
    padding: 20px;
  }

  .mobile-nav .nav-list {
    flex-direction: column;
  }

  .mobile-nav .nav-list li {
    margin: 10px 0;
  }

  .sp-close {
    text-align: right;
    color: #fff;
    margin-top: 10px;
  }
}


/* メインビジュアル */
/* メインビジュアルエリア */
.main-visual {
  background-image: url('/wp-content/themes/au2025_vol1/img/bg-top-mv.jpg');
}

.mv-inner {
text-align: center;
    padding: 16px;
}
/* 固定メイン画像 */
#main-sub {
  background: url('/path/to/image.jpg') no-repeat center center;
  background-size: cover;
  padding: 0px 20px;
  text-align: center;
  color: #fff;
  position: relative;
  height: 30vh;
}
#main-sub .mvsub-title {
	font-size: clamp(1.4rem, 4vw, 32px);
    font-weight: bold;
    line-height: 1.3;
    background: rgba(0, 0, 0, 0.6);
    display: inline;
    padding: 1rem 2rem;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    min-width: 340px;
	margin: auto;
}
/* 固定サービスメイン画像 */
#main-sub2 {
  background: url('/path/to/image.jpg') no-repeat center center;
  background-size: cover;
  padding: 0 20px;
  text-align: center;
  color: #fff;
  position: relative;
  height: 50vh;
}
#main-sub2 .mvsub-title {
	font-size: clamp(1.4rem, 4vw, 32px);
    font-weight: bold;
    line-height: 1.3;
    background: rgba(0, 0, 0, 0.6);
    display: inline;
    padding: 1rem 2rem;
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    min-width: 340px;
	margin: auto;
}

/* フッター全体 */

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 30px;
  text-align: left;
}

/* ロゴエリア */
.footer-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.footer-site-name {
  font-size: 20px;
  font-weight: bold;
}

.footer-tagline {
  font-size: 14px;
  margin-bottom: 20px;
}

.footer-cta-buttons {
  display: flex;
  gap: 15px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 30px auto;
  max-width: 700px;
}

.footer-btn a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 15px 25px;
  border-radius: 8px;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  transition: background 0.3s, transform 0.2s;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.footer-btn a:hover {
  transform: scale(1.03);
}

/* 電話ボタン */
.Fact-mail a {
  background-color: #ff6f00; /* 安心感＋緊急性あるオレンジ */
}

/* LINEボタン */
.Fact-line a {
  background-color: #00c300; /* 指定通りのLINEグリーン */
}

.footer-btn img {
  width: 24px;
  height: 24px;
}


.footer-copy {
  font-size: 12px;
  color: #FFFFFF;
  margin: 16px 0 0;
}

/* サイトマップ */
.footer-sitemap .footer-heading,
.footer-info .footer-heading {
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: bold;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  line-height: 1.8;
}

.footer-links li a {
  color: #ffffff;
  text-decoration: none;
}

.footer-links li a:hover {
  text-decoration: underline;
}

/* 会社情報 */
.footer-info p {
  font-size: 14px;
  margin-bottom: 10px;
}

.footer-sns {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}

.footer-sns img {
  width: 24px;
  height: 24px;
}

/* レスポンシブ */
@media (max-width: 768px) {
.main-visual {
	padding: 105px 0px 0px 0px;
}
  .footer-inner {
    flex-direction: column;
  }
  .footer-logo-area, .footer-sitemap, .footer-info {
    min-width: 100%;
  }
  .footer-logo-area {
    order: 3;
  }
  .footer-sitemap {
    order: 1;
  }
  .footer-info {
    order: 2;
  }
}
/* ===== アーカイブ ===== */

/* 投稿アーカイブ全体 */
#archive .post-archive {
  padding: 60px 0;
  background: #f9f9f9;
}

#archive .Contents {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

/* グリッドレイアウト */
#archive .post-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  margin-top: 30px;
}

/* カードスタイル */
#archive .post-card {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.06);
  transition: transform 0.2s, box-shadow 0.2s;
}

#archive .post-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

#archive .post-card a {
  text-decoration: none;
  color: inherit;
  display: block;
  height: 100%;
}

/* サムネイル */
#archive .post-thumb img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

/* コンテンツ */
#archive .post-content {
  padding: 20px;
}

#archive .post-title {
  font-size: 1.1rem;
  font-weight: bold;
  margin: 0 0 10px;
  color: #333;
}

#archive .post-excerpt {
  font-size: 0.95rem;
  color: #666;
  line-height: 1.6;
  margin-bottom: 10px;
}

/* 詳細ボタン */
#archive .btn-detail {
  display: inline-block;
  font-size: 0.9rem;
  font-weight: bold;
  color: #0073aa;
  margin-top: 5px;
}

/* ページネーション */
#archive .pagination-wrap {
  padding: 24px 0;
  text-align: center;
  background: #f9f9f9;
}

#archive .pagination {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  padding: 0;
  list-style: none;
}

#archive .page-numbers {
  display: inline-block;
  padding: 10px 18px;
  font-size: 1rem;
  color: #0073aa;
  background: #f8f8f8;
  border: 1px solid #ccc;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.25s, color 0.25s, box-shadow 0.25s;
}

#archive .page-numbers:hover {
  background: #0073aa;
  color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

#archive .current {
  background: #0073aa;
  color: #fff;
  font-weight: bold;
  pointer-events: none;
  box-shadow: none;
}

/***** 記事詳細 *****/
/* シングルページ全体 */
#single {
  padding: 60px 20px;
  background-color: #f9f9f9;
}

#single .Contents {
  max-width: 960px;
  margin: 0 auto;
  padding:24px;
  background: #ffffff;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
  overflow: hidden;
}
#single .post-meta-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}
#single  p.post-category {
	margin-bottom:0;
}
#single .post-category a {
  display: inline-block;
  padding: 6px 14px;
  background-color: #e3f2fd;
  color: #0073aa;
  font-size: 0.9rem;
  font-weight: bold;
  text-decoration: none;
  border-radius: 20px;
  border: 1px solid #90caf9;
  transition: background 0.3s, color 0.3s;
}

#single .post-category a:hover {
  background-color: #0073aa;
  color: #fff;
}

#single .post-date {
  font-size: 0.9rem;
  color: #999;
}

/* タイトル */
#single .post-title {
  font-size: 1.8rem;
  font-weight: bold;
  margin: 30px 0 20px;
  color: #333;
  border-bottom: 2px solid #0073aa;
  padding-bottom: 10px;
}

/* サムネイル画像 */
#single .post-thumb img {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 4px;
}

/* 本文 */
#single .post-content {
  font-size: 1rem;
  color: #444;
  line-height: 1.8;
  padding: 30px 0;
}

#single .post-content h2,
#single .post-content h3,
#single .post-content h4 {
  margin-top: 2.5em;
  color: #0073aa;
}

#single .post-content p {
  margin-bottom: 1.5em;
}

#single .post-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin: 60px 0 40px;
  padding: 20px;
  background: #f1f1f1;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

#single .post-pagination .prev a,
#single .post-pagination .next a {
  display: inline-block;
  padding: 12px 20px;
  background-color: #0073aa;
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  font-size: 0.95rem;
  border-radius: 6px;
  transition: background 0.3s, box-shadow 0.3s;
}

#single .post-pagination .prev a:hover,
#single .post-pagination .next a:hover {
  background-color: #005a8c;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}
#single .back-to-list {
  margin: 60px 0 40px;
  text-align: center;
}

#single .btn-back {
  display: inline-block;
  padding: 12px 24px;
  font-size: 0.95rem;
  font-weight: bold;
  color: #0073aa;
  background-color: #eef6fa;
  border: 2px solid #0073aa;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.3s, color 0.3s, box-shadow 0.3s;
}

#single .btn-back:hover {
  background-color: #0073aa;
  color: #fff;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}



/***** TOPセクション *****/
/* ===== ファーストビュー共通枠 ===== */
.fv {
  background: linear-gradient(to right, #e0f7fa, #f0f8ff);
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 0;
}

.fv .Contents {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

/* 小ラベル（信頼性訴求：水道局指定など） */
.fv-label {
  font-size: clamp(14px, 2vw, 18px);
  color: #00796b;
  font-weight: bold;
  margin-bottom: 20px;
}

/* メイン見出し（h1） */
.fv-heading {
  font-size: clamp(24px, 5vw, 36px);
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 30px;
  color: #333;
}

.fv-heading .highlight {
  color: #d32f2f;
  font-weight: bold;
}

/* ポイントリスト */
.fv-points {
  list-style: none;
  padding: 0;
  margin: 0 auto 30px;
}
.fv-points li {
  margin-bottom: 10px;
  font-size: clamp(16px, 2vw, 20px);
  color: #333;
}

/* 強調表示（無料など） */
.highlight-free {
  display: inline-block;
  background-color: #ffeb3b;
  color: #000;
  font-weight: bold;
  padding: 0.2em 0.5em;
  border-radius: 4px;
  font-size: clamp(16px, 2vw, 20px);
  box-shadow: 0 0 0 3px rgba(255, 235, 59, 0.4);
}

/* CTAテキスト（例：今すぐご相談ください） */
.fv-call {
  font-size: clamp(17px, 2.5vw, 20px);
  font-weight: bold;
  color: #d32f2f;
  margin-bottom: 20px;
}

/* ボタン群 */
.fv-buttons {
  display: flex;
  justify-content: center;
  gap: 15px;
  flex-wrap: wrap;
}

.btn {
  display: inline-block;
  padding: 14px 24px;
  border-radius: 6px;
  text-decoration: none;
  font-weight: bold;
  font-size: clamp(15px, 2vw, 18px);
  color: #fff;
  transition: background 0.3s ease;
  min-width: 200px;
}

.tel-btn {
  background-color: #f44336;
}

.tel-btn:hover {
  background-color: #d32f2f;
}

.line-btn {
  background-color: #00c300;
}

.line-btn:hover {
  background-color: #009e00;
}

.webform-btn {
  background-color: #0288d1;
}

.webform-btn:hover {
  background-color: #0277bd;
}
@media (max-width: 767px) {
.btn {
    width: 100%;
}
}
/* TOPセクション2 */
/* --- h2共通スタイル --- */
.section-title {
  text-align: center;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  margin-bottom: 50px;
  color: #111;
  letter-spacing: 0.05em;
}

/* --- 症状セクション --- */
.symptom {
  background-color: #fdf4ec;

  text-align: center;
}
.symptom .section-title {
  color: #b45309; /* このセクションだけ色変更 */
}

.symptom-lead {
  font-size: clamp(16px, 2.2vw, 20px);
  color: #555;
  margin-bottom: 30px;
}

.symptom-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 30px;
  list-style: none;
  padding: 0;
  margin-bottom: 40px;
  margin-inline: auto;
}

.symptom-list li {
  font-size: clamp(15px, 2vw, 18px);
  background: #FFF;
  padding: 12px 16px;
  border-radius: 6px;
  color: #222;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  text-align: left;
  display: flex;
  gap: 10px;
  align-items: center;
}

.symptom-list li span {
  font-size: 20px;
}

.symptom-note {
  font-size: clamp(15px, 2vw, 17px);
  color: #444;
}

.symptom-link {
  display: inline-block;
  margin-top: 15px;
  font-weight: bold;
  color: #fff;
  background: #ff9800;
  padding: 12px 24px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.3s ease;
}

.symptom-link:hover {
  background: #fb8c00;
}
/* 到着セクション全体 */
.arrival-grid {
  background-color: #f0f9f4;

}

/* Contents共通 */
.arrival-grid .Contents {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

/* レイアウト */
.arrival-wrapper {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 40px;
}

/* 画像部分 */
.arrival-img {
  flex: 1 1 45%;
}

.arrival-img img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  object-fit: cover;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* テキスト部分 */
.arrival-content {
  flex: 1 1 50%;
}

.arrival-grid .section-title {
  text-align: left;
  color: #2e7d32;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 800;
  margin-bottom: 20px;
}

.arrival-text {
  font-size: clamp(1rem, 2vw, 1.2rem);
  line-height: 1.8;
  color: #333;
}

.arrival-text .strong {
  font-weight: bold;
  color: #388e3c;
}

/* 注意・説明ボックス */
.arrival-note-box {
  background: #fff8e1;
  border-left: 6px solid #ffb300;
  padding: 20px;
  border-radius: 8px;
  margin-top: 30px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  line-height: 1.7;
  color: #444;
}

.note-main {
  font-weight: bold;
  color: #d84315;
  margin-bottom: 10px;
}

.note-main .underlined {
  text-decoration: underline;
  color: #c62828;
}

.note-sub {
  font-size: 0.98em;
}

.note-sub .strong {
  font-weight: bold;
  color: #c45c00;
}

.note-sub .highlight-free {
  background-color: #ffcc80;
  color: #222;
  padding: 0.3em 0.6em;
  border-radius: 4px;
  font-weight: bold;
  display: inline-block;
  margin-top: 5px;
}
.tel-diagnosis {
  background: 
    linear-gradient(rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.92)),
    url('/wp-content/themes/au2025_vol1/img/bg-diagnosis.jpg') center/cover no-repeat fixed;

}

.tel-diagnosis .Contents {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

.tel-diagnosis .section-title {
  text-align: center;
  color: #2c387e;
}

.tel-card {
  max-width: 900px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.tel-card-top {
  width: 100%;
  background: linear-gradient(135deg, #e3f2fd, #f5f5f5);
  text-align: center;
  padding: 40px 20px;
}

.tel-card-bottom {
  padding: 40px 0 0;
  text-align: center;
  font-size: clamp(1rem, 2vw, 1.15rem);
  line-height: 1.9;
  color: #333;
}

.tel-card-bottom .lead {
  font-size: clamp(1.1rem, 2.3vw, 1.3rem);
  font-weight: 500;
  margin-bottom: 1.5em;
}

.tel-card-bottom .strong {
  font-weight: bold;
  color: #1565c0;
}

.highlight {
  background: #d0f0ff;
  padding: 0.3em 0.6em;
  border-radius: 4px;
  font-weight: bold;
}

.warn {
  background: #ffebee;
  color: #c62828;
  padding: 0.3em 0.6em;
  border-radius: 4px;
  font-weight: bold;
}

.tel-card-bottom .highlight-free {
  background: #fff176;
  color: #000;
  font-weight: bold;
  padding: 0.3em 0.6em;
  border-radius: 4px;
  display: inline-block;
  margin-top: 10px;
}

.feature-cards {
  background: #f5fafd;
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  margin-top: 40px;
}

.card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
  padding: 30px 20px;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 25px rgba(0, 0, 0, 0.1);
}

.card-icon {
  font-size: 2.2rem;
  margin-bottom: 10px;
  color: #1e88e5;
}

.card-title {
  font-size: clamp(1.2rem, 2.5vw, 1.4rem);
  font-weight: 700;
  margin-bottom: 10px;
  color: #222;
}
.card-text {
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  color: #555;
  line-height: 1.6;
}
/* レスポンシブ */
@media (max-width: 480px) {
.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 16px;
}
}

/***** サービスリスト *****/
.service-links {
background: linear-gradient(rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.92)), url(/wp-content/themes/au2025_vol1/img/bg-service.jpg) center / cover no-repeat fixed;
}

.service-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  padding: 2em 1em;
}

.service-card {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  padding: 1.5em;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  border: 1px solid #e0e0e0;
}

.service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
}

.service-card img {
  width: 100%;
  height: auto;
  max-height: 180px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 1em;
}

.service-card h3 {
  font-size: 1.2em;
  color: #0073aa;
  margin-bottom: 0.6em;
}

.service-card p {
  font-size: 0.95em;
  color: #444;
  margin-bottom: 1em;
  min-height: 4em; /* 高さ揃え */
}

.service-card a {
  display: inline-block;
  margin-top: auto;
  background: #0073aa;
  color: #fff;
  padding: 0.6em 1.4em;
  border-radius: 5px;
  text-decoration: none;
  font-weight: bold;
  transition: background 0.3s ease;
}

.service-card a:hover {
  background: #005f8d;
}

@media (max-width: 480px) {
  .service-card {
    padding: 1em;
  }

  .service-card h3 {
    font-size: 1.1em;
  }

  .service-card p {
    font-size: 0.9em;
  }
}
/***** 固定QAページ *****/
.faq-nav {
  margin-bottom: 30px;
  text-align: center;
}

.faq-nav-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* PC：4列 */
  gap: 10px;
  padding: 0;
  list-style: none;
  max-width: 800px;
  margin: 0 auto;
}

.faq-nav-list li a {
  display: block;
  background-color: #00a3d9;
  color: #fff;
  padding: 12px 8px;
  border-radius: 6px;
  font-weight: bold;
  text-decoration: none;
  transition: background-color 0.3s;
}

.faq-nav-list li a:hover {
  background-color: #007ba5;
}
/* 初期状態：PCは全部表示 */
.faq-answer {
  display: block;
  padding: 10px 0;
}
.faq-list {
  margin: 0 auto 40px;
  padding: 0 20px;
}

.faq-question {
  background-color: #00a3d9;
  color: #fff;
  padding: 1.5em 4em 1.5em 3em;
  border-radius: 10px;
  font-weight: bold;
  position: relative;
  margin-bottom: 8px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.08);
  font-size: clamp(0.9rem, 2vw, 20px);
}

.faq-question::before {
	content: "Q";
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 20px;
    font-weight: bold;
    background: #fff;
    color: #00a3d9;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    display: flex
;
    align-items: center;
    justify-content: center;
}

.faq-answer {
  background-color: #f1f8e9; /* 薄い緑ベース（安心感） */
  border-left: 4px solid #7cb342;
  padding: 16px 20px;
  border-radius: 6px;
  position: relative;
  margin-bottom: 40px;
  margin: 0;
}

.faq-answer::before {
  content: "A";
  font-weight: bold;
  color: #7cb342;
  margin-right: 8px;
      font-size: 30px;
}



/* スマホ対応：2列×4行 */
@media screen and (max-width: 767px) {
  .faq-nav-list {
    grid-template-columns: repeat(2, 1fr);
  }
  .faq-answer {
    display: none;
  }
  .faq-list {
  margin: 0 auto 16px;
  padding: 0 20px;
}
  .faq-question {
    cursor: pointer;
    position: relative;
    padding-right: 30px;
  }
  .faq-question::after {
    content: "＋";
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-weight: bold;
    font-size: 16px;
  }
  .faq-question.open::after {
    content: "－";
  }
}


/***** 会社案内ページ *****/
.company-greeting {
  background-color: #f9f9f9;
  padding: 60px 20px;
}

.greeting-inner {
  font-size: 1em;
  line-height: 1.9;
  color: #444;
}

.greeting-inner p {
  margin-bottom: 1.6em;
}

.greeting-inner strong {
  font-weight: 600;
  color: #222;
}

.greeting-inner span {
  font-weight: bold;
  padding: 0 4px;
}

.greeting-inner p:last-child {
  margin-top: 3em;
  font-size: 0.95em;
  color: #666;
}
.company-overview {
  background-color: #ffffff;
  padding: 60px 20px;
}

.overview-lead p {
  font-size: 1em;
  line-height: 1.8;
  color: #444;
  margin-bottom: 2em;
}

.overview-table {
  width: 100%;
  border-collapse: collapse;
  background: #fdfdfd;
  font-size: 0.95em;
}

.overview-table th,
.overview-table td {
  border: 1px solid #ccc;
  padding: 1em;
  vertical-align: top;
}

.overview-table th {
  background-color: #f0f0f0;
  font-weight: bold;
  width: 25%;
  color: #333;
}

.overview-table td {
  color: #555;
}
.company-reason {
  background-color: #f4f8fb;
  padding: 60px 20px;
}

.reason-box {
  margin-bottom: 2.5em;
  padding: 1.6em;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 0 8px rgba(0,0,0,0.06);
}

.reason-box h3 {
  font-size: 1.2em;
  font-weight: bold;
  color: #0073aa;
  margin-bottom: 0.6em;
}

.reason-box p {
  font-size: 1em;
  line-height: 1.8;
  color: #444;
}

.company-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95em;
  background-color: #fdfdfd;
}

.company-table th,
.company-table td {
  border: 1px solid #ddd;
  padding: 1em;
  vertical-align: top;
}

.company-table th {
  background-color: #f0f0f0;
  font-weight: bold;
  width: 25%;
  color: #333;
}

.company-table td {
  color: #444;
}

/****** お客様の声 *****/
.voice-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  margin-top: 40px;
}

.voice-item {
  background: #fff;
  border-radius: 12px;
  padding: 25px 20px;
  box-shadow: 0 8px 16px rgba(0,0,0,0.05);
  transition: transform 0.3s ease;
}

.voice-item:hover {
  transform: translateY(-5px);
}

.voice-title {
  font-size: clamp(1.1rem, 2vw, 1.3rem);
  font-weight: bold;
  color: #1a237e;
  margin-bottom: 10px;
}

.voice-excerpt {
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  line-height: 1.6;
  color: #444;
  margin-bottom: 15px;
}

.voice-link {
  font-weight: bold;
  color: #0288d1;
  text-decoration: none;
}

.voice-link:hover {
  text-decoration: underline;
}

.voice-more {
  text-align: center;
  margin-top: 40px;
}

.voice-more .btn-more {
  background: #0288d1;
  color: #fff;
  font-weight: bold;
  padding: 12px 28px;
  border-radius: 30px;
  text-decoration: none;
  font-size: 1rem;
  transition: background 0.3s ease;
}

.voice-more .btn-more:hover {
  background: #0277bd;
}

.accordion-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: linear-gradient(90deg, #e3f2fd, #ffffff);
  color: #0d47a1;
  font-weight: bold;
  font-size: clamp(1rem, 2vw, 1.15rem);
  border: none;
  padding: 16px 20px;
  width: 100%;
  cursor: pointer;
  transition: background 0.3s ease;
  border-bottom: 1px solid #ddd;
}

.accordion-title:hover {
  background: #e0f7fa;
}

.accordion-icon {
  font-size: 1.5rem;
  transition: transform 0.3s ease;
}

.accordion-title[aria-expanded="true"] .accordion-icon {
  transform: rotate(45deg); /* ＝ を × に見せる */
}

.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  background: #fafafa;
  padding: 0 20px;
}

.accordion-content ul {
  padding: 20px 0;
  list-style: disc;
  padding-left: 1.2em;
}

.accordion-content li {
  margin-bottom: 0.8em;
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  color: #333;
}
/* ==============================
   料金セクション全体
============================== */
.price-accordion {
  background: #f9fbfd;
  padding: 60px 20px;
}

.price-accordion .Contents {
  max-width: 1000px;
  margin: 0 auto;
}

/* ==============================
   H2のタイトル（共通スタイルでOK）
============================== */
.price-accordion .section-title {
  text-align: center;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  margin-bottom: 40px;
  color: #111;
  letter-spacing: 0.05em;
}

/* ==============================
   ▶ 料金の詳細を見る ボタン
============================== */
.price-link {
  text-align: center;
  margin-bottom: 30px;
}
.btn-wrap {
    text-align: center;
    margin-top: 40px;
}
.btn-detail {
  display: inline-block;
  padding: 12px 28px;
  font-size: clamp(1rem, 2.5vw, 1.15rem);
  font-weight: 700;
  color: #fff;
  background-color: #0288d1;
  border: none;
  border-radius: 50px;
  text-decoration: none;
  transition: background 0.3s ease, transform 0.2s ease;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.btn-detail:hover {
  background-color: #0277bd;
  transform: translateY(-2px);
}

/* ==============================
   注記テキスト
============================== */
.price-note {
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  text-align: center;
  color: #444;
  margin-bottom: 40px;
}

/* ==============================
   アコーディオン本体
============================== */
.accordion-item {
  margin-bottom: 10px;
}

.accordion-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #FFF;
  color: #0d47a1;
  font-weight: 700;
  font-size: clamp(1rem, 2vw, 1.15rem);
  border: 1px solid #cfd8dc;
  padding: 16px 20px;
  width: 100%;
  cursor: pointer;
  border-radius: 8px;
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.accordion-title:hover {
  background: #e3f2fd;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.accordion-icon {
  font-size: 1.5rem;
  transition: transform 0.3s ease;
}

.accordion-title[aria-expanded="true"] .accordion-icon {
  transform: rotate(45deg); /* + → × に見せる */
}

/* アコーディオン内容 */
.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  background: #fff;
  padding: 0 20px;
}

.accordion-content ul {
  padding: 20px 0;
  list-style: disc;
  padding-left: 1.5em;
  margin: 0;
}

.accordion-content li {
  margin-bottom: 0.8em;
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  color: #333;
  line-height: 1.6;
}


/***** サービス一覧ページ *****/
.lead-text {
  text-align: center;
  color: #555;
  line-height: 1.6;
  margin-bottom: 2em;
}

/* 流れ */
#flow {
  background: #FFF;
}

.flow-list {
  display: flex;
  flex-direction: column;
  gap: 30px;
  max-width: 100%;
  margin: 0 auto;
}

.flow-box {
  display: flex;
  align-items: center;
  background: #f5fafd;
  padding: 20px 25px;
  border-radius: 16px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.05);
}

.flow-box img {
    width: 200px;
    height: auto;
    margin-right: 20px;
    border-radius: 8px;
}

.flow-text {
  flex: 1;
}

.flow-num {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: bold;
  color: #0076ff;
  display: block;
  margin-bottom: 6px;
}

.flow-box h3 {
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 700;
  margin-bottom: 5px;
  color: #111;
}

.flow-box p {
  font-size: 14px;
  color: #444;
}

@media (max-width: 600px) {
  .flow-box {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }

  .flow-box img {
  width: 100%;
    margin: 0 0 12px 0;
  }
}


/* FQ */
#faq {
  padding: 80px 20px;
  background: linear-gradient(to right, #e0f7fa, #f0f8ff);
}

.faq-box {
  background: #f9f9f9;
  padding: 24px;
  margin-bottom: 20px;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.03);
}

.faq-q span {
  font-weight: bold;
  color: #000;
  margin-right: 8px;
  font-size: 20px;
}

.faq-a span {
  font-weight: bold;
  color: #0076ff;
  margin-right: 8px;
  font-size: 18px;
}

.faq-q {
  font-size: clamp(16px, 2.2vw, 20px);
  font-weight: 700;
  margin-bottom: 10px;
  color: #111;
}

.faq-a {
  font-size: 15px;
  color: #333;
  line-height: 1.7;
}


/* ACT */
#cta {
  position: relative;
  background: url('/wp-content/themes/au2025_vol1/img/bg-act.jpg') no-repeat center center / cover;
  padding: 120px 20px;
  text-align: center;
  overflow: hidden;
}

#cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4); /* 黒の半透明オーバーレイ */
  z-index: 1;
}

#cta .Contents {
  position: relative;
  z-index: 2;
  color: #fff;
}

.cta-title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  margin-bottom: 30px;
  color: #fff;
}



/* レンタル場所 */
.location-merit p,
.location-spots ul {
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.location-info-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
}
.location-info-table th, .location-info-table td {
  border: 1px solid #ddd;
  padding: 0.8rem;
}
.location-cta {
  margin-top: 2rem;
  text-align: center;
}
.btn-reserve {
  background: #1e88e5;
  color: #fff;
  padding: 1rem 2rem;
  border-radius: 6px;
  text-decoration: none;
  font-weight: bold;
}
.btn-reserve:hover {
  background: #1565c0;
}
.location-merit {
  background: linear-gradient(135deg, #fff9f3, #ffffff);
  border: 1px solid #ffe0b2;
  border-radius: 16px;
  padding: 2.5rem 2rem;
  margin: 2.5rem 0;
  box-shadow: 0 10px 24px rgba(255, 152, 0, 0.1);
  position: relative;
  overflow: hidden;
}

/* POINTラベル */
.location-merit::before {
  content: "POINT";
  position: absolute;
  top: 0px;
  left: 0px;
  background: #fb8c00;
  color: #fff;
  font-size: 0.75rem;
  font-weight: bold;
  padding: 0.4rem 0.8rem;
  border-bottom-right-radius: 12px;
  z-index: 2;
}

/* h3見出しスタイリッシュ */
.location-merit h3 {
  background: linear-gradient(to right, #fb8c00, #f4511e);
  color: #fff;
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  font-weight: bold;
  padding: 0.6rem 1rem;
  border-radius: 8px;
  text-align: center;
  margin-bottom: 1.2rem;
  letter-spacing: 0.05em;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.location-merit p {
  font-size: clamp(1rem, 1.8vw, 1.125rem);
  line-height: 1.8;
}
.location-merit-list {
  list-style: none;
  font-size: clamp(1rem, 1.7vw, 1.125rem);
  margin: 0;
}

.location-merit-list li {
  position: relative;
  padding-left: 1.2em;
  margin-bottom: 0.8rem;
  font-size: 1.05rem;
  line-height: 1.8;
  color: #333;
}

.location-merit-list li::before {
  content: "✔";
  position: absolute;
  left: 0;
  color: #fb8c00;
  font-weight: bold;
}

.spot-list-banner {
  list-style: none;
  padding: 0;
  margin: 2rem 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.spot-list-banner li a {
  display: block;
  background: linear-gradient(135deg, #e3f2fd, #ffffff);
  border: 2px solid #1e88e5;
  border-radius: 12px;
  padding: 1rem;
  color: #1e88e5;
  font-weight: bold;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  transition: all 0.25s ease;
  line-height: 1.6;
}

.spot-list-banner li a:hover {
  background: #1e88e5;
  color: #fff;
  box-shadow: 0 8px 20px rgba(30, 136, 229, 0.3);
  transform: translateY(-2px);
}

.spot-list-banner li a strong {
  display: block;
  font-size: clamp(1.05rem, 1.8vw, 1.2rem);
  margin-bottom: 0.2rem;
  color: inherit;
  font-weight: 700;
}
.location-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-top: 2.5rem;
}

.btn-cta {
  display: inline-block;
  padding: 1rem 2rem;
  font-size: clamp(1rem, 1.8vw, 1.1rem);
  font-weight: bold;
  text-align: center;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.3s ease;
}

/* 今すぐ予約：目立たせる */
.btn-cta.primary {
  background-color: #e53935;
  color: #fff;
  border: none;
}

.btn-cta.primary:hover {
  background-color: #c62828;
}

/* 料金を確認：セカンダリボタン */
.btn-cta.secondary {
  background-color: #fff;
  color: #1e88e5;
  border: 2px solid #1e88e5;
}

.btn-cta.secondary:hover {
  background-color: #1e88e5;
  color: #fff;
}


/* モバイル対応 */
@media screen and (max-width: 768px) {
  .spot-list-banner {
    grid-template-columns: 1fr;
  }
}

/* ==============================
   サービスLPページ
============================== */

.cause-card {
  display: flex;
  align-items: flex-start;
  background: #ffffff;
  border: 1px solid #ddd;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  padding: 20px;
  margin-bottom: 24px;
  gap: 20px;
  flex-wrap: wrap;
}

.cause-card .card-image {
  flex: 0 0 150px;
}

.cause-card .card-image img {
  width: 100%;
  max-width: 150px;
  height: auto;
  border-radius: 8px;
}

.cause-card .card-content {
  flex: 1;
}

.cause-card .cause-title {
  font-weight: bold;
  margin-bottom: 10px;
  color: #00796b;
  font-size: clamp(1.3rem, 3vw, 2.0rem);
}

.cause-card p {
    margin-bottom: 16px;
    font-size: clamp(1.1rem, 2vw, 1.4rem);
}

@media screen and (max-width: 600px) {
  .cause-card {
    flex-direction: column;
    align-items: stretch;
  }
  .cause-card .card-image {
    margin-bottom: 10px;
    max-width: 100%;
  }
}

.section-call-first {
  background: #f2f9fc;
}

.section-call-first .section-title {
  color: #0077b6;
}

.section-call-first p {
	font-size:clamp(16px, 2.2vw, 20px);
  margin-bottom: 1.5em;
  text-align: center;
  line-height: 2.0;
}

.highlight {
  font-weight: bold;
  background-color: #ffeb3b;
  padding: 0 0.2em;
}

.emphasis {
  color: #d32f2f;
  font-weight: bold;
}

.call-example-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  margin-bottom: 1.8em;
}

.call-card {
  background: #ffffff;
  border: 1px solid #ddd;
  border-left: 5px solid #2196f3;
  padding: 1em;
  border-radius: 8px;
  flex: 1 1 300px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.call-icon {
  font-size: 1.6em;
}

.call-text {
  font-size: clamp(16px, 2.2vw, 20px);
  line-height: 1.6;
}
.call-text strong {
    font-size: clamp(18px, 2.2vw, 20px);
}
.strong-blue {
  font-weight: bold;
  color: #1976d2;
}

.section-price {
  background: #fffef9;
}

.section-price .section-title {
  color: #ff9800;
}

.price-table {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5em;
}

.price-row {
  background: #fff8e1;
  border-left: 6px solid #ffb300;
  padding: 1.2em 1.5em;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  height: 100%;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

.price-title {
  font-size: clamp(1.6rem, 2.2vw, 20px);
  font-weight: bold;
  color: #333;
  margin-bottom: 0.3em;
}

.price-amount {
  font-size: clamp(2.0rem, 4vw, 2.8rem);
  font-weight: bold;
  color: #d32f2f;
  margin-bottom: 0.3em;
}

.price-desc {
  font-size: 0.95em;
  color: #555;
  line-height: 1.6;
}

.price-note {
margin-top: 2em;
  font-size: 0.9em;
  text-align: center;
  background: #fff3cd;
  border: 1px dashed #ffecb5;
  padding: 1em;
  border-radius: 6px;
}
@media screen and (min-width: 768px) {
  .price-table {
    grid-template-columns: 1fr 1fr;
  }
}


.section-cases {
  background: #f0f9f4;
}
.section-cases .section-title {
  color: #2e7d32;
}
.case-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5em;
}

@media screen and (min-width: 768px) {
  .case-card-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.case-card {
  background: #FFF;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 150, 136, 0.1);
  padding: 1.5em;
  position: relative;
  transition: transform 0.2s ease;
}

.case-card:hover {
  transform: translateY(-3px);
}

.case-header {
  font-size: 1.1em;
  font-weight: bold;
  color: #00796b;
  display: flex;
  align-items: center;
  margin-bottom: 0.8em;
}

.case-icon {
  margin-right: 0.5em;
  font-size: 1.2em;
}

.case-content {
  font-size: 0.95em;
  color: #444;
  line-height: 1.6;
  margin-bottom: 16px;
}

.case-time {
  font-size: 0.85em;
  background: #00796b;
  color: #fff;
  padding: 0.4em 0.8em;
  border-radius: 20px;
  display: inline-block;
  position: absolute;
  bottom: 8px;
  right: 8px;
}


.judgement-columns {
  display: flex;
  flex-direction: column;
  gap: 2em;
}

@media screen and (min-width: 768px) {
  .judgement-columns {
    flex-direction: row;
  }
}

.judgement-box {
  background: #f0f9ff;
  border-radius: 12px;
  padding: 1.5em;
  flex: 1;
}

.judgement-title {
  font-weight: bold;
  color: #00796b;
  margin-bottom: 1em;
}

.judgement-list {
  list-style: none;
  padding-left: 1em;
  margin: 0 0 16px 0;
}

.judgement-list li::before {
  content: "✔️";
  margin-right: 0.5em;
  color: #388e3c;
}

.judgement-list li {
  margin-bottom: 0.5em;
}

.judgement-note {
	background: #fff8e1;
    padding: 0.8em 1em;
    border-left: 4px solid #ffb300;
    border-radius: 6px;
}
.cta-tel-button {
  text-align: center;
  margin-top: 2em;
}

.tel-button {
  display: inline-block;
  background: #0288d1;
  color: #fff;
  font-size: 1.1em;
  font-weight: bold;
  padding: 1em 2em;
  border-radius: 50px;
  text-decoration: none;
  box-shadow: 0 4px 10px rgba(0, 131, 143, 0.2);
  transition: background 0.3s ease;
}

.tel-button:hover {
  background: #0277bd;
}
.call-cta {
  text-align: center;
  margin: 3em 0 0;
}

.Ac-tel-button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 0.8em;
  width: 100%;
  max-width: 540px;
  margin: 0 auto;
  background: linear-gradient(135deg, #ff6f00, #ff9100);
  color: #fff;
  font-size: clamp(1.3rem, 4vw, 2rem);
  font-weight: 700;
  padding: 1.2em 1.5em;
  border-radius: 100px;
  text-decoration: none;
  box-shadow:
    0 4px 8px rgba(0, 0, 0, 0.15),
    0 0 25px rgba(255, 111, 0, 0.4);
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.4s ease;
  animation: pulseRing 2.5s infinite ease-in-out;
}

.Ac-tel-button:hover {
  transform: scale(1.05);
  box-shadow:
    0 6px 12px rgba(0, 0, 0, 0.2),
    0 0 40px rgba(255, 111, 0, 0.6);
}

.Ac-tel-button .icon-tel {
  width: clamp(1.6rem, 4vw, 2.2rem);
  height: auto;
  display: inline-block;
  vertical-align: middle;
  filter: drop-shadow(1px 1px 1px rgba(0,0,0,0.3));
}

/* pulsating ring effect */
@keyframes pulseRing {
  0% {
    box-shadow: 0 0 0 0 rgba(255, 111, 0, 0.4);
  }
  70% {
    box-shadow: 0 0 0 12px rgba(255, 111, 0, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(255, 111, 0, 0);
  }
}
