/* ==========================================================================
   MAGICPIXEL — SHARED STYLESHEET (site.css)
   ==========================================================================
   Single source of truth for the design system.
   Every page on magicpixel.ca references this file.
   Update once → entire site updates.
   ========================================================================== */

/* ===== DESIGN TOKENS ===== */
:root {
  --white:#FFFFFF;
  --paper:#FAFCFE;
  --sky-soft:#F0F6FB;
  --sky:#E1ECF5;
  --sky-mid:#C5D9EA;
  --blue-100:#DBE9F6;
  --blue-200:#A8C5E0;
  --blue-300:#6FA0CC;
  --blue-400:#4082BD;
  --blue-500:#2E6BAA;
  --blue-600:#1B4775;
  --blue-700:#133759;
  --blue-800:#0F2A47;
  --blue-900:#0A1628;
  --cyan:#38BDF8;
  --cyan-soft:#BAE6FD;
  --emerald:#10B981;
  --amber:#F59E0B;
  --rose:#EF4444;
  --ink:#0A1628;
  --slate:#3D5773;
  --mist:#7E92AC;
  --sh-1:0 1px 2px rgba(15,42,71,.04), 0 4px 12px rgba(15,42,71,.05);
  --sh-2:0 2px 4px rgba(15,42,71,.06), 0 16px 40px rgba(15,42,71,.08);
  --sh-3:0 4px 8px rgba(15,42,71,.08), 0 24px 60px rgba(15,42,71,.12);
}

/* ===== RESET & BASE ===== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--white);
  color:var(--ink);
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  line-height:1.65;
  letter-spacing:-0.01em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
::selection{background:var(--blue-500);color:var(--white)}
a{color:inherit;text-decoration:none}
button{border:none;background:none;cursor:pointer;font-family:inherit}
img{max-width:100%;height:auto}

/* ===== LAYOUT ===== */
.container{max-width:1240px;margin:0 auto;padding:0 32px}
.container-narrow{max-width:880px;margin:0 auto;padding:0 32px}
.serif{font-family:'Instrument Serif',serif;font-weight:400}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:11px;
  color:var(--blue-500);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2px;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--blue-500)}

/* ===== TOPBAR ===== */
.topbar{
  background:linear-gradient(90deg,var(--blue-900) 0%,var(--blue-800) 100%);
  color:var(--cyan-soft);
  font-size:12px;
  padding:9px 0;
  position:relative;
  z-index:60;
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:16px}
.topbar-left{display:flex;align-items:center;gap:10px;color:var(--cyan-soft)}
.pulse-dot{position:relative;width:7px;height:7px}
.pulse-dot::before,.pulse-dot::after{content:'';position:absolute;inset:0;border-radius:50%}
.pulse-dot::before{background:var(--cyan);z-index:1}
.pulse-dot::after{background:var(--cyan);animation:ping 2s cubic-bezier(0,0,.2,1) infinite}
@keyframes ping{75%,100%{transform:scale(2.5);opacity:0}}
.topbar-right{display:flex;gap:22px;color:var(--blue-200);font-family:'JetBrains Mono',monospace;font-size:11px}

/* ===== NAV ===== */
nav.main{
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--sky);
  position:sticky;
  top:0;
  z-index:50;
}
nav.main .container{display:flex;align-items:center;justify-content:space-between;padding:16px 32px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:19px;color:var(--ink);letter-spacing:-0.4px}
.brand-mark{
  width:36px;
  height:36px;
  background-image:url('/images/MagicPixel%20Logo.png');
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
}
.brand .pixel{color:var(--blue-500)}
.nav-links{display:flex;align-items:center;gap:32px;font-size:14px;color:var(--slate);font-weight:500}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{
  background:var(--blue-900);
  color:var(--white) !important;
  padding:10px 20px;
  border-radius:8px;
  font-weight:600;
  font-size:13px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:all .2s ease;
  box-shadow:var(--sh-1);
}
.nav-cta:hover{background:var(--blue-700);transform:translateY(-1px);box-shadow:var(--sh-2)}
.nav-cta i{width:14px;height:14px;transition:transform .2s}
.nav-cta:hover i{transform:translateX(2px)}
.menu-btn{display:none}

/* ===== PAGE HERO (used across all sub-pages) ===== */
.page-hero{
  padding:80px 0 60px;
  background:
    radial-gradient(ellipse 1100px 600px at 90% -10%,var(--sky-soft) 0%,transparent 60%),
    radial-gradient(ellipse 700px 400px at 0% 100%,var(--blue-100) 0%,transparent 50%),
    var(--white);
  position:relative;
  overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:radial-gradient(circle,var(--blue-200) 1px,transparent 1px);
  background-size:32px 32px;
  opacity:0.2;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 100%);
  pointer-events:none;
}
.page-hero .container{position:relative;max-width:880px;text-align:left}
.page-hero .breadcrumbs{font-size:13px;color:var(--mist);margin-bottom:18px}
.page-hero .breadcrumbs a{color:var(--blue-500)}
.page-hero .breadcrumbs a:hover{text-decoration:underline}
.page-hero h1{
  font-family:'Manrope',sans-serif;
  font-size:clamp(36px,5vw,60px);
  line-height:1.05;
  letter-spacing:-2px;
  font-weight:700;
  color:var(--ink);
  margin-bottom:22px;
}
.page-hero h1 .em{
  font-family:'Instrument Serif',serif;
  font-weight:400;
  font-style:italic;
  color:var(--blue-500);
  letter-spacing:-1px;
}
.page-hero .lede{
  font-size:19px;
  line-height:1.6;
  color:var(--slate);
  max-width:680px;
  margin-bottom:30px;
}
.page-hero .ctas{display:flex;gap:14px;flex-wrap:wrap}

/* ===== BUTTONS ===== */
.btn-primary{
  background:var(--blue-900);
  color:var(--white);
  padding:14px 24px;
  border-radius:10px;
  font-weight:600;
  font-size:15px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  transition:all .2s ease;
  box-shadow:var(--sh-2);
  position:relative;
  overflow:hidden;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--sh-3);color:var(--white) !important}
.btn-primary i{width:16px;height:16px;transition:transform .2s}
.btn-primary:hover i{transform:translateX(3px)}
.btn-secondary{
  background:var(--white);
  color:var(--ink);
  padding:14px 22px;
  border-radius:10px;
  font-weight:600;
  font-size:15px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--sky);
  transition:all .2s ease;
}
.btn-secondary:hover{border-color:var(--blue-500);color:var(--blue-500)}

/* ===== CONTENT BLOCKS ===== */
.content-section{padding:64px 0;background:var(--white)}
.content-section.alt{background:var(--paper)}
.content-section.dark{background:var(--blue-900);color:var(--white)}
.content-section .container,
.content-section .container-narrow{max-width:880px}
.content-section h2{
  font-family:'Manrope',sans-serif;
  font-size:clamp(28px,3.5vw,42px);
  line-height:1.15;
  letter-spacing:-1.2px;
  font-weight:700;
  color:var(--ink);
  margin:0 0 20px;
}
.content-section.dark h2{color:var(--white)}
.content-section h2 .em{
  font-family:'Instrument Serif',serif;
  font-weight:400;
  font-style:italic;
  color:var(--blue-500);
  letter-spacing:-0.5px;
}
.content-section.dark h2 .em{color:var(--cyan)}
.content-section h3{
  font-size:22px;
  line-height:1.3;
  font-weight:600;
  color:var(--ink);
  margin:30px 0 12px;
  letter-spacing:-0.3px;
}
.content-section.dark h3{color:var(--white)}
.content-section p{
  font-size:17px;
  line-height:1.7;
  color:var(--slate);
  margin:0 0 16px;
}
.content-section.dark p{color:var(--blue-100)}
.content-section ul,.content-section ol{
  font-size:17px;
  line-height:1.7;
  color:var(--slate);
  margin:0 0 16px;
  padding-left:22px;
}
.content-section.dark ul,.content-section.dark ol{color:var(--blue-100)}
.content-section li{margin-bottom:8px}
.content-section strong{color:var(--ink);font-weight:600}
.content-section.dark strong{color:var(--white)}
.content-section blockquote{
  margin:24px 0;
  padding:18px 22px;
  border-left:3px solid var(--blue-500);
  background:var(--sky-soft);
  border-radius:6px;
  font-family:'Instrument Serif',serif;
  font-size:18px;
  font-style:italic;
  color:var(--blue-700);
  line-height:1.5;
}
.content-section.dark blockquote{
  background:rgba(56,189,248,.08);
  border-color:var(--cyan);
  color:var(--cyan-soft);
}

/* ===== TABLES ===== */
.content-section table{
  width:100%;
  border-collapse:collapse;
  margin:20px 0 24px;
  font-size:15px;
}
.content-section table th{
  background:var(--sky-soft);
  text-align:left;
  padding:14px 16px;
  font-weight:600;
  color:var(--blue-700);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.5px;
  border-bottom:1px solid var(--sky);
}
.content-section table td{
  padding:14px 16px;
  border-bottom:1px solid var(--sky);
  color:var(--slate);
}
.content-section table tr:last-child td{border-bottom:none}

/* ===== CALLOUT BOX ===== */
.callout{
  background:var(--sky-soft);
  border:1px solid var(--sky);
  border-radius:14px;
  padding:24px 28px;
  margin:28px 0;
  border-left:3px solid var(--blue-500);
}
.callout .label{
  font-size:11px;
  color:var(--blue-500);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  margin-bottom:8px;
}
.callout p{margin-bottom:0;color:var(--ink);font-size:16px}

/* ===== FAQ ===== */
.faq-block{margin:24px 0}
.faq-block details{
  background:var(--white);
  border:1px solid var(--sky);
  border-radius:12px;
  margin-bottom:10px;
  padding:0;
  overflow:hidden;
}
.faq-block details[open]{border-color:var(--blue-300);box-shadow:var(--sh-1)}
.faq-block summary{
  padding:18px 22px;
  font-size:16px;
  font-weight:600;
  color:var(--ink);
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
}
.faq-block summary::-webkit-details-marker{display:none}
.faq-block summary::after{
  content:'+';
  font-size:22px;
  color:var(--blue-500);
  transition:transform .2s;
  flex-shrink:0;
}
.faq-block details[open] summary::after{transform:rotate(45deg)}
.faq-block details > div{padding:0 22px 18px;color:var(--slate);font-size:15px;line-height:1.65}

/* ===== STAT GRID ===== */
.stat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:18px;
  margin:32px 0;
}
.stat{
  background:var(--white);
  border:1px solid var(--sky);
  border-radius:14px;
  padding:22px;
  text-align:left;
}
.stat .num{
  font-family:'Instrument Serif',serif;
  font-size:42px;
  font-weight:400;
  color:var(--blue-500);
  line-height:1;
  margin-bottom:6px;
  letter-spacing:-1px;
}
.stat .label{
  font-size:13px;
  color:var(--slate);
  line-height:1.45;
}

/* ===== CTA BANNER ===== */
.cta-banner{
  background:var(--blue-900);
  color:var(--white);
  padding:64px 0;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 600px 300px at 50% 0%,rgba(56,189,248,.18) 0%,transparent 60%);
  pointer-events:none;
}
.cta-banner .container{position:relative;text-align:center;max-width:680px}
.cta-banner h2{
  font-family:'Manrope',sans-serif;
  font-size:clamp(28px,3.5vw,40px);
  line-height:1.15;
  letter-spacing:-1px;
  font-weight:700;
  color:var(--white);
  margin:0 0 16px;
}
.cta-banner h2 em{
  font-family:'Instrument Serif',serif;
  font-weight:400;
  font-style:italic;
  color:var(--cyan);
  letter-spacing:-0.5px;
}
.cta-banner p{font-size:17px;color:var(--blue-100);margin:0 0 28px;line-height:1.6}
.cta-banner .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-banner .btn-primary{background:var(--cyan);color:var(--blue-900)}
.cta-banner .btn-primary:hover{background:var(--white)}
.cta-banner .btn-secondary{background:transparent;color:var(--white);border-color:rgba(255,255,255,.2)}
.cta-banner .btn-secondary:hover{border-color:var(--cyan);color:var(--cyan)}

/* ===== FOOTER ===== */
footer.main{
  background:var(--blue-900);
  color:var(--blue-200);
  border-top:1px solid rgba(255,255,255,.05);
  padding:56px 0 28px;
  position:relative;
  overflow:hidden;
}
footer.main::before{
  content:'';
  position:absolute;
  bottom:70px;
  left:0;
  right:0;
  height:110px;
  opacity:0.18;
  background-image:url('/images/calgary-skyline.svg');
  background-repeat:no-repeat;
  background-position:center bottom;
  background-size:contain;
  pointer-events:none;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:40px;
  position:relative;
  z-index:1;
}
.footer-brand .brand{color:var(--white);margin-bottom:16px}
.footer-brand p{font-size:13px;line-height:1.6;max-width:320px;color:var(--blue-200)}
.footer-socials{display:flex;gap:10px;margin-top:20px}
.footer-socials a{
  width:36px;
  height:36px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  display:grid;
  place-items:center;
  color:var(--blue-200);
  transition:all .2s ease;
}
.footer-socials a:hover{background:var(--cyan);color:var(--blue-900);transform:translateY(-2px)}
.footer-socials a i{width:16px;height:16px}
.footer-col h4{
  font-size:11px;
  color:var(--cyan);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1.5px;
  margin-bottom:16px;
}
.footer-col ul{list-style:none;padding:0}
.footer-col li{margin-bottom:10px}
.footer-col a{color:var(--blue-100);font-size:13px}
.footer-col a:hover{color:var(--cyan)}
.footer-col li.addr{color:var(--blue-100);font-size:13px;line-height:1.6}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:12px;
  color:var(--mist);
  position:relative;
  z-index:1;
}

/* ===== RESPONSIVE ===== */
@media (max-width:1024px){
  .container,.container-narrow{padding:0 24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .topbar-right{display:none}
}
@media (max-width:720px){
  .nav-links{display:none}
  .menu-btn{
    display:grid;
    place-items:center;
    width:40px;
    height:40px;
    border-radius:8px;
    background:var(--paper);
    border:1px solid var(--sky);
    color:var(--ink);
  }
  .menu-btn i{width:18px;height:18px}
  .page-hero{padding:48px 0 40px}
  .content-section{padding:48px 0}
  .cta-banner{padding:48px 0}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:12px;align-items:flex-start}
  .content-section .container,.content-section .container-narrow{padding:0 20px}
  .content-section table{font-size:13px;display:block;overflow-x:auto}
  .content-section table th,.content-section table td{padding:10px 8px;white-space:nowrap}
}
