/*
Theme Name: Canada ServiceHub Pro
Theme URI: https://example.com/canada-servicehub-pro
Author: Marjan Online Digital Services
Author URI: https://example.com
Description: English only, Google Ads friendly WordPress service theme for Canada focused digital services with editable service links, trust pages, schema, responsive service cards and fast frontend performance.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: canada-servicehub-pro
Tags: custom-logo, custom-menu, one-column, two-columns, responsive-layout, theme-options, accessibility-ready
*/

:root {
  --cs-primary: #2563eb;
  --cs-primary-dark: #1d4ed8;
  --cs-dark: #0f172a;
  --cs-muted: #475569;
  --cs-soft: #f8fafc;
  --cs-border: #e2e8f0;
  --cs-card: #ffffff;
  --cs-success: #16a34a;
  --cs-warning: #f59e0b;
  --cs-radius: 22px;
  --cs-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--cs-dark);
  background: #ffffff;
  line-height: 1.65;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }

.cs-container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.cs-skip-link { position: absolute; left: -999px; top: 12px; background: var(--cs-dark); color: #fff; padding: 10px 14px; border-radius: 10px; z-index: 999; }
.cs-skip-link:focus { left: 12px; }

.cs-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--cs-border);
}
.cs-nav { display: flex; align-items: center; justify-content: space-between; min-height: 76px; gap: 24px; }
.cs-brand { display: flex; align-items: center; gap: 12px; font-weight: 900; letter-spacing: -0.04em; font-size: 1.1rem; }
.cs-brand-mark { width: 42px; height: 42px; border-radius: 14px; background: linear-gradient(135deg, var(--cs-primary), #60a5fa); color: #fff; display: grid; place-items: center; font-weight: 900; box-shadow: 0 10px 25px rgba(37,99,235,.26); }
.cs-menu { display: flex; align-items: center; gap: 22px; padding: 0; margin: 0; list-style: none; }
.cs-menu a { color: var(--cs-muted); font-weight: 700; font-size: 0.94rem; }
.cs-menu a:hover { color: var(--cs-primary); }
.cs-header-cta { background: var(--cs-primary); color: #fff; padding: 11px 18px; border-radius: 999px; font-weight: 800; box-shadow: 0 10px 25px rgba(37,99,235,.22); }
.cs-mobile-toggle { display: none; border: 1px solid var(--cs-border); background: #fff; border-radius: 12px; padding: 10px 12px; font-weight: 800; }

.cs-hero { position: relative; overflow: hidden; background: radial-gradient(circle at top left, rgba(37,99,235,.16), transparent 34%), linear-gradient(180deg, #fff, #f8fafc); padding: 88px 0 64px; }
.cs-hero-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(340px, .9fr); gap: 54px; align-items: center; }
.cs-eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px; background: #eff6ff; color: var(--cs-primary); border: 1px solid #bfdbfe; border-radius: 999px; font-size: .84rem; font-weight: 900; margin-bottom: 18px; }
.cs-hero h1 { font-size: clamp(2.6rem, 6vw, 5.25rem); line-height: .95; letter-spacing: -.07em; margin: 0 0 24px; }
.cs-hero h1 span { color: var(--cs-primary); }
.cs-lead { font-size: clamp(1.06rem, 2vw, 1.28rem); color: var(--cs-muted); max-width: 720px; margin: 0 0 30px; }
.cs-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.cs-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 999px; padding: 13px 20px; font-weight: 900; border: 1px solid transparent; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; cursor: pointer; }
.cs-btn:hover { transform: translateY(-2px); }
.cs-btn-primary { background: var(--cs-primary); color: #fff; box-shadow: 0 14px 28px rgba(37,99,235,.24); }
.cs-btn-primary:hover { background: var(--cs-primary-dark); }
.cs-btn-secondary { background: #fff; color: var(--cs-dark); border-color: var(--cs-border); }
.cs-btn-secondary:hover { box-shadow: var(--cs-shadow); }
.cs-proof { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 36px; }
.cs-proof-card { background: #fff; border: 1px solid var(--cs-border); border-radius: 18px; padding: 18px; box-shadow: 0 10px 30px rgba(15,23,42,.05); }
.cs-proof-card strong { display: block; font-size: 1.6rem; letter-spacing: -.04em; }
.cs-proof-card span { color: var(--cs-muted); font-size: .88rem; font-weight: 700; }
.cs-hero-panel { background: var(--cs-dark); color: #fff; border-radius: 34px; padding: 28px; box-shadow: 0 30px 70px rgba(15,23,42,.24); }
.cs-panel-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; }
.cs-pulse { display:inline-flex; width:12px; height:12px; background:#22c55e; border-radius:50%; box-shadow:0 0 0 8px rgba(34,197,94,.14); }
.cs-panel-row { display:flex; justify-content:space-between; gap:18px; padding:16px 0; border-top:1px solid rgba(255,255,255,.12); }
.cs-panel-row span { color:#cbd5e1; }
.cs-panel-row strong { text-align:right; }

.cs-section { padding: 72px 0; }
.cs-section-alt { background: var(--cs-soft); }
.cs-section-head { display:flex; justify-content:space-between; align-items:end; gap:30px; margin-bottom:34px; }
.cs-section-head h2 { font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1; letter-spacing: -.06em; margin: 0; }
.cs-section-head p { color: var(--cs-muted); margin: 0; max-width: 580px; }
.cs-category-title { display:flex; align-items:center; gap:12px; margin: 42px 0 18px; }
.cs-category-title:first-of-type { margin-top:0; }
.cs-category-title h3 { margin:0; font-size:1.35rem; letter-spacing:-.03em; }
.cs-category-dot { width:12px; height:12px; border-radius:50%; background:var(--cs-primary); }

.cs-services-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.cs-card { position:relative; overflow:hidden; display:flex; flex-direction:column; background:var(--cs-card); border:1px solid var(--cs-border); border-radius:var(--cs-radius); padding:24px; box-shadow: 0 8px 26px rgba(15,23,42,.04); transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease; min-height: 330px; }
.cs-card:hover { transform: translateY(-6px); box-shadow: var(--cs-shadow); border-color:#bfdbfe; }
.cs-card:before { content:""; position:absolute; inset:0 0 auto 0; height:4px; background:linear-gradient(90deg, var(--cs-primary), #93c5fd); opacity:0; transition:opacity .24s ease; }
.cs-card:hover:before { opacity:1; }
.cs-tag { width:max-content; max-width:100%; background:#eff6ff; color:var(--cs-primary); border:1px solid #dbeafe; padding:6px 10px; border-radius:999px; font-size:.76rem; font-weight:900; text-transform:uppercase; letter-spacing:.04em; }
.cs-card h4 { margin:18px 0 10px; font-size:1.18rem; line-height:1.2; letter-spacing:-.03em; }
.cs-card p { color:var(--cs-muted); margin:0 0 20px; font-size:.96rem; }
.cs-card-meta { display:flex; gap:10px; flex-wrap:wrap; margin-top:auto; padding-top:18px; }
.cs-mini { font-size:.78rem; color:#334155; background:#f1f5f9; padding:6px 9px; border-radius:999px; font-weight:800; }
.cs-card .cs-btn { width:100%; margin-top:16px; padding:11px 16px; }
.cs-featured { border-color:#bfdbfe; background:linear-gradient(180deg, #fff, #eff6ff); }

.cs-trust-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:18px; }
.cs-trust-card { background:#fff; border:1px solid var(--cs-border); border-radius:22px; padding:24px; }
.cs-trust-card strong { display:block; font-size:1.05rem; margin-bottom:8px; }
.cs-trust-card p { margin:0; color:var(--cs-muted); font-size:.94rem; }

.cs-page-header { background: linear-gradient(180deg, #eff6ff, #fff); padding:64px 0 44px; border-bottom:1px solid var(--cs-border); }
.cs-page-header h1 { font-size: clamp(2.2rem, 5vw, 4rem); letter-spacing:-.06em; line-height:1; margin:0 0 16px; }
.cs-page-header p { max-width:760px; color:var(--cs-muted); font-size:1.1rem; margin:0; }
.cs-content { padding:56px 0; }
.cs-prose { max-width:880px; }
.cs-prose h2 { letter-spacing:-.04em; margin-top:34px; }
.cs-prose p, .cs-prose li { color:#334155; }
.cs-contact-grid { display:grid; grid-template-columns: .9fr 1.1fr; gap:28px; }
.cs-contact-box, .cs-form-card { background:#fff; border:1px solid var(--cs-border); border-radius:26px; padding:28px; box-shadow:0 12px 34px rgba(15,23,42,.05); }
.cs-contact-list { list-style:none; padding:0; margin:20px 0 0; }
.cs-contact-list li { padding:12px 0; border-top:1px solid var(--cs-border); color:#334155; }
.cs-form-card input, .cs-form-card textarea, .cs-form-card select { width:100%; border:1px solid var(--cs-border); border-radius:14px; padding:13px 14px; margin:7px 0 16px; font:inherit; }
.cs-form-card label { font-weight:800; color:#334155; }
.cs-form-note { color:var(--cs-muted); font-size:.9rem; }

.cs-footer { background: var(--cs-dark); color:#fff; padding:54px 0 28px; }
.cs-footer-grid { display:grid; grid-template-columns: 1.2fr repeat(3, .8fr); gap:34px; }
.cs-footer h3, .cs-footer h4 { margin-top:0; }
.cs-footer p, .cs-footer a { color:#cbd5e1; }
.cs-footer ul { list-style:none; padding:0; margin:0; }
.cs-footer li { margin:9px 0; }
.cs-footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:34px; padding-top:22px; color:#94a3b8; font-size:.9rem; }

@media (max-width: 960px) {
  .cs-hero-grid, .cs-contact-grid { grid-template-columns: 1fr; }
  .cs-services-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cs-trust-grid, .cs-footer-grid { grid-template-columns: repeat(2, 1fr); }
  .cs-section-head { display:block; }
  .cs-section-head p { margin-top:14px; }
}
@media (max-width: 760px) {
  .cs-container { width: min(100% - 28px, 1180px); }
  .cs-menu { display:none; position:absolute; left:14px; right:14px; top:76px; background:#fff; border:1px solid var(--cs-border); border-radius:20px; box-shadow:var(--cs-shadow); padding:16px; flex-direction:column; align-items:stretch; }
  .cs-menu.is-open { display:flex; }
  .cs-mobile-toggle { display:block; }
  .cs-header-cta { display:none; }
  .cs-hero { padding:56px 0 44px; }
  .cs-proof, .cs-services-grid, .cs-trust-grid, .cs-footer-grid { grid-template-columns: 1fr; }
  .cs-card { min-height:auto; }
}
