/* Québec TPS TVQ Calculator - marketing site
   Brand: #52beec sky · #015c87 deep · #012238 navy */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --sky:#52beec;--deep:#015c87;--navy:#012238;--ink:#0c2433;
  --bg:#f4fafe;--card:#ffffff;--line:rgba(1,92,135,.12);
  --grad:linear-gradient(135deg,#52beec 0%,#015c87 60%,#012238 120%);
  --r:18px;--rl:26px;--mx:1140px;
  --fs:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fs);color:var(--ink);background:var(--bg);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:var(--mx);margin:0 auto;padding:0 22px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{line-height:1.12;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.1rem,5.4vw,3.9rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.5rem);margin-bottom:.5em}
.skip{position:absolute;left:-999px}
.skip:focus{left:12px;top:12px;background:#fff;padding:10px 16px;border-radius:12px;z-index:100}

/* Nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(160%) blur(14px);
  background:rgba(244,250,254,.78);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:1.05rem}
.brand img{border-radius:9px}
.brand b{font-weight:800}
.nav-links{display:flex;gap:26px;margin-left:auto;font-size:.95rem;font-weight:600}
.nav-links a{opacity:.72;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-act{display:flex;align-items:center;gap:14px;margin-left:24px}
.lang{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.lang button{font:inherit;font-weight:700;font-size:.8rem;border:0;background:none;
  padding:7px 13px;cursor:pointer;color:var(--deep)}
.lang button.on{background:var(--sky);color:#fff}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--grad);color:#fff;
  font-weight:700;padding:13px 22px;border-radius:999px;transition:transform .18s,box-shadow .18s;
  box-shadow:0 10px 26px -10px rgba(1,92,135,.6)}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px -10px rgba(1,92,135,.7)}
.btn small{display:block;font-size:.62rem;font-weight:600;opacity:.85;text-transform:uppercase;letter-spacing:.05em}
.btn b{display:block;font-size:1.02rem;line-height:1}
.btn-sm{padding:9px 16px;font-size:.85rem}
.btn-lg{padding:15px 26px;font-size:1rem}

/* Hero */
.hero{position:relative;padding:clamp(54px,9vw,108px) 0 clamp(50px,7vw,90px);
  background:var(--navy);color:#fff;overflow:hidden}
.hero .wrap{position:relative;z-index:2}
.orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;z-index:1;
  animation:float 16s ease-in-out infinite}
.orb1{width:520px;height:520px;background:#0a6ea0;top:-180px;right:-120px}
.orb2{width:440px;height:440px;background:#52beec;bottom:-220px;left:-140px;animation-delay:-5s}
.orb3{width:300px;height:300px;background:#0398c9;top:30%;left:40%;opacity:.32;animation-delay:-9s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(26px,-30px) scale(1.08)}}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.pill{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.04em;
  padding:7px 15px;border-radius:999px;background:rgba(82,190,236,.16);
  border:1px solid rgba(82,190,236,.4);color:#bfe8fa;margin-bottom:20px}
.hero h1{color:#eef7fc;margin-bottom:.35em}
.lede{font-size:clamp(1.02rem,1.7vw,1.22rem);color:#bcd4e3;max-width:36ch;margin-bottom:30px}
.cta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.soon{font-size:.84rem;color:#8fb4c8;font-weight:600}

/* Calculator card */
.calc-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--rl);padding:24px;backdrop-filter:blur(8px);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.7)}
.calc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;
  font-size:.82rem;font-weight:700;color:#bfe1f2;text-transform:uppercase;letter-spacing:.06em}
.seg{display:flex;background:rgba(255,255,255,.1);border-radius:999px;padding:3px}
.seg button{font:inherit;font-size:.74rem;font-weight:700;border:0;background:none;color:#cfe6f2;
  padding:6px 12px;border-radius:999px;cursor:pointer;text-transform:none;letter-spacing:0}
.seg button.on{background:var(--sky);color:#fff}
.amt{display:block;margin-bottom:18px}
.amt span{display:block;font-size:.8rem;color:#9fc1d4;margin-bottom:7px;font-weight:600}
.amt-in{display:flex;align-items:center;background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:0 16px}
.amt-in i{color:#7fb6cf;font-style:normal;font-size:1.3rem;font-weight:700}
.amt-in input{flex:1;background:none;border:0;color:#fff;font:inherit;font-size:1.6rem;
  font-weight:800;padding:14px 8px;outline:none;width:100%}
.rows{list-style:none}
.rows li{display:flex;justify-content:space-between;align-items:center;padding:11px 0;
  border-bottom:1px solid rgba(255,255,255,.1);font-size:.98rem;color:#cfe6f2}
.rows li i{font-style:normal;font-size:.74rem;color:#7fb6cf;font-weight:700}
.rows li b{font-weight:800;color:#fff;font-variant-numeric:tabular-nums}
.rows .tot{border-bottom:0;padding-top:15px;font-size:1.05rem}
.rows .tot b{font-size:1.5rem;color:var(--sky)}
.micro{font-size:.74rem;color:#7fa7bd;margin-top:12px;text-align:center}

/* Strip */
.strip{background:var(--deep);color:#fff}
.strip-in{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 34px;
  padding:18px 22px;font-size:.86rem;font-weight:700}
.strip-in span{position:relative;padding-left:22px;opacity:.92}
.strip-in span::before{content:"✓";position:absolute;left:0;color:var(--sky);font-weight:800}

/* Sections */
.sec{padding:clamp(56px,8vw,104px) 0}
.sec h2{text-align:center}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:26px 22px;transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 44px -22px rgba(1,92,135,.5)}
.ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:1.3rem;
  background:linear-gradient(135deg,rgba(82,190,236,.2),rgba(1,92,135,.18));
  color:var(--deep);margin-bottom:15px}
.card h3{font-size:1.08rem;margin-bottom:7px}
.card p{font-size:.92rem;color:#5b7282}

/* Band */
.band{background:var(--grad);color:#fff;text-align:center;padding:clamp(50px,7vw,88px) 0}
.band-eq{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
  font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;margin-bottom:14px}
.band-eq span{display:flex;flex-direction:column;line-height:1}
.band-eq small{font-size:.7rem;font-weight:700;opacity:.8;margin-top:6px;text-transform:uppercase;letter-spacing:.08em}
.band-eq i{font-style:normal;opacity:.7}
.band-eq .big{color:#012238;background:#fff;padding:10px 20px;border-radius:16px}
.band p{max-width:62ch;margin:0 auto;color:#e6f4fb;font-size:1rem}

/* Price */
.price-in{text-align:center;max-width:640px;margin:0 auto}
.price-in p{color:#5b7282;font-size:1.08rem;margin:14px 0 30px}

/* FAQ */
.faq-wrap{max-width:760px;margin:0 auto}
.faq{margin-top:36px;display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:4px 20px;transition:box-shadow .2s}
.faq details[open]{box-shadow:0 16px 34px -22px rgba(1,92,135,.4)}
.faq summary{cursor:pointer;font-weight:700;padding:16px 0;list-style:none;
  display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--sky);font-weight:700;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 18px;color:#5b7282;font-size:.95rem}

/* Footer */
.foot{background:var(--navy);color:#cfe2ee;padding:46px 0}
.foot-in{display:flex;flex-direction:column;gap:18px;align-items:center;text-align:center}
.foot-brand{display:flex;align-items:center;gap:10px;font-weight:700;color:#fff}
.foot-brand img{border-radius:8px}
.foot-links{display:flex;gap:26px;font-weight:600;font-size:.92rem}
.foot-links a{opacity:.8}.foot-links a:hover{opacity:1}
.disc{font-size:.78rem;color:#7fa0b3;max-width:70ch}

/* Reveal animation - only active once JS confirms (html.jsr); content
   is always visible if JS is off or fails (progressive enhancement) */
html.jsr .reveal{opacity:0;transform:translateY(26px);
  transition:opacity .7s ease,transform .7s ease}
html.jsr .reveal.in{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .nav-links{display:none}
  .grid{grid-template-columns:repeat(2,1fr)}
  .lede{max-width:none}
}
@media(max-width:560px){
  .grid{grid-template-columns:1fr}
  .nav-act .btn-sm{display:none}
  .cta{gap:14px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}
