15+ CSS Weather Card Examples

This post contains a total of 15+ CSS Weather Card Examples with Source Code. All these Weather Cards are made using CSS & Js.

You can use the source code of these examples with credits to the original owner.

Related Posts

CSS Weather Card Examples

1. Weather card

Made by Alex. CSS Weather card with cool animations. It has multiple weather themes which you can switch using the top buttons. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
<style>
@import 'https://fonts.googleapis.com/css?family=Lato:300';
@import 'https://cdnjs.cloudflare.com/ajax/libs/weather-icons/2.0.9/css/weather-icons.min.css';
html, body, .background {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: "Lato", sans-serif;
}

html {
  background: #fff;
}

body {
  background: #eee;
  background: linear-gradient(0deg, rgba(0, 0, 200, 0.2), rgba(0, 0, 200, 0));
}

.background {
  background: #eee;
  background: linear-gradient(120deg, rgba(50, 150, 100, 0.2), rgba(0, 0, 100, 0));
}

.container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%;
  overflow: auto;
  position: relative;
  background: #eee;
  background: linear-gradient(240deg, rgba(150, 50, 50, 0.3), rgba(0, 0, 200, 0));
}
nav ul {
  margin: 20px 20px 0 20px;
  list-style-type: none;
  padding: 0;
  display: flex;
  flex-direction: row;
}
nav li a {
  display: block;
  width: 50px;
  text-align: center;
  color: #aaa;
  cursor: pointer;
}
nav li a:hover {
  color: #444;
}
nav li a.active {
  color: #4444ff;
}

#card {
  box-shadow: 9px 7px 40px -6px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  width: 300px;
  padding: 0;
  height: 400px;
  min-height: 300px;
  margin: 20px;
  border-radius: 5px;
  position: relative;
}
#card .details {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: 16px 20px;
  color: #888;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  transition: color 2s ease;
}
.thunder #card .details {
  color: #ddd;
}
#card .details .right {
  text-align: right;
}
#card .details #date {
  margin: 4px 0;
}
#card .details #summary {
  font-weight: 600;
  font-size: 22px;
}
#card .details .temp {
  font-size: 60px;
  line-height: 60px;
}
#card .details .temp span {
  font-size: 18px;
  line-height: 30px;
  vertical-align: top;
  margin-left: 5px;
}

.weather {
  background-color: #DAE3FD;
  transition: background-color 2s ease;
}
.thunder .weather {
  background-color: #9FA4AD;
}
.rain .weather {
  background-color: #D8D8D8;
}
.sun .weather {
  background-color: #ccccff;
}
.weather #inner {
  background-color: white;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 100%);
}
.weather .cloud {
  transition: fill 2s ease;
}
.weather #cloud1 {
  fill: #efefef;
}
.thunder .weather #cloud1 {
  fill: #9FA4AD;
}
.weather #cloud2 {
  fill: #E6E6E6;
}
.thunder .weather #cloud2 {
  fill: #8B8E98;
}
.weather #cloud3 {
  fill: #D5D5D5;
}
.thunder .weather #cloud3 {
  fill: #7B7988;
}

#outer, #back {
  position: fixed;
  pointer-events: none;
}
</style>
</head>
<body>
  <div class="background">
<div class="container">	
	<svg id="back">
		<radialGradient id="SVGID_1_" cx="0" cy="0" r="320.8304" gradientUnits="userSpaceOnUse">
			<stop  offset="0" style="stop-color:#FFDE17;stop-opacity:0.7"/>
			<stop  offset="1" style="stop-color:#FFF200;stop-opacity:0"/>
		</radialGradient>
		<path id="sunburst" style="fill:url(#SVGID_1_);" d="M0,319.7c-18.6,0-37.3-1.6-55.5-4.8L-7.8,41.4c5.1,0.9,10.6,0.9,15.7,0L56,314.8C37.6,318,18.8,319.7,0,319.7z
	 M-160.8,276.6c-32.5-18.8-61.3-42.9-85.5-71.6L-34,26.2c3.4,4.1,7.4,7.4,12,10.1L-160.8,276.6z M161.3,276.4L22.1,36.2
	c4.5-2.6,8.6-6,12-10.1l212.6,178.5C222.5,233.4,193.8,257.6,161.3,276.4z M-302.5,108.3C-315.4,73-321.9,36-322-1.8l277.6-0.5
	c0,5.3,0.9,10.4,2.7,15.2L-302.5,108.3z M302.6,107.8L41.8,12.8c1.7-4.7,2.6-9.7,2.6-14.9c0-0.3,0-0.6,0-1H322l0-1.3l0,1.9
	C322,35.4,315.5,72.5,302.6,107.8z M-41.8-17.5l-261-94.5c12.8-35.4,31.6-68,55.8-96.9L-34.1-30.8C-37.5-26.8-40.1-22.3-41.8-17.5z
	 M41.7-17.7c-1.8-4.8-4.4-9.3-7.8-13.3l212-179.2c24.3,28.8,43.3,61.3,56.3,96.6L41.7-17.7z M-22.2-40.8l-139.6-240
	c32.7-19,68.1-32,105.2-38.6L-8-46.1C-13-45.2-17.8-43.4-22.2-40.8z M22-40.9c-4.4-2.6-9.2-4.3-14.2-5.1l47.1-273.6
	c37.2,6.4,72.7,19.2,105.4,38L22-40.9z"/>
	</svg>
	<nav>
		<ul>
			<li><a id="button-snow" class="active"><i class="wi wi-snow"></i></a></li>
			<li><a id="button-wind"><i class="wi wi-strong-wind"></i></a></li>
			<li><a id="button-rain"><i class="wi wi-rain"></i></a></li>
			<li><a id="button-thunder"><i class="wi wi-lightning"></i></a></li>
			<li><a id="button-sun"><i class="wi wi-day-sunny"></i></a></li>
		</ul>
	</nav>
	<div id="card" class="weather">
		<svg id="inner">
			<defs>
				<path id="leaf" d="M41.9,56.3l0.1-2.5c0,0,4.6-1.2,5.6-2.2c1-1,3.6-13,12-15.6c9.7-3.1,19.9-2,26.1-2.1c2.7,0-10,23.9-20.5,25 c-7.5,0.8-17.2-5.1-17.2-5.1L41.9,56.3z"/>
			</defs>
			<circle id="sun" style="fill: #F7ED47" cx="0" cy="0" r="50"/>
			<g id="layer3"></g>
			<g id="cloud3" class="cloud"></g>
			<g id="layer2"></g>
			<g id="cloud2" class="cloud"></g>
			<g id="layer1"></g>
			<g id="cloud1" class="cloud"></g>
		</svg>
		<div class="details">
			<div class="temp">20<span>c</span></div>
			<div class="right">
				<div id="date">Monday 22 August</div>
				<div id="summary"></div>
			</div>
			
		</div>
	</div>
	<svg id="outer"></svg>
</div>
</div>
<script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>

<script src='https://code.jquery.com/jquery-2.2.4.min.js'></script>
<script src='https://cdnjs.cloudflare.com/ajax/libs/gsap/1.19.0/TweenMax.min.js'></script>
<script src='https://cdnjs.cloudflare.com/ajax/libs/snap.svg/0.4.1/snap.svg-min.js'></script>
      <script id="rendered-js" >
// πŸ“ Fetch all DOM nodes in jQuery and Snap SVG

var container = $('.container');
var card = $('#card');
var innerSVG = Snap('#inner');
var outerSVG = Snap('#outer');
var backSVG = Snap('#back');
var summary = $('#summary');
var date = $('#date');
var weatherContainer1 = Snap.select('#layer1');
var weatherContainer2 = Snap.select('#layer2');
var weatherContainer3 = Snap.select('#layer3');
var innerRainHolder1 = weatherContainer1.group();
var innerRainHolder2 = weatherContainer2.group();
var innerRainHolder3 = weatherContainer3.group();
var innerLeafHolder = weatherContainer1.group();
var innerSnowHolder = weatherContainer1.group();
var innerLightningHolder = weatherContainer1.group();
var leafMask = outerSVG.rect();
var leaf = Snap.select('#leaf');
var sun = Snap.select('#sun');
var sunburst = Snap.select('#sunburst');
var outerSplashHolder = outerSVG.group();
var outerLeafHolder = outerSVG.group();
var outerSnowHolder = outerSVG.group();

var lightningTimeout;

// Set mask for leaf holder 

outerLeafHolder.attr({
  'clip-path': leafMask });


// create sizes object, we update this later

var sizes = {
  container: { width: 0, height: 0 },
  card: { width: 0, height: 0 } };


// grab cloud groups

var clouds = [
{ group: Snap.select('#cloud1') },
{ group: Snap.select('#cloud2') },
{ group: Snap.select('#cloud3') }];


// set weather types ☁️ 🌬 🌧 β›ˆ β˜€οΈ

var weather = [
{ type: 'snow', name: 'Snow' },
{ type: 'wind', name: 'Windy' },
{ type: 'rain', name: 'Rain' },
{ type: 'thunder', name: 'Storms' },
{ type: 'sun', name: 'Sunny' }];


// πŸ›  app settings
// in an object so the values can be animated in tweenmax

var settings = {
  windSpeed: 2,
  rainCount: 0,
  leafCount: 0,
  snowCount: 0,
  cloudHeight: 100,
  cloudSpace: 30,
  cloudArch: 50,
  renewCheck: 10,
  splashBounce: 80 };


var tickCount = 0;
var rain = [];
var leafs = [];
var snow = [];

// βš™ initialize app

init();

// πŸ‘ watch for window resize

$(window).resize(onResize);

// πŸƒ start animations

requestAnimationFrame(tick);

function init()
{
  onResize();

  // πŸ–± bind weather menu buttons

  for (var i = 0; i < weather.length; i++)
  {
    var w = weather[i];
    var b = $('#button-' + w.type);
    w.button = b;
    b.bind('click', w, changeWeather);
  }

  // ☁️ draw clouds

  for (var i = 0; i < clouds.length; i++)
  {
    clouds[i].offset = Math.random() * sizes.card.width;
    drawCloud(clouds[i], i);
  }

  // β˜€οΈ set initial weather

  TweenMax.set(sunburst.node, { opacity: 0 });
  changeWeather(weather[0]);
}

function onResize()
{
  // πŸ“ grab window and card sizes 

  sizes.container.width = container.width();
  sizes.container.height = container.height();
  sizes.card.width = card.width();
  sizes.card.height = card.height();
  sizes.card.offset = card.offset();

  // πŸ“ update svg sizes

  innerSVG.attr({
    width: sizes.card.width,
    height: sizes.card.height });


  outerSVG.attr({
    width: sizes.container.width,
    height: sizes.container.height });


  backSVG.attr({
    width: sizes.container.width,
    height: sizes.container.height });


  TweenMax.set(sunburst.node, { transformOrigin: "50% 50%", x: sizes.container.width / 2, y: sizes.card.height / 2 + sizes.card.offset.top });
  TweenMax.fromTo(sunburst.node, 20, { rotation: 0 }, { rotation: 360, repeat: -1, ease: Power0.easeInOut });
  // πŸƒ The leaf mask is for the leafs that float out of the
  // container, it is full window height and starts on the left
  // inline with the card

  leafMask.attr({ x: sizes.card.offset.left, y: 0, width: sizes.container.width - sizes.card.offset.left, height: sizes.container.height });
}

function drawCloud(cloud, i)
{
  /* 
  
  ☁️ We want to create a shape thats loopable but that can also
  be animated in and out. So we use Snap SVG to draw a shape
  with 4 sections. The 2 ends and 2 arches the same width as
  the card. So the final shape is about 4 x the width of the
  card.
  
  */

  var space = settings.cloudSpace * i;
  var height = space + settings.cloudHeight;
  var arch = height + settings.cloudArch + Math.random() * settings.cloudArch;
  var width = sizes.card.width;

  var points = [];
  points.push('M' + [-width, 0].join(','));
  points.push([width, 0].join(','));
  points.push('Q' + [width * 2, height / 2].join(','));
  points.push([width, height].join(','));
  points.push('Q' + [width * 0.5, arch].join(','));
  points.push([0, height].join(','));
  points.push('Q' + [width * -0.5, arch].join(','));
  points.push([-width, height].join(','));
  points.push('Q' + [-(width * 2), height / 2].join(','));
  points.push([-width, 0].join(','));

  var path = points.join(' ');
  if (!cloud.path) cloud.path = cloud.group.path();
  cloud.path.animate({
    d: path },
  0);
}

function makeRain()
{
  // πŸ’§ This is where we draw one drop of rain

  // first we set the line width of the line, we use this
  // to dictate which svg group it'll be added to and 
  // whether it'll generate a splash

  var lineWidth = Math.random() * 3;

  // β›ˆ line length is made longer for stormy weather

  var lineLength = currentWeather.type == 'thunder' ? 35 : 14;

  // Start the drop at a random point at the top but leaving 
  // a 20px margin 

  var x = Math.random() * (sizes.card.width - 40) + 20;

  // Draw the line

  var line = this['innerRainHolder' + (3 - Math.floor(lineWidth))].path('M0,0 0,' + lineLength).attr({
    fill: 'none',
    stroke: currentWeather.type == 'thunder' ? '#777' : '#0000ff',
    strokeWidth: lineWidth });


  // add the line to an array to we can keep track of how
  // many there are.

  rain.push(line);

  // Start the falling animation, calls onRainEnd when the 
  // animation finishes.

  TweenMax.fromTo(line.node, 1, { x: x, y: 0 - lineLength }, { delay: Math.random(), y: sizes.card.height, ease: Power2.easeIn, onComplete: onRainEnd, onCompleteParams: [line, lineWidth, x, currentWeather.type] });
}

function onRainEnd(line, width, x, type)
{
  // first lets get rid of the drop of rain πŸ’§

  line.remove();
  line = null;

  // We also remove it from the array

  for (var i in rain)
  {
    if (!rain[i].paper) rain.splice(i, 1);
  }

  // If there is less rain than the rainCount we should
  // make more.

  if (rain.length < settings.rainCount)
  {
    makeRain();

    // πŸ’¦ If the line width was more than 2 we also create a 
    // splash. This way it looks like the closer (bigger) 
    // drops hit the the edge of the card

    if (width > 2) makeSplash(x, type);
  }
}

function makeSplash(x, type)
{
  // πŸ’¦ The splash is a single line added to the outer svg.

  // The splashLength is how long the animated line will be
  var splashLength = type == 'thunder' ? 30 : 20;

  // splashBounce is the max height the line will curve up
  // before falling
  var splashBounce = type == 'thunder' ? 120 : 100;

  // this sets how far down the line can fall
  var splashDistance = 80;

  // because the storm rain is longer we want the animation
  // to last slighly longer so the overall speed is roughly
  // the same for both
  var speed = type == 'thunder' ? 0.7 : 0.5;

  // Set a random splash up amount based on the max splash bounce
  var splashUp = 0 - Math.random() * splashBounce;

  // Sets the end x position, and in turn defines the splash direction
  var randomX = Math.random() * splashDistance - splashDistance / 2;

  // Now we put the 3 line coordinates into an array. 

  var points = [];
  points.push('M' + 0 + ',' + 0);
  points.push('Q' + randomX + ',' + splashUp);
  points.push(randomX * 2 + ',' + splashDistance);

  // Draw the line with Snap SVG

  var splash = outerSplashHolder.path(points.join(' ')).attr({
    fill: "none",
    stroke: type == 'thunder' ? '#777' : '#0000ff',
    strokeWidth: 1 });


  // We animate the dasharray to have the line travel along the path 

  var pathLength = Snap.path.getTotalLength(splash);
  var xOffset = sizes.card.offset.left; //(sizes.container.width - sizes.card.width) / 2
  var yOffset = sizes.card.offset.top + sizes.card.height;
  splash.node.style.strokeDasharray = splashLength + ' ' + pathLength;

  // Start the splash animation, calling onSplashComplete when finished
  TweenMax.fromTo(splash.node, speed, { strokeWidth: 2, y: yOffset, x: xOffset + 20 + x, opacity: 1, strokeDashoffset: splashLength }, { strokeWidth: 0, strokeDashoffset: -pathLength, opacity: 1, onComplete: onSplashComplete, onCompleteParams: [splash], ease: SlowMo.ease.config(0.4, 0.1, false) });
}

function onSplashComplete(splash)
{
  // πŸ’¦ The splash has finished animating, we need to get rid of it

  splash.remove();
  splash = null;
}

function makeLeaf()
{
  var scale = 0.5 + Math.random() * 0.5;
  var newLeaf;

  var areaY = sizes.card.height / 2;
  var y = areaY + Math.random() * areaY;
  var endY = y - (Math.random() * (areaY * 2) - areaY);
  var x;
  var endX;
  var colors = ['#76993E', '#4A5E23', '#6D632F'];
  var color = colors[Math.floor(Math.random() * colors.length)];
  var xBezier;

  if (scale > 0.8)
  {
    newLeaf = leaf.clone().appendTo(outerLeafHolder).
    attr({
      fill: color });

    y = y + sizes.card.offset.top / 2;
    endY = endY + sizes.card.offset.top / 2;

    x = sizes.card.offset.left - 100;
    xBezier = x + (sizes.container.width - sizes.card.offset.left) / 2;
    endX = sizes.container.width + 50;
  } else

  {
    newLeaf = leaf.clone().appendTo(innerLeafHolder).
    attr({
      fill: color });

    x = -100;
    xBezier = sizes.card.width / 2;
    endX = sizes.card.width + 50;

  }

  leafs.push(newLeaf);


  var bezier = [{ x: x, y: y }, { x: xBezier, y: Math.random() * endY + endY / 3 }, { x: endX, y: endY }];
  TweenMax.fromTo(newLeaf.node, 2, { rotation: Math.random() * 180, x: x, y: y, scale: scale }, { rotation: Math.random() * 360, bezier: bezier, onComplete: onLeafEnd, onCompleteParams: [newLeaf], ease: Power0.easeIn });
}

function onLeafEnd(leaf)
{
  leaf.remove();
  leaf = null;

  for (var i in leafs)
  {
    if (!leafs[i].paper) leafs.splice(i, 1);
  }

  if (leafs.length < settings.leafCount)
  {
    makeLeaf();
  }
}

function makeSnow()
{
  var scale = 0.5 + Math.random() * 0.5;
  var newSnow;

  var x = 20 + Math.random() * (sizes.card.width - 40);
  var endX; // = x - ((Math.random() * (areaX * 2)) - areaX)
  var y = -10;
  var endY;

  if (scale > 0.8)
  {
    newSnow = outerSnowHolder.circle(0, 0, 5).
    attr({
      fill: 'white' });

    endY = sizes.container.height + 10;
    y = sizes.card.offset.top + settings.cloudHeight;
    x = x + sizes.card.offset.left;
    //xBezier = x + (sizes.container.width - sizes.card.offset.left) / 2;
    //endX = sizes.container.width + 50;
  } else

  {
    newSnow = innerSnowHolder.circle(0, 0, 5).
    attr({
      fill: 'white' });

    endY = sizes.card.height + 10;
    //x = -100;
    //xBezier = sizes.card.width / 2;
    //endX = sizes.card.width + 50;

  }

  snow.push(newSnow);


  TweenMax.fromTo(newSnow.node, 3 + Math.random() * 5, { x: x, y: y }, { y: endY, onComplete: onSnowEnd, onCompleteParams: [newSnow], ease: Power0.easeIn });
  TweenMax.fromTo(newSnow.node, 1, { scale: 0 }, { scale: scale, ease: Power1.easeInOut });
  TweenMax.to(newSnow.node, 3, { x: x + (Math.random() * 150 - 75), repeat: -1, yoyo: true, ease: Power1.easeInOut });
}

function onSnowEnd(flake)
{
  flake.remove();
  flake = null;

  for (var i in snow)
  {
    if (!snow[i].paper) snow.splice(i, 1);
  }

  if (snow.length < settings.snowCount)
  {
    makeSnow();
  }
}

function tick()
{
  tickCount++;
  var check = tickCount % settings.renewCheck;

  if (check)
  {
    if (rain.length < settings.rainCount) makeRain();
    if (leafs.length < settings.leafCount) makeLeaf();
    if (snow.length < settings.snowCount) makeSnow();
  }

  for (var i = 0; i < clouds.length; i++)
  {
    if (currentWeather.type == 'sun')
    {
      if (clouds[i].offset > -(sizes.card.width * 1.5)) clouds[i].offset += settings.windSpeed / (i + 1);
      if (clouds[i].offset > sizes.card.width * 2.5) clouds[i].offset = -(sizes.card.width * 1.5);
      clouds[i].group.transform('t' + clouds[i].offset + ',' + 0);
    } else

    {
      clouds[i].offset += settings.windSpeed / (i + 1);
      if (clouds[i].offset > sizes.card.width) clouds[i].offset = 0 + (clouds[i].offset - sizes.card.width);
      clouds[i].group.transform('t' + clouds[i].offset + ',' + 0);
    }
  }

  requestAnimationFrame(tick);
}

function reset()
{
  for (var i = 0; i < weather.length; i++)
  {
    container.removeClass(weather[i].type);
    weather[i].button.removeClass('active');
  }
}

function updateSummaryText()
{
  summary.html(currentWeather.name);
  TweenMax.fromTo(summary, 1.5, { x: 30 }, { opacity: 1, x: 0, ease: Power4.easeOut });
}

function startLightningTimer()
{
  if (lightningTimeout) clearTimeout(lightningTimeout);
  if (currentWeather.type == 'thunder')
  {
    lightningTimeout = setTimeout(lightning, Math.random() * 6000);
  }
}

function lightning()
{
  startLightningTimer();
  TweenMax.fromTo(card, 0.75, { y: -30 }, { y: 0, ease: Elastic.easeOut });

  var pathX = 30 + Math.random() * (sizes.card.width - 60);
  var yOffset = 20;
  var steps = 20;
  var points = [pathX + ',0'];
  for (var i = 0; i < steps; i++)
  {
    var x = pathX + (Math.random() * yOffset - yOffset / 2);
    var y = sizes.card.height / steps * (i + 1);
    points.push(x + ',' + y);
  }

  var strike = weatherContainer1.path('M' + points.join(' ')).
  attr({
    fill: 'none',
    stroke: 'white',
    strokeWidth: 2 + Math.random() });


  TweenMax.to(strike.node, 1, { opacity: 0, ease: Power4.easeOut, onComplete: function () {strike.remove();strike = null;} });
}

function changeWeather(weather)
{
  if (weather.data) weather = weather.data;
  reset();

  currentWeather = weather;

  TweenMax.killTweensOf(summary);
  TweenMax.to(summary, 1, { opacity: 0, x: -30, onComplete: updateSummaryText, ease: Power4.easeIn });

  container.addClass(weather.type);
  weather.button.addClass('active');

  // windSpeed

  switch (weather.type) {

    case 'wind':
      TweenMax.to(settings, 3, { windSpeed: 3, ease: Power2.easeInOut });
      break;
    case 'sun':
      TweenMax.to(settings, 3, { windSpeed: 20, ease: Power2.easeInOut });
      break;
    default:
      TweenMax.to(settings, 3, { windSpeed: 0.5, ease: Power2.easeOut });
      break;}


  // rainCount

  switch (weather.type) {

    case 'rain':
      TweenMax.to(settings, 3, { rainCount: 10, ease: Power2.easeInOut });
      break;
    case 'thunder':
      TweenMax.to(settings, 3, { rainCount: 60, ease: Power2.easeInOut });
      break;
    default:
      TweenMax.to(settings, 1, { rainCount: 0, ease: Power2.easeOut });
      break;}


  // leafCount

  switch (weather.type) {

    case 'wind':
      TweenMax.to(settings, 3, { leafCount: 5, ease: Power2.easeInOut });
      break;
    default:
      TweenMax.to(settings, 1, { leafCount: 0, ease: Power2.easeOut });
      break;}


  // snowCount

  switch (weather.type) {

    case 'snow':
      TweenMax.to(settings, 3, { snowCount: 40, ease: Power2.easeInOut });
      break;
    default:
      TweenMax.to(settings, 1, { snowCount: 0, ease: Power2.easeOut });
      break;}


  // sun position

  switch (weather.type) {

    case 'sun':
      TweenMax.to(sun.node, 4, { x: sizes.card.width / 2, y: sizes.card.height / 2, ease: Power2.easeInOut });
      TweenMax.to(sunburst.node, 4, { scale: 1, opacity: 0.8, y: sizes.card.height / 2 + sizes.card.offset.top, ease: Power2.easeInOut });
      break;
    default:
      TweenMax.to(sun.node, 2, { x: sizes.card.width / 2, y: -100, leafCount: 0, ease: Power2.easeInOut });
      TweenMax.to(sunburst.node, 2, { scale: 0.4, opacity: 0, y: sizes.container.height / 2 - 50, ease: Power2.easeInOut });
      break;}


  // lightning

  startLightningTimer();
}
    </script>
</body>
</html>

2. Weather card with hover effect

Made by Su. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title> 
<style>
html {
  font-size: 12px;
  font-family: "Oswald", "Microsoft JhengHei";
}

html, body {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

* {
  box-sizing: border-box;
  position: relative;
}

.weatherBox {
  width: 50%;
  max-width: 400px;
  border-radius: 5px;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2), 0px 25px 60px -10px rgba(0, 0, 0, 0.3);
}
.weatherBox .top {
  height: 330px;
  background: linear-gradient(20deg, #19283D 0%, #1D678F 95%);
  background-size: 100% 300%;
  animation: daylight 5s linear both;
  transition-duration: 0.5s;
}
.weatherBox .top .moon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  box-shadow: 15px -15px;
  position: absolute;
  left: 50px;
  top: 100px;
  animation: moonmove 50s both;
}
@keyframes daylight {
  0% {
    background-position: 100% 30%;
  }
  100% {
    background-position: 100% 100%;
  }
}
@keyframes moonmove {
  0% {
    transform: translateX(-15px) translateY(15px);
    box-shadow: 15px -15px 0 0 #FFD633;
  }
  100% {
    transform: translateX(30px) translateY(-30px);
    box-shadow: -30px 30px 0 0 #FFD633;
  }
}
.weatherBox .top .cloud {
  width: 100px;
  height: 36px;
  position: absolute;
  left: 270px;
  bottom: 70px;
  border-radius: 20px;
  animation: clouddrift 4s infinite linear;
  background-color: #f3f3f3;
}
.weatherBox .top .cloud:before, .weatherBox .top .cloud:after {
  content: "";
  display: block;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  position: absolute;
  background-color: #f3f3f3;
}
.weatherBox .top .cloud:before {
  left: 16px;
  top: -28px;
}
.weatherBox .top .cloud:after {
  left: 35px;
  top: -20px;
}
.weatherBox .top .cloud .rain {
  width: 2px;
  height: 10px;
  position: absolute;
  left: 45px;
  bottom: 15px;
  animation: raindrop 1s infinite linear;
  background-color: #f3f3f3;
}
.weatherBox .top .cloud .rain2 {
  left: 70px;
  bottom: 20px;
  animation-delay: 0.4s;
}
.weatherBox .top .cloud .rain3 {
  left: 30px;
  bottom: 20px;
  animation-delay: 0.7s;
}
@keyframes raindrop {
  0% {
    transform: translateY(0px);
  }
  100% {
    transform: translateY(80px);
    opacity: 0;
  }
}
@keyframes clouddrift {
  0% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0px);
  }
}
.weatherBox .top .temsvg {
  width: 100%;
}
.weatherBox .top .temsvg circle {
  fill: #f3f3f3;
}
.weatherBox .top .temsvg polyline {
  stroke: #f3f3f3;
  stroke-width: 2px;
  fill: none;
}
.weatherBox .top .temsvg text {
  fill: #f3f3f3;
  transform: translateX(-8px) translateY(25px);
  font-size: 1rem;
}
.weatherBox .top .text_area {
  display: inline-block;
  position: absolute;
  color: #f3f3f3;
  bottom: 25px;
  left: 40px;
  letter-spacing: 2px;
}
.weatherBox .top .text_area .temperature .low {
  font-size: 7rem;
}
.weatherBox .top .text_area .temperature .high {
  font-size: 2rem;
  float: right;
}
.weatherBox .top .text_area .info {
  font-size: 1.2rem;
  opacity: 0.8;
}
.weatherBox .bottom {
  height: 10px;
  display: flex;
  justify-content: center;
  transition-duration: 1s;
}
.weatherBox .bottom .dayweather {
  display: inline-block;
  width: calc(100% / 7);
  text-align: center;
  opacity: 0;
  top: 20px;
  transition: 1s linear;
}
.weatherBox .bottom .dayweather h3 {
  font-size: 1rem;
}
.weatherBox .bottom .dayweather svg {
  width: 100%;
  max-width: 40px;
  height: 40px;
}
.weatherBox .bottom .dayweather svg .sun {
  fill: rgba(255, 214, 51, 0.5);
  stroke: rgba(255, 214, 51, 0.5);
  stroke-width: 30px;
  stroke-dasharray: 5px;
}
.weatherBox .bottom .dayweather svg .rain {
  stroke: #4DACFF;
  stroke-width: 5px;
  animation: raindrop 1s infinite linear;
}
.weatherBox .bottom .dayweather svg .cloud {
  fill: #555;
}
.weatherBox .bottom .dayweather:nth-child(1) {
  transition-delay: 0.2s;
}
.weatherBox .bottom .dayweather:nth-child(2) {
  transition-delay: 0.3s;
}
.weatherBox .bottom .dayweather:nth-child(3) {
  transition-delay: 0.4s;
}
.weatherBox .bottom .dayweather:nth-child(4) {
  transition-delay: 0.5s;
}
.weatherBox .bottom .dayweather:nth-child(5) {
  transition-delay: 0.6s;
}
.weatherBox .bottom .dayweather:nth-child(6) {
  transition-delay: 0.7s;
}
.weatherBox .bottom .dayweather:nth-child(7) {
  transition-delay: 0.8s;
}
.weatherBox:hover .bottom {
  height: 100px;
}
.weatherBox:hover .dayweather {
  opacity: 1;
  top: 0;
}
</style>
</head>
<body>
  <div class="weatherBox">
  <div class="top">
    <div class="moon"></div>
    <div class="cloud">
      <div class="rain"></div>
      <div class="rain rain2"></div>
      <div class="rain rain3"></div>
    </div>
    <svg class="temsvg">
      <text x="0" y="100">26Β°</text>
      <circle cx="0" cy="100" r="3"></circle>
      <text x="70" y="80">27Β°</text>
      <circle cx="70" cy="80" r="3"></circle>
      <text x="140" y="60">28Β°</text>
      <circle cx="140" cy="60" r="3"></circle>
      <text x="210" y="70">27.8Β°</text>
      <circle cx="210" cy="70" r="3"></circle>
      <text x="280" y="100">26.3Β°</text>
      <circle cx="280" cy="100" r="3"></circle>
      <text x="350" y="110">26Β°</text>
      <circle cx="350" cy="110" r="3"></circle>
      <text x="420" y="80">25.8Β°</text>
      <circle cx="420" cy="80" r="3"></circle>
      <text x="490" y="80">30Β°</text>
      <circle cx="490" cy="90" r="3"></circle>
      <text x="560" y="560">27Β°</text>
      <circle cx="560" cy="560" r="3"></circle>
      <polyline points="0,100 70,80 140,60 210,70 280,100 350,110 420,80 490,90 560,90 630,100"></polyline>
    </svg>
    <div class="text_area">
      <div class="temperature"> 
        <div class="low">26Β°C</div>
        <div class="high">/ 29Β°C</div>
      </div>
      <div class="info">
        <div class="address">ε°εŒ—, 台灣</div>
        <div class="time">ζ˜ŸζœŸδΈ‰ 上午4:00</div>
      </div>
    </div>
  </div>
  <div class="bottom">
    <div class="dayweather">
      <h3>MON</h3>
      <svg viewbox="-50 -50 100 100">
        <circle class="sun" cx="0" cy="0" r="22"></circle>
      </svg>
    </div>
    <div class="dayweather">
      <h3>TUE</h3>
      <svg viewbox="-50 -50 100 100">
        <circle class="sun" cx="0" cy="0" r="22"></circle>
      </svg>
    </div>
    <div class="dayweather">
      <h3>WED</h3>
      <svg viewbox="-50 -50 100 100">
        <circle class="sun" cx="0" cy="0" r="22"></circle>
        <circle class="cloud" cx="-30" cy="30" r="20"></circle>
        <circle class="cloud" cx="-15" cy="30" r="20"></circle>
        <circle class="cloud" cx="0" cy="30" r="20"></circle>
        <circle class="cloud" cx="-25" cy="10" r="15"></circle>
        <circle class="cloud" cx="-7" cy="15" r="15"></circle>
      </svg>
    </div>
    <div class="dayweather">
      <h3>THU</h3>
      <svg viewbox="-50 -50 100 100">
        <circle class="sun" cx="0" cy="0" r="22"></circle>
        <circle class="cloud" cx="-30" cy="30" r="20"></circle>
        <circle class="cloud" cx="-15" cy="30" r="20"></circle>
        <circle class="cloud" cx="0" cy="30" r="20"></circle>
        <circle class="cloud" cx="-25" cy="10" r="15"></circle>
        <circle class="cloud" cx="-7" cy="15" r="15"></circle>
      </svg>
    </div>
    <div class="dayweather">
      <h3>FRI</h3>
      <svg viewbox="-50 -50 100 100">
        <circle class="sun" cx="0" cy="0" r="22"></circle>
      </svg>
    </div>
    <div class="dayweather">
      <h3>SAT</h3>
      <svg viewbox="-63 -30 100 100">
        <circle class="cloud" cx="-30" cy="30" r="20"></circle>
        <circle class="cloud" cx="-15" cy="30" r="20"></circle>
        <circle class="cloud" cx="0" cy="30" r="20"></circle>
        <circle class="cloud" cx="-25" cy="10" r="15"></circle>
        <circle class="cloud" cx="-7" cy="15" r="15"></circle>
      </svg>
    </div>
    <div class="dayweather">
      <h3>SUN</h3>
      <svg viewbox="-63 -30 100 100">
        <line class="rain" x1="-25" y1="15" x2="-25" y2="35"></line>
        <line class="rain" x1="-14" y1="5" x2="-14" y2="25"></line>
        <line class="rain" x1="-5" y1="20" x2="-5" y2="45"></line>
        <circle class="cloud" cx="-30" cy="30" r="20"></circle>
        <circle class="cloud" cx="-15" cy="30" r="20"></circle>
        <circle class="cloud" cx="0" cy="30" r="20"></circle>
        <circle class="cloud" cx="-25" cy="10" r="15"></circle>
        <circle class="cloud" cx="-7" cy="15" r="15"></circle>
      </svg>
    </div>
  </div>
</div>
  <script src='https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js'></script>
</body>
</html>

3. Weather card with animation

Made by Eli Moyal. Weather card with animations and rainy night theme. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
<style>
@import url("https://fonts.googleapis.com/css2?family=Roboto:[email protected];300&display=swap");
* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: Roboto;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin: 0;
}

main {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card {
  position: relative;
  width: 350px;
  aspect-ratio: 1;
  background: #1a2238;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 20px 25px 40px -5px rgba(0, 0, 0, 0.1);
}
.card .night {
  position: relative;
}
.card .night .rain {
  position: absolute;
  width: 350px;
  height: 280px;
  z-index: 5;
}
.card .night .rain span {
  position: absolute;
  top: -15px;
  left: 50px;
  width: 12px;
  aspect-ratio: 1;
  border-radius: 80% 0 55% 50%/55% 0 80% 50%;
  background: #7fc1f9;
  transform: rotate(-45deg);
  animation: rain 1s linear;
}
.card .night .rain span:nth-child(odd) {
  background: #395172;
}
.card .night .rain span:nth-child(1) {
  left: 248px;
  width: 2px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(2) {
  left: 336px;
  width: 4px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.5s;
}
.card .night .rain span:nth-child(3) {
  left: 78px;
  width: -1px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 1.25s;
}
.card .night .rain span:nth-child(4) {
  left: 260px;
  width: 12px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(5) {
  left: 388px;
  width: 7px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(6) {
  left: 114px;
  width: -1px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(7) {
  left: 385px;
  width: -1px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(8) {
  left: 250px;
  width: -5px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(9) {
  left: 323px;
  width: 5px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 0.5s;
}
.card .night .rain span:nth-child(10) {
  left: 50px;
  width: 7px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(11) {
  left: 365px;
  width: -7px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 0.75s;
}
.card .night .rain span:nth-child(12) {
  left: 156px;
  width: 10px;
  animation: rain linear infinite;
  animation-duration: 1.4333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(13) {
  left: 244px;
  width: -7px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.75s;
}
.card .night .rain span:nth-child(14) {
  left: 78px;
  width: 8px;
  animation: rain linear infinite;
  animation-duration: 0.7666666667s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(15) {
  left: 251px;
  width: -3px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(16) {
  left: 210px;
  width: 14px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.75s;
}
.card .night .rain span:nth-child(17) {
  left: 249px;
  width: -7px;
  animation: rain linear infinite;
  animation-duration: 0.7666666667s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(18) {
  left: 178px;
  width: 5px;
  animation: rain linear infinite;
  animation-duration: 1.4333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(19) {
  left: 118px;
  width: 9px;
  animation: rain linear infinite;
  animation-duration: 1.4333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(20) {
  left: 141px;
  width: -8px;
  animation: rain linear infinite;
  animation-duration: 0.7666666667s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(21) {
  left: 335px;
  width: 0px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(22) {
  left: 124px;
  width: 2px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(23) {
  left: 210px;
  width: -2px;
  animation: rain linear infinite;
  animation-duration: 0.7666666667s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(24) {
  left: 222px;
  width: 2px;
  animation: rain linear infinite;
  animation-duration: 0.7666666667s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(25) {
  left: 33px;
  width: 9px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(26) {
  left: 56px;
  width: 4px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 1.25s;
}
.card .night .rain span:nth-child(27) {
  left: 272px;
  width: 8px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(28) {
  left: 43px;
  width: 5px;
  animation: rain linear infinite;
  animation-duration: 1.4333333333s;
  animation-delay: 0.75s;
}
.card .night .rain span:nth-child(29) {
  left: 169px;
  width: 6px;
  animation: rain linear infinite;
  animation-duration: 1.4333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(30) {
  left: 291px;
  width: -7px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(31) {
  left: 228px;
  width: 5px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(32) {
  left: 268px;
  width: 12px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(33) {
  left: 356px;
  width: 10px;
  animation: rain linear infinite;
  animation-duration: 0.9333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(34) {
  left: 129px;
  width: -8px;
  animation: rain linear infinite;
  animation-duration: 1.4333333333s;
  animation-delay: 1.5s;
}
.card .night .rain span:nth-child(35) {
  left: 333px;
  width: 3px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.75s;
}
.card .night .rain span:nth-child(36) {
  left: 254px;
  width: 3px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(37) {
  left: 148px;
  width: 6px;
  animation: rain linear infinite;
  animation-duration: 0.7666666667s;
  animation-delay: 0.75s;
}
.card .night .rain span:nth-child(38) {
  left: 200px;
  width: -1px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 1s;
}
.card .night .rain span:nth-child(39) {
  left: 226px;
  width: -1px;
  animation: rain linear infinite;
  animation-duration: 1.1s;
  animation-delay: 0.25s;
}
.card .night .rain span:nth-child(40) {
  left: 40px;
  width: -3px;
  animation: rain linear infinite;
  animation-duration: 1.2666666667s;
  animation-delay: 0.75s;
}
.card .night .moon {
  position: absolute;
  top: 40px;
  left: 50px;
  background: #f6edbd;
  width: 60px;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 0 10px 2px #f6edbd70;
  animation: moon 1.5s;
}
.card .night .moon span {
  position: absolute;
  background: #ece1a8;
  aspect-ratio: 1;
  border-radius: 50%;
}
.card .night .moon span:nth-child(1) {
  width: 10px;
  top: 10px;
  left: 22px;
}
.card .night .moon span:nth-child(2) {
  width: 6px;
  top: 25px;
  left: 25px;
}
.card .night .moon span:nth-child(3) {
  width: 6px;
  top: 35px;
  left: 15px;
}
.card .night .moon span:nth-child(4) {
  width: 12px;
  top: 12px;
  left: 0px;
}
.card .night .moon span:nth-child(5) {
  width: 12px;
  top: 50px;
  left: 10px;
}
.card .night .moon span:nth-child(6) {
  width: 5px;
  top: 17px;
  left: 40px;
}
.card .night .moon span:nth-child(7) {
  width: 8px;
  top: 35px;
  left: 45px;
}
.card .night .moon span:nth-child(8) {
  width: 4px;
  top: 35px;
  left: 35px;
}
.card .night .moon span:nth-child(9) {
  width: 7px;
  top: 45px;
  left: 30px;
}
.card .night .moon span:nth-child(9) {
  width: 7px;
  top: 20px;
  left: 53px;
}
.card .night .moon span:nth-child(10) {
  width: 7px;
  top: 45px;
  left: 33px;
}
.card .night .clouds {
  position: absolute;
  top: 170px;
  width: 100%;
  height: 110px;
}
.card .night .clouds span {
  position: absolute;
  width: 300px;
  aspect-ratio: 1;
  background: #303c5d;
  border-radius: 50%;
}
.card .night .clouds span:nth-child(1) {
  top: 30px;
  left: 50px;
  z-index: 1;
}
.card .night .clouds span:nth-child(2) {
  top: 60px;
  left: -100px;
  z-index: 1;
}
.card .night .clouds span:nth-child(3) {
  top: 45px;
  left: 250px;
  z-index: 1;
}
.card .night .clouds span:nth-child(4) {
  background: #26314f;
  top: 10px;
  left: 170px;
}
.card .night .clouds span:nth-child(5) {
  background: #26314f;
  top: 20px;
  left: -50px;
}
.card .info {
  position: absolute;
  padding: 10px;
  bottom: 0;
  width: 100%;
  height: 20%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 5;
}
.card .info span {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 5px;
  justify-content: center;
  color: #000a;
}
.card .info span p {
  font-size: 14px;
}
.card .info span:nth-child(1) {
  width: 80px;
  align-items: center;
  font-size: 24px;
}
.card .info span:nth-child(1) h2 {
  font-weight: 300;
}
.card .info span:nth-child(3) {
  align-items: flex-end;
}

@keyframes rain {
  0% {
    transform: translate(0%, 0%) rotate(-30deg) scale(1, 1);
  }
  80% {
    transform: translate(-75px, 290px) rotate(-30deg) scale(1, 1);
  }
  100% {
    transform: translate(-80px, 300px) rotate(-30deg) scale(2, 3);
  }
}
@keyframes moon {
  0% {
    transform: translateY(300px);
  }
  100% {
    transform: translateY(0px);
  }
}
</style>
</head>
<body>
  <main>
  <div class="card">
    <div class="night">
      <div class="rain">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>

      </div>
      <div class="moon">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
      </div>
      <div class="clouds">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
      </div>
    </div>
    <div class="info">
      <span>
        <h2>12Β°</h2>
      </span>
      <span>
        <p>Wind: E 7 Km/h</p>
        <p>Humidity: 87%</p>
      </span>
      <span>
        <p>TUE 21Β°/9Β°</p>
        <p>WED 23Β°/10Β°</p>
      </span>
    </div>
  </div>
</main>
</body>
</html>

4. Simple Weather Cards

Made by Rashid. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
  <link rel='stylesheet' href='https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css'>
  
<style>
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:[email protected]&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lora&family=Playfair+Display&display=swap');
* {
    font-size: 16px;
}
body {
    line-height: 1.5rem;
    background: #ffd954;
}
.item h2 {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 2.5rem;
}
.design {
    content: '';
    width: 0; 
    height: 0; 
    border-top: 2px solid transparent;
    border-bottom: 2px solid transparent;
    opacity: 1;
}
.left {
    margin-right: 2rem;
    border-right: 230px solid #000;
}
.right {
    margin-left: 2rem;
    border-left: 230px solid #000;
}
.weather {
    position: relative;
    transition: 1s all cubic-bezier(0.68, -0.55, 0.27, 1.55);
}
.cards {
    margin: 15px;
    background: #fff;
    border-radius: 30px;
    overflow: hidden;
}
.weather h3 {
    position: absolute;
    top: -1%;
    left: 50%;
    transform: translate(-50%);
}
.imgBox {
    width: 100%;
    height: 130px;
}
.degree {
    font-size: 1.7rem;
    font-family: 'Lora', serif;
}
@media only screen and (min-width: 992px) {
    .weather:hover{
        transform: translate(0, -15%);
    }
}
</style>
</head>
<body>
  <div class="container">
        <div class="item my-5">
            <div class="site-header  d-flex justify-content-center align-items-center">
                <div class="left design"></div>
                <h2 class="my-5 text-uppercase text-center">weather card</h2>
                <div class="right design"></div>
            </div>
            <!-- /.site-header -->
            <div class="row">
                <div class="weather col-lg-3 col-sm-6">
                    <h3 class="">01</h3>
                    <div class="cards">
                        <div class="imgBox d-flex justify-content-center">
                            <img class="img-fluid h-100" src="https://i.ibb.co/cQkkMLs/windy2.png" alt="windy">
                        </div>
                        <!-- /.imgBox -->
                        <div class="textBox text-center">
                            <h4 class="">wind<b class="h4 text-warning">y</b></h4>
                            <div class="my-4  d-flex justify-content-center align-items-center">
                                <p class="degree m-0 d-inline-block ms-2">10&#176;C</p>
                            </div>
                            <div class="mb-5">
                                <p class="m-0 fw-bold d-inline-block">Autumn</p>
                                <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-volume-up text-warning" viewBox="0 0 16 16">
                                    <path d="M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z"/>
                                    <path d="M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z"/>
                                    <path d="M10.025 8a4.486 4.486 0 0 1-1.318 3.182L8 10.475A3.489 3.489 0 0 0 9.025 8c0-.966-.392-1.841-1.025-2.475l.707-.707A4.486 4.486 0 0 1 10.025 8zM7 4a.5.5 0 0 0-.812-.39L3.825 5.5H1.5A.5.5 0 0 0 1 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 7 12V4zM4.312 6.39L6 5.04v5.92L4.312 9.61A.5.5 0 0 0 4 9.5H2v-3h2a.5.5 0 0 0 .312-.11z"/>
                                </svg>
                            </div>
                        </div>
                        <!-- /.textBox -->
                    </div>
                    <!-- /.cards -->
                </div>
                <!-- /.col-lg-3 -->
                <div class="weather col-lg-3 col-sm-6">
                    <h3 class="">02</h3>
                    <div class="cards">
                        <div class="imgBox d-flex justify-content-center">
                            <img class="img-fluid h-100" src="https://i.ibb.co/YTrYGpb/cloudy.png" alt="cloudy">
                        </div>
                        <!-- /.imgBox -->
                        <div class="textBox text-center">
                            <h4 class="">cloud<b class="h4 text-warning">y</b></h4>
                            <div class="my-4 d-flex justify-content-center align-items-center">
                                <p class="degree m-0 d-inline-block ms-2">0&#176;C</p>
                            </div>
                            <div class="mb-5">
                                <p class="m-0 fw-bold d-inline-block">Winter</p>
                                <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-volume-up text-warning" viewBox="0 0 16 16">
                                    <path d="M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z"/>
                                    <path d="M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z"/>
                                    <path d="M10.025 8a4.486 4.486 0 0 1-1.318 3.182L8 10.475A3.489 3.489 0 0 0 9.025 8c0-.966-.392-1.841-1.025-2.475l.707-.707A4.486 4.486 0 0 1 10.025 8zM7 4a.5.5 0 0 0-.812-.39L3.825 5.5H1.5A.5.5 0 0 0 1 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 7 12V4zM4.312 6.39L6 5.04v5.92L4.312 9.61A.5.5 0 0 0 4 9.5H2v-3h2a.5.5 0 0 0 .312-.11z"/>
                                </svg>
                            </div>
                        </div>
                        <!-- /.textBox -->
                    </div>
                    <!-- /.cards -->
                </div>
                <!-- /.col-lg-3 -->
                <div class="weather col-lg-3 col-sm-6">
                    <h3 class="">03</h3>
                    <div class="cards">
                        <div class="imgBox d-flex justify-content-center">
                            <img class="img-fluid h-100" src="https://i.ibb.co/hRjyXPL/lightning.png" alt="lightning">
                        </div>
                        <!-- /.imgBox -->
                        <div class="textBox text-center">
                            <h4 class="">light<b class="h4 text-warning">ing</b></h4>
                            <div class="my-4 d-flex justify-content-center align-items-center">
                                <p class="degree m-0 d-inline-block ms-2">15&#176;C</p>
                            </div>
                            <div class="mb-5">
                                <p class="m-0 fw-bold d-inline-block">Spring</p>
                                <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-volume-up text-warning" viewBox="0 0 16 16">
                                    <path d="M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z"/>
                                    <path d="M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z"/>
                                    <path d="M10.025 8a4.486 4.486 0 0 1-1.318 3.182L8 10.475A3.489 3.489 0 0 0 9.025 8c0-.966-.392-1.841-1.025-2.475l.707-.707A4.486 4.486 0 0 1 10.025 8zM7 4a.5.5 0 0 0-.812-.39L3.825 5.5H1.5A.5.5 0 0 0 1 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 7 12V4zM4.312 6.39L6 5.04v5.92L4.312 9.61A.5.5 0 0 0 4 9.5H2v-3h2a.5.5 0 0 0 .312-.11z"/>
                                </svg>
                            </div>
                        </div>
                        <!-- /.textBox -->
                    </div>
                    <!-- /.cards -->
                </div>
                <!-- /.col-lg-3 -->
                <div class="weather col-lg-3 col-sm-6">
                    <h3 class="">04</h3>
                    <div class="cards">
                        <div class="imgBox d-flex justify-content-center">
                            <img class="img-fluid h-100" src="https://i.ibb.co/KDhkKfY/sun.png" alt="sun">
                        </div>
                        <!-- /.imgBox -->
                        <div class="textBox text-center">
                            <h4 class="">su<b class="h4 text-warning">n</b></h4>
                            <div class="my-4 d-flex justify-content-center align-items-center">
                                <p class="degree m-0 d-inline-block ms-2">30&#176;C</p>
                            </div>
                            <div class="mb-5">
                                <p class="m-0 fw-bold d-inline-block">Summer</p>
                                <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" class="bi bi-volume-up text-warning" viewBox="0 0 16 16">
                                    <path d="M11.536 14.01A8.473 8.473 0 0 0 14.026 8a8.473 8.473 0 0 0-2.49-6.01l-.708.707A7.476 7.476 0 0 1 13.025 8c0 2.071-.84 3.946-2.197 5.303l.708.707z"/>
                                    <path d="M10.121 12.596A6.48 6.48 0 0 0 12.025 8a6.48 6.48 0 0 0-1.904-4.596l-.707.707A5.483 5.483 0 0 1 11.025 8a5.483 5.483 0 0 1-1.61 3.89l.706.706z"/>
                                    <path d="M10.025 8a4.486 4.486 0 0 1-1.318 3.182L8 10.475A3.489 3.489 0 0 0 9.025 8c0-.966-.392-1.841-1.025-2.475l.707-.707A4.486 4.486 0 0 1 10.025 8zM7 4a.5.5 0 0 0-.812-.39L3.825 5.5H1.5A.5.5 0 0 0 1 6v4a.5.5 0 0 0 .5.5h2.325l2.363 1.89A.5.5 0 0 0 7 12V4zM4.312 6.39L6 5.04v5.92L4.312 9.61A.5.5 0 0 0 4 9.5H2v-3h2a.5.5 0 0 0 .312-.11z"/>
                                </svg>
                            </div>
                        </div>
                        <!-- /.textBox -->
                    </div>
                    <!-- /.cards -->
                </div>
                <!-- /.col-lg-3 -->
            </div>
        </div>
        <!-- /.item -->
    </div>
</body>
</html>

5. Simple Weather Card

Made by Colin Carter. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
  <link rel='stylesheet' href='https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.css'>
  
<style>
body {
  background: #211F2A;
  font-family: helvetica;
}

.card {
  background: #363345;
  margin: 0 auto;
  margin-top: 20vh;
  max-width: 30vw;
  text-align: center;
  border-radius: 5px;
  box-shadow: 0px 0px 35px rgba(0, 0, 0, 0.3);
}

.main {
  padding: 25px;
}

.gradient {
  font-size: 15vw;
  background: -webkit-linear-gradient(right, #7168FB, #db28fb);
  background: linear-gradient(right, #7168FB, #db28fb);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.temp {
  top: 55vh;
  right: 35vw;
  font-weight: 900;
  font-size: 8vw;
  color: white;
  padding: 20px;
}

.city {
  font-size: 3.5vw;
  font-weight: 600;
  color: white;
}

.country {
  font-size: 1.5vw;
  font-weight: 300;
  color: grey;
  padding-left: 20px;
}

hr {
  border: none;
  background: coral;
  height: 5px;
  width: 33%;
  float: right;
}

.date {
  color: white;
  font-size: 1.2vw;
}
</style>
</head>
<body>
  <body> 
<div class="card">
  <div class="main">
    <div class="icon">
        <i class="fa fa-cloud gradient"></i>
    </div>
    <div class="temp">
      12Β°C
    </div>
    <div class="info">
      <span class="city">Basel,</span><span class="country">Switzerland</span>
      <br>
      <hr>
      <span class="date">7. November 2017 | 13:50</span>
    </div>
  </div>
 </div>   
</body>
</body>
</html>

6. Weather card with Day/Night Mode

Made by Ashish Mehra. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
  <link href="https://fonts.googleapis.com/css?family=Nunito+Sans|Open+Sans+Condensed:300" rel="stylesheet">
 
<style>
/*
Colors Variables */
/*
Width and Height of a card */
/*
Fonts map */
/*
Mixins for BEM,
Element width and height,
and flexBox*/
/*
Card base Styles */
body {
  font-family: 'Open Sans Condensed', sans-serif;
  background: #fff;
}

label {
  text-align: center;
  display: block;
  background: #eea309;
  color: #fff;
  padding: 15px;
  font-family: 'Nunito Sans', sans-serif;
  cursor: pointer;
}
label:hover {
  opacity: 0.7;
}
label:last-child {
  background: #56CCF2;
}

input {
  display: none;
}
input:checked ~ label {
  display: none;
}
input:checked ~ .show {
  display: block;
}
input:checked ~ .weather-card__header {
  animation: daytonight 4s cubic-bezier(0.09, 0.76, 0.63, 1.6) forwards;
}
input:checked ~ .weather-card__header .weather-card__clear .sun {
  animation: suntomoon 3s linear forwards;
}
input:checked ~ .weather-card__header .weather-card__clear .stars span {
  animation: stars 10s ease-in 4s infinite;
}
input:checked ~ .weather-card__header .weather-card__clear .grassland {
  animation: darkGrass 1s linear 2s forwards;
}

/*
Weather Card Styles*/
.weather-card {
  width: 300px;
  height: 550px;
  background: #fff;
  margin: 100px auto 25px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
}
.weather-card__header {
  position: relative;
  width: 300px;
  height: 375px;
  background: #56CCF2;
  animation: nighttoday 10s cubic-bezier(0.09, 0.76, 0.63, 1.6) forwards;
}
.weather-card__header span {
  color: #fff;
  display: inline-block;
  margin: 25px 15px 0;
  font-size: 22px;
  letter-spacing: 1px;
}
.weather-card__header .temperature,
.weather-card__header .status {
  display: block;
  font-size: 35px;
  font-weight: 800;
  margin-top: 0;
}
.weather-card__header .status {
  font-size: 20px;
  font-weight: 400;
}
.weather-card__detail {
  width: 300px;
  height: auto;
  background: #fff;
  box-sizing: border-box;
  padding: 5px;
}
.weather-card__detail .forecast {
  margin: 10px 5px;
  padding: 10px;
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row;
  border-bottom: 1px solid #f2f2f2;
  transition: 300ms ease-in;
}
.weather-card__detail .forecast span {
  flex: 1;
  font-family: 'Nunito Sans', sans-serif;
}
.weather-card__detail .forecast span:nth-child(2) {
  text-align: center;
}
.weather-card__detail .forecast span:nth-child(3) {
  text-align: right;
}
.weather-card__detail .forecast:hover {
  transform: translateX(5px);
}

.weather-card__clear {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  overflow: hidden;
}
.weather-card__clear .grassland {
  position: absolute;
  width: 600px;
  height: 110px;
  background: #a8e063;
  bottom: 0;
  transform: skew(-72deg);
  border-top-left-radius: 100px;
  border: 2px solid transparent;
  border-top-color: #69a320;
  border-bottom: none;
  z-index: 999;
  animation: lightGrass 500ms linear forwards;
}
.weather-card__clear .grassland:last-child {
  bottom: 40px;
  left: -300px;
  border-top-right-radius: 100px;
  transform: skew(72deg);
  z-index: 998;
}
.weather-card__clear .sun {
  position: absolute;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  right: 25px;
  top: 25px;
  z-index: 99;
  background: #f8c04c;
  box-shadow: 0 0 25px 10px #f8c04c, inset 5px -45px 100px -20px #f7b733, inset 5px -45px 40px -20px rgba(0, 0, 0, 0.2);
  animation: moontosun 500ms linear forwards;
}
.weather-card__clear .stars {
  position: absolute;
  width: 100%;
  height: 100%;
}
.weather-card__clear .stars span:nth-child(3n+3) {
  width: 2px;
  height: 2px;
  background: #fff;
  opacity: 0;
}

@keyframes darkGrass {
  0% {
    background: #a8e063;
  }
  50% {
    background: #69a320;
  }
  100% {
    background: #4d7918;
    box-shadow: inset 0 2px 25px 10px rgba(255, 255, 255, 0.5);
  }
}
@keyframes lightGrass {
  from {
    background: #4d7918;
    box-shadow: inset 0 2px 25px 10px rgba(255, 255, 255, 0.5);
  }
  to {
    background: #a8e063;
  }
}
@keyframes stars {
  from {
    transform: translateY(20px);
    opacity: 1;
  }
  to {
    transform: translateY(100px);
    opacity: 0.7;
  }
}
@keyframes daytonight {
  0% {
    background: #56CCF2;
  }
  50% {
    background: #f46b45;
  }
  100% {
    background: black;
  }
}
@keyframes nighttoday {
  from {
    background: black;
  }
  to {
    background: #56CCF2;
  }
}
@keyframes moontosun {
  0% {
    transform: translateY(25px);
    opacity: 0;
  }
  25% {
    transform: translateY(100px);
  }
  50% {
    transform: translateY(250px);
  }
  75% {
    transform: translateY(100px);
    background: #f8c04c;
    box-shadow: 0 0 25px 10px #f8c04c, inset 5px -45px 100px -20px #f7b733, inset 5px -45px 40px -20px rgba(0, 0, 0, 0.2);
  }
  100% {
    transform: translateY(25px);
    background: #f8c04c;
    box-shadow: 0 0 25px 10px #f8c04c, inset 5px -45px 100px -20px #f7b733, inset 5px -45px 40px -20px rgba(0, 0, 0, 0.2);
  }
}
@keyframes suntomoon {
  0% {
    transform: translateY(25px);
  }
  25% {
    transform: translateY(100px);
    background: #f46b45;
  }
  50% {
    transform: translateY(250px);
  }
  75% {
    transform: translateY(100px);
    background: #fff;
    box-shadow: 0 0 20px #fff;
  }
  100% {
    transform: translateY(25px);
    background: #fff;
    box-shadow: 0 0 25px #fff;
  }
}
</style>
</head>
<body>
  <div class="weather-card">
  <!-- Checkbox for night animation  -->
  <input type="checkbox" id="nightMode">
  <div class="weather-card__header">
    <span class="city">Nainital</span>
    <span class="temperature">27Β°</span>
    <span class="status">Clear</span>
    <div class="weather-card__clear">
       <div class="sun"></div>
       <div class="stars">
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
         <span></span>
       </div>
       <div class="grassland"></div>
       <div class="grassland"></div>
    </div>
  </div>
  <div class="weather-card__detail">
    <div class="forecast"><span>Today</span><span>Clear</span><span>32Β°</span></div>
    <div class="forecast"><span>Tomorrow</span><span>Rainy</span><span>12Β°</span></div>
  </div>
  
      <label for="nightMode">Switch to night mode</label>
      <label for="nightMode" class="show">Switch to morning mode</label>

</div>
</body>
</html>

7. Basic Weather Card

Made by Gabriel Castro. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title> 
<style>
@import url("https://fonts.googleapis.com/css2?family=Roboto:[email protected];400;700&display=swap");
body {
  display: flex;
  justify-content: center;
  margin-top: 40px;
  background: #e5e5e5;
  color: #353535;
  font-family: "Roboto", sans-serif;
}

h1, h2, p {
  margin: 0;
  padding: 0;
}

article {
  width: 300px;
  height: 400px;
  border-radius: 8px;
  background: white;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
}
article header {
  position: relative;
}
article header span {
  position: absolute;
  top: 16px;
  left: 16px;
}
article header span h1 {
  font-size: 24px;
  background: white;
  width: fit-content;
}
article header span h2 {
  font-size: 16px;
  font-weight: 400;
  background: white;
  width: fit-content;
}
article .content {
  padding: 8px 16px;
  display: flex;
  flex: 1;
  justify-content: space-between;
}
article .content .temp-container .temp {
  font-size: 48px;
  font-weight: 100;
}
article .content .temp-container .d-temp {
  font-size: 22px;
  font-weight: 100;
  color: #a1a1a1;
}
article .content .w-icon p {
  font-size: 8px;
  text-align: center;
}
article footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding: 16px;
}
article footer .date {
  font-size: 10px;
  font-weight: 100;
}
article footer .city {
  font-size: 14px;
  font-weight: 100;
}
</style>
</head>
<body>
  <article>
  <header>
    <span>
      <h1>Hi Gabriel!</h1>
      <h2>It's going to snow today!</h2>
    </span>
    <svg width="300" height="221" viewBox="0 0 300 221" fill="none" xmlns="http://www.w3.org/2000/svg">
      <g clip-path="url(#clip0)">
      <path d="M213.564 164.303L211.762 170.693H219.152C218.096 168.168 217.827 165.771 218.741 163.566L213.564 164.303Z" fill="#FFB8B8"/>
      <path d="M300 220.199C300 220.298 299.997 220.401 299.991 220.501H0.151459C0.145389 220.401 0.142365 220.298 0.142365 220.199C0.142365 204.997 67.2681 192.675 150.071 192.675C232.874 192.675 300 204.997 300 220.199Z" fill="#3F3D56"/>
      <path d="M250.932 206.266C260.133 206.266 267.591 198.807 267.591 189.607C267.591 180.407 260.133 172.948 250.932 172.948C241.732 172.948 234.274 180.407 234.274 189.607C234.274 198.807 241.732 206.266 250.932 206.266Z" fill="#D0CDE1"/>
      <path d="M251.841 182.035C258.03 182.035 263.048 180.001 263.048 177.492C263.048 174.982 258.03 172.948 251.841 172.948C245.652 172.948 240.634 174.982 240.634 177.492C240.634 180.001 245.652 182.035 251.841 182.035Z" fill="#6C63FF"/>
      <path d="M252.447 177.794C258.302 177.794 263.048 173.048 263.048 167.193C263.048 161.339 258.302 156.592 252.447 156.592C246.592 156.592 241.846 161.339 241.846 167.193C241.846 173.048 246.592 177.794 252.447 177.794Z" fill="#D0CDE1"/>
      <path d="M249.222 165.18C250.118 165.18 250.844 164.454 250.844 163.559C250.844 162.663 250.118 161.937 249.222 161.937C248.327 161.937 247.601 162.663 247.601 163.559C247.601 164.454 248.327 165.18 249.222 165.18Z" fill="#575A89"/>
      <path d="M254.763 165.18C255.658 165.18 256.384 164.454 256.384 163.559C256.384 162.663 255.658 161.937 254.763 161.937C253.867 161.937 253.141 162.663 253.141 163.559C253.141 164.454 253.867 165.18 254.763 165.18Z" fill="#575A89"/>
      <path d="M251.538 165.679L251.096 170.99C251.092 171.039 251.106 171.087 251.136 171.126C251.165 171.165 251.208 171.192 251.257 171.201C251.305 171.21 251.355 171.2 251.396 171.175C251.438 171.149 251.469 171.109 251.483 171.061L253.053 165.679L251.538 165.679Z" fill="#FF6584"/>
      <path d="M242.001 211.46L240.073 213.387L229.428 200.814L229.686 199.144L242.001 211.46Z" fill="#575A89"/>
      <path d="M233.668 205.357V206.569L223.975 205.963L223.067 205.357H233.668Z" fill="#575A89"/>
      <path d="M241.24 187.79C242.746 187.79 243.966 186.434 243.966 184.761C243.966 183.088 242.746 181.732 241.24 181.732C239.734 181.732 238.514 183.088 238.514 184.761C238.514 186.434 239.734 187.79 241.24 187.79Z" fill="#D0CDE1"/>
      <path d="M264.104 184.503L266.032 186.43L276.678 173.857L276.42 172.187L264.104 184.503Z" fill="#575A89"/>
      <path d="M269.711 179.915V181.126L279.404 180.52L280.312 179.915H269.711Z" fill="#575A89"/>
      <path d="M264.865 187.79C266.371 187.79 267.591 186.434 267.591 184.761C267.591 183.088 266.371 181.732 264.865 181.732C263.36 181.732 262.139 183.088 262.139 184.761C262.139 186.434 263.36 187.79 264.865 187.79Z" fill="#D0CDE1"/>
      <path d="M251.841 187.184C252.51 187.184 253.053 186.641 253.053 185.972C253.053 185.303 252.51 184.761 251.841 184.761C251.172 184.761 250.63 185.303 250.63 185.972C250.63 186.641 251.172 187.184 251.841 187.184Z" fill="#575A89"/>
      <path d="M251.841 191.121C252.51 191.121 253.053 190.579 253.053 189.91C253.053 189.241 252.51 188.698 251.841 188.698C251.172 188.698 250.63 189.241 250.63 189.91C250.63 190.579 251.172 191.121 251.841 191.121Z" fill="#575A89"/>
      <path d="M251.841 195.059C252.51 195.059 253.053 194.516 253.053 193.847C253.053 193.178 252.51 192.636 251.841 192.636C251.172 192.636 250.63 193.178 250.63 193.847C250.63 194.516 251.172 195.059 251.841 195.059Z" fill="#575A89"/>
      <path d="M199.479 196.874C199.542 195.531 199.178 194.202 198.438 193.079C197.699 191.957 196.623 191.097 195.364 190.625C194.105 190.152 192.729 190.091 191.434 190.449C190.138 190.808 188.99 191.569 188.153 192.621C187.478 191.591 186.518 190.778 185.389 190.282C185.753 188.905 185.644 187.446 185.08 186.138C184.515 184.83 183.528 183.75 182.277 183.07C181.025 182.39 179.582 182.15 178.177 182.388C176.773 182.626 175.489 183.329 174.532 184.384C173.03 182.895 171.228 181.745 169.246 181.011C169.49 179.464 169.155 177.881 168.304 176.566C167.453 175.251 166.147 174.296 164.636 173.885C163.124 173.473 161.514 173.634 160.114 174.337C158.714 175.04 157.623 176.235 157.05 177.693C155.929 176.913 154.586 176.515 153.221 176.558C151.856 176.601 150.541 177.084 149.472 177.933C148.402 178.782 147.635 179.954 147.284 181.274C146.933 182.593 147.016 183.991 147.522 185.26C146.772 185.536 146.081 185.951 145.485 186.483C144.03 185.947 142.429 185.962 140.984 186.524C139.539 187.086 138.35 188.157 137.639 189.535C137.064 188.896 136.365 188.38 135.584 188.019C135.603 187.864 135.622 187.708 135.63 187.549C135.671 186.662 135.527 185.776 135.206 184.948C134.885 184.12 134.394 183.369 133.764 182.742C133.135 182.116 132.382 181.628 131.552 181.31C130.723 180.992 129.837 180.852 128.95 180.897C128.063 180.943 127.195 181.174 126.403 181.575C125.611 181.976 124.911 182.538 124.35 183.226C123.788 183.914 123.376 184.712 123.142 185.568C122.907 186.425 122.854 187.321 122.987 188.199C121.546 188.591 120.292 189.482 119.448 190.714C118.604 191.945 118.225 193.437 118.378 194.922C111.241 195.131 104.357 195.466 97.7781 195.918C96.9681 193.082 95.3316 190.552 93.0774 188.65C90.8233 186.748 88.0537 185.561 85.1219 185.239C82.1902 184.918 79.2292 185.478 76.6167 186.846C74.0043 188.215 71.8588 190.331 70.454 192.924C69.3525 192.091 68.0093 191.639 66.6278 191.636C65.2463 191.634 63.9017 192.082 62.7974 192.912C61.693 193.742 60.8891 194.909 60.5073 196.237C60.1254 197.564 60.1864 198.98 60.681 200.27C60.3931 200.322 60.1064 200.374 59.8209 200.426C59.831 200.321 59.8466 200.217 59.8516 200.11C59.8913 199.275 59.766 198.44 59.4829 197.654C59.1997 196.867 58.7644 196.144 58.2016 195.526C57.6389 194.908 56.9598 194.407 56.2032 194.051C55.4467 193.696 54.6274 193.493 53.7924 193.454C52.9574 193.415 52.1229 193.542 51.3367 193.826C50.5505 194.11 49.828 194.546 49.2105 195.11C48.5931 195.673 48.0927 196.353 47.7381 197.11C47.3835 197.867 47.1816 198.686 47.144 199.521C47.1409 199.587 47.1458 199.652 47.1448 199.717C46.5633 199.496 45.9378 199.417 45.3196 199.484C44.7014 199.552 44.108 199.766 43.5882 200.107C43.0684 200.449 42.637 200.908 42.3293 201.449C42.0216 201.989 41.8465 202.595 41.8183 203.216C41.7951 203.715 199.467 197.121 199.479 196.874Z" fill="#D0CDE1"/>
      <path d="M2.25366 102.008C2.26235 101.98 2.27152 101.952 2.28025 101.924C2.27647 101.936 2.27174 101.948 2.26805 101.96L2.25366 102.008Z" fill="#2F2E41"/>
      <path d="M147.111 184.581L169.546 151.219L147.157 188.17L147.204 191.924C145.566 191.936 143.944 191.909 142.339 191.842L143.451 143.586L143.421 143.214L143.462 143.142L143.568 138.582L119 102.912L143.539 135.169L143.626 136.133L144.467 99.6742L123.247 62.6926L144.527 93.2693L144.305 17.7354L144.306 17.484L144.313 17.7312L145.721 77.2621L165.061 53.0807L145.785 82.3906L146.207 115.002L164.003 83.1745L146.272 119.797L146.507 137.931L172.388 93.5948L146.586 144.257L147.111 184.581Z" fill="#3F3D56"/>
      <path d="M142.196 92.0775C143.534 92.0775 144.619 90.9927 144.619 89.6544C144.619 88.3162 143.534 87.2313 142.196 87.2313C140.858 87.2313 139.773 88.3162 139.773 89.6544C139.773 90.9927 140.858 92.0775 142.196 92.0775Z" fill="#D0CDE1"/>
      <path d="M157.946 129.03C159.284 129.03 160.369 127.945 160.369 126.607C160.369 125.268 159.284 124.184 157.946 124.184C156.608 124.184 155.523 125.268 155.523 126.607C155.523 127.945 156.608 129.03 157.946 129.03Z" fill="#D0CDE1"/>
      <path d="M137.35 137.208C138.688 137.208 139.773 136.123 139.773 134.785C139.773 133.446 138.688 132.361 137.35 132.361C136.012 132.361 134.927 133.446 134.927 134.785C134.927 136.123 136.012 137.208 137.35 137.208Z" fill="#D0CDE1"/>
      <path d="M129.475 99.3468C130.813 99.3468 131.898 98.2619 131.898 96.9237C131.898 95.5855 130.813 94.5006 129.475 94.5006C128.137 94.5006 127.052 95.5855 127.052 96.9237C127.052 98.2619 128.137 99.3468 129.475 99.3468Z" fill="#D0CDE1"/>
      <path d="M145.831 92.0775C145.831 91.6479 145.716 91.2261 145.5 90.8553C145.283 90.4846 144.971 90.1781 144.597 89.9675C144.654 89.5316 144.591 89.0884 144.415 88.6854C144.239 88.2824 143.957 87.9349 143.599 87.6801C143.241 87.4252 142.82 87.2727 142.382 87.2388C141.943 87.2049 141.504 87.291 141.111 87.4878C140.718 87.6846 140.386 87.9846 140.15 88.3558C139.915 88.727 139.784 89.1553 139.774 89.5948C139.763 90.0343 139.872 90.4685 140.089 90.8507C140.307 91.2328 140.624 91.5487 141.007 91.7643C140.964 92.0781 140.983 92.3973 141.065 92.7033C141.147 93.0093 141.289 93.2958 141.483 93.5459C141.315 93.9379 141.252 94.3675 141.303 94.7913C141.353 95.2152 141.514 95.6182 141.77 95.9596C142.027 96.301 142.368 96.5688 142.761 96.7358C143.154 96.9028 143.584 96.9631 144.007 96.9107C144.431 96.8583 144.833 96.6949 145.173 96.4372C145.514 96.1795 145.78 95.8365 145.945 95.4429C146.11 95.0494 146.168 94.6192 146.114 94.1959C146.059 93.7726 145.894 93.3711 145.635 93.0321C145.764 92.7306 145.831 92.4057 145.831 92.0775V92.0775Z" fill="#D0CDE1"/>
      <path d="M150.374 67.5438C149.731 67.5438 149.115 67.7991 148.661 68.2535C148.206 68.7079 147.951 69.3242 147.951 69.9669C147.412 69.9672 146.889 70.1472 146.464 70.4785C146.039 70.8097 145.736 71.2732 145.604 71.7956C145.162 71.8367 144.74 71.9986 144.383 72.2635C144.027 72.5285 143.75 72.8863 143.583 73.2978C143.417 73.7094 143.366 74.1589 143.438 74.5972C143.509 75.0355 143.699 75.4458 143.988 75.7831C144.277 76.1205 144.653 76.372 145.075 76.5102C145.497 76.6483 145.949 76.6678 146.381 76.5665C146.814 76.4652 147.21 76.247 147.527 75.9357C147.843 75.6245 148.068 75.2322 148.177 74.8016C148.778 74.7454 149.336 74.467 149.742 74.0209C150.149 73.5749 150.374 72.9933 150.374 72.39C151.017 72.39 151.633 72.1347 152.087 71.6802C152.542 71.2258 152.797 70.6095 152.797 69.9669C152.797 69.3242 152.542 68.7079 152.087 68.2535C151.633 67.7991 151.017 67.5438 150.374 67.5438V67.5438Z" fill="#D0CDE1"/>
      <path d="M99.1863 108.433C100.19 108.433 101.004 107.62 101.004 106.616C101.004 105.612 100.19 104.799 99.1863 104.799C98.1826 104.799 97.3689 105.612 97.3689 106.616C97.3689 107.62 98.1826 108.433 99.1863 108.433Z" fill="#D0CDE1"/>
      <path d="M118.874 130.241C119.878 130.241 120.691 129.428 120.691 128.424C120.691 127.42 119.878 126.607 118.874 126.607C117.87 126.607 117.057 127.42 117.057 128.424C117.057 129.428 117.87 130.241 118.874 130.241Z" fill="#D0CDE1"/>
      <path d="M207.317 46.9474C208.655 46.9474 209.74 45.8626 209.74 44.5243C209.74 43.1861 208.655 42.1012 207.317 42.1012C205.978 42.1012 204.894 43.1861 204.894 44.5243C204.894 45.8626 205.978 46.9474 207.317 46.9474Z" fill="#D0CDE1"/>
      <path d="M225.793 18.4761C226.796 18.4761 227.61 17.6624 227.61 16.6588C227.61 15.6551 226.796 14.8414 225.793 14.8414C224.789 14.8414 223.976 15.6551 223.976 16.6588C223.976 17.6624 224.789 18.4761 225.793 18.4761Z" fill="#D0CDE1"/>
      <path d="M245.48 40.2839C246.484 40.2839 247.298 39.4703 247.298 38.4666C247.298 37.4629 246.484 36.6493 245.48 36.6493C244.477 36.6493 243.663 37.4629 243.663 38.4666C243.663 39.4703 244.477 40.2839 245.48 40.2839Z" fill="#D0CDE1"/>
      <path d="M270.014 90.866C271.353 90.866 272.437 89.7811 272.437 88.4429C272.437 87.1046 271.353 86.0198 270.014 86.0198C268.676 86.0198 267.591 87.1046 267.591 88.4429C267.591 89.7811 268.676 90.866 270.014 90.866Z" fill="#D0CDE1"/>
      <path d="M237.545 65.7567C238.549 65.7567 239.362 64.943 239.362 63.9393C239.362 62.9356 238.549 62.122 237.545 62.122C236.541 62.122 235.728 62.9356 235.728 63.9393C235.728 64.943 236.541 65.7567 237.545 65.7567Z" fill="#D0CDE1"/>
      <path d="M186.418 130.847C187.756 130.847 188.841 129.762 188.841 128.424C188.841 127.086 187.756 126.001 186.418 126.001C185.079 126.001 183.994 127.086 183.994 128.424C183.994 129.762 185.079 130.847 186.418 130.847Z" fill="#D0CDE1"/>
      <path d="M215.192 132.967C216.196 132.967 217.009 132.154 217.009 131.15C217.009 130.146 216.196 129.332 215.192 129.332C214.188 129.332 213.375 130.146 213.375 131.15C213.375 132.154 214.188 132.967 215.192 132.967Z" fill="#D0CDE1"/>
      <path d="M36.7917 53.9138C38.1299 53.9138 39.2148 52.8289 39.2148 51.4907C39.2148 50.1525 38.1299 49.0676 36.7917 49.0676C35.4534 49.0676 34.3686 50.1525 34.3686 51.4907C34.3686 52.8289 35.4534 53.9138 36.7917 53.9138Z" fill="#D0CDE1"/>
      <path d="M34.3686 34.529C35.3723 34.529 36.1859 33.7154 36.1859 32.7117C36.1859 31.7081 35.3723 30.8944 34.3686 30.8944C33.3649 30.8944 32.5513 31.7081 32.5513 32.7117C32.5513 33.7154 33.3649 34.529 34.3686 34.529Z" fill="#D0CDE1"/>
      <path d="M32.5513 167.193C33.555 167.193 34.3686 166.38 34.3686 165.376C34.3686 164.372 33.555 163.559 32.5513 163.559C31.5476 163.559 30.7339 164.372 30.7339 165.376C30.7339 166.38 31.5476 167.193 32.5513 167.193Z" fill="#D0CDE1"/>
      <path d="M103.427 172.948C104.43 172.948 105.244 172.135 105.244 171.131C105.244 170.127 104.43 169.314 103.427 169.314C102.423 169.314 101.609 170.127 101.609 171.131C101.609 172.135 102.423 172.948 103.427 172.948Z" fill="#D0CDE1"/>
      <path d="M249.721 138.419C251.059 138.419 252.144 137.334 252.144 135.996C252.144 134.658 251.059 133.573 249.721 133.573C248.383 133.573 247.298 134.658 247.298 135.996C247.298 137.334 248.383 138.419 249.721 138.419Z" fill="#D0CDE1"/>
      <path d="M284.553 153.563C285.557 153.563 286.37 152.75 286.37 151.746C286.37 150.742 285.557 149.929 284.553 149.929C283.549 149.929 282.736 150.742 282.736 151.746C282.736 152.75 283.549 153.563 284.553 153.563Z" fill="#D0CDE1"/>
      <path d="M84.3448 73.6014C85.3485 73.6014 86.1621 72.7878 86.1621 71.7841C86.1621 70.7804 85.3485 69.9668 84.3448 69.9668C83.3411 69.9668 82.5274 70.7804 82.5274 71.7841C82.5274 72.7878 83.3411 73.6014 84.3448 73.6014Z" fill="#D0CDE1"/>
      <path d="M183.995 165.073C185.333 165.073 186.418 163.988 186.418 162.65C186.418 161.312 185.333 160.227 183.995 160.227C182.656 160.227 181.571 161.312 181.571 162.65C181.571 163.988 182.656 165.073 183.995 165.073Z" fill="#D0CDE1"/>
      <path d="M99.1863 3.63464C100.19 3.63464 101.004 2.821 101.004 1.81732C101.004 0.813642 100.19 0 99.1863 0C98.1826 0 97.3689 0.813642 97.3689 1.81732C97.3689 2.821 98.1826 3.63464 99.1863 3.63464Z" fill="#D0CDE1"/>
      <path d="M118.874 25.4424C119.878 25.4424 120.691 24.6288 120.691 23.6251C120.691 22.6214 119.878 21.8078 118.874 21.8078C117.87 21.8078 117.057 22.6214 117.057 23.6251C117.057 24.6288 117.87 25.4424 118.874 25.4424Z" fill="#D0CDE1"/>
      <path d="M114.633 49.0676C115.637 49.0676 116.451 48.2539 116.451 47.2503C116.451 46.2466 115.637 45.433 114.633 45.433C113.63 45.433 112.816 46.2466 112.816 47.2503C112.816 48.2539 113.63 49.0676 114.633 49.0676Z" fill="#D0CDE1"/>
      <path d="M170.062 20.2934C171.4 20.2934 172.485 19.2085 172.485 17.8703C172.485 16.532 171.4 15.4472 170.062 15.4472C168.723 15.4472 167.639 16.532 167.639 17.8703C167.639 19.2085 168.723 20.2934 170.062 20.2934Z" fill="#D0CDE1"/>
      <path d="M188.962 74.1595C189.966 74.1595 190.779 73.3459 190.779 72.3422C190.779 71.3386 189.966 70.5249 188.962 70.5249C187.958 70.5249 187.145 71.3386 187.145 72.3422C187.145 73.3459 187.958 74.1595 188.962 74.1595Z" fill="#D0CDE1"/>
      <path d="M233.062 106.616C234.066 106.616 234.879 105.802 234.879 104.799C234.879 103.795 234.066 102.981 233.062 102.981C232.058 102.981 231.245 103.795 231.245 104.799C231.245 105.802 232.058 106.616 233.062 106.616Z" fill="#D0CDE1"/>
      <path d="M47.6955 105.707C48.6992 105.707 49.5128 104.894 49.5128 103.89C49.5128 102.886 48.6992 102.073 47.6955 102.073C46.6918 102.073 45.8782 102.886 45.8782 103.89C45.8782 104.894 46.6918 105.707 47.6955 105.707Z" fill="#D0CDE1"/>
      <path d="M20.4357 140.539C21.4394 140.539 22.253 139.726 22.253 138.722C22.253 137.718 21.4394 136.905 20.4357 136.905C19.432 136.905 18.6184 137.718 18.6184 138.722C18.6184 139.726 19.432 140.539 20.4357 140.539Z" fill="#D0CDE1"/>
      <path d="M88.8881 116.611C91.5646 116.611 93.7343 114.442 93.7343 111.765C93.7343 109.089 91.5646 106.919 88.8881 106.919C86.2116 106.919 84.0419 109.089 84.0419 111.765C84.0419 114.442 86.2116 116.611 88.8881 116.611Z" fill="#D0CDE1"/>
      <path d="M232.002 170.222L234.728 167.496L236.242 169.011L233.819 172.948L232.002 170.222Z" fill="#FFB8B8"/>
      <path d="M233.214 167.496L235.031 166.285C235.031 166.285 239.574 160.227 241.392 163.256C243.209 166.285 238.06 169.314 238.06 169.314L236.545 171.131L233.214 167.496Z" fill="#FF6584"/>
      <path opacity="0.15" d="M233.214 167.496L235.031 166.285C235.031 166.285 239.574 160.227 241.392 163.256C243.209 166.285 238.06 169.314 238.06 169.314L236.545 171.131L233.214 167.496Z" fill="black"/>
      <path d="M216.858 173.251H226.55L232.305 169.313L235.637 173.857L227.762 179.915L219.584 181.429L216.858 173.251Z" fill="#6C63FF"/>
      <path opacity="0.15" d="M216.858 173.251H226.55L232.305 169.313L235.637 173.857L227.762 179.915L219.584 181.429L216.858 173.251Z" fill="black"/>
      <path d="M220.795 190.364C220.795 190.364 229.579 200.057 228.064 202.48C226.55 204.903 223.218 204.903 222.612 204.6C222.007 204.297 213.223 199.451 213.223 199.451L214.435 195.513C214.435 195.513 212.617 191.273 214.435 190.97C216.252 190.667 220.795 190.364 220.795 190.364Z" fill="#2F2E41"/>
      <path d="M215.04 195.513C215.04 195.513 209.286 190.97 208.074 191.879C206.862 192.787 202.925 198.542 203.531 201.268C204.136 203.994 203.531 204.903 205.348 204.6C207.165 204.297 207.468 201.268 207.468 201.268L213.829 198.845L215.04 195.513Z" fill="#2F2E41"/>
      <path opacity="0.15" d="M216.939 196.294L216.776 196.55L223.44 200.79L223.603 200.535L216.939 196.294Z" fill="black"/>
      <path d="M216.858 166.133C219.367 166.133 221.401 164.099 221.401 161.59C221.401 159.081 219.367 157.047 216.858 157.047C214.348 157.047 212.314 159.081 212.314 161.59C212.314 164.099 214.348 166.133 216.858 166.133Z" fill="#FFB8B8"/>
      <path d="M211.406 166.739C211.406 166.739 210.194 169.768 210.194 177.037C210.194 184.306 205.954 187.638 209.285 191.273C212.617 194.908 225.751 192.6 225.751 192.6C225.751 192.6 225.609 192.712 225.641 192.484C225.944 190.364 222.613 168.253 221.401 167.951C220.189 167.648 211.406 166.739 211.406 166.739Z" fill="#6C63FF"/>
      <path d="M232.002 165.225L234.728 162.499L236.242 164.013L233.819 167.95L232.002 165.225Z" fill="#FFB8B8"/>
      <path d="M208.206 161.232C207.203 161.379 206.096 161.491 205.385 161.797C204.453 162.199 204.508 162.802 204.761 163.328C205.014 163.855 205.409 164.403 204.987 164.913C204.742 165.21 204.239 165.465 203.847 165.738C203.455 166.011 203.167 166.332 203.398 166.63C203.64 166.942 204.382 167.153 204.902 167.411C206.028 167.968 206.044 168.81 204.94 169.373C205.89 168.801 207.703 168.546 209.365 168.303C211.028 168.06 212.815 167.736 213.512 167.114C214.223 166.48 213.562 165.742 213.931 165.067C214.246 164.49 215.277 164.015 216.1 163.515C216.923 163.015 217.572 162.399 217.03 161.847C216.63 161.44 215.608 161.084 215.802 160.656C215.922 160.391 216.485 160.193 216.89 159.972C217.294 159.751 217.519 159.42 217.01 159.233C215.16 159.567 213.277 159.882 211.453 160.235C210.328 160.453 209.662 161.232 208.206 161.232Z" fill="#2F2E41"/>
      <path d="M216.858 168.253H226.55L232.305 164.316L235.637 168.859L227.762 174.917L219.584 176.431L216.858 168.253Z" fill="#6C63FF"/>
      <path d="M241.359 166.588C241.359 166.588 249.84 162.347 249.84 160.833C249.84 159.318 246.508 154.775 240.451 154.775C240.451 154.775 238.936 152.049 237.119 154.169C235.302 156.289 238.028 157.804 238.028 157.804C238.028 157.804 234.696 163.256 239.542 166.588H241.359Z" fill="#6C63FF"/>
      <path d="M167.033 116.914C169.709 116.914 171.879 114.745 171.879 112.068C171.879 109.392 169.709 107.222 167.033 107.222C164.356 107.222 162.187 109.392 162.187 112.068C162.187 114.745 164.356 116.914 167.033 116.914Z" fill="#FF6584"/>
      <path d="M163.828 112.137L162.441 110.285L162.684 110.103L163.877 111.696L165.973 109.9L168.085 111.71L169.91 109.885L171.835 111.81L171.621 112.024L169.91 110.313L168.101 112.123L165.973 110.299L163.828 112.137Z" fill="#575A89"/>
      <path d="M163.528 114.532L162.154 112.696L162.366 112.538L163.571 114.148L165.67 112.349L167.783 114.16L169.607 112.336L171.518 114.246L171.331 114.433L169.607 112.709L167.797 114.519L165.67 112.696L163.528 114.532Z" fill="#575A89"/>
      <path d="M167.033 103.739H166.73V107.373H167.033V103.739Z" fill="#575A89"/>
      <path d="M157.946 77.2361C160.623 77.2361 162.792 75.0664 162.792 72.3899C162.792 69.7134 160.623 67.5437 157.946 67.5437C155.27 67.5437 153.1 69.7134 153.1 72.3899C153.1 75.0664 155.27 77.2361 157.946 77.2361Z" fill="#FF6584"/>
      <path d="M154.742 72.4589L153.355 70.6066L153.597 70.425L154.79 72.0181L156.886 70.2218L158.998 72.0324L160.824 70.207L162.748 72.1314L162.534 72.3454L160.824 70.6354L159.014 72.4447L156.886 70.6206L154.742 72.4589Z" fill="#575A89"/>
      <path d="M154.442 74.8534L153.067 73.0179L153.279 72.8596L154.484 74.4696L156.583 72.6703L158.697 74.4817L160.521 72.6577L162.432 74.5683L162.245 74.7549L160.521 73.0309L158.71 74.8415L156.583 73.0179L154.442 74.8534Z" fill="#575A89"/>
      <path d="M157.946 64.0605H157.643V67.6952H157.946V64.0605Z" fill="#575A89"/>
      <path d="M120.691 118.429C123.368 118.429 125.537 116.259 125.537 113.582C125.537 110.906 123.368 108.736 120.691 108.736C118.015 108.736 115.845 110.906 115.845 113.582C115.845 116.259 118.015 118.429 120.691 118.429Z" fill="#FF6584"/>
      <path d="M117.487 113.651L116.1 111.799L116.342 111.617L117.535 113.211L119.631 111.414L121.743 113.225L123.569 111.399L125.493 113.324L125.279 113.538L123.569 111.828L121.759 113.637L119.631 111.813L117.487 113.651Z" fill="#575A89"/>
      <path d="M117.187 116.046L115.812 114.211L116.024 114.052L117.229 115.662L119.328 113.863L121.441 115.674L123.266 113.85L125.176 115.761L124.99 115.947L123.266 114.224L121.455 116.034L119.328 114.211L117.187 116.046Z" fill="#575A89"/>
      <path d="M120.691 105.253H120.388V108.888H120.691V105.253Z" fill="#575A89"/>
      <path d="M148.704 24.5885L144.577 21.4915L140.356 24.4597L142.027 19.5774L137.899 16.4801L143.059 16.5598L144.729 11.6774L146.247 16.6091L151.407 16.6888L147.186 19.6571L148.704 24.5885Z" fill="#6C63FF"/>
      <path d="M199.774 193.854C199.837 192.511 199.473 191.183 198.734 190.06C197.994 188.937 196.918 188.077 195.659 187.605C194.401 187.132 193.025 187.071 191.729 187.43C190.433 187.789 189.285 188.549 188.449 189.602C187.773 188.571 186.813 187.758 185.685 187.263C186.048 185.885 185.939 184.426 185.375 183.118C184.81 181.811 183.823 180.73 182.572 180.05C181.32 179.37 179.877 179.13 178.472 179.369C177.068 179.607 175.785 180.309 174.827 181.364C173.326 179.876 171.523 178.726 169.541 177.992C169.785 176.444 169.45 174.861 168.599 173.546C167.749 172.231 166.442 171.276 164.931 170.865C163.419 170.454 161.809 170.615 160.409 171.318C159.01 172.02 157.918 173.215 157.345 174.673C156.224 173.893 154.881 173.495 153.516 173.539C152.151 173.582 150.837 174.064 149.767 174.913C148.698 175.763 147.93 176.934 147.579 178.254C147.228 179.574 147.311 180.972 147.817 182.24C147.067 182.517 146.376 182.931 145.78 183.463C144.325 182.928 142.725 182.942 141.28 183.504C139.835 184.066 138.645 185.137 137.935 186.515C137.359 185.876 136.66 185.361 135.879 185C135.898 184.844 135.917 184.689 135.925 184.53C135.967 183.642 135.822 182.757 135.501 181.929C135.18 181.101 134.689 180.349 134.059 179.723C133.43 179.096 132.677 178.608 131.848 178.29C131.018 177.973 130.132 177.832 129.245 177.878C128.358 177.923 127.491 178.154 126.698 178.555C125.906 178.956 125.207 179.519 124.645 180.206C124.083 180.894 123.672 181.692 123.437 182.548C123.202 183.405 123.149 184.301 123.282 185.179C121.841 185.571 120.587 186.463 119.743 187.694C118.899 188.926 118.52 190.417 118.674 191.902C111.536 192.111 104.652 192.446 98.0732 192.898C97.2632 190.062 95.6267 187.532 93.3726 185.63C91.1184 183.728 88.3488 182.541 85.417 182.22C82.4853 181.899 79.5243 182.458 76.9118 183.827C74.2994 185.196 72.1539 187.311 70.7491 189.905C69.6475 189.071 68.3044 188.619 66.9229 188.617C65.5414 188.614 64.1967 189.062 63.0924 189.892C61.9881 190.722 61.1842 191.889 60.8023 193.217C60.4205 194.545 60.4815 195.961 60.9761 197.251C60.6882 197.302 60.4014 197.354 60.1159 197.407C60.1261 197.301 60.1417 197.197 60.1466 197.09C60.1863 196.255 60.061 195.421 59.7779 194.634C59.4948 193.848 59.0594 193.125 58.4967 192.506C57.9339 191.888 57.2549 191.387 56.4983 191.032C55.7417 190.676 54.9225 190.473 54.0874 190.435C53.2524 190.396 52.4179 190.522 51.6317 190.806C50.8455 191.09 50.1231 191.527 49.5056 192.09C48.8881 192.653 48.3878 193.333 48.0332 194.09C47.6786 194.847 47.4767 195.667 47.439 196.502C47.436 196.568 47.4409 196.632 47.4398 196.697C46.8584 196.477 46.2329 196.397 45.6147 196.465C44.9964 196.533 44.4031 196.746 43.8833 197.087C43.3635 197.429 42.932 197.889 42.6243 198.429C42.3167 198.97 42.1415 199.576 42.1133 200.197C42.0902 200.696 199.762 194.101 199.774 193.854Z" fill="#D0CDE1"/>
      <path d="M45.4027 220.429C45.6421 220.44 45.8806 220.465 46.1175 220.501H44.1154C44.5407 220.431 44.9722 220.407 45.4027 220.429V220.429Z" fill="#D0CDE1"/>
      <path d="M74.3102 220.501H49.6734C51.0302 218.48 52.8636 216.824 55.0119 215.678C57.1602 214.533 59.5573 213.934 61.9918 213.934C64.4263 213.934 66.8234 214.533 68.9717 215.678C71.1199 216.824 72.9533 218.48 74.3102 220.501V220.501Z" fill="#D0CDE1"/>
      <path d="M24.6368 220.501H0C1.35684 218.48 3.19024 216.824 5.33851 215.678C7.48677 214.533 9.88388 213.934 12.3184 213.934C14.7529 213.934 17.15 214.533 19.2983 215.678C21.4465 216.824 23.2799 218.48 24.6368 220.501V220.501Z" fill="#D0CDE1"/>
      <path d="M39.1753 220.501H14.5386C15.8954 218.48 17.7288 216.824 19.8771 215.678C22.0253 214.533 24.4224 213.934 26.8569 213.934C29.2915 213.934 31.6886 214.533 33.8368 215.678C35.9851 216.824 37.8185 218.48 39.1753 220.501Z" fill="#D0CDE1"/>
      <path d="M107.628 206.569H82.9909C84.3477 204.547 86.1812 202.891 88.3294 201.746C90.4777 200.6 92.8748 200.001 95.3093 200.001C97.7438 200.001 100.141 200.6 102.289 201.746C104.437 202.891 106.271 204.547 107.628 206.569V206.569Z" fill="#D0CDE1"/>
      <path d="M206.369 213.535H181.732C183.089 211.514 184.922 209.857 187.07 208.712C189.219 207.567 191.616 206.968 194.05 206.968C196.485 206.968 198.882 207.567 201.03 208.712C203.178 209.857 205.012 211.514 206.369 213.535V213.535Z" fill="#D0CDE1"/>
      <path d="M163.877 219.066C164.646 219.406 165.342 219.894 165.924 220.501H97.384C97.7672 219.652 98.3319 218.896 99.0383 218.288C99.7447 217.68 100.576 217.234 101.473 216.982C101.411 216.572 101.389 216.157 101.409 215.743C101.448 214.909 101.65 214.09 102.005 213.333C102.36 212.577 102.86 211.898 103.478 211.335C104.095 210.772 104.818 210.336 105.603 210.053C106.389 209.769 107.223 209.643 108.058 209.682C108.893 209.721 109.711 209.923 110.467 210.279C111.224 210.634 111.902 211.135 112.465 211.753C113.027 212.37 113.463 213.093 113.746 213.879C114.029 214.665 114.155 215.499 114.115 216.334C114.109 216.491 114.091 216.646 114.07 216.803C114.851 217.163 115.551 217.679 116.127 218.318C116.838 216.94 118.027 215.87 119.472 215.308C120.917 214.747 122.517 214.732 123.971 215.268C124.568 214.735 125.259 214.32 126.01 214.044C125.674 213.207 125.522 212.307 125.565 211.406C125.616 210.271 125.97 209.17 126.591 208.218C127.212 207.267 128.077 206.499 129.096 205.996C130.115 205.492 131.25 205.271 132.383 205.355C133.516 205.44 134.606 205.826 135.539 206.475C136.09 205.073 137.122 203.913 138.449 203.201C139.776 202.489 141.313 202.271 142.785 202.587C144.258 202.902 145.571 203.73 146.491 204.923C147.41 206.116 147.876 207.596 147.806 209.101C147.794 209.333 147.769 209.565 147.733 209.794C149.715 210.529 151.517 211.678 153.018 213.166C153.975 212.109 155.259 211.404 156.664 211.165C158.07 210.926 159.515 211.166 160.767 211.846C162.02 212.527 163.007 213.609 163.571 214.918C164.135 216.227 164.243 217.688 163.877 219.066V219.066Z" fill="#D0CDE1"/>
      <path d="M231.732 220.501H220.041C220.531 219.357 221.346 218.381 222.385 217.696C223.424 217.01 224.642 216.645 225.887 216.645C227.132 216.645 228.349 217.01 229.388 217.696C230.428 218.381 231.243 219.357 231.732 220.501V220.501Z" fill="#D0CDE1"/>
      <path d="M280.873 220.501H243.96C243.746 219.813 243.655 219.092 243.691 218.372C243.742 217.237 244.096 216.136 244.717 215.185C245.338 214.233 246.203 213.466 247.222 212.962C248.24 212.459 249.375 212.237 250.509 212.322C251.642 212.406 252.732 212.793 253.665 213.441C254.216 212.04 255.248 210.88 256.575 210.168C257.902 209.456 259.439 209.238 260.911 209.553C262.384 209.868 263.697 210.696 264.616 211.889C265.536 213.082 266.002 214.563 265.931 216.067C265.919 216.3 265.895 216.531 265.859 216.761C267.84 217.495 269.642 218.645 271.144 220.132C271.768 219.445 272.534 218.903 273.389 218.544C274.244 218.185 275.167 218.017 276.094 218.052C277.021 218.087 277.929 218.325 278.755 218.748C279.58 219.171 280.303 219.769 280.873 220.501V220.501Z" fill="#D0CDE1"/>
      <path d="M175.714 220.501H167.524C168.668 219.533 170.119 219.002 171.619 219.002C173.118 219.002 174.569 219.533 175.714 220.501V220.501Z" fill="#D0CDE1"/>
      <path d="M67.5868 132.649C70.5673 132.649 72.9834 130.233 72.9834 127.253C72.9834 124.272 70.5673 121.856 67.5868 121.856C64.6064 121.856 62.1903 124.272 62.1903 127.253C62.1903 130.233 64.6064 132.649 67.5868 132.649Z" fill="#A0616A"/>
      <path d="M68.8565 120.372C70.7792 120.492 72.5632 121.384 74.2305 122.349C74.0921 122.279 73.9342 122.257 73.782 122.287C73.6298 122.317 73.492 122.397 73.3904 122.515C73.168 122.73 73.0282 123.018 72.8141 123.242C72.4161 123.659 71.8192 123.803 71.2571 123.928L68.6371 124.511L66.2072 125.051C65.6035 125.226 64.9719 125.284 64.3464 125.222C63.7279 125.12 63.1157 124.721 62.9541 124.116C62.7295 123.274 64.4023 122.022 65.0157 121.515C66.1097 120.671 67.4787 120.263 68.8565 120.372Z" fill="#2F2E41"/>
      <path d="M63.92 124.787C65.0527 123.197 66.8206 122.163 68.5939 121.271C68.2955 121.389 68.2197 121.775 68.2997 122.089C68.3797 122.403 68.5702 122.687 68.6622 122.999C68.8334 123.578 68.6485 124.174 68.4646 124.73L67.6078 127.321L66.8132 129.723C66.654 130.341 66.371 130.92 65.9813 131.425C65.7728 131.678 65.497 131.865 65.1859 131.967C64.8749 132.069 64.5414 132.08 64.2241 132C63.3314 131.717 63.0695 129.565 62.9299 128.749C62.7293 127.35 63.0847 125.928 63.92 124.787V124.787Z" fill="#2F2E41"/>
      <path d="M91.0776 123.126C91.0776 123.126 91.395 116.142 92.9823 116.46C94.5695 116.777 93.2997 123.761 93.2997 123.761L91.0776 123.126Z" fill="#A0616A"/>
      <path d="M90.7606 135.189L83.6284 140.355L81.5539 141.856L76.1582 134.236L79.5259 132.909L86.6336 130.109L90.7606 121.855L94.2508 122.808C94.8876 124.395 90.7606 135.189 90.7606 135.189Z" fill="#575A89"/>
      <path d="M79.6496 121.539C79.6496 121.539 78.6973 113.285 80.6019 113.92C82.5066 114.555 82.1891 122.491 82.1891 122.491L79.6496 121.539Z" fill="#A0616A"/>
      <path d="M65.1919 195.528L63.3601 200.318L68.4629 201.828L68.3657 195.48L65.1919 195.528Z" fill="#575A89"/>
      <path d="M80.2449 162.598L75.1694 183.629L70.2947 197.038L63.9464 197.135L69.715 179.902L71.9633 160.819L80.2449 162.598Z" fill="#2F2E41"/>
      <path d="M62.6489 199.796C62.6489 199.796 60.7163 203.91 62.0194 204.473C63.3226 205.037 66.862 205.793 66.862 205.793L67.348 205.384C67.348 205.384 75.5258 207.218 76.8952 204.407C78.2645 201.596 71.8372 200.365 71.8372 200.365L68.8995 197.858L65.3711 199.581L62.6489 199.796Z" fill="#2F2E41"/>
      <path d="M58.5115 194.678L56.6801 199.468L61.7828 200.978L61.6857 194.629L58.5115 194.678Z" fill="#575A89"/>
      <path d="M64.9232 161.401L63.0495 180.005L57.2518 195.332L62.6768 197.154L70.9993 180.835L74.8391 162.045L64.9232 161.401Z" fill="#2F2E41"/>
      <path d="M55.6255 199.123C55.6255 199.123 52.5967 202.512 53.6842 203.424C54.7717 204.337 57.9468 206.075 57.9468 206.075L58.5293 205.822C58.5293 205.822 65.8407 209.918 67.957 207.617C70.0733 205.316 64.267 202.297 64.267 202.297L62.1694 199.054L58.2956 199.696L55.6255 199.123Z" fill="#2F2E41"/>
      <path opacity="0.15" d="M83.6284 140.355L81.5539 141.856L76.1582 134.236L77.6596 133.969C77.7428 134.106 79.0434 134.072 79.1291 134.214C80.704 136.793 82.9744 138.973 83.6284 140.355Z" fill="black"/>
      <path d="M86.9667 165.81C86.5992 165.572 86.5137 163.088 85.987 162.871C85.7198 162.761 85.0657 164.91 84.7626 164.805C76.8918 162.082 59.2974 167.92 56.3508 161.401C54.3697 157.018 66.9513 148.52 66.9513 145.346C66.9097 144.538 66.7632 143.738 66.5153 142.968C65.9152 140.867 64.7984 138.221 63.897 136.225C63.1255 134.516 62.5083 133.284 62.5083 133.284C62.5083 133.284 71.7641 130.533 74.7302 129.47C75.1074 129.335 75.3817 129.228 75.5237 129.157C76.092 128.872 77.5517 130.881 79.0482 133.328C80.8901 136.343 82.7907 140.026 83.141 140.903C83.7753 142.49 92.3625 169.303 86.9667 165.81Z" fill="#575A89"/>
      <path opacity="0.15" d="M77.9045 132.745C74.4682 136.882 70.7697 141.827 67.5856 142.762C67.2369 142.867 66.8782 142.936 66.5153 142.968C65.9152 140.866 64.7983 138.221 63.897 136.225C64.2639 135.822 64.7035 135.493 65.1927 135.253L73.8019 131.016L74.7302 129.47C75.1074 129.335 75.3817 129.228 75.5238 129.157C76.092 128.872 76.408 130.298 77.9045 132.745Z" fill="black"/>
      <path d="M65.1925 134.028C62.8412 135.186 61.9844 138.194 63.5078 140.327C64.2983 141.434 65.5631 142.133 67.5868 141.538C72.9833 139.951 83.1415 128.523 83.1415 125.031V121.856L79.3322 120.586L73.8016 129.79L65.1925 134.028Z" fill="#575A89"/>
      <path d="M79.4532 135.502C79.6734 135.344 79.5971 134.86 79.2828 134.42C78.9685 133.979 78.5352 133.75 78.315 133.907C78.0948 134.064 78.1711 134.548 78.4854 134.989C78.7997 135.429 79.233 135.659 79.4532 135.502Z" fill="#2F2E41"/>
      <path d="M80.9228 138.196C81.1431 138.039 81.0668 137.554 80.7524 137.114C80.4381 136.673 80.0048 136.444 79.7846 136.601C79.5643 136.758 79.6406 137.243 79.955 137.683C80.2693 138.123 80.7026 138.353 80.9228 138.196Z" fill="#2F2E41"/>
      <path d="M82.1474 141.135C82.3676 140.978 82.2913 140.493 81.977 140.053C81.6627 139.613 81.2294 139.383 81.0092 139.54C80.789 139.697 80.8653 140.182 81.1796 140.622C81.4939 141.062 81.9272 141.292 82.1474 141.135Z" fill="#2F2E41"/>
      <path d="M82.6299 144.204C82.8859 144.116 82.9516 143.63 82.7766 143.118C82.6017 142.606 82.2523 142.262 81.9963 142.35C81.7403 142.437 81.6746 142.923 81.8496 143.435C82.0245 143.947 82.3739 144.291 82.6299 144.204Z" fill="#2F2E41"/>
      <path d="M83.6096 147.143C83.8656 147.055 83.9313 146.569 83.7563 146.057C83.5814 145.545 83.232 145.201 82.976 145.289C82.72 145.376 82.6543 145.862 82.8293 146.374C83.0043 146.886 83.3536 147.23 83.6096 147.143Z" fill="#2F2E41"/>
      <path d="M84.5894 149.837C84.8454 149.75 84.9111 149.264 84.7361 148.752C84.5612 148.239 84.2118 147.895 83.9558 147.983C83.6997 148.07 83.634 148.556 83.809 149.068C83.984 149.58 84.3334 149.925 84.5894 149.837Z" fill="#2F2E41"/>
      <path d="M85.0792 152.776C85.3353 152.689 85.401 152.203 85.226 151.691C85.051 151.179 84.7016 150.835 84.4456 150.922C84.1896 151.01 84.1239 151.495 84.2989 152.007C84.4738 152.519 84.8232 152.864 85.0792 152.776Z" fill="#2F2E41"/>
      <path d="M85.569 155.715C85.825 155.628 85.8907 155.142 85.7157 154.63C85.5408 154.118 85.1914 153.774 84.9354 153.861C84.6794 153.949 84.6137 154.435 84.7887 154.947C84.9636 155.459 85.313 155.803 85.569 155.715Z" fill="#2F2E41"/>
      <path d="M86.0589 158.899C86.3149 158.812 86.3806 158.326 86.2056 157.814C86.0307 157.302 85.6813 156.958 85.4253 157.045C85.1693 157.133 85.1036 157.619 85.2786 158.131C85.4535 158.643 85.8029 158.987 86.0589 158.899Z" fill="#2F2E41"/>
      <path d="M86.3038 162.083C86.5598 161.996 86.6255 161.51 86.4505 160.998C86.2755 160.486 85.9262 160.142 85.6701 160.229C85.4141 160.317 85.3484 160.803 85.5234 161.315C85.6984 161.827 86.0478 162.171 86.3038 162.083Z" fill="#2F2E41"/>
      <path d="M64.7526 130.511C64.7526 130.511 72.0037 122.058 71.314 120.419C70.6244 118.779 64.9484 115.377 58.3899 118.136C58.3899 118.136 55.509 115.874 54.5069 118.997C53.5048 122.12 57.1457 122.519 57.1457 122.519C57.1457 122.519 56.0211 129.938 62.7851 131.339L64.7526 130.511Z" fill="#6C63FF"/>
      <path d="M182.177 202.328C184.854 202.328 187.023 200.159 187.023 197.482C187.023 194.806 184.854 192.636 182.177 192.636C179.501 192.636 177.331 194.806 177.331 197.482C177.331 200.159 179.501 202.328 182.177 202.328Z" fill="#FF6584"/>
      <path d="M178.973 197.551L177.586 195.699L177.828 195.517L179.021 197.11L181.117 195.314L183.229 197.124L185.054 195.299L186.979 197.223L186.765 197.438L185.054 195.727L183.245 197.537L181.117 195.713L178.973 197.551Z" fill="#575A89"/>
      <path d="M178.673 199.946L177.298 198.11L177.51 197.952L178.715 199.562L180.814 197.763L182.927 199.574L184.752 197.75L186.662 199.66L186.476 199.847L184.752 198.123L182.941 199.933L180.814 198.11L178.673 199.946Z" fill="#575A89"/>
      <path d="M182.177 189.153H181.874V192.787H182.177V189.153Z" fill="#575A89"/>
      <path d="M165.967 202.158C168.643 202.158 170.813 199.988 170.813 197.312C170.813 194.635 168.643 192.465 165.967 192.465C163.291 192.465 161.121 194.635 161.121 197.312C161.121 199.988 163.291 202.158 165.967 202.158Z" fill="#6C63FF"/>
      <path d="M163.106 198.756L161.055 197.684L161.196 197.416L162.959 198.338L164.075 195.813L166.762 196.535L167.621 194.101L170.187 195.006L170.087 195.292L167.806 194.487L166.954 196.9L164.247 196.173L163.106 198.756Z" fill="#575A89"/>
      <path d="M163.748 200.789L161.84 199.975L161.944 199.732L163.63 200.452L164.863 198.162L167.436 198.642L168.411 196.454L170.826 197.095L170.759 197.35L168.56 196.767L167.592 198.939L165.004 198.457L163.748 200.789Z" fill="#575A89"/>
      <path d="M162.373 189.798L162.1 189.928L163.668 193.207L163.941 193.076L162.373 189.798Z" fill="#575A89"/>
      <path d="M122.434 199.428C125.11 199.428 127.28 197.259 127.28 194.582C127.28 191.906 125.11 189.736 122.434 189.736C119.757 189.736 117.587 191.906 117.587 194.582C117.587 197.259 119.757 199.428 122.434 199.428Z" fill="#6C63FF"/>
      <path d="M119.389 193.581L118.697 191.373L118.986 191.282L119.581 193.181L122.155 192.185L123.545 194.595L125.873 193.481L127.048 195.936L126.774 196.067L125.731 193.885L123.423 194.989L122.023 192.561L119.389 193.581Z" fill="#575A89"/>
      <path d="M125.7 198.243L124.648 196.044L122.338 197.148L120.939 194.721L118.309 195.739L117.624 193.551L117.876 193.472L118.477 195.391L121.055 194.393L122.445 196.805L124.772 195.692L125.938 198.129L125.7 198.243Z" fill="#575A89"/>
      <path d="M124.92 186.627L123.71 190.054L123.996 190.155L125.205 186.728L124.92 186.627Z" fill="#575A89"/>
      <path d="M224.964 185.325C225.21 185.286 225.303 184.585 225.172 183.759C225.041 182.932 224.736 182.294 224.49 182.333C224.245 182.372 224.151 183.073 224.282 183.9C224.413 184.726 224.719 185.364 224.964 185.325Z" fill="#575A89"/>
      <path d="M224.359 181.084C224.604 181.045 224.697 180.344 224.567 179.518C224.436 178.692 224.13 178.054 223.885 178.093C223.639 178.132 223.546 178.833 223.677 179.659C223.807 180.485 224.113 181.123 224.359 181.084Z" fill="#575A89"/>
      <path d="M225.57 189.262C225.816 189.223 225.909 188.522 225.778 187.696C225.647 186.87 225.342 186.232 225.096 186.271C224.85 186.31 224.757 187.011 224.888 187.837C225.019 188.663 225.324 189.301 225.57 189.262Z" fill="#575A89"/>
      <path d="M225.777 192.909C226.024 192.886 226.162 192.192 226.084 191.359C226.006 190.526 225.742 189.87 225.495 189.893C225.247 189.916 225.109 190.61 225.187 191.443C225.265 192.276 225.529 192.932 225.777 192.909Z" fill="#575A89"/>
      <path d="M232.618 167.792C233.209 167.2 233.546 166.578 233.37 166.402C233.194 166.226 232.572 166.563 231.981 167.155C231.389 167.746 231.052 168.368 231.228 168.544C231.404 168.72 232.027 168.383 232.618 167.792Z" fill="#575A89"/>
      <path d="M221.191 159.762C220.55 159.689 220.003 160.189 219.554 160.651C219.177 161.061 218.767 161.438 218.327 161.779C217.667 162.251 216.904 162.557 216.101 162.671C215.298 162.786 214.48 162.704 213.715 162.435C213.753 162.448 215.18 160.558 215.337 160.384C215.933 159.726 216.573 159.108 217.251 158.535C217.759 158.107 218.458 157.372 219.185 157.69C219.95 158.025 220.647 159.147 221.191 159.762Z" fill="#2F2E41"/>
      <path d="M212.314 163.71C212.314 163.71 220.795 159.47 220.795 157.955C220.795 156.441 217.463 151.898 211.406 151.898C211.406 151.898 209.891 149.172 208.074 151.292C206.257 153.412 208.983 154.926 208.983 154.926C208.983 154.926 205.651 160.378 210.497 163.71H212.314Z" fill="#575A89"/>
      <path d="M222.83 159.448C222.19 159.376 221.643 159.875 221.194 160.337C220.817 160.747 220.407 161.124 219.967 161.465C219.307 161.937 218.544 162.243 217.741 162.358C216.938 162.472 216.12 162.391 215.355 162.121C215.393 162.135 216.82 160.245 216.978 160.071C217.573 159.412 218.213 158.794 218.891 158.221C219.399 157.793 220.098 157.058 220.825 157.376C221.59 157.711 222.287 158.833 222.83 159.448Z" fill="#575A89"/>
      <path d="M241.392 158.258C240.427 156.651 238.695 157.603 237.282 158.85C237.213 158.074 236.977 157.501 236.697 157.501C236.362 157.501 236.091 158.315 236.091 159.318C236.091 159.54 236.105 159.762 236.133 159.982C235.472 160.7 235.031 161.287 235.031 161.287L233.214 162.499L236.545 166.133L238.06 164.316C238.06 164.316 243.209 161.287 241.392 158.258Z" fill="#FF6584"/>
      <path d="M207.62 151.746C208.289 151.746 208.831 151.204 208.831 150.535C208.831 149.866 208.289 149.323 207.62 149.323C206.95 149.323 206.408 149.866 206.408 150.535C206.408 151.204 206.95 151.746 207.62 151.746Z" fill="#575A89"/>
      <path d="M214.665 183.89V185.869C214.665 186.604 214.957 187.309 215.477 187.829C215.997 188.349 216.701 188.641 217.437 188.641C218.172 188.641 218.876 188.349 219.396 187.829C219.916 187.309 220.208 186.604 220.208 185.869V183.89H214.665Z" fill="#6C63FF"/>
      <path opacity="0.15" d="M214.665 183.89V185.869C214.665 186.604 214.957 187.309 215.477 187.829C215.997 188.349 216.701 188.641 217.437 188.641C218.172 188.641 218.876 188.349 219.396 187.829C219.916 187.309 220.208 186.604 220.208 185.869V183.89H214.665Z" fill="black"/>
      </g>
      <defs>
      <clipPath id="clip0">
      <rect width="300" height="220.501" fill="white"/>
      </clipPath>
      </defs>
    </svg>
  </header>
  <div class="content">
    <div class="temp-container">
      <p class="temp">-2ΒΊ</p>
      <p class="d-temp">-17ΒΊ/0ΒΊ</p>
    </div>
    <div class="w-icon">
      <svg width="82" height="60" viewBox="0 0 82 60" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M29.5405 37.1893C27.83 37.1893 26.1579 36.682 24.7356 35.7317C23.3133 34.7814 22.2048 33.4307 21.5502 31.8503C20.8956 30.27 20.7244 28.531 21.0581 26.8534C21.3918 25.1757 22.2155 23.6346 23.425 22.4251C24.6346 21.2156 26.1756 20.3919 27.8533 20.0582C29.5309 19.7244 31.2699 19.8957 32.8502 20.5503C34.4306 21.2049 35.7813 22.3134 36.7316 23.7357C37.682 25.1579 38.1892 26.8301 38.1892 28.5406C38.1866 30.8336 37.2745 33.0319 35.6532 34.6532C34.0318 36.2746 31.8335 37.1866 29.5405 37.1893ZM29.5405 21.3334C28.1151 21.3334 26.7216 21.7561 25.5364 22.548C24.3512 23.34 23.4274 24.4656 22.8819 25.7825C22.3365 27.0995 22.1937 28.5486 22.4718 29.9467C22.7499 31.3447 23.4363 32.6289 24.4443 33.6369C25.4522 34.6448 26.7364 35.3313 28.1345 35.6094C29.5326 35.8874 30.9817 35.7447 32.2986 35.1992C33.6156 34.6537 34.7412 33.73 35.5331 32.5447C36.3251 31.3595 36.7478 29.9661 36.7478 28.5406C36.7456 26.6298 35.9856 24.7979 34.6344 23.4467C33.2833 22.0956 31.4514 21.3356 29.5405 21.3334Z" fill="#6C63FF"/>
<path d="M29.2567 17.7297C29.0656 17.7297 28.8823 17.6538 28.7471 17.5186C28.6119 17.3835 28.536 17.2002 28.536 17.009V8.72072C28.536 8.52957 28.6119 8.34625 28.7471 8.21109C28.8823 8.07593 29.0656 8 29.2567 8C29.4479 8 29.6312 8.07593 29.7663 8.21109C29.9015 8.34625 29.9774 8.52957 29.9774 8.72072V17.009C29.9774 17.2002 29.9015 17.3835 29.7663 17.5186C29.6312 17.6538 29.4479 17.7297 29.2567 17.7297Z" fill="#6C63FF"/>
<path d="M18.009 28.9777H9.72072C9.52957 28.9777 9.34625 28.9017 9.21109 28.7666C9.07593 28.6314 9 28.4481 9 28.2569C9 28.0658 9.07593 27.8825 9.21109 27.7473C9.34625 27.6121 9.52957 27.5362 9.72072 27.5362H18.009C18.2002 27.5362 18.3835 27.6121 18.5186 27.7473C18.6538 27.8825 18.7297 28.0658 18.7297 28.2569C18.7297 28.4481 18.6538 28.6314 18.5186 28.7666C18.3835 28.9017 18.2002 28.9777 18.009 28.9777H18.009Z" fill="#6C63FF"/>
<path d="M48.2793 28.9777H39.991C39.7998 28.9777 39.6165 28.9017 39.4814 28.7666C39.3462 28.6314 39.2703 28.4481 39.2703 28.2569C39.2703 28.0658 39.3462 27.8825 39.4814 27.7473C39.6165 27.6121 39.7998 27.5362 39.991 27.5362H48.2793C48.4704 27.5362 48.6537 27.6121 48.7889 27.7473C48.9241 27.8825 49 28.0658 49 28.2569C49 28.4481 48.9241 28.6314 48.7889 28.7666C48.6537 28.9017 48.4704 28.9777 48.2793 28.9777Z" fill="#6C63FF"/>
<path d="M39.7633 21.0972C39.6198 21.0972 39.4796 21.0544 39.3606 20.9742C39.2416 20.894 39.1493 20.7802 39.0954 20.6472C39.0415 20.5142 39.0285 20.3682 39.0581 20.2278C39.0877 20.0874 39.1585 19.9591 39.2615 19.8592L42.7325 16.4917C42.8004 16.4256 42.8806 16.3735 42.9687 16.3385C43.0567 16.3035 43.1508 16.2861 43.2455 16.2875C43.3403 16.2888 43.4338 16.3089 43.5208 16.3464C43.6078 16.384 43.6865 16.4383 43.7525 16.5063C43.8185 16.5743 43.8704 16.6547 43.9053 16.7428C43.9402 16.8309 43.9573 16.925 43.9558 17.0197C43.9543 17.1144 43.9341 17.208 43.8964 17.2949C43.8587 17.3818 43.8043 17.4605 43.7361 17.5263L40.2652 20.8938C40.1308 21.0245 39.9507 21.0975 39.7633 21.0972V21.0972Z" fill="#6C63FF"/>
<path d="M18.597 21.0972C18.4096 21.0974 18.2295 21.0244 18.0952 20.8938L14.6243 17.5263C14.5562 17.4605 14.5017 17.3818 14.464 17.2949C14.4263 17.208 14.4061 17.1144 14.4046 17.0197C14.4031 16.925 14.4203 16.8309 14.4551 16.7428C14.49 16.6547 14.5419 16.5743 14.6079 16.5063C14.6739 16.4383 14.7526 16.384 14.8396 16.3464C14.9266 16.3089 15.0202 16.2888 15.1149 16.2875C15.2096 16.2861 15.3037 16.3035 15.3918 16.3385C15.4798 16.3735 15.56 16.4256 15.6279 16.4917L19.0989 19.8592C19.2018 19.9591 19.2727 20.0874 19.3023 20.2278C19.3319 20.3682 19.3189 20.5142 19.265 20.6472C19.2111 20.7802 19.1187 20.894 18.9997 20.9742C18.8807 21.0544 18.7405 21.0972 18.597 21.0972V21.0972Z" fill="#6C63FF"/>
<path d="M15.8468 40.7928C15.7052 40.7928 15.5667 40.751 15.4487 40.6727C15.3306 40.5945 15.2383 40.4831 15.1831 40.3527C15.1279 40.2222 15.1124 40.0784 15.1385 39.9392C15.1646 39.8 15.2311 39.6716 15.3297 39.5699L18.8006 35.9955C18.9339 35.8585 19.116 35.7801 19.3071 35.7773C19.4981 35.7746 19.6825 35.8479 19.8195 35.981C19.9566 36.1141 20.0352 36.2962 20.0381 36.4872C20.041 36.6783 19.9679 36.8627 19.8349 36.9999L16.364 40.5743C16.2968 40.6435 16.2164 40.6985 16.1276 40.7361C16.0388 40.7736 15.9433 40.7929 15.8468 40.7928V40.7928Z" fill="#6C63FF"/>
<path d="M43.9549 41.5136C43.8588 41.5137 43.7635 41.4946 43.6749 41.4572C43.5863 41.4199 43.5062 41.365 43.4392 41.2961L39.2476 37.001C39.1813 36.9333 39.1291 36.8532 39.0938 36.7653C39.0585 36.6774 39.0409 36.5834 39.042 36.4887C39.0431 36.3939 39.0629 36.3004 39.1002 36.2133C39.1374 36.1262 39.1915 36.0474 39.2593 35.9812C39.3271 35.9151 39.4073 35.8629 39.4952 35.8278C39.5832 35.7927 39.6772 35.7752 39.7719 35.7764C39.8666 35.7777 39.9601 35.7976 40.0472 35.835C40.1342 35.8724 40.213 35.9266 40.279 35.9945L44.4706 40.2896C44.5697 40.3911 44.6366 40.5195 44.663 40.6588C44.6894 40.7981 44.6742 40.9421 44.6191 41.0728C44.5641 41.2035 44.4717 41.315 44.3535 41.3934C44.2354 41.4718 44.0967 41.5136 43.9549 41.5136V41.5136Z" fill="#6C63FF"/>
<path d="M29.2567 48.7208C29.0656 48.7207 28.8823 48.6448 28.7471 48.5097C28.6119 48.3745 28.536 48.1912 28.536 48V39.7117C28.536 39.6171 28.5546 39.5233 28.5909 39.4359C28.6271 39.3485 28.6802 39.269 28.7471 39.2021C28.814 39.1352 28.8935 39.0821 28.9809 39.0458C29.0683 39.0096 29.1621 38.991 29.2567 38.991C29.3514 38.991 29.4451 39.0096 29.5325 39.0458C29.62 39.0821 29.6994 39.1352 29.7663 39.2021C29.8333 39.269 29.8864 39.3485 29.9226 39.4359C29.9588 39.5233 29.9774 39.6171 29.9774 39.7117V48C29.9774 48.1912 29.9015 48.3745 29.7663 48.5097C29.6312 48.6448 29.4479 48.7207 29.2567 48.7208V48.7208Z" fill="#6C63FF"/>
<path d="M59.5493 59.9502H25.5906C18.2645 59.9502 12.3043 53.8897 12.3043 46.4403C12.3043 38.9909 18.2645 32.9304 25.5906 32.9304H28.0065C29.3357 30.2204 31.3838 27.9277 33.9273 26.3026C36.508 24.6525 39.5069 23.7752 42.57 23.7743C51.0665 23.7743 58.1484 30.4557 58.8075 39.0345H59.5493C65.226 39.0345 69.8443 43.7259 69.8443 49.4924C69.8443 55.2588 65.226 59.9502 59.5493 59.9502Z" fill="white"/>
<path d="M59.5493 59.9502H25.5906C18.2645 59.9502 12.3043 53.8897 12.3043 46.4403C12.3043 38.9909 18.2645 32.9304 25.5906 32.9304H28.0065C29.3357 30.2204 31.3838 27.9277 33.9273 26.3026C36.508 24.6525 39.5069 23.7752 42.57 23.7743C51.0665 23.7743 58.1484 30.4557 58.8075 39.0345H59.5493C65.226 39.0345 69.8443 43.7259 69.8443 49.4924C69.8443 55.2588 65.226 59.9502 59.5493 59.9502ZM25.5906 33.4994C18.5783 33.4994 12.8733 39.3047 12.8733 46.4403C12.8733 53.5759 18.5783 59.3812 25.5906 59.3812H59.5493C64.9122 59.3812 69.2753 54.9451 69.2753 49.4924C69.2753 44.0396 64.9122 39.6035 59.5493 39.6035H58.2742L58.2579 39.3363C57.7453 30.929 50.8543 24.3433 42.57 24.3433C36.6045 24.3433 31.0587 27.8739 28.4412 33.3378L28.3638 33.4994H25.5906Z" fill="#3F3D56"/>
</svg>
      <p>SUNNY</p>
    </div>
  </div>
  <footer>
    <p class="date">April, 15</p>
    <p class="city">Berlin, Germany</p>
  </footer>
</article>
    <script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>
      <script id="rendered-js" >
"use strict";
    </script>
</body>
</html>

8. Weather card with floating animation

Made by Dadda Hicham. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title> 
<style>
:root {
  --font-body: Poppins, sans-serif;
  --secondary: #eef7fe;
  --primary: #22215B;
  --primary-light: #2F2F31;
}

html {
  font-size: 100%;
  box-sizing: border-box;
}

*,
*::before,
*::after {
  padding: 0;
  margin: 0;
  box-sizing: inherit;
}

html {
  font-family: var(--font-body);
}

body {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background-color: #E7E9F0;
}

ul {
  list-style: none;
}

button {
  font-family: inherit;
  border: none;
  background: transparent;
  cursor: pointer;
}

.card {
  background: #fff;
  width: 500px;
  display: flex;
  align-items: center;
  border-radius: 30px;
  padding: 32px;
}
.card__info__place {
  font-size: 14px;
  color: var(--primary-light);
}
.card__info__time {
  font-size: 30px;
  color: var(--primary);
}
.card__info__date {
  font-size: 14px;
  color: var(--primary-light);
}
.card__weather {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 12px;
}
.card__weather__temp {
  font-size: 30px;
}
.card__weather__icon {
  animation: move 1s infinite alternate ease-in-out;
}

@keyframes move {
  to {
    transform: translateY(-10px);
  }
}
</style>
</head>
<body>
  <div class="card">
		<div class="card__info">
			<p class="card__info__place">New Delhi</p>
			<p class="card__info__time">06:20 AM</p>
			<p class="card__info__date">Novemaber 10.2020 | Wednesday</p>
		</div>
		<div class="card__weather">
			<svg width="34" class="card__weather__icon" height="24" viewBox="0 0 34 24" fill="none"
				xmlns="http://www.w3.org/2000/svg">
				<path
					d="M31.7764 13.3718C30.8073 12.1841 29.5779 11.4201 28.0897 11.0793C28.5632 10.3633 28.7992 9.57921 28.7992 8.72709C28.7992 7.52249 28.3664 6.49418 27.5014 5.64182C26.6361 4.78976 25.592 4.36354 24.3688 4.36354C23.2612 4.36354 22.3034 4.71584 21.496 5.42044C20.8155 3.80682 19.7334 2.50001 18.251 1.50001C16.7682 0.500241 15.1152 0 13.2921 0C10.8461 0 8.75757 0.852482 7.02679 2.55703C5.29589 4.26116 4.43071 6.31818 4.43071 8.72727C4.43071 8.89777 4.44229 9.1419 4.46532 9.46011C3.12694 10.0738 2.04801 11.0027 1.22884 12.2473C0.409735 13.4913 0 14.8637 0 16.3637C0 18.4659 0.758789 20.2642 2.27594 21.7583C3.79316 23.2528 5.61918 24 7.75375 24H26.5847C28.4191 24 29.9853 23.3603 31.2836 22.0823C32.5816 20.804 33.2308 19.2615 33.2308 17.4545C33.2306 15.9206 32.7457 14.5591 31.7764 13.3718Z"
					fill="#567DF4" />
			</svg>

			<p class="card__weather__temp">18Β° C</p>
		</div>
	</div>
</body>
</html>

9. CSS Weather report card UX

Made by UI Gems. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
<style>
body {
	font-family: segoe ui;
	background-color: #fff;
}
.container {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100vh;
}
.weather-card {
	height: 450px;
	width: 300px;
	border-radius: 30px;
	box-shadow:15px 20px 85px #d7c4bd;
	overflow: hidden;
}
.weather-card .image-section {
	height: 57%;
	background-image: url();
    background-position: -300px -60px;
    position: relative;
    background-size: 90%;
}
.weather-card .image-section .weather {
	height: 60px;
    width: 60px;
    position: absolute;
    top: 20px;
    right: 20px;
    display: inline-block;
    background: url() -170px -76px no-repeat;
    background-size: 240px;
}
.weather-card .image-section .type {
	text-transform: uppercase;
    color: #ffffff;
    position: absolute;
    bottom: 60px;
    right: 20px;
    z-index: 9;
    font-weight: 700;
}
.layer {
	height: 100%;
	width: 100%;
	background: linear-gradient(141deg,#f9ebe2 30%, #e7c3bb 75%);
	position: absolute;
    opacity: 0.6;
}
.weather-card .info-section {
	height: 47%;
	background: #fff;
	position: relative;
	display: flex;
    justify-content: center;
    align-items: center;
}
.layer-1 {
	position: absolute;
    height: 400px;
    width: 290px;
    border-radius: 100%;
    background-color: rgba(255,255,255,0.5);
    top: -40px;
    left: -120px;
}
.layer-2 {
	position: absolute;
	height: 150px;
	width: 210px;
	border-radius: 100%;
	background-color: rgba(255,255,255,0.5);
	top: -50px;
	left: 160px;
}
.layer-3 {
	position: absolute;
	height: 150px;
	width: 230px;
	border-radius: 100%;
	background-color: rgba(255,255,255,0.5);
	top: -27px;
	left: 100px;
}
.wave {
	position: absolute;
    height: 31px;
    background-image: url();
    background-position: -110px 0px;
    background-size: 100%;
    width: 100%;
    top: -30px;
}
.contents {
	z-index: 9;
    text-align: center;
}
.contents h1 {
	margin: 0;
    font-size: 90px;
    line-height: 50px;
    font-weight: 100;
    position: relative;
    color:#868383;
}
.contents h1 .deg {
	position: absolute;
	top:-15px;-webkit-animation:spin 4s linear infinite;
    -moz-animation:spin 4s linear infinite;
    animation:spin 4s linear infinite;
}
.contents h3 {
	margin-bottom: 5px;
    margin-top: 40px;
    font-weight: 500;
    color: #908e8e;
    font-size: 16px;
}
.contents small {
    color:#908e8e;
}
@-moz-keyframes spin { 
  	from {transform: rotateY(0deg);}
	to {transform: rotateY(359deg);}
}
@-webkit-keyframes spin { 
  	from {transform: rotateY(0deg);}
	to {transform: rotateY(359deg);}
}
@keyframes spin {
  	from {transform: rotateY(0deg);}
	to {transform: rotateY(359deg);}
}
</style>
</head>
<body>
	<div>
		<div class="weather-card">
			<div class="image-section">
				<div class="layer"></div>
				<div class="weather"></div>
				<small class="type">rainy</small>
			</div>
			<div class="info-section">
				<div class="wave"></div>
				<div class="layer-1"></div>
				<div class="layer-2"></div>
				<div class="layer-3"></div>
				<div class="contents">
					<h1>18<span class="deg">&deg;</span></h1>
					<h3>NEW YORK</h3>
					<small>MONDAY | JUNE 28 | 12:15</small>
				</div>
			</div>
		</div>
	</div>
</body>
</html>

10. Weather Card Medellin City

Made by Jorge Ossa. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css"> 
<style>
@import url("https://fonts.googleapis.com/css?family=IBM+Plex+Sans:200,300,400,500,700");
.main {
  width: 100vw;
  height: 100vh;
  background-color: #ccc;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "IBM Plex Sans", sans-serif;
}

.card {
  width: 300px;
  height: 500px;
  background-color: #fff;
  border-radius: 10px;
  position: relative;
  padding: 1rem;
  box-shadow: rgba(0, 0, 0, 0.3) 3px 3px 9px;
}
.card__image {
  max-width: 100%;
  width: 340px;
  position: absolute;
  top: -5%;
  right: 0;
}
.card__data {
  position: absolute;
  bottom: 1.5rem;
}

.data__temp {
  font-size: 4rem;
}
.data__description {
  font-size: 1.5rem;
  letter-spacing: 0.5rem;
  margin-bottom: 0.5rem;
  text-transform: uppercase;
}
.data__date {
  font-size: 1rem;
  font-weight: 200;
}
</style>
</head>
<body>
  <div class="main">
  <div class="card">
    <div class="card__image"><?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="100%" height="100%" viewBox="0 0 328 359" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:10;"><g><path d="M166.461,328.94c89.086,13.251 161.059,26.387 160.624,29.316c-0.436,2.93 -73.117,-5.45 -162.203,-18.7c-89.086,-13.25 -161.06,-26.386 -160.624,-29.316c0.436,-2.929 73.116,5.45 162.203,18.7Z" style="fill:#e8e8e8;"/><path d="M48.303,196.992l38.081,118.126l-0.644,0.188l-38.081,-118.126l0.644,-0.188Z" style="fill:#a8a8a8;"/><path d="M63.28,194.473l8.158,123.316l-0.674,0.036l-8.158,-123.316l0.674,-0.036Z" style="fill:#a8a8a8;"/><path d="M75.346,195.63l0.678,0.096l-17.325,120.943l-0.678,-0.095l17.325,-120.944Z" style="fill:#a8a8a8;"/><path d="M45.355,312.078l-0.631,-0.233l43.964,-111.626l0.63,0.236l-43.963,111.623Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M100.043,207.466l0.624,0.402l-66.666,96.966l-0.624,-0.402l66.666,-96.966Z" style="fill:#a8a8a8;"/><path d="M109.639,217.084l0.526,0.54l-85.759,77.588l-0.525,-0.54l85.758,-77.588Z" style="fill:#a8a8a8;"/><path d="M17.871,285.409l-0.354,-0.553l98.652,-57.966l0.356,0.556l-98.654,57.963Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M12.568,272.763l-0.203,-0.62l109.109,-32.606l0.206,0.62l-109.112,32.606Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M123.654,249.17l0.102,0.761l-113.366,13.199l-0.102,-0.762l113.366,-13.198Z" style="fill:#a8a8a8;"/><path d="M9.652,252.777l0.038,-0.648l114.703,7.393l-0.041,0.648l-114.7,-7.393Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M11.083,239.89l112.065,31.896l-0.186,0.622l-112.065,-31.896l0.186,-0.622Z" style="fill:#a8a8a8;"/><path d="M14.533,228.791l105.289,54.147l-0.313,0.572l-105.289,-54.147l0.313,-0.572Z" style="fill:#a8a8a8;"/><path d="M19.309,219.654l95.839,72.48l-0.413,0.51l-95.839,-72.481l0.413,-0.509Z" style="fill:#a8a8a8;"/><path d="M26.162,210.928l82.225,90.013l-0.504,0.428l-82.226,-90.013l0.505,-0.428Z" style="fill:#a8a8a8;"/><path d="M34.441,203.858l65.738,104.248l-0.575,0.335l-65.739,-104.249l0.576,-0.334Z" style="fill:#a8a8a8;"/><path d="M70.998,195.568c-13.625,-1.53 -27.041,2.432 -37.773,11.157c-12.63,10.267 -20.42,26.213 -21.374,43.75c-1.839,33.813 21.773,64.142 52.633,67.609c13.628,1.531 27.042,-2.431 37.776,-11.158c12.627,-10.268 20.415,-26.212 21.371,-43.748c1.839,-33.814 -21.772,-64.143 -52.633,-67.61m-6.804,125.095c-32.259,-3.624 -56.943,-35.18 -55.031,-70.345c0.993,-18.246 9.125,-34.861 22.316,-45.584c11.303,-9.189 25.439,-13.359 39.809,-11.745c32.257,3.624 56.946,35.18 55.031,70.345c-0.993,18.246 -9.124,34.859 -22.313,45.582c-11.303,9.189 -25.442,13.362 -39.812,11.747" style="fill:#282727;fill-rule:nonzero;"/><path d="M72.212,257.853c-0.198,3.617 -3.038,6.249 -6.35,5.877c-3.311,-0.372 -5.835,-3.606 -5.637,-7.223c0.196,-3.617 3.039,-6.249 6.35,-5.877c3.309,0.372 5.835,3.607 5.637,7.223" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M168.548,251.64l-27.161,-9.859c-1.72,-0.623 -3.63,0.211 -4.262,1.865c-0.632,1.654 0.249,3.503 1.969,4.128l27.162,9.857c1.718,0.623 3.627,-0.212 4.26,-1.866c0.634,-1.654 -0.247,-3.499 -1.968,-4.125" style="fill:#3432a5;fill-rule:nonzero;"/><path d="M231.604,224.013l37.175,118.288l-0.645,0.183l-37.176,-118.287l0.646,-0.184Z" style="fill:#a8a8a8;"/><path d="M246.599,220.932l7.21,124.604l-0.67,0.03l-7.21,-124.603l0.67,-0.031Z" style="fill:#a8a8a8;"/><path d="M241.065,344.85l-0.666,-0.096l18.274,-123.106l0.666,0.099l-18.274,123.103Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M271.889,225.795l0.715,0.264l-44.755,114.645l-0.715,-0.264l44.755,-114.645Z" style="fill:#a8a8a8;"/><path d="M216.466,333.733l-0.57,-0.355l67.372,-100.611l0.568,0.353l-67.37,100.613Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M206.946,324.326l-0.471,-0.467l86.315,-81.685l0.473,0.464l-86.317,81.688Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M200.491,314.626l-0.373,-0.543l99.127,-62.209l0.373,0.543l-99.127,62.209Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M195.29,302.005l-0.229,-0.613l109.386,-36.9l0.231,0.614l-109.388,36.899Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M193.169,292.209l-0.109,-0.643l113.508,-17.276l0.109,0.643l-113.508,17.276Z" style="fill:#a8a8a8;fill-rule:nonzero;"/><path d="M307.215,284.632l-0.018,0.743l-114.673,-3.509l0.018,-0.743l114.673,3.509Z" style="fill:#a8a8a8;"/><path d="M194.026,268.772l111.847,28.326l-0.165,0.627l-111.848,-28.326l0.166,-0.627Z" style="fill:#a8a8a8;"/><path d="M197.569,257.409l104.897,51.103l-0.299,0.578l-104.897,-51.103l0.299,-0.578Z" style="fill:#a8a8a8;"/><path d="M202.42,247.99l95.304,70.005l-0.407,0.517l-95.304,-70.006l0.407,-0.516Z" style="fill:#a8a8a8;"/><path d="M209.343,238.912l81.552,88.244l-0.501,0.43l-81.552,-88.244l0.501,-0.43Z" style="fill:#a8a8a8;"/><path d="M217.682,231.458l64.95,103.25l-0.574,0.333l-64.951,-103.25l0.575,-0.333Z" style="fill:#a8a8a8;"/><path d="M256.087,221.898c-0.569,-0.064 -1.14,-0.119 -1.716,-0.162c-13.433,-1.053 -26.742,3.318 -37.481,12.302c-12.981,10.866 -21.059,27.442 -22.165,45.48c-2.099,34.293 21.262,64.114 52.07,66.566c13.431,1.053 26.74,-3.318 37.479,-12.302c12.981,-10.866 21.059,-27.442 22.165,-45.48c2.059,-33.65 -20.398,-63.039 -50.352,-66.404m-11.297,126.604c-31.372,-3.525 -54.896,-34.128 -52.751,-69.159c1.149,-18.726 9.557,-35.955 23.076,-47.27c11.284,-9.444 25.296,-14.034 39.453,-12.927c32.392,2.526 56.742,33.631 54.555,69.331c-1.144,18.726 -9.555,35.955 -23.076,47.27c-11.284,9.444 -25.292,14.035 -39.448,12.925c-0.605,-0.047 -1.211,-0.103 -1.809,-0.17" style="fill:#282727;fill-rule:nonzero;"/><path d="M255.047,284.792c-0.226,3.671 -3.089,6.436 -6.398,6.177c-3.31,-0.26 -5.807,-3.443 -5.582,-7.117c0.226,-3.669 3.089,-6.434 6.398,-6.175c3.307,0.257 5.806,3.444 5.582,7.115" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M201.522,176.009c-0.223,5.203 -2.95,9.986 -6.141,14.17c-10.446,13.705 -26.219,23.044 -36.2,37.069c-0.816,1.143 -1.617,2.408 -1.59,3.799c0.042,2.32 2.273,3.986 4.283,5.279c4.082,2.629 8.162,5.257 12.246,7.885c1.21,0.781 2.529,1.708 2.796,3.086c0.34,1.763 -1.332,3.401 -3.151,3.763c-1.817,0.364 -3.689,-0.19 -5.462,-0.745c-10.341,-3.236 -20.625,-6.642 -30.843,-10.22c-0.797,-0.281 -1.635,-0.59 -2.156,-1.236c-0.962,-1.193 -0.422,-2.905 0.192,-4.284c5.636,-12.688 14.157,-24.029 19.635,-36.785c1.901,-4.422 3.431,-9.009 5.786,-13.22c5.715,-10.228 41.725,-34.826 40.605,-8.561" style="fill:#ed8b7e;fill-rule:nonzero;"/><path d="M116.785,306.788l-15.794,-12.71c-2.518,-2.027 -6.153,-2.08 -8.697,-0.124l-1.023,0.783c-3.135,2.41 -3.447,6.905 -0.67,9.738l13.641,13.931c2.301,2.347 6.002,2.78 8.783,1.028l3.177,-2.004c3.849,-2.428 4.145,-7.776 0.583,-10.642" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M158.111,244.859c2.06,0.939 4.16,1.889 6.414,2.178c2.252,0.289 4.723,-0.184 6.296,-1.751c0.687,-0.69 1.309,-1.628 2.298,-1.696c0.443,-0.032 0.877,0.124 1.276,0.305c1.589,0.707 3.032,1.858 3.732,3.404c0.694,1.547 0.506,3.512 -0.73,4.69c-1.95,1.852 -5.198,1.055 -7.784,0.141c-6.144,-2.177 -12.289,-4.353 -18.433,-6.527c-5.487,-1.943 -10.984,-3.891 -16.215,-6.41c-1.32,-0.635 1.696,-3.506 2.609,-3.549c1.82,-0.087 4.87,2.077 6.515,2.825c4.674,2.131 9.348,4.259 14.022,6.39" style="fill:#111;fill-rule:nonzero;"/><path d="M109.526,307.997c2.896,3.033 6.829,6.304 10.89,5.104c0.719,-0.216 2.608,-1.382 3.316,-1.126c0.668,0.238 1.02,0.922 1.422,1.489c0.662,0.932 1.623,1.699 1.988,2.77c0.757,2.207 -2.718,5.279 -5.116,5.427c-2.398,0.149 -4.636,-1.12 -6.644,-2.411c-9.952,-6.411 -18.672,-14.597 -25.587,-24.019c-1.087,-1.479 -2.144,-3.022 -2.65,-4.763c-1.174,-4.029 2.025,-10.871 6.919,-10.279c1.826,11.297 7.468,19.441 15.462,27.808" style="fill:#111;fill-rule:nonzero;"/><path d="M1.899,248.774c2.116,-39.699 33.835,-68.509 70.843,-64.352c37.011,4.158 65.296,39.71 63.18,79.408" style="fill:none;stroke:#5449c1;stroke-width:2px;"/><path d="M18.81,204.763l48.478,52.536l49.722,-51.951" style="fill:none;stroke:#5449c1;stroke-width:2px;stroke-linecap:butt;stroke-linejoin:miter;"/><path d="M187.444,275.067c2.019,-37.865 32.274,-65.347 67.575,-61.381c35.301,3.966 62.282,37.877 60.263,75.742" style="fill:none;stroke:#5449c1;stroke-width:2px;"/><path d="M146.269,249.303l-5.822,27.868c-0.261,1.249 0.504,2.494 1.773,2.875c1.442,0.437 2.953,-0.409 3.269,-1.828l6.276,-28.298l-5.496,-0.617Z" style="fill:#3432a5;fill-rule:nonzero;"/><path d="M224.331,155.219c-1.262,-0.142 -2.287,-1.127 -2.393,-2.391c-0.122,-1.431 0.985,-2.673 2.468,-2.779l20.037,-1.395l-0.482,-0.229c-1.338,-0.635 -1.899,-2.194 -1.249,-3.478c0.643,-1.285 2.257,-1.813 3.595,-1.178l9.389,4.46c1.095,0.52 1.699,1.677 1.476,2.825c-0.226,1.15 -1.222,2.006 -2.43,2.093l-29.902,2.084c-0.172,0.011 -0.348,0.006 -0.509,-0.012" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M143.269,279.491c-0.086,-0.009 -0.171,-0.021 -0.256,-0.04c-0.853,-0.177 -1.567,-0.738 -1.914,-1.506l-25.767,-84.11l-6.954,-2.251c-1.448,-0.337 -2.35,-1.74 -2.012,-3.134c0.34,-1.393 1.795,-2.249 3.233,-1.913l8.265,2.555c0.821,0.193 1.508,0.745 1.851,1.491l24.785,81.969l77.696,-68.442l-7.883,-45.801c-0.171,-0.975 0.249,-1.953 1.079,-2.522l2.965,-2.039l-23.678,-5.934l-25,-1.461c-1.54,-0.11 -2.627,-1.32 -2.548,-2.749c0.076,-1.432 1.344,-2.521 2.828,-2.435l25.265,1.479c0.178,0.01 0.346,0.038 0.515,0.079l29.543,7.4c1.013,0.255 1.789,1.052 1.985,2.046c0.198,0.992 -0.22,2.002 -1.069,2.585l-6.301,4.334l7.847,45.596c0.148,0.865 -0.164,1.74 -0.83,2.327l-81.53,71.82c-0.573,0.507 -1.346,0.743 -2.115,0.656" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M157.618,278.483c-0.438,8.196 -6.987,14.149 -14.628,13.29c-7.644,-0.859 -13.484,-8.202 -13.049,-16.399c0.438,-8.199 6.987,-14.149 14.631,-13.291c7.641,0.859 13.483,8.201 13.046,16.4" style="fill:#111;fill-rule:nonzero;"/><path d="M144.861,277.174c-0.047,0.858 -0.732,1.481 -1.533,1.391c-0.8,-0.09 -1.411,-0.859 -1.367,-1.716c0.047,-0.858 0.732,-1.481 1.533,-1.391c0.801,0.09 1.411,0.859 1.367,1.716" style="fill:#111;fill-rule:nonzero;"/><path d="M139.499,276.094l-30.552,22.33l2.96,4.232l30.825,-22.462c0.95,-0.694 1.299,-1.916 0.854,-2.989c-0.659,-1.579 -2.69,-2.132 -4.087,-1.111" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M74.865,153.026c-3.463,0.462 -6.841,2.957 -7.131,6.317c-0.413,4.713 4.782,7.897 9.235,9.921l17.883,8.133c2.541,1.158 5.633,2.294 7.992,0.855c1.076,-0.655 1.782,-1.754 2.264,-2.89c2.124,-4.994 0.323,-11.084 -3.654,-14.933c-5.138,-4.976 -19.399,-8.361 -26.589,-7.403" style="fill:#ec6717;fill-rule:nonzero;"/><path d="M149.931,201.864c0,0 11.273,8.232 6.943,18.627c-4.33,10.395 -41.042,47.621 -45.071,59.355c-4.029,11.735 12.14,32.703 12.14,32.703c0,0 -2.897,9.686 -13.88,-1.122c-10.985,-10.811 -19.856,-28.349 -19.856,-28.349c0,0 8.307,-5.595 11.553,-14.372c2.668,-7.213 10.013,-28.905 19.526,-40.448c4.546,-5.518 7.605,-12.058 8.397,-19.089l0.001,-0.002l-13.01,-8.862l33.257,1.559Z" style="fill:#f6a091;fill-rule:nonzero;"/><path d="M233.075,137.488c2.812,1.262 6.531,-0.64 9.558,0.006c3.961,0.844 11.581,6.639 9.521,8.945c-1.905,-0.214 -4.623,-0.132 -6.129,1.001c-0.617,0.461 -1.115,1.134 -1.87,1.324c-0.418,0.103 -0.858,0.044 -1.288,-0.018c-3.076,-0.437 -6.231,-0.896 -8.962,-2.348c-0.614,-0.324 -1.208,-0.704 -1.696,-1.194c-0.502,-0.505 -6.507,-4.625 -8.764,-5.861c-1.25,-0.688 -1.299,-2.189 -1.033,-3.547c0.151,-0.765 1.736,-3.485 2.531,-3.625c3.342,-0.592 5.4,4.093 8.132,5.317" style="fill:#ed8b7e;fill-rule:nonzero;"/><path d="M176.508,7.491c2.481,1.366 4.902,3.017 6.418,5.352c1.513,2.337 1.937,5.494 0.409,7.797c-0.577,0.87 -1.392,1.571 -1.997,2.426c-1.697,2.39 -1.518,5.542 -1.388,8.448c0.127,2.908 0.018,6.133 -2.046,8.238c-1.096,1.12 -2.639,1.787 -3.633,2.992c-1.857,2.248 -1.244,5.497 -1.711,8.343c-0.412,2.52 -1.715,4.801 -2.996,7.025c-2.286,3.965 -4.574,7.933 -7.054,11.788c-1.141,1.771 -2.37,3.569 -4.162,4.734c-2.272,1.477 -5.143,1.754 -7.88,1.987c-2.85,0.244 -6.111,0.35 -8.139,-1.615c-1.291,-1.251 -1.758,-3.076 -1.976,-4.824c-1.089,-8.671 2.59,-17.182 3.1,-25.889c0.274,-4.672 -0.342,-9.52 1.314,-13.902c0.931,-2.467 2.536,-4.633 4.12,-6.763l10.789,-14.51c1.481,-1.991 4.276,-6.205 7.29,-5.855c1.295,0.15 2.972,1.208 4.177,1.69c1.84,0.737 3.635,1.584 5.365,2.538" style="fill:#111;fill-rule:nonzero;"/><path d="M149.339,129.744c0.722,1.589 1.489,3.197 2.701,4.48c1.087,1.147 2.479,1.98 3.856,2.789c12.491,7.341 25.36,14.079 38.541,20.183c2.176,1.007 4.585,2.238 5.29,4.463c0.803,2.542 -1.079,5.188 -3.368,6.644c-2.287,1.456 -5.015,2.185 -7.284,3.667c-5.594,3.651 -7.119,10.76 -9.604,16.822c-5.742,14.026 -19.127,24.837 -34.463,27.872c-15.335,3.034 -32.164,-1.793 -43.405,-12.425c-5.396,-5.105 -9.478,-11.339 -13.367,-17.587c-2.785,-4.477 -5.522,-9.035 -7.279,-13.971c-4.747,-13.319 -1.941,-27.875 1.388,-41.522c1.027,-4.217 2.19,-8.593 5.126,-11.854c2.676,-2.978 6.524,-4.686 10.25,-6.311c4.533,-1.973 9.063,-3.949 13.595,-5.923c2.587,-1.128 5.192,-2.262 7.944,-2.961c2.354,-0.601 4.786,-0.875 7.207,-1.145c2.59,-0.29 9.428,-2.322 11.728,-1.32c2.545,1.105 2.59,4.699 3.43,7.508c2.097,7.014 4.677,13.896 7.714,20.591" style="fill:#7167cb;fill-rule:nonzero;"/><path d="M154.558,51.46c5.397,-1.135 11.007,1.832 14.589,5.926c3.585,4.096 5.621,9.197 7.96,14.052c3.879,8.056 8.748,15.673 14.473,22.643c5.723,6.968 12.272,13.262 18.804,19.539c6.443,6.188 12.885,12.379 19.328,18.567c-1.874,2.927 -5.733,6.596 -8.405,8.872c-6.863,-4.767 -14.412,-9.784 -20.968,-14.939c-10.084,-7.93 -20.31,-17.11 -23.385,-29.278c-4.203,-2.917 -7.909,-6.575 -11.311,-10.341c-5.285,6.183 -10.1,13.274 -14.341,20.166c-0.963,1.569 -1.913,3.19 -2.274,4.984c-0.449,2.23 0.045,4.526 0.468,6.767c0.995,5.268 1.591,10.606 1.784,15.952c-4.803,-8.772 -9.678,-17.742 -11.322,-27.51c-1.643,-9.771 0.496,-20.661 7.986,-27.348c1.563,-1.397 3.337,-2.593 4.679,-4.189c2.624,-3.115 3.305,-7.432 2.755,-11.432c-0.552,-4 0.818,-8.711 -0.82,-12.431" style="fill:#efc03c;fill-rule:nonzero;"/><path d="M178.846,11.238c2.035,3.032 12.825,20.026 -4.328,38.041c-0.933,0.977 -2.88,0.62 -4.212,0.248c-1.332,-0.372 -2.548,-1.051 -3.75,-1.721c-1.749,-0.973 -3.496,-1.951 -5.247,-2.926c-1.382,2.723 -3.09,5.299 -4.473,8.022c3.902,6.926 4.112,16.412 1.495,23.828c-0.655,1.857 -1.549,3.699 -3.068,4.996c-3.969,-3.93 -5.168,-9.68 -5.846,-15.106c-0.677,-5.428 -1.083,-11.108 -3.973,-15.831c2.402,-3.74 4.877,-7.689 7.698,-11.142c2.588,-3.169 -2.552,-9.845 -2.181,-13.874c0.371,-4.03 1.635,-8.662 4.221,-11.832c4.168,-5.111 17.209,-4.721 23.664,-2.703" style="fill:#f6a091;fill-rule:nonzero;"/><path d="M122.594,54.95c-2.168,3.498 -3.607,7.406 -5.966,10.787c-3.079,4.407 -7.573,7.71 -10.996,11.87c-2.645,3.211 -4.615,6.882 -6.492,10.561c-3.735,7.329 -7.176,14.799 -10.308,22.39c-0.384,0.931 -0.77,1.915 -0.622,2.912c0.227,1.533 1.625,2.622 2.915,3.55c6.797,4.883 13.598,9.767 20.395,14.65c1.297,0.931 2.759,1.91 4.359,1.756c1.728,-0.169 2.984,-1.591 4.049,-2.91c7.579,-9.377 15.158,-18.755 22.737,-28.132c10.154,10.414 19.436,21.616 27.729,33.46c3.277,-2.279 7.019,-3.935 10.956,-4.848c-4.847,-10.1 -9.697,-20.2 -14.547,-30.3c-1.273,-2.649 -2.555,-5.319 -4.311,-7.7c-1.888,-2.558 -4.294,-4.743 -6.096,-7.358c-5.592,-8.103 -4.555,-18.71 -7.366,-28.041c-1.094,-3.637 -2.922,-7.26 -6.103,-9.49c-6.951,-4.872 -16.637,0.876 -20.333,6.843" style="fill:#fad34f;fill-rule:nonzero;"/><path d="M158.419,23.824c0.484,-1.816 -0.866,-3.905 -2.776,-4.295c-0.461,-0.094 -0.949,-0.099 -1.392,0.045c-1.019,0.327 -1.615,1.352 -1.864,2.359c-0.702,2.822 0.297,6.752 3.528,7.361c0.173,-0.155 0.204,1.206 0.326,1.557c1.061,5.739 -2.406,10.004 -5.827,14.774c-1.891,2.64 -4.232,5.287 -7.468,6.054c-2.14,0.507 -4.393,0.12 -6.599,0.193c-7.346,0.24 -13.944,6.321 -14.527,13.383c-0.094,1.129 -0.057,2.297 -0.478,3.353c-1.275,3.181 -5.689,3.638 -8.546,5.645c-1.586,1.114 -2.693,2.736 -4.112,4.042c-1.422,1.305 -3.418,2.323 -5.309,1.778c-2.102,-0.604 -3.223,-2.992 -2.971,-5.084c0.25,-2.093 1.544,-3.914 2.931,-5.534c3.957,-4.626 9.036,-8.459 11.87,-13.798c1.606,-3.034 2.45,-6.482 4.639,-9.149c3.58,-4.362 10.113,-5.836 13.35,-10.44c3.159,-4.491 2.5,-11.055 6.515,-14.852c1.801,-1.704 4.305,-2.577 6.119,-4.266c4.103,-3.821 3.752,-10.83 8.203,-14.272c2.586,-1.999 6.271,-2.256 9.491,-1.431c3.224,0.823 6.091,2.593 8.878,4.364c3.56,2.261 7.531,5.419 7.069,9.484c-0.195,1.713 -1.193,3.245 -2.374,4.534c-4.311,4.708 -12.356,5.868 -18.676,4.195" style="fill:#111;fill-rule:nonzero;"/><path d="M252.165,291.046c-1.029,-0.116 -1.944,-0.802 -2.279,-1.817l-27.365,-83.372c-0.449,-1.372 0.337,-2.824 1.754,-3.246c1.421,-0.426 2.929,0.348 3.378,1.715l27.365,83.375c0.451,1.37 -0.334,2.822 -1.751,3.246c-0.367,0.11 -0.745,0.139 -1.102,0.099" style="fill:#5449c1;fill-rule:nonzero;"/><path d="M226.434,159.48l39.813,-3.661c5.253,-0.485 9.811,3.559 9.755,8.651l-0.368,32.376c-0.045,4.069 -3.064,7.515 -7.214,8.231l-30.169,5.208c-4.55,0.784 -8.989,-1.956 -10.174,-6.285l-9.282,-33.921c-1.387,-5.071 2.241,-10.104 7.639,-10.599" style="fill:#ec6717;fill-rule:nonzero;"/><path d="M263.906,165.573c0.974,-1.65 1.823,-3.444 1.859,-5.349c0.033,-1.906 -0.927,-3.939 -2.73,-4.735c-1.801,-0.794 -4.335,0.171 -4.652,2.049c0.088,-2.153 -0.193,-4.423 -1.474,-6.199c-1.281,-1.776 -3.79,-2.863 -5.841,-2.025c-2.052,0.84 -2.797,3.943 -1.012,5.253c-1.199,-1.982 -3.193,-3.506 -5.465,-4.184c-1.575,-0.468 -3.491,-0.454 -4.621,0.687c-1.131,1.145 -0.582,3.565 1.062,3.661c-4.783,-3.782 -11.561,-5.067 -17.434,-3.306c-1.019,0.306 -2.115,0.794 -2.494,1.758c-0.547,1.381 0.823,2.916 2.334,3.198c1.511,0.283 3.029,-0.295 4.445,-0.862c-3.707,0.326 -8.09,1.1 -9.549,4.392c-0.178,0.4 -0.3,0.84 -0.214,1.268c0.172,0.873 1.12,1.383 1.999,1.658c2.588,0.807 5.487,0.612 7.913,-0.539c-1.974,0.499 -4.21,1.641 -5.63,3.044c-0.254,0.254 -0.514,0.552 -0.516,0.908c-0.01,0.751 1.013,1.05 1.792,1.044c1.437,-0.01 2.867,-0.268 4.207,-0.757c-0.553,1.013 -1.019,2.093 -1.193,3.225c-0.177,1.137 0.099,2.405 0.993,3.172c1.543,1.318 3.933,0.578 5.804,-0.227c0.717,-0.311 1.492,-0.673 1.815,-1.363c-1.74,2.416 -0.198,6.202 2.595,7.433c1.324,0.581 2.916,0.686 4.199,0.042c1.28,-0.643 2.125,-2.118 1.782,-3.475c0.161,2.233 2.755,3.908 4.778,5.026c0.724,0.399 1.505,0.772 2.336,0.772c1.521,-0.006 2.74,-1.274 3.297,-2.636c0.557,-1.359 0.648,-2.856 1.072,-4.264c1.726,1.059 3.545,1.799 5.528,2.248c1.57,0.356 3.366,0.465 4.631,-0.483c1.264,-0.947 1.318,-3.281 -0.2,-3.81c2.177,0.453 4.941,0.682 6.107,-1.129c0.648,-1.003 0.503,-2.36 -0.131,-3.382c-0.634,-1.022 -1.683,-1.752 -2.787,-2.279c-2.059,-0.989 -2.574,-0.844 -4.605,0.166" style="fill:#70aa55;fill-rule:nonzero;"/><path d="M268.421,150.999c0.166,-0.906 0.005,-2.033 -0.852,-2.444c-1.228,-0.59 -2.448,0.75 -3.105,1.899c0.347,-1.304 0.693,-2.698 0.231,-3.974c-0.462,-1.277 -2.085,-2.258 -3.292,-1.586c-0.568,0.314 -0.907,0.9 -1.208,1.458c-0.742,1.37 -1.449,2.968 -0.871,4.419c-0.972,-1.077 -2.361,-1.9 -3.837,-1.875c-1.473,0.026 -2.953,1.095 -3.065,2.511c-0.149,1.95 1.999,3.252 3.837,4.087c-1.398,0.61 -2.474,1.975 -2.477,3.461c-0.004,1.488 1.223,2.957 2.759,3.077c1.539,0.12 3.034,-1.351 2.699,-2.805c-0.348,1.198 0.348,2.533 1.435,3.212c1.084,0.681 2.471,0.787 3.737,0.554c1.942,-0.358 3.928,-1.913 3.617,-3.804c-0.264,-1.604 -2.611,-2.042 -2.684,-3.355c-0.071,-1.306 2.769,-3.19 3.076,-4.835" style="fill:#efc03c;fill-rule:nonzero;"/><path d="M263.85,152.964c-0.193,-0.273 -0.434,-0.527 -0.746,-0.665c-0.423,-0.186 -0.93,-0.138 -1.346,0.055c-0.413,0.194 -0.75,0.517 -1.03,0.873c-0.431,0.547 -0.747,1.197 -0.795,1.887c-0.053,0.689 0.193,1.414 0.731,1.876c0.467,0.397 1.13,0.567 1.734,0.441c2.006,-0.415 2.481,-3.004 1.452,-4.467" style="fill:#fefbe3;fill-rule:nonzero;"/><path d="M242.221,163.425c0.935,-0.175 1.964,-0.724 2.037,-1.642c0.108,-1.312 -1.641,-1.927 -2.996,-2.1c1.387,-0.158 2.862,-0.353 3.923,-1.225c1.055,-0.873 1.392,-2.682 0.294,-3.525c-0.519,-0.395 -1.208,-0.487 -1.862,-0.558c-1.598,-0.17 -3.404,-0.232 -4.588,0.811c0.675,-1.262 0.948,-2.802 0.371,-4.116c-0.576,-1.314 -2.162,-2.257 -3.572,-1.847c-1.936,0.566 -2.389,2.96 -2.504,4.909c-1.113,-1.036 -2.834,-1.509 -4.265,-0.977c-1.436,0.532 -2.398,2.161 -1.937,3.582c0.462,1.423 2.442,2.236 3.72,1.412c-1.286,0.118 -2.312,1.222 -2.561,2.441c-0.249,1.219 0.171,2.499 0.868,3.552c1.074,1.617 3.318,2.834 5.025,1.877c1.448,-0.812 0.993,-3.076 2.229,-3.614c1.233,-0.535 4.116,1.337 5.818,1.02" style="fill:#fad34f;fill-rule:nonzero;"/><path d="M238.613,160.032c0.189,-0.271 0.343,-0.581 0.36,-0.908c0.023,-0.445 -0.213,-0.882 -0.556,-1.186c-0.343,-0.304 -0.784,-0.489 -1.229,-0.611c-0.69,-0.19 -1.436,-0.24 -2.121,-0.038c-0.68,0.206 -1.29,0.687 -1.531,1.334c-0.212,0.561 -0.125,1.219 0.224,1.714c1.151,1.649 3.824,1.147 4.853,-0.305" style="fill:#fefbe3;fill-rule:nonzero;"/><path d="M257.509,156.678c0.963,-0.671 2.243,-1.136 3.337,-0.674c1.632,0.685 1.796,2.82 1.703,4.528c0.63,-1.523 2.45,-2.506 4.124,-2.175c1.671,0.334 2.97,1.995 2.777,3.626c-0.193,1.632 -1.905,2.957 -3.596,2.731c1.337,0.444 2.476,1.519 2.806,2.844c0.33,1.324 -0.248,2.848 -1.472,3.519c-1.223,0.667 -2.997,0.294 -3.71,-0.885c0.345,1.032 0.598,2.119 0.46,3.193c-0.138,1.074 -0.731,2.133 -1.724,2.631c-1.364,0.683 -3.166,0.093 -4.133,-1.074c-0.973,-1.168 -1.231,-2.757 -1.087,-4.236c-0.343,0.979 -1.222,1.764 -2.265,2.017c-1.041,0.256 -2.209,-0.028 -3.011,-0.73c-0.386,-0.342 -0.698,-0.802 -0.719,-1.306c-0.021,-0.452 0.193,-0.877 0.444,-1.255c0.538,-0.816 1.277,-1.503 2.141,-1.996c-1.022,-0.036 -2.066,-0.196 -2.955,-0.693c-0.889,-0.496 -1.596,-1.378 -1.644,-2.364c-0.057,-1.198 0.879,-2.283 2.024,-2.742c0.82,-0.326 1.596,-0.275 2.458,-0.329c1.168,-0.071 0.878,0.171 1.379,-0.755c0.818,-1.521 1.094,-2.787 2.663,-3.875" style="fill:#fefbe3;fill-rule:nonzero;"/><path d="M182.434,135.928c0.822,0.893 1.976,1.417 3.066,1.979c2.703,1.393 5.2,3.15 7.401,5.209c0.66,0.619 1.331,1.337 1.403,2.217c0.053,0.637 -0.22,1.249 -0.486,1.828c-0.876,1.909 -1.939,3.993 -3.959,4.738c-0.976,0.359 -2.056,0.35 -3.1,0.264c-3.905,-0.324 -7.723,-1.687 -10.919,-3.898c-0.63,-0.439 -1.284,-0.976 -1.42,-1.713c-0.118,-0.646 0.196,-1.283 0.412,-1.903c0.901,-2.561 0.127,-5.606 -1.905,-7.497c-0.955,-0.889 -2.285,-2.068 -1.61,-3.161c0.188,-0.306 0.509,-0.509 0.821,-0.706c1.534,-0.96 4.827,-3.471 6.827,-2.814c1.961,0.645 2.184,4.066 3.469,5.457" style="fill:#f6a091;fill-rule:nonzero;"/><path d="M235.763,159.311c-1.238,0.272 -2.578,1.049 -2.636,2.275c-0.083,1.749 2.272,2.492 4.085,2.667c-1.841,0.269 -3.794,0.589 -5.16,1.798c-1.366,1.208 -1.73,3.631 -0.228,4.705c0.704,0.504 1.627,0.596 2.502,0.661c2.135,0.159 4.543,0.162 6.064,-1.276c-0.834,1.708 -1.128,3.771 -0.3,5.496c0.828,1.725 2.984,2.911 4.84,2.302c2.547,-0.835 3.041,-4.043 3.1,-6.643c1.532,1.331 3.841,1.887 5.726,1.116c1.884,-0.77 3.085,-2.979 2.407,-4.852c-0.682,-1.876 -3.355,-2.872 -5.013,-1.717c1.704,-0.215 3.019,-1.728 3.292,-3.363c0.276,-1.634 -0.341,-3.321 -1.32,-4.69c-1.503,-2.105 -4.546,-3.629 -6.773,-2.281c-1.89,1.145 -1.177,4.138 -2.801,4.906c-1.613,0.765 -5.534,-1.599 -7.785,-1.104" style="fill:#fefbe3;fill-rule:nonzero;"/><path d="M240.723,163.672c-0.242,0.369 -0.433,0.785 -0.438,1.224c-0.009,0.594 0.323,1.164 0.795,1.554c0.473,0.39 1.065,0.617 1.663,0.763c0.928,0.221 1.923,0.257 2.82,-0.044c0.9,-0.303 1.689,-0.969 1.98,-1.842c0.254,-0.755 0.109,-1.625 -0.377,-2.272c-1.611,-2.145 -5.145,-1.359 -6.443,0.617" style="fill:#fad34f;fill-rule:nonzero;"/><path d="M260.265,163.27c-0.997,-0.461 -2.243,-0.364 -3.14,0.245c-0.757,0.512 -1.26,1.5 -0.896,2.329c0.282,0.646 0.984,1.019 1.657,1.276c0.837,0.319 1.74,0.539 2.63,0.429c0.888,-0.108 1.763,-0.593 2.132,-1.378c0.32,-0.683 0.225,-1.499 -0.084,-2.193c-0.083,-0.189 -0.188,-0.375 -0.352,-0.503c-0.196,-0.154 -0.454,-0.202 -0.702,-0.246c-0.452,-0.082 -0.904,-0.164 -1.357,-0.244" style="fill:#fad34f;fill-rule:nonzero;"/></g></svg></div>
    <div class="card__data">
      <div class="data__temp"> </div>
      <div class="data__description"> </div>
      <div class="data__date"></div>
    </div>
  </div>
</div>
    <script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>
      <script id="rendered-js" >
const $date = document.querySelector('.data__date');

//get date
function formatDate(date) {
  var monthNames = [
  "Jan", "Feb", "Mar",
  "Apr", "May", "Jun", "Jul",
  "Aug", "Sep", "Oct",
  "Nov", "Dec"];

  var dayNames = [
  "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturaday"];


  var day = date.getDate();
  var dayIndex = date.getDay();
  var monthIndex = date.getMonth();

  return `${dayNames[dayIndex]}, ${monthNames[monthIndex]} ${day}`;
}
const today = formatDate(new Date());
$date.innerHTML = today;

fetch('//api.openweathermap.org/data/2.5/weather?id=3674962&units=metric&appid=7dfbd67abc9490e0070d2892e144264d').
then(response => response.json()).
then(data => {
  const { main: { temp } } = data;
  const { name } = data;
  const { weather: [{ description }] } = data;
  const { weather: [{ main }] } = data;
  $temp = document.querySelector('.data__temp');
  $temp.innerText = `${parseInt(temp)}ΒΊ`;
  $description = document.querySelector('.data__description');
  $description.innerText = `${description}`;
  if (main == "Clouds") {
    $image = document.querySelector('.card__image');
    $image.innerHTML = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 64 64"><defs><linearGradient y2="535.55" x2="395.24" y1="551.32" x1="395.48" gradientUnits="userSpaceOnUse" id="0" gradientTransform="matrix(2.07793 0 0 2.08909-503.11-599.88)"><stop stop-color="#ebebeb"/><stop offset="1" stop-color="#fff"/></linearGradient><linearGradient id="1" gradientUnits="userSpaceOnUse" x1="305.68" y1="541.42" x2="304.72" y2="511.03"><stop stop-color="#ff9300"/><stop offset="1" stop-color="#ffd702"/></linearGradient></defs><g transform="matrix(1.08334 0 0 1.08334-307.62-542.03)"><circle cx="305.38" cy="526.52" r="15.881" fill="url(#1)"/><path d="m311.11 530.14c-.874-.686-1.973-1.095-3.165-1.095-2.808 0-5.093 2.265-5.165 5.087-2.898 1.099-4.961 3.927-4.961 7.241 0 3.916 2.879 7.151 6.613 7.662v.07h26.451v-.013c3.688-.216 6.613-3.309 6.613-7.093 0-3.649-2.72-6.655-6.222-7.06.014-.222.022-.447.022-.673 0-5.655-4.719-10.239-10.539-10.239-4.308 0-8.01 2.512-9.647 6.11" fill="url(#0)"/></g></svg>';

    console.log('Clouds');
  }
});
//# sourceURL=pen.js
    </script>
</body>
</html>

11. Weather Card using Flexbox

Made by Aditya Bhandari. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title>CodePen - Weather Card using FlexBox</title>
<style>
@import url(https://fonts.googleapis.com/css?family=Poiret+One);
@import url(https://cdnjs.cloudflare.com/ajax/libs/weather-icons/2.0.9/css/weather-icons.min.css);
body {
  background-color: #A64253;
  font-family: Poiret One;
}

.widget {
  position: absolute;
  top: 50%;
  left: 50%;
  display: flex;
  height: 300px;
  width: 600px;
  transform: translate(-50%, -50%);
  flex-wrap: wrap;
  cursor: pointer;
  border-radius: 20px;
  box-shadow: 0 27px 55px 0 rgba(0, 0, 0, 0.3), 0 17px 17px 0 rgba(0, 0, 0, 0.15);
}
.widget .weatherIcon {
  flex: 1 100%;
  height: 60%;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  background: #FAFAFA;
  font-family: weathericons;
  display: flex;
  align-items: center;
  justify-content: space-around;
  font-size: 100px;
}
.widget .weatherIcon i {
  padding-top: 30px;
}
.widget .weatherInfo {
  flex: 0 0 70%;
  height: 40%;
  background: #080705;
  border-bottom-left-radius: 20px;
  display: flex;
  align-items: center;
  color: white;
}
.widget .weatherInfo .temperature {
  flex: 0 0 40%;
  width: 100%;
  font-size: 65px;
  display: flex;
  justify-content: space-around;
}
.widget .weatherInfo .description {
  flex: 0 60%;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  justify-content: center;
}
.widget .weatherInfo .description .weatherCondition {
  text-transform: uppercase;
  font-size: 35px;
  font-weight: 100;
}
.widget .weatherInfo .description .place {
  font-size: 15px;
}
.widget .date {
  flex: 0 0 30%;
  height: 40%;
  background: #70C1B3;
  border-bottom-right-radius: 20px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  color: white;
  font-size: 30px;
  font-weight: 800;
}

p {
  position: fixed;
  bottom: 0%;
  right: 2%;
}
p a {
  text-decoration: none;
  color: #E4D6A7;
  font-size: 10px;
}
</style>
</head>
<body>
  <article class="widget">
  <div class="weatherIcon"><i class="wi wi-day-cloudy"></i></div>
  <div class="weatherInfo">
    <div class="temperature"><span>25&deg;</span></div>
    <div class="description">    
      <div class="weatherCondition">CLOUDY</div>    
      <div class="place">New York, New York</div>
    </div>
  </div>
  <div class="date">1st Jan</div>
</article>
<p><a href="https://codepen.io/nerios/full/jWjmby/">Inspired by: https://codepen.io/nerios/full/jWjmby/. Implemented using FlexBox.</a>
</p>
</body>
</html>

12. Weather card (WIP)

Made by Kitsune. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
 
<style>
@charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,600,300);
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html, body {
  height: 100%;
  width: 100%;
  background-color: #f3f3f3;
}

.body {
  padding: 0;
  margin: 0;
  background-color: #1a1a1a;
  -webkit-font-smoothing: antialiased;
}

.flex {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card--container {
  width: 400px;
  position: relative;
}

.sunny {
  width: 120px;
  height: 120px;
  background-color: #F9CC6A;
  position: absolute;
  bottom: -30px;
  right: -30px;
  border-radius: 60px;
  -webkit-box-shadow: -5px -5px 47px -1px #f9cc6a;
  -moz-box-shadow: -5px -5px 47px -1px #f9cc6a;
  box-shadow: -5px -5px 47px -1px #f9cc6a;
}

.card {
  font-family: "Source Sans Pro", sans-serif;
  display: block;
  background-color: #4d6efb;
  text-align: center;
  padding: 30px 20px;
  width: 400px;
  height: 240px;
  border-radius: 8px;
  position: absolute;
  overflow: hidden;
  /* Better done with ::before and ::after pseudo elements - Will update */
}
.card span {
  display: block;
}
.card .temp {
  color: #FFF;
  font-weight: 300;
  font-size: 70px;
  letter-spacing: 2px;
  display: block;
  position: relative;
}
.card .temp:after {
  font-size: 18px;
  position: absolute;
  top: 18px;
  color: rgba(255, 255, 255, 0.5);
  content: "℃";
}
.card .city {
  color: rgba(255, 255, 255, 0.7);
}
.card:first-of-type {
  background-color: #98abfd;
  z-index: 997;
  width: 80%;
  left: 10%;
  top: -20px;
}
.card:nth-of-type(2) {
  background-color: #7f97fc;
  z-index: 998;
  width: 90%;
  left: 5%;
  top: -10px;
}
.card:last-of-type {
  background-color: #4d6efb;
  z-index: 999;
}
</style>
</head>
<body>
  <div class="flex">
  <div class="card--container">
    <div class="card"></div>
    <div class="card"></div>
    <div class="card">
      <span class="temp">17</span>
      <span class="city">London, UK</span>
      <div class="sunny"></div>
    </div>
  </div>
</div>
</body>
</html>

13. Weather card 3D effect

Made by Baptiste Marck. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title> 
<style>
body {
  background: #E0EAFC;
  /* fallback for old browsers */
  /* Chrome 10-25, Safari 5.1-6 */
  background: linear-gradient(to left, #E0EAFC, #CFDEF3);
  /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
  font-family: "Montserrat", sans-serif;
  text-align: center;
  padding: 100px;
}

.weather {
  perspective: 1000px;
}

.weather-symbol {
  display: block;
  width: 50px;
  height: 50px;
}
.weather-symbol.is-sunny {
  background: url("https://db.tt/Eci0vL1h") no-repeat center;
}
.weather-symbol.is-sunny.is-white {
  background: url("https://db.tt/lSuOMB3o") no-repeat center;
}
.weather-symbol.is-foggy {
  background: url("https://db.tt/7jdwCwXc") no-repeat center;
}
.weather-symbol.is-rainy {
  background: url("https://db.tt/FfcVMaVr") no-repeat center;
}

.weather__teaser {
  display: inline-block;
  vertical-align: top;
  width: 340px;
  margin: 0 auto 1%;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.3);
  border-radius: 10px;
  position: relative;
  background: white;
  overflow: hidden;
  text-align: left;
}
.weather__teaser header {
  text-align: center;
  position: relative;
  overflow: hidden;
  height: 280px;
  padding-bottom: 40px;
}
.weather__teaser header .weather-symbol {
  position: absolute;
  z-index: 200;
  left: 50%;
  transform: translateY(70px) translateX(-50%);
}
.weather__teaser header h1 {
  position: absolute;
  z-index: 200;
  color: white;
  text-align: center;
  font-size: 42px;
  left: 50%;
  transform: translateY(90px) translateX(-50%);
  text-shadow: 1px 1.732px 3px rgba(0, 0, 0, 0.2);
}
.weather__teaser header .hour {
  position: absolute;
  z-index: 200;
  color: white;
  text-align: center;
  font-size: 22px;
  font-weight: light;
  left: 50%;
  transform: translateY(160px) translateX(-50%);
  text-shadow: 1px 1.732px 3px rgba(0, 0, 0, 0.2);
}
.weather__teaser header img {
  width: 480px;
  height: auto;
  display: block;
  transform: scale(1.4);
  top: 0;
  position: absolute;
  transition: 0.3s margin-top, 0.1s transform;
}
.weather__teaser .main-content {
  position: relative;
  padding: 10px 0;
  text-align: left;
  left: 0;
  width: 100%;
  bottom: 0;
  transition: bottom 0.3s;
  background: white;
  box-shadow: 0px -3px 10px 0px rgba(0, 0, 0, 0.2);
  display: table;
}
.weather__teaser .main-content:before {
  content: "";
  display: block;
  width: 100%;
  position: absolute;
  height: 70px;
  top: -70px;
  background: url("https://db.tt/sxdDLS2S") no-repeat;
}
.weather__teaser .main-content .weather-column {
  padding: 0 0 20px;
  display: table-cell;
  text-align: center;
  opacity: 0.5;
  transition: all 0.3s;
  cursor: pointer;
}
.weather__teaser .main-content .weather-column.is-active, .weather__teaser .main-content .weather-column:hover {
  opacity: 1;
  transition: all 0.3s;
}
.weather__teaser .main-content .weather-column .weather-symbol {
  margin: 0 auto;
}
.weather__teaser .main-content .weather-column .day {
  text-transform: uppercase;
  font-weight: bold;
  font-size: 20px;
  margin: 10px 0 0;
}
.weather__teaser .main-content .weather-column .temperature {
  margin: 5px 0 0;
}
</style>
</head>
<body>
  <link href='https://fonts.googleapis.com/css?family=Montserrat:400,700' rel='stylesheet' type='text/css'>
<script src="https://code.jquery.com/jquery-2.2.4.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js"></script>
<div class="weather">
  <section class="weather__teaser">
    <article class="weather-teaser__web">
      <header>
        <span class="weather-symbol is-sunny is-white"></span>
        <h1>32Β°C</h1>
        <p class="hour">23:00</p>
        <img src="https://3.bp.blogspot.com/-Cuk0mIWimLg/VSWNRcciYWI/AAAAAAAAfmg/amgrLwnh62g/s1600/Milky-Way-Galaxy-Mount-Rainier.jpg" class="image-style-teaser-work">
      </header>
      <main class="main-content">
        <article class="weather-column">
          <span class="weather-symbol is-rainy"></span>
          <p class="day">Sun</p>
          <p class="temperature">26Β°</p>
        </article>
        <article class="weather-column is-active">
          <span class="weather-symbol is-sunny"></span>
          <p class="day">Mon</p>
          <p class="temperature">32Β°</p>
        </article>
        <article class="weather-column">
          <span class="weather-symbol is-foggy"></span>
          <p class="day">Tue</p>
          <p class="temperature">28Β°</p>
        </article>
      </main>
    </article>
  </section>
</div>
<script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>
<script src='https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js'></script>
      <script>
function calculateDistanceX(elem, mouseX) {
  return Math.pow(mouseX - (elem.offset().left + elem.width() / 2), 1);
}

function calculateDistanceY(elem, mouseY) {
  return Math.pow(mouseY - (elem.offset().top + elem.height() / 2), 1);
}

function bouncingValue(elem, valX, valY) {
  var matrix = elem.css('transform');
  var results = matrix.split('(')[1].split(')')[0].split(',');
  var array = $({
    a: results[0],
    b: results[1],
    c: results[2],
    d: results[3],
    e: results[4],
    f: results[5],
    g: results[6],
    h: results[7],
    i: results[8],
    j: results[9],
    k: results[10],
    l: results[11],
    m: results[12],
    n: results[13],
    o: results[15],
    p: results[15],
    x: valX,
    y: valY });

  array.animate({
    a: 1,
    b: 0,
    c: 0,
    d: 0,
    e: 0,
    f: 1,
    g: 0,
    h: 0,
    i: 0,
    j: 0,
    k: 1,
    l: 0,
    m: 0,
    n: 0,
    o: 0,
    p: 1,
    x: 0,
    y: 0 },
  {
    duration: 2000,
    easing: 'easeOutElastic',
    step: function () {
      elem.css({
        'transform': 'matrix3d(' + this.a + ',' + this.b + ',' + this.c + ',' + this.d + ',' + this.e + ',' + this.f + ',' + this.g + ',' + this.h + ',' + this.i + ',' + this.j + ',' + this.k + ',' + this.l + ',' + this.m + ',' + this.n + ',' + this.o + ',' + this.p + ')',
        'box-shadow': '' + this.x * 3 * -1 + 'px ' + this.y * 3 + 'px 10px rgba(0,0,0,.3)' });

      elem.find('img').css('transform', 'matrix3d(' + this.a + ',' + this.b + ',' + this.c + ',' + this.d + ',' + this.e + ',' + this.f + ',' + this.g + ',' + this.h + ',' + this.i + ',' + this.j + ',' + this.k + ',' + this.l + ',' + this.m + ',' + this.n + ',' + this.o + ',' + this.p + ')');
    } });


  elem.on('mousemove', function (e) {
    mX = e.pageX;
    mY = e.pageY;
    distanceY = calculateDistanceY(elem, mY) / 100 * -2;
    distanceX = calculateDistanceX(elem, mX) / 100 * 2;
    elem.css({
      'transform': 'rotateY(' + distanceX + 'deg) rotateX(' + distanceY + 'deg)',
      'box-shadow': '' + distanceX * 3 * -1 + 'px ' + distanceY * 3 + 'px 10px 0px rgba(0,0,0,0.3)',
      'transition': 'all 0s' });

    array.finish();
  });
}

var mX, mY, distance;

var $teaser = $('.weather__teaser');

var teaser = function (box) {
  var onMouseLeave,
  onMouseEnter,
  onMouseMove,
  mX,
  mY,
  distance,
  $teaser = $(box);

  onMouseEnter = function (e) {
    e.stopImmediatePropagation();
    $element = $(this);
  };

  onMouseMove = function (e) {
    mX = e.pageX;
    mY = e.pageY;
    distanceY = calculateDistanceY($element, mY) / 100 * -2;
    distanceX = calculateDistanceX($element, mX) / 100 * 2;
    $element.css({
      'transform': 'rotateY(' + distanceX + 'deg) rotateX(' + distanceY + 'deg)',
      'box-shadow': '' + distanceX * 3 * -1 + 'px ' + distanceY * 3 + 'px 10px 0px rgba(0,0,0,0.3)',
      'transition': 'all 0s' });

    $element.find('img').css('transform', 'scale(1.2) translate3d(' + distanceY * 3 + 'px, ' + distanceX * 2 + 'px, 0)');
  };
  onMouseLeave = function (e) {
    e.stopImmediatePropagation();
    bouncingValue($element, distanceX, distanceY);
  };
  return {
    bindHandlers: function (e) {
      $teaser.on('mouseenter', onMouseEnter);
      $teaser.on('mousemove', onMouseMove);
      $teaser.on('mouseleave', onMouseLeave);
      return this;
    } };

};
t = teaser('.weather__teaser').bindHandlers();
//# sourceURL=pen.js
    </script>
</body>
</html>

14. Weather card with Sliding Effect

Made by Thomas Vallez. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
<style>
@import url(https://fonts.googleapis.com/css?family=Roboto:400,300);
html,
body {
    background-color: #F3F3F3;
    font-family: 'Roboto', sans-serif;
}

.card {
    margin: 0 auto;
    margin-top: 5%;
    padding: 5px 30px;
    width: 290px;
    height: 470px;
    border-radius: 3px;
    background-color: #fff;
    box-shadow: 1px 2px 10px rgba(0, 0, 0, .2);
    -webkit-animation: open 2s cubic-bezier(.39, 0, .38, 1);
}

@-webkit-keyframes open {
    from {
        padding: 0 30px;
        height: 0;
    }
    to {
        height: 470px;
    }
}

h1,
h2,
h3,
h4 {
    position: relative;
}

h1 {
    float: right;
    color: #666;
    font-weight: 300;
    font-size: 6.59375em;
    line-height: .2em;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .2s;
}

h2 {
    font-weight: 300;
    font-size: 2.25em;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1);
}

h3 {
    float: left;
    margin-right: 33px;
    color: #777;
    font-weight: 400;
    font-size: 1em;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .1s;
}

span {
    margin-left: 24px;
    color: #999;
    font-weight: 300;
}

span span {
    margin-left: 0;
}

.dot {
    font-size: .9em;
}

.sky {
    position: relative;
    margin-top: 108px;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background-color: #03A9F4;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .2s;
}

.sun {
    position: relative;
    top: -3px;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    background-color: #FFEB3B;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .5s;
}

.cloud {
    position: absolute;
    top: 60px;
    left: 30px;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .7s;
}

.cloud:before,
.cloud:after {
    position: absolute;
    display: block;
    content: "";
}

.cloud:before {
    margin-left: -10px;
    width: 51px;
    height: 18px;
    background: #fff;
}

.cloud:after {
    position: absolute;
    top: -10px;
    left: -22px;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 50px -6px 0 6px #fff, 25px -19px 0 10px #fff;
}

table {
    position: relative;
    top: 10px;
    width: 100%;
    text-align: center;
}

tr:nth-child(1) td:nth-child(1),
tr:nth-child(1) td:nth-child(2),
tr:nth-child(1) td:nth-child(3),
tr:nth-child(1) td:nth-child(4),
tr:nth-child(1) td:nth-child(5) {
    padding-bottom: 32px;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .7s;
}

tr:nth-child(2) td:nth-child(1),
tr:nth-child(2) td:nth-child(2),
tr:nth-child(2) td:nth-child(3),
tr:nth-child(2) td:nth-child(4),
tr:nth-child(2) td:nth-child(5) {
    padding-bottom: 7px;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .9s;
}

tr:nth-child(3) td:nth-child(1),
tr:nth-child(3) td:nth-child(2),
tr:nth-child(3) td:nth-child(3),
tr:nth-child(3) td:nth-child(4),
tr:nth-child(3) td:nth-child(5) {
    padding-bottom: 7px;
    -webkit-animation: up 2s cubic-bezier(.39, 0, .38, 1) .9s;
}

tr:nth-child(2),
tr:nth-child(3) {
    font-size: .9em;
}

tr:nth-child(3) {
    color: #999;
}

@-webkit-keyframes up {
    0% {
        opacity: 0;
        -webkit-transform: translateY(15px);
    }
    50% {
        opacity: 0;
        -webkit-transform: translateY(15px);
    }
    99% {
        -webkit-animation-play-state: paused;
    }
    100% {
        opacity: 1;
    }
}
</style>
</head>
<body>
  <div class="card">

        <h2>Brussels</h2>
        <h3>Cloudy<span>Wind 10km/h <span class="dot">β€’</span> Precip 0%</span></h3>
        <h1>23Β°</h1>
        <div class="sky">
            <div class="sun"></div>
            <div class="cloud">
                <div class="circle-small"></div>
                <div class="circle-tall"></div>
                <div class="circle-medium"></div>
            </div>
        </div>
        <table>
            <tr>
                <td>TUE</td>
                <td>WED</td>
                <td>THU</td>
                <td>FRI</td>
                <td>SAT</td>
            </tr>
            <tr>
                <td>30Β°</td>
                <td>34Β°</td>
                <td>36Β°</td>
                <td>34Β°</td>
                <td>37Β°</td>
            </tr>
            <tr>
                <td>17Β°</td>
                <td>22Β°</td>
                <td>19Β°</td>
                <td>23Β°</td>
                <td>19Β°</td>
            </tr>
        </table>
    </div>
</body>
</html>

15. SlideUP Weather Card

Made by Oğuzhan ULUKAYA. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
  <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.13.0/css/all.css" integrity="sha384-Bfad6CLCknfcloXFOyFnlgtENryhrpZCe29RTifKEixXQZ38WheV+i/6YWSzkz3V" crossorigin="anonymous"> 
  <link rel='stylesheet' href='https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.5.0/css/bootstrap.min.css'>
  
<style>
@import url("https://fonts.googleapis.com/css?family=Montserrat:400,500,600,700,800,900");

.container {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Montserrat", sans-serif;
}
.card {
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
  height: 480px;
  width: 320px;
  top: 15vh;
  margin-bottom: 150px;
}
.card-body {
  background-image: url("https://cdn.pixabay.com/photo/2016/07/29/10/07/nature-1552091_960_720.png");
  background-position: top;
  background-repeat: no-repeat;
  background-size: 200% 100%;
}
.info {
  background-color: #0000004f;
  color: white;
  height: 410px;
}
.info h4 {
  font-size: 2.5rem;
  font-weight: 400;
}
.info h6 {
  font-size: 1.2rem;
  font-weight: 400;
}
.info h1 {
  font-size: 3.5rem;
  font-weight: 600;
}
.card-footer {
  padding: 1.25rem 1.25rem;
  padding-bottom: 0.5rem;
}
.card-footer p:first-child {
  float: left;
}
.arrow{
  transition: .4s;
}
.arrow:hover {
  margin-top: -10px;
  transform: scale(1.5);
  cursor: pointer;
}
#extra {
  display: none;
  width: 250px;
  opacity: 0.7;
}

.animate-footer {
  -webkit-animation: nextDay 2s;
  animation: nextDay 2s;
  animation-fill-mode: forwards;
}
.animate-shadow {
  -webkit-animation: shadow 2s;
  animation: shadow 2s;
  animation-fill-mode: forwards;
}
@keyframes nextDay {
  0% {
    height: 70px;
  }
  100% {
    height: 265px;
  }
}
@-webkit-keyframes nextDay {
  0% {
    height: 70px;
  }
  100% {
    height: 265px;
  }
}
@keyframes shadow {
  0% {
    height: 410px;
  }
  100% {
    height: 215px;
  }
}
@-webkit-keyframes shadow {
  0% {
    height: 410px;
  }
  100% {
    height: 215px;
  }
}
</style>
</head>
<body>
  <div class="container">
  <div class="row">
    <div class=col-12>
      <div class="card">
        <div class="card-body px-0 py-0">
          <div class="info text-center" id=info>
            <h4 class="pt-5">Clear night</h4>
            <h6 class="">Izmir, Turkey</h6>
            <h1 class="">33Β°C</h1>
          </div>
        </div>
        <div class="card-footer" id="footer">
          <div class="container">
            <div class="row">
              <div class="col-12 text-center" style="margin-top: -35px;">
                <i class="fas fa-chevron-up fa-2x arrow" style="color: #000000c2;"></i>
              </div>
              <div class="col-12" id="future">
                <p>Tomorrow</p>
                <p class="text-right">23Β°C</p>
                <span id="extra">
                  <div class="col-12">
                    <p>Tuesday</p>
                    <p class="text-right">22Β°C</p>
                  </div>
                  <div class="col-12">
                    <p>Wednesday</p>
                    <p class="text-right">19Β°C</p>
                  </div>
                  <div class="col-12">
                    <p>Thursday</p>
                    <p class="text-right">21Β°C</p>
                  </div>
                  <div class="col-12">
                    <p>Friday</p>
                    <p class="text-right">23Β°C</p>
                  </div>
                </span>
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </div>
</div>
    <script src="https://cpwebassets.codepen.io/assets/common/stopExecutionOnTimeout-1b93190375e9ccc259df3a57c1abc0e64599724ae30d7ea4c6877eb615f89387.js"></script>
      <script>
window.onload = function () {
  let arrow = document.getElementsByClassName("arrow")[0];
  let footer = document.getElementById("footer");
  let info = document.getElementById("info");
  let extra = document.getElementById("extra");

  arrow.addEventListener("click", function () {
    footer.classList.add("animate-footer");
    info.classList.add("animate-shadow");
    setTimeout(function () {
      extra.style.display = "block";
    }, 2100);
  });
};
//# sourceURL=pen.js
    </script>
</body>
</html>

16. Weather Card Material Design

Made by Bart van den Berkmortel. Source

<!DOCTYPE html>
<html lang="en" >
<head>
  <meta charset="UTF-8">
  <title></title>
<style>
@import url(https://fonts.googleapis.com/css?family=Roboto);

body{
  background: rgba(26, 188, 156, 0.7);
}

.container{
  width: 100%;
  height: 100%;
  margin: 100px auto;
}

.card{
  margin: 100px auto;
  width: 340px;
  height: 220px;
  background-color: #fff;
  border-radius: 7px;
  box-shadow: 0.3px 0.3px 0.3px 1px rgba(0, 0, 0, 0.2);
  font-family: 'Roboto', sans-serif;
}

.city, .date{
  color: gray;
  margin-left: 35px;
}

.city{
  padding-top: 50px;
  font-size: 26px;
}

.date{
  font-size: 20px;
  line-height: 40px;
}

.sun{
  position: absolute;
  display: inline;
  margin-left: 35px;
	width: 70px;
	height: 70px;
	background: #FFC107;
	-moz-border-radius: 50px;
	-webkit-border-radius: 50px;
	border-radius: 50px;
}

.temp{
  padding-left: 125px;
  padding-top: 6px;
  font-size: 50px;
}
</style>
</head>
<body>
  <div class="container">
  <div class="card">
    <div class="city">Eindhoven</div>
    <div class="date">29 september 2015</div>
    <div class="weather">
      <div class="sun">
        <div class="temp">12Β°C</div>
      </div>
    </div>
  </div>
</div>
</body>
</html>