:root {
  --ctweb-btt-size: 48px;
  --ctweb-btt-bg: #3867b5;
  --ctweb-btt-bg-hover: #F0B01B;
  --ctweb-btt-color: #fff;
  --ctweb-btt-radius: 999px;
  --ctweb-btt-shadow: 0 8px 20px rgba(0,0,0,.25);
  --ctweb-btt-bottom: 24px;
  --ctweb-btt-right: 24px;
  --ctweb-btt-z: 9999;
  --ctweb-btt-transition: .25s ease;
}

.ctweb-back-to-top {
  position: fixed;
  right: var(--ctweb-btt-right);
  bottom: var(--ctweb-btt-bottom);
  width: var(--ctweb-btt-size);
  height: var(--ctweb-btt-size);
  display: grid;
  place-items: center;
  background: var(--ctweb-btt-bg);
  color: var(--ctweb-btt-color);
  border-radius: var(--ctweb-btt-radius);
  text-decoration: none;
  box-shadow: var(--ctweb-btt-shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--ctweb-btt-transition), transform var(--ctweb-btt-transition), background var(--ctweb-btt-transition), visibility var(--ctweb-btt-transition);
  z-index: var(--ctweb-btt-z);
  line-height: 1;
  font-size: 20px;
}

.ctweb-back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ctweb-back-to-top:hover,
.ctweb-back-to-top:focus {
  background: var(--ctweb-btt-bg-hover);
  outline: none;
}

.ctweb-btt-arrow { display: inline-block; font-weight: bold; }

body.admin-bar .ctweb-back-to-top {
  bottom: calc(var(--ctweb-btt-bottom) + 32px);
}

@media (prefers-reduced-motion: reduce) {
  .ctweb-back-to-top { transition: none; }
}
