
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  font-family: "Funnel Display", system-ui;
  color: #4A4947; 
  line-height: 1.6;
  font-weight: 300;
  background-color: transparent; 
}

/* Fonts  */
h1, h2, h3 {
  font-family: "Archivo Narrow", sans-serif;
  font-weight: 500;
  color: #4A4947;
}

/* Header */
.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 40px;
  position: sticky;
  top: 0;
  background-color: transparent;
  z-index: 1000;
}

.logo img {
  height: 50px;
}

.navbar {
  display: flex;
  gap: 50px;
  background-color: #fbf7f0;
  padding: 10px 40px;
  border-radius: 999px;
}

.navbar a {
  text-decoration: none;
  color: #4A4947;
  font-weight: 350;
  transition: color 0.3s;
}

.navbar a:hover {
  color: #B17457; 
}

.navbar a.active {
  font-weight: 500;
}

.hero-content-home {
  position: absolute;
  bottom: 10%;
  left: 5%;
  color: #ffffff;      
}

.hero-content-home h1 {
  font-size: 3.5rem;   
  line-height: 1.2;
  margin: 0 0 20px 0;
}

.hero-content-home p {
  font-size: 1.2rem;   
  line-height: 1.5;
  margin: 0;
  color: #ffffff;       
}


.hero-content h1 {
  font-size: 3rem;
  line-height: 1.2;
  margin-bottom: 20px;
}

.hero-btn {
  display: inline-block;
  padding: 12px 24px;
  background-color: #E77A8B; 
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  transition: background 0.3s;
}

.hero-btn:hover {
  background-color: #B17457;
}

/* Our Story */
.about {
  padding: 80px 20px;
  text-align: center;
  background-color: #fef6ee;
}

.about-content {
  position: absolute;
  bottom: 10%;
  left: 8%;
}
.about-headline {
  font-size: 2rem;
  margin-bottom: 20px;
  text-align: centre ;
}

.about-subtext {
  font-size: 1rem;
  margin-bottom: 50px;
  text-align: center ;
}

.btn-pink {
  background-color: #E77A8B;
  color: white;
  padding: 14px 50px;
  text-decoration: none;
  font-weight: 500;
  transition: background 0.3s;
}

.btn-pink:hover {
  background-color: #B17457;
}

/* Crowd Pleasers */
.crowd-pleasers {
  padding: 60px 20px;
  text-align: center;
  background-color: #fef6ee;
}

.crowd-text h2 {
  font-size: 1.8rem;
  margin-bottom: 10px;
}

.crowd-text p {
  font-size: 1rem;
  margin-bottom: 40px;
}

.crowd-grid {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 15px;
}

.crowd-item {
  width: 280px;
  text-align: center;
}

.crowd-item img {
  width: 100%;
  object-fit: cover;
}

.item-label {
  font-size: 0.9rem;
  margin-top: 3px;
  color: #4A4947;
  text-align: left;
}

/* Light Filled Mornings */
.light-filled-mornings {
  padding: 80px 10px;
  text-align: center;
  background-color: #D8D2C2;
}

/* Row for LFM */
.image-row {
  display: flex;
  gap: 15px; 
  justify-content: center;
  margin-top: 10px;
}

.image-row img {
  width: 30%; 
  max-width: 100%; 
  height: auto;
  object-fit: cover;
}

/* === Homepage: Find Us === */
.find-us {
  display: flex;              
  align-items: flex-start;    
  padding: 60px 100px;
  background-color: #4A4947;
  color: #fff;
  gap: 10px;                 
}

/* Text section */
.find-us .find-us-text {
  flex: 1;                    
  padding-left: 20px;          
}

/* Map section */
.find-us .find-us-map {
  flex: 1;                     
  max-width: 800px;          
}

.find-us-map iframe {
  width: 100%;
  height: 400px;
  border: 0;
  display: block;
}

/* Heading & logo inside text section */
.find-us h2 {
  font-size: 1.8rem;
  margin-bottom: 20px;
  color: #fff;
}

.find-us .woo-logo {
  width: 150px; 
  height: auto;
  margin-top: 10px;
}

/* === Our Story Page === */

.our-story-page {
  padding: 170px 100px; 
  background-color: #FBF7F0;
}

.our-story-page h2 {
  font-size: 2rem;
  margin-bottom: 15px;
  margin-top: 100px; 
  text-align: center;
}

.our-story-page .intro {
  text-align: center;
  font-family: "Funnel Display", system-ui; 
}

.our-story-page h3 {
  font-size: 1.5rem;
  margin-bottom: 5px;
  text-align: left;
}

.our-story-page p {
  font-size: 1rem;
  font-weight: 200;
  margin-bottom: 40px;
  text-align: left;
}

.our-story-image {
  display: block;
  width: 100%;
  max-width: 1300px; 
  margin: 60px auto; 
  height: auto;
}

/* === Menu === */
.menu {
  padding: 60px 100px;         
  background-color: #FBF7F0;   
  color: #000;
  display: flex;
  flex-direction: column;   
  gap: 80px;                  
}

/* Menu section headers */
.menu-title {
  font-size: 2rem;
  margin: 30px;           
  text-align: left;            
  max-width: 800px;           
}

/* Hero Section */
.hero {
  position: relative;
  width: 100%;
  height: 800px;                
  overflow: hidden;
}

/* bg image */
.hero-bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Row container: heading + paragraph box side by side */
.hero-row {
  position: absolute;
  top: 50%;                    
  right: 60px;                   
  left: 100px;                   
  transform: translateY(-50%);
  display: flex;
  gap: 10px;                     
  align-items: flex-start;      
  z-index: 2;                    
}

/* Heading */
.hero-title {
  font-size: 3rem;
  color: #fff;
  margin: 0;
  line-height: 1.1;
}

/* Paragraph box */
.hero-content {
  background-color: rgba(255, 255, 255, 0.9);
  padding: 30px 40px;
  max-width: 400px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

/* Paragraph inside box */
.hero-content {
  margin: 0;
  font-size: 1rem;
  line-height: 1.5;
  color: #4A4947;
}

/* menu grid container */
.crowd-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;                    
}

/* Individual menu items */
.crowd-item {
  flex: 1 1 250px;       
  max-width: 300px;       
  display: flex;
  flex-direction: column; 
  align-items: flex-start; 
}

/* Item labels */
.item-label {
  margin-top: 10px;
  text-align: left;       
  font-weight: 100;
  font-size: 1rem;
  width: 100%;           
}

/* Item images */
.crowd-item img {
  width: 100%;
  height: auto;
}

/* Item labels */
.item-label {
  margin-top: 10px;
  text-align: left;
  font-weight: 500;
  font-size: 1rem;
}

/* Full menu button */
.fullmenu-btn {
  display: inline-block;
  margin-top: 20px;
  padding: 12px 30px;
  background-color: #E77A8B;
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  max-width: 150px;
  text-align: center;
  transition: background 0.3s;

}

.fullmenu-btn:hover {
  background-color: #B17457;
}


/* === Services === */
.private-experience-section {
  background-color: #FBF7F0;
  padding: 120px 0;
  color: #4A4947;
  font-family: "Funnel Display", system-ui;
}

.private-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
}

.private-inner h2 {
  text-align: left;
  margin-bottom: 40px;
}

.private-inner p {
  max-width: 1200px;
  margin: 0 auto 20px;
  text-align: left;
  line-height: 1.7;
}

.findout-btn {
  display: inline-block;
  margin: 40px auto 100px;
  padding: 12px 30px;
  background-color: #E77A8B;
  color: #fff;
  text-decoration: none;
  font-weight: 500;
  text-align: left;
  transition: background-color 0.3s ease;
}

.findout-btn:hover {
  background-color: #B17457;
}

/* Advantages section */
.advantages {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 120px;
}

.advantages-item {
  margin-bottom: 32px;
}

.advantages-item h3 {
  font-weight: 600;
  margin-bottom: 12px;
}

.advantages-item p {
  margin: 0 auto;
  max-width: 500px;
  line-height: 1.6;
}

/* Services grid */
.services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 60px;
}

.services-grid img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Accordion */
.accordion {
  max-width: 1200px;
  margin: 60px auto 0;
}

.accordion-button {
  font-weight: 600;
  color: #4A4947;
  background-color: transparent;
  border: none;
  padding: 16px;
  text-align: left;
  width: 100%;
  cursor: pointer;
  transition: color 0.3s ease;
}

.accordion-button:not(.collapsed) {
  color: #4A4947;
}

.accordion-body {
  line-height: 1.7;
  padding: 12px 20px 20px;
  border-top: 1px solid #ccc;
}


/* === Find Us === */

/* Shared map styles */
.find-us-map iframe {
  width: 100%;
  height: 400px;
  border: 0;
  display: block;
}

/* Find Us page map — full width */
.fullwidth-map {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}


.find-us-section {
  background-color: #FBF7F0;
  padding: 100px 0;
  color: #4A4947;
}
.find-us-grid {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;

  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-areas:
    "location contact instagram"
    "hours    .        .";
  row-gap: 80px;
  column-gap: 80px;
}

.find-us-section h2 {
  max-width: 1100px;
  margin: 0 auto 60px;
  padding: 0 40px;

  font-weight: 600;
}


.find-us-section h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: 16px;
}

.find-us-section p {
  line-height: 1.7;
  margin: 0;
}

.hours-grid {
  display: grid;
  grid-template-columns: auto auto;
  column-gap: 48px;
}

.hours-grid p {
  line-height: 1.8;
}

.find-us-grid > div > p:first-child {
  font-weight: 600;
  margin-bottom: 16px;
}

.find-us-grid > div > p:first-child {
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}

.find-us-section a {
  color: #4A4947;
  text-decoration: none;
  transition: color 0.3s ease;
}

.find-us-section a:hover {
  color: #B17457;
}

/* === Footer === */ 
.footer { 
  background-color: #E77A8B; 
  color: white; 
  text-align: center; 
  padding: 1px; 
  font-size: 0.9rem; 
}
