/* ===========================================================
   DreamPagesCo Funnel Website — Stylesheet
   Ocean / mermaid theme. Plain CSS, no frameworks.
=========================================================== */

:root{
  --teal:#1b9aaa;
  --teal-dark:#147885;
  --navy:#14415c;
  --gold:#f4a259;
  --coral:#ef767a;
  --bg:#f3fbfc;
  --bg-alt:#e6f6f8;
  --card:#ffffff;
  --text:#1d3a4a;
  --muted:#5b7785;
  --line:#d6ecef;
  --shadow:0 6px 24px rgba(20,65,92,.10);
  --radius:16px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Nunito',system-ui,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
}
h1,h2,h3,.brand-name{font-family:'Baloo 2',system-ui,sans-serif;line-height:1.2}
img{max-width:100%;display:block}
a{color:var(--teal-dark);text-decoration:none}

.container{max-width:1120px;margin:0 auto;padding:0 20px}
.container-narrow{max-width:760px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-weight:700;font-family:'Baloo 2',sans-serif;
  padding:13px 26px;border-radius:50px;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 6px 16px rgba(27,154,170,.35)}
.btn-primary:hover{background:var(--teal-dark);color:#fff}
.btn-ghost{background:transparent;color:var(--teal-dark);border-color:var(--teal)}
.btn-ghost:hover{background:var(--teal);color:#fff}
.btn-small{padding:8px 18px;font-size:.9rem}
.btn-lg{padding:16px 34px;font-size:1.1rem}
.btn-block{display:block;width:100%;margin-top:12px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{width:42px;height:42px;border-radius:50%;object-fit:cover}
.brand-name{font-size:1.35rem;font-weight:700;color:var(--navy)}
.nav{display:flex;align-items:center;gap:22px}
.nav a{color:var(--navy);font-weight:600}
.nav a:hover{color:var(--teal)}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;color:var(--navy);cursor:pointer}

/* ---------- Hero ---------- */
.hero{
  background:linear-gradient(160deg,#d3f0f4 0%, #eafaf7 55%, var(--bg) 100%);
  padding:64px 0 72px;
}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:2.8rem;color:var(--navy);margin-bottom:14px}
.lead{font-size:1.2rem;color:var(--muted);margin-bottom:26px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.hero-note{font-size:.9rem;color:var(--muted)}
.hero-img img{border-radius:var(--radius);box-shadow:var(--shadow)}

/* ---------- Sections ---------- */
.section{padding:64px 0}
.section-alt{background:var(--bg-alt)}
.section-title{font-size:2rem;color:var(--navy);text-align:center;margin-bottom:10px}
.section-sub{text-align:center;color:var(--muted);max-width:640px;margin:0 auto 38px;font-size:1.08rem}

/* ---------- Free pages grid ---------- */
.page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.page-card{
  background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);
  text-align:center;transition:transform .18s ease;
}
.page-card:hover{transform:translateY(-4px)}
.page-card img{
  border-radius:10px;border:1px solid var(--line);aspect-ratio:1/1.29;object-fit:cover;width:100%;
}
.page-card h3{margin:14px 0 4px;font-size:1.15rem;color:var(--navy)}

/* ---------- Ad slot ---------- */
.ad-wrap{padding:18px 20px;text-align:center}
.ad-placeholder{
  border:1px dashed var(--line);border-radius:10px;color:#9bb4bd;
  padding:18px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
}

/* ---------- Full book funnel ---------- */
.book-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:center}
.book-img img{border-radius:var(--radius);box-shadow:var(--shadow)}
.tag{
  display:inline-block;background:var(--gold);color:#5a3000;font-weight:700;
  font-size:.78rem;padding:5px 14px;border-radius:50px;text-transform:uppercase;letter-spacing:.05em;
}
.book-text h2{font-size:2rem;color:var(--navy);margin:12px 0 12px}
.checklist{list-style:none;margin:18px 0}
.checklist li{padding:6px 0 6px 30px;position:relative;color:var(--text)}
.checklist li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:800}
.price{font-size:1.05rem;color:var(--muted);margin:14px 0 18px}
.price span{font-family:'Baloo 2',sans-serif;font-size:2rem;color:var(--coral);font-weight:700;margin-right:6px}

/* ---------- Features ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feature{background:var(--card);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow);text-align:center}
.feature-icon{font-size:2.4rem;margin-bottom:10px}
.feature h3{color:var(--navy);margin-bottom:8px;font-size:1.25rem}
.feature p{color:var(--muted)}

/* ---------- Steps & tips ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:880px;margin:0 auto 34px}
.step{background:var(--card);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);text-align:center}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;
  background:var(--teal);color:#fff;font-family:'Baloo 2',sans-serif;font-size:1.3rem;font-weight:700;margin-bottom:10px;
}
.tips-box{background:var(--card);border-radius:var(--radius);padding:28px 32px;box-shadow:var(--shadow);max-width:720px;margin:0 auto}
.tips-box h3{color:var(--navy);margin-bottom:10px}
.tips-box ul{margin-left:20px}
.tips-box li{margin:8px 0;color:var(--muted)}

/* ---------- FAQ ---------- */
.faq details{
  background:var(--card);border-radius:12px;box-shadow:var(--shadow);margin-bottom:12px;padding:0 20px;
  border:1px solid var(--line);
}
.faq summary{
  cursor:pointer;font-weight:700;font-family:'Baloo 2',sans-serif;color:var(--navy);
  padding:16px 0;list-style:none;position:relative;
}
.faq summary::after{content:"+";position:absolute;right:0;color:var(--teal);font-size:1.4rem}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 16px;color:var(--muted)}

/* ---------- Final CTA ---------- */
.final-cta{background:linear-gradient(135deg,var(--teal) 0%, var(--navy) 100%);color:#fff;text-align:center}
.final-cta h2{color:#fff;font-size:2rem;margin-bottom:10px}
.final-cta p{color:#d7f1f5;margin-bottom:24px;font-size:1.1rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#cfe3ec;padding:44px 0 20px}
.footer-inner{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-start}
.footer-brand{max-width:300px}
.footer-brand .brand-logo{margin-bottom:10px}
.footer-brand p{color:#a9c6d2}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav a{color:#cfe3ec}
.footer-nav a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:30px;padding-top:18px;text-align:center}
.footer-bottom p{color:#8fb2c0;font-size:.9rem}

/* ---------- Legal / content pages ---------- */
.page-body{max-width:760px;margin:0 auto;padding:54px 20px}
.page-body h1{font-size:2.2rem;color:var(--navy);margin-bottom:18px}
.page-body h2{font-size:1.4rem;color:var(--navy);margin:28px 0 10px}
.page-body p,.page-body li{color:var(--text);margin-bottom:12px}
.page-body ul{margin-left:22px}
.page-body a{color:var(--teal-dark);text-decoration:underline}
.page-body .updated{color:var(--muted);font-size:.92rem;margin-bottom:24px}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .hero-inner,.book-inner{grid-template-columns:1fr;gap:30px}
  .hero-img{order:-1;max-width:420px;margin:0 auto}
  .page-grid,.feature-grid,.steps{grid-template-columns:1fr}
  .hero h1{font-size:2.2rem}
  .nav{
    display:none;position:absolute;top:68px;left:0;right:0;background:#fff;
    flex-direction:column;gap:0;padding:10px 0;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
  }
  .nav.open{display:flex}
  .nav a{padding:12px 20px;width:100%}
  .nav-toggle{display:block}
  .footer-inner{flex-direction:column}
}
@media(max-width:520px){
  .page-grid{grid-template-columns:1fr 1fr;gap:14px}
  .page-card h3{font-size:1rem}
  .section{padding:48px 0}
}
