/* ============================================
   OUR STORY PAGE
   ============================================ */

/* Equal spacing for all modules */
.our-story-page .bottom1.box {
    padding: 40px 0;
}

.our-story-page .ot-hero {
    position: relative;
    width: 100%;
    min-height: 420px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: url('/images/OurStory/ourstoryhero.jpg') center / cover no-repeat;
    margin: 30px 0;
    padding: 80px 0;
    overflow: visible;
}
/* ============================================
   OUR STORY PAGE
   ============================================ */

/* Equal spacing for all modules */
.our-story-page .bottom1.box {
    padding: 40px 0;
}

.our-story-page .ot-hero {
    position: relative;
    width: 100%;
    min-height: 420px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: url('/images/OurStory/ourstoryhero.jpg') center / cover no-repeat;
    margin: 30px 0;
    padding: 80px 0;
    overflow: visible;
}

h2.ourstory { color : #DB2164; }
h2.ourstoryhead { color : #DB2164; font-size : 20px !important;  }

.our-story-page .ot-hero .ot-hero-content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: #ffffff;
}

/* ── Hero bubbles ── */

.our-story-page .ot-hero .ot-bubbles-bottom {
    position: absolute;
    left: 50%;
    width: 100%;
    max-width: 1920px;
    height: 160px;
    background: url("/images/Home/circles.png") center / contain no-repeat;
    z-index: 2;
    pointer-events: none;
    bottom: -80px;
    transform: translateX(-50%) scaleY(-1);
}

.our-story-page #gkHeaderMod .ot-hero .ot-content h1 {
    color: #ffffff !important;
}

.our-story-page #gkHeaderMod .ot-hero .ot-content * {
    color: #ffffff !important;
}

/* ============================================
   MEET JACQUI (side-by-side layout)
   ============================================ */

.our-story-page .ot-meet-jacqui {
    padding: 60px 0;
}

.our-story-page .ot-meet-jacqui-inner {
    display: flex;
    align-items: center;
    gap: 50px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

.our-story-page .ot-meet-jacqui-image {
    flex: 0 0 40%;
}

.our-story-page .ot-meet-jacqui-image img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    display: block;
}

.our-story-page .ot-meet-jacqui-content {
    flex: 1;
}

.our-story-page .ot-meet-jacqui-content h2 {
    font-size: 2rem;
    margin-bottom: 10px;
}

.our-story-page .ot-meet-jacqui-content h3 {
    font-size: 1.2rem;
    font-weight: 400;
    margin-bottom: 24px;
    color: #555;
}

.our-story-page .ot-jacqui-quote {
    font-size: 1.15rem;
    font-style: italic;
    color: #444;
    border-left: 4px solid #f90;
    padding-left: 16px;
    line-height: 1.7;
}

/* ============================================
   MEET JACQUI MODULE (letter card)
   ============================================ */

.our-story-page .ot-jacqui-wrap {
    background: #fdf6ee;
    border-radius: 18px;
    padding: 32px 44px 44px;
    max-width: 860px;
    margin: 0 auto;
    font-family: 'Alan Sans', sans-serif;
    color: #3a2a1e;
    position: relative;
}

/* ── Heading across the top ── */
.our-story-page .ot-jacqui-top {
    text-align: center;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.our-story-page .ot-jacqui-top h2 {
    /* font-weight: 700; */
    /* font-size: 1.9rem; */
    /* line-height: 1.2; */
    /* color: #c0392b; */
    /* margin: 0 0 16px; */
}

.our-story-page .ot-jacqui-top h2 em {
    font-style: italic;
    color: #e8413c;
}

/* ── Photo centred, overlapping the card ── */
.our-story-page .ot-jacqui-photo-wrap {
    display: flex;
    justify-content: center;
    position: relative;
    z-index: 2;
    margin-top: 20px;
    margin-bottom: -80px;
}

.our-story-page .ot-jacqui-photo-ring {
    position: relative;
    width: 160px;
    height: 160px;
}

.our-story-page .ot-jacqui-photo {
    width: 160px;
    height: 160px;
    border-radius: 50%;
    object-fit: cover;
    object-position: top center;
    display: block;
    position: relative;
    z-index: 1;
    border: 4px solid #fff;
    box-shadow: 0 8px 28px rgba(0,0,0,0.14);
}

/* ── White letter card ── */
.our-story-page .ot-jacqui-letter {
    background: #ffffff;
    border-radius: 14px;
    padding: 100px 42px 38px;
    box-shadow: 0 4px 28px rgba(60,30,10,0.09);
    position: relative;
    z-index: 1;
}

.our-story-page .ot-jacqui-letter table {
    width: 100%;
    border-collapse: collapse;
}

.our-story-page .ot-jacqui-letter td {
    padding: 0;
    vertical-align: top;
}

.our-story-page .ot-jacqui-letter p {
    color: #4a3828;
}

.our-story-page .ot-jacqui-sign-off {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px dashed #f0d9c0;
}

.our-story-page .ot-jacqui-sign-off p {
    margin: 0 0 4px;
    font-weight: 600;
    color: #3a2a1e;
}

.our-story-page .ot-jacqui-sign-off p.signature {
    font-style: italic;
    font-size: 1.45rem;
    color: #e8413c;
    font-weight: 400;
    margin: 4px 0;
}

/* ============================================
   MAGICAL MODULE
   ============================================ */

.our-story-page .ot-magical-wrap {
    max-width: 1100px;
    margin: 0 auto;
    font-family: 'Alan Sans', sans-serif;
}

.our-story-page .ot-magical-title {
    text-align: center;
    margin-bottom: 48px;
}

.our-story-page .ot-magical-title h2 {
    /* font-size: 2rem; */
    /* font-weight: 700; */
    /* color: #c0392b; */
    /* margin: 0; */
    /* line-height: 1.2; */
}

.our-story-page .ot-magical-title h2 em {
    font-style: italic;
    color: #e8413c;
}

.our-story-page .ot-magical-cols {
    display: flex;
    gap: 32px;
}

.our-story-page .ot-magical-col {
    flex: 1;
    background: #ffffff;
    border-radius: 14px;
    padding: 36px 32px;
    box-shadow: 0 4px 24px rgba(60,30,10,0.08);
}

.our-story-page .ot-magical-col h2 {
    /* font-size: 1.5rem; */
    /* font-weight: 700; */
    /* color: #c0392b; */
    /* margin: 0 0 16px; */
}

.our-story-page .ot-magical-col p {
    color: #4a3828;
    line-height: 1.75;
    margin: 0;
}

/* ============================================
   TOGETHER MODULE
   ============================================ */

.our-story-page .ot-together-wrap {
    max-width: 860px;
    margin: 0 auto;
    font-family: 'Alan Sans', sans-serif;
    text-align: center;
}

.our-story-page .ot-together-wrap h2 {
    /* font-size: 2rem; */
    /* font-weight: 700; */
    /* color: #c0392b; */
    /* margin: 0 0 24px; */
    /* line-height: 1.2; */
}

.our-story-page .ot-together-wrap h2 em {
    font-style: italic;
    color: #e8413c;
}

.our-story-page .ot-together-wrap p {
    color: #4a3828;
    line-height: 1.75;
    margin: 0 0 36px;
}

.our-story-page .ot-together-btn {
    display: inline-block;
    background: #DB2164;
    color: #ffffff;
    text-decoration: none;
    font-weight: 700;
    padding: 14px 32px;
    border-radius: 50px;
    transition: background 0.2s ease;
}

.our-story-page .ot-together-btn:hover {
    background: #593606;
    color: #ffffff;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 767px) {
    .our-story-page .ot-meet-jacqui-inner {
        flex-direction: column;
    }

    .our-story-page .ot-meet-jacqui-image {
        flex: 0 0 100%;
    }

    .our-story-page .ot-magical-cols {
        flex-direction: column;
    }
}

@media (max-width: 560px) {
    .our-story-page .ot-jacqui-wrap   { padding: 24px 18px 32px; }
    .our-story-page .ot-jacqui-letter { padding: 100px 22px 28px; }
    .our-story-page .ot-jacqui-top h2 { font-size: 1.45rem; }
}

h2.ourstory { color : #DB2164}
.our-story-page .ot-hero .ot-hero-content {
    position: relative;
    z-index: 2;
    text-align: center;
    color: #ffffff;
}

/* ── Hero bubbles ── */

.our-story-page .ot-hero .ot-bubbles-bottom {
    position: absolute;
    left: 50%;
    width: 100%;
    max-width: 1920px;
    height: 160px;
    background: url("/images/Home/circles.png") center / contain no-repeat;
    z-index: 2;
    pointer-events: none;
    bottom: -80px;
    transform: translateX(-50%) scaleY(-1);
}

.our-story-page #gkHeaderMod .ot-hero .ot-content h1 {
    color: #ffffff !important;
}

.our-story-page #gkHeaderMod .ot-hero .ot-content * {
    color: #ffffff !important;
}

/* ============================================
   MEET JACQUI (side-by-side layout)
   ============================================ */

.our-story-page .ot-meet-jacqui {
    padding: 60px 0;
}

.our-story-page .ot-meet-jacqui-inner {
    display: flex;
    align-items: center;
    gap: 50px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

.our-story-page .ot-meet-jacqui-image {
    flex: 0 0 40%;
}

.our-story-page .ot-meet-jacqui-image img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    display: block;
}

.our-story-page .ot-meet-jacqui-content {
    flex: 1;
}

.our-story-page .ot-meet-jacqui-content h2 {
    font-size: 2rem;
    margin-bottom: 10px;
}

.our-story-page .ot-meet-jacqui-content h3 {
    font-size: 1.2rem;
    font-weight: 400;
    margin-bottom: 24px;
    color: #555;
}

.our-story-page .ot-jacqui-quote {
    font-size: 1.15rem;
    font-style: italic;
    color: #444;
    border-left: 4px solid #f90;
    padding-left: 16px;
    line-height: 1.7;
}

/* ============================================
   MEET JACQUI MODULE (letter card)
   ============================================ */

.our-story-page .ot-jacqui-wrap {
    background: #fdf6ee;
    border-radius: 18px;
    padding: 32px 44px 44px;
    max-width: 860px;
    margin: 0 auto;
    font-family: 'Alan Sans', sans-serif;
    color: #3a2a1e;
    position: relative;
}

/* ── Heading across the top ── */
.our-story-page .ot-jacqui-top {
    text-align: center;
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.our-story-page .ot-jacqui-top h2 {
    /* font-weight: 700; */
    /* font-size: 1.9rem; */
    /* line-height: 1.2; */
    /* color: #c0392b; */
    /* margin: 0 0 16px; */
}

.our-story-page .ot-jacqui-top h2 em {
    font-style: italic;
    color: #e8413c;
}

/* ── Photo centred, overlapping the card ── */
.our-story-page .ot-jacqui-photo-wrap {
    display: flex;
    justify-content: center;
    position: relative;
    z-index: 2;
    margin-top: 20px;
    margin-bottom: -80px;
}

.our-story-page .ot-jacqui-photo-ring {
    position: relative;
    width: 160px;
    height: 160px;
}

.our-story-page .ot-jacqui-photo {
    width: 160px;
    height: 160px;
    border-radius: 50%;
    object-fit: cover;
    object-position: top center;
    display: block;
    position: relative;
    z-index: 1;
    border: 4px solid #fff;
    box-shadow: 0 8px 28px rgba(0,0,0,0.14);
}

/* ── White letter card ── */
.our-story-page .ot-jacqui-letter {
    background: #ffffff;
    border-radius: 14px;
    padding: 100px 42px 38px;
    box-shadow: 0 4px 28px rgba(60,30,10,0.09);
    position: relative;
    z-index: 1;
}

.our-story-page .ot-jacqui-letter table {
    width: 100%;
    border-collapse: collapse;
}

.our-story-page .ot-jacqui-letter td {
    padding: 0;
    vertical-align: top;
}

.our-story-page .ot-jacqui-letter p {
    color: #4a3828;
}

.our-story-page .ot-jacqui-sign-off {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px dashed #f0d9c0;
}

.our-story-page .ot-jacqui-sign-off p {
    margin: 0 0 4px;
    font-weight: 600;
    color: #3a2a1e;
}

.our-story-page .ot-jacqui-sign-off p.signature {
    font-style: italic;
    font-size: 1.45rem;
    color: #e8413c;
    font-weight: 400;
    margin: 4px 0;
}

/* ============================================
   MAGICAL MODULE
   ============================================ */

.our-story-page .ot-magical-wrap {
    max-width: 1100px;
    margin: 0 auto;
    font-family: 'Alan Sans', sans-serif;
}

.our-story-page .ot-magical-title {
    text-align: center;
    margin-bottom: 48px;
}

.our-story-page .ot-magical-title h2 {
    /* font-size: 2rem; */
    /* font-weight: 700; */
    /* color: #c0392b; */
    /* margin: 0; */
    /* line-height: 1.2; */
}

.our-story-page .ot-magical-title h2 em {
    font-style: italic;
    color: #e8413c;
}

.our-story-page .ot-magical-cols {
    display: flex;
    gap: 32px;
}

.our-story-page .ot-magical-col {
    flex: 1;
    background: #ffffff;
    border-radius: 14px;
    padding: 36px 32px;
    box-shadow: 0 4px 24px rgba(60,30,10,0.08);
}

.our-story-page .ot-magical-col h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: #c0392b;
    margin: 0 0 16px;
}

.our-story-page .ot-magical-col p {
    color: #4a3828;
    line-height: 1.75;
    margin: 0;
}

/* ============================================
   TOGETHER MODULE
   ============================================ */

.our-story-page .ot-together-wrap {
    max-width: 860px;
    margin: 0 auto;
    font-family: 'Alan Sans', sans-serif;
    text-align: center;
}

.our-story-page .ot-together-wrap h2 {
    /* font-size: 2rem; */
    /* font-weight: 700; */
    /* color: #c0392b; */
    /* margin: 0 0 24px; */
    /* line-height: 1.2; */
}

.our-story-page .ot-together-wrap h2 em {
    font-style: italic;
    color: #e8413c;
}

.our-story-page .ot-together-wrap p {
    color: #4a3828;
    line-height: 1.75;
    margin: 0 0 36px;
}

.our-story-page .ot-together-btn {
    display: inline-block;
    background: #DB2164;
    color: #ffffff;
    text-decoration: none;
    font-weight: 700;
    padding: 14px 32px;
    border-radius: 50px;
    transition: background 0.2s ease;
}

.our-story-page .ot-together-btn:hover {
    background: #593606;
    color: #ffffff;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 767px) {
    .our-story-page .ot-meet-jacqui-inner {
        flex-direction: column;
    }

    .our-story-page .ot-meet-jacqui-image {
        flex: 0 0 100%;
    }

    .our-story-page .ot-magical-cols {
        flex-direction: column;
    }
}

@media (max-width: 560px) {
    .our-story-page .ot-jacqui-wrap   { padding: 24px 18px 32px; }
    .our-story-page .ot-jacqui-letter { padding: 100px 22px 28px; }
    .our-story-page .ot-jacqui-top h2 { font-size: 1.45rem; }
}

/* =====================================================
   VALUES CARDS
   ===================================================== */
.ot-values { padding: 40px 0; }

.ot-values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  max-width: 980px;
  margin: 0 auto;
  align-items: stretch;
}

.ot-value-card {
  background: #fff;
  border-radius: 48px;
  padding: 32px 26px 34px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  box-shadow: 0 10px 30px rgba(240,138,0,0.18);
}

.ot-value-icon-wrap {
  height: 120px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  margin-bottom: 18px;
}

.ot-value-icon {
  width: 110px;
  height: auto;
  display: block;
}

.ot-value-title {
  margin: 0 0 16px;
  min-height: 48px;
  font-weight: 900;
  text-transform: lowercase;
  color: #592d06;
}

.ot-value-text {
  font-weight: 400;
  color: #592d06;
  margin: 0;
}

@media (max-width: 980px) {
  .ot-values-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
  }
}

@media (max-width: 600px) {
  .ot-value-icon-wrap {
    height: 90px;
  }
}


/* =====================================================
   HOME: ABOUT BLOCK
   ===================================================== */
.ot-about {
  padding: 30px 18px;
  margin: 30px 0;
}

.ot-about-inner,
.ot-about-panel {
  max-width: 1150px;
  margin: 0 auto;
  background: #fcecdf;
  border-radius: 22px;
  padding: 28px 24px;
  text-align: center;
}

.ot-about-inner h2,
.ot-about-panel h2 {
  color: #592d06;
  font-weight: 900;
}

.ot-about-sub {
  margin: 0 0 16px;
  color: #592d06;
  font-weight: 700;
}

.ot-about-text {
  margin: 0 auto 18px;
  max-width: 920px;
  color: #592d06;
}

.ot-about-btn,
.ot-about-cta {
  display: inline-block;
  background: #db2164;
  color: #fff !important;
  text-decoration: none;
  font-weight: 800;
  padding: 10px 18px;
  border-radius: 12px;
}

.ot-about-cta:hover {
  background-color: #592d06;
}

.ot-about-btn:hover,
.ot-about-cta:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

@media (max-width: 600px) {
  .ot-about-inner,
  .ot-about-panel {
    padding: 22px 16px;
  }
}