diff --git a/Week-1/Task-1/r3f/src/App.jsx b/Week-1/Task-1/r3f/src/App.jsx
index e69de29..e3242ed 100644
--- a/Week-1/Task-1/r3f/src/App.jsx
+++ b/Week-1/Task-1/r3f/src/App.jsx
@@ -0,0 +1,16 @@
+import { Canvas } from '@react-three/fiber'
+import Box from './components/Box'
+
+function App() {
+ return (
+
+ )
+}
+
+export default App;
\ No newline at end of file
diff --git a/Week-1/Task-1/r3f/src/components/Box.jsx b/Week-1/Task-1/r3f/src/components/Box.jsx
new file mode 100644
index 0000000..742eef9
--- /dev/null
+++ b/Week-1/Task-1/r3f/src/components/Box.jsx
@@ -0,0 +1,24 @@
+import { useRef, useState } from 'react'
+import { useFrame } from '@react-three/fiber'
+
+function Box() {
+ const meshRef = useRef()
+ const [color, setColor] = useState('red')
+ useFrame(() => {
+ meshRef.current.rotation.x += 0.01
+ meshRef.current.rotation.y += 0.01
+ })
+
+ return (
+ setColor(prev => (prev === 'pink' ? 'yellow' : 'pink'))}
+ rotation={[0.4, 0.4, 0]}
+ >
+
+
+
+ )
+}
+
+export default Box
diff --git a/Week-1/Task-1/r3f/src/index.css b/Week-1/Task-1/r3f/src/index.css
index 2c84af0..e60751d 100644
--- a/Week-1/Task-1/r3f/src/index.css
+++ b/Week-1/Task-1/r3f/src/index.css
@@ -1,111 +1,12 @@
-:root {
- --text: #6b6375;
- --text-h: #08060d;
- --bg: #fff;
- --border: #e5e4e7;
- --code-bg: #f4f3ec;
- --accent: #aa3bff;
- --accent-bg: rgba(170, 59, 255, 0.1);
- --accent-border: rgba(170, 59, 255, 0.5);
- --social-bg: rgba(244, 243, 236, 0.5);
- --shadow:
- rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px;
-
- --sans: system-ui, 'Segoe UI', Roboto, sans-serif;
- --heading: system-ui, 'Segoe UI', Roboto, sans-serif;
- --mono: ui-monospace, Consolas, monospace;
-
- font: 18px/145% var(--sans);
- letter-spacing: 0.18px;
- color-scheme: light dark;
- color: var(--text);
- background: var(--bg);
- font-synthesis: none;
- text-rendering: optimizeLegibility;
- -webkit-font-smoothing: antialiased;
- -moz-osx-font-smoothing: grayscale;
-
- @media (max-width: 1024px) {
- font-size: 16px;
- }
-}
-
-@media (prefers-color-scheme: dark) {
- :root {
- --text: #9ca3af;
- --text-h: #f3f4f6;
- --bg: #16171d;
- --border: #2e303a;
- --code-bg: #1f2028;
- --accent: #c084fc;
- --accent-bg: rgba(192, 132, 252, 0.15);
- --accent-border: rgba(192, 132, 252, 0.5);
- --social-bg: rgba(47, 48, 58, 0.5);
- --shadow:
- rgba(0, 0, 0, 0.4) 0 10px 15px -3px, rgba(0, 0, 0, 0.25) 0 4px 6px -2px;
- }
-
- #social .button-icon {
- filter: invert(1) brightness(2);
- }
-}
-
-body {
- margin: 0;
-}
-
-#root {
- width: 1126px;
- max-width: 100%;
- margin: 0 auto;
- text-align: center;
- border-inline: 1px solid var(--border);
- min-height: 100svh;
- display: flex;
- flex-direction: column;
+* {
box-sizing: border-box;
}
-h1,
-h2 {
- font-family: var(--heading);
- font-weight: 500;
- color: var(--text-h);
-}
-
-h1 {
- font-size: 56px;
- letter-spacing: -1.68px;
- margin: 32px 0;
- @media (max-width: 1024px) {
- font-size: 36px;
- margin: 20px 0;
- }
-}
-h2 {
- font-size: 24px;
- line-height: 118%;
- letter-spacing: -0.24px;
- margin: 0 0 8px;
- @media (max-width: 1024px) {
- font-size: 20px;
- }
-}
-p {
+body, html, #root {
margin: 0;
-}
-
-code,
-.counter {
- font-family: var(--mono);
- display: inline-flex;
- border-radius: 4px;
- color: var(--text-h);
-}
-
-code {
- font-size: 15px;
- line-height: 135%;
- padding: 4px 8px;
- background: var(--code-bg);
+ padding: 0;
+ width: 100%;
+ height: 100%;
+ overflow: hidden;
+ background-color: #111;
}