/* Theme Name:Paw Duties Bluehost Theme URI:https://pawduties.com Description:A premium custom WordPress theme for Paw Duties Dog Waste Removal, built with a modern glassmorphism aesthetic. Ready for Bluehost deployment. Version:2.0 Author:Paw Duties Author URI:https://pawduties.com Text Domain:paw-duties License:GNU General Public License v2 or later License URI:http://www.gnu.org/licenses/gpl-2.0.html */ /* Paw Duties — Professional, Warm, Animated Theme Modern glassmorphism aesthetic with balanced tone */:root{/* Color Palette — Playful, Vibrant, Fun */ --primary:#2dd4a8;/* Bright Teal-Mint */ --primary-dark:#14b89a;--primary-light:#d5f5ec;--primary-color:#2dd4a8;--secondary:#334155;/* Soft charcoal (not harsh) */ --accent:#818cf8;/* Playful Purple */ --accent-warm:#fbbf24;/* Sunny Yellow */ --accent-pink:#f472b6;/* Fun Pink */ --accent-orange:#fb923c;/* Tangerine */ --success:#4ade80;--success-color:#4ade80;--success-light:#f0fdf4;--warning:#fbbf24;--warning-light:#fefce8;--bg-color:#fffbf2;/* Warm creamy vanilla */ --bg-light:#fef5e7;/* Soft peach cream */ --bg-mint:#edfcf7;/* Mint tint */ --text-primary:#334155;--text-dark:#334155;--text-secondary:#64748b;--text-muted:#64748b;--text-light:#fffbf2;--glass-bg:rgba(255, 255, 255, 0.9);--glass-bg-dark:rgba(51, 65, 85, 0.85);--glass-border:rgba(255, 255, 255, 0.6);--glass-shadow:0 8px 32px rgba(0, 0, 0, 0.05);/* Typography */ --font-main:'Outfit', sans-serif;--font-heading:'Baloo 2', 'Outfit', cursive;/* Spacing */ --section-pad:5rem 0;/* Radii — SUPER rounded and bubbly */ --radius-sm:16px;--radius-md:24px;--radius-lg:32px;--radius-xl:50px;/* Transitions — VERY bouncy */ --transition:all 0.4s cubic-bezier(0.34, 1.8, 0.64, 1);--transition-smooth:all 0.35s ease;--transition-spring:all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275)}
/* ================= Keyframe Animations ================= */ @keyframes float{0%{transform:translateY(0px) rotate(0deg)}
25%{transform:translateY(-12px) rotate(2deg)}
50%{transform:translateY(-22px) rotate(0deg)}
75%{transform:translateY(-12px) rotate(-2deg)}
100%{transform:translateY(0px) rotate(0deg)}
}
@keyframes wiggle{0%, 100%{transform:rotate(0deg)}
10%{transform:rotate(-12deg)}
20%{transform:rotate(10deg)}
30%{transform:rotate(-8deg)}
40%{transform:rotate(6deg)}
50%{transform:rotate(-3deg)}
60%{transform:rotate(1deg)}
}
@keyframes pop-in{0%{opacity:0;transform:scale(0.6) translateY(30px)}
50%{opacity:1;transform:scale(1.08) translateY(-8px)}
70%{transform:scale(0.97) translateY(2px)}
100%{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes bounce-in{0%{opacity:0;transform:scale(0.2) rotate(-10deg)}
40%{opacity:1;transform:scale(1.15) rotate(3deg)}
60%{transform:scale(0.9) rotate(-2deg)}
80%{transform:scale(1.05) rotate(1deg)}
100%{opacity:1;transform:scale(1) rotate(0deg)}
}
@keyframes pulse-glow{0%, 100%{box-shadow:0 0 0 0 rgba(45, 212, 168, 0.4)}
50%{box-shadow:0 0 30px 10px rgba(45, 212, 168, 0.15)}
}
@keyframes paw-float{0%{transform:translateY(110vh) rotate(0deg) scale(0.8);opacity:0}
5%{opacity:0.2}
50%{opacity:0.25;transform:translateY(50vh) rotate(180deg) scale(1.1)}
95%{opacity:0.15}
100%{transform:translateY(-15vh) rotate(360deg) scale(0.9);opacity:0}
}
@keyframes wave-sway{0%, 100%{transform:translateX(0) scaleY(1)}
50%{transform:translateX(-15px) scaleY(1.05)}
}
@keyframes spin-slow{from{transform:rotate(0deg)}
to{transform:rotate(360deg)}
}
@keyframes slide-up-fade{0%{opacity:0;transform:translateY(40px)}
100%{opacity:1;transform:translateY(0)}
}
@keyframes hero-blob-morph{0%, 100%{border-radius:60% 40% 30% 70% / 60% 30% 70% 40%;transform:scale(1) translate(0, 0)}
25%{border-radius:30% 60% 70% 40% / 50% 60% 30% 60%;transform:scale(1.05) translate(10px, -15px)}
50%{border-radius:50% 60% 30% 70% / 40% 70% 60% 50%;transform:scale(0.98) translate(-8px, 8px)}
75%{border-radius:40% 60% 70% 30% / 70% 30% 50% 60%;transform:scale(1.03) translate(5px, -5px)}
}
@keyframes rainbow-border{0%{border-color:var(--primary)}
25%{border-color:var(--accent)}
50%{border-color:var(--accent-pink)}
75%{border-color:var(--accent-warm)}
100%{border-color:var(--primary)}
}
@keyframes shimmer{0%{background-position:-200% center}
100%{background-position:200% center}
}
@keyframes tada{0%{transform:scale(1)}
10%, 20%{transform:scale(0.9) rotate(-3deg)}
30%, 50%, 70%, 90%{transform:scale(1.1) rotate(3deg)}
40%, 60%, 80%{transform:scale(1.1) rotate(-3deg)}
100%{transform:scale(1) rotate(0deg)}
}
@keyframes jelly{0%{transform:scaleX(1) scaleY(1)}
30%{transform:scaleX(1.25) scaleY(0.75)}
40%{transform:scaleX(0.75) scaleY(1.25)}
50%{transform:scaleX(1.15) scaleY(0.85)}
65%{transform:scaleX(0.95) scaleY(1.05)}
75%{transform:scaleX(1.05) scaleY(0.95)}
100%{transform:scaleX(1) scaleY(1)}
}
@keyframes gradient-shift{0%{background-position:0% 50%}
50%{background-position:100% 50%}
100%{background-position:0% 50%}
}
/* ================= CSS Reset & Globals ================= */ *{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-main);background-color:var(--bg-color);color:var(--text-primary);line-height:1.7;overflow-x:hidden}
/* Force white text on dark backgrounds */ .text-white h1, .text-white h2, .text-white h3, .text-white h4{color:#ffffff !important}
.text-white p, .text-white span{color:rgba(255, 255, 255, 0.9) !important}
/* FAQ accordion */ .faq-toggle .fa-chevron-down.rotated{transform:rotate(180deg)}
.page-header{position:relative;overflow:hidden;padding:12rem 0 7rem;margin-bottom:2rem}
/* Wave divider */ .wave-divider{position:absolute;bottom:-1px;left:0;width:100%;line-height:0;z-index:2}
.wave-divider svg{display:block;width:100%;height:70px}
h1, h2, h3, h4, h5, h6{font-family:var(--font-heading);color:var(--secondary);line-height:1.2;font-weight:700}
h1{font-size:clamp(2.5rem, 5vw, 4.5rem);letter-spacing:-1px}
h2{font-size:clamp(2rem, 4vw, 3.25rem);letter-spacing:-0.5px;margin-bottom:1rem}
h3{font-size:1.5rem;margin-bottom:0.75rem}
h4{font-size:1.25rem;margin-bottom:0.5rem}
p{color:var(--text-secondary);margin-bottom:1rem;font-size:1.125rem}
a{text-decoration:none;color:var(--primary-dark);transition:var(--transition-smooth)}
ul{list-style:none}
/* ================= Layout ================= */ .container{width:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem}
.container-narrow{max-width:1000px}
.section{padding:var(--section-pad);position:relative}
.section-header{margin-bottom:4rem;max-width:700px;margin-left:auto;margin-right:auto}
.grid-2{display:grid;grid-template-columns:repeat(2, 1fr);gap:3rem}
.grid-3{display:grid;grid-template-columns:repeat(3, 1fr);gap:2rem}
.grid-3 > .glass-panel{display:flex;flex-direction:column}
.grid-3 > .glass-panel > a.btn:last-child, .grid-3 > .glass-panel > .btn:last-child{margin-top:auto}
.grid-4{display:grid;grid-template-columns:repeat(4, 1fr);gap:2rem}
.align-center{align-items:center}
/* Utilities */ .text-center{text-align:center}
.text-left{text-align:left}
.text-right{text-align:right}
.text-primary{color:var(--primary) !important}
.text-success{color:var(--success) !important}
.text-warning{color:var(--warning) !important}
.text-white{color:white !important}
.text-muted{color:var(--text-secondary) !important}
.text-dark{color:var(--text-dark) !important}
.bg-light{background-color:var(--bg-light)}
.bg-primary-light{background-color:var(--primary-light)}
.bg-success-light{background-color:var(--success-light)}
.bg-warning-light{background-color:var(--warning-light)}
.bg-gradient{background:linear-gradient(135deg, #334155 0%, #475569 40%, #334155 100%);background-size:200% 200%;animation:gradient-shift 8s ease infinite}
.align-start{align-items:flex-start !important}
.p-2{padding:0.5rem !important}
.p-3{padding:1rem !important}
.p-4{padding:1.5rem !important}
.p-5{padding:3rem !important}
.mb-2{margin-bottom:0.5rem}
.mb-3{margin-bottom:1rem}
.mb-4{margin-bottom:1.5rem}
.mb-5{margin-bottom:3rem}
.mt-2{margin-top:0.5rem}
.mt-3{margin-top:1rem}
.mt-4{margin-top:1.5rem}
.mt-5{margin-top:3rem}
.w-100{width:100%}
.mb-0{margin-bottom:0 !important}
.pb-5{padding-bottom:3rem}
.pt-4{padding-top:1.5rem}
.pt-5{padding-top:3rem}
.lead{font-size:1.25rem;line-height:1.7}
.font-weight-bold{font-weight:700}
.mx-0{margin-left:0 !important;margin-right:0 !important}
.mx-auto{margin-left:auto;margin-right:auto}
.mr-3{margin-right:1rem}
.ml-2{margin-left:0.5rem}
.d-flex{display:flex}
.justify-content-center{justify-content:center}
/* ================= Components ================= */ /* Buttons — super fun and bouncy */ .btn{display:inline-flex;align-items:center;justify-content:center;padding:0.9rem 2.2rem;border-radius:var(--radius-xl);font-family:var(--font-heading);font-weight:700;font-size:1.05rem;cursor:pointer;border:none;transition:var(--transition);gap:0.6rem;position:relative;overflow:hidden;letter-spacing:0.3px}
.btn::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.25);border-radius:50%;transform:translate(-50%, -50%);transition:width 0.5s ease, height 0.5s ease}
.btn:hover::before{width:300px;height:300px}
.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-dark), var(--accent));background-size:200% 200%;animation:gradient-shift 4s ease infinite;color:white;box-shadow:0 6px 20px rgba(45, 212, 168, 0.35), 0 2px 8px rgba(129, 140, 248, 0.15)}
.btn-primary:hover{transform:translateY(-4px) scale(1.06) rotate(-1deg);box-shadow:0 12px 35px rgba(45, 212, 168, 0.45), 0 4px 12px rgba(129, 140, 248, 0.25);color:white}
.btn-primary:active{transform:translateY(0) scale(0.95);box-shadow:0 2px 10px rgba(45, 212, 168, 0.3)}
.btn-outline{background-color:transparent;border:3px solid var(--primary);color:var(--primary-dark)}
.btn-outline:hover{background:var(--primary);color:white;transform:translateY(-4px) scale(1.06) rotate(1deg);box-shadow:0 8px 25px rgba(45, 212, 168, 0.35);border-color:var(--primary)}
.btn-outline:active{transform:translateY(0) scale(0.95)}
.btn-large{padding:1.15rem 3rem;font-size:1.15rem}
.btn-sm{padding:0.55rem 1.4rem;font-size:0.9rem}
/* Glass Panels — SUPER soft and friendly */ .glass-panel{background:var(--glass-bg);border:2px solid rgba(45, 212, 168, 0.08);box-shadow:0 4px 30px rgba(0, 0, 0, 0.04);border-radius:var(--radius-lg);transition:var(--transition)}
.dark-glass{background:var(--glass-bg-dark);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:2px solid rgba(255, 255, 255, 0.1);color:var(--text-light)}
.dark-glass h3, .dark-glass h4{color:white}
.dark-glass p{color:rgba(255, 255, 255, 0.8)}
/* Effects — SUPER bouncy with tilt */ .hover-lift{transition:var(--transition)}
.hover-lift:hover{transform:translateY(-16px) rotate(-1deg);box-shadow:0 25px 60px rgba(0, 0, 0, 0.1), 0 10px 20px rgba(45, 212, 168, 0.08)}
/* Icon wiggle on hover — more dramatic */ .hover-lift:hover .icon-box{animation:tada 0.8s ease}
.hover-wiggle:hover{animation:wiggle 0.7s ease}
/* ================= Floating Paw Prints ================= */ .floating-paws{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:0}
.paw-print{position:absolute;font-size:1.5rem;opacity:0;animation:paw-float linear infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.1))}
/* ================= Navbar ================= */ .navbar{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:1rem 0;transition:var(--transition-smooth)}
.navbar.has-glass{background:rgba(255, 251, 242, 0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:2px solid rgba(45, 212, 168, 0.08);box-shadow:0 4px 30px rgba(0,0,0,0.04)}
.nav-btn-short{display:none}
.nav-container{display:flex;justify-content:space-between;align-items:center}
.brand-logo{font-family:var(--font-heading);font-size:1.7rem;font-weight:800;color:var(--secondary);display:flex;align-items:center;gap:0.5rem;letter-spacing:-0.5px;transition:var(--transition)}
.brand-logo:hover{transform:scale(1.05) rotate(-2deg)}
.brand-logo i{color:var(--primary);font-size:1.8rem;transition:var(--transition)}
.brand-logo:hover i{animation:tada 0.8s ease;color:var(--accent-pink)}
.brand-logo span{background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;gap:1.75rem}
.nav-links a{color:var(--text-primary);font-weight:500;position:relative;padding:0.25rem 0.5rem;border-radius:var(--radius-sm);transition:var(--transition)}
.nav-links a::after{content:'';position:absolute;width:0;height:3px;bottom:-6px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg, var(--primary), var(--accent), var(--accent-pink));border-radius:3px;transition:var(--transition)}
.nav-links a:hover::after{width:110%}
.nav-links a:hover{color:var(--primary-dark);transform:translateY(-2px)}
/* WordPress Menu Compatibility */ .nav-links ul{display:flex;gap:1.75rem;list-style:none;margin:0;padding:0}
.nav-links ul li a{color:var(--text-primary);font-weight:500;position:relative;text-decoration:none}
.nav-links ul li a::after{content:'';position:absolute;width:0;height:3px;bottom:-6px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg, var(--primary), var(--accent), var(--accent-pink));border-radius:3px;transition:var(--transition)}
.nav-links ul li a:hover::after{width:110%}
.nav-links ul li a:hover{color:var(--primary-dark)}
/* ================= Hero ================= */ .hero{padding:10rem 0 10rem;min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(180deg, var(--bg-color) 0%, var(--bg-mint) 50%, var(--bg-light) 100%)}
.hero-bg-shapes{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;overflow:hidden}
.shape{position:absolute;filter:blur(80px);z-index:0;animation:hero-blob-morph 12s ease-in-out infinite}
.shape-1{background:linear-gradient(135deg, rgba(45, 212, 168, 0.25), rgba(129, 140, 248, 0.15));width:650px;height:650px;top:-250px;right:-150px}
.shape-2{background:linear-gradient(135deg, rgba(251, 191, 36, 0.2), rgba(244, 114, 182, 0.15));width:550px;height:550px;bottom:-250px;left:-200px;animation-delay:4s}
.hero-container{display:grid;grid-template-columns:1.1fr 0.9fr;gap:4rem;align-items:center;position:relative;z-index:3}
.badge{display:inline-block;padding:0.6rem 1.5rem;background:white;border:2px solid var(--primary-light);border-radius:2rem;font-family:var(--font-heading);font-weight:600;font-size:0.95rem;color:var(--primary-dark);margin-bottom:1.5rem;box-shadow:0 6px 15px rgba(45, 212, 168, 0.12);transition:var(--transition)}
.badge:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 25px rgba(45, 212, 168, 0.2)}
.hero-buttons{display:flex;gap:1rem;margin-top:2.5rem}
.hero-trust{display:flex;align-items:center;gap:1rem;margin-top:3rem;padding-top:2rem;border-top:3px dashed rgba(45, 212, 168, 0.2)}
.avatars{display:flex}
.avatars img{width:40px;height:40px;border-radius:50%;border:3px solid white;margin-left:-10px;transition:var(--transition)}
.avatars img:first-child{margin-left:0}
.avatars img:hover{transform:scale(1.2) translateY(-4px);z-index:10}
.hero-trust span{font-size:0.875rem;color:var(--text-secondary)}
/* Hero Image & Floating Cards */ .image-wrapper{position:relative;border-radius:var(--radius-xl);padding:0.75rem;background:white;box-shadow:0 20px 60px rgba(0, 0, 0, 0.08), 0 8px 20px rgba(45, 212, 168, 0.06);transition:var(--transition)}
.image-wrapper:hover{transform:rotate(-1deg) scale(1.01);box-shadow:0 30px 80px rgba(0, 0, 0, 0.1), 0 12px 30px rgba(45, 212, 168, 0.1)}
.image-wrapper img{width:100%;height:auto;border-radius:calc(var(--radius-xl) - 8px);object-fit:cover;display:block}
.floating-card{position:absolute;padding:1rem 1.5rem;display:flex;align-items:center;gap:0.75rem;font-family:var(--font-heading);font-weight:700;background:white !important;z-index:10;animation:float 6s ease-in-out infinite;box-shadow:0 12px 35px rgba(0, 0, 0, 0.1);border-radius:var(--radius-lg) !important;border:2px solid rgba(45, 212, 168, 0.1) !important}
.floating-card i{font-size:1.5rem}
.card-1{top:10%;left:-10%}
.card-2{bottom:15%;right:-5%;animation-delay:3s}
/* ================= Feature Cards ================= */ .feature-card{padding:2.5rem 2rem;text-align:center}
.icon-box{width:76px;height:76px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1.5rem;transition:var(--transition);position:relative}
/* Fun blob outline around icons */ .icon-box::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:3px dashed currentColor;opacity:0.15;animation:spin-slow 15s linear infinite}
/* Details Grid */ .details-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:2.5rem 4rem}
.detail-item{display:flex;gap:1.5rem}
.detail-icon{width:50px;height:50px;border-radius:var(--radius-sm);background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;transition:var(--transition)}
.detail-item:hover .detail-icon{animation:jelly 0.6s ease;background:var(--primary);color:white;border-radius:50%}
/* ================= Reviews ================= */ .review-card{padding:2.5rem 2rem;display:flex;flex-direction:column;height:100%}
.review-text{font-style:italic;margin-bottom:2rem;flex-grow:1}
.reviewer{display:flex;align-items:center;gap:1rem;border-top:1px solid rgba(255,255,255,0.1);padding-top:1.5rem}
.r-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary);color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem}
.r-info{display:flex;flex-direction:column}
.r-info strong{color:white}
.r-info span{font-size:0.875rem}
/* ================= Service Area & Offers ================= */ .city-list{display:grid;grid-template-columns:repeat(2, 1fr);gap:1rem}
.city-list li{display:flex;align-items:center;gap:0.5rem;font-weight:500;transition:var(--transition)}
.city-list li:hover{transform:translateX(8px) scale(1.02);color:var(--primary-dark)}
.city-list li:hover i{animation:bounce-in 0.5s ease}
.offer-card{padding:2.5rem;position:relative;overflow:hidden;background:white;border-radius:var(--radius-lg)}
.accent-border{border:3px solid transparent;background-image:linear-gradient(white, white), linear-gradient(135deg, var(--primary), var(--accent-warm), var(--accent-pink));background-origin:border-box;background-clip:padding-box, border-box;animation:none}
.gradient-border{border:3px solid transparent;background-image:linear-gradient(white, white), linear-gradient(135deg, var(--accent), var(--primary), var(--accent-warm));background-origin:border-box;background-clip:padding-box, border-box}
.offer-badge{position:absolute;top:1rem;right:-2rem;background:linear-gradient(135deg, var(--accent-warm), var(--accent-orange));color:white;font-family:var(--font-heading);font-weight:700;font-size:0.75rem;padding:0.3rem 3rem;transform:rotate(45deg);text-transform:uppercase;box-shadow:0 4px 10px rgba(251, 191, 36, 0.3)}
.coupon-box{background:rgba(251, 191, 36, 0.1);border:2px dashed var(--accent-warm);padding:1.25rem;border-radius:var(--radius-md);margin-top:1.5rem;display:flex;justify-content:space-between;align-items:center;transition:var(--transition)}
.coupon-box:hover{transform:scale(1.02);box-shadow:0 5px 20px rgba(251, 191, 36, 0.15)}
.code{font-family:var(--font-heading);font-weight:800;font-size:1.3rem;background:linear-gradient(135deg, var(--primary-dark), var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.expiry{font-size:0.75rem;color:var(--accent-orange);text-transform:uppercase;font-weight:700}
/* ================= Stats Counter ================= */ .stat-number{font-family:var(--font-heading);font-size:2.8rem;font-weight:800;background:linear-gradient(135deg, var(--primary), var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
/* ================= Footer ================= */ .footer{background:linear-gradient(180deg, #334155 0%, #1e293b 60%, #0f172a 100%);color:white;padding:5rem 0 2rem;position:relative;overflow:hidden}
.footer::before{content:'🐾';position:absolute;top:30px;right:5%;font-size:8rem;opacity:0.03;transform:rotate(-15deg)}
.footer p{color:rgba(255,255,255,0.7)}
.footer-logo{color:white}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:4rem}
.footer-links h4, .footer-areas h4, .footer-contact h4{color:white;margin-bottom:1.5rem;position:relative;display:inline-block}
.footer-links h4::after, .footer-areas h4::after, .footer-contact h4::after{content:'';position:absolute;bottom:-6px;left:0;width:35px;height:4px;background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:3px}
.footer-areas ul{list-style:none;margin:0;padding:0}
.footer-areas ul li{margin-bottom:0.5rem}
.footer-areas a{color:rgba(255,255,255,0.7);transition:var(--transition);font-size:0.9rem}
.footer-areas a:hover{color:var(--primary);padding-left:4px}
.footer-links ul{list-style:none;margin:0;padding:0}
.footer-links ul li{margin-bottom:0.75rem}
.footer-links a{color:rgba(255,255,255,0.7);transition:var(--transition);display:inline-flex;align-items:center;gap:0.25rem}
.footer-links a::before{content:'🐾';font-size:0.7rem;opacity:0;transform:translateX(-10px) scale(0.5);transition:var(--transition)}
.footer-links a:hover::before{opacity:1;transform:translateX(0) scale(1)}
.footer-links a:hover{color:var(--primary);padding-left:8px;transform:translateX(4px)}
.footer-contact ul li{display:flex;align-items:center;gap:0.75rem;margin-bottom:1rem;color:rgba(255,255,255,0.7);transition:var(--transition)}
.footer-contact ul li:hover{transform:translateX(5px);color:white}
.footer-contact i{color:var(--primary);transition:var(--transition)}
.footer-contact ul li:hover i{animation:jelly 0.5s ease}
.social-links{display:flex;gap:1rem}
.social-links a{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;color:white;transition:var(--transition);border:2px solid rgba(255,255,255,0.05)}
.social-links a:hover{background:linear-gradient(135deg, var(--primary), var(--accent));transform:translateY(-6px) rotate(10deg) scale(1.1);box-shadow:0 8px 20px rgba(45, 212, 168, 0.3);border-color:transparent}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:2px dashed rgba(255,255,255,0.06)}
.legal-links{display:flex;gap:1.5rem}
.legal-links a{color:rgba(255,255,255,0.7);font-size:0.875rem}
/* ================= Contact Form ================= */ .contact-card{background:white;border-radius:var(--radius-lg);padding:3rem;box-shadow:0 15px 60px rgba(0,0,0,0.06);border:2px solid rgba(45, 212, 168, 0.06)}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;margin-bottom:0.5rem;font-weight:600;font-family:var(--font-heading);color:var(--secondary)}
.form-control{width:100%;padding:0.9rem 1.25rem;border:2px solid rgba(0,0,0,0.06);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:var(--transition);background:var(--bg-color)}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 5px rgba(45, 212, 168, 0.12);background:white;transform:scale(1.01)}
/* ================= FAQ ================= */ .faq-item{margin-bottom:1.5rem;border-bottom:2px dashed rgba(0,0,0,0.06);padding-bottom:1.5rem}
.faq-item h4{color:var(--primary-dark);margin-bottom:0.5rem;display:flex;align-items:center;gap:0.5rem}
/* ================= Blog ================= */ .featured-post{border-radius:var(--radius-lg);overflow:hidden;background:white;box-shadow:0 15px 50px rgba(0,0,0,0.06);display:flex;align-items:center;margin-bottom:4rem;border:2px solid rgba(0,0,0,0.03)}
.featured-img{flex:1;height:100%;min-height:400px;background:linear-gradient(135deg, var(--primary-light), var(--primary));background-size:cover;background-position:center}
.featured-content{flex:1;padding:4rem}
.blog-card{background:white;border-radius:var(--radius-md);overflow:hidden;transition:var(--transition);box-shadow:0 5px 25px rgba(0,0,0,0.04);height:100%;display:flex;flex-direction:column;border:2px solid rgba(0,0,0,0.03)}
.blog-card:hover{transform:translateY(-14px) rotate(-1deg);box-shadow:0 25px 50px rgba(0,0,0,0.12)}
.blog-card-img{height:220px;background:linear-gradient(135deg, var(--primary-light), var(--bg-mint));display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:3rem}
.blog-card-body{padding:2rem;flex-grow:1;display:flex;flex-direction:column}
.badge-category{display:inline-block;padding:0.3rem 0.9rem;background:linear-gradient(135deg, rgba(45, 212, 168, 0.12), rgba(129, 140, 248, 0.08));color:var(--primary-dark);border-radius:50px;font-size:0.8rem;font-weight:700;font-family:var(--font-heading);margin-bottom:1rem;text-transform:uppercase;letter-spacing:0.5px}
/* City page utility */ .styled-list li{font-size:1.05rem}
/* ================= Scroll Animations ================= */ .fade-in-up{opacity:0;transform:translateY(40px);transition:opacity 0.5s ease, transform 0.7s cubic-bezier(0.34, 1.8, 0.64, 1)}
.fade-in-left{opacity:0;transform:translateX(-40px) rotate(-2deg);transition:opacity 0.5s ease, transform 0.7s cubic-bezier(0.34, 1.8, 0.64, 1)}
.fade-in-right{opacity:0;transform:translateX(40px) rotate(2deg);transition:opacity 0.5s ease, transform 0.7s cubic-bezier(0.34, 1.8, 0.64, 1)}
/* New:pop-in with dramatic spring bounce */ .pop-in{opacity:0;transform:scale(0.7) translateY(30px);transition:opacity 0.4s ease, transform 0.7s cubic-bezier(0.34, 1.8, 0.64, 1)}
.appear{opacity:1;transform:translate(0) scale(1) rotate(0deg)}
.delay-1{transition-delay:0.12s}
.delay-2{transition-delay:0.24s}
.delay-3{transition-delay:0.36s}
.delay-4{transition-delay:0.48s}
/* ================= Fun Section Decorations ================= */ .section-decoration{position:absolute;pointer-events:none;z-index:0}
/* ================= Responsive ================= */ .mobile-menu-toggle{display:none}
/* ── Tablet (≤1024px) ── */ @media (max-width:1024px){.hero-container, .grid-3, .details-grid, .footer-grid{gap:2rem}
.grid-4{grid-template-columns:repeat(2, 1fr)}
}
/* ── Mobile (≤900px) ── */ @media (max-width:900px){/* ---- Navigation ---- */ .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(255, 251, 242, 0.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-direction:column;padding:1rem 0;box-shadow:0 20px 40px rgba(0,0,0,0.1);border-top:2px dashed rgba(45, 212, 168, 0.15);z-index:999;border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.nav-links.mobile-open{display:flex;animation:slide-up-fade 0.35s cubic-bezier(0.34, 1.56, 0.64, 1)}
.nav-links a{padding:0.9rem 2rem;border-bottom:1px dashed rgba(0,0,0,0.04);font-size:1.1rem}
.nav-links a::after{display:none}
.nav-links a:hover{background:var(--primary-light);transform:translateX(8px)}
/* WordPress nav menu compat */ .nav-links ul{flex-direction:column;gap:0}
.nav-links ul li a{padding:0.9rem 2rem;display:block;border-bottom:1px dashed rgba(0,0,0,0.04);font-size:1.1rem}
.nav-btn{font-size:0.78rem;padding:0.5rem 0.85rem;white-space:nowrap;order:3}
.nav-btn-full{display:none}
.nav-btn-short{display:inline}
.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, var(--primary-light), var(--bg-mint));border:2px solid var(--primary);color:var(--primary);width:48px;height:48px;border-radius:50%;font-size:1.25rem;cursor:pointer;transition:var(--transition)}
.mobile-menu-toggle:hover{background:var(--primary);color:white;transform:rotate(180deg) scale(1.1)}
.nav-container{position:relative}
/* ---- Grid Collapse ---- */ .hero-container, .grid-2, .grid-3, .grid-4, .details-grid, .footer-grid{grid-template-columns:1fr}
/* ---- Hero Polish ---- */ .hero{padding-top:7rem;padding-bottom:8.5rem;min-height:auto;text-align:center}
.hero-buttons{justify-content:center;flex-direction:column;align-items:center}
.hero-buttons .btn{width:100%;max-width:340px}
.hero-trust{justify-content:center;flex-wrap:wrap}
.hero-image{order:-1}
/* Keep floating cards visible but repositioned */ .floating-card{padding:0.6rem 1rem;font-size:0.85rem}
.floating-card i{font-size:1.1rem}
.floating-card.card-1{left:5px;top:5%}
.floating-card.card-2{right:5px;bottom:10%}
/* ---- Section Spacing ---- */ .section{padding:3rem 0}
.section-header{margin-bottom:2rem}
.page-header{padding:8rem 0 3.5rem}
/* ---- Typography ---- */ h1{font-size:2rem}
h2{font-size:1.65rem}
h3{font-size:1.2rem}
p, li{font-size:1rem}
.lead{font-size:1.1rem}
/* ---- Feature Cards ---- */ .feature-card{padding:2rem 1.5rem}
.icon-box{width:60px;height:60px;font-size:1.5rem}
/* ---- Glass Panels ---- */ .glass-panel.p-4{padding:1.25rem !important}
.glass-panel.p-5{padding:1.75rem !important}
/* ---- Buttons:Full-width CTAs on mobile ---- */ .btn-large{width:100%;text-align:center;justify-content:center}
/* ---- Stats Bar ---- */ .stat-number{font-size:2rem}
/* ---- Review Cards ---- */ .review-card{padding:2rem 1.5rem}
/* ---- Forms ---- */ .contact-card{padding:1.5rem !important}
.form-control{font-size:16px;/* Prevents iOS zoom on focus */ padding:0.85rem 1rem}
select.form-control{font-size:16px}
textarea.form-control{min-height:100px}
/* ---- Blog ---- */ .featured-post{flex-direction:column}
.featured-img{min-height:200px}
.featured-content{padding:2rem}
.blog-card-img{height:160px}
.blog-card-body{padding:1.5rem}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 15px 30px rgba(0,0,0,0.08)}
/* ---- Footer ---- */ .footer{padding:3rem 0 1.5rem}
.footer-grid{gap:2.5rem;margin-bottom:2rem}
/* ---- Offers/Coupons ---- */ .coupon-box{flex-direction:column;gap:0.75rem;text-align:center}
.offer-card{padding:1.75rem}
.offer-badge{font-size:0.65rem;padding:0.25rem 2.5rem;top:0.75rem;right:-1.5rem}
/* ---- Details Grid ---- */ .detail-item{flex-direction:column;text-align:center;align-items:center}
/* ---- City List (service areas) ---- */ .city-list{grid-template-columns:1fr}
/* ---- Reduce animations on mobile ---- */ .hover-lift:hover{transform:translateY(-6px)}
.floating-paws{display:none}
.icon-box::before{display:none}
/* Reduce bounce intensity on mobile for performance */ .image-wrapper:hover{transform:none}
}
/* ── Small Phone (≤600px) ── */ @media (max-width:600px){/* Container padding */ .container{padding:0 1rem}
/* Even smaller headings */ h1{font-size:1.7rem;letter-spacing:-0.5px}
h2{font-size:1.45rem}
h3{font-size:1.15rem}
/* Page header for subpages */ .page-header{padding:7rem 0 2.5rem}
.page-header .badge{font-size:0.8rem;padding:0.4rem 1rem}
.page-header h1{font-size:1.6rem;line-height:1.25}
.page-header p{font-size:0.95rem}
/* Hero tighter on small screens */ .hero{padding-top:6rem}
.badge{font-size:0.85rem;padding:0.45rem 1.1rem}
/* Buttons */ .btn{padding:0.8rem 1.5rem;font-size:0.95rem}
.btn-large{padding:0.85rem 1.75rem;font-size:1rem}
/* Footer bottom stack */ .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
.legal-links{flex-wrap:wrap;justify-content:center}
/* d-flex targeted overrides — only CTA button groups, NOT inline flex items */ .hero-buttons, .page-header .d-flex, .footer-bottom .d-flex{flex-direction:column;align-items:center}
/* Stats bar wrapping */ .grid-3[style*="padding"], .grid-4[style*="padding"]{gap:1.5rem}
/* Image wrapper no rotation on mobile */ .image-wrapper{padding:0.5rem}
/* Floating cards smaller */ .floating-card{padding:0.5rem 0.8rem;font-size:0.8rem;gap:0.4rem}
.floating-card i{font-size:0.9rem}
/* Feature cards tighter */ .feature-card{padding:1.5rem 1rem}
/* Glass panels */ .glass-panel.p-4{padding:1rem !important}
.glass-panel.p-5{padding:1.5rem !important}
/* Review cards */ .review-card{padding:1.5rem 1.25rem}
.r-avatar{width:40px;height:40px;font-size:1rem}
/* Section decoration/padding */ .section{padding:2.5rem 0}
.section-header{margin-bottom:1.5rem}
/* Blog */ .blog-card-body{padding:1.25rem}
.blog-card-img{height:140px}
.featured-content{padding:1.5rem}
/* Contact info cards on contact page */ .contact-card{padding:1.25rem !important}
/* Offer cards */ .offer-card{padding:1.5rem}
.code{font-size:1.1rem}
/* Stat numbers */ .stat-number{font-size:1.75rem}
/* City cards — center align for consistency */ .glass-panel.dark-glass[style*="display:flex"]{flex-direction:column !important;text-align:center;align-items:center !important;gap:0.5rem !important}
}
/* ── Very Small Phone (≤400px) ── */ @media (max-width:400px){h1{font-size:1.5rem}
h2{font-size:1.3rem}
.page-header h1{font-size:1.4rem}
.hero{padding-top:5.5rem}
.page-header{padding:6.5rem 0 2rem}
.container{padding:0 0.75rem}
.btn{padding:0.75rem 1.25rem;font-size:0.9rem}
.floating-card{display:none}
.footer-grid{gap:2rem}
}
/* ── Safe area insets for notched phones ── */ @supports (padding:env(safe-area-inset-bottom)){.footer-bottom{padding-bottom:calc(1rem + env(safe-area-inset-bottom))}
.navbar{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
}
/* ── Touch-friendly:ensure minimum tap targets ── */ @media (hover:none) and (pointer:coarse){.nav-links a, .footer-links a, .btn, .city-list li a, .social-links a{min-height:44px;display:flex;align-items:center}
/* Disable 3D tilt and heavy hover effects on touch */ .hover-lift:hover{transform:translateY(-4px)}
.blog-card:hover{transform:translateY(-4px)}
.btn-primary:hover{transform:translateY(-2px) scale(1.02)}
.btn-outline:hover{transform:translateY(-2px) scale(1.02)}
}
/* ── Fix:Page header text contrast on dark backgrounds ── */ .page-header.bg-gradient h1, .page-header.bg-gradient h2, .page-header.bg-gradient h3, .page-header.bg-gradient h4, .page-header.bg-gradient p, .page-header.bg-gradient span, .page-header.bg-gradient .badge{color:white !important;-webkit-text-fill-color:white !important}
.page-header.bg-gradient .badge{background:rgba(255,255,255,0.15) !important;border-color:rgba(255,255,255,0.3) !important}
/* ── Fix:Service card buttons full-width on mobile ── */ @media (max-width:600px){.glass-panel .btn, .offer-card .btn, .feature-card .btn{width:100%;text-align:center;justify-content:center}
/* ── Fix:City cards centered on service areas page ── */ /* Target the city card links in grid-3 */ .grid-3 > a.glass-panel{text-align:center;border-left:none !important;border-top:4px solid var(--primary) !important}
/* Stack the icon + city name div vertically */ .grid-3 > a.glass-panel > div[style*="display:flex"]{flex-direction:column !important;align-items:center !important;text-align:center}
/* Force city card link flex to column on mobile */ a.glass-panel.dark-glass[style*="display:flex"]{flex-direction:column !important;align-items:center !important;text-align:center}
}
