/* ==========================================================================
   GIFTED HANDS CLEANING — COMPONENT STYLES
   All reusable UI components for Elementor widgets
   ========================================================================== */

/* ─── Hero Section ─── */
.gifted-hero { position:relative; min-height:100vh; display:flex; align-items:center; padding-top:100px; overflow:hidden; }
.gifted-hero-video-wrap { position:absolute; top:0; left:0; width:100%; height:100%; z-index:-2; background-size:cover; background-position:center; }
.gifted-hero-video { width:100%; height:100%; object-fit:cover; }
.gifted-hero-bg { position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; z-index:-2; transform:scale(1.05); }
.gifted-hero-overlay { position:absolute; top:0; left:0; width:100%; height:100%; background:linear-gradient(105deg,rgba(27,42,94,0.95) 0%,rgba(27,42,94,0.85) 40%,rgba(27,42,94,0.4) 100%); z-index:-1; }
.gifted-hero-content { max-width:700px; color:white; position:relative; z-index:2; }
.gifted-hero h1 { color:white; font-size:clamp(3rem,6vw,4.5rem); margin-bottom:1.5rem; line-height:1.1; text-shadow:0 4px 20px rgba(0,0,0,0.3); }
.gifted-hero p { font-size:1.25rem; margin-bottom:2.5rem; color:rgba(255,255,255,0.95); max-width:550px; line-height:1.7; }
.gifted-hero-buttons { display:flex; gap:1rem; flex-wrap:wrap; }
.gifted-trust-badges-hero { display:flex; align-items:center; gap:2rem; margin-top:4rem; padding-top:2rem; border-top:1px solid rgba(255,255,255,0.15); }
.gifted-trust-badge { display:flex; align-items:center; gap:0.75rem; font-size:0.95rem; color:white; font-weight:500; }
.gifted-trust-badge i, .gifted-trust-badge svg { color:var(--color-accent); font-size:1.5rem; width:1em; height:1em; background:rgba(212,168,67,0.1); padding:0.5rem; border-radius:50%; box-sizing:content-box; fill:currentColor; display:inline-block; vertical-align:middle; }

/* ─── Bond Guarantee Banner ─── */
.gifted-bond-banner { background:var(--gradient-primary); color:white; padding:2rem 0; text-align:center; position:relative; z-index:10; }
.gifted-bond-banner h2 { color:white; margin-bottom:0.5rem; font-size:2rem; }
.gifted-bond-banner p { font-size:1.1rem; color:rgba(255,255,255,0.9); margin-bottom:0; }

/* ─── Stats Section ─── */
.gifted-stats-section { position:relative; margin-top:-60px; z-index:10; }
.gifted-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); background:white; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); overflow:hidden; }
.gifted-stat-card { padding:2.5rem 2rem; text-align:center; border-right:1px solid rgba(0,0,0,0.05); transition:transform var(--transition-fast); }
.gifted-stat-card:last-child { border-right:none; }
.gifted-stat-card:hover { transform:translateY(-5px); }
.gifted-stat-icon { font-size:2rem; color:var(--color-accent); margin-bottom:1rem; }
.gifted-stat-icon i, .gifted-stat-icon svg { width:1em; height:1em; fill:currentColor; display:inline-block; vertical-align:middle; }
.gifted-stat-number { font-family:var(--font-heading); font-size:2.5rem; font-weight:800; color:var(--color-primary); line-height:1; margin-bottom:0.5rem; }
.gifted-stat-label { color:var(--color-text-muted); font-weight:500; }

/* ─── Services Grid ─── */
.gifted-services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(350px,1fr)); gap:2.5rem; position:relative; z-index:2; }
.gifted-service-card { background:white; border-radius:var(--radius-xl); box-shadow:var(--shadow-md); transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275); position:relative; display:flex; flex-direction:column; border:1px solid rgba(0,0,0,0.02); }
.gifted-service-card:hover { transform:translateY(-15px); box-shadow:var(--shadow-lg); border-color:rgba(212,168,67,0.3); }
.gifted-service-card.featured { border:2px solid var(--color-accent); }
.gifted-service-content { padding:3rem 2.5rem 2.5rem; position:relative; flex-grow:1; display:flex; flex-direction:column; padding-top:4rem; }
.gifted-service-icon { position:absolute; top:-35px; right:30px; width:70px; height:70px; background:var(--gradient-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; color:white; font-size:1.75rem; box-shadow:0 10px 20px rgba(27,42,94,0.2); border:4px solid white; transition:transform 0.4s ease; }
.gifted-service-icon i, .gifted-service-icon svg { width:1em; height:1em; fill:currentColor; }
.gifted-service-card:hover .gifted-service-icon { transform:rotateY(180deg); }
.gifted-service-icon.accent { background:var(--gradient-accent); }
.gifted-service-card h3 { font-size:1.6rem; margin-bottom:1rem; }
.gifted-service-card p { color:var(--color-text-muted); margin-bottom:2rem; flex-grow:1; }
.gifted-service-link { display:inline-flex; align-items:center; gap:0.5rem; font-weight:600; color:var(--color-accent-dark); font-size:1.05rem; margin-top:auto; }
.gifted-service-link i { transition:transform var(--transition-fast); }
.gifted-service-card:hover .gifted-service-link { color:var(--color-primary); }
.gifted-service-card:hover .gifted-service-link i { transform:translateX(8px); }

/* ─── Why Choose Us / Features ─── */
.gifted-features-wrap { display:flex; align-items:center; gap:5rem; position:relative; z-index:2; }
.gifted-features-wrap.reversed { flex-direction:row-reverse; }
.gifted-features-image { flex:1; position:relative; }
.gifted-image-stack { position:relative; padding-right:2rem; padding-bottom:2rem; }
.gifted-img-main { border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); width:90%; position:relative; z-index:2; }
.gifted-img-sub { position:absolute; bottom:0; right:0; width:50%; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); border:10px solid white; z-index:3; }
.gifted-experience-card { position:absolute; top:10%; left:-20px; background:white; padding:1.5rem 2rem; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); display:flex; align-items:center; gap:1.5rem; z-index:4; animation:gifted-float 6s ease-in-out infinite; }
.gifted-exp-num { font-family:var(--font-heading); font-size:3.5rem; font-weight:800; background:var(--gradient-accent); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.gifted-exp-text { font-weight:600; color:var(--color-primary); line-height:1.3; font-size:1.1rem; }
.gifted-features-content { flex:1.2; }
.gifted-feature-list { margin-top: 1.5rem; display:grid; gap:2rem; }
.gifted-feature-item { display:flex; gap:1.5rem; align-items:flex-start; padding:1.5rem; border-radius:var(--radius-lg); background:white; box-shadow:var(--shadow-sm); transition:all var(--transition-normal); border:1px solid transparent; }
.gifted-feature-item:hover { box-shadow:var(--shadow-md); transform:translateX(10px); border-color:rgba(212,168,67,0.3); }
.gifted-feature-item.compact { padding:1rem; box-shadow:none; border-bottom:1px solid rgba(0,0,0,0.05); align-items:center; }
.gifted-feature-icon { width:60px; height:60px; background:var(--gradient-primary); color:white; border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; flex-shrink:0; box-shadow:0 8px 15px rgba(27,42,94,0.2); }
.gifted-feature-icon.small { width:45px; height:45px; font-size:1.1rem; border-radius:10px; }
.gifted-feature-icon i, .gifted-feature-icon svg { width:1em; height:1em; fill:currentColor; }
.gifted-feature-item h4 { margin-bottom:0.5rem; font-size:1.2rem; }
.gifted-feature-item p { color:var(--color-text-muted); font-size:1rem; margin-bottom:0; }

/* ─── How It Works / Steps ─── */
.gifted-steps-wrapper { background:white; border-radius:var(--radius-xl); padding: 2rem; box-shadow:var(--shadow-lg); position:relative; z-index:2; }
.gifted-steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:4rem; position:relative; }
.gifted-steps-grid::after { content:''; position:absolute; top:45px; left:15%; right:15%; height:3px; background:linear-gradient(90deg,rgba(212,168,67,0.1) 0%,rgba(212,168,67,1) 50%,rgba(212,168,67,0.1) 100%); z-index:1; }
.gifted-step-card { text-align:center; position:relative; z-index:2; }
.gifted-step-num { width:90px; height:90px; background:var(--color-bg-body); color:var(--color-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-size:2.5rem; font-weight:800; margin:0 auto 2rem; box-shadow:0 0 0 10px rgba(212,168,67,0.1),inset 0 0 0 3px var(--color-accent); transition:all var(--transition-normal); }
.gifted-step-card:hover .gifted-step-num { background:var(--gradient-accent); color:var(--color-navy); transform:scale(1.1); box-shadow:0 0 0 15px rgba(212,168,67,0.2); }
.gifted-step-card h4 { font-size:1.4rem; margin-bottom:1rem; }
.gifted-step-card p { color:var(--color-text-muted); font-size:1.05rem; }

/* ─── Testimonials ─── */
.gifted-testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; align-items:start; }
.gifted-review-card { background:var(--color-bg-body); padding:3rem 2.5rem; border-radius:var(--radius-xl); box-shadow:var(--shadow-md); position:relative; transition:transform var(--transition-normal); }
.gifted-review-card:hover { transform:translateY(-10px); }
.gifted-quote-icon { position:absolute; top:2rem; right:2.5rem; font-size:4rem; color:rgba(212,168,67,0.12); line-height:1; }
.gifted-stars { color:var(--color-accent); margin-bottom:1.5rem; font-size:1.1rem; display:flex; gap:0.25rem; }
.gifted-review-text { font-size:1.1rem; font-style:italic; margin-bottom:2rem; color:var(--color-text-main); line-height:1.8; position:relative; z-index:2; }
.gifted-reviewer { display:flex; align-items:center; gap:1.25rem; border-top:1px solid rgba(0,0,0,0.05); padding-top:1.5rem; }
.gifted-reviewer-img { width:60px; height:60px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--font-heading); font-weight:700; font-size:1.2rem; color:white; }
.gifted-reviewer-info h5 { margin-bottom:0.25rem; font-size:1.1rem; }
.gifted-reviewer-info span { font-size:0.9rem; color:var(--color-accent-dark); font-weight:500; }

/* ─── FAQ ─── */
.gifted-faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.gifted-faq-item { background:white; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); overflow:hidden; }
.gifted-faq-question { padding:1.5rem 2rem; display:flex; justify-content:space-between; align-items:center; cursor:pointer; font-family:var(--font-heading); font-weight:600; font-size:1.1rem; color:var(--color-primary); background:white; transition:background var(--transition-fast); }
.gifted-faq-question:hover { background:var(--color-bg-alt); }
.gifted-faq-icon { color:var(--color-accent); transition:transform var(--transition-fast); }
.gifted-faq-answer { padding:0 2rem; max-height:0; overflow:hidden; transition:all 0.3s ease-out; color:var(--color-text-muted); }
.gifted-faq-item.active .gifted-faq-icon { transform:rotate(180deg); }
.gifted-faq-item.active .gifted-faq-answer { padding:0 2rem 1.5rem; max-height:300px; }

/* ─── CTA Section ─── */
.gifted-cta-section { position:relative; border-radius:var(--radius-xl); overflow:hidden; padding: 2.5rem 4rem; background:var(--gradient-dark); color:white; text-align:center; box-shadow:var(--shadow-lg); }
.gifted-cta-section::before { content:''; position:absolute; top:0; left:0; width:100%; height:100%; background:url('https://images.unsplash.com/photo-1584622650111-993a426fbf0a?q=80&w=2000&auto=format&fit=crop') center/cover; opacity:0.15; z-index:1; }
.gifted-cta-content { position:relative; z-index:2; max-width:700px; margin:0 auto; }
.gifted-cta-content h2 { color:white; font-size:3rem; margin-bottom:1.5rem; }
.gifted-cta-content p { font-size:1.25rem; margin-bottom: 1.5rem; color:rgba(255,255,255,0.9); }
.gifted-cta-badges { display:flex; justify-content:center; gap:2rem; margin-top: 1.5rem; }
.gifted-cta-badge { display:flex; align-items:center; gap:0.5rem; background:rgba(255,255,255,0.1); padding:0.75rem 1.5rem; border-radius:var(--radius-full); backdrop-filter:blur(5px); font-weight:500; }

/* ─── Contact ─── */
.gifted-contact-grid { display:grid; grid-template-columns:1.5fr 1fr; gap:4rem; position:relative; z-index:5; margin-top:-80px; }
.gifted-contact-form-wrapper { background:white; padding: 4rem; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); border:1px solid rgba(0,0,0,0.05); }
.gifted-contact-info-wrapper { background:var(--gradient-primary); color:white; padding: 4rem; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); height:100%; }
.gifted-contact-info-item { display:flex; gap:1.5rem; margin-bottom:2.5rem; }
.gifted-contact-info-icon { width:50px; height:50px; background:rgba(212,168,67,0.15); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.25rem; color:var(--color-accent); flex-shrink:0; transition:transform var(--transition-fast); }
.gifted-contact-info-icon i, .gifted-contact-info-icon svg { width:1em; height:1em; fill:currentColor; }
.gifted-contact-info-item:hover .gifted-contact-info-icon { transform:scale(1.1); background:var(--color-accent); color:var(--color-navy); }
.gifted-contact-info-text h4 { color:white; margin-bottom:0.25rem; font-size:1.2rem; }
.gifted-contact-info-text p,.gifted-contact-info-text a { color:rgba(255,255,255,0.8); font-size:1.05rem; line-height:1.6; }
.gifted-contact-info-text a:hover { color:var(--color-accent); }

/* ─── Forms ─── */
.gifted-form-group { margin-bottom:1.5rem; }
.gifted-form-label { display:block; font-weight:600; margin-bottom:0.5rem; color:var(--color-primary); font-size:0.95rem; }
.gifted-form-control { width:100%; padding:1rem 1.25rem; border:1px solid rgba(0,0,0,0.1); border-radius:var(--radius-md); font-family:var(--font-body); font-size:1rem; background:var(--color-bg-alt); transition:all var(--transition-fast); color:var(--color-text-main); }
select.gifted-form-control { appearance:none; background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e"); background-repeat:no-repeat; background-position:right 1rem center; background-size:1em; }
.gifted-form-control:focus { outline:none; border-color:var(--color-accent); box-shadow:0 0 0 4px rgba(212,168,67,0.12); background:white; }
textarea.gifted-form-control { resize:vertical; min-height:150px; }
.gifted-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }

/* ─── Responsive ─── */
@media(max-width:1200px) {
  .gifted-features-wrap { gap:3rem; }
}
@media(max-width:1024px) {
  .gifted-features-wrap,.gifted-features-wrap.reversed { flex-direction:column !important; }
  .gifted-features-image { width:100%; margin-bottom: 1.5rem; }
  .gifted-experience-card { top:auto; bottom:-20px; left:auto; right:20px; }
  .gifted-steps-wrapper { padding: 1.5rem 2rem; }
  .gifted-steps-grid { gap:2rem; }
  .gifted-testimonials-grid { grid-template-columns:repeat(2,1fr); }
  .gifted-faq-grid { grid-template-columns:1fr; }
  .gifted-contact-grid { grid-template-columns:1fr; gap:2rem; margin-top:-40px; }
  .gifted-contact-form-wrapper { padding:3rem 2rem; }
}
@media(max-width:768px) {
  .gifted-hero h1 { font-size:2.5rem; }
  .gifted-hero-buttons { flex-direction:column; }
  .gifted-hero-buttons .btn { width:100%; }
  .gifted-trust-badges-hero { flex-direction:column; align-items:flex-start; gap:1.5rem; }
  .gifted-stats-grid { grid-template-columns:repeat(2,1fr); }
  .gifted-stat-card { border-right:none; border-bottom:1px solid rgba(0,0,0,0.05); }
  .gifted-steps-grid { grid-template-columns:1fr; }
  .gifted-steps-grid::after { display:none; }
  .gifted-testimonials-grid { grid-template-columns:1fr; }
  .gifted-cta-section { padding: 1.5rem 2rem; }
  .gifted-cta-badges { flex-direction:column; align-items:center; gap:1rem; }
  .gifted-form-row { grid-template-columns:1fr; }
  .gifted-services-grid { grid-template-columns:1fr; }
}

/* ==========================================================================
   INNER PAGES SPECIFIC STYLES
   ========================================================================== */

/* Inner Page Hero */
.gifted-inner-hero { position:relative; padding:180px 0 100px; background:var(--color-primary); color:white; text-align:center; overflow:hidden; }
.gifted-inner-hero-overlay { content:''; position:absolute; top:0; left:0; width:100%; height:100%; background-position:center; background-size:cover; opacity:0.1; z-index:1; }
.gifted-inner-hero .container { position:relative; z-index:2; }
.gifted-inner-hero h1 { color:white; font-size:clamp(2.5rem,5vw,4rem); margin-bottom:1rem; }
.gifted-inner-hero p { font-size:1.2rem; color:rgba(255,255,255,0.8); max-width:600px; margin:0 auto; }

/* Alternating Service Details */
.gifted-service-detail-row { display:flex; align-items:center; gap:4rem; margin-bottom:6rem; }
.gifted-service-detail-row:last-child { margin-bottom:0; }
.gifted-service-detail-row.reversed { flex-direction:row-reverse; }
.gifted-service-detail-img { flex:1; position:relative; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.gifted-service-detail-img img { width:100%; height:400px; object-fit:cover; transition:transform var(--transition-slow); }
.gifted-service-detail-row:hover .gifted-service-detail-img img { transform:scale(1.05); }
.gifted-service-detail-content { flex:1; }
.gifted-service-detail-content h2 { font-size:2.2rem; margin-bottom:1rem; }
.gifted-service-detail-content p { color:var(--color-text-muted); font-size:1.1rem; margin-bottom:1.5rem; }
.gifted-service-detail-list { list-style:none; margin-bottom:2rem; display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.gifted-service-detail-list li { display:flex; align-items:center; gap:0.75rem; font-weight:500; color:var(--color-primary); }
.gifted-service-detail-list i, .gifted-service-detail-list svg { color:var(--color-accent); background:rgba(212,168,67,0.1); padding:0.4rem; border-radius:50%; width:1em; height:1em; fill:currentColor; box-sizing:content-box; display:inline-block; vertical-align:middle; }

/* Service Areas Grid */
.gifted-areas-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1.5rem; margin-top: 1.5rem; }
.gifted-area-card { background:white; padding:1.25rem; border-radius:var(--radius-md); border:1px solid rgba(0,0,0,0.05); display:flex; align-items:center; gap:1rem; box-shadow:var(--shadow-sm); transition:all var(--transition-fast); cursor:default; }
.gifted-area-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--color-accent); }
.gifted-area-icon { color:var(--color-accent); font-size:1.2rem; }
.gifted-area-icon i, .gifted-area-icon svg { width:1em; height:1em; fill:currentColor; }
.gifted-area-name { font-weight:600; color:var(--color-primary); margin-bottom:0; }

/* Responsive Overrides for Inner Pages */
@media(max-width:1024px) {
  .gifted-service-detail-row, .gifted-service-detail-row.reversed { flex-direction:column !important; gap:2rem; }
}
@media(max-width:768px) {
  .gifted-service-detail-list { grid-template-columns:1fr; }
}

/* ==========================================================================
   PRICING PAGE SPECIFIC STYLES
   ========================================================================== */

/* Pricing/Packages */
.gifted-pricing-section { position:relative; overflow:hidden; }
.gifted-pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(350px,1fr)); gap:2rem; align-items:center; position:relative; z-index:2; }
.gifted-price-card { background:white; border-radius:var(--radius-xl); padding:3rem 2.5rem; box-shadow:var(--shadow-md); text-align:center; transition:all var(--transition-normal); border:1px solid rgba(0,0,0,0.05); display:flex; flex-direction:column; }
.gifted-price-card.popular { background:var(--color-primary); color:white; transform:scale(1.05); box-shadow:var(--shadow-lg); border:none; }

/* Pricing Hero Specific */
.gifted-hero-buttons { display:flex; gap:1rem; flex-wrap:wrap; }
.gifted-trust-badges-hero { display:flex; gap:2rem; flex-wrap:wrap; border-top:1px solid rgba(255,255,255,0.1); padding-top:2rem; }
.gifted-trust-badge { display:flex; align-items:center; gap:0.5rem; color:white; font-weight:600; }
.gifted-trust-badge i, .gifted-trust-badge svg { color:var(--color-accent); font-size:1.25rem; }
.gifted-popular-badge { background:var(--gradient-accent); color:white; padding:0.5rem 1.5rem; border-radius:var(--radius-full); font-size:0.85rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; display:inline-block; margin-bottom:1.5rem; }
.gifted-price-card h3 { font-size:1.5rem; margin-bottom:1rem; }
.gifted-price-card.popular h3 { color:white; }
.gifted-price { margin-bottom:2rem; display:flex; justify-content:center; align-items:baseline; }
.gifted-price .currency { font-size:1.5rem; font-weight:600; color:var(--color-accent); }
.gifted-price .amount { font-family:var(--font-heading); font-size:3.5rem; font-weight:800; line-height:1; }
.gifted-price .period { color:var(--color-text-muted); font-weight:500; margin-left:0.5rem; }
.gifted-price-card.popular .period { color:rgba(255,255,255,0.7); }
.gifted-price-features { list-style:none; margin-bottom:2.5rem; text-align:left; }
.gifted-price-features li { margin-bottom:1rem; display:flex; align-items:center; gap:1rem; color:var(--color-text-muted); }
.gifted-price-card.popular .gifted-price-features li { color:rgba(255,255,255,0.9); }
.gifted-price-features i, .gifted-price-features svg { color:var(--color-accent); font-size:1.2rem; }

/* Afterpay Banner */
.gifted-afterpay-banner { background:#B2FCE4; color:#000; padding:1.25rem; text-align:center; font-weight:600; font-size:1.15rem; display:flex; align-items:center; justify-content:center; gap:1rem; flex-wrap:wrap; }
.gifted-afterpay-logo { font-family:var(--font-heading); font-weight:800; font-size:1.4rem; letter-spacing:-0.5px; }

/* Pricing Comparison Table */
.gifted-comparison-table-wrapper { background:white; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); overflow:hidden; margin:3rem auto; border:1px solid rgba(0,0,0,0.05); }
.gifted-comparison-table { width:100%; border-collapse:collapse; }
.gifted-comparison-table th, .gifted-comparison-table td { padding:1.25rem 1.5rem; border-bottom:1px solid rgba(0,0,0,0.05); }
.gifted-comparison-table tbody tr:hover { background:var(--color-bg-alt); }
.gifted-comparison-table th { background:var(--color-bg-body); font-family:var(--font-heading); font-size:1.1rem; text-align:left; font-weight:700; }
.gifted-comparison-table th.text-center, .gifted-comparison-table td.text-center { text-align:center; }
.gifted-comparison-table .category-row th { background:var(--color-primary); color:white; text-transform:uppercase; font-size:0.85rem; letter-spacing:1.5px; padding:0.75rem 1.5rem; }
.gifted-comparison-table i.fa-check, .gifted-comparison-table svg.fa-check { color:var(--color-accent); font-size:1.2rem; }
.gifted-comparison-table i.fa-minus, .gifted-comparison-table svg.fa-minus { color:rgba(0,0,0,0.2); }

/* Add-ons Grid */
.gifted-addons-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; margin-top:2rem; }
.gifted-addon-card { display:flex; justify-content:space-between; align-items:center; padding:1.5rem; background:white; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); border:1px solid rgba(0,0,0,0.05); transition:all var(--transition-fast); }
.gifted-addon-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--color-accent); }
.gifted-addon-info { display:flex; align-items:center; gap:1rem; }
.gifted-addon-info i, .gifted-addon-info svg { color:var(--color-accent); font-size:1.2rem; background:var(--color-bg-alt); padding:0.75rem; border-radius:50%; box-sizing:content-box; width:1em; height:1em; display:inline-flex; align-items:center; justify-content:center; }
.gifted-addon-info h4 { margin-bottom:0; font-size:1.1rem; }
.gifted-addon-price { font-weight:700; color:var(--color-primary); background:var(--color-bg-alt); padding:0.5rem 1rem; border-radius:var(--radius-full); }

/* Promo Banner */
.gifted-promo-banner { background:var(--gradient-accent); color:white; padding: 2rem 2rem; text-align:center; position:relative; overflow:hidden; }
.gifted-promo-banner::before { content:''; position:absolute; top:0; left:0; width:100%; height:100%; background:url('https://images.unsplash.com/photo-1584622650111-993a426fbf0a?q=80&w=2000&auto=format&fit=crop') center/cover; opacity:0.1; z-index:0; }
.gifted-promo-banner-content { position:relative; z-index:1; }

@media(max-width:1200px) {
  .gifted-pricing-grid { gap:1rem; }
  .gifted-price-card { padding:2rem 1.5rem; }
}
@media(max-width:1024px) {
  .gifted-pricing-grid { grid-template-columns:repeat(2,1fr); }
  .gifted-price-card.popular { transform:none; grid-column:1 / -1; display:flex; justify-content:space-between; align-items:center; text-align:left; }
  .gifted-price-card.popular .gifted-price-features { margin-bottom:0; }
}
@media(max-width:768px) {
  .gifted-pricing-grid { grid-template-columns:1fr; }
  .gifted-price-card.popular { flex-direction:column; text-align:center; }
  .gifted-price-card.popular .gifted-price-features { margin-bottom:2.5rem; }
}

/* --- Add-Ons Table --- */
.gifted-addons-table-container {
    background: white;
    border-radius: var(--radius-xl);
    box-shadow: 0 10px 40px rgba(0,0,0,0.1);
    max-width: 800px;
    margin: 0 auto 4rem auto;
    overflow: hidden;
    position: relative;
    z-index: 10;
}
.gifted-addons-header {
    text-align: center;
    padding: 3rem 2rem 2rem;
}
.gifted-addons-header h2 {
    color: var(--color-accent);
    font-size: 2rem;
    text-transform: uppercase;
    font-weight: 800;
    margin-bottom: 1rem;
}
.gifted-addons-header p {
    color: var(--color-primary);
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 0;
}
.gifted-addons-table {
    border-top: 2px solid var(--color-accent);
}
.addon-row.header {
    background: var(--gradient-accent);
    color: white;
    font-weight: 800;
    padding: 0.75rem 1.5rem;
    text-transform: uppercase;
    font-size: 1rem;
}
.addon-row.item {
    display: flex;
    justify-content: space-between;
    padding: 0.75rem 1.5rem;
    border-bottom: 1px solid rgba(0,0,0,0.1);
    font-size: 1rem;
    color: var(--color-text);
}
.addon-row.full-span {
    padding: 0.75rem 1.5rem;
    border-bottom: 1px solid rgba(0,0,0,0.1);
    text-align: center;
    font-size: 1rem;
    color: var(--color-text);
}
.addon-row.full-span strong {
    font-weight: 700;
}
.addon-row.item .addon-price {
    font-weight: 600;
}
.gifted-addons-footer {
    text-align: center;
    padding: 2.5rem 2rem 3rem;
}
.gifted-addons-footer h4 {
    font-weight: 800;
    font-size: 1.1rem;
    margin-bottom: 1rem;
    color: var(--color-primary);
}
.addon-reasons {
    list-style: none;
    padding: 0;
    margin: 0 0 2rem;
    font-style: italic;
    color: var(--color-text-muted);
}
.addon-btn {
    font-size: 1.25rem;
    padding: 1.25rem 2.5rem;
    border-radius: var(--radius-lg);
    background: var(--gradient-accent);
    color: white;
    text-transform: uppercase;
    font-weight: 800;
    letter-spacing: 1px;
}
.addon-btn:hover {
    background: var(--color-primary);
    transform: translateY(-3px);
}

/* ==========================================================================
   GIFTED HANDS CLEANING — ABOUT PAGE STYLES
   Extends the shared design system (style.css)
   ========================================================================== */

/* --- About Hero Enhancement --- */
.about-hero {
  background: linear-gradient(135deg, var(--color-primary) 0%, #0D3347 50%, var(--color-primary-light) 100%);
}

.about-hero::before {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: url('https://images.unsplash.com/photo-1527515637462-cff94eebd21d?q=80&w=2000&auto=format&fit=crop') center/cover;
  opacity: 0.08;
  z-index: 1;
}

.about-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 2rem;
  font-size: 0.95rem;
  color: rgba(255,255,255,0.6);
}

.about-breadcrumb a {
  color: rgba(255,255,255,0.6);
  transition: color var(--transition-fast);
}

.about-breadcrumb a:hover {
  color: var(--color-accent);
}

.about-breadcrumb i {
  font-size: 0.65rem;
}

.about-breadcrumb span {
  color: var(--color-accent);
  font-weight: 600;
}

/* --- Section 3: Mission / Vision / Values --- */
.mvv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
  position: relative;
  z-index: 2;
}

.mvv-card {
  background: white;
  border-radius: var(--radius-xl);
  padding: 3.5rem 2.5rem;
  box-shadow: var(--shadow-md);
  text-align: center;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  border: 1px solid rgba(0,0,0,0.03);
  position: relative;
  overflow: hidden;
}

.mvv-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: var(--gradient-accent);
  transform: scaleX(0);
  transition: transform var(--transition-normal);
  transform-origin: left;
}

.mvv-card:hover::before {
  transform: scaleX(1);
}

.mvv-card:hover {
  transform: translateY(-12px);
  box-shadow: var(--shadow-lg);
}

.mvv-card.featured {
  background: var(--gradient-primary);
  color: white;
  transform: scale(1.03);
  box-shadow: var(--shadow-lg);
}

.mvv-card.featured::before {
  background: var(--color-accent);
  transform: scaleX(1);
}

.mvv-card.featured:hover {
  transform: scale(1.03) translateY(-10px);
}

.mvv-card.featured h3 {
  color: white;
}

.mvv-card.featured p {
  color: rgba(255,255,255,0.85);
}

.mvv-icon-wrap {
  width: 80px;
  height: 80px;
  background: rgba(212, 168, 67, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 2rem;
  font-size: 2rem;
  color: var(--color-accent);
  transition: all var(--transition-normal);
}

.mvv-card.featured .mvv-icon-wrap {
  background: rgba(255,255,255,0.15);
  color: white;
}

.mvv-card:hover .mvv-icon-wrap {
  transform: rotateY(180deg);
  background: var(--gradient-accent);
  color: white;
}

.mvv-card h3 {
  font-size: 1.5rem;
  margin-bottom: 1.25rem;
}

.mvv-card p {
  color: var(--color-text-muted);
  font-size: 1.05rem;
  line-height: 1.7;
}

.values-list {
  list-style: none;
  text-align: left;
  padding: 0;
}

.values-list li {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--color-text-main);
}

.values-list li:last-child {
  margin-bottom: 0;
}

.values-list li i {
  color: var(--color-accent);
  font-size: 1.1rem;
}

/* --- Section 4: Meet the Team --- */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  position: relative;
  z-index: 2;
}

.team-card {
  background: white;
  border-radius: var(--radius-xl);
  padding: 2.5rem 2rem;
  box-shadow: var(--shadow-md);
  text-align: center;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  border: 1px solid rgba(0,0,0,0.03);
  position: relative;
  overflow: hidden;
}

.team-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: var(--gradient-accent);
  transform: scaleX(0);
  transition: transform var(--transition-normal);
  transform-origin: center;
}

.team-card:hover::after {
  transform: scaleX(1);
}

.team-card:hover {
  transform: translateY(-10px);
  box-shadow: var(--shadow-lg);
}

.team-avatar {
  margin-bottom: 1.5rem;
}

.team-avatar-placeholder {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 2.5rem;
  color: white;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
  transition: transform var(--transition-normal);
}

.team-card:hover .team-avatar-placeholder {
  transform: scale(1.1);
}

.team-info h4 {
  font-size: 1.3rem;
  margin-bottom: 0.25rem;
}

.team-role {
  display: inline-block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 1rem;
  background: rgba(212, 168, 67, 0.1);
  padding: 0.25rem 0.75rem;
  border-radius: var(--radius-full);
}

.team-info p {
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1.6;
}

.team-social {
  margin-top: 1.5rem;
}

.team-social a {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--color-bg-alt);
  color: var(--color-primary);
  font-size: 1rem;
  transition: all var(--transition-fast);
}

.team-social a:hover {
  background: var(--gradient-accent);
  color: white;
  transform: translateY(-3px);
}

/* --- Section 5: By The Numbers --- */
.numbers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  position: relative;
  z-index: 2;
}

.number-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  padding: 2.5rem 2rem;
  text-align: center;
  transition: all var(--transition-normal);
  backdrop-filter: blur(10px);
}

.number-card:hover {
  background: rgba(255,255,255,0.1);
  transform: translateY(-8px);
  border-color: var(--color-accent);
}

.number-icon {
  font-size: 2rem;
  color: var(--color-accent);
  margin-bottom: 1.25rem;
}

.number-value {
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 800;
  color: white;
  line-height: 1;
  margin-bottom: 0.5rem;
}

.number-label {
  color: rgba(255,255,255,0.6);
  font-weight: 500;
  margin-bottom: 1.5rem;
  font-size: 1rem;
}

.number-bar {
  height: 4px;
  background: rgba(255,255,255,0.1);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.number-bar-fill {
  height: 100%;
  background: var(--gradient-accent);
  border-radius: var(--radius-full);
  transition: width 1.5s cubic-bezier(0.4, 0, 0.2, 1);
}

/* --- Section 6: Cleaning Process Timeline --- */
.timeline {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  padding-left: 60px;
}

.timeline::before {
  content: '';
  position: absolute;
  top: 0;
  left: 30px;
  width: 3px;
  height: 100%;
  background: var(--gradient-accent);
  border-radius: var(--radius-full);
}

.timeline-item {
  position: relative;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: flex-start;
}

.timeline-item:last-child {
  margin-bottom: 0;
}

.timeline-marker {
  position: absolute;
  left: -60px;
  top: 0;
}

.timeline-dot {
  width: 55px;
  height: 55px;
  background: white;
  border: 3px solid var(--color-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--color-primary);
  box-shadow: 0 0 0 8px rgba(212, 168, 67, 0.08);
  transition: all var(--transition-normal);
  position: relative;
  z-index: 2;
}

.timeline-item:hover .timeline-dot {
  background: var(--gradient-accent);
  color: white;
  transform: scale(1.15);
  box-shadow: 0 0 0 12px rgba(212, 168, 67, 0.12);
}

.timeline-content {
  background: white;
  border-radius: var(--radius-lg);
  padding: 2.5rem;
  box-shadow: var(--shadow-md);
  width: 100%;
  transition: all var(--transition-normal);
  border: 1px solid rgba(0,0,0,0.03);
  position: relative;
}

.timeline-content::before {
  content: '';
  position: absolute;
  left: -10px;
  top: 18px;
  width: 20px;
  height: 20px;
  background: white;
  transform: rotate(45deg);
  box-shadow: -2px 2px 4px rgba(0,0,0,0.03);
  border-left: 1px solid rgba(0,0,0,0.03);
  border-bottom: 1px solid rgba(0,0,0,0.03);
}

.timeline-item:hover .timeline-content {
  transform: translateX(8px);
  box-shadow: var(--shadow-lg);
}

.timeline-icon {
  width: 50px;
  height: 50px;
  background: var(--gradient-accent);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 1.25rem;
  margin-bottom: 1.25rem;
  transition: transform var(--transition-normal);
}

.timeline-item:hover .timeline-icon {
  transform: rotateY(180deg);
}

.timeline-content h4 {
  font-size: 1.3rem;
  margin-bottom: 0.75rem;
}

.timeline-content p {
  color: var(--color-text-muted);
  font-size: 1.05rem;
  line-height: 1.7;
  margin-bottom: 0;
}

/* --- Section 7: Community & Sustainability --- */
.commitment-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

.commitment-card {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  padding: 1.5rem;
  background: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-normal);
  border: 1px solid transparent;
}

.commitment-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-5px);
  border-color: rgba(212, 168, 67, 0.2);
}

.commitment-icon {
  width: 50px;
  height: 50px;
  min-width: 50px;
  background: rgba(212, 168, 67, 0.1);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
  font-size: 1.25rem;
  transition: all var(--transition-normal);
}

.commitment-card:hover .commitment-icon {
  background: var(--gradient-accent);
  color: white;
  transform: scale(1.1);
}

.commitment-card h4 {
  font-size: 1.1rem;
  margin-bottom: 0.35rem;
}

.commitment-card p {
  color: var(--color-text-muted);
  font-size: 0.95rem;
  margin-bottom: 0;
  line-height: 1.5;
}

/* ==========================================================================
   RESPONSIVE — ABOUT PAGE
   ========================================================================== */
@media (max-width: 1024px) {
  .mvv-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .mvv-card.featured {
    transform: none;
  }

  .mvv-card.featured:hover {
    transform: translateY(-12px);
  }

  .team-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

  .numbers-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .commitment-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .team-grid {
    grid-template-columns: 1fr;
  }

  .numbers-grid {
    grid-template-columns: 1fr;
  }

  .timeline {
    padding-left: 50px;
  }

  .timeline::before {
    left: 20px;
  }

  .timeline-marker {
    left: -50px;
  }

  .timeline-dot {
    width: 45px;
    height: 45px;
    font-size: 1.1rem;
  }

  .timeline-content {
    padding: 2rem 1.5rem;
  }

  .timeline-content::before {
    display: none;
  }
}

/* ==========================================================================
   END OF LEASE CHECKLIST WIDGET  (Elementor-safe specificity)
   ========================================================================== */
.gifted-eol-section {
  padding: 2rem 0 !important;
  background: var(--color-bg-alt) !important;
}

/* Header */
.gifted-eol-section .gifted-eol-head {
  text-align: center !important;
  max-width: 720px;
  margin: 0 auto 3rem !important;
}
.gifted-eol-section .gifted-eol-head .section-subtitle { margin-bottom: 1rem !important; }
.gifted-eol-section .gifted-eol-head h2 {
  font-family: var(--font-heading) !important;
  font-size: 2.2rem !important;
  font-weight: 700 !important;
  color: #1B2A5E !important;
  margin-bottom: 1rem !important;
}
.gifted-eol-section .gifted-eol-head p {
  color: #4A5568 !important;
  font-size: 1.05rem !important;
  line-height: 1.7 !important;
  margin-bottom: 0 !important;
}

/* Card Grid */
.gifted-eol-section .gifted-eol-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 1.5rem !important;
  margin-bottom: 2rem !important;
}
.gifted-eol-section .gifted-eol-card {
  background: #fff !important;
  border-radius: 1.5rem !important;
  box-shadow: 0 4px 6px rgba(0,0,0,0.03) !important;
  overflow: hidden !important;
  border: 1px solid rgba(0,0,0,0.04) !important;
  transition: all 0.3s ease !important;
}
.gifted-eol-section .gifted-eol-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 40px rgba(27,42,94,0.12) !important;
  border-color: rgba(212,168,67,0.25) !important;
}

/* Card Head */
.gifted-eol-section .gifted-eol-card-head {
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
  padding: 1.25rem 1.5rem !important;
  background: linear-gradient(135deg, #1B2A5E 0%, #3355CC 100%) !important;
  color: #fff !important;
  position: relative !important;
}
.gifted-eol-section .gifted-eol-card-head i,
.gifted-eol-section .gifted-eol-card-head svg {
  font-size: 1.2rem !important;
  color: #D4A843 !important;
  width: 1em !important;
  height: 1em !important;
  fill: currentColor !important;
}
.gifted-eol-section .gifted-eol-card-head h3 {
  font-family: var(--font-heading) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #fff !important;
  flex: 1 !important;
  line-height: 1.3 !important;
}
.gifted-eol-section .gifted-eol-count {
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  background: rgba(212,168,67,0.2) !important;
  color: rgba(255,255,255,0.9) !important;
  padding: 0.25rem 0.6rem !important;
  border-radius: 99px !important;
  white-space: nowrap !important;
  display: inline-block !important;
}

/* Checklist Items */
.gifted-eol-section .gifted-eol-items {
  list-style: none !important;
  margin: 0 !important;
  padding: 1.25rem 1.5rem !important;
}
.gifted-eol-section .gifted-eol-items li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.6rem !important;
  padding: 0.45rem 0 !important;
  font-size: 0.88rem !important;
  color: #4A5568 !important;
  line-height: 1.5 !important;
  border-bottom: 1px solid rgba(0,0,0,0.03) !important;
  list-style: none !important;
  margin: 0 !important;
}
.gifted-eol-section .gifted-eol-items li:last-child { border-bottom: none !important; }
.gifted-eol-section .gifted-eol-items li::before { display: none !important; }
.gifted-eol-section .gifted-eol-items li > i {
  color: #D4A843 !important;
  font-size: 0.7rem !important;
  margin-top: 0.3rem !important;
  flex-shrink: 0 !important;
}

/* Extras Bar */
.gifted-eol-section .gifted-eol-extras {
  display: flex !important;
  align-items: center !important;
  gap: 1.25rem !important;
  background: #fff !important;
  padding: 1.25rem 2rem !important;
  border-radius: 1.5rem !important;
  box-shadow: 0 4px 6px rgba(0,0,0,0.03) !important;
  margin-bottom: 2rem !important;
  border: 1px solid rgba(0,0,0,0.04) !important;
  flex-wrap: wrap !important;
}
.gifted-eol-section .gifted-eol-extras-label {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  font-size: 0.9rem !important;
  color: #1B2A5E !important;
  white-space: nowrap !important;
}
.gifted-eol-section .gifted-eol-extras-label i { color: #D4A843 !important; }
.gifted-eol-section .gifted-eol-extras-list {
  display: flex !important;
  gap: 0.5rem !important;
  flex-wrap: wrap !important;
  flex: 1 !important;
}
.gifted-eol-section .gifted-eol-extra-chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.4rem !important;
  padding: 0.4rem 0.85rem !important;
  background: rgba(212,168,67,0.08) !important;
  border: 1px solid rgba(212,168,67,0.2) !important;
  border-radius: 99px !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: #1B2A5E !important;
  transition: all 0.2s !important;
}
.gifted-eol-section .gifted-eol-extra-chip:hover {
  background: rgba(212,168,67,0.15) !important;
  border-color: rgba(212,168,67,0.35) !important;
  transform: translateY(-2px) !important;
}
.gifted-eol-section .gifted-eol-extra-chip i,
.gifted-eol-section .gifted-eol-extra-chip svg {
  font-size: 0.75rem !important;
  color: #D4A843 !important;
  width: 1em !important;
  height: 1em !important;
  fill: currentColor !important;
}

/* CTA */
.gifted-eol-section .gifted-eol-cta {
  text-align: center !important;
  padding-top: 1rem !important;
}
.gifted-eol-section .gifted-eol-cta .btn {
  font-size: 1.05rem !important;
  padding: 1rem 2.5rem !important;
}
.gifted-eol-section .gifted-eol-guarantee {
  margin-top: 1rem !important;
  font-size: 0.88rem !important;
  color: #4A5568 !important;
}
.gifted-eol-section .gifted-eol-guarantee i { color: #D4A843 !important; margin-right: 0.35rem !important; }

/* Responsive */
@media (max-width: 1024px) {
  .gifted-eol-section .gifted-eol-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 640px) {
  .gifted-eol-section .gifted-eol-grid { grid-template-columns: 1fr !important; }
  .gifted-eol-section .gifted-eol-head h2 { font-size: 1.6rem !important; }
  .gifted-eol-section .gifted-eol-extras { flex-direction: column !important; align-items: flex-start !important; }
}

/* ==========================================================================
   CITY / SUBURB LANDING PAGE WIDGETS
   ========================================================================== */

/* ─── City Hero ─── */
.city-hero {
  position: relative; min-height: 85vh; display: flex; align-items: center;
  padding-top: 100px; overflow: hidden;
}
.city-hero-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; }
.city-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.city-hero-overlay {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(135deg, rgba(27,42,94,0.95) 0%, rgba(27,42,94,0.8) 50%, rgba(27,42,94,0.5) 100%);
}
.city-hero-content { position: relative; z-index: 2; max-width: 700px; color: white; }
.city-hero-badge {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: rgba(212,168,67,0.15); border: 1px solid rgba(212,168,67,0.3);
  padding: 0.5rem 1.25rem; border-radius: 99px; font-size: 0.88rem;
  font-weight: 600; color: var(--color-accent-light); margin-bottom: 1.5rem;
  backdrop-filter: blur(5px);
}
.city-hero h1 {
  font-size: clamp(2.8rem, 5.5vw, 4rem); font-weight: 800; line-height: 1.1;
  margin-bottom: 1.5rem; color: white;
}
.text-gradient {
  background: var(--gradient-accent);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.city-hero p { font-size: 1.2rem; color: rgba(255,255,255,0.9); line-height: 1.7; margin-bottom: 2rem; max-width: 550px; }
.city-hero-buttons { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.city-hero-stats {
  display: flex; align-items: center; gap: 2rem;
  padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.15);
}
.city-stat strong { display: block; font-family: var(--font-heading); font-size: 1.5rem; font-weight: 800; color: var(--color-accent); }
.city-stat span { font-size: 0.85rem; color: rgba(255,255,255,0.7); }
.city-stat-divider { width: 1px; height: 40px; background: rgba(255,255,255,0.15); }

/* ─── City Trust Bar ─── */
.city-trust-bar {
  background: white; padding: 2rem 0; position: relative; z-index: 10;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}
.city-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.city-trust-item { display: flex; align-items: center; gap: 1rem; }
.city-trust-icon {
  width: 48px; height: 48px; min-width: 48px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(212,168,67,0.1); color: var(--color-accent); font-size: 1.2rem;
}
.city-trust-icon i, .city-trust-icon svg { width: 1em; height: 1em; fill: currentColor; }
.city-trust-item strong { display: block; font-family: var(--font-heading); font-size: 0.92rem; color: var(--color-primary); }
.city-trust-item span { font-size: 0.8rem; color: var(--color-text-muted); }

/* ─── City Process ─── */
.city-process-grid { display: flex; align-items: flex-start; gap: 0; justify-content: center; }
.city-process-step {
  flex: 1; text-align: center; padding: 2rem 1.5rem; position: relative;
  background: white; border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
  margin: 0 0.5rem; border: 1px solid rgba(0,0,0,0.04); transition: all 0.3s;
}
.city-process-step:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.city-process-num {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  width: 28px; height: 28px; background: var(--gradient-accent); color: var(--color-navy);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading); font-weight: 800; font-size: 0.8rem;
  box-shadow: 0 4px 12px rgba(212,168,67,0.3);
}
.city-process-icon {
  width: 60px; height: 60px; border-radius: 50%; margin: 0.5rem auto 1rem;
  display: flex; align-items: center; justify-content: center;
  background: rgba(212,168,67,0.08); color: var(--color-accent); font-size: 1.5rem;
}
.city-process-icon i, .city-process-icon svg { width: 1em; height: 1em; fill: currentColor; }
.city-process-step h3 { font-size: 1.05rem; margin-bottom: 0.5rem; }
.city-process-step p { font-size: 0.88rem; color: var(--color-text-muted); line-height: 1.6; margin: 0; }
.city-process-connector {
  display: flex; align-items: center; color: var(--color-accent); font-size: 1rem;
  padding-top: 4rem; opacity: 0.4;
}

/* ─── City Suburbs ─── */
.city-suburbs-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0.75rem; }
.city-suburb-card {
  display: flex; align-items: center; gap: 0.6rem; padding: 0.85rem 1.25rem;
  background: white; border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
  font-weight: 600; font-size: 0.9rem; color: var(--color-primary);
  border: 1px solid rgba(0,0,0,0.04); transition: all 0.3s; cursor: pointer;
}
.city-suburb-card:hover {
  transform: translateY(-3px); box-shadow: var(--shadow-md);
  border-color: rgba(212,168,67,0.3); color: var(--color-accent-dark);
}
.city-suburb-card i { color: var(--color-accent); font-size: 0.85rem; }

/* ─── City Reviews ─── */
.city-reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.city-review-card {
  background: white; border-radius: var(--radius-lg); padding: 2rem;
  box-shadow: var(--shadow-sm); border: 1px solid rgba(0,0,0,0.04);
  transition: all 0.3s; position: relative;
}
.city-review-card::before {
  content: '\201C'; position: absolute; top: 1rem; right: 1.5rem;
  font-size: 4rem; font-family: Georgia, serif; color: rgba(212,168,67,0.12); line-height: 1;
}
.city-review-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.city-review-stars { color: #D4A843; font-size: 1rem; margin-bottom: 1rem; letter-spacing: 2px; }
.city-review-card > p { font-size: 0.95rem; color: var(--color-text-muted); line-height: 1.7; margin-bottom: 1.5rem; font-style: italic; }
.city-review-author { display: flex; align-items: center; gap: 0.75rem; }
.city-review-avatar {
  width: 42px; height: 42px; border-radius: 50%; background: var(--gradient-primary);
  color: white; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading); font-weight: 700; font-size: 0.85rem;
}
.city-review-author strong { display: block; font-size: 0.9rem; color: var(--color-primary); }
.city-review-author span { font-size: 0.8rem; color: var(--color-text-muted); }

/* ─── City FAQ ─── */
.city-faq-list { max-width: 800px; margin: 0 auto; }
.city-faq-item {
  background: white; border-radius: var(--radius-md); margin-bottom: 0.75rem;
  box-shadow: var(--shadow-sm); border: 1px solid rgba(0,0,0,0.04);
  overflow: hidden; transition: all 0.3s;
}
.city-faq-item:hover { box-shadow: var(--shadow-md); }
.city-faq-q {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 1.25rem 1.5rem; background: none; border: none; cursor: pointer;
  font-family: var(--font-heading); font-weight: 700; font-size: 1rem;
  color: var(--color-primary); text-align: left; gap: 1rem;
}
.city-faq-q span { flex: 1; }
.city-faq-q i { color: var(--color-accent); font-size: 0.85rem; transition: transform 0.3s; }
.city-faq-item.open .city-faq-q i { transform: rotate(180deg); }
.city-faq-a {
  max-height: 0; overflow: hidden; transition: max-height 0.4s ease, padding 0.4s ease;
  padding: 0 1.5rem;
}
.city-faq-item.open .city-faq-a { max-height: 300px; padding: 0 1.5rem 1.25rem; }
.city-faq-a p { font-size: 0.92rem; color: var(--color-text-muted); line-height: 1.7; margin: 0; }

/* ─── City Widgets Responsive ─── */
@media (max-width: 1024px) {
  .city-trust-grid { grid-template-columns: repeat(2, 1fr); }
  .city-process-grid { flex-wrap: wrap; }
  .city-process-connector { display: none; }
  .city-process-step { flex: 0 0 calc(50% - 1rem); margin-bottom: 1.5rem; }
  .city-suburbs-grid { grid-template-columns: repeat(3, 1fr); }
  .city-reviews-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .city-hero { min-height: 70vh; }
  .city-hero h1 { font-size: 2rem; }
  .city-hero-stats { flex-direction: column; gap: 1rem; align-items: flex-start; }
  .city-stat-divider { width: 40px; height: 1px; }
  .city-trust-grid { grid-template-columns: 1fr; }
  .city-process-step { flex: 0 0 100%; }
  .city-suburbs-grid { grid-template-columns: repeat(2, 1fr); }
  .city-reviews-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   INDIVIDUAL SERVICE WIDGETS
   ========================================================================== */

/* Utility Classes for Service Widgets */
.bg-alt { background: var(--color-bg-alt); }
.text-center { text-align: center; }
.section-header { max-width: 700px; margin: 0 auto 3rem; text-align: center; }
.section-header p { color: var(--color-text-muted); font-size: 1.1rem; }
.section-pill { display:inline-block; padding:0.4rem 1.2rem; background:rgba(212,168,67,0.15); color:var(--color-gold-dark); border-radius:99px; font-weight:600; margin-bottom:1rem; font-size:0.85rem; text-transform:uppercase; letter-spacing:1px; }

/* Widget 1: Service Hero */
.service-hero { background: var(--color-primary); color: white; padding: 8rem 0 5rem; text-align: center; position: relative; overflow: hidden; }
.service-hero::before { content: ''; position: absolute; top:0; left:0; width:100%; height:100%; background: radial-gradient(circle at 50% 0%, rgba(212,168,67,0.15) 0%, transparent 60%); }
.service-hero h1 { color: white; font-size: 3.5rem; margin-bottom: 1.5rem; z-index: 2; position: relative; }
.service-hero p { font-size: 1.2rem; color: rgba(255,255,255,0.8); max-width: 700px; margin: 0 auto 2rem; z-index: 2; position: relative; }
.hero-trust-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 2rem; margin-top: 3rem; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 2rem; position:relative; z-index:2; }
.hero-badge { display: flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.9); font-weight: 500; }
.hero-badge i { color: var(--color-gold); font-size: 1.2rem; }

/* Widget 2: Service Overview (Split Content) */
.service-overview { display: flex; gap: 4rem; align-items: center; }
.service-overview.reverse { flex-direction: row-reverse; }
.overview-content { flex: 1; }
.overview-image { flex: 1; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); position:relative; }
.overview-image img { width: 100%; height: auto; display: block; }
.overview-image::after { content:''; position:absolute; inset:0; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.1); border-radius:var(--radius-lg); pointer-events:none; }
.overview-list { list-style: none; margin-top: 2rem; }
.overview-list li { margin-bottom: 1.5rem; display: flex; gap: 1rem; align-items: flex-start; }
.overview-list i, .overview-list svg { color: var(--color-gold); font-size: 1.5rem; margin-top: 0.2rem; }
.overview-list h4 { margin-bottom: 0.25rem; font-size:1.1rem; }
.overview-list p { color: var(--color-text-muted); font-size: 0.95rem; margin:0; }

/* Widget 3: Our Process (Steps) */
.process-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 2rem; position: relative; }
.process-step { background: white; padding: 2.5rem 2rem; border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); text-align: center; position: relative; z-index: 2; border:1px solid #f0f0f0;}
.step-number { width: 50px; height: 50px; background: var(--gradient-gold); color: var(--color-navy); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: 700; margin: 0 auto 1.5rem; }
.process-step h3 { font-size: 1.2rem; margin-bottom: 1rem; }
.process-step p { color: var(--color-text-muted); font-size: 0.95rem; }

/* Widget 4: Target Industries (For Commercial) */
.industries-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; }
.industry-card { position: relative; border-radius: var(--radius-md); overflow: hidden; height: 250px; display:flex; align-items:flex-end; padding:2rem; color:white; }
.industry-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; transition: transform 0.5s; }
.industry-card:hover img { transform: scale(1.05); }
.industry-card::before { content:''; position:absolute; inset:0; background: linear-gradient(to top, rgba(27,42,94,0.9), transparent); z-index: 1; }
.industry-content { position: relative; z-index: 2; width:100%; }
.industry-content h3 { color:white; margin:0 0 0.5rem; font-size:1.5rem; }
.industry-content p { color:rgba(255,255,255,0.8); font-size:0.9rem; margin:0; }

/* Widget 5: Pricing Packages (For Domestic) */
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; align-items: stretch; }
.pricing-card { background: white; border-radius: var(--radius-lg); padding: 3rem 2rem; box-shadow: var(--shadow-md); text-align: center; border: 1px solid #eee; position:relative; overflow:hidden; }
.pricing-card.popular { border-color: var(--color-gold); box-shadow: 0 20px 40px rgba(212,168,67,0.15); transform:scale(1.02); }
.pricing-badge { position:absolute; top:1rem; right:-2rem; background:var(--color-gold); color:var(--color-navy); font-weight:700; font-size:0.75rem; padding:0.25rem 3rem; transform:rotate(45deg); letter-spacing:1px; }
.pricing-title { font-size: 1.5rem; color: var(--color-primary); margin-bottom: 0.5rem; }
.pricing-price { font-size: 3rem; font-weight: 700; color: var(--color-primary); margin-bottom: 1rem; font-family:var(--font-heading); }
.pricing-price span { font-size: 1rem; color: var(--color-text-muted); font-weight: 400; }
.pricing-features { list-style: none; margin: 2rem 0; text-align: left; }
.pricing-features li { margin-bottom: 1rem; font-size: 0.95rem; color: var(--color-text-muted); display: flex; gap: 0.5rem; }
.pricing-features i, .pricing-features svg { color: var(--color-secondary); margin-top:0.3rem;}

/* Widget 6: Before & After (For Carpet/Gardening) */
.ba-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.ba-card { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.ba-label { position:absolute; top:1rem; left:1rem; background:rgba(27,42,94,0.8); color:white; padding:0.25rem 1rem; border-radius:99px; font-size:0.8rem; font-weight:600; text-transform:uppercase; z-index:2; backdrop-filter:blur(4px); }
.ba-card img { width:100%; height:300px; object-fit:cover; display:block; }

/* Widget 7: Included Checklist (Grid style) */
.checklist-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }
.checklist-card { background: white; padding: 2rem; border-radius: var(--radius-md); box-shadow: var(--shadow-sm); border:1px solid #f0f0f0; }
.checklist-card-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; border-bottom: 1px solid #eee; padding-bottom: 1rem; }
.checklist-card-head i, .checklist-card-head svg { font-size: 1.8rem; color: var(--color-gold); }
.checklist-card-head h3 { margin: 0; font-size: 1.25rem; }
.check-items { list-style: none; }
.check-items li { margin-bottom: 0.75rem; font-size: 0.95rem; color: var(--color-text-muted); display: flex; gap: 0.5rem; }
.check-items li i, .check-items li svg { color: var(--color-secondary); font-size: 0.8rem; margin-top: 0.3rem; }

/* Widget 8: Optional Extras Pills */
.extras-wrapper { background: var(--color-primary); color: white; padding: 3rem; border-radius: var(--radius-lg); text-align:center; }
.extras-wrapper h3 { color: white; margin-bottom: 2rem; }
.extras-grid { display: flex; flex-wrap: wrap; gap: 1rem; justify-content:center; }
.extra-chip { background: rgba(255,255,255,0.1); padding: 0.75rem 1.5rem; border-radius: 99px; font-size: 0.95rem; display: flex; align-items: center; gap: 0.5rem; border: 1px solid rgba(255,255,255,0.2); transition:background 0.3s; }
.extra-chip:hover { background: rgba(255,255,255,0.2); }
/* Widget 1: Service Hero */
.service-hero { background: var(--color-primary); color: white; padding: 8rem 0 5rem; text-align: center; position: relative; overflow: hidden; }
.service-hero::before { content: ''; position: absolute; top:0; left:0; width:100%; height:100%; background: radial-gradient(circle at 50% 0%, rgba(212,168,67,0.15) 0%, transparent 60%); }
.service-hero h1 { color: white; font-size: 3.5rem; margin-bottom: 1.5rem; z-index: 2; position: relative; }
.service-hero p { font-size: 1.2rem; color: rgba(255,255,255,0.8); max-width: 700px; margin: 0 auto 2rem; z-index: 2; position: relative; }
.hero-trust-badges { display: flex; justify-content: center; flex-wrap: wrap; gap: 2rem; margin-top: 3rem; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 2rem; position:relative; z-index:2; }
.hero-badge { display: flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.9); font-weight: 500; }
.hero-badge i { color: var(--color-gold); font-size: 1.2rem; }

/* Widget 2: Service Overview (Split Content) */
.service-overview { display: flex; gap: 4rem; align-items: center; }
.service-overview.reverse { flex-direction: row-reverse; }
.overview-content { flex: 1; }
.overview-image { flex: 1; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); position:relative; }
.overview-image img { width: 100%; height: auto; display: block; }
.overview-image::after { content:''; position:absolute; inset:0; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.1); border-radius:var(--radius-lg); pointer-events:none; }
.overview-list { list-style: none; margin-top: 2rem; }
.overview-list li { margin-bottom: 1.5rem; display: flex; gap: 1rem; align-items: flex-start; }
.overview-list i, .overview-list svg { color: var(--color-gold); font-size: 1.5rem; margin-top: 0.2rem; }
.overview-list h4 { margin-bottom: 0.25rem; font-size:1.1rem; }
.overview-list p { color: var(--color-text-muted); font-size: 0.95rem; margin:0; }

/* Widget 3: Our Process (Steps) */
.process-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 2rem; position: relative; }
.process-step { background: white; padding: 2.5rem 2rem; border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); text-align: center; position: relative; z-index: 2; border:1px solid #f0f0f0;}
.step-number { width: 50px; height: 50px; background: var(--gradient-gold); color: var(--color-navy); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: 700; margin: 0 auto 1.5rem; }
.process-step h3 { font-size: 1.2rem; margin-bottom: 1rem; }
.process-step p { color: var(--color-text-muted); font-size: 0.95rem; }

/* Widget 4: Target Industries (For Commercial) */
.industries-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; }
.industry-card { position: relative; border-radius: var(--radius-md); overflow: hidden; height: 250px; display:flex; align-items:flex-end; padding:2rem; color:white; }
.industry-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; transition: transform 0.5s; }
.industry-card:hover img { transform: scale(1.05); }
.industry-card::before { content:''; position:absolute; inset:0; background: linear-gradient(to top, rgba(27,42,94,0.9), transparent); z-index: 1; }
.industry-content { position: relative; z-index: 2; width:100%; }
.industry-content h3 { color:white; margin:0 0 0.5rem; font-size:1.5rem; }
.industry-content p { color:rgba(255,255,255,0.8); font-size:0.9rem; margin:0; }

/* Widget 5: Pricing Packages (For Domestic) */
.pricing-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; align-items: stretch; }
.pricing-card { background: white; border-radius: var(--radius-lg); padding: 3rem 2rem; box-shadow: var(--shadow-md); text-align: center; border: 1px solid #eee; position:relative; overflow:hidden; }
.pricing-card.popular { border-color: var(--color-gold); box-shadow: 0 20px 40px rgba(212,168,67,0.15); transform:scale(1.02); }
.pricing-badge { position:absolute; top:1rem; right:-2rem; background:var(--color-gold); color:var(--color-navy); font-weight:700; font-size:0.75rem; padding:0.25rem 3rem; transform:rotate(45deg); letter-spacing:1px; }
.pricing-title { font-size: 1.5rem; color: var(--color-primary); margin-bottom: 0.5rem; }
.pricing-price { font-size: 3rem; font-weight: 700; color: var(--color-primary); margin-bottom: 1rem; font-family:var(--font-heading); }
.pricing-price span { font-size: 1rem; color: var(--color-text-muted); font-weight: 400; }
.pricing-features { list-style: none; margin: 2rem 0; text-align: left; }
.pricing-features li { margin-bottom: 1rem; font-size: 0.95rem; color: var(--color-text-muted); display: flex; gap: 0.5rem; }
.pricing-features i, .pricing-features svg { color: var(--color-secondary); margin-top:0.3rem;}

/* Widget 6: Before & After (For Carpet/Gardening) */
.ba-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.ba-card { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.ba-label { position:absolute; top:1rem; left:1rem; background:rgba(27,42,94,0.8); color:white; padding:0.25rem 1rem; border-radius:99px; font-size:0.8rem; font-weight:600; text-transform:uppercase; z-index:2; backdrop-filter:blur(4px); }
.ba-card img { width:100%; height:300px; object-fit:cover; display:block; }

/* Widget 7: Included Checklist (Grid style) */
.checklist-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }
.checklist-card { background: white; padding: 2rem; border-radius: var(--radius-md); box-shadow: var(--shadow-sm); border:1px solid #f0f0f0; }
.checklist-card-head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; border-bottom: 1px solid #eee; padding-bottom: 1rem; }
.checklist-card-head i, .checklist-card-head svg { font-size: 1.8rem; color: var(--color-gold); }
.checklist-card-head h3 { margin: 0; font-size: 1.25rem; }
.check-items { list-style: none; }
.check-items li { margin-bottom: 0.75rem; font-size: 0.95rem; color: var(--color-text-muted); display: flex; gap: 0.5rem; }
.check-items li i, .check-items li svg { color: var(--color-secondary); font-size: 0.8rem; margin-top: 0.3rem; }

/* Widget 8: Optional Extras Pills */
.extras-wrapper { background: var(--color-primary); color: white; padding: 3rem; border-radius: var(--radius-lg); text-align:center; }
.extras-wrapper h3 { color: white; margin-bottom: 2rem; }
.extras-grid { display: flex; flex-wrap: wrap; gap: 1rem; justify-content:center; }
.extra-chip { background: rgba(255,255,255,0.1); padding: 0.75rem 1.5rem; border-radius: 99px; font-size: 0.95rem; display: flex; align-items: center; gap: 0.5rem; border: 1px solid rgba(255,255,255,0.2); transition:background 0.3s; }
.extra-chip:hover { background: rgba(255,255,255,0.2); }
.extra-chip i, .extra-chip svg { color: var(--color-gold); }

/* Widget 9: FAQs */
.faq-wrapper { max-width: 800px; margin: 0 auto; }
.faq-item { background: white; margin-bottom: 1rem; border-radius: var(--radius-md); border: 1px solid #eee; box-shadow:var(--shadow-sm); }
.faq-q { padding: 1.5rem; cursor: pointer; font-weight: 600; display: flex; justify-content: space-between; align-items: center; color: var(--color-primary); font-size:1.1rem; }
.faq-a { padding: 0 1.5rem 1.5rem; color: var(--color-text-muted); display: none; }

/* Widget 10: CTA Banner */
.cta-banner { background: var(--gradient-gold); padding: 5rem 0; text-align: center; border-radius:var(--radius-lg); margin: 4rem 0; box-shadow:var(--shadow-md); }
.cta-banner h2 { color: var(--color-navy); font-size: 2.5rem; }
.cta-banner p { color: var(--color-navy); font-size: 1.1rem; margin-bottom: 2rem; font-weight: 500; }

/* ==========================================================================
   MEGA MENU & BLOG ARCHIVE / SINGLE
   ========================================================================== */

/* Mega Menu Dropdown */
.mega-menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(15px); width: 900px; background: white; border-radius: var(--radius-md); box-shadow: 0 20px 40px rgba(27,42,94,0.1); opacity: 0; visibility: hidden; transition: all 0.3s ease; display: flex; border-top: 4px solid var(--color-primary); pointer-events: none; z-index:999; }
.nav-item.has-mega-menu:hover .mega-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); pointer-events: auto; }
.mega-menu::before { content: ''; position: absolute; top: -8px; left: 50%; transform: translateX(-50%); border-left: 8px solid transparent; border-right: 8px solid transparent; border-bottom: 8px solid var(--color-primary); }
.mega-menu-content { flex: 1; padding: 2.5rem; display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.mega-col h3 { font-family: var(--font-heading); color: var(--color-primary); font-size: 1.2rem; margin-bottom: 1.5rem; padding-bottom: 0.5rem; border-bottom: 2px solid rgba(27,42,94,0.1); }
.mega-service-item { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.25rem; text-decoration: none; color: var(--color-text); transition: all 0.3s; border-radius: 8px; padding: 0.5rem; }
.mega-service-item:hover { background: var(--color-bg-light); transform: translateX(5px); }
.mega-thumb { width: 60px; height: 60px; border-radius: 8px; object-fit: cover; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.mega-text h4 { font-size: 1rem; color: var(--color-primary); margin-bottom: 0.2rem; transition: color 0.3s; }
.mega-service-item:hover .mega-text h4 { color: var(--color-accent); }
.mega-text p { font-size: 0.8rem; color: var(--color-text-muted); margin: 0; line-height: 1.3; }
.mega-sidebar { width: 280px; background: var(--color-primary); color: white; padding: 2.5rem; border-radius: 0 var(--radius-md) var(--radius-md) 0; display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.mega-sidebar h3 { font-family: var(--font-heading); font-size: 1.4rem; margin-bottom: 1rem; position: relative; z-index: 2; color: white; }
.mega-sidebar p { font-size: 0.9rem; color: rgba(255,255,255,0.8); margin-bottom: 1.5rem; position: relative; z-index: 2; }
.mega-sidebar .btn-sidebar { background: white; color: var(--color-primary); text-align: center; padding: 0.8rem; border-radius: 99px; text-decoration: none; font-weight: 700; font-size: 0.9rem; position: relative; z-index: 2; }
.mega-sidebar .btn-sidebar:hover { background: var(--color-accent); color: var(--color-secondary); }

/* Responsive Mega Menu */
@media (max-width: 1024px) {
  .mega-menu { width: 90vw; left: 5vw; transform: translateY(15px); }
  .nav-item.has-mega-menu:hover .mega-menu { transform: translateY(0); }
  .mega-sidebar { width: 220px; padding: 1.5rem; }
  .mega-menu-content { padding: 1.5rem; gap: 1.5rem; }
}

@media (max-width: 768px) {
  .mega-menu { position: static; width: 100%; transform: none !important; flex-direction: column; box-shadow: none; border-top: none; display: none !important; background: transparent; }
  .nav-item.has-mega-menu:hover .mega-menu, .nav-item.has-mega-menu.active .mega-menu { display: flex !important; opacity: 1; visibility: visible; pointer-events: auto; padding-top: 1rem; margin-bottom: 1rem; }
  .mega-menu::before { display: none; }
  .mega-menu-content { padding: 0 0 1rem 1rem; gap: 1.5rem; border-left: 2px solid rgba(212,168,67,0.3); margin-left: 0.5rem; grid-template-columns: 1fr; background: transparent; }
  .mega-col h3 { font-size: 1.1rem; margin-bottom: 1rem; border-bottom: none; padding-bottom: 0; color: white; }
  .mega-service-item { margin-bottom: 0.8rem !important; padding: 0; gap: 0.75rem; color: white !important; display: flex; align-items: center; }
  .mega-service-item:hover { background: transparent; transform: translateX(3px); }
  .mega-text h4 { font-size: 0.95rem; color: white; margin-bottom: 0; }
  .mega-service-item:hover .mega-text h4 { color: var(--color-accent); }
  .mega-text p { display: none; }
  .mega-thumb { width: 40px; height: 40px; border-radius: 6px; }
  .mega-sidebar { width: 100%; border-radius: var(--radius-md); padding: 1.5rem; text-align: center; }
}

/* Advanced Reveal & Blobs */
.reveal { opacity: 0; transform: translateY(40px); transition: all 0.8s cubic-bezier(0.25, 0.8, 0.25, 1); }
.reveal.active { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: 0.1s; } .delay-2 { transition-delay: 0.2s; } .delay-3 { transition-delay: 0.3s; }
.shape-blob { position: absolute; background: var(--color-accent); border-radius: 50%; filter: blur(80px); opacity: 0.15; z-index: 0; animation: float 8s infinite alternate ease-in-out; pointer-events: none; }
@keyframes float { 0% { transform: translate(0, 0) scale(1) rotate(0deg); } 100% { transform: translate(50px, -50px) scale(1.1) rotate(10deg); } }

/* Blog Archive */
.blog-hero { background: var(--color-primary); color: white; padding: 8rem 0 6rem; text-align: center; position: relative; overflow: hidden; box-shadow: 0 10px 30px rgba(13,21,41,0.3); }
.blog-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at center, rgba(212,168,67,0.15) 0%, transparent 70%); z-index: 1; }
.blog-hero h1 { font-family: var(--font-heading); font-size: clamp(2.5rem, 5vw, 4rem); margin-bottom: 1rem; position: relative; z-index: 2; text-shadow: 0 4px 20px rgba(0,0,0,0.3); color:white; }
.blog-hero p { font-size: 1.25rem; color: rgba(255,255,255,0.8); max-width: 650px; margin: 0 auto; position: relative; z-index: 2; }
.blog-filters { display: flex; justify-content: center; flex-wrap: wrap; gap: 1rem; margin: -30px auto 4rem; position: relative; z-index: 10; }
.filter-btn { background: white; color: var(--color-primary); border: 2px solid transparent; padding: 0.8rem 1.8rem; border-radius: 99px; font-family: var(--font-body); font-weight: 600; cursor: pointer; box-shadow: 0 10px 20px rgba(0,0,0,0.05); transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); text-decoration:none; }
.filter-btn:hover { transform: translateY(-5px); border-color: var(--color-accent); box-shadow: 0 15px 25px rgba(212,168,67,0.2); }
.filter-btn.active { background: var(--color-primary); color: white; border-color: var(--color-primary); }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)); gap: 2.5rem; padding-bottom: 5rem; position: relative; z-index:2; }
.blog-card { background: white; border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 5px 15px rgba(0,0,0,0.03); transition: all 0.5s cubic-bezier(0.25, 0.8, 0.25, 1); display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,0.04); position: relative; text-decoration:none; }
.blog-card:hover { transform: translateY(-12px); border-color: rgba(212,168,67,0.3); box-shadow: 0 20px 40px rgba(27,42,94,0.12); }
.blog-thumb { height: 240px; overflow: hidden; position: relative; }
.blog-thumb::before { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(13,21,41,0.5), transparent); z-index: 1; opacity: 0.5; transition: opacity 0.3s; }
.blog-card:hover .blog-thumb::before { opacity: 0.2; }
.blog-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s cubic-bezier(0.25, 0.8, 0.25, 1); }
.blog-card:hover .blog-thumb img { transform: scale(1.08); }
.blog-category { position: absolute; top: 1.5rem; left: 1.5rem; background: rgba(255,255,255,0.9); backdrop-filter: blur(5px); color: var(--color-primary); font-size: 0.75rem; font-weight: 700; padding: 0.4rem 1.2rem; border-radius: 99px; text-transform: uppercase; letter-spacing: 1px; z-index: 2; transition: background 0.3s, color 0.3s; }
.blog-card:hover .blog-category { background: var(--color-accent); color: var(--color-secondary); }
.blog-content { padding: 2.5rem; flex: 1; display: flex; flex-direction: column; position: relative; z-index: 2; background: white; }
.blog-meta { font-size: 0.85rem; color: var(--color-text-muted); margin-bottom: 1rem; display: flex; gap: 1.5rem; align-items: center; }
.blog-meta i { color: var(--color-accent); }
.blog-title { font-family: var(--font-heading); font-size: 1.5rem; color: var(--color-primary); margin-bottom: 1rem; line-height: 1.3; transition: color 0.3s; }
.blog-card:hover .blog-title { color: var(--color-accent-dark); }
.blog-excerpt { color: var(--color-text-muted); font-size: 1rem; margin-bottom: 2rem; flex: 1; }
.read-more { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--color-primary); font-weight: 700; text-decoration: none; font-size: 0.95rem; transition: all 0.3s; margin-top: auto; position: relative; padding-bottom: 0.2rem; }
.read-more::after { content: ''; position: absolute; left: 0; bottom: 0; width: 0%; height: 2px; background: var(--color-accent); transition: width 0.3s; }
.blog-card:hover .read-more { color: var(--color-accent-dark); }
.blog-card:hover .read-more::after { width: 100%; }
.blog-card:hover .read-more i { transform: translateX(8px); }

/* Blog Single */
.article-header { padding: 6rem 0 4rem; text-align: center; max-width: 900px; margin: 0 auto; position:relative; z-index:2; }
.category-pill { display: inline-block; background: rgba(212,168,67,0.15); color: #B58A2D; font-size: 0.85rem; font-weight: 700; padding: 0.5rem 1.5rem; border-radius: 99px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 2rem; box-shadow: 0 5px 15px rgba(212,168,67,0.1); }
.article-header h1 { font-family: var(--font-heading); font-size: clamp(2.5rem, 5vw, 3.5rem); color: var(--color-primary); line-height: 1.2; margin-bottom: 2rem; }
.author-meta { display: inline-flex; align-items: center; justify-content: center; gap: 1rem; color: var(--color-text-muted); font-size: 1rem; background: white; padding: 1rem 2rem; border-radius: 99px; box-shadow: 0 10px 25px rgba(0,0,0,0.05); }
.author-meta img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.author-meta .divider { color: #ddd; }
.featured-image-container { max-width: 1000px; margin: 0 auto 5rem; border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 25px 50px rgba(27,42,94,0.15); position: relative; z-index:2; }
.featured-image-container img { width: 100%; max-height: 500px; object-fit: cover; display: block; }
.content-layout { display: grid; grid-template-columns: 1fr 350px; gap: 4rem; max-width: 1100px; margin: 0 auto 5rem; position:relative; z-index:2; }
.article-body { background: white; padding: 4rem; border-radius: var(--radius-lg); box-shadow: 0 10px 30px rgba(0,0,0,0.03); border: 1px solid rgba(0,0,0,0.02); }
.article-content h2 { font-family: var(--font-heading); color: var(--color-primary); font-size: 2.2rem; margin: 3rem 0 1.5rem; }
.article-content h3 { font-family: var(--font-heading); color: var(--color-primary); font-size: 1.6rem; margin: 2.5rem 0 1rem; }
.article-content p { margin-bottom: 1.5rem; font-size: 1.15rem; color: #555; }
.article-content ul, .article-content ol { margin-bottom: 2rem; padding-left: 1.5rem; font-size: 1.15rem; color: #555; }
.article-content li { margin-bottom: 0.8rem; }
.article-content blockquote { border-left: 5px solid var(--color-accent); background: rgba(212,168,67,0.05); padding: 2rem 3rem; margin: 3rem 0; font-size: 1.4rem; font-style: italic; color: var(--color-primary); border-radius: 0 12px 12px 0; position: relative; }
.article-content blockquote::before { content: '\f10d'; font-family: 'Font Awesome 6 Free'; font-weight: 900; position: absolute; top: 1rem; left: 1rem; font-size: 3rem; color: rgba(212,168,67,0.15); z-index: 0; }
.article-content blockquote p { position: relative; z-index: 1; margin: 0; }
.article-content img { width: 100%; height: auto; border-radius: var(--radius-lg); margin: 3rem 0; box-shadow: 0 10px 20px rgba(0,0,0,0.05); }
.article-footer { margin-top: 4rem; padding-top: 3rem; border-top: 2px solid #f0f0f0; display: flex; justify-content: space-between; align-items: center; flex-wrap:wrap; gap:1rem;}
.tags { display: flex; gap: 0.8rem; flex-wrap:wrap;}
.tags span, .tags a { background: var(--color-bg-light); padding: 0.5rem 1.2rem; border-radius: 99px; font-size: 0.9rem; color: var(--color-primary); font-weight: 600; transition: all 0.3s; cursor: pointer; text-decoration:none;}
.tags span:hover, .tags a:hover { background: var(--color-primary); color: white; transform: translateY(-2px); }
.share { display: flex; gap: 1rem; align-items: center; }
.share a { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--color-bg-light); color: var(--color-primary); border-radius: 50%; text-decoration: none; transition: all 0.4s; font-size: 1.1rem; }
.share a:hover { background: var(--color-accent); color: var(--color-secondary); transform: translateY(-5px) rotate(8deg); box-shadow: 0 10px 20px rgba(212,168,67,0.3); }

/* Sidebar */
.blog-sidebar { position: sticky; top: 40px; }
.service-cta { background: var(--color-primary); color: white; padding: 3rem 2rem; border-radius: var(--radius-lg); text-align: center; position: relative; overflow: hidden; box-shadow: 0 20px 40px rgba(27,42,94,0.2); transition: transform 0.3s; }
.service-cta:hover { transform: translateY(-5px); }
.service-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at top right, rgba(212,168,67,0.2) 0%, transparent 70%); }
.service-cta h4 { color: white; font-family: var(--font-heading); font-size: 1.8rem; margin-bottom: 1rem; position: relative; z-index: 2; border:none; padding:0; }
.service-cta p { font-size: 1rem; color: rgba(255,255,255,0.8); margin-bottom: 2rem; position: relative; z-index: 2; }
.service-cta .btn { position:relative; z-index:2; }
.sidebar-widget { background: white; padding: 2.5rem; border-radius: var(--radius-lg); margin-top: 2.5rem; box-shadow: 0 10px 30px rgba(0,0,0,0.03); border: 1px solid rgba(0,0,0,0.02); }
.sidebar-widget h4 { font-family: var(--font-heading); color: var(--color-primary); font-size: 1.4rem; margin-bottom: 1.5rem; padding-bottom: 1rem; border-bottom: 2px solid rgba(27,42,94,0.1); }
.recent-post { display: flex; gap: 1.2rem; margin-bottom: 1.5rem; text-decoration: none; color: var(--color-text); align-items: center; padding: 0.5rem; border-radius: 8px; transition: background 0.3s, transform 0.3s; }
.recent-post:hover { background: var(--color-bg-light); transform: translateX(5px); }
.recent-post img { width: 80px; height: 80px; object-fit: cover; border-radius: 12px; box-shadow: 0 5px 15px rgba(0,0,0,0.05); }
.recent-text h5 { font-size: 1rem; margin-bottom: 0.3rem; transition: color 0.3s; line-height: 1.3; color:var(--color-primary); }
.recent-post:hover .recent-text h5 { color: var(--color-accent-dark); }
.recent-text span { font-size: 0.8rem; color: var(--color-text-muted); font-weight: 500; }
@media (max-width: 1024px) { .content-layout { grid-template-columns: 1fr; } .blog-sidebar { position: static; } }
