:root {
  --tan: #F5C98A; --tan-light: #FBE8C3; --tan-dark: #E8B86D;
  --brown: #5C3317; --brown-mid: #7A4A2A; --brown-light: #A0673A;
  --green: #6AAF5A; --green-dark: #4D8C3E; --green-light: #8FCC80;
  --white: #FFFFFF; --off-white: #FDF8F0;
  --text-dark: #2C1A0A; --text-mid: #5C3317;
  --shadow: rgba(92,51,23,0.15); --shadow-md: rgba(92,51,23,0.25);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Nunito','Segoe UI',sans-serif; background:var(--off-white); color:var(--text-dark); line-height:1.6; overflow-x:hidden; }
img { max-width:100%; height:auto; }
a { text-decoration:none; color:inherit; }
h1,h2,h3,h4 { font-family:'Nunito',sans-serif; font-weight:900; line-height:1.2; }
.section-title { font-size:clamp(2rem,5vw,3.2rem); color:var(--brown); text-align:center; margin-bottom:0.5rem; }
.section-subtitle { font-size:clamp(1rem,2.5vw,1.25rem); color:var(--brown-mid); text-align:center; margin-bottom:3rem; font-weight:500; }
.section-tag { display:inline-block; background:var(--green); color:var(--white); font-size:0.8rem; font-weight:800; letter-spacing:2px; text-transform:uppercase; padding:0.35rem 1rem; border-radius:50px; margin-bottom:1rem; }
.btn { display:inline-flex; align-items:center; gap:0.5rem; padding:0.9rem 2rem; border-radius:50px; font-weight:800; font-size:1rem; cursor:pointer; transition:all 0.3s ease; border:none; text-decoration:none; }
.btn-primary { background:var(--green); color:var(--white); box-shadow:0 4px 20px rgba(106,175,90,0.4); }
.btn-primary:hover { background:var(--green-dark); transform:translateY(-2px); box-shadow:0 8px 30px rgba(106,175,90,0.5); }
.btn-secondary { background:var(--white); color:var(--brown); border:2px solid var(--brown); }
.btn-secondary:hover { background:var(--brown); color:var(--white); transform:translateY(-2px); }
.btn-lg { padding:1.1rem 2.8rem; font-size:1.15rem; }

/* NAV */
#site-header { position:fixed; top:0; left:0; right:0; z-index:1000; transition:all 0.3s ease; padding:1rem 0; }
#site-header.scrolled { background:var(--white); box-shadow:0 2px 20px var(--shadow-md); padding:0.6rem 0; }
.nav-container { max-width:1200px; margin:0 auto; padding:0 2rem; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:center; gap:0.75rem; }
.nav-logo img { height:55px; width:auto; transition:height 0.3s ease; }
#site-header.scrolled .nav-logo img { height:45px; }
.nav-logo-text { font-size:1.5rem; font-weight:900; color:var(--brown); }
.nav-logo-text span { color:var(--green); }
nav ul { display:flex; list-style:none; gap:2rem; align-items:center; }
nav ul li a { font-weight:700; color:var(--brown); font-size:0.95rem; transition:color 0.2s; position:relative; }
nav ul li a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:2px; background:var(--green); transition:width 0.3s; }
nav ul li a:hover::after { width:100%; }
nav ul li a:hover { color:var(--green-dark); }
.nav-cta { background:var(--green) !important; color:var(--white) !important; padding:0.5rem 1.3rem; border-radius:50px; }
.nav-cta:hover { background:var(--green-dark) !important; }
.nav-cta::after { display:none !important; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:5px; }
.hamburger span { display:block; width:25px; height:3px; background:var(--brown); border-radius:3px; transition:all 0.3s; }

/* HERO */
#hero { min-height:100vh; background:linear-gradient(135deg,var(--tan) 0%,var(--tan-light) 50%,#FFF8ED 100%); display:flex; align-items:center; position:relative; overflow:hidden; padding-top:80px; }
.hero-bg-shapes { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.hero-shape { position:absolute; border-radius:50%; opacity:0.12; }
.hero-shape-1 { width:600px; height:600px; background:var(--brown); top:-200px; right:-150px; animation:float 8s ease-in-out infinite; }
.hero-shape-2 { width:400px; height:400px; background:var(--green); bottom:-100px; left:-100px; animation:float 10s ease-in-out infinite reverse; }
.hero-shape-3 { width:200px; height:200px; background:var(--brown-light); top:40%; left:40%; animation:float 6s ease-in-out infinite; }
@keyframes float { 0%,100% { transform:translateY(0) rotate(0deg); } 50% { transform:translateY(-25px) rotate(5deg); } }
.hero-container { max-width:1200px; margin:0 auto; padding:4rem 2rem; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; position:relative; z-index:1; }
.hero-tag { display:inline-flex; align-items:center; gap:0.5rem; background:var(--white); color:var(--brown); border:2px solid var(--tan-dark); padding:0.4rem 1rem; border-radius:50px; font-size:0.85rem; font-weight:700; margin-bottom:1.5rem; animation:slideDown 0.6s ease both; }
.hero-tag .dot { width:8px; height:8px; background:var(--green); border-radius:50%; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100% { transform:scale(1); opacity:1; } 50% { transform:scale(1.4); opacity:0.7; } }
.hero-title { font-size:clamp(2.8rem,6vw,4.5rem); color:var(--brown); margin-bottom:1rem; animation:slideUp 0.7s ease 0.1s both; }
.hero-title .highlight { color:var(--green); position:relative; display:inline-block; }
.hero-title .highlight::after { content:''; position:absolute; bottom:0; left:0; width:100%; height:6px; background:var(--tan-dark); border-radius:3px; z-index:-1; }
.hero-tagline { font-size:clamp(1.1rem,2.5vw,1.4rem); color:var(--brown-mid); font-weight:700; margin-bottom:1.5rem; animation:slideUp 0.7s ease 0.2s both; font-style:italic; }
.hero-description { font-size:1.05rem; color:var(--text-mid); margin-bottom:2.5rem; animation:slideUp 0.7s ease 0.3s both; max-width:500px; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; animation:slideUp 0.7s ease 0.4s both; }
.hero-stats { display:flex; gap:2rem; margin-top:3rem; animation:slideUp 0.7s ease 0.5s both; }
.hero-stat .number { font-size:2rem; font-weight:900; color:var(--brown); display:block; }
.hero-stat .label { font-size:0.8rem; color:var(--brown-mid); font-weight:600; text-transform:uppercase; letter-spacing:1px; }
.hero-visual { display:flex; justify-content:center; align-items:center; position:relative; animation:slideUp 0.8s ease 0.2s both; }
.hero-logo-wrap { position:relative; }
.hero-logo-main { width:380px; max-width:100%; filter:drop-shadow(0 20px 60px rgba(92,51,23,0.25)); animation:heroFloat 6s ease-in-out infinite; }
@keyframes heroFloat { 0%,100% { transform:translateY(0) rotate(-2deg); } 50% { transform:translateY(-20px) rotate(2deg); } }
.hero-badge { position:absolute; background:var(--white); border-radius:16px; padding:0.8rem 1.2rem; box-shadow:0 8px 30px var(--shadow-md); font-weight:800; font-size:0.9rem; color:var(--brown); white-space:nowrap; animation:badgeFloat 4s ease-in-out infinite; }
.hero-badge .badge-icon { font-size:1.4rem; display:block; margin-bottom:0.2rem; }
.badge-1 { top:10%; right:-10%; animation-delay:0s; }
.badge-2 { bottom:20%; left:-12%; animation-delay:1.5s; }
.badge-3 { top:55%; right:-8%; animation-delay:0.8s; }
@keyframes badgeFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-10px); } }
.scroll-indicator { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:0.5rem; color:var(--brown-mid); font-size:0.8rem; font-weight:600; animation:fadeIn 1s ease 1s both; }
.scroll-mouse { width:26px; height:40px; border:2px solid var(--brown-light); border-radius:13px; display:flex; justify-content:center; padding-top:6px; }
.scroll-wheel { width:4px; height:8px; background:var(--brown-light); border-radius:2px; animation:scrollWheel 2s ease-in-out infinite; }
@keyframes scrollWheel { 0% { transform:translateY(0); opacity:1; } 100% { transform:translateY(10px); opacity:0; } }

/* WHY NEED US */
#why-need-us { background:var(--brown); padding:6rem 0; position:relative; overflow:hidden; }
#why-need-us::before { content:''; position:absolute; top:-50px; left:0; right:0; height:100px; background:var(--off-white); clip-path:ellipse(55% 100% at 50% 0%); }
#why-need-us::after { content:''; position:absolute; bottom:-50px; left:0; right:0; height:100px; background:var(--off-white); clip-path:ellipse(55% 100% at 50% 100%); z-index:1; }
.why-container { max-width:1200px; margin:0 auto; padding:2rem 2rem; position:relative; z-index:2; }
.why-header { text-align:center; margin-bottom:3.5rem; }
.why-header .section-title { color:var(--tan-light); }
.why-header .section-subtitle { color:var(--tan); }
.why-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:2rem; }
.why-card { background:rgba(255,255,255,0.08); border:1px solid rgba(245,201,138,0.2); border-radius:20px; padding:2rem; text-align:center; transition:all 0.3s ease; backdrop-filter:blur(10px); }
.why-card:hover { background:rgba(255,255,255,0.14); transform:translateY(-5px); border-color:var(--tan-dark); }
.why-card-icon { font-size:3.5rem; margin-bottom:1rem; display:block; }
.why-card h3 { color:var(--tan-light); font-size:1.2rem; margin-bottom:0.75rem; }
.why-card p { color:var(--tan); font-size:0.95rem; line-height:1.6; }

/* HOW IT WORKS */
#how-it-works { padding:7rem 0; background:var(--off-white); }
.hiw-container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.hiw-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; position:relative; margin-top:3rem; }
.hiw-steps::before { content:''; position:absolute; top:40px; left:12.5%; right:12.5%; height:3px; background:linear-gradient(90deg,var(--green),var(--brown-light)); z-index:0; }
.hiw-step { text-align:center; position:relative; z-index:1; padding:0 1rem; }
.hiw-step-num { width:80px; height:80px; background:var(--white); border:3px solid var(--green); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:2rem; margin:0 auto 1.5rem; box-shadow:0 5px 20px var(--shadow); transition:all 0.3s ease; }
.hiw-step:hover .hiw-step-num { background:var(--green); transform:scale(1.1); }
.hiw-step h3 { color:var(--brown); font-size:1.1rem; margin-bottom:0.5rem; }
.hiw-step p { color:var(--brown-mid); font-size:0.9rem; }

/* WHY CHOOSE US */
#why-choose-us { padding:7rem 0; background:linear-gradient(180deg,var(--tan-light) 0%,var(--off-white) 100%); }
.wcu-container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.wcu-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:2rem; margin-top:3rem; }
.wcu-card { background:var(--white); border-radius:24px; padding:2.5rem; box-shadow:0 4px 25px var(--shadow); transition:all 0.3s ease; position:relative; overflow:hidden; }
.wcu-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--green),var(--green-light)); transform:scaleX(0); transition:transform 0.3s ease; }
.wcu-card:hover::before { transform:scaleX(1); }
.wcu-card:hover { transform:translateY(-6px); box-shadow:0 15px 50px var(--shadow-md); }
.wcu-icon { width:70px; height:70px; background:linear-gradient(135deg,var(--tan-light),var(--tan)); border-radius:20px; display:flex; align-items:center; justify-content:center; font-size:2rem; margin-bottom:1.5rem; }
.wcu-card h3 { color:var(--brown); font-size:1.25rem; margin-bottom:0.75rem; }
.wcu-card p { color:var(--brown-mid); font-size:0.95rem; line-height:1.7; }
.wcu-badge { display:inline-block; background:var(--tan-light); color:var(--brown); font-size:0.75rem; font-weight:700; padding:0.3rem 0.8rem; border-radius:50px; margin-top:1rem; text-transform:uppercase; letter-spacing:1px; }

/* PRICING */
#pricing { padding:7rem 0; background:var(--off-white); }
.pricing-container { max-width:1100px; margin:0 auto; padding:0 2rem; }
.pricing-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:3rem; }
.pricing-card { background:var(--white); border-radius:28px; padding:2.5rem 2rem; text-align:center; box-shadow:0 4px 25px var(--shadow); transition:all 0.3s ease; position:relative; overflow:hidden; }
.pricing-card.featured { background:var(--brown); transform:scale(1.05); box-shadow:0 20px 60px var(--shadow-md); }
.pricing-card:not(.featured):hover { transform:translateY(-8px); box-shadow:0 20px 50px var(--shadow-md); }
.pricing-popular { position:absolute; top:1rem; right:1rem; background:var(--green); color:var(--white); font-size:0.75rem; font-weight:800; padding:0.3rem 0.8rem; border-radius:50px; text-transform:uppercase; letter-spacing:1px; }
.pricing-icon { font-size:3rem; margin-bottom:1rem; display:block; }
.pricing-title { font-size:1.3rem; font-weight:900; color:var(--brown); margin-bottom:0.5rem; }
.pricing-card.featured .pricing-title { color:var(--tan-light); }
.pricing-freq { color:var(--brown-mid); font-size:0.9rem; margin-bottom:1.5rem; }
.pricing-card.featured .pricing-freq { color:var(--tan); }
.pricing-price { margin-bottom:1.5rem; }
.pricing-price .amount { font-size:3.5rem; font-weight:900; color:var(--green); line-height:1; }
.pricing-price .per { font-size:0.9rem; color:var(--brown-mid); font-weight:600; }
.pricing-card.featured .pricing-price .per { color:var(--tan); }
.pricing-features { list-style:none; margin-bottom:2rem; text-align:left; }
.pricing-features li { padding:0.5rem 0; color:var(--brown-mid); font-size:0.9rem; display:flex; align-items:center; gap:0.5rem; border-bottom:1px solid var(--tan-light); }
.pricing-card.featured .pricing-features li { color:var(--tan); border-bottom-color:rgba(245,201,138,0.2); }
.pricing-features li::before { content:'\2713'; color:var(--green); font-weight:900; font-size:1rem; }
.pricing-note { text-align:center; color:var(--brown-mid); font-size:0.9rem; margin-top:2rem; font-style:italic; }

/* SERVICE AREA */
#service-area { padding:7rem 0; background:linear-gradient(180deg,var(--tan-light) 0%,var(--tan) 100%); }
.sa-container { max-width:1200px; margin:0 auto; padding:0 2rem; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.sa-content .section-title,.sa-content .section-subtitle { text-align:left; }
.sa-areas { display:flex; flex-wrap:wrap; gap:0.75rem; margin-top:1.5rem; }
.sa-chip { background:var(--white); color:var(--brown); padding:0.5rem 1.2rem; border-radius:50px; font-weight:700; font-size:0.9rem; box-shadow:0 2px 10px var(--shadow); transition:all 0.3s ease; display:flex; align-items:center; gap:0.4rem; }
.sa-chip:hover { background:var(--brown); color:var(--white); transform:translateY(-2px); }
.sa-map-visual { background:var(--white); border-radius:28px; padding:2.5rem; box-shadow:0 10px 50px var(--shadow-md); text-align:center; }
.sa-map-visual h3 { color:var(--brown); font-size:1.3rem; margin-bottom:1rem; }
.sa-map-svg { width:100%; max-width:380px; margin:0 auto; display:block; }
.sa-highlight { background:var(--tan-light); border-radius:16px; padding:1.2rem; margin-top:1.5rem; display:flex; align-items:center; gap:1rem; }
.sa-highlight .icon { font-size:2rem; }
.sa-highlight p { color:var(--brown-mid); font-size:0.9rem; font-weight:600; }

/* TESTIMONIALS */
#testimonials { padding:7rem 0; background:var(--off-white); }
.testimonials-container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:3rem; }
.testimonial-card { background:var(--white); border-radius:24px; padding:2rem; box-shadow:0 4px 25px var(--shadow); transition:all 0.3s ease; position:relative; }
.testimonial-card:hover { transform:translateY(-5px); box-shadow:0 15px 50px var(--shadow-md); }
.testimonial-stars { color:#F5A623; font-size:1.2rem; margin-bottom:1rem; }
.testimonial-text { color:var(--brown-mid); font-size:0.95rem; line-height:1.7; margin-bottom:1.5rem; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:0.75rem; }
.testimonial-avatar { width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,var(--tan),var(--tan-dark)); display:flex; align-items:center; justify-content:center; font-size:1.4rem; }
.testimonial-name { font-weight:800; color:var(--brown); font-size:0.95rem; }
.testimonial-location { color:var(--brown-light); font-size:0.82rem; }
.testimonial-quote { position:absolute; top:1.5rem; right:1.5rem; font-size:4rem; color:var(--tan); line-height:1; font-family:Georgia,serif; }

/* BOOKING */
#booking { padding:7rem 0; background:linear-gradient(135deg,var(--brown) 0%,var(--brown-mid) 100%); position:relative; overflow:hidden; }
#booking::before { content:''; position:absolute; top:-60px; left:0; right:0; height:120px; background:var(--off-white); clip-path:ellipse(55% 100% at 50% 0%); }
.booking-container { max-width:900px; margin:0 auto; padding:2rem 2rem; position:relative; z-index:1; }
.booking-header { text-align:center; margin-bottom:3rem; }
.booking-header .section-title { color:var(--tan-light); }
.booking-header .section-subtitle { color:var(--tan); }
.booking-form { background:var(--white); border-radius:32px; padding:3rem; box-shadow:0 20px 80px rgba(0,0,0,0.3); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-bottom:1.5rem; }
.form-group { display:flex; flex-direction:column; gap:0.5rem; }
.form-group.full-width { grid-column:1/-1; }
.form-group label { font-weight:700; color:var(--brown); font-size:0.9rem; text-transform:uppercase; letter-spacing:0.5px; }
.form-group input,.form-group select,.form-group textarea { padding:0.9rem 1.2rem; border:2px solid var(--tan); border-radius:12px; font-size:1rem; font-family:inherit; color:var(--text-dark); background:var(--off-white); transition:all 0.3s ease; outline:none; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--green); background:var(--white); box-shadow:0 0 0 4px rgba(106,175,90,0.15); }
.form-group textarea { min-height:120px; resize:vertical; }
.form-plan-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:1.5rem; }
.plan-card-radio { position:relative; }
.plan-card-radio input[type="radio"] { position:absolute; opacity:0; width:0; }
.plan-card-label { display:block; border:2px solid var(--tan); border-radius:16px; padding:1.2rem; text-align:center; cursor:pointer; transition:all 0.3s ease; background:var(--off-white); }
.plan-card-label:hover { border-color:var(--green); background:var(--white); }
.plan-card-radio input:checked+.plan-card-label { border-color:var(--green); background:var(--white); box-shadow:0 0 0 3px rgba(106,175,90,0.2); }
.plan-card-icon { font-size:2rem; display:block; margin-bottom:0.5rem; }
.plan-card-title { font-weight:800; color:var(--brown); font-size:0.9rem; }
.plan-card-price { color:var(--green); font-weight:900; font-size:1.1rem; margin-top:0.25rem; }
.form-row-label { font-weight:700; color:var(--brown); font-size:0.9rem; text-transform:uppercase; letter-spacing:0.5px; margin-bottom:0.75rem; }
.dog-count-selector { display:flex; align-items:center; gap:1rem; background:var(--off-white); border:2px solid var(--tan); border-radius:12px; padding:0.6rem 1rem; width:fit-content; margin-bottom:1.5rem; }
.dog-count-btn { width:36px; height:36px; background:var(--tan); border:none; border-radius:50%; font-size:1.3rem; font-weight:900; color:var(--brown); cursor:pointer; transition:all 0.2s ease; display:flex; align-items:center; justify-content:center; }
.dog-count-btn:hover { background:var(--green); color:var(--white); }
.dog-count-display { font-size:1.5rem; font-weight:900; color:var(--brown); min-width:2ch; text-align:center; }
.dog-count-label { color:var(--brown-mid); font-weight:600; font-size:0.9rem; }
.form-submit-area { text-align:center; margin-top:2rem; }
.form-submit-area .btn-primary { font-size:1.1rem; padding:1.1rem 3rem; width:100%; justify-content:center; }
.form-legal { text-align:center; margin-top:1rem; color:var(--brown-light); font-size:0.82rem; }
.form-success { display:none; background:#E8F8E8; border:3px solid var(--green); border-radius:24px; padding:3rem 2rem; text-align:center; margin-top:1rem; box-shadow:0 10px 50px rgba(106,175,90,0.3); animation:successPop 0.5s cubic-bezier(0.175,0.885,0.32,1.275) both; }
@keyframes successPop { from{opacity:0;transform:scale(0.9)} to{opacity:1;transform:scale(1)} }
.form-success h3 { color:var(--green-dark); margin-bottom:0.5rem; }
.form-success p { color:var(--brown-mid); }

/* FAQ */
#faq { padding:7rem 0; background:var(--off-white); }
.faq-container { max-width:800px; margin:0 auto; padding:0 2rem; }
.faq-list { margin-top:3rem; display:flex; flex-direction:column; gap:1rem; }
.faq-item { background:var(--white); border-radius:16px; overflow:hidden; box-shadow:0 2px 15px var(--shadow); }
.faq-question { padding:1.4rem 1.8rem; display:flex; justify-content:space-between; align-items:center; cursor:pointer; font-weight:800; color:var(--brown); font-size:1rem; transition:background 0.2s; }
.faq-question:hover { background:var(--tan-light); }
.faq-icon { width:28px; height:28px; background:var(--tan-light); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.2rem; color:var(--brown); transition:all 0.3s ease; flex-shrink:0; }
.faq-item.open .faq-icon { background:var(--green); color:var(--white); transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.4s ease,padding 0.3s ease; padding:0 1.8rem; color:var(--brown-mid); font-size:0.95rem; line-height:1.7; }
.faq-item.open .faq-answer { max-height:400px; padding:0 1.8rem 1.4rem; }

/* FOOTER */
#site-footer { background:var(--brown); color:var(--tan); padding:4rem 0 2rem; }
.footer-container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3rem; margin-bottom:3rem; }
.footer-brand .footer-logo { height:60px; margin-bottom:1rem; }
.footer-brand p { font-size:0.9rem; line-height:1.7; color:var(--tan); margin-bottom:1.5rem; }
.footer-social { display:flex; gap:0.75rem; }
.social-btn { width:40px; height:40px; background:rgba(245,201,138,0.15); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--tan); font-size:1.1rem; transition:all 0.3s ease; text-decoration:none; }
.social-btn:hover { background:var(--green); color:var(--white); transform:translateY(-3px); }
.footer-col h4 { color:var(--tan-light); font-size:1rem; margin-bottom:1.2rem; font-weight:800; text-transform:uppercase; letter-spacing:1px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:0.6rem; }
.footer-col ul li a { color:var(--tan); font-size:0.9rem; transition:color 0.2s; }
.footer-col ul li a:hover { color:var(--tan-light); }
.footer-contact-item { display:flex; gap:0.75rem; align-items:flex-start; margin-bottom:0.9rem; color:var(--tan); font-size:0.9rem; }
.footer-contact-item .contact-icon { font-size:1.1rem; flex-shrink:0; margin-top:1px; }
.footer-bottom { border-top:1px solid rgba(245,201,138,0.15); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.footer-bottom p { color:var(--tan); font-size:0.85rem; }

/* STICKY CTA */
.sticky-cta { position:fixed; bottom:0; left:0; right:0; background:var(--brown); padding:0.85rem 2rem; display:none; align-items:center; justify-content:center; gap:1.5rem; z-index:999; box-shadow:0 -4px 20px rgba(0,0,0,0.2); }
.sticky-cta p { color:var(--tan); font-size:0.95rem; font-weight:700; }
.sticky-cta.visible { display:flex; }

/* ANIMATIONS */
@keyframes slideUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
@keyframes slideDown { from { opacity:0; transform:translateY(-20px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
.reveal { opacity:0; transform:translateY(40px); transition:opacity 0.7s ease,transform 0.7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }
.reveal-delay-4 { transition-delay:0.4s; }

/* RESPONSIVE */
@media (max-width:1024px) {
  .hero-container { grid-template-columns:1fr; text-align:center; }
  .hero-logo-main { width:280px; }
  .hero-visual { order:-1; }
  .hero-actions { justify-content:center; }
  .hero-stats { justify-content:center; }
  .badge-1,.badge-2,.badge-3 { display:none; }
  .sa-container { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .hiw-steps { grid-template-columns:repeat(2,1fr); }
  .hiw-steps::before { display:none; }
}
@media (max-width:768px) {
  nav ul { display:none; }
  nav ul.open { display:flex; flex-direction:column; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--white); align-items:center; justify-content:center; gap:2rem; z-index:999; }
  nav ul.open li a { font-size:1.5rem; }
  .hamburger { display:flex; z-index:1000; }
  .pricing-cards { grid-template-columns:1fr; }
  .pricing-card.featured { transform:scale(1); }
  .testimonials-grid { grid-template-columns:1fr; }
  .booking-form { padding:2rem 1.5rem; }
  .form-row { grid-template-columns:1fr; }
  .form-plan-cards { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .hero-description { margin:0 auto 2.5rem; }
  .sticky-cta { flex-direction:column; gap:0.75rem; padding:1rem; }
}

@keyframes shake {
  0%,100% { transform:translateX(0); }
  20%      { transform:translateX(-8px); }
  40%      { transform:translateX(8px); }
  60%      { transform:translateX(-5px); }
  80%      { transform:translateX(5px); }
}
