@import url("../fonts/fonts.css");

:root{
  --bg:#f5f2ee;
  --surface:#ffffff;
  --surface-alt:#fdf7f1;
  --text:#0f172a;
  --muted:#475569;
  --accent:#0f766e;
  --accent-2:#c2410c;
  --border:rgba(15,23,42,0.12);
  --ring:rgba(15,118,110,0.25);
  --shadow:0 20px 60px rgba(15,23,42,0.10);
  --shadow-soft:0 12px 30px rgba(15,23,42,0.08);
  --radius:18px;
  --font-body:"Manrope","Segoe UI",system-ui,-apple-system,Arial,sans-serif;
  --font-display:"Fraunces","Times New Roman",serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 15% 0%,rgba(15,118,110,0.12),transparent 45%),
    radial-gradient(circle at 85% 10%,rgba(194,65,12,0.12),transparent 40%),
    linear-gradient(180deg,#fefcf9 0%,#f5f2ee 55%,#f1eee9 100%);
  z-index:-1;
}

img{max-width:100%;height:auto;display:block}

a{color:inherit}

a:focus,button:focus{outline:3px solid var(--ring);outline-offset:3px}

.container{width:min(1160px,92%);margin:0 auto}

h1,h2,h3,h4{
  font-family:var(--font-display);
  letter-spacing:0.2px;
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.86);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(15,23,42,0.08);
  box-shadow:0 8px 28px rgba(15,23,42,0.06);
}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}
.brand-wrap{display:flex;flex-direction:column;gap:.15rem}
.brand{
  margin:0;
  font-weight:700;
  font-size:1.6rem;
  text-decoration:none;
  letter-spacing:0.3px;
  font-family:var(--font-display);
}
.tag{color:var(--muted);font-size:0.95rem}

.main-nav{display:flex;align-items:center;gap:.25rem}
.main-nav a{
  text-decoration:none;
  color:var(--muted);
  font-weight:600;
  padding:.5rem .85rem;
  border-radius:999px;
  transition:background .12s ease,color .12s ease,transform .12s ease;
}
.main-nav a:hover{background:rgba(15,118,110,0.10);color:var(--text);transform:translateY(-1px)}
.main-nav a[aria-current="page"]{background:rgba(15,118,110,0.16);color:var(--text)}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:700;
  padding:.78rem 1.2rem;
  border-radius:999px;
  border:1px solid rgba(15,23,42,0.12);
  background:#fff;
  color:var(--text);
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease;
}
.btn.primary{
  background:linear-gradient(100deg,var(--accent),#0f6b63);
  color:#fff;
  border-color:transparent;
  box-shadow:0 12px 26px rgba(15,118,110,0.18);
}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(15,118,110,0.22)}
.btn.outline{background:transparent;color:var(--text)}
.btn.outline:hover{background:rgba(15,118,110,0.08);border-color:rgba(15,118,110,0.2)}
.btn.login{padding:.55rem 1rem;border-radius:999px}

.nav-toggle{display:none;background:transparent;border:0;font-size:1.4rem;cursor:pointer;padding:.45rem .6rem;border-radius:10px}

@media(max-width:820px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .main-nav{display:none;position:absolute;left:0;right:0;top:100%;background:var(--surface);flex-direction:column;align-items:stretch;gap:0;border-bottom:1px solid var(--border);box-shadow:var(--shadow-soft)}
  .main-nav.open{display:flex}
  .main-nav a{border-radius:0;padding:1rem}
  .main-nav a.btn{margin:.5rem 1rem 1rem;border-radius:999px}
}

/* Proudly Canadian banner */
.country-banner{
  background:linear-gradient(90deg,#0f766e,#0f4c5c);
  color:#fff;
  text-align:center;
  padding:.55rem 0;
  font-weight:700;
  letter-spacing:0.2px;
}
.country-banner .flag{margin-right:.5rem}

/* Sections */
main section{padding:3.5rem 0}
.band{background:rgba(255,255,255,0.6)}

.lead{color:var(--muted);font-size:1.05rem;margin:.75rem 0 0}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:.7rem;
  font-weight:700;
  color:var(--accent);
  background:rgba(15,118,110,0.10);
  padding:.35rem .75rem;
  border-radius:999px;
}

/* Hero */
.hero{
  padding-top:4.5rem;
  background:linear-gradient(180deg,rgba(255,255,255,0.92) 0%,rgba(245,242,238,0.4) 80%);
}
.hero-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center}
.hero-copy h1{font-size:2.6rem;line-height:1.08;margin:.75rem 0 0}
.hero-copy .lead{max-width:62ch}
.cta-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.4rem}
.hero-highlights{display:grid;grid-template-columns:1fr;gap:.75rem;margin-top:1.5rem}
.highlight{
  padding:.8rem 1rem;
  border-radius:14px;
  background:rgba(255,255,255,0.8);
  border:1px solid rgba(15,23,42,0.08);
}
.highlight strong{display:block;font-weight:700}
.highlight span{color:var(--muted);font-size:.95rem}
.hero-panel{
  background:var(--surface);
  border-radius:24px;
  border:1px solid rgba(15,23,42,0.08);
  box-shadow:var(--shadow);
  padding:1.2rem;
}
.hero-panel img{border-radius:18px;box-shadow:var(--shadow-soft)}
.hero-panel ul{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.6rem}
.hero-panel li{display:flex;gap:.55rem;align-items:flex-start;color:var(--muted)}
.hero-panel li span{color:var(--accent);font-weight:700}

@media(min-width:980px){
  .hero-grid{grid-template-columns:1.1fr .9fr;gap:2.6rem}
  .hero-copy h1{font-size:3.3rem}
  .hero-highlights{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:720px){
  main section{padding:2.6rem 0}
  .header-row{padding:.9rem 0}
  .tag{font-size:.85rem}
  .hero{padding-top:3.6rem}
  .hero-copy h1{font-size:2.1rem}
  .page-hero h1{font-size:2rem}
  .hero-panel{padding:1rem}
  .hero-panel ul{gap:.5rem}
  .trust-item{padding:.9rem}
  .step{padding:.9rem}
  .cards,.services-grid{gap:.85rem}
  .tech-icon{width:48px;height:48px}
  .btn{width:100%}
  .cta-row{width:100%}
  .cta-row .btn{flex:1 1 100%}
}

@media(min-width:721px) and (max-width:1024px){
  .hero-copy h1{font-size:2.6rem}
  .cards,.services-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
}

/* Trust bar */
.trust-bar{padding-top:0}
.trust-grid{display:grid;grid-template-columns:1fr;gap:1rem}
.trust-item{
  background:var(--surface);
  border:1px solid rgba(15,23,42,0.08);
  border-radius:16px;
  padding:1rem 1.1rem;
  box-shadow:var(--shadow-soft);
}
.trust-label{display:block;font-weight:700;margin-bottom:.25rem}
.trust-item p{margin:0;color:var(--muted)}
@media(min-width:860px){
  .trust-grid{grid-template-columns:repeat(3,1fr)}
}

/* Page hero */
.page-hero{
  background:linear-gradient(180deg,rgba(255,255,255,0.92) 0%,rgba(245,242,238,0.6) 75%);
}
.page-hero h1{margin:.7rem 0 0;font-size:2.4rem;line-height:1.12}

/* Cards */
.cards{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}
@media(min-width:820px){.cards{grid-template-columns:repeat(3,1fr);gap:1.25rem}}

.card{
  background:var(--surface);
  border:1px solid rgba(15,23,42,0.08);
  border-radius:var(--radius);
  padding:1.25rem;
  box-shadow:var(--shadow-soft);
}
.card h3{margin:.15rem 0 .4rem}
.card p{margin:0;color:var(--muted)}
.panel{background:linear-gradient(160deg,#fff 0%,#f7f4ef 100%)}

/* Steps */
.steps{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1.2rem}
.step{padding:1rem;border-radius:16px;border:1px solid rgba(15,23,42,0.08);background:rgba(255,255,255,0.85)}
.step .step-count{font-weight:700;color:var(--accent)}
@media(min-width:900px){.steps{grid-template-columns:repeat(4,1fr)}}

/* Forms */
label{display:block;margin-top:.8rem;font-weight:700;color:var(--text)}
input,select,textarea{
  width:100%;
  padding:.85rem .9rem;
  border-radius:14px;
  border:1px solid rgba(15,23,42,0.12);
  background:#fff;
  color:var(--text);
  font:inherit;
}
select{appearance:auto}
.form-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;margin-top:1rem}
.muted{color:var(--muted)}

/* Services grid */
.services-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}
@media(min-width:820px){.services-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem}}

.service{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.7rem}
.service .icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;color:var(--accent)}
.service .lead{margin:.15rem 0 0}

.service.featured{grid-column:1/-1;align-items:flex-start;text-align:left}
.service.featured .icon{margin-bottom:.25rem}
.service.featured .benefits{margin:.7rem 0 0;color:var(--muted)}
.service.featured .benefits p{margin:0 0 .35rem}

@media(min-width:820px){
  .service.featured{padding:1.35rem}
}

/* Technologies */
.technologies .tech-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,320px));gap:1rem;margin-top:1rem;justify-content:center}
.tech-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:.5rem;
}
.tech-icon-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:.25rem}
.tech-icon{width:56px;height:56px}

.tech-link{display:block;text-decoration:none;color:inherit}
.tech-link:hover{transform:translateY(-2px)}
.tech-link.card{transition:transform .12s ease,box-shadow .12s ease}
.tech-link.card:hover{box-shadow:0 16px 32px rgba(15,23,42,0.12)}

/* Technology detail layout */
.tech-detail{scroll-margin-top:96px}
.media-row{display:grid;grid-template-columns:1fr;gap:1.25rem;align-items:start;margin-top:1rem}
.media{border-radius:18px;border:1px solid rgba(15,23,42,0.08);box-shadow:var(--shadow-soft)}
@media(min-width:980px){.media-row{grid-template-columns:1.1fr .9fr;gap:1.5rem}}

/* CTA section */
.cta{text-align:center}
.cta .cta-row{justify-content:center}

/* Reveal animations */
.reveal{animation:rise .7s ease both}
.delay-1{animation-delay:.12s}
.delay-2{animation-delay:.22s}
.delay-3{animation-delay:.32s}
@keyframes rise{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion: reduce){
  .reveal,.delay-1,.delay-2,.delay-3{animation:none}
}

/* Footer */
.site-footer{padding:1.5rem 0;border-top:1px solid rgba(15,23,42,0.08);background:#fff}
.footer-grid{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.footer-links a{color:var(--muted);text-decoration:none}
.footer-links a:hover{color:var(--text)}
.footer-note{padding:.25rem 0 1rem;color:var(--muted);font-size:.92rem}

/* Portal app shell */
.app-shell-page{background:var(--bg)}
.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr}
.app-sidebar{background:var(--surface);border-right:1px solid var(--border);padding:1.25rem 1rem;position:sticky;top:0;height:100vh;overflow:auto;box-shadow:var(--shadow-soft)}
.app-brand-wrap{margin-bottom:1rem}
.app-brand{font-family:var(--font-display);font-size:1.3rem;font-weight:700}
.app-brand-sub{color:var(--muted);font-size:.9rem}
.app-nav{display:grid;gap:.35rem}
.app-nav a{text-decoration:none;color:var(--muted);font-weight:700;padding:.65rem .8rem;border-radius:12px;border:1px solid transparent}
.app-nav a:hover{background:rgba(15,118,110,0.10);color:var(--text)}
.app-nav a[aria-current="page"]{background:rgba(15,118,110,0.16);color:var(--text);border-color:rgba(15,118,110,0.22)}
.app-main{display:grid;grid-template-rows:auto 1fr;min-width:0}
.app-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:rgba(255,255,255,0.86)}
.app-topbar h1{margin:0 0 .25rem 0}
.app-user-meta{display:grid;justify-items:end;gap:.35rem}
.app-user-meta p{margin:0}
.app-content{padding:1.25rem}

@media(max-width:900px){
  .app-shell{grid-template-columns:1fr}
  .app-sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--border);box-shadow:none}
  .app-user-meta{justify-items:start}
}
