diff --git a/app/about-us/page.tsx b/app/about-us/page.tsx
new file mode 100644
index 0000000..7c7697c
--- /dev/null
+++ b/app/about-us/page.tsx
@@ -0,0 +1,3 @@
+import AboutUsPage from "@/Pages/AboutUsPage/AboutUsPage";
+
+export default AboutUsPage;
diff --git a/app/layout.tsx b/app/layout.tsx
new file mode 100644
index 0000000..31838fa
--- /dev/null
+++ b/app/layout.tsx
@@ -0,0 +1,9 @@
+import RootLayout from "@/App/App";
+import type { Metadata } from "next";
+
+export const metadata: Metadata = {
+  title: "KG Road",
+  description: "Road in Kyrgyzstan",
+};
+
+export default RootLayout;
diff --git a/app/news/page.tsx b/app/news/page.tsx
new file mode 100644
index 0000000..955b210
--- /dev/null
+++ b/app/news/page.tsx
@@ -0,0 +1,3 @@
+import NewsPage from "@/Pages/NewsPage/NewsPage";
+
+export default NewsPage;
diff --git a/app/page.tsx b/app/page.tsx
new file mode 100644
index 0000000..3095677
--- /dev/null
+++ b/app/page.tsx
@@ -0,0 +1,3 @@
+import Homepage from "@/Pages/Homepage/Homepage";
+
+export default Homepage;
diff --git a/app/profile/page.tsx b/app/profile/page.tsx
new file mode 100644
index 0000000..a54c709
--- /dev/null
+++ b/app/profile/page.tsx
@@ -0,0 +1,7 @@
+import React from "react";
+
+const page = () => {
+  return 
page
;
+};
+
+export default page;
diff --git a/app/sign-in/page.tsx b/app/sign-in/page.tsx
new file mode 100644
index 0000000..a54c709
--- /dev/null
+++ b/app/sign-in/page.tsx
@@ -0,0 +1,7 @@
+import React from "react";
+
+const page = () => {
+  return page
;
+};
+
+export default page;
diff --git a/app/sign-up/page.tsx b/app/sign-up/page.tsx
new file mode 100644
index 0000000..a54c709
--- /dev/null
+++ b/app/sign-up/page.tsx
@@ -0,0 +1,7 @@
+import React from "react";
+
+const page = () => {
+  return page
;
+};
+
+export default page;
diff --git a/app/statistics/page.tsx b/app/statistics/page.tsx
new file mode 100644
index 0000000..2ea4a18
--- /dev/null
+++ b/app/statistics/page.tsx
@@ -0,0 +1,3 @@
+import StatisticsPage from "@/Pages/StatisticsPage/StatisticsPage";
+
+export default StatisticsPage;
diff --git a/app/volunteers/page.tsx b/app/volunteers/page.tsx
new file mode 100644
index 0000000..8bc622c
--- /dev/null
+++ b/app/volunteers/page.tsx
@@ -0,0 +1,3 @@
+import VolunteersPage from "@/Pages/VolunteersPage/VolunteersPage";
+
+export default VolunteersPage;
diff --git a/package.json b/package.json
index 84ce1a5..8e8148e 100644
--- a/package.json
+++ b/package.json
@@ -9,16 +9,17 @@
     "lint": "next lint"
   },
   "dependencies": {
+    "next": "14.1.0",
     "react": "^18",
     "react-dom": "^18",
-    "next": "14.1.0"
+    "sass": "^1.70.0"
   },
   "devDependencies": {
-    "typescript": "^5",
     "@types/node": "^20",
     "@types/react": "^18",
     "@types/react-dom": "^18",
     "eslint": "^8",
-    "eslint-config-next": "14.1.0"
+    "eslint-config-next": "14.1.0",
+    "typescript": "^5"
   }
 }
diff --git a/src/App/App.tsx b/src/App/App.tsx
new file mode 100644
index 0000000..fd75142
--- /dev/null
+++ b/src/App/App.tsx
@@ -0,0 +1,22 @@
+import { Montserrat } from "next/font/google";
+import "./globals.scss";
+import Navbar from "@/Widgets/general/Navbar/Navbar";
+import Footer from "@/Widgets/general/Footer/Footer";
+
+const montserrat = Montserrat({ subsets: ["latin"] });
+
+export default function RootLayout({
+  children,
+}: Readonly<{
+  children: React.ReactNode;
+}>) {
+  return (
+    
+      
+        
+        {children}
+        
+      
+    
+  );
+}
diff --git a/src/App/globals.scss b/src/App/globals.scss
new file mode 100644
index 0000000..310b34e
--- /dev/null
+++ b/src/App/globals.scss
@@ -0,0 +1,28 @@
+* {
+  box-sizing: border-box;
+  padding: 0;
+  margin: 0;
+}
+
+button {
+  border: none;
+  cursor: pointer;
+  background-color: transparent;
+  display: flex;
+  align-items: center;
+  justify-content: center;
+}
+
+input {
+  outline: none;
+}
+
+a {
+  color: black;
+  text-decoration: none;
+  background-color: transparent;
+}
+
+ul {
+  list-style-type: none;
+}
diff --git a/src/Entities/ChangeLanguage/ChangeLanguage.scss b/src/Entities/ChangeLanguage/ChangeLanguage.scss
new file mode 100644
index 0000000..fdb1c74
--- /dev/null
+++ b/src/Entities/ChangeLanguage/ChangeLanguage.scss
@@ -0,0 +1,61 @@
+.change-language {
+  position: relative;
+  display: flex;
+  flex-direction: column;
+  align-items: center;
+  &__btn {
+    display: flex;
+    align-items: center;
+    gap: 6px;
+  }
+
+  &__popUp {
+    position: absolute;
+    top: 35px;
+  }
+  &__item,
+  &__item_active {
+    button {
+      width: 150px;
+      padding: 10px 14px;
+      justify-content: flex-start;
+      gap: 8px;
+      background-color: #fff;
+      line-height: 24px;
+
+      color: #101828;
+      font-size: 16px;
+      font-weight: 600;
+    }
+  }
+
+  &__item:first-child,
+  &__item_active:first-child {
+    button {
+      border-top-left-radius: 5px;
+      border-top-right-radius: 5px;
+    }
+  }
+
+  &__item:last-child,
+  &__item_active:last-child {
+    button {
+      border-bottom-right-radius: 5px;
+      border-bottom-left-radius: 5px;
+    }
+  }
+
+  &__item_active {
+    button {
+      background-color: #f9fafb;
+    }
+  }
+}
+
+@media screen and (max-width: 768px) {
+  .change-language {
+    &__popUp {
+      right: 0;
+    }
+  }
+}
diff --git a/src/Entities/ChangeLanguage/ChangeLanguage.tsx b/src/Entities/ChangeLanguage/ChangeLanguage.tsx
new file mode 100644
index 0000000..ca726a0
--- /dev/null
+++ b/src/Entities/ChangeLanguage/ChangeLanguage.tsx
@@ -0,0 +1,50 @@
+import "./ChangeLanguage.scss";
+import Image from "next/image";
+import lang_icon from "./icons/lang-icon.svg";
+import chevron_icon from "./icons/chevron-down-icon.svg";
+import check_icon from "./icons/check-icon.svg";
+import { useState } from "react";
+
+const ChangeLanguage = () => {
+  const [lang, setLang] = useState("ru");
+  const [popUp, setPopUp] = useState(false);
+  const languages = [
+    { id: "ru", language: "Русский" },
+    { id: "kg", language: "Кыргыз" },
+    { id: "en", language: "English" },
+  ];
+  return (
+    
+      
+      {popUp && (
+        
+          {languages.map((language) => (
+            - 
+              
+            +          ))}
+
+      )}
+    
+          
+            {pages.map((page) => (
+              - 
+                {page.page}
+              +            ))}
+            {auth ? (
+
- 
+                Войти
+              +            ) : (
+
- 
+                Профиль
+              +            )}
+
+        
AboutUsPage
;
+};
+
+export default AboutUsPage;
diff --git a/src/Pages/Homepage/Homepage.scss b/src/Pages/Homepage/Homepage.scss
new file mode 100644
index 0000000..dba3251
--- /dev/null
+++ b/src/Pages/Homepage/Homepage.scss
@@ -0,0 +1,9 @@
+.home {
+  padding-top: 78px;
+}
+
+@media screen and (max-width: 768px) {
+  .home {
+    padding-top: 72px;
+  }
+}
diff --git a/src/Pages/Homepage/Homepage.tsx b/src/Pages/Homepage/Homepage.tsx
new file mode 100644
index 0000000..b8851db
--- /dev/null
+++ b/src/Pages/Homepage/Homepage.tsx
@@ -0,0 +1,20 @@
+import "./Homepage.scss";
+import Header from "@/Widgets/home/Header/Header";
+import MapSection from "@/Widgets/home/MapSection/MapSection";
+import RatingSection from "@/Widgets/home/RatingSection/RatingSection";
+import StatisticsSection from "@/Widgets/home/StatisticsSection/StatisticsSection";
+import NewsSection from "@/Widgets/home/NewsSection/NewsSection";
+
+const Homepage = () => {
+  return (
+    
+      
+      
+      
+      
+      
+    
+  );
+};
+
+export default Homepage;
diff --git a/src/Pages/NewsPage/NewsPage.scss b/src/Pages/NewsPage/NewsPage.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/Pages/NewsPage/NewsPage.tsx b/src/Pages/NewsPage/NewsPage.tsx
new file mode 100644
index 0000000..224df72
--- /dev/null
+++ b/src/Pages/NewsPage/NewsPage.tsx
@@ -0,0 +1,7 @@
+import "./NewsPage.scss";
+
+const NewsPage = () => {
+  return NewsPage
;
+};
+
+export default NewsPage;
diff --git a/src/Pages/StatisticsPage/StatisticsPage.scss b/src/Pages/StatisticsPage/StatisticsPage.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/Pages/StatisticsPage/StatisticsPage.tsx b/src/Pages/StatisticsPage/StatisticsPage.tsx
new file mode 100644
index 0000000..9ebcd69
--- /dev/null
+++ b/src/Pages/StatisticsPage/StatisticsPage.tsx
@@ -0,0 +1,7 @@
+import "./StatisticsPage.scss";
+
+const StatisticsPage = () => {
+  return StatisticsPage
;
+};
+
+export default StatisticsPage;
diff --git a/src/Pages/VolunteersPage/VolunteersPage.scss b/src/Pages/VolunteersPage/VolunteersPage.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/Pages/VolunteersPage/VolunteersPage.tsx b/src/Pages/VolunteersPage/VolunteersPage.tsx
new file mode 100644
index 0000000..62368a4
--- /dev/null
+++ b/src/Pages/VolunteersPage/VolunteersPage.tsx
@@ -0,0 +1,7 @@
+import "./VolunteersPage.scss";
+
+const VolunteersPage = () => {
+  return VolunteersPage
;
+};
+
+export default VolunteersPage;
diff --git a/src/Shared/UI/SectionHeader/SectionHeader.scss b/src/Shared/UI/SectionHeader/SectionHeader.scss
new file mode 100644
index 0000000..705cb5e
--- /dev/null
+++ b/src/Shared/UI/SectionHeader/SectionHeader.scss
@@ -0,0 +1,39 @@
+.section-header {
+  display: flex;
+  flex-direction: column;
+  align-items: center;
+  gap: 24px;
+  text-align: center;
+  h3 {
+    font-size: 42px;
+    font-weight: 500;
+    color: #32303a;
+  }
+
+  p {
+    font-size: 24px;
+    font-weight: 300;
+  }
+}
+
+@media screen and (max-width: 768px) {
+  .section-header {
+    gap: 20px;
+    h3 {
+      font-size: 36px;
+    }
+  }
+}
+
+@media screen and (max-width: 550px) {
+  .section-header {
+    gap: 16px;
+    h3 {
+      font-size: 24px;
+    }
+
+    p {
+      font-size: 18px;
+    }
+  }
+}
diff --git a/src/Shared/UI/SectionHeader/SectionHeader.tsx b/src/Shared/UI/SectionHeader/SectionHeader.tsx
new file mode 100644
index 0000000..e06accc
--- /dev/null
+++ b/src/Shared/UI/SectionHeader/SectionHeader.tsx
@@ -0,0 +1,20 @@
+import "./SectionHeader.scss";
+
+interface ISectionHeader {
+  children: React.ReactNode;
+  description?: string;
+}
+
+const SectionHeader: React.FC = ({
+  children,
+  description,
+}: ISectionHeader) => {
+  return (
+    
+      
{children}
+      
{description}
+    
+      
+        Карта дорог
+      
+
+      
+
+      
+        
+          
+          
Разбитая дорога
+        
+        
+          
+          
В планах ремонта
+        
+        
+          
+          
Очаг аварийности
+        
+        
+          
+          
Локальный дефект исправлен
+        
+        
+          
+          
Локальный дефект
+        
+        
+          
+          
Отремонтировано
+        
+      
+
+      
+    
+      
Новости
+
+      
+        {[0, 1, 2, 3].map((card) => (
+          - 
+            
+
+            
+               23/09/2023
+               
+                Short title of the card describing the main content
+              
+               
+                Short paragraph description of the article, outlining
+                main story and focus.
+               
+             
+        ))}
+
+      
+        Читать
+        
+      
+    
+      
+        Рейтинг
+      
+      
+    
+  );
+};
+
+export default RatingSection;
diff --git a/src/Widgets/home/StatisticsSection/StatisticsSection.scss b/src/Widgets/home/StatisticsSection/StatisticsSection.scss
new file mode 100644
index 0000000..b766a61
--- /dev/null
+++ b/src/Widgets/home/StatisticsSection/StatisticsSection.scss
@@ -0,0 +1,55 @@
+@import "../../../Shared/variables.scss";
+
+.statistics-section {
+  margin-top: 128px;
+  padding: 0px 90px;
+  display: grid;
+  grid-template-columns: 1fr 1fr 1fr;
+  gap: 30px;
+
+  &__item {
+    padding: 20px;
+    min-height: 128px;
+    display: flex;
+    flex-direction: column;
+    justify-content: space-between;
+    gap: 20px;
+    border-radius: 10px;
+    border: 1px solid #d4d4d4;
+
+    h4 {
+      font-size: 14px;
+      font-weight: 500;
+    }
+
+    p {
+      font-size: 24px;
+      font-weight: 700;
+      color: $light-blue;
+    }
+  }
+}
+
+@media screen and (max-width: 1024px) {
+  .statistics-section {
+    padding: 0 30px;
+  }
+}
+
+@media screen and (max-width: 768px) {
+  .statistics-section {
+    grid-template-columns: 1fr 1fr;
+  }
+}
+
+@media screen and (max-width: 550px) {
+  .statistics-section {
+    grid-template-columns: 1fr;
+    gap: 16px;
+    padding: 0 16px;
+
+    &__item {
+      padding: 20px;
+    }
+  }
+}
diff --git a/src/Widgets/home/StatisticsSection/StatisticsSection.tsx b/src/Widgets/home/StatisticsSection/StatisticsSection.tsx
new file mode 100644
index 0000000..449d706
--- /dev/null
+++ b/src/Widgets/home/StatisticsSection/StatisticsSection.tsx
@@ -0,0 +1,28 @@
+import "./StatisticsSection.scss";
+
+const StatisticsSection = () => {
+  const stats = [
+    { id: 1, statName: "Разбитых дорог", statCount: 231 },
+    { id: 2, statName: "Очагов аварийности", statCount: 31 },
+    { id: 3, statName: "Локальных дефектов", statCount: 211 },
+    { id: 4, statName: "В планах ремонта", statCount: 101 },
+    { id: 5, statName: "Отремонтировано", statCount: 14 },
+    {
+      id: 6,
+      statName: "Локальных дефектов исправлено",
+      statCount: 12,
+    },
+  ];
+  return (
+    
+      {stats.map((stat) => (
+        
+          
{stat.statName}
+          
{stat.statCount}
+        
+      ))}
+    
-        
-          Get started by editing 
-          src/app/page.tsx
-        
-        
-      
-        
-      
-
-      
-    
-  );
-}
diff --git a/yarn.lock b/yarn.lock
index b596a00..00e3b50 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -303,6 +303,14 @@ ansi-styles@^6.1.0:
   resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-6.2.1.tgz#0e62320cf99c21afff3b3012192546aacbfb05c5"
   integrity sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==
 
+anymatch@~3.1.2:
+  version "3.1.3"
+  resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e"
+  integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==
+  dependencies:
+    normalize-path "^3.0.0"
+    picomatch "^2.0.4"
+
 argparse@^2.0.1:
   version "2.0.1"
   resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38"
@@ -428,6 +436,11 @@ balanced-match@^1.0.0:
   resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee"
   integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==
 
+binary-extensions@^2.0.0:
+  version "2.2.0"
+  resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d"
+  integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==
+
 brace-expansion@^1.1.7:
   version "1.1.11"
   resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd"
@@ -443,7 +456,7 @@ brace-expansion@^2.0.1:
   dependencies:
     balanced-match "^1.0.0"
 
-braces@^3.0.2:
+braces@^3.0.2, braces@~3.0.2:
   version "3.0.2"
   resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107"
   integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==
@@ -484,6 +497,21 @@ chalk@^4.0.0:
     ansi-styles "^4.1.0"
     supports-color "^7.1.0"
 
+"chokidar@>=3.0.0 <4.0.0":
+  version "3.5.3"
+  resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd"
+  integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==
+  dependencies:
+    anymatch "~3.1.2"
+    braces "~3.0.2"
+    glob-parent "~5.1.2"
+    is-binary-path "~2.1.0"
+    is-glob "~4.0.1"
+    normalize-path "~3.0.0"
+    readdirp "~3.6.0"
+  optionalDependencies:
+    fsevents "~2.3.2"
+
 client-only@0.0.1:
   version "0.0.1"
   resolved "https://registry.yarnpkg.com/client-only/-/client-only-0.0.1.tgz#38bba5d403c41ab150bff64a95c85013cf73bca1"
@@ -1001,6 +1029,11 @@ fs.realpath@^1.0.0:
   resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f"
   integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==
 
+fsevents@~2.3.2:
+  version "2.3.3"
+  resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6"
+  integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==
+
 function-bind@^1.1.1, function-bind@^1.1.2:
   version "1.1.2"
   resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c"
@@ -1046,7 +1079,7 @@ get-tsconfig@^4.5.0:
   dependencies:
     resolve-pkg-maps "^1.0.0"
 
-glob-parent@^5.1.2:
+glob-parent@^5.1.2, glob-parent@~5.1.2:
   version "5.1.2"
   resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4"
   integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==
@@ -1172,6 +1205,11 @@ ignore@^5.2.0:
   resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.3.0.tgz#67418ae40d34d6999c95ff56016759c718c82f78"
   integrity sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==
 
+immutable@^4.0.0:
+  version "4.3.4"
+  resolved "https://registry.yarnpkg.com/immutable/-/immutable-4.3.4.tgz#2e07b33837b4bb7662f288c244d1ced1ef65a78f"
+  integrity sha512-fsXeu4J4i6WNWSikpI88v/PcVflZz+6kMhUfIwc5SY+poQRPnaf5V7qds6SUyUN3cVxEzuCab7QIoLOQ+DQ1wA==
+
 import-fresh@^3.2.1:
   version "3.3.0"
   resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b"
@@ -1230,6 +1268,13 @@ is-bigint@^1.0.1:
   dependencies:
     has-bigints "^1.0.1"
 
+is-binary-path@~2.1.0:
+  version "2.1.0"
+  resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09"
+  integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==
+  dependencies:
+    binary-extensions "^2.0.0"
+
 is-boolean-object@^1.1.0:
   version "1.1.2"
   resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.2.tgz#5c6dc200246dd9321ae4b885a114bb1f75f63719"
@@ -1281,7 +1326,7 @@ is-generator-function@^1.0.10:
   dependencies:
     has-tostringtag "^1.0.0"
 
-is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3:
+is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1:
   version "4.0.3"
   resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084"
   integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==
@@ -1588,6 +1633,11 @@ next@14.1.0:
     "@next/swc-win32-ia32-msvc" "14.1.0"
     "@next/swc-win32-x64-msvc" "14.1.0"
 
+normalize-path@^3.0.0, normalize-path@~3.0.0:
+  version "3.0.0"
+  resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65"
+  integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==
+
 object-assign@^4.1.1:
   version "4.1.1"
   resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863"
@@ -1736,7 +1786,7 @@ picocolors@^1.0.0:
   resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c"
   integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==
 
-picomatch@^2.3.1:
+picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1:
   version "2.3.1"
   resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42"
   integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==
@@ -1794,6 +1844,13 @@ react@^18:
   dependencies:
     loose-envify "^1.1.0"
 
+readdirp@~3.6.0:
+  version "3.6.0"
+  resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7"
+  integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==
+  dependencies:
+    picomatch "^2.2.1"
+
 reflect.getprototypeof@^1.0.4:
   version "1.0.4"
   resolved "https://registry.yarnpkg.com/reflect.getprototypeof/-/reflect.getprototypeof-1.0.4.tgz#aaccbf41aca3821b87bb71d9dcbc7ad0ba50a3f3"
@@ -1886,6 +1943,15 @@ safe-regex-test@^1.0.0:
     get-intrinsic "^1.2.2"
     is-regex "^1.1.4"
 
+sass@^1.70.0:
+  version "1.70.0"
+  resolved "https://registry.yarnpkg.com/sass/-/sass-1.70.0.tgz#761197419d97b5358cb25f9dd38c176a8a270a75"
+  integrity sha512-uUxNQ3zAHeAx5nRFskBnrWzDUJrrvpCPD5FNAoRvTi0WwremlheES3tg+56PaVtCs5QDRX5CBLxxKMDJMEa1WQ==
+  dependencies:
+    chokidar ">=3.0.0 <4.0.0"
+    immutable "^4.0.0"
+    source-map-js ">=0.6.2 <2.0.0"
+
 scheduler@^0.23.0:
   version "0.23.0"
   resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.0.tgz#ba8041afc3d30eb206a487b6b384002e4e61fdfe"
@@ -1956,7 +2022,7 @@ slash@^3.0.0:
   resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634"
   integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==
 
-source-map-js@^1.0.2:
+"source-map-js@>=0.6.2 <2.0.0", source-map-js@^1.0.2:
   version "1.0.2"
   resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c"
   integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==
@@ -1967,6 +2033,7 @@ streamsearch@^1.1.0:
   integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==
 
 "string-width-cjs@npm:string-width@^4.2.0", string-width@^4.1.0:
+  name string-width-cjs
   version "4.2.3"
   resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010"
   integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==