/* ─── VANCOUVER BC COLOR SYSTEM ─────────────────────────────────────────── */
:root{
  /* Primary: Deep ocean teal - False Creek / Burrard Inlet */
  --primary:#0a6e7c;
  --primary-dark:#085a66;
  --primary-light:#0e8fa0;
  --primary-pale:#e6f4f6;
  --primary-soft:#b8dfe4;

  /* Accent: Forest green - North Shore mountains */
  --accent:#2d6a4f;
  --accent-light:#40916c;
  --accent-pale:#d8f3dc;

  /* Highlight: Warm gold - sunset over English Bay */
  --gold:#c68b2a;
  --gold-pale:#fef3dd;

  /* Neutrals */
  --white:#ffffff;
  --off-white:#f7fafb;
  --light:#eef4f5;
  --border:#d0e4e7;
  --mid-gray:#6b8a90;
  --text:#1a2e32;
  --text-muted:#4a6670;
  --dark:#0d2126;

  /* Functional */
  --star:#f4b942;
  --radius:8px;
  --radius-lg:14px;
  --shadow-sm:0 2px 8px rgba(10,110,124,0.10);
  --shadow-md:0 6px 24px rgba(10,110,124,0.14);
  --shadow-lg:0 16px 48px rgba(10,110,124,0.18);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;color:var(--text);background:var(--white);overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font:inherit;cursor:pointer;border:none;background:none;}

/* ─── ANNOUNCEMENT BAR ───────────────────────────────────────────────────── */
.announce-bar{
  background:var(--primary);color:var(--white);
  padding:0;overflow:hidden;
}
.announce-track{
  display:flex;gap:0;white-space:nowrap;
  animation:scroll-left 38s linear infinite;
}
.announce-item{
  display:inline-flex;align-items:center;gap:0.6rem;
  padding:0.65rem 2.5rem;font-size:0.78rem;font-weight:500;letter-spacing:0.04em;
  border-right:1px solid rgba(255,255,255,0.2);flex-shrink:0;
}
.announce-item .leaf{color:#7ed8a4;font-size:0.9rem;}
@keyframes scroll-left{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── NAV ────────────────────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:200;
  background:var(--white);
  border-bottom:2px solid var(--primary);
  box-shadow:var(--shadow-sm);
}
.nav-inner{
  max-width:1240px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1.5rem;min-height:72px;gap:1.5rem;
}
.nav-inner a {
  text-decoration: none !important;
}
.nav-logo{
  display:flex;align-items:center;gap:0.75rem;flex-shrink:0;
}
.nav-logo-mark{
  width:44px;height:44px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  display:flex;align-items:center;justify-content:center;
  color:white;flex-shrink:0;
}
.nav-logo-mark svg{width:26px;height:26px;}
.nav-logo-text{line-height:1.1;}
.nav-logo-text strong{display:block;font-size:1rem;font-weight:800;color:var(--primary);letter-spacing:-0.02em;}
.nav-logo-text span{display:block;font-size:0.7rem;color:var(--mid-gray);font-weight:400;letter-spacing:0.03em;}

.nav-links{display:flex;align-items:center;gap:0.15rem;}
.nav-links a{
  padding:0.6rem 0.85rem;font-size:0.82rem;font-weight:500;color:var(--text-muted);
  border-radius:6px;transition:all 0.2s;white-space:nowrap;
}
.nav-links a:hover{background:var(--primary-pale);color:var(--primary);}
.nav-links .has-dropdown{position:relative;}
.dropdown{
  position:absolute;top:100%;left:0;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);min-width:230px;padding:0.5rem;
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:all 0.22s;z-index:300;
}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.dropdown a{
  display:block;padding:0.65rem 1rem;font-size:0.83rem;color:var(--text);
  border-radius:6px;transition:background 0.15s;
}
.dropdown a:hover{background:var(--primary-pale);color:var(--primary);}

.nav-cta{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:var(--primary);color:var(--white);
  padding:0.65rem 1.3rem;border-radius:var(--radius);
  font-size:0.82rem;font-weight:700;letter-spacing:0.02em;
  transition:background 0.2s,transform 0.2s;white-space:nowrap;flex-shrink:0;
}
.nav-cta:hover{background:var(--primary-dark);transform:translateY(-1px);color: var(--white);}
.nav-cta .star-icon{font-size:0.9rem;}
.menu-btn{display:none;padding:0.5rem;border-radius:6px;color:var(--text);}

/* ─── HERO ───────────────────────────────────────────────────────────────── */
.hero{
  background:linear-gradient(135deg,var(--dark) 0%,var(--primary-dark) 45%,var(--accent) 100%);
  position:relative;overflow:hidden;
  padding:4.5rem 1.5rem 3.5rem;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%,rgba(14,143,160,0.25),transparent),
    radial-gradient(ellipse 40% 60% at 20% 80%,rgba(45,106,79,0.2),transparent);
}
/* Mountain silhouette */
.hero-mountain{
  position:absolute;bottom:0;left:0;right:0;height:180px;
  opacity:0.12;pointer-events:none;
}
.hero-inner{max-width:1240px;margin:0 auto;position:relative;z-index:2;}
.hero-grid{display:grid;grid-template-columns:1fr 420px;gap:3rem;align-items:center;}

.hero-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);
  color:rgba(255,255,255,0.9);border-radius:100px;
  padding:0.45rem 1rem;font-size:0.75rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  margin-bottom:1.25rem;backdrop-filter:blur(8px);
}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:#7ed8a4;flex-shrink:0;}
.hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.2rem,4.5vw,3.6rem);
  font-weight:700;line-height:1.05;letter-spacing:-0.02em;
  color:var(--white);margin-bottom:1.25rem;
}
.hero h1 em{font-style:italic;color:#7ed8a4;}
.hero-sub{
  font-size:1.05rem;color:rgba(255,255,255,0.75);line-height:1.7;
  max-width:52ch;margin-bottom:2rem;font-weight:300;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:0.85rem;margin-bottom:2.5rem;}
.btn-hero-primary{
  display:inline-flex;align-items:center;gap:0.6rem;
  background:var(--white);color:var(--primary);
  padding:0.9rem 1.8rem;border-radius:var(--radius);
  font-size:0.9rem;font-weight:800;letter-spacing:0.01em;
  transition:all 0.2s;box-shadow:0 4px 16px rgba(0,0,0,0.2);
}
.btn-hero-primary:hover{background:var(--primary-pale);transform:translateY(-2px);}
.btn-hero-ghost{
  display:inline-flex;align-items:center;gap:0.6rem;
  border:1.5px solid rgba(255,255,255,0.35);color:var(--white);
  padding:0.9rem 1.8rem;border-radius:var(--radius);
  font-size:0.9rem;font-weight:600;
  transition:all 0.2s;backdrop-filter:blur(6px);
}
.btn-hero-ghost:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.6);}

.hero-trust-pills{display:flex;flex-wrap:wrap;gap:0.6rem;}
.trust-pill{
  display:inline-flex;align-items:center;gap:0.45rem;
  background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.85);border-radius:100px;
  padding:0.4rem 0.85rem;font-size:0.75rem;font-weight:500;
  backdrop-filter:blur(6px);
}
.trust-pill .icon{font-size:0.85rem;}

/* Hero card */
.hero-card{
  background:rgba(255,255,255,0.95);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);overflow:hidden;
  backdrop-filter:blur(12px);
}
.hero-card-top{
  background:linear-gradient(135deg,var(--primary-pale),var(--light));
  padding:2rem;text-align:center;
  border-bottom:1px solid var(--border);
}
.stars-large{color:var(--star);font-size:1.4rem;letter-spacing:2px;margin-bottom:0.5rem;}
.hero-card-rating{font-size:1.8rem;font-weight:800;color:var(--primary);line-height:1;}
.hero-card-rating span{font-size:0.85rem;font-weight:400;color:var(--text-muted);display:block;margin-top:0.2rem;}
.hero-card-body{padding:1.5rem;}
.hero-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.hero-stat-item{background:var(--white);padding:1rem;text-align:center;}
.hero-stat-item strong{display:block;font-size:1.3rem;font-weight:800;color:var(--primary);line-height:1;}
.hero-stat-item span{font-size:0.72rem;color:var(--text-muted);font-weight:500;letter-spacing:0.04em;text-transform:uppercase;margin-top:0.2rem;display:block;}
.hero-cta-card{
  display:block;margin:1.25rem;
  background:var(--primary);color:var(--white);
  text-align:center;padding:0.9rem;border-radius:var(--radius);
  font-weight:700;font-size:0.88rem;letter-spacing:0.02em;
  transition:background 0.2s;
}
.hero-cta-card:hover{background:var(--primary-dark);}

/* ─── TRUST BAR ──────────────────────────────────────────────────────────── */
.trust-bar{background:var(--primary-pale);border-bottom:1px solid var(--primary-soft);}
.trust-bar-inner{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(5,1fr);
  divide-x:1px solid var(--border);
}
.trust-item{
  display:flex;align-items:center;gap:0.85rem;
  padding:1.1rem 1.5rem;border-right:1px solid var(--primary-soft);
}
.trust-item:last-child{border-right:none;}
.trust-icon{
  width:2.6rem;height:2.6rem;border-radius:10px;
  background:var(--primary);color:var(--white);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.trust-icon svg{width:18px;height:18px;}
.trust-text strong{display:block;font-size:0.83rem;font-weight:700;color:var(--text);}
.trust-text span{font-size:0.72rem;color:var(--text-muted);}

/* ─── SECTION COMMONS ────────────────────────────────────────────────────── */
.section{padding:5rem 1.5rem;}
.section-alt{background:var(--off-white);}
.section-dark{background:var(--dark);color:var(--white);}
.container{max-width:1240px;margin:0 auto;}
.section-header{text-align:center;margin-bottom:3.5rem;}
.section-eyebrow{
  display:inline-flex;align-items:center;gap:0.5rem;
  color:var(--primary);font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;
  margin-bottom:0.85rem;
}
.section-eyebrow::before,.section-eyebrow::after{content:'';width:2rem;height:2px;background:var(--primary);border-radius:2px;}
h2.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;
  letter-spacing:-0.02em;line-height:1.15;color:var(--text);margin-bottom:0.75rem;
}
h2.section-title em{font-style:italic;color:var(--primary);}
.section-sub{font-size:1rem;color:var(--text-muted);max-width:58ch;margin:0 auto;line-height:1.7;}

/* ─── PRODUCTS GRID ──────────────────────────────────────────────────────── */
.products-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.product-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform 0.25s,box-shadow 0.25s;display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.product-img{
  height:210px;
  background:linear-gradient(135deg,var(--primary-pale) 0%,var(--light) 100%);
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
}
/* Illustrated canvas mockup in each card */
.canvas-mockup{
  width:130px;height:100px;background:var(--white);
  border:8px solid #f0ede8;border-bottom-width:12px;
  box-shadow:0 8px 24px rgba(0,0,0,0.18),inset 0 0 0 1px rgba(0,0,0,0.06);
  position:relative;border-radius:2px;overflow:hidden;
}
.pc-badge{
  position:absolute;top:0.85rem;left:0.85rem;
  background:var(--primary);color:var(--white);
  font-size:0.65rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  padding:0.3rem 0.65rem;border-radius:100px;
}
.pc-badge.gold{background:var(--gold);}
.product-body{padding:1.5rem;flex:1;display:flex;flex-direction:column;}
.product-body h3{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:0.5rem;line-height:1.25;}
.product-body p{font-size:0.85rem;color:var(--text-muted);line-height:1.65;flex:1;}
.product-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);
}
.product-price{font-size:0.9rem;font-weight:700;color:var(--primary);}
.product-price span{font-size:0.75rem;font-weight:400;color:var(--text-muted);}
.btn-card{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:var(--primary);color:var(--white);
  padding:0.5rem 1rem;border-radius:var(--radius);
  font-size:0.78rem;font-weight:700;
  transition:background 0.2s;
}
.btn-card:hover{background:var(--primary-dark);}

/* Canvas art fills */
.art-landscape{background:linear-gradient(180deg,#5b9eb3 0%,#4a8a9e 35%,#3d7a52 60%,#2d6040 100%);}
.art-wedding{background:linear-gradient(135deg,#f9f0e8,#f0dcc8);}
.art-pet{background:linear-gradient(180deg,#e8f4d8,#c8e8a8);}
.art-collage{background:linear-gradient(135deg,#e8f0f8,#c8d8ec);}
.art-wall{background:linear-gradient(135deg,#f0e8e8,#e8d8d8);}
.art-baby{background:linear-gradient(135deg,#fef0f8,#f8e0f0);}

/* ─── HOW IT WORKS ───────────────────────────────────────────────────────── */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;}
.step-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:2rem;text-align:center;position:relative;
  box-shadow:var(--shadow-sm);
}
.step-num{
  width:2.8rem;height:2.8rem;border-radius:50%;
  background:var(--primary);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;font-weight:800;margin:0 auto 1.25rem;
}
.step-icon{
  width:3.5rem;height:3.5rem;border-radius:14px;
  background:var(--primary-pale);display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;color:var(--primary);
}
.step-icon svg{width:22px;height:22px;}
.step-card h3{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:0.6rem;}
.step-card p{font-size:0.85rem;color:var(--text-muted);line-height:1.65;}
.step-connector{
  position:absolute;top:2.8rem;right:-1.3rem;width:2.6rem;height:2px;
  background:var(--border);z-index:1;
}
.step-connector::after{
  content:'›';position:absolute;right:-8px;top:-11px;
  color:var(--primary);font-size:1.3rem;font-weight:700;
}

/* ─── WHY CHOOSE ─────────────────────────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;}
.why-card{
  display:flex;gap:1rem;align-items:flex-start;
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:1.5rem;box-shadow:var(--shadow-sm);
  transition:border-color 0.2s;
}
.why-card:hover{border-color:var(--primary);}
.why-icon{
  width:2.8rem;height:2.8rem;border-radius:12px;
  background:var(--primary);color:var(--white);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.why-icon svg{width:18px;height:18px;}
.why-card h3{font-size:0.92rem;font-weight:700;color:var(--text);margin-bottom:0.35rem;}
.why-card p{font-size:0.82rem;color:var(--text-muted);line-height:1.65;}

/* ─── COMPARISON TABLE ───────────────────────────────────────────────────── */
.compare-wrap{overflow-x:auto;}
.compare-table{width:100%;border-collapse:collapse;font-size:0.85rem;}
.compare-table thead th{
  padding:1rem 1.5rem;text-align:left;
  font-size:0.78rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  border-bottom:2px solid var(--border);
}
.compare-table thead th:first-child{color:var(--text-muted);}
.compare-table thead th.ours{
  background:var(--primary-pale);color:var(--primary);
  border-bottom-color:var(--primary);border-radius:var(--radius) var(--radius) 0 0;
}
.compare-table tbody td{
  padding:0.9rem 1.5rem;border-bottom:1px solid var(--border);vertical-align:middle;
}
.compare-table tbody td.ours{background:rgba(10,110,124,0.04);}
.compare-table tbody tr:last-child td{border-bottom:none;}
.compare-table tbody tr:hover td{background:var(--off-white);}
.compare-table tbody tr:hover td.ours{background:rgba(10,110,124,0.06);}
.check{color:var(--accent);font-weight:700;}
.cross{color:#d94040;font-weight:700;}
.badge-best{
  display:inline-flex;align-items:center;gap:0.3rem;
  background:var(--primary);color:var(--white);
  font-size:0.65rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;
  padding:0.25rem 0.6rem;border-radius:100px;margin-left:0.4rem;
}

/* ─── REVIEWS ────────────────────────────────────────────────────────────── */
.rating-hero{
  background:linear-gradient(135deg,var(--primary),var(--accent));
  border-radius:var(--radius-lg);padding:2.5rem;color:var(--white);text-align:center;
  margin-bottom:2.5rem;
}
.rating-big{font-size:4rem;font-weight:800;line-height:1;}
.rating-stars{color:var(--star);font-size:1.6rem;letter-spacing:3px;margin:0.5rem 0;}
.rating-label{font-size:0.85rem;opacity:0.8;}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
.review-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:1.5rem;box-shadow:var(--shadow-sm);
}
.review-stars{color:var(--star);font-size:0.9rem;letter-spacing:2px;margin-bottom:0.85rem;}
.review-text{font-size:0.85rem;color:var(--text);line-height:1.7;margin-bottom:1.1rem;font-style:italic;}
.review-author{display:flex;align-items:center;gap:0.75rem;}
.review-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--primary);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:0.8rem;font-weight:700;flex-shrink:0;
}
.review-name{font-size:0.82rem;font-weight:700;color:var(--text);}
.review-meta{font-size:0.72rem;color:var(--text-muted);}

/* ─── SERVICE AREAS ──────────────────────────────────────────────────────── */
.areas-panel{
  background:linear-gradient(135deg,var(--primary-pale),var(--accent-pale));
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:2.5rem;
}
.area-chips{display:flex;flex-wrap:wrap;gap:0.65rem;margin-top:1.25rem;}
.area-chip{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:var(--white);border:1px solid var(--border);
  color:var(--text);border-radius:100px;
  padding:0.45rem 1rem;font-size:0.8rem;font-weight:500;
  transition:all 0.2s;
}
.area-chip:hover{background:var(--primary);color:var(--white);border-color:var(--primary);}
.area-chip .wave{font-size:0.8rem;}

/* ─── FAQ ────────────────────────────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column;gap:0.65rem;max-width:820px;margin:0 auto;}
.faq-item{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.25rem 1.5rem;text-align:left;
  font-size:0.9rem;font-weight:600;color:var(--text);
  transition:background 0.2s;
}
.faq-q:hover{background:var(--primary-pale);}
.faq-q.open{background:var(--primary-pale);color:var(--primary);}
.faq-toggle{
  width:24px;height:24px;border-radius:50%;
  background:var(--primary);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:400;flex-shrink:0;
  transition:transform 0.3s;
}
.faq-q.open .faq-toggle{transform:rotate(45deg);}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.4s cubic-bezier(0.16,1,0.3,1);
}
.faq-a-inner{padding:0 1.5rem 1.25rem;font-size:0.87rem;color:var(--text-muted);line-height:1.75;}
.faq-item.open .faq-a{max-height:300px;}

/* ─── RESELLER ───────────────────────────────────────────────────────────── */
.reseller-split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;}
.reseller-perks{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem;}
.perk-row{
  display:flex;gap:0.85rem;align-items:flex-start;
  padding:1rem;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius);
}
.perk-icon{
  width:2.2rem;height:2.2rem;border-radius:8px;
  background:rgba(255,255,255,0.12);color:var(--white);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.perk-row strong{display:block;font-size:0.85rem;font-weight:700;color:var(--white);margin-bottom:0.15rem;}
.perk-row span{font-size:0.78rem;color:rgba(255,255,255,0.6);}

/* ─── CTA FINAL ──────────────────────────────────────────────────────────── */
.final-cta{
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,var(--accent) 100%);
  padding:5.5rem 1.5rem;text-align:center;position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='20'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.final-cta-inner{position:relative;z-index:1;max-width:640px;margin:0 auto;}
.final-cta h2{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--white);margin-bottom:1rem;line-height:1.1;}
.final-cta p{color:rgba(255,255,255,0.75);font-size:1rem;line-height:1.7;margin-bottom:2.5rem;}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.btn-white{
  display:inline-flex;align-items:center;gap:0.6rem;
  background:var(--white);color:var(--primary);
  padding:1rem 2rem;border-radius:var(--radius);
  font-size:0.9rem;font-weight:800;
  transition:all 0.2s;box-shadow:0 4px 16px rgba(0,0,0,0.2);
}
.btn-white:hover{background:var(--primary-pale);transform:translateY(-2px);}
.btn-outline-white{
  display:inline-flex;align-items:center;gap:0.6rem;
  border:2px solid rgba(255,255,255,0.4);color:var(--white);
  padding:1rem 2rem;border-radius:var(--radius);
  font-size:0.9rem;font-weight:600;
  transition:all 0.2s;
}
.btn-outline-white:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.7);}

/* Order flow strip */
.order-flow{
  display:inline-flex;align-items:center;gap:0;margin-top:3rem;
  background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);
  border-radius:var(--radius);overflow:hidden;backdrop-filter:blur(6px);
}
.flow-step{
  padding:0.75rem 1.25rem;text-align:center;border-right:1px solid rgba(255,255,255,0.15);
}
.flow-step:last-child{border-right:none;}
.flow-num{font-size:0.6rem;color:rgba(255,255,255,0.5);display:block;letter-spacing:0.1em;text-transform:uppercase;}
.flow-label{font-size:0.78rem;color:rgba(255,255,255,0.85);font-weight:600;}

/* ─── FOOTER ─────────────────────────────────────────────────────────────── */
.footer{background:var(--dark);color:rgba(255,255,255,0.65);}
.footer-top{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:3rem;
  padding:4rem 1.5rem 3rem;border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-brand-name{
  font-size:1rem;font-weight:800;color:var(--white);letter-spacing:-0.01em;margin-bottom:0.75rem;
  display:flex;align-items:center;gap:0.5rem;
}
.footer-brand-name .leaf{color:#7ed8a4;}
.footer-tagline{font-size:0.8rem;line-height:1.7;margin-bottom:1.25rem;}
.footer-contact{font-size:0.8rem;line-height:1.9;}
.footer-contact a{color:var(--primary-soft);transition:color 0.2s;}
.footer-contact a:hover{color:var(--white);}
.footer-col-title{font-size:0.7rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);margin-bottom:1rem;}
.footer-col a{display:block;font-size:0.8rem;padding:0.22rem 0;transition:color 0.2s;}
.footer-col a:hover{color:var(--white);}
.footer-bottom{
  max-width:1240px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.75rem;
  padding:1.25rem 1.5rem;font-size:0.75rem;color:rgba(255,255,255,0.35);
}

/* ─── REVEAL ─────────────────────────────────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity 0.65s ease,transform 0.65s ease;}
[data-reveal].visible{opacity:1;transform:translateY(0);}
[data-reveal][data-delay="1"]{transition-delay:0.1s;}
[data-reveal][data-delay="2"]{transition-delay:0.2s;}
[data-reveal][data-delay="3"]{transition-delay:0.3s;}
[data-reveal][data-delay="4"]{transition-delay:0.4s;}
[data-reveal][data-delay="5"]{transition-delay:0.5s;}


/* ─── LOCAL SEO / AEO / GEO CONTENT ─────────────────────────────────────── */
.local-seo-grid{display:grid;grid-template-columns:1.15fr 0.85fr;gap:1.5rem;align-items:start;}
.local-copy-card,.answer-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.6rem;box-shadow:var(--shadow-sm);}
.local-copy-card h3,.answer-card h3{font-size:1rem;font-weight:800;color:var(--primary);margin-bottom:0.65rem;}
.local-copy-card p,.answer-card p{font-size:0.88rem;color:var(--text-muted);line-height:1.75;margin-bottom:0.85rem;}
.answer-list{display:flex;flex-direction:column;gap:0.75rem;}
.answer-mini{border-left:3px solid var(--primary);padding-left:0.9rem;}
.answer-mini strong{display:block;font-size:0.86rem;color:var(--text);margin-bottom:0.2rem;}
.answer-mini span{font-size:0.8rem;color:var(--text-muted);line-height:1.6;display:block;}
.geo-keywords{display:flex;flex-wrap:wrap;gap:0.45rem;margin-top:1rem;}
.geo-keywords span{background:var(--primary-pale);color:var(--primary);border:1px solid var(--primary-soft);border-radius:999px;padding:0.35rem 0.7rem;font-size:0.75rem;font-weight:600;}
@media(max-width:900px){.local-seo-grid{grid-template-columns:1fr;}}

/* ─── RESPONSIVE ─────────────────────────────────────────────────────────── */
@media(max-width:1100px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-card{max-width:480px;}
  .products-grid{grid-template-columns:repeat(2,1fr);}
  .reviews-grid{grid-template-columns:repeat(2,1fr);}
  .steps-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr 1fr;}
  .trust-bar-inner{grid-template-columns:repeat(3,1fr);}
  .why-grid{grid-template-columns:1fr;}
  .reseller-split{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .products-grid{grid-template-columns:1fr;}
  .reviews-grid{grid-template-columns:1fr;}
  .steps-grid{grid-template-columns:1fr;}
  .step-connector{display:none;}
  .nav-links{display:none;}
  .menu-btn{display:flex;}
  .trust-bar-inner{grid-template-columns:1fr 1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
  .cta-actions{flex-direction:column;align-items:center;}
  .order-flow{flex-direction:column;}
  .flow-step{border-right:none;border-bottom:1px solid rgba(255,255,255,0.15);}
  .flow-step:last-child{border-bottom:none;}
  .hero-stats-grid{grid-template-columns:1fr 1fr;}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;}
  [data-reveal]{opacity:1;transform:none;}
}

/* Scrollbar */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--light);}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px;}
::selection{background:var(--primary);color:var(--white);}

.max-w-150 {
  max-width: 150px;
}

.main-menu .menu-item a {
  padding: 0.6rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text-muted);
  border-radius: 6px;
  transition: all 0.2s;
  white-space: nowrap;
}
.main-menu .menu-item .sub-menu a {
    display: block;
    padding: 0.65rem 1rem;
    font-size: 0.83rem;
    color: var(--text);
    border-radius: 6px;
    font-weight: 500;
    transition: background 0.15s;
    white-space: nowrap;
}
.main-menu .menu-item:hover>a {
    background: var(--primary-pale) !important;
    color: var(--primary) !important;
}
.mega-menu .narrow ul.sub-menu {
  background-color: white;
}

.mega-menu .narrow li.menu-item>a {
    color: var(--text);
}