commit 179c8b841d5f2397181c6f8ac1bc6d3aef9a413c
Author: root <root@hub.scroll.pub> Date: 2025-01-07 03:30:16 +0000 Subject: Initial commit diff --git a/body.html b/body.html new file mode 100644 index 0000000..faca3a5 --- /dev/null +++ b/body.html @@ -0,0 +1,57 @@ +<header> + <nav> + <div class="logo">TAAT</div> + <div class="menu-toggle" aria-label="Toggle menu"> + <span></span><span></span><span></span> + </div> + <ul class="nav-links"> + <li><a href="#mirror">Mirror</a></li> + <li><a href="#reflect">Reflect</a></li> + <li><a href="#contact">Contact</a></li> + </ul> + </nav> +</header> + +<main> + <section class="hero" aria-label="Hero section"> + <div class="mirror-text"> + <span>T</span> + <span>A</span> + <span>A</span> + <span>T</span> + </div> + <h1>Where symmetry meets design</h1> + </section> + + <section id="mirror" class="content-section"> + <h2>Mirror Effect</h2> + <div class="mirror-container"> + <div class="mirror-item"> + <div class="reflection-text">REFLECT</div> + </div> + </div> + </section> + + <section id="reflect" class="content-section"> + <div class="grid"> + <div class="grid-item"></div> + <div class="grid-item"></div> + <div class="grid-item"></div> + <div class="grid-item"></div> + </div> + </section> + + <section id="contact" class="content-section"> + <h2>Connect</h2> + <form class="contact-form"> + <input type="text" placeholder="Name" aria-label="Name"> + <input type="email" placeholder="Email" aria-label="Email"> + <textarea placeholder="Message" aria-label="Message"></textarea> + <button type="submit">Send</button> + </form> + </section> +</main> + +<footer> + <p>TAAT | Symmetry in Design</p> +</footer> diff --git a/index.scroll b/index.scroll new file mode 100644 index 0000000..4b65372 --- /dev/null +++ b/index.scroll @@ -0,0 +1,8 @@ +buildHtml +baseUrl https://taat.scroll.pub +metaTags +editButton /edit.html +title TAAT | Symmetry in Design +style.css +body.html +script.js diff --git a/prompt.json b/prompt.json new file mode 100644 index 0000000..b6e7e61 --- /dev/null +++ b/prompt.json @@ -0,0 +1,20 @@ +{ + "id": "msg_019W1DAcPMuFGqP2dNLy5cF9", + "type": "message", + "role": "assistant", + "model": "claude-3-5-sonnet-20241022", + "content": [ + { + "type": "text", + "text": "Let me create a website for \"taat\" - I'll interpret this as a minimalist palindrome concept that could work well for a modern, artistic website.\n\n---domain---\ntaat.scroll.pub\n\n---index.scroll---\nbuildHtml\nbaseUrl https://taat.scroll.pub\nmetaTags\neditButton /edit.html\ntitle TAAT | Symmetry in Design\nstyle.css\nbody.html\nscript.js\n\n---body.html---\n<header>\n <nav>\n <div class=\"logo\">TAAT</div>\n <div class=\"menu-toggle\" aria-label=\"Toggle menu\">\n <span></span><span></span><span></span>\n </div>\n <ul class=\"nav-links\">\n <li><a href=\"#mirror\">Mirror</a></li>\n <li><a href=\"#reflect\">Reflect</a></li>\n <li><a href=\"#contact\">Contact</a></li>\n </ul>\n </nav>\n</header>\n\n<main>\n <section class=\"hero\" aria-label=\"Hero section\">\n <div class=\"mirror-text\">\n <span>T</span>\n <span>A</span>\n <span>A</span>\n <span>T</span>\n </div>\n <h1>Where symmetry meets design</h1>\n </section>\n\n <section id=\"mirror\" class=\"content-section\">\n <h2>Mirror Effect</h2>\n <div class=\"mirror-container\">\n <div class=\"mirror-item\">\n <div class=\"reflection-text\">REFLECT</div>\n </div>\n </div>\n </section>\n\n <section id=\"reflect\" class=\"content-section\">\n <div class=\"grid\">\n <div class=\"grid-item\"></div>\n <div class=\"grid-item\"></div>\n <div class=\"grid-item\"></div>\n <div class=\"grid-item\"></div>\n </div>\n </section>\n\n <section id=\"contact\" class=\"content-section\">\n <h2>Connect</h2>\n <form class=\"contact-form\">\n <input type=\"text\" placeholder=\"Name\" aria-label=\"Name\">\n <input type=\"email\" placeholder=\"Email\" aria-label=\"Email\">\n <textarea placeholder=\"Message\" aria-label=\"Message\"></textarea>\n <button type=\"submit\">Send</button>\n </form>\n </section>\n</main>\n\n<footer>\n <p>TAAT | Symmetry in Design</p>\n</footer>\n\n---style.css---\n:root {\n --primary: #1a1a1a;\n --secondary: #f0f0f0;\n --accent: #ff3366;\n --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n}\n\nbody {\n font-family: 'Inter', sans-serif;\n line-height: 1.6;\n color: var(--primary);\n background: var(--secondary);\n}\n\n/* Header & Navigation */\nheader {\n position: fixed;\n width: 100%;\n z-index: 1000;\n background: rgba(255, 255, 255, 0.95);\n backdrop-filter: blur(10px);\n}\n\nnav {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 1rem 2rem;\n max-width: 1200px;\n margin: 0 auto;\n}\n\n.logo {\n font-size: 2rem;\n font-weight: 700;\n letter-spacing: 0.2em;\n}\n\n.nav-links {\n display: flex;\n gap: 2rem;\n list-style: none;\n}\n\n.nav-links a {\n text-decoration: none;\n color: var(--primary);\n position: relative;\n}\n\n.nav-links a::after {\n content: '';\n position: absolute;\n width: 0;\n height: 2px;\n bottom: -4px;\n left: 0;\n background: var(--accent);\n transition: var(--transition);\n}\n\n.nav-links a:hover::after {\n width: 100%;\n}\n\n/* Hero Section */\n.hero {\n height: 100vh;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n text-align: center;\n padding: 2rem;\n}\n\n.mirror-text {\n font-size: 8vw;\n font-weight: 900;\n display: flex;\n gap: 0.5rem;\n}\n\n.mirror-text span {\n display: inline-block;\n animation: float 3s ease-in-out infinite;\n}\n\n.mirror-text span:nth-child(2) { animation-delay: 0.2s; }\n.mirror-text span:nth-child(3) { animation-delay: 0.4s; }\n.mirror-text span:nth-child(4) { animation-delay: 0.6s; }\n\n@keyframes float {\n 0%, 100% { transform: translateY(0); }\n 50% { transform: translateY(-20px); }\n}\n\n/* Content Sections */\n.content-section {\n padding: 6rem 2rem;\n max-width: 1200px;\n margin: 0 auto;\n}\n\n.mirror-container {\n height: 400px;\n position: relative;\n overflow: hidden;\n background: linear-gradient(45deg, var(--primary), var(--accent));\n border-radius: 1rem;\n}\n\n.reflection-text {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n font-size: 4rem;\n color: white;\n text-shadow: 0 0 20px rgba(255,255,255,0.5);\n}\n\n.grid {\n display: grid;\n grid-template-columns: repeat(2, 1fr);\n gap: 2rem;\n padding: 2rem 0;\n}\n\n.grid-item {\n aspect-ratio: 1;\n background: var(--primary);\n border-radius: 1rem;\n transition: var(--transition);\n}\n\n.grid-item:hover {\n transform: scale(1.05);\n background: var(--accent);\n}\n\n/* Contact Form */\n.contact-form {\n display: flex;\n flex-direction: column;\n gap: 1rem;\n max-width: 600px;\n margin: 0 auto;\n}\n\n.contact-form input,\n.contact-form textarea {\n padding: 1rem;\n border: 2px solid var(--primary);\n border-radius: 0.5rem;\n background: transparent;\n transition: var(--transition);\n}\n\n.contact-form input:focus,\n.contact-form textarea:focus {\n outline: none;\n border-color: var(--accent);\n}\n\n.contact-form button {\n padding: 1rem 2rem;\n background: var(--primary);\n color: var(--secondary);\n border: none;\n border-radius: 0.5rem;\n cursor: pointer;\n transition: var(--transition);\n}\n\n.contact-form button:hover {\n background: var(--accent);\n transform: translateY(-2px);\n}\n\n/* Footer */\nfooter {\n padding: 2rem;\n text-align: center;\n background: var(--primary);\n color: var(--secondary);\n}\n\n/* Mobile Responsiveness */\n.menu-toggle {\n display: none;\n flex-direction: column;\n gap: 6px;\n cursor: pointer;\n}\n\n.menu-toggle span {\n width: 30px;\n height: 3px;\n background: var(--primary);\n transition: var(--transition);\n}\n\n@media (max-width: 768px) {\n .menu-toggle {\n display: flex;\n }\n\n .nav-links {\n display: none;\n position: absolute;\n top: 100%;\n left: 0;\n width: 100%;\n background: white;\n flex-direction: column;\n text-align: center;\n padding: 1rem 0;\n }\n\n .nav-links.active {\n display: flex;\n }\n\n .mirror-text {\n font-size: 12vw;\n }\n\n .grid {\n grid-template-columns: 1fr;\n }\n}\n\n---script.js---\ndocument.addEventListener('DOMContentLoaded', () => {\n // Mobile menu toggle\n const menuToggle = document.querySelector('.menu-toggle');\n const navLinks = document.querySelector('.nav-links');\n\n menuToggle.addEventListener('click', () => {\n navLinks.classList.toggle('active');\n menuToggle.classList.toggle('active');\n });\n\n // Smooth scroll 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 if (target) {\n target.scrollIntoView({\n behavior: 'smooth'\n });\n // Close mobile menu if open\n navLinks.classList.remove('active');\n menuToggle.classList.remove('active');\n }\n });\n });\n\n // Form submission handling\n const form = document.querySelector('.contact-form');\n if (form) {\n form.addEventListener('submit', (e) => {\n e.preventDefault();\n // Add form submission logic here\n const formElements = form.elements;\n let isValid = true;\n\n for (let element of formElements) {\n if (element.type !== 'submit' && !element.value.trim()) {\n isValid = false;\n element.style.borderColor = 'red';\n } else {\n element.style.borderColor = '';\n }\n }\n\n if (isValid) {\n // Simulated success message\n const button = form.querySelector('button');\n const originalText = button.textContent;\n button.textContent = 'Sent!';\n button.style.background = '#28a745';\n setTimeout(() => {\n button.textContent = originalText;\n button.style.background = '';\n form.reset();\n }, 2000);\n }\n });\n }\n\n // Animation on scroll\n const observerOptions = {\n threshold: 0.1\n };\n\n const observer = new IntersectionObserver((entries) => {\n entries.forEach(entry => {\n if (entry.isIntersecting) {\n entry.target.style.opacity = '1';\n entry.target.style.transform = 'translateY(0)';\n }\n });\n }, observerOptions);\n\n document.querySelectorAll('.content-section').forEach(section => {\n section.style.opacity = '0';\n section.style.transform = 'translateY(20px)';\n section.style.transition = 'all 0.6s ease-out';\n observer.observe(section);\n });\n});\n\n---end---\n\nThis website features:\n1. A palindrome-inspired design (TAAT reads the same forward and backward)\n2. Smooth animations and transitions\n3. Responsive layout with mobile menu\n4. Interactive hover effects\n5. Form validation\n6. Intersection Observer for scroll animations\n7. Clean, semantic HTML structure\n8. Accessible navigation and form elements\n9. Modern CSS with variables and flexbox/grid\n10. Performance-optimized animations and transitions\n\nThe design emphasizes symmetry and minimalism while maintaining visual interest through animations and interactive elements. The color scheme is bold yet professional, with careful attention to contrast and readability." + } + ], + "stop_reason": "end_turn", + "stop_sequence": null, + "usage": { + "input_tokens": 272, + "cache_creation_input_tokens": 0, + "cache_read_input_tokens": 0, + "output_tokens": 3010 + } +} \ No newline at end of file diff --git a/readme.scroll b/readme.scroll new file mode 100644 index 0000000..33c8ff0 --- /dev/null +++ b/readme.scroll @@ -0,0 +1,2 @@ +# taat.scroll.pub +Website generated by Claude from prompt: taat \ No newline at end of file diff --git a/script.js b/script.js new file mode 100644 index 0000000..0b8c6d8 --- /dev/null +++ b/script.js @@ -0,0 +1,80 @@ +document.addEventListener('DOMContentLoaded', () => { + // Mobile menu toggle + const menuToggle = document.querySelector('.menu-toggle'); + const navLinks = document.querySelector('.nav-links'); + + menuToggle.addEventListener('click', () => { + navLinks.classList.toggle('active'); + menuToggle.classList.toggle('active'); + }); + + // Smooth scroll for navigation links + document.querySelectorAll('a[href^="#"]').forEach(anchor => { + anchor.addEventListener('click', function (e) { + e.preventDefault(); + const target = document.querySelector(this.getAttribute('href')); + if (target) { + target.scrollIntoView({ + behavior: 'smooth' + }); + // Close mobile menu if open + navLinks.classList.remove('active'); + menuToggle.classList.remove('active'); + } + }); + }); + + // Form submission handling + const form = document.querySelector('.contact-form'); + if (form) { + form.addEventListener('submit', (e) => { + e.preventDefault(); + // Add form submission logic here + const formElements = form.elements; + let isValid = true; + + for (let element of formElements) { + if (element.type !== 'submit' && !element.value.trim()) { + isValid = false; + element.style.borderColor = 'red'; + } else { + element.style.borderColor = ''; + } + } + + if (isValid) { + // Simulated success message + const button = form.querySelector('button'); + const originalText = button.textContent; + button.textContent = 'Sent!'; + button.style.background = '#28a745'; + setTimeout(() => { + button.textContent = originalText; + button.style.background = ''; + form.reset(); + }, 2000); + } + }); + } + + // Animation on scroll + const observerOptions = { + threshold: 0.1 + }; + + const observer = new IntersectionObserver((entries) => { + entries.forEach(entry => { + if (entry.isIntersecting) { + entry.target.style.opacity = '1'; + entry.target.style.transform = 'translateY(0)'; + } + }); + }, observerOptions); + + document.querySelectorAll('.content-section').forEach(section => { + section.style.opacity = '0'; + section.style.transform = 'translateY(20px)'; + section.style.transition = 'all 0.6s ease-out'; + observer.observe(section); + }); +}); diff --git a/style.css b/style.css new file mode 100644 index 0000000..e235516 --- /dev/null +++ b/style.css @@ -0,0 +1,238 @@ +:root { + --primary: #1a1a1a; + --secondary: #f0f0f0; + --accent: #ff3366; + --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); +} + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +body { + font-family: 'Inter', sans-serif; + line-height: 1.6; + color: var(--primary); + background: var(--secondary); +} + +/* Header & Navigation */ +header { + position: fixed; + width: 100%; + z-index: 1000; + background: rgba(255, 255, 255, 0.95); + backdrop-filter: blur(10px); +} + +nav { + display: flex; + justify-content: space-between; + align-items: center; + padding: 1rem 2rem; + max-width: 1200px; + margin: 0 auto; +} + +.logo { + font-size: 2rem; + font-weight: 700; + letter-spacing: 0.2em; +} + +.nav-links { + display: flex; + gap: 2rem; + list-style: none; +} + +.nav-links a { + text-decoration: none; + color: var(--primary); + position: relative; +} + +.nav-links a::after { + content: ''; + position: absolute; + width: 0; + height: 2px; + bottom: -4px; + left: 0; + background: var(--accent); + transition: var(--transition); +} + +.nav-links a:hover::after { + width: 100%; +} + +/* Hero Section */ +.hero { + height: 100vh; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; + text-align: center; + padding: 2rem; +} + +.mirror-text { + font-size: 8vw; + font-weight: 900; + display: flex; + gap: 0.5rem; +} + +.mirror-text span { + display: inline-block; + animation: float 3s ease-in-out infinite; +} + +.mirror-text span:nth-child(2) { animation-delay: 0.2s; } +.mirror-text span:nth-child(3) { animation-delay: 0.4s; } +.mirror-text span:nth-child(4) { animation-delay: 0.6s; } + +@keyframes float { + 0%, 100% { transform: translateY(0); } + 50% { transform: translateY(-20px); } +} + +/* Content Sections */ +.content-section { + padding: 6rem 2rem; + max-width: 1200px; + margin: 0 auto; +} + +.mirror-container { + height: 400px; + position: relative; + overflow: hidden; + background: linear-gradient(45deg, var(--primary), var(--accent)); + border-radius: 1rem; +} + +.reflection-text { + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + font-size: 4rem; + color: white; + text-shadow: 0 0 20px rgba(255,255,255,0.5); +} + +.grid { + display: grid; + grid-template-columns: repeat(2, 1fr); + gap: 2rem; + padding: 2rem 0; +} + +.grid-item { + aspect-ratio: 1; + background: var(--primary); + border-radius: 1rem; + transition: var(--transition); +} + +.grid-item:hover { + transform: scale(1.05); + background: var(--accent); +} + +/* Contact Form */ +.contact-form { + display: flex; + flex-direction: column; + gap: 1rem; + max-width: 600px; + margin: 0 auto; +} + +.contact-form input, +.contact-form textarea { + padding: 1rem; + border: 2px solid var(--primary); + border-radius: 0.5rem; + background: transparent; + transition: var(--transition); +} + +.contact-form input:focus, +.contact-form textarea:focus { + outline: none; + border-color: var(--accent); +} + +.contact-form button { + padding: 1rem 2rem; + background: var(--primary); + color: var(--secondary); + border: none; + border-radius: 0.5rem; + cursor: pointer; + transition: var(--transition); +} + +.contact-form button:hover { + background: var(--accent); + transform: translateY(-2px); +} + +/* Footer */ +footer { + padding: 2rem; + text-align: center; + background: var(--primary); + color: var(--secondary); +} + +/* Mobile Responsiveness */ +.menu-toggle { + display: none; + flex-direction: column; + gap: 6px; + cursor: pointer; +} + +.menu-toggle span { + width: 30px; + height: 3px; + background: var(--primary); + transition: var(--transition); +} + +@media (max-width: 768px) { + .menu-toggle { + display: flex; + } + + .nav-links { + display: none; + position: absolute; + top: 100%; + left: 0; + width: 100%; + background: white; + flex-direction: column; + text-align: center; + padding: 1rem 0; + } + + .nav-links.active { + display: flex; + } + + .mirror-text { + font-size: 12vw; + } + + .grid { + grid-template-columns: 1fr; + } +}