恭喜发财!

news2025/1/11 16:44:20
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>恭喜发财</title>
    <link rel="stylesheet" href="css/style.css">
</head>

<body>
    <section class="container">
        <label class="card" for="card">
            <div class="ear-shadow"></div>
            <div class="ear-shadow ear-shadow_right"></div>
            <div class="eyes"></div>
            <div class="mouth"></div>
            <div class="nose"></div>
            <div class="mustache"></div>
            <div class="mustache mustache_right"></div>
            <div class="paw"></div>
            <div class="paw paw_right"></div>
            <div class="plate">恭喜发财</div>
            <div class="card card_back"></div>
        </label>
    </section>
    <section class="flakes">
        <span class="flake">😷</span>
        <span class="flake">💊</span>
        <span class="flake">🏥</span>
        <span class="flake">🧼</span>
        <span class="flake">🚑</span>
        <span class="flake">🦠</span>
        <span class="flake">🤒</span>
        <span class="flake">💸</span>
        <span class="flake">🧪</span>
        <span class="flake">👩‍⚕️</span>
    </section>
</body>

</html>

style.css

@import url("https://fonts.googleapis.com/css2?family=Fredoka+One&display=swap");
body {
  font-family: "Fredoka One", cursive;
  position: relative;
  overflow: hidden;
  height: 100vh;
  background: conic-gradient(from -90deg at 50% 50%, #eb5757 0deg, #f2994a 90deg, #219653 180deg, #2d9cdb 270deg, #eb5757 360deg);
  perspective: 100vmin;
}
body::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: radial-gradient(50% 50% at 50% 50%, #eb5757 0%, rgba(235, 87, 87, 0.67) 26.56%, rgba(235, 87, 87, 0) 100%);
}


/*\
|*| Container
\*/
.container {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-animation: jump 1s ease-in-out alternate infinite;
          animation: jump 1s ease-in-out alternate infinite;
}
@-webkit-keyframes jump {
  from {
    transform: scaleY(1) translateY(-10vmin);
  }
  to {
    transform: scaleY(0.9) translateY(10vmin);
  }
}
@keyframes jump {
  from {
    transform: scaleY(1) translateY(-10vmin);
  }
  to {
    transform: scaleY(0.9) translateY(10vmin);
  }
}

/*\
|*| Card
\*/
.card {
  position: relative;
  background: #f5f5f5;
  width: 50vmin;
  height: 70vmin;
  border-radius: 25vmin 25vmin 3vmin 3vmin;
  border-bottom: 0.5vmin solid #777;
  box-shadow: rgba(0, 0, 0, 0.3) 0 0.4vmin 0.4vmin, rgba(0, 0, 0, 0.25) 0 0.8vmin 0.8vmin, rgba(0, 0, 0, 0.2) 0 1.6vmin 1.6vmin;
  cursor: url(""), default;
  transform: rotateX(0deg) rotateY(20deg) scale(1);
  transform-style: preserve-3d;
  transition: 1.5s ease-in-out;
  transition-property: transform;
}
.card::after, .card::before {
  content: "";
  position: absolute;
  top: -2vmin;
  left: 8vmin;
  width: 12vmin;
  height: 7vmin;
  border-radius: 6vmin 6vmin 0 0;
  background: #f5f5f5;
  box-shadow: 0 -0.3vmin 0.2vmin rgba(0, 0, 0, 0.1);
}
.card::after {
  transform: rotate(-10deg);
}
.card::before {
  left: calc(50vmin - 12vmin - 8vmin);
  transform: rotate(10deg);
}
.card_back {
  box-shadow: none;
  transform: translateZ(-0.1vmin);
}

#card {
  height: 0;
  width: 0;
  position: absolute;
  opacity: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  left: 100%;
}
#card:checked + .card {
  transform: rotateX(360deg) rotateY(-20deg) scale(0.8);
}

/*\
|*| Eears' Shadow
\*/
.ear-shadow {
  z-index: 1;
  position: absolute;
  top: -1vmin;
  left: 11vmin;
  width: 8vmin;
  height: 8vmin;
  border-radius: 50%;
  border-top: 0.5vmin solid rgba(180, 0, 0, 0.25);
  transform: rotate(-25deg);
}
.ear-shadow_right {
  transform: rotate(25deg);
  left: calc(50vmin - 8vmin - 11vmin);
}

/*\
|*| Eyes
\*/
.eyes {
  z-index: 1;
  position: absolute;
}
.eyes::after, .eyes::before {
  content: "";
  position: absolute;
  top: 15vmin;
  left: 10vmin;
  width: 10vmin;
  height: 10vmin;
  border-radius: 50%;
  border-top: 1vmin solid #111;
}
.eyes::before {
  left: calc(50vmin - 10vmin - 10vmin);
}

/*\
|*| Nose
\*/
.nose {
  z-index: 1;
  position: absolute;
  top: 23vmin;
  left: 23.5vmin;
  width: 3vmin;
  height: 2vmin;
  border-radius: 50%;
  background: #d98695;
  box-shadow: inset 0.5vmin 0.3vmin 0.7vmin rgba(255, 255, 255, 0.8);
}

/*\
|*| Mouth
\*/
.mouth {
  z-index: 1;
  position: absolute;
}
.mouth::after, .mouth::before {
  content: "";
  position: absolute;
  top: 21.7vmin;
  left: 20.05vmin;
  width: 5vmin;
  height: 5vmin;
  border-radius: 50%;
  border-bottom: 0.7vmin solid #111;
}
.mouth::before {
  left: calc(50vmin - 5vmin - 20.05vmin);
}

/*\
|*| Mustache
\*/
.mustache {
  z-index: 1;
  position: absolute;
  top: 24vmin;
  left: 9vmin;
  width: 10vmin;
  height: 2vmin;
  border-radius: 50%;
  border-top: 0.35vmin solid #111;
  transform: rotate(-10deg);
}
.mustache::after, .mustache::before {
  content: "";
  position: absolute;
  top: 1vmin;
  left: 3vmin;
  width: 7vmin;
  height: 2vmin;
  border-radius: 50%;
  border-top: 0.35vmin solid #111;
  transform: rotate(-24deg);
}
.mustache::before {
  top: -1.7vmin;
  left: 2vmin;
  width: 8vmin;
  transform: rotate(19deg);
}
.mustache_right {
  left: calc(50vmin - 10vmin - 9vmin);
  transform: rotate(10deg) scale(-1, 1);
}

/*\
|*| Paws
\*/
.paw {
  z-index: 1;
  position: absolute;
  top: 37vmin;
  left: 1vmin;
  width: 12vmin;
  height: 12vmin;
  border-radius: 50%;
  border-right: 0.6vmin solid #111;
  box-shadow: inset -1vmin 1vmin 0 #c8c8c8;
  transform: rotate(45deg);
}
.paw_right {
  left: calc(50vmin - 12vmin - 1vmin);
  transform: rotate(-45deg) scale(-1, 1);
}

/*\
|*| Plate
\*/
.plate {
  position: absolute;
  top: 37vmin;
  left: 13vmin;
  width: 24.5vmin;
  height: 12vmin;
  border-radius: 1vmin;
  background-image: linear-gradient(315deg, #d99058 0%, #f8de7e 74%);
  color: rgba(162, 71, 0, 0.5);
  text-shadow: 0.25vmin 0.25vmin 0 #ffe897;
  font-size: 6.1vmin;
  overflow: hidden;
  text-align: center;
  display: flex;
  align-items: center;
  transform: rotate(7deg);
  box-shadow: 0 0.9vmin 0 #6d4c36, rgba(0, 0, 0, 0.15) 0 1.1vmin 0.2vmin, rgba(0, 0, 0, 0.15) 0 1.3vmin 0.4vmin, rgba(0, 0, 0, 0.15) 0 1.7vmin 0.8vmin, rgba(0, 0, 0, 0.15) 0 2.5vmin 1.6vmin, rgba(0, 0, 0, 0.15) 0 4.1vmin 3.2vmin;
}

/*\
|*| Flakes of 2020
\*/
.flakes {
  position: relative;
  color: rgba(255, 255, 255, 0.5);
  font-size: 3vmin;
  font-family: ProximaNova, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.flake {
  position: fixed;
  top: -10%;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-animation-name: flakes-fall, flakes-shake-rotate;
          animation-name: flakes-fall, flakes-shake-rotate;
  -webkit-animation-duration: 10s, 3s;
          animation-duration: 10s, 3s;
  -webkit-animation-timing-function: linear, ease-in-out;
          animation-timing-function: linear, ease-in-out;
  -webkit-animation-iteration-count: infinite, infinite;
          animation-iteration-count: infinite, infinite;
  -webkit-animation-play-state: running, running;
          animation-play-state: running, running;
}
@-webkit-keyframes flakes-fall {
  0% {
    top: -10%;
  }
  100% {
    top: 100%;
  }
}
@keyframes flakes-fall {
  0% {
    top: -10%;
  }
  100% {
    top: 100%;
  }
}
@-webkit-keyframes flakes-shake-rotate {
  0% {
    transform: translateX(0px) rotate(0deg);
  }
  50% {
    transform: translateX(8vmin) rotate(180deg);
  }
  100% {
    transform: translateX(0px) rotate(360deg);
  }
}
@keyframes flakes-shake-rotate {
  0% {
    transform: translateX(0px) rotate(0deg);
  }
  50% {
    transform: translateX(8vmin) rotate(180deg);
  }
  100% {
    transform: translateX(0px) rotate(360deg);
  }
}
.flake:nth-of-type(0) {
  left: 1%;
  -webkit-animation-delay: 0s, 0s;
          animation-delay: 0s, 0s;
}
.flake:nth-of-type(1) {
  left: 10%;
  -webkit-animation-delay: 1s, 1s;
          animation-delay: 1s, 1s;
}
.flake:nth-of-type(2) {
  left: 20%;
  -webkit-animation-delay: 6s, 0.5s;
          animation-delay: 6s, 0.5s;
}
.flake:nth-of-type(3) {
  left: 30%;
  -webkit-animation-delay: 4s, 2s;
          animation-delay: 4s, 2s;
}
.flake:nth-of-type(4) {
  left: 40%;
  -webkit-animation-delay: 2s, 2s;
          animation-delay: 2s, 2s;
}
.flake:nth-of-type(5) {
  left: 50%;
  -webkit-animation-delay: 8s, 3s;
          animation-delay: 8s, 3s;
}
.flake:nth-of-type(6) {
  left: 60%;
  -webkit-animation-delay: 6s, 2s;
          animation-delay: 6s, 2s;
}
.flake:nth-of-type(7) {
  left: 70%;
  -webkit-animation-delay: 2.5s, 1s;
          animation-delay: 2.5s, 1s;
}
.flake:nth-of-type(8) {
  left: 80%;
  -webkit-animation-delay: 1s, 0s;
          animation-delay: 1s, 0s;
}
.flake:nth-of-type(9) {
  left: 90%;
  -webkit-animation-delay: 3s, 1.5s;
          animation-delay: 3s, 1.5s;
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/915622.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

leetcode1094. 拼车(差分数组-java)

差分数组 leetcode 1094 拼车差分数组代码演示&#xff1a; 前缀和数组 leetcode 1094 拼车 难度 - 中等 原题链接 - 拼车 车上最初有 capacity 个空座位。车 只能 向一个方向行驶&#xff08;也就是说&#xff0c;不允许掉头或改变方向&#xff09; 给定整数 capacity 和一个数…

解决方案:fatal error: openssl/bio.h: 没有那个文件或目录

出现报错如下&#xff1a; 出现该错误的原因有两个&#xff1a; 没有安装openssl或者libssl-dev库Libssl-dev版本过高&#xff0c;需要降级 一. 没有安装openssl或者libssl-dev库 使用指令安装openssl&#xff1a; 我的是已经安装完成了&#xff0c;所以再把libssl-dev的库也…

进程调度和进程切换——《王道考研》

一、王道书咋说 二、chatgpt咋说 进程调度和进程切换是多道程序操作系统中两个关键的概念&#xff0c;它们在处理多个进程时起着不同的作用。 2.1进程调度是指&#xff1a; 操作系统根据一定的调度算法&#xff0c;从就绪态的进程队列中选择一个进程来占用CPU资源&#xff0…

dfs之单词搜索

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 单词必须按照字母顺序&#xff0c;通过相邻的单元格内的字母构成&#xff0c;其中“相邻”单元格是那些水平相邻或垂直相…

江西抚州新能源汽车3d扫描零部件逆向抄数测量改装-CASAIM中科广电

汽车改装除了在外观方面越来越受到消费者的青睐&#xff0c;在性能和实用性提升上面的需求也是日趋增多&#xff0c;能快速有效地对客户指定汽车零部件进行一个改装&#xff0c;是每一个汽车改装企业和工程师的追求&#xff0c;也是未来消费者个性化差异化的要求。下面CASAIM中…

汉字占用两字节原因

经常可以看到这么一句话: 英文及符号占用一个字节,汉字占用两个字节. 大家大都强行记忆,并没有关注原因. 今天就能看看到底是什么原因导致的呢? 我们先看大家都见过的一张图 其中字符char占位一个字节或者两个字节. 当占位一个字节时,最大值为2^7-1,十进制为127,二进制为0111…

一文速学-LightGBM模型算法原理以及实现+Python项目实战

LighGBM 前言 LighGBM作为GBDT算法的衍生模型&#xff0c;在其他论文研究以及数学建模比赛中十分常见。如果不熟悉GBDT算法的可以去看看我的上一篇文章&#xff0c;过多关于GBDT的细节不再过多描述。主要将讲述一下LighGBM较于GBDT算法的改进以及独特算法细节优化&#xff0c…

yolov8后处理——DFL卷积如何卷

以 512*288 输入为例&#xff0c;网络输出大小 1*64*3024&#xff0c;其中 1 为 batch size&#xff0c;64为超参数reg_max16 和 bbox 个数 4 的乘积&#xff0c;302416*932*1864*36&#xff08;其中512/3216,288/329&#xff09; 首先 DFL 卷积是和 0-15 卷积&#xff0c;下面…

Ros noetic Move_base 监听Move状态 实战使用教程

前言: 承接上一篇文章,在上一文中我们了解到move_base有几种监听的状态,我一文章中我将开源全部监听代码,本文将从0开始建立监听包,并覆上全部的工程代码,和仿真实操结果。 本文,还将解决当临时障碍物与机身相交时,机器人回人为自己被“卡住”,局部规划器规划的速度为…

商业大厦烟感监控,效果出乎意料!

烟感监控是现代安全技术中至关重要的一环&#xff0c;其在预防火灾、保护生命和财产方面发挥着关键作用。通过使用先进的烟雾探测器和智能报警系统&#xff0c;烟感监控能够及早发现烟雾和火源&#xff0c;并在火灾爆发前提供必要的警示和警报。 通过其精密的传感技术和联动装置…

新品如何传播,小红书种草策略分析!

种草是小红书品宣与传播的核心&#xff0c;也是平台的巨大优势。品牌想要在小红书进行快速传播&#xff0c;制定一份可落地实施的种草策略是必不可少的。今天将通过一篇文章&#xff0c;给大家分享一下新品如何传播&#xff0c;小红书种草策略分析&#xff01; 一、如何进行小红…

6、Spring_Junit与JdbcTemplate整合

Spring 整合 1.Spring 整合 Junit 1.1新建项目结构 1.2导入依赖 导入 junit 与 Spring 依赖 <!-- 添加 spring 依赖--> <dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version…

pdf格式怎么编辑?了解这种编辑方法就可以了

pdf格式怎么编辑&#xff1f;PDF作为一种通用的文档格式&#xff0c;以其跨平台、保真排版等优势在各个领域得到广泛应用。然而&#xff0c;对于许多人来说&#xff0c;PDF文件一直以来都被视为“静态”文件&#xff0c;不易编辑。但现在&#xff0c;有很多编辑器可以帮助我们进…

qt5 TLS initialization failed error

首先打印openssl支持信息 qDebug() << QSslSocket::supportsSsl() << "\n"; qDebug() << QSslSocket::sslLibraryBuildVersionString(); //上述代码打印下面的结果&#xff1a; false "OpenSSL 1.1.1g 21 Apr 2020"更新对应openssl证…

【从零学习python 】74. UDP网络程序:端口问题与绑定信息详解

文章目录 udp网络程序-端口问题UDP绑定信息总结 进阶案例 udp网络程序-端口问题 在运行 UDP 网络程序时&#xff0c;会遇到端口号会变化的情况。 每次重新运行网络程序后&#xff0c;可以观察到运行中的“网络调试助手”显示的数字是不同的。这是因为该数字标识了网络程序的…

35309-53-6,cyclo(Asp-Asp),氨基酸中间体,环(-天冬氨酰-天冬氨酰),

中文名&#xff1a;CYCLO(-天冬氨酸-ASP) 2,5-哌嗪二乙酸&#xff0c;3,6-二氧基-&#xff08;2S-顺式&#xff09; 环(-天冬氨酰-天冬氨酰) 英文名&#xff1a;cyclo(Asp-Asp)&#xff0c; [(2S)-(3,6-dioxo-piperazine-2r,5c-diyl)-di-acetic acid Cyclo(L-Aspartyl-L-A…

iPhone如何录屏?详细教程大揭秘(最新)

“iphone怎么录屏呀&#xff0c;有人知道吗&#xff1f;用了很久的iphone12了&#xff0c;却不知道录屏功能在哪里&#xff0c;现在需要用来录教程&#xff0c;找也找不到&#xff0c;有人知道iphone录屏在哪里吗&#xff1f;很急&#xff01;” iphone作为一款备受欢迎的智能…

MySQL 主从配置

环境 centos6.7 虚拟机两台 主&#xff1a;192.168.23.160 从&#xff1a;192.168.23.163 准备 在两台机器上分别安装mysql5.6.23&#xff0c;安装完成后利用临时密码登录mysql数据修改root的密码&#xff1b;将my.cnf配置文件放至/etc/my.cnf&#xff0c;重启mysql服务进…

多旋翼飞控底层算法开发系列实验 | 多旋翼动力系统设计实验2

多旋翼飞控底层算法开发系列实验 | 多旋翼动力系统设计实验2 01/多旋翼动力系统简介 多旋翼无人机的动力系统通常包括螺旋桨、电机、电调以及电池。动力系统是多旋翼最重要的组成部分&#xff0c;它决定了多旋翼的主要性能&#xff0c;如悬停时间、载重能力、飞行速度和飞行距…

一文学会使用ChatGPT API搭建自己的聊天网站

一文读懂如何搭建自己的ChatGPT聊天网站 在数字时代的浪潮下&#xff0c;人工智能正变得愈发令人惊叹和亲近。ChatGPT&#xff0c;就是这个变革的杰出代表。这项令人兴奋的技术将强大的自然语言处理能力带到您的指尖&#xff0c;让您能够以前所未有的方式与计算机进行互动。 …