/*
Theme Name: The Puppy Paws
Theme URI: https://www.thepuppypaws.com/
Description: Custom child theme for The Puppy Paws — a dog walking & care service in Atlanta. Pink, cursive, paw-print aesthetic designed by Alexa (age 10).
Author: The Puppy Paws Team
Author URI: https://www.thepuppypaws.com/
Template: hello-elementor
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: puppy-paws
*/

/* =========================================================
   Google Fonts: Dancing Script (cursive) + Quicksand (body)
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Dancing+Script:wght@500;600;700&family=Quicksand:wght@400;500;600;700&display=swap');

/* =========================================================
   CSS variables — the brand palette
   ========================================================= */
:root {
  --pp-pink:        #f4a3b8;   /* main pink (matches "See you soon" cursive) */
  --pp-pink-dark:   #e07a93;   /* hover/link */
  --pp-pink-soft:   #fde4ec;   /* very pale pink backgrounds */
  --pp-cream:       #fff8f3;   /* page background */
  --pp-brown:       #8b5a3c;   /* paw print brown */
  --pp-text:        #4a3a3a;   /* body text — soft warm dark */
  --pp-green-grass: #a8d8a0;   /* accent (matches grass on Thank You page) */
  --font-cursive:   'Dancing Script', 'Brush Script MT', cursive;
  --font-body:      'Quicksand', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* =========================================================
   Hide the parent theme's auto-prepended page title
   (we provide our own H1 inside each page hero)
   ========================================================= */
.page header.page-header,
.page .entry-header,
.page h1.entry-title,
.page h1.page-title {
  display: none !important;
}

/* Reset wrapper padding from Hello Elementor so our hero spans full width */
.site-main, main.site-main, .page-content {
  padding: 0 !important;
  margin: 0 !important;
  max-width: none !important;
}

.entry-content, .page .entry-content {
  margin: 0 !important;
}

/* =========================================================
   Base / typography
   ========================================================= */
html, body {
  background: var(--pp-cream);
  color: var(--pp-text);
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.65;
}

body {
  /* subtle paw-print pattern in the corners */
  background-image:
    radial-gradient(circle at 20px 20px, rgba(244,163,184,0.08) 6px, transparent 7px),
    radial-gradient(circle at 60px 80px, rgba(244,163,184,0.06) 4px, transparent 5px);
  background-size: 200px 200px;
}

h1, h2, h3, .pp-script {
  font-family: var(--font-cursive);
  color: var(--pp-pink);
  font-weight: 600;
  line-height: 1.2;
}

h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
h2 { font-size: clamp(2rem, 5vw, 3.4rem); }
h3 { font-size: clamp(1.6rem, 4vw, 2.4rem); }

h4, h5, h6 {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--pp-text);
}

a { color: var(--pp-pink-dark); text-decoration: none; }
a:hover { color: var(--pp-pink); text-decoration: underline; }

p { margin: 0 0 1rem; }

/* =========================================================
   Layout — site-wide container
   ========================================================= */
.pp-container { max-width: 1100px; margin: 0 auto; padding: 0 1.25rem; }
.pp-section   { padding: 4rem 0; }
.pp-section--soft { background: var(--pp-pink-soft); }

/* =========================================================
   Site header
   ========================================================= */
.site-header,
header.site-header {
  background: var(--pp-cream);
  border-bottom: 2px dashed var(--pp-pink);
  padding: 1rem 0;
}

.site-header .site-title,
.site-header h1.site-title a {
  font-family: var(--font-cursive);
  color: var(--pp-pink-dark) !important;
  font-size: 2.4rem;
  text-decoration: none;
}

.site-header .site-description {
  font-style: italic;
  color: var(--pp-brown);
  font-size: 1rem;
}

/* Nav menu */
nav.site-navigation ul,
.menu, .nav-menu {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 1.6rem;
  padding: 0;
  margin: 0.5rem 0 0;
  justify-content: center;
}

.menu li a, .nav-menu li a, nav a {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--pp-text);
  text-transform: lowercase;
  font-size: 1.05rem;
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  transition: all 0.2s ease;
}

.menu li a:hover, .nav-menu li a:hover, nav a:hover {
  background: var(--pp-pink-soft);
  color: var(--pp-pink-dark);
  text-decoration: none;
}

.menu li.current-menu-item a,
.nav-menu li.current-menu-item a {
  background: var(--pp-pink);
  color: white;
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer, footer.site-footer {
  background: var(--pp-pink-soft);
  border-top: 2px dashed var(--pp-pink);
  padding: 2.5rem 1rem;
  text-align: center;
  margin-top: 3rem;
  color: var(--pp-text);
}

.site-footer .pp-script {
  font-size: 1.6rem;
  display: block;
  margin-bottom: 0.5rem;
}

/* =========================================================
   Buttons
   ========================================================= */
.pp-btn,
button.pp-btn,
a.pp-btn,
.wp-block-button__link {
  display: inline-block;
  background: var(--pp-pink);
  color: white !important;
  font-family: var(--font-body);
  font-weight: 700;
  padding: 0.85rem 2rem;
  border-radius: 999px;
  text-decoration: none !important;
  border: none;
  cursor: pointer;
  font-size: 1.05rem;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 14px rgba(244,163,184,0.4);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.pp-btn:hover, .wp-block-button__link:hover {
  background: var(--pp-pink-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(224,122,147,0.5);
}

.pp-btn--big { font-size: 1.3rem; padding: 1.1rem 2.6rem; }

/* =========================================================
   Hero (homepage)
   ========================================================= */
.pp-hero {
  text-align: center;
  padding: 5rem 1rem 6rem;
  background: linear-gradient(180deg, var(--pp-cream) 0%, var(--pp-pink-soft) 100%);
  position: relative;
  overflow: hidden;
}

.pp-hero h1 {
  font-size: clamp(3rem, 8vw, 5.5rem);
  margin: 0 0 1rem;
}

.pp-hero .pp-tagline {
  font-family: var(--font-cursive);
  color: var(--pp-pink-dark);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  margin: 0 0 1.5rem;
}

.pp-hero p.pp-lead {
  font-size: 1.25rem;
  max-width: 620px;
  margin: 0 auto 2rem;
  color: var(--pp-text);
}

.pp-hero .pp-paw-deco {
  position: absolute;
  font-size: 4rem;
  opacity: 0.18;
  user-select: none;
}

.pp-hero .pp-paw-deco--tl { top: 1rem;  left: 2rem;  transform: rotate(-20deg); }
.pp-hero .pp-paw-deco--tr { top: 2rem;  right: 2rem; transform: rotate(15deg); }
.pp-hero .pp-paw-deco--bl { bottom: 1rem; left: 4rem; transform: rotate(35deg); }
.pp-hero .pp-paw-deco--br { bottom: 2rem; right: 3rem; transform: rotate(-12deg); }

/* =========================================================
   Pricing cards
   ========================================================= */
.pp-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.5rem;
  margin: 2rem auto;
  max-width: 1000px;
}

.pp-price-card {
  background: white;
  border: 3px solid var(--pp-pink-soft);
  border-radius: 24px;
  padding: 2rem 1.5rem;
  text-align: center;
  box-shadow: 0 6px 20px rgba(0,0,0,0.04);
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.pp-price-card:hover {
  transform: translateY(-6px);
  border-color: var(--pp-pink);
}

.pp-price-card .pp-emoji {
  font-size: 3rem;
  display: block;
  margin-bottom: 0.5rem;
}

.pp-price-card h3 {
  font-family: var(--font-body);
  color: var(--pp-text);
  font-weight: 700;
  font-size: 1.3rem;
  margin: 0.3rem 0;
}

.pp-price-card .pp-price {
  font-family: var(--font-cursive);
  color: var(--pp-pink-dark);
  font-size: 3rem;
  font-weight: 700;
  margin: 0.5rem 0;
  display: block;
}

.pp-price-card .pp-price-unit {
  color: var(--pp-brown);
  font-style: italic;
  margin-bottom: 1rem;
}

/* =========================================================
   Galleries / image grids
   ========================================================= */
.pp-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin: 2rem 0;
}

.pp-gallery img,
.pp-gallery figure {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 16px;
  border: 3px solid white;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* =========================================================
   Section heading w/ paws
   ========================================================= */
.pp-heading {
  text-align: center;
  margin-bottom: 2rem;
}

.pp-heading::before, .pp-heading::after {
  content: '🐾';
  display: inline-block;
  font-size: 1.5rem;
  margin: 0 0.8rem;
  vertical-align: middle;
  opacity: 0.6;
}

/* =========================================================
   Cards / panels
   ========================================================= */
.pp-card {
  background: white;
  border-radius: 24px;
  padding: 2.5rem;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
  margin: 2rem auto;
  max-width: 800px;
}

/* =========================================================
   Amelia booking — restyle to match
   ========================================================= */
#amelia-app .amelia-app-booking,
.amelia-app-booking {
  font-family: var(--font-body) !important;
}

.amelia-app-booking .el-button--primary,
.amelia-app-booking button.el-button--primary {
  background-color: var(--pp-pink) !important;
  border-color: var(--pp-pink) !important;
  border-radius: 999px !important;
  font-weight: 700 !important;
}

.amelia-app-booking .el-button--primary:hover {
  background-color: var(--pp-pink-dark) !important;
  border-color: var(--pp-pink-dark) !important;
}

/* =========================================================
   WPForms — restyle to match
   ========================================================= */
.wpforms-form input[type=text],
.wpforms-form input[type=email],
.wpforms-form input[type=tel],
.wpforms-form textarea {
  border: 2px solid var(--pp-pink-soft) !important;
  border-radius: 12px !important;
  padding: 0.75rem !important;
  font-family: var(--font-body) !important;
}

.wpforms-form input:focus,
.wpforms-form textarea:focus {
  border-color: var(--pp-pink) !important;
  outline: none !important;
}

.wpforms-form button[type=submit] {
  background: var(--pp-pink) !important;
  color: white !important;
  border: none !important;
  border-radius: 999px !important;
  padding: 0.85rem 2rem !important;
  font-weight: 700 !important;
  font-family: var(--font-body) !important;
  cursor: pointer;
}

.wpforms-form button[type=submit]:hover {
  background: var(--pp-pink-dark) !important;
}

/* =========================================================
   Responsive tweaks
   ========================================================= */
@media (max-width: 640px) {
  .pp-section { padding: 2.5rem 0; }
  .pp-card    { padding: 1.5rem; }
  .pp-hero    { padding: 3rem 1rem 4rem; }
  nav.site-navigation ul, .menu { gap: 0.6rem; }
}
