:root {
  color-scheme: dark;
  --page-bg: #050608;
  --panel-bg: rgba(8, 10, 13, 0.68);
  --panel-border: rgba(255, 255, 255, 0.13);
  --text: #f7f3ee;
  --muted: rgba(247, 243, 238, 0.72);
  --soft: rgba(247, 243, 238, 0.56);
  --faint: rgba(247, 243, 238, 0.22);
  --accent: #f2cf91;
  --accent-soft: rgba(242, 207, 145, 0.18);
  --line: rgba(255, 255, 255, 0.66);
  --header-x: clamp(1.4rem, 5vw, 5.4rem);
  --header-y: clamp(1.15rem, 2.8vw, 2.9rem);
  --content-x: clamp(1.4rem, 5vw, 5.4rem);
  --section-y: clamp(5.6rem, 10vw, 9.5rem);
  --ease: cubic-bezier(.2, .8, .2, 1);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: 7rem;
  background: var(--page-bg);
}

body {
  min-height: 100%;
  margin: 0;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 18% 8%, rgba(242, 207, 145, 0.08), transparent 32rem),
    linear-gradient(180deg, #050608 0%, #090b0f 44%, #050608 100%);
  color: var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
}

body::before {
  position: fixed;
  inset: 0;
  z-index: 8;
  content: "";
  pointer-events: none;
  opacity: 0;
  background: rgba(0, 0, 0, 0.30);
  transition: opacity 260ms var(--ease);
}

body.menu-is-open::before {
  opacity: 1;
}

body.menu-is-open {
  overflow-x: hidden;
}

::selection {
  color: #08090b;
  background: var(--accent);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
a {
  -webkit-tap-highlight-color: transparent;
}

button {
  font: inherit;
}

img {
  display: block;
  max-width: 100%;
}

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

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  padding: calc(var(--header-y) + env(safe-area-inset-top)) var(--header-x) 0;
  pointer-events: none;
}

.site-header > * {
  pointer-events: auto;
}

.site-header::before {
  position: absolute;
  inset: 0 0 auto;
  height: clamp(6.2rem, 10vw, 8.5rem);
  z-index: -1;
  content: "";
  pointer-events: none;
  background: linear-gradient(180deg, rgba(4, 5, 7, 0.70), rgba(4, 5, 7, 0));
}

.brand {
  display: inline-flex;
  align-items: center;
  min-height: 2.35rem;
  color: rgba(255, 255, 255, 0.93);
  font-size: clamp(1.06rem, 1.45vw, 1.55rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: clamp(0.36em, 0.58vw, 0.52em);
  text-transform: uppercase;
  transition: opacity 240ms var(--ease), transform 240ms var(--ease);
}

.brand:hover,
.brand:focus-visible {
  opacity: 1;
  transform: translateY(-1px);
}

.menu-toggle {
  min-height: 2.85rem;
  padding: 0 1rem 0 1.15rem;
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.92);
  background: rgba(8, 10, 13, 0.48);
  box-shadow: 0 0.8rem 2.8rem rgba(0, 0, 0, 0.22);
  
  -webkit-
  cursor: pointer;
  transition: transform 240ms var(--ease), border-color 240ms var(--ease), background-color 240ms var(--ease), box-shadow 240ms var(--ease);
}

.menu-toggle:hover,
.menu-toggle:focus-visible,
body.menu-is-open .menu-toggle {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.42);
  background: rgba(16, 18, 21, 0.72);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.34);
}

.menu-toggle__text {
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.17em;
  text-transform: uppercase;
}

.menu-toggle__icon {
  position: relative;
  width: 1.15rem;
  height: 0.78rem;
  display: inline-flex;
  align-items: center;
}

.menu-toggle__icon::before,
.menu-toggle__icon::after,
.menu-toggle__icon span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  content: "";
  border-radius: 999px;
  background: currentColor;
  transition: transform 240ms var(--ease), opacity 180ms var(--ease), top 240ms var(--ease), bottom 240ms var(--ease);
}

.menu-toggle__icon::before {
  top: 0;
}

.menu-toggle__icon span {
  top: calc(50% - 1px);
  opacity: 0.78;
}

.menu-toggle__icon::after {
  bottom: 0;
}

body.menu-is-open .menu-toggle__icon::before {
  top: calc(50% - 1px);
  transform: rotate(45deg);
}

body.menu-is-open .menu-toggle__icon span {
  opacity: 0;
  transform: scaleX(0.2);
}

body.menu-is-open .menu-toggle__icon::after {
  bottom: calc(50% - 1px);
  transform: rotate(-45deg);
}

.menu-panel {
  position: fixed;
  top: calc(var(--header-y) + env(safe-area-inset-top) + 3.65rem);
  right: var(--header-x);
  z-index: 21;
  width: min(24rem, calc(100vw - (var(--header-x) * 2)));
  padding: 0.8rem;
  display: grid;
  gap: 0.35rem;
  border: 1px solid var(--panel-border);
  border-radius: 1.25rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)),
    var(--panel-bg);
  box-shadow: 0 2rem 6rem rgba(0, 0, 0, 0.48);
  
  -webkit-
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-0.8rem) scale(0.985);
  transform-origin: top right;
  transition: opacity 240ms var(--ease), visibility 240ms var(--ease), transform 240ms var(--ease);
}

body.menu-is-open .menu-panel {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.menu-link {
  position: relative;
  min-height: 4.15rem;
  padding: 0 1.1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.15rem;
  border-radius: 0.9rem;
  color: rgba(255, 255, 255, 0.88);
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  font-family: Georgia, "Times New Roman", Times, serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: background-color 220ms var(--ease), color 220ms var(--ease), transform 220ms var(--ease);
}

.menu-link span {
  order: 2;
  color: var(--accent);
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  opacity: 0.74;
}

.menu-link:hover,
.menu-link:focus-visible,
.menu-link.is-active {
  color: #fff;
  background: rgba(255, 255, 255, 0.085);
  transform: translateX(-2px);
}

main {
  position: relative;
  z-index: 1;
}

.section-snap {
  scroll-margin-top: 0;
}

.hero {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
  overflow: hidden;
  display: grid;
  grid-template-rows: 1fr auto;
  background: var(--page-bg);
}

.hero::before,
.hero::after {
  position: absolute;
  inset: 0;
  content: "";
  pointer-events: none;
}

.hero::before {
  z-index: -3;
  background-image: url("../images/hero-desktop.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  transform: scale(1.012);
}

.hero::after {
  z-index: -2;
  background:
    radial-gradient(circle at 76% 44%, rgba(251, 167, 85, 0.14), transparent 28%),
    linear-gradient(90deg, rgba(3, 5, 8, 0.88) 0%, rgba(3, 5, 8, 0.76) 27%, rgba(3, 5, 8, 0.30) 56%, rgba(3, 5, 8, 0.40) 100%),
    linear-gradient(180deg, rgba(2, 3, 5, 0.34) 0%, rgba(2, 3, 5, 0.08) 42%, rgba(2, 3, 5, 0.78) 100%);
}

.hero-content {
  position: relative;
  z-index: 1;
  width: min(44rem, calc(100vw - (var(--content-x) * 2)));
  margin-left: var(--content-x);
  align-self: center;
  padding: clamp(6.5rem, 12vh, 9rem) 0 clamp(5rem, 10vh, 8.5rem);
}

.eyebrow,
.section-kicker {
  margin: 0;
  color: var(--accent);
  font-size: clamp(0.78rem, 1.1vw, 1.1rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: clamp(0.24em, 0.44vw, 0.40em);
  text-transform: uppercase;
}

.hero .eyebrow {
  margin-bottom: clamp(1.2rem, 2.6vw, 2.1rem);
}

.hero-title {
  margin: 0;
  color: var(--text);
  font-family: Georgia, "Times New Roman", Times, serif;
  font-size: clamp(4.7rem, 8.4vw, 9.6rem);
  font-weight: 500;
  line-height: 0.86;
  letter-spacing: 0.02em;
  text-shadow: 0 0.08em 0.22em rgba(0, 0, 0, 0.24);
}

.title-rule {
  width: clamp(3.2rem, 4.8vw, 5rem);
  height: 2px;
  margin: clamp(2rem, 4.4vw, 4.1rem) 0 clamp(1.5rem, 2.6vw, 2.3rem);
  background: var(--accent);
  box-shadow: 0 0 0.75rem rgba(242, 207, 145, 0.22);
}

.hero-copy {
  margin: 0;
  max-width: 31rem;
  color: var(--muted);
  font-size: clamp(1rem, 1.65vw, 1.45rem);
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: -0.02em;
  text-shadow: 0 0.12em 0.6em rgba(0, 0, 0, 0.42);
}

.cta {
  width: fit-content;
  min-height: 4rem;
  margin-top: clamp(2.6rem, 5vw, 4.25rem);
  padding: 0 2.1rem;
  display: inline-flex;
  align-items: center;
  gap: 1.05rem;
  border: 1px solid rgba(255, 255, 255, 0.54);
  border-radius: 0.5rem;
  color: rgba(255, 255, 255, 0.94);
  background: rgba(255, 255, 255, 0.035);
  box-shadow: 0 1.2rem 3.3rem rgba(0, 0, 0, 0.24);
  
  -webkit-
  font-size: 0.88rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.17em;
  text-transform: uppercase;
  transition: transform 240ms var(--ease), border-color 240ms var(--ease), background-color 240ms var(--ease), box-shadow 240ms var(--ease);
}

.cta img {
  width: 1rem;
  height: 1rem;
  transition: transform 240ms var(--ease);
}

.cta:hover,
.cta:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.88);
  background: rgba(255, 255, 255, 0.075);
  box-shadow: 0 1.5rem 4rem rgba(0, 0, 0, 0.32);
}

.cta:hover img,
.cta:focus-visible img {
  transform: translate(2px, -2px);
}

.hero-social {
  position: relative;
  z-index: 2;
  width: fit-content;
  margin: 0 0 calc(clamp(1.75rem, 4.8vw, 4.75rem) + env(safe-area-inset-bottom)) var(--content-x);
  display: flex;
  align-items: center;
  gap: clamp(1.55rem, 3.8vw, 3.4rem);
}

.hero-social a,
.contact-social a img {
  transition: opacity 220ms var(--ease), transform 220ms var(--ease), filter 220ms var(--ease);
}

.hero-social a {
  width: clamp(1.35rem, 1.85vw, 1.75rem);
  height: clamp(1.35rem, 1.85vw, 1.75rem);
  display: grid;
  place-items: center;
  opacity: 0.72;
}

.hero-social a:hover,
.hero-social a:focus-visible {
  opacity: 1;
  transform: translateY(-3px);
  filter: drop-shadow(0 0.35rem 0.9rem rgba(242, 207, 145, 0.28));
}

.hero-social img,
.contact-social img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.content-section {
  position: relative;
  overflow: hidden;
  min-height: 100svh;
  padding: var(--section-y) var(--content-x);
  display: grid;
  align-items: center;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(circle at 86% 14%, rgba(242, 207, 145, 0.12), transparent 32rem),
    linear-gradient(180deg, #07090d 0%, #0a0d12 54%, #050608 100%);
}

.content-section::before {
  position: absolute;
  inset: 0;
  content: "";
  pointer-events: none;
  background:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 4.6rem 4.6rem;
  mask-image: linear-gradient(180deg, transparent, black 20%, black 75%, transparent);
  opacity: 0.52;
}

.blog-section {
  background:
    radial-gradient(circle at 18% 18%, rgba(251, 167, 85, 0.12), transparent 32rem),
    linear-gradient(180deg, #050608 0%, #0c0d11 50%, #06080b 100%);
}

.contact-section {
  background:
    radial-gradient(circle at 70% 26%, rgba(242, 207, 145, 0.14), transparent 30rem),
    radial-gradient(circle at 12% 76%, rgba(251, 167, 85, 0.08), transparent 28rem),
    linear-gradient(180deg, #06080b 0%, #050608 100%);
}

.section-inner {
  position: relative;
  z-index: 1;
  width: min(100%, 76rem);
  margin: 0 auto;
}

.two-column,
.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  align-items: center;
  gap: clamp(2.4rem, 6vw, 6rem);
}

.section-heading h2 {
  margin: clamp(1rem, 2vw, 1.35rem) 0 0;
  max-width: 42rem;
  color: var(--text);
  font-family: Georgia, "Times New Roman", Times, serif;
  font-size: clamp(2.65rem, 5.8vw, 5.7rem);
  font-weight: 500;
  line-height: 0.96;
  letter-spacing: -0.035em;
}

.section-heading--wide h2 {
  max-width: 63rem;
}

.work-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.2rem;
}

.work-card,
.blog-item,
.contact-card {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.028)),
    rgba(255, 255, 255, 0.035);
  box-shadow: 0 1.2rem 3.8rem rgba(0, 0, 0, 0.22);
  
  -webkit-
}

.work-card {
  min-height: 21rem;
  padding: clamp(1.35rem, 2.2vw, 1.9rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 1.25rem;
  transition: transform 260ms var(--ease), border-color 260ms var(--ease), background-color 260ms var(--ease), box-shadow 260ms var(--ease);
}

.work-card:hover {
  transform: translateY(-0.45rem);
  border-color: rgba(242, 207, 145, 0.35);
  background-color: rgba(255, 255, 255, 0.055);
}

.card-number {
  color: var(--accent);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.2em;
}

.work-card h3 {
  margin: auto 0 1rem;
  color: var(--text);
  font-family: Georgia, "Times New Roman", Times, serif;
  font-size: clamp(1.7rem, 2.4vw, 2.35rem);
  font-weight: 500;
  line-height: 1.02;
}

.website-card {
  min-height: 0;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
  padding: clamp(0.75rem, 1.4vw, 1rem);
  gap: clamp(0.7rem, 1.2vw, 0.95rem);
  justify-content: start;
}

.website-thumb {
  position: relative;
  overflow: hidden;
  border-radius: 0.95rem;
  aspect-ratio: 4 / 3;
  background: rgba(255, 255, 255, 0.03);
  box-shadow: 0 1rem 2.75rem rgba(0, 0, 0, 0.24);
}

.website-thumb::after {
  position: absolute;
  inset: 0;
  content: "";
  pointer-events: none;
  background: linear-gradient(180deg, rgba(5, 6, 8, 0) 45%, rgba(5, 6, 8, 0.14) 100%);
}

.website-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 420ms var(--ease);
}

.website-card:hover .website-thumb img,
.website-card:focus-within .website-thumb img {
  transform: scale(1.035);
}

.website-meta {
  display: grid;
  gap: 0.35rem;
  min-width: 0;
  max-width: 100%;
  padding: 0.1rem 0.2rem 0.15rem;
}

.website-meta h3 {
  margin: 0;
  max-width: 100%;
  color: var(--text);
  font-family: Georgia, "Times New Roman", Times, serif;
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  font-weight: 500;
  line-height: 1.06;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

.website-meta p {
  max-width: 100%;
  color: var(--muted);
  line-height: 1.45;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.work-card p,
.blog-item p,
.contact-copy {
  margin: 0;
  color: var(--muted);
  font-size: clamp(0.98rem, 1.2vw, 1.08rem);
  line-height: 1.75;
}

.blog-list {
  margin-top: clamp(2rem, 4vw, 3.8rem);
  display: grid;
  gap: 1rem;
}

.blog-item {
  padding: clamp(1.25rem, 2.4vw, 2rem);
  display: grid;
  grid-template-columns: 8rem minmax(0, 1fr);
  gap: clamp(1.2rem, 3vw, 3.2rem);
  align-items: start;
  border-radius: 1.1rem;
}

.blog-item time {
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.blog-item h3 {
  margin: 0 0 0.55rem;
  color: var(--text);
  font-family: Georgia, "Times New Roman", Times, serif;
  font-size: clamp(1.45rem, 2.5vw, 2.2rem);
  font-weight: 500;
  line-height: 1.05;
}

.contact-layout {
  grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.72fr);
}

.contact-copy {
  max-width: 36rem;
  margin-top: 1.4rem;
}

.contact-card {
  padding: clamp(1.35rem, 3vw, 2.25rem);
  border-radius: 1.35rem;
}

.contact-button {
  min-height: 4.2rem;
  padding: 0 1.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.9rem;
  color: #08090b;
  background: var(--accent);
  font-size: 0.85rem;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: transform 240ms var(--ease), filter 240ms var(--ease);
}

.contact-button:hover,
.contact-button:focus-visible {
  transform: translateY(-2px);
  filter: brightness(1.08);
}

.contact-social {
  margin-top: 1rem;
  display: grid;
  gap: 0.85rem;
}

.contact-social a {
  min-height: 4rem;
  padding: 0 1.05rem;
  display: flex;
  align-items: center;
  gap: 0.95rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0.9rem;
  color: rgba(255, 255, 255, 0.86);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: transform 220ms var(--ease), border-color 220ms var(--ease), background-color 220ms var(--ease);
}

.contact-social a:hover,
.contact-social a:focus-visible {
  transform: translateX(0.25rem);
  border-color: rgba(242, 207, 145, 0.36);
  background: rgba(255, 255, 255, 0.07);
}

.contact-social img {
  width: 1.3rem;
  height: 1.3rem;
  opacity: 0.82;
}

@media (max-width: 1100px) {
  :root {
    --header-x: clamp(1.35rem, 4.8vw, 3.5rem);
    --content-x: clamp(1.35rem, 4.8vw, 3.5rem);
  }

  .hero::before {
    background-image: url("../images/hero-tablet.jpg");
    background-position: center center;
  }

  .hero::after {
    background:
      linear-gradient(90deg, rgba(3, 5, 8, 0.88) 0%, rgba(3, 5, 8, 0.70) 40%, rgba(3, 5, 8, 0.34) 100%),
      linear-gradient(180deg, rgba(2, 3, 5, 0.34) 0%, rgba(2, 3, 5, 0.12) 46%, rgba(2, 3, 5, 0.80) 100%);
  }

  .two-column,
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .work-grid {
    grid-template-columns: repeat(2, minmax(15rem, 1fr));
  }

  .work-card {
    min-height: 18rem;
  }

  .contact-card {
    max-width: 36rem;
  }
}

@media (max-width: 760px) {
  html {
    scroll-padding-top: 6rem;
  }

  :root {
    --section-y: 5rem;
  }

  .site-header {
    padding-top: calc(1.05rem + env(safe-area-inset-top));
    align-items: flex-start;
  }

  .site-header::before {
    height: 6.7rem;
  }

  .brand {
    min-height: 2.85rem;
    font-size: 1rem;
    letter-spacing: 0.46em;
  }

  .menu-toggle {
    min-height: 2.75rem;
    padding-inline: 0.92rem;
    gap: 0.7rem;
  }

  .menu-toggle__text {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
  }

  .menu-panel {
    top: calc(1.05rem + env(safe-area-inset-top) + 3.6rem);
    left: var(--header-x);
    right: var(--header-x);
    width: auto;
    border-radius: 1.05rem;
  }

  .menu-link {
    min-height: 3.75rem;
    font-size: 1.05rem;
  }

  .hero {
    min-height: 100dvh;
  }

  .hero::before {
    background-image: url("../images/hero-mobile.jpg");
    background-position: 58% center;
    transform: scale(1.008);
  }

  .hero::after {
    background:
      linear-gradient(90deg, rgba(2, 3, 5, 0.87) 0%, rgba(2, 3, 5, 0.56) 58%, rgba(2, 3, 5, 0.26) 100%),
      linear-gradient(180deg, rgba(2, 3, 5, 0.38) 0%, rgba(2, 3, 5, 0.20) 38%, rgba(2, 3, 5, 0.85) 100%);
  }

  .hero-content {
    align-self: end;
    width: min(100% - 2.7rem, 31rem);
    margin-left: var(--content-x);
    padding: clamp(8rem, 20vh, 12rem) 0 clamp(1.7rem, 4vh, 2.8rem);
  }

  .hero .eyebrow {
    margin-bottom: 1rem;
    font-size: 0.76rem;
    letter-spacing: 0.32em;
  }

  .hero-title {
    font-size: clamp(4rem, 17.5vw, 6.1rem);
    line-height: 0.88;
  }

  .title-rule {
    width: 3.25rem;
    margin: 1.7rem 0 1.25rem;
  }

  .hero-copy {
    max-width: 21rem;
    font-size: clamp(0.96rem, 4vw, 1.15rem);
    line-height: 1.62;
  }

  .desktop-break {
    display: none;
  }

  .cta {
    min-height: 3.45rem;
    margin-top: 2rem;
    padding: 0 1.45rem;
    border-radius: 0.45rem;
    font-size: 0.76rem;
    letter-spacing: 0.14em;
  }

  .hero-social {
    margin: 0 0 calc(1.8rem + env(safe-area-inset-bottom)) var(--content-x);
    gap: 1.4rem;
  }

  .hero-social a {
    width: 1.25rem;
    height: 1.25rem;
  }

  .content-section {
    min-height: auto;
    padding-top: 6rem;
    padding-bottom: 6rem;
  }

  .content-section::before {
    background-size: 3.2rem 3.2rem;
  }

  .section-heading h2 {
    font-size: clamp(2.4rem, 11vw, 4rem);
  }

  .work-grid {
    grid-template-columns: 1fr;
    overflow: visible;
    padding-bottom: 0;
  }

  .work-card {
    min-height: 14.5rem;
  }

  .website-thumb {
    aspect-ratio: 4 / 3;
  }

  .blog-item {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .contact-card {
    max-width: none;
  }
}

@media (max-width: 430px) {
  .brand {
    letter-spacing: 0.38em;
  }

  .menu-toggle__text {
    width: 1px;
    height: 1px;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
  }

  .menu-toggle {
    width: 2.85rem;
    justify-content: center;
    padding: 0;
  }

  .hero-content {
    width: min(100% - 2rem, 28rem);
  }

  .hero-title {
    font-size: clamp(3.35rem, 17vw, 4.9rem);
  }

  .cta {
    width: 100%;
    max-width: 15.7rem;
    justify-content: center;
  }

  .contact-social a {
    min-height: 3.7rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    transition-duration: 0.001ms !important;
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* PHP article + admin */
.article-page .site-header { pointer-events: auto; }
.admin-small { width: auto; min-height: 2.5rem; padding: 0.75rem 1rem; }
.article-shell {
  width: min(860px, calc(100% - 2.8rem));
  margin: 0 auto;
  padding: clamp(8rem, 16vw, 12rem) 0 5rem;
}
.article-title {
  margin: 0.5rem 0 1rem;
  font-size: clamp(2.4rem, 7vw, 5.8rem);
  line-height: 0.94;
  letter-spacing: -0.06em;
}
.article-summary { color: var(--muted); font-size: clamp(1.05rem, 2vw, 1.35rem); line-height: 1.7; }
.article-body { margin-top: 3rem; color: rgba(247,243,238,0.86); font-size: 1.05rem; line-height: 1.9; }
.article-body p { margin: 0 0 1.35rem; }
.admin-body {
  min-height: 100vh;
  background:
    radial-gradient(circle at 82% 12%, rgba(242, 207, 145, 0.12), transparent 28rem),
    radial-gradient(circle at 10% 85%, rgba(255, 255, 255, 0.055), transparent 30rem),
    linear-gradient(180deg, #050608 0%, #0b0d11 100%);
}
.admin-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem var(--content-x);
  border-bottom: 1px solid var(--panel-border);
  background: rgba(5, 6, 8, 0.76);
  
  -webkit-
}
.admin-nav { display: flex; flex-wrap: wrap; gap: 0.45rem; justify-content: flex-end; }
.admin-nav a, .admin-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0 0.8rem;
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.admin-nav a:hover, .admin-link:hover { color: var(--text); border-color: rgba(242,207,145,0.45); }
.admin-main { width: min(1120px, calc(100% - 2rem)); margin: 0 auto; padding: clamp(2rem, 6vw, 4.5rem) 0; }
.admin-panel, .login-card {
  border: 1px solid var(--panel-border);
  border-radius: 1.5rem;
  background: linear-gradient(180deg, rgba(255,255,255,0.075), rgba(255,255,255,0.025)), rgba(8,10,13,0.76);
  box-shadow: 0 2rem 6rem rgba(0,0,0,0.36);
  
  -webkit-
}
.admin-panel { padding: clamp(1.25rem, 4vw, 2.4rem); }
.admin-panel h1, .login-card h1 { margin: 0.3rem 0 1.5rem; font-size: clamp(2rem, 5vw, 4rem); line-height: 0.95; letter-spacing: -0.05em; }
.login-card { width: min(440px, calc(100% - 2rem)); margin: 14vh auto 0; padding: clamp(1.5rem, 5vw, 2.2rem); }
.admin-form { display: grid; gap: 1rem; }
.admin-form-wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-form-wide h2, .admin-form-wide .contact-button, .admin-form-wide label:has(textarea), .admin-form-wide .admin-check { grid-column: 1 / -1; }
.admin-form label { display: grid; gap: 0.45rem; color: var(--muted); font-size: 0.86rem; font-weight: 800; letter-spacing: 0.05em; }
.admin-form input, .admin-form textarea, .admin-form select {
  width: 100%;
  border: 1px solid var(--panel-border);
  border-radius: 0.95rem;
  padding: 0.9rem 1rem;
  color: var(--text);
  background: rgba(0,0,0,0.26);
  outline: none;
}
.admin-form textarea { resize: vertical; line-height: 1.65; }
.admin-form input:focus, .admin-form textarea:focus { border-color: rgba(242,207,145,0.6); box-shadow: 0 0 0 3px rgba(242,207,145,0.12); }
.admin-check { display: flex !important; grid-template-columns: auto 1fr !important; align-items: center; }
.admin-check input { width: auto; }
.admin-flash { margin: 0 0 1rem; padding: 0.9rem 1rem; border: 1px solid rgba(242,207,145,0.32); border-radius: 1rem; color: var(--accent); background: var(--accent-soft); }
.admin-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.admin-card { min-height: 9rem; padding: 1.2rem; border: 1px solid var(--panel-border); border-radius: 1.2rem; background: rgba(255,255,255,0.04); display: flex; flex-direction: column; justify-content: space-between; }
.admin-card strong { font-size: 1.25rem; }
.admin-card span, .admin-note, .admin-list-row span { color: var(--muted); line-height: 1.6; }
.admin-fieldset { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; margin: 0; padding: 1rem; border: 1px solid var(--panel-border); border-radius: 1.2rem; }
.admin-fieldset legend { color: var(--accent); padding: 0 0.4rem; }
.admin-list { display: grid; gap: 0.75rem; margin-top: 1.25rem; }
.admin-list-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem; border: 1px solid var(--panel-border); border-radius: 1rem; background: rgba(255,255,255,0.035); }
.admin-list-row div { display: grid; gap: 0.25rem; }
.admin-list-row nav { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.admin-list-row nav a { color: var(--accent); font-weight: 800; }
.admin-thumb { width: 84px; height: 52px; object-fit: cover; border-radius: 0.6rem; border: 1px solid var(--panel-border); }
code { color: var(--accent); }
@media (max-width: 860px) { .admin-header { align-items: flex-start; flex-direction: column; } .admin-form-wide, .admin-fieldset, .admin-grid { grid-template-columns: 1fr; } .admin-list-row { align-items: flex-start; flex-direction: column; } }

.blog-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.7rem;
  margin-top: clamp(1.2rem, 3vw, 2rem);
}
.blog-page-link {
  min-width: 2.65rem;
  min-height: 2.65rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(255,255,255,0.04);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  transition: color 0.2s ease, border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.blog-page-link:hover, .blog-page-link.is-active {
  color: var(--text);
  border-color: rgba(242,207,145,0.55);
  background: var(--accent-soft);
  transform: translateY(-2px);
}

/* Blog image, article media, and local editor */
.blog-item--with-image {
  grid-template-columns: minmax(8rem, 13rem) minmax(5.2rem, 0.35fr) minmax(0, 1fr);
  align-items: center;
}
.blog-thumb {
  margin: 0;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  border: 1px solid var(--panel-border);
  border-radius: 1rem;
  background: rgba(255,255,255,0.04);
}
.blog-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.55s var(--ease);
}
.blog-item:hover .blog-thumb img { transform: scale(1.05); }
.blog-thumb {
  position: relative;
}

.blog-play-badge {
  position: absolute;
  left: 50%;
  top: 50%;
  width: clamp(2.7rem, 5vw, 4.25rem);
  height: clamp(2.7rem, 5vw, 4.25rem);
  transform: translate(-50%, -50%);
  border: 1px solid rgba(255,255,255,0.72);
  border-radius: 999px;
  background: rgba(8,8,10,0.52);
  box-shadow: 0 1rem 2.6rem rgba(0,0,0,0.32);
  
  pointer-events: none;
}

.blog-play-badge::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-36%, -50%);
  width: 0;
  height: 0;
  border-top: 0.52rem solid transparent;
  border-bottom: 0.52rem solid transparent;
  border-left: 0.82rem solid var(--text);
}

.blog-video-text {
  align-self: start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  padding: 0.45rem 0.75rem;
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: rgba(255,255,255,0.035);
}

.article-cover, .article-media {
  margin: clamp(1.4rem, 4vw, 2.4rem) 0;
  overflow: hidden;
  border: 1px solid var(--panel-border);
  border-radius: 1.35rem;
  background: rgba(255,255,255,0.04);
}
.article-cover img, .article-media img, .article-media video {
  width: 100%;
  display: block;
}
.article-media video { background: #000; }
.article-body h2, .article-body h3 {
  margin: 2.4rem 0 1rem;
  letter-spacing: -0.035em;
  line-height: 1.08;
}
.article-body h2 { font-size: clamp(1.7rem, 4vw, 2.6rem); }
.article-body h3 { font-size: clamp(1.25rem, 3vw, 1.8rem); }
.article-body ul { margin: 0 0 1.5rem 1.2rem; color: rgba(247,243,238,0.82); }
.article-body li { margin: 0.35rem 0; }
.code-card {
  margin: 2rem 0;
  overflow: hidden;
  border: 1px solid rgba(242,207,145,0.24);
  border-radius: 1.1rem;
  background: rgba(0,0,0,0.42);
}
.code-card figcaption {
  padding: 0.65rem 0.9rem;
  color: var(--accent);
  border-bottom: 1px solid var(--panel-border);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.code-card pre {
  margin: 0;
  padding: 1rem;
  overflow-x: auto;
  line-height: 1.7;
}
.code-card code { color: rgba(247,243,238,0.88); }
.code-keyword { color: var(--accent); font-weight: 800; }
.code-string { color: #f6d9a4; }
.editor-label { grid-column: 1 / -1; }
.editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.55rem;
  border: 1px solid var(--panel-border);
  border-radius: 1rem 1rem 0 0;
  background: rgba(255,255,255,0.04);
}
.editor-toolbar button, .admin-cover-tools .admin-link {
  min-height: 2.15rem;
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  padding: 0 0.8rem;
  color: var(--text);
  background: rgba(0,0,0,0.22);
  font-weight: 800;
  cursor: pointer;
}
.editor-toolbar button:hover, .admin-cover-tools .admin-link:hover { border-color: rgba(242,207,145,0.55); color: var(--accent); }
.editor-label textarea {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}
.admin-cover-tools {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.7rem;
}
@media (max-width: 780px) {
  .blog-item--with-image { grid-template-columns: 1fr; }
  .blog-thumb { width: 100%; }
}


.admin-note-box { grid-column: 1 / -1; padding: 1rem; border: 1px solid var(--panel-border); border-radius: 1rem; background: rgba(255,255,255,0.035); }
.permalink-options { grid-template-columns: repeat(3, minmax(0,1fr)); }
.admin-radio-card { padding: 1rem; border: 1px solid var(--panel-border); border-radius: 1rem; background: rgba(255,255,255,0.035); cursor: pointer; }
.admin-radio-card input { width: auto; margin: 0 0 0.65rem; }
.admin-radio-card span { display: grid; gap: 0.35rem; }
.admin-radio-card strong { color: var(--text); font-size: 1rem; }
.admin-radio-card em { color: var(--muted); font-style: normal; letter-spacing: 0; text-transform: none; word-break: break-all; }
.admin-help { display: block; margin-top: 0.25rem; color: var(--muted); font-size: 0.78rem; letter-spacing: 0; text-transform: none; }
.admin-help code { color: var(--accent); }
.admin-actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 0.75rem; }
.admin-rules-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; margin-top: 1.4rem; }
.admin-rules-card { padding: 1rem; border: 1px solid var(--panel-border); border-radius: 1.2rem; background: rgba(255,255,255,0.035); }
.admin-rules-card h2 { margin: 0 0 0.6rem; font-size: 1.2rem; }
.admin-code-output { width: 100%; min-height: 20rem; margin-top: 0.8rem; padding: 1rem; border: 1px solid var(--panel-border); border-radius: 1rem; background: rgba(7,7,7,0.55); color: rgba(247,243,238,0.88); font: 0.82rem/1.6 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; resize: vertical; }
@media (max-width: 860px) { .permalink-options, .admin-rules-grid { grid-template-columns: 1fr; } }
.admin-flash.is-error { border-color: rgba(255, 120, 120, 0.35); color: #ffb4a8; background: rgba(255, 120, 120, 0.08); }
.admin-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.account-form { max-width: 760px; }
@media (max-width: 860px) { .admin-grid.two { grid-template-columns: 1fr; } }

/* Article comments */
.comments-section {
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 1px solid var(--panel-border);
}
.comments-head { margin-bottom: 1.25rem; }
.comments-head h2 { margin: 0.25rem 0 0; font-size: clamp(1.8rem, 4vw, 3rem); letter-spacing: -0.05em; }
.comment-list { display: grid; gap: 1rem; margin: 1.25rem 0 2rem; }
.comment-card, .comment-form {
  border: 1px solid var(--panel-border);
  background: rgba(255,255,255,0.035);
  border-radius: 1.25rem;
  
}
.comment-card { padding: 1.1rem; }
.comment-card header { display: flex; justify-content: space-between; gap: 1rem; margin-bottom: 0.7rem; }
.comment-card strong { color: var(--text); }
.comment-card time, .comment-meta, .comments-empty, .comments-closed { color: var(--muted); font-size: 0.86rem; }
.comment-card p { margin: 0; color: rgba(247,243,238,0.86); line-height: 1.75; }
.comment-meta { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 0.8rem; }
.comment-meta a { color: var(--accent); font-weight: 800; }

.comment-form {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  padding: 1.1rem;
  margin-top: 1.4rem;
}
.comment-field-row,
.comment-optional-grid label {
  display: grid;
  grid-template-columns: 8.5rem minmax(0, 1fr);
  align-items: center;
  gap: 1rem;
  width: 100%;
  box-sizing: border-box;
}
.comment-field-row label,
.comment-optional-grid label {
  display: contents;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.05em;
}
.comment-form input,
.comment-form textarea {
  display: block;
  width: 100%;
  height: 3rem;
  min-height: 3rem;
  max-height: 3rem;
  box-sizing: border-box;
  border: 1px solid var(--panel-border);
  border-radius: 0.95rem;
  padding: 0.82rem 1rem;
  color: var(--text);
  background: rgba(0,0,0,0.26);
  outline: none;
  font: inherit;
  line-height: 1.25;
}
.comment-form textarea {
  resize: none;
  overflow-y: auto;
}
.comment-form input:focus,
.comment-form textarea:focus { border-color: rgba(242,207,145,0.6); box-shadow: 0 0 0 3px rgba(242,207,145,0.12); }
.comment-alert { width: 100%; padding: 0.8rem 1rem; border-radius: 1rem; border: 1px solid rgba(255,120,120,0.34); color: #ffb4a8; background: rgba(255,120,120,0.08); box-sizing: border-box; }
.comment-form .contact-button {
  align-self: flex-start;
  width: auto;
  min-height: 2.25rem;
  padding: 0 0.85rem;
  font-size: 0.68rem;
  border-radius: 0.62rem;
  letter-spacing: 0.1em;
  display: inline-flex;
}
.comment-admin-row nav { align-items: center; }
.comment-admin-row nav form { margin: 0; }
.admin-link.danger { color: #ffb4a8; border-color: rgba(255,120,120,0.34); }
.admin-list-row button.admin-link { cursor: pointer; font: inherit; }
@media (max-width: 780px) { .comment-card header { flex-direction: column; } }

/* Comment optional fields */
.comment-optional {
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 1rem;
  padding: 0.9rem 1rem;
  background: rgba(255,255,255,0.025);
  box-sizing: border-box;
}
.comment-optional summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  list-style: none;
}
.comment-optional summary::-webkit-details-marker { display: none; }
.comment-optional summary::after {
  content: '+';
  float: right;
  color: var(--accent);
  font-size: 1rem;
}
.comment-optional[open] summary::after { content: '−'; }
.comment-optional-grid {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  margin-top: 0.9rem;
}

@media (max-width: 640px) {
  .comment-field-row,
  .comment-optional-grid label {
    grid-template-columns: 1fr;
    gap: 0.45rem;
  }
  .comment-field-row label,
  .comment-optional-grid label {
    display: flex;
    flex-direction: column;
  }
}

/* Threaded comments */
.comment-card {
  margin-left: calc(var(--comment-depth, 0) * 1.6rem);
}
.comment-card.is-admin-comment {
  border-color: rgba(242, 207, 145, 0.34);
  background: rgba(242, 207, 145, 0.08);
}
.admin-badge {
  display: inline-flex;
  margin-left: 0.45rem;
  padding: 0.15rem 0.45rem;
  border-radius: 999px;
  background: rgba(242,207,145,0.16);
  color: var(--accent);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  vertical-align: middle;
}
.comment-captcha-row input {
  max-width: 12rem;
}
.comment-captcha-row label {
  color: var(--muted);
}

.comment-reply-button {
  margin-top: 0.9rem;
  border: 0;
  background: transparent;
  color: var(--accent);
  font-weight: 900;
  cursor: pointer;
  padding: 0;
}
.comment-reply-note {
  grid-column: 1 / -1;
  padding: 0.75rem 0.9rem;
  border-radius: 0.9rem;
  border: 1px solid rgba(242,207,145,0.24);
  background: rgba(242,207,145,0.08);
  color: var(--muted);
}
.comment-reply-note button {
  margin-left: 0.75rem;
  border: 0;
  background: transparent;
  color: var(--accent);
  font-weight: 900;
  cursor: pointer;
}
.admin-reply-box {
  margin-top: 0.8rem;
}
.admin-reply-box summary {
  color: var(--accent);
  cursor: pointer;
  font-weight: 900;
}
.admin-reply-box form {
  display: grid;
  gap: 0.65rem;
  margin-top: 0.7rem;
}
.admin-reply-box textarea {
  width: 100%;
  min-height: 90px;
  border-radius: 0.9rem;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.18);
  color: var(--text);
  padding: 0.85rem;
}
@media (max-width: 780px) {
  .comment-card { margin-left: calc(var(--comment-depth, 0) * 0.7rem); }
}


.article-back-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0 0 1.75rem;
  padding: 0.45rem 0.8rem;
  border: 1px solid rgba(242, 207, 145, 0.35);
  border-radius: 999px;
  color: var(--accent);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-decoration: none;
  background: rgba(255, 255, 255, 0.04);
}

.article-back-link:hover,
.article-back-link:focus-visible {
  color: var(--text);
  border-color: rgba(242, 207, 145, 0.6);
}

/* Article page floating back button under Menu */
.article-header-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.7rem;
  pointer-events: auto;
}

.article-header-actions .menu-toggle,
.article-back-button {
  width: 7.35rem;
  min-height: 2.85rem;
  justify-content: center;
}

.article-back-button {
  padding: 0 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.92);
  background: rgba(8, 10, 13, 0.48);
  box-shadow: 0 0.8rem 2.8rem rgba(0, 0, 0, 0.22);
  
  -webkit-
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.17em;
  text-transform: uppercase;
  transition: transform 240ms var(--ease), border-color 240ms var(--ease), background-color 240ms var(--ease), box-shadow 240ms var(--ease);
}

.article-back-button:hover,
.article-back-button:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.42);
  background: rgba(16, 18, 21, 0.72);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.34);
}

body.article-page .menu-panel {
  top: calc(var(--header-y) + env(safe-area-inset-top) + 7.2rem);
}


/* Menu items no longer use numeric prefixes. */
.menu-link span { display: none; }
.menu-link { justify-content: flex-start; }
.menu-admin-row { display: grid; grid-template-columns: 1.2fr 2fr 0.55fr auto; gap: 0.8rem; align-items: end; }
.menu-admin-row label { margin: 0; }
@media (max-width: 860px) { .menu-admin-row { grid-template-columns: 1fr; } }

.admin-help {
  margin: -0.5rem 0 1rem;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.7;
}

.admin-social-list {
  display: grid;
  gap: 0.85rem;
  margin: 1rem 0 1.5rem;
}

.admin-social-row {
  display: grid;
  grid-template-columns: minmax(9rem, 12rem) 2.25rem 1fr;
  align-items: center;
  gap: 0.9rem;
  padding: 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 0.9rem;
  background: rgba(255, 255, 255, 0.035);
}

.admin-social-enabled {
  margin: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-social-row img {
  width: 1.35rem;
  height: 1.35rem;
  object-fit: contain;
  opacity: 0.86;
}

.admin-social-row input[type="text"],
.admin-social-row input:not([type]) {
  width: 100%;
}

@media (max-width: 720px) {
  .admin-social-row {
    grid-template-columns: 1fr;
  }
}

/* Cleaner Settings social icon manager */
.admin-section {
  margin: 1.4rem 0 1.7rem;
}

.admin-social-panel {
  padding: 1.1rem;
  border: 1px solid rgba(255, 255, 255, 0.11);
  border-radius: 1.15rem;
  background: rgba(255, 255, 255, 0.035);
}

.admin-section-head h2 {
  margin: 0 0 0.45rem;
}

.admin-social-panel .admin-help {
  margin: 0 0 1rem;
}

.admin-social-table {
  display: grid;
  gap: 0.55rem;
}

.admin-social-head,
.admin-social-row {
  display: grid;
  grid-template-columns: 6.5rem minmax(10rem, 14rem) minmax(16rem, 1fr);
  gap: 0.85rem;
  align-items: center;
}

.admin-social-head {
  padding: 0 0.85rem 0.25rem;
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.admin-social-row {
  min-height: 3.5rem;
  padding: 0.65rem 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 0.85rem;
  background: rgba(8, 10, 13, 0.28);
}

.admin-social-switch {
  margin: 0 !important;
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: 0.45rem;
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
}

.admin-social-switch input {
  width: 1rem;
  height: 1rem;
  margin: 0;
}

.admin-social-platform {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  min-width: 0;
}

.admin-social-platform strong {
  overflow: hidden;
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.admin-social-icon {
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.admin-social-icon img {
  width: 1.08rem;
  height: 1.08rem;
  object-fit: contain;
  opacity: 0.9;
}

.admin-social-url {
  width: 100%;
  min-width: 0;
}

@media (max-width: 820px) {
  .admin-social-head {
    display: none;
  }
  .admin-social-row {
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 0.7rem;
  }
  .admin-social-switch,
  .admin-social-platform {
    justify-content: flex-start;
  }
}

/* Admin media library */
.media-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: stretch;
  margin: 0 0 1rem;
}
.media-upload-form,
.media-filter-form {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border: 1px solid var(--panel-border);
  border-radius: 1.2rem;
  background: rgba(255,255,255,0.035);
}
.media-upload-form { grid-template-columns: minmax(0,1fr) auto; align-items: end; }
.media-upload-form label,
.media-filter-form label {
  display: grid;
  gap: 0.45rem;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.media-upload-form input,
.media-filter-form input,
.media-filter-form select,
.media-url {
  width: 100%;
  border: 1px solid rgba(242,207,145,0.18);
  border-radius: 0.85rem;
  background: rgba(0,0,0,0.22);
  color: var(--text);
  padding: 0.8rem 0.9rem;
  box-sizing: border-box;
}
.media-filter-form {
  grid-template-columns: 12rem minmax(0, 1fr) auto auto;
  align-items: end;
  margin: 0 0 1.25rem;
}
.media-stats {
  min-width: 12rem;
  padding: 1rem;
  border: 1px solid var(--panel-border);
  border-radius: 1.2rem;
  background: rgba(255,255,255,0.035);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.25rem 0.6rem;
  align-content: center;
}
.media-stats strong { color: var(--accent); font-size: 1.15rem; }
.media-stats span { color: var(--muted); text-transform: uppercase; font-size: 0.78rem; letter-spacing: 0.08em; }
.media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1rem;
}
.media-card {
  overflow: hidden;
  border: 1px solid var(--panel-border);
  border-radius: 1.2rem;
  background: rgba(255,255,255,0.04);
}
.media-preview {
  aspect-ratio: 4 / 3;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,0.28);
  border-bottom: 1px solid var(--panel-border);
}
.media-preview img,
.media-preview video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.media-icon {
  width: 5rem;
  height: 5rem;
  border: 1px solid rgba(242,207,145,0.28);
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--accent);
  font-weight: 900;
  letter-spacing: 0.08em;
  background: rgba(242,207,145,0.08);
}
.media-info {
  display: grid;
  gap: 0.65rem;
  padding: 0.9rem;
}
.media-info strong {
  overflow-wrap: anywhere;
  line-height: 1.25;
}
.media-info span {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.45;
}
.media-url {
  font-size: 0.78rem;
  padding: 0.65rem 0.75rem;
}
.media-actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}
.media-actions form { margin: 0; }
.media-actions .admin-link {
  min-height: auto;
  padding: 0.55rem 0.7rem;
  font-size: 0.72rem;
}
.media-delete { color: #ffb3a8 !important; }
.notice-error { border-color: rgba(255,120,100,0.45) !important; color: #ffb3a8 !important; background: rgba(255,120,100,0.08) !important; }
@media (max-width: 760px) {
  .media-toolbar,
  .media-upload-form,
  .media-filter-form {
    grid-template-columns: 1fr;
  }
  .media-stats { min-width: 0; }
}

/* Floating scroll progress / back-to-top button */
.home-header-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.7rem;
  pointer-events: auto;
}

.home-header-actions .menu-toggle,
.home-header-actions .scroll-top-button,
.article-header-actions .scroll-top-button {
  width: 7.35rem;
}

.scroll-top-button {
  --scroll-progress: 0deg;
  min-height: 2.85rem;
  aspect-ratio: 1 / 1;
  width: 2.85rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  color: rgba(255, 255, 255, 0.92);
  background:
    linear-gradient(rgba(8, 10, 13, 0.72), rgba(8, 10, 13, 0.72)) padding-box,
    conic-gradient(var(--accent) var(--scroll-progress), rgba(255, 255, 255, 0.2) 0deg) border-box;
  box-shadow: 0 0.8rem 2.8rem rgba(0, 0, 0, 0.22);
  
  -webkit-
  cursor: pointer;
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: transform 240ms var(--ease), border-color 240ms var(--ease), background-color 240ms var(--ease), box-shadow 240ms var(--ease);
}

.scroll-top-button span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background: rgba(8, 10, 13, 0.82);
}

.scroll-top-button:hover,
.scroll-top-button:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.42);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.34);
}

.article-header-actions .scroll-top-button,
.home-header-actions .scroll-top-button {
  align-self: flex-end;
}

@media (max-width: 720px) {
  .home-header-actions .menu-toggle,
  .home-header-actions .scroll-top-button,
  .article-header-actions .menu-toggle,
  .article-back-button,
  .article-header-actions .scroll-top-button {
    width: 6.5rem;
  }
}

/* Keep TOP as a compact circle while aligned to the right edge of Menu/BACK. */
.home-header-actions .scroll-top-button,
.article-header-actions .scroll-top-button {
  width: 2.85rem;
  min-width: 2.85rem;
  max-width: 2.85rem;
  flex: 0 0 auto;
}

.home-header-actions ~ .menu-panel {
  top: calc(var(--header-y) + env(safe-area-inset-top) + 7.2rem);
}

body.article-page .menu-panel {
  top: calc(var(--header-y) + env(safe-area-inset-top) + 10.7rem);
}

/* Blog card responsive width fix: keep desktop/tablet text from wrapping early. */
.blog-item {
  width: 100%;
  box-sizing: border-box;
}

.blog-content {
  min-width: 0;
  width: 100%;
  max-width: none;
}

.blog-content h3,
.blog-content p {
  max-width: none;
  overflow-wrap: anywhere;
  word-break: normal;
}

.blog-item--show-date {
  grid-template-columns: minmax(5.5rem, 8rem) minmax(0, 1fr);
}

.blog-item--no-date {
  grid-template-columns: minmax(0, 1fr);
}

.blog-item--with-image.blog-item--show-date {
  grid-template-columns: minmax(9rem, 15rem) minmax(5.2rem, 8rem) minmax(0, 1fr);
}

.blog-item--with-image.blog-item--no-date {
  grid-template-columns: minmax(9rem, 15rem) minmax(0, 1fr);
}

.blog-item--video:not(.blog-item--with-image).blog-item--show-date {
  grid-template-columns: max-content minmax(5.2rem, 8rem) minmax(0, 1fr);
}

.blog-item--video:not(.blog-item--with-image).blog-item--no-date {
  grid-template-columns: max-content minmax(0, 1fr);
}

@media (max-width: 780px) {
  .blog-item,
  .blog-item--show-date,
  .blog-item--no-date,
  .blog-item--with-image.blog-item--show-date,
  .blog-item--with-image.blog-item--no-date,
  .blog-item--video:not(.blog-item--with-image).blog-item--show-date,
  .blog-item--video:not(.blog-item--with-image).blog-item--no-date {
    grid-template-columns: 1fr;
  }
}

/* Contact message card and responsive social icons */
.contact-side {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}

.contact-message-card {
  border: 1px solid var(--panel-border);
  background: rgba(255, 255, 255, 0.035);
  
}

.contact-message-card .comment-form {
  margin-top: 0;
  border: 0;
  padding: 0;
  background: transparent;
  backdrop-filter: none;
}

.contact-message-card .comment-list {
  margin: 1.25rem 0 0;
}

.contact-message-card .comment-card {
  margin-left: 0;
  background: rgba(0, 0, 0, 0.18);
}

.contact-social--outside {
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
}

.contact-social--outside a {
  width: 3.15rem;
  height: 3.15rem;
  min-width: 3.15rem;
  min-height: 3.15rem;
  padding: 0;
  justify-content: center;
  border-radius: 0.9rem;
  box-sizing: border-box;
}

.contact-social--outside a:hover,
.contact-social--outside a:focus-visible {
  transform: translateY(-2px);
}

.contact-social--outside img {
  width: 1.28rem;
  height: 1.28rem;
}

.contact-social--outside span {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

@media (max-width: 640px) {
  .contact-social--outside {
    gap: 0.6rem;
  }

  .contact-social--outside a {
    width: 2.85rem;
    height: 2.85rem;
    min-width: 2.85rem;
    min-height: 2.85rem;
  }
}


/* Comment textarea taller */
.comment-row textarea,
.comment-form textarea,
textarea[name="comment"]{
    min-height: 140px !important;
    height: 140px !important;
}

/* Reply relationship label */
.comment-reply-target {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}
.comment-reply-target::before {
  content: "→";
  margin-right: 0.45rem;
  color: var(--accent);
}
@media (max-width: 780px) {
  .comment-reply-target { margin-top: -0.35rem; }
}


/* Random cat avatars for comments/messages */
.comment-author-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.72rem;
  min-width: 0;
}
.comment-avatar {
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.08);
  box-shadow: 0 10px 24px rgba(0,0,0,0.18);
}
.comment-author-meta {
  display: grid;
  gap: 0.16rem;
  min-width: 0;
}
.comment-author-meta strong {
  overflow-wrap: anywhere;
}
.comment-card header {
  align-items: flex-start;
}
@media (max-width: 780px) {
  .comment-avatar {
    width: 34px;
    height: 34px;
    flex-basis: 34px;
  }
}

/* Hero / Get in touch social icons as rounded-square buttons */
.hero-social {
  gap: clamp(0.55rem, 1.1vw, 0.9rem) !important;
  flex-wrap: wrap;
}

.hero-social a {
  width: clamp(2.55rem, 3vw, 2.95rem) !important;
  height: clamp(2.55rem, 3vw, 2.95rem) !important;
  min-width: clamp(2.55rem, 3vw, 2.95rem) !important;
  min-height: clamp(2.55rem, 3vw, 2.95rem) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0.72rem !important;
  box-sizing: border-box !important;
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
  border-radius: 0.85rem !important;
  background: rgba(255, 255, 255, 0.045) !important;
  
  -webkit-
  opacity: 0.9 !important;
  transition: opacity 220ms var(--ease), transform 220ms var(--ease), border-color 220ms var(--ease), background 220ms var(--ease), filter 220ms var(--ease) !important;
}

.hero-social a:hover,
.hero-social a:focus-visible {
  opacity: 1 !important;
  transform: translateY(-3px) !important;
  border-color: rgba(242, 207, 145, 0.72) !important;
  background: rgba(242, 207, 145, 0.12) !important;
  filter: drop-shadow(0 0.35rem 0.9rem rgba(242, 207, 145, 0.22)) !important;
}

.hero-social img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
}

@media (max-width: 640px) {
  .hero-social {
    gap: 0.55rem !important;
  }

  .hero-social a {
    width: 2.65rem !important;
    height: 2.65rem !important;
    min-width: 2.65rem !important;
    min-height: 2.65rem !important;
    border-radius: 0.75rem !important;
    padding: 0.68rem !important;
  }
}


/* Favicon/admin avatar and comment avatar */
.comment-avatar{width:38px;height:38px;border-radius:999px;object-fit:cover;flex:0 0 auto;border:1px solid rgba(255,255,255,.18)}
.comment-author,.comment-meta{display:flex;align-items:center;gap:.65rem}
.admin-favicon-preview{margin:.5rem 0 1rem}


/* Reply target avatar */
.comment-reply-target {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  flex-wrap: wrap;
}
.comment-reply-target-avatar {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  object-fit: cover;
  vertical-align: middle;
  border: 1px solid rgba(255,255,255,.18);
}


/* Modern post editor */
.modern-post-form .admin-card,
.modern-editor-card {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 1.2rem;
  background: rgba(255,255,255,.035);
}
.modern-editor-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}
.modern-editor-head h2 {
  margin: 0 0 .25rem;
}
.editor-mode-tabs {
  display: inline-flex;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: .2rem;
  gap: .2rem;
}
.editor-mode-tabs button,
.modern-editor-toolbar button {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: inherit;
  border-radius: 999px;
  padding: .45rem .75rem;
  cursor: pointer;
}
.editor-mode-tabs button.is-active {
  background: rgba(255,255,255,.16);
}
.modern-editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-bottom: .85rem;
}
.visual-editor,
.code-editor {
  width: 100%;
  min-height: 520px;
  box-sizing: border-box;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 18px;
  background: rgba(0,0,0,.18);
  color: inherit;
  padding: 1.2rem;
  line-height: 1.75;
  outline: none;
}
.visual-editor:empty::before {
  content: attr(data-placeholder);
  color: rgba(255,255,255,.42);
}
.visual-editor.is-dragging {
  border-color: rgba(255,255,255,.55);
  background: rgba(255,255,255,.07);
}
.visual-editor img,
.visual-editor video {
  max-width: 100%;
  height: auto;
  border-radius: 16px;
}
.visual-editor blockquote {
  margin: 1rem 0;
  padding: .8rem 1rem;
  border-left: 3px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.04);
}
.visual-editor pre,
.code-editor {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}
.visual-editor pre {
  padding: 1rem;
  border-radius: 14px;
  overflow: auto;
  background: rgba(0,0,0,.28);
}
.editor-upload-progress {
  display: flex;
  align-items: center;
  gap: .7rem;
  margin-top: .8rem;
  font-size: .9rem;
}
.editor-upload-progress progress {
  width: 180px;
}
.comment-admin-reply-note {
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 14px;
  padding: .75rem .9rem;
  background: rgba(255,255,255,.045);
  margin-bottom: .8rem;
}
@media (max-width: 760px) {
  .modern-editor-head { display: block; }
  .editor-mode-tabs { margin-top: .75rem; }
  .visual-editor, .code-editor { min-height: 420px; }
}


/* dashboard nav */
.menu-link-dashboard{
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:rgba(255,255,255,.06);
}
.menu-link-dashboard:hover{
  background:rgba(255,255,255,.12);
}

.social-popup-trigger{
cursor:pointer;
color:inherit;
}
.social-popup-overlay{
position:fixed;inset:0;background:rgba(0,0,0,.55);
display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;
}
.social-popup-card{
width:min(92vw,360px);border-radius:28px;padding:1.4rem;
background:rgba(20,20,20,.88);border:1px solid rgba(255,255,255,.12);
position:relative;text-align:center;
}
.social-popup-close{
position:absolute;top:.7rem;right:.8rem;background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer;
}
.social-popup-card h3{margin:.2rem 0 1rem;}
.social-popup-qr{
width:220px;max-width:100%;border-radius:20px;
}
.social-popup-text,.social-popup-link{
padding:.9rem 1rem;border-radius:16px;background:rgba(255,255,255,.06);
margin:1rem 0;word-break:break-word;
}
.social-copy-btn,.social-visit-btn{
display:inline-flex;align-items:center;justify-content:center;
padding:.8rem 1.2rem;border-radius:999px;
background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
color:#fff;text-decoration:none;
}


.social-popup-overlay[hidden],
#socialPopup[hidden]{
  display:none !important;
}


/* restore original social icon sizing/frame */
.hero-social .social-popup-trigger,
.contact-social .social-popup-trigger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  height:auto;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  padding:.78rem;
  transition:all .2s ease;
  
}

.hero-social .social-popup-trigger:hover,
.contact-social .social-popup-trigger:hover{
  background:rgba(255,255,255,.08);
  transform:translateY(-2px);
}

.hero-social .social-popup-trigger img,
.contact-social .social-popup-trigger img{
  width:22px;
  height:22px;
  display:block;
}

.contact-social .social-popup-trigger span{
  margin-left:.55rem;
}


/* fix hero social popup icon size */
.hero-social .social-popup-trigger{
  width:42px !important;
  height:42px !important;
  min-width:42px !important;
  min-height:42px !important;
  padding:0 !important;
  border-radius:12px !important;
  border:1px solid rgba(255,255,255,.14) !important;
  background:rgba(255,255,255,.04) !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.hero-social .social-popup-trigger img{
  width:18px !important;
  height:18px !important;
  object-fit:contain !important;
}

.contact-social .social-popup-trigger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}


/* admin social conditional fields */
.admin-social-field[hidden] {
  display: none !important;
}
.admin-social-field {
  width: 100%;
}
.admin-social-qr-tools {
  display: grid;
  gap: .5rem;
}


/* social popup polish */
.social-popup-card{
  width:min(88vw,320px) !important;
  border-radius:22px !important;
  padding:1.1rem !important;
  background:#111 !important;
  border:1px solid rgba(255,255,255,.18) !important;
  text-align:center !important;
  box-shadow:0 22px 60px rgba(0,0,0,.45) !important;
}

.social-popup-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

.social-popup-content h3{
  width:100%;
  margin:.1rem 0 .85rem !important;
  text-align:center;
}

.social-popup-qr-wrap{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}

.social-popup-qr{
  display:block !important;
  width:190px !important;
  max-width:100% !important;
  height:auto !important;
  margin:0 auto !important;
  border-radius:16px !important;
}

.social-popup-text,
.social-popup-link{
  width:100%;
  box-sizing:border-box;
  background:#1b1b1b !important;
  border:1px solid rgba(255,255,255,.12);
  margin:.75rem 0 !important;
  text-align:center;
}

.social-copy-btn,
.social-visit-btn{
  background:#1f1f1f !important;
}

.social-copy-btn.is-copied{
  background:#2b2b2b !important;
}


/* smart top button */
.top-button{
  position:fixed;
  right:12px;
  bottom:12px;
  width:54px;
  height:54px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(16,16,16,.92);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  z-index:999;
  cursor:pointer;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:opacity .25s ease, transform .25s ease, visibility .25s ease, background .25s ease;
  overflow:hidden;
}

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

.top-button::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:conic-gradient(#fff var(--scroll-progress, 0deg), rgba(255,255,255,.08) 0deg);
  mask:radial-gradient(farthest-side, transparent calc(100% - 3px), #000 0);
  -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 3px), #000 0);
}

.top-button span{
  position:relative;
  z-index:1;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.top-button.is-scrolling span{
  font-size:12px;
}

@media (max-width: 768px){
  .top-button{
    width:50px;
    height:50px;
    right:10px;
    bottom:10px;
  }
}


/* restore TOP button to right upper menu column */
.top-button{
  top:132px !important;
  right:24px !important;
  bottom:auto !important;
  left:auto !important;
}

@media (max-width: 768px){
  .top-button{
    top:126px !important;
    right:18px !important;
    bottom:auto !important;
  }
}
