@charset "UTF-8";

/*
** Theme Name:  のぞみデンタルクリニック
** Description: のぞみデンタルクリニック
** Author: Satoshi Saito
** Version: 1.0.0
** ================================================== */
.icon {
  max-width: 100%;
  /* 親要素の幅を超えない */
  height: auto;
  /* 比率を維持して高さを自動調整 */
  display: block;
  /* imgと同じ挙動にする */
  stroke: var(--color_orangeDark);
  /* 線の色 */
  stroke-width: 6;
  /* 線の太さ */
  fill: none;
  /* 塗りつぶしなし */
  stroke-linecap: round;
  /* 端を丸くする */
}

:root {
  /* === Color === */
  --color_orangeMain: #f0aa00;
  --color_orangeDark: #e18f00;
  --color_orangeLight: #ffd466;
  --color_brownMain: #7a6831;
  --color_brownLight: #bcae86;
  --color_white: #fffdf9;
  --color_offwhite: #fff7e9;
  --color_red: #c13;

  /* === Size === */
  --size-ss: 0.25rem;
  --size-s: 0.75rem;
  --size-m: 1.0rem;
  --size-l: 1.5rem;
  --size-ll: 2.0rem;

  /* === BoxShadow === */
  --shadow-light: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-card: 0 2px 6px rgba(0,0,0,0.10);
  --shadow-strong: 0 4px 12px rgba(0,0,0,0.12);
}


/* Base Styles
======================================== */
html {
  scroll-behavior: smooth;
  font-size: 16px;
  line-height: 1.7;
}

body {
  background-color: var(--color_orangeMain);
  font-family: YakuHanJP_Noto, "BIZ UDPGothic", sans-serif;
  font-size: var(--size-m);
  text-align: justify;
  word-break: break-all;
  overflow-wrap: break-word;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.2);
}

#bodyInner {
  background-color: var(--color_white);
  color: var(--color_brownMain);
}

summary {
  cursor: pointer;
}

a {
  text-decoration: none;
  transition: 0.4s;
  color: var(--color_orangeMain);
}

a:hover {
  color: var(--color_orangeLight);
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}


/* Layout
======================================== */
.contentsWrap {
  padding: var(--size-ll) 0;
}

.innerWrap {
  max-width: 1000px;
  margin: 0 auto;
  padding: var(--size-m) var(--size-m);
}


/* Header
======================================== */
header .desc p {
  background-color: var(--color_orangeMain);
  text-align: center;
  color: var(--color_white);
  padding-top: var(--size-ss);
}

header .innerWrap {
  height: 40vh;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  place-items: center;
  font-weight: 700;
  text-shadow:
    1px 1px 1px var(--color_white),
    -1px 1px 1px var(--color_white),
    -1px -1px 1px var(--color_white),
    1px -1px 1px var(--color_white),
    1px 0px 1px var(--color_white),
    0px 1px 1px var(--color_white),
    -1px 0px 1px var(--color_white),
    0px -1px 1px var(--color_white);
}

body:not(.home) header .innerWrap {
  height: 25vh;
}



/* Main
======================================== */
/* InnerWrap ---------- */
main .contentsWrap>.contentsInner>.innerWrap {
  transition: 1.0s;
  opacity: 0;
  translate: 0 30px;
}

main #mainContent .contentsWrap:first-of-type>.contentsInner>.innerWrap,
main .contentsWrap>.contentsInner>.innerWrap.visible {
  opacity: 1;
  translate: 0 0px;
}

.innerWrap:has(> section:nth-of-type(2)) {
  display: grid;
  gap: var(--size-ll);
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}


/* Treatment ---------- */
#treatment .treatmentList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--size-m);
  align-items: stretch;
}


#treatment .treatmentList section {
  background-color: var(--color_white);
  padding: var(--size-m);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  cursor: pointer;
}

#treatment .treatmentList section:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transform: translateY(-3px);
}



/* News ---------- */
#news .newsList {
  list-style: none;
  padding: 0;
}

#news .newsList li:not(:last-child) {
  border-bottom: 1px dotted var(--color_brownMain);
  margin-bottom: var(--size-ss);
  padding-bottom: var(--size-ss);
}

#news .newsList li a {
  display: inline-block;
  padding: var(--size-ss) 0;
  line-height: 1.4;
}

#news .newsList li a time {
  color: var(--color_brownMain);
  font-weight: 700;
}

#news .newsList li a time::after {
  content: "｜";
}


/* xo-event-calendar
------------------------------ */
.xo-event-calendar .calendars {
  display: grid;
  gap: var(--size-ll);
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  margin-bottom: var(--size-m);
  padding-top: var(--size-s);
}

.xo-event-calendar .calendars .calendar {
  background-color: var(--color_white);
  padding: var(--size-m);
  border-radius: var(--size-s);
  border: 3px solid rgb(122 104 49 / 0.2);
}

.holiday-titles {
  text-align: right;
}


/* Features
------------------------------ */
#features .featuresList dt+dd {
  margin-bottom: var(--size-m);
}



/* FAQ
------------------------------ */
#faq details {
  overflow: hidden;
  border: 3px solid var(--color_orangeMain);
  border-radius: var(--size-ss);
}

#faq details summary {
  background-color: var(--color_offwhite);
  padding: var(--size-s);
  font-weight: 700;
}

#faq details p {
  border-top: 1px solid var(--color_brownMain);
  padding: var(--size-s);
}



/* Footer
======================================== */
footer .contentsInner {
  background-color: var(--color_orangeMain);
  text-align: center;
  color: var(--color_white);
  padding: var(--size-ss) 0 var(--size-m) 0;
}

footer address {
  padding: var(--size-m) 0;
}

footer address span {
  display: inline-block;
  padding: 0 var(--size-ss);
}

footer .copy a {
  color: var(--color_white);
}




@media (width >=1000px) {
  html {
    font-size: 18px;
  }
}