commit 544b0b92568d9fdc68f43bdbce9cb10db29f32f0
Author: root <root@hub.scroll.pub> Date: 2025-01-13 20:08:06 +0000 Subject: Initial commit diff --git a/body.html b/body.html new file mode 100644 index 0000000..80e9961 --- /dev/null +++ b/body.html @@ -0,0 +1,62 @@ +<header> + <nav> + <ul> + <li><a href="#home" class="active">Home</a></li> + <li><a href="#about">About</a></li> + <li><a href="#contact">Contact</a></li> + </ul> + </nav> +</header> + +<main> + <section id="home" class="hero"> + <div class="container"> + <h1>Hello, I'm <span class="highlight">Your Name</span></h1> + <p class="tagline">Welcome to my personal space on the web</p> + <div class="cta"> + <button class="primary-btn">Learn More</button> + </div> + </div> + </section> + + <section id="about"> + <div class="container"> + <h2>About Me</h2> + <div class="about-grid"> + <div class="about-text"> + <p>Share your story here. What drives you? What are you passionate about?</p> + </div> + <div class="about-image"> + <div class="image-placeholder"></div> + </div> + </div> + </div> + </section> + + <section id="contact"> + <div class="container"> + <h2>Get in Touch</h2> + <form id="contact-form"> + <div class="form-group"> + <label for="name">Name</label> + <input type="text" id="name" required> + </div> + <div class="form-group"> + <label for="email">Email</label> + <input type="email" id="email" required> + </div> + <div class="form-group"> + <label for="message">Message</label> + <textarea id="message" required></textarea> + </div> + <button type="submit" class="primary-btn">Send Message</button> + </form> + </div> + </section> +</main> + +<footer> + <div class="container"> + <p>Made with passion by Your Name</p> + </div> +</footer> \ No newline at end of file diff --git a/index.scroll b/index.scroll new file mode 100644 index 0000000..61cc9f1 --- /dev/null +++ b/index.scroll @@ -0,0 +1,8 @@ +buildHtml +baseUrl https://me.scroll.pub +metaTags +editButton /edit.html +title Welcome +style.css +body.html +script.js \ No newline at end of file diff --git a/prompt.json b/prompt.json new file mode 100644 index 0000000..6aaa2da --- /dev/null +++ b/prompt.json @@ -0,0 +1,20 @@ +{ + "id": "msg_01AeKdq763SnzQ4QLnTfAHJH", + "type": "message", + "role": "assistant", + "model": "claude-3-5-sonnet-20241022", + "content": [ + { + "type": "text", + "text": "I notice the request is incomplete (\"Personal website to\"). Without a more specific purpose, I'll create a minimal personal portfolio/landing page website.\n\nSuggested domain: me.scroll.pub (simple, personal, memorable)\n\n---domain---\nme.scroll.pub\n---index.scroll---\nbuildHtml\nbaseUrl https://me.scroll.pub\nmetaTags\neditButton /edit.html\ntitle Welcome\nstyle.css\nbody.html\nscript.js\n---body.html---\n<header>\n <nav>\n <ul>\n <li><a href=\"#home\" class=\"active\">Home</a></li>\n <li><a href=\"#about\">About</a></li>\n <li><a href=\"#contact\">Contact</a></li>\n </ul>\n </nav>\n</header>\n\n<main>\n <section id=\"home\" class=\"hero\">\n <div class=\"container\">\n <h1>Hello, I'm <span class=\"highlight\">Your Name</span></h1>\n <p class=\"tagline\">Welcome to my personal space on the web</p>\n <div class=\"cta\">\n <button class=\"primary-btn\">Learn More</button>\n </div>\n </div>\n </section>\n\n <section id=\"about\">\n <div class=\"container\">\n <h2>About Me</h2>\n <div class=\"about-grid\">\n <div class=\"about-text\">\n <p>Share your story here. What drives you? What are you passionate about?</p>\n </div>\n <div class=\"about-image\">\n <div class=\"image-placeholder\"></div>\n </div>\n </div>\n </div>\n </section>\n\n <section id=\"contact\">\n <div class=\"container\">\n <h2>Get in Touch</h2>\n <form id=\"contact-form\">\n <div class=\"form-group\">\n <label for=\"name\">Name</label>\n <input type=\"text\" id=\"name\" required>\n </div>\n <div class=\"form-group\">\n <label for=\"email\">Email</label>\n <input type=\"email\" id=\"email\" required>\n </div>\n <div class=\"form-group\">\n <label for=\"message\">Message</label>\n <textarea id=\"message\" required></textarea>\n </div>\n <button type=\"submit\" class=\"primary-btn\">Send Message</button>\n </form>\n </div>\n </section>\n</main>\n\n<footer>\n <div class=\"container\">\n <p>Made with passion by Your Name</p>\n </div>\n</footer>\n---style.css---\n:root {\n --primary-color: #2d46b9;\n --text-color: #333;\n --bg-color: #fff;\n --accent-color: #f0f4ff;\n --transition: all 0.3s ease;\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n}\n\nhtml {\n scroll-behavior: smooth;\n}\n\nbody {\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;\n line-height: 1.6;\n color: var(--text-color);\n}\n\n.container {\n max-width: 1200px;\n margin: 0 auto;\n padding: 0 2rem;\n}\n\n/* Header & Navigation */\nheader {\n position: fixed;\n width: 100%;\n background: rgba(255, 255, 255, 0.95);\n backdrop-filter: blur(10px);\n z-index: 1000;\n box-shadow: 0 2px 20px rgba(0,0,0,0.1);\n}\n\nnav ul {\n display: flex;\n justify-content: center;\n list-style: none;\n padding: 1.5rem 0;\n}\n\nnav a {\n color: var(--text-color);\n text-decoration: none;\n padding: 0.5rem 1.5rem;\n margin: 0 0.5rem;\n border-radius: 25px;\n transition: var(--transition);\n}\n\nnav a:hover, nav a.active {\n background: var(--accent-color);\n color: var(--primary-color);\n}\n\n/* Hero Section */\n.hero {\n min-height: 100vh;\n display: flex;\n align-items: center;\n background: linear-gradient(135deg, var(--accent-color) 0%, #fff 100%);\n}\n\n.hero h1 {\n font-size: 3.5rem;\n margin-bottom: 1rem;\n}\n\n.highlight {\n color: var(--primary-color);\n}\n\n.tagline {\n font-size: 1.5rem;\n margin-bottom: 2rem;\n}\n\n/* Buttons */\n.primary-btn {\n background: var(--primary-color);\n color: white;\n border: none;\n padding: 1rem 2rem;\n border-radius: 25px;\n cursor: pointer;\n transition: var(--transition);\n font-size: 1rem;\n}\n\n.primary-btn:hover {\n transform: translateY(-2px);\n box-shadow: 0 5px 15px rgba(45,70,185,0.3);\n}\n\n/* About Section */\n#about {\n padding: 6rem 0;\n}\n\n.about-grid {\n display: grid;\n grid-template-columns: 1fr 1fr;\n gap: 4rem;\n align-items: center;\n}\n\n.image-placeholder {\n width: 100%;\n padding-bottom: 100%;\n background: var(--accent-color);\n border-radius: 10px;\n transition: var(--transition);\n}\n\n.image-placeholder:hover {\n transform: rotate(5deg);\n}\n\n/* Contact Form */\n#contact {\n padding: 6rem 0;\n background: var(--accent-color);\n}\n\n.form-group {\n margin-bottom: 1.5rem;\n}\n\nlabel {\n display: block;\n margin-bottom: 0.5rem;\n}\n\ninput, textarea {\n width: 100%;\n padding: 0.8rem;\n border: 2px solid transparent;\n border-radius: 8px;\n transition: var(--transition);\n}\n\ninput:focus, textarea:focus {\n outline: none;\n border-color: var(--primary-color);\n}\n\ntextarea {\n height: 150px;\n resize: vertical;\n}\n\n/* Footer */\nfooter {\n padding: 2rem 0;\n text-align: center;\n background: var(--text-color);\n color: white;\n}\n\n/* Mobile Responsiveness */\n@media (max-width: 768px) {\n .hero h1 {\n font-size: 2.5rem;\n }\n \n .about-grid {\n grid-template-columns: 1fr;\n }\n \n nav ul {\n flex-direction: column;\n align-items: center;\n }\n \n nav a {\n display: block;\n margin: 0.5rem 0;\n }\n}\n---script.js---\ndocument.addEventListener('DOMContentLoaded', () => {\n // Smooth scrolling for navigation links\n document.querySelectorAll('a[href^=\"#\"]').forEach(anchor => {\n anchor.addEventListener('click', function (e) {\n e.preventDefault();\n const target = document.querySelector(this.getAttribute('href'));\n target.scrollIntoView({ behavior: 'smooth' });\n });\n });\n\n // Active navigation state\n const sections = document.querySelectorAll('section');\n const navLinks = document.querySelectorAll('nav a');\n\n window.addEventListener('scroll', () => {\n let current = '';\n sections.forEach(section => {\n const sectionTop = section.offsetTop;\n const sectionHeight = section.clientHeight;\n if (scrollY >= (sectionTop - sectionHeight/3)) {\n current = section.getAttribute('id');\n }\n });\n\n navLinks.forEach(link => {\n link.classList.remove('active');\n if (link.getAttribute('href').slice(1) === current) {\n link.classList.add('active');\n }\n });\n });\n\n // Form submission handler\n const contactForm = document.getElementById('contact-form');\n if (contactForm) {\n contactForm.addEventListener('submit', (e) => {\n e.preventDefault();\n // Add form handling logic here\n alert('Message sent! (Demo only)');\n contactForm.reset();\n });\n }\n});\n---end---\n\nThis creates a modern, responsive personal website with smooth animations, interactive elements, and a clean design. Key features:\n\n1. Fixed header with smooth-scrolling navigation\n2. Hero section with gradient background\n3. About section with interactive image placeholder\n4. Contact form with styled inputs\n5. Responsive design that works on all devices\n6. Interactive hover effects and animations\n7. Active state tracking for navigation\n8. Form handling (demo)\n\nThe CSS uses modern features like:\n- CSS Variables\n- Flexbox and Grid\n- Smooth transitions\n- Backdrop filters\n- Modern box-shadow effects\n- Gradient backgrounds\n\nThe JavaScript handles:\n- Smooth scrolling\n- Navigation active states\n- Form submission\n- Interactive elements\n\nYou can customize the content, colors, and styling by modifying the CSS variables and HTML content." + } + ], + "stop_reason": "end_turn", + "stop_sequence": null, + "usage": { + "input_tokens": 273, + "cache_creation_input_tokens": 0, + "cache_read_input_tokens": 0, + "output_tokens": 2399 + } +} \ No newline at end of file diff --git a/readme.scroll b/readme.scroll new file mode 100644 index 0000000..54cb0ae --- /dev/null +++ b/readme.scroll @@ -0,0 +1,3 @@ +# me.scroll.pub + +website generated by Claude from prompt: Personal website to \ No newline at end of file diff --git a/script.js b/script.js new file mode 100644 index 0000000..fce9338 --- /dev/null +++ b/script.js @@ -0,0 +1,43 @@ +document.addEventListener('DOMContentLoaded', () => { + // Smooth scrolling for navigation links + document.querySelectorAll('a[href^="#"]').forEach(anchor => { + anchor.addEventListener('click', function (e) { + e.preventDefault(); + const target = document.querySelector(this.getAttribute('href')); + target.scrollIntoView({ behavior: 'smooth' }); + }); + }); + + // Active navigation state + const sections = document.querySelectorAll('section'); + const navLinks = document.querySelectorAll('nav a'); + + window.addEventListener('scroll', () => { + let current = ''; + sections.forEach(section => { + const sectionTop = section.offsetTop; + const sectionHeight = section.clientHeight; + if (scrollY >= (sectionTop - sectionHeight/3)) { + current = section.getAttribute('id'); + } + }); + + navLinks.forEach(link => { + link.classList.remove('active'); + if (link.getAttribute('href').slice(1) === current) { + link.classList.add('active'); + } + }); + }); + + // Form submission handler + const contactForm = document.getElementById('contact-form'); + if (contactForm) { + contactForm.addEventListener('submit', (e) => { + e.preventDefault(); + // Add form handling logic here + alert('Message sent! (Demo only)'); + contactForm.reset(); + }); + } +}); \ No newline at end of file diff --git a/style.css b/style.css new file mode 100644 index 0000000..d014c25 --- /dev/null +++ b/style.css @@ -0,0 +1,185 @@ +:root { + --primary-color: #2d46b9; + --text-color: #333; + --bg-color: #fff; + --accent-color: #f0f4ff; + --transition: all 0.3s ease; +} + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +html { + scroll-behavior: smooth; +} + +body { + font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; + line-height: 1.6; + color: var(--text-color); +} + +.container { + max-width: 1200px; + margin: 0 auto; + padding: 0 2rem; +} + +/* Header & Navigation */ +header { + position: fixed; + width: 100%; + background: rgba(255, 255, 255, 0.95); + backdrop-filter: blur(10px); + z-index: 1000; + box-shadow: 0 2px 20px rgba(0,0,0,0.1); +} + +nav ul { + display: flex; + justify-content: center; + list-style: none; + padding: 1.5rem 0; +} + +nav a { + color: var(--text-color); + text-decoration: none; + padding: 0.5rem 1.5rem; + margin: 0 0.5rem; + border-radius: 25px; + transition: var(--transition); +} + +nav a:hover, nav a.active { + background: var(--accent-color); + color: var(--primary-color); +} + +/* Hero Section */ +.hero { + min-height: 100vh; + display: flex; + align-items: center; + background: linear-gradient(135deg, var(--accent-color) 0%, #fff 100%); +} + +.hero h1 { + font-size: 3.5rem; + margin-bottom: 1rem; +} + +.highlight { + color: var(--primary-color); +} + +.tagline { + font-size: 1.5rem; + margin-bottom: 2rem; +} + +/* Buttons */ +.primary-btn { + background: var(--primary-color); + color: white; + border: none; + padding: 1rem 2rem; + border-radius: 25px; + cursor: pointer; + transition: var(--transition); + font-size: 1rem; +} + +.primary-btn:hover { + transform: translateY(-2px); + box-shadow: 0 5px 15px rgba(45,70,185,0.3); +} + +/* About Section */ +#about { + padding: 6rem 0; +} + +.about-grid { + display: grid; + grid-template-columns: 1fr 1fr; + gap: 4rem; + align-items: center; +} + +.image-placeholder { + width: 100%; + padding-bottom: 100%; + background: var(--accent-color); + border-radius: 10px; + transition: var(--transition); +} + +.image-placeholder:hover { + transform: rotate(5deg); +} + +/* Contact Form */ +#contact { + padding: 6rem 0; + background: var(--accent-color); +} + +.form-group { + margin-bottom: 1.5rem; +} + +label { + display: block; + margin-bottom: 0.5rem; +} + +input, textarea { + width: 100%; + padding: 0.8rem; + border: 2px solid transparent; + border-radius: 8px; + transition: var(--transition); +} + +input:focus, textarea:focus { + outline: none; + border-color: var(--primary-color); +} + +textarea { + height: 150px; + resize: vertical; +} + +/* Footer */ +footer { + padding: 2rem 0; + text-align: center; + background: var(--text-color); + color: white; +} + +/* Mobile Responsiveness */ +@media (max-width: 768px) { + .hero h1 { + font-size: 2.5rem; + } + + .about-grid { + grid-template-columns: 1fr; + } + + nav ul { + flex-direction: column; + align-items: center; + } + + nav a { + display: block; + margin: 0.5rem 0; + } +} \ No newline at end of file