/* Gov Services Canada - Mobile-First Responsive */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#1a365d;--primary-light:#2d4a7c;--accent:#c41e3a;--accent-hover:#a01830;
  --bg:#fff;--bg-alt:#f8f9fa;--text:#333;--text-light:#666;--text-muted:#999;
  --border:#dee2e6;--link:#0056b3;--link-hover:#003d80;
  --shadow:0 2px 4px rgba(0,0,0,.1);--shadow-lg:0 4px 12px rgba(0,0,0,.15);
  --radius:8px;--max-w:1200px
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--link);text-decoration:none;transition:color .2s}
a:hover{color:var(--link-hover);text-decoration:underline}
img{max-width:100%;height:auto}
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 16px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* Header */
.site-header{background:var(--primary);color:#fff;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;max-width:var(--max-w);margin:0 auto}
.site-logo{display:flex;align-items:center;gap:8px;color:#fff;font-size:1.05rem;font-weight:700;text-decoration:none;white-space:nowrap}
.site-logo:hover{color:#fff;text-decoration:none}
.site-logo .maple{color:#c41e3a;font-size:1.3rem}
.header-controls{display:flex;align-items:center;gap:10px}
.lang-toggle{display:flex;background:rgba(255,255,255,.15);border-radius:4px;overflow:hidden}
.lang-toggle a{color:rgba(255,255,255,.7);padding:4px 10px;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .2s}
.lang-toggle a.active{background:rgba(255,255,255,.25);color:#fff}
.lang-toggle a:hover{color:#fff;text-decoration:none}

/* Mobile Menu */
#menu-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
#menu-toggle span{display:block;width:22px;height:2px;background:#fff;transition:.3s;border-radius:1px}
#menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
#menu-toggle.active span:nth-child(2){opacity:0}
#menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
#main-nav{display:none;background:var(--primary-light)}
#main-nav.active{display:block}
#main-nav ul{list-style:none;max-width:var(--max-w);margin:0 auto;padding:0 16px}
#main-nav li{border-bottom:1px solid rgba(255,255,255,.1)}
#main-nav li:last-child{border-bottom:none}
#main-nav a{display:block;color:rgba(255,255,255,.9);padding:11px 0;font-size:.92rem;text-decoration:none}
#main-nav a:hover{color:#fff;text-decoration:none}

/* Hero */
.hero{background:linear-gradient(135deg,var(--primary) 0%,#2d5a9e 50%,var(--primary-light) 100%);color:#fff;padding:28px 16px 32px;text-align:center}
.hero h1{font-size:1.7rem;font-weight:800;margin-bottom:8px;line-height:1.25}
.hero p{font-size:1rem;opacity:.9;margin-bottom:18px;max-width:580px;margin-left:auto;margin-right:auto}

/* Search */
.search-box{max-width:540px;margin:0 auto 16px;position:relative}
.search-box input{width:100%;padding:13px 52px 13px 16px;border:none;border-radius:var(--radius);font-size:1rem;box-shadow:var(--shadow-lg);color:var(--text)}
.search-box input:focus{outline:2px solid var(--accent);outline-offset:0}
.search-box button{position:absolute;right:4px;top:4px;bottom:4px;padding:0 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:background .2s}
.search-box button:hover{background:var(--accent-hover)}

/* Province Bar */
.province-bar{background:rgba(255,255,255,.12);padding:10px 16px;border-radius:var(--radius);display:inline-flex;align-items:center;gap:8px;font-size:.9rem;flex-wrap:wrap;justify-content:center}
.province-bar select{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:#fff;padding:5px 8px;border-radius:4px;font-size:.85rem;cursor:pointer}
.province-bar select option{color:var(--text);background:#fff}

/* Sections */
.section{padding:28px 16px}
.section-alt{background:var(--bg-alt)}
.section-title{font-size:1.4rem;font-weight:700;color:var(--primary);margin-bottom:4px}
.section-subtitle{color:var(--text-light);margin-bottom:16px;font-size:.92rem}
.section-inner{max-width:var(--max-w);margin:0 auto}

/* Card Grid */
.card-grid{display:grid;grid-template-columns:1fr;gap:10px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;transition:box-shadow .2s,transform .2s;text-decoration:none;color:var(--text);display:block}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);text-decoration:none;color:var(--text)}
.card-icon{width:42px;height:42px;background:var(--bg-alt);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--primary);margin-bottom:8px}
.card h3{font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--primary)}
.card p{font-size:.88rem;color:var(--text-light);line-height:1.5}
.card .card-arrow{display:inline-block;margin-top:6px;color:var(--accent);font-weight:600;font-size:.85rem}

/* Popular Services Chips */
.popular-services{display:flex;gap:10px;overflow-x:auto;padding:12px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.popular-services::-webkit-scrollbar{display:none}
.popular-chip{flex-shrink:0;padding:9px 16px;background:#fff;border:1px solid var(--border);border-radius:20px;font-size:.83rem;font-weight:500;color:var(--primary);text-decoration:none;white-space:nowrap;transition:all .2s}
.popular-chip:hover{background:var(--primary);color:#fff;border-color:var(--primary);text-decoration:none}

/* Service List (detail pages) */
.service-list{list-style:none}
.service-item{padding:14px 0;border-bottom:1px solid var(--border)}
.service-item:last-child{border-bottom:none}
.service-item h3{font-size:1rem;font-weight:600;margin-bottom:3px}
.service-item h3 a{color:var(--link)}
.service-item p{font-size:.88rem;color:var(--text-light);margin-bottom:4px;line-height:1.6}
.service-item .visit-link{display:inline-flex;align-items:center;gap:4px;font-size:.83rem;color:var(--accent);font-weight:600}
.service-item .visit-link:hover{text-decoration:underline}

/* FAQ */
.faq-list{list-style:none}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:6px;overflow:hidden}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;cursor:pointer;font-weight:600;font-size:.92rem;background:#fff;border:none;width:100%;text-align:left;color:var(--text);transition:background .2s;gap:12px}
.faq-question:hover{background:var(--bg-alt)}
.faq-question::after{content:'+';font-size:1.3rem;font-weight:300;color:var(--text-muted);flex-shrink:0;transition:transform .2s}
.faq-question.active::after{content:'\2212'}
.faq-answer{display:none;padding:0 14px 14px;font-size:.9rem;color:var(--text-light);line-height:1.7}
.faq-answer.active{display:block}
.faq-answer a{font-weight:500}
.faq-answer ul,.faq-answer ol{margin:6px 0;padding-left:20px}
.faq-answer li{margin-bottom:3px}

/* Province Grid */
.province-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.province-link{display:block;padding:10px 8px;background:#fff;border:1px solid var(--border);border-radius:6px;text-align:center;font-size:.83rem;font-weight:500;color:var(--primary);text-decoration:none;transition:all .2s}
.province-link:hover{background:var(--primary);color:#fff;border-color:var(--primary);text-decoration:none}
.province-link .abbr{display:block;font-size:.72rem;color:var(--text-muted);margin-top:2px}
.province-link:hover .abbr{color:rgba(255,255,255,.7)}

/* Breadcrumbs */
.breadcrumbs{padding:8px 16px;font-size:.83rem;color:var(--text-muted);max-width:var(--max-w);margin:0 auto}
.breadcrumbs a{color:var(--text-light)}
.breadcrumbs .sep{margin:0 6px}

/* Page Header (inner pages) */
.page-header{background:var(--bg-alt);padding:24px 16px;border-bottom:1px solid var(--border)}
.page-header .section-inner{max-width:var(--max-w);margin:0 auto}
.page-header h1{font-size:1.6rem;color:var(--primary);margin-bottom:4px}
.page-header p{color:var(--text-light);font-size:.95rem}

/* Category Nav Chips */
.cat-nav{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.cat-chip{padding:6px 12px;border:1px solid var(--border);border-radius:20px;font-size:.82rem;font-weight:500;color:var(--text-light);text-decoration:none;transition:all .2s}
.cat-chip:hover,.cat-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);text-decoration:none}

/* Footer */
.site-footer{background:#111827;color:rgba(255,255,255,.8);padding:28px 16px 14px}
.footer-inner{max-width:var(--max-w);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}
.footer-section h4{color:#fff;font-size:.9rem;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.footer-section a{display:block;color:rgba(255,255,255,.65);font-size:.83rem;padding:2px 0;text-decoration:none}
.footer-section a:hover{color:#fff;text-decoration:none}
.footer-disclaimer{background:rgba(255,255,255,.05);padding:10px;border-radius:6px;margin-bottom:14px;font-size:.78rem;color:rgba(255,255,255,.45);text-align:center;line-height:1.5}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;font-size:.78rem;color:rgba(255,255,255,.4);text-align:center}

/* Back to Top */
#back-to-top{display:none;position:fixed;bottom:24px;right:24px;width:44px;height:44px;background:var(--primary);color:#fff;border:none;border-radius:50%;cursor:pointer;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:var(--shadow-lg);z-index:50;transition:background .2s}
#back-to-top:hover{background:var(--accent)}

/* About Page */
.about-content{max-width:800px;margin:0 auto;padding:28px 16px}
.about-content h2{color:var(--primary);font-size:1.3rem;margin:20px 0 6px}
.about-content p{margin-bottom:10px;line-height:1.7;color:var(--text-light)}
.about-content ul{margin:6px 0 14px;padding-left:20px}
.about-content li{margin-bottom:5px;color:var(--text-light)}

/* Search Results */
.search-results{max-width:800px;margin:0 auto}
.search-result{padding:14px 0;border-bottom:1px solid var(--border)}
.search-result h3{font-size:1rem;margin-bottom:3px}
.search-result h3 a{color:var(--link)}
.search-result p{font-size:.88rem;color:var(--text-light)}
.no-results{text-align:center;padding:40px 16px;color:var(--text-light)}

/* Life Events */
.life-events{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.life-event{padding:14px 10px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);text-align:center;text-decoration:none;color:var(--text);transition:all .2s}
.life-event:hover{border-color:var(--primary);box-shadow:var(--shadow);text-decoration:none;color:var(--text)}
.life-event i{font-size:1.4rem;color:var(--primary);display:block;margin-bottom:4px}
.life-event span{font-size:.82rem;font-weight:500}

/* Stats Bar */
.stats-bar{display:flex;justify-content:center;gap:20px;padding:16px 16px;flex-wrap:wrap}
.stat{text-align:center}
.stat .num{display:block;font-size:1.5rem;font-weight:800;color:#fff}
.stat .label{font-size:.78rem;opacity:.8}

/* Phone Numbers Section */
.phone-grid{display:grid;grid-template-columns:1fr;gap:8px}
.phone-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:6px}
.phone-item .name{font-size:.88rem;font-weight:500}
.phone-item .number{font-size:.92rem;font-weight:700;color:var(--primary);white-space:nowrap}
.phone-item .number a{color:var(--primary);text-decoration:none}

/* Benefits Amount Table */
.benefits-table{width:100%;border-collapse:collapse}
.benefits-table th{text-align:left;padding:10px 12px;background:var(--primary);color:#fff;font-size:.82rem;font-weight:600}
.benefits-table td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:.85rem}
.benefits-table tr:hover{background:var(--bg-alt)}
.benefits-table .amount{font-weight:700;color:var(--primary);white-space:nowrap}

/* Deadlines/Dates */
.deadline-list{list-style:none}
.deadline-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.deadline-date{flex-shrink:0;width:65px;padding:6px 8px;background:var(--accent);color:#fff;border-radius:6px;text-align:center;font-size:.75rem;font-weight:700;line-height:1.2}
.deadline-info{font-size:.88rem}
.deadline-info strong{display:block;margin-bottom:2px}

/* Info Banner */
.info-banner{background:linear-gradient(135deg,#eef2ff 0%,#e8f4fd 100%);border:1px solid #c7d2fe;border-radius:var(--radius);padding:16px;margin-bottom:16px;font-size:.88rem;color:var(--primary)}
.info-banner strong{display:block;margin-bottom:4px}

/* Two-column content layout for desktop */
.content-two-col{display:grid;grid-template-columns:1fr;gap:16px}

/* Quick stats inline */
.quick-stats{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.quick-stat{background:#fff;border:1px solid var(--border);border-radius:6px;padding:12px 16px;text-align:center;flex:1;min-width:120px}
.quick-stat .val{display:block;font-size:1.3rem;font-weight:800;color:var(--primary)}
.quick-stat .lbl{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}

/* Category pills for inner pages */
.cat-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.cat-pill{padding:5px 12px;background:var(--bg-alt);border:1px solid var(--border);border-radius:16px;font-size:.78rem;color:var(--text-light);text-decoration:none;transition:all .2s}
.cat-pill:hover,.cat-pill.active{background:var(--primary);color:#fff;border-color:var(--primary);text-decoration:none}

/* ===== TABLET 768px+ ===== */
@media(min-width:768px){
  .container{padding:0 24px}
  .hero{padding:40px 24px}
  .hero h1{font-size:2.3rem}
  .hero p{font-size:1.1rem}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .province-grid{grid-template-columns:repeat(4,1fr)}
  .life-events{grid-template-columns:repeat(4,1fr)}
  .section{padding:36px 24px}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
  #menu-toggle{display:none}
  #main-nav{display:block;background:none;padding:0}
  #main-nav ul{display:flex;gap:0;padding:0}
  #main-nav li{border-bottom:none}
  #main-nav a{padding:8px 14px;font-size:.87rem;white-space:nowrap}
  .page-header h1{font-size:1.9rem}
  .phone-grid{grid-template-columns:repeat(2,1fr)}
  .content-two-col{grid-template-columns:2fr 1fr}
}

/* ===== DESKTOP 1024px+ ===== */
@media(min-width:1024px){
  .hero h1{font-size:2.7rem}
  .hero p{font-size:1.15rem}
  .card-grid{grid-template-columns:repeat(3,1fr)}
  .province-grid{grid-template-columns:repeat(5,1fr)}
  .life-events{grid-template-columns:repeat(5,1fr)}
  .section{padding:44px 24px}
  .phone-grid{grid-template-columns:repeat(3,1fr)}
}

/* ===== WIDE 1280px+ ===== */
@media(min-width:1280px){
  .card-grid{grid-template-columns:repeat(4,1fr)}
  .province-grid{grid-template-columns:repeat(7,1fr)}
}

/* Focus */
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Print */
@media print{
  .site-header,.site-footer,#menu-toggle,.search-box,#back-to-top{display:none!important}
  .hero{background:none!important;color:var(--text);padding:16px 0}
  .card{break-inside:avoid;border:1px solid #ccc}
  a{color:var(--text)}
}
