/* Start custom CSS for html, class: .elementor-element-307f909 */<style>

/* ================================
   GLOBAL STYLES
================================ */
.hoc-homepage {
  background: #0e0e0e;
  color: #f5f5f5;
  font-family: Arial, Helvetica, sans-serif;
  overflow: hidden;
}

.hoc-homepage .container {
  width: 100%;
  max-width: 1200px;
  margin: auto;
  padding: 0 20px;
}
body{
  background:#0e0e0e !important;
}

/* ================================
   HERO SECTION
================================ */
.hero{
  width:100vw;
  margin-left:calc(50% - 50vw);

  min-height:100vh;
  position:relative;

  display:flex;
  align-items:center;

  background:
  linear-gradient(
    90deg,
    rgba(0,0,0,0.88) 15%,
    rgba(0,0,0,0.72) 55%,
    rgba(0,0,0,0.82) 100%
  ),
    url('https://hopeovercoffee.com/wp-content/uploads/2026/05/Hope-in-every-sip.png');

  background-size: cover;
  background-position: center;
    background-repeat:no-repeat;

  overflow:hidden;
}

/* CONTENT */
.hero-content {
  max-width: 760px;
  padding: 180px 0 140px;
}

/* SMALL TEXT */
.hero-subtitle {
  color: #c89b3c;
  font-size: 14px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 20px;
  font-weight: bold;
}

/* MAIN TITLE */
.hero h1 {
  color:#ffffff;
  font-size: clamp(52px, 8vw, 96px);
  line-height: 1.05;
  margin-bottom: 25px;
  font-weight: 800;
  letter-spacing: -2px;
}

/* TEXT */
.hero p {
  font-size: 20px;
  color: #d0d0d0;
  max-width: 600px;
  margin-bottom: 40px;
  line-height: 1.7;
}

/* BUTTONS */
.hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}

.btn {
  display: inline-block;
  padding: 15px 30px;
  border-radius: 4px;
  text-decoration: none;
  font-weight: bold;
  transition: 0.3s ease;
}

/* PRIMARY */
.btn-primary {
  background: #c89b3c;
  color: #0e0e0e;
}

.btn-primary:hover {
  background: #ddb04a;
}

/* SECONDARY */
.btn-secondary {
  border: 1px solid #c89b3c;
  color: #c89b3c;
  background: transparent;
}

.btn-secondary:hover {
  background: #c89b3c;
  color: #0e0e0e;
}

/* ================================
   MOBILE
================================ */
@media(max-width:768px){

  .hero {
    min-height: auto;
  }

  .hero-content {
    padding: 140px 0 100px;
  }

  .hero h1 {
    font-size: 46px;
  }

  .hero p {
    font-size: 18px;
  }

}
/* ================================
   PODCAST SECTION
================================ */
.podcast-section {
  padding: 120px 0;
  background: #121212;
}

.podcast-section h2 {
  font-size: 52px;
  margin-bottom: 15px;
  font-weight: 800;
  text-align: center;
  color: #ffffff;
}

.podcast-intro {
  text-align: center;
  color: #cfcfcf;
  font-size: 20px;
  margin-bottom: 50px;
}

/* BADGE */
.podcast-badge {
  display: inline-block;
  margin: 0 auto 25px;
  padding: 10px 18px;
  border: 1px solid #333;
  border-radius: 50px;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #c89b3c;
  background: #1a1a1a;
}

.podcast-section .container {
  text-align: center;
}

/* FEATURED VIDEO */
.featured-video {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  margin-bottom: 60px;
  overflow: hidden;
  border-radius: 10px;
}

.featured-video iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}

/* EPISODE SCROLL */
.episodes-scroll {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  padding-bottom: 10px;
  scroll-snap-type: x mandatory;
}

/* SCROLLBAR */
.episodes-scroll::-webkit-scrollbar {
  height: 8px;
}

.episodes-scroll::-webkit-scrollbar-thumb {
  background: #333;
  border-radius: 20px;
}

/* EPISODE CARD */
.episode-card {
  min-width: 320px;
  background: #1a1a1a;
  border-radius: 8px;
  overflow: hidden;
  text-decoration: none;
  transition: 0.3s ease;
  border: 1px solid #222;
  scroll-snap-align: start;
}

.episode-card:hover {
  transform: translateY(-5px);
  border-color: #c89b3c;
}

/* IMAGE */
.episode-card img {
  width: 100%;
  display: block;
}

/* INFO */
.episode-info {
  padding: 20px;
  text-align: left;
}

.episode-info h3 {
  color: #ffffff;
  margin-bottom: 10px;
  font-size: 20px;
}

.episode-info p {
  color: #bdbdbd;
  font-size: 15px;
  line-height: 1.6;
}

/* BUTTON */
.podcast-button-wrap {
  margin-top: 50px;
}

/* MOBILE */
@media(max-width:768px){

  .podcast-section {
    padding: 90px 0;
  }

  .podcast-section h2 {
    font-size: 38px;
  }

  .podcast-intro {
    font-size: 18px;
  }

  .episode-card {
    min-width: 280px;
  }

}
/* ================================
   REAL STORIES SECTION
================================ */
.stories-section {
  padding: 120px 0;
  background: #0e0e0e;
}

/* HEADER */
.stories-header {
  text-align: center;
  max-width: 750px;
  margin: auto auto 70px;
}

/* TAG */
.section-tag {
  color: #c89b3c;
  font-size: 13px;
  letter-spacing: 2px;
  font-weight: bold;
  text-transform: uppercase;
  margin-bottom: 20px;
}

/* TITLE */
.stories-header h2 {
  font-size: 58px;
  margin-bottom: 20px;
  line-height: 1.1;
  color: #ffffff;
}

/* TEXT */
.stories-header p {
  font-size: 20px;
  color: #cfcfcf;
  line-height: 1.8;
}

/* GRID */
.stories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 30px;
}

/* CARD */
.story-card {
  background: #171717;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #222;
  transition: 0.3s ease;
}

.story-card:hover {
  transform: translateY(-6px);
  border-color: #c89b3c;
}

/* VIDEO */
.story-video {
  position: relative;
  padding-bottom: 177%;
  height: 0;
  overflow: hidden;
}

.story-video iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}

/* CONTENT */
.story-content {
  padding: 25px;
}

.story-content h3 {
  font-size: 24px;
  margin-bottom: 15px;
  color: #ffffff;
}

.story-content p {
  font-size: 16px;
  color: #bdbdbd;
  line-height: 1.7;
}

/* CTA */
.stories-cta {
  margin-top: 60px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 15px;
}

/* MOBILE */
@media(max-width:768px){

  .stories-section {
    padding: 90px 0;
  }

  .stories-header h2 {
    font-size: 42px;
  }

  .stories-header p {
    font-size: 18px;
  }

}
/* ================================
   WHAT THIS IS SECTION
================================ */
.what-is-section {
  padding: 120px 0;
  background: #121212;
}

/* HEADER */
.what-header {
  text-align: center;
  max-width: 800px;
  margin: auto auto 70px;
}

.what-header h2 {
  font-size: 56px;
  margin-bottom: 20px;
  line-height: 1.1;
  color: #ffffff;
}

.what-header p {
  font-size: 20px;
  color: #cfcfcf;
  line-height: 1.8;
}

/* GRID */
.what-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 25px;
}

/* CARD */
.what-card {
  background: #1a1a1a;
  padding: 40px 30px;
  border-radius: 10px;
  border: 1px solid #222;
  text-decoration: none;
  transition: 0.3s ease;
  display: flex;
  flex-direction: column;
}

.what-card:hover {
  transform: translateY(-6px);
  border-color: #c89b3c;
}

/* ICON */
.what-icon {
  font-size: 38px;
  margin-bottom: 20px;
}

/* TITLE */
.what-card h3 {
  font-size: 24px;
  color: #ffffff;
  margin-bottom: 15px;
  line-height: 1.3;
}

/* TEXT */
.what-card p {
  color: #bdbdbd;
  line-height: 1.7;
  font-size: 16px;
}

/* MOBILE */
@media(max-width:768px){

  .what-is-section {
    padding: 90px 0;
  }

  .what-header h2 {
    font-size: 42px;
  }

  .what-header p {
    font-size: 18px;
  }

}
/* ================================
   5-DAY RESET EMAIL BUTTON SECTION
================================ */

.reset-form-section{
    width:100%;
    padding:90px 20px;
    background:#0B0F14;
}

.reset-form-box{
    max-width:760px;
    margin:auto;
    padding:55px 45px;
    text-align:center;

    background:
    linear-gradient(
        180deg,
        rgba(22,28,36,.98) 0%,
        rgba(14,19,25,.98) 100%
    );

    border:1px solid rgba(255,255,255,.08);
    border-radius:28px;

    box-shadow:
    0 22px 60px rgba(0,0,0,.35);
}

.reset-form-box h2{
    font-size:42px;
    line-height:1.1;
    font-weight:800;
    color:#FFFFFF;
    margin-bottom:18px;
}

.reset-form-box p{
    font-size:18px;
    line-height:1.8;
    color:#B8C1CC;
    margin-bottom:34px;
}

.reset-email-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    min-height:64px;
    padding:0 34px;

    border-radius:14px;

    background:
    linear-gradient(
        135deg,
        #8B5E3C 0%,
        #C89B3C 100%
    );

    color:#0B0F14 !important;

    text-decoration:none !important;

    font-size:16px;
    font-weight:800;

    box-shadow:
    0 16px 36px rgba(200,155,60,.22);

    transition:
    transform .3s ease,
    box-shadow .3s ease;
}

.reset-email-btn:hover{
    transform:translateY(-3px);

    box-shadow:
    0 20px 44px rgba(200,155,60,.30);

    color:#0B0F14 !important;
}

/* Mobile */
@media(max-width:768px){

    .reset-form-section{
        padding:70px 20px;
    }

    .reset-form-box{
        padding:40px 24px;
        border-radius:22px;
    }

    .reset-form-box h2{
        font-size:32px;
    }

    .reset-form-box p{
        font-size:17px;
    }

    .reset-email-btn{
        width:100%;
        padding:0 20px;
        text-align:center;
    }
}
/* ================================
   JOIN SECTION
================================ */
.join-section {
  padding: 140px 0;
  background:
    linear-gradient(
      rgba(0,0,0,0.82),
      rgba(0,0,0,0.88)
    ),
    url('YOUR-BACKGROUND-IMAGE.jpg');

  background-size: cover;
  background-position: center;
  position: relative;
}

/* CONTENT */
.join-content {
  max-width: 760px;
  margin: auto;
  text-align: center;
}

/* TITLE */
.join-content h2 {
  font-size: 64px;
  line-height: 1.1;
  margin-bottom: 20px;
  color: #ffffff;
}

/* TEXT */
.join-text {
  font-size: 22px;
  color: #d0d0d0;
  line-height: 1.8;
  margin-bottom: 50px;
}

/* RESOURCE BOX */
.resource-box {
  background: rgba(255,255,255,0.04);
  border: 1px solid #222;
  padding: 35px;
  border-radius: 10px;
  margin-bottom: 40px;
  text-align: left;
}

.resource-box h3 {
  font-size: 28px;
  margin-bottom: 15px;
  color: #ffffff;
}

.resource-box p {
  color: #cfcfcf;
  margin-bottom: 20px;
  line-height: 1.7;
}

.resource-box ul {
  padding-left: 20px;
}

.resource-box li {
  margin-bottom: 10px;
  color: #c89b3c;
  font-weight: bold;
}

/* FORM */
.join-form {
  display: flex;
  gap: 15px;
  margin-top: 20px;
  flex-wrap: wrap;
  justify-content: center;
}

/* INPUT */
.join-form input {
  flex: 1;
  min-width: 260px;
  padding: 18px 20px;
  background: #1a1a1a;
  border: 1px solid #333;
  color: #ffffff;
  border-radius: 5px;
  font-size: 16px;
}

/* BUTTON */
.join-form button {
  padding: 18px 30px;
  border: none;
  background: #c89b3c;
  color: #0e0e0e;
  font-weight: bold;
  font-size: 16px;
  border-radius: 5px;
  cursor: pointer;
  transition: 0.3s ease;
}

.join-form button:hover {
  background: #ddb04a;
}

/* NOTE */
.join-note {
  margin-top: 20px;
  font-size: 14px;
  color: #888;
}

/* MOBILE */
@media(max-width:768px){

  .join-section {
    padding: 100px 0;
  }

  .join-content h2 {
    font-size: 42px;
  }

  .join-text {
    font-size: 18px;
  }

  .resource-box {
    padding: 25px;
  }

}

/* ================================
   FINAL PUSH SECTION
================================ */
.final-push {
  position: relative;
  padding: 160px 0;

  background:
    linear-gradient(
      rgba(0,0,0,0.82),
      rgba(0,0,0,0.92)
    ),
    url('YOUR-FINAL-BACKGROUND.jpg');

  background-size: cover;
  background-position: center;
  overflow: hidden;
}

/* CONTENT */
.final-push-content {
  text-align: center;
  max-width: 850px;
  margin: auto;
}

/* TITLE */
.final-push-content h2 {
  font-size: 72px;
  line-height: 1.05;
  margin-bottom: 25px;
  font-weight: 800;
  letter-spacing: -2px;
  color: #ffffff;
}

/* TEXT */
.final-push-content p {
  font-size: 22px;
  color: #d0d0d0;
  line-height: 1.8;
  margin-bottom: 50px;
}

/* BUTTONS */
.final-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 18px;
}

/* MOBILE */
@media(max-width:768px){

  .final-push {
    padding: 110px 0;
  }

  .final-push-content h2 {
    font-size: 46px;
  }

  .final-push-content p {
    font-size: 18px;
  }

}
</style>/* End custom CSS */