/*
    Theme Name: ARTEMAS
    Author:  ARTEMAS
    Author URL: https://artemasdigital.com/
    Description: ---- 2025.
    Document   : Framework
    Created on :  NOV 18 2025, 12.00 AM
*/

html {
  scroll-behavior: smooth;
  box-sizing: border-box;
  -ms-overflow-style: scrollbar;
}

body {
  animation: fadeIn ease 1s;
  -webkit-animation: fadeIn ease 1s;
  -moz-animation: fadeIn ease 1s;
  -o-animation: fadeIn ease 1s;
  -ms-animation: fadeIn ease 1s;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

@media screen and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

body {
  font-size: 100%;
  color: var(--textcolor);
  background: var(--bg-color);
  font-family: var(--font-one);
  margin: 0px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: relative;
  -webkit-text-size-adjust: none;
  font-weight: 300;
}


::placeholder {
  color: var(--secondry-color);
  font-family: var(--font-one);
  font-weight: 400;
}

.clear {
  clear: both;
  font-size: 0;
  line-height: 0;
  height: 0;
  margin: 0;
  padding: 0;
}

:focus {
  outline: 0;
}

a,
a:link,
a:visited {
  outline: none;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
  cursor: pointer;
  color: #fff;
  font-family: var(--font-one);
}


a:before {
  transition: all 0.3s ease-in-out;
}

a:after {
  transition: all 0.3s ease-in-out;
}

img {
  border: none;
  max-width: 100%;
}

ul,
li {
  list-style: none;
  margin: 0px;
  padding: 0px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  font-weight: normal;
  line-height: 1.2;
  font-family: var(--font-one);
}

p {
  margin: 0;
  line-height: 1.3;
  font-size: 1.3em;
  color: var(--bg-color);
  font-weight: 200;
  font-family: var(--font-one);
}

h1 {
  margin: 0;
  padding: 0;
  color: var(--maincolor);
  line-height: 1;
  font-size: 4em;
  font-weight: 700;

  font-family: var(--font-two);
  text-transform: uppercase;
}

h2 {
  margin: 0;
  padding: 0;
  color: var(--bg-color);
  font-size: 4em;
  line-height: 1;
  font-weight: 300;
  text-transform: uppercase;
  font-family: var(--font-two);
}

h3 {
  margin: 0;
  padding: 0;
  color: var(--bg-color);
  font-size: 2.3em;
  line-height: 1;
  font-weight: 700;
  font-family: var(--font-one);
  text-transform: uppercase;
}

h4 {
  margin: 0;
  padding: 0;
  color: var(--color-white);
  line-height: 1.3;
  font-size: 1.1em;
  font-weight: 600;
  font-family: var(--font-one);
  text-transform: uppercase;
}

.outer:before,
.outer:after,
.container:after,
.container:before,
.container-full:after,
.container-full:before,
.slider-area:after,
.slider-area:before {
  content: " ";
  display: table;
}

.outer:after,
.container:after,
.container-full:after,
.slider-area:after {
  clear: both;
}

.outer {
  width: 100%;
  padding: 0 0;
  margin: 0 auto;
  position: relative;
  z-index: 2;

}

.container {
  width: 90%;
  max-width: 1700px;
  margin: 0 auto;
}
.small-container {
  width: 90%;
  max-width: 1050px;
  margin: 0 auto;
}
.medium-container {
  width: 90%;
  max-width: 1100px;
  margin: 0 auto;
}
:root {
  --font-one: "Instrument Sans", sans-serif;
  --font-two: "Instrument Serif", serif;
  --font-three: "Allura", cursive;
  --maincolor: #fff;
  --bg-color: #1F1C25;
  --brand-color-one: #EDA8C4;
  --text-color: #1F1C25;
  --bg-white: #F8E8EE;
  --grey: #484848;
   --bg: #0f0b11;
    --panel: #161017;
    --muted: #b9aeb6;
    --line: rgb(255 255 255 / 47%);
    --accent: #f0a7c0; /* pink */
    --accent-strong: #ff9bc1;
    --input-h: 25px;
    --radius: 6px;
}

.content-start {
  width: 100%;
  margin: 200px 0 0 0;
}

.anim-text-banner {
  font-size: 6vw;
  white-space: nowrap;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1;
}

.anim-text-banner>span {
  position: absolute;
  display: inline-block;
  clip: rect(0px, 0px, 300px, 0px);
  color: var(--maincolor);
  font-family: var(--font-two);
  text-transform: capitalize;

}

.anim-text-parent {
  position: relative;
  color: var(--maincolor);
}

.anim-text-parent>.v-bar {
  position: absolute;
  width: 0px;
  height: 1vw;
  background: #ff9933;
  display: inline-block;
  top: 0px;
  left: -20px;
  transform: translate(-100%, 450%);
}

span.anim-text.color-text {

  color: var(--brand-color-one);

}

.maternity-section {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 40px;
  align-items: start;

}

.flex {
  display: flex;
}

.align-item-center {
  align-items: center;
}

.justify-content-space-between {
  justify-content: space-between;
}

.gap-10 {
  gap: 10px;
}

.gap-20 {
  gap: 10px;
}

.gap-50 {
  gap: 50px;
}

.parallax-container {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.parallax-img {
  width: 100%;
  height: 100%;
  object-fit: cover;

  /* fade + slide */
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}

.parallax-container.show .parallax-img {
  opacity: 1;
  transform: translateY(0);
}

.maternity-section .left p {
  margin: 50px 0 100px 0;
  opacity: 0.6;
  max-width: 450px;
}

.reveal-container {
  position: relative;
  width: 800px;
  height: 100%;
  margin: 100px auto;
  overflow: hidden;
}

.reveal-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-out;
}

.curtain {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-color);
  /* curtain color */
  transform: translateY(0);
  transition: transform 1s ease-out;
}

.reveal-container.show .curtain {
  transform: translateY(100%);
  /* curtain slides down */
}

.reveal-container.show .reveal-img {
  opacity: 1;
  /* image fades in */
}



body:not(.no-js) .image-wrap {
  transition: 1s ease-out;
  transition-delay: 0.2s;
  position: relative;
  width: auto;
  height: 100%;
  overflow: hidden;
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
  visibility: hidden;
}

body:not(.no-js) .image-wrap img {
  transform: scale(1);
  transition: 2s ease-out;
}

body:not(.no-js) .animating .image-wrap {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  visibility: visible;
  transform: skewY(0);
}

body:not(.no-js) .animating img {
  transform: scale(1);
  transition: 2s ease-out;
  width: 100%;
  height: 100%;
  display: block;
}

body:not(.no-js) .fadeup {
  opacity: 0;
  transition: 0.2s ease-out;
  transform: translateY(40px);
}

body:not(.no-js) .fading-up {
  opacity: 1;
  transition: 1s ease-out;
  transform: translateY(0px);
  transition-delay: 0.7s;
}

.first-section {
  position: relative;
  padding: 0 0 100px 0;
  width: 100%;

}

.home .floating{
  position: fixed;
  font-size: 23vw;
  font-weight: 500;
  color: rgba(119, 119, 119, 0.05);
  left: 0;
  white-space: nowrap;
  font-family: var(--font-two);
  text-transform: capitalize;
  bottom: 0;
  right: 0;
  margin: 0 auto;
  width: 100%;
  z-index: 1;
 display: block;
}
.floating {
  display: none;
}
span.hello-span {
  color: var(--brand-color-one);
  font-size: 6vw;
  font-family: var(--font-three);
  transform: rotateY(41deg);
  display: block;
  text-align: end;
}

/* This CSS ensures Lenis takes full control of scrolling */
html.lenis {
  height: auto;
}

.lenis.lenis-smooth {
  scroll-behavior: auto;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: hidden;
}

.lenis.lenis-scrolling iframe {
  pointer-events: none;
}


.signature {
  width: 420px;
}

.signature-stroke {
  stroke-dasharray: 1700;
  stroke-dashoffset: 1700;
  stroke-width: 6;
}

.signature-dot {
  opacity: 0;
}

/* Animation starts only when .start class is added */
.sig-wrap.start .signature-stroke {
  animation: writing 2.2s linear forwards;
}

.sig-wrap.start .signature-dot {
  animation:
    reveal 2s ease forwards 2.2s,
    plop .5s cubic-bezier(.5, .48, .76, 1.35) forwards 2.2s;
}

/* keyframes */
@keyframes reveal {
  to {
    opacity: 1;
  }
}

@keyframes plop {
  0% {
    transform: scale(.85);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes writing {
  0% {
    stroke-dashoffset: 1700;
  }

  45% {
    stroke-width: 5;
  }

  90% {
    stroke-dashoffset: 0;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-width: 15;
  }
}

.bg-white {
  background-color: var(--bg-white);
}

.second-section {
  width: 100%;
  padding: 200px 0 100px 0;
}

.z-index-1 {
  position: relative;
  z-index: 1;
}

.z-index-2 {
  position: relative;
  z-index: 2;
}

.hello-wrapper {
 transform: translate(80px, -110px);
    position: relative;
width: 50%;
}
.right-big-para {
  width: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.hello-wrapper svg {
  width: 100%;
    overflow: visible;
}
#slider {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.reveal-text {
  display: inline-block;
  opacity: 0;
  transform: translateY(25px);
  transition: opacity 0.4s ease-out, transform 0.4s ease-out;

}

/* Each letter */
.reveal-text span {
  opacity: 0;
  display: inline-block;
  transform: translateY(20px);
  transition: opacity 0.35s ease-out, transform 0.35s ease-out;
  color: var(--bg-color);
  font-size: 5em;
  line-height: 1;
  font-weight: 300;
  font-family: var(--font-two);
}

/* When visible */
.reveal-text.show {
  opacity: 1;
  transform: none;
}

/* Animate letters */
.reveal-text.show span {
  opacity: 1;
  transform: translateY(0);
}


/* Curtain layer */
.curtain {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bg-color);
  /* color of curtain */
  transform: translateX(-100%);
  transition: transform 0.7s ease-in-out;
  z-index: 2;
}

.show {
  transform: translateX(0);
}

.hide {
  transform: translateX(100%);
}

.layer1 {
  background: var(--bg-color);
}

.layer2 {
  background: var(--bg-color);
  transition-delay: 0.05s;
  opacity: 0.8;
}

.layer3 {
  background: var(--bg-color);
  transition-delay: 0.1s;
  opacity: 0.6;
}

.heading-two {
  margin: 0 0 10px 0;
}

.full-width-img img {
  width: 100%;
  display: block;
  object-fit: cover;
}

.section-title {
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  padding: 0 0;
}

/* Line */
.section-title .line {
 width: 180px;
  height: 1px;
  background: var(--bg-color);
  position: relative;
  overflow: hidden;
}

.section-title .line::after {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: var(--brand-color-one);
  /* active color on hover */
  transition: left 0.55s cubic-bezier(.25, .46, .45, .94);
}

/* Text */
.section-title a {
  font-size: 1em;
  font-weight: 600;
  color: var(--bg-color);
  position: relative;
  overflow: hidden;
}

.section-title a::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0%;
  height: 1.5px;
  background: var(--bg-color);
  transition: width 0.4s ease-in-out;
}

/* HOVER EFFECT */
.section-title:hover .line::after {
  left: 0;
  /* sliding fill animation */
}

.section-title:hover h3::after {
  width: 100%;
  /* underline reveal */
}

:root {
  --color-dark: #202330;
  --color-white: #fff;
}




.l-cards {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.c-card {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 24px;
  margin-top: 20px;
  width: 100%;
  height: 90vh;
  min-height: 600px;
  background-color: white;
  border: 1px solid var(--color-dark);
}

.c-card .c-card__description {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 40px;
}

.c-card .c-card__description .c-card__tagline {
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
}

.c-card .c-card__description .c-card__title {
  font-size: 36px;
}

.c-card .c-card__description .c-card__excerpt {
  font-size: 16px;
  line-height: 1.6;
}

.c-card .c-card__description .c-card__cta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 32px;
}

.c-card .c-card__description .c-card__cta a {
  width: max-content;
  padding: 12px 24px;
  border: 1px solid black;
  color: black;
  font-size: 16px;
  text-decoration: none;
}

.c-card .c-card__figure {
  position: relative;
  overflow: hidden;
}

.c-card .c-card__figure img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.second-section .flex {
  display: flex;
  justify-content: space-between;
  margin: 50px 0;
  align-items: flex-start;
}

.second-section .flex .right-content {
  max-width: 355px;
  width: 90%;
}




.reveal-text.heading-two.white-text span {
  color: var(--color-white);
}

.third-section {
  padding: 100px 0 0 0;
  margin: 0 0 80px 0;
}

.banner p {
  color: var(--color-white);
  opacity: 6;
}



.list-sec ul li a {
  color: var(--color-white);
  font-size: 1em;
  font-weight: 500;
}

 ul.desktop-menu li a.active {
  color: var(--brand-color-one);
}


.stacked-cards {
  position: relative;
  width: 100%;

}

.card {
  position: sticky;
  top: 0;
  height: 100vh;
  /* Your required height */
  display: flex;
  align-items: flex-end;
  margin-bottom: 20vh;
  /* space before next one pushes it */
  overflow: hidden;
  background-color: var(--color-white);
}

.hover-line {
  position: relative;
  padding-bottom: 4px;
  color: var(--bg-color)!important;
  font-weight: 700;
  margin: 20px 0 0 0;
  font-size: 1em;
  display: inline-block;
  text-transform: uppercase;
}

.hover-line::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 0%;
  height: 2px;
  background: #000;
  transform: translateX(-50%);
  transition: width 0.3s ease;
}

.hover-line:hover::after {
  width: 100%;
}

.box {
  position: absolute;
  width: 30%;
  margin: 50px;

}

.white-box {
  background-color: var(--color-white);
  padding: 50px;
}

.white-box i {
  font-size: 1.3em;
  color: var(--bg-color);
  font-weight: 600;
}

.white-box p {
  color: var(--grey);
  max-width: 370px;
  margin: 30px 0 0 0;
  width: 90%;
}

.white-box h3 {
  max-width: 300px;
}

.justify-flex-end {
  justify-content: flex-end;
}

.justify-flex-start {
  justify-content: flex-start;
}

  .review {
  opacity: 0;
  filter: blur(12px);
  transform: skewY(8deg) translateY(20px);
  transition: 0.7s ease-out;
}

.review.show {
  opacity: 1;
  filter: blur(0);
  transform: skewY(0deg) translateY(0);
}
p.review {
  color: var(--maincolor);
    font-size: 2em;
    max-width: 650px;
    line-height: 1.5;
    text-align: center;
    margin: 0 auto;
    padding: 50px 0;
   
}
.spacer.top {
 border-top: 1px solid rgb(168 160 160 / 9%);
 margin: 30px 0 0 0;
}
.spacer.bottom {
 border-bottom: 1px solid rgb(168 160 160 / 9%);
  margin: 30px 0 0 0;
}
   .fourth-section {
    text-align: center;
    width: 100%;
  padding: 0 0 100px 0;
   }
   .review span {
  opacity: 0;
  filter: blur(12px);
  transform: skewY(10deg) translateY(20px);
  display: inline;
  transition: 0.55s ease-out;
  font-weight: 400;
}

.review.show span {
  opacity: 1;
  filter: blur(0);
  transform: skewY(0deg) translateY(0);

}
.fourth-section strong {
  font-family: var(--font-two);
  color: var(--maincolor);
  font-weight: 200;
  font-size: 1.7em;
  text-transform: uppercase;
  opacity: 0.5;
}
.card:last-child {
  margin-bottom: 0;
}
 
  .word {
  opacity: 0.1;
  filter: blur(5px);
  display: inline-block;
  transform: translateY(20px) skewX(5deg);
  transition: 0.3s;
}
p.paragraph {
 font-size: 2.2em;
    line-height: 1.2;
    max-width: 700px;
    margin: 0 auto;
    color: var(--maincolor);
    padding: 50px 0;
    text-align: center;
}
     .maternity-section .left.contact-section p{
      color: var(--color-white);
      opacity: 0.7;
      max-width: 250px;
      margin: 0 0 0 0;
      width: 90%;
    }
      .contact-section a {
      color: var(--color-white);
      font-family: var(--font-two);
  font-weight: 300;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.3em;
    }
.five-section .maternity-section {
  grid-template-columns: 0.5fr 1fr;
  align-items: flex-end;
} 
.hello-wrapper.down-top-sign {
  text-align: left;
    position: absolute;
    right: inherit;
    top: 170px;
    left: -210px;
    transform: rotate(275deg);
}
.five-section .maternity-section .right {
  position: relative;
}
section.five-section {
    padding: 0 0 100px 0;
}
.footer-logo a {
  color:  var(--bg-color);
    font-weight: 200;
    font-family: var(--font-two);
    font-size: 2.5em;
   
}
footer {
  padding: 100px 0;
}
.footer-nav ul {
  display: flex;
  gap: 10px;
  margin: 20px 0 0 0;
}
.footer-nav ul li a {
  color: var(--bg-color);
  font-family: var(--font-one);
  text-transform: uppercase;
  font-size: 1em;
}
.footer-nav ul li a:hover {
	border-bottom: 1px solid #000;
}
.bottom-footer {
  margin: 200px 0 0 0;
}
.bottom-footer .left p {
 color: var(--bg-color);
 font-weight: 300;
 font-size: 15px;

}
span.anim-text:hover a {
  color: var(--brand-color-one);
}
span.anim-text a {
  font-family: var(--font-two);
}
.bottom-footer ul {
  display: flex;
  gap: 10px;
  align-items: center;
}


/* Desktop Menu */
.desktop-menu {
  display: flex;
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.desktop-menu li a {
  text-decoration: none;
  color: #333;
  padding: 8px 0;
  transition: all 0.3s ease;
}



/* Mobile Menu */
.mobile-menu {
  display: none;
  width: 100%;
  padding: 10px;
  font-size: 16px;
  border-radius: 8px;
  border: 1px solid #ccc;
}

/* Responsive */
@media (max-width: 768px) {
  .desktop-menu {
    display: none;
  }
  .mobile-menu {
    display: block;
  }
} 
.first-section.service-banner .heading-two {
  text-transform: capitalize;
  margin: 0 0 50px 0;
}
.hello-wrapper.left-align-sign {

    position: relative;
}
.second-section .right-big-para .right-content {
  max-width: 500px;
  width: 90%;
}
.second-section.service-second {
  padding: 0 0 100px 0;
}
.second-section .right-big-para .right-content p {
  color: #111;
  opacity: 0.6;
}
.second-section.service-second .flex {
  justify-content: space-around;
}
.service-image {
  display: grid;
    grid-template-columns: 0.6fr 0.9fr; /* two columns */
    column-gap: 20px;

}
.service-image .reveal {
  margin: 0 0 0 0;
}
.service-image.grid-layout-two {
  grid-template-columns: 1.5fr 1fr;
  margin: 20px 0 0 0;
}
.reveal.height-adjust {
  height: 100%;
}
.service-image.grid-layout-two .reveal {
  margin: 0 0 0 0;
}
.service-image .image-wrap {
  cursor: pointer;
} 
.service-image .image-wrap img {
   transition: transform 0.5s ease!important; /* smooth zoom */
}
.service-image .image-wrap:hover img {
    transform: scale(1.2)!important; /* zoom effect */
}
.service-second {
  background-color: var(--color-white);
}
  /* New class instead of 'card' */
  .photo-package {
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.5s ease;
  }

  .photo-package img {
    width: 100%;
    display: block;
    transition: transform 0.5s ease, filter 0.5s ease;
    height: 600px !important;
    object-fit: cover !important;
    object-position: top;
  }

  /* Overlay content */
  .photo-package .content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 40px;
    height: 100%;
 background: #1F1C25;
background: linear-gradient(180deg, rgba(31, 28, 37, 0.01) 0%, rgba(31, 28, 37, 0.15) 50%, rgba(31, 28, 37, 0.34) 81%, rgba(31, 28, 37, 0.56) 100%);
  
    text-align: left;
    transition: background 0.5s ease;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
  }
.package-content {
  width: 100%;
}
  .photo-package .content h2 {
    margin: 0;
    font-size: 2.2em;
    font-family: var(--font-one);
    color: var(--color-white);
    font-weight: 700;
  }

  .photo-package .content p {
    margin: 5px 0 20px 0;
     font-size: 1.2em;
    font-family: var(--font-one);
    color: var(--color-white);
    font-weight: 500;
    max-width: 300px;
  }

  .photo-package .content a {
    display: flex;
    align-items: center;
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    gap: 5px;
    transition: color 0.3s ease;
    justify-content: space-between;
  }

  .photo-package:hover img {
    transform: scale(1.1)!important;
   
  }



  .photo-package:hover .content a {
    color: var(--brand-color-one);
  }
  .photo-grid {
     display: grid;
    grid-template-columns: repeat(3, 1fr); /* Exactly 3 columns */
    gap: 20px;
  }
  .package-see {
    border-top: 1px solid #fff;
    padding: 10px 0 0 0;
	  display: flex;
    justify-content: space-between;
  }
  .service-package {
    padding: 100px 0 100px 0;
  }



.faq-title {
  font-size: 48px;
  margin-bottom: 40px;
  padding-bottom: 10px;
}

.faq {
  border-bottom: 1px solid var(--brand-color-one);
  padding: 12px 0;
}

.faq-question {
  width: 100%;
  background: none;
  border: none;
  color: #fff;
  font-size: 2em;
  text-align: left;
  padding: 15px 0 0 0;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-two);
}

.icon {
  font-size: 30px;
  transition: transform 0.35s ease, opacity 0.2s;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  line-height: 1.6;
    font-size: 1.2em;
    padding-right: 40px;
    transition: max-height 0.45s 
ease, opacity 0.35s 
ease;
    will-change: max-height;
    color: var(--color-white);
    opacity: 0.6;
    max-width: 1000px;
}

/* Active state */
.faq.active .faq-answer {
  max-height: 300px;
  margin-top: 10px;
}

/* Icon changes */
.faq.active .icon {
  opacity: 0.5;
}
.fourth-section.faq-section-block {
  text-align: left;
}
.button-links {
    display: flex; /* Arrange links side by side */
    gap: 20px; /* Space between the two links */
    margin: 50px 0 150px 0;
}

.policy-link {
    /* Style the button */
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 20px 25px;
    background-color: #fff; /* White background */
    color: #000; /* Black text */
    text-decoration: none; /* Remove underline from links */
    /* Transition for smooth hover effect */
    transition: transform 0.3s ease, background-color 0.3s ease;
    
}



/* --- Hover Effect --- */

.policy-link:hover {
    /* Slightly scale up the button on hover */
    transform: scale(1.03); 
    /* Slightly change background color on hover */
    background-color: #f0f0f0; 
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.3);
}

/* Optional: Style for the text to ensure it's centered */
.policy-link span {
    flex-grow: 1;
    text-align: left;
    font-size: 1em;
    font-weight: 500;
    color: var(--bg-color);
}
.about-me-banner .right {
  position: relative;
}
.about-me-banner .maternity-section {
  align-items: center;
}
.about-me-banner .maternity-section .reveal-text span {
  text-transform: capitalize;
}
.about-me-banner .left {
position: relative;
}
.left-after {
     width: 5px;
    height: 53%;
    position: absolute;
    bottom: -88px;
    left: 0;
    background-color: var(--brand-color-one);
}
.about-me-banner .container {
  position: relative;
}
.about-page-details p.paragraph {
  max-width: 900px;
  font-family: var(--font-two);
  text-align: left;
  margin: inherit;
  line-height: 1.3;
  opacity: 0.8;
}
.about-page-details p.paragraph b {
  font-family: var(--font-one);
  color: var(--brand-color-one);
}
.second-section.about-page-details {
  padding: 0 0 100px 0;
}
 .clip-fade {
      --r: 100%; /* CSS var we animate: right inset percentage */
      clip-path: inset(0 var(--r) 0 0);           /* hidden from the right */
      -webkit-clip-path: inset(0 var(--r) 0 0);   /* Safari fallback */
      opacity: 0;
      transform: translateX(-6px); /* tiny nudge for nicer motion */
      display: inline-block;       /* works for text; use block for images/cards */
      will-change: clip-path, opacity, transform;
      font-size: 2.5em;
      color: var(--color-white);
      font-family: var(--font-two); 
     line-height: 1.3;
     opacity: 0.7;
    }
.wrap {
 max-width: 1000px;
 width: 90%;
}
 .clip-fade b {
  color: var(--brand-color-one);
  font-family: var(--font-one);
  font-weight: 700;
  opacity: 1;
 }
 .service-page-links {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
 }
 .service-page-third {
  padding: 0 0 0 0;
 }
 .photography-content-block .clip-fade {
  font-size: 9em;
    line-height: 1.1;
    font-weight: 300;
   text-transform: capitalize;
    font-family: var(--font-two);
    color: var(--color-white);
    opacity: 1;
 }
  .photography-content-block .wrap {
    max-width: inherit;
    text-align: left;
    width: auto;
  }
 
   .photography-content-block .wrap .clip-fade b {
     font-family: var(--font-two);
     font-weight: 400;
   }
   .what-makes {
    background-color:  var(--color-white);
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin: 0 0 100px 0;
   }
   .stories-top .clip-fade b {
    color: #9C9C9C;
    font-weight: 300;
    font-size: 0.6em;
   }
     .what-makes .left {
      padding: 50px 0 0 60px;
     }
     .stories-middle .clip-fade {
      color: #383838;
      font-family: var(--font-two);
      font-size: 3em;
     }
     .what-makes .right img {
      width: 100%!important;
      height: 100%!important;
      display: block;
      object-fit: cover;
     }
       .what-makes .left img {
        width: auto!important;
       }
     .stories-middle {
      margin: 30px 0 0 0;
     }
     .stories-bottom .clip-fade strong {
      color: #A75676;
      font-family: var(--font-two);
      font-size: 1em;
      max-width: 600px;
      display: block;
      margin: 0 0 40px 0;
      border-left: 3px solid var(--brand-color-one);
      line-height: 1;
      padding: 0 0 0 8px;
     }
     .stories-bottom {
      margin: 350px 0 0 0;
     }
       .stories-bottom img {
        display: block;
       }
       .thank-you-contact {
        text-align: center;
        padding: 0 0 150px 0;
       }
       .thank-you-contact .reveal-text span {
        opacity: 0.7;
       }
       .thank-you-contact.photography-content-block .clip-fade {
        text-align: center;
        font-size: 5em;
        opacity: 0.7!important;
        text-transform: uppercase;
       }
        .thank-you-contact.photography-content-block .wrap {
          text-align: center;
        }
        .thank-you-contact.photography-content-block .clip-fade b {
          font-size: 1.1em!important;
           text-transform: capitalize;
           font-family: var(--font-one);
        }
        .thank-you-contact strong {
          color: var(--brand-color-one);
          font-size: 1.5em;
          font-weight: 500;
          display: block;
          padding: 50px 0 30px 0;
        }
        .contact-page .hello-wrapper {
          text-align: left;
    position: absolute;
    right: 0;
    top: -85px;
    left: 0;
    z-index: 2;
    margin: 0 0 100px 0;
    transform: none;
        } 
        .contact-page .stories-middle {
          margin: 180px 0;
        }
          .contact-page .stories-middle .clip-fade {
            text-align: center;
            font-size: 2.3em;
          }
             .contact-page .what-makes .left {
              padding: 80px;
             }
             .appointemnt {
              border-top: 1px solid #A75676;
              border-bottom: 1px solid #A75676;
              padding: 40px 0;
              text-align: center;
             }
             .appointemnt a {
              color: var(--bg-color);
              display: flex;
              align-items: center;
              justify-content: center;
              gap: 20px;
              text-transform: uppercase;
              font-weight: 600;
              font-size: 1.3em;
               -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;    
    transition: all 0.3s ease-in-out;
             }
             .appointemnt a:hover img {
              transform: translateX(10px);
               -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;    
    transition: all 0.3s ease-in-out;
             }
              .appointemnt a img {
                  -webkit-transition: all 0.3s ease-in-out;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;    
    transition: all 0.3s ease-in-out;
              }
              .call-me a {
                color: var(--bg-color);
              display: flex;
              align-items: center;
              justify-content: center;
              text-transform: uppercase;
              font-weight: 500;
              font-size: 1.3em;
              margin: 30px 0 0 0;
              }
              .call-me a strong {
                font-weight: 700;
              }
                   .call-me a img {
                    margin: 0 10px 0 0;
                   }
                   .connect {
                    text-align: center;
                    margin: 30px 0 0 0;
                   }
                   .connect span {
                    display: block;
                    color: var(--brand-color-one);
                    letter-spacing: 8px;
                    text-transform: uppercase;
                    font-weight: 600;
                   }
                    .connect ul {
                      display: flex;
                      justify-content: center;
                      gap: 30px;
                      margin: 30px 0 0 0;
                    }
                      /* container with screenshot-like left visual (hero) */



/* 
  .wrap-book {
    max-width: 800px;
    margin: 0 auto;
    width: 90%;
  } */
#appointment .small-container {
	max-width: 800px;
}
  .card-book h3 {
    font-size: 1.2em;
    color: var(--color-white);
    margin: 2px 0 35px 0;
    font-weight: 600;
    font-family: var(--font-one);
    text-transform: capitalize;
  }

  /* --- Shoot Type (big radios) --- */
  .shoot-types{
    display:flex;
    gap:30px;
    align-items:center;
    padding:0  0 0 0;
  }

  .big-radio{
    display:flex;
    align-items:center;
    gap:10px;
    cursor:pointer;
    user-select:none;
    color:var(--muted);
    font-weight:400;
    font-size: 2em;
    font-family: var(--font-two);
  }

  .big-radio input{
    display:none;
  }

  .big-radio .dot{
    width: 25px;
    height: 25px;
    border-radius: 50%;
    border: 3px solid rgba(255, 255, 255, 0.15);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.01), rgba(0, 0, 0, 0.02));
    transition: all .18s 
ease;
  }
  .big-radio .dot::after{
    content: '';
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: transparent;
    display: block;
    transition: all .18s 
ease;
  }
  .big-radio input:checked span {
    color: var(--color-white);
  }
  .big-radio input:checked + .dot{
   border-color: #fff;
    transform: scale(1.02);
  }
  .big-radio input:checked + .dot::after{
    background:var(--accent);
  }

  /* --- form fields --- */
  form .group{
    border-left:1px solid var(--brand-color-one);
    padding-left:18px;
    margin-bottom:22px;
  }
.group{
  border-left:1px solid var(--brand-color-one);
    transition:border 0.25s ease;
    margin: 50px 0;
    padding: 0 0 0 20px;
}
.group.active{
  border-right:3px solid var(--accent);
  padding-right:15px;
}

  label.small{
    display:block;
    font-size:12px;
    color:var(--muted);
    margin-bottom:0;
    font-weight:600;
  }

  .field{
    background:transparent;
    border:none;
    border-bottom:1px solid var(--line);
    padding: 0 0 20px 0;
    color:#eee;
    outline:none;
    font-size:14px;
    width:100%;
    transition: border-color .12s ease;
  }
input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required.walcf7-timepicker {
	 background:transparent;
    border:none;
    border-bottom:1px solid var(--line);
    padding: 0 0 20px 0;
    color:#eee;
    outline:none;
    font-size:14px;
    width:100%;
    transition: border-color .12s ease;
}
  .field:focus{
    border-bottom-color: rgba(240,167,192,0.6);
  }

  .inline-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
  }

  /* custom select */
  .custom-select{
    position:relative;
  }
  .custom-select select{
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;
    width:100%;
    background:transparent;
    color:#eee;
    border:none;
    padding:10px 36px 20px 6px;
    border-bottom:1px solid var(--line);
    font-size:14px;
    font-family: var(--font-one);
  }
  .custom-select::after{
    content: "▾";
    position:absolute;
    right:8px;
    top:50%;
    transform:translateY(-50%);
    color:var(--brand-color-one);
    font-size:1.8em;
    pointer-events:none;
  }

  .note{
    font-size:12px;
    color: #a69aa2;
    margin-top:8px;
    line-height:1.4;
  }

  /* icons for date/time */
  .icon{
    position:relative;
  }
  .icon input[type="date"],
  .icon input[type="time"]{
    padding-left:6px;
  }
.wpcf7-not-valid-tip {
	font-size: 15px;
	margin: 10px 0 0 0;
}
  .icon .i{
    position:absolute;
    right: 10px;
    top: 0;
    transform:translateY(0);
    color:var(--muted);
    font-size:16px;
  }

  /* CTA */
  .cta-wrap{
   
    margin-top:18px;
    background:linear-gradient(180deg,transparent, rgba(0,0,0,0.1));
    padding: 15px 0;
  }

  .cta {
    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    background: var(--brand-color-one);
    color:var(--bg-color);
    border:none;
    width:100%;
    padding: 30px 20px;
    font-weight:700;
    cursor:pointer;
    letter-spacing:0.6px;
    font-family: var(--font-one);
    font-size: 1.2em;
  }
.cta img {
  max-width: 60px;
}
  /* small helpers */
  .divider{height:1px;background:var(--line);margin:18px 0;border-radius:2px}
  .subtle{color:var(--muted);font-size:13px}

  /* responsive */
  @media (max-width:640px){
    .wrap-book{padding:0 0}
    .inline-row{grid-template-columns:1fr}
   
    .big-radio{font-size:16px}
  }
input[type="time"]::-webkit-calendar-picker-indicator {
    opacity: 0;
    display: none;
}
input[type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0;        /* hides the icon */
    display: none;     /* fully removes it */
}
textarea.field {
    margin: 30px 0 0 0;
    resize: none;
}
section.first-section.contact-page {
  padding: 0 0 0 0;
}
.custom-select option {
  background-color: var(--brand-color-one);
  color: var(--bg-color);
}
.custom-select option:hover {
  background-color: var(--color-white);
}
.header-contact ul {
  display: flex;
  grid-gap: 20px;
  margin: 50px 0 0 0;
}
.header-contact ul li a img {
  max-width: 30px;
}
.nav-item:hover {
  color: var(--brand-color-one);
}
body.hamburg_open .right-sec {
  display: none;
}
.header-contact.inner-left-menu a {
  align-items: center;
    display: flex!important;
    opacity: 0.8;
}
.header-contact.inner-left-menu {
  justify-content: flex-start;
  margin: 30px 0 0 0;
}
.what-makes.image-wrap .left {
  background-color: #F8E8EE;
}
.contact-page .reveal {
  position: relative;
}
.contact-page .hello-wrapper {
  left: 100px;
}
.service-image .left {
gap: 20px;
  display: grid;
}
.home .first-section .hello-wrapper {
position: absolute;
    right: 110px;
    bottom: 0;
    z-index: 9;
    transform: translate(80px, 197px);
}
.banner {
  position: relative;
}
.card img {
  width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
}
.hello-wrapper.left-align-sign img {
    max-width: 550px;
}
  .badge {
        position: absolute;
    left: 0;
    top: 14px;
    font-size: 8em;
    line-height: 1.1;
    font-weight: 300;
    font-family: var(--font-two);
    color: var(--color-white);
    opacity: 0.3;
    transform: rotate(270deg);
    bottom: 0;
    z-index: 22;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    margin: 0 auto;
    width: 100%;
     transition: transform .5s ease;
  }
   .image-wrap img {

    transition: transform .5s ease;
	   object-fit: cover;
  }
   .image-wrap {
    transition: transform .5s ease;
   }
  .image-wrap:hover .badge  {
    transform: scale(0.5)!important;
      transition: transform .5s ease;
  }
   .image-wrap:hover .badge {
    opacity: 1;
     transition: transform .5s ease;
   }
   .image-wrap .badge {
     transition: transform .5s ease;
   }
   .breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  color: #555;
  margin: 0 0 20px 0;
}

.breadcrumb a {
  color: var(--color-white);
  text-decoration: none;
  transition: color 0.25s ease;
  opacity: 0.5;
}



.breadcrumb .active {
  font-size: 12px;
  font-weight: 400;
  color: var(--color-white);
  margin: 0;
  padding: 0;
  font-family: var(--font-one);
  text-transform: capitalize;
}
.reveal-text.main-title span {
  font-size: 8em;
}
/* ------------------------------
   PRELOADER
------------------------------ */
#preloader {
    position: fixed;
    inset: 0;
    background: #000;
    z-index: 999999999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
    visibility: visible;
    transition: opacity 0.7s ease, visibility 0.7s ease;
}

#preloader.hide {
    opacity: 0;
    visibility: hidden;
     transition: opacity 0s ease, visibility 0s ease;
}

#preloader-logo img {
    width: 140px;
    opacity: 0;
    transform: scale(0.5);
}


/* ------------------------------
   MODAL BACKDROP
--------------------------------*/
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.4);
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  z-index: 999;
  backdrop-filter: blur(5px);
}

.modal-overlay.show {
  opacity: 1;
  visibility: visible;
}


/* ------------------------------
   SLIDING MODAL PANEL
--------------------------------*/
.modal-panel {
  position: fixed;
  top: 0;
  right: -100%;
  width: 100%;
  max-width: 50%;
  height: 100%;
  background: #fff;
  transition: 0.4s ease;
  z-index: 1000;
  overflow-y: auto;
  padding-bottom: 60px;
  position: fixed;
}

.modal-panel.show {
  right: 0;
}


/* CLOSE BUTTON */
.close-btn {
  position: absolute;
  right: 12px;
  top: 12px;
  background: #ddd;
  border-radius: 50%;
  width: 34px;
  height: 34px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  cursor: pointer;
  display: none;
}
.close-btn:hover {
  background: #bbb;
}


.tab-nav {
  display: flex;
    border-bottom: 0;
    margin-top: 0;
    padding: 0 0;

}

.tab-btn {
  flex: 1;
  text-align: center;
  padding: 14px;
  font-size: 1.2em;
  cursor: pointer;
  border: none;
  font-weight: 700;
  /* color: var(--maincolor); */
}
.tab-btn.active {
  background: var(--brand-color-one);
  color: var(--bg-color);
}


/* ------------------------------
   TAB CONTENT
--------------------------------*/
.tab-content {
  display: none;
  padding: 30px 50px;
}
.tab-content.active {
  display: block;
}


/* ------------------------------
   MOBILE ACCORDION
--------------------------------*/
.accordion-tab {
  display: none;
  border-bottom: 1px solid #ddd;
}

.accordion-header {
  padding: 14px;
  cursor: pointer;
  font-size: 1.3em;
  text-align: left;
  border: 0;
    background-color: #efefef;
    font-weight: 600;
    position: relative;
}
.accordion-body {
  display: none;
  padding: 16px;
}

.accordion-body.active {
  display: block;
}

/* ------------------------------
   RESPONSIVE RULES
--------------------------------*/
@media (max-width: 600px) {
  .tab-nav {
    display: none;
  }
  .accordion-tab {
    display: block;
  }
  .close-btn {

        position: absolute;
    right: 0;
    top: 0;
    background: #000;
    border-radius: 0;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    cursor: pointer;
    left: -50px;
    bottom: 72%;
    /* transform: translateY(50%); */
    color: #fff;
  }
  .modal-panel {
    max-width: 80%;
    width: 80%;
  overflow-y: visible;

  }
  .tab-content.active {
    display: none;
  }
}
.body-fixed {
  overflow: hidden;
  height: 100vh;
  position: static;
}

.tab-content h3,.accordion-body  h3 {
  font-family: var(--font-two);
  font-size: 2.5em;
  font-weight: 600;
}
.tab-content ul, .accordion-body ul {
  margin: 20px 0;
}
.tab-content li, .accordion-body li {
  list-style: none; /* remove default bullet */
  position: relative;
  padding: 0 0 10px 15px;
  font-size: 1.4em;
  font-family: var(--font-one);
}

.tab-content li::before, .accordion-body li::before {
  content: "-";       /* the hyphen */
  position: absolute;
  left: 0;            /* align left */
  color: #000;        /* optional color */
}
.modal-panel .tab-content .cta, .accordion-body .cta  {
 position: absolute;
    bottom: 0;
    left: 0;
    margin: 0 auto;
    width: 100%;
    right: 0;
    color: var(--bg-color);
    border-top: 1px solid #c5c5c5;
    background-color: transparent;
}
.accordion-header.active {
  background: var(--brand-color-one);
    color: var(--bg-color);
}
.add-on {
    font-size: 1.2em;
    line-height: 1.5;
    border-left: 4px solid var(--brand-color-one);
    padding: 0 0 0 10px;
    color: var(--bg-color);
}
.add-on b {
  font-weight: 600;
}
.amt {
  font-size: 2.5em;
    font-weight: 600;
    margin: 0 0 20px 0;
}
/* Allow native scroll inside elements */
[data-lenis-prevent] {
  overscroll-behavior: contain;
  overflow: auto !important;
  -webkit-overflow-scrolling: touch;
}
.accordion-header::after {
  content: '';
    position: absolute;
    right: 18px;
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 10px solid #000;
    margin: 20px auto;
    cursor: pointer;
    top: 0;
}
.accordion-header.active::after {
    transform: rotate(60deg);
}
.c-photo-slider {
    margin: 0 0 30px 0;
}
span.wpcf7-list-item-label {
	user-select: none;
    color: var(--muted);
    font-weight: 400;
    font-size: 2em;
    font-family: var(--font-two);
}
input[type="radio"] {
	width: 25px;
    height: 25px;
    border-radius: 50%;
    border: 3px solid rgba(255, 255, 255, 0.15);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.01), rgba(0, 0, 0, 0.02));
    transition: all .18s 
ease;
}
input[type="radio"]:checked {
	border-color: #fff;
    transform: scale(1.02);
}
input[type="radio"]::after {
	content: '';
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: transparent;
    display: block;
    transition: all .18s 
ease;
}
input:checked + [type="radio"]::after {
	background: var(--accent);
}
/* WRAP: align items inline like screenshot */
.shoot-radio .wpcf7-list-item {
    display: inline-flex;
    align-items: center;
  margin: 0 30px 0 0;
}

/* Text style */
.shoot-radio .wpcf7-list-item-label {

  font-size: 2em;
    color: #d6d0d2;
    margin-left: 8px;
    text-transform: capitalize;
}

/* Hide default radio */
.shoot-radio input[type="radio"] {
   appearance: none;
    -webkit-appearance: none;
    width: 30px;
    height: 30px;
    border: 3px solid #d6d0d2;
    border-radius: 50%;
    position: relative;
    cursor: pointer;
    transition: border-color 0.2s 
ease;
    background: transparent;
}

/* Pink active border */
.shoot-radio input[type="radio"]:checked {
  border-color: #fff;
}

/* Pink fill on check */
.shoot-radio input[type="radio"]:checked::after {
   content: "";
    width: 20px;
    height: 20px;
    background: #e4a3b5;
    border-radius: 100%;
    position: absolute;
    top: 2px;
    left: 2px;
}
.contact-section a.hover-line.white-text {
    color: var(--color-white) !important;
   
}
.page-template-maternity ul.desktop-menu {
    display: flex;
    gap: 20px;
    list-style: none;
    padding: 0;
    margin: 0 0 40px 0;
}

.inner.body-fixed header {
    z-index: 1;
}
.service-image.grid-layout-two.reverse {
	grid-auto-flow: column;
    grid-auto-columns: 1fr;
    direction: rtl;
}
/* ==========================================
   TERMS & LATE ARRIVAL POLICY – FULL STYLES
   ========================================== */

.page-template-termsandconditions .content-start,
.page-template-laterarrivalpolicy .content-start {
  color: #ffffff;
}

/* Headings */
.page-template-termsandconditions .content-start h2,
.page-template-laterarrivalpolicy .content-start h2 {
  font-size: 2rem;
  line-height: 1.3;
  margin-bottom: 1rem;
  color: #ffffff;
}

.page-template-termsandconditions .content-start h3,
.page-template-laterarrivalpolicy .content-start h3 {
  font-size: 1.5rem;
  line-height: 1.4;
  margin-bottom: 0.75rem;
  color: #ffffff;
}

.page-template-termsandconditions .content-start h4,
.page-template-laterarrivalpolicy .content-start h4 {
  font-size: 1.25rem;
  line-height: 1.4;
  margin-bottom: 0.5rem;
  color: #ffffff;
}

/* Paragraphs */
.page-template-termsandconditions .content-start p,
.page-template-laterarrivalpolicy .content-start p {
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 1rem;
  color: #ffffff;
}

/* Strong / Bold */
.page-template-termsandconditions .content-start strong,
.page-template-termsandconditions .content-start b,
.page-template-laterarrivalpolicy .content-start strong,
.page-template-laterarrivalpolicy .content-start b {
  font-weight: 600;
  color: #ffffff;
}

/* Lists */
.page-template-termsandconditions .content-start ul,
.page-template-laterarrivalpolicy .content-start ul {
  list-style-type: disc;
  list-style-position: outside;
  padding-left: 1.25rem;
 
  color: #ffffff;
}
.page-template-termsandconditions .content-start ,
.page-template-laterarrivalpolicy .content-start {
	margin: 200px 0 100px 0;
}
.page-template-termsandconditions .content-start li,
.page-template-laterarrivalpolicy .content-start li {
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 0.5rem;
  display: list-item;
	list-style: disc;
}

/* Links inside list */
.page-template-termsandconditions .content-start li a,
.page-template-laterarrivalpolicy .content-start li a {
  font-size: 1rem;
  color: #ffffff;
  text-decoration: underline;
  transition: opacity 0.3s ease;
}

.page-template-termsandconditions .content-start li a:hover,
.page-template-laterarrivalpolicy .content-start li a:hover {
  opacity: 0.8;
}

/* General links inside content */
.page-template-termsandconditions .content-start a,
.page-template-laterarrivalpolicy .content-start a {
  color: #ffffff;
  text-decoration: underline;
}
.page-template-termsandconditions .content-start ul,
.page-template-laterarrivalpolicy .content-start ul {
  list-style: disc !important;
}
/* Responsive (mobile) */
@media (max-width: 768px) {
  .page-template-termsandconditions .content-start h2,
  .page-template-laterarrivalpolicy .content-start h2 {
    font-size: 1.75rem;
  }

  .page-template-termsandconditions .content-start h3,
  .page-template-laterarrivalpolicy .content-start h3 {
    font-size: 1.35rem;
  }

  .page-template-termsandconditions .content-start h4,
  .page-template-laterarrivalpolicy .content-start h4 {
    font-size: 1.15rem;
  }

  .page-template-termsandconditions .content-start p,
  .page-template-laterarrivalpolicy .content-start p,
  .page-template-termsandconditions .content-start li,
  .page-template-laterarrivalpolicy .content-start li {
    font-size: 0.95rem;
  }
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
    border-color: #fff;
    color: #fff;
    padding: 10px;
    margin: 0;
}
.datepicker {
 background-color: transparent;
    color: #ffffff;
    border: 0;
    padding: 0 0 20px 0;
    box-shadow: none;
    border-bottom: 1px solid var(--line);
    width: 100%;
}

/* Placeholder color */
.datepicker::placeholder {
  color: rgba(255, 255, 255, 0.7);
}

/* Cross-browser support */
.datepicker::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.7);
}

.datepicker:-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.7);
}
.logo img {
    max-width: 170px;
}

.datepicker::-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.7);
}
#appointment {
  scroll-margin-top: 50vh;
}
.footer-logo img {
    max-width: 230px;
}
.wpcf7 form.sent .wpcf7-response-output {
    border-color: #46b450;
    color: #46b450;
    font-size: 1.5em;
    padding: 10px;
    text-align: center;
    font-weight: 600;
}